/*
Theme Name: NON-NEUTRAL
Theme URI: https://non-neutral.org
Author: NON-NEUTRAL Collective
Author URI: https://non-neutral.org
Description: A radical media and organizing platform led by exiled Global South activists. Built for resistance, not neutrality.
Version: 2.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: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: non-neutral
Tags: activist, political, dark, bold, radical
*/

/* ============================================================
   GOOGLE FONTS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=IBM+Plex+Mono:wght@400;700&family=IBM+Plex+Sans:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400&display=swap');

/* ============================================================
   CSS VARIABLES
   ============================================================ */
:root {
    --red:       #ff2020;
    --red-dim:   #cc1a1a;
    --black:     #0a0a0a;
    --black-2:   #111111;
    --black-3:   #1a1a1a;
    --black-4:   #222222;
    --off-white: #e8e8e8;
    --grey:      #888888;
    --grey-dim:  #444444;
    --mono:      'IBM Plex Mono', monospace;
    --display:   'Bebas Neue', sans-serif;
    --body:      'IBM Plex Sans', sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--body);
    background: var(--black);
    color: var(--off-white);
    line-height: 1.7;
    overflow-x: hidden;
    font-size: 16px;
}
img { display:block; max-width:100%; height:auto; }
a { color:var(--red); text-decoration:none; transition:color .25s; }
a:hover { color:#ff6060; }
ul, ol { list-style:none; }
p { margin-bottom:1.4rem; }
p:last-child { margin-bottom:0; }
.screen-reader-text {
    position:absolute;
    width:1px;
    height:1px;
    padding:0;
    margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
}

/* ============================================================
   NOISE OVERLAY
   ============================================================ */
body::before {
    content:'';
    position:fixed; inset:0;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
    pointer-events:none; z-index:9999; opacity:.5;
}

/* ============================================================
   SCAN LINES
   ============================================================ */
body::after {
    content:'';
    position:fixed; inset:0;
    background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.07) 3px,rgba(0,0,0,.07) 4px);
    pointer-events:none; z-index:9998;
}

/* ============================================================
   KEYFRAME ANIMATIONS
   ============================================================ */
@keyframes glitch {
    0%,100% { clip-path:inset(0 0 100% 0); }
    10%  { clip-path:inset(10% 0 85% 0); transform:translateX(-4px); }
    20%  { clip-path:inset(40% 0 50% 0); transform:translateX(4px); }
    30%  { clip-path:inset(60% 0 30% 0); transform:translateX(-2px); }
    40%  { clip-path:inset(80% 0 10% 0); transform:translateX(2px); }
    50%  { clip-path:inset(0 0 0 0);     transform:translateX(0); }
}
@keyframes fadeUp {
    from { opacity:0; transform:translateY(30px); }
    to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
    from { opacity:0; } to { opacity:1; }
}
@keyframes ticker {
    0%   { transform:translateX(0); }
    100% { transform:translateX(-50%); }
}
@keyframes redPulse {
    0%,100% { box-shadow:0 0 0 0 rgba(255,32,32,0); }
    50%     { box-shadow:0 0 24px 4px rgba(255,32,32,.25); }
}

/* ============================================================
   CONTAINER
   ============================================================ */
.wrap, .container { max-width:1200px; margin:0 auto; padding:0 2rem; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal {
    opacity:0; transform:translateY(28px);
    transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible { opacity:1; transform:none; }

/* ============================================================
   TICKER BAR
   ============================================================ */
.nn-ticker {
    background:var(--red); color:#fff;
    padding:.55rem 0; overflow:hidden; white-space:nowrap;
    font-family:var(--mono); font-size:.75rem; letter-spacing:.08em;
    position:relative; z-index:100;
}
.nn-ticker-inner {
    display:inline-flex; gap:0;
    animation:ticker 28s linear infinite;
}
.nn-ticker-inner span { padding:0 3rem; }
.nn-ticker-inner span::before { content:"// "; }

/* ============================================================
   NAVIGATION
   ============================================================ */
#site-header {
    background:var(--black);
    border-bottom:2px solid var(--black-4);
    position:sticky; top:0; z-index:500;
    transition:border-color .3s;
}
#site-header.scrolled { border-bottom-color:var(--red); }

#site-header .header-inner {
    display:flex; align-items:center; justify-content:space-between;
    padding:1.1rem 2rem; max-width:1200px; margin:0 auto;
}

.site-logo a {
    font-family:var(--display); font-size:2rem;
    letter-spacing:.2em; color:#fff; text-decoration:none; position:relative;
}
.site-logo a::after {
    content:''; position:absolute; bottom:-2px; left:0; right:0;
    height:2px; background:var(--red);
    transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.site-logo a:hover { color:#fff; }
.site-logo a:hover::after { transform:scaleX(1); }

#primary-navigation ul { display:flex; gap:2.5rem; list-style:none; align-items:center; }
#primary-navigation ul li a {
    font-family:var(--mono); font-size:.8rem; letter-spacing:.12em;
    color:var(--grey); text-transform:uppercase;
    padding:.3rem 0; border-bottom:1px solid transparent;
    transition:color .25s, border-color .25s;
}
#primary-navigation ul li a:hover,
#primary-navigation ul li.current-menu-item a { color:#fff; border-bottom-color:var(--red); }

.menu-toggle {
    display:none; background:none; border:1.5px solid var(--grey-dim);
    color:#fff; padding:.5rem 1rem; font-family:var(--mono);
    font-size:.75rem; letter-spacing:.1em; cursor:pointer; text-transform:uppercase;
    transition:border-color .25s, background .25s;
}
.menu-toggle:hover { background:var(--red); border-color:var(--red); }

/* ============================================================
   HERO
   ============================================================ */
.hero-section {
    background:var(--black); min-height:100vh;
    display:flex; flex-direction:column; justify-content:center;
    position:relative; overflow:hidden; padding:6rem 2rem 5rem;
}
.hero-section::before {
    content:''; position:absolute; top:0; bottom:0; left:50%;
    width:1px;
    background:linear-gradient(to bottom,transparent,var(--red) 30%,var(--red) 70%,transparent);
    opacity:.1; pointer-events:none;
}
.hero-grid-bg {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,32,32,.04) 1px,transparent 1px),
        linear-gradient(90deg,rgba(255,32,32,.04) 1px,transparent 1px);
    background-size:80px 80px;
    mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 30%,transparent 100%);
    pointer-events:none;
}
.hero-content { position:relative; z-index:2; max-width:1200px; margin:0 auto; width:100%; }

.hero-eyebrow {
    font-family:var(--mono); font-size:.75rem; letter-spacing:.2em;
    color:var(--red); text-transform:uppercase; margin-bottom:2rem;
    display:flex; align-items:center; gap:1rem;
    animation:fadeIn .8s ease both;
}
.hero-eyebrow::before { content:''; display:block; width:40px; height:1px; background:var(--red); }

.hero-title {
    font-family:var(--display);
    font-size:clamp(5rem,16vw,14rem);
    line-height:.9; letter-spacing:-.01em; color:#fff; position:relative;
    animation:fadeUp .9s ease .1s both;
}
.hero-title .ghost {
    position:absolute; top:0; left:0;
    color:transparent; -webkit-text-stroke:1px rgba(255,32,32,.2);
    user-select:none; pointer-events:none;
    animation:glitch 4s ease-in-out 2s infinite;
}
.hero-dash { display:block; width:120px; height:3px; background:var(--red); margin:2rem 0; animation:fadeIn .8s ease .3s both; }
.hero-tagline { font-size:clamp(1.2rem,3vw,1.8rem); font-weight:300; font-style:italic; color:var(--grey); margin-bottom:1rem; max-width:700px; animation:fadeUp .9s ease .4s both; }
.hero-sub { font-size:1rem; color:var(--grey-dim); max-width:600px; margin-bottom:3.5rem; animation:fadeUp .9s ease .5s both; }
.hero-cta-group { display:flex; gap:1.2rem; flex-wrap:wrap; animation:fadeUp .9s ease .6s both; }

.hero-stats {
    position:absolute; bottom:2.5rem; left:0; right:0;
    display:flex; justify-content:center; gap:5rem;
    animation:fadeIn 1s ease 1s both; z-index:2;
}
.hero-stat { text-align:center; }
.hero-stat-num { font-family:var(--display); font-size:2.2rem; color:var(--red); display:block; line-height:1; }
.hero-stat-label { font-family:var(--mono); font-size:.65rem; color:var(--grey-dim); letter-spacing:.12em; text-transform:uppercase; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display:inline-flex; align-items:center; gap:.6rem;
    padding:.9rem 2.2rem; font-family:var(--mono); font-size:.8rem;
    letter-spacing:.15em; text-transform:uppercase; font-weight:700;
    cursor:pointer; border:1.5px solid transparent; transition:all .25s; text-decoration:none;
}
.btn-red,.btn-primary { background:var(--red); color:#fff; border-color:var(--red); animation:redPulse 3s ease infinite; }
.btn-red:hover,.btn-primary:hover { background:transparent; color:var(--red); }
.btn-ghost,.btn-outline { background:transparent; color:#fff; border-color:var(--grey-dim); }
.btn-ghost:hover,.btn-outline:hover { border-color:#fff; color:#fff; }

/* ============================================================
   SECTION LABELS & HEADERS
   ============================================================ */
.section-label {
    font-family:var(--mono); font-size:.7rem; letter-spacing:.2em;
    color:var(--red); text-transform:uppercase;
    display:flex; align-items:center; gap:.8rem; margin-bottom:3rem;
}
.section-label::before { content:''; display:block; width:24px; height:1px; background:var(--red); }
.section-label::after  { content:''; display:block; flex:1; height:1px; background:var(--black-4); }

.section-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:3rem; gap:2rem; }
.section-header h2 { font-family:var(--display); font-size:clamp(2.5rem,5vw,4rem); color:#fff; line-height:1; }
.section-header .see-all {
    font-family:var(--mono); font-size:.75rem; letter-spacing:.12em;
    color:var(--grey); text-transform:uppercase; border-bottom:1px solid var(--grey-dim);
    padding-bottom:.2rem; white-space:nowrap; transition:color .25s, border-color .25s; text-decoration:none;
}
.section-header .see-all:hover { color:var(--red); border-color:var(--red); }

/* ============================================================
   MANIFESTO SECTION
   ============================================================ */
.manifesto-section {
    background:var(--black-2); padding:6rem 0;
    border-top:1px solid var(--black-4); border-bottom:1px solid var(--black-4);
    position:relative; overflow:hidden;
}
.manifesto-section::before {
    content:'"'; font-family:var(--display); font-size:30rem;
    color:rgba(255,32,32,.025); position:absolute; top:-5rem; left:-2rem;
    line-height:1; user-select:none; pointer-events:none;
}
.manifesto-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; position:relative; z-index:1; }

.manifesto-label { font-family:var(--mono); font-size:.7rem; letter-spacing:.2em; color:var(--red); text-transform:uppercase; margin-bottom:2rem; display:flex; align-items:center; gap:.8rem; }
.manifesto-label::before { content:''; display:block; width:24px; height:1px; background:var(--red); }

.manifesto-heading { font-family:var(--display); font-size:clamp(3rem,6vw,5rem); line-height:1; color:#fff; margin-bottom:2rem; }
.manifesto-heading em { display:block; color:var(--red); font-style:normal; }

.manifesto-body p { font-size:1rem; color:var(--grey); margin-bottom:1.4rem; line-height:1.85; }

.we-center { background:var(--black-3); border-left:3px solid var(--red); padding:2.5rem; margin-top:2.5rem; }
.we-center h3 { font-family:var(--mono); font-size:.75rem; letter-spacing:.15em; color:var(--red); text-transform:uppercase; margin-bottom:1.5rem; }
.we-center ol { counter-reset:center-list; list-style:none; }
.we-center ol li { counter-increment:center-list; font-size:.95rem; color:var(--off-white); padding:.6rem 0 .6rem 2.5rem; border-bottom:1px solid var(--black-4); position:relative; line-height:1.5; }
.we-center ol li:last-child { border:none; }
.we-center ol li::before { content:counter(center-list,decimal-leading-zero); font-family:var(--mono); font-size:.65rem; color:var(--red); position:absolute; left:0; top:.7rem; }

.welcome-block { background:var(--black-3); border:1px solid var(--black-4); border-left:3px solid var(--red); padding:2.5rem; }
.welcome-block h3 { font-family:var(--display); font-size:2rem; color:#fff; margin-bottom:1.5rem; }

.welcome-check { list-style:none; margin-bottom:2rem; }
.welcome-check li { font-size:.95rem; color:var(--off-white); padding:.5rem 0 .5rem 2rem; position:relative; border-bottom:1px solid var(--black-4); }
.welcome-check li:last-child { border:none; }
.welcome-check li::before { content:'✓'; position:absolute; left:0; color:var(--red); font-weight:700; }
.not-your-space { font-size:.9rem; color:var(--grey-dim); font-style:italic; padding-top:1.5rem; border-top:1px solid var(--black-4); }

.hashtags { margin-top:2.5rem; }
.hashtags p { font-family:var(--mono); font-size:.8rem; color:var(--red); letter-spacing:.05em; padding:.4rem 0; border-bottom:1px solid var(--black-4); margin-bottom:0; }
.hashtags .final { font-family:var(--display); font-size:1.6rem; color:#fff; letter-spacing:.08em; margin-top:1rem; border:none; padding:0; }

/* ============================================================
   FEATURE CARDS
   ============================================================ */
.feature-grid-section { background:var(--black); padding:6rem 0; border-bottom:1px solid var(--black-4); }
.cards-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--black-4); border:1px solid var(--black-4); }
.feature-card { background:var(--black-2); padding:2.5rem 2rem; transition:background .3s; position:relative; overflow:hidden; }
.feature-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .3s; }
.feature-card:hover { background:var(--black-3); }
.feature-card:hover::after { transform:scaleX(1); }
.feature-card .card-icon { font-size:2rem; margin-bottom:1.5rem; display:block; }
.feature-card h3 { font-family:var(--mono); font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:#fff; margin-bottom:1.2rem; }
.feature-card ul { list-style:none; }
.feature-card ul li { font-size:.85rem; color:var(--grey); padding:.35rem 0 .35rem 1.2rem; position:relative; border-bottom:1px solid var(--black-4); line-height:1.4; }
.feature-card ul li:last-child { border:none; }
.feature-card ul li::before { content:'▸'; position:absolute; left:0; color:var(--red); font-size:.7rem; top:.45rem; }

/* ============================================================
   BLOG / MEDIA SECTION  (asymmetric: 2fr 1fr 1fr)
   ============================================================ */
.blog-section { background:var(--black-2); padding:6rem 0; border-bottom:1px solid var(--black-4); }
.blog-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:1px; background:var(--black-4); border:1px solid var(--black-4); }
.blog-card { background:var(--black-3); transition:background .3s; display:flex; flex-direction:column; overflow:hidden; }
.blog-card:hover { background:var(--black-2); }
.blog-card-img-wrap { overflow:hidden; }
.blog-card-img { width:100%; aspect-ratio:16/9; object-fit:cover; filter:grayscale(40%) contrast(1.1); transition:filter .4s, transform .4s; display:block; }
.blog-card:hover .blog-card-img { filter:grayscale(0%) contrast(1.15); transform:scale(1.03); }
.blog-card-img-placeholder { width:100%; aspect-ratio:16/9; background:linear-gradient(135deg,#1a0808 0%,#2d0505 40%,#0a0a0a 100%); display:flex; align-items:center; justify-content:center; }
.blog-card-img-placeholder span { font-size:4rem; opacity:.15; }
.blog-card.sm .blog-card-img-placeholder span { font-size:2.5rem; }
.blog-card-body { padding:2rem; flex:1; display:flex; flex-direction:column; }
.card-meta-row { display:flex; align-items:center; gap:.8rem; margin-bottom:1rem; }
.cat-tag { font-family:var(--mono); font-size:.65rem; letter-spacing:.12em; background:var(--red); color:#fff; padding:.2rem .6rem; text-transform:uppercase; }
.post-date { font-family:var(--mono); font-size:.65rem; color:var(--grey-dim); letter-spacing:.08em; }
.blog-card h3 { font-family:var(--display); font-size:clamp(1.3rem,2.5vw,2rem); color:#fff; line-height:1.1; margin-bottom:1rem; flex:1; text-transform:uppercase; letter-spacing:.02em; }
.blog-card.sm h3 { font-size:1.1rem; font-family:var(--body); font-weight:700; text-transform:none; letter-spacing:0; }
.blog-card h3 a { color:#fff; }
.blog-card h3 a:hover { color:var(--red); }
.blog-excerpt { font-size:.9rem; color:var(--grey); margin-bottom:1.5rem; line-height:1.7; }
.read-link { font-family:var(--mono); font-size:.7rem; letter-spacing:.12em; color:var(--red); text-transform:uppercase; margin-top:auto; display:inline-flex; align-items:center; gap:.5rem; transition:gap .25s; text-decoration:none; }
.read-link:hover { gap:1rem; color:var(--red); }
.view-all-wrap { text-align:center; margin-top:3rem; }

/* ============================================================
   PHOTO ARCHIVE  (mosaic: first item 2-col × 2-row)
   ============================================================ */
.photo-archive { background:var(--black); padding:6rem 0; border-bottom:1px solid var(--black-4); }
.photo-grid { display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:auto auto; gap:4px; margin-top:.5rem; }
.photo-item { position:relative; overflow:hidden; cursor:pointer; aspect-ratio:4/3; }
.photo-item:first-child { grid-column:span 2; grid-row:span 2; aspect-ratio:auto; min-height:420px; }
.photo-item img { width:100%; height:100%; object-fit:cover; filter:grayscale(60%) brightness(.7); transition:filter .4s, transform .6s; }
.photo-item:hover img { filter:grayscale(0%) brightness(.85); transform:scale(1.05); }
.photo-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.9) 0%,transparent 50%); display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem; opacity:0; transition:opacity .3s; }
.photo-item:hover .photo-overlay,
.photo-item:first-child .photo-overlay { opacity:1; }
.photo-overlay h3 { font-family:var(--mono); font-size:.75rem; color:var(--red); letter-spacing:.1em; text-transform:uppercase; margin-bottom:.3rem; }
.photo-overlay p { font-size:.8rem; color:rgba(255,255,255,.6); font-family:var(--mono); margin:0; }
.photo-placeholder { width:100%; height:100%; min-height:200px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem; padding:2rem; background:linear-gradient(135deg,#1a0a0a 0%,#0a0a0a 100%); }
.photo-placeholder-icon { font-size:2.5rem; opacity:.3; }
.photo-placeholder-text { font-family:var(--mono); font-size:.65rem; color:var(--grey-dim); letter-spacing:.12em; text-transform:uppercase; text-align:center; }
.photo-add-note { margin-top:2rem; padding:1.5rem 2rem; background:var(--black-3); border-left:3px solid var(--red); font-family:var(--mono); font-size:.75rem; color:var(--grey); letter-spacing:.05em; }
.photo-add-note strong { color:var(--red); }

/* ============================================================
   VIDEO ARCHIVE
   ============================================================ */
.video-archive { background:var(--black-2); padding:6rem 0; border-bottom:1px solid var(--black-4); }
.video-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--black-4); border:1px solid var(--black-4); margin-top:.5rem; }
.video-card { background:var(--black-3); transition:background .3s; overflow:hidden; }
.video-card:hover { background:var(--black-2); }
.video-thumb { width:100%; aspect-ratio:16/9; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; cursor:pointer; background:var(--black); }
.video-thumb video, .video-thumb iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.video-type { position:absolute; top:1rem; left:1rem; font-family:var(--mono); font-size:.65rem; letter-spacing:.12em; background:var(--red); color:#fff; padding:.25rem .6rem; text-transform:uppercase; z-index:2; }
.play-btn { width:64px; height:64px; background:rgba(255,32,32,.9); border-radius:50%; display:flex; align-items:center; justify-content:center; position:relative; z-index:2; transition:transform .3s, background .3s; pointer-events:none; }
.play-btn::before { content:''; border-style:solid; border-width:10px 0 10px 18px; border-color:transparent transparent transparent #fff; margin-left:4px; }
.video-card:hover .play-btn { transform:scale(1.12); background:var(--red); }
.video-card-body { padding:1.8rem; }
.video-card-body h3 { font-family:var(--body); font-weight:700; font-size:1rem; color:#fff; margin-bottom:.7rem; line-height:1.3; }
.video-card-body p { font-size:.85rem; color:var(--grey); line-height:1.65; margin-bottom:1rem; }
.video-meta { font-family:var(--mono); font-size:.65rem; color:var(--grey-dim); letter-spacing:.08em; display:flex; gap:1rem; }

/* ============================================================
   PAGE HERO (INNER PAGES)
   ============================================================ */
.page-hero { background:var(--black); color:#fff; padding:5rem 2rem; border-bottom:3px solid var(--red); text-align:center; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,32,32,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,32,32,.03) 1px,transparent 1px); background-size:60px 60px; pointer-events:none; }
.page-hero h1 { font-family:var(--display); font-size:clamp(3rem,8vw,6rem); letter-spacing:.05em; margin-bottom:1rem; position:relative; }
.page-hero p { font-size:1.1rem; color:var(--grey); max-width:700px; margin:0 auto; position:relative; }

/* ============================================================
   ISSUES PAGE
   ============================================================ */
.issues-section { background:var(--black); padding:5rem 0; }
.issue-block { background:var(--black-3); padding:3.5rem; margin-bottom:2.5rem; border-left:5px solid var(--red); }
.issue-block h3 { font-family:var(--display); font-size:2.5rem; color:var(--red); margin-bottom:1rem; letter-spacing:.05em; }
.issue-quote { font-size:1.2rem; font-style:italic; color:var(--grey); margin-bottom:2rem; padding-left:1.5rem; border-left:2px solid var(--black-4); }
.issue-block p { color:#cccccc; margin-bottom:1.5rem; line-height:1.9; }
.issue-block h4 { font-family:var(--mono); font-size:.8rem; letter-spacing:.15em; color:#fff; text-transform:uppercase; margin:2rem 0 1rem; }
.issue-list { list-style:disc; padding-left:2rem; margin-bottom:2rem; }
.issue-list li { color:#cccccc; margin-bottom:.8rem; line-height:1.7; }

/* ============================================================
   TAKE ACTION PAGE
   ============================================================ */
.take-action-section { background:var(--black-2); padding:5rem 0; }
.take-action-intro { font-size:1.2rem; font-weight:600; margin-bottom:3rem; max-width:800px; line-height:1.9; color:var(--off-white); }
.action-block { background:var(--black-3); padding:2.5rem; margin-bottom:2rem; border-left:5px solid var(--red); transition:background .3s; }
.action-block:hover { background:var(--black-4); }
.action-block h3 { font-family:var(--display); font-size:2rem; margin-bottom:1.5rem; color:#fff; letter-spacing:.05em; }
.action-block p { margin-bottom:1rem; line-height:1.8; color:var(--grey); }
.action-block ul { list-style:disc; padding-left:2rem; margin-bottom:1.5rem; }
.action-block ul li { margin-bottom:.7rem; line-height:1.7; color:var(--grey); }
.solidarity-closing { background:var(--black); border:1px solid var(--black-4); border-left:5px solid var(--red); padding:3rem; margin-top:3rem; }
.solidarity-closing p { font-family:var(--display); font-size:1.8rem; color:#fff; margin-bottom:.8rem; letter-spacing:.05em; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-section { padding:5rem 0; background:var(--black-2); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.contact-info h3 { font-family:var(--display); font-size:2rem; color:#fff; margin-bottom:2rem; letter-spacing:.05em; }
.contact-info p { color:var(--grey); margin-bottom:1.5rem; line-height:1.9; }
.contact-item { background:var(--black-3); padding:1.5rem 2rem; margin-bottom:1rem; border-left:4px solid var(--red); }
.contact-item strong { display:block; font-family:var(--mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.15em; margin-bottom:.4rem; color:var(--red); }
.contact-form label { display:block; font-family:var(--mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; margin-bottom:.5rem; color:var(--off-white); }
.contact-form input, .contact-form textarea, .contact-form select { width:100%; padding:1rem; background:var(--black-3); border:1.5px solid var(--black-4); color:var(--off-white); font-family:var(--body); font-size:.95rem; margin-bottom:1.5rem; transition:border-color .25s; }
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus { outline:none; border-color:var(--red); }
.contact-form textarea { height:160px; resize:vertical; }
.contact-form .btn-submit { background:var(--red); color:#fff; border:1.5px solid var(--red); padding:1rem 3rem; font-family:var(--mono); font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.15em; cursor:pointer; width:100%; transition:all .25s; }
.contact-form .btn-submit:hover { background:transparent; color:var(--red); }

/* ============================================================
   PODCAST PAGE
   ============================================================ */
.podcast-hero { background:var(--black); padding:6rem 0; border-bottom:1px solid var(--black-4); position:relative; overflow:hidden; }
.podcast-hero::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,32,32,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,32,32,.035) 1px,transparent 1px); background-size:72px 72px; pointer-events:none; }
.podcast-hero-grid { position:relative; z-index:1; display:grid; grid-template-columns:minmax(0,1fr) minmax(320px,480px); gap:4rem; align-items:center; }
.podcast-hero-copy h1 { font-family:var(--display); font-size:clamp(4rem,9vw,8rem); line-height:.92; letter-spacing:.02em; color:#fff; margin-bottom:1.5rem; text-transform:uppercase; }
.podcast-hero-copy > p:not(.section-label) { color:var(--grey); font-size:1.1rem; line-height:1.9; max-width:660px; margin-bottom:2rem; }
.podcast-actions { display:flex; flex-wrap:wrap; gap:1rem; align-items:center; margin:2rem 0; }
.podcast-platforms { display:flex; flex-wrap:wrap; gap:1rem 2rem; font-family:var(--mono); font-size:.72rem; color:var(--grey-dim); letter-spacing:.12em; text-transform:uppercase; }
.podcast-platforms li::before { content:'// '; color:var(--red-dim); }
.podcast-cover { aspect-ratio:1; background:linear-gradient(135deg,#2d0505 0%,var(--black-3) 45%,var(--black) 100%); border:1px solid var(--black-4); display:flex; align-items:center; justify-content:center; padding:3rem; position:relative; box-shadow:0 24px 80px rgba(0,0,0,.45); }
.podcast-cover::before { content:''; position:absolute; inset:1.5rem; border:1px solid rgba(255,32,32,.35); pointer-events:none; }
.podcast-cover::after { content:''; position:absolute; inset:0; background:radial-gradient(circle at 80% 20%,rgba(255,32,32,.26),transparent 34%); pointer-events:none; }
.podcast-cover-inner { position:relative; z-index:1; text-align:center; }
.podcast-cover span { display:block; font-family:var(--mono); font-size:.7rem; color:var(--red); letter-spacing:.2em; text-transform:uppercase; margin-bottom:1rem; }
.podcast-cover h2 { font-family:var(--display); font-size:clamp(3rem,6vw,5.5rem); line-height:.95; color:#fff; letter-spacing:.05em; text-transform:uppercase; margin-bottom:1rem; }
.podcast-cover p { color:var(--grey); line-height:1.8; max-width:360px; margin:0 auto; }
.podcast-latest { background:var(--black-2); padding:5rem 0; border-bottom:1px solid var(--black-4); border-top:1px solid var(--black-4); }
.podcast-latest-grid { display:grid; grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr); gap:4rem; align-items:center; }
.podcast-latest h2,.podcast-about h2,.podcast-subscribe h2 { font-family:var(--display); font-size:clamp(2.75rem,5vw,4.5rem); line-height:1; color:#fff; letter-spacing:.04em; text-transform:uppercase; margin-bottom:1.5rem; }
.podcast-latest p,.podcast-about p,.podcast-subscribe p { color:var(--grey); line-height:1.9; font-size:1.05rem; }
.podcast-meta { display:flex; flex-wrap:wrap; gap:1rem 2rem; margin:2rem 0; font-family:var(--mono); font-size:.72rem; color:var(--grey-dim); letter-spacing:.12em; text-transform:uppercase; }
.podcast-meta li { padding-left:1rem; border-left:2px solid var(--red); }
.podcast-player { background:var(--black); border:1px solid var(--black-4); border-left:5px solid var(--red); padding:2.5rem; }
.podcast-waveform { min-height:150px; background:var(--black-3); border:1px solid var(--black-4); display:flex; align-items:center; justify-content:center; gap:.55rem; margin-bottom:2rem; }
.podcast-waveform span { display:block; width:8px; background:var(--red); opacity:.8; }
.podcast-waveform span:nth-child(1) { height:42px; }
.podcast-waveform span:nth-child(2) { height:86px; }
.podcast-waveform span:nth-child(3) { height:58px; }
.podcast-waveform span:nth-child(4) { height:104px; }
.podcast-waveform span:nth-child(5) { height:70px; }
.podcast-waveform span:nth-child(6) { height:36px; }
.podcast-detail { padding-top:1.4rem; margin-top:1.4rem; border-top:1px solid var(--black-4); }
.podcast-detail:first-of-type { border-top:0; padding-top:0; margin-top:0; }
.podcast-detail strong { display:block; font-family:var(--mono); font-size:.7rem; color:var(--red); letter-spacing:.16em; text-transform:uppercase; margin-bottom:.5rem; }
.podcast-detail p { color:var(--off-white); font-size:1rem; margin:0; }
.podcast-episodes { background:var(--black); padding:6rem 0; }
.podcast-episode-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--black-4); border:1px solid var(--black-4); }
.podcast-episode-card { background:var(--black-2); transition:background .3s, transform .3s; }
.podcast-episode-card:hover { background:var(--black-3); transform:translateY(-4px); }
.podcast-episode-art { aspect-ratio:16/9; background:linear-gradient(135deg,#1a0808 0%,#2d0505 42%,var(--black) 100%); display:flex; align-items:center; justify-content:center; border-bottom:1px solid var(--black-4); }
.podcast-episode-art span { font-family:var(--display); font-size:3rem; color:rgba(255,255,255,.08); letter-spacing:.1em; text-transform:uppercase; }
.podcast-episode-body { padding:2rem; }
.podcast-episode-meta { display:flex; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; font-family:var(--mono); font-size:.68rem; color:var(--grey-dim); letter-spacing:.12em; text-transform:uppercase; }
.podcast-episode-meta span:first-child { color:var(--red); }
.podcast-episode-card h3 { font-family:var(--display); font-size:2rem; line-height:1.05; letter-spacing:.04em; color:#fff; text-transform:uppercase; margin-bottom:1rem; }
.podcast-episode-card p { color:var(--grey); line-height:1.75; margin-bottom:1.6rem; }
.podcast-about { background:var(--black-2); padding:6rem 0; border-top:1px solid var(--black-4); border-bottom:1px solid var(--black-4); text-align:center; }
.podcast-about .section-label { justify-content:center; }
.podcast-about .section-label::after { max-width:80px; }
.podcast-about h2,.podcast-about p { max-width:820px; margin-left:auto; margin-right:auto; }
.podcast-subscribe { background:var(--black); padding:6rem 0; }
.podcast-subscribe-box { max-width:860px; margin:0 auto; background:var(--black-2); border:1px solid var(--black-4); border-left:5px solid var(--red); padding:3.5rem; text-align:center; }
.podcast-subscribe-box .section-label { justify-content:center; }
.podcast-subscribe-box .section-label::after { max-width:80px; }
.podcast-subscribe-form { display:flex; gap:1rem; margin:2.5rem auto 0; max-width:680px; }
.podcast-subscribe-form input { flex:1; min-width:0; padding:1rem; background:var(--black); border:1.5px solid var(--black-4); color:var(--off-white); font-family:var(--body); font-size:.95rem; transition:border-color .25s; }
.podcast-subscribe-form input:focus { outline:none; border-color:var(--red); }

/* ============================================================
   BLOG SINGLE
   ============================================================ */
.single-content { padding:5rem 0; background:var(--black-2); }
.single-content .content-wrap { max-width:800px; margin:0 auto; }
.single-content .post-meta { font-family:var(--mono); font-size:.75rem; color:var(--grey-dim); text-transform:uppercase; letter-spacing:.1em; margin-bottom:2rem; padding-bottom:1.5rem; border-bottom:1px solid var(--black-4); }
.single-content .post-meta .category { color:var(--red); font-weight:700; }
.single-content h2,.single-content h3,.single-content h4 { font-family:var(--display); margin:2.5rem 0 1rem; color:#fff; letter-spacing:.05em; }
.single-content p { margin-bottom:1.5rem; color:var(--grey); line-height:1.9; }
.single-content ul,.single-content ol { list-style:disc; padding-left:2rem; margin-bottom:1.5rem; color:var(--grey); }
.single-content ul li,.single-content ol li { margin-bottom:.6rem; }
.single-content blockquote { border-left:4px solid var(--red); padding:1.5rem 2rem; background:var(--black-3); font-size:1.2rem; font-style:italic; margin:2rem 0; color:var(--off-white); }

/* ============================================================
   LIGHTBOX
   ============================================================ */
.nn-lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,.96); z-index:99999; justify-content:center; align-items:center; padding:2rem; }
.nn-lightbox.active { display:flex; }
.nn-lightbox-inner { max-width:90vw; max-height:90vh; position:relative; }
.nn-lightbox-inner img { max-height:85vh; max-width:80vw; object-fit:contain; border:3px solid var(--red); }
.nn-lightbox-close { position:absolute; top:-3rem; right:0; background:none; border:none; color:#fff; font-size:2.5rem; cursor:pointer; font-weight:700; transition:color .25s; }
.nn-lightbox-close:hover { color:var(--red); }

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer { background:var(--black); border-top:3px solid var(--red); padding:5rem 0 0; }
.footer-top { text-align:center; padding-bottom:3.5rem; margin-bottom:3.5rem; border-bottom:1px solid var(--black-4); }
.footer-logo-text { font-family:var(--display); font-size:4rem; letter-spacing:.3em; color:#fff; display:block; margin-bottom:.5rem; }
.footer-logo-tag { font-family:var(--mono); font-size:.75rem; color:var(--grey-dim); letter-spacing:.15em; font-style:italic; }
.footer-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:3rem; padding-bottom:4rem; border-bottom:1px solid var(--black-4); }
.footer-col h4 { font-family:var(--mono); font-size:.7rem; letter-spacing:.2em; color:var(--red); text-transform:uppercase; margin-bottom:1.5rem; padding-bottom:.8rem; border-bottom:1px solid var(--black-4); }
.footer-col p { font-size:.85rem; color:var(--grey); line-height:1.8; margin-bottom:.8rem; }
.footer-col ul { list-style:none; }
.footer-col ul li { padding:.4rem 0; border-bottom:1px solid var(--black-4); }
.footer-col ul li:last-child { border:none; }
.footer-col ul li a { font-family:var(--mono); font-size:.75rem; letter-spacing:.05em; color:var(--grey); transition:color .25s; }
.footer-col ul li a::before { content:'→ '; color:var(--red-dim); font-size:.65rem; }
.footer-col ul li a:hover { color:#fff; }
.footer-no-neutrality p { font-size:.85rem; color:var(--grey); font-weight:700; padding:.35rem 0; border-bottom:1px solid var(--black-4); line-height:1.4; margin-bottom:0; }
.footer-no-neutrality p:last-child { border:none; }
.nn-final { font-family:var(--display) !important; font-size:1.3rem !important; color:#fff !important; letter-spacing:.08em; margin-top:.5rem; }
.footer-bottom { padding:1.5rem 2rem; text-align:center; border-top:1px solid var(--black-4); }
.footer-bottom p { font-family:var(--mono); font-size:.65rem; color:var(--grey-dim); letter-spacing:.06em; }

/* ============================================================
   WP PAGINATION
   ============================================================ */
.nav-links { display:flex; gap:1rem; justify-content:center; margin-top:3rem; font-family:var(--mono); font-size:.8rem; letter-spacing:.1em; }
.nav-links .page-numbers { color:var(--grey); padding:.5rem 1rem; border:1px solid var(--black-4); transition:color .25s, border-color .25s; }
.nav-links .page-numbers:hover,.nav-links .page-numbers.current { color:var(--red); border-color:var(--red); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px) {
    .footer-grid { grid-template-columns:repeat(3,1fr); }
    .cards-grid  { grid-template-columns:repeat(2,1fr); }
    .podcast-episode-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px) {
    .manifesto-grid,.contact-grid { grid-template-columns:1fr; }
    .blog-grid,.video-grid { grid-template-columns:1fr; }
    .podcast-hero-grid,.podcast-latest-grid { grid-template-columns:1fr; }
    .photo-grid { grid-template-columns:repeat(2,1fr); }
    .photo-item:first-child { grid-column:span 2; grid-row:span 1; min-height:280px; }
    .hero-stats { gap:2.5rem; }
}
@media (max-width:768px) {
    .menu-toggle { display:block; }
    #primary-navigation { display:none; width:100%; background:var(--black-2); padding:1rem 2rem; border-top:1px solid var(--black-4); }
    #primary-navigation.open { display:block; }
    #primary-navigation ul { flex-direction:column; gap:0; }
    #primary-navigation ul li a { display:block; padding:1rem 0; border-bottom:1px solid var(--black-4); }
    #site-header .header-inner { flex-wrap:wrap; }
}
@media (max-width:600px) {
    .footer-grid { grid-template-columns:1fr 1fr; }
    .cards-grid  { grid-template-columns:1fr; }
    .podcast-episode-grid { grid-template-columns:1fr; }
    .podcast-subscribe-box { padding:2rem; }
    .podcast-subscribe-form { flex-direction:column; }
    .photo-grid  { grid-template-columns:1fr; }
    .photo-item:first-child { grid-column:span 1; }
    .hero-cta-group { flex-direction:column; align-items:flex-start; }
    .hero-stats { gap:1.5rem; }
    .hero-stat-num { font-size:1.6rem; }
}
