/*
Theme Name: Dead Cyber Society Theme v2.6
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.8
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); }
}

/* ────────────────────────────────────────────────
   DCS Mission Page - human mission update
   Added in v2.2 without altering the homepage template
   ──────────────────────────────────────────────── */
.dcs-mission-page .page-hero__inner { max-width: 920px; }
.dcs-mission-page .page-hero h1 { max-width: 900px; }
.dcs-mission-hero__actions { display:flex; gap:14px; flex-wrap:wrap; margin-top: 30px; }
.dcs-story-card,
.dcs-panel-card {
  border: 1px solid rgba(255,255,255,.11);
  background: linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  border-radius: 26px;
  padding: clamp(26px, 5vw, 54px);
  box-shadow: 0 22px 70px rgba(0,0,0,.28);
}
.dcs-story-card p,
.dcs-panel-card p,
.dcs-home-section p { color: var(--text-secondary); line-height: 1.85; font-size: 1.04rem; }
.dcs-story-card h2,
.dcs-panel-card h3 { margin-bottom: 18px; }
.dcs-human-quote { border-left-color: var(--green); background: rgba(0,255,157,.055); }
.dcs-two-col { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; }
.dcs-harm-grid {
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 36px;
}
.dcs-harm-chip {
  border: 1px solid rgba(0,212,255,.22);
  background: rgba(0,212,255,.06);
  border-radius: 999px;
  padding: 12px 16px;
  text-align:center;
  font-family:'JetBrains Mono', monospace;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color: var(--text-primary);
}
.dcs-center-note { margin-top: 34px; text-align:center; }
.dcs-center-note p { color: var(--text-secondary); line-height: 1.85; font-size: 1.08rem; }
.dcs-mission-grid { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.dcs-belief-list .principle-item { align-items: flex-start; }
.dcs-home-section h2 { margin-bottom: 22px; }
.dcs-final-declaration h2 { font-size: clamp(2.2rem, 6vw, 5.2rem); text-transform:uppercase; margin-bottom: 18px; }
.dcs-final-declaration p { color: var(--text-secondary); font-size: 1.12rem; }

@media (max-width: 900px) {
  .dcs-two-col,
  .dcs-mission-grid { grid-template-columns: 1fr; }
  .dcs-harm-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .dcs-mission-hero__actions { flex-direction: column; align-items: stretch; }
  .dcs-harm-grid { grid-template-columns: 1fr; }
  .dcs-story-card,
  .dcs-panel-card { border-radius: 20px; }
}

/* Mission harm glossary interaction - v2.4 */
button.dcs-harm-chip { width:100%; cursor:pointer; appearance:none; transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease; }
button.dcs-harm-chip:hover,
button.dcs-harm-chip:focus-visible { transform:translateY(-2px); border-color:rgba(0,212,255,.58); background:rgba(0,212,255,.11); box-shadow:0 10px 30px rgba(0,212,255,.08); outline:none; }
button.dcs-harm-chip.is-active { border-color:var(--purple); background:rgba(168,85,247,.14); box-shadow:0 0 0 1px rgba(168,85,247,.16), 0 14px 38px rgba(168,85,247,.1); }
.dcs-harm-info { position:relative; max-width:900px; margin:28px auto 0; padding:clamp(24px,4vw,38px); border:1px solid rgba(168,85,247,.42); border-radius:22px; background:linear-gradient(145deg,rgba(168,85,247,.11),rgba(0,212,255,.045) 55%,rgba(255,255,255,.025)); box-shadow:0 22px 65px rgba(0,0,0,.34); }
.dcs-harm-info[hidden] { display:none; }
.dcs-harm-info.is-opening { animation:dcsHarmReveal .22s ease-out; }
@keyframes dcsHarmReveal { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }
.dcs-harm-info__close { position:absolute; top:14px; right:16px; width:38px; height:38px; border:1px solid rgba(255,255,255,.14); border-radius:50%; background:rgba(255,255,255,.04); color:var(--text-primary); font-size:1.5rem; line-height:1; cursor:pointer; }
.dcs-harm-info__close:hover,.dcs-harm-info__close:focus-visible { border-color:var(--purple); color:var(--purple); outline:none; }
.dcs-harm-info__label { margin-bottom:10px; }
.dcs-harm-info__title { margin:0 48px 12px 0; font-size:clamp(1.35rem,3vw,2rem); }
.dcs-harm-info__definition { color:var(--text-secondary); line-height:1.75; font-size:1.03rem; margin:0; }
.dcs-harm-info__example { margin-top:18px; padding:16px 18px; border-left:3px solid var(--green); background:rgba(0,255,157,.055); color:var(--text-primary); line-height:1.65; }

/* ────────────────────────────────────────────────
   DCS Resources Page - victim support hub
   Added in v2.5 without altering homepage or mission templates
   ──────────────────────────────────────────────── */
.dcs-resources-page .page-hero__inner { max-width: 1180px; }
.dcs-resources-hero__inner { display:grid; grid-template-columns:minmax(0,1.4fr) minmax(280px,.6fr); gap:36px; align-items:center; }
.dcs-resources-lead { max-width:720px; font-size:1.16rem; color:var(--text-secondary); line-height:1.75; }
.dcs-emergency-card { border:1px solid rgba(168,85,247,.48); background:linear-gradient(145deg,rgba(168,85,247,.14),rgba(255,255,255,.035)); border-radius:22px; padding:28px; box-shadow:0 24px 70px rgba(0,0,0,.34); display:flex; gap:18px; align-items:flex-start; }
.dcs-emergency-card__icon { width:62px; height:62px; border:1px solid rgba(168,85,247,.55); border-radius:18px; display:grid; place-items:center; color:var(--purple); font-size:2rem; flex:0 0 auto; }
.dcs-emergency-card h2 { margin:0 0 8px; font-size:1.2rem; color:var(--purple); text-transform:uppercase; }
.dcs-emergency-card p { color:var(--text-secondary); line-height:1.55; margin:0 0 16px; }
.dcs-resource-block .section-head { max-width:880px; margin-bottom:30px; }
.dcs-help-grid { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:16px; }
.dcs-help-card { appearance:none; cursor:pointer; text-align:center; min-height:205px; border:1px solid rgba(255,255,255,.12); background:linear-gradient(160deg,rgba(255,255,255,.065),rgba(255,255,255,.018)); border-radius:16px; padding:22px 18px; color:var(--text-primary); display:flex; flex-direction:column; align-items:center; justify-content:flex-start; gap:10px; box-shadow:0 16px 46px rgba(0,0,0,.22); transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease; }
.dcs-help-card:hover,.dcs-help-card:focus-visible { transform:translateY(-3px); border-color:rgba(168,85,247,.62); box-shadow:0 22px 60px rgba(168,85,247,.12); outline:none; }
.dcs-help-card.is-active { border-color:var(--purple); background:linear-gradient(160deg,rgba(168,85,247,.18),rgba(0,212,255,.055)); }
.dcs-help-icon { width:54px; height:54px; border-radius:16px; display:grid; place-items:center; color:var(--purple); font-size:1.8rem; text-shadow:0 0 16px rgba(168,85,247,.55); }
.dcs-help-card strong { font-size:1rem; line-height:1.22; }
.dcs-help-card span:not(.dcs-help-icon) { color:var(--text-secondary); line-height:1.45; font-size:.86rem; }
.dcs-help-card em { margin-top:auto; font-style:normal; color:var(--purple); font-size:1.4rem; }
.dcs-resource-info { position:relative; max-width:980px; margin:28px auto 0; padding:clamp(24px,4vw,38px); border:1px solid rgba(168,85,247,.45); border-radius:22px; background:linear-gradient(145deg,rgba(168,85,247,.12),rgba(0,212,255,.045) 55%,rgba(255,255,255,.026)); box-shadow:0 24px 72px rgba(0,0,0,.35); }
.dcs-resource-info[hidden] { display:none; }
.dcs-resource-info.is-opening { animation:dcsHarmReveal .22s ease-out; }
.dcs-resource-info__close { position:absolute; top:14px; right:16px; width:38px; height:38px; border:1px solid rgba(255,255,255,.14); border-radius:50%; background:rgba(255,255,255,.04); color:var(--text-primary); font-size:1.5rem; line-height:1; cursor:pointer; }
.dcs-resource-info__close:hover,.dcs-resource-info__close:focus-visible { border-color:var(--purple); color:var(--purple); outline:none; }
.dcs-resource-info h3 { margin:0 48px 12px 0; font-size:clamp(1.35rem,3vw,2rem); }
.dcs-resource-info p { color:var(--text-secondary); line-height:1.75; font-size:1.02rem; }
.dcs-resource-steps { margin-top:18px; padding:18px 20px; border-left:3px solid var(--green); background:rgba(0,255,157,.055); color:var(--text-primary); }
.dcs-resource-steps ul { margin:10px 0 0 18px; color:var(--text-secondary); line-height:1.7; }
.dcs-pathway-card { margin-top:28px; border:1px solid rgba(168,85,247,.45); background:linear-gradient(90deg,rgba(168,85,247,.11),rgba(0,212,255,.035)); border-radius:18px; padding:26px; display:flex; gap:28px; align-items:center; justify-content:space-between; }
.dcs-pathway-card h3 { margin:0 0 8px; color:var(--purple); }
.dcs-pathway-card p { color:var(--text-secondary); line-height:1.65; margin:0; max-width:700px; }
.dcs-services-grid { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:16px; }
.dcs-service-card { border:1px solid rgba(255,255,255,.12); background:linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.018)); border-radius:16px; padding:22px 18px; text-align:center; min-height:245px; display:flex; flex-direction:column; align-items:center; gap:10px; }
.dcs-service-icon { font-size:2.1rem; margin-bottom:4px; }
.dcs-service-icon.purple{color:var(--purple)} .dcs-service-icon.yellow{color:var(--yellow)} .dcs-service-icon.green{color:var(--green)} .dcs-service-icon.blue{color:var(--blue)}
.dcs-service-card h3 { font-size:1rem; margin:0; }
.dcs-service-card p { color:var(--text-secondary); line-height:1.55; font-size:.86rem; margin:0; }
.dcs-status { margin-top:auto; border:1px solid rgba(255,255,255,.18); border-radius:6px; padding:6px 9px; font-family:'JetBrains Mono',monospace; font-size:.68rem; text-transform:uppercase; letter-spacing:.05em; }
.dcs-status--green{color:var(--green);border-color:rgba(0,255,157,.45);background:rgba(0,255,157,.06)}
.dcs-status--yellow{color:var(--yellow);border-color:rgba(255,204,0,.45);background:rgba(255,204,0,.06)}
.dcs-status--blue{color:var(--blue);border-color:rgba(0,212,255,.45);background:rgba(0,212,255,.06)}
.dcs-status--muted{color:var(--text-secondary);border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.04)}
.dcs-check-list { list-style:none; margin:22px 0 26px; padding:0; }
.dcs-check-list li { position:relative; padding-left:28px; color:var(--text-secondary); line-height:1.75; }
.dcs-check-list li::before { content:'✓'; position:absolute; left:0; color:var(--purple); }
.dcs-silent-card { border-color:rgba(255,70,70,.55); background:linear-gradient(145deg,rgba(255,70,70,.085),rgba(255,255,255,.02)); }
.dcs-silent-card .section-label,.dcs-silent-card h2 { color:#ff6464; }
.dcs-silent-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:22px; margin-top:22px; }
.dcs-silent-grid > div { border:1px solid rgba(255,255,255,.12); border-radius:14px; padding:18px; background:rgba(0,0,0,.16); }
.dcs-silent-grid h3 { margin:0 0 10px; color:var(--text-primary); text-transform:uppercase; font-size:1rem; }
.dcs-silent-grid p { color:var(--text-secondary); line-height:1.62; font-size:.92rem; }
.btn--danger { background:#c93434; color:#fff; border-color:#ff6464; }
.btn--danger:hover,.btn--danger:focus-visible { background:#e44747; }
.dcs-danger-note { margin-top:18px; color:#ff7777 !important; font-weight:700; }
.dcs-trusted-grid { display:grid; grid-template-columns:repeat(6,minmax(0,1fr)); gap:12px; }
.dcs-trusted-grid a { border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.035); border-radius:10px; padding:16px; color:var(--text-primary); text-decoration:none; font-weight:700; min-height:90px; display:flex; flex-direction:column; justify-content:center; }
.dcs-trusted-grid a:hover,.dcs-trusted-grid a:focus-visible { border-color:var(--purple); outline:none; }
.dcs-trusted-grid span { display:block; margin-top:6px; color:var(--text-secondary); font-size:.8rem; font-weight:400; }
.dcs-privacy-strip { margin-top:16px; border:1px solid rgba(168,85,247,.3); background:rgba(168,85,247,.07); border-radius:12px; padding:16px 18px; color:var(--text-secondary); }
.dcs-privacy-strip strong { color:var(--purple); text-transform:uppercase; margin-right:8px; }

@media (max-width: 1100px) {
  .dcs-help-grid,.dcs-services-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .dcs-trusted-grid { grid-template-columns:repeat(3,minmax(0,1fr)); }
}
@media (max-width: 860px) {
  .dcs-resources-hero__inner,.dcs-silent-grid { grid-template-columns:1fr; }
  .dcs-pathway-card { flex-direction:column; align-items:flex-start; }
}
@media (max-width: 560px) {
  .dcs-help-grid,.dcs-services-grid,.dcs-trusted-grid { grid-template-columns:1fr; }
  .dcs-help-card { min-height:auto; }
  .dcs-emergency-card { flex-direction:column; }
}


/* v2.7 Resources visual polish + Telegram contact hub */
.dcs-resources-page{
  --dcs-violet:#8b5cf6;
  --dcs-purple:#a855f7;
  --dcs-yellow:#f6d84a;
  --dcs-green:#55e6a5;
  --dcs-blue:#55b7ff;
}
.dcs-resources-hero{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid rgba(168,85,247,.28);
  background:
    radial-gradient(circle at 18% 28%,rgba(139,92,246,.24),transparent 34%),
    radial-gradient(circle at 82% 24%,rgba(85,183,255,.12),transparent 30%),
    linear-gradient(135deg,#090713 0%,#11101c 52%,#08070e 100%);
}
.dcs-resources-hero .page-hero__bg{
  opacity:.55;
  background-image:
    linear-gradient(rgba(168,85,247,.055) 1px,transparent 1px),
    linear-gradient(90deg,rgba(168,85,247,.055) 1px,transparent 1px);
  background-size:34px 34px;
  mask-image:linear-gradient(to bottom,#000,transparent);
}
.dcs-resources-hero__inner{min-height:560px;align-items:center;gap:52px}
.dcs-resources-hero h1{
  font-size:clamp(3.7rem,8vw,7.6rem);
  letter-spacing:-.055em;
  line-height:.86;
  text-transform:uppercase;
  text-shadow:0 0 35px rgba(139,92,246,.18);
}
.dcs-resources-lead{max-width:760px;font-size:clamp(1.1rem,2vw,1.45rem);line-height:1.65}
.dcs-emergency-card{
  border:1px solid rgba(246,216,74,.42);
  background:linear-gradient(145deg,rgba(246,216,74,.10),rgba(14,12,24,.92));
  box-shadow:0 24px 80px rgba(0,0,0,.38),0 0 34px rgba(246,216,74,.07);
  border-radius:24px;padding:30px;
}
.dcs-resource-block{position:relative}
.dcs-help-grid{gap:18px}
.dcs-help-card{
  min-height:210px;border-radius:20px;padding:24px;
  background:linear-gradient(155deg,rgba(28,24,43,.98),rgba(12,11,20,.98));
  border:1px solid rgba(168,85,247,.22);
  box-shadow:0 16px 38px rgba(0,0,0,.22);
  transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;
}
.dcs-help-card:hover,.dcs-help-card:focus-visible{
  transform:translateY(-4px);
  border-color:rgba(168,85,247,.72);
  box-shadow:0 22px 48px rgba(0,0,0,.34),0 0 28px rgba(139,92,246,.13);
}
.dcs-help-card:nth-child(4n+2){border-top-color:rgba(246,216,74,.62)}
.dcs-help-card:nth-child(4n+3){border-top-color:rgba(85,230,165,.62)}
.dcs-help-card:nth-child(4n+4){border-top-color:rgba(85,183,255,.62)}
.dcs-help-icon{
  width:46px;height:46px;display:grid;place-items:center;border-radius:13px;
  background:rgba(139,92,246,.14);border:1px solid rgba(168,85,247,.32);
}
.dcs-resource-info{
  margin-top:24px;border-radius:22px;padding:30px;
  border:1px solid rgba(168,85,247,.45);
  background:linear-gradient(145deg,rgba(34,27,55,.98),rgba(11,10,18,.98));
  box-shadow:0 20px 60px rgba(0,0,0,.35),0 0 32px rgba(139,92,246,.09);
}
.dcs-pathway-card{
  margin-top:34px;border-radius:24px;padding:30px;
  background:linear-gradient(120deg,rgba(139,92,246,.16),rgba(85,183,255,.07),rgba(15,13,24,.95));
  border:1px solid rgba(168,85,247,.3);
}
.dcs-services-grid{gap:20px}
.dcs-service-card{
  border-radius:20px;padding:26px;
  background:linear-gradient(150deg,rgba(27,24,39,.98),rgba(11,10,17,.98));
  box-shadow:0 16px 42px rgba(0,0,0,.22);
}
.dcs-contact-hub{
  position:relative;
  background:
    radial-gradient(circle at 12% 20%,rgba(139,92,246,.16),transparent 28%),
    radial-gradient(circle at 88% 72%,rgba(85,230,165,.08),transparent 28%),
    #0b0a11;
  border-top:1px solid rgba(168,85,247,.18);
  border-bottom:1px solid rgba(168,85,247,.18);
}
.dcs-contact-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin-top:30px;
}
.dcs-contact-card{
  position:relative;overflow:hidden;border-radius:24px;padding:32px;
  background:linear-gradient(145deg,rgba(31,26,47,.98),rgba(12,11,19,.98));
  border:1px solid rgba(168,85,247,.32);
  box-shadow:0 22px 60px rgba(0,0,0,.32);
}
.dcs-contact-card--community{border-color:rgba(85,230,165,.30)}
.dcs-contact-card__icon{
  width:58px;height:58px;display:grid;place-items:center;margin-bottom:22px;
  border-radius:18px;font-size:1.55rem;background:rgba(139,92,246,.15);
  border:1px solid rgba(168,85,247,.34);
}
.dcs-contact-card--community .dcs-contact-card__icon{
  background:rgba(85,230,165,.10);border-color:rgba(85,230,165,.28);
}
.dcs-contact-card h3{font-size:clamp(1.45rem,2.4vw,2rem);margin:.35rem 0 .7rem}
.dcs-contact-card p:not(.section-label){max-width:58ch;line-height:1.65;margin-bottom:22px}
.dcs-device-warning{
  display:flex;gap:18px;align-items:flex-start;margin-top:22px;padding:20px 22px;
  border-radius:16px;background:rgba(246,216,74,.075);border:1px solid rgba(246,216,74,.3);
}
.dcs-device-warning strong{color:var(--dcs-yellow);white-space:nowrap}
.dcs-device-warning span{line-height:1.55}
.dcs-two-col{gap:24px}
.dcs-panel-card{border-radius:24px;box-shadow:0 20px 55px rgba(0,0,0,.25)}
.dcs-silent-card{
  border:1px solid rgba(255,82,82,.5);
  background:linear-gradient(150deg,rgba(88,20,31,.34),rgba(15,11,18,.98));
  box-shadow:0 22px 60px rgba(0,0,0,.35),0 0 34px rgba(255,82,82,.07);
}
.dcs-trusted-grid a{
  border-radius:16px;transition:transform .2s ease,border-color .2s ease,background .2s ease;
}
.dcs-trusted-grid a:hover{transform:translateY(-3px);border-color:rgba(168,85,247,.58);background:rgba(139,92,246,.08)}
.dcs-privacy-strip{border-radius:16px}

@media (max-width: 820px){
  .dcs-resources-hero__inner{min-height:auto;gap:28px}
  .dcs-contact-grid{grid-template-columns:1fr}
  .dcs-device-warning{flex-direction:column;gap:8px}
  .dcs-device-warning strong{white-space:normal}
}

/* v2.8 Equal private contact choices */
.dcs-private-contact-list{display:grid;gap:12px;margin-top:22px}
.dcs-person-contact{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;border-radius:16px;background:rgba(8,7,14,.58);border:1px solid rgba(168,85,247,.22)}
.dcs-person-contact>div{display:grid;gap:4px}
.dcs-person-contact strong{font-size:1rem}
.dcs-person-contact span{font-size:.88rem;opacity:.76}
.dcs-person-contact .btn{flex:0 0 auto}
@media(max-width:620px){.dcs-person-contact{align-items:stretch;flex-direction:column}.dcs-person-contact .btn{width:100%;text-align:center}}
