/* ============================================================
   WEALTHY NOMADS — Design variant A1 · "Golden Hour"
   Same page set, content and funnel as the approved design A
   ("Ivory & Gold"); this sheet only changes the visual skin and
   composition. Character: the sunniest, most personal expression
   of the warm/premium direction — champagne grounds, honey golds,
   late-afternoon gradient bands, sunset-brown dark sections, and
   photography scaled up (full-bleed split hero, wide photo bands).
   Fonts stay brand: Cormorant Garamond (display, italics leaned
   on) + Hanken Grotesk (body).
   ============================================================ */

:root{
  /* grounds */
  --base:#FBF5EA;          /* champagne base */
  --band:#F7EDDC;          /* warm band */
  --band-deep:#F3E5CD;     /* warmest band */
  --panel:#FFFDF6;         /* card top-light */

  /* ink */
  --ink:#221C12;
  --ink-soft:#4A4030;
  --muted:#6B5C42;         /* AA on champagne + warm bands */

  /* sunset darks (replace design A's navy) */
  --sunset:#2A2014;
  --sunset-2:#332715;

  /* honey golds */
  --gold:#B8843B;          /* primary honey */
  --gold-bright:#D9A85F;
  --gold-mid:#A97E35;      /* large numerals on light (≥3:1) */
  --gold-deep:#855A1D;     /* AA text accents on all light grounds */
  --honey-deep:#8F6224;    /* eyebrows on base grounds */
  --highlight:#EFD9B0;

  --hairline:rgba(184,132,59,0.20);
  --hairline-strong:rgba(184,132,59,0.38);

  --maxw:1120px;
  --pad:clamp(20px, 5vw, 48px);
  --radius:22px;           /* cards */
  --radius-photo:26px;     /* photography */
  --shadow-warm:0 26px 64px -30px rgba(120,80,20,0.14);
  --shadow-warm-lift:0 34px 80px -36px rgba(120,80,20,0.18);

  --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;}
html,body{overflow-x:clip;}

body{
  margin:0;
  /* late-afternoon light: warm sun from the upper right */
  background:
    radial-gradient(1300px 780px at 82% -10%, rgba(239,217,176,0.62), rgba(239,217,176,0) 62%),
    radial-gradient(900px 640px at -12% 28%, rgba(247,237,220,0.55), rgba(247,237,220,0) 55%),
    linear-gradient(180deg, #FDF9F0 0%, var(--base) 48%, #F9F0DF 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 var(--pad);
}

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

/* ---------- Eyebrow label (honey) ---------- */
.eyebrow{
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(0.62rem, 1.2vw, 0.72rem);
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--honey-deep);
  margin:0 0 1.1rem;
  display:inline-flex;
  align-items:center;
  gap:0.7em;
}
.eyebrow::before{
  content:"";
  width:30px;
  height:1px;
  background:linear-gradient(90deg, var(--gold-bright), var(--gold));
  display:inline-block;
}
.eyebrow.center{justify-content:center;}
.eyebrow.center.flanked::after{
  content:"";
  width:30px;
  height:1px;
  background:linear-gradient(90deg, var(--gold), var(--gold-bright));
  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,245,234,0.86);
  backdrop-filter:saturate(140%) blur(9px);
  -webkit-backdrop-filter:saturate(140%) blur(9px);
  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:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--gold-bright), var(--gold) 70%);
  box-shadow:0 0 0 3px rgba(217,168,95,0.22);
  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 (gold pills, warm glow) ---------- */
.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, #9A6C22, var(--gold) 50%, var(--gold-bright));
  color:#FFFBF2;
  box-shadow:
    0 14px 34px -12px rgba(184,132,59,0.62),
    0 4px 14px rgba(184,132,59,0.20),
    inset 0 1px 0 rgba(255,255,255,0.3);
}
.btn-primary:hover{
  transform:translateY(-2px);
  color:#FFFBF2;
  box-shadow:
    0 20px 44px -14px rgba(184,132,59,0.72),
    0 6px 18px rgba(184,132,59,0.24),
    inset 0 1px 0 rgba(255,255,255,0.34);
}
.btn-primary .arrow{transition:transform .2s ease;}
.btn-primary:hover .arrow{transform:translateX(4px);}

/* on sunset-dark bands */
.btn-light{
  background:var(--highlight);
  color:var(--sunset);
  box-shadow:0 14px 34px -14px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn-light:hover{transform:translateY(-2px);color:var(--sunset);background:var(--band);}

/* ghost / outline button */
.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(239,217,176,0.35);
}

/* 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-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:clamp(1.15rem,2.3vw,1.35rem);
  color:var(--ink-soft);
  max-width:52ch;
  margin:1.1rem auto 0;
}

/* ---------- Hero (full-bleed split: photo owns half the viewport) ---------- */
.hero{padding-block:0;}
.hero .wrap{max-width:none;padding:0;}
.hero-grid{
  display:grid;
  grid-template-columns:
    minmax(var(--pad), 1fr)
    minmax(0, calc(var(--maxw)/2 - var(--pad)))
    minmax(0, calc(var(--maxw)/2 - var(--pad)))
    minmax(var(--pad), 1fr);
  gap:0;
  align-items:stretch;
}
.hero-copy{
  grid-column:2;
  align-self:center;
  padding-block:clamp(3rem, 7vw, 5rem);
  padding-right:clamp(1.8rem, 4.5vw, 4rem);
}
.hero h1{
  font-size:clamp(2.45rem, 5.4vw, 4.2rem);
  max-width:16ch;
  font-weight:600;
}
.hero .subhead{
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:clamp(1.3rem, 2.6vw, 1.62rem);
  line-height:1.42;
  color:var(--ink-soft);
  max-width:40ch;
  margin:clamp(1.2rem,3vw,1.6rem) 0 0;
}
.hero .cta-row{
  margin-top:clamp(1.6rem, 4vw, 2.2rem);
  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(239,217,176,0.4);
  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 — flush to the right edge, golden-hour glow behind */
.hero-figure{
  grid-column:3 / 5;
  position:relative;
  margin:0;
  min-height:clamp(460px, 74vh, 720px);
}
.hero-figure .frame{
  position:absolute;
  inset:0;
  border-radius:var(--radius-photo) 0 0 var(--radius-photo);
  overflow:hidden;
  box-shadow:-30px 44px 90px -50px rgba(120,80,20,0.4);
  background:var(--band);
}
.hero-figure .frame img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:50% 30%;
}
.hero-figure::after{
  content:"";
  position:absolute;
  inset:12px 0 12px 12px;
  border:1px solid rgba(255,251,242,0.35);
  border-right:0;
  border-radius:18px 0 0 18px;
  pointer-events:none;
  mix-blend-mode:overlay;
}
.hero-figure .stamp{
  position:absolute;
  bottom:34px;left:-26px;
  background:var(--panel);
  border:1px solid var(--hairline-strong);
  border-radius:16px;
  padding:0.85rem 1.15rem;
  box-shadow:0 22px 48px -24px rgba(120,80,20,0.4);
  display:flex;align-items:center;gap:0.7rem;
  max-width:230px;
  z-index:2;
}
.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;}

/* Opt-in card inside a hero grid (free training) stays on the grid, no bleed */
.hero-grid .optin-card{
  grid-column:3;
  align-self:center;
  margin-block:clamp(2.6rem, 6vw, 4.2rem);
}

@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-copy{
    grid-column:1;
    padding:clamp(2.2rem,6vw,3rem) var(--pad) clamp(2.6rem,7vw,3.4rem);
  }
  .hero h1{max-width:20ch;}
  .hero .subhead{max-width:52ch;}
  .hero-figure{
    grid-column:1;
    order:-1;
    min-height:clamp(340px, 52vh, 480px);
  }
  .hero-figure .frame{border-radius:0 0 var(--radius-photo) var(--radius-photo);}
  .hero-figure::after{
    inset:0 12px 12px 12px;
    border:1px solid rgba(255,251,242,0.35);
    border-top:0;
    border-radius:0 0 18px 18px;
  }
  .hero-figure .stamp{left:16px;bottom:16px;}
  .hero-grid .optin-card{grid-column:1;margin:0 var(--pad) 2.8rem;}
}

/* ---------- Page hero (centred, interior pages) ---------- */
.page-hero{
  padding-top:clamp(2.8rem,7vw,4.6rem);
  padding-bottom:clamp(2rem,5vw,3rem);
  text-align:center;
}
/* when nested inside a .hero section (testimonials), re-contain it */
.hero .page-hero{
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--pad);
}
.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-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:clamp(1.25rem, 2.5vw, 1.5rem);
  line-height:1.45;
  color:var(--ink-soft);
  max-width:52ch;
  margin:clamp(1.2rem,3vw,1.6rem) auto 0;
}

/* ---------- Trust bar (soft warm band) ---------- */
.trustbar{
  border:0;
  background:linear-gradient(180deg,
    rgba(243,229,205,0) 0%,
    rgba(243,229,205,0.72) 26%,
    rgba(243,229,205,0.72) 74%,
    rgba(243,229,205,0) 100%);
  padding-block:clamp(1.6rem,3.6vw,2.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:6px;height:6px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--gold-bright), var(--gold) 75%);
  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 (sunset dark) */
.path-a{
  background:
    radial-gradient(640px 360px at 85% -12%, rgba(217,168,95,0.30), rgba(217,168,95,0) 62%),
    linear-gradient(160deg, var(--sunset-2) 0%, var(--sunset) 100%);
  border:1px solid rgba(217,168,95,0.34);
  box-shadow:0 34px 80px -42px rgba(66,44,16,0.6);
}
.path-a::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--highlight), var(--gold-bright), var(--gold));
}
.path-a .p-num{color:var(--gold-bright);}
.path-a h2,.path-a h3{color:var(--band);}
.path-a p{color:rgba(247,237,220,0.85);}
.path-a .p-note{
  font-size:0.82rem;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(247,237,220,0.62);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(--highlight);
  border:1px solid rgba(239,217,176,0.42);
  padding:0.32rem 0.7rem;border-radius:999px;
}
/* Card B — champagne */
.path-b{
  background:linear-gradient(175deg, var(--panel) 0%, var(--band) 100%);
  border:1px solid var(--hairline-strong);
  box-shadow:var(--shadow-warm);
}
.path-b .p-num{color:var(--gold-deep);}
.path-b p{color:var(--ink-soft);}

/* ---------- Feature band (full-width late-afternoon gradient) ---------- */
.feature-band{
  position:relative;
  margin-inline:calc(50% - 50vw);
  border:0;
  border-radius:0;
  box-shadow:none;
  background:linear-gradient(180deg,
    rgba(243,229,205,0) 0%,
    rgba(243,229,205,0.85) 22%,
    var(--band-deep) 50%,
    rgba(243,229,205,0.85) 78%,
    rgba(243,229,205,0) 100%);
  padding:clamp(3.4rem, 7vw, 5.8rem) var(--pad);
  text-align:center;
}
.feature-band::before{
  content:"\201C";
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-weight:600;
  font-size:clamp(3.4rem, 7vw, 5rem);
  line-height:0.7;
  color:var(--gold-bright);
  margin:0 0 0.4rem;
}
.feature-band p,
.feature-band blockquote{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.65rem, 3.7vw, 2.5rem);
  line-height:1.36;
  color:var(--ink);
  font-weight:500;
  margin:0.6rem auto 0;
  max-width:25ch;
}
.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 (large round headshot, golden halo) ---------- */
.about{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:clamp(1.8rem, 4.5vw, 3.4rem);
  align-items:center;
}
.about .headshot{
  flex:0 0 auto;
  width:clamp(170px, 32vw, 290px);
  height:clamp(170px, 32vw, 290px);
  border-radius:50%;
  overflow:hidden;
  border:1px solid var(--hairline-strong);
  box-shadow:
    0 0 0 12px rgba(239,217,176,0.4),
    0 30px 70px -32px rgba(120,80,20,0.4);
  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,251,242,0.45);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:1.02fr 0.98fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
.results-figure{
  margin:0;
  border-radius:var(--radius-photo);
  overflow:hidden;
  border:0;
  box-shadow:0 44px 96px -48px rgba(120,80,20,0.42);
  aspect-ratio:4/5;
  position:relative;
  background:var(--band);
}
.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-style:italic;
  font-size:clamp(2.6rem,7vw,3.9rem);
  color:var(--gold-mid);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:460px;margin-inline:auto;order:-1;}
}

/* ---------- Story (prose + sticky figure, about page) ---------- */
.story-grid{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  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:var(--radius-photo);
  overflow:hidden;
  border:0;
  box-shadow:0 44px 96px -48px rgba(120,80,20,0.42);
  aspect-ratio:4/5;
  background:var(--band);
  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:460px;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:linear-gradient(175deg, var(--panel) 0%, #F9EFDD 100%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.7rem,3.4vw,2.3rem);
  box-shadow:var(--shadow-warm);
  transition:transform .25s ease, box-shadow .25s ease;
}
.principle:hover{transform:translateY(-4px);box-shadow:var(--shadow-warm-lift);}
.principle .p-icon{
  width:46px;height:46px;border-radius:14px;
  border:1px solid var(--hairline-strong);
  background:rgba(239,217,176,0.42);
  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:linear-gradient(175deg, var(--panel) 0%, #F9EFDD 100%);
  box-shadow:var(--shadow-warm);
}
.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 — WIDE PHOTO BAND (about page #life) ---------- */
.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:var(--radius-photo);
  overflow:hidden;
  border:0;
  box-shadow:0 44px 96px -48px rgba(120,80,20,0.42);
  aspect-ratio:5/6;
  position:relative;
  background:var(--band);
}
.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:460px;margin-inline:auto;order:-1;}
}
/* about page: the photo goes full-width; the words sit on an
   overlapping champagne card — a lifestyle-magazine moment */
#life{padding-top:clamp(2rem,5vw,3.5rem);}
#life .wrap{max-width:none;padding:0;}
#life .human-grid{display:block;}
#life .human-figure{
  aspect-ratio:auto;
  height:clamp(380px, 62vh, 620px);
  border-radius:0;
  box-shadow:none;
  max-width:none;
}
#life .human-figure::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(42,32,20,0) 55%, rgba(42,32,20,0.30) 100%);
  pointer-events:none;
}
#life .human-body{
  position:relative;
  z-index:1;
  width:min(860px, calc(100% - 2*var(--pad)));
  margin:clamp(-120px,-11vw,-76px) auto 0;
  background:linear-gradient(180deg, var(--panel) 0%, #FBF3E3 100%);
  border:1px solid var(--hairline);
  border-radius:var(--radius);
  padding:clamp(1.9rem,4.5vw,3rem) clamp(1.6rem,4.5vw,3.2rem);
  box-shadow:0 34px 80px -38px rgba(120,80,20,0.3);
}

/* ---------- 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:linear-gradient(175deg, var(--panel) 0%, #F9EFDD 100%);
  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:var(--shadow-warm);
  transition:transform .25s ease, box-shadow .25s ease;
}
.quote:hover{transform:translateY(-4px);box-shadow:var(--shadow-warm-lift);}
.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-style:italic;
  font-size:clamp(1.2rem,2.5vw,1.38rem);
  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 (sunset dark) ---------- */
.stats-band{
  background:
    radial-gradient(640px 360px at 85% -12%, rgba(217,168,95,0.26), rgba(217,168,95,0) 62%),
    linear-gradient(160deg, var(--sunset-2) 0%, var(--sunset) 100%);
  border:1px solid rgba(217,168,95,0.32);
  border-radius:calc(var(--radius) + 6px);
  padding:clamp(2.4rem,5vw,3.6rem) clamp(1.6rem,4vw,3rem);
  box-shadow:0 40px 90px -46px rgba(66,44,16,0.65);
  position:relative;
  overflow:hidden;
}
.stats-band::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--highlight), var(--gold-bright), var(--gold));
}
.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-style:italic;
  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(247,237,220,0.85);
  text-transform:uppercase;
  margin-top:0.7rem;
  line-height:1.4;
  display:block;
}

/* ---------- Join box (sunset dark over the palm photo) ---------- */
.join-section{padding-bottom:clamp(3.5rem,8vw,6rem);}
.join{
  background:
    radial-gradient(900px 520px at 82% -18%, rgba(217,168,95,0.24), rgba(217,168,95,0) 58%),
    linear-gradient(165deg, rgba(42,32,20,0.84) 0%, rgba(51,39,21,0.92) 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 32%/cover no-repeat;
  border:1px solid rgba(217,168,95,0.32);
  border-radius:calc(var(--radius) + 6px);
  padding:clamp(2.6rem, 6vw, 4.4rem);
  text-align:center;
  box-shadow:0 44px 100px -50px rgba(66,44,16,0.75);
  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(217,168,95,0.38);
  pointer-events:none;
}
.join .corner.tl{top:18px;left:18px;border-right:0;border-bottom:0;border-top-left-radius:12px;}
.join .corner.tr{top:18px;right:18px;border-left:0;border-bottom:0;border-top-right-radius:12px;}
.join .corner.bl{bottom:18px;left:18px;border-right:0;border-top:0;border-bottom-left-radius:12px;}
.join .corner.br{bottom:18px;right:18px;border-left:0;border-top:0;border-bottom-right-radius:12px;}
.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:var(--band);
  font-size:clamp(2rem, 5vw, 3.2rem);
  max-width:18ch;
  margin:0 auto 0.6rem;
}
.join .join-sub{
  font-family:var(--sans);
  color:var(--highlight);
  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:var(--base);
  background:rgba(251,245,234,0.07);
  border:1px solid rgba(239,217,176,0.36);
  border-radius:999px;
  padding:1rem 1.4rem;
  transition:border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.field input::placeholder{color:rgba(247,237,220,0.55);}
.field input:focus{
  outline:none;
  border-color:var(--gold-bright);
  background:rgba(251,245,234,0.11);
  box-shadow:0 0 0 3px rgba(217,168,95,0.28);
}
.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:#FFDFAE;}
.join .reassure{
  margin:1.6rem auto 0;
  font-size:0.8rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:rgba(247,237,220,0.6);
}

/* ---------- Closing CTA band (sunset dark, no photo) ---------- */
.cta-section{padding-bottom:clamp(3.5rem,8vw,6rem);}
.cta-band{
  background:
    radial-gradient(900px 520px at 82% -18%, rgba(217,168,95,0.22), rgba(217,168,95,0) 58%),
    linear-gradient(165deg, var(--sunset-2) 0%, var(--sunset) 100%);
  border:1px solid rgba(217,168,95,0.32);
  border-radius:calc(var(--radius) + 6px);
  padding:clamp(2.6rem, 6vw, 4.4rem);
  text-align:center;
  box-shadow:0 44px 100px -50px rgba(66,44,16,0.75);
  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(217,168,95,0.38);
  pointer-events:none;
}
.cta-band .corner.tl{top:18px;left:18px;border-right:0;border-bottom:0;border-top-left-radius:12px;}
.cta-band .corner.tr{top:18px;right:18px;border-left:0;border-bottom:0;border-top-right-radius:12px;}
.cta-band .corner.bl{bottom:18px;left:18px;border-right:0;border-top:0;border-bottom-left-radius:12px;}
.cta-band .corner.br{bottom:18px;right:18px;border-left:0;border-top:0;border-bottom-right-radius:12px;}
.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:var(--band);
  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(--highlight);
  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(247,237,220,0.6);
}

/* ---------- 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,253,246,0.75);
  border:1px solid var(--hairline-strong);
  border-radius:14px;
  padding:0.85rem 1.1rem;
  transition:border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.form-field textarea{
  border-radius:16px;
  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(184,132,59,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:linear-gradient(175deg, var(--panel) 0%, #F9EFDD 100%);
  padding:clamp(1.8rem,4vw,2.6rem);
  text-align:center;
  box-shadow:var(--shadow-warm);
}
.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 (settles into the warmest band) ---------- */
footer{
  border-top:1px solid var(--hairline);
  background:linear-gradient(180deg, rgba(243,229,205,0) 0%, rgba(243,229,205,0.8) 100%);
  padding-block:clamp(2.4rem,5vw,3.2rem);
  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.1rem;
  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;
}

/* ============================================================
   Funnel pages (free training / training delivery)
   ============================================================ */

/* ---------- Opt-in squeeze card (free training) ---------- */
.optin-card{
  background:linear-gradient(175deg, var(--panel) 0%, var(--band) 100%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.9rem,4vw,2.6rem);
  box-shadow:0 34px 80px -38px rgba(120,80,20,0.3);
  position:relative;
  overflow:hidden;
}
.optin-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--highlight), var(--gold-bright), var(--gold));
}
.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(239,217,176,0.42);
  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;
}

/* ---------- What you'll learn — WIDE PHOTO BAND (free training #learn) ----------
   The palm photo bleeds to the left viewport edge; the benefits sit
   on the golden right half. */
#learn .wrap{max-width:none;padding:0;}
#learn .results-grid{
  display:grid;
  grid-template-columns:
    minmax(var(--pad), 1fr)
    minmax(0, calc(var(--maxw)/2 - var(--pad)))
    minmax(0, calc(var(--maxw)/2 - var(--pad)))
    minmax(var(--pad), 1fr);
  gap:0;
  align-items:stretch;
}
#learn .results-figure{
  grid-column:1 / 3;
  aspect-ratio:auto;
  min-height:clamp(440px, 64vh, 660px);
  border-radius:0 var(--radius-photo) var(--radius-photo) 0;
  box-shadow:30px 44px 90px -50px rgba(120,80,20,0.35);
  max-width:none;
  margin:0;
}
#learn .results-body{
  grid-column:3;
  align-self:center;
  padding:clamp(2.6rem,6vw,4rem) 0 clamp(2.6rem,6vw,4rem) clamp(1.8rem,4.5vw,4rem);
}
@media (max-width:880px){
  #learn .results-grid{grid-template-columns:1fr;}
  #learn .results-figure{
    grid-column:1;
    min-height:clamp(300px, 46vh, 430px);
    border-radius:0 0 var(--radius-photo) var(--radius-photo);
  }
  #learn .results-body{
    grid-column:1;
    padding:clamp(2.2rem,6vw,3rem) var(--pad) 0;
  }
}

/* ---------- Video player card (training delivery) ---------- */
.player-card{
  background:linear-gradient(175deg, var(--panel) 0%, var(--band) 100%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(0.9rem,2vw,1.3rem);
  box-shadow:0 40px 90px -44px rgba(120,80,20,0.35);
}
video.native{
  width:100%;height:auto;display:block;
  border-radius:calc(var(--radius) - 8px);
  background:var(--sunset);
}

/* ---------- 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:linear-gradient(175deg, var(--panel) 0%, #F9EFDD 100%);
  border:1px solid var(--hairline-strong);
  border-radius:var(--radius);
  padding:clamp(1.1rem,2.4vw,1.5rem);
  box-shadow:var(--shadow-warm);
  display:flex;flex-direction:column;
}
.yt{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:var(--sunset);
  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-style:italic;
  font-size:clamp(1.12rem,2.2vw,1.3rem);
  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;}
}
