/*
Theme Name: Dead Cyber Society Theme v2.1
Theme URI: https://deadcybersociety.org
Author: Dead Cyber Society
Description: Official Dead Cyber Society WordPress theme with DCS branding, safety feed, member cards and neon tickers.
Version: 2.1
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: dead-cyber-society
*/

/* ═══════════════════════════════════════════════════
   DEAD CYBER SOCIETY — Global Stylesheet
   OSINT · Free Speech · Accountability
   ═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

/* ─── 1. Custom Properties ──────────────────────── */

:root {
  /* Backgrounds — soft charcoal, not pure black */
  --bg-base:    #0b0b14;
  --bg-body:    #0f0f1a;
  --bg-raised:  #141421;
  --bg-card:    #191926;
  --bg-surface: #1f1f30;
  --bg-hover:   #252538;

  /* Brand Accents */
  --purple:     #9b5de5;
  --purple-lt:  #c084fc;
  --purple-dk:  #7c3aed;
  --green:      #3dd68c;
  --green-lt:   #6ee7a8;
  --yellow:     #f5c842;
  --yellow-lt:  #fde68a;
  --blue:       #4a9eff;
  --blue-lt:    #93c5fd;
  --pink:       #e040fb; /* signature brand — use sparingly */

  /* Text */
  --text-primary:   #e6e6f2;
  --text-secondary: #9898b8;
  --text-muted:     #5a5a7a;
  --text-link:      var(--purple-lt);

  /* Borders */
  --border:      rgba(155, 93, 229, 0.14);
  --border-md:   rgba(155, 93, 229, 0.32);
  --border-lg:   rgba(155, 93, 229, 0.55);

  /* Glows / Shadows */
  --glow-purple: 0 0 28px rgba(155, 93, 229, 0.22);
  --glow-green:  0 0 24px rgba(61, 214, 140, 0.18);
  --shadow-card: 0 4px 28px rgba(0, 0, 0, 0.45);

  /* Layout */
  --nav-height:   64px;
  --section-gap:  96px;
  --card-radius:  10px;

  /* Transitions */
  --t-fast: 150ms ease;
  --t-base: 250ms ease;
  --t-slow: 400ms ease;
}

/* ─── 2. Reset & Base ───────────────────────────── */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  background-color: var(--bg-body);
  color: var(--text-primary);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  line-height: 1.7;
  padding-top: var(--nav-height);
  overflow-x: hidden;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--text-link);
  text-decoration: none;
  transition: color var(--t-fast);
}

a:hover { color: var(--purple-lt); }

ul { list-style: none; }

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

input, textarea, select { font-family: inherit; }

/* ─── 3. Typography ─────────────────────────────── */

h1, h2, h3, h4, h5, h6 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  line-height: 1.15;
  color: var(--text-primary);
}

h1 { font-size: clamp(2.4rem, 5vw, 4rem); letter-spacing: 0.02em; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); letter-spacing: 0.02em; }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.15rem; }

p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

.mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.875em;
}

.text-purple { color: var(--purple); }
.text-green  { color: var(--green);  }
.text-yellow { color: var(--yellow); }
.text-blue   { color: var(--blue);   }
.text-muted  { color: var(--text-secondary); }

/* ─── 4. Layout Utilities ───────────────────────── */

.container {
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 28px;
}

.container--sm { max-width: 760px; }

.section        { padding: var(--section-gap) 0; }
.section--sm    { padding: 64px 0; }
.section--xs    { padding: 40px 0; }

.section--dark {
  background: var(--bg-raised);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

.text-center { text-align: center; }

.mt-8  { margin-top:  8px;  }
.mt-16 { margin-top:  16px; }
.mt-24 { margin-top:  24px; }
.mt-32 { margin-top:  32px; }
.mt-48 { margin-top:  48px; }

/* ─── 5. Ticker ─────────────────────────────────── */

.ticker-wrap {
  background: var(--bg-base);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  padding: 9px 0;
}

.ticker-track {
  display: inline-flex;
  white-space: nowrap;
  animation: ticker-scroll 55s linear infinite;
  will-change: transform;
}

.ticker-wrap:hover .ticker-track { animation-play-state: paused; }

.ticker-item {
  padding: 0 28px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  text-transform: uppercase;
}

.ticker-item .dot {
  color: var(--purple);
  margin: 0 10px;
}

@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ─── 6. Navigation ─────────────────────────────── */

.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  height: var(--nav-height);
  background: rgba(11, 11, 20, 0.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 28px;
  gap: 24px;
}

.nav__logo {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.07em;
  color: var(--text-primary);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.nav__logo .accent { color: var(--purple); }

.nav__logo-badge {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.58rem;
  background: var(--purple);
  color: #fff;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.06em;
}

.nav__links {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
  justify-content: center;
}

.nav__links a {
  font-size: 0.865rem;
  font-weight: 500;
  color: var(--text-secondary);
  padding: 6px 13px;
  border-radius: 6px;
  transition: color var(--t-fast), background var(--t-fast);
  letter-spacing: 0.025em;
  white-space: nowrap;
}

.nav__links a:hover,
.nav__links a.active {
  color: var(--text-primary);
  background: rgba(155, 93, 229, 0.1);
}

.nav__links a.active { color: var(--purple-lt); }

.nav__cta { flex-shrink: 0; }

.nav__toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  padding: 8px;
  cursor: pointer;
  flex-shrink: 0;
}

.nav__toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--text-secondary);
  border-radius: 2px;
  transition: transform var(--t-base), opacity var(--t-base), background var(--t-base);
}

.nav__toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav__toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav__toggle.open span { background: var(--purple-lt); }

/* Mobile Drawer */
.nav__drawer {
  display: none;
  position: fixed;
  top: var(--nav-height);
  left: 0; right: 0; bottom: 0;
  background: var(--bg-base);
  border-top: 1px solid var(--border);
  padding: 28px;
  z-index: 199;
  overflow-y: auto;
  flex-direction: column;
  gap: 4px;
}

.nav__drawer.open { display: flex; }

.nav__drawer a {
  display: block;
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--text-secondary);
  padding: 14px 16px;
  border-radius: 8px;
  transition: color var(--t-fast), background var(--t-fast);
  letter-spacing: 0.04em;
}

.nav__drawer a:hover,
.nav__drawer a.active {
  color: var(--purple-lt);
  background: rgba(155, 93, 229, 0.08);
}

.nav__drawer .drawer-cta {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}

/* ─── 7. Buttons ────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 24px;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  transition: all var(--t-base);
  white-space: nowrap;
  cursor: pointer;
  border: none;
  font-family: inherit;
  text-decoration: none;
  line-height: 1;
}

.btn--primary {
  background: var(--purple);
  color: #fff;
}
.btn--primary:hover {
  background: var(--purple-dk);
  color: #fff;
  box-shadow: var(--glow-purple);
  transform: translateY(-1px);
}

.btn--outline {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-md);
}
.btn--outline:hover {
  border-color: var(--purple);
  color: var(--purple-lt);
  background: rgba(155, 93, 229, 0.07);
  transform: translateY(-1px);
}

.btn--green {
  background: rgba(61, 214, 140, 0.1);
  color: var(--green);
  border: 1px solid rgba(61, 214, 140, 0.28);
}
.btn--green:hover {
  background: rgba(61, 214, 140, 0.17);
  color: var(--green-lt);
  box-shadow: var(--glow-green);
  transform: translateY(-1px);
}

.btn--ghost {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border);
}
.btn--ghost:hover {
  border-color: var(--border-md);
  color: var(--text-primary);
}

.btn--sm  { padding: 7px 16px; font-size: 0.82rem; }
.btn--lg  { padding: 14px 32px; font-size: 0.975rem; }

/* ─── 8. Cards ──────────────────────────────────── */

.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  padding: 28px;
  transition: border-color var(--t-base), box-shadow var(--t-base);
}

.card:hover {
  border-color: var(--border-md);
  box-shadow: var(--glow-purple);
}

.card--surface   { background: var(--bg-surface); }
.card--highlight { border-color: var(--border-md); }

/* ─── 9. Badges ─────────────────────────────────── */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 100px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.badge--purple { background: rgba(155, 93, 229, 0.14); color: var(--purple-lt); border: 1px solid rgba(155, 93, 229, 0.28); }
.badge--green  { background: rgba(61, 214, 140, 0.11); color: var(--green-lt);  border: 1px solid rgba(61, 214, 140, 0.22); }
.badge--yellow { background: rgba(245, 200, 66, 0.11); color: var(--yellow-lt); border: 1px solid rgba(245, 200, 66, 0.22); }
.badge--blue   { background: rgba(74, 158, 255, 0.11); color: var(--blue-lt);   border: 1px solid rgba(74, 158, 255, 0.22); }

/* ─── 10. Terminal Widget ────────────────────────── */

.terminal {
  background: #08080f;
  border: 1px solid var(--border-md);
  border-radius: 8px;
  overflow: hidden;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.82rem;
  line-height: 1.85;
}

.terminal__header {
  background: #0d0d1a;
  border-bottom: 1px solid var(--border);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 7px;
}

.terminal__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.terminal__dot--r { background: #ff5f57; }
.terminal__dot--y { background: #febc2e; }
.terminal__dot--g { background: #28c840; }

.terminal__title {
  margin-left: 6px;
  font-size: 0.68rem;
  color: var(--text-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.terminal__body { padding: 20px 22px; }

.terminal__line {
  display: flex;
  gap: 14px;
  align-items: baseline;
}

.t-prompt { color: var(--purple); }
.t-key    { color: var(--text-secondary); min-width: 120px; }
.t-green  { color: var(--green);  }
.t-yellow { color: var(--yellow); }
.t-red    { color: #ff6b6b;       }
.t-blue   { color: var(--blue);   }
.t-dim    { color: var(--text-muted); }
.t-accent { color: var(--purple-lt); }

/* ─── 11. Status Indicators ─────────────────────── */

.status-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 5px;
  flex-shrink: 0;
}

.status-dot--online  { background: var(--green);  box-shadow: 0 0 6px rgba(61, 214, 140, 0.7); }
.status-dot--denied  { background: #ff6b6b;       box-shadow: 0 0 6px rgba(255, 107, 107, 0.7); }
.status-dot--active  { background: var(--yellow); box-shadow: 0 0 6px rgba(245, 200, 66, 0.7); }
.status-dot--live    { background: var(--blue);   box-shadow: 0 0 6px rgba(74, 158, 255, 0.7); }

.pulse-dot { animation: pulse-glow 2s ease-in-out infinite; }

@keyframes pulse-glow {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* ─── 12. Section Labels & Headers ──────────────── */

.section-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--purple);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.section-label::after {
  content: '';
  display: block;
  width: 32px;
  height: 1px;
  background: var(--purple);
  opacity: 0.4;
}

.section-header { margin-bottom: 52px; }

.section-header.centered { text-align: center; }
.section-header.centered .section-label { justify-content: center; }
.section-header.centered .section-label::after { display: none; }
.section-header.centered p { max-width: 560px; margin: 14px auto 0; color: var(--text-secondary); font-size: 1.025rem; }

/* ─── 13. Hero — Home ───────────────────────────── */

.hero {
  position: relative;
  min-height: calc(100vh - var(--nav-height));
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 55% 55% at 72% 50%, rgba(155, 93, 229, 0.09) 0%, transparent 65%),
    radial-gradient(ellipse 35% 50% at 15% 80%, rgba(61, 214, 140, 0.05) 0%, transparent 60%),
    var(--bg-body);
}

.hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(155, 93, 229, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155, 93, 229, 0.04) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}

.hero__content { position: relative; z-index: 1; padding: 80px 0; }

.hero__eyebrow {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.hero__eyebrow::before {
  content: '';
  display: block;
  width: 24px; height: 1px;
  background: var(--green);
}

.hero__title {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(3.2rem, 7.5vw, 6rem);
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: 0.02em;
  margin-bottom: 22px;
}

.hero__sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.8rem;
  letter-spacing: 0.2em;
  color: var(--text-secondary);
  text-transform: uppercase;
  margin-bottom: 24px;
}

.hero__desc {
  font-size: 1.05rem;
  color: var(--text-secondary);
  max-width: 520px;
  line-height: 1.75;
  margin-bottom: 36px;
}

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

.hero__image-wrap {
  position: relative;
  z-index: 1;
}

.hero__image-wrap img {
  border-radius: 12px;
  border: 1px solid var(--border-md);
  box-shadow: var(--shadow-card), var(--glow-purple);
  width: 100%;
}

/* ─── 14. Page Hero (sub-pages) ─────────────────── */

.page-hero {
  position: relative;
  padding: 72px 0 60px;
  background: var(--bg-raised);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.page-hero__bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 55% 100% at 0% 50%, rgba(155, 93, 229, 0.07) 0%, transparent 65%);
  pointer-events: none;
}

.page-hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(155, 93, 229, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155, 93, 229, 0.025) 1px, transparent 1px);
  background-size: 44px 44px;
}

.page-hero__inner {
  position: relative;
  z-index: 1;
}

.page-hero h1 {
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  margin-top: 12px;
  margin-bottom: 16px;
}

.page-hero p {
  font-size: 1.05rem;
  color: var(--text-secondary);
  max-width: 600px;
  line-height: 1.75;
  margin: 0;
}

/* ─── 15. Pillar Icons ──────────────────────────── */

.pillar-icon {
  width: 46px; height: 46px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}

.pillar-icon--purple { background: rgba(155, 93, 229, 0.14); }
.pillar-icon--green  { background: rgba(61, 214, 140, 0.11); }
.pillar-icon--yellow { background: rgba(245, 200, 66, 0.11); }
.pillar-icon--blue   { background: rgba(74, 158, 255, 0.11); }

.pillar-icon svg { width: 22px; height: 22px; }

/* ─── 16. Forms ─────────────────────────────────── */

.form-group { margin-bottom: 20px; }

.form-label {
  display: block;
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: 8px;
  letter-spacing: 0.03em;
}

.form-control {
  width: 100%;
  padding: 11px 16px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text-primary);
  font-size: 0.9rem;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  outline: none;
  -webkit-appearance: none;
}

.form-control:focus {
  border-color: var(--purple);
  box-shadow: 0 0 0 3px rgba(155, 93, 229, 0.12);
}

.form-control::placeholder { color: var(--text-muted); }

textarea.form-control {
  resize: vertical;
  min-height: 130px;
}

.form-status {
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 0.875rem;
  margin-top: 16px;
  display: none;
}

.form-status.show { display: block; }

.form-status--success {
  background: rgba(61, 214, 140, 0.1);
  border: 1px solid rgba(61, 214, 140, 0.25);
  color: var(--green-lt);
}

.form-status--error {
  background: rgba(255, 107, 107, 0.08);
  border: 1px solid rgba(255, 107, 107, 0.22);
  color: #ff9999;
}

/* ─── 17. Resource Links ────────────────────────── */

.resource-link {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  text-decoration: none;
  color: var(--text-primary);
  transition: all var(--t-base);
}

.resource-link:hover {
  border-color: var(--border-md);
  background: var(--bg-surface);
  color: var(--text-primary);
  transform: translateX(4px);
  box-shadow: var(--glow-purple);
}

.resource-link__icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
  background: var(--bg-surface);
  border: 1px solid var(--border);
}

.resource-link__name {
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 3px;
  color: var(--text-primary);
}

.resource-link__desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.45;
}

.resource-category-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 12px;
  margin-top: 36px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.resource-category-title:first-child { margin-top: 0; }

.resource-category-title::before {
  content: '';
  display: block;
  width: 3px; height: 14px;
  border-radius: 2px;
}

.resource-category-title.purple::before { background: var(--purple); }
.resource-category-title.green::before  { background: var(--green); }
.resource-category-title.yellow::before { background: var(--yellow); }
.resource-category-title.blue::before   { background: var(--blue); }

.resource-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ─── 18. Member Cards ──────────────────────────── */

.member-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  overflow: hidden;
  transition: border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base);
  display: block;
  text-decoration: none;
  color: inherit;
}

.member-card:hover {
  border-color: var(--border-md);
  box-shadow: var(--glow-purple);
  transform: translateY(-3px);
}

.member-card__img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  object-position: top center;
}

.member-card__body { padding: 20px; }

.member-card__handle {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.68rem;
  color: var(--purple-lt);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 5px;
}

.member-card__name {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 6px;
}

.member-card__role {
  font-size: 0.82rem;
  color: var(--text-secondary);
  margin-bottom: 14px;
  line-height: 1.5;
}

/* ─── 19. Download Cards ────────────────────────── */

.download-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  overflow: hidden;
  transition: border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base);
}

.download-card:hover {
  border-color: var(--border-md);
  box-shadow: var(--glow-purple);
  transform: translateY(-3px);
}

.download-card__preview {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-bottom: 1px solid var(--border);
}

.download-card__body { padding: 18px; }

.download-card__title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 5px;
  color: var(--text-primary);
}

.download-card__meta {
  font-size: 0.74rem;
  color: var(--text-muted);
  margin-bottom: 14px;
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.04em;
}

/* ─── 20. CTA Band ──────────────────────────────── */

.cta-band {
  background: var(--bg-raised);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

.cta-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 120% at 50% 50%, rgba(155, 93, 229, 0.05) 0%, transparent 70%);
  pointer-events: none;
}

/* ─── 21. Manifesto / Blockquote ────────────────── */

.manifesto-quote {
  border-left: 3px solid var(--purple);
  padding: 20px 28px;
  background: rgba(155, 93, 229, 0.05);
  border-radius: 0 8px 8px 0;
  font-size: 1.075rem;
  color: var(--text-secondary);
  font-style: italic;
  line-height: 1.8;
  margin: 32px 0;
}

/* ─── 22. Principle List ────────────────────────── */

.principle-list { display: flex; flex-direction: column; gap: 2px; }

.principle-item {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 22px 20px;
  border-radius: 8px;
  border: 1px solid transparent;
  transition: background var(--t-fast), border-color var(--t-fast);
}

.principle-item:hover {
  background: var(--bg-raised);
  border-color: var(--border);
}

.principle-item__num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.7rem;
  color: var(--purple);
  min-width: 28px;
  padding-top: 4px;
  letter-spacing: 0.06em;
}

.principle-item__title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 5px;
  letter-spacing: 0.02em;
}

.principle-item__desc {
  font-size: 0.875rem;
  color: var(--text-secondary);
  line-height: 1.65;
}

/* ─── 23. Footer ────────────────────────────────── */

.footer {
  background: var(--bg-base);
  border-top: 1px solid var(--border);
  padding-top: 60px;
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 52px;
}

.footer__logo {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: 0.07em;
  color: var(--text-primary);
  margin-bottom: 12px;
}

.footer__logo .accent { color: var(--purple); }

.footer__brand p {
  font-size: 0.86rem;
  color: var(--text-secondary);
  line-height: 1.7;
  max-width: 270px;
  margin: 0;
}

.footer__col-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 18px;
}

.footer__links {
  display: flex;
  flex-direction: column;
  gap: 11px;
}

.footer__links a {
  font-size: 0.875rem;
  color: var(--text-secondary);
  transition: color var(--t-fast);
}

.footer__links a:hover { color: var(--purple-lt); }

.footer__bottom {
  border-top: 1px solid var(--border);
  padding: 22px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.footer__copy {
  font-size: 0.75rem;
  color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.04em;
}

.footer__signals {
  display: flex;
  align-items: center;
  gap: 18px;
}

.footer__signal {
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.66rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ─── 24. Scroll Reveal Animations ─────────────── */

@keyframes fade-in-up {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0);    }
}

.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ─── 25. Accessibility ─────────────────────────── */

.skip-link {
  position: absolute;
  top: -100px;
  left: 8px;
  padding: 8px 18px;
  background: var(--purple);
  color: #fff;
  border-radius: 0 0 8px 8px;
  font-weight: 600;
  font-size: 0.875rem;
  z-index: 1000;
  transition: top var(--t-fast);
}

.skip-link:focus { top: 0; color: #fff; }

:focus-visible {
  outline: 2px solid var(--purple);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ─── 26. Responsive ────────────────────────────── */

@media (max-width: 960px) {
  :root { --section-gap: 72px; }

  .grid-3 { grid-template-columns: 1fr 1fr; }
  .grid-4 { grid-template-columns: 1fr 1fr; }

  .footer__grid { grid-template-columns: 1fr 1fr; gap: 36px; }

  .hero-layout { grid-template-columns: 1fr; }
  .hero__image-col { display: none; }
}

@media (max-width: 720px) {
  :root { --section-gap: 60px; }

  .nav__links, .nav__cta { display: none; }
  .nav__toggle { display: flex; }

  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }

  .footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; gap: 10px; }
}

@media (max-width: 480px) {
  :root { --nav-height: 56px; }

  .container { padding: 0 20px; }
  .card { padding: 22px; }

  .hero__actions { flex-direction: column; align-items: flex-start; }
  .btn--lg { padding: 12px 26px; }
}

/* ─── 27. Reduced Motion ────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .ticker-track { animation: none; }
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ─── Editable DCS Members ─────────────────────── */
.dcs-members-grid {
  grid-template-columns: repeat(3, 1fr);
}

.member-profile {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
  gap: 36px;
  align-items: stretch;
  padding: 28px;
  margin-bottom: 36px;
  background: linear-gradient(135deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012));
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.member-profile.reverse {
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.9fr);
}

.member-profile.reverse .member-profile__image { order: 2; }
.member-profile.reverse .member-profile__content { order: 1; }

.member-profile__image img {
  width: 100%;
  height: 100%;
  min-height: 360px;
  max-height: 560px;
  object-fit: cover;
  object-position: top center;
  border-radius: calc(var(--card-radius) - 4px);
  border: 1px solid var(--border-md);
  box-shadow: var(--glow-purple);
}

.member-profile__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.member-profile__handle {
  font-family: 'JetBrains Mono', monospace;
  color: var(--purple-lt);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.78rem;
  margin-bottom: 8px;
}

.member-profile__name {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(2rem, 4vw, 3.1rem);
  line-height: 1;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 14px;
}

.member-profile__role {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 22px;
  color: var(--text-secondary);
}

.member-profile__bio {
  color: var(--text-secondary);
  line-height: 1.78;
  font-size: 0.98rem;
}

.member-profile__bio p { margin: 0 0 14px; }

.member-profile__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 24px;
}

.member-profile__stats > div {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px;
  background: rgba(255,255,255,0.025);
}

.member-stat__value {
  font-family: 'Rajdhani', sans-serif;
  font-size: 1.05rem;
  line-height: 1.15;
  font-weight: 700;
}

.member-stat__label {
  margin-top: 4px;
  font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  font-size: 0.62rem;
}

@media (max-width: 980px) {
  .dcs-members-grid { grid-template-columns: 1fr; }
  .member-profile,
  .member-profile.reverse {
    grid-template-columns: 1fr;
  }
  .member-profile.reverse .member-profile__image,
  .member-profile.reverse .member-profile__content {
    order: initial;
  }
  .member-profile__image img {
    min-height: auto;
    max-height: none;
    aspect-ratio: 3 / 4;
  }
  .member-profile__stats {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================
   DCS v1.0 Header + Sleek Single-Line Tickers + Hero
   ========================================================== */
:root {
  --dcs-black: #030309;
  --dcs-panel: #080815;
  --dcs-blue: #00d4ff;
  --dcs-pink: #ff008c;
  --dcs-purple: #7a00ff;
  --dcs-red: #ff1744;
  --dcs-green: #39ff8f;
  --dcs-white: #f8f8ff;
}
body { padding-top: 0 !important; background: var(--dcs-black); }
.dcs-site-header {
  position: relative;
  z-index: 10;
  background: linear-gradient(180deg, #020207 0%, #060612 100%);
  border-bottom: 1px solid rgba(0, 212, 255, .22);
  box-shadow: 0 16px 50px rgba(0,0,0,.45);
}
.dcs-nav-shell {
  min-height: 126px;
  display: grid;
  grid-template-columns: minmax(320px, 1.1fr) minmax(430px, 1.7fr) auto;
  align-items: center;
  gap: 28px;
  padding: 18px clamp(20px, 3vw, 46px);
}
.dcs-brand { display: flex; align-items: center; gap: 22px; color: var(--dcs-white); min-width: 0; }
.dcs-brand:hover { color: var(--dcs-white); }
.dcs-brand__mark {
  width: 112px; height: 112px; object-fit: contain; flex: 0 0 auto;
  filter: drop-shadow(0 0 14px rgba(0,212,255,.45)) drop-shadow(0 0 18px rgba(255,0,140,.25));
}
.dcs-brand__name {
  font-family: 'Rajdhani', sans-serif; font-size: clamp(1.9rem, 2.8vw, 3.25rem); font-weight: 700;
  letter-spacing: .035em; line-height: .95; text-transform: uppercase; color: #f2f2f2;
  text-shadow: 0 0 12px rgba(255,255,255,.12);
}
.dcs-brand__name::first-letter { color: #fff; }
.dcs-brand__strap { font-family: 'JetBrains Mono', monospace; margin-top: 10px; text-transform: uppercase; letter-spacing: .08em; font-size: .92rem; }
.dcs-brand__strap span:nth-child(1) { color: var(--dcs-pink); }
.dcs-brand__strap span:nth-child(2) { color: var(--dcs-blue); }
.dcs-brand__strap span:nth-child(3) { color: var(--dcs-purple); }
.dcs-main-nav { display:flex; align-items:center; justify-content:center; gap: clamp(12px, 1.35vw, 28px); }
.dcs-main-nav a {
  font-family: 'Rajdhani', sans-serif; color:#f4f4fa; text-transform: uppercase; letter-spacing:.06em; font-weight:700; font-size:1.02rem;
  padding: 10px 2px; border-bottom: 2px solid transparent;
}
.dcs-main-nav a:hover { color: var(--dcs-pink); border-bottom-color: var(--dcs-pink); }
.dcs-mic-button {
  justify-self:end; font-family:'Rajdhani',sans-serif; color:#fff; text-transform:uppercase; font-size:1.15rem; font-weight:700; letter-spacing:.04em;
  border:1px solid rgba(255,0,140,.8); border-radius:7px; padding:15px 28px; box-shadow:0 0 18px rgba(255,0,140,.35), inset 0 0 22px rgba(122,0,255,.18);
}
.dcs-mic-button:hover { color:#fff; background:rgba(255,0,140,.12); box-shadow:0 0 25px rgba(255,0,140,.55); }
.dcs-tickers { border-top:1px solid rgba(0,212,255,.32); }
.dcs-ticker {
  height: 54px; display:flex; align-items:center; overflow:hidden; white-space:nowrap; position:relative;
  font-family:'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing:.045em;
}
.dcs-ticker__label {
  height:100%; display:inline-flex; align-items:center; flex:0 0 auto; padding: 0 24px; font-weight:800; z-index:2;
  border-right:1px solid currentColor; background:rgba(0,0,0,.38);
}
.dcs-ticker--blue { color: var(--dcs-blue); border-bottom:1px solid rgba(0,212,255,.55); box-shadow: inset 0 0 22px rgba(0,212,255,.06); }
.dcs-ticker--red { color: var(--dcs-red); border-bottom:1px solid rgba(255,23,68,.62); box-shadow: inset 0 0 26px rgba(255,23,68,.09); }
.dcs-ticker__window { overflow:hidden; flex:1; height:100%; display:flex; align-items:center; }
.dcs-ticker__track { display:inline-flex; align-items:center; animation: dcsMarquee 48s linear infinite; will-change: transform; white-space: nowrap; }
.dcs-ticker--red .dcs-ticker__track { animation-duration: 58s; }
.dcs-ticker:hover .dcs-ticker__track { animation-play-state: paused; }
.dcs-ticker__item {
  display:inline-flex; align-items:center; color:inherit; padding:0 22px; font-weight:700; font-size:.86rem;
  text-shadow:0 0 8px currentColor, 0 0 18px currentColor;
}
.dcs-ticker__item::after { content:'•'; margin-left: 28px; opacity:.9; }
.dcs-ticker--red .dcs-ticker__item { color:#fff; text-decoration: underline; text-decoration-color: rgba(255,255,255,.55); text-shadow:0 0 8px var(--dcs-red),0 0 16px rgba(255,23,68,.75); }
.dcs-ticker--red .dcs-ticker__item:hover { color:#fff; text-decoration-color:#fff; }
@keyframes dcsMarquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.dcs-hero-v1 {
  min-height: 610px; padding: clamp(54px,6vw,88px) clamp(24px,4vw,78px); position:relative; display:grid;
  grid-template-columns: minmax(300px, .95fr) minmax(360px, .95fr) minmax(260px, .58fr); gap: clamp(28px,4vw,64px); align-items:center;
  background:
    radial-gradient(circle at 56% 50%, rgba(122,0,255,.19), transparent 34%),
    radial-gradient(circle at 70% 52%, rgba(255,0,140,.12), transparent 34%),
    linear-gradient(90deg, #030309 0%, #050513 52%, #030309 100%);
  overflow:hidden;
}
.dcs-hero-v1::before { content:''; position:absolute; inset:0; opacity:.26; background-image:linear-gradient(rgba(0,212,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,0,140,.05) 1px, transparent 1px); background-size:64px 64px; }
.dcs-hero-v1 > * { position:relative; z-index:1; }
.dcs-hero-v1__eyebrow { color: var(--dcs-purple); font-family:'JetBrains Mono',monospace; text-transform:uppercase; letter-spacing:.12em; font-weight:800; margin-bottom: 12px; }
.dcs-hero-v1 h1 { font-size: clamp(3.5rem, 7vw, 7.4rem); text-transform:uppercase; line-height:.88; color:#f5f5f5; text-shadow:0 0 20px rgba(255,255,255,.15); }
.dcs-hero-v1 h1 span { background:linear-gradient(90deg,var(--dcs-pink),#7c5cff,var(--dcs-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.dcs-hero-v1__copy { max-width:620px; color:#e8e8f2; font-size:1.23rem; line-height:1.55; margin-top:24px; }
.dcs-hero-v1__pillars { display:flex; gap:20px; flex-wrap:wrap; margin-top:26px; font-family:'Rajdhani',sans-serif; text-transform:uppercase; font-weight:700; letter-spacing:.07em; font-size:1.18rem; }
.dcs-hero-v1__pillars span:nth-child(1){color:var(--dcs-pink)} .dcs-hero-v1__pillars span:nth-child(2){color:var(--dcs-blue)} .dcs-hero-v1__pillars span:nth-child(3){color:var(--dcs-purple)}
.dcs-hero-v1__actions { display:flex; gap:18px; flex-wrap:wrap; margin-top:34px; }
.dcs-action { color:#fff; border:1px solid; padding:15px 30px; border-radius:7px; font-family:'Rajdhani',sans-serif; font-weight:800; text-transform:uppercase; font-size:1.07rem; letter-spacing:.05em; }
.dcs-action--pink { border-color:var(--dcs-pink); box-shadow:0 0 18px rgba(255,0,140,.35); }
.dcs-action--blue { border-color:var(--dcs-blue); box-shadow:0 0 18px rgba(0,212,255,.32); }
.dcs-action:hover { color:#fff; transform:translateY(-1px); }
.dcs-hero-v1__mark { display:flex; justify-content:center; align-items:center; }
.dcs-hero-v1__mark img { width:min(520px, 100%); filter:drop-shadow(0 0 26px rgba(0,212,255,.30)) drop-shadow(0 0 28px rgba(255,0,140,.20)); }
.dcs-status-card { border:1px solid rgba(255,0,140,.45); background:rgba(6,6,16,.72); padding:28px 32px; box-shadow:0 0 30px rgba(122,0,255,.16); }
.dcs-status-card h2 { color:var(--dcs-pink); font-family:'Rajdhani',sans-serif; font-size:1.6rem; text-transform:uppercase; margin-bottom:18px; }
.dcs-status-card div { display:flex; justify-content:space-between; gap:24px; padding:10px 0; color:#fff; border-bottom:1px dotted rgba(255,255,255,.12); }
.dcs-status-card strong { color:var(--dcs-green); text-transform:uppercase; font-family:'JetBrains Mono',monospace; font-size:.82rem; }
.dcs-status-card strong.live { color:var(--dcs-red); }
.dcs-card-row { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; padding:26px clamp(18px,3vw,36px) 42px; background:#05050d; }
.dcs-feature-card { border:1px solid rgba(122,0,255,.28); background:linear-gradient(180deg, rgba(15,15,30,.95), rgba(5,5,11,.95)); padding:22px; border-radius:10px; color:#e8e8f8; min-height:116px; }
.dcs-feature-card strong { display:block; color:var(--dcs-blue); font-family:'Rajdhani',sans-serif; text-transform:uppercase; font-size:1.25rem; margin-bottom:8px; }
.dcs-feature-card:nth-child(odd) strong { color:var(--dcs-pink); }
.dcs-feature-card span { color:#c8c8d6; font-size:.92rem; line-height:1.45; }
.dcs-feature-card:hover { color:#fff; border-color:var(--dcs-blue); box-shadow:0 0 22px rgba(0,212,255,.18); transform:translateY(-2px); }
@media (max-width: 1180px) {
  .dcs-nav-shell { grid-template-columns: 1fr; text-align:center; justify-items:center; }
  .dcs-main-nav { flex-wrap:wrap; }
  .dcs-mic-button { justify-self:center; }
  .dcs-hero-v1 { grid-template-columns:1fr; text-align:center; }
  .dcs-hero-v1__actions, .dcs-hero-v1__pillars { justify-content:center; }
  .dcs-status-card { max-width:460px; margin:0 auto; width:100%; }
  .dcs-card-row { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 700px) {
  .dcs-brand { flex-direction:column; gap:10px; text-align:center; }
  .dcs-brand__mark { width:88px; height:88px; }
  .dcs-main-nav { gap:8px; }
  .dcs-main-nav a { font-size:.88rem; }
  .dcs-ticker { height:46px; }
  .dcs-ticker__label { padding:0 12px; font-size:.72rem; }
  .dcs-ticker__item { font-size:.72rem; padding:0 14px; }
  .dcs-card-row { grid-template-columns:1fr; }
}


/* Official DCS logo fixes */
.footer__brand-row { display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.footer__logo-mark { width:58px; height:58px; object-fit:contain; filter:drop-shadow(0 0 12px rgba(0,212,255,.45)) drop-shadow(0 0 12px rgba(255,0,140,.35)); }
.dcs-brand__mark { object-fit: contain; }
.site-icon-preview, .dcs-official-logo { object-fit: contain; }


/* DCS Theme v2.0 official logo placement */
.dcs-brand__mark {
  width: 118px;
  height: 118px;
  object-fit: contain;
  filter: drop-shadow(0 0 16px rgba(0,212,255,.42)) drop-shadow(0 0 18px rgba(255,0,140,.34));
}
.dcs-hero-v1__mark img {
  width: min(520px, 42vw);
  max-height: 560px;
  object-fit: contain;
  filter: drop-shadow(0 0 24px rgba(0,212,255,.30)) drop-shadow(0 0 24px rgba(255,0,140,.24));
}
.footer__logo-mark { width: 74px; height: 74px; object-fit: contain; }
@media (max-width: 760px) {
  .dcs-brand__mark { width: 76px; height: 76px; }
  .dcs-hero-v1__mark img { width: min(340px, 80vw); }
}
