/* ============================================================
   WEALTHY NOMADS — Design direction A2 · "Gallery"
   A full-site restyle of the approved design-A content in the
   same warm/light/premium family, at its most refined & minimal:
   Mayfair-gallery restraint. Near-white grounds, ink typography,
   gold worn like jewellery — 1px hairlines, tiny markers, eyebrow
   labels, thin button borders. No shadows anywhere: separation is
   hairline (#E6E2D9) and whitespace only. Photography hangs in
   exact hairline frames with italic wall-label captions; one gold
   offset frame per page at most. Content is design-A's, 1:1.
   ============================================================ */

:root{
  --bg:#FCFBF8;            /* near-white gallery wall */
  --band:#F7F5F0;          /* whisper band */
  --panel:#FFFFFF;         /* mat white */
  --ink:#191A1C;
  --ink-soft:#45464B;
  --muted:#726F66;
  --gold:#A9772E;          /* jewellery gold — hairlines, markers, borders */
  --gold-deep:#8A6026;     /* AA-legible gold for small text on light */
  --gold-ink:#C9A566;      /* gold for text on ink */
  --hairline:#E6E2D9;
  --hairline-mid:#D9D4C7;  /* frame hairline, a breath darker */
  --ink-hairline:rgba(255,255,255,0.16);

  --maxw:1060px;
  --r:6px;                 /* squared-ish */
  --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(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:0.875rem;                /* 14px — small and precise */
  font-weight:400;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

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(22px, 6vw, 56px);
}

/* skip link */
.skip{
  position:absolute;left:-999px;top:0;z-index:100;
  background:var(--panel);color:var(--gold-deep);
  padding:0.7rem 1.2rem;border:1px solid var(--hairline);
  font-weight:600;
}
.skip:focus{left:0;}

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

/* ---------- Eyebrow label — tracked wide, gold ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.64rem;
  letter-spacing:0.34em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin:0 0 1.4rem;
  display:inline-flex;
  align-items:center;
  gap:0.9em;
}
.eyebrow::before{
  content:"";
  width:30px;height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.center{justify-content:center;}
.eyebrow.center.flanked::after{
  content:"";
  width:30px;height:1px;
  background:var(--gold);
  display:inline-block;
}

/* ---------- Serif display — large scale contrast ---------- */
h1,h2,h3{
  font-family:var(--serif);
  font-weight:500;
  color:var(--ink);
  margin:0;
  line-height:1.06;
  letter-spacing:-0.012em;
}
em.gold{
  font-style:italic;
  color:var(--gold-deep);
  font-weight:500;
}

.hairline{
  border:0;height:1px;background:var(--hairline);margin:0;
}

/* ---------- Masthead ---------- */
.masthead{
  border-bottom:1px solid var(--hairline);
  background:rgba(252,251,248,0.92);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  position:sticky;
  top:0;
  z-index:50;
}
.masthead .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding-top:1.05rem;
  padding-bottom:1.05rem;
}
.brand{
  font-family:var(--serif);
  font-weight:500;
  font-size:1.28rem;
  letter-spacing:0.02em;
  color:var(--ink);
  display:flex;
  align-items:baseline;
  gap:0.55rem;
}
.brand:hover{color:var(--ink);}
.brand .dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--gold);
  display:inline-block;
  transform:translateY(-3px);
}
.nav-links{
  display:flex;
  align-items:center;
  gap:clamp(1.1rem,3vw,2.3rem);
}
.nav-links a.navlink{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.66rem;
  letter-spacing:0.22em;
  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(--gold);
  padding-bottom:0.3em;
}
.nav-links .btn{padding:0.72em 1.6em;}
@media (max-width:820px){
  .nav-links a.navlink{display:none;}
}
@media (max-width:480px){
  .brand{font-size:1.05rem;white-space:nowrap;}
  .nav-links .btn{padding:0.75em 1.1em;font-size:0.58rem;letter-spacing:0.16em;white-space:nowrap;}
}

/* ---------- Buttons — outlined or ink-solid, gold on hover ---------- */
.btn{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.7rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  cursor:pointer;
  border-radius:var(--r);
  padding:1em 2.2em;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.7em;
  border:1px solid transparent;
  transition:color .2s ease, background .2s ease, border-color .2s ease;
  text-decoration:none;
  line-height:1.2;
}
.btn:active{transform:translateY(1px);}
.btn .arrow{transition:transform .2s ease;font-size:1.05em;}
.btn:hover .arrow{transform:translateX(4px);}

/* ink-solid — gold hover */
.btn-solid{
  background:var(--ink);
  border-color:var(--ink);
  color:#FCFBF8;
}
.btn-solid:hover{
  color:var(--gold-ink);
  border-color:var(--gold);
  background:var(--ink);
}

/* thin gold border on light grounds */
.btn-outline{
  background:transparent;
  border-color:var(--gold);
  color:var(--ink);
}
.btn-outline:hover{
  background:var(--ink);
  border-color:var(--ink);
  color:#FCFBF8;
}

/* thin gold border on ink grounds */
.btn-invert{
  background:transparent;
  border-color:rgba(201,165,102,0.65);
  color:var(--gold-ink);
}
.btn-invert:hover{
  background:var(--gold-ink);
  border-color:var(--gold-ink);
  color:var(--ink);
}

/* secondary text link — tracked, hairline underline */
.text-link{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.7rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:0.6em;
  border-bottom:1px solid var(--hairline-mid);
  padding-bottom:0.45em;
}
.text-link .arrow{transition:transform .2s ease;}
.text-link:hover{color:var(--gold);border-bottom-color:var(--gold);}
.text-link:hover .arrow{transform:translateX(4px);}

/* ---------- Section frame — more air than design A ---------- */
section{padding-block:clamp(4.5rem, 10vw, 8rem);}
.band{
  background:var(--band);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
}
.section-head{margin-bottom:clamp(2.6rem,6vw,4.2rem);}
.section-head h2{
  font-size:clamp(2rem, 5vw, 3.4rem);
  max-width:20ch;
}
.section-head.center{text-align:center;}
.section-head.center h2{margin-inline:auto;}
.section-head.center .eyebrow{justify-content:center;}
.section-head.center .sub{
  font-size:0.95rem;
  color:var(--ink-soft);
  max-width:52ch;
  margin:1.4rem auto 0;
  line-height:1.8;
}

/* ---------- Hanging works — photos framed like a gallery ---------- */
.work{
  position:relative;
  background:var(--panel);
  border:1px solid var(--hairline-mid);
  padding:clamp(10px, 1.8vw, 18px);   /* the mat */
}
.work img{width:100%;height:100%;object-fit:cover;}
/* the one gold offset frame per page */
.work--gold::after{
  content:"";
  position:absolute;
  inset:-11px;
  border:1px solid var(--gold);
  pointer-events:none;
}
/* wall label */
.work-label{
  margin-top:1.1rem;
  font-family:var(--serif);
  font-style:italic;
  font-size:0.92rem;
  color:var(--muted);
  line-height:1.5;
  letter-spacing:0.01em;
}
.work-label .wl-m{
  font-style:italic;
  color:var(--gold-deep);
  margin-right:0.7em;
}
.work-label .wl-strong{
  font-family:var(--sans);
  font-style:normal;
  font-weight:600;
  font-size:0.62rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-right:0.8em;
}

/* ---------- Home hero — exhibition title wall ---------- */
.hero-center{
  text-align:center;
  padding-top:clamp(4rem,9vw,6.5rem);
  padding-bottom:clamp(4rem,9vw,6.5rem);
}
.hero-center h1{
  font-size:clamp(2.8rem, 7.4vw, 5.6rem);
  line-height:1.04;
  max-width:17ch;
  margin:0 auto;
}
.hero-center .subhead{
  font-size:0.95rem;
  color:var(--ink-soft);
  max-width:42ch;
  margin:clamp(1.6rem,3.4vw,2.2rem) auto 0;
  line-height:1.8;
}
.hero-center .cta-row{
  margin-top:clamp(2rem, 4.5vw, 2.8rem);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:1.3rem 2rem;
}
.hero-center .cred-line{
  margin:clamp(2.2rem,5vw,3.2rem) auto 0;
  padding-top:1.4rem;
  border-top:1px solid var(--hairline);
  max-width:44ch;
  font-size:0.78rem;
  line-height:1.7;
  color:var(--muted);
}
.hero-center .cred-line p{margin:0;}
.hero-center .cred-line strong{color:var(--ink);font-weight:600;}
.hanging{
  margin:clamp(3rem,7vw,4.8rem) auto 0;
  max-width:480px;
  text-align:center;
}
.hanging .work{aspect-ratio:4/5;}
.hanging .work img{aspect-ratio:auto;height:100%;}

/* ---------- Split hero (about / free-training) ---------- */
.hero{padding-top:clamp(3.4rem,8vw,5.4rem);padding-bottom:clamp(3.4rem,8vw,5.4rem);}
.hero-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:clamp(2.4rem,6vw,4.8rem);
  align-items:center;
}
.hero h1{
  font-size:clamp(2.3rem, 5.4vw, 4rem);
  max-width:17ch;
}
.hero .subhead{
  font-size:0.95rem;
  color:var(--ink-soft);
  max-width:46ch;
  margin:clamp(1.4rem,3vw,1.9rem) 0 0;
  line-height:1.8;
}
.hero .cta-row{
  margin-top:clamp(1.8rem, 4vw, 2.5rem);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:1.3rem 2rem;
}
.cred-line{
  margin-top:clamp(1.8rem,4vw,2.6rem);
  padding-top:1.4rem;
  border-top:1px solid var(--hairline);
  max-width:46ch;
}
.cred-line p{
  margin:0;
  font-size:0.78rem;
  line-height:1.7;
  color:var(--muted);
}
.cred-line p strong{color:var(--ink);font-weight:600;}
.hero-figure{
  margin:0;
  max-width:400px;
  justify-self:end;
  width:100%;
}
.hero-figure .work{aspect-ratio:4/5;}
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;}
  .hero h1{max-width:20ch;}
  .hero-figure{max-width:400px;justify-self:center;margin-inline:auto;order:-1;}
}

/* ---------- Page hero (centred, interior pages) ---------- */
.page-hero{
  padding-top:clamp(3.6rem,8vw,5.6rem);
  padding-bottom:clamp(2.4rem,6vw,4rem);
  text-align:center;
}
.page-hero .eyebrow{justify-content:center;}
.page-hero h1{
  font-size:clamp(2.6rem, 6.4vw, 4.8rem);
  max-width:18ch;
  margin:0 auto;
}
.page-hero .subhead{
  font-size:0.95rem;
  color:var(--ink-soft);
  max-width:52ch;
  margin:clamp(1.5rem,3.4vw,2.1rem) auto 0;
  line-height:1.8;
}

/* ---------- Trust bar — hairline registry ---------- */
.trustbar{
  background:var(--band);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  padding-block:clamp(1.5rem,3.6vw,2.1rem);
}
.trustbar .wrap{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:0.9rem 0;
}
.trustbar .ts{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.64rem;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--ink-soft);
  white-space:nowrap;
  padding-inline:clamp(1.2rem,3.4vw,2.6rem);
  display:inline-flex;
  align-items:center;
}
.trustbar .ts + .ts{border-left:1px solid var(--hairline-mid);}
@media (max-width:700px){
  .trustbar .wrap{flex-direction:column;gap:0.85rem;}
  .trustbar .ts + .ts{border-left:0;}
}

/* ---------- Two paths ---------- */
.paths{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(1.4rem,3.4vw,2.2rem);
  align-items:stretch;
}
@media (max-width:760px){ .paths{grid-template-columns:1fr;} }
.path{
  position:relative;
  border-radius:2px;
  padding:clamp(2.2rem,5vw,3.2rem);
  display:flex;
  flex-direction:column;
}
.path .p-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  line-height:1;
  color:var(--gold-deep);
  margin-bottom:1.4rem;
  display:block;
}
.path .p-num::after{
  content:"";
  display:block;
  width:26px;height:1px;
  background:var(--gold);
  margin-top:0.9rem;
}
.path h2,.path h3{font-size:clamp(1.6rem,3.4vw,2.15rem);margin-bottom:0.9rem;font-weight:500;}
.path p{margin:0 0 2rem;font-size:0.875rem;color:var(--ink-soft);line-height:1.75;max-width:38ch;}
.path .p-cta{margin-top:auto;}
/* Card A — flat ink block */
.path-a{
  background:var(--ink);
  border:1px solid var(--ink);
}
.path-a .p-num{color:var(--gold-ink);}
.path-a .p-num::after{background:var(--gold-ink);}
.path-a h2,.path-a h3{color:#FCFBF8;}
.path-a p{color:rgba(252,251,248,0.72);}
.path-a .p-note{
  font-size:0.62rem;letter-spacing:0.22em;text-transform:uppercase;
  color:rgba(252,251,248,0.55);margin:1.4rem 0 0;
}
.path-a .p-tag{
  position:absolute;top:1.6rem;right:1.6rem;
  font-family:var(--sans);font-weight:600;
  font-size:0.56rem;letter-spacing:0.26em;text-transform:uppercase;
  color:var(--gold-ink);
  border:1px solid rgba(201,165,102,0.5);
  padding:0.42em 0.9em;border-radius:2px;
}
/* Card B — white vitrine */
.path-b{
  background:var(--panel);
  border:1px solid var(--hairline-mid);
}

/* ---------- Feature band — typographic, between gold rules ---------- */
.feature-band{
  text-align:center;
  padding-block:clamp(1rem,2vw,1.6rem);
}
.feature-band::before,
.feature-band::after{
  content:"";
  display:block;
  width:72px;height:1px;
  background:var(--gold);
  margin:0 auto;
}
.feature-band::before{margin-bottom:clamp(2.2rem,5vw,3.2rem);}
.feature-band::after{margin-top:clamp(2.2rem,5vw,3.2rem);}
.feature-band p,
.feature-band blockquote{
  font-family:var(--serif);
  font-size:clamp(1.7rem, 4vw, 2.8rem);
  line-height:1.35;
  color:var(--ink);
  font-weight:500;
  margin:0.4rem auto 0;
  max-width:26ch;
}
.feature-band .stars{
  color:var(--gold);font-size:0.8rem;letter-spacing:0.34em;margin:1.8rem 0 0.4rem;
}
.feature-band figcaption{
  font-family:var(--sans);
  margin-top:1rem;
}
.feature-band figcaption .name{
  display:block;font-weight:600;font-size:0.66rem;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);
}
.feature-band figcaption .role{
  display:block;
  font-family:var(--serif);font-style:italic;
  font-size:0.9rem;color:var(--muted);margin-top:0.4rem;
}

/* ---------- About block (home) ---------- */
.about{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(2.2rem, 6vw, 4.4rem);
  align-items:center;
}
.about .headshot{
  width:clamp(180px, 26vw, 250px);
  margin:0;
}
.about .headshot .work{aspect-ratio:1/1;}
.about .body h2{
  font-size:clamp(2rem,5vw,3.4rem);
  margin-bottom:1.3rem;
}
.about .body p{
  font-size:0.9rem;
  color:var(--ink-soft);
  margin:0 0 2rem;
  max-width:54ch;
  line-height:1.85;
}
.about .cta-row{
  display:flex;flex-wrap:wrap;align-items:center;gap:1.3rem 2rem;
}
@media (max-width:680px){
  .about{grid-template-columns:1fr;text-align:center;justify-items:center;}
  .about .body p{margin-inline:auto;}
  .about .cta-row{justify-content:center;}
}

/* ---------- Results / proof ---------- */
.results-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:clamp(2.4rem,6vw,5rem);
  align-items:center;
}
.results-figure{
  margin:0;
  max-width:380px;
  width:100%;
}
.results-figure .work{aspect-ratio:5/6;}
.results-body h2{
  font-size:clamp(2rem,5vw,3.4rem);
  margin-bottom:1.3rem;
  max-width:16ch;
}
.results-body .lead{
  font-size:0.9rem;
  color:var(--ink-soft);
  margin:0 0 2.2rem;
  max-width:46ch;
  line-height:1.85;
}
.results-body .stat{
  display:block;
  margin:0 0 2.4rem;
  padding-top:1.4rem;
  border-top:1px solid var(--hairline);
  max-width:340px;
}
.results-body .stat .big{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.8rem,7vw,4.4rem);
  color:var(--ink);line-height:1;
  display:block;
  letter-spacing:-0.01em;
}
.results-body .stat .lbl{
  font-family:var(--sans);font-weight:600;
  font-size:0.62rem;letter-spacing:0.24em;
  color:var(--gold-deep);text-transform:uppercase;
  display:block;margin-top:0.9rem;line-height:1.7;
}
@media (max-width:760px){
  .results-grid{grid-template-columns:1fr;}
  .results-figure{max-width:380px;margin-inline:auto;order:-1;}
}

/* ---------- Story (about page) ---------- */
.story-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:clamp(2.4rem,6vw,5rem);
  align-items:start;
}
.story-body h2{
  font-size:clamp(2rem,5vw,3.2rem);
  margin-bottom:1.6rem;
  max-width:18ch;
}
.story-body p{
  font-size:0.9rem;
  color:var(--ink-soft);
  margin:0 0 1.4rem;
  max-width:56ch;
  line-height:1.85;
}
.story-body p:last-child{margin-bottom:0;}
.story-figure{
  margin:0;
  max-width:380px;
  width:100%;
  position:sticky;
  top:110px;
  justify-self:end;
}
.story-figure .work{aspect-ratio:4/5;}
@media (max-width:820px){
  .story-grid{grid-template-columns:1fr;}
  .story-figure{max-width:380px;margin-inline:auto;order:-1;position:static;justify-self:center;}
}

/* ---------- Principles — hairline vitrine grid (about) ---------- */
.principles{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--hairline-mid);
  border:1px solid var(--hairline-mid);
}
@media (max-width:760px){ .principles{grid-template-columns:1fr;} }
.principle{
  background:var(--panel);
  padding:clamp(2rem,4.5vw,3rem);
}
.principle .p-icon{
  color:var(--gold);
  margin-bottom:1.3rem;
}
.principle .p-icon svg{width:20px;height:20px;}
.principle h3{font-size:clamp(1.35rem,2.8vw,1.7rem);margin-bottom:0.7rem;font-weight:500;}
.principle p{margin:0;font-size:0.85rem;color:var(--ink-soft);line-height:1.75;max-width:44ch;}

/* ---------- Who I help — hairline vitrine grid (about) ---------- */
.who-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--hairline-mid);
  border:1px solid var(--hairline-mid);
}
@media (max-width:820px){ .who-list{grid-template-columns:1fr;} }
.who{
  background:var(--panel);
  padding:clamp(2rem,4.5vw,2.8rem);
}
.who .w-num{
  font-family:var(--serif);font-style:italic;
  font-size:1rem;line-height:1;color:var(--gold-deep);margin-bottom:1.2rem;
}
.who .w-num::after{
  content:"";display:block;width:26px;height:1px;
  background:var(--gold);margin-top:0.8rem;
}
.who h3{font-size:clamp(1.3rem,2.7vw,1.6rem);margin-bottom:0.7rem;font-weight:500;}
.who p{margin:0;font-size:0.85rem;color:var(--ink-soft);line-height:1.75;}

/* ---------- Human touch (about) ---------- */
.human-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:clamp(2.4rem,6vw,5rem);
  align-items:center;
}
.human-figure{
  margin:0;
  max-width:380px;
  width:100%;
}
.human-figure .work{aspect-ratio:5/6;}
.human-body h2{
  font-size:clamp(2rem,5vw,3.2rem);
  margin-bottom:1.3rem;
  max-width:16ch;
}
.human-body p{
  font-size:0.9rem;
  color:var(--ink-soft);
  margin:0 0 1.4rem;
  max-width:50ch;
  line-height:1.85;
}
.human-body p:last-child{margin-bottom:0;}
@media (max-width:760px){
  .human-grid{grid-template-columns:1fr;}
  .human-figure{max-width:380px;margin-inline:auto;order:-1;}
}

/* ---------- Quotes — hairline-divided columns (home) ---------- */
.quotes-rail{
  display:grid;
  grid-template-columns:repeat(3,1fr);
}
@media (max-width:820px){
  .quotes-rail{grid-template-columns:1fr;max-width:520px;margin-inline:auto;}
}
.quotes-rail .quote{
  margin:0;
  padding:clamp(0.4rem,1vw,0.8rem) clamp(1.8rem,4vw,2.8rem);
  display:flex;flex-direction:column;
}
.quotes-rail .quote + .quote{border-left:1px solid var(--hairline-mid);}
.quotes-rail .quote:first-child{padding-left:0;}
.quotes-rail .quote:last-child{padding-right:0;}
@media (max-width:820px){
  .quotes-rail .quote{padding:clamp(1.8rem,5vw,2.4rem) 0;}
  .quotes-rail .quote + .quote{border-left:0;border-top:1px solid var(--hairline-mid);}
}

/* ---------- Quotes — vitrine grid (testimonials page) ---------- */
.quotes-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(1.4rem,3vw,2rem);
}
@media (max-width:900px){ .quotes-grid{grid-template-columns:1fr 1fr;} }
@media (max-width:620px){ .quotes-grid{grid-template-columns:1fr;max-width:520px;margin-inline:auto;} }
.quotes-grid .quote{
  margin:0;
  background:var(--panel);
  border:1px solid var(--hairline-mid);
  border-radius:2px;
  padding:clamp(1.8rem,3.6vw,2.4rem);
  display:flex;flex-direction:column;
}

/* shared quote anatomy */
.quote .mark{
  font-family:var(--serif);font-style:italic;
  font-size:2.2rem;line-height:0.6;color:var(--gold);
  margin-bottom:1rem;
}
.quote .stars{
  color:var(--gold);font-size:0.68rem;letter-spacing:0.3em;margin-bottom:1.1rem;
}
.quote blockquote{
  margin:0 0 1.6rem;
  font-family:var(--serif);
  font-size:clamp(1.15rem,2.4vw,1.35rem);
  line-height:1.45;
  color:var(--ink);
  font-weight:500;
}
.quote .attr{
  margin-top:auto;
  padding-top:1.1rem;
  border-top:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:0.3rem;
}
.quote .attr .name{
  font-family:var(--sans);font-weight:600;font-size:0.66rem;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);
}
.quote .attr .role{
  font-family:var(--serif);font-style:italic;
  font-size:0.88rem;color:var(--muted);
}

/* ---------- Stats band — flat ink ---------- */
.stats-band{
  background:var(--ink);
  border-radius:2px;
  padding:clamp(2.6rem,6vw,4rem) clamp(1.6rem,4vw,3rem);
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  text-align:center;
}
.stats-grid.cols-3{grid-template-columns:repeat(3,1fr);}
.stats-grid .stat-item + .stat-item{border-left:1px solid var(--ink-hairline);}
@media (max-width:760px){
  .stats-grid,.stats-grid.cols-3{grid-template-columns:1fr;gap:2.2rem;}
  .stats-grid .stat-item + .stat-item{border-left:0;border-top:1px solid var(--ink-hairline);padding-top:2.2rem;}
}
.stat-item{padding-inline:clamp(0.8rem,2vw,1.6rem);}
.stat-item .num{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.1rem,5.4vw,3rem);
  color:#FCFBF8;line-height:1;
  display:block;
}
.stat-item .cap{
  font-family:var(--sans);font-weight:600;
  font-size:0.6rem;letter-spacing:0.22em;
  color:var(--gold-ink);
  text-transform:uppercase;
  margin-top:1rem;
  line-height:1.8;
  display:block;
}

/* ---------- Join band — flat ink, photo at low opacity ---------- */
.join-section{padding-bottom:clamp(4.5rem,10vw,8rem);}
.join{
  position:relative;
  overflow:hidden;
  background:var(--ink);
  border-radius:2px;
  padding:clamp(3rem, 7vw, 5.2rem) clamp(1.6rem, 5vw, 4rem);
  text-align:center;
}
.join .join-photo{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 30%;
  opacity:0.14;
  filter:saturate(0.5);
  pointer-events:none;
}
.join > *{position:relative;z-index:1;}
.join .eyebrow{color:var(--gold-ink);}
.join .eyebrow::before,
.join .eyebrow.center.flanked::after{background:var(--gold-ink);}
.join h2{
  color:#FCFBF8;
  font-size:clamp(2rem, 5.4vw, 3.4rem);
  max-width:18ch;
  margin:0 auto 1rem;
}
.join h2 em.gold{color:var(--gold-ink);}
.join .join-sub{
  font-family:var(--sans);
  color:rgba(252,251,248,0.72);
  font-size:0.875rem;
  line-height:1.8;
  margin:0 auto 2.6rem;
  max-width:50ch;
}

.join-form{
  display:flex;
  gap:0.9rem;
  max-width:620px;
  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.875rem;
  color:#FCFBF8;
  background:transparent;
  border:1px solid rgba(252,251,248,0.28);
  border-radius:var(--r);
  padding:0.95em 1.3em;
  transition:border-color .2s ease;
}
.field input::placeholder{color:rgba(252,251,248,0.45);}
.field input:focus{
  outline:none;
  border-color:var(--gold-ink);
}
.join-form .btn{flex:0 0 auto;}
@media (max-width:600px){
  .join-form .btn{width:100%;}
}
.form-msg{
  margin:1.1rem auto 0;
  min-height:1.2em;
  font-size:0.78rem;
  color:var(--gold-ink);
  letter-spacing:0.04em;
}
.form-msg[data-state="warn"]{color:#E4C08A;}
.join .reassure{
  margin:2rem auto 0;
  font-size:0.6rem;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:rgba(252,251,248,0.5);
}

/* ---------- Closing CTA band — flat ink ---------- */
.cta-section{padding-bottom:clamp(4.5rem,10vw,8rem);}
.cta-band{
  background:var(--ink);
  border-radius:2px;
  padding:clamp(3rem, 7vw, 5.2rem) clamp(1.6rem, 5vw, 4rem);
  text-align:center;
}
.cta-band .eyebrow{color:var(--gold-ink);}
.cta-band .eyebrow::before,
.cta-band .eyebrow.center.flanked::after{background:var(--gold-ink);}
.cta-band h2{
  color:#FCFBF8;
  font-size:clamp(2rem, 5.4vw, 3.4rem);
  max-width:20ch;
  margin:0 auto 1rem;
}
.cta-band h2 em.gold{color:var(--gold-ink);}
.cta-band .cta-sub{
  font-family:var(--sans);
  color:rgba(252,251,248,0.72);
  font-size:0.875rem;
  line-height:1.8;
  margin:0 auto 2.4rem;
  max-width:50ch;
}
.cta-band .cta-row{
  display:flex;flex-wrap:wrap;justify-content:center;
  align-items:center;gap:1rem 1.6rem;
}
.cta-band .reassure{
  margin:2rem auto 0;
  font-size:0.6rem;
  letter-spacing:0.26em;
  text-transform:uppercase;
  color:rgba(252,251,248,0.5);
}

/* ---------- Contact form (light) ---------- */
.contact-section{padding-top:clamp(1.5rem,4vw,2.5rem);}
.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.2rem;
  text-align:left;
}
.form-field{display:flex;flex-direction:column;gap:0.5rem;}
.form-field label{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.62rem;
  letter-spacing:0.22em;
  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.875rem;
  color:var(--ink);
  background:var(--bg);
  border:1px solid var(--hairline-mid);
  border-radius:var(--r);
  padding:0.85em 1.1em;
  transition:border-color .2s ease;
}
.form-field textarea{
  resize:vertical;
  min-height:130px;
  line-height:1.6;
}
.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:#FFFFFF;
}
.form-field input[aria-invalid="true"],
.form-field textarea[aria-invalid="true"]{
  border-color:#B4471F;
}
.contact-form .btn{align-self:flex-start;margin-top:0.4rem;}
@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);
}
.contact-form .form-msg[data-state="warn"]{color:#B4471F;}
.contact-form .form-msg[data-state="ok"]{color:var(--gold-deep);font-weight:600;}

/* ---------- Direct contact block ---------- */
.direct{
  margin-top:clamp(3rem,7vw,4.5rem);
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  padding:clamp(2.4rem,5.5vw,3.6rem) clamp(1rem,3vw,2rem);
  text-align:center;
}
.direct .eyebrow{justify-content:center;margin-bottom:1.1rem;}
.direct .email-line{
  font-family:var(--serif);
  font-size:clamp(1.6rem,4vw,2.4rem);
  font-weight:500;
  margin:0 0 0.7rem;
  color:var(--ink);
}
.direct .email-line a{color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:0.1em;}
.direct .email-line a:hover{color:var(--gold-deep);}
.direct .response{
  margin:0;
  font-family:var(--serif);
  font-style:italic;
  font-size:0.95rem;
  color:var(--muted);
}

/* ---------- Legal document layout ---------- */
.legal-hero{
  padding-top:clamp(3.4rem,7vw,5rem);
  padding-bottom:clamp(1.6rem,3.4vw,2.4rem);
  text-align:center;
}
.legal-hero .eyebrow{justify-content:center;}
.legal-hero h1{
  font-size:clamp(2.4rem,6vw,4.2rem);
  max-width:20ch;
  margin:0 auto;
}
.legal-hero .updated{
  margin:1.6rem 0 0;
  font-family:var(--serif);
  font-style:italic;
  font-size:0.95rem;
  color:var(--muted);
}
.legal{
  padding-top:clamp(1.5rem,3vw,2rem);
  padding-bottom:clamp(4.5rem,10vw,8rem);
}
.legal-doc{
  max-width:68ch;
  margin:0 auto;
  border-top:1px solid var(--hairline);
  padding-top:clamp(2.2rem,5vw,3.2rem);
}
.legal-doc h2{
  font-size:clamp(1.6rem,3.6vw,2.2rem);
  margin:clamp(2.6rem,6vw,3.6rem) 0 1rem;
  line-height:1.14;
  font-weight:500;
}
.legal-doc h2:first-of-type{margin-top:0;}
.legal-doc h3{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.72rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--ink);
  margin:1.8rem 0 0.6rem;
}
.legal-doc p{
  font-size:0.875rem;
  color:var(--ink-soft);
  margin:0 0 1.2rem;
  line-height:1.85;
}
.legal-doc ul{
  margin:0 0 1.2rem;
  padding-left:1.3rem;
  color:var(--ink-soft);
  font-size:0.875rem;
  line-height:1.85;
}
.legal-doc li{margin:0 0 0.5rem;}
.legal-doc strong{color:var(--ink);font-weight:600;}

/* ---------- Footer ---------- */
footer{
  border-top:1px solid var(--hairline);
  padding-block:clamp(2.8rem,6vw,4rem);
  text-align:center;
}
footer .foot-nav{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:0.8rem clamp(1.3rem,3.4vw,2.4rem);
  margin-bottom:1.8rem;
}
footer .foot-nav a{
  font-family:var(--sans);font-weight:600;
  font-size:0.62rem;letter-spacing:0.22em;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.6rem clamp(1.3rem,3.4vw,2.4rem);
  margin-bottom:1.8rem;
}
footer .foot-reach a{
  font-family:var(--sans);font-weight:600;
  font-size:0.66rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gold-deep);
}
footer .disclaimer{
  font-style:italic;
  font-family:var(--serif);
  font-size:1rem;
  color:var(--ink-soft);
  margin:0 0 0.7rem;
}
footer .fine{
  font-size:0.72rem;color:var(--muted);margin:0 auto 1rem;line-height:1.7;
  max-width:80ch;
}
footer .copy{
  font-size:0.6rem;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0;
}

/* ============================================================
   Funnel pages, in the same language
   ============================================================ */

/* ---------- Opt-in squeeze card (free training) ---------- */
.optin-card{
  background:var(--panel);
  border:1px solid var(--hairline-mid);
  border-top:1px solid var(--gold);
  border-radius:2px;
  padding:clamp(2rem,4.5vw,2.8rem);
}
.optin-card h2{font-size:clamp(1.6rem,3.4vw,2.1rem);margin-bottom:0.8rem;font-weight:500;}
.optin-card > p{margin:0 0 1.6rem;font-size:0.875rem;color:var(--ink-soft);line-height:1.75;}
.optin-card .reassure{
  margin:1.4rem 0 0;
  font-size:0.6rem;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--muted);
}

/* ---------- Benefits list (what you'll learn) ---------- */
.benefits{
  list-style:none;
  margin:0;
  padding:0;
  border-top:1px solid var(--hairline);
}
.benefits li{
  display:flex;
  gap:clamp(1.1rem,2.6vw,1.7rem);
  align-items:flex-start;
  padding:clamp(1.3rem,3vw,1.8rem) 0;
  border-bottom:1px solid var(--hairline);
}
.benefits .tick{
  flex:0 0 auto;
  color:var(--gold);
  margin-top:0.35rem;
}
.benefits .tick svg{width:15px;height:15px;}
.benefits .b-text{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 2.6vw, 1.45rem);
  font-weight:500;
  color:var(--ink);
  line-height:1.4;
}

/* ---------- Video player (training delivery) ---------- */
.player-card{
  position:relative;
  background:var(--panel);
  border:1px solid var(--hairline-mid);
  padding:clamp(10px,1.8vw,18px);
}
.player-card.work--gold::after{inset:-11px;}
video.native{
  width:100%;height:auto;display:block;
  background:var(--ink);
}
.after-video{
  text-align:center;
  margin-top:clamp(2.6rem,6vw,3.8rem);
}
.after-video .watch-line{
  font-family:var(--serif);
  font-size:clamp(1.3rem,3vw,1.8rem);
  font-weight:500;
  color:var(--ink);
  margin:0 0 1.8rem;
}

/* ---------- Video testimonial works ---------- */
.video-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,3.4rem);
}
@media (max-width:760px){ .video-grid{grid-template-columns:1fr;} }
.video-card{
  margin:0;
  display:flex;flex-direction:column;
}
.video-card .work{padding:clamp(8px,1.4vw,14px);}
.yt{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:var(--ink);
  overflow:hidden;
}
.yt iframe{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;
}
.video-card figcaption{padding:1.2rem 0.2rem 0;}
.video-card .v-quote{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.05rem,2.2vw,1.2rem);
  line-height:1.5;
  color:var(--ink);
  font-weight:500;
  margin:0 0 0.9rem;
}
.video-card .v-name{
  display:block;
  font-family:var(--sans);
  font-size:0.62rem;
  font-weight:600;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);
  border-top:1px solid var(--hairline);
  padding-top:0.9rem;
}

/* ---------- Utility ---------- */
.center-note{text-align:center;margin-top:clamp(2rem,5vw,3rem);}

/* ---------- Entrance motion ---------- */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .9s ease, transform .9s 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;}
}
