/* AI for Defenders — site styles.
   Consumes brand tokens from brand/tokens.css (loaded first). Every color,
   font, and most spacing references var(--afd-*). Dark-mode only. */

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(900px 520px at 82% -8%, color-mix(in srgb, var(--afd-cyan) 12%, transparent), transparent 60%),
    radial-gradient(720px 520px at 2% 108%, color-mix(in srgb, var(--afd-amber) 9%, transparent), transparent 55%),
    var(--afd-bg-base);
  background-attachment: fixed;
  color: var(--afd-text-primary);
  font-family: var(--afd-font-body);
  line-height: 1.6;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
.grain { position: fixed; inset: 0; pointer-events: none; opacity: 0.025; z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.wrap { max-width: 1040px; margin: 0 auto; padding: 0 var(--afd-space-8); position: relative; z-index: 2; }

/* Wordmark — canonical treatment from brand/preview.html */
.wm { font-family: var(--afd-font-display); font-weight: 700; letter-spacing: -0.03em; line-height: 1; }
.wm .ai { color: var(--afd-cyan); }
.wm .for { color: var(--afd-text-muted); font-weight: 500; }
a.wm-link { text-decoration: none; color: var(--afd-text-primary); }

/* Nav */
.site-nav { display: flex; align-items: center; justify-content: space-between;
  padding: var(--afd-space-6) 0; position: relative; z-index: 2; }
.site-nav .wm { font-size: var(--afd-size-xl); }
.site-nav .links { display: flex; gap: var(--afd-space-6); font-family: var(--afd-font-mono);
  font-size: var(--afd-size-xs); letter-spacing: .12em; text-transform: uppercase; }
.site-nav .links a { color: var(--afd-text-muted); text-decoration: none; transition: color .2s ease; }
.site-nav .links a:hover, .site-nav .links a.active { color: var(--afd-cyan); }

.eyebrow { font-family: var(--afd-font-mono); font-size: var(--afd-size-xs);
  letter-spacing: .22em; text-transform: uppercase; color: var(--afd-text-muted);
  display: flex; align-items: center; gap: var(--afd-space-3); margin-bottom: var(--afd-space-6); }
.eyebrow::before { content: ''; width: 28px; height: 1px; background: var(--afd-cyan); }

/* Hero */
.hero { padding: var(--afd-space-16) 0 var(--afd-space-12); }
.hero .wm { font-size: clamp(2.75rem, 9vw, 5.5rem); }
.hero .tagline { font-family: var(--afd-font-display); font-size: var(--afd-size-2xl);
  color: var(--afd-text-secondary); font-weight: 400; margin-top: var(--afd-space-6); letter-spacing: -0.01em; }
.hero .mission { font-size: var(--afd-size-lg); color: var(--afd-text-secondary);
  max-width: 640px; margin-top: var(--afd-space-6); }
.hero .meta { display: flex; align-items: center; gap: var(--afd-space-4); margin-top: var(--afd-space-8); flex-wrap: wrap; }
.badge { font-family: var(--afd-font-mono); font-size: var(--afd-size-sm); font-weight: 500;
  color: var(--afd-text-primary); background: var(--afd-cyan-dim);
  padding: var(--afd-space-2) var(--afd-space-4); border-radius: var(--afd-radius-full); }
.btn { font-family: var(--afd-font-body); font-size: var(--afd-size-sm); font-weight: 600;
  color: var(--afd-cyan); text-decoration: none; border: 1px solid var(--afd-cyan-dim);
  padding: var(--afd-space-2) 18px; border-radius: var(--afd-radius-full); transition: border-color .2s ease, color .2s ease; }
.btn:hover { border-color: var(--afd-cyan); }

section.band { padding: var(--afd-space-12) 0; border-top: 1px solid var(--afd-border); }
h2 { font-family: var(--afd-font-display); font-size: var(--afd-size-2xl);
  font-weight: 600; letter-spacing: -0.02em; margin-bottom: var(--afd-space-6); }

/* Why */
.why p { font-size: var(--afd-size-lg); color: var(--afd-text-secondary); max-width: 720px; }
.why p + p { margin-top: var(--afd-space-4); }
.why .pull { color: var(--afd-text-primary); }

/* What — pillar cards */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: var(--afd-space-4); }
.pillar { background: var(--afd-bg-surface); border: 1px solid var(--afd-border);
  border-radius: var(--afd-radius-lg); padding: var(--afd-space-6);
  transition: transform .3s ease, border-color .3s ease; }
.pillar:hover { transform: translateY(-4px); border-color: var(--afd-cyan-dim); }
.pillar .k { font-family: var(--afd-font-mono); font-size: var(--afd-size-xs);
  color: var(--afd-cyan); letter-spacing: .12em; text-transform: uppercase; }
.pillar h3 { font-family: var(--afd-font-display); font-size: var(--afd-size-lg);
  font-weight: 600; margin: var(--afd-space-3) 0; letter-spacing: -0.01em; }
.pillar p { color: var(--afd-text-secondary); font-size: var(--afd-size-sm); }
.pillar.soon .k { color: var(--afd-amber); }

/* Episode teaser card (also reused in episode lists) */
.card { background: var(--afd-bg-surface); border: 1px solid var(--afd-border);
  border-radius: var(--afd-radius-lg); padding: var(--afd-space-8); max-width: 580px;
  position: relative; overflow: hidden; }
.card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--afd-gradient-signature); }
.card .epnum { font-family: var(--afd-font-mono); font-size: var(--afd-size-xs);
  color: var(--afd-cyan); letter-spacing: .15em; text-transform: uppercase; }
.card .eptitle { font-family: var(--afd-font-display); font-size: var(--afd-size-xl);
  font-weight: 600; margin: var(--afd-space-3) 0; letter-spacing: -0.02em; }
.card .epdesc { color: var(--afd-text-secondary); }
.card .epmeta { display: flex; gap: var(--afd-space-4); margin-top: var(--afd-space-6);
  font-family: var(--afd-font-mono); font-size: var(--afd-size-xs); color: var(--afd-text-muted); }
.tag { display: inline-block; font-family: var(--afd-font-mono); font-size: var(--afd-size-xs);
  color: var(--afd-amber); border: 1px solid var(--afd-amber-dim); border-radius: var(--afd-radius-full);
  padding: 2px 10px; margin-top: var(--afd-space-4); }

/* Closing */
.closing { text-align: center; padding: var(--afd-space-16) 0; position: relative; z-index: 2; }
.closing .rally { font-family: var(--afd-font-display); font-size: var(--afd-size-3xl);
  font-weight: 700; letter-spacing: -0.02em;
  background: var(--afd-gradient-signature); -webkit-background-clip: text; background-clip: text; color: transparent; }
.closing .sub { color: var(--afd-text-secondary); margin-top: var(--afd-space-4); font-size: var(--afd-size-lg); }

/* Footer */
.site-footer { border-top: 1px solid var(--afd-border); padding: var(--afd-space-8) 0; margin-top: var(--afd-space-12);
  position: relative; z-index: 2; }
.site-footer .inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
  gap: var(--afd-space-4); color: var(--afd-text-muted); font-size: var(--afd-size-sm); }
.site-footer .wm { font-size: var(--afd-size-base); }

/* Inner pages (about, contact, single, list) */
main { position: relative; z-index: 2; }
.page { padding: var(--afd-space-12) 0 var(--afd-space-8); }
.page-head { margin-bottom: var(--afd-space-8); }
.page-head h1 { font-family: var(--afd-font-display); font-size: var(--afd-size-3xl);
  font-weight: 700; letter-spacing: -0.02em; }
.page-head .lede { color: var(--afd-text-secondary); font-size: var(--afd-size-lg);
  margin-top: var(--afd-space-4); max-width: 680px; }

/* Prose (markdown body) */
.prose { max-width: 680px; color: var(--afd-text-secondary); }
.prose > * + * { margin-top: var(--afd-space-4); }
.prose h2 { font-size: var(--afd-size-xl); color: var(--afd-text-primary); margin-top: var(--afd-space-8); }
.prose h3 { font-family: var(--afd-font-display); font-size: var(--afd-size-lg); color: var(--afd-text-primary);
  font-weight: 600; margin-top: var(--afd-space-6); }
.prose a { color: var(--afd-cyan); text-decoration: none; border-bottom: 1px solid var(--afd-cyan-dim); }
.prose a:hover { border-bottom-color: var(--afd-cyan); }
.prose ul, .prose ol { padding-left: var(--afd-space-6); }
.prose li + li { margin-top: var(--afd-space-2); }
.prose code { font-family: var(--afd-font-mono); font-size: var(--afd-size-sm);
  background: var(--afd-bg-surface); border: 1px solid var(--afd-border);
  border-radius: var(--afd-radius-sm); padding: 1px 6px; color: var(--afd-text-primary); }
.prose blockquote { border-left: 2px solid var(--afd-cyan-dim); padding-left: var(--afd-space-4);
  color: var(--afd-text-muted); }
.prose strong { color: var(--afd-text-primary); }

/* List + empty states (episodes / field notes pre-launch) */
.empty-state { background: var(--afd-bg-surface); border: 1px dashed var(--afd-border);
  border-radius: var(--afd-radius-lg); padding: var(--afd-space-12) var(--afd-space-8); text-align: center; }
.empty-state .k { font-family: var(--afd-font-mono); font-size: var(--afd-size-xs);
  letter-spacing: .15em; text-transform: uppercase; color: var(--afd-cyan); }
.empty-state h3 { font-family: var(--afd-font-display); font-size: var(--afd-size-xl);
  font-weight: 600; margin: var(--afd-space-3) 0; }
.empty-state p { color: var(--afd-text-secondary); max-width: 420px; margin: 0 auto; }
.post-list { display: grid; gap: var(--afd-space-4); }
.post-item { background: var(--afd-bg-surface); border: 1px solid var(--afd-border);
  border-radius: var(--afd-radius-md); padding: var(--afd-space-6); transition: border-color .3s ease; }
.post-item:hover { border-color: var(--afd-cyan-dim); }
.post-item a { color: var(--afd-text-primary); text-decoration: none; font-family: var(--afd-font-display);
  font-size: var(--afd-size-lg); font-weight: 600; letter-spacing: -0.01em; }
.post-item .date { font-family: var(--afd-font-mono); font-size: var(--afd-size-xs); color: var(--afd-text-muted); }
.post-item p { color: var(--afd-text-secondary); font-size: var(--afd-size-sm); margin-top: var(--afd-space-2); }

/* 404 */
.notfound { text-align: center; padding: var(--afd-space-16) 0; }
.notfound .code { font-family: var(--afd-font-mono); color: var(--afd-cyan); letter-spacing: .2em; }
.notfound h1 { font-family: var(--afd-font-display); font-size: var(--afd-size-3xl); font-weight: 700;
  margin: var(--afd-space-4) 0; letter-spacing: -0.02em; }
.notfound p { color: var(--afd-text-secondary); }

/* Entrance */
.rise { opacity: 0; transform: translateY(16px); animation: rise .7s ease forwards; }
.rise:nth-child(2){animation-delay:.06s} .rise:nth-child(3){animation-delay:.12s}
@keyframes rise { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .rise { animation: none; opacity: 1; transform: none; } html { scroll-behavior: auto; } }
