/* ============================================================================
   styles.css — DOC CHROME + PREVIEW COMPONENT STYLES
   The page's own editorial identity is namespaced --doc-* so it never collides
   with the token contract it showcases. Preview components (.pv-*) read ONLY
   contract tokens, never hardcoded values.
   ============================================================================ */
:root {
  --doc-paper: #f3f0e9;  --doc-card: #fbfaf6;  --doc-ink: #1c1b18;
  --doc-faint: #8a857a;  --doc-rule: #d9d3c6;  --doc-rule-2: #c7c0b1;
  --doc-serif: "Newsreader", Georgia, serif;
  --doc-sans: "Inter", system-ui, sans-serif;
  --doc-mono: "JetBrains Mono", ui-monospace, monospace;
  --doc-maxw: 1320px;
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; background: var(--doc-paper); color: var(--doc-ink);
  font-family: var(--doc-sans); font-size: 16px; line-height: 1.6;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
::selection { background: #1c1b18; color: #f3f0e9; }
.wrap { max-width: var(--doc-maxw); margin: 0 auto; padding: 0 24px; }
code { font-family: var(--doc-mono); font-size: 0.88em; }

/* ---- Masthead ---- */
.masthead { border-bottom: 3px solid var(--doc-ink); }
.masthead__topline {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  flex-wrap: wrap; font-family: var(--doc-mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--doc-faint);
  padding: 14px 0 12px; border-bottom: 1px solid var(--doc-rule);
}
.masthead__topline span { white-space: nowrap; }
.masthead__title {
  font-family: var(--doc-serif); font-weight: 600; letter-spacing: -0.02em;
  line-height: 0.96; font-size: clamp(40px, 9vw, 104px); margin: 22px 0 18px;
  text-wrap: balance;
}
.masthead__sub { border-top: 1px solid var(--doc-rule); padding-top: 14px; padding-bottom: 18px; }
.masthead__lede {
  font-family: var(--doc-serif); font-size: clamp(18px, 2.4vw, 23px);
  line-height: 1.4; max-width: 60ch; color: #353330; font-weight: 400; margin: 0;
}
.masthead__lede em { color: var(--doc-ink); font-style: italic; }

/* ---- Section scaffolding ---- */
section { padding: 64px 0; border-bottom: 1px solid var(--doc-rule); }
.sec-head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 32px; flex-wrap: wrap; }
.sec-num {
  font-family: var(--doc-mono); font-size: 12px; letter-spacing: 0.1em;
  color: var(--doc-faint); border: 1px solid var(--doc-rule-2);
  padding: 3px 9px; border-radius: 2px; white-space: nowrap;
}
.sec-title { font-family: var(--doc-serif); font-weight: 600; letter-spacing: -0.01em; font-size: clamp(26px, 4vw, 40px); line-height: 1.05; margin: 0; }
.sec-note { color: #4a473f; max-width: 70ch; margin: 0 0 8px; font-size: 16px; }
.sec-note + .sec-note { margin-top: 12px; }
.eyebrow { font-family: var(--doc-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--doc-faint); margin: 0 0 10px; }

/* ============================================================================
   PLAYGROUND
   ============================================================================ */
.pg { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 1000px) { .pg { grid-template-columns: 340px 1fr; align-items: start; } }

.pg-controls { display: flex; flex-direction: column; gap: 22px; position: sticky; top: 18px; }
.ctrl-group { background: var(--doc-card); border: 1px solid var(--doc-rule); border-radius: 5px; padding: 18px; }
.ctrl-group__head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.ctrl-group__title { font-family: var(--doc-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--doc-ink); }
.ctrl-group__hint { font-family: var(--doc-mono); font-size: 10px; color: var(--doc-faint); }

.opt-list { display: flex; flex-direction: column; gap: 6px; }
.opt {
  display: flex; align-items: center; gap: 11px; width: 100%; cursor: pointer;
  background: transparent; border: 1px solid transparent; border-radius: 4px;
  padding: 8px 10px; text-align: left; font: inherit; color: var(--doc-ink);
  transition: background .12s ease, border-color .12s ease;
}
.opt:hover { background: #efebe2; }
.opt[aria-pressed="true"] { background: #fff; border-color: var(--doc-ink); }
.opt:focus-visible { outline: 2px solid var(--doc-ink); outline-offset: 1px; }
.opt__sw { width: 26px; height: 26px; border-radius: 4px; border: 1px solid rgba(0,0,0,.12); flex: none; display: grid; place-items: center; overflow: hidden; }
.opt__sw span { display: block; width: 50%; height: 100%; }
.opt__name { font-size: 13px; font-weight: 500; line-height: 1.15; }
.opt__meta { font-family: var(--doc-mono); font-size: 10px; color: var(--doc-faint); margin-top: 1px; }
.opt__txt { flex: 1; min-width: 0; }
.opt__demo { font-size: 18px; line-height: 1; color: var(--doc-ink); white-space: nowrap; }

/* accent picker */
.accent-row { display: flex; align-items: center; gap: 12px; }
.accent-swatch { width: 42px; height: 42px; border-radius: 5px; border: 1px solid var(--doc-rule-2); flex: none; padding: 0; cursor: pointer; overflow: hidden; }
.accent-swatch::-webkit-color-swatch-wrapper { padding: 0; }
.accent-swatch::-webkit-color-swatch { border: 0; }
.accent-fields { flex: 1; min-width: 0; }
.accent-hex {
  width: 100%; font-family: var(--doc-mono); font-size: 13px; color: var(--doc-ink);
  background: #fff; border: 1px solid var(--doc-rule-2); border-radius: 4px;
  padding: 8px 10px; text-transform: uppercase;
}
.accent-hex:focus-visible { outline: 2px solid var(--doc-ink); outline-offset: 1px; }
.accent-note { font-size: 11px; color: var(--doc-faint); margin: 8px 0 0; line-height: 1.4; }
.accent-reset { font-family: var(--doc-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--doc-faint); background: none; border: 0; cursor: pointer; padding: 0; text-decoration: underline; }
.accent-reset:hover { color: var(--doc-ink); }

/* presets */
.preset-row { display: flex; flex-wrap: wrap; gap: 7px; }
.preset {
  font-family: var(--doc-mono); font-size: 11px; letter-spacing: .04em;
  color: var(--doc-ink); background: #fff; border: 1px solid var(--doc-rule-2);
  border-radius: 999px; padding: 6px 12px; cursor: pointer; transition: background .12s, border-color .12s;
}
.preset:hover { background: #efebe2; border-color: var(--doc-ink); }
.preset:focus-visible { outline: 2px solid var(--doc-ink); outline-offset: 1px; }

/* ---- live stage ---- */
.pg-stage { border: 1px solid var(--doc-rule); border-radius: 5px; overflow: hidden; background: var(--doc-card); }
.pg-stage__bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 16px; border-bottom: 1px solid var(--doc-rule); background: #efebe2; flex-wrap: wrap; }
.pg-stage__sig { font-family: var(--doc-mono); font-size: 11px; color: #4a473f; letter-spacing: .02em; }
.pg-stage__sig b { color: var(--doc-ink); }
.pg-stage__toggle { display: flex; gap: 4px; }
.vp-btn { font-family: var(--doc-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--doc-faint); background: transparent; border: 1px solid var(--doc-rule-2); border-radius: 3px; padding: 5px 9px; cursor: pointer; }
.vp-btn[aria-pressed="true"] { color: var(--doc-ink); background: #fff; border-color: var(--doc-ink); }

.render-host { display: grid; place-items: start center; padding: 28px 22px; background: repeating-linear-gradient(45deg, #efece4, #efece4 10px, #ebe7df 10px, #ebe7df 20px); }
.render {
  width: 100%; background: var(--color-bg); color: var(--color-fg);
  font-family: var(--font-body);
  position: relative; overflow: hidden; max-width: 100%;
}
.render * { box-sizing: border-box; min-width: 0; }
.render-host[data-vp="mobile"] .render { max-width: 380px; }
.render-host[data-vp="desktop"] .render { max-width: 100%; }

/* ============================================================================
   PREVIEW COMPONENTS — read ONLY contract tokens
   ============================================================================ */
.pv-nav { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-4) var(--space-6); border-bottom: var(--border-thin) solid var(--color-border); position: relative; }
.pv-brand { display: flex; align-items: center; gap: var(--space-3); }
.pv-brandname { white-space: nowrap; }
.pv-logo { width: 30px; height: 30px; border-radius: var(--radius-sm); background: var(--color-accent); display: grid; place-items: center; color: var(--color-accent-fg); font-family: var(--font-display); font-weight: 800; font-size: var(--text-base); flex: none; }
.pv-brandname { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); color: var(--color-fg); letter-spacing: -0.01em; }
[data-shape="brutalist"] .pv-logo { font-weight: 400; }
.pv-navlinks { display: flex; gap: var(--space-5); }
.pv-navlink { font-family: var(--font-body); font-size: var(--text-sm); font-weight: 500; color: var(--color-muted); text-decoration: none; }
.pv-navlink:hover { color: var(--color-fg); }

.pv-hero { padding: var(--space-10) var(--space-6) var(--space-8); }
.pv-eyebrow { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-muted); margin: 0 0 var(--space-3); }
.pv-h {
  font-family: var(--font-display); color: var(--color-fg);
  font-size: var(--text-5xl); line-height: var(--leading-tight);
  margin: 0 0 var(--space-4); font-weight: 700; letter-spacing: -0.015em; text-wrap: balance;
  overflow-wrap: anywhere; hyphens: auto;
}
.render-host[data-vp="mobile"] .pv-h { font-size: var(--text-3xl); letter-spacing: -0.01em; }
.render-host[data-vp="mobile"] .pv-lede { font-size: var(--text-base); }
.render-host[data-vp="mobile"] .pv-hero { padding: var(--space-7) var(--space-5) var(--space-6); }
[data-type="anton"] .pv-h, [data-type="archivo"] .pv-h { letter-spacing: 0.005em; text-transform: uppercase; font-weight: 400; }
[data-type="playfair"] .pv-h, [data-type="dmserif"] .pv-h, [data-type="spectral"] .pv-h { font-weight: 600; }
[data-type="dmserif"] .pv-h { font-weight: 400; }
.pv-lede { font-family: var(--font-body); color: var(--color-muted); font-size: var(--text-lg); line-height: var(--leading-normal); margin: 0 0 var(--space-6); max-width: 46ch; }

.pv-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; margin-bottom: var(--space-7); }
.pv-btn {
  font-family: var(--font-body); font-weight: 600; font-size: var(--text-sm);
  padding: var(--space-3) var(--space-5); border-radius: var(--radius-md);
  cursor: pointer; line-height: 1; display: inline-flex; align-items: center; gap: var(--space-2);
  transition: filter .15s ease, transform .12s ease, box-shadow .15s ease;
}
.pv-btn--primary { background: var(--color-accent); color: var(--color-accent-fg); border: var(--border-default) solid color-mix(in srgb, var(--color-accent) 86%, #000); box-shadow: var(--shadow-md); }
.pv-btn--secondary { background: transparent; color: var(--color-fg); border: var(--border-default) solid var(--color-border); }
.pv-btn--ghost { background: transparent; color: var(--color-fg); border: var(--border-default) solid transparent; padding-left: var(--space-3); padding-right: var(--space-3); }
.pv-btn:focus-visible { outline: var(--border-heavy) solid var(--color-ring); outline-offset: 2px; }
.pv-btn--primary:hover { filter: brightness(1.04); }
[data-shape="brutalist"] .pv-btn--primary:hover { transform: translate(-1px,-1px); box-shadow: var(--shadow-lg); }
.pv-btn--secondary:hover { background: color-mix(in srgb, var(--color-fg) 6%, transparent); }
.pv-btn--ghost:hover { background: color-mix(in srgb, var(--color-fg) 6%, transparent); }

.pv-meta { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.pv-badge { font-family: var(--font-body); font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; background: var(--color-accent); color: var(--color-accent-fg); border-radius: var(--radius-pill); padding: var(--space-1) var(--space-3); line-height: 1.4; white-space: nowrap; }
.pv-tag { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--color-muted); border: var(--border-thin) solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-1) var(--space-2); white-space: nowrap; }

.pv-cardrow { display: grid; grid-template-columns: 1fr; gap: var(--space-4); padding: 0 var(--space-6) var(--space-8); }
@media (min-width: 560px) { .pv-cardrow { grid-template-columns: 1fr 1fr; } }
.render-host[data-vp="mobile"] .pv-cardrow { grid-template-columns: 1fr; }
.pv-card { background: var(--color-surface); border: var(--border-thin) solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: var(--space-5); }
[data-shape="brutalist"] .pv-card { border-width: var(--border-default); }
.pv-card__k { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-muted); margin: 0 0 var(--space-2); }
.pv-card__t { font-family: var(--font-display); color: var(--color-fg); font-size: var(--text-xl); margin: 0 0 var(--space-1); font-weight: 700; line-height: var(--leading-snug); }
[data-type="anton"] .pv-card__t, [data-type="archivo"] .pv-card__t { font-weight: 400; }
[data-type="dmserif"] .pv-card__t { font-weight: 400; }
.pv-card__b { font-family: var(--font-body); color: var(--color-muted); font-size: var(--text-sm); margin: 0; line-height: var(--leading-normal); }

.pv-formbar { display: flex; gap: var(--space-3); align-items: flex-end; flex-wrap: wrap; padding: var(--space-6); border-top: var(--border-thin) solid var(--color-border); background: var(--color-surface); }
.pv-field { flex: 1; min-width: 180px; }
.pv-label { display: block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: 600; color: var(--color-fg); margin-bottom: var(--space-2); letter-spacing: 0.01em; }
.pv-input { width: 100%; font-family: var(--font-body); font-size: var(--text-sm); color: var(--color-fg); background: var(--color-bg); border: var(--border-default) solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); }
.pv-input::placeholder { color: var(--color-muted); }
.pv-input:focus-visible { outline: var(--border-default) solid var(--color-ring); outline-offset: 1px; border-color: var(--color-ring); }

/* ============================================================================
   GALLERY GRIDS (palette / type / shape libraries)
   ============================================================================ */
.gal { display: grid; gap: 16px; }
.gal--pal { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }
.gal--type { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.gal--shape { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }

.card { background: var(--doc-card); border: 1px solid var(--doc-rule); border-radius: 5px; overflow: hidden; }
.card__head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; padding: 13px 16px 11px; }
.card__name { font-family: var(--doc-serif); font-weight: 600; font-size: 17px; }
.card__tag { font-family: var(--doc-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--doc-faint); }
.card__use { font-size: 12px; color: #4a473f; padding: 0 16px 12px; }

/* palette card */
.pal-strip { display: flex; height: 56px; }
.pal-strip span { flex: 1; }
.pal-chips { display: grid; grid-template-columns: repeat(2, 1fr); gap: 7px; padding: 12px 16px 16px; }
.pal-chip { display: flex; align-items: center; gap: 8px; }
.pal-chip i { width: 16px; height: 16px; border-radius: 3px; border: 1px solid rgba(0,0,0,.12); flex: none; }
.pal-chip b { font-family: var(--doc-mono); font-size: 10px; font-weight: 500; color: var(--doc-ink); }
.pal-chip em { font-family: var(--doc-mono); font-size: 9px; font-style: normal; color: var(--doc-faint); margin-left: auto; text-transform: uppercase; }

/* type card */
.type-spec { padding: 6px 16px 18px; }
.type-disp { color: var(--doc-ink); line-height: 1; margin: 6px 0 10px; }
.type-body { color: #4a473f; font-size: 13px; line-height: 1.5; margin: 0; }
.type-foot { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.type-pill { font-family: var(--doc-mono); font-size: 9.5px; letter-spacing: .04em; color: var(--doc-faint); border: 1px solid var(--doc-rule-2); border-radius: 999px; padding: 3px 9px; }

/* shape card — uses a tiny live token island */
.shape-demo { padding: 18px 16px 20px; display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.shape-box { width: 100%; height: 54px; background: #fbfaf6; border: 2px solid var(--doc-ink); box-shadow: var(--shadow-md); border-radius: var(--radius-md); }
.shape-btn { font-family: var(--doc-mono); font-size: 11px; padding: 8px 14px; background: var(--doc-ink); color: #fbfaf6; border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }
.shape-specs { font-family: var(--doc-mono); font-size: 10px; color: var(--doc-faint); line-height: 1.5; }
.shape-specs b { color: var(--doc-ink); }

/* ============================================================================
   SHARED SKELETON PANELS
   ============================================================================ */
.panel { background: var(--doc-card); border: 1px solid var(--doc-rule); border-radius: 5px; padding: 26px; }
.grid-2 { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 880px) { .grid-2 { grid-template-columns: 1fr 1fr; } }
.ramp-row { display: flex; align-items: baseline; gap: 18px; padding: 9px 0; border-bottom: 1px solid var(--doc-rule); }
.ramp-row:last-child { border-bottom: 0; }
.ramp-tag { font-family: var(--doc-mono); font-size: 11px; color: var(--doc-faint); min-width: 122px; }
.ramp-tag b { color: var(--doc-ink); font-weight: 600; }
.ramp-sample { font-family: var(--doc-serif); color: var(--doc-ink); line-height: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.space-row { display: flex; align-items: center; gap: 16px; padding: 6px 0; }
.space-tag { font-family: var(--doc-mono); font-size: 11px; color: var(--doc-faint); min-width: 150px; }
.space-tag b { color: var(--doc-ink); }
.space-bar { height: 14px; background: #1c1b18; border-radius: 1px; }
.lh-row { display: grid; grid-template-columns: 130px 1fr; gap: 18px; padding: 12px 0; border-bottom: 1px solid var(--doc-rule); align-items: start; }
.lh-row:last-child { border-bottom: 0; }
.lh-tag { font-family: var(--doc-mono); font-size: 11px; color: var(--doc-faint); }
.lh-tag b { color: var(--doc-ink); display: block; font-size: 13px; margin-top: 2px; }
.lh-sample { font-family: var(--doc-serif); font-size: 15px; color: #353330; }
.slot-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(108px,1fr)); gap: 16px; }
.slot { text-align: center; }
.slot__box { height: 64px; display: grid; place-items: center; margin-bottom: 8px; }
.slot__chip { width: 56px; height: 56px; background: var(--doc-card); border: 1px solid var(--doc-rule-2); }
.slot__tag { font-family: var(--doc-mono); font-size: 10.5px; color: var(--doc-faint); line-height: 1.35; }
.slot__tag b { color: var(--doc-ink); display: block; }

/* ============================================================================
   CODE PANEL
   ============================================================================ */
.code-wrap { border: 1px solid var(--doc-rule); border-radius: 5px; overflow: hidden; background: #1b1a17; }
.code-tabs { display: flex; flex-wrap: wrap; background: #211f1b; border-bottom: 1px solid #34322c; }
.code-tab { font-family: var(--doc-mono); font-size: 12px; color: #b7b1a3; background: transparent; border: 0; cursor: pointer; padding: 13px 16px; border-bottom: 2px solid transparent; }
.code-tab[aria-selected="true"] { color: #fff8e8; border-bottom-color: #c9a96e; background: #1b1a17; }
.code-tab:focus-visible { outline: 2px solid #c9a96e; outline-offset: -2px; }
.code-body { position: relative; }
.code-panel { display: none; }
.code-panel[data-active="true"] { display: block; }
.code-pre { margin: 0; padding: 22px 20px; overflow-x: auto; font-family: var(--doc-mono); font-size: 12.5px; line-height: 1.7; color: #e9e3d4; }
.code-pre .c { color: #8f8a7a; font-style: italic; }
.code-pre .v { color: #c9a96e; }
.code-pre .s { color: #9ec99b; }
.code-pre .k { color: #d6a3c4; }
.copy-btn { position: absolute; top: 12px; right: 12px; z-index: 2; font-family: var(--doc-mono); font-size: 11px; letter-spacing: 0.06em; color: #1b1a17; background: #c9a96e; border: 0; cursor: pointer; padding: 7px 12px; border-radius: 3px; text-transform: uppercase; }
.copy-btn:hover { background: #d8bd86; }
.copy-btn:focus-visible { outline: 2px solid #fff8e8; outline-offset: 2px; }

/* ============================================================================
   CONTRACT TABLE + NOTES
   ============================================================================ */
.tbl-scroll { overflow-x: auto; border: 1px solid var(--doc-rule); border-radius: 5px; }
table.contract { border-collapse: collapse; width: 100%; min-width: 720px; background: var(--doc-card); }
table.contract th, table.contract td { text-align: left; padding: 11px 16px; border-bottom: 1px solid var(--doc-rule); vertical-align: top; }
table.contract thead th { font-family: var(--doc-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--doc-faint); background: #efebe2; }
table.contract td.var { font-family: var(--doc-mono); font-size: 12px; color: #6b4f1e; white-space: nowrap; }
table.contract td.desc { font-size: 14px; color: #4a473f; }
table.contract tr:last-child td { border-bottom: 0; }
.grp-row td { background: #efebe2; font-family: var(--doc-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--doc-ink); font-weight: 600; }
.cards-2 { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 820px) { .cards-2 { grid-template-columns: 1fr 1fr; } }
.note-card { background: var(--doc-card); border: 1px solid var(--doc-rule); border-radius: 5px; padding: 26px 28px; }
.note-card h3 { font-family: var(--doc-serif); font-weight: 600; font-size: 21px; margin: 0 0 14px; }
.note-card ul { margin: 0; padding-left: 20px; }
.note-card li { margin-bottom: 9px; color: #3c3a34; font-size: 15px; }
.note-card li b { color: var(--doc-ink); }
.note-card p { color: #3c3a34; font-size: 15px; margin: 0 0 12px; }
.note-card p:last-child { margin-bottom: 0; }
.kbd { font-family: var(--doc-mono); font-size: 11px; background: #efebe2; border: 1px solid var(--doc-rule-2); border-radius: 3px; padding: 1px 6px; color: var(--doc-ink); }
.pill-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; }
.pill { font-family: var(--doc-mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: #4a473f; border: 1px solid var(--doc-rule-2); border-radius: 999px; padding: 5px 12px; }

/* ============================================================================
   HAMBURGER MOBILE-NAV COMPONENT ("the weave") — token-driven drawer
   Shown only in the simulated mobile viewport (and on real small screens).
   ============================================================================ */
.pv-burger {
  display: none; flex: none; width: 40px; height: 40px; align-items: center; justify-content: center;
  flex-direction: column; gap: 5px; cursor: pointer; background: transparent;
  border: var(--border-default) solid var(--color-border); border-radius: var(--radius-md);
  padding: 0;
}
.pv-burger:focus-visible { outline: var(--border-heavy) solid var(--color-ring); outline-offset: 2px; }
.pv-burger span { display: block; width: 18px; height: 2px; background: var(--color-fg); border-radius: 2px; transition: transform .2s ease, opacity .2s ease; }
.render.nav-open .pv-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.render.nav-open .pv-burger span:nth-child(2) { opacity: 0; }
.render.nav-open .pv-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.pv-scrim {
  position: absolute; inset: 0; z-index: 4; background: color-mix(in srgb, var(--color-fg) 38%, transparent);
  opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease;
}
.render.nav-open .pv-scrim { opacity: 1; visibility: visible; }

.pv-sheet {
  position: absolute; top: 0; right: 0; z-index: 5; height: 100%; width: min(74%, 280px);
  background: var(--color-surface); border-left: var(--border-default) solid var(--color-border);
  box-shadow: var(--shadow-lg); padding: var(--space-6) var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-1);
  transform: translateX(100%); transition: transform .28s cubic-bezier(.2,.7,.2,1);
}
.render.nav-open .pv-sheet { transform: translateX(0); }
.pv-sheet__head { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: .14em; text-transform: uppercase; color: var(--color-muted); margin: 0 0 var(--space-3); }
.pv-sheet a {
  font-family: var(--font-body); font-size: var(--text-lg); font-weight: 600; color: var(--color-fg);
  text-decoration: none; padding: var(--space-3) 0; border-bottom: var(--border-thin) solid var(--color-border);
}
.pv-sheet a:last-of-type { border-bottom: 0; }
.pv-sheet a:hover { color: var(--color-accent); }
.pv-sheet__cta { margin-top: auto; }
.pv-sheet .pv-btn { width: 100%; justify-content: center; }

/* viewport-driven swap: mobile shows burger, hides inline links */
.render-host[data-vp="mobile"] .pv-navlinks { display: none; }
.render-host[data-vp="mobile"] .pv-burger { display: inline-flex; }
/* real small screens behave the same regardless of toggle */
@media (max-width: 560px) {
  .pv-navlinks { display: none; }
  .pv-burger { display: inline-flex; }
}

/* ============================================================================
   BRAND-GUIDE OVERRIDE PANEL — "a client handed us a brand guide"
   ============================================================================ */
.brandguide { border-top: 1px solid var(--doc-rule); margin-top: 14px; padding-top: 14px; }
.bg-fieldgrid { display: grid; grid-template-columns: 1fr; gap: 9px; margin-top: 12px; }
.bg-field { display: flex; align-items: center; gap: 10px; }
.bg-field__lbl { font-family: var(--doc-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--doc-faint); width: 64px; flex: none; }
.bg-swatch { width: 34px; height: 34px; border-radius: 5px; border: 1px solid var(--doc-rule-2); flex: none; padding: 0; cursor: pointer; overflow: hidden; }
.bg-swatch::-webkit-color-swatch-wrapper { padding: 0; } .bg-swatch::-webkit-color-swatch { border: 0; }
.bg-hex { flex: 1; min-width: 0; font-family: var(--doc-mono); font-size: 12px; color: var(--doc-ink); background: #fff; border: 1px solid var(--doc-rule-2); border-radius: 4px; padding: 7px 9px; text-transform: uppercase; }
.bg-hex:focus-visible { outline: 2px solid var(--doc-ink); outline-offset: 1px; }
.bg-toggle { font-family: var(--doc-mono); font-size: 11px; color: var(--doc-ink); background: none; border: 0; cursor: pointer; padding: 10px 0 0; text-decoration: underline; }
.bg-toggle:hover { color: #000; }
.bg-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.bg-action { font-family: var(--doc-mono); font-size: 10.5px; letter-spacing: .04em; color: var(--doc-ink); background: #fff; border: 1px solid var(--doc-rule-2); border-radius: 4px; padding: 7px 11px; cursor: pointer; }
.bg-action:hover { background: #efebe2; border-color: var(--doc-ink); }
.bg-action--solid { background: var(--doc-ink); color: var(--doc-card); border-color: var(--doc-ink); }
.bg-action--solid:hover { background: #000; }

/* ============================================================================
   RESPONSIVE — kill the mobile bleed, stack controls
   ============================================================================ */
.pg-stage__sig { max-width: 100%; overflow-wrap: anywhere; }
@media (max-width: 1000px) {
  .pg-controls { position: static; }
}
@media (max-width: 720px) {
  .wrap { padding: 0 16px; }
  section { padding: 48px 0; }
  .render-host { padding: 18px 12px; }
  .gal--pal, .gal--type, .gal--shape { grid-template-columns: 1fr; }
}

/* ---- footer ---- */
footer { padding: 40px 0 64px; }
.foot { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-family: var(--doc-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--doc-faint); }
