/* =========================================================
   Springwood Capital — Swiss / systematic
   Shared stylesheet for all pages
   ========================================================= */
:root {
  --paper:       #F6F1E7;
  --paper-2:     #FFFBF2;
  --paper-deep:  #ECE5D3;
  --paper-sunk:  #E5DCC4;
  --rule:        #D9D1BB;
  --rule-soft:   #E8E1CD;
  --ink:         #17231F;
  --ink-2:       #2C3530;
  --muted:       #6E746D;
  --muted-2:     #898E84;
  --accent:      #C75D2A;
  --accent-deep: #8A3D17;
  --teal:        #1E8A7A;
  --teal-deep:   #0F4F46;
  --deep:        #14201C;

  --sans: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --max: 1280px;
  --gutter: 32px;
  --rail-l: 60px;
  --rail-r: 220px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 400;
  font-feature-settings: "ss01" on, "cv11" on;
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.skip { position: absolute; left: -9999px; top: 0; background: var(--ink); color: var(--paper-2); padding: 10px 16px; font-size: 13px; font-weight: 500; border-radius: 4px; z-index: 100; }
.skip:focus { left: 16px; top: 16px; }

/* ---------- HEADER ---------- */
.site-header { background: var(--paper); border-bottom: 1.5px solid var(--ink); position: sticky; top: 0; z-index: 40; }
.nav { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; padding: 18px var(--gutter); gap: 24px; max-width: var(--max); margin: 0 auto; }
.brand { display: inline-block; line-height: 0; color: var(--ink); }
.brand svg { display: block; }
.nav-links { display: flex; justify-content: center; gap: 28px; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; }
.nav-links a { color: var(--ink); transition: color 100ms; position: relative; padding: 4px 0; }
.nav-links a:hover { color: var(--accent); }
.nav-links a.active { color: var(--accent); }
.nav-links a.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--accent); }
.nav-cta { justify-self: end; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--accent); border-bottom: 1px solid var(--accent); padding-bottom: 2px; font-weight: 500; }
.menu-btn { display: none; background: var(--ink); color: var(--paper-2); border: 0; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; padding: 8px 12px; cursor: pointer; }

/* ---------- SHARED PRIMITIVES ---------- */
.frame { max-width: var(--max); margin: 0 auto; border-bottom: 1.5px solid var(--ink); }
.row { display: grid; grid-template-columns: var(--rail-l) 1fr var(--rail-r); }
.row.no-rright { grid-template-columns: var(--rail-l) 1fr; }
.rail-l, .rail-r { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 500; }
.rail-l { border-right: 1px solid var(--rule); writing-mode: vertical-rl; transform: rotate(180deg); padding: 28px 0; display: flex; justify-content: flex-start; align-items: flex-start; }
.rail-l > span { letter-spacing: 0.12em; line-height: 1.4; }
.rail-l .accent { color: var(--accent); }
.rail-r { border-left: 1px solid var(--rule); padding: 28px 20px; line-height: 1.8; }
.rail-r dl { margin: 0; }
.rail-r dt { color: var(--accent); margin-bottom: 4px; font-weight: 500; }
.rail-r dd { margin: 0 0 16px; color: var(--ink); font-family: var(--sans); font-size: 12px; text-transform: none; letter-spacing: 0; font-weight: 500; line-height: 1.4; }
.rail-r dd:last-child { margin-bottom: 0; }

/* ---------- HOMEPAGE HERO ---------- */
.hero { background: var(--paper); }
.hero-stage { padding: 80px 56px 64px; }
.hero h1 { font-family: var(--sans); font-weight: 700; font-size: clamp(3.5rem, 9vw, 8.6rem); line-height: 0.86; letter-spacing: -0.055em; text-transform: uppercase; margin: 0 0 36px; text-wrap: balance; max-width: 11ch; }
.hero h1 .neg { font-weight: 300; color: var(--muted); }
.hero h1 .small { display: block; font-size: 0.34em; font-weight: 500; letter-spacing: 0.06em; color: var(--accent); text-transform: uppercase; font-family: var(--mono); margin-bottom: 18px; line-height: 1; }
.hero-lede { font-size: 17px; line-height: 1.5; max-width: 54ch; margin: 0 0 36px; color: var(--ink-2); }
.hero-lede strong { font-weight: 600; color: var(--ink); }

/* ---------- INNER-PAGE HERO ---------- */
.page-hero { background: var(--paper); }
.page-hero-row { display: grid; grid-template-columns: var(--rail-l) 1fr var(--rail-r); }
.page-hero .ph-body { padding: 64px 56px 56px; }
.page-hero .eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  font-weight: 500;
  margin-bottom: 22px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 16px;
}
.page-hero .eyebrow .ref { color: var(--muted); }
.page-hero h1 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(2.6rem, 6.5vw, 5.6rem);
  line-height: 0.9;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  text-wrap: balance;
  margin: 0;
  max-width: 16ch;
}
.page-hero h1 .neg { font-weight: 300; color: var(--muted); }
.page-hero h1 .acc { color: var(--accent); font-weight: 700; }
.page-hero .lede {
  font-size: 16.5px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 28px 0 0;
  max-width: 60ch;
}
.page-hero .lede strong { color: var(--ink); font-weight: 600; }

/* ---------- CTA / ACTIONS BAR ---------- */
.actions-bar { display: grid; grid-template-columns: 60px 1fr; border-top: 1.5px solid var(--ink); }
.actions-bar .rail-l-mini { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 500; padding: 20px 0; border-right: 1px solid var(--rule); writing-mode: vertical-rl; transform: rotate(180deg); display: flex; justify-content: flex-start; align-items: flex-start; }
.actions { display: grid; grid-template-columns: repeat(3, 1fr); }
.actions a { padding: 22px 28px; font-family: var(--sans); font-weight: 600; font-size: 14px; letter-spacing: 0.005em; color: var(--ink); display: flex; justify-content: space-between; align-items: center; transition: background 100ms, color 100ms; }
.actions a + a { border-left: 1px solid var(--rule); }
.actions a:hover { background: var(--ink); color: var(--paper-2); }
.actions a:hover .arr { color: var(--paper-2); }
.actions a .arr { font-family: var(--mono); font-weight: 400; color: var(--accent); transition: color 100ms; font-size: 16px; }

/* ---------- PERFORMANCE TRACTS ---------- */
.tracts { display: grid; grid-template-columns: 60px repeat(4, 1fr); background: var(--paper); }
.tracts .rail-l { border-right: 1px solid var(--rule); padding: 32px 0; }
.tract { padding: 40px 28px 36px; border-right: 1px solid var(--rule); }
.tract:last-child { border-right: 0; }
.tract .marker { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); font-weight: 500; margin-bottom: 28px; }
.tract .figure { font-family: var(--sans); font-size: 64px; font-weight: 500; line-height: 1; letter-spacing: -0.045em; margin-bottom: 12px; }
.tract .figure .unit { font-size: 32px; color: var(--muted); font-weight: 400; margin-left: 1px; }
.tract .lbl { font-size: 13.5px; color: var(--ink-2); line-height: 1.45; max-width: 28ch; }
.tract .lbl .ast { color: var(--accent); font-family: var(--mono); }

/* ---------- SECTIONS ---------- */
section[id^="s-"] { background: var(--paper); }
.section-head { display: grid; grid-template-columns: var(--rail-l) 1fr; border-bottom: 1.5px solid var(--ink); }
.section-head .rail-l { padding: 32px 0; }
.section-head .head-body { padding: 56px 56px 40px; display: grid; grid-template-columns: 200px 1fr; gap: 64px; align-items: end; }
.section-head .num-block { font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 500; line-height: 1.6; }
.section-head .num-block .nbig { display: block; font-family: var(--sans); font-size: 56px; font-weight: 300; color: var(--ink); letter-spacing: -0.04em; line-height: 1; margin-bottom: 12px; }
.section-head .num-block .nbig .ink-accent { color: var(--accent); font-weight: 500; }
.section-head h2 { font-family: var(--sans); font-weight: 700; font-size: clamp(2.2rem, 5vw, 4.6rem); line-height: 0.92; letter-spacing: -0.045em; text-transform: uppercase; text-wrap: balance; max-width: 16ch; }
.section-head h2 .neg { font-weight: 300; color: var(--muted); }
.section-head h2 .acc { color: var(--accent); }

/* ---------- EXHIBIT (screenshot frame) ---------- */
.exhibit { background: var(--paper); padding: 48px 56px 56px; border-bottom: 1.5px solid var(--ink); }
.exhibit.tighter { padding: 36px 56px 44px; }
.exhibit-head { display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: baseline; padding-bottom: 14px; border-bottom: 1px solid var(--ink); margin-bottom: 0; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink); font-weight: 500; }
.exhibit-head .fig { color: var(--accent); }
.exhibit-head .title { font-weight: 500; letter-spacing: 0.08em; }
.exhibit-head .meta { color: var(--muted); font-weight: 400; }
.exhibit-frame { border: 1px solid var(--ink); border-top: 0; padding: 14px; background: var(--paper-deep); position: relative; }
.exhibit-frame::before { content: ""; position: absolute; top: 5px; left: 5px; width: 6px; height: 6px; border-top: 1px solid var(--ink); border-left: 1px solid var(--ink); }
.exhibit-frame::after { content: ""; position: absolute; top: 5px; right: 5px; width: 6px; height: 6px; border-top: 1px solid var(--ink); border-right: 1px solid var(--ink); }
.exhibit-frame img { width: 100%; height: auto; display: block; border: 1px solid rgba(23, 35, 31, 0.18); }
.exhibit-caption { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: start; padding: 14px 0 0; border-top: 1px solid var(--ink); margin-top: -1px; }
.exhibit-caption .desc { font-family: var(--sans); font-size: 13.5px; color: var(--ink-2); line-height: 1.55; max-width: 78ch; }
.exhibit-caption .desc .lab { font-family: var(--mono); font-size: 10.5px; color: var(--accent); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; margin-right: 4px; }
.exhibit-caption .desc strong { color: var(--ink); font-weight: 600; }
.exhibit-caption .stamp { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 500; white-space: nowrap; padding-top: 1px; line-height: 1.6; text-align: right; }
.exhibit-caption .stamp strong { color: var(--ink); font-weight: 500; display: block; }

/* ---------- SECTION BODY ROWS ---------- */
.body-row { display: grid; grid-template-columns: var(--rail-l) 1fr; background: var(--paper); }
.body-row .rail-l { padding: 40px 0; }
.body-row .body-inner { padding: 56px 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
.body-row .body-inner.solo { grid-template-columns: 1fr; }
.body-row h3 { font-family: var(--sans); font-weight: 600; font-size: clamp(1.4rem, 2.2vw, 1.8rem); line-height: 1.15; letter-spacing: -0.025em; margin: 0 0 18px; color: var(--ink); text-transform: uppercase; }
.body-row p { font-size: 15.5px; line-height: 1.65; color: var(--ink-2); margin: 0 0 14px; max-width: 56ch; }
.body-row p:last-child { margin-bottom: 0; }
.body-row p em { font-style: italic; color: var(--ink); }

/* ---------- KEY LISTS (inline mini-register) ---------- */
.key-list { list-style: none; margin: 0; padding: 0; }
.key-list li { display: grid; grid-template-columns: 32px 1fr; gap: 0; padding: 14px 0; border-bottom: 1px solid var(--rule); align-items: baseline; }
.key-list li:last-child { border-bottom: 0; }
.key-list .ki { font-family: var(--mono); font-size: 10px; color: var(--accent); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 500; padding-top: 3px; }
.key-list .kt { font-size: 14.5px; color: var(--ink-2); line-height: 1.5; }
.key-list .kt strong { color: var(--ink); font-weight: 600; display: block; margin-bottom: 2px; }

/* ---------- SUB-EXHIBIT ---------- */
.sub-exhibit { display: grid; grid-template-columns: var(--rail-l) 1fr; background: var(--paper); border-top: 1.5px solid var(--ink); }
.sub-exhibit .rail-l { padding: 32px 0; }
.sub-exhibit .sub-inner { padding: 48px 56px; }

/* ---------- TABLES (register tables) ---------- */
.register-section .body-inner,
.industries-section .body-inner { padding: 0 56px 56px; }
.reg-table { width: 100%; border-collapse: collapse; border-top: 1px solid var(--ink); }
.reg-table th, .reg-table td { text-align: left; padding: 18px 16px; border-bottom: 1px solid var(--rule); vertical-align: top; }
.reg-table th { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 500; padding-top: 14px; padding-bottom: 14px; }
.reg-table td.idx { font-family: var(--mono); font-size: 11px; color: var(--accent); font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; width: 80px; }
.reg-table td.name { font-family: var(--sans); font-size: 17px; font-weight: 600; letter-spacing: -0.015em; color: var(--ink); width: 220px; text-transform: uppercase; }
.reg-table td.scope { font-size: 14.5px; color: var(--ink-2); line-height: 1.5; }
.reg-table td.fig { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); white-space: nowrap; width: 160px; text-align: right; }
.reg-table td.fig.has-fig { color: var(--accent); font-weight: 500; }
.reg-table tr.no-fig td { color: var(--ink-2); }

/* ---------- CHECK / RULES LIST ---------- */
.rules-list { list-style: none; margin: 0; padding: 0; }
.rules-list li { display: grid; grid-template-columns: 56px 1fr; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--rule); align-items: start; }
.rules-list li:last-child { border-bottom: 0; }
.rules-list .check { font-family: var(--mono); font-size: 18px; color: var(--accent); line-height: 1; padding-top: 2px; }
.rules-list .check::before { content: "✓"; }
.rules-list .rule-text { font-size: 15px; color: var(--ink-2); line-height: 1.55; }
.rules-list .rule-text strong { color: var(--ink); font-weight: 600; display: block; margin-bottom: 4px; font-size: 14px; text-transform: uppercase; letter-spacing: 0.02em; }

/* ---------- PROCESS (numbered steps) ---------- */
.process { display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1px solid var(--ink); }
.process-step { display: grid; grid-template-columns: 80px 220px 1fr; gap: 32px; padding: 28px 0; border-bottom: 1px solid var(--rule); align-items: baseline; }
.process-step .pn { font-family: var(--mono); font-size: 11px; color: var(--accent); font-weight: 500; letter-spacing: 0.04em; }
.process-step .pv { font-family: var(--sans); font-weight: 600; font-size: 20px; color: var(--ink); text-transform: uppercase; letter-spacing: -0.015em; }
.process-step .pd { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; max-width: 60ch; }

/* ---------- STAGE TABLE ---------- */
.stage-table { width: 100%; border-collapse: collapse; border-top: 1px solid var(--ink); }
.stage-table thead th { background: var(--ink); color: var(--paper-2); padding: 14px 16px; text-align: left; font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500; }
.stage-table tbody td { padding: 18px 16px; border-bottom: 1px solid var(--rule); vertical-align: top; font-size: 14px; line-height: 1.55; color: var(--ink-2); }
.stage-table tbody td.stage { font-family: var(--sans); font-weight: 600; color: var(--ink); text-transform: uppercase; font-size: 13.5px; letter-spacing: 0.02em; width: 200px; }
.stage-table tbody td.does { width: 45%; }

/* ---------- COLUMN GRID (technology security) ---------- */
.col-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--ink); }
.col-grid .cell { padding: 24px 24px 28px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.col-grid .cell:last-child { border-right: 0; }
.col-grid .cell .ci { font-family: var(--mono); font-size: 10px; color: var(--accent); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500; margin-bottom: 18px; }
.col-grid .cell h4 { font-family: var(--sans); font-weight: 600; font-size: 17px; color: var(--ink); margin: 0 0 8px; text-transform: uppercase; letter-spacing: -0.015em; }
.col-grid .cell p { font-size: 13.5px; color: var(--ink-2); line-height: 1.5; margin: 0; }

/* ---------- CONTACT FORM ---------- */
.form-frame { border-top: 1px solid var(--ink); padding-top: 0; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-bottom: 1px solid var(--rule); }
.form-grid .ff { padding: 18px 0 18px 16px; border-left: 1px solid var(--rule); display: flex; flex-direction: column; gap: 6px; }
.form-grid .ff:first-child { padding-left: 16px; border-left: 0; }
.form-grid.full { grid-template-columns: 1fr; }
.form-grid .ff .flbl { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--accent); font-weight: 500; }
.form-grid .ff .fhint { font-family: var(--sans); font-size: 14px; color: var(--ink-2); }

/* ---------- CTA BAND ---------- */
.cta-band { background: var(--deep); color: var(--paper-2); border-bottom: 1.5px solid var(--deep); }
.cta-grid { display: grid; grid-template-columns: 60px 1fr; }
.cta-band .rail-l { border-right: 1px solid rgba(255, 251, 242, 0.16); color: rgba(255, 251, 242, 0.5); padding: 48px 0; }
.cta-inner { padding: 88px 56px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: end; }
.cta-inner h2 { font-family: var(--sans); font-weight: 700; font-size: clamp(2.4rem, 5.5vw, 5rem); line-height: 0.92; letter-spacing: -0.045em; text-transform: uppercase; color: var(--paper-2); max-width: 13ch; margin: 0; text-wrap: balance; }
.cta-inner h2 .neg { font-weight: 300; color: rgba(255, 251, 242, 0.55); }
.cta-inner h2 .accent { color: var(--accent); }
.cta-right p { font-size: 16px; line-height: 1.6; color: rgba(255, 251, 242, 0.72); margin: 0 0 24px; max-width: 44ch; }
.cta-right .cta-actions { display: flex; flex-direction: column; border: 1px solid rgba(255, 251, 242, 0.18); }
.cta-right .cta-actions a { padding: 18px 22px; font-family: var(--sans); font-weight: 600; font-size: 14px; color: var(--paper-2); display: flex; justify-content: space-between; align-items: center; transition: background 100ms, color 100ms; }
.cta-right .cta-actions a + a { border-top: 1px solid rgba(255, 251, 242, 0.18); }
.cta-right .cta-actions a:hover { background: var(--accent); color: #1A1107; }
.cta-right .cta-actions a:hover .arr { color: #1A1107; }
.cta-right .cta-actions a .arr { font-family: var(--mono); color: var(--accent); font-size: 16px; transition: color 100ms; }

/* ---------- FOOTER ---------- */
.site-footer { background: var(--paper); padding: 64px var(--gutter) 28px; }
.footer-inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 56px; align-items: start; padding-top: 32px; border-top: 1.5px solid var(--ink); }
.footer-brand .brand { margin-bottom: 18px; display: inline-block; }
.footer-brand p { font-size: 13.5px; color: var(--muted); line-height: 1.6; margin: 0 0 18px; max-width: 360px; }
.footer-brand .legal { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.04em; color: var(--muted); line-height: 1.7; }
.footer-col h4 { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink); font-weight: 500; margin: 0 0 14px; }
.footer-col a { display: block; padding: 5px 0; font-size: 13.5px; color: var(--ink-2); transition: color 100ms; }
.footer-col a:hover { color: var(--accent); }
.footer-bottom { max-width: var(--max); margin: 48px auto 0; padding-top: 20px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }

/* ---------- NOTE BLOCK ---------- */
.note { border-left: 4px solid var(--accent); background: rgba(199,93,42,0.06); padding: 18px 22px; margin: 0; font-size: 14px; line-height: 1.55; color: var(--ink-2); }
.note strong { color: var(--ink); font-weight: 600; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1080px) {
  :root { --rail-r: 0px; }
  .row, .page-hero-row { grid-template-columns: var(--rail-l) 1fr; }
  .rail-r { display: none; }
  .hero-stage { padding: 56px 40px 48px; }
  .actions { grid-template-columns: 1fr; }
  .actions a + a { border-left: 0; border-top: 1px solid var(--rule); }
  .section-head .head-body { padding: 40px 40px 32px; grid-template-columns: 1fr; gap: 28px; }
  .body-row .body-inner { padding: 40px 40px; grid-template-columns: 1fr; gap: 36px; }
  .exhibit { padding: 32px 40px 40px; }
  .sub-exhibit .sub-inner { padding: 32px 40px; }
  .cta-inner { padding: 56px 40px; grid-template-columns: 1fr; gap: 36px; }
  .register-section .body-inner, .industries-section .body-inner { padding: 0 40px 40px; }
  .page-hero .ph-body { padding: 48px 40px 40px; }
  .col-grid { grid-template-columns: 1fr 1fr; }
  .col-grid .cell:nth-child(2) { border-right: 0; }
  .process-step { grid-template-columns: 60px 1fr; gap: 16px; }
  .process-step .pd { grid-column: 2; }
}
@media (max-width: 760px) {
  :root { --rail-l: 0px; --gutter: 20px; }
  .row, .body-row, .sub-exhibit, .cta-grid, .section-head, .tracts, .actions-bar, .page-hero-row { grid-template-columns: 1fr; }
  .rail-l, .actions-bar .rail-l-mini { display: none; }
  .nav { grid-template-columns: 1fr auto; gap: 16px; padding: 14px 20px; }
  .nav-links { display: none; position: absolute; top: 56px; left: 8px; right: 8px; background: var(--paper-2); padding: 12px; border: 1px solid var(--rule); flex-direction: column; gap: 4px; }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 8px 12px; }
  .nav-cta { display: none; }
  .menu-btn { display: inline-flex; align-items: center; }
  .hero-stage { padding: 36px 20px 32px; }
  .hero-lede { font-size: 15.5px; }
  .tracts { grid-template-columns: 1fr 1fr; }
  .tract { padding: 28px 20px; border-bottom: 1px solid var(--rule); }
  .tract:nth-child(odd) { border-right: 1px solid var(--rule); }
  .tract:nth-child(even) { border-right: 0; }
  .tract:last-child { border-bottom: 0; }
  .tract .figure { font-size: 44px; }
  .section-head .head-body { padding: 32px 20px 24px; }
  .section-head h2 { font-size: 2rem; }
  .body-row .body-inner { padding: 32px 20px; gap: 28px; }
  .exhibit { padding: 24px 20px 28px; }
  .exhibit-head { grid-template-columns: 1fr; gap: 6px; padding-bottom: 10px; }
  .exhibit-caption { grid-template-columns: 1fr; gap: 12px; }
  .exhibit-caption .stamp { text-align: left; }
  .sub-exhibit .sub-inner { padding: 24px 20px; }
  .cta-inner { padding: 40px 20px; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; padding: 28px 0 0; }
  .register-section .body-inner, .industries-section .body-inner { padding: 0 20px 32px; overflow-x: auto; }
  .reg-table, .stage-table { min-width: 580px; }
  .page-hero .ph-body { padding: 28px 20px 24px; }
  .page-hero .eyebrow { flex-direction: column; align-items: flex-start; gap: 4px; }
  .col-grid { grid-template-columns: 1fr; }
  .col-grid .cell { border-right: 0; }
  .process-step { padding: 18px 20px; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .ff { border-left: 0; border-top: 1px solid var(--rule); padding-left: 20px; padding-right: 20px; }
  .form-grid .ff:first-child { border-top: 0; padding-left: 20px; }
}
