/* Shared vocabulary / reference-page layout — "Institutional Density" re-skin.
   Used by ai-stance.html and vocab/acst/index.html (the .vocab-* pattern).
   Loaded after density.css (provides --cn-* tokens). Phase Two static sweep. */

.vocab-main { max-width: 880px; margin: 0 auto; padding: var(--space-lg) var(--space-md) var(--space-2xl); }
.vocab-hero { padding: var(--space-md) 0 var(--space-sm); border-bottom: 1px solid var(--cn-line); margin-bottom: var(--space-lg); }
.vocab-hero h1 { font-family: var(--cn-font-serif); font-weight: 700; font-size: var(--cn-text-display); line-height: 1.1; margin: 0 0 0.6rem; color: var(--cn-ink); }
.vocab-uri { font-family: var(--cn-font-mono); font-size: 0.82rem; color: var(--cn-ink-muted); display: inline-block; margin-bottom: 0.6rem; }
.vocab-hero p.lede, p.lede { font-family: var(--cn-font-serif); font-size: 1.15rem; line-height: 1.6; color: var(--cn-ink); margin: 0; }
.vocab-section { margin: var(--space-lg) 0; }
.vocab-section > h2 { font-family: var(--cn-font-serif); font-weight: 700; font-size: var(--cn-text-h2); margin: 0 0 0.6rem; color: var(--cn-ink); border-bottom: 2px solid var(--cn-bronze); padding-bottom: 0.4rem; }
.vocab-class, .vocab-prop { background: var(--cn-surface); border: 1px solid var(--cn-line); border-radius: var(--cn-radius); padding: var(--space-sm) var(--space-md); margin: var(--space-sm) 0; }
.vocab-class h3, .vocab-prop h3 { margin: 0 0 0.5rem; font-family: var(--cn-font-mono); font-weight: 500; font-size: 1.02rem; color: var(--cn-ink); }
.vocab-class h3 a, .vocab-prop h3 a { color: var(--cn-teal); text-decoration: none; }
.vocab-class h3 a:hover, .vocab-prop h3 a:hover { text-decoration: underline; }
.vocab-meta { font-family: var(--cn-font-mono); font-size: 0.82rem; color: var(--cn-ink-muted); margin: 4px 0 0.5rem; }
.vocab-meta code { font-family: var(--cn-font-mono); padding: 1px 6px; background: var(--cn-canvas); border: 1px solid var(--cn-line); border-radius: var(--cn-radius); color: var(--cn-bronze); }
.vocab-class p, .vocab-prop p { margin: 0; line-height: 1.6; color: var(--cn-ink); }
.lens-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
.lens-card { background: var(--cn-surface); border: 1px solid var(--cn-line); border-left: 3px solid var(--cn-bronze); border-radius: var(--cn-radius); padding: var(--space-sm); }
.lens-card h4 { margin: 0 0 6px; font-family: var(--cn-font-serif); font-size: 1rem; color: var(--cn-ink); }
.lens-card .lens-icon { margin-right: 6px; filter: grayscale(1); }
.lens-card .lens-uri { font-family: var(--cn-font-mono); font-size: 0.76rem; color: var(--cn-ink-muted); display: block; margin-bottom: 8px; }
.lens-card p { font-size: var(--cn-text-small); line-height: 1.5; color: var(--cn-ink-muted); margin: 0; }
pre.example { background: var(--cn-canvas); border: 1px solid var(--cn-line); border-radius: var(--cn-radius); padding: var(--space-sm); font-size: 0.8rem; line-height: 1.55; overflow-x: auto; font-family: var(--cn-font-mono); color: var(--cn-ink); }
pre.example .json-key { color: var(--cn-teal); }
pre.example .json-str { color: var(--cn-bronze); }
.vocab-toc { background: var(--cn-surface); border: 1px solid var(--cn-line); border-left: 3px solid var(--cn-bronze); border-radius: var(--cn-radius); padding: var(--space-sm) var(--space-md); margin: var(--space-sm) 0 var(--space-md); }
.vocab-toc h3 { font-family: var(--cn-font-mono); font-weight: 500; font-size: var(--cn-text-label); text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 0.6rem; color: var(--cn-ink-muted); }
.vocab-toc ol { margin: 0; padding-left: 20px; }
.vocab-toc ol li { margin: 4px 0; }
.vocab-toc a { color: var(--cn-teal); }
.vocab-foot { margin-top: var(--space-lg); padding-top: var(--space-md); border-top: 1px solid var(--cn-line); font-size: var(--cn-text-small); color: var(--cn-ink-muted); }
