/* ============================================================
   WEALTHY NOMADS — Design direction A3 · "Maison"
   Classic heritage luxury in the approved ivory-and-gold family:
   old-money stationery. Aged-ivory grounds with parchment bands,
   deep ink as the second protagonist, gold as rules and ornament.
   Grammar: centered compositions, double hairline rules, true
   small-caps labels, an engraved WN monogram letterhead, photos
   framed like plates in a book, full-bleed deep-ink report bands.
   Content is ported 1:1 from the approved design-a; only the
   visual skin and composition change.
   ============================================================ */

:root{
  --ivory:#F5EFE3;          /* aged-ivory ground */
  --parchment:#EFE6D3;      /* parchment bands */
  --cream:#FBF6EA;          /* card faces, slightly lifted */
  --ink:#1A1C22;            /* deep navy-black ink */
  --ink-deep:#14161C;       /* report-cover panels */
  --ink-soft:#3A3C42;
  --gold:#A9772E;
  --gold-bright:#C99B5E;
  --gold-deep:#8A6026;      /* AA-legible gold for text on ivory */
  --muted:#5F594A;

  --line-ink:rgba(26,28,34,0.30);
  --line-ink-soft:rgba(26,28,34,0.16);
  --line-gold:rgba(169,119,46,0.50);
  --line-gold-soft:rgba(169,119,46,0.26);
  --gold-on-ink:rgba(201,155,94,0.55);
  --gold-on-ink-soft:rgba(201,155,94,0.32);
  --ivory-on-ink:rgba(245,239,227,0.82);

  --maxw:1060px;
  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}

body{
  margin:0;
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

::selection{background:rgba(169,119,46,0.22);}

a{color:var(--gold-deep);text-decoration:none;}
a:hover{color:var(--gold);}
img{max-width:100%;display:block;}

.wrap{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 clamp(20px, 5vw, 48px);
}

/* skip link */
.skip{
  position:absolute;left:-999px;top:0;z-index:100;
  background:var(--cream);color:var(--ink);
  border:1px solid var(--line-ink);
  padding:0.7rem 1.2rem;
  font-weight:600;letter-spacing:0.06em;
}
.skip:focus{left:0;}

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

/* ---------- Small-caps label (eyebrow) ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(0.6rem, 1.2vw, 0.7rem);
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin:0 0 1.2rem;
  display:inline-flex;
  align-items:center;
  gap:0.95em;
}
.eyebrow::before,
.eyebrow::after{
  content:"";
  width:5px;height:5px;
  background:var(--gold);
  transform:rotate(45deg);
  display:inline-block;
  flex:0 0 auto;
}

/* ---------- Serif headings ---------- */
h1,h2,h3{
  font-family:var(--serif);
  font-weight:600;
  color:var(--ink);
  margin:0;
  line-height:1.08;
  letter-spacing:0.002em;
}
em.gold{
  font-style:italic;
  color:var(--gold-deep);
  font-weight:600;
}

/* ---------- Double hairline rules & ornament dividers ---------- */
.rule-double{
  height:5px;
  border-top:1px solid var(--line-ink);
  border-bottom:1px solid var(--line-ink-soft);
}
.divider{
  --ground:var(--ivory);
  position:relative;
  height:5px;
  border-top:1px solid var(--line-ink);
  border-bottom:1px solid var(--line-ink-soft);
  margin:0 auto;
  max-width:min(var(--maxw), calc(100% - 40px));
}
.divider::after{
  content:"";
  position:absolute;
  left:50%;top:50%;
  width:7px;height:7px;
  background:var(--gold);
  transform:translate(-50%,-50%) rotate(45deg);
  box-shadow:0 0 0 7px var(--ground);
}

/* ---------- Full-bleed bands ---------- */
.band-parchment{
  position:relative;
  background:var(--parchment);
  border-top:1px solid var(--line-ink);
  border-bottom:1px solid var(--line-ink);
}
.band-parchment::before,
.band-parchment::after{
  content:"";
  position:absolute;left:0;right:0;height:1px;
  background:var(--line-ink-soft);
  pointer-events:none;
}
.band-parchment::before{top:4px;}
.band-parchment::after{bottom:4px;}

.band-ink{
  position:relative;
  background:var(--ink-deep);
  border-top:1px solid var(--gold-on-ink);
  border-bottom:1px solid var(--gold-on-ink);
  color:var(--ivory-on-ink);
}
.band-ink::before,
.band-ink::after{
  content:"";
  position:absolute;left:0;right:0;height:1px;
  background:var(--gold-on-ink-soft);
  pointer-events:none;
}
.band-ink::before{top:4px;}
.band-ink::after{bottom:4px;}
.band-ink h1,.band-ink h2,.band-ink h3{color:var(--ivory);}
.band-ink em.gold{color:var(--gold-bright);}
.band-ink .eyebrow{color:var(--gold-bright);}
.band-ink .eyebrow::before,
.band-ink .eyebrow::after{background:var(--gold-bright);}

/* ---------- Masthead — engraved letterhead ---------- */
.masthead{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(245,239,227,0.94);
  backdrop-filter:saturate(130%) blur(8px);
  -webkit-backdrop-filter:saturate(130%) blur(8px);
  border-bottom:1px solid var(--line-ink);
}
.masthead::after{
  content:"";
  position:absolute;left:0;right:0;bottom:3px;height:1px;
  background:var(--line-ink-soft);
  pointer-events:none;
}
.masthead .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding-top:0.85rem;
  padding-bottom:0.95rem;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:0.85rem;
  color:var(--ink);
}
.brand:hover{color:var(--ink);}
.monogram{
  flex:0 0 auto;
  width:42px;height:42px;
  border:1px solid var(--ink);
  position:relative;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);
  font-weight:600;
  font-size:1.18rem;
  letter-spacing:0.06em;
  color:var(--ink);
  background:var(--cream);
}
.monogram::after{
  content:"";
  position:absolute;inset:3px;
  border:1px solid var(--line-gold);
  pointer-events:none;
}
.wordmark{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(0.92rem, 2.2vw, 1.05rem);
  letter-spacing:0.22em;
  text-transform:uppercase;
  white-space:nowrap;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:clamp(1rem,2.6vw,2rem);
}
.nav-links a.navlink{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.7rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.nav-links a.navlink:hover{color:var(--gold-deep);}
.nav-links a.navlink[aria-current="page"]{
  color:var(--gold-deep);
  border-bottom:1px solid var(--line-gold);
  padding-bottom:0.3em;
}
.nav-links .btn{padding:0.72rem 1.3rem;font-size:0.66rem;}
@media (max-width:880px){
  .nav-links a.navlink{display:none;}
}
@media (max-width:560px){
  .wordmark{display:none;}
}

/* ---------- Buttons — engraved, squared ---------- */
.btn{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.74rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  border:1px solid transparent;
  cursor:pointer;
  border-radius:4px;
  padding:1rem 1.9rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.7rem;
  transition:background .18s ease, color .18s ease, border-color .18s ease;
  text-decoration:none;
  text-align:center;
  line-height:1.3;
}
.btn:active{transform:translateY(1px);}
.btn .arrow{font-family:var(--serif);font-size:1.05em;line-height:1;transition:transform .2s ease;}
.btn:hover .arrow{transform:translateX(3px);}

/* ink-solid */
.btn-ink{
  background:var(--ink);
  color:var(--ivory);
  border-color:var(--ink);
}
.btn-ink:hover{background:#2A2D36;color:var(--ivory);}

/* gold-ruled (light grounds) */
.btn-gold{
  background:transparent;
  color:var(--gold-deep);
  border-color:var(--gold);
}
.btn-gold:hover{background:rgba(169,119,46,0.09);color:var(--gold-deep);}

/* ivory-solid (on ink panels) */
.btn-ivory{
  background:var(--ivory);
  color:var(--ink);
  border-color:var(--ivory);
}
.btn-ivory:hover{background:#FFFBF0;color:var(--ink);}

/* gold-ruled (on ink panels) */
.btn-gold-dark{
  background:transparent;
  color:var(--gold-bright);
  border-color:var(--gold-on-ink);
}
.btn-gold-dark:hover{background:rgba(201,155,94,0.10);color:var(--gold-bright);}

/* secondary text link — small caps */
.text-link{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.72rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:0.55em;
  border-bottom:1px solid var(--line-gold);
  padding-bottom:0.35em;
}
.text-link .arrow{font-family:var(--serif);font-size:1.15em;line-height:1;transition:transform .2s ease;}
.text-link:hover{color:var(--gold);}
.text-link:hover .arrow{transform:translateX(3px);}

/* ---------- Section frame ---------- */
section{padding-block:clamp(3rem, 7vw, 5.2rem);}
.section-head{
  text-align:center;
  margin-bottom:clamp(2rem,4.5vw,3.2rem);
}
.section-head h2{
  font-size:clamp(1.95rem, 4.4vw, 2.9rem);
  max-width:24ch;
  margin-inline:auto;
}
.section-head .sub{
  font-size:clamp(1.02rem,2.1vw,1.16rem);
  color:var(--ink-soft);
  max-width:56ch;
  margin:1.1rem auto 0;
}

/* ---------- Centered stationery hero ---------- */
.hero-c{
  padding-top:clamp(3.2rem,7.5vw,5rem);
  padding-bottom:clamp(2.4rem,6vw,4rem);
  text-align:center;
}
.hero-c h1{
  font-size:clamp(2.45rem, 5.8vw, 4.3rem);
  max-width:19ch;
  margin:0 auto;
  line-height:1.05;
}
.hero-c .lede{
  font-size:clamp(1.05rem, 2.1vw, 1.24rem);
  color:var(--ink-soft);
  max-width:52ch;
  margin:clamp(1.2rem,3vw,1.6rem) auto 0;
}
.cta-row-c{
  margin-top:clamp(1.8rem, 4vw, 2.4rem);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:1.1rem 1.6rem;
}
.cred-line-c{
  margin:clamp(2rem,4.5vw,2.8rem) auto 0;
  padding-top:clamp(1.1rem,2.6vw,1.4rem);
  border-top:1px solid var(--line-ink-soft);
  max-width:56ch;
  font-size:0.92rem;
  line-height:1.6;
  color:var(--muted);
}
.cred-line-c strong{color:var(--ink-soft);font-weight:600;}

/* ---------- Plates — photographs framed like book plates ---------- */
.plate{
  margin:clamp(2.4rem,5.5vw,3.8rem) auto 0;
  max-width:540px;
}
.plate .mat{
  border:1px solid var(--line-ink);
  background:var(--cream);
  padding:clamp(10px,1.8vw,14px);
}
.plate .ph{
  border:1px solid var(--ink);
  overflow:hidden;
  background:var(--parchment);
}
.plate .ph img{
  width:100%;height:100%;
  object-fit:cover;
}
.plate figcaption{
  margin-top:0.95rem;
  text-align:center;
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:clamp(1.02rem,2vw,1.18rem);
  color:var(--ink-soft);
  line-height:1.5;
}
.plate.ratio-45 .ph{aspect-ratio:4/5;}
.plate.ratio-45 .ph img{object-position:50% 28%;}
.plate.ratio-56 .ph{aspect-ratio:5/6;}
.plate.ratio-56 .ph img{object-position:50% 38%;}

/* ---------- Cameo — engraved oval portrait ---------- */
.cameo-frame{
  width:fit-content;
  margin:0 auto;
  border:1px solid var(--line-ink);
  border-radius:50%;
  padding:10px;
  background:var(--cream);
}
.cameo{
  width:clamp(170px, 26vw, 216px);
  aspect-ratio:4/5;
  border-radius:50%;
  overflow:hidden;
  border:1px solid var(--ink);
}
.cameo img{width:100%;height:100%;object-fit:cover;object-position:50% 20%;}

/* ---------- Trust bar (parchment) ---------- */
.trustbar{padding-block:clamp(1.5rem,3.4vw,2.1rem);}
.trustbar .wrap{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:0.9rem clamp(1.6rem,4vw,3.2rem);
}
.trustbar .ts{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(0.66rem,1.5vw,0.74rem);
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:inline-flex;
  align-items:center;
  gap:0.8rem;
  white-space:nowrap;
}
.trustbar .ts::before{
  content:"";
  width:5px;height:5px;
  background:var(--gold);
  transform:rotate(45deg);
  display:inline-block;
  flex:0 0 auto;
}

/* ---------- Two paths — centered cards ---------- */
.paths{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(1.2rem,3vw,1.8rem);
  align-items:stretch;
}
@media (max-width:760px){ .paths{grid-template-columns:1fr;max-width:560px;margin-inline:auto;} }
.path{
  position:relative;
  border-radius:6px;
  padding:clamp(2.2rem,4.6vw,3.1rem) clamp(1.6rem,3.6vw,2.6rem);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}
.path > *{position:relative;z-index:1;}
.path .p-num{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:1.5rem;line-height:1;margin-bottom:1rem;
}
.path h2,.path h3{font-size:clamp(1.5rem,3vw,1.95rem);margin-bottom:0.75rem;}
.path p{margin:0 0 1.7rem;font-size:1.02rem;max-width:38ch;}
.path .p-cta{margin-top:auto;}
/* variant: vertically centered card (contact page ink panel) */
.path.path-center{justify-content:center;}
.path.path-center .p-cta{margin-top:0;}
.path .p-note{
  font-size:0.68rem;letter-spacing:0.24em;text-transform:uppercase;
  margin:1.2rem 0 0;
}
.path .p-tag{
  font-family:var(--sans);font-weight:600;
  font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;
  padding:0.42rem 0.95rem 0.36rem;
  border-radius:3px;
  margin-bottom:1.3rem;
}
/* Card A — deep-ink report cover */
.path-ink{
  background:var(--ink-deep);
  border:1px solid var(--gold-on-ink);
  color:var(--ivory-on-ink);
}
.path-ink::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--gold-on-ink-soft);
  pointer-events:none;
  z-index:0;
}
.path-ink .p-num{color:var(--gold-bright);}
.path-ink h2,.path-ink h3{color:var(--ivory);}
.path-ink p{color:var(--ivory-on-ink);}
.path-ink .p-note{color:rgba(245,239,227,0.6);}
.path-ink .p-tag{
  color:var(--gold-bright);
  border:1px solid var(--gold-on-ink);
}
/* Card B — cream stationery */
.path-light{
  background:var(--cream);
  border:1px solid var(--line-ink);
}
.path-light::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--line-ink-soft);
  pointer-events:none;
  z-index:0;
}
.path-light .p-num{color:var(--gold-deep);}
.path-light p{color:var(--ink-soft);}

/* ---------- Vision band (parchment pull-quote) ---------- */
.vision{text-align:center;}
.vision .mark{
  font-family:var(--serif);
  font-style:italic;
  font-weight:600;
  font-size:clamp(3rem, 6.5vw, 4.4rem);
  line-height:0.6;
  color:var(--gold);
  display:block;
  margin:0 0 1.1rem;
}
.vision .line{
  font-family:var(--serif);
  font-size:clamp(1.6rem, 3.6vw, 2.4rem);
  line-height:1.38;
  color:var(--ink);
  font-weight:500;
  margin:0.4rem auto 0;
  max-width:28ch;
}
.vision .stars{
  color:var(--gold);font-size:0.92rem;letter-spacing:0.3em;margin:1.5rem 0 0.5rem;
}
.vision figcaption{font-family:var(--sans);margin-top:0.8rem;}
.vision figcaption .name{
  display:block;font-weight:600;font-size:0.78rem;
  letter-spacing:0.26em;text-transform:uppercase;color:var(--ink);
}
.vision figcaption .role{
  display:block;font-size:0.82rem;letter-spacing:0.05em;color:var(--muted);margin-top:0.3rem;
}

/* ---------- Centered content block (about / results) ---------- */
.centered-block{text-align:center;}
.centered-block h2{
  font-size:clamp(1.95rem,4.4vw,2.9rem);
  max-width:22ch;
  margin:0 auto 1.1rem;
}
.centered-block .body-copy{
  font-size:clamp(1.05rem, 2.1vw, 1.18rem);
  color:var(--ink-soft);
  max-width:58ch;
  margin:0 auto 1.7rem;
}
.centered-block .cta-row-c{margin-top:0.4rem;}

/* stat — ledger numeral */
.stat-c{margin:clamp(1.6rem,3.6vw,2.2rem) auto;}
.stat-c .big{
  display:block;
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(3rem,7.5vw,4.6rem);
  color:var(--gold-deep);
  line-height:1;
}
.stat-c .lbl{
  display:block;
  margin-top:0.8rem;
  font-family:var(--sans);font-weight:600;
  font-size:0.7rem;letter-spacing:0.28em;
  color:var(--muted);text-transform:uppercase;
  line-height:1.7;
}

/* ---------- Testimonial quote cards ---------- */
.quotes{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(1.2rem,2.6vw,1.8rem);
}
@media (max-width:900px){ .quotes{grid-template-columns:1fr 1fr;} }
@media (max-width:620px){ .quotes{grid-template-columns:1fr;max-width:520px;margin-inline:auto;} }
.quote{
  position:relative;
  background:var(--cream);
  border:1px solid var(--line-ink);
  border-radius:6px;
  padding:clamp(1.9rem,3.6vw,2.5rem) clamp(1.4rem,3vw,2rem);
  display:flex;flex-direction:column;
  text-align:center;
}
.quote > *{position:relative;z-index:1;}
.quote::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--line-ink-soft);
  pointer-events:none;
  z-index:0;
}
.quote .mark{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:2.8rem;line-height:0.6;color:var(--gold);
  margin-bottom:0.7rem;
}
.quote .stars{
  color:var(--gold);font-size:0.8rem;letter-spacing:0.28em;margin-bottom:1rem;
}
.quote blockquote{
  margin:0 0 1.5rem;
  font-family:var(--serif);
  font-size:clamp(1.18rem,2.4vw,1.34rem);
  line-height:1.42;
  color:var(--ink);
  font-weight:500;
}
.quote .attr{
  margin-top:auto;
  padding-top:1.05rem;
  border-top:1px solid var(--line-ink-soft);
  display:flex;flex-direction:column;gap:0.3rem;
}
.quote .attr .name{
  font-family:var(--sans);font-weight:600;
  font-size:0.74rem;letter-spacing:0.26em;text-transform:uppercase;
  color:var(--ink);
}
.quote .attr .role{
  font-family:var(--sans);font-size:0.8rem;letter-spacing:0.05em;color:var(--muted);
}

/* ---------- Stats strip (parchment ledger) ---------- */
.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(1.8rem,4vw,2.4rem);
  text-align:center;
}
@media (max-width:760px){ .stats-grid{grid-template-columns:1fr;gap:2.4rem;} }
.stat-item .num{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.3rem,5.4vw,3.3rem);
  color:var(--gold-deep);line-height:1;
  display:block;
}
.stat-item .cap{
  font-family:var(--sans);font-weight:600;
  font-size:0.68rem;letter-spacing:0.24em;
  color:var(--muted);
  text-transform:uppercase;
  margin:0.85rem auto 0;
  line-height:1.8;
  display:block;
  max-width:24ch;
}

/* ---------- Deep-ink report bands (join / closing CTA) ---------- */
.report-band{
  text-align:center;
  padding-block:clamp(3.4rem,7.5vw,5.6rem);
}
.report-band .medallion{
  width:52px;height:52px;
  margin:0 auto 1.6rem;
  border:1px solid var(--gold-on-ink);
  position:relative;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);
  font-weight:600;
  font-size:1.35rem;
  letter-spacing:0.06em;
  color:var(--gold-bright);
}
.report-band .medallion::after{
  content:"";
  position:absolute;inset:4px;
  border:1px solid var(--gold-on-ink-soft);
  pointer-events:none;
}
.report-band h2{
  font-size:clamp(2rem, 4.8vw, 3.1rem);
  max-width:20ch;
  margin:0 auto 0.8rem;
}
.report-band .band-sub{
  font-family:var(--sans);
  color:var(--ivory-on-ink);
  font-size:clamp(1rem,2.1vw,1.1rem);
  line-height:1.6;
  margin:0 auto 2.1rem;
  max-width:52ch;
}
.report-band .cta-row-c{margin-top:0;}
.report-band .reassure{
  margin:1.8rem auto 0;
  font-size:0.66rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:rgba(245,239,227,0.55);
}

/* join form on ink */
.join-form{
  display:flex;
  gap:0.8rem;
  max-width:640px;
  margin:0 auto;
  flex-wrap:wrap;
}
.field{
  flex:1 1 200px;
  text-align:left;
  position:relative;
}
.field label{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.field input{
  width:100%;
  font-family:var(--sans);
  font-size:0.98rem;
  color:var(--ivory);
  background:rgba(245,239,227,0.05);
  border:1px solid var(--gold-on-ink-soft);
  border-radius:4px;
  padding:0.95rem 1.2rem;
  transition:border-color .2s ease, background .2s ease;
}
.field input::placeholder{color:rgba(245,239,227,0.5);}
.field input:focus{
  outline:none;
  border-color:var(--gold-bright);
  background:rgba(245,239,227,0.09);
  box-shadow:0 0 0 3px rgba(201,155,94,0.22);
}
.join-form .btn{flex:0 0 auto;}
@media (max-width:600px){
  .join-form .btn{width:100%;}
}
.form-msg{
  margin:1rem auto 0;
  min-height:1.2em;
  font-size:0.9rem;
  color:var(--gold-bright);
  letter-spacing:0.02em;
}
.form-msg[data-state="warn"]{color:#E8C48D;}

/* ---------- Story prose (about page) — drop cap ---------- */
.prose{
  max-width:62ch;
  margin:0 auto;
  text-align:left;
}
.prose p{
  font-size:clamp(1.03rem,2.1vw,1.15rem);
  color:var(--ink-soft);
  line-height:1.78;
  margin:0 0 1.35rem;
}
.prose p:last-child{margin-bottom:0;}
.prose > p:first-of-type::first-letter{
  font-family:var(--serif);
  font-weight:500;
  font-size:3.6em;
  float:left;
  line-height:0.78;
  padding:0.08em 0.14em 0 0;
  color:var(--gold-deep);
}

/* ---------- Approach principles ---------- */
.principles{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(1.2rem,2.6vw,1.8rem);
}
@media (max-width:760px){ .principles{grid-template-columns:1fr;max-width:560px;margin-inline:auto;} }
.principle{
  position:relative;
  background:var(--cream);
  border:1px solid var(--line-ink);
  border-radius:6px;
  padding:clamp(1.9rem,3.6vw,2.5rem) clamp(1.5rem,3vw,2.1rem);
  text-align:center;
}
.principle > *{position:relative;z-index:1;}
.principle::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--line-ink-soft);
  pointer-events:none;
  z-index:0;
}
.principle .p-icon{
  width:46px;height:46px;
  border-radius:50%;
  border:1px solid var(--line-gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);
  margin:0 auto 1.15rem;
}
.principle .p-icon svg{width:20px;height:20px;}
.principle h3{font-size:clamp(1.3rem,2.6vw,1.6rem);margin-bottom:0.55rem;}
.principle p{margin:0 auto;font-size:0.99rem;color:var(--ink-soft);line-height:1.6;max-width:40ch;}

/* ---------- Who I help ---------- */
.who-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(1.2rem,2.6vw,1.8rem);
}
@media (max-width:820px){ .who-list{grid-template-columns:1fr;max-width:560px;margin-inline:auto;} }
.who{
  position:relative;
  border:1px solid var(--line-ink);
  border-radius:6px;
  padding:clamp(1.8rem,3.4vw,2.3rem) clamp(1.4rem,3vw,1.9rem);
  background:var(--cream);
  text-align:center;
}
.who > *{position:relative;z-index:1;}
.who::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--line-ink-soft);
  pointer-events:none;
  z-index:0;
}
.who .w-num{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:1.35rem;line-height:1;color:var(--gold-deep);margin-bottom:0.85rem;
}
.who h3{font-size:clamp(1.25rem,2.5vw,1.5rem);margin-bottom:0.5rem;}
.who p{margin:0 auto;font-size:0.97rem;color:var(--ink-soft);line-height:1.6;max-width:34ch;}

/* ---------- Contact form (light) ---------- */
.contact-section{padding-top:clamp(1rem,3vw,2rem);}
.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
  text-align:left;
  width:100%;
}
.form-field{display:flex;flex-direction:column;gap:0.45rem;}
.form-field label{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.68rem;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.form-field .req{color:var(--gold-deep);}
.form-field input,
.form-field textarea{
  width:100%;
  font-family:var(--sans);
  font-size:0.98rem;
  color:var(--ink);
  background:rgba(255,255,255,0.65);
  border:1px solid var(--line-ink);
  border-radius:4px;
  padding:0.85rem 1.05rem;
  transition:border-color .2s ease, background .2s ease;
}
.form-field textarea{
  resize:vertical;
  min-height:130px;
  line-height:1.5;
}
.form-field input::placeholder,
.form-field textarea::placeholder{color:var(--muted);opacity:0.7;}
.form-field input:focus,
.form-field textarea:focus{
  outline:none;
  border-color:var(--gold);
  background:#FFFDF6;
  box-shadow:0 0 0 3px rgba(169,119,46,0.16);
}
.form-field input[aria-invalid="true"],
.form-field textarea[aria-invalid="true"]{
  border-color:#A4401C;
  box-shadow:0 0 0 3px rgba(164,64,28,0.16);
}
.contact-form .btn{align-self:center;margin-top:0.3rem;}
@media (max-width:520px){
  .contact-form .btn{width:100%;align-self:stretch;}
}
.contact-form .form-msg{
  margin:0.4rem 0 0;
  color:var(--gold-deep);
  text-align:center;
}
.contact-form .form-msg[data-state="warn"]{color:#A4401C;}
.contact-form .form-msg[data-state="ok"]{color:var(--gold-deep);font-weight:600;}

/* ---------- Direct contact block ---------- */
.direct{
  margin-top:clamp(2.5rem,5vw,3.5rem);
  position:relative;
  border:1px solid var(--line-ink);
  border-radius:6px;
  background:var(--parchment);
  padding:clamp(2rem,4.4vw,2.8rem);
  text-align:center;
}
.direct > *{position:relative;z-index:1;}
.direct::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--line-ink-soft);
  pointer-events:none;
  z-index:0;
}
.direct .eyebrow{margin-bottom:1rem;}
.direct .email-line{
  font-family:var(--serif);
  font-size:clamp(1.5rem,3.6vw,2.1rem);
  font-weight:600;
  margin:0 0 0.6rem;
  color:var(--ink);
}
.direct .email-line a{color:var(--gold-deep);}
.direct .email-line a:hover{color:var(--gold);}
.direct .response{
  margin:0;
  font-size:0.95rem;
  color:var(--muted);
}

/* ---------- Legal document layout ---------- */
.legal-hero{
  padding-top:clamp(2.8rem,6vw,4.2rem);
  padding-bottom:clamp(1.4rem,3vw,2rem);
  text-align:center;
}
.legal-hero h1{
  font-size:clamp(2.2rem,5.4vw,3.4rem);
  max-width:20ch;
  margin:0 auto;
}
.legal-hero .updated{
  margin:1.3rem auto 0;
  font-size:0.72rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);
  max-width:52ch;
  line-height:1.9;
}
.legal{
  padding-top:clamp(1.4rem,3vw,2rem);
  padding-bottom:clamp(3.5rem,8vw,6rem);
}
.legal-doc{
  max-width:70ch;
  margin:0 auto;
}
.legal-doc h2{
  font-size:clamp(1.5rem,3.4vw,2.05rem);
  margin:clamp(2.2rem,5vw,3rem) 0 0.9rem;
  line-height:1.14;
}
.legal-doc h2:first-of-type{margin-top:0;}
.legal-doc h3{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.8rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink);
  margin:1.7rem 0 0.5rem;
}
.legal-doc p{
  font-size:clamp(1rem,2vw,1.06rem);
  color:var(--ink-soft);
  margin:0 0 1.1rem;
  line-height:1.75;
  overflow-wrap:anywhere;
}
.legal-doc ul{
  margin:0 0 1.1rem;
  padding-left:1.4rem;
  color:var(--ink-soft);
  font-size:clamp(1rem,2vw,1.06rem);
  line-height:1.75;
}
.legal-doc li{margin:0 0 0.5rem;}
.legal-doc strong{color:var(--ink);font-weight:600;}

/* ---------- Footer — letterhead colophon ---------- */
footer{
  position:relative;
  border-top:1px solid var(--line-ink);
  padding-block:clamp(2.6rem,5.5vw,3.6rem) clamp(2.2rem,5vw,3rem);
  text-align:center;
}
footer::before{
  content:"";
  position:absolute;left:0;right:0;top:3px;height:1px;
  background:var(--line-ink-soft);
}
footer .foot-monogram{
  width:48px;height:48px;
  margin:0 auto 0.9rem;
  border:1px solid var(--ink);
  position:relative;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);
  font-weight:600;
  font-size:1.25rem;
  letter-spacing:0.06em;
  color:var(--ink);
  background:var(--cream);
}
footer .foot-monogram::after{
  content:"";
  position:absolute;inset:3px;
  border:1px solid var(--line-gold);
  pointer-events:none;
}
footer .foot-wordmark{
  font-family:var(--serif);
  font-weight:600;
  font-size:0.95rem;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--ink);
  margin:0 0 1.6rem;
}
footer .foot-nav{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:0.7rem clamp(1.2rem,3vw,2rem);
  margin-bottom:1.4rem;
}
footer .foot-nav a{
  font-family:var(--sans);font-weight:600;
  font-size:0.66rem;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--ink-soft);
}
footer .foot-nav a:hover{color:var(--gold-deep);}
footer .foot-reach{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:0.5rem clamp(1.2rem,3vw,2rem);
  margin-bottom:1.6rem;
}
footer .foot-reach a{
  font-family:var(--sans);font-weight:600;
  font-size:0.82rem;letter-spacing:0.05em;color:var(--gold-deep);
}
footer .disclaimer{
  font-style:italic;
  font-family:var(--serif);
  font-size:1.08rem;
  color:var(--ink-soft);
  margin:0 0 0.6rem;
}
footer .fine{
  font-size:0.78rem;color:var(--muted);margin:0 auto 1rem;line-height:1.6;
  max-width:88ch;
}
footer .copy{
  font-size:0.66rem;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0;
}

/* ============================================================
   Funnel pages (free-training / training), in the maison grammar
   ============================================================ */

/* ---------- Opt-in squeeze card (free training) ---------- */
.optin-card{
  position:relative;
  background:var(--cream);
  border:1px solid var(--line-ink);
  border-radius:6px;
  padding:clamp(2rem,4.4vw,2.8rem) clamp(1.6rem,3.6vw,2.4rem);
  max-width:560px;
  margin:clamp(2.4rem,5vw,3.4rem) auto 0;
  text-align:center;
}
.optin-card > *{position:relative;z-index:1;}
.optin-card::after{
  content:"";
  position:absolute;inset:7px;
  border:1px solid var(--line-ink-soft);
  pointer-events:none;
  z-index:0;
}
.optin-card h2{font-size:clamp(1.5rem,3vw,1.95rem);margin-bottom:0.6rem;}
.optin-card > p{margin:0 auto 1.5rem;font-size:1rem;color:var(--ink-soft);max-width:38ch;}
.optin-card .reassure{
  margin:1.3rem 0 0;
  font-size:0.64rem;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ---------- Benefits list (what you'll learn) ---------- */
.benefits{
  list-style:none;
  margin:0 auto;
  padding:0;
  border-top:1px solid var(--line-ink-soft);
  max-width:640px;
  text-align:left;
}
.benefits li{
  display:flex;
  gap:clamp(1rem,2.5vw,1.5rem);
  align-items:flex-start;
  padding:clamp(1.2rem,2.8vw,1.6rem) 0;
  border-bottom:1px solid var(--line-ink-soft);
}
.benefits .tick{
  flex:0 0 auto;
  width:34px;height:34px;
  border-radius:50%;
  border:1px solid var(--line-gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);
  margin-top:0.2rem;
}
.benefits .tick svg{width:15px;height:15px;}
.benefits .b-text{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 2.5vw, 1.45rem);
  font-weight:500;
  color:var(--ink);
  line-height:1.35;
}

/* ---------- Video player plate (training delivery) ---------- */
.player-plate{
  max-width:880px;
  margin:0 auto;
}
.player-plate .mat{
  border:1px solid var(--line-ink);
  background:var(--cream);
  padding:clamp(10px,1.8vw,14px);
}
.player-plate .ph{border:1px solid var(--ink);}
video.native{
  width:100%;height:auto;display:block;
  background:var(--ink-deep);
}

/* ---------- Video testimonial plates ---------- */
.video-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(1.4rem,3vw,2rem);
}
@media (max-width:760px){ .video-grid{grid-template-columns:1fr;max-width:560px;margin-inline:auto;} }
.video-card{
  margin:0;
  display:flex;flex-direction:column;
}
.video-card .mat{
  border:1px solid var(--line-ink);
  background:var(--cream);
  padding:clamp(9px,1.6vw,12px);
}
.yt{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:var(--ink-deep);
  overflow:hidden;
  border:1px solid var(--ink);
}
.yt iframe{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;
}
.video-card figcaption{padding:1.05rem 0.4rem 0.3rem;text-align:center;}
.video-card .v-quote{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.08rem,2.2vw,1.26rem);
  line-height:1.45;
  color:var(--ink);
  font-weight:500;
  margin:0 auto 0.85rem;
  max-width:44ch;
}
.video-card .v-name{
  display:block;
  font-family:var(--sans);
  font-size:0.68rem;
  font-weight:600;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:var(--muted);
  border-top:1px solid var(--line-ink-soft);
  padding-top:0.85rem;
  max-width:340px;
  margin:0 auto;
}

/* ---------- Entrance motion ---------- */
.reveal{
  opacity:0;
  transform:translateY(16px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .btn,.btn *,.text-link .arrow{transition:none;}
}
