/* ============================================================
   WEALTHY NOMADS — Design direction A · "Ivory & Gold"
   Ported from the operator-approved mock (reference/old-alfie-*.html,
   live at wealthynomad-insider.pages.dev/site/) into one shared
   stylesheet. Tokens, components and type are the mock's own;
   additions at the bottom cover the two new funnel pages
   (/a/free-training/, /a/training/) in the same language.
   ============================================================ */

:root{
  --ivory:#F6F1E7;
  --paper:#FBF8F1;
  --panel:#FFFFFF;
  --ink:#1A1C22;
  --ink-soft:#3C3A34;
  --midnight:#0E1118;
  --midnight-2:#15191F;
  --gold:#A9772E;          /* deepened base gold for AA on light */
  --gold-bright:#C99B5E;
  --gold-deep:#8A6026;     /* deepened for AA-legible labels on ivory */
  --gold-pale:#E7D2AE;
  --hairline:rgba(169,119,46,0.22);
  --hairline-strong:rgba(169,119,46,0.42);
  --muted:#615C50;         /* deepened for AA on ivory */

  --maxw:1120px;
  --radius:18px;
  --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:
    radial-gradient(1200px 700px at 50% -10%, rgba(231,210,174,0.45), rgba(231,210,174,0) 60%),
    linear-gradient(180deg, var(--paper) 0%, var(--ivory) 100%);
  background-attachment:fixed;
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.6;
  -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(20px, 5vw, 48px);
}

/* 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-radius:0 0 12px 0;
  font-weight:600;
}
.skip:focus{left:0;}

/* ---------- Eyebrow label ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(0.62rem, 1.2vw, 0.72rem);
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin:0 0 1.1rem;
  display:inline-flex;
  align-items:center;
  gap:0.7em;
}
.eyebrow::before{
  content:"";
  width:26px;
  height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.center{justify-content:center;}
.eyebrow.center.flanked::after{
  content:"";
  width:26px;
  height:1px;
  background:var(--gold);
  display:inline-block;
}

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

.hairline{
  border:0;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--hairline-strong), transparent);
  margin:0;
}

/* ---------- Masthead ---------- */
.masthead{
  border-bottom:1px solid var(--hairline);
  background:rgba(251,248,241,0.82);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  position:sticky;
  top:0;
  z-index:50;
}
.masthead .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding-top:0.95rem;
  padding-bottom:0.95rem;
}
.brand{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(1.15rem, 2.6vw, 1.4rem);
  letter-spacing:0.02em;
  color:var(--ink);
  display:flex;
  align-items:baseline;
  gap:0.55rem;
}
.brand:hover{color:var(--ink);}
.brand .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--gold);
  display:inline-block;
  transform:translateY(-2px);
}
.nav-links{
  display:flex;
  align-items:center;
  gap:clamp(1rem,2.6vw,2rem);
}
.nav-links a.navlink{
  font-family:var(--sans);
  font-weight:500;
  font-size:0.9rem;
  letter-spacing:0.03em;
  color:var(--ink-soft);
}
.nav-links a.navlink:hover{color:var(--gold-deep);}
.nav-links a.navlink[aria-current="page"]{
  color:var(--gold-deep);
  font-weight:600;
}
.nav-links .btn{padding:0.68rem 1.35rem;font-size:0.92rem;}
@media (max-width:820px){
  .nav-links a.navlink{display:none;}
}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--sans);
  font-weight:600;
  font-size:1rem;
  letter-spacing:0.01em;
  border:none;
  cursor:pointer;
  border-radius:999px;
  padding:1rem 2.1rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.6rem;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  text-decoration:none;
}
.btn:active{transform:translateY(1px) scale(0.99);}
.btn-primary{
  background:linear-gradient(135deg, var(--gold-deep), var(--gold) 55%, var(--gold-bright));
  color:#FFFDF8;
  box-shadow:0 10px 26px -10px rgba(154,110,51,0.6), inset 0 1px 0 rgba(255,255,255,0.25);
}
.btn-primary:hover{
  transform:translateY(-2px);
  color:#FFFDF8;
  box-shadow:0 16px 34px -12px rgba(154,110,51,0.72), inset 0 1px 0 rgba(255,255,255,0.3);
}
.btn-primary .arrow{transition:transform .2s ease;}
.btn-primary:hover .arrow{transform:translateX(4px);}

.btn-light{
  background:var(--gold-bright);
  color:#1A1409;
}
.btn-light:hover{transform:translateY(-2px);color:#1A1409;background:var(--gold-pale);}

/* ghost / outline button for dark & light backgrounds */
.btn-ghost{
  background:transparent;
  color:var(--gold-deep);
  border:1px solid var(--hairline-strong);
}
.btn-ghost:hover{
  transform:translateY(-2px);
  color:var(--gold-deep);
  background:rgba(231,210,174,0.28);
}

/* secondary text link */
.text-link{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.98rem;
  letter-spacing:0.02em;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:0.4em;
}
.text-link .arrow{transition:transform .2s ease;}
.text-link:hover{color:var(--gold);}
.text-link:hover .arrow{transform:translateX(4px);}

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

/* ---------- Section frame ---------- */
section{padding-block:clamp(3rem, 7vw, 5.5rem);}
.section-head{margin-bottom:clamp(2rem,4vw,3rem);}
.section-head h2{
  font-size:clamp(1.9rem, 4.4vw, 2.9rem);
  max-width:22ch;
}
.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:clamp(1.05rem,2.1vw,1.2rem);
  color:var(--ink-soft);
  max-width:52ch;
  margin:1.1rem auto 0;
}

/* ---------- Hero (split, homepage / about) ---------- */
.hero{padding-top:clamp(2.8rem,7vw,4.6rem);padding-bottom:clamp(2.6rem,7vw,4.6rem);}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
.hero h1{
  font-size:clamp(2.35rem, 5.6vw, 4.1rem);
  max-width:16ch;
  font-weight:600;
}
.hero .subhead{
  font-size:clamp(1.05rem, 2.1vw, 1.25rem);
  color:var(--ink-soft);
  max-width:46ch;
  margin:clamp(1.2rem,3vw,1.6rem) 0 0;
  font-weight:400;
}
.hero .cta-row{
  margin-top:clamp(1.6rem, 4vw, 2.1rem);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:1.2rem 1.6rem;
}
.cred-line{
  margin-top:clamp(1.5rem,3.4vw,2rem);
  padding-top:clamp(1.1rem,2.6vw,1.5rem);
  border-top:1px solid var(--hairline);
  display:flex;
  align-items:center;
  gap:0.9rem;
  max-width:52ch;
}
.cred-line .badge{
  flex:0 0 auto;
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--hairline-strong);
  background:rgba(231,210,174,0.28);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);
}
.cred-line .badge svg{width:18px;height:18px;}
.cred-line p{
  margin:0;
  font-size:0.92rem;
  line-height:1.5;
  color:var(--muted);
}
.cred-line p strong{color:var(--ink-soft);font-weight:600;}

/* Hero image — editorial framed */
.hero-figure{
  position:relative;
  margin:0;
}
.hero-figure .frame{
  position:relative;
  border-radius:calc(var(--radius) + 8px);
  overflow:hidden;
  border:1px solid var(--hairline-strong);
  box-shadow:0 40px 90px -46px rgba(138,96,38,0.55);
  aspect-ratio:4/5;
  background:var(--ivory);
}
.hero-figure .frame img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:50% 30%;
}
.hero-figure::after{
  content:"";
  position:absolute;
  inset:10px;
  border:1px solid rgba(255,253,248,0.35);
  border-radius:var(--radius);
  pointer-events:none;
  mix-blend-mode:overlay;
}
.hero-figure .stamp{
  position:absolute;
  bottom:-18px;left:-18px;
  background:var(--panel);
  border:1px solid var(--hairline-strong);
  border-radius:14px;
  padding:0.85rem 1.15rem;
  box-shadow:0 20px 44px -24px rgba(154,110,51,0.5);
  display:flex;align-items:center;gap:0.7rem;
  max-width:230px;
}
.hero-figure .stamp .mono{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:1.5rem;color:var(--gold-deep);line-height:1;
}
.hero-figure .stamp .st-text{
  font-size:0.72rem;letter-spacing:0.04em;line-height:1.35;color:var(--ink-soft);
}
.hero-figure .stamp .st-text strong{display:block;color:var(--ink);font-weight:600;letter-spacing:0.02em;}
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;}
  .hero h1{max-width:20ch;}
  .hero .subhead{max-width:56ch;}
  .hero-figure{max-width:460px;margin-inline:auto;order:-1;}
  .hero-figure .stamp{left:auto;right:-8px;}
}
@media (max-width:520px){
  .hero-figure .stamp{position:static;margin-top:1.4rem;max-width:none;}
}

/* ---------- Page hero (centred, interior pages) ---------- */
.page-hero{
  padding-top:clamp(2.8rem,7vw,4.6rem);
  padding-bottom:clamp(2rem,5vw,3rem);
  text-align:center;
}
.page-hero .eyebrow{justify-content:center;}
.page-hero h1{
  font-size:clamp(2.35rem, 5.6vw, 4.1rem);
  max-width:18ch;
  margin:0 auto;
  font-weight:600;
}
.page-hero .subhead{
  font-size:clamp(1.05rem, 2.1vw, 1.25rem);
  color:var(--ink-soft);
  max-width:52ch;
  margin:clamp(1.2rem,3vw,1.6rem) auto 0;
  font-weight:400;
}

/* ---------- Trust bar ---------- */
.trustbar{
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  padding-block:clamp(1.4rem,3.4vw,2rem);
}
.trustbar .wrap{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:0.9rem clamp(1.4rem,4vw,3rem);
}
.trustbar .ts{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(0.72rem,1.5vw,0.86rem);
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:inline-flex;
  align-items:center;
  gap:0.55rem;
  white-space:nowrap;
}
.trustbar .ts::before{
  content:"";
  width:5px;height:5px;border-radius:50%;
  background:var(--gold);
  display:inline-block;
}

/* ---------- Two paths ---------- */
.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;} }
.path{
  position:relative;
  border-radius:var(--radius);
  padding:clamp(1.9rem,4vw,2.6rem);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.path:hover{transform:translateY(-4px);}
.path .p-num{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:1.4rem;line-height:1;margin-bottom:0.9rem;
}
.path h2,.path h3{font-size:clamp(1.5rem,3vw,1.95rem);margin-bottom:0.7rem;}
.path p{margin:0 0 1.6rem;font-size:1.02rem;}
.path .p-cta{margin-top:auto;}
/* Card A — primary emphasised (dark) */
.path-a{
  background:
    radial-gradient(600px 340px at 85% -10%, rgba(201,155,94,0.20), rgba(201,155,94,0) 60%),
    linear-gradient(165deg, var(--midnight) 0%, var(--midnight-2) 100%);
  border:1px solid rgba(201,155,94,0.30);
  box-shadow:0 34px 80px -46px rgba(14,17,24,0.7);
}
.path-a::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--gold-pale), var(--gold-bright), var(--gold-deep));
}
.path-a .p-num{color:var(--gold-bright);}
.path-a h2,.path-a h3{color:#F6F1E7;}
.path-a p{color:rgba(246,241,231,0.82);}
.path-a .p-note{
  font-size:0.82rem;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(246,241,231,0.6);margin:1.2rem 0 0;
}
.path-a .p-tag{
  position:absolute;top:1.4rem;right:1.4rem;
  font-family:var(--sans);font-weight:600;
  font-size:0.62rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold-bright);
  border:1px solid rgba(201,155,94,0.42);
  padding:0.32rem 0.7rem;border-radius:999px;
}
/* Card B — light */
.path-b{
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 78%);
  border:1px solid var(--hairline-strong);
  box-shadow:0 24px 60px -40px rgba(138,96,38,0.4);
}
.path-b .p-num{color:var(--gold-deep);}
.path-b p{color:var(--ink-soft);}

/* ---------- Feature band (framed quote panel) ---------- */
.feature-band{
  position:relative;
  overflow:hidden;
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 72%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(2.8rem, 5.5vw, 4.4rem) clamp(1.6rem, 5vw, 3.8rem);
  box-shadow:0 34px 80px -46px rgba(138,96,38,0.45);
  text-align:center;
}
.feature-band::after{
  content:"";
  position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg, var(--gold-pale), var(--gold-bright), var(--gold-deep));
}
.feature-band::before{
  content:"\201C";
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-weight:600;
  font-size:clamp(3.2rem, 7vw, 4.8rem);
  line-height:0.7;
  color:var(--gold-bright);
  margin:0 0 0.4rem;
}
.feature-band > *{ position:relative; z-index:1; }
.feature-band p,
.feature-band blockquote{
  font-family:var(--serif);
  font-size:clamp(1.5rem, 3.4vw, 2.25rem);
  line-height:1.4;
  color:var(--ink);
  font-weight:500;
  margin:0.6rem auto 0;
  max-width:26ch;
}
.feature-band .stars{
  color:var(--gold);font-size:1rem;letter-spacing:0.2em;margin:1.4rem 0 0.6rem;
}
.feature-band figcaption{
  font-family:var(--sans);
  margin-top:0.6rem;
}
.feature-band figcaption .name{
  display:block;font-weight:600;font-size:1rem;color:var(--ink);
}
.feature-band figcaption .role{
  display:block;font-size:0.85rem;letter-spacing:0.04em;color:var(--muted);margin-top:0.15rem;
}

/* ---------- About block (round headshot) ---------- */
.about{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(1.8rem, 4vw, 3rem);
  align-items:center;
}
.about .headshot{
  flex:0 0 auto;
  width:clamp(150px, 30vw, 240px);
  height:clamp(150px, 30vw, 240px);
  border-radius:50%;
  overflow:hidden;
  border:1px solid var(--hairline-strong);
  box-shadow:0 24px 54px -30px rgba(154,110,51,0.6);
  position:relative;
}
.about .headshot img{width:100%;height:100%;object-fit:cover;object-position:50% 22%;}
.about .headshot::after{
  content:"";position:absolute;inset:9px;border-radius:50%;
  border:1px solid rgba(255,253,248,0.4);pointer-events:none;
}
.about .body h2{
  font-size:clamp(1.9rem,4.4vw,2.9rem);
  margin-bottom:1.1rem;
}
.about .body p{
  font-size:clamp(1.05rem, 2.2vw, 1.18rem);
  color:var(--ink-soft);
  margin:0 0 1.6rem;
  max-width:56ch;
}
.about .cta-row{
  display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem 1.6rem;
}
@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.95fr 1.05fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
.results-figure{
  margin:0;
  border-radius:calc(var(--radius) + 4px);
  overflow:hidden;
  border:1px solid var(--hairline-strong);
  box-shadow:0 40px 90px -46px rgba(138,96,38,0.5);
  aspect-ratio:5/6;
  position:relative;
  background:var(--ivory);
}
.results-figure img{width:100%;height:100%;object-fit:cover;object-position:50% 40%;}
.results-body h2{
  font-size:clamp(1.9rem,4.6vw,3rem);
  margin-bottom:1.1rem;
  max-width:16ch;
}
.results-body .lead{
  font-size:clamp(1.08rem,2.3vw,1.28rem);
  color:var(--ink-soft);
  margin:0 0 1.4rem;
  max-width:48ch;
}
.results-body .stat{
  display:inline-flex;align-items:baseline;gap:0.5rem;
  margin:0 0 2rem;
}
.results-body .stat .big{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(2.6rem,7vw,3.8rem);
  color:var(--gold-deep);line-height:1;
}
.results-body .stat .lbl{
  font-family:var(--sans);font-weight:500;
  font-size:0.9rem;letter-spacing:0.06em;
  color:var(--muted);text-transform:uppercase;max-width:14ch;line-height:1.35;
}
@media (max-width:760px){
  .results-grid{grid-template-columns:1fr;}
  .results-figure{max-width:440px;margin-inline:auto;order:-1;}
}

/* ---------- Story (prose + sticky figure, about page) ---------- */
.story-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:start;
}
.story-body h2{
  font-size:clamp(1.9rem,4.6vw,3rem);
  margin-bottom:1.2rem;
  max-width:18ch;
}
.story-body p{
  font-size:clamp(1.03rem,2.1vw,1.15rem);
  color:var(--ink-soft);
  margin:0 0 1.3rem;
  max-width:58ch;
}
.story-body p:last-child{margin-bottom:0;}
.story-figure{
  margin:0;
  border-radius:calc(var(--radius) + 4px);
  overflow:hidden;
  border:1px solid var(--hairline-strong);
  box-shadow:0 40px 90px -46px rgba(138,96,38,0.5);
  aspect-ratio:4/5;
  background:var(--ivory);
  position:sticky;
  top:96px;
}
.story-figure img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;}
@media (max-width:820px){
  .story-grid{grid-template-columns:1fr;}
  .story-figure{max-width:440px;margin-inline:auto;order:-1;position:static;}
}

/* ---------- Approach principles (about page) ---------- */
.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:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 82%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.7rem,3.4vw,2.3rem);
  box-shadow:0 24px 60px -44px rgba(138,96,38,0.4);
  transition:transform .25s ease, box-shadow .25s ease;
}
.principle:hover{transform:translateY(-4px);box-shadow:0 30px 70px -44px rgba(138,96,38,0.5);}
.principle .p-icon{
  width:44px;height:44px;border-radius:12px;
  border:1px solid var(--hairline-strong);
  background:rgba(231,210,174,0.28);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);
  margin-bottom:1.1rem;
}
.principle .p-icon svg{width:22px;height:22px;}
.principle h3{font-size:clamp(1.3rem,2.6vw,1.6rem);margin-bottom:0.5rem;}
.principle p{margin:0;font-size:1rem;color:var(--ink-soft);line-height:1.55;}

/* ---------- Who I help (about page) ---------- */
.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{
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.6rem,3.2vw,2.1rem);
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 82%);
  box-shadow:0 24px 60px -44px rgba(138,96,38,0.4);
}
.who .w-num{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:1.3rem;line-height:1;color:var(--gold-deep);margin-bottom:0.7rem;
}
.who h3{font-size:clamp(1.25rem,2.5vw,1.5rem);margin-bottom:0.5rem;}
.who p{margin:0;font-size:0.98rem;color:var(--ink-soft);line-height:1.55;}

/* ---------- Human touch (photo + values, about page) ---------- */
.human-grid{
  display:grid;
  grid-template-columns:0.95fr 1.05fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
.human-figure{
  margin:0;
  border-radius:calc(var(--radius) + 4px);
  overflow:hidden;
  border:1px solid var(--hairline-strong);
  box-shadow:0 40px 90px -46px rgba(138,96,38,0.5);
  aspect-ratio:5/6;
  position:relative;
  background:var(--ivory);
}
.human-figure img{width:100%;height:100%;object-fit:cover;object-position:50% 35%;}
.human-body h2{
  font-size:clamp(1.9rem,4.6vw,3rem);
  margin-bottom:1.1rem;
  max-width:16ch;
}
.human-body p{
  font-size:clamp(1.05rem,2.2vw,1.18rem);
  color:var(--ink-soft);
  margin:0 0 1.3rem;
  max-width:50ch;
}
.human-body p:last-child{margin-bottom:0;}
@media (max-width:760px){
  .human-grid{grid-template-columns:1fr;}
  .human-figure{max-width:440px;margin-inline:auto;order:-1;}
}

/* ---------- 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:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 82%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.8rem,3.4vw,2.4rem);
  display:flex;flex-direction:column;
  box-shadow:0 24px 60px -44px rgba(138,96,38,0.4);
  transition:transform .25s ease, box-shadow .25s ease;
}
.quote:hover{transform:translateY(-4px);box-shadow:0 30px 70px -44px rgba(138,96,38,0.5);}
.quote .mark{
  font-family:var(--serif);font-style:italic;font-weight:700;
  font-size:3rem;line-height:0.6;color:var(--gold-bright);
  margin-bottom:0.4rem;
}
.quote blockquote{
  margin:0 0 1.4rem;
  font-family:var(--serif);
  font-size:clamp(1.15rem,2.4vw,1.32rem);
  line-height:1.42;
  color:var(--ink);
  font-weight:500;
}
.quote .attr{
  margin-top:auto;
  padding-top:1rem;
  border-top:1px solid var(--hairline);
  display:flex;flex-direction:column;gap:0.15rem;
}
.quote .attr .name{
  font-family:var(--sans);font-weight:600;font-size:0.95rem;color:var(--ink);
}
.quote .attr .role{
  font-family:var(--sans);font-size:0.82rem;letter-spacing:0.04em;color:var(--muted);
}
.quote .stars{
  color:var(--gold);font-size:0.85rem;letter-spacing:0.15em;margin-bottom:0.9rem;
}

/* ---------- Results / stats strip (dark) ---------- */
.stats-band{
  background:
    radial-gradient(600px 340px at 85% -10%, rgba(201,155,94,0.18), rgba(201,155,94,0) 60%),
    linear-gradient(165deg, var(--midnight) 0%, var(--midnight-2) 100%);
  border:1px solid rgba(201,155,94,0.30);
  border-radius:calc(var(--radius) + 6px);
  padding:clamp(2.4rem,5vw,3.6rem) clamp(1.6rem,4vw,3rem);
  box-shadow:0 34px 80px -46px rgba(14,17,24,0.7);
  position:relative;
  overflow:hidden;
}
.stats-band::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--gold-pale), var(--gold-bright), var(--gold-deep));
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(1.6rem,4vw,2.4rem);
  text-align:center;
}
.stats-grid.cols-3{grid-template-columns:repeat(3,1fr);}
@media (max-width:760px){ .stats-grid,.stats-grid.cols-3{grid-template-columns:1fr 1fr;gap:2.2rem 1.6rem;} }
@media (max-width:420px){ .stats-grid,.stats-grid.cols-3{grid-template-columns:1fr;} }
.stat-item .num{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(2.1rem,5.4vw,3rem);
  color:var(--gold-bright);line-height:1;
  display:block;
}
.stat-item .cap{
  font-family:var(--sans);font-weight:500;
  font-size:0.86rem;letter-spacing:0.05em;
  color:rgba(246,241,231,0.82);
  text-transform:uppercase;
  margin-top:0.7rem;
  line-height:1.4;
  display:block;
}

/* ---------- Join box (dark, framed, palm photo) ---------- */
.join-section{padding-bottom:clamp(3.5rem,8vw,6rem);}
.join{
  background:
    radial-gradient(900px 500px at 80% -20%, rgba(201,155,94,0.16), rgba(201,155,94,0) 55%),
    linear-gradient(165deg, rgba(12,14,20,0.82) 0%, rgba(12,14,20,0.90) 100%),
    /* NOTE: photo hotlinked from the approved mock's preview deployment — re-host alongside the new site before launch. */
    url("https://wealthynomad-insider.pages.dev/site/assets/p-join.jpg") center 30%/cover no-repeat;
  border:1px solid rgba(201,155,94,0.28);
  border-radius:calc(var(--radius) + 6px);
  padding:clamp(2.6rem, 6vw, 4.4rem);
  text-align:center;
  box-shadow:0 40px 90px -50px rgba(14,17,24,0.8);
  position:relative;
  overflow:hidden;
}
.join::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-bright), transparent);
}
.join .corner{
  position:absolute;
  width:30px;height:30px;
  border:1px solid rgba(201,155,94,0.4);
  pointer-events:none;
}
.join .corner.tl{top:18px;left:18px;border-right:0;border-bottom:0;}
.join .corner.tr{top:18px;right:18px;border-left:0;border-bottom:0;}
.join .corner.bl{bottom:18px;left:18px;border-right:0;border-top:0;}
.join .corner.br{bottom:18px;right:18px;border-left:0;border-top:0;}
.join .eyebrow{color:var(--gold-bright);}
.join .eyebrow::before{background:var(--gold-bright);}
.join .eyebrow.center.flanked::after{background:var(--gold-bright);}
.join h2{
  color:#F6F1E7;
  font-size:clamp(2rem, 5vw, 3.2rem);
  max-width:18ch;
  margin:0 auto 0.6rem;
}
.join .join-sub{
  font-family:var(--sans);
  color:var(--gold-pale);
  letter-spacing:0.01em;
  font-size:clamp(1rem,2.1vw,1.12rem);
  line-height:1.5;
  margin:0 auto 2rem;
  max-width:52ch;
}

.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:1rem;
  color:#F6F1E7;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(231,210,174,0.34);
  border-radius:999px;
  padding:1rem 1.4rem;
  transition:border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.field input::placeholder{color:rgba(246,241,231,0.5);}
.field input:focus{
  outline:none;
  border-color:var(--gold-bright);
  background:rgba(255,255,255,0.09);
  box-shadow:0 0 0 3px rgba(201,155,94,0.25);
}
.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:#FFD9A3;}
.join .reassure{
  margin:1.6rem auto 0;
  font-size:0.8rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(246,241,231,0.55);
}

/* ---------- Closing CTA band (dark, framed, no photo) ---------- */
.cta-section{padding-bottom:clamp(3.5rem,8vw,6rem);}
.cta-band{
  background:
    radial-gradient(900px 500px at 80% -20%, rgba(201,155,94,0.16), rgba(201,155,94,0) 55%),
    linear-gradient(165deg, var(--midnight) 0%, var(--midnight-2) 100%);
  border:1px solid rgba(201,155,94,0.28);
  border-radius:calc(var(--radius) + 6px);
  padding:clamp(2.6rem, 6vw, 4.4rem);
  text-align:center;
  box-shadow:0 40px 90px -50px rgba(14,17,24,0.8);
  position:relative;
  overflow:hidden;
}
.cta-band::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--gold-bright), transparent);
}
.cta-band .corner{
  position:absolute;
  width:30px;height:30px;
  border:1px solid rgba(201,155,94,0.4);
  pointer-events:none;
}
.cta-band .corner.tl{top:18px;left:18px;border-right:0;border-bottom:0;}
.cta-band .corner.tr{top:18px;right:18px;border-left:0;border-bottom:0;}
.cta-band .corner.bl{bottom:18px;left:18px;border-right:0;border-top:0;}
.cta-band .corner.br{bottom:18px;right:18px;border-left:0;border-top:0;}
.cta-band .eyebrow{color:var(--gold-bright);}
.cta-band .eyebrow::before{background:var(--gold-bright);}
.cta-band .eyebrow.center.flanked::after{background:var(--gold-bright);}
.cta-band h2{
  color:#F6F1E7;
  font-size:clamp(2rem, 5vw, 3.2rem);
  max-width:20ch;
  margin:0 auto 0.6rem;
}
.cta-band .cta-sub{
  font-family:var(--sans);
  color:var(--gold-pale);
  letter-spacing:0.01em;
  font-size:clamp(1rem,2.1vw,1.12rem);
  line-height:1.5;
  margin:0 auto 2rem;
  max-width:52ch;
}
.cta-band .cta-row{
  display:flex;flex-wrap:wrap;justify-content:center;
  align-items:center;gap:1rem 1.4rem;
}
.cta-band .reassure{
  margin:1.6rem auto 0;
  font-size:0.8rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(246,241,231,0.55);
}

/* ---------- Contact form (light) ---------- */
.contact-section{padding-top:clamp(1rem,3vw,2rem);}
.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
  text-align:left;
}
.form-field{display:flex;flex-direction:column;gap:0.4rem;}
.form-field label{
  font-family:var(--sans);
  font-weight:600;
  font-size:0.85rem;
  letter-spacing:0.04em;
  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:1rem;
  color:var(--ink);
  background:rgba(255,255,255,0.7);
  border:1px solid var(--hairline-strong);
  border-radius:12px;
  padding:0.85rem 1.1rem;
  transition:border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.form-field textarea{
  border-radius:14px;
  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:#FFFFFF;
  box-shadow:0 0 0 3px rgba(169,119,46,0.2);
}
.form-field input[aria-invalid="true"],
.form-field textarea[aria-invalid="true"]{
  border-color:#B4471F;
  box-shadow:0 0 0 3px rgba(180,71,31,0.18);
}
.contact-form .btn{align-self:flex-start;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);
}
.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(2.5rem,5vw,3.5rem);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 82%);
  padding:clamp(1.8rem,4vw,2.6rem);
  text-align:center;
  box-shadow:0 24px 60px -44px rgba(138,96,38,0.4);
}
.direct .eyebrow{justify-content:center;margin-bottom:0.9rem;}
.direct .email-line{
  font-family:var(--serif);
  font-size:clamp(1.5rem,3.6vw,2.1rem);
  font-weight:600;
  margin:0 0 0.6rem;
}
.direct .email-line a{color:var(--gold-deep);}
.direct .email-line a:hover{color:var(--gold);}
.direct .response{
  margin:0;
  font-size:0.98rem;
  color:var(--muted);
}

/* ---------- Legal document layout ---------- */
.legal-hero{
  padding-top:clamp(2.6rem,6vw,4rem);
  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.2rem 0 0;
  font-size:0.86rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--muted);
}
.legal{
  padding-top:clamp(1rem,2vw,1.5rem);
  padding-bottom:clamp(3.5rem,8vw,6rem);
}
.legal-doc{
  max-width:72ch;
  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:1.02rem;
  letter-spacing:0.01em;
  color:var(--ink);
  margin:1.6rem 0 0.5rem;
}
.legal-doc p{
  font-size:clamp(1rem,2vw,1.08rem);
  color:var(--ink-soft);
  margin:0 0 1.1rem;
  line-height:1.75;
}
.legal-doc ul{
  margin:0 0 1.1rem;
  padding-left:1.4rem;
  color:var(--ink-soft);
  font-size:clamp(1rem,2vw,1.08rem);
  line-height:1.75;
}
.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.2rem,5vw,3rem);
  text-align:center;
}
footer .foot-nav{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:0.6rem clamp(1.2rem,3vw,2rem);
  margin-bottom:1.4rem;
}
footer .foot-nav a{
  font-family:var(--sans);font-weight:500;
  font-size:0.88rem;letter-spacing:0.04em;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.4rem;
}
footer .foot-reach a{
  font-family:var(--sans);font-weight:600;
  font-size:0.88rem;letter-spacing:0.04em;color:var(--gold-deep);
}
footer .disclaimer{
  font-style:italic;
  font-family:var(--serif);
  font-size:1.05rem;
  color:var(--ink-soft);
  margin:0 0 0.5rem;
}
footer .fine{
  font-size:0.8rem;color:var(--muted);margin:0 auto 0.8rem;line-height:1.5;
  max-width:88ch;
}
footer .copy{
  font-size:0.78rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0;
}

/* ============================================================
   Additions for the two new funnel pages, in the mock's language
   ============================================================ */

/* ---------- Opt-in squeeze card (free training) ---------- */
.optin-card{
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 78%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.9rem,4vw,2.6rem);
  box-shadow:0 24px 60px -40px rgba(138,96,38,0.4);
  position:relative;
  overflow:hidden;
}
.optin-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--gold-pale), var(--gold-bright), var(--gold-deep));
}
.optin-card h2{font-size:clamp(1.5rem,3vw,1.95rem);margin-bottom:0.6rem;}
.optin-card > p{margin:0 0 1.4rem;font-size:1rem;color:var(--ink-soft);}
.optin-card .reassure{
  margin:1.2rem 0 0;
  font-size:0.78rem;
  letter-spacing:0.08em;
  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(1rem,2.5vw,1.6rem);
  align-items:flex-start;
  padding:clamp(1.2rem,2.8vw,1.7rem) 0;
  border-bottom:1px solid var(--hairline);
}
.benefits .tick{
  flex:0 0 auto;
  width:34px;height:34px;
  border-radius:50%;
  border:1px solid var(--hairline-strong);
  background:rgba(231,210,174,0.28);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);
  margin-top:0.15rem;
}
.benefits .tick svg{width:16px;height:16px;}
.benefits .b-text{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 2.5vw, 1.5rem);
  font-weight:500;
  color:var(--ink);
  line-height:1.3;
}

/* ---------- Video player card (training delivery) ---------- */
.player-card{
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 82%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(0.9rem,2vw,1.3rem);
  box-shadow:0 34px 80px -46px rgba(138,96,38,0.45);
}
video.native{
  width:100%;height:auto;display:block;
  border-radius:calc(var(--radius) - 8px);
  background:var(--midnight);
}

/* ---------- Video testimonial cards ---------- */
.video-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(1.2rem,2.6vw,1.8rem);
}
@media (max-width:760px){ .video-grid{grid-template-columns:1fr;} }
.video-card{
  margin:0;
  background:radial-gradient(130% 150% at 50% 0%, #FFFFFF 0%, var(--ivory) 82%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.1rem,2.4vw,1.5rem);
  box-shadow:0 24px 60px -44px rgba(138,96,38,0.4);
  display:flex;flex-direction:column;
}
.yt{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:var(--midnight);
  border-radius:calc(var(--radius) - 8px);
  overflow:hidden;
  border:1px solid var(--hairline);
}
.yt iframe{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;
}
.video-card figcaption{padding:1.2rem 0.4rem 0.3rem;}
.video-card .v-quote{
  font-family:var(--serif);
  font-size:clamp(1.1rem,2.2vw,1.28rem);
  line-height:1.42;
  color:var(--ink);
  font-weight:500;
  margin:0 0 0.8rem;
}
.video-card .v-name{
  display:block;
  font-family:var(--sans);
  font-size:0.82rem;
  font-weight:600;
  letter-spacing:0.06em;
  color:var(--muted);
  border-top:1px solid var(--hairline);
  padding-top:0.8rem;
}

/* ---------- Entrance motion ---------- */
.reveal{
  opacity:0;
  transform:translateY(18px);
  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 *,.path,.quote,.principle,.text-link .arrow{transition:none;}
}
