/* =====================================================================
   Cromwell & Holmes — Site institutionnel (v6 — financeurs)
   Palette : or bronze (logo) + encre chaude + ivoire/papier
   Typo    : Cormorant Garamond (titres, italiques) + Cormorant SC (caps)
             + Inter (corps, labels)
   ===================================================================== */

:root {
  --gold:      #c89a68;
  --gold-deep: #a6794a;
  --gold-soft: #d9bd95;
  --ink:       #16120c;
  --ink-2:     #221b12;
  --ink-soft:  #3a3024;
  --text:      #36302a;
  --text-soft: #6a6055;
  --line:      #e0d6c4;
  --line-dk:   rgba(200,154,104,.22);
  --paper:     #faf6ef;
  --ivory:     #f3ecdf;
  --cream:     #ece3d2;

  --serif:     'Cormorant Garamond', 'EB Garamond', Georgia, serif;
  --serif-sc:  'Cormorant SC', 'Cormorant Garamond', serif;
  --sans:      'Inter', system-ui, -apple-system, sans-serif;

  --max:       1180px;
  --max-narrow:780px;
}

html { color-scheme: light; scroll-behavior: smooth; }
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: var(--sans);
  font-weight: 400;
  color: var(--text);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* paper grain */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(60,40,10,.05) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode: multiply;
  opacity: .35;
  z-index: 1;
}
body > * { position: relative; z-index: 2; }

::selection { background: rgba(200,154,104,.28); }

/* ====================== layout primitives ====================== */
.container {
  width: 100%;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 32px;
}
.container.narrow { max-width: var(--max-narrow); }
.centered { text-align: center; }
.section { padding: 104px 0; }

.eyebrow {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 1px;
  background: var(--gold);
}
.eyebrow.centered { justify-content: center; }

.display {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(28px, 3.6vw, 46px);
  line-height: 1.16;
  letter-spacing: -.005em;
  color: var(--ink);
  text-wrap: balance;
  margin: 0 0 28px;
}
.display em { font-style: italic; color: var(--gold-deep); }
.display .amp { font-style: italic; color: var(--gold); margin: 0 .04em; }
.display.centered { text-align: center; }

.lede {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 20px;
  line-height: 1.65;
  color: var(--text);
  margin: 0 0 18px;
  max-width: 66ch;
}
.lede.narrow { margin-left: auto; margin-right: auto; }
.lede em { font-style: italic; color: var(--gold-deep); }

.amp {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--gold);
}

/* ====================== buttons ====================== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 15px 30px;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
}
.btn-primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.btn-primary:hover { background: var(--gold-deep); border-color: var(--gold-deep); }
.btn-gold {
  background: var(--gold);
  color: var(--ink);
  border-color: var(--gold);
}
.btn-gold:hover { background: var(--gold-deep); border-color: var(--gold-deep); color: #fff; }
.btn-ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--gold);
}
.btn-ghost:hover { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.btn-ghost-light {
  background: transparent;
  color: var(--paper);
  border-color: rgba(217,189,149,.5);
}
.btn-ghost-light:hover { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.btn-large { padding: 18px 40px; }

/* ====================== header ====================== */
.site-header {
  position: sticky;
  top: 0;
  background: rgba(250,246,239,.9);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 32px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 13px;
  text-decoration: none;
}
.brand-mark { width: 30px; height: 29px; display: block; }
.brand-words {
  font-family: var(--serif-sc);
  font-weight: 500;
  font-size: 15px;
  letter-spacing: .26em;
  color: var(--ink);
  white-space: nowrap;
}
.brand-words .amp { font-size: 16px; letter-spacing: normal; vertical-align: -.04em; }

.nav { display: flex; align-items: center; gap: 24px; }
.nav a {
  text-decoration: none;
  color: var(--text-soft);
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: .14em;
  font-weight: 500;
  text-transform: uppercase;
  transition: color .15s;
}
.nav a:hover { color: var(--ink); }
.nav .nav-cta {
  color: var(--ink);
  padding: 9px 18px;
  border: 1px solid var(--gold);
}
.nav .nav-cta:hover { background: var(--gold); color: var(--ink); }
@media (max-width: 1024px) {
  .nav { gap: 16px; }
  .nav > a:not(.nav-cta) { display: none; }
  .lang-switch { display: flex; }
  .lang-switch a { display: block; }
}
@media (max-width: 600px) {
  .site-header { padding: 14px 20px; }
  .brand-words { display: none; }
  .brand-mark { width: 36px; height: 35px; }
  .nav .nav-cta { padding: 9px 14px; font-size: 11px; }
  .lang-switch { margin-left: 10px; padding-left: 10px; }
}

/* ====================== HERO ====================== */
.hero {
  background:
    radial-gradient(120% 80% at 50% -10%, #2a2014 0%, var(--ink) 55%, #100d08 100%);
  color: var(--paper);
  padding: 96px 32px 110px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.hero::after {
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(200,154,104,.05) 1px, transparent 1px);
  background-size: 4px 4px;
  opacity: .5;
  pointer-events: none;
}
.hero-inner {
  max-width: 860px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  position: relative;
  z-index: 1;
}
.hero-eyebrow {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--gold-soft);
}
.hero-eyebrow .bar { width: 44px; height: 1px; background: rgba(217,189,149,.5); }
.hero-mark { width: 230px; height: 221px; margin-bottom: 8px; }
.hero-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(25px, 3.2vw, 38px);
  line-height: 1.18;
  letter-spacing: -.01em;
  color: var(--paper);
  margin: 4px 0 0;
  text-wrap: balance;
  max-width: 20ch;
}
.hero-title .accent { color: var(--gold-soft); font-style: italic; }
.hero-tagline {
  font-family: var(--serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(17px, 2vw, 21px);
  line-height: 1.5;
  color: rgba(244,239,230,.78);
  max-width: 46ch;
  margin: 4px auto 8px;
}
.hero-actions {
  display: flex;
  gap: 14px;
  margin-top: 16px;
  flex-wrap: wrap;
  justify-content: center;
}
.hero-wordmark { height: 30px; width: auto; margin-top: 30px; opacity: .92; }

/* ====================== section heads ====================== */
.section-head { max-width: 760px; }
.section-head.centered { margin: 0 auto; }

/* ====================== PROBLEM / STATS ====================== */
.section-problem { background: var(--ivory); border-bottom: 1px solid var(--line); }
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin: 52px 0 60px;
}
.stat { display: flex; flex-direction: column; gap: 10px; padding-top: 22px; border-top: 2px solid var(--gold); }
.stat-figure {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 4.6vw, 60px);
  line-height: 1;
  color: var(--ink);
  letter-spacing: -.02em;
}
.stat-text { font-family: var(--serif); font-size: 16px; line-height: 1.45; color: var(--text-soft); margin: 0; }
.stat-figure .mult { font-size: .72em; color: var(--gold-deep); margin-right: .04em; vertical-align: baseline; }
.problem-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.problem {
  background: var(--paper);
  padding: 32px 30px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.problem-num {
  font-family: var(--serif-sc);
  font-size: 13px;
  letter-spacing: .2em;
  color: var(--gold-deep);
}
.problem h3 { font-family: var(--serif); font-weight: 500; font-size: 22px; color: var(--ink); margin: 0; }
.problem p { font-family: var(--sans); font-size: 14px; line-height: 1.6; color: var(--text-soft); margin: 0; }
.problem-note {
  margin-top: 36px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 20px;
  line-height: 1.5;
  color: var(--ink);
  text-align: center;
  max-width: 64ch;
  margin-left: auto; margin-right: auto;
}
.problem-note .amp { color: var(--gold); }
.src-line {
  margin-top: 28px;
  font-family: var(--sans);
  font-size: 10.5px;
  letter-spacing: .04em;
  color: var(--text-soft);
  opacity: .7;
  text-align: center;
}
@media (max-width: 880px) { .stats-row { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .stats-row, .problem-grid { grid-template-columns: 1fr; } }

/* ====================== RÉPONSE / PONT (dark band) ====================== */
.section-bridge {
  background: radial-gradient(120% 100% at 80% 0%, #241c12 0%, var(--ink) 70%);
  color: var(--paper);
}
.section-bridge .eyebrow { color: var(--gold-soft); }
.section-bridge .eyebrow::before { background: var(--gold); }
.section-bridge .display { color: var(--paper); }
.section-bridge .display em { color: var(--gold-soft); }
.section-bridge .lede { color: rgba(244,239,230,.74); }
.bridge-cols {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 36px;
  align-items: stretch;
  margin-top: 52px;
}
.bridge-card {
  border: 1px solid var(--line-dk);
  background: rgba(200,154,104,.04);
  padding: 34px 30px;
}
.bridge-card .bc-label {
  font-family: var(--serif-sc);
  font-size: 12px;
  letter-spacing: .24em;
  color: var(--gold);
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line-dk);
}
.bridge-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.bridge-card li {
  font-family: var(--serif);
  font-size: 19px;
  color: rgba(244,239,230,.9);
  line-height: 1.4;
}
.bridge-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-size: 34px;
  color: var(--gold);
}
.bridge-foot {
  margin-top: 44px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 21px;
  line-height: 1.5;
  color: var(--gold-soft);
  text-align: center;
  max-width: 70ch;
  margin-left: auto; margin-right: auto;
}
@media (max-width: 820px) {
  .bridge-cols { grid-template-columns: 1fr; gap: 18px; }
  .bridge-arrow { transform: rotate(90deg); }
}

/* ====================== INTERVENTION (4 steps) ====================== */
.section-steps { background: var(--paper); }
.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px;
  margin-top: 52px;
}
.step-card { display: flex; flex-direction: column; gap: 12px; }
.step-card .sc-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 40px;
  color: var(--gold);
  line-height: 1;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}
.step-card h3 { font-family: var(--serif); font-weight: 500; font-size: 24px; color: var(--ink); margin: 0; }
.step-card p { font-family: var(--sans); font-size: 14px; line-height: 1.6; color: var(--text-soft); margin: 0; }

.reporting-band {
  margin-top: 64px;
  padding: 40px;
  background: var(--ivory);
  border: 1px solid var(--line);
}
.reporting-band .rb-label {
  font-family: var(--serif-sc);
  font-size: 12px;
  letter-spacing: .24em;
  color: var(--gold-deep);
  margin-bottom: 26px;
}
.reporting-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.report { background: var(--paper); padding: 22px 20px; display: flex; flex-direction: column; gap: 8px; }
.report .rn { font-family: var(--serif-sc); font-size: 12px; letter-spacing: .16em; color: var(--gold-deep); }
.report h4 { font-family: var(--serif); font-weight: 500; font-size: 18px; color: var(--ink); margin: 0; }
.report p { font-family: var(--sans); font-size: 12.5px; line-height: 1.5; color: var(--text-soft); margin: 0; }
@media (max-width: 980px) { .steps-grid { grid-template-columns: repeat(2, 1fr); } .reporting-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .steps-grid { grid-template-columns: 1fr; } .reporting-grid { grid-template-columns: 1fr; } }

/* ====================== LIVRABLE (6 components) ====================== */
.section-deliverable { background: var(--ivory); border-top: 1px solid var(--line); }
.deliv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  margin-top: 52px;
}
.deliv {
  background: var(--paper);
  padding: 34px 30px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}
.deliv .dn {
  font-family: var(--serif-sc);
  font-size: 13px;
  letter-spacing: .2em;
  color: var(--gold-deep);
}
.deliv h3 { font-family: var(--serif); font-weight: 500; font-size: 21px; color: var(--ink); margin: 0; line-height: 1.25; }
.deliv p { font-family: var(--sans); font-size: 13.5px; line-height: 1.6; color: var(--text-soft); margin: 0; }
.deliv-foot {
  margin-top: 36px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 20px;
  line-height: 1.5;
  color: var(--ink);
  text-align: center;
  max-width: 66ch;
  margin-left: auto; margin-right: auto;
}
@media (max-width: 880px) { .deliv-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .deliv-grid { grid-template-columns: 1fr; } }

/* ====================== MÉTHODE (timeline) ====================== */
.section-method { background: var(--paper); }
.method-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin-top: 52px;
  position: relative;
}
.method-grid::before {
  content: "";
  position: absolute;
  top: 19px; left: 4%; right: 4%;
  height: 1px;
  background: var(--line);
}
.method-step { position: relative; padding-top: 52px; display: flex; flex-direction: column; gap: 12px; }
.method-step .ms-dot {
  position: absolute;
  top: 0; left: 0;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--gold-soft);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 20px;
}
.method-step .ms-label {
  font-family: var(--serif-sc);
  font-size: 11px;
  letter-spacing: .22em;
  color: var(--gold-deep);
}
.method-step h3 { font-family: var(--serif); font-weight: 500; font-size: 22px; color: var(--ink); margin: 0; }
.method-step p { font-family: var(--sans); font-size: 13.5px; line-height: 1.6; color: var(--text-soft); margin: 0; }
@media (max-width: 880px) {
  .method-grid { grid-template-columns: 1fr; gap: 30px; }
  .method-grid::before { display: none; }
  .method-step { padding-top: 0; padding-left: 56px; }
}

/* ====================== EXPERTISES ====================== */
.section-expertise { background: var(--ivory); border-top: 1px solid var(--line); }
.exp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
  margin-top: 52px;
}
.exp-card {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 38px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.exp-card .ec-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 30px;
  color: var(--gold);
  line-height: 1;
}
.exp-card h3 { font-family: var(--serif); font-weight: 500; font-size: 24px; color: var(--ink); margin: 0; line-height: 1.2; }
.exp-card p { font-family: var(--sans); font-size: 14px; line-height: 1.62; color: var(--text-soft); margin: 0; }
.exp-foot {
  margin-top: 52px;
  padding: 36px 40px;
  background: var(--ink);
  color: var(--paper);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.exp-foot .ef-label {
  font-family: var(--serif-sc);
  font-size: 12px;
  letter-spacing: .24em;
  color: var(--gold-soft);
}
.exp-foot .ef-items {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 28px;
}
.exp-foot .ef-items span {
  font-family: var(--serif);
  font-size: 18px;
  color: rgba(244,239,230,.9);
}
.exp-foot .ef-items span strong { color: var(--gold-soft); font-weight: 500; }
@media (max-width: 880px) { .exp-grid { grid-template-columns: 1fr; } }

/* ====================== DUE DILIGENCE CROISÉE ====================== */
.section-dd { background: var(--paper); }
.dd-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-top: 52px;
}
.dd-block { background: var(--ivory); border: 1px solid var(--line); padding: 38px 34px; }
.dd-block .dd-kicker {
  font-family: var(--serif-sc);
  font-size: 12px;
  letter-spacing: .2em;
  color: var(--gold-deep);
  margin-bottom: 6px;
}
.dd-block h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 24px;
  line-height: 1.3;
  color: var(--ink);
  margin: 0 0 24px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.dd-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.dd-list li {
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.4;
  color: var(--text);
  padding-left: 26px;
  position: relative;
}
.dd-list li::before {
  content: "→";
  position: absolute; left: 0;
  color: var(--gold);
  font-family: var(--sans);
}
.dd-foot {
  margin-top: 44px;
  text-align: center;
  font-family: var(--serif);
  font-style: italic;
  font-size: 21px;
  color: var(--ink);
}
.dd-foot strong { color: var(--gold-deep); font-weight: 500; font-style: normal; }
@media (max-width: 820px) { .dd-grid { grid-template-columns: 1fr; } }

/* ====================== OFFRES ====================== */
.section-offers { background: var(--ivory); border-top: 1px solid var(--line); }
.offers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 52px;
  align-items: stretch;
}
.offer {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  position: relative;
}
.offer-featured {
  background: var(--ink);
  border-color: var(--ink);
  box-shadow: 0 26px 60px -28px rgba(22,18,12,.7);
}
.offer-flag {
  position: absolute;
  top: 0; left: 50%;
  transform: translate(-50%, -50%);
  background: var(--gold);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 6px 16px;
  white-space: nowrap;
}
.offer-tier {
  font-family: var(--serif-sc);
  font-size: 12px;
  letter-spacing: .26em;
  color: var(--gold-deep);
}
.offer-featured .offer-tier { color: var(--gold-soft); }
.offer-name {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 25px;
  line-height: 1.25;
  color: var(--ink);
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
  margin-top: -8px;
}
.offer-featured .offer-name { color: var(--paper); border-bottom-color: var(--line-dk); }
.offer-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 13px; flex: 1; }
.offer-list li {
  font-family: var(--serif);
  font-size: 16.5px;
  line-height: 1.4;
  color: var(--text);
  padding-left: 24px;
  position: relative;
}
.offer-list li::before {
  content: "✓";
  position: absolute; left: 0;
  font-family: var(--sans);
  font-size: 12px;
  color: var(--gold-deep);
  top: 3px;
}
.offer-featured .offer-list li { color: rgba(244,239,230,.92); }
.offer-featured .offer-list li::before { color: var(--gold); }
.offer .btn { width: 100%; }
.offer-note {
  margin-top: 40px;
  text-align: center;
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  line-height: 1.55;
  color: var(--text-soft);
  max-width: 72ch;
  margin-left: auto; margin-right: auto;
}
.offer-note strong { color: var(--ink); font-weight: 500; font-style: normal; }
@media (max-width: 900px) { .offers-grid { grid-template-columns: 1fr; } }

/* ====================== FOUNDER ====================== */
.section-founder { background: var(--paper); }
.founder-grid {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 56px;
  align-items: start;
}
.founder-portrait { position: sticky; top: 100px; }
.portrait-frame {
  width: 100%;
  aspect-ratio: 4/5;
  background: var(--ivory);
  border: 1px solid var(--line);
  display: block;
  position: relative;
  overflow: hidden;
}
.portrait-frame img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(.12) contrast(1.02);
}
.portrait-frame::after {
  content: "";
  position: absolute; inset: 10px;
  border: 1px solid rgba(217,189,149,.35);
  pointer-events: none;
  z-index: 1;
}
.portrait-label { font-family: var(--sans); font-size: 10px; letter-spacing: .26em; text-transform: uppercase; color: var(--gold-deep); }
.portrait-sub { font-family: var(--serif); font-style: italic; font-size: 15px; color: var(--text-soft); }
.founder-role { font-family: var(--serif); font-style: italic; font-size: 19px; color: var(--gold-deep); margin: -14px 0 22px; }
.founder-stops {
  display: flex; flex-direction: column; gap: 24px;
  margin: 36px 0;
  padding-left: 24px;
  border-left: 1px solid var(--line);
}
.stop { display: grid; grid-template-columns: 150px 1fr; gap: 22px; align-items: baseline; position: relative; }
.stop::before {
  content: "";
  position: absolute; left: -28px; top: 7px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold);
}
.stop-year { font-family: var(--serif-sc); font-size: 12px; letter-spacing: .18em; color: var(--ink); text-transform: uppercase; }
.stop-text { font-family: var(--serif); font-size: 16.5px; line-height: 1.55; color: var(--text); }
.stop-text strong { color: var(--ink); font-weight: 500; }
.stop-text .amp { color: var(--gold); }
.founder-figures {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin-top: 36px; padding-top: 32px; border-top: 1px solid var(--line);
}
.fig { display: flex; flex-direction: column; gap: 8px; }
.fig-num { font-family: var(--serif); font-size: 36px; color: var(--ink); letter-spacing: -.01em; line-height: 1; }
.fig-label { font-family: var(--sans); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--gold-deep); line-height: 1.5; }
@media (max-width: 900px) {
  .founder-grid { grid-template-columns: 1fr; gap: 36px; }
  .founder-portrait { position: static; max-width: 260px; }
  .stop { grid-template-columns: 1fr; gap: 4px; }
  .founder-figures { grid-template-columns: 1fr; gap: 18px; }
}

/* ====================== CONTACT ====================== */
.section-contact {
  background: radial-gradient(120% 100% at 50% 0%, #241c12 0%, var(--ink) 70%);
  color: var(--paper);
  text-align: center;
}
.section-contact .eyebrow { color: var(--gold-soft); justify-content: center; }
.section-contact .eyebrow::before { background: var(--gold); }
.section-contact .display { color: var(--paper); }
.section-contact .lede { color: rgba(244,239,230,.74); }
.contact-card {
  margin: 48px auto 36px;
  max-width: 540px;
  border: 1px solid var(--line-dk);
  background: rgba(200,154,104,.04);
  text-align: left;
}
.contact-row { display: grid; grid-template-columns: 130px 1fr; align-items: center; padding: 22px 30px; }
.contact-row + .contact-row { border-top: 1px solid var(--line-dk); }
.contact-label { font-family: var(--sans); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--gold-soft); }
.contact-value { font-family: var(--serif); font-size: 19px; color: var(--paper); text-decoration: none; transition: color .15s; }
a.contact-value:hover { color: var(--gold-soft); }

/* ====================== FOOTER ====================== */
.site-footer {
  background: #0f0c08;
  color: rgba(244,239,230,.6);
  padding: 56px 0 30px;
  border-top: 3px solid var(--gold);
}
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 2fr; align-items: center; gap: 32px; }
.foot-brand { display: flex; align-items: center; gap: 13px; }
.foot-mark { width: 38px; height: 36px; }
.foot-words { display: flex; flex-direction: column; gap: 3px; }
.foot-name { font-family: var(--serif-sc); font-size: 14px; letter-spacing: .24em; color: var(--paper); }
.foot-name .amp { letter-spacing: normal; color: var(--gold-soft); }
.foot-tagline { font-family: var(--serif); font-style: italic; font-size: 14px; color: rgba(244,239,230,.5); }
.foot-nav { display: flex; justify-content: center; gap: 22px; flex-wrap: wrap; }
.foot-nav a {
  color: rgba(244,239,230,.6);
  text-decoration: none;
  font-family: var(--sans);
  font-size: 11.5px;
  letter-spacing: .16em;
  text-transform: uppercase;
  transition: color .15s;
}
.foot-nav a:hover { color: var(--gold-soft); }
.foot-legal {
  text-align: right;
  font-family: var(--sans);
  font-size: 11px;
  color: rgba(244,239,230,.45);
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; align-items: center;
}
.foot-legal .amp { color: var(--gold-soft); }
.foot-sep { opacity: .3; }
@media (max-width: 800px) {
  .footer-grid { grid-template-columns: 1fr; text-align: center; }
  .foot-brand { justify-content: center; }
  .foot-legal { justify-content: center; text-align: center; }
}

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