/* ── Glossary ──────────────────────────────────────────────────────────────
   Two page types, both build-generated by tooling/glossary.js from the
   committed content/glossary/<slug>.json records (the CMS-ready seam):
     • the index  (/glossary/)          — hero + A–Z jump nav + alphabetical list
     • a term page (/glossary/<slug>/)  — breadcrumb + title + summary + article
   Dark theme, sitting on the site's --almost-black body. Term pages reuse the
   blog .post / .post-body reading column (css/blog.css) for the article body. */

/* ── Shared section head (index hero) ─────────────────────────────────────── */
.glossary-head {
  padding: 96px 38px 40px;
}

.glossary-head__eyebrow {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 22px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--orange);
}
.glossary-head__eyebrow::before {
  content: '';
  width: 10px;
  height: 10px;
  background: var(--orange);
  display: inline-block;
}

.glossary-head__title {
  font-family: var(--font-pixel);
  font-size: 64px;
  font-weight: 400;
  line-height: 1.04;
  letter-spacing: -0.02em;
  color: var(--white);
  margin: 0 0 20px;
}

.glossary-head__intro {
  font-family: var(--font-sans);
  font-size: 20px;
  font-weight: 300;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.7);
  max-width: 640px;
  margin: 0;
}

/* ── A–Z jump navigation ──────────────────────────────────────────────────── */
.glossary-az {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0;
  padding: 0 38px 28px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.glossary-az__link,
.glossary-az__empty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  font-family: var(--font-mono);
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}
.glossary-az__link {
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.18);
}
.glossary-az__link:hover {
  color: var(--black);
  background: var(--orange);
  border-color: var(--orange);
}
.glossary-az__empty {
  color: rgba(255, 255, 255, 0.22);
  cursor: default;
}

/* ── Alphabetical term list ───────────────────────────────────────────────── */
.glossary-index {
  padding: 16px 38px 96px;
}

.glossary-letter {
  padding: 36px 0 4px;
  scroll-margin-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.glossary-letter:first-child { border-top: 0; }

.glossary-letter__h {
  font-family: var(--font-pixel);
  font-size: 34px;
  font-weight: 400;
  color: var(--orange);
  margin: 0 0 22px;
  line-height: 1;
}

.glossary-terms {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 2px 36px;
}

.glossary-terms a {
  display: block;
  padding: 9px 0;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 300;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.82);
  text-decoration: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: color 0.15s ease, padding-left 0.15s ease;
}
.glossary-terms a:hover {
  color: var(--orange);
  padding-left: 8px;
}

/* ── Term page ────────────────────────────────────────────────────────────── */
/* Reuses .post (top padding) and .post-body (article typography). The header
   block is constrained to the same 720px reading column as .post-body. */
.glossary-term__inner {
  max-width: 720px;
  margin: 0 auto;
}

.glossary-crumb {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 26px;
}
.glossary-crumb a { color: var(--orange); text-decoration: none; }
.glossary-crumb a:hover { text-decoration: underline; }
.glossary-crumb__sep { color: rgba(255, 255, 255, 0.3); }
.glossary-crumb__here { color: rgba(255, 255, 255, 0.55); }

.glossary-term__title {
  font-family: var(--font-pixel);
  font-size: 46px;
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--white);
  margin: 0 0 28px;
}

/* Summary box — the highlighted lead definition (Webflow "Summary box"). */
.glossary-term__summary {
  border-left: 2px solid var(--orange);
  background: rgba(255, 255, 255, 0.04);
  padding: 22px 26px;
  margin-bottom: 8px;
}
.glossary-term__summary p {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 19px;
  font-weight: 300;
  line-height: 1.6;
  color: var(--white);
}
.glossary-term__summary p + p { margin-top: 0.8em; }

/* Article body extras layered on top of .post-body (css/blog.css). */
.glossary-term__body h3 {
  font-family: var(--font-pixel);
  font-size: 21px;
  font-weight: 400;
  color: var(--white);
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin-top: 1.6em;
  margin-bottom: 0;
}

/* Embedded diagrams (Webflow rich-text figures, currently CDN-hosted). */
.glossary-term__body figure {
  margin: 0;
}
.glossary-term__body img {
  max-width: 100%;
  height: auto;
  display: block;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

/* Code samples render as fenced ``` → <pre><code>, which reuses the blog
   .post-body pre / pre code styles (css/blog.css); no extra rule needed here. */

.glossary-term__body ul,
.glossary-term__body ol {
  padding-left: 1.3em;
}
.glossary-term__body li { margin-top: 0.4em; }

.glossary-term__body table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
}
.glossary-term__body th,
.glossary-term__body td {
  border: 1px solid rgba(255, 255, 255, 0.15);
  padding: 10px 12px;
  text-align: left;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .glossary-head { padding: 64px 20px 32px; }
  .glossary-head__title { font-size: 44px; }
  .glossary-head__intro { font-size: 17px; }
  .glossary-az { padding: 0 20px 24px; margin: 0; }
  .glossary-index { padding: 8px 20px 72px; }
  .glossary-terms { grid-template-columns: 1fr; }
  .glossary-term__title { font-size: 34px; }
}
