/* b.well coaching, light editorial system.
   All-Helvetica (statements + body), matching the offer PDFs and shipped lead magnets.
   Light paper is the baseline; sand is reserved for dark surfaces only. Rounded, never square. */

:root{
  --paper:#F1EFEC;        /* baseline ground */
  --paper2:#FBFAF8;       /* lifted card surface */
  --ink:#171513;          /* statement + body on paper */
  --mute:#BCB9B2;         /* dots, marks, faint accents */
  --turn:#94918A;         /* the two-tone turn in headings on light (reads as intentional, not disabled) */
  --dark:#0c0b0a;         /* the closer only */
  --sand:#D0B688;         /* accent only: eyebrow, tick, hairline, dot */
  --white:#F5F4F1;        /* type on dark */
  --grey:#AAA8A4;         /* secondary on dark */
  --dim:#969890;          /* fine print, captions */
  --line:#e0ddd6;
  --hair:rgba(23,21,19,.12);   /* neutral hairline (was sand-tinted) */
  --eye:#6E6E6C;               /* eyebrow / subtitle grey on light (matches the offer doc) */
  --statement:"Helvetica Neue",Helvetica,Arial,sans-serif;
  --serif:"Helvetica Neue",Helvetica,Arial,sans-serif;  /* body now matches the offer PDFs + shipped lead magnets (sans). Source Serif retired for the site. */
  --mx:clamp(24px,7vw,150px);
  --maxw:1240px;
  --pad:clamp(24px,5vw,64px);
  --sec:clamp(48px,5vw,80px);
  --r:18px;               /* cards / panels */
  --r-md:14px;            /* image frames */
  --r-sm:10px;            /* inputs */
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
[id]{scroll-margin-top:72px}
:focus-visible{outline:2px solid var(--sand);outline-offset:3px}
.btn:focus-visible,.textlink:focus-visible,.nav-links a:focus-visible,.mark:focus-visible{outline:2px solid var(--sand);outline-offset:4px;border-radius:4px}
body{background:var(--paper);color:var(--ink);font-family:var(--serif);font-weight:400;line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Type ---------- */
.statement{font-family:var(--statement);font-weight:700;letter-spacing:-.03em;line-height:1.0;color:var(--ink)}
.statement .m{color:var(--turn)}
h1{font-family:var(--statement);font-weight:700;letter-spacing:-.035em;line-height:1.07;font-size:clamp(34px,5vw,60px);color:var(--ink)}
h1 .m{color:var(--mute)}
h2{font-family:var(--statement);font-weight:700;letter-spacing:-.025em;line-height:1.12;font-size:clamp(25px,3vw,37px);color:var(--ink)}
h2 .m{color:var(--turn)}
/* controlled two-tone break: mute clause drops to its own line on desktop */
.brk{display:none}
@media(min-width:720px){.brk{display:block}}
/* mobile: the mute two-tone clause always starts its own line (no mid-phrase break) */
@media(max-width:719px){h1 .m,h2 .m{display:block}}
.eyebrow{text-wrap:balance}
h2 + .lead,.hair + .lead{margin-top:20px}
h3{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.3vw,27px);line-height:1.22;color:var(--ink)}
p{color:#46423b;max-width:64ch;font-size:17px;line-height:1.6}
.lead{font-family:var(--serif);font-size:clamp(18px,1.6vw,21px);line-height:1.58;color:#46423b}
.fine{font-family:var(--serif);font-size:14px;line-height:1.6;color:#7a766e}
em{font-style:italic}
strong{font-weight:600;color:var(--ink)}

.eyebrow{font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--eye);display:inline-block;margin-bottom:22px}
.center .eyebrow{margin-bottom:18px}
.num{font-family:var(--serif);font-weight:400;font-size:clamp(34px,5vw,68px);line-height:1;color:var(--mute);display:block;margin-bottom:18px}
.hair{height:1px;background:var(--hair);border:0;width:46px;margin:28px 0}
.hair.center{margin-left:auto;margin-right:auto}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{padding-top:var(--sec);padding-bottom:var(--sec)}
/* collapse doubled padding around stacked sections + dividers (kills the voids).
   the sibling combinator must also catch the <hr> dividers between sections,
   else offer pages keep ~166px voids. */
section + section,
.rule-full + section{padding-top:0}
.creds + section{padding-top:clamp(40px,5vw,72px)}
/* Editorial two-column block: heading left, body right (no stranded narrow column) */
.txtcols{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(36px,5vw,80px);align-items:start}
.txtcols .lead{margin-top:0}
.txtcols .head h2{margin-bottom:0}
@media(max-width:820px){.txtcols{grid-template-columns:1fr;gap:18px}}
.measure{max-width:64ch}
.center{text-align:center}
.center .lead,.center .measure{margin-left:auto;margin-right:auto}
.rule-full{height:1px;background:var(--line);border:0;margin:0 var(--mx)}

/* ---------- Nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--mx);transition:background .3s,padding .3s,border-color .3s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(241,239,236,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:13px var(--mx)}
.mark{font-family:var(--statement);font-weight:700;font-size:18px;letter-spacing:-.02em;color:var(--ink)}
.mark .dot{color:inherit}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-family:var(--statement);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#7a766e;transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.cta{color:var(--sand)}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);font-size:21px;cursor:pointer;line-height:1}

/* ---------- Buttons (pill, rounded) ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--statement);font-weight:700;font-size:13px;letter-spacing:.04em;
  padding:15px 32px;border-radius:999px;cursor:pointer;transition:all .25s ease;border:1px solid transparent}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:#322d27}
.btn-outline{background:transparent;color:var(--ink);border-color:rgba(23,21,19,.28)}
.btn-outline:hover{border-color:var(--ink)}
.btn-sand{background:var(--sand);color:#231d10}
.btn-sand:hover{background:#c6a877}
.btn-white{background:var(--white);color:var(--ink);border-color:var(--white)}
.btn-white:hover{background:#e6e3dc;border-color:#e6e3dc}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.center .btn-row{justify-content:center}
.textlink{font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  border-bottom:1.5px solid var(--ink);padding-bottom:4px;transition:color .2s,border-color .2s}
.textlink:hover{color:#6E6E6C;border-color:#6E6E6C}

/* dark variants */
.dark .btn-primary{background:var(--white);color:var(--dark)}
.dark .btn-primary:hover{background:#e3e0d9}
.dark .btn-outline{color:var(--white);border-color:rgba(245,244,241,.32)}
.dark .btn-outline:hover{border-color:var(--white)}

/* ---------- Hero (light, type-led) ---------- */
.hero{padding-top:clamp(150px,22vh,230px);padding-bottom:var(--sec)}
.hero h1{max-width:15ch}
.hero .lead{margin-top:26px;max-width:54ch}

/* ---------- Credibility strip ---------- */
.cred{display:flex;flex-wrap:wrap;gap:12px 28px;align-items:center;justify-content:center;
  padding:24px var(--mx);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cred span{font-family:var(--statement);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.cred .dot{color:var(--mute)}

/* ---------- Split (text + image) ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,90px);align-items:center}
.split .media{border-radius:var(--r-md);overflow:hidden;aspect-ratio:4/5;background:#0c0b0a}
.split .media img{width:100%;height:100%;object-fit:cover}
.split .media.wide{aspect-ratio:4/3}
.phone-wrap{display:flex;justify-content:center;align-items:center}
.phone-wrap img{height:auto;max-height:600px;width:auto;filter:drop-shadow(0 28px 56px rgba(23,21,19,.26))}
.phones{margin:clamp(40px,5vw,68px) auto 0;display:flex;justify-content:center;align-items:center;gap:clamp(14px,2.2vw,38px)}
.phones img{width:clamp(150px,21vw,256px);height:auto;filter:drop-shadow(0 26px 52px rgba(12,11,10,.18))}
.phones .lead-phone{width:clamp(166px,23vw,282px)}
@media(max-width:680px){.phones{gap:0}.phones img:not(.lead-phone){display:none}.phones .lead-phone{width:min(72vw,300px)}}

/* How-it-works: dense four-across feature row (faceless, any client) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(28px,3vw,40px)}
.step{border-top:1px solid var(--line);padding-top:20px}
.step .n{font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.14em;color:var(--eye)}
.step h3{font-family:var(--statement);font-weight:700;letter-spacing:-.02em;font-size:clamp(18px,1.6vw,21px);line-height:1.15;margin:14px 0 11px}
.step p{font-size:17px;line-height:1.6;color:#56524b}
@media(max-width:980px){.steps{grid-template-columns:1fr 1fr;gap:clamp(28px,3.5vw,44px)}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}

/* ---------- Tick list ---------- */
.ticks{list-style:none;margin:32px 0 0;display:grid;gap:15px}
.ticks li{position:relative;padding-left:34px;font-family:var(--serif);font-size:17px;line-height:1.55;color:#46423b}
.ticks li strong{color:var(--ink)}
.ticks li::before{content:"";position:absolute;left:2px;top:7px;width:14px;height:7px;
  border-left:2.2px solid var(--ink);border-bottom:2.2px solid var(--ink);transform:rotate(-45deg)}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,34px);align-items:stretch}
.cards.three{grid-template-columns:repeat(3,1fr)}
.card{background:var(--paper2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s,transform .3s,box-shadow .3s}
.card:hover{border-color:var(--hair);transform:translateY(-3px);box-shadow:0 14px 34px -20px rgba(23,21,19,.25)}
.card:not(:has(.ph)) .body{padding-top:clamp(30px,3.6vw,46px)}
.card .ph{aspect-ratio:16/11;overflow:hidden;background:#0c0b0a}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.card:hover .ph img{transform:scale(1.04)}
.card .body{padding:clamp(24px,3vw,38px);display:flex;flex-direction:column;flex:1}
.card h3{margin-bottom:12px}
.card>.ph + .body p{flex:1}
.card .body>p{font-size:17px}
.card .textlink{margin-top:auto;padding-top:24px;align-self:flex-start}
.card.featured{border-color:var(--line)}
.card.featured .body{box-shadow:none}

/* ---------- Offer tiers (PDF-faithful: header, full tick list, photo row) ---------- */
.tiers{display:grid;gap:0}
.tier + .tier{border-top:1px solid var(--line);padding-top:clamp(54px,7vw,90px)}
.tier-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px 32px;flex-wrap:wrap}
.tier-head > div{flex:1 1 320px;min-width:0}
.tier-head .eyebrow{margin-bottom:12px}
.tier-where{font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--eye);white-space:nowrap;padding-top:4px}
.tier h3{font-family:var(--statement);font-weight:700;letter-spacing:-.025em;line-height:1.0;font-size:clamp(30px,4vw,52px);color:var(--ink)}
.tier .tier-sub{font-family:var(--serif);font-size:clamp(17px,1.7vw,21px);line-height:1.35;color:var(--eye);margin-top:8px}
.tier .ticks{margin-top:clamp(26px,3vw,40px);max-width:860px}
/* tier media: a row of equal tiles (studio photos cover; app phones contained on a light tile) */
.tier-media{margin-top:clamp(30px,3.6vw,50px);display:grid;gap:clamp(12px,1.5vw,20px)}
.tier-media.c3{grid-template-columns:repeat(3,1fr)}
.tier-media.c4{grid-template-columns:repeat(4,1fr)}
.tier-media .tile{border-radius:var(--r-md);overflow:hidden;background:#ECE9E3;aspect-ratio:4/5}
.tier-media .tile.wide{aspect-ratio:4/3}
.tier-media .tile img{width:100%;height:100%;object-fit:cover;display:block}
/* app phones sit bare on the paper (like the PDF), not in a card; cell keeps the row aligned */
.tier-media .tile.app{background:transparent;display:flex;align-items:flex-end;justify-content:center;padding:0}
.tier-media .tile.app img{width:auto;max-width:100%;height:100%;object-fit:contain;object-position:bottom}
/* mobile: keep rows even, never strand a lone tile */
@media(max-width:680px){
  .tier-media.c3{grid-template-columns:repeat(3,1fr)}
  .tier-media.c4{grid-template-columns:repeat(3,1fr)}
  .tier-media.c4 .tile:first-child{grid-column:1 / -1;aspect-ratio:16/10}
}

/* journey strip (SAC bio) + CES / bio photo blocks */
.journey{margin-top:clamp(36px,4.2vw,60px)}
.journey .jlabel{font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--eye);margin-bottom:16px}
.journey-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.4vw,20px)}
.journey-row .frame{border-radius:var(--r-md);overflow:hidden;aspect-ratio:204/272;background:#ECE9E3}
.journey-row .frame img{width:100%;height:100%;object-fit:cover}
@media(max-width:680px){.journey-row{grid-template-columns:1fr 1fr}}
.spec-photos{margin-top:clamp(30px,3.6vw,50px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,28px);align-items:stretch}
.spec-photos .frame{border-radius:var(--r-md);overflow:hidden;aspect-ratio:4/3;background:#ECE9E3}
.spec-photos .frame.cert{background:#fff;display:flex;align-items:center;justify-content:center;padding:clamp(14px,1.8vw,26px);border:1px solid var(--line)}
.spec-photos .frame img{width:100%;height:100%;object-fit:cover}
.spec-photos .frame.cert img{width:100%;height:100%;object-fit:contain}
@media(max-width:680px){.spec-photos{grid-template-columns:1fr}}
.bio-photos{margin-top:clamp(30px,3.6vw,50px);display:grid;grid-template-columns:repeat(2,minmax(0,300px));gap:clamp(16px,2vw,28px)}
.bio-photos .frame{border-radius:var(--r-md);overflow:hidden;aspect-ratio:3/4;background:#ECE9E3}
.bio-photos .frame img{width:100%;height:100%;object-fit:cover}

/* dark "Message me to start" closer (matches PDF page 7) */
.pdf-closer{background:var(--dark);color:var(--white);padding:clamp(76px,11vw,150px) var(--mx)}
.pdf-closer .inner{max-width:var(--maxw);margin:0 auto}
.pdf-closer .eyebrow{color:var(--sand);margin-bottom:18px}
.pdf-closer h2{color:var(--white);font-size:clamp(34px,5vw,58px);line-height:1.0}
.pdf-closer h2 .m{color:var(--sand)}
.pdf-closer .contacts{margin-top:clamp(36px,4.5vw,60px);display:grid;gap:clamp(24px,2.6vw,34px)}
.pdf-closer .c-lab{font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--sand);margin-bottom:7px}
.pdf-closer .c-val{font-family:var(--statement);font-size:clamp(20px,2.4vw,30px);color:var(--white);transition:color .2s}
.pdf-closer a.c-val:hover{color:var(--sand)}

/* ---------- Dark closer (the one dark moment) ---------- */
.closer{padding:var(--sec) var(--mx)}
.closer-panel{max-width:var(--maxw);margin:0 auto;background:var(--dark);color:var(--white);border-radius:var(--r);
  padding:clamp(44px,5vw,72px) clamp(28px,6vw,80px);text-align:center}
.closer-panel .btn-row{margin-top:26px}
.closer-panel .eyebrow{color:var(--sand)}
.closer-panel h2{color:var(--white)}
.closer-panel h2 .m{color:rgba(245,244,241,.5)}
.col .media{border-radius:var(--r-md);overflow:hidden;aspect-ratio:16/10;margin-bottom:26px}
.col .media img{width:100%;height:100%;object-fit:cover}
.closer-panel .lead{color:var(--grey)}
.closer-panel .fine{color:var(--dim)}

/* ---------- Form ---------- */
.formwrap{max-width:520px}
.form-card{background:var(--paper2);border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,4vw,42px)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--statement);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:#7a766e;margin-bottom:8px}
.field input{width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink);
  font-family:var(--serif);font-size:16px;padding:14px 16px;transition:border-color .2s}
.field input:focus{outline:none;border-color:var(--sand)}
.field input::placeholder{color:#b3afa7}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-card .btn{width:100%;justify-content:center;margin-top:6px}
.formnote{margin-top:16px}
.alert{border-radius:var(--r-sm);padding:13px 16px;margin-bottom:22px;font-family:var(--serif);font-size:15px}
.alert.err{background:#f7e9e6;border:1px solid #e0b8af;color:#8a3d31}

/* ---------- Footer ---------- */
.foot{border-top:1px solid var(--line);padding:clamp(54px,8vh,86px) var(--mx) clamp(36px,5vh,56px)}
.foot-in{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:40px}
@media(max-width:860px){.foot-in{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-in{grid-template-columns:1fr}}
.foot .mark{display:inline-block;margin-bottom:16px;font-size:20px}
.foot .legal{font-family:var(--statement);font-size:11px;letter-spacing:.06em;line-height:1.9;color:var(--dim);text-transform:uppercase}
.foot h4{font-family:var(--statement);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);margin-bottom:16px;font-weight:700}
.foot nav a,.foot .contact a{display:block;font-family:var(--serif);font-size:15px;color:#56524b;margin-bottom:9px;transition:color .2s}
.foot nav a:hover,.foot .contact a:hover{color:var(--sand)}
.foot .signoff{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--ink);margin-top:6px}
.foot .signoff .h{color:var(--sand)}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav-links{position:fixed;inset:0 0 auto 0;flex-direction:column;align-items:flex-start;gap:22px;
    background:rgba(241,239,236,.98);padding:90px var(--mx) 40px;transform:translateY(-100%);transition:transform .35s ease;border-bottom:1px solid var(--line)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:15px;letter-spacing:.12em}
  .nav-toggle{display:block;z-index:60}
  .split{grid-template-columns:1fr;gap:34px}
  .split .media{aspect-ratio:4/3;order:-1}
  .cards,.cards.three{grid-template-columns:1fr}
}
@media(max-width:520px){
  .btn{width:100%;justify-content:center}
  .btn-row{flex-direction:column}
  .nav-login,.nav-pill{padding:9px 16px;font-size:11.5px}
  .nav-right{gap:10px}
}

/* ============================================================
   Blanket-adapted layer: floating pill nav, full-bleed photographic
   hero, immersive scroll section, pull-quote, dark footer.
   ============================================================ */

/* Nav: full-width bar, content aligned to the same frame as the page (.wrap). */
.nav{top:0;left:0;right:0;width:100%;margin:0;border:0;border-radius:0;box-shadow:none;
  background:transparent;backdrop-filter:none;
  padding-top:24px;padding-bottom:24px;
  padding-left:max(var(--pad),calc(50% - var(--maxw)/2 + var(--pad)));
  padding-right:max(var(--pad),calc(50% - var(--maxw)/2 + var(--pad)));
  transition:background .3s ease,padding .3s ease,box-shadow .3s ease}
.nav.scrolled{padding-top:14px;padding-bottom:14px;
  padding-left:max(var(--pad),calc(50% - var(--maxw)/2 + var(--pad)));
  padding-right:max(var(--pad),calc(50% - var(--maxw)/2 + var(--pad)));
  background:rgba(12,11,10,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(255,255,255,.07);border-bottom:0}
.nav .mark{margin-right:26px}
.nav-links{margin-right:auto;gap:26px}
.nav-links a{font-size:13px;font-weight:500;letter-spacing:.01em;text-transform:none;color:#56524b}
.nav-links a:hover{color:var(--ink)}
/* Over a dark hero, the top (not-scrolled) nav is light; the pill returns to dark text */
body.hero-dark .nav:not(.scrolled) .mark{color:var(--white)}
body.hero-dark .nav:not(.scrolled) .nav-links a,
body.hero-dark .nav:not(.scrolled) .nav-right a:not(.nav-pill):not(.nav-login){color:rgba(245,244,241,.82)}
body.hero-dark .nav:not(.scrolled) .nav-links a:hover,
body.hero-dark .nav:not(.scrolled) .nav-right a:not(.nav-pill):not(.nav-login):hover{color:#fff}
body.hero-dark .nav:not(.scrolled) .nav-pill{background:var(--white);color:var(--ink)}
body.hero-dark .nav:not(.scrolled) .nav-toggle{color:var(--white)}
.nav-pill{display:inline-flex;align-items:center;background:var(--ink);color:var(--paper);
  font-family:var(--statement);font-weight:700;font-size:12.5px;letter-spacing:.03em;
  padding:11px 22px;border-radius:999px;transition:background .25s}
.nav-pill:hover{background:#322d27}
.nav-login{display:inline-flex;align-items:center;background:var(--sand);color:var(--ink);
  font-family:var(--statement);font-weight:700;font-size:12.5px;letter-spacing:.03em;
  padding:11px 22px;border-radius:999px;transition:background .25s}
.nav-login:hover{background:#c2a87a}
/* Scrolled: black bar, light content */
.nav.scrolled .mark{color:var(--white)}
.nav.scrolled .nav-links a{color:#fff}
.nav.scrolled .nav-links a:hover{color:#fff}
.nav.scrolled .nav-pill{background:var(--white);color:var(--ink)}
.nav.scrolled .nav-pill:hover{background:#e6e3dc}
.nav.scrolled .nav-toggle{color:var(--white)}
body.hero-dark .nav:not(.scrolled) .nav-links a{color:#fff;text-shadow:0 1px 10px rgba(0,0,0,.35)}
@media(min-width:861px){.nav-links{position:absolute;left:50%;transform:translateX(-50%);margin-right:0}}
.nav-right{display:flex;align-items:center;gap:24px}
.nav-right a:not(.nav-pill):not(.nav-login){font-family:var(--statement);font-size:13px;color:#56524b;transition:color .2s}
.nav-right a:not(.nav-pill):not(.nav-login):hover{color:var(--ink)}

/* Split hero: text framed left, model framed right, no overlap */
/* No min-height: the TEXT column drives the height, the image matches it exactly */
.hero-split{position:relative;background:var(--dark);display:grid;grid-template-columns:.86fr 1.14fr;align-items:stretch}
.hero-split .text{color:var(--white);
  padding:var(--hero-pt) clamp(24px,3vw,48px) var(--hero-pb) max(var(--pad),calc(50% - var(--maxw)/2 + var(--pad)))}
.hero-split{--hero-pt:88px;--hero-pb:72px}
.hero-split .text .eyebrow{color:var(--sand);margin-bottom:18px}
.hero-split .text h1{color:var(--white);max-width:none;font-size:clamp(30px,3.2vw,46px);line-height:1.08}
.hero-split .text h1 .m{color:rgba(245,244,241,.5)}
.hero-split .text .lead{color:rgba(245,244,241,.86);max-width:52ch;margin-top:20px;font-size:clamp(16px,1.5vw,19px)}
.hero-split .text .btn-row{margin-top:30px}
.hero-split .text .btn-outline{color:var(--white);border-color:rgba(245,244,241,.4)}
.hero-split .text .btn-outline:hover{border-color:var(--white)}
.hero-split .text .proof{margin-top:26px}
.hero-split .media{position:relative;overflow:hidden;background:var(--dark)}
/* whole image shown (no crop) at the text height, pinned right, dark blends its left edge into the words */
.hero-split .media img{position:absolute;top:var(--hero-pt);right:0;height:calc(100% - var(--hero-pt) - var(--hero-pb));width:auto;max-width:100%;object-fit:contain}
.hero-split .media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,var(--dark) 0%,rgba(12,11,10,1) 22%,rgba(12,11,10,.5) 40%,rgba(12,11,10,0) 62%)}
@media(max-width:860px){
  .hero-split{grid-template-columns:1fr;min-height:auto;--hero-pt:0px;--hero-pb:0px}
  .hero-split .text{order:2;align-self:auto;padding:46px var(--pad) 54px}
  .hero-split .media{order:1;min-height:58vh}
  .hero-split .media::after{background:linear-gradient(0deg,rgba(12,11,10,.5) 0%,rgba(12,11,10,0) 40%)}
}

/* PDF-cover hero variant: dark, two-tone SAND title, photo fills the right half */
.hero-split.hero-pdf{min-height:76vh}
.hero-split.hero-pdf .text{display:flex;flex-direction:column;justify-content:center}
.hero-split.hero-pdf .text h1{font-size:clamp(42px,6.4vw,96px);line-height:.96;letter-spacing:-.04em}
.hero-split.hero-pdf .text h1 .m{color:var(--sand)}
.hero-split.hero-pdf .text .lead{color:#C2C0BB;font-size:clamp(18px,1.9vw,24px);max-width:32ch}
.hero-split.hero-pdf .media img{position:absolute;inset:0;top:0;width:100%;height:100%;max-width:none;object-fit:cover;object-position:62% 30%}
.hero-split.hero-pdf .media::after{background:linear-gradient(90deg,var(--dark) 0%,rgba(12,11,10,.72) 12%,rgba(12,11,10,.2) 34%,rgba(12,11,10,0) 60%)}
@media(max-width:860px){
  .hero-split.hero-pdf{min-height:auto}
  .hero-split.hero-pdf .text{order:1;padding-top:96px;padding-bottom:22px}
  .hero-split.hero-pdf .text h1{font-size:clamp(40px,12vw,62px)}
  .hero-split.hero-pdf .text .lead{margin-top:14px}
  .hero-split.hero-pdf .text .btn-row{margin-top:22px}
  .hero-split.hero-pdf .media{order:2;min-height:42vh}
  .hero-split.hero-pdf .media img{position:relative;height:100%}
  .hero-split.hero-pdf .media::after{background:linear-gradient(0deg,rgba(12,11,10,.45) 0%,rgba(12,11,10,0) 42%)}
}

/* ---------- Hero: three-photo background + copy over a scrim ---------- */
.hero-tri{position:relative;background:var(--dark);min-height:92vh;display:flex;align-items:center;overflow:hidden}
.hero-tri-imgs{position:absolute;inset:0;display:flex}
.hero-tri-imgs img{flex:1 1 0;min-width:0;height:100%;object-fit:cover}
.hero-tri-imgs img:nth-child(1){object-position:50% 50%;filter:brightness(1.13) saturate(1.95) contrast(1.05)}  /* pool */
.hero-tri-imgs img:nth-child(2){object-position:100% 0%;filter:contrast(1.22) saturate(1.2)}  /* bike + Burj */
.hero-tri-imgs img:nth-child(3){object-position:50% 42%;transform:scale(1.04) translate(0%,2%)}  /* stairs */
.hero-tri-imgs::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,rgba(12,11,10,.82) 0%,rgba(12,11,10,.66) 26%,rgba(12,11,10,.5) 44%,rgba(12,11,10,.3) 56%,rgba(12,11,10,.1) 68%,rgba(12,11,10,0) 78%)}
.hero-tri-text{position:relative;z-index:2;color:var(--white);width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.hero-tri-text h1{color:var(--white);max-width:none;font-size:clamp(32px,3.5vw,52px);line-height:1.07}
.hero-tri-text h1 .m{color:rgba(245,244,241,.55)}
.hero-tri-text .lead{color:rgba(245,244,241,.9);max-width:62ch;margin-top:20px;font-size:clamp(16px,1.5vw,19px)}
.hero-tri-text .btn-row{margin-top:32px}
.hero-tri-text .btn-outline{color:var(--white);border-color:rgba(245,244,241,.42)}
.hero-tri-text .btn-outline:hover{border-color:var(--white)}
.hero-tri-text .proof{margin-top:26px;display:flex;gap:11px;align-items:flex-start}
.hero-tri-text .proof > span:last-child{color:var(--sand);font-family:var(--statement);font-weight:600;font-size:13px;letter-spacing:.01em;line-height:1.5;max-width:54ch}
@media(max-width:860px){
  .hero-tri{min-height:auto;padding:120px 0 56px}
  .hero-tri-imgs::after{background:linear-gradient(0deg,rgba(12,11,10,.96) 0%,rgba(12,11,10,.72) 46%,rgba(12,11,10,.55) 100%)}
}

/* Full-bleed photographic hero */
.hero-full{position:relative;min-height:100svh;display:flex;align-items:flex-end;isolation:isolate;overflow:hidden}
.hero-full .bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center 28%}
.hero-full .scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(12,11,10,.62) 0%,rgba(12,11,10,.30) 32%,rgba(12,11,10,.45) 62%,rgba(12,11,10,.94) 100%),
             linear-gradient(90deg,rgba(12,11,10,.86) 0%,rgba(12,11,10,.55) 46%,rgba(12,11,10,.12) 88%)}
.hero-full .inner{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(64px,10vh,120px)}
.hero-full .eyebrow{color:var(--sand)}
.hero-full h1{color:var(--white);max-width:16ch}
.hero-full h1 .m{color:rgba(245,244,241,.5)}
.hero-full .lead{color:rgba(245,244,241,.86);max-width:48ch;margin-top:22px}
.hero-full .btn-outline{color:var(--white);border-color:rgba(245,244,241,.4)}
.hero-full .btn-outline:hover{border-color:var(--white)}
.proof{display:flex;align-items:center;gap:14px;margin-top:34px;flex-wrap:wrap}
.proof .tick{width:22px;height:22px;border-radius:999px;background:var(--sand);display:inline-flex;align-items:center;justify-content:center;flex:none}
.proof .tick::after{content:"";width:7px;height:4px;border-left:2px solid #231d10;border-bottom:2px solid #231d10;transform:rotate(-45deg);margin-top:-2px}
.proof span{font-family:var(--statement);font-size:13px;letter-spacing:.02em;color:rgba(245,244,241,.9)}

/* Press / credential strip */
.creds{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 22px;
  padding:30px var(--pad);max-width:1200px;margin:0 auto}
.creds span{font-family:var(--statement);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#9a958c;white-space:nowrap}
.creds .dot{color:var(--sand)}
/* on narrow screens drop the separator dots so nothing dangles at a line end */
@media(max-width:760px){.creds{gap:6px 16px}.creds .dot{display:none}}

/* Editorial feature columns (no card chrome) */
.cols{display:grid;gap:clamp(30px,4vw,56px)}
.cols.c2{grid-template-columns:1fr 1fr}
.cols.c3{grid-template-columns:repeat(3,1fr)}
.col h3{font-family:var(--statement);font-weight:700;letter-spacing:-.02em;font-size:clamp(20px,2.1vw,26px);margin-bottom:12px}
.col p{font-size:17px}
.col .textlink{margin-top:18px}
.col .path-tag{font-family:var(--serif);font-weight:600;font-size:clamp(17px,1.6vw,19px);line-height:1.35;color:var(--ink);margin:-2px 0 0}
.col .path-for{font-family:var(--serif);font-style:italic;font-size:16px;color:#56524b;margin:11px 0 2px;line-height:1.45}
.col p + p{margin-top:14px}
/* How-it-works flow */
.flow{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,46px)}
.flow::before{content:"";position:absolute;left:0;right:0;top:24px;height:1px;background:var(--line);z-index:0}
.flow-step{position:relative}
.flow-node{position:relative;z-index:1;width:48px;height:48px;border-radius:50%;border:1.5px solid var(--ink);background:var(--paper);display:flex;align-items:center;justify-content:center;font-family:var(--statement);font-weight:700;font-size:14px;letter-spacing:.04em;color:var(--ink);margin-bottom:22px}
.flow-step h3{font-family:var(--statement);font-weight:700;letter-spacing:-.02em;font-size:clamp(18px,1.6vw,21px);line-height:1.18;margin-bottom:10px}
.flow-step p{font-size:17px;line-height:1.6;color:#56524b}
@media(max-width:760px){
  .flow{grid-template-columns:1fr;gap:0}
  .flow::before{left:23px;right:auto;top:8px;bottom:8px;width:1px;height:auto}
  .flow-step{padding:0 0 30px 76px}
  .flow-step:last-child{padding-bottom:0}
  .flow-node{position:absolute;left:0;top:0;margin:0}
}
/* Meet Julita */
.meet{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(34px,5vw,66px);align-items:stretch}
.meet-text .eyebrow{margin-bottom:18px}
.meet-text p{font-family:var(--serif);font-size:17px;line-height:1.6;color:#46423b;margin-top:16px;max-width:56ch}
.meet-text h2 + p{margin-top:24px}
.meet-quote{font-family:var(--serif);font-size:clamp(18px,1.6vw,22px);line-height:1.42;color:var(--ink);margin:30px 0 0;padding-left:22px;border-left:2px solid var(--mute)}
.meet-media{border-radius:18px;overflow:hidden;min-height:440px}
.meet-media img{width:100%;height:100%;object-fit:cover;object-position:50% 18%}
@media(max-width:820px){.meet{grid-template-columns:1fr;gap:30px}.meet-media{order:-1;aspect-ratio:4/5;min-height:0}}
/* Checklist (two-column ticks) */
.ticks.checklist{display:grid;grid-template-columns:1fr 1fr;gap:4px clamp(30px,4vw,60px);max-width:var(--maxw);margin:0 auto}
@media(max-width:680px){.ticks.checklist{grid-template-columns:1fr}}
/* What we work on grid */
.workon{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,3vw,42px) clamp(30px,4vw,56px)}
.workon-item{border-top:1px solid var(--line);padding-top:18px}
.workon-item h4{font-family:var(--statement);font-weight:700;letter-spacing:-.01em;font-size:clamp(18px,1.6vw,21px);color:var(--ink);margin-bottom:9px}
.workon-item p{font-size:17px;line-height:1.6;color:#56524b}
@media(max-width:820px){.workon{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.workon{grid-template-columns:1fr}}
/* FAQ accordion */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:28px;
  font-family:var(--statement);font-weight:600;font-size:clamp(16px,1.5vw,19px);color:var(--ink);padding:24px 2px;transition:color .2s}
.faq-item summary:hover{color:#56524b}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:var(--statement);font-weight:400;font-size:26px;color:var(--mute);transition:transform .25s ease;line-height:1;flex:none}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{font-family:var(--serif);font-size:17px;line-height:1.6;color:#46423b;padding:0 2px 24px;max-width:66ch}
/* mobile reading comfort */
@media(max-width:680px){.ticks li{line-height:1.66}.faq-item p{line-height:1.68}.hero-split + .wrap{padding-top:clamp(44px,9vw,60px)}}
/* Contact closer line */
.closer-contact{font-family:var(--statement);font-size:13.5px;letter-spacing:.01em;color:var(--grey);margin:26px auto 0;text-align:center;max-width:none}
.icon-row{display:flex;justify-content:center;gap:16px;margin-top:34px}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;border:1px solid rgba(245,244,241,.25);color:var(--white);transition:background .25s,color .25s,border-color .25s,transform .2s}
.icon-btn svg{width:23px;height:23px;fill:currentColor}
.icon-btn:hover{background:var(--sand);border-color:var(--sand);color:var(--ink);transform:translateY(-2px)}

/* Pull-quote */
.quote{display:grid;grid-template-columns:1.34fr .66fr;gap:clamp(40px,6vw,84px);align-items:center}
.quote .mark{font-family:var(--serif);font-size:64px;line-height:.6;color:var(--mute);height:32px}
.quote blockquote{font-family:var(--serif);font-weight:400;font-size:clamp(24px,3vw,37px);line-height:1.3;color:var(--ink);margin:20px 0 26px}
.quote .by{display:flex;align-items:center;gap:12px;font-family:var(--statement);font-size:14px;color:#56524b}
.quote .by b{color:var(--ink);font-weight:700}
.quote .qmedia{aspect-ratio:4/5;border-radius:var(--r-md);overflow:hidden}
.quote .qmedia img{width:100%;height:100%;object-fit:cover}

/* Dark footer variant */
.foot.dark{background:var(--dark);border-top:0;color:var(--grey)}
.foot.dark .mark{color:var(--white)}
.foot.dark .legal,.foot.dark h4{color:var(--dim)}
.foot.dark nav a,.foot.dark .contact a{color:var(--grey)}
.foot.dark nav a:hover,.foot.dark .contact a:hover{color:var(--sand)}
.foot.dark .signoff{color:var(--white)}

/* ---- Rhythm: tighter, more deliberate vertical spacing (blanket-grade) ---- */
.hero-full .eyebrow{margin-bottom:18px}
.hero-full .lead{margin-top:20px;max-width:46ch}
.hero-full .btn-row{margin-top:30px}
.hero-full .proof{margin-top:24px}
.btn-row{margin-top:30px}
h2 + .lead,.hair + .lead{margin-top:18px}
.num{margin-bottom:12px}
.steps{gap:clamp(26px,3vw,40px) clamp(40px,6vw,84px)}
.step{padding-top:20px}
.creds{padding-top:26px;padding-bottom:26px}
.section-head{margin-bottom:clamp(26px,3.2vw,42px)}

@media(max-width:860px){
  .nav-right{gap:14px}
  .nav-right a:not(.nav-pill):not(.nav-login){display:none}
  .cols.c2,.cols.c3{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .quote{grid-template-columns:1fr}
  .quote .qmedia{order:-1;aspect-ratio:4/3;max-height:54vh}
}

/* ---- Footer legal bar: legal links + consent disclaimer + copyright (added with legal pages) ---- */
.foot-base{max-width:var(--maxw);margin:34px auto 0;padding-top:26px;border-top:1px solid rgba(245,244,241,.12);
  display:flex;flex-wrap:wrap;align-items:center;gap:12px 26px;justify-content:space-between}
.foot-legal-links{display:flex;flex-wrap:wrap;gap:22px}
.foot-legal-links a{font-family:var(--statement);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey);transition:color .2s}
.foot-legal-links a:hover{color:var(--sand)}
.foot-copy{font-family:var(--statement);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--dim);margin:0}
.foot-consent{flex:1 1 100%;order:3;font-family:var(--serif);font-size:13px;line-height:1.6;color:var(--grey);max-width:none;margin:8px 0 0}
.foot-consent a{color:var(--grey);border-bottom:1px solid rgba(245,244,241,.2);transition:color .2s,border-color .2s}
.foot-consent a:hover{color:var(--sand);border-color:var(--sand)}
.foot:not(.dark) .foot-base{border-top-color:var(--line)}
.foot:not(.dark) .foot-legal-links a,.foot:not(.dark) .foot-copy,.foot:not(.dark) .foot-consent{color:var(--dim)}
.foot:not(.dark) .foot-consent a{color:#56524b;border-bottom-color:var(--hair)}
