/* Brand Site — shared styles. Consumed by all pages under /brand/. */

/* Font loading. Fonts are served from /brand/fonts/ at runtime (passthrough from brand/fonts/). */
@font-face { font-family: 'Space Grotesk'; src: url('fonts/space-grotesk.woff2') format('woff2'); font-weight: 400 700; font-display: swap; }
@font-face { font-family: 'Space Grotesk'; src: url('fonts/space-grotesk-ext.woff2') format('woff2'); font-weight: 400 700; font-display: swap; unicode-range: U+0100-024F; }
@font-face { font-family: 'Inter';         src: url('fonts/inter.woff2')         format('woff2'); font-weight: 400 600; font-display: swap; }
@font-face { font-family: 'Inter';         src: url('fonts/inter-ext.woff2')     format('woff2'); font-weight: 400 600; font-display: swap; unicode-range: U+0100-024F; }
@font-face { font-family: 'Manrope';       src: url('fonts/manrope.woff2')       format('woff2'); font-weight: 400 800; font-display: swap; }
@font-face { font-family: 'Manrope';       src: url('fonts/manrope-ext.woff2')   format('woff2'); font-weight: 400 800; font-display: swap; unicode-range: U+0100-024F; }
@font-face { font-family: 'JetBrains Mono'; src: url('fonts/jetbrains-mono.woff2')     format('woff2'); font-weight: 400 700; font-display: swap; }
@font-face { font-family: 'JetBrains Mono'; src: url('fonts/jetbrains-mono-ext.woff2') format('woff2'); font-weight: 400 700; font-display: swap; unicode-range: U+0100-024F; }

* { margin: 0; padding: 0; box-sizing: border-box; }
/* Reserve the scrollbar gutter on every page so the centered .container doesn't
   shift horizontally between tall (scrolling) and short (non-scrolling) pages. */
html { scrollbar-gutter: stable; }
body { font-family: var(--font-body); background: var(--color-cream); color: var(--color-text); line-height: 1.6; }
a { color: var(--color-terracotta); }

/* Layout — .container is defined once in css/base.css, token-driven from
   --container-max + --padding-desktop/tablet/mobile. Don't redefine it here
   (Token-Sourcing Rule); it loads before site.css so its values apply. */
section { padding: 60px 0; border-bottom: 1px solid rgba(0,0,0,0.06); }
section:last-child { border-bottom: none; }

/* Header & nav are now the brand `docnav` component (see css/components.css),
   dogfooded via _includes/base.njk. The old bespoke .demo-header / .demo-nav /
   .demo-subnav chrome was removed when the site adopted its own component. */

/* Section headings */
h2 { font-family: var(--font-headline); font-weight: 700; font-size: 22px; color: var(--color-text); margin-bottom: 24px; }
h3 { font-family: var(--font-headline); font-weight: 600; font-size: 14px; color: var(--color-subtle); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; margin-top: 32px; }
h3:first-child { margin-top: 0; }
/* .eyebrow → css/components.css (brand component layer) */

/* Logo strip */
.logo-strip { background: var(--color-black); padding: 48px 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
.logo-strip .container { display: flex; align-items: center; justify-content: center; gap: 60px; }
.logo-strip img { display: block; }

/* Swatches */
.swatches { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
@media (max-width: 640px) { .swatches { grid-template-columns: repeat(2, 1fr); } }
.swatch { border-radius: 12px; overflow: hidden; border: 1px solid rgba(0,0,0,0.06); }
.swatch-color { height: 80px; }
.swatch-info { padding: 10px 12px; background: white; }
.swatch-name { font-family: var(--font-ui); font-weight: 600; font-size: 12px; color: var(--color-text); }
.swatch-hex { font-family: var(--font-mono), monospace; font-size: 11px; color: var(--color-subtle); }
.swatch-token { font-family: var(--font-mono), monospace; font-size: 10px; color: var(--color-muted); }

/* Font samples */
.font-card { background: white; border-radius: 12px; padding: 24px; border: 1px solid rgba(0,0,0,0.06); margin-bottom: 16px; }
.font-card .label { font-family: var(--font-ui); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; color: var(--color-muted); margin-bottom: 8px; }

/* Nav cards */
.nav-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 640px) { .nav-cards { grid-template-columns: 1fr; } }
.nav-card {
  background: white;
  border-radius: 12px;
  padding: 28px;
  border: 1px solid rgba(0,0,0,0.06);
  box-shadow: 0 1px 3px rgba(0,0,0,0.03);
  text-decoration: none;
  display: block;
  transition: border-color 0.2s;
}
.nav-card:hover { border-color: var(--color-terracotta); }
.nav-card h4 { font-family: var(--font-headline); font-weight: 600; font-size: 18px; color: var(--color-text); margin-bottom: 6px; }
.nav-card p { font-size: 14px; color: var(--color-body); line-height: 1.5; }

/* ===== Identity page additions ===== */
.swatch-role { font-family: var(--font-body); font-size: 11px; color: var(--color-subtle); margin-top: 4px; line-height: 1.4; }

.type-table, .spec-table { width: 100%; border-collapse: collapse; font-family: var(--font-body); font-size: 13px; }
.type-table thead th, .spec-table thead th {
  font-family: var(--font-ui); font-weight: 700; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.5px; color: var(--color-text);
  text-align: left; padding: 10px 12px; border-bottom: 2px solid var(--color-terracotta);
}
.type-table tbody td, .spec-table tbody td {
  padding: 10px 12px; color: var(--color-body);
  border-bottom: 1px solid rgba(0,0,0,0.04); vertical-align: top;
}
.type-table tbody tr:nth-child(even) td { background: rgba(0,0,0,0.015); }
.type-table .role-name { font-weight: 600; color: var(--color-text); }
.type-table .font-name { font-family: var(--font-mono), monospace; font-size: 12px; }
.type-table .color-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.spec-table code { font-family: var(--font-mono), monospace; font-size: 12px; background: rgba(0,0,0,0.04); padding: 2px 6px; border-radius: 3px; }

.voice-card { background: white; border-radius: 12px; padding: 28px; border: 1px solid rgba(0,0,0,0.06); margin-bottom: 20px; }

/* ===== Components page — demo scaffolding only =====
   The component classes themselves (.btn-*, .card-*, .badge, .tag*, .divider-*,
   .tldr-*, .callout-*, .eyebrow) now live in css/components.css — the single
   source of truth, mirrored by components.meta.ts. Only the gallery's demo
   layout wrappers remain here. */
.badge { margin-bottom: 12px; }   /* gallery context: badge sits above a title */
.dark-strip { background: var(--color-black); padding: 32px; border-radius: 12px; display: flex; align-items: center; gap: 16px; margin-top: 24px; }
.button-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.cards-row { display: grid; grid-template-columns: 1.2fr 0.9fr 0.9fr; gap: 20px; }
@media (max-width: 640px) { .cards-row { grid-template-columns: 1fr; } }
.tags-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.divider-demo { margin-bottom: 32px; }
.divider-label { font-family: var(--font-ui); font-size: 12px; font-weight: 600; color: var(--color-subtle); margin-bottom: 8px; }

/* ===== Documents / Social pages ===== */
.preview-img { max-width: 100%; border-radius: 8px; border: 1px solid rgba(0,0,0,0.06); margin-bottom: 8px; }
.preview-caption { font-family: var(--font-ui); font-size: 12px; color: var(--color-subtle); }
.previews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; }
.logo-preview-box { background: var(--color-cream); border-radius: 8px; border: 1px solid rgba(0,0,0,0.06); padding: 24px; display: flex; align-items: center; justify-content: center; margin-bottom: 8px; }
.logo-preview-box.dark { background: var(--color-black); }
.logo-preview-box.transparent { background: repeating-conic-gradient(#e0e0e0 0% 25%, #f5f5f5 0% 50%) 50% / 20px 20px; }
.action-bar { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
.action-bar a { font-family: var(--font-ui); font-size: 13px; font-weight: 500; color: var(--color-terracotta); text-decoration: none; }
.action-bar a:hover { text-decoration: underline; }

/* Page intro — the single lead-paragraph style for every page's hero block.
   (Formerly split between .section-intro and a near-duplicate .lede; unified.) */
.section-intro { font-family: var(--font-body); font-size: 15px; line-height: 1.7; color: var(--color-body); max-width: 720px; margin: 8px 0 28px; }
.section-intro code { font-family: var(--font-mono); font-size: 14px; background: rgba(0,0,0,0.04); padding: 1px 6px; border-radius: 3px; color: var(--color-doc-text); }

/* ===== Logo picker + gallery (Foundations) ===== */

.logo-picker { border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; overflow: hidden; background: var(--color-cream); }
.logo-picker-controls { padding: 20px 24px; border-bottom: 1px solid rgba(0,0,0,0.06); display: flex; flex-direction: column; gap: 14px; }
.logo-axis { display: grid; grid-template-columns: 64px 1fr; align-items: center; gap: 12px; }
.logo-axis-label { font-family: var(--font-ui); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--color-subtle); }
.logo-axis-options { display: flex; flex-wrap: wrap; gap: 8px; }
.logo-toggle { font-family: var(--font-ui); font-size: 13px; font-weight: 500; color: var(--color-text); background: #fff; border: 1px solid rgba(0,0,0,0.12); border-radius: 999px; padding: 6px 14px; cursor: pointer; transition: all 0.12s ease; }
.logo-toggle:hover { border-color: var(--color-terracotta); }
.logo-toggle.active { background: var(--color-terracotta); border-color: var(--color-terracotta); color: #fff; }

.logo-picker-stage { display: grid; grid-template-columns: minmax(0, 2fr) minmax(220px, 1fr); }
.logo-stage-canvas { min-height: 320px; display: flex; align-items: center; justify-content: center; padding: 40px; background: #d9d5cf; }
.logo-stage-canvas.checker-light { background: repeating-conic-gradient(#e0e0e0 0% 25%, #f5f5f5 0% 50%) 50% / 24px 24px; }
.logo-stage-canvas.checker-dark { background: repeating-conic-gradient(#2c2a28 0% 25%, #3a3734 0% 50%) 50% / 24px 24px; }
.logo-stage-canvas img { max-width: 100%; max-height: 360px; width: auto; height: auto; display: block; }
.logo-stage-meta { padding: 24px; border-left: 1px solid rgba(0,0,0,0.06); display: flex; flex-direction: column; gap: 8px; }
.logo-stage-caption { font-family: var(--font-headline); font-weight: 600; font-size: 18px; color: var(--color-text); }
.logo-stage-aspect { font-family: var(--font-ui); font-size: 12px; color: var(--color-subtle); margin-bottom: 8px; }
.logo-stage-downloads { margin-top: auto; display: flex; flex-direction: column; gap: 12px; }
.logo-dl-primary { display: inline-block; text-align: center; font-family: var(--font-ui); font-weight: 600; font-size: 14px; color: #fff; background: var(--color-terracotta); border-radius: 8px; padding: 10px 16px; text-decoration: none; }
.logo-dl-primary:hover { background: var(--color-terracotta-hover, #C2653A); }
.logo-dl-pngs { display: flex; flex-wrap: wrap; gap: 8px; }
.logo-dl-pngs a { font-family: var(--font-ui); font-size: 12px; font-weight: 500; color: var(--color-text); background: #fff; border: 1px solid rgba(0,0,0,0.12); border-radius: 6px; padding: 5px 10px; text-decoration: none; }
.logo-dl-pngs a:hover { border-color: var(--color-terracotta); color: var(--color-terracotta); }

.logo-gallery { margin-top: 28px; }
.logo-gallery > summary { font-family: var(--font-ui); font-weight: 600; font-size: 14px; color: var(--color-terracotta); cursor: pointer; padding: 8px 0; }
.logo-gallery-heading { font-family: var(--font-headline); font-size: 16px; margin: 20px 0 12px; }
.logo-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; margin-bottom: 8px; }
.logo-gallery-item { margin: 0; }
.logo-tile { background: #d9d5cf; border-radius: 8px; border: 1px solid rgba(0,0,0,0.06); overflow: hidden; display: flex; align-items: center; justify-content: center; min-height: 96px; padding: 16px; }
.logo-tile.checker-light { background: repeating-conic-gradient(#e0e0e0 0% 25%, #f5f5f5 0% 50%) 50% / 16px 16px; }
.logo-tile.checker-dark { background: repeating-conic-gradient(#2c2a28 0% 25%, #3a3734 0% 50%) 50% / 16px 16px; }
.logo-tile img { max-width: 100%; max-height: 120px; width: auto; height: auto; display: block; }
.logo-gallery-item figcaption { font-family: var(--font-ui); font-size: 12px; color: var(--color-subtle); margin: 8px 0 4px; }

@media (max-width: 640px) {
  .logo-picker-stage { grid-template-columns: 1fr; }
  .logo-stage-meta { border-left: none; border-top: 1px solid rgba(0,0,0,0.06); }
  .logo-axis { grid-template-columns: 1fr; gap: 6px; }
}

pre { background: var(--color-black); color: var(--color-light); padding: 16px 20px; border-radius: 8px; font-size: 13px; overflow-x: auto; margin-top: 12px; line-height: 1.6; font-family: var(--font-mono), monospace; }
code { font-family: var(--font-mono), monospace; overflow-wrap: break-word; }

.doc-card { background: white; border-radius: 12px; padding: 32px; border: 1px solid rgba(0,0,0,0.06); margin-bottom: 32px; }
.doc-card h3 { margin-top: 0; }
.doc-card p { font-size: 14px; color: var(--color-body); margin-bottom: 16px; }

/* ===== Workflow page ===== */
.step { background: white; border-radius: 12px; padding: 24px; border: 1px solid rgba(0,0,0,0.06); margin-bottom: 16px; }
.step-number { font-family: var(--font-headline); font-weight: 700; font-size: 18px; color: var(--color-terracotta); margin-bottom: 4px; }
.step p { font-size: 14px; color: var(--color-body); }

table { width: 100%; border-collapse: collapse; margin-top: 12px; }
/* Wide data tables scroll horizontally on mobile instead of widening the page.
   display:block turns each table into its own overflow-x:auto scroll container. */
@media (max-width: 640px) {
  table, .type-table, .spec-table, .params-table, .ref-templates-table { display: block; overflow-x: auto; }
}
table th { font-family: var(--font-ui); font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; text-align: left; padding: 10px 12px; border-bottom: 2px solid var(--color-terracotta); color: var(--color-text); }
table td { font-size: 14px; padding: 10px 12px; border-bottom: 1px solid rgba(0,0,0,0.06); color: var(--color-body); }
table td code { font-size: 12px; background: rgba(0,0,0,0.04); padding: 2px 6px; border-radius: 3px; }

/* Demo blocks — live render + collapsible HTML source (see partials/demo.njk).
   Summary bar reads as a normal light card; only the code region itself
   flips to dark (terminal style). */
.demo-block { margin-bottom: 24px; }
.demo-live { /* live render area — uses component's own styling */ }
.demo-source { margin-top: 10px; border: 1px solid var(--color-doc-border); border-radius: 6px; background: var(--color-light); overflow: hidden; }
.demo-source summary { list-style: none; cursor: pointer; padding: 8px 12px; display: flex; align-items: center; justify-content: space-between; gap: 12px; font-family: var(--font-ui); font-size: 12px; color: var(--color-subtle); user-select: none; }
.demo-source summary:hover { color: var(--color-text); }
.demo-source summary::-webkit-details-marker { display: none; }
.demo-summary-label::before { content: "▸ "; display: inline-block; transition: transform 0.15s; }
.demo-source[open] .demo-summary-label::before { content: "▾ "; }
.demo-source[open] summary { border-bottom: 1px solid var(--color-doc-border); }
.demo-copy { font-family: var(--font-ui); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; padding: 4px 10px; border: 1px solid var(--color-doc-border); border-radius: 4px; background: white; color: var(--color-subtle); cursor: pointer; }
.demo-copy:hover { color: var(--color-terracotta); border-color: var(--color-terracotta); }
.demo-copy.copied { color: white; background: var(--color-terracotta); border-color: var(--color-terracotta); }
/* Code region: dark surface, light text. Override the global `pre` rule. */
.demo-source pre { margin: 0; padding: 14px 16px; overflow-x: auto; background: var(--color-black); color: var(--color-light); border-radius: 0; }
.demo-source pre code { font-family: var(--font-mono); font-size: 12px; line-height: 1.55; color: var(--color-light); background: transparent; padding: 0; white-space: pre; }

/* "States" strip — lets you explore a component's interactive states (hover /
   selected / focus …) without physically hovering. Rendered for any component
   or variant that declares `states` in components.meta.ts. */
.demo-states { margin-top: 12px; padding: 16px; border: 1px dashed var(--color-doc-border); border-radius: 8px; background: var(--color-cream); }
.demo-states-label { display: block; font-family: var(--font-ui); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--color-subtle); margin-bottom: 14px; }
.demo-states-row { display: flex; flex-wrap: wrap; gap: 24px; align-items: flex-start; }
.demo-state { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.demo-state-tag { font-family: var(--font-mono); font-size: 11px; color: var(--color-terracotta); }
.demo-state-tag em { color: var(--color-subtle); font-style: normal; }

/* ============================================================
   /presentations/ — slide-type showcase
   ============================================================ */
/* .lede unified into .section-intro (see Page intro, above). */

.action-bar { display: flex; gap: 24px; flex-wrap: wrap; margin: 16px 0 24px; font-family: var(--font-ui); font-size: 14px; }
.action-bar a { color: var(--color-terracotta); text-decoration: none; font-weight: 600; }
.action-bar a:hover { text-decoration: underline; }

.slidetype-grid { display: grid; grid-template-columns: 1fr; gap: 32px; margin: 40px 0; }
@media (min-width: 768px) { .slidetype-grid { grid-template-columns: 1fr 1fr; } }

.slidetype-card { background: white; border-radius: 12px; border: 1px solid rgba(0,0,0,0.06); overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.03); transition: border-color 0.15s, box-shadow 0.15s; }
.slidetype-card:hover { border-color: var(--color-terracotta); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }

.slidetype-thumb { display: block; aspect-ratio: 16 / 9; background: var(--color-light); overflow: hidden; border-bottom: 1px solid rgba(0,0,0,0.08); }
.slidetype-thumb img { width: 100%; height: 100%; object-fit: contain; display: block; image-rendering: auto; }
.slidetype-thumb-missing { display: flex; align-items: center; justify-content: center; height: 100%; padding: 24px; text-align: center; color: var(--color-subtle); font-family: var(--font-ui); font-size: 13px; }

.slidetype-meta { padding: 20px 24px 24px; }
.slidetype-meta h3 { font-family: var(--font-headline); font-weight: 600; font-size: 18px; color: var(--color-text); margin: 0 0 8px; display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.slidetype-type code { font-family: var(--font-mono); font-size: 11px; font-weight: 400; color: var(--color-terracotta); background: rgba(212,120,74,0.08); padding: 2px 6px; border-radius: 3px; }
.slidetype-meta p { font-family: var(--font-body); font-size: 13px; line-height: 1.55; color: var(--color-body); margin: 0 0 14px; }

.slidetype-syntax { background: var(--color-light); border-left: 3px solid var(--color-terracotta); border-radius: 0 6px 6px 0; padding: 12px 14px; margin: 0 0 14px; overflow-x: auto; }
.slidetype-syntax code { font-family: var(--font-mono); font-size: 12px; line-height: 1.55; color: var(--color-doc-text); background: transparent; padding: 0; white-space: pre; }

.slidetype-link { font-family: var(--font-ui); font-size: 13px; font-weight: 600; color: var(--color-terracotta); text-decoration: none; }
.slidetype-link:hover { text-decoration: underline; }

.callout { background: var(--color-light); border-left: 3px solid var(--color-terracotta); padding: 20px 24px; border-radius: 0 8px 8px 0; margin: 40px 0; }
.callout h3 { font-family: var(--font-headline); font-weight: 600; font-size: 16px; color: var(--color-text); margin: 0 0 8px; }
.callout p { font-family: var(--font-body); font-size: 14px; line-height: 1.6; color: var(--color-body); margin: 0 0 8px; }
.callout p:last-child { margin-bottom: 0; }
.callout code { font-family: var(--font-mono); font-size: 13px; background: rgba(0,0,0,0.04); padding: 1px 6px; border-radius: 3px; color: var(--color-doc-text); }

.footnote { font-family: var(--font-ui); font-size: 12px; color: var(--color-subtle); margin: 40px 0 0; }
.footnote code { font-family: var(--font-mono); font-size: 11px; background: rgba(0,0,0,0.04); padding: 1px 5px; border-radius: 3px; color: var(--color-doc-text); }

/* ============================================================
   /decks/ — rendered deck archive
   ============================================================ */
.decks-grid { display: grid; grid-template-columns: 1fr; gap: 24px; margin: 32px 0; }
@media (min-width: 768px) { .decks-grid { grid-template-columns: 1fr 1fr; } }

.deck-card { background: white; border-radius: 12px; border: 1px solid rgba(0,0,0,0.06); overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.03); transition: border-color 0.15s, box-shadow 0.15s; }
.deck-card:hover { border-color: var(--color-terracotta); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }

.deck-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; padding: 12px; background: var(--color-light); }
@media (max-width: 640px) { .deck-thumbs { grid-template-columns: repeat(2, 1fr); } }
.deck-thumb { width: 100%; aspect-ratio: 16 / 9; object-fit: contain; border-radius: 4px; border: 1px solid rgba(0,0,0,0.08); background: white; image-rendering: auto; }

.deck-meta { padding: 18px 22px 22px; }
.deck-titlerow { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 4px; }
.deck-meta h3 { font-family: var(--font-headline); font-weight: 600; font-size: 18px; color: var(--color-text); margin: 0; }
.deck-badge { font-family: var(--font-ui); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; padding: 3px 8px; background: rgba(212,120,74,0.08); color: var(--color-terracotta); border-radius: 4px; white-space: nowrap; }
.deck-slug { font-family: var(--font-mono); font-size: 11px; color: var(--color-subtle); background: rgba(0,0,0,0.04); padding: 1px 5px; border-radius: 3px; display: inline-block; margin-bottom: 14px; }

/* Published-deck card extras: ID chip (copy-to-clipboard) + timestamp row. */
.deck-idrow { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.deck-id-chip { font-family: var(--font-mono); font-size: 11px; color: var(--color-terracotta); background: rgba(212,120,74,0.08); border: 1px solid rgba(212,120,74,0.18); padding: 2px 8px; border-radius: 4px; cursor: pointer; transition: background 0.12s, color 0.12s; }
.deck-id-chip:hover { background: var(--color-terracotta); color: white; }
.deck-published-at { font-family: var(--font-ui); font-size: 11px; color: var(--color-subtle); }

.deck-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.deck-actions .btn-primary { padding: 10px 20px; font-size: 14px; }
.btn-secondary-light { display: inline-flex; align-items: center; gap: 8px; padding: 10px 20px; background: transparent; color: var(--color-terracotta); border: 1px solid var(--color-terracotta); border-radius: 8px; font-family: var(--font-ui); font-weight: 600; font-size: 14px; text-decoration: none; }
.btn-secondary-light:hover { background: var(--color-terracotta); color: white; }

.deck-empty { background: var(--color-light); border-left: 3px solid var(--color-terracotta); padding: 24px; border-radius: 0 8px 8px 0; font-family: var(--font-body); font-size: 14px; color: var(--color-body); }
.deck-empty p { margin: 0 0 8px; }
.deck-empty pre { margin: 0; padding: 12px 16px; background: white; border-radius: 6px; overflow-x: auto; }
.deck-empty code { font-family: var(--font-mono); font-size: 12px; color: var(--color-doc-text); }

/* ===== Tooling page ===== */
.tooling-matrix { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 32px; }
@media (max-width: 640px) { .tooling-matrix { grid-template-columns: 1fr; } }
.tooling-col { background: white; border-radius: 12px; padding: 28px; border: 1px solid rgba(0,0,0,0.06); }
.tooling-col-label { font-family: var(--font-ui); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--color-terracotta); margin-bottom: 16px; }
.tooling-note { font-family: var(--font-body); font-size: 12px; font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--color-subtle); }
.tooling-transports { white-space: nowrap; }

.transport-badge { display: inline-block; padding: 2px 8px; border-radius: 4px; font-family: var(--font-ui); font-weight: 600; font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; margin-right: 4px; }
.transport-stdio { background: rgba(0,0,0,0.06); color: var(--color-subtle); }
.transport-http  { background: rgba(59,130,246,0.08); color: #3B82F6; }

.tooling-templates-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin-bottom: 32px; }
.tooling-tmpl-card { background: white; border-radius: 10px; overflow: hidden; border: 1px solid rgba(0,0,0,0.06); }
.tooling-tmpl-card .tooling-tmpl-header,
.tooling-tmpl-card .tooling-tmpl-desc,
.tooling-tmpl-card .tooling-tmpl-dims { padding-left: 16px; padding-right: 16px; }
.tooling-tmpl-card .tooling-tmpl-header { padding-top: 14px; padding-bottom: 0; }
.tooling-tmpl-card .tooling-tmpl-desc { padding-bottom: 14px; }
.tooling-tmpl-preview { width: 100%; aspect-ratio: 16 / 9; overflow: hidden; background: var(--color-cream); border-bottom: 1px solid rgba(0,0,0,0.06); }
.tooling-tmpl-preview img { width: 100%; height: 100%; object-fit: cover; object-position: top left; display: block; }
.tooling-tmpl-header { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 10px; }
.tooling-tmpl-key { font-family: var(--font-mono); font-size: 13px; color: var(--color-terracotta); background: rgba(212,120,74,0.08); padding: 2px 8px; border-radius: 4px; }
.tooling-tmpl-desc { font-family: var(--font-body); font-size: 13px; line-height: 1.55; color: var(--color-body); margin: 0 0 8px; }
.tooling-tmpl-dims { font-family: var(--font-mono); font-size: 11px; color: var(--color-subtle); background: rgba(0,0,0,0.04); padding: 2px 7px; border-radius: 3px; display: inline-block; }

.output-badge { display: inline-block; padding: 2px 8px; border-radius: 4px; font-family: var(--font-ui); font-weight: 700; font-size: 10px; letter-spacing: 0.5px; white-space: nowrap; }
.output-pdf  { background: rgba(212,120,74,0.12); color: #C2653A; }
.output-png  { background: rgba(59,130,246,0.08); color: #3B82F6; }
.output-slide { background: rgba(34,197,94,0.08);  color: #16A34A; }

.method-badge { display: inline-block; padding: 3px 9px; border-radius: 4px; font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: 0.3px; white-space: nowrap; }
.method-get    { background: rgba(34,197,94,0.08);   color: #16A34A; }
.method-post   { background: rgba(59,130,246,0.08);  color: #2563EB; }
.method-delete { background: rgba(212,120,74,0.12);  color: #C2653A; }

.auth-tag { display: inline-block; padding: 2px 8px; border-radius: 4px; font-family: var(--font-ui); font-size: 11px; font-weight: 600; background: rgba(0,0,0,0.05); color: var(--color-subtle); white-space: nowrap; }

/* ===== Params tables (template parameter docs) ===== */
.params-table { width: 100%; border-collapse: collapse; margin: 12px 0 24px; font-size: 13px; }
.params-table thead th { text-align: left; font-family: var(--font-ui); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--color-subtle); border-bottom: 1px solid rgba(0,0,0,0.1); padding: 6px 10px; }
.params-table tbody td { padding: 8px 10px; border-bottom: 1px solid rgba(0,0,0,0.05); vertical-align: top; }
.params-table tbody tr:last-child td { border-bottom: none; }
.param-name { font-family: var(--font-mono); font-size: 12px; color: var(--color-terracotta); background: rgba(212,120,74,0.06); padding: 1px 6px; border-radius: 3px; }
.param-type { font-family: var(--font-mono); font-size: 11px; color: var(--color-subtle); background: rgba(0,0,0,0.04); padding: 1px 6px; border-radius: 3px; }
.param-required { font-family: var(--font-ui); font-size: 10px; font-weight: 700; color: #C2653A; text-transform: uppercase; letter-spacing: 0.4px; }
.param-optional { font-family: var(--font-ui); font-size: 10px; color: var(--color-subtle); text-transform: uppercase; letter-spacing: 0.4px; }
.param-notes { color: var(--color-body); font-size: 12px; line-height: 1.5; }
.param-flag { display: inline-block; margin-left: 6px; padding: 1px 6px; border-radius: 3px; font-family: var(--font-ui); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; }
.flag-undocumented { background: rgba(234,179,8,0.15); color: #A16207; }
.flag-unused { background: rgba(0,0,0,0.05); color: var(--color-subtle); }
.params-empty { font-size: 13px; color: var(--color-subtle); font-style: italic; margin: 8px 0 24px; }
.params-heading { font-family: var(--font-ui); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--color-subtle); margin: 20px 0 0; }

/* Reference page — flat templates table */
.param-filter { margin: 12px 0 16px; }
.param-filter input { width: 100%; max-width: 480px; padding: 8px 12px; border: 1px solid rgba(0,0,0,0.12); border-radius: 6px; font-family: var(--font-ui); font-size: 13px; }
.param-filter input:focus { outline: none; border-color: var(--color-terracotta); box-shadow: 0 0 0 3px rgba(212,120,74,0.12); }
.ref-templates-table { width: 100%; border-collapse: collapse; font-size: 13px; margin-bottom: 24px; }
.ref-templates-table thead th { text-align: left; font-family: var(--font-ui); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--color-subtle); border-bottom: 1px solid rgba(0,0,0,0.1); padding: 8px 10px; }
.ref-templates-table tbody td { padding: 10px; border-bottom: 1px solid rgba(0,0,0,0.05); vertical-align: top; }
.ref-tmpl-desc { font-size: 12px; color: var(--color-body); margin: 6px 0 0; line-height: 1.45; }
.ref-tmpl-dims { font-family: var(--font-mono); font-size: 11px; color: var(--color-subtle); white-space: nowrap; }
.ref-tmpl-params { min-width: 280px; }
.ref-param { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; padding: 3px 0; }
.ref-tmpl-tags .tag-chip { display: inline-block; margin: 0 4px 4px 0; padding: 1px 7px; border-radius: 3px; font-family: var(--font-ui); font-size: 10px; font-weight: 600; background: rgba(0,0,0,0.05); color: var(--color-subtle); }

/* ===== Overview hero ===== */
.overview-hero {
  background: var(--color-black);
  color: var(--color-light);
  padding: 64px 0 56px;
  text-align: center;
}
.overview-hero .container { border-bottom: none; }
.overview-hero img { display: block; margin: 0 auto 28px; }
.overview-hero .tagline-label {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-terracotta);
  margin-bottom: 12px;
}
.overview-hero .descriptor {
  font-family: var(--font-body);
  font-size: 14px;
  color: rgba(255,255,255,0.45);
  margin-top: 6px;
}

/* ===== In-page nav (Layer 3) = the docnav-toc component =====
   The "Auf dieser Seite" nav is the docnav-toc rail (css/components.css), now in
   the left sidebar of the docnav shell (_includes/base.njk). These rules only
   adapt the brand-site page content to live in that shell's content column:
   `.docnav-page` holds the page's own sections, so it must NOT inherit the
   demo typography of `.docnav-content` (which styles gallery demos). The inner
   sections already carry `.container`; the shell + docnav-inner own the width
   and padding here, so neutralise the nested container to avoid double gutters. */
.docnav-page { min-width: 0; }
.docnav-page .container { max-width: none; margin-inline: 0; padding-inline: 0; }
.docnav-page > section:first-child { padding-top: 0; }
.docnav-page section:last-child { border-bottom: none; }
/* Breathing room when an in-page TOC anchor (category section or component h3)
   is jumped to, so the heading clears the sticky top bar (~60px) instead of
   sitting flush against the viewport top. */
.docnav-page section[id], .docnav-page h3[id] { scroll-margin-top: 84px; }

/* ===== Press / Photos (moved from press.njk inline style) ===== */
.prose h1 { font-size: 1.75rem; margin: 1.5rem 0 0.5rem; }
.prose h2 { font-size: 1.35rem; margin: 1.5rem 0 0.5rem; }
.prose h3 { font-size: 1.1rem; margin: 1.25rem 0 0.4rem; color: var(--color-text); }
.prose hr { border: 0; border-top: 1px solid rgba(0,0,0,0.06); margin: 2rem 0; }
.prose ul { margin: 0.5rem 0 1rem 1.25rem; }
.prose li { margin-bottom: 0.25rem; }
.prose p { margin: 0.5rem 0 1rem; }
.prose a { color: var(--color-terracotta); }
.prose code { font-family: var(--font-mono); font-size: 0.9em; }

.photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  margin-top: 1rem;
}
.photo {
  margin: 0;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 8px;
  overflow: hidden;
  background: white;
}
.photo img { display: block; width: 100%; height: auto; }
.photo figcaption {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1rem;
  font-size: 0.85rem;
  color: var(--color-subtle);
}
.photo figcaption a { color: var(--color-terracotta); font-weight: 500; text-decoration: none; }

/* ===== Overview features ("What's inside") =====
   The grid + card now come from the .feature-grid / .feature component
   (css/components.css). Only the section spacing and the doc-specific
   <p>/<code> styling (the component styles .feature-body, not a bare <p>)
   stay site-local. */
.feature-grid { margin-top: 28px; }
.feature p { font-size: 13px; line-height: 1.6; color: var(--color-body); margin: 0; }
.feature code { font-family: var(--font-mono), monospace; font-size: 12px; background: rgba(0,0,0,0.04); padding: 1px 5px; border-radius: 3px; }

/* ===== Component gallery — two-tier band (Primitives / Blocks) ===== */
.tier-band {
  margin-top: 24px;
  padding: 28px 0 4px;
  border-top: 2px solid var(--color-terracotta);
}
.tier-band .eyebrow { font-size: 15px; letter-spacing: 2.5px; }
.tier-band__note { max-width: 60ch; margin-top: 6px; font-size: 14px; color: var(--color-subtle); }
.tier-band__note em { font-style: italic; }

/* ===== Overview resources (downloads + connections) ===== */
/* ===== Overview chapters (Downloads & Connections) ===== */
.overview-chapters { margin-top: 8px; }
.overview-chapter {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px 48px;
  padding: 28px 0;
  border-top: 1px solid rgba(0,0,0,0.07);
  align-items: start;
}
.overview-chapter:last-child { border-bottom: 1px solid rgba(0,0,0,0.07); }
@media (max-width: 640px) {
  .overview-chapter { grid-template-columns: 1fr; gap: 10px; }
}
/* min-width:0 lets the body shrink below its <pre> content so the pre's
   own overflow-x:auto scrolls the code instead of widening the page. */
.overview-chapter-body { min-width: 0; }
.overview-chapter-label {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--color-terracotta);
  padding-top: 3px;
}
.overview-chapter-body p { font-size: 14px; line-height: 1.65; color: var(--color-body); margin: 0 0 16px; }
.overview-chapter-body p:last-child { margin-bottom: 0; }
.overview-chapter-body pre { margin: 0; padding: 14px 18px; background: var(--color-black); border-radius: 8px; overflow-x: auto; }
.overview-chapter-body pre code { font-family: var(--font-mono); font-size: 13px; color: rgba(255,255,255,0.85); background: none; padding: 0; }
.overview-chapter-body a:not([class]) { color: var(--color-terracotta); }
