@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 400 500;
  font-display: swap;
  src: url('assets/fonts/fraunces-italic-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 400 500;
  font-display: swap;
  src: url('assets/fonts/fraunces-italic-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('assets/fonts/fraunces-normal-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('assets/fonts/fraunces-normal-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('assets/fonts/manrope-normal-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('assets/fonts/manrope-normal-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ════════════════════════════════════════════════════════════════
   FALLBACK FONT METRICS — prevent layout shift (CLS) when the web
   fonts swap in. The size-adjust/metric overrides make the system
   fallback occupy the same line-box as Fraunces / Manrope, so the
   swap is invisible to layout instead of reflowing the hero.
   ════════════════════════════════════════════════════════════════ */
@font-face {
  font-family: 'Fraunces Fallback';
  src: local('Georgia');
  size-adjust: 102%;
  ascent-override: 92%;
  descent-override: 26%;
  line-gap-override: 0%;
}
@font-face {
  font-family: 'Manrope Fallback';
  src: local('Arial');
  size-adjust: 100%;
  ascent-override: 100%;
  descent-override: 26%;
  line-gap-override: 0%;
}

/* ════════════════════════════════════════════════════════════════
   DESIGN TOKENS — NYSIDI v13
   ════════════════════════════════════════════════════════════════ */
:root {
  --charcoal:    #14171a;
  --slate:       #1f2428;
  --slate-2:     #272d31;
  --ink:         #1a1e21;
  --bone:        #eef1ed;
  --bone-2:      #e6e9e3;
  --ivory:       #f5f1e8;
  --cream:       #e6e0d2;
  --mist:        #889089;
  --mist-soft:   #aab2ad;
  --accent:        #5b8def;
  --accent-deep:   #1d3f8f;
  --rule-dark:   rgba(238, 241, 237, 0.14);
  --rule-dark-2: rgba(238, 241, 237, 0.28);
  --rule-light:  rgba(26, 30, 33, 0.16);

  --fs-eyebrow:  0.72rem;
  --fs-body:     clamp(1rem, 0.96rem + 0.2vw, 1.1rem);
  --fs-lead:     clamp(1.2rem, 1.05rem + 0.7vw, 1.62rem);
  --fs-h3:       clamp(1.35rem, 1.15rem + 0.8vw, 1.85rem);
  --fs-h2:       clamp(2.1rem, 1.6rem + 2.2vw, 3.6rem);
  --fs-h1:       clamp(2.6rem, 1.7rem + 4vw, 5.4rem);
  --fs-numeral:  clamp(3.5rem, 2rem + 7vw, 9rem);

  --container:   75rem;
  --container-wide: 84rem;
  --gutter:      clamp(1.25rem, 4vw, 4.25rem);
  --section-pad: clamp(4.5rem, 8vw, 9.5rem);

  --ease:        cubic-bezier(0.22, 1, 0.36, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
body {
  font-family: 'Manrope', 'Manrope Fallback', system-ui, -apple-system, sans-serif;
  font-size: var(--fs-body);
  line-height: 1.62;
  color: var(--ink);
  background: var(--bone);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
::selection { background: var(--accent); color: var(--charcoal); }

.serif { font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif; }
.mono  { font-family: 'Manrope', 'Manrope Fallback', sans-serif; }

.eyebrow {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: var(--fs-eyebrow);
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--accent-deep);
}

h1, h2, h3 { font-family: 'Fraunces', Georgia, serif; font-weight: 400; line-height: 1.07; }
h2 { font-size: var(--fs-h2); letter-spacing: -0.018em; }
h3 { font-size: var(--fs-h3); letter-spacing: -0.012em; line-height: 1.16; }
.lead {
  font-size: var(--fs-lead);
  line-height: 1.48;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  color: var(--ink);
}
em, .italic { font-style: italic; }

/* ── the document spine: oversized index numerals ── */
.article-mark {
  display: flex;
  align-items: baseline;
  gap: 1.1rem;
  margin-bottom: clamp(1.6rem, 3vw, 2.6rem);
}
.article-mark .numeral {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: var(--fs-numeral);
  font-weight: 400;
  line-height: 0.8;
  color: var(--accent-deep);
  letter-spacing: -0.03em;
}
.article-mark .label {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: var(--fs-eyebrow);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mist);
  padding-bottom: 0.4em;
}
.article-mark .label .title {
  display: block;
  color: var(--ink);
  font-size: 0.84rem;
  letter-spacing: 0.04em;
  text-transform: none;
  font-weight: 500;
  margin-top: 0.35em;
}
.article-mark--ondark .numeral { color: var(--accent); }
.article-mark--ondark .label { color: var(--mist-soft); }
.article-mark--ondark .label .title { color: var(--bone); }

.wrap { max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.wrap--wide { max-width: var(--container-wide); }
.section { padding-block: var(--section-pad); }

/* ── buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 1.05em 1.9em;
  border: 1px solid var(--ink);
  color: var(--ink);
  background: transparent;
  transition: background 0.4s var(--ease), color 0.4s var(--ease), border-color 0.4s var(--ease);
}
.btn:hover { background: var(--ink); color: var(--bone); }
.btn .arrow { transition: transform 0.4s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }
.btn--ondark { border-color: var(--rule-dark-2); color: var(--bone); }
.btn--ondark:hover { background: var(--bone); color: var(--charcoal); border-color: var(--bone); }
.btn--solid { background: var(--charcoal); color: var(--bone); border-color: var(--charcoal); }
.btn--solid:hover { background: transparent; color: var(--charcoal); }

.link-rule {
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.83rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding-bottom: 0.35em;
  border-bottom: 1px solid currentColor;
  transition: gap 0.35s var(--ease);
}
.link-rule:hover { gap: 1em; }
.link-rule .arrow { transition: transform 0.35s var(--ease); }
.link-rule:hover .arrow { transform: translateX(3px); }
/* Guarantee a 44px touch target on mobile (Apple HIG / Material baseline) */
@media (max-width: 760px) { .link-rule { min-height: 44px; } }

/* ── header ── */
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--charcoal);
  border-bottom: 1px solid var(--rule-dark);
}
.header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
  max-width: var(--container-wide);
  margin-inline: auto;
  padding: 0.9rem var(--gutter);
}
.header__nav {
  display: flex;
  gap: 1.9rem;
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.77rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.header__nav--right { justify-content: flex-end; }
.header__nav a {
  color: var(--mist-soft);
  padding-block: 0.4em;
  border-bottom: 1px solid transparent;
  transition: color 0.3s, border-color 0.3s;
}
.header__nav a:hover { color: var(--bone); border-bottom-color: var(--accent); }
.header__nav a .idx {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.62rem;
  color: var(--accent);
  margin-right: 0.5em;
}
.header__brand { display: flex; align-items: center; gap: 0.7rem; }
.header__brand img { height: 30px; width: auto; }
.header__brand .lockup { display: flex; flex-direction: column; gap: 0.12rem; }
.header__brand .wordmark {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: 1.16rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-indent: 0.3em;
  color: var(--bone);
  line-height: 1;
}
.header__brand .sub {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.54rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mist);
}
.nav-toggle { display: none; }
.mobile-menu { display: none; }

@media (max-width: 900px) {
  .header__inner { grid-template-columns: auto 1fr; }
  .header__nav { display: none; }
  .nav-toggle {
    display: flex; flex-direction: column; gap: 5px;
    justify-self: end; padding: 0.5rem;
  }
  .nav-toggle span {
    width: 26px; height: 1.5px; background: var(--bone);
    transition: transform 0.3s, opacity 0.3s;
  }
  .mobile-menu {
    display: flex; position: fixed; inset: 0;
    background: var(--charcoal); z-index: 200;
    flex-direction: column; justify-content: center;
    gap: 1.3rem; padding: var(--gutter);
    transform: translateY(-100%);
    transition: transform 0.5s var(--ease);
  }
  .mobile-menu.open { transform: translateY(0); }
  .mobile-menu a {
    font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif; font-size: 2rem; color: var(--bone);
    display: flex; align-items: baseline; gap: 1rem;
  }
  .mobile-menu a .idx {
    font-family: 'Manrope', 'Manrope Fallback', sans-serif;
    font-size: 0.8rem; color: var(--accent);
  }
  .mobile-menu__close {
    position: absolute; top: 1.3rem; right: var(--gutter);
    color: var(--bone); font-size: 2rem; line-height: 1;
  }
}

/* ── hero ── */
.hero {
  background: var(--charcoal);
  color: var(--bone);
  padding-block: clamp(3rem, 6vw, 5.5rem) clamp(3.5rem, 7vw, 6rem);
  position: relative;
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0;
  z-index: 0;
}
.hero__bg img {
  width: 100%; height: 100%; object-fit: cover;
  object-position: 60% 42%;
  opacity: 0.9;
  filter: contrast(1.03) saturate(1.02);
}
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(18,21,23,0.85) 0%, rgba(18,21,23,0.55) 32%, rgba(18,21,23,0.12) 62%, rgba(18,21,23,0.05) 100%),
    linear-gradient(180deg, rgba(18,21,23,0.30) 0%, rgba(18,21,23,0) 40%, rgba(18,21,23,0.45) 100%);
}
@media (max-width: 720px) {
  .hero__bg::after {
    background:
      linear-gradient(180deg,
        rgba(18,21,23,0.60) 0%,
        rgba(18,21,23,0.26) 20%,
        rgba(18,21,23,0.08) 40%,
        rgba(18,21,23,0.42) 56%,
        rgba(18,21,23,0.92) 100%);
  }
}
.hero .wrap { position: relative; z-index: 1; }
/* a single quiet line of standing — pride without badge-art */
.hero__credential {
  margin-bottom: clamp(2.4rem, 5vw, 4rem);
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--mist-soft);
  max-width: 52ch;
  line-height: 1.7;
}
.hero__credential .accent { color: var(--accent); }
.hero__statement {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-weight: 400;
  font-size: var(--fs-h1);
  line-height: 1.05;
  letter-spacing: -0.022em;
  max-width: 15ch;
}
.hero__statement em { font-style: italic; color: var(--accent); }
.hero__base {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: clamp(1.8rem, 5vw, 4.5rem);
  align-items: end;
  margin-top: clamp(2.8rem, 6vw, 4.8rem);
  padding-top: 2.2rem;
  border-top: 1px solid var(--rule-dark);
}
.hero__summary {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: clamp(1.08rem, 1rem + 0.45vw, 1.34rem);
  line-height: 1.48;
  color: var(--mist-soft);
  max-width: 42ch;
}
.hero__summary strong { color: var(--bone); font-weight: 500; }
.hero__cta-col { display: flex; flex-direction: column; gap: 0.8rem; }
.hero__cta-col .btn { justify-content: space-between; }
@media (max-width: 720px) {
  .hero__base { grid-template-columns: 1fr; gap: 2rem; align-items: start; }
  .hero__cta-col { width: 100%; }
  /* Reserve line-box height so the Fraunces swap can't reflow the
     headline and push the summary / CTA column down (kills mobile CLS). */
  .hero__statement { min-height: 4.2em; }
}

/* ── capabilities rank ── */
.rank {
  background: var(--slate);
  color: var(--bone);
  border-top: 1px solid var(--rule-dark);
}
/* The .rank band is full-bleed dark and is the last child of its light section;
   drop that section's bottom padding so the band meets the next section cleanly
   instead of leaving an empty light gap below it. */
.section:has(.rank) { padding-bottom: 0; }
.rank__inner {
  max-width: var(--container-wide);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
.rank__item {
  padding: clamp(2.2rem, 4vw, 3.4rem) clamp(1.3rem, 2.5vw, 2.3rem);
  border-right: 1px solid var(--rule-dark);
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  transition: background 0.4s var(--ease);
}
.rank__item:last-child { border-right: none; }
.rank__item:hover { background: var(--charcoal); }
.rank__item .num {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.07em;
  color: var(--accent);
}
.rank__item h3 { font-size: 1.16rem; line-height: 1.18; color: var(--bone); }
.rank__item p { font-size: 0.85rem; color: var(--mist-soft); line-height: 1.5; }
@media (max-width: 760px) {
  .rank__inner { grid-template-columns: repeat(2, 1fr); }
  .rank__item:nth-child(2) { border-right: none; }
  .rank__item:nth-child(1), .rank__item:nth-child(2) {
    border-bottom: 1px solid var(--rule-dark);
  }
}

/* ── Article I — positioning ── */
.positioning { background: var(--bone); }
.positioning__grid {
  display: grid;
  grid-template-columns: 0.85fr 1.4fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: start;
}
.positioning__aside { position: sticky; top: 7rem; }
.positioning__aside h2 { font-size: var(--fs-h3); line-height: 1.18; margin-top: 0.4rem; }
.positioning__body p { margin-bottom: 1.45rem; }
.positioning__body p:last-of-type { margin-bottom: 0; }
.positioning__body .lead { margin-bottom: 2rem; }
.positioning__body strong { font-weight: 600; color: var(--ink); }
.origin-note {
  margin-top: 2.8rem;
  padding: 1.8rem 2rem;
  background: var(--ivory);
  border-left: 2px solid var(--accent-deep);
}
.origin-note .label {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--accent-deep);
  display: block;
  margin-bottom: 0.7rem;
}
.origin-note p { font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif; font-size: 1.06rem; line-height: 1.5; margin-bottom: 0; }
@media (max-width: 820px) {
  .positioning__grid { grid-template-columns: 1fr; gap: 2.4rem; }
  .positioning__aside { position: static; }
}

/* ── Article II — the record ── */
.record { background: var(--cream); }
.record__head { margin-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.record__head p { max-width: 44ch; margin-top: 0.4rem; color: var(--ink); opacity: 0.78; }
.record__grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--rule-light); }
.record__cell {
  padding: clamp(1.8rem, 3vw, 2.6rem) 0;
  border-bottom: 1px solid var(--rule-light);
  border-right: 1px solid var(--rule-light);
  padding-left: clamp(1rem, 2vw, 1.8rem);
  padding-right: 1.5rem;
}
.record__cell:nth-child(4n) { border-right: none; }
.record__cell:nth-child(4n+1) { padding-left: 0; }
.record__cell .figure {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: clamp(2.4rem, 1.6rem + 3vw, 4rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 0.7rem;
}
.record__cell .figure span { color: var(--accent-deep); }
.record__cell .caption {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0.62;
  line-height: 1.5;
}
.record__note {
  margin-top: 1.6rem;
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.66rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent-deep);
}
@media (max-width: 720px) {
  .record__grid { grid-template-columns: 1fr 1fr; }
  .record__cell:nth-child(2n) { border-right: none; }
  .record__cell:nth-child(2n+1) { padding-left: 0; }
}

/* ── Article III — divisions ── */
.divisions { background: var(--charcoal); color: var(--bone); }
.divisions__head {
  max-width: var(--container);
  margin-inline: auto;
  padding: var(--section-pad) var(--gutter) clamp(2.8rem, 5vw, 4.5rem);
}
.divisions__head h2 { color: var(--bone); max-width: 17ch; }
.divisions__head p { color: var(--mist-soft); max-width: 50ch; margin-top: 1.5rem; font-size: 1.04rem; }
.division { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--rule-dark); }
.division:last-child { border-bottom: 1px solid var(--rule-dark); }
.division__photo {
  position: relative;
  min-height: clamp(24rem, 44vw, 38rem);
  background: var(--slate);
  overflow: hidden;
}
.division__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.photo-slot {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 0.55rem; text-align: center; padding: 2rem;
  background: repeating-linear-gradient(135deg, var(--slate), var(--slate) 24px, #242a2e 24px, #242a2e 48px);
}
.photo-slot .mono {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.7rem; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--mist);
}
.photo-slot .slot-title {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif; font-size: 1.06rem; color: var(--mist-soft); max-width: 22ch;
}
.division__chapter {
  position: absolute;
  top: 0; left: 0;
  display: flex; align-items: baseline; gap: 0.8rem;
  padding: 1.3rem 1.6rem;
  background: var(--charcoal);
  border-right: 1px solid var(--rule-dark);
  border-bottom: 1px solid var(--rule-dark);
}
.division__chapter .ch-num { font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif; font-size: 1.7rem; line-height: 1; color: var(--accent); }
.division__chapter .ch-label {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--mist-soft);
}
.division__body {
  padding: clamp(2.8rem, 5vw, 5rem) clamp(1.6rem, 4vw, 4.25rem);
  display: flex; flex-direction: column; justify-content: center;
}
.division__body h3 {
  font-size: clamp(1.8rem, 1.3rem + 1.8vw, 2.7rem);
  color: var(--bone);
  margin-bottom: 1rem;
}
.division__body .audience {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-style: italic;
  font-size: 1.14rem;
  color: var(--accent);
  margin-bottom: 1.6rem;
  padding-bottom: 1.6rem;
  border-bottom: 1px solid var(--rule-dark);
}
.division__body p { color: var(--mist-soft); font-size: 0.99rem; margin-bottom: 1.7rem; }
.division__list { list-style: none; margin-bottom: 2.1rem; }
.division__list li {
  padding: 0.9rem 0;
  border-bottom: 1px solid var(--rule-dark);
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.91rem;
  color: var(--bone);
  display: flex; gap: 1rem;
}
.division__list li:first-child { border-top: 1px solid var(--rule-dark); }
.division__list li .mono {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.7rem; color: var(--accent); padding-top: 0.2em;
}
.division__body .link-rule { color: var(--bone); align-self: flex-start; }
.division__body .link-rule:hover { color: var(--accent); }
.division--flip .division__photo { order: 2; }
.division--flip .division__chapter { left: auto; right: 0; border-right: none; border-left: 1px solid var(--rule-dark); }
@media (max-width: 820px) {
  .division, .division--flip { grid-template-columns: 1fr; }
  .division--flip .division__photo { order: 0; }
  .division__photo { min-height: 17rem; }
}

/* ── Article IV — credentials ── */
.credentials { background: var(--bone-2); }
.credentials__head { max-width: 50ch; margin-bottom: clamp(2.4rem, 4vw, 3.6rem); }
.credentials__head p {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.9rem);
  line-height: 1.34;
  color: var(--ink);
  margin-top: 0.3rem;
}
.credentials__list { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--rule-light); }
.cred {
  padding: clamp(1.7rem, 3vw, 2.4rem) clamp(1.3rem, 2vw, 1.9rem);
  padding-left: 0;
  border-right: 1px solid var(--rule-light);
  border-bottom: 1px solid var(--rule-light);
}
.cred:not(:first-child) { padding-left: clamp(1.3rem, 2vw, 1.9rem); }
.cred:last-child { border-right: none; }
.cred .code {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.06em;
  color: var(--accent-deep);
  display: block;
  margin-bottom: 0.9rem;
}
.cred h3 {
  font-size: 1.04rem;
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin-bottom: 0.5rem;
  line-height: 1.3;
}
.cred p { font-size: 0.83rem; color: var(--ink); opacity: 0.7; line-height: 1.5; }
@media (max-width: 760px) {
  .credentials__list { grid-template-columns: 1fr 1fr; }
  .cred:nth-child(2n) { border-right: none; }
  .cred:nth-child(2n+1):not(:first-child) { padding-left: 0; }
}
@media (max-width: 420px) {
  .credentials__list { grid-template-columns: 1fr; }
  .cred { border-right: none; padding-left: 0 !important; }
}

/* ── Article V — leadership ── */
.leadership { background: var(--slate); color: var(--bone); padding-block: var(--section-pad); }
.leadership__grid {
  display: grid;
  grid-template-columns: 0.7fr 1fr;
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.leadership__figure { position: relative; max-width: 24rem; }
.leadership__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--bone);
  padding: 0.55rem;
  box-shadow: 0 24px 60px -28px rgba(0,0,0,0.7);
}
.leadership__photo img {
  position: absolute;
  inset: 0.55rem;
  width: calc(100% - 1.1rem); height: calc(100% - 1.1rem);
  object-fit: cover; object-position: center 24%;
}
.leadership__plate {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding-top: 1.4rem;
  margin-top: 1.4rem;
  border-top: 2px solid var(--accent);
}
.leadership__plate .name {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: 1.45rem;
  line-height: 1.1;
  color: var(--bone);
}
.leadership__plate .role {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
}
.leadership__body { display: flex; flex-direction: column; justify-content: center; }
.leadership__body .article-mark { margin-bottom: 1.6rem; }
.leadership__body h2 { color: var(--bone); margin-bottom: 1.8rem; max-width: 18ch; }
.leadership__quote {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-style: italic;
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.85rem);
  line-height: 1.42;
  color: var(--bone);
  padding-left: 1.6rem;
  border-left: 2px solid var(--accent);
  margin: 0 0 1.9rem;
  max-width: 32ch;
}
.leadership__body p { color: var(--mist-soft); margin-bottom: 1.8rem; max-width: 46ch; }
.leadership__body .link-rule { color: var(--bone); align-self: flex-start; }
.leadership__body .link-rule:hover { color: var(--accent); }
@media (max-width: 860px) {
  .leadership__grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .leadership__photo { aspect-ratio: 4 / 5; }
  .leadership__figure { max-width: 17rem; margin-inline: auto; width: 100%; }
  .leadership__plate { align-items: center; text-align: center; }
}

/* ── Article VI — selected work ── */
.projects { background: var(--bone); }
.projects__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  margin-bottom: clamp(2.4rem, 5vw, 3.8rem);
  flex-wrap: wrap;
}
.projects__head h2 { margin-top: 0.3rem; }
.projects__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.2vw, 1.7rem); }
.project-card { background: var(--charcoal); }
.project-card__photo {
  position: relative;
  aspect-ratio: 4 / 3.2;
  overflow: hidden;
  background: var(--charcoal);
}
.project-card__photo img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.7s var(--ease);
}
.project-card:hover .project-card__photo img { transform: scale(1.04); }
.project-card__photo .photo-slot {
  background: repeating-linear-gradient(135deg, var(--charcoal), var(--charcoal) 20px, #1d2225 20px, #1d2225 40px);
}
.project-card__photo .ref {
  position: absolute; top: 0; left: 0;
  padding: 0.6rem 0.9rem;
  background: var(--charcoal);
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.62rem; letter-spacing: 0.06em;
  color: var(--accent);
}
.project-card__meta { padding: 1.4rem 1.5rem 1.6rem; }
.project-card__meta .tag {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.66rem; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--accent);
  display: block;
  margin-bottom: 0.7rem;
}
.project-card__meta h3 { font-size: 1.12rem; color: var(--bone); margin-bottom: 0.4rem; }
.project-card__meta p { font-size: 0.81rem; color: var(--mist); }
@media (max-width: 820px) { .projects__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .projects__grid { grid-template-columns: 1fr; } }

/* ── Article VII — engagement ── */
.engagement { background: var(--ivory); }
.engagement__grid {
  display: grid;
  grid-template-columns: 0.85fr 1.4fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: start;
}
.engagement__aside { position: sticky; top: 7rem; }
.engagement__aside h2 { font-size: var(--fs-h3); line-height: 1.18; margin-top: 0.4rem; }
.engagement__aside p { margin-top: 1rem; font-size: 0.92rem; color: var(--ink); opacity: 0.74; }
.engagement__steps { list-style: none; }
.engagement__steps li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1.2rem, 3vw, 2.4rem);
  padding: clamp(1.6rem, 3vw, 2.3rem) 0;
  border-top: 1px solid var(--rule-light);
}
.engagement__steps li:last-child { border-bottom: 1px solid var(--rule-light); }
.engagement__steps .step-num {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: clamp(1.8rem, 1.3rem + 1.5vw, 2.6rem);
  line-height: 0.9;
  color: var(--accent-deep);
}
.engagement__steps .step-body h3 { font-size: 1.18rem; margin-bottom: 0.5rem; }
.engagement__steps .step-body p { font-size: 0.94rem; color: var(--ink); opacity: 0.8; }
@media (max-width: 820px) {
  .engagement__grid { grid-template-columns: 1fr; gap: 2.2rem; }
  .engagement__aside { position: static; }
}

/* ── testimonials ── */
.testimonials { background: var(--charcoal); color: var(--bone); }
.testimonials__head { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.testimonials__head h2 { font-size: var(--fs-h2); line-height: 1.06; margin-top: 0.6rem; max-width: 16ch; }
.testimonial { margin: 0; }
.testimonial blockquote { margin: 0; }
.testimonial--feature {
  border-top: 1px solid var(--rule-dark-2);
  padding-top: clamp(1.8rem, 3.5vw, 2.8rem);
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
  max-width: 72ch;
}
.testimonial--feature blockquote p {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: clamp(1.08rem, 0.92rem + 0.75vw, 1.55rem);
  line-height: 1.5;
  color: var(--bone);
  margin-bottom: 1rem;
  text-wrap: pretty;
}
.testimonial--feature blockquote p:last-child { margin-bottom: 0; }
.testimonials__pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4.5rem);
}
.testimonials__pair--trio {
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.5rem, 3vw, 3rem);
}
@media (max-width: 1000px) and (min-width: 761px) {
  .testimonials__pair--trio { grid-template-columns: repeat(2, 1fr); }
}
.testimonials__pair .testimonial {
  border-top: 1px solid var(--rule-dark);
  padding-top: 1.6rem;
}
.testimonials__pair blockquote p {
  font-size: 1.02rem;
  line-height: 1.72;
  color: var(--mist-soft);
}
.testimonial figcaption {
  margin-top: 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.testimonial .cite-name {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.01em;
  color: var(--bone);
}
.testimonial .cite-detail {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent);
}
@media (max-width: 760px) {
  .testimonials__pair { grid-template-columns: 1fr; gap: 2.2rem; }
}

/* ── faq ── */
.faq { background: var(--bone); }
.faq__head { margin-bottom: clamp(2rem, 4vw, 3.2rem); }
.faq__head h2 { font-size: var(--fs-h2); line-height: 1.08; margin-top: 0.5rem; max-width: 14ch; }
.faq__list { border-top: 1px solid var(--rule-light); }
.faq__item { border-bottom: 1px solid var(--rule-light); }
.faq__item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1.5rem;
  padding: clamp(1.3rem, 2.4vw, 1.9rem) 0;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__q {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: clamp(1.12rem, 0.95rem + 0.7vw, 1.5rem);
  line-height: 1.3;
  color: var(--charcoal);
  font-weight: 500;
}
.faq__icon { position: relative; flex: 0 0 auto; width: 16px; height: 16px; margin-top: 0.35rem; }
.faq__icon::before, .faq__icon::after {
  content: ""; position: absolute; background: var(--accent-deep);
  transition: transform 0.28s ease, opacity 0.28s ease;
}
.faq__icon::before { top: 7px; left: 0; width: 16px; height: 2px; }
.faq__icon::after  { left: 7px; top: 0; width: 2px; height: 16px; }
.faq__item[open] .faq__icon::after { transform: scaleY(0); opacity: 0; }
.faq__item summary:hover .faq__q { color: var(--accent-deep); }
.faq__a {
  padding-bottom: clamp(1.3rem, 2.4vw, 1.9rem);
  max-width: 62ch;
}
.faq__a p { font-size: 0.96rem; line-height: 1.7; color: var(--ink); opacity: 0.82; }
.faq__item summary:focus-visible {
  outline: 2px solid var(--accent-deep);
  outline-offset: 4px;
  border-radius: 2px;
}
@media (min-width: 900px) {
  .faq .wrap { display: grid; grid-template-columns: 0.7fr 1.5fr; gap: clamp(2rem, 6vw, 6rem); align-items: start; }
  .faq__head { position: sticky; top: 7rem; margin-bottom: 0; }
}

/* ── inquiry ── */
.inquiry { background: var(--charcoal); color: var(--bone); }
.inquiry__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 6vw, 5.5rem);
  align-items: end;
}
.inquiry__inner h2 { color: var(--bone); max-width: 13ch; }
.inquiry__inner h2 em { color: var(--accent); }
.inquiry__right p { margin-bottom: 1.7rem; color: var(--mist-soft); }
.inquiry__contact {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.86rem;
  letter-spacing: 0.04em;
  color: var(--bone);
  margin-bottom: 0.6rem !important;
}
.inquiry__contact a { border-bottom: 1px solid var(--rule-dark-2); padding-bottom: 2px; transition: border-color 0.3s; }
.inquiry__contact a:hover { border-bottom-color: var(--accent); }
@media (max-width: 760px) {
  .inquiry__inner { grid-template-columns: 1fr; gap: 2.2rem; align-items: start; }
}

/* ── footer ── */
.footer {
  background: var(--charcoal);
  color: var(--mist-soft);
  border-top: 1px solid var(--rule-dark);
  padding-block: clamp(3.5rem, 6vw, 5rem) 2rem;
}
.footer__top {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--rule-dark);
}
.footer__brand .lockup { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 1.2rem; }
.footer__brand .lockup img { height: 34px; }
.footer__brand .wordmark {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-size: 1.35rem; font-weight: 500;
  letter-spacing: 0.26em; color: var(--bone);
}
.footer__brand p { font-size: 0.89rem; max-width: 36ch; line-height: 1.62; }
.footer__col h2 {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.7rem; letter-spacing: 0.07em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 1.25rem; font-weight: 600;
}
.footer__col a, .footer__col p {
  display: block; font-size: 0.89rem;
  color: var(--mist-soft); margin-bottom: 0.7rem;
  transition: color 0.3s;
}
.footer__col a:hover { color: var(--bone); }
.footer__social { display: flex; gap: 0.85rem; margin-top: 1.3rem; }
.footer__social a { color: var(--mist); display: inline-flex; transition: color 0.3s var(--ease); }
.footer__social a:hover { color: var(--accent); }
.footer__social svg { width: 20px; height: 20px; display: block; }
.footer__bottom {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 1rem;
  padding-top: 2rem;
  font-size: 0.76rem;
}
.footer__bottom .mono { font-family: 'Manrope', 'Manrope Fallback', sans-serif; letter-spacing: 0.05em; color: var(--mist); }
.footer__sileon a { color: var(--mist); border-bottom: 1px solid var(--rule-dark); transition: color 0.3s; }
.footer__sileon a:hover { color: var(--accent); }
@media (max-width: 760px) {
  .footer__top { grid-template-columns: 1fr; gap: 2.4rem; }
}

/* ── scroll reveal ── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s var(--ease), transform 0.8s var(--ease);
}
.reveal.in { opacity: 1; transform: translateY(0); }

/* ── draft notice ── */
.draft-banner {
  background: var(--accent-deep);
  color: var(--bone);
  text-align: center;
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.5rem 1rem;
}

/* ════════════════════════════════════════════════════════════════
   INNER PAGES — added for the 6-page build.
   Page hero, breadcrumb, section tones, work gallery, contact form.
   All built on the existing token system; reuses .article-mark, .rank,
   .division, .project-card, .cred, .engagement__steps, .testimonial, .faq.
   ════════════════════════════════════════════════════════════════ */

/* section background tones */
.section.bg-bone     { background: var(--bone); }
.section.bg-bone-2   { background: var(--bone-2); }
.section.bg-ivory    { background: var(--ivory); }
.section.bg-cream    { background: var(--cream); }
.section.bg-slate    { background: var(--slate); color: var(--bone); }
.section.bg-charcoal { background: var(--charcoal); color: var(--bone); }
.section.bg-slate p, .section.bg-charcoal p { color: var(--mist-soft); }
.section.bg-slate .serif, .section.bg-charcoal .serif { color: var(--bone); }

/* ── page hero (inner-page header) ── */
.page-hero {
  position: relative;
  background: var(--charcoal);
  color: var(--bone);
  overflow: hidden;
  padding-block: clamp(7rem, 13vw, 10.5rem) clamp(3.2rem, 6vw, 5rem);
}
.page-hero__bg { position: absolute; inset: 0; z-index: 0; }
.page-hero__bg img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  opacity: 0.85; filter: contrast(1.03) saturate(1.02);
}
.page-hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(18,21,23,0.9) 0%, rgba(18,21,23,0.62) 38%, rgba(18,21,23,0.22) 72%, rgba(18,21,23,0.08) 100%),
    linear-gradient(180deg, rgba(18,21,23,0.5) 0%, rgba(18,21,23,0.08) 42%, rgba(18,21,23,0.55) 100%);
}
.page-hero .wrap { position: relative; z-index: 1; }
.page-hero__title {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, serif;
  font-weight: 400; font-size: var(--fs-h1);
  line-height: 1.04; letter-spacing: -0.022em;
  max-width: 17ch; margin: 0.7rem 0 0;
}
.page-hero__title em { font-style: italic; color: var(--accent); }
.page-hero__intro {
  margin-top: clamp(1.3rem, 3vw, 1.9rem);
  max-width: 58ch; font-size: var(--fs-lead); line-height: 1.5;
  color: var(--mist-soft);
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
}
@media (max-width: 720px) {
  .page-hero__bg::after {
    background: linear-gradient(180deg, rgba(18,21,23,0.62) 0%, rgba(18,21,23,0.2) 40%, rgba(18,21,23,0.74) 100%);
  }
}

/* ── breadcrumb ── */
.breadcrumb {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: var(--fs-eyebrow); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mist); display: flex; gap: 0.6em; align-items: center; flex-wrap: wrap;
}
.breadcrumb a { color: var(--mist); text-decoration: none; }
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb span[aria-current] { color: var(--bone); }
.breadcrumb .sep { opacity: 0.45; }

/* ── long-form prose (leadership) ── */
.prose { max-width: 64ch; }
.prose p + p { margin-top: 1.15em; }
.prose .lead { margin-bottom: 1.15em; }

/* ── work gallery (finished-work image grid) ── */
.gallery { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(0.8rem, 1.6vw, 1.3rem); }
.gallery__item { position: relative; overflow: hidden; background: var(--charcoal); grid-column: span 4; }
.gallery__item img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/3; transition: transform 0.7s var(--ease); display: block; }
.gallery__item:hover img { transform: scale(1.04); }
.gallery__item--wide { grid-column: span 8; }
.gallery__item--wide img { aspect-ratio: 16/9; }
.gallery__item--tall img { aspect-ratio: 3/4; }
.gallery__cap {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 1.7rem 1.2rem 0.95rem;
  background: linear-gradient(180deg, transparent, rgba(18,21,23,0.82));
  color: var(--bone);
  font-family: 'Manrope', 'Manrope Fallback', sans-serif; font-size: 0.78rem; letter-spacing: 0.03em;
}
.gallery__cap b { display: block; font-weight: 600; letter-spacing: 0.01em; }
.gallery__cap span { color: var(--mist-soft); }
@media (max-width: 860px) {
  .gallery__item, .gallery__item--wide { grid-column: span 6; }
  .gallery__item--wide img { aspect-ratio: 4/3; }
}
@media (max-width: 560px) {
  .gallery__item, .gallery__item--wide { grid-column: span 12; }
}

/* ── contact form ── */
.contact__grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.contact__aside .article-mark { margin-bottom: 1.4rem; }
.contact__details { margin-top: 2.1rem; display: grid; gap: 1.4rem; }
.contact__details .row span {
  display: block; font-family: 'Manrope', 'Manrope Fallback', sans-serif;
  font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mist); margin-bottom: 0.3rem;
}
.contact__details .row a, .contact__details .row p { font-size: 1.08rem; color: var(--ink); margin: 0; text-decoration: none; }
.contact__details .row a:hover { color: var(--accent-deep); }
.contact-form { display: grid; gap: 1.3rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.3rem; }
.field { display: flex; flex-direction: column; gap: 0.5rem; }
.field label {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif; font-size: 0.74rem;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--mist);
}
.field input, .field select, .field textarea {
  font-family: 'Manrope', 'Manrope Fallback', sans-serif; font-size: 1rem; line-height: 1.4;
  color: var(--ink); background: var(--bone-2);
  border: 1px solid var(--rule-light); border-radius: 0; padding: 0.9em 1em; width: 100%;
}
.field textarea { min-height: 8.5em; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: 2px solid var(--accent-deep); outline-offset: 2px; border-color: transparent;
}
.contact-form button { justify-self: start; margin-top: 0.4rem; cursor: pointer; }
.form-note { font-size: 0.82rem; color: var(--mist); }
@media (max-width: 820px) { .contact__grid { grid-template-columns: 1fr; gap: 2.6rem; } }
@media (max-width: 560px) { .form-row { grid-template-columns: 1fr; } }


/* ── accessibility & tap-target pass ── */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: 1rem; top: -3.5rem; z-index: 200;
  background: var(--accent-deep); color: #fff; padding: 0.7em 1.1em;
  font-family: 'Manrope','Manrope Fallback',sans-serif; font-size: 0.85rem;
  letter-spacing: 0.06em; text-decoration: none; transition: top 0.2s var(--ease);
}
.skip-link:focus-visible { top: 1rem; }
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, summary:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}
.section.bg-bone a:focus-visible, .section.bg-bone-2 a:focus-visible,
.section.bg-ivory a:focus-visible, .section.bg-cream a:focus-visible,
.section.bg-bone button:focus-visible {
  outline-color: var(--accent-deep);
}
.nav-toggle { min-width: 44px; min-height: 44px; align-items: center; justify-content: center; }
.mobile-menu__close { min-width: 44px; min-height: 44px; display: inline-flex; align-items: center; justify-content: center; }
.link-rule { padding-block: 0.6em; }
.header__brand { min-height: 44px; align-items: center; }
