/* ============================================================
   Wealthy Nomads — Design C · "Private Bank"
   Porcelain grounds, charcoal ink, one deep-forest accent.
   Source Serif 4 (display) + Inter (body/labels). No gradients.
   ============================================================ */

:root {
  --porcelain: #F7F7F5;
  --pearl:     #EFEFEC;
  --ink:       #17191C;
  --ink-soft:  #585B54;
  --forest:    #1E3B2E;
  --forest-deep: #142A20;
  --hairline:  #D8D8D3;
  --hairline-dark: #C6C6C0;
  --serif: "Source Serif 4", Georgia, "Times New Roman", serif;
  --sans: "Inter", -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  background: var(--porcelain);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16.5px;
  line-height: 1.68;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }

a { color: var(--forest); text-decoration: none; }
a:hover { color: var(--forest-deep); }

:focus-visible { outline: 2px solid var(--forest); outline-offset: 3px; }

::selection { background: var(--forest); color: var(--porcelain); }

.wrap { max-width: 1160px; margin: 0 auto; padding-left: clamp(22px, 5.5vw, 72px); padding-right: clamp(22px, 5.5vw, 72px); }

/* ---------- type ---------- */

h1, h2, h3, .serif {
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.012em;
  font-optical-sizing: auto;
}

h1 { font-size: clamp(38px, 5vw, 60px); font-weight: 500; }
h2 { font-size: clamp(28px, 3.4vw, 40px); }
h3 { font-size: clamp(21px, 2.2vw, 25px); line-height: 1.25; }

.lead { font-size: clamp(17px, 1.6vw, 19px); line-height: 1.7; color: var(--ink-soft); max-width: 58ch; }

p + p { margin-top: 1.1em; }

.label {
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.label.forest { color: var(--forest); }

/* text link — thin underline */
.tlink {
  color: var(--forest);
  font-weight: 500;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 5px;
  text-decoration-color: var(--hairline-dark);
  transition: text-decoration-color .2s ease;
}
.tlink:hover { text-decoration-color: var(--forest); }

/* footnotes */
sup { font-size: 0.62em; color: var(--forest); font-weight: 600; }
.fn {
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  border-top: 1px solid var(--hairline);
  padding-top: 12px;
  max-width: 62ch;
}

/* ---------- buttons ---------- */

.btn {
  display: inline-block;
  background: var(--forest);
  color: #F7F7F5;
  border: 1px solid var(--forest);
  border-radius: 2px;
  font-family: var(--sans);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 16px 30px;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
}
.btn:hover { background: var(--forest-deep); border-color: var(--forest-deep); color: #F7F7F5; }

.btn.small { padding: 11px 20px; font-size: 11.5px; }

/* ---------- letterhead header ---------- */

.site-head { border-bottom: 1px solid var(--hairline); background: var(--porcelain); }

.site-head .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 78px;
  padding-top: 14px;
  padding-bottom: 14px;
  flex-wrap: wrap;
}

.wordmark { display: block; color: var(--ink); }
.wordmark .wm-name {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  display: block;
  line-height: 1.15;
}
.wordmark .wm-sub {
  display: block;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 3px;
}
.wordmark:hover { color: var(--ink); }

.site-nav { display: flex; align-items: center; gap: clamp(18px, 2.6vw, 34px); flex-wrap: wrap; }
.site-nav a.navlink {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  padding: 4px 0;
}
.site-nav a.navlink:hover { color: var(--ink); }
.site-nav a.navlink[aria-current="page"] {
  color: var(--forest);
  border-bottom: 1px solid var(--forest);
}

/* ---------- section machinery ---------- */

.band { padding-top: clamp(72px, 9vw, 116px); padding-bottom: clamp(72px, 9vw, 116px); }
.band.pearl { background: var(--pearl); border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.band.tight { padding-top: clamp(54px, 6.5vw, 84px); padding-bottom: clamp(54px, 6.5vw, 84px); }

/* indexed section head: 01 — LABEL, ruled above */
.sec-head {
  display: flex;
  align-items: baseline;
  gap: 18px;
  border-top: 1px solid var(--ink);
  padding-top: 16px;
  margin-bottom: clamp(40px, 5vw, 64px);
}
.sec-head .idx {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--forest);
  font-variant-numeric: tabular-nums;
}
.sec-head .label { color: var(--ink); }
.sec-head .rule-note { margin-left: auto; font-size: 11.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 500; }

/* ---------- hero ---------- */

.hero { padding-top: clamp(56px, 7vw, 96px); padding-bottom: clamp(56px, 7vw, 96px); }
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 4.4fr);
  gap: clamp(40px, 6vw, 88px);
  align-items: start;
}
.hero h1 { margin: 18px 0 26px; max-width: 15ch; }
.hero .lead { margin-bottom: 36px; }

.cta-row { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }

/* figures / photography — annual-report treatment */
figure.plate { margin: 0; }
figure.plate img {
  width: 100%;
  height: auto; /* let aspect-ratio win over the height attribute */
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: saturate(0.82);
  border: 1px solid var(--hairline-dark);
}
figure.plate img.gray { filter: grayscale(1) contrast(1.03); }
figure.plate img.square { aspect-ratio: 1 / 1; }
figure.plate img.wide { aspect-ratio: 3 / 2; }
figure.plate figcaption {
  font-size: 12px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--hairline);
}
figure.plate figcaption .cap-idx { color: var(--forest); font-weight: 600; letter-spacing: 0.08em; margin-right: 8px; }

/* credential strip */
.cred {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--hairline);
}
.cred > div { padding: 26px 32px 26px 0; }
.cred > div + div { border-left: 1px solid var(--hairline); padding-left: 32px; }
.cred .fig { font-family: var(--serif); font-size: clamp(22px, 2.4vw, 28px); font-weight: 600; letter-spacing: -0.01em; }
.cred .cap { font-size: 13px; color: var(--ink-soft); margin-top: 6px; line-height: 1.5; }
.cred-note { margin-top: 14px; }
.cred-note.fn { border-top: 0; padding-top: 0; }

/* ---------- two lanes (Schedule A / B) ---------- */

.lanes { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.lane { padding: 8px clamp(28px, 4vw, 60px) 8px 0; }
.lane + .lane { border-left: 1px solid var(--hairline-dark); padding-left: clamp(28px, 4vw, 60px); padding-right: 0; }
.lane .sched {
  font-family: var(--serif);
  font-size: 21px;
  font-weight: 600;
  color: var(--forest);
  display: block;
  margin-bottom: 14px;
}
.lane h3 { margin-bottom: 14px; }
.lane p { color: var(--ink-soft); font-size: 15.5px; }

/* spec table — hairline rows */
.spec { margin: 26px 0 30px; border-top: 1px solid var(--hairline-dark); }
.spec > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 24px;
  padding: 10px 0;
  border-bottom: 1px solid var(--hairline);
}
.spec dt { font-size: 11px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); }
.spec dd { font-size: 14px; text-align: right; }

/* left-running variant for prose rows (timelines, curricula) */
.spec.left > div { justify-content: flex-start; }
.spec.left dt { min-width: 72px; flex-shrink: 0; padding-top: 3px; }
.spec.left dd { text-align: left; }

/* ---------- manifesto interstitial ---------- */

.manifesto { text-align: center; }
.manifesto .inner-quote {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(20px, 3vw, 34px) 0;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.manifesto blockquote {
  font-family: var(--serif);
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.3;
  font-weight: 400;
}
.manifesto blockquote em { font-style: italic; color: var(--forest); }
.manifesto .label { margin-bottom: 22px; display: block; }
.manifesto .after { margin-top: 22px; }

/* ---------- split rows (about teaser, etc.) ---------- */

.split { display: grid; grid-template-columns: minmax(0, 4.2fr) minmax(0, 7fr); gap: clamp(40px, 6vw, 88px); align-items: start; }
.split.rev { grid-template-columns: minmax(0, 7fr) minmax(0, 4.2fr); }
.split h2 { margin-bottom: 20px; }
.split .body-col p { color: var(--ink-soft); }
.split .after { margin-top: 30px; }

/* ---------- outcomes table ---------- */

.big-stat { font-family: var(--serif); font-size: clamp(40px, 5.4vw, 66px); font-weight: 600; letter-spacing: -0.015em; line-height: 1.05; }
.big-stat .arrow { color: var(--forest); }
.stat-sub { margin-top: 16px; }

.qtable { border-top: 1px solid var(--ink); margin-top: clamp(36px, 4.5vw, 56px); }
.qrow {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  gap: clamp(20px, 3vw, 48px);
  padding: 26px 0;
  border-bottom: 1px solid var(--hairline);
}
.qrow .who { font-size: 11.5px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); padding-top: 6px; }
.qrow .who .role { display: block; font-weight: 500; letter-spacing: 0.1em; color: var(--hairline-dark); margin-top: 4px; color: var(--ink-soft); opacity: .7; }
.qrow q, .qrow .quote {
  font-family: var(--serif);
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.45;
  font-weight: 400;
  quotes: "\201C" "\201D";
}

/* ---------- newsletter ---------- */

.news-grid { display: grid; grid-template-columns: minmax(0, 6fr) minmax(0, 5fr); gap: clamp(40px, 6vw, 88px); align-items: start; }
.news-grid h2 { margin-bottom: 18px; }
.news-grid .body-col p { color: var(--ink-soft); }

form.quiet { margin-top: 6px; }
.field { margin-bottom: 18px; }
.field label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 8px;
}
.field input, .field textarea {
  width: 100%;
  background: #FFFFFF;
  border: 1px solid var(--hairline-dark);
  border-radius: 2px;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  padding: 14px 16px;
}
.field input:focus, .field textarea:focus { outline: 2px solid var(--forest); outline-offset: 0; border-color: var(--forest); }
.field textarea { min-height: 150px; resize: vertical; }
.form-note { font-size: 12.5px; color: var(--ink-soft); margin-top: 14px; line-height: 1.6; }

/* ---------- CTA band ---------- */

.cta-band { text-align: center; }
.cta-band .inner-c { max-width: 660px; margin: 0 auto; }
.cta-band h2 { margin: 14px 0 18px; }
.cta-band p { color: var(--ink-soft); margin-bottom: 32px; }

/* ---------- media rows (testimonials / training) ---------- */

.embed {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #101210;
  border: 1px solid var(--hairline-dark);
}
.embed iframe, .embed video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.vrow {
  display: grid;
  grid-template-columns: minmax(0, 4.6fr) minmax(0, 6.4fr);
  gap: clamp(28px, 4.5vw, 64px);
  padding: clamp(36px, 4.5vw, 56px) 0;
  border-bottom: 1px solid var(--hairline);
  align-items: start;
}
.vrow:first-of-type { border-top: 1px solid var(--ink); }
.vrow .v-meta .v-idx { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; color: var(--forest); font-variant-numeric: tabular-nums; display: block; margin-bottom: 14px; }
.vrow .v-meta .v-name { font-size: 11.5px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 12px; }
.vrow .v-meta .quote { font-family: var(--serif); font-size: clamp(19px, 2.2vw, 24px); line-height: 1.4; }

/* ---------- legal ---------- */

.legal { max-width: 780px; }
.legal h1 { margin-bottom: 10px; }
.legal .updated { margin-bottom: 48px; }
.legal h2 { font-size: 22px; margin: 44px 0 14px; }
.legal p, .legal li { font-size: 15px; color: #3A3D38; }
.legal ul { padding-left: 22px; margin: 12px 0; }
.legal li { margin: 6px 0; }

/* ---------- footer ---------- */

.site-foot { border-top: 1px solid var(--ink); background: var(--pearl); padding: clamp(48px, 6vw, 72px) 0 40px; }
.foot-grid { display: grid; grid-template-columns: minmax(0, 5fr) repeat(3, minmax(0, 2.2fr)); gap: clamp(28px, 4vw, 56px); }
.foot-grid .fcol h4 { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 16px; }
.foot-grid .fcol a { display: block; font-size: 14px; color: var(--ink); padding: 4px 0; }
.foot-grid .fcol a:hover { color: var(--forest); }
.foot-brand .wm-name { font-family: var(--serif); font-size: 17px; font-weight: 600; letter-spacing: 0.09em; text-transform: uppercase; display: block; }
.foot-brand .wm-sub { font-size: 9.5px; font-weight: 600; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ink-soft); display: block; margin-top: 3px; margin-bottom: 20px; }
.foot-brand p { font-size: 13.5px; color: var(--ink-soft); max-width: 40ch; }
.disclaimer {
  margin-top: clamp(40px, 5vw, 56px);
  border-top: 1px solid var(--hairline);
  padding-top: 22px;
  font-size: 11.5px;
  line-height: 1.65;
  color: var(--ink-soft);
}
.disclaimer p + p { margin-top: 10px; }
.foot-base { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-top: 26px; font-size: 12px; color: var(--ink-soft); }
.foot-base a { color: var(--ink-soft); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.foot-base a:hover { color: var(--forest); }

/* ---------- reveal (JS adds .js; degrades gracefully) ---------- */

.js .reveal { opacity: 0; transform: translateY(14px); transition: opacity .7s ease, transform .7s ease; }
.js .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------- responsive ---------- */

@media (max-width: 920px) {
  .hero-grid, .split, .split.rev, .news-grid { grid-template-columns: 1fr; }
  .hero-grid figure.plate { max-width: 460px; }
  .split .plate-col { order: -1; max-width: 420px; }
  .lanes { grid-template-columns: 1fr; }
  .lane + .lane { border-left: 0; border-top: 1px solid var(--hairline-dark); padding-left: 0; margin-top: 34px; padding-top: 40px; }
  .vrow { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 680px) {
  .cred { grid-template-columns: 1fr; }
  .cred > div { padding: 20px 0; }
  .cred > div + div { border-left: 0; border-top: 1px solid var(--hairline); padding-left: 0; }
  .qrow { grid-template-columns: 1fr; gap: 10px; }
  .foot-grid { grid-template-columns: 1fr; }
  .site-head .inner { justify-content: flex-start; }
}
