
:root {
  --base: #f6f2e8;
  --paper: #fffdf7;
  --ink: #14231f;
  --forest: #123c33;
  --jade: #1a8c78;
  --sky: #7bb7c9;
  --sand: #d9b77a;
  --line: #d6cdbd;
  --mist: #e7eee8;
  --muted: #5f6d67;
  --footer: #10241f;
  --shadow: 0 18px 42px rgba(28, 54, 46, 0.1);
}

* { box-sizing: border-box; }
html { max-width: 100%; overflow-x: hidden; scroll-behavior: smooth; }
body { max-width: 100%; margin: 0; overflow-x: hidden; color: var(--ink); background: var(--base); font-family: Inter, "Segoe UI", Arial, sans-serif; letter-spacing: 0; }
a { color: inherit; text-decoration: none; }
p { max-width: 850px; margin: 0 0 18px; line-height: 1.7; }
h1, h2, h3 { margin: 0; color: var(--forest); letter-spacing: 0; }
h1 { font-size: 64px; line-height: 1.02; }
h2 { font-size: 36px; line-height: 1.14; }
h3 { font-size: 21px; line-height: 1.3; }

.site-header { position: sticky; top: 0; z-index: 30; background: rgba(255, 253, 247, 0.96); border-bottom: 1px solid var(--line); }
.header-inner { width: min(1360px, calc(100% - 40px)); min-height: 82px; margin: 0 auto; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 8px 24px; }
.brand { flex: 0 0 auto; display: inline-flex; align-items: center; gap: 13px; color: var(--forest); }
.brand > span:last-child { display: grid; }
.brand b { font-size: 17px; }
.brand small { color: var(--jade); font-size: 11px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; }
.fern-mark { position: relative; width: 43px; height: 43px; display: block; border-left: 2px solid var(--forest); transform: rotate(-12deg); }
.fern-mark i { position: absolute; left: 4px; width: 21px; height: 9px; border: 2px solid var(--jade); border-left: 0; border-radius: 0 100% 0 100%; transform-origin: left center; }
.fern-mark i:nth-child(1) { top: 3px; transform: rotate(-18deg); }
.fern-mark i:nth-child(2) { top: 10px; transform: rotate(10deg) scale(0.92); }
.fern-mark i:nth-child(3) { top: 18px; transform: rotate(-13deg) scale(0.82); }
.fern-mark i:nth-child(4) { top: 26px; transform: rotate(14deg) scale(0.68); }
.fern-mark i:nth-child(5) { top: 34px; transform: rotate(-10deg) scale(0.52); }
.primary-nav { min-width: 0; flex: 1 1 760px; display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 2px; color: #38564e; font-size: 12px; font-weight: 800; }
.primary-nav a { padding: 10px 9px; border-bottom: 2px solid transparent; white-space: nowrap; }
.primary-nav a:hover, .primary-nav a:focus-visible { color: var(--forest); border-bottom-color: var(--jade); }

.eyebrow { margin: 0 0 12px; color: var(--jade); font-size: 11px; font-weight: 900; letter-spacing: 0.13em; text-transform: uppercase; }
.text-button, .quiet-button { min-height: 45px; padding: 0 18px; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 900; }
.text-button { color: var(--paper); background: var(--forest); border: 1px solid var(--forest); }
.text-button:hover, .text-button:focus-visible { background: var(--jade); border-color: var(--jade); }
.quiet-button { color: var(--forest); background: transparent; border: 1px solid #769087; }
.quiet-button:hover, .quiet-button:focus-visible { color: var(--paper); background: var(--forest); }
.hero-actions, .row-actions { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 26px; }

.opening-field { min-height: 560px; padding: 54px max(24px, calc((100% - 1360px) / 2)); display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(310px, 0.55fr); align-items: center; gap: 70px; background-color: var(--base); background-image: linear-gradient(rgba(246, 242, 232, 0.28), rgba(246, 242, 232, 0.28)), url("/assets/topographic-field.jpg"); background-position: center; background-size: cover; border-bottom: 1px solid var(--line); }
.opening-copy { padding: 46px 0; }
.opening-copy h1 { max-width: 900px; }
.hero-title-line { display: block; white-space: nowrap; }
.opening-copy > p:not(.eyebrow) { max-width: 760px; margin-top: 24px; color: #314c44; font-size: 19px; }
.field-card { padding: 30px; background: rgba(255, 253, 247, 0.94); border: 1px solid var(--line); border-top: 5px solid var(--jade); box-shadow: var(--shadow); }
.field-card > span, .report-key > span, .page-key > span, .company-summary-head aside > span { color: var(--jade); font-size: 10px; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; }
.field-card dl, .report-key dl, .company-summary-head aside dl { margin: 22px 0 0; display: grid; gap: 0; }
.field-card dl div, .report-key dl div, .company-summary-head aside dl div { padding: 13px 0; display: grid; grid-template-columns: 110px 1fr; gap: 10px; border-bottom: 1px solid var(--line); }
.field-card dt, .report-key dt { color: var(--forest); font-weight: 900; }
.field-card dd, .report-key dd, .company-summary-head aside dd { margin: 0; color: var(--muted); font-size: 13px; }

.compass-band { padding: 24px max(24px, calc((100% - 1360px) / 2)); display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; color: var(--paper); background: var(--forest); }
.compass-band div { min-height: 58px; padding: 8px 20px; display: flex; align-items: center; gap: 13px; border-right: 1px solid rgba(255,255,255,0.2); }
.compass-band div:last-child { border-right: 0; }
.compass-band span { color: var(--sand); font-size: 11px; font-weight: 900; }
.compass-band strong { font-size: 13px; line-height: 1.35; }

.content-band, .breadcrumbs, .page-lead { width: min(1320px, calc(100% - 48px)); margin: 0 auto; }
.content-band { padding: 76px 0; }
.wide-band { width: 100%; padding: 76px max(24px, calc((100% - 1320px) / 2)); }
.section-heading { margin-bottom: 34px; display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(300px, 0.7fr); align-items: end; gap: 32px; }
.section-heading .eyebrow { grid-column: 1; }
.section-heading h2 { grid-column: 1; }
.section-heading > p:not(.eyebrow) { grid-column: 2; grid-row: 1 / span 2; margin: 0; color: var(--muted); }

.trail-preview > div:last-child { border-top: 1px solid var(--line); }
.trail-preview-row { position: relative; padding: 28px 0; display: grid; grid-template-columns: 54px 0.62fr 1.38fr; gap: 26px; border-bottom: 1px solid var(--line); }
.trail-preview-row:before { content: ""; position: absolute; left: 22px; top: 0; bottom: 0; width: 1px; background: var(--sky); }
.trail-preview-row > span { z-index: 1; width: 45px; height: 45px; display: grid; place-items: center; color: var(--forest); background: var(--base); border: 1px solid var(--sky); border-radius: 50%; font-size: 11px; font-weight: 900; }
.trail-preview-row p { margin: 8px 0 0; color: var(--muted); font-size: 14px; }
.trail-preview-row nav { display: flex; flex-wrap: wrap; align-content: start; gap: 8px 18px; }
.trail-preview-row nav a { padding-bottom: 4px; color: #276457; border-bottom: 1px solid #99b8ae; font-size: 13px; font-weight: 800; }
.trail-preview-row nav a:hover { color: var(--jade); border-color: var(--jade); }

.featured-lists > div:last-child { border-top: 1px solid var(--line); }
.featured-row { padding: 23px 0; display: grid; grid-template-columns: minmax(360px, 1fr) 110px 150px 90px; align-items: center; gap: 24px; border-bottom: 1px solid var(--line); }
.featured-row > div > span { color: var(--jade); font-size: 10px; font-weight: 900; text-transform: uppercase; }
.featured-row h3 { margin-top: 6px; font-size: 22px; }
.featured-row p { margin: 7px 0 0; color: var(--muted); font-size: 13px; }
.featured-row b, .featured-row em, .featured-row strong { font-size: 11px; font-style: normal; }
.featured-row em { color: var(--muted); }
.featured-row strong { color: var(--jade); text-align: right; text-transform: uppercase; }
.featured-row:hover h3 { color: var(--jade); }

.evidence-snapshot { display: grid; grid-template-columns: 0.7fr 1.3fr; gap: 60px; color: var(--paper); background: var(--forest); }
.evidence-snapshot h2 { color: var(--paper); }
.evidence-snapshot > div > p:not(.eyebrow) { color: #bed0c9; }
.evidence-snapshot ol { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); list-style: none; }
.evidence-snapshot li { min-height: 100px; padding: 20px; display: flex; flex-direction: column; justify-content: space-between; border-left: 1px solid #55736a; border-bottom: 1px solid #55736a; font-weight: 800; }
.evidence-snapshot li span { color: var(--sand); font-size: 11px; }

.clarity-band { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: 60px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.clarity-band > p { margin: 0; color: var(--muted); font-size: 17px; }
.match-preview nav { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--line); }
.match-preview nav a { min-height: 74px; padding: 18px 20px 18px 42px; position: relative; display: flex; align-items: center; border-bottom: 1px solid var(--line); }
.match-preview nav a:before { content: ""; position: absolute; left: 12px; width: 15px; height: 15px; border: 1px solid var(--jade); border-radius: 50%; }
.match-preview nav a:hover { color: var(--jade); background: var(--paper); }
.bottom-path { width: min(1320px, calc(100% - 48px)); margin: 0 auto 80px; padding: 40px 44px; display: flex; align-items: center; justify-content: space-between; gap: 30px; background: var(--paper); border: 1px solid var(--line); border-left: 8px solid var(--sand); box-shadow: var(--shadow); }
.bottom-path p { margin: 10px 0 0; color: var(--muted); }

.breadcrumbs { min-height: 50px; display: flex; align-items: center; gap: 8px; color: #6e776f; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.breadcrumbs a { color: var(--jade); }
.breadcrumbs a:hover { color: var(--forest); }
.page-lead { position: relative; min-height: 320px; padding: 58px 52px; display: grid; grid-template-columns: minmax(0, 1fr) 250px; align-items: center; gap: 70px; overflow: hidden; background: var(--paper); border: 1px solid var(--line); border-top: 5px solid var(--jade); box-shadow: var(--shadow); }
.page-lead:after { content: ""; position: absolute; right: -50px; bottom: -90px; width: 280px; height: 280px; border: 1px solid var(--sky); border-radius: 46% 54% 52% 48%; opacity: 0.45; }
.page-lead > div, .page-key { position: relative; z-index: 1; }
.page-lead h1 { max-width: 940px; font-size: 50px; }
.lead-copy { margin: 20px 0 0; color: var(--muted); font-size: 17px; }
.page-key { padding-left: 22px; border-left: 1px solid var(--line); }
.page-key i { width: 52px; height: 1px; margin: 14px 0; display: block; background: var(--sand); }
.page-key p { margin: 0; color: var(--muted); font-size: 13px; }

.service-trails { display: grid; gap: 0; }
.service-trail { padding: 30px 0; display: grid; grid-template-columns: 86px 0.55fr 1.25fr 80px; gap: 25px; align-items: start; border-top: 1px solid var(--line); }
.service-trail:last-child { border-bottom: 1px solid var(--line); }
.service-trail > span { color: var(--jade); font-size: 11px; font-weight: 900; text-transform: uppercase; }
.service-trail h2 { font-size: 27px; }
.service-trail p { margin: 10px 0 0; color: var(--muted); font-size: 13px; }
.service-trail nav { display: flex; flex-wrap: wrap; gap: 8px; }
.service-trail nav a { padding: 7px 9px; color: #315e53; background: rgba(255,253,247,0.7); border: 1px solid var(--line); font-size: 11px; font-weight: 800; }
.service-trail nav a:hover { color: var(--paper); background: var(--jade); border-color: var(--jade); }
.trail-jump { color: var(--jade); font-size: 11px; font-weight: 900; text-align: right; text-transform: uppercase; }

.ranked-ledger { display: grid; gap: 34px; }
.ranked-ledger-section { scroll-margin-top: 100px; }
.ledger-section-head { padding: 16px 18px; display: grid; grid-template-columns: 50px 1fr auto; align-items: center; gap: 15px; color: var(--paper); background: var(--forest); border-left: 5px solid var(--sand); }
.ledger-section-head span { color: var(--sand); font-weight: 900; }
.ledger-section-head h2 { color: var(--paper); font-size: 23px; }
.ledger-section-head b { color: #b9cec6; font-size: 10px; text-transform: uppercase; }
.ledger-row { padding: 17px 12px 17px 0; display: grid; grid-template-columns: 7px minmax(300px, 1fr) 150px 90px 130px 80px; align-items: center; gap: 16px; border-bottom: 1px solid var(--line); background: rgba(255,253,247,0.45); }
.ledger-row:nth-child(odd) { background: rgba(231,238,232,0.45); }
.ledger-dot { align-self: stretch; background: var(--sky); border-radius: 0 10px 10px 0; }
.ledger-row h3 { font-size: 17px; }
.ledger-row p { margin: 4px 0 0; overflow: hidden; color: var(--muted); font-size: 12px; text-overflow: ellipsis; white-space: nowrap; }
.ledger-row b, .ledger-row em, .ledger-row > span:not(.ledger-dot), .ledger-row strong { font-size: 10px; font-style: normal; }
.ledger-row b { color: #41675d; text-transform: uppercase; }
.ledger-row em, .ledger-row > span:not(.ledger-dot) { color: var(--muted); }
.ledger-row strong { color: var(--jade); text-align: right; text-transform: uppercase; }
.ledger-row:hover h3 { color: var(--jade); }

.ledger-layout { display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 42px; }
.ledger-index { position: sticky; top: 110px; align-self: start; padding: 24px 0; display: grid; border-top: 3px solid var(--jade); border-bottom: 1px solid var(--line); }
.ledger-index a { padding: 10px 0; color: #395a51; border-bottom: 1px solid var(--line); font-size: 12px; font-weight: 800; }
.ledger-index a:hover { color: var(--jade); }
.company-ledger-list { border-top: 1px solid var(--line); }
.company-ledger-row { padding: 28px 0; display: grid; grid-template-columns: 1.05fr 1fr 0.75fr 130px; gap: 24px; align-items: start; border-bottom: 1px solid var(--line); }
.company-ledger-row > div > span { color: var(--jade); font-size: 10px; font-weight: 900; text-transform: uppercase; }
.company-ledger-row h2 { margin-top: 8px; font-size: 25px; }
.company-ledger-row > div > p { margin: 10px 0 0; color: var(--muted); font-size: 13px; }
.company-ledger-row dl { margin: 0; display: grid; gap: 9px; }
.company-ledger-row dl div { display: grid; grid-template-columns: 105px 1fr; gap: 9px; }
.company-ledger-row dt { color: var(--muted); font-size: 10px; font-weight: 900; text-transform: uppercase; }
.company-ledger-row dd { margin: 0; font-size: 12px; line-height: 1.45; }
.company-ledger-row ul { margin: 0; padding-left: 18px; color: var(--muted); font-size: 12px; line-height: 1.55; }
.company-ledger-row > a { color: var(--jade); font-size: 11px; font-weight: 900; text-align: right; text-transform: uppercase; }

.evidence-notebook { position: relative; display: grid; gap: 0; }
.evidence-notebook:before { content: ""; position: absolute; top: 0; bottom: 0; left: 55px; width: 1px; background: var(--sky); }
.notebook-entry { position: relative; padding: 30px 0; display: grid; grid-template-columns: 110px 1fr; border-top: 1px solid var(--line); }
.notebook-entry:last-child { border-bottom: 1px solid var(--line); }
.notebook-entry > span { z-index: 1; width: 54px; height: 54px; display: grid; place-items: center; color: var(--forest); background: var(--base); border: 2px solid var(--jade); border-radius: 50%; font-weight: 900; }
.notebook-entry > div { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 40px; }
.notebook-entry h2 { font-size: 27px; }
.notebook-entry > div > p { margin: 10px 0 0; color: var(--muted); }
.notebook-entry aside { padding: 19px; background: var(--paper); border-left: 4px solid var(--sky); }
.notebook-entry aside strong { color: var(--jade); font-size: 10px; text-transform: uppercase; }
.notebook-entry aside p { margin: 8px 0 0; font-size: 13px; }
.red-entry > span { border-color: #b66a53; }
.red-entry aside { border-left-color: #b66a53; background: #fff6ef; }

.match-notes-list, .standards-list { display: grid; border-top: 1px solid var(--line); }
.match-notes-list article, .standards-list article { padding: 27px 0; display: grid; grid-template-columns: 80px 1fr; gap: 20px; border-bottom: 1px solid var(--line); }
.match-notes-list article > span, .standards-list article > span { color: var(--sand); font-size: 27px; font-weight: 900; }
.match-notes-list h2, .standards-list h2 { font-size: 27px; }
.match-notes-list p, .standards-list p { margin: 9px 0 0; color: var(--muted); }
.about-copy { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 50px; }
.about-copy article { padding: 30px 0; border-top: 1px solid var(--line); }
.about-copy h2 { font-size: 27px; }
.about-copy p { margin: 12px 0 0; color: var(--muted); }
.legal-copy { margin-top: 70px; margin-bottom: 70px; padding: 36px; background: var(--paper); border: 1px solid var(--line); border-top: 4px solid var(--sand); }
.legal-copy h2 { margin: 28px 0 10px; font-size: 26px; }
.legal-copy h2:first-child { margin-top: 0; }
.legal-copy p { color: var(--muted); }

.field-report-head, .company-summary-head { padding: 68px max(24px, calc((100% - 1320px) / 2)); display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(310px, 0.55fr); gap: 60px; align-items: start; background: var(--paper); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.field-report-head h1, .company-summary-head h1 { max-width: 900px; font-size: 52px; }
.report-intro, .company-summary-head > div > p { margin-top: 23px; color: #354e47; font-size: 17px; }
.report-key, .company-summary-head aside { padding: 26px; background: var(--base); border: 1px solid var(--line); border-top: 4px solid var(--sky); }
.company-summary-head aside dt { color: var(--jade); font-size: 10px; font-weight: 900; text-transform: uppercase; }

.match-strip ol { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); list-style: none; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.match-strip li { min-height: 150px; padding: 22px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.match-strip li span { color: var(--jade); font-size: 10px; font-weight: 900; text-transform: uppercase; }
.match-strip li strong { margin: 13px 0 8px; display: block; color: var(--forest); font-size: 18px; }
.match-strip li p { margin: 0; color: var(--muted); font-size: 13px; }

.ranked-list { display: grid; border-top: 1px solid var(--line); }
.ranked-company { display: grid; grid-template-columns: 92px 1fr; border-bottom: 1px solid var(--line); background: rgba(255,253,247,0.42); }
.ranked-company:nth-child(even) { background: rgba(231,238,232,0.38); }
.rank-marker { padding: 28px 12px; display: flex; flex-direction: column; align-items: center; border-right: 1px solid var(--line); }
.rank-marker span { color: var(--muted); font-size: 9px; font-weight: 900; text-transform: uppercase; }
.rank-marker b { margin-top: 8px; color: var(--jade); font-size: 29px; }
.company-main { padding: 28px 30px; }
.company-heading { display: flex; align-items: start; justify-content: space-between; gap: 25px; }
.company-coverage { margin: 0 0 7px; color: var(--jade); font-size: 10px; font-weight: 900; text-transform: uppercase; }
.company-heading h3 { font-size: 27px; }
.company-heading > span { max-width: 210px; padding-bottom: 4px; color: #496b62; border-bottom: 1px solid var(--sky); font-size: 10px; font-weight: 900; text-align: right; text-transform: uppercase; }
.company-main > p { margin-top: 16px; color: #40554f; }
.company-facts { margin: 20px 0; display: grid; grid-template-columns: 0.55fr 1.2fr 0.55fr; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.company-facts div { padding: 14px; border-right: 1px solid var(--line); }
.company-facts div:first-child { padding-left: 0; }
.company-facts div:last-child { border-right: 0; }
.company-facts dt { color: var(--muted); font-size: 9px; font-weight: 900; text-transform: uppercase; }
.company-facts dd { margin: 5px 0 0; font-size: 12px; line-height: 1.45; }
.service-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.service-tags span { padding: 6px 8px; color: #315e53; background: var(--mist); border: 1px solid #c7d8d0; font-size: 10px; font-weight: 800; }
.evidence-list { margin: 18px 0 0; padding-left: 18px; columns: 2; color: var(--muted); font-size: 12px; }
.evidence-list li { margin-bottom: 7px; break-inside: avoid; }

.top-notes { border-top: 1px solid var(--line); }
.top-notes > div:last-child { display: grid; grid-template-columns: repeat(3, 1fr); }
.top-notes article { padding: 24px; display: grid; grid-template-columns: 45px 1fr; gap: 12px; border-right: 1px solid var(--line); }
.top-notes article:last-child { border-right: 0; }
.top-notes article > span { color: var(--sand); font-size: 21px; font-weight: 900; }
.top-notes h3 { font-size: 19px; }
.top-notes p { margin: 8px 0 0; color: var(--muted); font-size: 13px; }
.checklist-band, .inclusion-note { display: grid; grid-template-columns: 0.65fr 1.35fr; gap: 50px; color: var(--paper); background: var(--forest); }
.checklist-band h2, .inclusion-note h2 { color: var(--paper); }
.checklist-band p, .inclusion-note > p { color: #bfd0ca; }
.checklist-band ul { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; list-style: none; }
.checklist-band li { min-height: 66px; padding: 15px 15px 15px 43px; position: relative; display: flex; align-items: center; background: #1a4b40; border: 1px solid #467267; }
.checklist-band li:before { content: ""; position: absolute; left: 15px; width: 15px; height: 15px; border: 2px solid var(--sand); border-radius: 50%; }

.table-wrap { overflow-x: auto; background: var(--paper); border: 1px solid var(--line); }
.comparison-ledger { width: 100%; min-width: 1160px; border-collapse: collapse; }
.comparison-ledger th, .comparison-ledger td { padding: 14px; text-align: left; vertical-align: top; border-bottom: 1px solid var(--line); line-height: 1.45; }
.comparison-ledger th { color: var(--paper); background: var(--forest); font-size: 10px; text-transform: uppercase; }
.comparison-ledger td { font-size: 12px; }
.comparison-ledger td a { color: var(--jade); font-weight: 900; }
.note-columns { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.note-columns article { padding: 22px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.note-columns h3 { font-size: 18px; }
.note-columns p { margin: 10px 0 0; color: var(--muted); font-size: 13px; }
.inclusion-note > p { margin: 0; }
.faq-list { display: grid; gap: 7px; }
.faq-list details { background: var(--paper); border: 1px solid var(--line); border-left: 4px solid var(--sky); }
.faq-list summary { padding: 18px 20px; color: var(--forest); font-weight: 900; cursor: pointer; }
.faq-list p { padding: 0 20px 20px; color: var(--muted); }
.nearby-trails { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.nearby-trails a { min-height: 105px; padding: 18px; display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.nearby-trails a:hover { background: var(--paper); }
.nearby-trails span { color: var(--jade); font-size: 10px; font-weight: 900; text-transform: uppercase; }

.company-sections { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 45px; }
.company-sections article { padding: 30px 0; border-top: 1px solid var(--line); }
.company-sections h2 { font-size: 27px; }
.company-sections p:not(.eyebrow) { margin-top: 12px; color: var(--muted); }
.company-sections ul { padding-left: 18px; columns: 2; color: var(--muted); line-height: 1.6; }
.placement-ledger > div:last-child { border-top: 1px solid var(--line); }
.placement-ledger a { padding: 16px 0; display: grid; grid-template-columns: 55px 1fr; gap: 12px; border-bottom: 1px solid var(--line); }
.placement-ledger a span { color: var(--jade); font-weight: 900; }
.placement-ledger a:hover strong { color: var(--jade); }

.site-footer { padding: 62px max(24px, calc((100% - 1320px) / 2)) 22px; color: #b7c8c2; background: var(--footer); }
.footer-field { display: grid; grid-template-columns: 1.5fr 0.8fr 0.8fr; gap: 55px; }
.footer-brand { color: var(--paper); }
.footer-intro p { margin-top: 18px; color: #9eb3ac; }
.footer-field nav { display: grid; align-content: start; gap: 11px; }
.footer-field nav a:hover { color: var(--paper); }
.footer-base { margin-top: 42px; padding-top: 18px; display: flex; justify-content: space-between; gap: 24px; border-top: 1px solid #345148; font-size: 11px; }

@media (max-width: 1180px) {
  h1 { font-size: 54px; }
  .header-inner { padding: 9px 0; }
  .primary-nav { flex-basis: 100%; justify-content: center; font-size: 11px; }
  .opening-field { grid-template-columns: 1fr 0.55fr; gap: 40px; }
  .compass-band { grid-template-columns: repeat(3, 1fr); }
  .compass-band div { border-bottom: 1px solid rgba(255,255,255,0.2); }
  .ledger-row { grid-template-columns: 7px minmax(280px, 1fr) 130px 80px 110px 70px; }
  .company-ledger-row { grid-template-columns: 1fr 1fr; }
  .company-ledger-row > a { text-align: left; }
}

@media (max-width: 900px) {
  .site-header { position: static; }
  .header-inner { padding: 14px 0; align-items: flex-start; flex-direction: column; }
  .primary-nav { width: 100%; flex-basis: auto; justify-content: flex-start; }
  .opening-field, .page-lead, .field-report-head, .company-summary-head, .evidence-snapshot, .clarity-band, .checklist-band, .inclusion-note { grid-template-columns: 1fr; }
  .opening-field { min-height: auto; }
  .section-heading { grid-template-columns: 1fr; }
  .section-heading > p:not(.eyebrow) { grid-column: 1; grid-row: auto; }
  .trail-preview-row { grid-template-columns: 54px 1fr; }
  .trail-preview-row nav { grid-column: 2; }
  .featured-row { grid-template-columns: 1fr 100px 130px; }
  .featured-row strong { grid-column: 1 / -1; text-align: left; }
  .service-trail { grid-template-columns: 74px 1fr; }
  .service-trail nav, .trail-jump { grid-column: 2; text-align: left; }
  .ledger-row { padding: 18px; grid-template-columns: 6px 1fr auto; }
  .ledger-row > div { grid-column: 2 / -1; }
  .ledger-row b, .ledger-row em, .ledger-row > span:not(.ledger-dot) { grid-column: 2; }
  .ledger-row strong { grid-column: 3; grid-row: 2; }
  .ledger-row p { white-space: normal; }
  .ledger-layout { grid-template-columns: 1fr; }
  .ledger-index { position: static; grid-template-columns: repeat(3, 1fr); gap: 0 18px; }
  .notebook-entry > div { grid-template-columns: 1fr; }
  .match-strip ol { grid-template-columns: repeat(2, 1fr); }
  .top-notes > div:last-child { grid-template-columns: 1fr; }
  .top-notes article { border-right: 0; border-bottom: 1px solid var(--line); }
  .company-facts { grid-template-columns: 1fr; }
  .company-facts div, .company-facts div:first-child { padding: 12px 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .company-facts div:last-child { border-bottom: 0; }
  .note-columns, .nearby-trails { grid-template-columns: repeat(2, 1fr); }
  .footer-field { grid-template-columns: repeat(2, 1fr); }
  .footer-intro { grid-column: 1 / -1; }
}

@media (max-width: 640px) {
  h1, .field-report-head h1, .company-summary-head h1 { font-size: 38px; }
  h2 { font-size: 30px; }
  .content-band, .breadcrumbs, .page-lead, .bottom-path { width: min(100% - 30px, 1320px); }
  .content-band { padding-top: 50px; padding-bottom: 50px; }
  .wide-band, .field-report-head, .company-summary-head { padding: 50px 15px; }
  .header-inner { padding-top: 10px; padding-bottom: 10px; }
  .fern-mark { width: 36px; height: 36px; }
  .primary-nav { gap: 0; font-size: 10px; }
  .primary-nav a { padding: 6px 5px; }
  .opening-field { min-height: auto; padding: 20px 15px; gap: 15px; }
  .opening-copy { padding: 6px 0; }
  .opening-copy h1 { font-size: 34px; }
  .hero-title-line { font-size: clamp(28px, 8.7vw, 34px); }
  .opening-copy > p:not(.eyebrow) { margin-top: 13px; font-size: 14px; line-height: 1.55; }
  .hero-actions { margin-top: 14px; }
  .hero-actions .text-button, .hero-actions .quiet-button { min-height: 40px; padding: 0 12px; font-size: 11px; }
  .field-card { padding: 13px 16px; }
  .field-card dl { margin-top: 8px; }
  .field-card dl div { padding: 5px 0; grid-template-columns: 84px 1fr; }
  .field-card dt { font-size: 13px; }
  .field-card dd { font-size: 11px; }
  .compass-band { padding-left: 15px; padding-right: 15px; grid-template-columns: 1fr; }
  .compass-band div { border-right: 0; }
  .trail-preview-row { grid-template-columns: 45px 1fr; gap: 16px; }
  .trail-preview-row:before { left: 18px; }
  .trail-preview-row > span { width: 38px; height: 38px; }
  .featured-row { grid-template-columns: 1fr; gap: 8px; }
  .featured-row strong { grid-column: auto; }
  .evidence-snapshot ol { grid-template-columns: repeat(2, 1fr); }
  .match-preview nav, .about-copy, .company-sections { grid-template-columns: 1fr; }
  .bottom-path { padding: 28px; align-items: flex-start; flex-direction: column; }
  .page-lead { min-height: auto; padding: 44px 24px; grid-template-columns: 1fr; gap: 30px; }
  .page-lead h1 { font-size: 36px; }
  .page-key { padding: 20px 0 0; border-left: 0; border-top: 1px solid var(--line); }
  .service-trail { grid-template-columns: 1fr; gap: 12px; }
  .service-trail nav, .trail-jump { grid-column: auto; }
  .ledger-section-head { grid-template-columns: 40px 1fr; }
  .ledger-section-head b { grid-column: 2; }
  .ledger-row { grid-template-columns: 5px 1fr; }
  .ledger-row > div, .ledger-row b, .ledger-row em, .ledger-row > span:not(.ledger-dot), .ledger-row strong { grid-column: 2; text-align: left; }
  .ledger-row strong { grid-row: auto; }
  .ledger-index { grid-template-columns: 1fr; }
  .company-ledger-row { grid-template-columns: 1fr; }
  .evidence-notebook:before { left: 26px; }
  .notebook-entry { grid-template-columns: 65px 1fr; }
  .notebook-entry > span { width: 48px; height: 48px; }
  .match-notes-list article, .standards-list article { grid-template-columns: 50px 1fr; }
  .match-strip ol, .checklist-band ul, .note-columns, .nearby-trails { grid-template-columns: 1fr; }
  .ranked-company { grid-template-columns: 1fr; }
  .rank-marker { padding: 14px 20px; flex-direction: row; justify-content: space-between; border-right: 0; border-bottom: 1px solid var(--line); }
  .rank-marker b { margin: 0; }
  .company-main { padding: 24px 20px; }
  .company-heading { flex-direction: column; }
  .company-heading > span { max-width: none; text-align: left; }
  .evidence-list, .company-sections ul { columns: 1; }
  .footer-field { grid-template-columns: 1fr; }
  .footer-intro { grid-column: auto; }
  .footer-base { flex-direction: column; }
}
