/*
Theme Name: Wayfinder
Theme URI: https://wayfinderconvergence.com
Author: Brian Caruso · Līfstead
Author URI: https://wayfinderconvergence.com
Description: Wayfinder by Līfstead – a custom Full Site Editing block theme for WayfinderConvergence.com. A structural orientation instrument brand: paper-and-brass editorial design system, five-system convergence layout, and WooCommerce orientation instruments. Built as a native FSE theme with editable block patterns, template parts, and a vanilla-JS Orientation Console.
Version: 1.0.2
Requires at least: 6.5
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: wayfinder
Tags: full-site-editing, block-patterns, woocommerce, custom-colors, custom-menu, editor-style, threaded-comments, block-styles, wide-blocks
*/

/* ═══════════════════════════════════════════════════════════════
   WAYFINDER THEME STYLES
   Ported verbatim from the source design system:
     1. wayfinder-base.css      (tokens, reset, header, console)
     2. wayfinder-sections.css  (homepage sections, footer)
     3. product-pages.css       (product/inner page components)
   Followed by theme-level additions (reveal, reduced-motion, reset).
   ═══════════════════════════════════════════════════════════════ */


/* ============================================================
   1 · BASE  (wayfinder-base.css)
   ============================================================ */
/* ═══════════════════════════════════════════════════════════════
   WAYFINDER BASE – Tokens · Reset · Header · Orientation Console
   ═══════════════════════════════════════════════════════════════ */

/* ─── DESIGN TOKENS ─────────────────────────────────────────── */
:root {
  --paper:       #ede7da;
  --paper-dark:  #e4ddd0;
  --paper-aged:  #d8d0c2;
  --paper-deep:  #ccc4b2;
  --bone:        #f5f0e6;

  --ink:         #1e2018;
  --ink-mid:     #2e3228;
  --ink-body:    #4a5442;
  --ink-faded:   #6b7860;
  --ink-ghost:   #9aaa8c;

  --brass:       #8c7040;
  --brass-lt:    #b8965a;
  --brass-pale:  #d4b87a;

  --rust:        #7a4020;

  --slate:       #3d4a52;
  --slate-mid:   #5a6870;
  --slate-lt:    #8a9aa4;

  --header-h:    60px;
}

/* ─── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background-color: var(--paper);
  background-image:
    linear-gradient(rgba(30,32,24,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(30,32,24,0.018) 1px, transparent 1px);
  background-size: 36px 36px;
  color: var(--ink);
  font-family: 'Jost', sans-serif;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; }
ul { list-style: none; }

/* ─── BUTTONS ────────────────────────────────────────────────── */
.btn-primary {
  display: block;
  width: 100%;
  background: var(--ink);
  color: var(--bone);
  border: 1px solid var(--ink);
  padding: 0.9rem 1rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.67rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  transition: background 160ms ease, border-color 160ms ease;
}
.btn-primary:hover { background: var(--brass); border-color: var(--brass); }

.btn-secondary {
  display: block;
  width: 100%;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--brass);
  padding: 0.9rem 1rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.67rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  transition: background 160ms ease, color 160ms ease;
}
.btn-secondary:hover { background: var(--brass); color: var(--bone); }

.btn-inline {
  display: inline-block;
  width: auto;
  padding: 0.65rem 1.1rem;
}

/* ─── STAMPS ─────────────────────────────────────────────────── */
.stamp {
  display: inline-block;
  border: 1px solid rgba(140,112,64,0.45);
  color: var(--brass);
  padding: 0.28rem 0.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  width: fit-content;
}

/* ─── HEADER ─────────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--header-h);
  background: var(--paper);
  border-bottom: 1px solid rgba(30,32,24,0.22);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding: 0 3%;
  max-width: 1600px;
  margin: 0 auto;
}
.header-brand { display: flex; flex-direction: column; gap: 0.1rem; }
.header-wordmark {
  font-family: 'Cormorant SC', serif;
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  color: var(--ink);
  line-height: 1;
}
.header-sublabel {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-faded);
}
.header-nav {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.nav-link {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.66rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-body);
  transition: color 140ms ease;
}
.nav-link:hover { color: var(--brass); }
.nav-begin {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.66rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--bone);
  background: var(--ink);
  border: 1px solid var(--ink);
  padding: 0.5rem 1rem;
  transition: background 160ms, border-color 160ms;
}
.nav-begin:hover { background: var(--brass); border-color: var(--brass); }

/* ─── MOBILE NAV ─────────────────────────────────────────────── */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  background: none;
  border: 1px solid rgba(30,32,24,0.22);
  cursor: pointer;
  padding: 0;
  width: 38px;
  height: 38px;
  flex-shrink: 0;
}
.nav-hamburger span {
  display: block;
  width: 18px;
  height: 1.5px;
  background: var(--ink);
  transition: transform 220ms ease, opacity 150ms ease;
}
.nav-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
.nav-mobile-menu {
  position: fixed;
  top: var(--header-h);
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--paper);
  background-image:
    linear-gradient(rgba(30,32,24,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(30,32,24,0.018) 1px, transparent 1px);
  background-size: 36px 36px;
  z-index: 99;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  border-top: 2px solid var(--brass);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity 200ms ease, transform 200ms ease;
}
.nav-mobile-menu.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.nav-mobile-link {
  display: block;
  padding: 1.1rem 6%;
  border-bottom: 1px solid rgba(30,32,24,0.1);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-body);
  text-decoration: none;
  transition: background 130ms ease, color 130ms ease;
}
.nav-mobile-link:hover { background: var(--paper-dark); color: var(--brass); }
.nav-mobile-section {
  padding: 0.65rem 6%;
  border-bottom: 1px solid rgba(30,32,24,0.1);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  background: var(--paper-dark);
}
.nav-mobile-instrument {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 6% 1.1rem calc(6% + 1.25rem);
  border-bottom: 1px solid rgba(30,32,24,0.1);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-body);
  text-decoration: none;
  transition: background 130ms ease, color 130ms ease;
  background: rgba(30,32,24,0.02);
}
.nav-mobile-instrument:hover { background: var(--paper-dark); color: var(--brass); }
.nav-mobile-instrument-price {
  font-size: 0.62rem;
  color: var(--brass);
  letter-spacing: 0.06em;
}
.nav-mobile-begin-btn {
  display: block;
  margin: 1.5rem 6% 2.5rem;
  background: var(--ink);
  color: var(--bone);
  border: 1px solid var(--ink);
  padding: 1.1rem 1rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  transition: background 160ms ease, border-color 160ms ease;
}
.nav-mobile-begin-btn:hover { background: var(--brass); border-color: var(--brass); }
@media (max-width: 600px) {
  .nav-hamburger { display: flex; }
}

/* ─── ORIENTATION CONSOLE ───────────────────────────────────── */
#orientation-root { display: block; }

.orientation-console {
  display: grid;
  grid-template-columns: 0.65fr 1.4fr 1fr;
  grid-template-rows: 1fr auto;
  min-height: calc(100vh - var(--header-h));
}
.left-rail    { grid-row: 1; grid-column: 1; }
.center-panel { grid-row: 1; grid-column: 2; }
.right-panel  { grid-row: 1; grid-column: 3; }

/* Left Rail */
.left-rail {
  background: var(--paper-dark);
  border-right: 1px solid rgba(30,32,24,0.18);
  border-top: 3px solid var(--brass);
  padding: 3rem 2.25rem;
}
.left-rail-inner {
  position: sticky;
  top: calc(var(--header-h) + 2rem);
}
.left-wordmark {
  font-family: 'Cormorant SC', serif;
  font-size: 1.55rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 0.4rem;
}
.left-stage {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0;
}
.rail-divider {
  width: 100%;
  height: 1px;
  background: rgba(30,32,24,0.18);
  margin: 1.6rem 0;
}
.rail-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.875rem;
  line-height: 1.65;
  color: var(--ink-body);
  margin-bottom: 0.9rem;
}
.rail-stamps {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

/* Center Panel */
.center-panel {
  padding: 3rem 3rem 3rem 2.75rem;
  border-right: 1px solid rgba(30,32,24,0.12);
}
.console-sublabel {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 1.1rem;
}
.console-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2rem, 3.2vw, 3.4rem);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin-bottom: 0.65rem;
}
.console-subcopy {
  font-family: 'Jost', sans-serif;
  font-size: 0.875rem;
  color: var(--ink-faded);
  margin-bottom: 2.25rem;
}

/* Threshold Cards */
.threshold-cards { display: flex; flex-direction: column; gap: 0.8rem; }

.threshold-card {
  background: var(--bone);
  border: 1px solid rgba(30,32,24,0.32);
  padding: 1.2rem 1.4rem;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
  gap: 1.1rem;
  transition: border-color 170ms ease, box-shadow 170ms ease, transform 170ms ease;
  outline: none;
}
.threshold-card:hover:not(.active) { border-color: rgba(140,112,64,0.55); }
.threshold-card:focus-visible { outline: 2px solid var(--brass); outline-offset: 2px; }
.threshold-card.active {
  border-color: var(--brass);
  border-left: 3px solid var(--rust);
  box-shadow: 5px 5px 0 var(--brass);
  transform: translate(-2px, -2px);
  background: var(--bone);
}
.card-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  color: var(--brass);
  padding-top: 0.2rem;
  flex-shrink: 0;
  min-width: 1.5rem;
}
.card-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.08rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--ink);
}

/* Right Panel */
.right-panel {
  padding: 2.5rem 2.25rem;
  background: var(--paper-dark);
  display: flex;
  flex-direction: column;
}

/* Recommendation Panel */
.rec-panel {
  background: var(--bone);
  border: 2px solid var(--ink);
  padding: 1.75rem;
  box-shadow: 6px 6px 0 var(--brass);
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
}
.rec-panel--empty { gap: 1rem; justify-content: center; }

.rec-panel-content { opacity: 1; }

.rec-empty-heading {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate-mid);
}
.rec-empty-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  color: var(--ink-faded);
  font-style: italic;
  line-height: 1.5;
}
.rec-empty-sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.8rem;
  color: var(--ink-ghost);
  line-height: 1.65;
}

.rec-meta-block { margin-bottom: 1.1rem; }
.rec-meta-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 0.3rem;
}
.rec-condition {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
}
.rec-phase {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-weight: 500;
  color: var(--slate);
}
.rec-mechanism {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.65;
}
.rec-divider {
  height: 1px;
  background: rgba(140,112,64,0.3);
  margin: 1rem 0;
}
.rec-instrument-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.55rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: 0.2rem;
}
.rec-instrument-sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: var(--ink-faded);
}
.rec-nextstep {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.65;
}
.rec-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.45rem;
  color: var(--ink);
  letter-spacing: 0.04em;
  margin: 0.9rem 0 1rem;
}
.rec-ctas { display: flex; flex-direction: column; gap: 0.55rem; margin-top: auto; }

/* ─── MOBILE DRAWER ─────────────────────────────────────────── */
.mobile-drawer {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--ink);
  color: var(--bone);
  border-top: 2px solid var(--brass);
  z-index: 200;
}
.mobile-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.9rem 1.25rem;
  cursor: pointer;
  gap: 1rem;
}
.mobile-drawer-summary { flex: 1; min-width: 0; }
.mobile-drawer-label {
  display: block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 0.1rem;
}
.mobile-drawer-instrument {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.mobile-drawer-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.mobile-btn-sm {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--bone);
  color: var(--ink);
  border: 1px solid var(--bone);
  padding: 0.4rem 0.65rem;
}
.mobile-btn-sm.outline {
  background: transparent;
  color: var(--brass-lt);
  border-color: var(--brass);
}
.drawer-toggle {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.75rem;
  color: var(--brass-lt);
  margin-left: 0.25rem;
  line-height: 1;
}
.mobile-drawer-body {
  padding: 1.25rem;
  border-top: 1px solid rgba(245,240,230,0.1);
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.m-rec-row { display: flex; flex-direction: column; gap: 0.18rem; }
.m-rec-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate-lt);
}
.m-rec-value {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--bone);
}
.m-rec-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.25rem;
  color: var(--bone);
  letter-spacing: 0.04em;
}
.btn-drawer-primary {
  display: block;
  width: 100%;
  background: var(--brass);
  color: var(--bone);
  border: 1px solid var(--brass);
  padding: 0.85rem 1rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.67rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  margin-top: 0.25rem;
}

/* ─── CONSOLE PROOF STRIP ────────────────────────────────────── */
.console-proof-strip {
  grid-row: 2;
  grid-column: 1 / 4;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  padding: 0.9rem 2rem;
  border-top: 2px solid rgba(140,112,64,0.45);
  background: var(--ink-mid);
  flex-wrap: wrap;
}
.cps-dot {
  color: var(--brass-lt);
  font-size: 0.45rem;
  line-height: 1;
}
.cps-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,230,0.5);
}
.cps-sep {
  color: var(--brass-lt);
  font-size: 0.7rem;
  opacity: 0.4;
}

/* ─── CARD HEADER ROW + PHASE LABEL ─────────────────────────── */
.card-header-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.55rem;
  gap: 0.5rem;
}
.card-title-group {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.28rem;
}
.card-phase-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  transition: color 170ms ease;
  text-align: right;
  line-height: 1.3;
  padding-top: 0.1rem;
}
.card-phase-label.active { color: var(--brass); }
.phase-active-badge {
  display: inline-block;
  background: var(--rust);
  color: var(--bone);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.49rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.14rem 0.42rem;
  line-height: 1.35;
}

/* ─── LEFT RAIL METADATA ─────────────────────────────────────── */
.rail-meta-block {
  border: 1px solid rgba(30,32,24,0.18);
  background: rgba(30,32,24,0.03);
}
.rail-meta-row {
  display: grid;
  grid-template-columns: 1.1fr 1.9fr;
  gap: 0.4rem;
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid rgba(30,32,24,0.1);
  align-items: start;
}
.rail-meta-row:last-child { border-bottom: none; }
.rml {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--slate-mid);
  padding-top: 0.1rem;
}
.rmv {
  font-family: 'Jost', sans-serif;
  font-size: 0.77rem;
  color: var(--ink-body);
  line-height: 1.4;
}
.status-dot { color: var(--brass); font-size: 0.65rem; }

.rail-ref {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}
.rail-ref-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate-mid);
}
.rail-ref-val {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.05em;
  color: var(--ink-faded);
}

/* ─── 3-STEP PROCESS MARKER ──────────────────────────────────── */
.rail-steps { display: flex; flex-direction: column; gap: 0.4rem; }
.rail-step {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  opacity: 0.4;
  transition: opacity 200ms ease;
}
.rail-step.done { opacity: 1; }
.step-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  color: var(--brass);
  min-width: 1.2rem;
}
.step-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-body);
}

/* ─── CENTER PANEL PROTOCOL LABEL ───────────────────────────── */
.console-protocol-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 1.1rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(140,112,64,0.3);
}

/* ─── RECOMMENDATION PANEL – OUTPUT HEADER ──────────────────── */
.rec-output-header {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  background: var(--ink);
  padding: 0.75rem 1.25rem;
  margin: -1.75rem -1.75rem 1.1rem;
  border-bottom: 1px solid rgba(140,112,64,0.3);
}
.rec-output-dot {
  width: 6px;
  height: 6px;
  background: var(--brass-lt);
  flex-shrink: 0;
}
.rec-output-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bone);
}

/* ─── REC CLASS GRID ─────────────────────────────────────────── */
.rec-class-grid {
  background: rgba(61,74,82,0.07);
  border: 1px solid rgba(61,74,82,0.2);
  border-left: 3px solid var(--slate);
  margin-bottom: 1.1rem;
}
.rcg-row {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  padding: 0.45rem 0.75rem;
  border-bottom: 1px solid rgba(30,32,24,0.1);
  align-items: center;
  gap: 0.4rem;
}
.rcg-row:last-child { border-bottom: none; }
.rcg-k {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate-mid);
}
.rcg-v {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
}

/* ─── REC INSTRUMENT GRID ────────────────────────────────────── */
.rec-instrument-grid {
  border: 1px solid rgba(30,32,24,0.2);
  margin-bottom: 1rem;
}
.rig-row {
  display: grid;
  grid-template-columns: 1fr 1.8fr;
  padding: 0.45rem 0.75rem;
  border-bottom: 1px solid rgba(30,32,24,0.1);
  align-items: start;
  gap: 0.4rem;
}
.rig-row:last-child { border-bottom: none; }
.rig-k {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate-mid);
  padding-top: 0.15rem;
}
.rig-v {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-body);
}
.rig-instrument-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.15;
  margin-bottom: 0.15rem;
}
.rig-instrument-sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.75rem;
  color: var(--ink-faded);
}
.rig-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.88rem;
  color: var(--ink);
  letter-spacing: 0.04em;
}

/* ─── REC STANDBY STATE ──────────────────────────────────────── */
.rec-panel--standby {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.rec-standby-bar {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  background: var(--ink-mid);
  padding: 0.75rem 1.25rem;
  margin: -1.75rem -1.75rem 1.1rem;
}
.rec-standby-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  background: rgba(245,240,230,0.3);
  flex-shrink: 0;
}
.rec-standby-body { flex: 1; display: flex; flex-direction: column; gap: 0.75rem; }
.rec-standby-sub {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-ghost);
}
.rec-standby-grid {
  border: 1px solid rgba(30,32,24,0.15);
  margin-top: 0.25rem;
}
.rsg-row {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  padding: 0.4rem 0.75rem;
  border-bottom: 1px solid rgba(30,32,24,0.08);
  gap: 0.4rem;
}
.rsg-row:last-child { border-bottom: none; }
.rsg-k {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate-lt);
}
.rsg-v {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  color: var(--ink-ghost);
}

/* ─── HEADER – DOCUMENT INSTRUMENT VERSION ───────────────────── */
.header-ref {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
  margin-top: 0.1rem;
}
.header-doc-info {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
.header-doc-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  border: 1px solid rgba(30,32,24,0.15);
  padding: 0.22rem 0.6rem;
}
.nav-sep {
  color: var(--brass);
  opacity: 0.4;
  font-size: 0.7rem;
  user-select: none;
}

/* ─── RAIL INK HEADER ───────────────────────────────────────── */
.rail-ink-header {
  background: rgba(30,32,24,0.06);
  border-bottom: 1px solid rgba(140,112,64,0.22);
  padding: 0.5rem 2.25rem;
  margin: -3rem -2.25rem 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rih-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.52rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate-mid);
}
.rih-ref {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.52rem;
  letter-spacing: 0.1em;
  color: var(--brass);
}

/* ─── DOSSIER WRAPPER + REPORT GHOST DOC ────────────────────── */
.dossier-wrapper {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  margin-right: 14px;
  margin-bottom: 14px;
}
.report-ghost-doc {
  position: absolute;
  top: 14px;
  left: 14px;
  right: -14px;
  bottom: -14px;
  background: var(--paper-aged);
  border: 1px solid rgba(30,32,24,0.18);
  z-index: 0;
  overflow: hidden;
  padding: 1.1rem 1.3rem;
}
.rg-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.85rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(30,32,24,0.1);
  gap: 0.5rem;
}
.rg-ref {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.5rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  line-height: 1.4;
}
.rg-redacted {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.5rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(122,64,32,0.5);
  border: 1px solid rgba(122,64,32,0.3);
  padding: 0.12rem 0.32rem;
  white-space: nowrap;
  flex-shrink: 0;
}
.rg-body {
  display: flex;
  flex-direction: column;
  gap: 0.72rem;
}
.rg-section {
  display: flex;
  flex-direction: column;
}
.rg-section-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.47rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.38rem;
  opacity: 0.55;
}
.rg-line {
  height: 1px;
  background: rgba(30,32,24,0.1);
  margin-bottom: 0.3rem;
}

/* ─── TERTIARY CTA LINK ─────────────────────────────────────── */
.rec-cta-tertiary {
  display: block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--slate-mid);
  text-align: center;
  padding-top: 0.55rem;
  border-top: 1px solid rgba(30,32,24,0.1);
  transition: color 140ms ease;
  line-height: 1.5;
}
.rec-cta-tertiary:hover { color: var(--brass); }

/* ============================================================
   2 · SECTIONS  (wayfinder-sections.css)
   ============================================================ */
/* ═══════════════════════════════════════════════════════════════
   WAYFINDER SECTIONS – Proof Strip · Phases · Instruments ·
   Artifact · Method · Boundary · Purchase · Timeline · Footer
   ═══════════════════════════════════════════════════════════════ */

/* ─── PROOF STRIP ───────────────────────────────────────────── */
.proof-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid rgba(30,32,24,0.55);
  border-bottom: 1px solid rgba(30,32,24,0.55);
  background: var(--paper-dark);
}
.proof-item {
  padding: 0.95rem 1.25rem;
  border-right: 1px solid rgba(30,32,24,0.18);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-body);
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.proof-item:last-child { border-right: none; }
.proof-item::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  background: var(--brass);
  flex-shrink: 0;
}

/* ─── SECTION BASE ──────────────────────────────────────────── */
.section {
  /* intrinsic: 3.5rem@600px -> 5.5rem@1280px (was stepped at 900/600) */
  padding: clamp(3.5rem, 1.74rem + 4.71vw, 5.5rem) clamp(5%, 8.76vw - 1.41rem, 7%);
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.section-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.8rem;
}
.section-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.75rem, 2.8vw, 2.7rem);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.section-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.95rem;
  color: var(--ink-body);
  line-height: 1.7;
  margin-top: 0.9rem;
  max-width: 54ch;
}
.section-header { margin-bottom: 3rem; }

/* ─── PHASE RECOGNITION ─────────────────────────────────────── */
.phase-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border: 1px solid rgba(30,32,24,0.22);
  gap: 0;
}
.phase-card {
  background: var(--paper-dark);
  padding: 2rem 1.75rem;
  border-right: 1px solid rgba(30,32,24,0.15);
  border-left: 4px solid transparent;
  transition: border-left-color 200ms ease, background 200ms ease;
}
.phase-card:last-child { border-right: none; }
.phase-card.active {
  border-left-color: var(--brass);
  background: var(--bone);
}
.phase-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.5rem;
}
.phase-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 0.85rem;
}
.phase-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.6;
  margin-bottom: 1.25rem;
}
.phase-fit {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--slate);
}
.phase-fit-label {
  color: var(--slate-mid);
  margin-right: 0.3rem;
}

/* ─── PHASE RECOGNITION V2 ──────────────────────────────────── */
.pr2-section { background: var(--paper-dark); }

.pr2-intro {
  max-width: 680px;
  margin-bottom: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.pr2-intro-p {
  font-family: 'Jost', sans-serif;
  font-size: 0.92rem;
  line-height: 1.8;
  color: var(--ink-body);
  text-wrap: pretty;
}

/* Signal cards */
.pr2-signals {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(30,32,24,0.28);
  margin-bottom: 0;
}
.pr2-signal-card {
  border-bottom: 1px solid rgba(30,32,24,0.18);
  display: grid;
  grid-template-columns: 220px 1fr;
}
.pr2-signal-card:last-child { border-bottom: none; }

.pr2-sig-head {
  background: var(--paper-aged);
  border-right: 1px solid rgba(30,32,24,0.18);
  padding: 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  justify-content: center;
}
.pr2-sig-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: clamp(1rem, 0.46rem + 1.24vw, 1.45rem);
  letter-spacing: 0.04em;
  color: var(--brass);
  line-height: 1;
}
.pr2-sig-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate);
}
.pr2-sig-body {
  padding: 1.5rem 1.75rem;
  background: var(--bone);
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  justify-content: center;
}
.pr2-sig-q {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
}
.pr2-sig-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.8rem;
  color: var(--ink-body);
  line-height: 1.7;
}

/* Consensus band */
.pr2-consensus {
  background: var(--ink);
  border: 1px solid rgba(140,112,64,0.3);
  border-top: none;
  padding: 1.5rem 2rem;
  margin-bottom: 3.5rem;
}
.pr2-con-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 1rem;
}
.pr2-con-equation {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6rem 1rem;
}
.pr2-eq-term {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-style: italic;
  color: var(--bone);
}
.pr2-eq-op {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.85rem;
  color: var(--brass);
}
.pr2-eq-result {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 600;
  font-style: italic;
  color: var(--brass-pale);
}

/* Artifact + sample output */
.pr2-artifact-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 3rem;
  align-items: start;
  margin-bottom: 3rem;
}
.pr2-artifact-frame {
  border: 1px solid rgba(30,32,24,0.3);
  box-shadow: 4px 4px 0 var(--paper-deep);
  overflow: hidden;
  background: var(--bone);
}
.pr2-artifact-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: top;
}
.pr2-sample-output {
  border: 2px solid var(--ink);
  background: var(--bone);
  padding: 1.75rem;
  position: relative;
}
.pr2-sample-output::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--brass);
}
.pr2-so-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1rem;
}
.pr2-so-phase {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 2.4vw, 2.1rem);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: 0.6rem;
}
.pr2-so-tagline {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-style: italic;
  color: var(--ink-body);
  line-height: 1.5;
  margin-bottom: 1.1rem;
  padding-bottom: 1.1rem;
  border-bottom: 1px solid rgba(140,112,64,0.3);
}
.pr2-so-note {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.7;
}

/* Closing copy */
.pr2-closing {
  max-width: 620px;
  margin-bottom: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pr2-close-p {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--ink-body);
}
.pr2-close-em {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-style: italic;
  color: var(--ink);
}

/* CTAs */
.pr2-ctas {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

/* Responsive – tablet */
@media (max-width: 900px) {
  .pr2-artifact-grid { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 700px) {
  .pr2-signal-card { grid-template-columns: 1fr; }
  .pr2-sig-head {
    border-right: none;
    border-bottom: 1px solid rgba(30,32,24,0.18);
    flex-direction: row;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem 1.25rem;
  }
  .pr2-sig-body { padding: 1.1rem 1.25rem; }
  .pr2-con-equation { flex-direction: column; gap: 0.3rem; align-items: flex-start; }
  .pr2-ctas { flex-direction: column; }
  .pr2-ctas .btn-inline { width: 100%; display: block; text-align: center; }
}

/* ─── INSTRUMENT LADDER ─────────────────────────────────────── */
.instruments-section { background: var(--paper-aged); }

.instrument-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
.instrument-card {
  background: var(--bone);
  border: 1px solid rgba(30,32,24,0.35);
  padding: 2rem 1.75rem;
  display: flex;
  flex-direction: column;
}
.instrument-card.featured {
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 var(--brass);
}
.instrument-role {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 0.5rem;
}
.instrument-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.45rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.45rem;
}
.instrument-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.88rem;
  color: var(--brass);
  letter-spacing: 0.05em;
  margin-bottom: 1.25rem;
}
.instrument-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-body);
  line-height: 1.65;
  margin-bottom: 1.5rem;
  flex: 1;
}
.includes-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.6rem;
}
.includes-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1.75rem;
}
.includes-list li {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
}
.includes-list li::before {
  content: '–';
  color: var(--brass);
  font-size: 0.75rem;
  flex-shrink: 0;
  padding-top: 0.05rem;
}
/* Business wide card */
.instrument-business {
  background: var(--paper-dark);
  border: 1px solid rgba(30,32,24,0.3);
  border-top: 3px solid var(--slate);
  padding: 2.25rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 3rem;
  align-items: center;
}
.business-role {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 0.4rem;
}
.business-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.55rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.35rem;
}
.business-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.82rem;
  color: var(--brass);
  margin-bottom: 0.85rem;
  letter-spacing: 0.04em;
}
.business-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.875rem;
  color: var(--ink-body);
  line-height: 1.65;
  max-width: 56ch;
}

/* ─── ARTIFACT PROOF ────────────────────────────────────────── */
.artifact-section {
  background: var(--paper);
  border-bottom: 1px solid rgba(30,32,24,0.15);
}
.artifact-inner {
  padding: 5.5rem 7%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}
.artifact-header { margin-bottom: 2rem; }
.artifact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0.75rem;
  align-items: start;
}
.artifact-col { display: flex; flex-direction: column; gap: 0.75rem; }

/* Image artifact frames */
.artifact-frame {
  border: 1px solid rgba(30,32,24,0.38);
  overflow: hidden;
  position: relative;
  display: block;
}
.artifact-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.artifact-frame.ap-tall { aspect-ratio: 3 / 4.2; }
.artifact-frame.ap-wide { aspect-ratio: 4 / 2.6; }
.artifact-frame.ap-sq   { aspect-ratio: 1 / 1; }

.artifact-placeholder {
  background: var(--paper-aged);
  border: 1px solid rgba(30,32,24,0.38);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 1.5rem;
}
.artifact-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 11px,
    rgba(30,32,24,0.032) 11px,
    rgba(30,32,24,0.032) 12px
  );
}
.artifact-placeholder::after {
  content: '';
  position: absolute;
  top: 8px;
  right: 8px;
  width: 14px;
  height: 14px;
  border-top: 1px solid rgba(140,112,64,0.4);
  border-right: 1px solid rgba(140,112,64,0.4);
}
.ap-tall  { aspect-ratio: 3 / 4.2; }
.ap-wide  { aspect-ratio: 4 / 2.6; }
.ap-sq    { aspect-ratio: 1 / 1; }
.ap-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-faded);
  text-align: center;
  position: relative;
  z-index: 1;
  line-height: 1.5;
}
.ap-sub {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.52rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  position: relative;
  z-index: 1;
}

.artifact-excerpt {
  background: var(--bone);
  border: 2px solid var(--ink);
  padding: 2rem;
}
.excerpt-meta {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding-bottom: 1.4rem;
  margin-bottom: 1.4rem;
  border-bottom: 1px solid rgba(140,112,64,0.3);
}
.excerpt-meta-row {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--slate);
}
.excerpt-meta-val { color: var(--ink-body); }
.excerpt-body {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.08rem;
  color: var(--ink-body);
  line-height: 1.75;
  font-style: italic;
  margin-bottom: 1.5rem;
}
.excerpt-diagram {
  margin-bottom: 1.75rem;
}

/* ─── ARTIFACT V2 – CONVERGENT PATTERN ──────────────────────── */
.av2-wrap {
  padding: 5.5rem 7%;
  max-width: 1600px;
  margin: 0 auto;
}
.av2-header {
  max-width: 800px;
  margin-bottom: 3.5rem;
}
.av2-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.9rem, 2.6vw, 2.9rem);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0.55rem 0 1rem;
}
.av2-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.8;
  color: var(--ink-body);
  max-width: 680px;
  text-wrap: pretty;
  margin-bottom: 0.75rem;
}
.av2-body:last-child { margin-bottom: 0; }

/* Main 2-col */
.av2-main {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 4.5rem;
  align-items: start;
}

/* ── Pages column ── */
.av2-pages { display: flex; flex-direction: column; gap: 0.9rem; }
.av2-scene {
  position: relative;
  height: 540px;
  background: var(--paper-aged);
  border: 1px solid rgba(30,32,24,0.14);
  overflow: hidden;
}
.av2-doc {
  position: absolute;
  overflow: hidden;
  box-shadow: 0 3px 14px rgba(30,32,24,0.22), 0 0 0 1px rgba(30,32,24,0.12);
  background: #f8f4ec;
}
.av2-doc-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
/* Cover – back layer, tilted left */
.av2-doc--cover {
  width: 50%;
  top: 6%;
  left: 4%;
  bottom: 14%;
  transform: rotate(-2.8deg);
  transform-origin: bottom left;
  z-index: 1;
}
/* Legend – middle layer */
.av2-doc--legend {
  width: 52%;
  top: 10%;
  left: 22%;
  bottom: 8%;
  transform: rotate(1.6deg);
  transform-origin: bottom center;
  z-index: 2;
}
/* Convergent Pattern – front, most prominent */
.av2-doc--pattern {
  width: 54%;
  top: 5%;
  right: 4%;
  bottom: 4%;
  transform: rotate(-0.7deg);
  transform-origin: bottom right;
  z-index: 3;
}
.av2-scene-caption {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}

/* Intake block */
.av2-intake-block {
  border-left: 2px solid var(--brass);
  padding: 1rem 1.25rem;
  background: rgba(140,112,64,0.06);
  margin-top: 0.25rem;
}
.av2-intake-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.6rem;
}
.av2-intake-lead {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.5;
  margin-bottom: 0.55rem;
}
.av2-intake-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.7;
}
.av2-cap-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
}
.av2-cap-sep { color: var(--ink-ghost); font-size: 0.65rem; }
.av2-cap-text {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.06em;
  color: var(--ink-ghost);
}

/* ── Proof column ── */
.av2-proof {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* Convergent Truth card */
.av2-ct-card {
  background: var(--ink);
  border: 1px solid rgba(140,112,64,0.35);
  padding: 2rem 2.1rem 1.75rem;
  position: relative;
}
.av2-ct-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--brass);
}
.av2-ct-meta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 1.25rem;
}
.av2-ct-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.35rem, 1.9vw, 1.85rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.35;
  color: var(--bone);
  margin-bottom: 1.4rem;
  letter-spacing: -0.01em;
}
.av2-ct-orient {
  font-family: 'Jost', sans-serif;
  font-size: 0.8rem;
  color: var(--brass-pale);
  line-height: 1.6;
  border-top: 1px solid rgba(140,112,64,0.25);
  padding-top: 1rem;
}

/* Evidence grid */
.av2-ev-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid rgba(30,32,24,0.28);
}
.av2-ev-card {
  padding: 1.1rem 1.25rem;
  border-right: 1px solid rgba(30,32,24,0.15);
  border-bottom: 1px solid rgba(30,32,24,0.15);
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  background: var(--bone);
  transition: background 150ms ease;
}
.av2-ev-card:nth-child(even) { border-right: none; }
.av2-ev-card:nth-child(3),
.av2-ev-card:nth-child(4) { border-bottom: none; }
.av2-ev-card:hover { background: var(--paper); }
.av2-ev-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  color: var(--brass);
  line-height: 1;
}
.av2-ev-system {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  line-height: 1.3;
  margin-top: 0.1rem;
}
.av2-ev-q {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: var(--ink-body);
  line-height: 1.5;
  margin-top: 0.2rem;
}

/* Sample report CTA */
.av2-sample-btn {
  display: block;
  width: 100%;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--brass);
  padding: 0.85rem 1rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.67rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  transition: background 160ms ease, color 160ms ease;
  margin-top: 0.25rem;
}
.av2-sample-btn:hover { background: var(--brass); color: var(--bone); }

/* Responsive */
@media (max-width: 1024px) {
  .av2-main { grid-template-columns: 1fr; gap: 3rem; }
  .av2-scene { height: 420px; }
}
@media (max-width: 640px) {
  .av2-wrap { padding: 3.5rem 5%; }
  .av2-scene { height: 320px; }
  .av2-ev-grid { grid-template-columns: 1fr; }
  .av2-ev-card { border-right: none !important; }
  .av2-ev-card:nth-child(3) { border-bottom: 1px solid rgba(30,32,24,0.15) !important; }
  .av2-ev-card:nth-child(4) { border-bottom: none !important; }
}

/* ─── DRIFT BAND ────────────────────────────────────────────── */
.drift-band {
  background: var(--paper);
  border-top: 1px solid rgba(30,32,24,0.1);
  border-bottom: 1px solid rgba(30,32,24,0.1);
  padding: 2rem 7%;
  text-align: center;
}
.drift-line {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1rem, 1.5vw, 1.3rem);
  font-style: italic;
  font-weight: 500;
  color: var(--ink-body);
  line-height: 1.65;
  margin: 0;
  letter-spacing: 0.01em;
}

/* ─── TESTIMONIAL ────────────────────────────────────────────── */
.tf-section {
  background: var(--ink);
  border-top: 2px solid var(--brass);
  border-bottom: 2px solid var(--brass);
}
.tf-wrap {
  padding: 4.5rem 7%;
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}
.tf-meta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 2rem;
}
.tf-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.5rem, 2.4vw, 2.2rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.4;
  color: var(--bone);
  margin: 0 0 1.75rem;
  letter-spacing: -0.01em;
}
.tf-attrib {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--brass-lt, var(--brass));
  text-transform: uppercase;
}

/* ─── ANTI-DEPENDENCY BLOCK ──────────────────────────────────── */
.ad-block {
  border: 1px solid rgba(30,32,24,0.3);
  border-left: 3px solid var(--brass);
  background: var(--bone);
  padding: 1.75rem 2rem;
  margin-bottom: 2.5rem;
  max-width: 680px;
}
.ad-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.65rem;
}
.ad-statement {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.2rem, 1.7vw, 1.5rem);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.2;
  margin: 0 0 0.6rem;
}
.ad-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-body);
  line-height: 1.7;
  margin: 0;
  text-wrap: pretty;
}

/* ─── TIMELINE WINDOWS ──────────────────────────────────────── */
.tw-section { background: var(--paper); }
.tw-wrap {
  padding: 5.5rem 7%;
  max-width: 1600px;
  margin: 0 auto;
}
.tw-header {
  max-width: 760px;
  margin-bottom: 3.5rem;
}
.tw-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.9rem, 2.6vw, 2.9rem);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0.55rem 0 1rem;
}
.tw-lead {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--ink-body);
  max-width: 620px;
  text-wrap: pretty;
}

/* Main 2-col */
.tw-main {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 4.5rem;
  align-items: start;
  margin-bottom: 3.5rem;
}

/* Image column */
.tw-image-col { display: flex; flex-direction: column; gap: 0.9rem; }
.tw-doc-frame {
  border: 1px solid rgba(30,32,24,0.18);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(30,32,24,0.14);
  background: #f6f2ea;
}
.tw-doc-img {
  display: block;
  width: 100%;
  height: auto;
}
.tw-img-caption {
  display: flex;
  align-items: center;
  gap: 0.55rem;
}
.tw-cap-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
}

/* Content column */
.tw-content-col { display: flex; flex-direction: column; gap: 2.25rem; }
.tw-intro p {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.8;
  color: var(--ink-body);
  margin: 0 0 0.9rem;
  text-wrap: pretty;
}
.tw-intro p:last-child { margin-bottom: 0; }

/* Source cards */
.tw-sources {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid rgba(30,32,24,0.28);
}
.tw-src-card {
  padding: 1.25rem 1.4rem;
  border-right: 1px solid rgba(30,32,24,0.15);
  border-bottom: 1px solid rgba(30,32,24,0.15);
  background: var(--bone);
  transition: background 150ms ease;
}
.tw-src-card:nth-child(even) { border-right: none; }
.tw-src-card:nth-child(3),
.tw-src-card:nth-child(4) { border-bottom: none; }
.tw-src-card:hover { background: var(--paper); }
.tw-src-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  color: var(--brass);
  margin-bottom: 0.25rem;
}
.tw-src-name {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 0.2rem;
}
.tw-src-tag {
  font-family: 'Cormorant Garamond', serif;
  font-size: 0.95rem;
  font-style: italic;
  color: var(--ink);
  margin-bottom: 0.4rem;
}
.tw-src-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: var(--ink-body);
  line-height: 1.55;
  margin: 0;
}

/* Output block */
.tw-output {
  border: 1px solid rgba(30,32,24,0.28);
  background: var(--paper-dark);
  padding: 2.5rem 2.75rem;
  margin-bottom: 3rem;
}
.tw-output-header {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.75rem;
}
.tw-output-lead {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.4rem, 2vw, 1.9rem);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.15;
  margin-bottom: 0.55rem;
}
.tw-output-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.87rem;
  color: var(--ink-body);
  line-height: 1.7;
  margin: 0 0 2rem;
  max-width: 560px;
  text-wrap: pretty;
}
.tw-windows-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid rgba(30,32,24,0.22);
}
.tw-win-card {
  padding: 1.4rem 1.6rem;
  border-right: 1px solid rgba(30,32,24,0.15);
  background: var(--bone);
}
.tw-win-card:last-child { border-right: none; }
.tw-win-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.56rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.55rem;
  min-height: 1em;
}
.tw-win-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 0.65rem;
  border-bottom: 1px solid rgba(30,32,24,0.14);
  padding-bottom: 0.65rem;
}
.tw-win-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.8rem;
  color: var(--ink-body);
  line-height: 1.7;
  margin: 0;
}

/* Footer: principle + CTAs */
.tw-footer {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  align-items: flex-start;
}
.tw-principle {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.2rem, 1.7vw, 1.5rem);
  font-weight: 500;
  font-style: italic;
  color: var(--ink);
  line-height: 1.5;
  border-left: 2px solid var(--brass);
  padding-left: 1.5rem;
  margin: 0;
  max-width: 640px;
}
.tw-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

/* ─── BOUNDARY (WHAT THIS IS NOT) ───────────────────────────── */
.boundary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.boundary-col {
  padding: 2.25rem;
  border: 1px solid rgba(30,32,24,0.28);
}
.boundary-not { background: var(--bone); border-top: 4px solid var(--rust); }
.boundary-this { background: var(--paper-aged); border-top: 4px solid var(--brass); }
.boundary-col-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
}
.boundary-not .boundary-col-label { color: var(--rust); }
.boundary-this .boundary-col-label { color: var(--brass); }
.boundary-list { display: flex; flex-direction: column; gap: 0.8rem; }
.boundary-list li {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: var(--ink-body);
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  line-height: 1.4;
}
.boundary-not .boundary-list li::before {
  content: '×';
  color: var(--rust);
  font-size: 0.68rem;
  padding-top: 0.18rem;
  flex-shrink: 0;
}
.boundary-this .boundary-list li::before {
  content: '→';
  color: var(--brass);
  font-size: 0.82rem;
  flex-shrink: 0;
}

#not-this  { background: var(--paper-dark); }
#purchase  { background: var(--paper-aged); }
#process   { background: var(--paper); }
#ai-data   { background: var(--paper-dark); }

/* ─── PURCHASE PATH ─────────────────────────────────────────── */
.purchase-cards {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}
.purchase-card {
  background: var(--bone);
  border: 1px solid rgba(30,32,24,0.28);
  padding: 1.6rem 1.75rem;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 2rem;
  transition: border-color 150ms ease;
}
.purchase-card:hover { border-color: var(--brass); }
.purchase-card.featured { border-color: var(--brass); border-width: 1px; }
.purchase-intent {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.35rem;
  line-height: 1.3;
}
.purchase-arrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--slate);
}

/* ─── POST-PURCHASE TIMELINE ────────────────────────────────── */
.timeline {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border: 1px solid rgba(30,32,24,0.22);
  gap: 0;
}
.timeline-step {
  background: var(--bone);
  padding: 2rem 1.5rem;
  border-right: 1px solid rgba(30,32,24,0.15);
  position: relative;
}
.timeline-step:last-child { border-right: none; }
.timeline-step::after {
  content: '';
  position: absolute;
  top: 50%;
  right: -9px;
  width: 8px;
  height: 1px;
  background: var(--brass);
  display: none;
}
.timeline-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--brass);
  margin-bottom: 0.6rem;
}
.timeline-step-name {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 0.75rem;
}
.timeline-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.65;
}

/* ─── AI PRODUCT DATA BLOCK ─────────────────────────────────── */
.ai-block {
  background: var(--paper-dark);
  border: 1px solid rgba(61,74,82,0.35);
  border-left: 4px solid var(--slate);
  padding: 2.75rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4rem;
  align-items: center;
}
.ai-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 0.7rem;
}
.ai-heading {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.8rem;
  line-height: 1.2;
}
.ai-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.875rem;
  color: var(--ink-body);
  line-height: 1.7;
  max-width: 52ch;
}

/* ─── FOOTER ─────────────────────────────────────────────────── */
.site-footer {
  background: var(--ink);
  color: var(--paper);
  padding: 4.5rem 7% 2.5rem;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3.5rem;
}
.footer-wordmark {
  font-family: 'Cormorant SC', serif;
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--paper);
  margin-bottom: 0.3rem;
}
.footer-sub {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 1.5rem;
}
.footer-disclaimer {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: rgba(237,231,218,0.4);
  line-height: 1.65;
}
.footer-col-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 1rem;
}
.footer-links { display: flex; flex-direction: column; gap: 0.55rem; }
.footer-links a {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: rgba(237,231,218,0.55);
  transition: color 140ms;
}
.footer-links a:hover { color: var(--paper); }
.footer-bottom {
  border-top: 1px solid rgba(237,231,218,0.1);
  padding-top: 1.75rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: rgba(237,231,218,0.25);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

/* ─── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .orientation-console { grid-template-columns: 0.7fr 1fr 1fr; }
  .instrument-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

@media (max-width: 900px) {
  .orientation-console {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    min-height: auto;
  }
  .center-panel { grid-row: auto; grid-column: 1; padding: 2.25rem 5%; border-right: none; order: 1; }
  .left-rail    { display: none; }
  .right-panel  { display: none; }
  .console-proof-strip { grid-row: auto; grid-column: 1; order: 3; }
  .left-rail-inner { position: static; }
  .rail-ink-header { margin: -2.25rem -5% 1.5rem; }
  .mobile-drawer { display: block; }
  body { padding-bottom: 72px; }

  .proof-strip { grid-template-columns: repeat(3, 1fr); }
  .proof-item:nth-child(3) { border-right: none; }
  .proof-item:nth-child(4),
  .proof-item:nth-child(5) { border-top: 1px solid rgba(30,32,24,0.15); }
  .proof-item:nth-child(5) { border-right: none; }

  .phase-grid { grid-template-columns: 1fr 1fr; }
  .phase-card:nth-child(2),
  .phase-card:nth-child(4) { border-right: none; }
  .phase-card:nth-child(3),
  .phase-card:nth-child(4),
  .phase-card:nth-child(5) { border-top: 1px solid rgba(30,32,24,0.15); }
  .phase-card:nth-child(5) { grid-column: 1 / -1; border-right: none; }

  .instrument-grid { grid-template-columns: 1fr; }
  .instrument-business { grid-template-columns: 1fr; gap: 1.5rem; }

  .artifact-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .artifact-grid { grid-template-columns: 1fr 1fr; }

  .tw-main { grid-template-columns: 1fr; gap: 2.5rem; }
  .tw-windows-grid { grid-template-columns: 1fr; }
  .tw-win-card { border-right: none; border-bottom: 1px solid rgba(30,32,24,0.15); }
  .tw-win-card:last-child { border-bottom: none; }
  /* legacy method kept for safety */
  .tw-src-card:nth-child(2n) { border-right: none; }
  .method-col:nth-child(3),
  .method-col:nth-child(4) { border-top: 1px solid rgba(30,32,24,0.15); }

  .boundary-grid { grid-template-columns: 1fr; gap: 1rem; }

  .purchase-card { grid-template-columns: 1fr; gap: 1rem; }

  .timeline { grid-template-columns: 1fr; }
  .timeline-step { border-right: none; border-bottom: 1px solid rgba(30,32,24,0.15); }
  .timeline-step:last-child { border-bottom: none; }

  .ai-block { grid-template-columns: 1fr; gap: 1.5rem; }

  .header-nav { gap: 1.2rem; }
  .nav-link:not(:last-child):nth-child(n+3) { display: none; }

  .artifact-inner { padding: 4rem 5%; }
}

@media (max-width: 600px) {
  .phase-grid { grid-template-columns: 1fr; }
  .phase-card { border-right: none; border-bottom: 1px solid rgba(30,32,24,0.15); }
  .phase-card:last-child { border-bottom: none; }

  .tw-sources { grid-template-columns: 1fr; }
  .tw-src-card { border-right: none !important; }
  .tw-src-card:nth-child(3) { border-bottom: 1px solid rgba(30,32,24,0.15) !important; }
  .tw-wrap { padding: 3.5rem 5%; }
  .tw-output { padding: 1.75rem 1.5rem; }

  .artifact-grid { grid-template-columns: 1fr; }

  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }

  .proof-strip { grid-template-columns: 1fr; }
  .proof-item { border-right: none; border-bottom: 1px solid rgba(30,32,24,0.12); }
  .proof-item:last-child { border-bottom: none; }

  .artifact-inner { padding: 3.5rem 5%; }

  .header-nav { display: none; }
}

/* ─── DRIFT BRIDGE – SECONDARY LINE ─────────────────────────── */
.drift-sub {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-faded);
  text-align: center;
  margin-top: 0.65rem;
}

/* ─── SYSTEMS CREDIBILITY NOTE ───────────────────────────────── */
.av2-systems-note {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  line-height: 1.8;
  letter-spacing: 0.03em;
  color: var(--slate-mid);
  border-left: 2px solid rgba(140,112,64,0.4);
  padding-left: 1rem;
  margin-bottom: 1.4rem;
}

/* ─── TESTIMONIAL GRID ───────────────────────────────────────── */
.tf-grid {
  display: flex;
  justify-content: center;
  width: 100%;
}

/* ─── CREATOR SECTION ────────────────────────────────────────── */
.bc-section { background: var(--paper); }

.bc-wrap {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 4.5rem;
  align-items: start;
  max-width: 960px;
}
.bc-photo-col {
  position: sticky;
  top: calc(var(--header-h) + 2rem);
}
.bc-photo {
  width: 200px;
  height: auto;
  display: block;
}
.bc-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.4rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: 0.3rem;
}
.bc-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
}
.bc-rule {
  width: 100%;
  height: 1px;
  background: rgba(30,32,24,0.15);
  margin: 1.5rem 0;
}
.bc-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.935rem;
  line-height: 1.78;
  color: var(--ink-body);
  margin-bottom: 1rem;
}
.bc-close {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.15rem;
  color: var(--ink);
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

/* ─── INSTRUMENTS VALUE STRIP ────────────────────────────────── */
.instr-value-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.75rem;
  padding: 0.85rem 1.25rem;
  border: 1px solid rgba(140,112,64,0.25);
  border-left: 3px solid var(--brass);
  background: rgba(140,112,64,0.04);
  margin-bottom: 2.5rem;
}
.ivs-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.06em;
  color: var(--ink-body);
}
.ivs-sep {
  color: var(--brass);
  opacity: 0.45;
  font-size: 0.7rem;
  line-height: 1;
}

/* ─── CREATOR – RESPONSIVE ───────────────────────────────────── */
@media (max-width: 680px) {
  .bc-wrap {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .bc-photo-col { position: static; }
  .bc-photo { width: 130px; }
}

/* ============================================================
   3 · PRODUCT PAGES  (product-pages.css)
   ============================================================ */
/* ═══════════════════════════════════════════════════════════════
   WAYFINDER PRODUCT PAGES – Shared Styles
   ═══════════════════════════════════════════════════════════════ */

/* ─── ALERT BAR ─────────────────────────────────────────────── */
.pp-alert {
  background: var(--ink-mid);
  border-bottom: 1px solid rgba(140,112,64,0.25);
  padding: 0.55rem 5%;
  text-align: center;
}
.pp-alert-text {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(237,231,218,0.38);
  line-height: 1.7;
  margin: 0;
}
.pp-alert-text em {
  color: rgba(237,231,218,0.6);
  font-style: normal;
}

/* ─── NAV DROPDOWN ──────────────────────────────────────────── */
.nav-dropdown { position: relative; }
.nav-dropdown-btn {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.66rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-body);
  transition: color 140ms ease;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 0.28rem;
}
.nav-dropdown-btn:hover { color: var(--brass); }
.nav-dd-arrow {
  display: inline-block;
  width: 0;
  height: 0;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 4px solid currentColor;
  transition: transform 160ms ease;
  margin-top: 1px;
}
.nav-dropdown.open .nav-dd-arrow { transform: rotate(180deg); }
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  min-width: 210px;
  background: var(--bone);
  border: 1px solid rgba(30,32,24,0.22);
  border-top: 2px solid var(--brass);
  z-index: 300;
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
  box-shadow: 4px 4px 0 var(--paper-deep);
}
.nav-dropdown.open .nav-dropdown-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.nav-dd-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.7rem 1.1rem;
  border-bottom: 1px solid rgba(30,32,24,0.09);
  transition: background 130ms ease;
  gap: 1rem;
}
.nav-dd-item:last-child { border-bottom: none; }
.nav-dd-item:hover { background: var(--paper-dark); }
.nav-dd-item.active {
  background: var(--paper-dark);
  border-left: 2px solid var(--rust);
  padding-left: calc(1.1rem - 2px);
}
.nav-dd-name {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink);
}
.nav-dd-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  color: var(--brass);
}

/* ─── HERO ──────────────────────────────────────────────────── */
.pp-hero {
  /* intrinsic: 3.5/3rem@900px -> 5.5/5rem@1280px */
  padding: clamp(3.5rem, 8.42vw - 1.24rem, 5.5rem) clamp(5%, 11.7vw - 3.77rem, 7%) clamp(3rem, 8.42vw - 1.74rem, 5rem);
  border-bottom: 1px solid rgba(30,32,24,0.12);
}
.pp-hero-inner { max-width: 700px; }
.pp-hero-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.1rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.pp-hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--brass);
  flex-shrink: 0;
}
.pp-hero-name {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(3rem, 5.5vw, 5.5rem);
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--ink);
  line-height: 0.92;
  margin-bottom: 1.4rem;
}
.pp-hero-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.45rem;
  letter-spacing: 0.06em;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 0.9rem;
  margin-bottom: 2rem;
}
.pp-hero-price-sub {
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-ghost);
}
.pp-hero-sentence {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.2rem, 1.9vw, 1.65rem);
  font-weight: 400;
  font-style: italic;
  color: var(--ink-body);
  line-height: 1.5;
  margin-bottom: 2.75rem;
  max-width: 580px;
  letter-spacing: -0.01em;
  text-wrap: pretty;
}
.pp-cta-block { display: flex; flex-direction: column; align-items: flex-start; gap: 0.55rem; }
.pp-hero-cta {
  display: inline-block;
  background: var(--ink);
  color: var(--bone);
  border: 1px solid var(--ink);
  padding: 0.95rem 2.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: background 160ms ease, border-color 160ms ease;
}
.pp-hero-cta:hover { background: var(--brass); border-color: var(--brass); }
.pp-hero-microcopy {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--ink-ghost);
}
.pp-hero-microtrust {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.06em;
  color: var(--ink-faded);
  line-height: 1.9;
  margin-top: 0.85rem;
  padding-top: 1.1rem;
  border-top: 1px solid rgba(30,32,24,0.12);
  max-width: 500px;
  display: block;
}

/* ─── PRODUCT PAGE SECTION ──────────────────────────────────── */
.pp-section {
  /* intrinsic: 3.5rem@900px -> 4.5rem@1280px */
  padding: clamp(3.5rem, 1.13rem + 4.21vw, 4.5rem) clamp(5%, 11.7vw - 3.77rem, 7%);
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.pp-section--aged { background: var(--paper-aged); }
.pp-section--dark { background: var(--ink); border-color: transparent; }
.pp-section--slate { background: var(--slate); border-top: 2px solid var(--brass); border-bottom: 2px solid var(--brass); }
.pp-section-inner { max-width: 860px; margin: 0 auto; }
.pp-section-inner--wide { max-width: 1100px; margin: 0 auto; }

.pp-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.85rem;
  display: block;
}
.pp-label--lt { color: var(--brass-lt); }
.pp-h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 2.5vw, 2.35rem);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 1.5rem;
  font-style: italic;
  text-wrap: pretty;
}
.pp-h2--bone { color: var(--bone); }
.pp-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.93rem;
  line-height: 1.8;
  color: var(--ink-body);
  margin-bottom: 1rem;
  text-wrap: pretty;
  max-width: 660px;
}

/* ─── RIGHT-USE CARDS ───────────────────────────────────────── */
.pp-right-use {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid rgba(30,32,24,0.2);
  margin-top: 1.75rem;
}
.pp-ru-card {
  padding: 1.75rem 2rem;
  border-right: 1px solid rgba(30,32,24,0.12);
  border-bottom: 1px solid rgba(30,32,24,0.12);
  background: var(--bone);
}
.pp-ru-card:nth-child(even) { border-right: none; background: var(--paper); }
.pp-ru-card:nth-child(3),
.pp-ru-card:nth-child(4) { border-bottom: none; }
.pp-ru-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.55rem;
  display: block;
}
.pp-ru-text {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  line-height: 1.72;
  color: var(--ink-body);
  text-wrap: pretty;
}
.pp-ru-text em {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-style: italic;
  color: var(--ink);
}

/* ─── DELIVERABLES ──────────────────────────────────────────── */
.pp-deliverable-block {
  border: 2px solid var(--ink);
  background: var(--bone);
  padding: 2rem 2.25rem;
  box-shadow: 5px 5px 0 var(--brass);
  margin-top: 1.75rem;
}
.pp-del-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 0.5rem 1rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(30,32,24,0.09);
  align-items: start;
}
.pp-del-row:last-child { border-bottom: none; }
.pp-del-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate-mid);
  padding-top: 0.15rem;
}
.pp-del-value {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  color: var(--ink-body);
  line-height: 1.6;
}
.pp-del-value strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
}
.pp-del-outcome {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(140,112,64,0.2);
}
.pp-del-outcome-item {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  color: var(--ink-body);
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  line-height: 1.5;
}
.pp-del-outcome-item::before {
  content: '–';
  color: var(--brass);
  flex-shrink: 0;
}
.pp-del-frame-note {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.05em;
  color: var(--ink-ghost);
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(30,32,24,0.1);
  line-height: 1.85;
}

/* ─── ARTIFACT GALLERY ──────────────────────────────────────── */
.pp-artifact-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 1.75rem;
  margin-bottom: 0.6rem;
}
.pp-artifact-panel {
  border: 1px solid rgba(30,32,24,0.22);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  box-shadow: 3px 3px 0 var(--paper-deep);
}
.pp-artifact-panel img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.pp-artifact-caption {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink-ghost);
  display: block;
}

/* ─── ROI TABLE ─────────────────────────────────────────────── */
.pp-roi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid rgba(30,32,24,0.18);
  margin-top: 1.75rem;
}
.pp-roi-head-before,
.pp-roi-head-after {
  padding: 0.65rem 1.4rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.pp-roi-head-before {
  background: var(--paper-aged);
  color: var(--rust);
  border-bottom: 2px solid var(--rust);
  border-right: 1px solid rgba(30,32,24,0.12);
}
.pp-roi-head-after {
  background: var(--paper-dark);
  color: var(--brass);
  border-bottom: 2px solid var(--brass);
}
.pp-roi-before,
.pp-roi-after {
  padding: 1.2rem 1.4rem;
  border-bottom: 1px solid rgba(30,32,24,0.09);
  font-family: 'Jost', sans-serif;
  font-size: 0.87rem;
  line-height: 1.65;
  color: var(--ink-body);
}
.pp-roi-before {
  background: var(--bone);
  border-right: 1px solid rgba(30,32,24,0.1);
}
.pp-roi-after { background: var(--paper); }
.pp-roi-after em {
  font-family: 'Cormorant Garamond', serif;
  font-size: 0.98rem;
  font-style: italic;
  color: var(--ink);
}
.pp-roi-close {
  grid-column: 1 / -1;
  background: var(--paper-dark);
  padding: 1.4rem 1.4rem;
  border-top: 1px solid rgba(30,32,24,0.1);
}
.pp-roi-close-text {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  line-height: 1.78;
  color: var(--ink-body);
  text-wrap: pretty;
}

/* ─── PROCESS STEPS ─────────────────────────────────────────── */
.pp-steps {
  border: 1px solid rgba(30,32,24,0.18);
  margin-top: 1.75rem;
}
.pp-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.pp-step:last-child { border-bottom: none; }
.pp-step:nth-child(odd) { background: var(--bone); }
.pp-step:nth-child(even) { background: var(--paper); }
.pp-step-num {
  padding: 1.2rem 0 1.2rem 1.25rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.95rem;
  color: var(--brass);
  letter-spacing: 0.04em;
  border-right: 1px solid rgba(30,32,24,0.1);
  display: flex;
  align-items: center;
}
.pp-step-body { padding: 1.2rem 1.5rem; }
.pp-step-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.64rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 0.25rem;
}
.pp-step-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-body);
  line-height: 1.65;
}

/* ─── INTAKE + CONVERGENCE ──────────────────────────────────── */
.pp-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem;
  margin-top: 1.75rem;
}
.pp-intake-block {
  border-left: 2px solid var(--brass);
  padding: 1.25rem 1.5rem;
  background: rgba(140,112,64,0.05);
}
.pp-intake-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.82;
  color: var(--ink-body);
  text-wrap: pretty;
}
.pp-conv-block {
  border: 1px solid rgba(61,74,82,0.25);
  border-left: 3px solid var(--slate);
  padding: 1.25rem 1.5rem;
  background: rgba(61,74,82,0.04);
}
.pp-conv-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.82;
  color: var(--ink-body);
  text-wrap: pretty;
}
.pp-conv-body em {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1rem;
  color: var(--ink);
}

/* ─── FOUNDER ───────────────────────────────────────────────── */
.pp-founder-grid {
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 3.5rem;
  align-items: start;
}
.pp-founder-photo {
  width: 155px;
  height: auto;
  display: block;
  filter: grayscale(15%) contrast(1.05);
  border: 1px solid rgba(140,112,64,0.2);
}
.pp-founder-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.95rem;
  font-weight: 500;
  color: var(--bone);
  line-height: 1.05;
  margin-bottom: 0.2rem;
}
.pp-founder-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 1.5rem;
}
.pp-founder-rule {
  width: 100%;
  height: 1px;
  background: rgba(140,112,64,0.22);
  margin-bottom: 1.5rem;
}
.pp-founder-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.82;
  color: rgba(237,231,218,0.6);
  margin-bottom: 1rem;
  text-wrap: pretty;
}
.pp-founder-em {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.08rem;
  font-style: italic;
  color: var(--bone);
  line-height: 1.55;
  margin-bottom: 1.25rem;
  border-left: 2px solid rgba(140,112,64,0.3);
  padding-left: 1.1rem;
}
.pp-founder-process-note {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.05em;
  color: rgba(237,231,218,0.35);
  line-height: 1.9;
  border-top: 1px solid rgba(140,112,64,0.18);
  padding-top: 1rem;
  margin-bottom: 1rem;
}
.pp-founder-sig {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--brass-lt);
}

/* ─── TESTIMONIAL ───────────────────────────────────────────── */
.pp-testimonial-inner {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}
.pp-testimonial-meta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass-lt);
  margin-bottom: 2rem;
  display: block;
}
.pp-testimonial-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.3rem, 2.1vw, 1.75rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.52;
  color: var(--bone);
  margin-bottom: 1.5rem;
  letter-spacing: -0.01em;
  text-wrap: pretty;
}
.pp-testimonial-attr {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(184,150,90,0.7);
}

/* ─── GATEWAY BANNER (Diagnostic) ───────────────────────────── */
.pp-gateway {
  border: 2px solid var(--brass);
  background: var(--bone);
  /* intrinsic: 1.75rem@640px -> 2.5rem@1280px */
  padding: clamp(1.75rem, 1rem + 1.875vw, 2.5rem);
  margin-top: 1.75rem;
  position: relative;
}
.pp-gateway::before {
  content: '';
  position: absolute;
  top: -2px; left: -2px; right: -2px;
  height: 3px;
  background: var(--brass);
}
.pp-gateway-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.75rem;
  display: block;
}
.pp-gateway-head {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.45rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.9rem;
  line-height: 1.25;
}
.pp-gateway-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.8;
  color: var(--ink-body);
  text-wrap: pretty;
  margin-bottom: 0.75rem;
}
.pp-gateway-math {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.05em;
  color: var(--ink-faded);
  border-top: 1px solid rgba(140,112,64,0.25);
  padding-top: 0.85rem;
  margin-top: 0.85rem;
  line-height: 2.1;
}
.pp-gateway-math strong { color: var(--brass); }

/* ─── FINAL CTA ─────────────────────────────────────────────── */
.pp-final-cta {
  text-align: center;
  /* intrinsic: 4rem@640px -> 5.5rem@1280px */
  padding: clamp(4rem, 2.5rem + 3.75vw, 5.5rem) clamp(5%, 9vw - 1.6rem, 7%);
}
.pp-final-name {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(2rem, 3.5vw, 3.5rem);
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--bone);
  margin-bottom: 0.45rem;
}
.pp-final-price {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1.15rem;
  color: var(--brass-lt);
  letter-spacing: 0.06em;
  margin-bottom: 1.75rem;
}
.pp-final-what {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.07em;
  color: rgba(237,231,218,0.38);
  line-height: 2.1;
  margin: 0 auto 2.5rem;
  max-width: 480px;
}
.pp-final-btn {
  display: inline-block;
  background: var(--brass);
  color: var(--ink);
  border: 1px solid var(--brass);
  padding: 1.1rem 3rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: background 160ms ease, color 160ms ease, border-color 160ms ease;
  margin-bottom: 1.25rem;
  display: block;
  max-width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.pp-final-btn:hover { background: var(--bone); border-color: var(--bone); }
.pp-final-gate {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: rgba(237,231,218,0.28);
  display: block;
  margin-bottom: 0.3rem;
}
.pp-final-note {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.06em;
  color: rgba(237,231,218,0.2);
  display: block;
  line-height: 1.8;
}

/* ─── CAREER JUSTIFICATION ──────────────────────────────────── */
.pp-career-just {
  border: 1px solid rgba(61,74,82,0.28);
  border-left: 3px solid var(--slate);
  padding: 1.75rem 2rem;
  background: var(--paper-dark);
  margin-top: 1.5rem;
}
.pp-career-just p {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  line-height: 1.82;
  color: var(--ink-body);
  text-wrap: pretty;
  margin-bottom: 0.75rem;
}
.pp-career-just p:last-child { margin-bottom: 0; }
.pp-career-just strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
}

/* ─── FAQ ───────────────────────────────────────────────────── */
.pp-faq-list {
  border: 1px solid rgba(30,32,24,0.18);
  margin-top: 1.75rem;
}
details.pp-faq-item { border-bottom: 1px solid rgba(30,32,24,0.1); }
details.pp-faq-item:last-child { border-bottom: none; }
details.pp-faq-item > summary {
  list-style: none;
  padding: 1.2rem 1.5rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: var(--bone);
  transition: background 140ms ease;
  user-select: none;
}
details.pp-faq-item > summary::-webkit-details-marker { display: none; }
details.pp-faq-item > summary::marker { display: none; }
details.pp-faq-item > summary:hover { background: var(--paper-dark); }
details.pp-faq-item[open] > summary { background: var(--paper-dark); }
.pp-faq-q {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.63rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
}
.pp-faq-icon {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 1rem;
  color: var(--brass);
  flex-shrink: 0;
  line-height: 1;
  transition: transform 160ms ease;
  display: inline-block;
}
details.pp-faq-item[open] .pp-faq-icon { transform: rotate(45deg); }
.pp-faq-answer {
  padding: 1.25rem 1.5rem;
  background: var(--paper);
  border-top: 1px solid rgba(30,32,24,0.07);
}
.pp-faq-a {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  color: var(--ink-body);
  line-height: 1.78;
  text-wrap: pretty;
}
.pp-faq-a em {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 0.98rem;
  color: var(--ink);
}
.pp-faq-a a { color: var(--brass); text-underline-offset: 2px; }

/* ─── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .pp-artifact-gallery { grid-template-columns: 1fr 1fr; }
  .pp-artifact-gallery .pp-artifact-panel:last-child { display: none; }
  .pp-two-col { grid-template-columns: 1fr; gap: 1.5rem; }
  .pp-founder-grid { grid-template-columns: 1fr; gap: 2rem; }
  .pp-founder-photo { width: 110px; }
  .pp-right-use { grid-template-columns: 1fr; }
  .pp-roi-grid { grid-template-columns: 1fr; }
  /* Hide stacked column headers; inject per-row labels via ::before instead */
  .pp-roi-head-before,
  .pp-roi-head-after { display: none; }
  .pp-roi-before,
  .pp-roi-after { grid-column: auto; border-right: none; }
  .pp-roi-before {
    border-bottom: none;
    padding-bottom: 0.35rem;
  }
  .pp-roi-before::before {
    content: 'Before';
    display: block;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.57rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--rust);
    margin-bottom: 0.35rem;
  }
  .pp-roi-after::before {
    content: 'After';
    display: block;
    font-family: 'IBM Plex Mono', monospace;
    font-size: 0.57rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--brass);
    margin-bottom: 0.35rem;
  }
  .pp-roi-after {
    padding-top: 0.5rem;
    border-top: 1px dashed rgba(30,32,24,0.12);
  }
  .pp-roi-close { grid-column: auto; }
  .nav-dropdown-menu { left: auto; right: 0; transform: translateX(0) translateY(-4px); }
  .nav-dropdown.open .nav-dropdown-menu { transform: translateX(0) translateY(0); }
}
@media (max-width: 640px) {
  .pp-hero-name { font-size: 2.6rem; }
  .pp-artifact-gallery { grid-template-columns: 1fr; }
  .pp-artifact-gallery .pp-artifact-panel:not(:first-child) { display: none; }
  .pp-del-row { grid-template-columns: 1fr; gap: 0.1rem; }
  .pp-del-label { padding-top: 0; }
  .pp-deliverable-block { box-shadow: none; }
  .pp-founder-grid { gap: 1.5rem; }
}

/* ============================================================
   4 · THEME ADDITIONS  (FSE integration)
   ============================================================ */

/* Remove default FSE block gap/margin so the bespoke layout owns spacing */
.wp-site-blocks > footer { margin-block-start: 0; }
.wp-site-blocks > * { margin-block-start: 0; margin-block-end: 0; }
body .is-layout-constrained > * { margin-block-start: 0; }
.wp-site-blocks { overflow-x: clip; }

/* Editor + frontend: let our section wrappers run full-bleed */
.wayfinder-section-pattern { display: block; width: 100%; }

/* ─── SCROLL-TRIGGERED REVEAL ─────────────────────────────── */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 700ms ease, transform 700ms ease;
  will-change: opacity, transform;
}
.animate-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ─── REDUCED MOTION ──────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .animate-on-scroll {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ─── WP ADMIN BAR OFFSET FOR STICKY HEADER ───────────────── */
.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}

/* ─── BLOCK EDITOR: constrain pattern preview width ───────── */
.editor-styles-wrapper { background: var(--paper); }


/* ============================================================
   5 · PAGE-SPECIFIC STYLES (ported verbatim from page <style> blocks)
   ============================================================ */

/* ---- story.html ---- */
/* ── STORY HERO ───────────────────────────────────────────────── */
.story-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  /* intrinsic: 3.5rem@600px -> 6/5.5rem@1280px */
  padding: clamp(3.5rem, 1.29rem + 5.88vw, 6rem) clamp(5%, 8.76vw - 1.41rem, 7%) clamp(3.5rem, 1.74rem + 4.71vw, 5.5rem);
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 5rem;
  align-items: center;
}
.story-hero-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.75rem;
}
.story-hero-headline {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.5rem, 4.5vw, 5rem);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--bone);
  margin-bottom: 0.45rem;
}
.story-hero-sub {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.3rem, 2vw, 1.85rem);
  font-style: italic;
  color: var(--brass-pale);
  line-height: 1.3;
  margin-bottom: 2.25rem;
}
.story-hero-meta {
  font-family: 'Jost', sans-serif;
  font-size: 0.875rem;
  color: rgba(245,240,230,0.42);
  line-height: 1.75;
  max-width: 52ch;
}
.story-photo-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
.story-photo-img {
  width: 220px;
  height: 220px;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid rgba(140,112,64,0.35);
  display: block;
}
.story-photo-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--bone);
  text-align: center;
  line-height: 1.2;
}
.story-photo-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.56rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
  text-align: center;
}

/* ── DOC STRIP ───────────────────────────────────────────────── */
.story-doc-strip {
  background: var(--paper-dark);
  border-bottom: 1px solid rgba(30,32,24,0.15);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.sds-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.59rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-faded);
  padding: 0.65rem 1.4rem;
  border-right: 1px solid rgba(30,32,24,0.12);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap;
}
.sds-item::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  background: var(--brass);
  flex-shrink: 0;
}
.sds-item:last-child { border-right: none; }

/* ── STORY SECTIONS ─────────────────────────────────────────── */
.story-section-wrap {
  /* intrinsic: 3.5rem@600px -> 5.5rem@1280px */
  padding: clamp(3.5rem, 1.74rem + 4.71vw, 5.5rem) clamp(5%, 8.76vw - 1.41rem, 7%);
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.story-section-wrap--base  { background: var(--paper); }
.story-section-wrap--dark  { background: var(--paper-dark); }
.story-section-wrap--aged  { background: var(--paper-aged); }

.story-content {
  max-width: 700px;
}

/* ── BODY COPY ───────────────────────────────────────────────── */
.story-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.95rem;
  line-height: 1.85;
  color: var(--ink-body);
  margin-bottom: 1.05rem;
  text-wrap: pretty;
}
.story-body:last-child { margin-bottom: 0; }
.story-body em {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.08rem;
  font-style: italic;
  color: var(--ink);
}

/* ── PULL QUOTE ──────────────────────────────────────────────── */
.story-pull {
  border-left: 3px solid var(--brass);
  padding: 1.25rem 1.75rem;
  background: rgba(140,112,64,0.055);
  margin: 2.75rem 0;
}
.story-pull-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.15rem, 1.6vw, 1.5rem);
  font-weight: 500;
  font-style: italic;
  line-height: 1.5;
  color: var(--ink);
  margin: 0;
}

/* ── CONVERGENT PATTERN ARTIFACT ─────────────────────────────── */
.story-artifact-block {
  border: 1px solid rgba(30,32,24,0.3);
  background: var(--bone);
  overflow: hidden;
  margin: 2.75rem 0 0;
  box-shadow: 3px 3px 0 var(--paper-deep);
}
.story-artifact-img {
  display: block;
  width: 100%;
  height: auto;
}
.story-artifact-cap {
  padding: 0.85rem 1.1rem;
  background: var(--paper-aged);
  border-top: 1px solid rgba(30,32,24,0.12);
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
}
.story-artifact-cap-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
  flex-shrink: 0;
  padding-top: 0.08rem;
  line-height: 1.5;
}
.story-artifact-cap-text {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: var(--ink-body);
  line-height: 1.6;
}

/* ── CONVERGENCE CALLOUT (dark box) ──────────────────────────── */
.story-conv-box {
  background: var(--ink);
  border: 1px solid rgba(140,112,64,0.2);
  border-left: 3px solid var(--brass);
  padding: 1.5rem 1.75rem;
  margin: 2.75rem 0;
}
.story-conv-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.8rem;
}
.story-conv-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1rem, 1.4vw, 1.25rem);
  font-style: italic;
  line-height: 1.65;
  color: var(--bone);
  margin: 0;
}

/* ── CLOSING SECTION ─────────────────────────────────────────── */
.story-closing {
  background: var(--ink);
  border-top: 2px solid var(--brass);
  padding: 6rem 7%;
  text-align: center;
}
.story-closing-quote {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.5rem, 2.4vw, 2.4rem);
  font-style: italic;
  font-weight: 500;
  color: var(--bone);
  line-height: 1.4;
  max-width: 640px;
  margin: 0 auto 1.25rem;
  letter-spacing: -0.01em;
}
.story-closing-sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.875rem;
  color: rgba(245,240,230,0.4);
  margin: 0 auto 3rem;
  max-width: 480px;
  line-height: 1.75;
}
.story-closing-ctas {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
}
.btn-secondary-inv {
  display: inline-block;
  width: auto;
  background: transparent;
  color: var(--bone);
  border: 1px solid rgba(140,112,64,0.45);
  padding: 0.65rem 1.1rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.67rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  transition: background 160ms ease, border-color 160ms ease;
}
.btn-secondary-inv:hover { background: var(--brass); border-color: var(--brass); color: var(--bone); }

/* ── SECTION TITLE SPACING ───────────────────────────────────── */
.story-section-title {
  margin-top: 0.6rem;
  margin-bottom: 2rem;
}

/* ── INTAKE SECTION (dark bg) ────────────────────────────────── */
.story-section-wrap--intake {
  background: var(--ink);
  border-top: 2px solid rgba(140,112,64,0.3);
  border-bottom: 2px solid rgba(140,112,64,0.3);
}
.story-section-wrap--intake .section-label { color: var(--brass-lt); }
.story-section-wrap--intake .section-title { color: var(--bone); }

/* ── NAV ACTIVE ──────────────────────────────────────────────── */
.nav-link.nav-active { color: var(--brass); }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 860px) {
  .story-hero {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .story-photo-col {
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
    justify-content: flex-start;
    order: -1;
  }
  .story-photo-img { width: 90px; height: 90px; }
  .story-photo-name, .story-photo-title { text-align: left; }
  .story-closing { padding: 4.5rem 5%; }
}
@media (max-width: 600px) {
  .story-hero-headline { font-size: 2.2rem; }
  .sds-item { padding: 0.65rem 0.9rem; font-size: 0.54rem; }
  .story-closing { padding: 4rem 5%; }
}

/* ---- Sample.html ---- */
/* ── SAMPLE PAGE SHELL ─────────────────────────────────────── */
.sample-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  padding: 4rem 7% 3.5rem;
}
.sample-hero-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.sample-hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--brass);
  flex-shrink: 0;
}
.sample-hero h1 {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--bone);
  line-height: 1;
  margin: 0 0 1rem;
}
.sample-hero-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.92rem;
  color: rgba(245,240,230,0.6);
  line-height: 1.7;
  max-width: 600px;
  margin: 0 0 1.5rem;
}
.sample-hero-meta {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.sample-hero-meta-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  color: rgba(245,240,230,0.3);
}
.sample-hero-meta-item span { color: var(--brass-lt); }

/* ── VIEWER ────────────────────────────────────────────────── */
.sample-viewer {
  background: #2a2c24;
  padding: 3rem 0;
}
.sample-viewer-inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 2rem;
}
.sample-progress {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,230,0.3);
  margin-bottom: 2rem;
  text-align: center;
}
.sample-progress span { color: var(--brass-lt); }

/* ── REPORT PAGE CARD ──────────────────────────────────────── */
.rp-wrap { margin-bottom: 2rem; }
.rp-pg-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  color: rgba(245,240,230,0.25);
  text-align: right;
  margin-bottom: 0.4rem;
}
.rp-card {
  background: #ede7da;
  box-shadow: 0 6px 32px rgba(0,0,0,0.35), 0 0 0 1px rgba(0,0,0,0.1);
  padding: 0.7in 0.75in;
  font-family: Georgia, 'Cormorant Garamond', serif;
  font-size: 10pt;
  line-height: 1.72;
  color: #1e2018;
  position: relative;
  overflow: hidden;
}
.rp-card--blur {
  filter: blur(5px);
  user-select: none;
  pointer-events: none;
}

/* ── REPORT TYPOGRAPHY (scoped) ────────────────────────────── */
.rp-card h1 {
  font-family: Georgia, serif;
  font-size: 20pt;
  font-weight: 400;
  color: #1e2018;
  line-height: 1.15;
  margin: 0 0 0.15in;
  border-bottom: 1px solid #a08870;
  padding-bottom: 0.08in;
}
.rp-card h2 {
  font-family: Georgia, serif;
  font-size: 13pt;
  font-weight: 400;
  color: #1e2018;
  margin: 0.25in 0 0.08in;
}
.rp-card h3 {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7.5pt;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #8c7040;
  margin: 0.2in 0 0.05in;
}
.rp-card p { margin-bottom: 0.11in; font-size: 10pt; line-height: 1.72; }
.rp-sec-lbl {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7pt;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: #8c7040;
  margin-bottom: 0.04in;
}
.rp-rule { width: 100%; height: 1px; background: #a08870; margin-bottom: 0.16in; }
.rp-callout {
  border-left: 4px solid #8c7040;
  background: #d8d0c2;
  padding: 0.13in 0.2in;
  margin: 0 0 0.11in 0.1in;
}
.rp-callout-lbl {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 6.5pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #8c7040;
  margin-bottom: 0.04in;
}
.rp-callout p { font-size: 10pt; line-height: 1.6; margin-bottom: 0.05in; }
.rp-callout p:last-child { margin-bottom: 0; }
.rp-ct-box {
  background: #2e3228;
  border-left: 5px solid #8c7040;
  padding: 0.18in 0.24in;
  margin: 0.18in 0 0.2in;
}
.rp-ct-lbl {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 6.5pt;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #d4b87a;
  margin-bottom: 0.07in;
}
.rp-ct-text {
  font-family: Georgia, serif;
  font-size: 13pt;
  font-style: italic;
  color: #f5f0e6;
  line-height: 1.58;
  margin: 0;
}
.rp-hl-box {
  border-left: 3px solid #d4b87a;
  padding: 0.12in 0.2in;
  margin: 0.12in 0 0.12in 0.1in;
  background: #e4ddd0;
}
.rp-hl-box p {
  font-family: Georgia, serif;
  font-size: 11pt;
  font-style: italic;
  line-height: 1.6;
  margin: 0;
}
.rp-card .rp-win {
  border: 1px solid #2e3228;
  margin-bottom: 0.15in;
}
.rp-win-header {
  background: #2e3228;
  padding: 0.08in 0.15in;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rp-win-lbl {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8pt;
  font-weight: 700;
  color: #f5f0e6;
}
.rp-win-badge {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 6.5pt;
  color: #d4b87a;
}
.rp-win-body { padding: 0.12in 0.15in; background: #ede7da; }
.rp-win-body p { font-size: 9pt; line-height: 1.58; margin-bottom: 0; }
.rp-toc-entry {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 0.06in;
  border-bottom: 1px dotted #a08870;
  padding-bottom: 0.04in;
}
.rp-toc-num {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 8pt;
  color: #8c7040;
  flex-shrink: 0;
  width: 2rem;
}
.rp-toc-title { font-size: 10pt; color: #1e2018; flex: 1; }
.rp-data-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 0.12in;
  font-size: 9pt;
}
.rp-data-table th {
  background: #2e3228;
  color: #f5f0e6;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 7pt;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.06in 0.1in;
  text-align: left;
  border: 1px solid #2e3228;
  font-weight: 500;
}
.rp-data-table td {
  border: 1px solid #a08870;
  padding: 0.06in 0.1in;
  vertical-align: top;
}
.rp-data-table tr:nth-child(odd) td { background: #f5f0e6; }
.rp-data-table tr:nth-child(even) td { background: #e8e2d6; }

/* ── GATE / BLUR / CTA ─────────────────────────────────────── */
.sample-gate {
  position: relative;
  margin-top: -3rem;
}
.sample-gate-gradient {
  height: 240px;
  background: linear-gradient(to bottom, transparent 0%, #2a2c24 70%);
  pointer-events: none;
}
.sample-cta-wrap {
  background: #2a2c24;
  padding: 2.5rem 2rem 3.5rem;
}
.sample-cta-inner {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.sample-cta-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1rem;
}
.sample-cta-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  font-weight: 500;
  color: var(--bone);
  line-height: 1.3;
  margin-bottom: 1rem;
}
.sample-cta-body {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: rgba(245,240,230,0.55);
  line-height: 1.7;
  margin-bottom: 2rem;
}
.sample-cta-specs {
  display: flex;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
}
.sample-cta-spec {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(245,240,230,0.35);
}
.sample-cta-spec span { color: var(--brass-lt); display: block; font-size: 0.82rem; margin-top: 0.2rem; }
.sample-cta-btn {
  display: inline-block;
  background: var(--brass);
  color: var(--bone);
  border: 1px solid var(--brass);
  padding: 0.85rem 2.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 160ms;
  margin-bottom: 1rem;
}
.sample-cta-btn:hover { background: #a08045; border-color: #a08045; }
.sample-cta-sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: rgba(245,240,230,0.3);
  line-height: 1.6;
}
.sample-cta-sub a { color: rgba(245,240,230,0.45); }
.sample-permission {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.08em;
  color: rgba(245,240,230,0.2);
  text-align: center;
  padding: 1rem 2rem 0;
  max-width: 600px;
  margin: 0 auto;
}

@media (max-width: 700px) {
  .rp-card { padding: 0.4in 0.35in; font-size: 9pt; }
  .rp-win-header { flex-direction: column; align-items: flex-start; gap: 0.25rem; }
}

/* ---- Contact.html ---- */
.contact-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  padding: 5rem 7% 4.5rem;
}
.contact-hero-inner { max-width: 800px; }
.contact-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.contact-eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--brass);
  flex-shrink: 0;
}
.contact-hero h1 {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--bone);
  line-height: 1;
  margin: 0 0 1.25rem;
}
.contact-hero-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.95rem;
  color: rgba(245,240,230,0.6);
  line-height: 1.75;
  max-width: 560px;
  margin: 0;
}
.contact-main {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 0;
  min-height: 500px;
}
.contact-sidebar {
  background: var(--paper-dark);
  padding: 3rem 2.5rem;
  border-right: 1px solid rgba(30,32,24,0.12);
}
.contact-form-area {
  background: var(--paper);
  padding: 3rem 3.5rem;
}
.contact-type-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.85rem;
}
.contact-type-list {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-bottom: 2.5rem;
}
.contact-type-item {}
.contact-type-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  color: var(--ink);
  margin-bottom: 0.25rem;
}
.contact-type-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.55;
}
.contact-email-block {
  border-top: 1px solid rgba(30,32,24,0.12);
  padding-top: 1.5rem;
  margin-top: 0.5rem;
}
.contact-email-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.4rem;
}
.contact-email-link {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.78rem;
  color: var(--brass);
  text-decoration: none;
  letter-spacing: 0.04em;
}
.contact-email-link:hover { text-decoration: underline; }
.contact-response {
  font-family: 'Jost', sans-serif;
  font-size: 0.78rem;
  color: var(--slate-mid);
  margin-top: 0.35rem;
}
.contact-form-head {
  margin-bottom: 2rem;
}
.contact-form-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.35rem;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 0.4rem;
}
.contact-form-subtitle {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-body);
  line-height: 1.6;
  margin: 0;
}

/* ── FORM STYLES (used by WP plugin and fallback) ── */
.contact-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
.contact-field-full { margin-bottom: 1rem; }
.contact-field label {
  display: block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.4rem;
}
.contact-field input,
.contact-field select,
.contact-field textarea {
  width: 100%;
  background: var(--bone);
  border: 1px solid rgba(30,32,24,0.25);
  padding: 0.6rem 0.75rem;
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  color: var(--ink);
  box-sizing: border-box;
  outline: none;
  transition: border-color 150ms;
  -webkit-appearance: none;
  border-radius: 0;
}
.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus {
  border-color: var(--brass);
}
.contact-field textarea { min-height: 120px; resize: vertical; }
.contact-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%231e2018' opacity='.4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right: 2rem;
}
.contact-submit {
  display: inline-block;
  background: var(--ink);
  color: var(--bone);
  border: 1px solid var(--ink);
  padding: 0.7rem 1.5rem;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 150ms, border-color 150ms;
  margin-top: 0.5rem;
}
.contact-submit:hover { background: var(--brass); border-color: var(--brass); }

/* ── WP PLACEHOLDER ── */
.wp-form-placeholder {
  border: 2px dashed rgba(140,112,64,0.3);
  background: rgba(140,112,64,0.04);
  padding: 2rem;
  text-align: center;
  margin-bottom: 1.5rem;
}
.wp-form-placeholder-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.5rem;
}
.wp-form-placeholder-note {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--slate-mid);
  line-height: 1.6;
}

@media (max-width: 820px) {
  .contact-main { grid-template-columns: 1fr; }
  .contact-sidebar { border-right: none; border-bottom: 1px solid rgba(30,32,24,0.12); }
  .contact-form-area { padding: 2.5rem 5%; }
  .contact-field-row { grid-template-columns: 1fr; }
}

/* ---- Privacy.html ---- */
.doc-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  padding: 5rem 7% 4rem;
}
.doc-hero-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.doc-hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--brass);
  flex-shrink: 0;
}
.doc-hero h1 {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--bone);
  line-height: 1;
  margin: 0 0 1.25rem;
}
.doc-hero-meta {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.doc-hero-meta-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  color: rgba(245,240,230,0.3);
}
.doc-hero-meta-item span { color: var(--brass-lt); }
.doc-body {
  background: var(--paper);
  padding: 4rem 7%;
}
.doc-inner {
  max-width: 760px;
  margin: 0 auto;
}
.doc-section { margin-bottom: 3rem; }
.doc-section h2 {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 1rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(30,32,24,0.15);
  font-weight: 400;
}
.doc-p {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: var(--ink-body);
  line-height: 1.8;
  margin: 0 0 1rem;
  text-wrap: pretty;
}
.doc-p:last-child { margin-bottom: 0; }
.doc-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.doc-list li {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: var(--ink-body);
  line-height: 1.6;
  padding-left: 1.25rem;
  position: relative;
}
.doc-list li::before {
  content: '–';
  position: absolute;
  left: 0;
  color: var(--brass);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
}
.doc-callout {
  background: var(--paper-dark);
  border-left: 3px solid var(--brass);
  padding: 1.1rem 1.4rem;
  margin: 1.25rem 0;
}
.doc-callout p {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  color: var(--ink-body);
  line-height: 1.65;
  margin: 0;
}
.doc-email-link {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.82rem;
  color: var(--brass);
  text-decoration: none;
}
.doc-email-link:hover { text-decoration: underline; }

/* ---- Terms.html ---- */
.doc-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  padding: 5rem 7% 4rem;
}
.doc-hero-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.doc-hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--brass);
  flex-shrink: 0;
}
.doc-hero h1 {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(2rem, 3.5vw, 3.2rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--bone);
  line-height: 1;
  margin: 0 0 1.25rem;
}
.doc-hero-meta {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.doc-hero-meta-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  color: rgba(245,240,230,0.3);
}
.doc-hero-meta-item span { color: var(--brass-lt); }
.doc-body {
  background: var(--paper);
  padding: 4rem 7%;
}
.doc-inner {
  max-width: 760px;
  margin: 0 auto;
}
.doc-section { margin-bottom: 3rem; }
.doc-section h2 {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 1rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(30,32,24,0.15);
  font-weight: 400;
}
.doc-p {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: var(--ink-body);
  line-height: 1.8;
  margin: 0 0 1rem;
  text-wrap: pretty;
}
.doc-p:last-child { margin-bottom: 0; }
.doc-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.doc-list li {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: var(--ink-body);
  line-height: 1.6;
  padding-left: 1.25rem;
  position: relative;
}
.doc-list li::before {
  content: '–';
  position: absolute;
  left: 0;
  color: var(--brass);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
}
.doc-callout {
  background: var(--paper-dark);
  border-left: 3px solid var(--brass);
  padding: 1.1rem 1.4rem;
  margin: 1.25rem 0;
}
.doc-callout p {
  font-family: 'Jost', sans-serif;
  font-size: 0.88rem;
  color: var(--ink-body);
  line-height: 1.65;
  margin: 0;
}
.doc-callout--hard {
  background: rgba(120,50,30,0.06);
  border-left: 3px solid var(--rust);
}
.doc-email-link {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.82rem;
  color: var(--brass);
  text-decoration: none;
}
.doc-email-link:hover { text-decoration: underline; }

/* ---- Field-Notes.html ---- */
/* ── FIELD NOTES HERO ────────────────────────────────────────── */
.fn-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  padding: 5rem 7% 4rem;
}
.fn-hero-eyebrow {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.65rem;
}
.fn-hero-eyebrow::before {
  content: '';
  display: inline-block;
  width: 18px;
  height: 1px;
  background: var(--brass);
  flex-shrink: 0;
}
.fn-hero h1 {
  font-family: 'Cormorant SC', serif;
  font-size: clamp(2.2rem, 4vw, 3.8rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--bone);
  line-height: 1;
  margin: 0 0 1.1rem;
}
.fn-hero-desc {
  font-family: 'Jost', sans-serif;
  font-size: 0.95rem;
  color: rgba(245,240,230,0.55);
  line-height: 1.75;
  max-width: 600px;
  margin: 0;
}

/* ── CATEGORY FILTER BAR ────────────────────────────────────── */
.fn-filter-bar {
  background: var(--paper-dark);
  border-bottom: 1px solid rgba(30,32,24,0.12);
  padding: 0 7%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.fn-filter-inner {
  display: flex;
  gap: 0;
  max-width: 1200px;
  margin: 0 auto;
  white-space: nowrap;
}
.fn-filter-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate-mid);
  padding: 0.85rem 1.25rem;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: color 150ms, border-color 150ms;
  display: inline-block;
}
.fn-filter-item:hover { color: var(--ink); }
.fn-filter-item.active { color: var(--brass); border-bottom-color: var(--brass); }

/* ── FEATURED POST ──────────────────────────────────────────── */
.fn-featured {
  background: var(--paper);
  padding: 3.5rem 7%;
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.fn-featured-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.fn-featured-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.85rem;
}
.fn-featured-cat {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.65rem;
}
.fn-featured h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.6rem, 2.5vw, 2.4rem);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.25;
  margin: 0 0 1rem;
}
.fn-featured-excerpt {
  font-family: 'Jost', sans-serif;
  font-size: 0.92rem;
  color: var(--ink-body);
  line-height: 1.75;
  margin-bottom: 1.5rem;
  text-wrap: pretty;
}
.fn-featured-meta {
  display: flex;
  gap: 1.5rem;
  align-items: center;
  margin-bottom: 1.25rem;
}
.fn-featured-date {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.08em;
  color: var(--slate-mid);
}
.fn-read-link {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(30,32,24,0.3);
  padding-bottom: 0.1rem;
  transition: color 150ms, border-color 150ms;
}
.fn-read-link:hover { color: var(--brass); border-color: var(--brass); }
.fn-featured-img {
  background: var(--ink-mid);
  border: 1px solid rgba(30,32,24,0.2);
  aspect-ratio: 4/3;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fn-img-placeholder {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,230,0.2);
  text-align: center;
  padding: 1rem;
}

/* ── POST GRID ──────────────────────────────────────────────── */
.fn-grid-section {
  background: var(--paper-aged);
  padding: 3.5rem 7%;
}
.fn-grid-inner { max-width: 1200px; margin: 0 auto; }
.fn-grid-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 2rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(30,32,24,0.12);
}
.fn-grid-title {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate-mid);
}
.fn-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.fn-card {
  background: var(--bone);
  border: 1px solid rgba(30,32,24,0.15);
  display: flex;
  flex-direction: column;
  transition: border-color 150ms;
}
.fn-card:hover { border-color: var(--brass); }
.fn-card-img {
  background: var(--ink-mid);
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.fn-card-body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.fn-card-cat {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.53rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.6rem;
}
.fn-card h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.35;
  margin: 0 0 0.65rem;
  text-wrap: pretty;
}
.fn-card-excerpt {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.65;
  flex: 1;
  margin-bottom: 1rem;
  text-wrap: pretty;
}
.fn-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(30,32,24,0.08);
}
.fn-card-date {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.52rem;
  letter-spacing: 0.08em;
  color: var(--slate-mid);
}

/* ── PAGINATION ─────────────────────────────────────────────── */
.fn-pagination {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 2.5rem;
}
.fn-page-btn {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  padding: 0.5rem 0.85rem;
  border: 1px solid rgba(30,32,24,0.2);
  color: var(--ink-body);
  text-decoration: none;
  transition: border-color 150ms, color 150ms;
}
.fn-page-btn:hover, .fn-page-btn.active { border-color: var(--brass); color: var(--brass); }

/* ── CTA BAND ────────────────────────────────────────────────── */
.fn-cta-band {
  background: var(--ink);
  border-top: 2px solid var(--brass);
  padding: 3.5rem 7%;
  text-align: center;
}
.fn-cta-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.57rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.85rem;
}
.fn-cta-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  font-style: italic;
  font-weight: 500;
  color: var(--bone);
  line-height: 1.4;
  margin-bottom: 1.5rem;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.fn-cta-btns { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }

@media (max-width: 960px) { .fn-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 820px) {
  .fn-featured-inner { grid-template-columns: 1fr; }
  .fn-featured-img { display: none; }
}
@media (max-width: 600px) { .fn-grid { grid-template-columns: 1fr; } }

/* ---- Post-Template.html ---- */
/* ── POST HERO ───────────────────────────────────────────────── */
.post-hero {
  background: var(--ink);
  border-bottom: 2px solid var(--brass);
  padding: 5rem 7% 4.5rem;
}
.post-hero-inner { max-width: 780px; }
.post-breadcrumb {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,230,0.3);
  margin-bottom: 1.25rem;
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.post-breadcrumb a { color: rgba(245,240,230,0.3); text-decoration: none; }
.post-breadcrumb a:hover { color: var(--brass); }
.post-breadcrumb-sep { opacity: 0.4; }
.post-cat {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 1rem;
}
.post-hero h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1.8rem, 3.2vw, 3rem);
  font-weight: 500;
  color: var(--bone);
  line-height: 1.2;
  margin: 0 0 1.25rem;
  text-wrap: pretty;
}
.post-hero-lede {
  font-family: 'Jost', sans-serif;
  font-size: 1.05rem;
  color: rgba(245,240,230,0.6);
  line-height: 1.7;
  max-width: 640px;
  margin-bottom: 1.75rem;
  text-wrap: pretty;
}
.post-meta {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  align-items: center;
}
.post-meta-item {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.08em;
  color: rgba(245,240,230,0.3);
}
.post-meta-item span { color: rgba(245,240,230,0.5); }

/* ── POST BODY ──────────────────────────────────────────────── */
.post-wrap {
  background: var(--paper);
  padding: 4rem 7%;
}
.post-inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 5rem;
  max-width: 1100px;
  margin: 0 auto;
  align-items: start;
}
.post-content { min-width: 0; }
.post-content p {
  font-family: 'Jost', sans-serif;
  font-size: 1rem;
  color: var(--ink-body);
  line-height: 1.85;
  margin-bottom: 1.5rem;
  text-wrap: pretty;
}
.post-content h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.55rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
  margin: 2.5rem 0 1rem;
  text-wrap: pretty;
}
.post-content h3 {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 2rem 0 0.75rem;
}
.post-pull {
  border-left: 3px solid var(--brass);
  padding: 0.75rem 1.5rem;
  margin: 2rem 0;
  background: var(--paper-dark);
}
.post-pull p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  font-style: italic;
  color: var(--ink);
  line-height: 1.55;
  margin: 0 !important;
}
.post-callout {
  background: var(--ink);
  padding: 1.5rem 1.75rem;
  margin: 2rem 0;
}
.post-callout-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.65rem;
}
.post-callout p {
  font-family: 'Jost', sans-serif;
  font-size: 0.9rem;
  color: rgba(245,240,230,0.7);
  line-height: 1.7;
  margin: 0 !important;
}
.post-divider {
  width: 2.5rem;
  height: 1px;
  background: var(--brass);
  margin: 2.5rem 0;
}

/* ── POST CTA ───────────────────────────────────────────────── */
.post-cta {
  border: 2px solid var(--brass);
  padding: 2rem 2.25rem;
  margin-top: 3rem;
  background: var(--paper-aged);
}
.post-cta-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.75rem;
}
.post-cta h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.35rem;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
  margin: 0 0 0.75rem;
  text-transform: none;
  letter-spacing: 0;
}
.post-cta p {
  font-family: 'Jost', sans-serif;
  font-size: 0.85rem;
  color: var(--ink-body);
  line-height: 1.65;
  margin-bottom: 1.25rem !important;
}
.post-cta-links { display: flex; flex-direction: column; gap: 0.5rem; }
.post-cta-link {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  text-decoration: none;
  border: 1px solid rgba(30,32,24,0.25);
  padding: 0.55rem 0.85rem;
  transition: border-color 150ms, color 150ms;
  display: flex;
  justify-content: space-between;
}
.post-cta-link:hover { border-color: var(--brass); color: var(--brass); }

/* ── SIDEBAR ────────────────────────────────────────────────── */
.post-sidebar { position: sticky; top: 5rem; }
.post-sidebar-block {
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(30,32,24,0.1);
}
.post-sidebar-block:last-child { border-bottom: none; margin-bottom: 0; }
.post-sidebar-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 0.85rem;
}
.post-sidebar-text {
  font-family: 'Jost', sans-serif;
  font-size: 0.82rem;
  color: var(--ink-body);
  line-height: 1.65;
  margin-bottom: 0.85rem;
}
.post-sidebar-related { display: flex; flex-direction: column; gap: 1rem; }
.post-sidebar-item {}
.post-sidebar-item-cat {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.5rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.25rem;
}
.post-sidebar-item a {
  font-family: 'Cormorant Garamond', serif;
  font-size: 0.95rem;
  color: var(--ink);
  line-height: 1.35;
  text-decoration: none;
  text-wrap: pretty;
}
.post-sidebar-item a:hover { color: var(--brass); }

/* ── AUTHOR BLOCK ───────────────────────────────────────────── */
.post-author {
  background: var(--paper-dark);
  border-top: 1px solid rgba(30,32,24,0.1);
  padding: 3rem 7%;
}
.post-author-inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  gap: 2rem;
  align-items: flex-start;
}
.post-author-photo {
  width: 64px;
  height: 64px;
  background: var(--ink-mid);
  border: 1px solid rgba(30,32,24,0.2);
  flex-shrink: 0;
  overflow: hidden;
}
.post-author-photo img { width: 100%; height: 100%; object-fit: cover; }
.post-author-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate-mid);
  margin-bottom: 0.3rem;
}
.post-author-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 0.5rem;
}
.post-author-bio {
  font-family: 'Jost', sans-serif;
  font-size: 0.83rem;
  color: var(--ink-body);
  line-height: 1.65;
}

@media (max-width: 860px) {
  .post-inner { grid-template-columns: 1fr; }
  .post-sidebar { position: static; margin-top: 3rem; padding-top: 3rem; border-top: 1px solid rgba(30,32,24,0.1); }
  .post-author-inner { flex-direction: column; }
}

/* ---- Category-Template.html ---- */
.fn-hero { background: var(--ink); border-bottom: 2px solid var(--brass); padding: 5rem 7% 4rem; }
.fn-hero-eyebrow { font-family: 'IBM Plex Mono', monospace; font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brass); margin-bottom: 1.25rem; display: flex; align-items: center; gap: 0.65rem; }
.fn-hero-eyebrow::before { content: ''; display: inline-block; width: 18px; height: 1px; background: var(--brass); flex-shrink: 0; }
.fn-hero-breadcrumb { font-family: 'IBM Plex Mono', monospace; font-size: 0.55rem; letter-spacing: 0.08em; color: rgba(245,240,230,0.3); margin-bottom: 0.85rem; }
.fn-hero-breadcrumb a { color: rgba(245,240,230,0.3); text-decoration: none; }
.fn-hero-breadcrumb a:hover { color: var(--brass); }
.fn-hero h1 { font-family: 'Cormorant SC', serif; font-size: clamp(2rem, 3.5vw, 3.2rem); font-weight: 600; letter-spacing: 0.06em; color: var(--bone); line-height: 1; margin: 0 0 1rem; }
.fn-hero-desc { font-family: 'Jost', sans-serif; font-size: 0.92rem; color: rgba(245,240,230,0.55); line-height: 1.7; max-width: 560px; margin: 0; }
.fn-filter-bar { background: var(--paper-dark); border-bottom: 1px solid rgba(30,32,24,0.12); padding: 0 7%; overflow-x: auto; }
.fn-filter-inner { display: flex; gap: 0; max-width: 1200px; margin: 0 auto; white-space: nowrap; }
.fn-filter-item { font-family: 'IBM Plex Mono', monospace; font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--slate-mid); padding: 0.85rem 1.25rem; border-bottom: 2px solid transparent; cursor: pointer; text-decoration: none; transition: color 150ms, border-color 150ms; display: inline-block; }
.fn-filter-item:hover { color: var(--ink); }
.fn-filter-item.active { color: var(--brass); border-bottom-color: var(--brass); }
.fn-grid-section { background: var(--paper); padding: 3.5rem 7%; }
.fn-grid-inner { max-width: 1200px; margin: 0 auto; }
.fn-grid-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 2rem; padding-bottom: 0.75rem; border-bottom: 1px solid rgba(30,32,24,0.12); }
.fn-grid-title { font-family: 'IBM Plex Mono', monospace; font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--slate-mid); }
.fn-grid-count { font-family: 'IBM Plex Mono', monospace; font-size: 0.55rem; letter-spacing: 0.08em; color: var(--slate-mid); }
.fn-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.fn-card { background: var(--bone); border: 1px solid rgba(30,32,24,0.15); display: flex; flex-direction: column; transition: border-color 150ms; }
.fn-card:hover { border-color: var(--brass); }
.fn-card-img { background: var(--ink-mid); aspect-ratio: 16/9; display: flex; align-items: center; justify-content: center; border-bottom: 1px solid rgba(30,32,24,0.1); }
.fn-img-placeholder { font-family: 'IBM Plex Mono', monospace; font-size: 0.5rem; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(245,240,230,0.15); }
.fn-card-body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.fn-card-cat { font-family: 'IBM Plex Mono', monospace; font-size: 0.53rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--brass); margin-bottom: 0.6rem; }
.fn-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-weight: 500; color: var(--ink); line-height: 1.35; margin: 0 0 0.65rem; text-wrap: pretty; }
.fn-card-excerpt { font-family: 'Jost', sans-serif; font-size: 0.82rem; color: var(--ink-body); line-height: 1.65; flex: 1; margin-bottom: 1rem; text-wrap: pretty; }
.fn-card-footer { display: flex; justify-content: space-between; align-items: center; padding-top: 0.85rem; border-top: 1px solid rgba(30,32,24,0.08); }
.fn-card-date { font-family: 'IBM Plex Mono', monospace; font-size: 0.52rem; letter-spacing: 0.08em; color: var(--slate-mid); }
.fn-read-link { font-family: 'IBM Plex Mono', monospace; font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink); text-decoration: none; border-bottom: 1px solid rgba(30,32,24,0.3); padding-bottom: 0.1rem; transition: color 150ms, border-color 150ms; }
.fn-read-link:hover { color: var(--brass); border-color: var(--brass); }
.fn-pagination { display: flex; justify-content: center; gap: 0.5rem; margin-top: 2.5rem; }
.fn-page-btn { font-family: 'IBM Plex Mono', monospace; font-size: 0.6rem; letter-spacing: 0.08em; padding: 0.5rem 0.85rem; border: 1px solid rgba(30,32,24,0.2); color: var(--ink-body); text-decoration: none; transition: border-color 150ms, color 150ms; }
.fn-page-btn:hover, .fn-page-btn.active { border-color: var(--brass); color: var(--brass); }
.fn-cta-band { background: var(--ink); border-top: 2px solid var(--brass); padding: 3.5rem 7%; text-align: center; }
.fn-cta-label { font-family: 'IBM Plex Mono', monospace; font-size: 0.57rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--brass); margin-bottom: 0.85rem; }
.fn-cta-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.4rem, 2.2vw, 2rem); font-style: italic; font-weight: 500; color: var(--bone); line-height: 1.4; margin-bottom: 1.5rem; max-width: 560px; margin-left: auto; margin-right: auto; }
.fn-cta-btns { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }
@media (max-width: 960px) { .fn-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .fn-grid { grid-template-columns: 1fr; } }

/* ── Audit additions (v1.0.1) ───────────────────────────────── */
/* Outcome line on instrument cards: the result, above the deliverables. */
.instrument-outcome {
	font-family: 'Cormorant Garamond', serif;
	font-style: italic;
	font-size: 1.02rem;
	line-height: 1.5;
	color: var(--ink-mid, #4a5442);
	margin: 0.6rem 0 0.9rem;
	padding-left: 0.85rem;
	border-left: 2px solid var(--brass, #a07c3e);
}

/* Static hero CTA shown only when JS is unavailable (console removes it on boot). */
.console-fallback-cta {
	margin-top: 1.25rem;
	text-align: center;
}

/* ── Intrinsic design conventions (v1.0.2) ──────────────────────
 * New CSS in this theme is written intrinsic-first:
 * 1. Fluid type/spacing via clamp(min, rem + vw, max) – no stepped
 *    media-query overrides for sizes. Anchor the mobile value at the
 *    old small breakpoint, the desktop value at 1280px.
 * 2. Media queries are reserved for LAYOUT changes (grid collapses,
 *    order, visibility) – not for resizing text or padding.
 * 3. Prefer auto-fit/minmax() grids and container queries for new
 *    components so they adapt to their container, not the viewport.
 * Fluid spacing tokens for new sections: */
:root {
	--space-section: clamp(3.5rem, 1.74rem + 4.71vw, 5.5rem);
	--space-gutter: clamp(5%, 8.76vw - 1.41rem, 7%);
	--space-block: clamp(1.75rem, 1rem + 1.875vw, 2.5rem);
}
