/* theme.css - canonical component styling for the Directory Factory.
   Ships byte-identical in BOTH the Engine A and Engine B starters. Both engines emit
   the same canonical class names, so this one stylesheet themes both identically and a
   palette/theme swap (tokens only) reskins both. Uses ONLY var(--token); no literal
   colors. Canonical classes:
   .site-header .brand .brand-mark .nav .container .crumbs .card .card-grid .card .meta
   .profile .aeo-takeaways .aeo-h .aeo-list .authority-sources .cta .label .btn
   .search-box .faq .faq-q .faq-a .site-footer .disclaimer */

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--color-ink);
  background: var(--color-bg);
  line-height: 1.55;
}
a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3 { font-family: var(--font-display); line-height: 1.2; color: var(--color-ink); }

.container { max-width: 1080px; margin: 0 auto; padding: 0 var(--space); }

.site-header {
  background: var(--color-primary);
  color: var(--color-card);
  padding: calc(var(--space) * 0.75) 0;
}
.site-header .container { display: flex; align-items: center; gap: var(--space); flex-wrap: wrap; }
.brand {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 700; font-size: 1.2rem;
  color: var(--color-card);
}
.brand:hover { text-decoration: none; }
.brand-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: var(--radius);
  background: var(--color-accent); color: var(--color-card);
  font-weight: 800; font-size: 0.95rem;
}
.nav { margin-left: auto; display: flex; gap: var(--space); flex-wrap: wrap; }
.nav a { color: var(--color-accent-soft); font-size: 0.92rem; }

.crumbs { font-size: 0.85rem; color: var(--color-muted); margin: var(--space) 0; }
.crumbs a { color: var(--color-muted); }

.card-grid {
  display: grid; gap: var(--space);
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  margin: var(--space) 0;
}
.card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space);
  display: block;
}
.card:hover { border-color: var(--color-accent); text-decoration: none; }
.card h3 { margin: 0 0 4px; font-size: 1.05rem; }
.card .meta { color: var(--color-muted); font-size: 0.85rem; }

.profile {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: calc(var(--space) * 1.5);
  margin: var(--space) 0;
}
.profile h1 { margin-top: 0; }
.profile h2 { font-size: 1.25rem; margin: calc(var(--space) * 1.5) 0 8px; }
.profile .meta { color: var(--color-muted); }

.aeo-takeaways, .authority-sources {
  background: var(--color-accent-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space);
  margin: var(--space) 0;
}
.aeo-h { margin: 0 0 8px; font-size: 1rem; color: var(--color-primary-dark); }
.aeo-list { margin: 0; padding-left: 1.2em; }
.aeo-list li { margin: 4px 0; }
.authority-sources ul { margin: 0; padding-left: 1.2em; }

.cta {
  background: var(--color-primary);
  color: var(--color-card);
  border-radius: var(--radius);
  padding: calc(var(--space) * 1.5);
  margin: calc(var(--space) * 1.5) 0;
}
.cta h2, .cta h3 { color: var(--color-card); margin-top: 0; }
.cta .label {
  font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; opacity: 0.85;
}

.btn {
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-card);
  padding: 10px 18px;
  border-radius: var(--radius);
  font-weight: 600;
  border: none;
}
.btn:hover { background: var(--color-primary-dark); text-decoration: none; }

.search-box { display: flex; gap: 8px; margin: var(--space) 0; }
.search-box input {
  flex: 1; padding: 10px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font-size: 1rem;
}

.faq { margin: var(--space) 0; }
.faq-q { font-weight: 700; margin: var(--space) 0 4px; color: var(--color-ink); }
.faq-a { margin: 0; color: var(--color-muted); }

.site-footer {
  background: var(--color-primary-dark);
  color: var(--color-accent-soft);
  padding: calc(var(--space) * 2) 0;
  margin-top: calc(var(--space) * 2);
  font-size: 0.88rem;
}
.site-footer a { color: var(--color-accent-soft); }
.disclaimer { color: var(--color-muted); font-size: 0.82rem; margin-top: var(--space); }
/* On the dark footer, muted (slate) disclaimer text is illegible; lift contrast. */
.site-footer .disclaimer { color: rgba(255, 255, 255, 0.72); }
