/* ═══════════════════════════════════════════════════════════
   UAPScan™ — Classified Military Terminal
   Green terminal + purple accent + teal stats
   ═══════════════════════════════════════════════════════════ */

:root {
    --bg-deep: #0a0e17;
    --bg-surface: #0f1420;
    --bg-card: #111827;
    --bg-card-hover: #1a2236;
    --bg-elevated: #1c2438;
    --border: rgba(57, 255, 20, 0.08);
    --border-hover: rgba(57, 255, 20, 0.22);
    --border-glow: rgba(57, 255, 20, 0.4);
    --green: #39ff14;
    --green-dim: rgba(57, 255, 20, 0.08);
    --green-glow: rgba(57, 255, 20, 0.3);
    --green-soft: #4ade80;
    --purple: #7b2dff;
    --purple-dim: rgba(123, 45, 255, 0.12);
    --purple-glow: rgba(123, 45, 255, 0.3);
    --teal: #00f0ff;
    --teal-dim: rgba(0, 240, 255, 0.1);
    --teal-glow: rgba(0, 240, 255, 0.3);
    --red: #ef4444;
    --red-dim: rgba(239, 68, 68, 0.1);
    --text: #d1d5db;
    --text-muted: #7a8ba0;
    --text-dim: #4a5568;
    --font-mono: 'IBM Plex Mono', 'Fira Code', monospace;
    --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --radius: 3px;
    --glow-sm: 0 0 8px rgba(57, 255, 20, 0.12);
    --glow-md: 0 0 16px rgba(57, 255, 20, 0.18);
    --glow-lg: 0 0 32px rgba(57, 255, 20, 0.22);
    --scanline: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(57, 255, 20, 0.008) 2px, rgba(57, 255, 20, 0.008) 4px);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-sans);
    background: var(--bg-deep);
    color: var(--text);
    min-height: 100vh;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--green-soft); text-decoration: none; transition: all 0.2s; }
a:hover { color: #fff; text-shadow: 0 0 8px var(--green-glow); }

/* ═══ Star Field ═══ */
body::before {
    content: '';
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background:
        radial-gradient(1px 1px at 15% 25%, rgba(255,255,255,0.35) 0%, transparent 100%),
        radial-gradient(1px 1px at 45% 65%, rgba(255,255,255,0.25) 0%, transparent 100%),
        radial-gradient(1px 1px at 65% 15%, rgba(255,255,255,0.2) 0%, transparent 100%),
        radial-gradient(1px 1px at 85% 45%, rgba(255,255,255,0.3) 0%, transparent 100%),
        radial-gradient(1.5px 1.5px at 8% 75%, rgba(57,255,20,0.2) 0%, transparent 100%),
        radial-gradient(1px 1px at 92% 12%, rgba(255,255,255,0.35) 0%, transparent 100%),
        radial-gradient(1px 1px at 35% 88%, rgba(255,255,255,0.2) 0%, transparent 100%),
        radial-gradient(1.5px 1.5px at 72% 82%, rgba(123,45,255,0.15) 0%, transparent 100%);
    pointer-events: none; z-index: 0;
    animation: drift 150s linear infinite;
}
@keyframes drift { 0% { transform: translateY(0); } 100% { transform: translateY(-15px); } }

/* CRT Scanline */
body::after {
    content: '';
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: var(--scanline);
    pointer-events: none; z-index: 9998; opacity: 0.5;
}

/* ═══ Header — 3-column grid: logo | nav | spacer ═══ */
header {
    position: sticky; top: 0; z-index: 1000;
    background: rgba(10, 14, 23, 0.95);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--border);
}
header .container {
    max-width: 1200px; margin: 0 auto;
    padding: 0.6rem 1.5rem;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
}

.logo {
    font-family: var(--font-mono); font-size: 1.05rem; font-weight: 700;
    color: var(--green); letter-spacing: -0.02em;
    display: flex; align-items: center; gap: 0.4rem;
    text-shadow: 0 0 10px var(--green-glow);
}
.logo i { font-size: 0.9rem; }
.logo .tm { font-size: 0.55rem; vertical-align: super; opacity: 0.5; }

#mainNav {
    display: flex; justify-content: center; gap: 0.15rem; align-items: center;
}
#mainNav a {
    font-family: var(--font-mono); font-size: 0.68rem; font-weight: 500;
    color: var(--text-muted); padding: 0.35rem 0.65rem;
    border-radius: var(--radius); text-transform: uppercase;
    letter-spacing: 0.06em; transition: all 0.2s;
}
#mainNav a:hover {
    color: var(--green); background: var(--green-dim);
    text-shadow: 0 0 6px var(--green-glow);
}
#mainNav a.active {
    color: var(--green); background: transparent;
    border-bottom: 2px solid var(--green);
    border-radius: 0;
}

.header-actions { display: none; }

/* Mobile */
@media (max-width: 768px) {
    header .container { grid-template-columns: 1fr; gap: 0.4rem; justify-items: center; }
    #mainNav { flex-wrap: wrap; justify-content: center; }
}

/* ═══ Main ═══ */
main {
    position: relative; z-index: 1;
    max-width: 1200px; margin: 0 auto;
    padding: 2rem 1.5rem; min-height: calc(100vh - 180px);
}

/* ═══ Hero ═══ */
.hero { text-align: center; padding: 4rem 1rem 3rem; position: relative; }
.hero::before {
    content: ''; position: absolute; top: 50%; left: 50%;
    width: 600px; height: 600px; transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(57,255,20,0.04) 0%, transparent 70%);
    pointer-events: none;
}

/* Classification stamp in hero */
.hero-classification {
    font-family: var(--font-mono); font-size: 0.6rem; font-weight: 700;
    letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--red); opacity: 0.7;
    border: 1px solid rgba(239,68,68,0.3); padding: 0.2rem 0.8rem;
    display: inline-block; margin-bottom: 1.2rem;
    transform: rotate(-1deg);
}

.hero-badge {
    display: inline-flex; align-items: center; gap: 0.4rem;
    font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.15em; color: var(--green);
    background: var(--green-dim); border: 1px solid rgba(57,255,20,0.2);
    padding: 0.4rem 1rem; border-radius: 2px; margin-bottom: 1.5rem;
    animation: pulse-green 3s ease-in-out infinite;
}
@keyframes pulse-green {
    0%, 100% { box-shadow: 0 0 6px rgba(57,255,20,0.2); }
    50% { box-shadow: 0 0 20px rgba(57,255,20,0.5), 0 0 40px rgba(57,255,20,0.15); }
}

.hero h1 {
    font-family: var(--font-mono); font-size: clamp(1.8rem, 5vw, 3rem);
    font-weight: 700; line-height: 1.2; color: #fff;
    margin-bottom: 1.2rem; letter-spacing: -0.02em;
}
.hero h1 .accent { color: var(--green); text-shadow: 0 0 20px var(--green-glow); }

.hero-subtitle { max-width: 640px; margin: 0 auto 2rem; color: var(--text-muted); font-size: 0.95rem; line-height: 1.7; }

/* ═══ Email Form ═══ */
.email-form {
    display: flex; max-width: 420px; margin: 0 auto;
    border: 1px solid var(--border); border-radius: var(--radius);
    overflow: hidden; background: var(--bg-card); transition: border-color 0.3s, box-shadow 0.3s;
}
.email-form:focus-within { border-color: var(--green); box-shadow: var(--glow-md); }
.email-form input {
    flex: 1; background: transparent; border: none;
    padding: 0.75rem 1rem; color: var(--text);
    font-family: var(--font-mono); font-size: 0.8rem; outline: none;
}
.email-form input::placeholder { color: var(--text-dim); }
.email-form button {
    background: var(--green); color: var(--bg-deep); border: none;
    padding: 0.75rem 1.2rem; font-family: var(--font-mono);
    font-size: 0.75rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.05em; cursor: pointer; transition: all 0.2s; white-space: nowrap;
}
.email-form button:hover { background: #fff; box-shadow: 0 0 16px var(--green-glow); }
.email-msg { text-align: center; margin-top: 0.5rem; font-family: var(--font-mono); font-size: 0.75rem; color: var(--green); }

/* ═══ Stats Bar ═══ */
.stats-bar {
    display: flex; justify-content: center; flex-wrap: wrap; gap: 2rem;
    padding: 1.5rem; margin: 1rem 0 2.5rem;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); position: relative;
}
.stats-bar::before, .stats-bar::after {
    content: ''; position: absolute; width: 14px; height: 14px;
    border-color: var(--green); opacity: 0.3;
}
.stats-bar::before { top: 5px; left: 5px; border-top: 1px solid; border-left: 1px solid; }
.stats-bar::after { bottom: 5px; right: 5px; border-bottom: 1px solid; border-right: 1px solid; }
.stat-item { text-align: center; min-width: 80px; }
.stat-value {
    font-family: var(--font-mono); font-size: 1.5rem; font-weight: 700;
    color: var(--green); text-shadow: 0 0 10px var(--green-glow);
}
.stat-value.green { color: var(--teal); text-shadow: 0 0 10px var(--teal-glow); }
.stat-label { font-family: var(--font-mono); font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); margin-top: 0.2rem; }

/* ═══ Section Headers ═══ */
.section-header {
    display: flex; align-items: center; gap: 0.6rem;
    margin: 2.5rem 0 1rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--border);
}
.section-header i { color: var(--green); font-size: 0.9rem; }
.section-header h2 { font-family: var(--font-mono); font-size: 0.9rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text); }
.section-header .badge { font-family: var(--font-mono); font-size: 0.65rem; background: var(--purple-dim); color: var(--purple); border: 1px solid rgba(123,45,255,0.2); padding: 0.15rem 0.5rem; border-radius: 2px; }
.section-header .section-more { margin-left: auto; font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-muted); }
.section-header .section-more:hover { color: var(--green); }

/* ═══ Document Cards ═══ */
.doc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 0.75rem; }
.doc-card {
    display: block; background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 1rem; transition: all 0.2s;
    position: relative; overflow: hidden;
}
.doc-card::before {
    content: 'DECLASSIFIED'; position: absolute; top: 8px; right: -22px;
    font-family: var(--font-mono); font-size: 0.5rem; font-weight: 700;
    letter-spacing: 0.1em; color: rgba(57,255,20,0.15);
    transform: rotate(45deg); pointer-events: none;
}
.doc-card::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--green), transparent);
    opacity: 0; transition: opacity 0.3s;
}
.doc-card:hover { border-color: var(--border-hover); background: var(--bg-card-hover); box-shadow: var(--glow-sm); transform: translateY(-1px); }
.doc-card:hover::after { opacity: 1; }
.doc-card-title {
    font-family: var(--font-mono); font-size: 0.8rem; font-weight: 500;
    color: var(--text); margin-bottom: 0.5rem; line-height: 1.4;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.doc-card-meta { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.badge-classification { font-family: var(--font-mono); font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; padding: 0.15rem 0.4rem; border-radius: 2px; }
.badge-unclassified { background: var(--green-dim); color: var(--green); border: 1px solid rgba(57,255,20,0.2); }
.badge-confidential { background: var(--purple-dim); color: var(--purple); border: 1px solid rgba(123,45,255,0.2); }
.badge-secret { background: var(--red-dim); color: var(--red); border: 1px solid rgba(239,68,68,0.2); }
.badge-top-secret, .badge-top-secret-sci { background: rgba(239,68,68,0.15); color: #f87171; border: 1px solid rgba(239,68,68,0.3); }
.badge-source { font-family: var(--font-mono); font-size: 0.6rem; color: var(--text-muted); background: rgba(100,116,139,0.08); border: 1px solid rgba(100,116,139,0.12); padding: 0.1rem 0.4rem; border-radius: 2px; }

/* ═══ Release Banner ═══ */
.release-banner {
    background: var(--bg-card); border: 1px solid var(--green);
    border-radius: var(--radius); padding: 1.2rem 1.5rem; margin: 2rem 0;
    display: flex; align-items: center; gap: 1.2rem;
    position: relative; overflow: hidden; box-shadow: 0 0 20px rgba(57,255,20,0.08);
}
.release-banner::before {
    content: 'CLASSIFIED MATERIAL'; position: absolute; top: 0; right: 0;
    font-family: var(--font-mono); font-size: 0.5rem; font-weight: 700;
    letter-spacing: 0.12em; background: var(--green); color: var(--bg-deep); padding: 0.2rem 0.6rem;
}
.release-banner::after {
    content: ''; position: absolute; top: 5px; left: 5px; bottom: 5px; right: 5px;
    border: 1px dashed rgba(57,255,20,0.15); border-radius: 2px; pointer-events: none;
}
.release-banner-icon { font-size: 1.8rem; color: var(--green); text-shadow: 0 0 12px var(--green-glow); }
.release-banner-text h3 { font-family: var(--font-mono); font-size: 0.9rem; font-weight: 700; color: #fff; margin-bottom: 0.2rem; }
.release-banner-text p { font-size: 0.8rem; color: var(--text-muted); }
.release-banner-text .release-stats { font-family: var(--font-mono); font-size: 0.7rem; color: var(--green); margin-top: 0.3rem; }

/* ═══ Search ═══ */
.search-hero { text-align: center; padding: 2rem 0 1.5rem; }
.search-hero h1 { font-family: var(--font-mono); font-size: 1.2rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: #fff; margin-bottom: 0.3rem; }
.search-hero p { color: var(--text-muted); font-size: 0.85rem; }
.search-box {
    display: flex; max-width: 600px; margin: 1.5rem auto;
    border: 1px solid var(--border); border-radius: var(--radius);
    overflow: hidden; background: var(--bg-card); transition: all 0.3s;
}
.search-box:focus-within { border-color: var(--green); box-shadow: var(--glow-md); }
.search-box input { flex: 1; background: transparent; border: none; padding: 0.9rem 1.2rem; color: var(--text); font-family: var(--font-mono); font-size: 0.85rem; outline: none; }
.search-box input::placeholder { color: var(--text-dim); }
.search-box button {
    background: var(--green); color: var(--bg-deep); border: none; padding: 0 1.5rem;
    font-family: var(--font-mono); font-size: 0.8rem; font-weight: 700;
    text-transform: uppercase; cursor: pointer; position: relative; overflow: hidden; transition: all 0.2s;
}
.search-box button::after {
    content: ''; position: absolute; top: -50%; left: -100%; width: 200%; height: 200%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
    animation: scan-sweep 3s ease-in-out infinite;
}
@keyframes scan-sweep { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }
.search-box button:hover { background: #fff; }
.search-info { text-align: center; font-family: var(--font-mono); font-size: 0.75rem; color: var(--text-muted); margin-bottom: 1.5rem; }
.search-info strong { color: var(--green); }

/* Search Results */
.result-item {
    display: block; background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 1rem 1.2rem; margin-bottom: 0.6rem;
    transition: all 0.2s; position: relative;
}
.result-item::after {
    content: 'DECLASSIFIED'; position: absolute; top: 0.6rem; right: 0.8rem;
    font-family: var(--font-mono); font-size: 0.5rem; font-weight: 700;
    letter-spacing: 0.1em; color: var(--green); opacity: 0.35;
}
.result-item:hover { border-color: var(--border-hover); background: var(--bg-card-hover); box-shadow: var(--glow-sm); }
.result-title { font-family: var(--font-mono); font-size: 0.85rem; font-weight: 600; color: #fff; margin-bottom: 0.4rem; }
.result-snippet { font-size: 0.8rem; color: var(--text-muted); line-height: 1.5; margin-bottom: 0.5rem; }
.result-snippet mark { background: var(--green-dim); color: var(--green); border-radius: 2px; padding: 0 2px; }
.result-meta { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.result-meta span { font-family: var(--font-mono); font-size: 0.65rem; color: var(--text-muted); }

/* Pagination */
.pagination { display: flex; justify-content: center; gap: 0.5rem; margin-top: 1.5rem; font-family: var(--font-mono); font-size: 0.75rem; }
.pagination a, .pagination .disabled { padding: 0.4rem 0.8rem; border: 1px solid var(--border); border-radius: var(--radius); color: var(--text-muted); }
.pagination a:hover { border-color: var(--green); color: var(--green); }
.pagination .disabled { opacity: 0.3; }

/* ═══ Timeline ═══ */
.timeline { position: relative; padding-left: 2rem; margin: 1rem 0; }
.timeline::before {
    content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px;
    background: linear-gradient(180deg, var(--green), rgba(57,255,20,0.05));
    box-shadow: 0 0 6px var(--green-glow);
}
.timeline-item {
    position: relative; padding: 0.8rem 1rem; margin-bottom: 0.8rem;
    background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); transition: all 0.2s;
}
.timeline-item::before {
    content: ''; position: absolute; left: -1.65rem; top: 1.1rem;
    width: 10px; height: 10px; background: var(--green); border-radius: 50%;
    box-shadow: 0 0 6px var(--green-glow); animation: node-pulse 3s ease-in-out infinite;
}
@keyframes node-pulse {
    0%, 100% { box-shadow: 0 0 4px var(--green-glow); }
    50% { box-shadow: 0 0 12px var(--green-glow), 0 0 20px rgba(57,255,20,0.1); }
}
.timeline-item:hover { border-color: var(--border-hover); box-shadow: var(--glow-sm); }
.timeline-date { font-family: var(--font-mono); font-size: 0.7rem; color: var(--green); margin-bottom: 0.2rem; }
.timeline-title { font-family: var(--font-mono); font-size: 0.85rem; font-weight: 600; color: #fff; margin-bottom: 0.2rem; }
.timeline-desc { font-size: 0.8rem; color: var(--text-muted); line-height: 1.5; }
.timeline-badge { display: inline-block; font-family: var(--font-mono); font-size: 0.6rem; padding: 0.1rem 0.4rem; border-radius: 2px; margin-top: 0.4rem; background: var(--purple-dim); color: var(--purple); border: 1px solid rgba(123,45,255,0.2); }

/* ═══ Page Header ═══ */
.page-header { margin-bottom: 1.5rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border); }
.page-header h1 { font-family: var(--font-mono); font-size: 1.2rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; color: #fff; }
.page-header h1 i { color: var(--green); margin-right: 0.5rem; }
.page-header p { font-family: var(--font-mono); font-size: 0.75rem; color: var(--text-muted); margin-top: 0.3rem; }

/* ═══ Video Grid ═══ */
.video-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1rem; }
.video-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); overflow: hidden; transition: all 0.2s; position: relative;
}
.video-card::before {
    content: 'CLASSIFIED FOOTAGE'; position: absolute; top: 0.5rem; left: 0.5rem;
    font-family: var(--font-mono); font-size: 0.5rem; font-weight: 700;
    letter-spacing: 0.1em; color: var(--green);
    background: rgba(10,14,23,0.88); padding: 0.15rem 0.4rem;
    border-radius: 2px; border: 1px solid rgba(57,255,20,0.25); z-index: 5;
}
.video-card:hover { border-color: var(--border-hover); box-shadow: var(--glow-sm); transform: translateY(-2px); }
.video-card video { width: 100%; height: 200px; object-fit: cover; background: #000; display: block; }
.video-info { padding: 0.8rem; }
.video-filename { font-family: var(--font-mono); font-size: 0.75rem; font-weight: 500; color: var(--text); margin-bottom: 0.3rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.video-meta { display: flex; gap: 0.3rem; align-items: center; flex-wrap: wrap; }
.video-badge { font-family: var(--font-mono); font-size: 0.6rem; background: var(--purple-dim); color: var(--purple); border: 1px solid rgba(123,45,255,0.2); padding: 0.1rem 0.35rem; border-radius: 2px; }

.video-dl-card { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 200px; background: rgba(0,0,0,0.4); text-align: center; padding: 1rem; }
.video-dl-card-icon { font-size: 2rem; color: var(--text-dim); margin-bottom: 0.5rem; }
.video-dl-card-name { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-muted); margin-bottom: 0.3rem; }
.video-dl-card-msg { font-size: 0.7rem; color: var(--text-dim); margin-bottom: 0.6rem; }
.video-dl-card-btn { font-family: var(--font-mono); font-size: 0.7rem; color: var(--green); border: 1px solid var(--green); padding: 0.4rem 0.8rem; border-radius: var(--radius); transition: all 0.2s; }
.video-dl-card-btn:hover { background: var(--green); color: var(--bg-deep); }

/* ═══ Image Grid ═══ */
.image-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 1rem; }
.image-card {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); overflow: hidden; transition: all 0.2s; position: relative; cursor: pointer;
}
.image-card:hover { border-color: var(--border-hover); box-shadow: var(--glow-sm); transform: translateY(-2px); }
.image-card img { width: 100%; height: 200px; object-fit: cover; display: block; transition: transform 0.3s; }
.image-card:hover img { transform: scale(1.03); }
.image-card .image-source-badge {
    position: absolute; top: 0.5rem; left: 0.5rem;
    font-family: var(--font-mono); font-size: 0.5rem; font-weight: 700;
    letter-spacing: 0.08em; color: var(--green); background: rgba(10,14,23,0.88);
    padding: 0.15rem 0.5rem; border-radius: 2px; border: 1px solid rgba(57,255,20,0.2);
}
.image-card .image-info { padding: 0.7rem; }
.image-card .image-title { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Lightbox */
.lightbox-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.92); z-index: 10000; align-items: center; justify-content: center; cursor: pointer; padding: 2rem; }
.lightbox-overlay.active { display: flex; }
.lightbox-overlay img { max-width: 90vw; max-height: 85vh; object-fit: contain; border: 1px solid var(--border); border-radius: var(--radius); }
.lightbox-close { position: absolute; top: 1.5rem; right: 1.5rem; font-size: 1.5rem; color: #fff; cursor: pointer; background: none; border: none; opacity: 0.7; }
.lightbox-close:hover { opacity: 1; }

/* ═══ People Grid ═══ */
.people-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 0.75rem; }
.person-card {
    display: flex; align-items: center; gap: 0.8rem;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 0.9rem; transition: all 0.2s;
}
.person-card:hover { border-color: var(--border-hover); background: var(--bg-card-hover); box-shadow: var(--glow-sm); }
.person-initials {
    width: 44px; height: 44px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-mono); font-size: 0.8rem; font-weight: 700; color: #fff; flex-shrink: 0;
}
.person-photo { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.person-info { overflow: hidden; }
.person-name { font-family: var(--font-mono); font-size: 0.8rem; font-weight: 600; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.role-badge { display: inline-block; font-family: var(--font-mono); font-size: 0.6rem; font-weight: 600; padding: 0.1rem 0.4rem; border-radius: 2px; color: #fff; margin-top: 0.2rem; }
.person-bio { font-size: 0.72rem; color: var(--text-muted); margin-top: 0.2rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.person-stats { font-family: var(--font-mono); font-size: 0.65rem; color: var(--text-dim); margin-top: 0.3rem; }
.person-stats i { color: var(--green); margin-right: 0.2rem; }

/* ═══ Cross Promo ═══ */
.cross-promo {
    display: flex; align-items: center; gap: 1rem;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 1rem 1.2rem;
    font-size: 0.8rem; color: var(--text-muted);
}
.cross-promo-icon { font-size: 1.3rem; color: var(--purple); flex-shrink: 0; }
.cross-promo a { font-weight: 600; }

/* ═══ Footer ═══ */
footer {
    position: relative; z-index: 1; max-width: 1200px; margin: 0 auto;
    padding: 2rem 1.5rem; text-align: center; border-top: 1px solid var(--border);
}
footer p { font-size: 0.75rem; color: var(--text-muted); margin-bottom: 0.3rem; }
footer strong { color: var(--green); }
.footer-disclaimer { font-size: 0.7rem; color: var(--text-dim); max-width: 600px; margin: 0 auto 1rem; line-height: 1.5; }
.footer-links { display: flex; justify-content: center; gap: 1.5rem; margin-top: 0.8rem; }
.footer-links a { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-muted); }
.footer-links a:hover { color: var(--green); }
.footer-network { font-family: var(--font-mono); font-size: 0.6rem; color: var(--text-dim); margin-top: 0.8rem; letter-spacing: 0.05em; }

/* ═══ Age Gate ═══ */
.age-gate-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(5,8,14,0.97); z-index: 99999; align-items: center; justify-content: center; padding: 1rem; }
.age-gate-overlay.show { display: flex; }
.age-gate-card { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem; max-width: 450px; width: 100%; text-align: center; position: relative; }
.age-gate-card::before, .age-gate-card::after { content: ''; position: absolute; width: 16px; height: 16px; border-color: var(--red); opacity: 0.4; }
.age-gate-card::before { top: 8px; left: 8px; border-top: 1px solid; border-left: 1px solid; }
.age-gate-card::after { bottom: 8px; right: 8px; border-bottom: 1px solid; border-right: 1px solid; }
.age-gate-lock { font-size: 1.5rem; color: var(--red); margin-bottom: 0.5rem; }
.age-gate-classified { font-family: var(--font-mono); font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.2em; color: var(--red); margin-bottom: 0.8rem; }
.age-gate-title { font-family: var(--font-mono); font-size: 1.1rem; font-weight: 700; color: #fff; margin-bottom: 0.2rem; }
.age-gate-subtitle { font-family: var(--font-mono); font-size: 0.75rem; color: var(--text-muted); margin-bottom: 1rem; }
.age-gate-text { font-size: 0.8rem; color: var(--text-muted); line-height: 1.5; margin-bottom: 0.8rem; }
.age-gate-age-req { font-family: var(--font-mono); font-size: 0.7rem; color: var(--red); margin: 0.8rem 0; }
.age-gate-rule { border: none; border-top: 1px solid var(--border); margin: 1rem 0; }
.age-gate-confirm-label { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; margin-bottom: 0.5rem; }
.age-gate-bullets { list-style: none; text-align: left; margin: 0 0 1rem 1rem; }
.age-gate-bullets li { font-size: 0.78rem; color: var(--text-muted); padding: 0.15rem 0; }
.age-gate-bullets li::before { content: '>'; font-family: var(--font-mono); color: var(--green); margin-right: 0.5rem; }
.age-gate-enter { display: block; width: 100%; background: var(--green); color: var(--bg-deep); border: none; padding: 0.8rem; font-family: var(--font-mono); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer; border-radius: var(--radius); margin-bottom: 0.5rem; transition: all 0.2s; }
.age-gate-enter:hover { background: #fff; box-shadow: var(--glow-md); }
.age-gate-leave { display: block; width: 100%; background: transparent; color: var(--text-dim); border: 1px solid var(--border); padding: 0.6rem; font-family: var(--font-mono); font-size: 0.7rem; cursor: pointer; border-radius: var(--radius); transition: all 0.2s; }
.age-gate-leave:hover { border-color: var(--red); color: var(--red); }

/* ═══ Document Detail ═══ */
.doc-detail-header { margin-bottom: 1.5rem; }
.doc-detail-header h1 { font-family: var(--font-mono); font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: 0.5rem; }
.doc-detail-meta { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; }

/* No Results */
.no-results { text-align: center; padding: 4rem 1rem; color: var(--text-dim); }
.no-results i { font-size: 2rem; margin-bottom: 1rem; display: block; }

/* About */
.about-content { max-width: 700px; }
.about-content h2 { font-family: var(--font-mono); font-size: 0.9rem; font-weight: 700; color: var(--green); text-transform: uppercase; letter-spacing: 0.03em; margin: 2rem 0 0.8rem; }
.about-content p, .about-content li { font-size: 0.85rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 0.6rem; }
.about-content ul { list-style: none; margin-left: 0.5rem; }
.about-content li::before { content: '>'; font-family: var(--font-mono); color: var(--green); margin-right: 0.5rem; }

/* ═══ Responsive ═══ */
@media (max-width: 768px) {
    main { padding: 1.2rem 1rem; }
    .hero { padding: 2rem 0.5rem 1.5rem; }
    .hero h1 { font-size: 1.5rem; }
    .stats-bar { gap: 1rem; padding: 1rem; }
    .stat-value { font-size: 1.2rem; }
    .doc-grid { grid-template-columns: 1fr; }
    .video-grid { grid-template-columns: 1fr; }
    .image-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
    .people-grid { grid-template-columns: 1fr; }
    .release-banner { flex-direction: column; text-align: center; }
    .search-box { flex-direction: column; }
    .search-box button { padding: 0.8rem; }
}
@media (max-width: 480px) {
    .stats-bar { gap: 0.8rem; }
    .stat-item { min-width: 60px; }
    .stat-value { font-size: 1rem; }
    .email-form { flex-direction: column; }
    .email-form button { padding: 0.7rem; }
}

/* ═══ Document Viewer ═══ */
.doc-viewer {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 1rem;
}
.doc-header {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    position: relative;
    overflow: hidden;
}
.doc-header::after {
    content: 'DECLASSIFIED';
    position: absolute;
    top: 12px; right: -28px;
    font-family: var(--font-mono);
    font-size: 0.55rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: rgba(57, 255, 20, 0.2);
    background: rgba(57, 255, 20, 0.04);
    padding: 0.15rem 2.5rem;
    transform: rotate(35deg);
    border: 1px solid rgba(57, 255, 20, 0.08);
}
.doc-header .back-link {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    color: var(--text-muted);
    margin-bottom: 1rem;
    display: inline-block;
}
.doc-header .back-link:hover { color: var(--green-soft); }
.doc-title {
    font-family: var(--font-mono);
    font-size: 1.1rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}
.doc-metadata {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem 1.2rem;
    font-family: var(--font-mono);
    font-size: 0.72rem;
    color: var(--text-muted);
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}
.doc-metadata span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}
.doc-metadata i { color: var(--green); font-size: 0.65rem; }
.doc-actions {
    display: flex;
    gap: 0.6rem;
    margin-top: 0.8rem;
}
.doc-actions a {
    font-family: var(--font-mono);
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.45rem 1rem;
    border-radius: var(--radius);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.2s;
}
.btn-download {
    background: var(--green);
    color: var(--bg-deep) !important;
    border: 1px solid var(--green);
}
.btn-download:hover {
    background: #fff;
    color: var(--bg-deep) !important;
    box-shadow: 0 0 16px var(--green-glow);
    text-shadow: none;
}
.btn-outline {
    background: transparent;
    color: var(--green-soft) !important;
    border: 1px solid var(--border);
}
.btn-outline:hover {
    border-color: var(--green);
    color: var(--green) !important;
    box-shadow: var(--glow-sm);
    text-shadow: none;
}
.doc-content {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 2rem 2.5rem;
    position: relative;
    overflow: hidden;
}
.doc-content::before {
    content: '';
    position: absolute;
    top: 5px; left: 5px;
    width: 12px; height: 12px;
    border-top: 1px solid rgba(57, 255, 20, 0.15);
    border-left: 1px solid rgba(57, 255, 20, 0.15);
}
.doc-content::after {
    content: '';
    position: absolute;
    bottom: 5px; right: 5px;
    width: 12px; height: 12px;
    border-bottom: 1px solid rgba(57, 255, 20, 0.15);
    border-right: 1px solid rgba(57, 255, 20, 0.15);
}
.doc-text {
    font-family: var(--font-sans);
    font-size: 0.88rem;
    line-height: 1.8;
    color: #d1d5db;
    white-space: pre-wrap;
    word-wrap: break-word;
}
.doc-text p {
    margin-bottom: 1.2rem;
}
.doc-text p:last-child { margin-bottom: 0; }
.doc-text .marking {
    color: #f87171;
    font-weight: 700;
    font-family: var(--font-mono);
    font-size: 0.82rem;
    text-shadow: 0 0 6px rgba(239, 68, 68, 0.3);
}
.doc-ocr-notice {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    color: var(--text-dim);
    text-align: right;
    margin-top: 1rem;
    padding-top: 0.8rem;
    border-top: 1px solid var(--border);
}
@media (max-width: 768px) {
    .doc-content { padding: 1.2rem 1rem; }
    .doc-metadata { flex-direction: column; gap: 0.4rem; }
}
