@charset "UTF-8";
/* ============================================================
   Miles Ahead — pages.css
   Component CSS for service, location, about, FAQ, and blog pages.
   Layered on top of styles.css — uses the same design tokens.
   ============================================================ */

/* RGB triplets for opacity overlays — derived from styles.css brand tokens.
   Use as: rgba(var(--accent-rgb), .X), rgba(var(--paper-hi-rgb), .X). */
:root {
  --accent-rgb:    93, 169, 233;
  --paper-hi-rgb:  251, 247, 236;
}

/* ---------- CONTENT-COLUMN GRID (shared) ----------
   Three-column grid where the middle column matches the body's content area
   (container minus its own gutter padding). Children land in column 2 via
   `grid-column: 2`, which keeps every page-element's left edge aligned. */
.breadcrumbs,
.service-hero,
.post-hero {
  display: grid;
  grid-template-columns:
    minmax(var(--gutter), 1fr)
    min(100% - 2 * var(--gutter), calc(var(--container-wide) - 2 * var(--gutter)))
    minmax(var(--gutter), 1fr);
}
.breadcrumbs > *,
.service-hero > *,
.post-hero > * { grid-column: 2; }

/* ---------- BREADCRUMBS (sits above the dark hero, shares its theme) ---------- */
.breadcrumbs {
  background: var(--brand);
  color: rgba(var(--paper-hi-rgb),.62);
  padding: clamp(7rem, 12vh, 10rem) 0 var(--s-3);
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.breadcrumbs ol {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: .5rem;
}
.breadcrumbs li { display: inline-flex; align-items: center; gap: .5rem; }
.breadcrumbs a { color: rgba(var(--paper-hi-rgb),.62); text-decoration: none; border-bottom: 1px solid transparent; transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.breadcrumbs a:hover { color: var(--paper-hi); border-bottom-color: var(--accent); }
.breadcrumbs span[aria-current] { color: var(--paper-hi); font-weight: 600; }

/* ---------- SHARED PAGE WRAPPERS ---------- */
.service-page,
.location-page,
.about-page,
.faq-page,
.index-page,
.blog-index,
.post {
  display: block;
}

/* ---------- HERO (service / location / about / faq / index / blog index) ----------
   Dark navy band that continues the breadcrumbs background — gives the fixed cream nav
   enough contrast to be visible, and frames inner-page heros with the homepage's mood.
   Layout uses the content-column grid above so children align with body sections. */
.service-hero {
  background: var(--brand);
  color: var(--paper-hi);
  padding: var(--s-3) 0 clamp(4rem, 8vh, 6rem);
  position: relative;
  isolation: isolate;
}
.service-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(55% 65% at 90% 10%, rgba(var(--accent-rgb),.18), transparent 70%),
    radial-gradient(45% 55% at 5% 95%, rgba(var(--accent-rgb),.10), transparent 70%);
  pointer-events: none;
}
.service-hero .section-no {
  color: rgba(var(--paper-hi-rgb),.72);
  border-bottom-color: rgba(var(--paper-hi-rgb),.18);
}
.service-hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-display-2);
  line-height: 1.02;
  color: var(--paper-hi);
  margin: 0 0 var(--s-5);
  letter-spacing: -0.025em;
  max-width: 22ch;
  overflow-wrap: break-word;
  hyphens: auto;
}
.service-hero__title em { color: var(--accent); font-weight: 300; }
.service-hero__lede {
  font-size: var(--fs-md);
  line-height: 1.5;
  color: rgba(var(--paper-hi-rgb),.82);
  max-width: 60ch;
  margin: 0 0 var(--s-7);
}
.service-hero__cta {
  display: flex; flex-wrap: wrap; gap: var(--s-3);
  margin: 0 0 var(--s-8);
}
/* On the navy hero, .btn--primary defaults to navy-on-navy (invisible).
   Flip to sky-blue + navy for AA contrast. */
.service-hero .btn--primary,
.post-hero .btn--primary {
  background: var(--accent);
  color: var(--brand);
  border-color: var(--accent);
}
.service-hero .btn--primary:hover,
.post-hero .btn--primary:hover {
  background: var(--paper-hi);
  color: var(--brand);
  border-color: var(--paper-hi);
}
.service-hero__cta .btn--ghost {
  color: var(--paper-hi);
  border-color: rgba(var(--paper-hi-rgb),.55);
}
.service-hero__cta .btn--ghost:hover {
  background: var(--paper-hi);
  color: var(--brand);
  border-color: var(--paper-hi);
}
.service-hero__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: var(--s-5);
  border-top: 1px solid rgba(var(--paper-hi-rgb),.18);
  padding-top: var(--s-5);
  margin: 0;
}
.service-hero__meta div { margin: 0; }
.service-hero__meta dt {
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(var(--paper-hi-rgb),.55);
  margin-bottom: .35rem;
}
.service-hero__meta dd { margin: 0; font-weight: 500; color: var(--paper-hi); }

/* ---------- TL;DR ---------- */
.tldr {
  max-width: var(--container-wide);
  margin: 0 auto var(--s-9);
  padding: var(--s-8) var(--gutter);
  background: var(--paper-2);
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
}
.tldr__heading {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  line-height: 1.05;
  margin: 0 0 var(--s-5);
  font-weight: 400;
}
.tldr__list {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--s-3);
}
.tldr__list li {
  position: relative;
  padding-left: 1.5rem;
  font-size: var(--fs-base);
  line-height: 1.5;
  color: var(--ink-soft);
}
.tldr__list li::before {
  content: "→";
  position: absolute; left: 0; top: .1rem;
  color: var(--accent);
  font-weight: 700;
}

/* ---------- SERVICE BLOCK (generic content section) ---------- */
.service-block {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: var(--s-8) var(--gutter);
}
.service-block + .service-block { padding-top: var(--s-7); }
.service-block h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  line-height: 1.05;
  margin: 0 0 var(--s-5);
  max-width: 28ch;
}
.service-block h3 {
  font-family: var(--font-label);
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-3);
  color: var(--ink);
}
.service-block p {
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 65ch;
}
.service-block__lede {
  font-size: var(--fs-md) !important;
  color: var(--ink) !important;
  margin-bottom: var(--s-6);
}
.service-block--accent {
  background: var(--brand);
  color: var(--paper);
  padding: var(--s-9) var(--gutter) !important;
  border-radius: 0;
  margin: var(--s-7) auto !important;
  max-width: var(--container-wide);
}
.service-block--accent h2 { color: var(--paper); }
.service-block--accent p { color: rgba(255,255,255,.85); }

/* ---------- CONTACT PAGE ---------- */
.contact-channels {
  list-style: none; padding: 0; margin: var(--s-5) 0 0;
  display: grid; gap: var(--s-4);
}
.contact-channels li {
  padding: var(--s-4) 0;
  border-top: 1px solid var(--rule);
}
.contact-channels li:last-child { border-bottom: 1px solid var(--rule); }
.contact-channels__label {
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0 0 .35rem;
}
.contact-channels__value {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-lg);
  margin: 0 0 .35rem;
}
.contact-channels__value a {
  color: var(--brand);
  text-decoration-color: var(--accent);
  text-underline-offset: 6px;
}
.contact-channels__note {
  font-size: var(--fs-sm);
  color: var(--mute);
  margin: 0;
}
.contact-card {
  background: var(--paper-hi);
  border: 1px solid var(--rule);
  padding: var(--s-6);
}
.contact-card__address {
  font-style: normal;
  margin: var(--s-4) 0 var(--s-5);
  line-height: 1.7;
  color: var(--ink-soft);
}
.contact-card .map-embed { margin-top: 0; }

/* ---------- 2-COLUMN SERVICE BLOCK (text + image placeholder) ---------- */
.service-block--2col {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--s-7);
  align-items: center;
}
.service-block--2col .service-block__copy h2,
.service-block--2col .service-block__copy p { max-width: 56ch; }
.service-block__media {
  background: var(--paper-2);
  aspect-ratio: 4 / 5;
  display: grid; place-items: center;
  border: 1px solid var(--rule);
  position: relative;
  overflow: hidden;
}
.service-block__media::after {
  content: "Image · 4:5";
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mute);
}
.service-block__media img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.service-block__media:has(img)::after { display: none; }
@media (max-width: 720px) {
  .service-block--2col { grid-template-columns: 1fr; gap: var(--s-6); }
  .service-block__media { aspect-ratio: 4 / 3; }
}

/* ---------- SERVICE CHECKLIST (3-column scope grid) ---------- */
.service-checklist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  gap: var(--s-6);
  margin-top: var(--s-5);
}
.service-checklist__col h3 {
  font-family: var(--font-label);
  font-size: var(--fs-sm);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--rule);
}
.service-checklist__col ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: .65rem;
}
.service-checklist__col li {
  position: relative;
  padding-left: 1.4rem;
  font-size: var(--fs-base);
  line-height: 1.5;
  color: var(--ink-soft);
}
.service-checklist__col li::before {
  content: "•";
  position: absolute; left: .25rem; top: -.05rem;
  color: var(--accent);
  font-weight: 700;
}

/* ---------- WHY US (visual cards in a responsive grid) ---------- */
.service-why {
  list-style: none; padding: 0; margin: var(--s-5) 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
  gap: var(--s-5);
  counter-reset: why;
}
.service-why li {
  background: var(--paper-hi);
  border: 1px solid var(--rule);
  border-top: 3px solid var(--accent);
  padding: var(--s-6);
  counter-increment: why;
  display: flex; flex-direction: column;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.service-why li::before {
  content: counter(why, decimal-leading-zero);
  display: block;
  font-family: var(--font-label);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: .14em;
  color: var(--accent-ink);
  margin-bottom: var(--s-4);
}
.service-why h3 {
  margin: 0 0 var(--s-3);
  color: var(--ink);
}
.service-why p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
}

/* ---------- LOCAL NOTES (3-column local data) ----------
   The wrapping section's H2 is large and the column labels are tiny,
   so this needs generous space between H2 and grid, plus internal
   padding so each column reads as a distinct zone. */
.local-notes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
  gap: var(--s-7);
  margin-top: var(--s-8);
}
.local-notes__col {
  background: var(--paper-hi);
  border: 1px solid var(--rule);
  padding: var(--s-6);
  display: flex; flex-direction: column;
}
.local-notes__col h3 {
  font-family: var(--font-label);
  font-size: var(--fs-sm);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--brand);
  margin: 0 0 var(--s-5);
  padding-bottom: var(--s-4);
  border-bottom: 2px solid var(--accent);
}
.local-notes__col p {
  font-size: var(--fs-base);
  line-height: 1.75;
  color: var(--ink-soft);
  margin: 0;
}
@media (max-width: 720px) {
  .local-notes { gap: var(--s-5); margin-top: var(--s-7); }
  .local-notes__col { padding: var(--s-5); }
}

/* ---------- MAP EMBED ---------- */
.map-embed {
  margin-top: var(--s-5);
  border: 1px solid var(--rule);
  overflow: hidden;
  border-radius: 12px;
}
.map-embed iframe { display: block; }

/* ---------- FAQ ---------- */
.faq {
  max-width: var(--container-wide);
  margin: var(--s-7) auto var(--s-9);
  padding: var(--s-9) var(--gutter);
  background: var(--paper-hi);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.faq__head { margin-bottom: var(--s-6); }
.faq__heading {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  line-height: 1.05;
  margin: 0;
}
.faq__list {
  display: grid; gap: var(--s-5);
  margin: 0;
  border-top: 1px solid var(--rule);
}
.faq__item {
  padding: var(--s-5) 0;
  border-bottom: 1px solid var(--rule);
}
.faq__q {
  font-family: var(--font-label);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 var(--s-3);
  letter-spacing: -0.01em;
}
.faq__a {
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0;
  max-width: 70ch;
}
.faq__a a { color: var(--accent-ink); }

/* ---------- RELATED ---------- */
.related {
  max-width: var(--container-wide);
  margin: 0 auto var(--s-9);
  padding: var(--s-9) var(--gutter) 0;
  border-top: 1px solid var(--rule);
}
.related__heading {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 400;
  margin-bottom: var(--s-6);
}

/* ---------- CREDS LIST (about page) ---------- */
.creds {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--s-3);
  border-top: 1px solid var(--rule);
  padding-top: var(--s-5);
}
.creds li {
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--ink-soft);
}

/* ---------- FOUNDER (about page) ---------- */
.founder {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-5);
  margin-top: var(--s-5);
}
.founder__bio { padding: 0; }
.founder__role {
  font-family: var(--font-label);
  font-size: var(--fs-sm);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mute);
  margin: -.5rem 0 var(--s-4);
}

/* ---------- TABLE OF CONTENTS (post) ---------- */
.toc {
  max-width: var(--container-wide);
  margin: 0 auto var(--s-7);
  padding: var(--s-5) var(--gutter);
  background: var(--paper-2);
  border-left: 4px solid var(--accent);
}
.toc__head {
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0 0 var(--s-3);
}
.toc ol {
  list-style: decimal-leading-zero;
  padding-left: 1.8rem;
  margin: 0;
  columns: 2;
  column-gap: var(--s-7);
}
.toc li { margin-bottom: .4rem; line-height: 1.4; break-inside: avoid; }
.toc a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--rule); }
.toc a:hover { text-decoration-color: var(--accent); }
@media (max-width: 720px) { .toc ol { columns: 1; } }

/* ---------- POST hero (same dark navy treatment as service-hero) ---------- */
.post-hero {
  background: var(--brand);
  color: var(--paper-hi);
  padding: var(--s-3) 0 clamp(4rem, 8vh, 6rem);
  position: relative;
  isolation: isolate;
}
.post-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(55% 65% at 90% 10%, rgba(var(--accent-rgb),.18), transparent 70%),
    radial-gradient(45% 55% at 5% 95%, rgba(var(--accent-rgb),.10), transparent 70%);
  pointer-events: none;
}
.post-hero .section-no {
  color: rgba(var(--paper-hi-rgb),.72);
  border-bottom-color: rgba(var(--paper-hi-rgb),.18);
}
.post-hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-display-2);
  line-height: 1.04;
  color: var(--paper-hi);
  margin: 0 0 var(--s-5);
  max-width: 24ch;
  overflow-wrap: break-word;
  hyphens: auto;
}
.post-hero__title em { color: var(--accent); font-weight: 300; }
.post-hero__lede {
  font-size: var(--fs-md);
  line-height: 1.55;
  color: rgba(var(--paper-hi-rgb),.82);
  max-width: 65ch;
  margin: 0 0 var(--s-7);
}
.post-hero__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: var(--s-5);
  border-top: 1px solid rgba(var(--paper-hi-rgb),.18);
  padding-top: var(--s-5);
  margin: 0;
}
.post-hero__meta dt {
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(var(--paper-hi-rgb),.55);
  margin-bottom: .35rem;
}
.post-hero__meta dd { margin: 0; font-weight: 500; color: var(--paper-hi); }

.post-section {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: var(--s-7) var(--gutter);
}
.post-section h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  line-height: 1.1;
  margin: var(--s-7) 0 var(--s-4);
  max-width: 30ch;
  scroll-margin-top: 4rem;
}
.post-section p,
.post-section ul,
.post-section ol {
  font-size: var(--fs-base);
  line-height: 1.7;
  color: var(--ink-soft);
  max-width: 65ch;
}
.post-section ul,
.post-section ol { padding-left: 1.4rem; }
.post-section ul li,
.post-section ol li { margin-bottom: .55rem; }
.post-section strong { color: var(--ink); }

.numbered-list {
  list-style: decimal-leading-zero;
  padding-left: 1.8rem !important;
}

/* ---------- BLOG LIST ---------- */
.blog-list {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: var(--s-8) var(--gutter) var(--s-9);
}
.blog-list__items { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--s-7); }
.blog-list__item { border-top: 1px solid var(--rule); padding-top: var(--s-6); }
.blog-list__link {
  display: grid; gap: var(--s-3);
  text-decoration: none;
  color: var(--ink);
}
.blog-list__no {
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0;
}
.blog-list__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-xl);
  line-height: 1.1;
  margin: 0;
  max-width: 28ch;
}
.blog-list__lede {
  font-size: var(--fs-md);
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
  max-width: 65ch;
}
.blog-list__meta {
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mute);
  margin: 0;
}
.blog-list__link:hover .blog-list__title {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 6px;
  text-decoration-color: var(--accent);
}

/* ---------- RESPONSIVE TIGHTEN ---------- */
@media (max-width: 720px) {
  .breadcrumbs { padding-top: clamp(5.5rem, 11vh, 8rem); }
  .service-hero, .post-hero { padding-bottom: var(--s-8); }
  .service-hero__title, .post-hero__title { font-size: clamp(2.2rem, 6vw + 1rem, 3.6rem); }
  .service-block { padding-top: var(--s-7); padding-bottom: var(--s-7); }
  .tldr, .faq { padding: var(--s-7) var(--gutter); }
  .service-block--accent { padding: var(--s-7) var(--gutter) !important; }
  .service-why li { grid-template-columns: 1fr; gap: var(--s-2); }
  .post-section { padding-top: var(--s-6); padding-bottom: var(--s-6); }
}

/* Bump CSS version when pages.css rhythm changes — match query string in head.php. */

/* ---------- FOOTER — 4-column row layout ----------
   Brand info | Services | Places | Company — all in one row.
   Uses display:contents on .site-footer__cols so its 3 navs become direct
   grid children of .site-footer__inner, making a clean 4-col grid. */
.site-footer__inner {
  grid-template-columns: 1.5fr 1fr 1fr 1fr !important;
  gap: var(--s-6) var(--s-7) !important;
  align-items: start;
}
.site-footer__cols {
  display: contents;
  border-top: none !important;
  padding-top: 0 !important;
}
.site-footer__cols nav {
  padding: 0;
  border: none;
}
.site-footer__colophon {
  grid-column: 1 / -1;
}
@media (max-width: 900px) {
  .site-footer__inner {
    grid-template-columns: 1fr 1fr !important;
    gap: var(--s-5) var(--s-6) !important;
  }
  .site-footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) {
  .site-footer__inner { grid-template-columns: 1fr !important; }
}

/* ---------- FOOTER COLOPHON — split layout (legal left, credit right) ---------- */
.site-footer__colophon {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3) var(--s-5);
}
.site-footer__legal { flex: 0 1 auto; }
.site-footer__credit {
  flex: 0 1 auto;
  font-size: var(--fs-xs);
  letter-spacing: .04em;
  color: rgba(var(--paper-hi-rgb), .85);
}
.site-footer__credit a { color: rgba(var(--paper-hi-rgb), .95); }
.site-footer__credit a:hover { color: var(--accent); }
@media (max-width: 720px) {
  .site-footer__colophon {
    justify-content: center;
    text-align: center;
  }
}
.site-footer__credit a {
  color: inherit;
  text-decoration-color: rgba(var(--paper-hi-rgb), .35);
  text-underline-offset: 3px;
}
.site-footer__credit a:hover {
  color: var(--accent);
  text-decoration-color: var(--accent);
}

/* ---------- MID-PAGE CTA STRIP ----------
   Full-width navy band with heading + sub + two buttons. Injected mid-scroll
   on long pages so users don't have to bounce to the hero or bottom to act. */
.cta-strip {
  background: var(--brand);
  color: var(--paper-hi);
  padding: var(--s-8) var(--gutter);
  margin: var(--s-8) 0;
  text-align: center;
  position: relative;
  isolation: isolate;
}
.cta-strip::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(50% 60% at 85% 20%, rgba(var(--accent-rgb),.16), transparent 70%),
    radial-gradient(40% 50% at 15% 90%, rgba(var(--accent-rgb),.10), transparent 70%);
  pointer-events: none;
}
.cta-strip__inner {
  max-width: 56rem;
  margin: 0 auto;
}
.cta-strip__head {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-lg);
  line-height: 1.15;
  color: var(--paper-hi);
  margin: 0 0 var(--s-3);
  letter-spacing: -0.02em;
}
.cta-strip__head em { color: var(--accent); font-weight: 300; }
.cta-strip__sub {
  font-size: var(--fs-base);
  line-height: 1.5;
  color: rgba(var(--paper-hi-rgb),.82);
  margin: 0 0 var(--s-5);
  max-width: 42ch;
  margin-inline: auto;
}
.cta-strip__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  justify-content: center;
}
.cta-strip .btn--primary {
  background: var(--accent);
  color: var(--brand);
  border-color: var(--accent);
}
.cta-strip .btn--primary:hover {
  background: var(--paper-hi);
  color: var(--brand);
  border-color: var(--paper-hi);
}
.cta-strip .btn--ghost {
  color: var(--paper-hi);
  border-color: rgba(var(--paper-hi-rgb),.55);
}
.cta-strip .btn--ghost:hover {
  background: var(--paper-hi);
  color: var(--brand);
  border-color: var(--paper-hi);
}

/* ---------- PAGE FEATURE FIGURE — sits between hero and TLDR/first content section ----------
   Sized as a contained 16:10 band so portrait photos don't dominate the viewport.
   The inline aspect-ratio on each figure is kept for data fidelity but overridden
   here so every page has a consistent, modest visual rhythm. Object-fit cover
   crops portraits sensibly with the subject centered. */
.page-feature {
  max-width: min(64rem, calc(100% - 2 * var(--gutter))) !important;
  margin: var(--s-7) auto var(--s-8) !important;
  padding: 0 !important;
  aspect-ratio: 16 / 10 !important;
  position: relative;
  border: 1px solid var(--rule);
  overflow: hidden;
  background: var(--paper-2);
}
.page-feature picture,
.page-feature img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border: 0;
}
@media (max-width: 720px) {
  .page-feature { margin: var(--s-6) auto var(--s-7) !important; aspect-ratio: 4 / 3 !important; }
}

/* ---------- HOMEPAGE LEDE — image figure beneath the body copy ---------- */
.lede__media {
  margin: var(--s-6) 0 0;
  padding: 0;
  border: 1px solid var(--rule);
  background: var(--paper-2);
  overflow: hidden;
  position: relative;
}
.lede__media picture,
.lede__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}

/* ---------- NAV DROPDOWN ---------- */
.nav-menu .has-sub { position: relative; }

.nav-menu__sub {
  position: absolute;
  top: 100%; left: 0;
  margin: 0; padding: var(--s-3) 0;
  list-style: none;
  background: var(--paper-hi);
  color: var(--ink);
  border: 1px solid var(--rule);
  border-top: 3px solid var(--accent);
  box-shadow: 0 12px 32px rgba(11,31,59,.18);
  min-width: 18rem;
  z-index: 60;

  /* Closed by default — animate to open */
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s var(--dur) linear;
}
.nav-menu .has-sub:hover > .nav-menu__sub,
.nav-menu .has-sub:focus-within > .nav-menu__sub {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility 0s linear;
}

.nav-menu__sub li { display: block; }
.nav-menu__sub a {
  display: flex; align-items: baseline; gap: .55rem;
  padding: .55rem 1.25rem;
  min-height: auto;
  font-family: var(--font-label);
  font-size: var(--fs-xs);
  letter-spacing: .1em;
  font-weight: 500;
  color: var(--ink-soft);
  text-decoration: none;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.nav-menu__sub a::after { display: none !important; }
.nav-menu__sub a:hover {
  background: var(--paper-2);
  color: var(--brand);
}
.nav-menu__sub-no {
  font-size: .58rem;
  opacity: .6;
  letter-spacing: .18em;
  min-width: 1.4rem;
}
.nav-menu__sub-foot {
  border-top: 1px solid var(--rule);
  margin-top: var(--s-2);
  padding-top: var(--s-2);
}
.nav-menu__sub-foot a { color: var(--accent-ink); font-weight: 600; }

/* 2-column variant for the long Places list */
.nav-menu__sub--cols {
  min-width: 28rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
}
.nav-menu__sub--cols .nav-menu__sub-foot {
  grid-column: 1 / -1;
}

/* Mobile: dropdowns expand inline (no hover state on touch).
   Breakpoint must match the nav-mobile breakpoint in styles.css (60rem) —
   they got out of sync (900px vs 60rem/960px) and produced a 60px-wide
   broken layout band where desktop nav showed inline-expanded submenus. */
@media (max-width: 60rem) {
  .nav-menu__sub {
    position: static;
    opacity: 1; visibility: visible; transform: none; pointer-events: auto;
    box-shadow: none; border: none; border-left: 2px solid var(--accent);
    background: transparent; color: inherit;
    padding: var(--s-2) 0 var(--s-3) var(--s-3);
    min-width: 0;
    transition: none;
  }
  .nav-menu__sub--cols { grid-template-columns: 1fr; }
  .nav-menu__sub a { color: inherit; padding: .5rem .75rem; }
  .nav-menu__sub a:hover { background: rgba(255,255,255,.08); }
  .nav-menu__sub-foot a { color: var(--accent); }
}
