/* 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:#F4F3F1;        /* baseline ground (canonical, matches lead-magnet-offer-style.html) */
  --paper2:#FBFAF8;       /* lifted card surface */
  --ink:#141414;          /* statement + body on paper (canonical) */
  --mute:#BCB9B2;         /* dots, marks, faint accents */
  --turn:#7D7A73;         /* 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(64px,6.5vw,108px);
  --headgap:clamp(36px,4vw,56px);
  --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:96px}
:focus-visible{outline:2px solid var(--sand);outline-offset:3px}
.skip{position:absolute;left:-9999px;top:0;z-index:100;background:var(--ink);color:var(--paper);font-family:var(--statement);font-weight:700;font-size:13px;letter-spacing:.04em;padding:12px 20px;border-radius:0 0 10px 0}
.skip:focus{left:0}
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(--turn)}
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:18px}
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:#67635b}
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:clamp(16px,2vw,32px)}
.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}
.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-toggle{display:none;background:none;border:0;color:var(--ink);font-size:21px;cursor:pointer;line-height:1}
/* Drawer-only links (Home, Login): hidden on desktop, shown inside the mobile drawer */
.nav-links .drawer-only{display:none}

/* ---------- 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 .card-sub{font-family:var(--serif);font-weight:600;font-size:16px;line-height:1.4;color:var(--eye);margin:-6px 0 12px}

/* Credential card (CETI / REPs: logo + what it is + link; no certificate scans on the site) */
.cred-card{background:var(--paper2);border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,3.2vw,44px);display:flex;flex-direction:column;justify-content:center;align-self:start}
.cred-card .cred-logo{height:clamp(56px,6vw,72px);width:auto;max-width:100%;margin-bottom:22px;align-self:flex-start;object-fit:contain}
.cred-card p{font-size:16px;line-height:1.62;color:#46423b}
.cred-card p + p{margin-top:12px}
.cred-card .textlink{margin-top:22px;align-self:flex-start}
.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}
/* two balanced columns on desktop (CSS multicol balances height, so odd item counts don't leave ragged column bottoms) */
@media(min-width:720px){.tier .ticks{display:block;column-count:2;column-gap:clamp(34px,4vw,60px);max-width:none}.tier .ticks li{break-inside:avoid;margin-bottom:15px}}
/* 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 on a quiet lifted card so the row reads as one set with the photo tiles */
.tier-media .tile.app{background:var(--paper2);border:1px solid var(--line);display:flex;align-items:flex-end;justify-content:center;padding:clamp(14px,2vw,22px) clamp(10px,1.5vw,18px) 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}
/* one muted grade across the journey frames so the mixed-source memories read as a single, intentional strip */
.journey-row .frame img{width:100%;height:100%;object-fit:cover;filter:grayscale(.4) contrast(1.03) brightness(1.0)}
@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:var(--paper2);display:flex;align-items:center;justify-content:center;padding:clamp(14px,1.8vw,26px);border:1px solid var(--line)}
/* mute the colour bench photo a touch so it doesn't clash with the desaturated journey strip above */
.spec-photos .frame:not(.cert) img{filter:grayscale(.28) contrast(1.03)}
.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 closer (the one dark moment) ---------- */
/* light top padding: the section above already carries --sec bottom padding */
.closer{padding:clamp(12px,1.5vw,24px) var(--pad) var(--sec)}
.closer-panel{max-width:calc(var(--maxw) - var(--pad)*2);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:var(--sand)}
.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);text-wrap:balance}
.closer-panel .fine{color:var(--dim)}
/* the panel is always a dark surface, so its outline button must read light regardless of the .dark class (keeps the closer one signature across every page) */
.closer-panel .btn-outline{color:var(--white);border-color:rgba(245,244,241,.32)}
.closer-panel .btn-outline:hover{border-color:var(--white)}

/* ---------- 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{border-color:var(--sand)}
.field input::placeholder{color:#b3afa7}
.field textarea{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;resize:none;min-height:88px;transition:border-color .2s}
.field textarea:focus{border-color:var(--sand)}
.field textarea::placeholder{color:#b3afa7}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.icon-col{display:flex;flex-direction:column;align-items:center;gap:9px}
.icon-cap{font-family:var(--statement);font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--grey)}
.closer-fine{margin:26px auto 0;text-align:center;color:var(--grey)}
.nb{white-space:nowrap}
@media(max-width:560px){.sep-m{display:none}.proof .nb{display:block}.story-creds .sep{display:none}.story-creds span:not(.sep){display:block}}

.hero-split .btn-row .btn{padding:15px 26px}

/* mandatory consent checkbox */
.check{display:flex;gap:10px;align-items:flex-start;cursor:pointer;margin-top:4px}
.check input{margin-top:4px;width:16px;height:16px;flex:none;accent-color:var(--ink)}
.check span{font-family:var(--serif);font-size:14px;line-height:1.55;color:#56524b}
.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(38px,5.5vh,60px) var(--mx) clamp(30px,4.5vh,48px)}
/* first row mirrors the header: wordmark left, page links right, on the page frame */
.foot-in{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:flex;align-items:center;justify-content:space-between;gap:16px 28px;flex-wrap:wrap}
.foot .mark{display:inline-block;margin-bottom:0;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}
/* headingless horizontal page links */
.foot .foot-links{display:flex;flex-wrap:wrap;gap:10px 26px;align-self:center}
.foot .foot-links a{display:inline-block;margin:0}
.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(244,243,241,.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 .drawer-only{display:block}
  .nav-toggle{display:block;z-index:60}
  /* The open drawer is a light surface: force dark links + toggle regardless of hero-dark/scrolled state */
  .nav-links.open a,
  body.hero-dark .nav:not(.scrolled) .nav-links.open a{color:var(--ink);text-shadow:none}
  .nav-toggle[aria-expanded="true"],
  body.hero-dark .nav:not(.scrolled) .nav-toggle[aria-expanded="true"]{color:var(--ink)}
  /* Login lives in the drawer on mobile, not as a second pill crowding the bar */
  .nav-right .nav-login{display:none}
  .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}
}

/* ============================================================
   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((100% - var(--maxw))/2 + var(--pad)));
  padding-right:max(var(--pad),calc((100% - 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((100% - var(--maxw))/2 + var(--pad)));
  padding-right:max(var(--pad),calc((100% - 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(--sand);color:var(--ink)}
body.hero-dark .nav:not(.scrolled) .nav-login{color:#F5F4F1;border-color:rgba(245,244,241,.62);background:rgba(12,11,10,.28)}
body.hero-dark .nav:not(.scrolled) .nav-toggle{color:var(--white)}
.nav-pill{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-pill:hover{background:#c2a87a}
.nav-login{display:inline-flex;align-items:center;background:transparent;color:#3d3a35;border:1px solid rgba(23,21,19,.4);
  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{border-color:var(--ink);color:var(--ink)}
/* 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(--sand);color:var(--ink)}
.nav.scrolled .nav-pill:hover{background:#c2a87a}
.nav.scrolled .nav-toggle{color:var(--white)}
@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{padding-top:0;padding-bottom:0;min-height:clamp(660px,92vh,930px);position:relative;background:var(--dark);display:grid;grid-template-columns:1.02fr .98fr;align-items:stretch}
.hero-split .text{color:var(--white);
  /* 50vw (not 50%): the % would resolve against the narrow grid column, pushing the
     hero text wider than the page frame below it */
  padding:var(--hero-pt) clamp(24px,3vw,48px) var(--hero-pb) max(var(--pad),calc(50vw - 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:18px;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:58vh}
  .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%;transform:scale(1.16);transform-origin:58% 100%;filter:contrast(1.22) saturate(1.2)}  /* bike + Burj, moderate zoom: Julita prominent, tower kept */
.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,.86) 0%,rgba(12,11,10,.72) 28%,rgba(12,11,10,.58) 48%,rgba(12,11,10,.34) 60%,rgba(12,11,10,.12) 70%,rgba(12,11,10,0) 80%)}
.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:18px;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:#6E6E6C;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)}
/* routing cards: flex columns so the "Explore" links bottom-align across unequal copy lengths */
.cols.c2 .col{display:flex;flex-direction:column}
.cols.c2 .col .textlink{margin-top:auto;padding-top:22px;align-self:flex-start}
.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-lead{font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(17px,1.6vw,19px);line-height:1.4;color:var(--ink);margin:-2px 0 14px}
.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}
}
/* (segment chips retired 2026-07-02: the routing heading does the work) */
/* 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(20px,2vw,26px);line-height:1.3;color:var(--ink);margin:32px 0 0;padding-left:22px;border-left:2px solid var(--ink)}
.meet-quote cite{display:block;margin-top:14px;font-style:normal;font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--eye)}
.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}
.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:20px;height:20px;fill:currentColor}/* 20px + per-icon viewBox crops (index closer) = equal ~20px optical glyph size */
.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)}
/* footer contact icons: 4-class selector beats .foot .contact a text-link rules (see lessons 2026-06-22) */
.foot .contact{width:max-content}
.foot .contact h4{text-align:center}
.foot .contact .icon-row{justify-content:flex-start;gap:14px;margin-top:6px}
.foot.dark .contact .icon-btn{display:inline-flex;margin:0;color:var(--white);background:transparent;border-color:rgba(245,244,241,.25)}
.foot.dark .contact .icon-btn:hover{background:var(--sand);border-color:var(--sand);color:var(--ink)}
.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:calc(var(--maxw) - var(--pad)*2);margin:34px auto 0;padding:26px 0 0;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:hover{color:var(--sand)}
.foot-copy{font-family:var(--statement);font-size:13px;letter-spacing:.02em;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)}

/* ---------- Julita story band (dark, full-bleed, competition cutout) ----------
   The one founder moment on the page: cutout on the dark field, sand reserved
   for the heading turn, quote rule and credential caps (sand-on-dark only). */
.story{background:var(--dark);padding:0}
.story + section{padding-top:var(--sec)}
/* vertical padding lives on the grid so the cutout's feet line up with the credential row */
.story-in{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,7vw,110px) var(--pad);display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(28px,4vw,64px);align-items:end}
.story-text{padding:0}
.story-text h2{color:var(--white)}
.story-text h2 .m{color:var(--sand)}
.story-text p{color:rgba(245,244,241,.78);margin-top:16px;max-width:56ch}
.story-text h2 + p{margin-top:26px}
.story-quote{font-family:var(--serif);font-size:clamp(19px,1.9vw,25px);line-height:1.35;color:var(--white);margin:30px 0 0}
.story-quote cite{display:block;margin-top:12px;font-style:normal;font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--sand)}
.story-creds{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:32px;padding-top:24px;border-top:1px solid rgba(245,244,241,.14)}
.story-creds span{font-family:var(--statement);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--sand)}
.story-creds .sep{color:rgba(245,244,241,.35)}
.story-media{position:relative;align-self:stretch;display:flex;align-items:flex-end;justify-content:center}
.story-media::before{content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:min(52vw,560px);height:82%;
  background:radial-gradient(ellipse at 50% 78%,rgba(208,182,136,.30),rgba(208,182,136,.10) 46%,transparent 72%);pointer-events:none}
.story-media img{position:relative;z-index:1;width:auto;max-width:100%;max-height:min(660px,76vh);align-self:flex-end;filter:drop-shadow(0 34px 60px rgba(0,0,0,.6));-webkit-mask-image:linear-gradient(to bottom,#000 88%,transparent);mask-image:linear-gradient(to bottom,#000 88%,transparent)}
@media(max-width:860px){
  .story-in{grid-template-columns:1fr;gap:0;padding-top:44px;padding-bottom:56px}
  /* headline and story lead; the stage photo follows as biography, not banner */
  .story-media img{max-height:52vh}
  .story-media::before{width:80vw}
  .story-text{padding:0 0 34px}
}

/* ---------- Free-guide strip ---------- */
.guide-strip{display:grid;grid-template-columns:.58fr 1.42fr;gap:clamp(30px,4.5vw,70px);align-items:center;
  background:var(--paper2);border:1px solid var(--line);border-radius:var(--r);padding:clamp(30px,4vw,56px)}
.guide-strip .gmedia{display:flex;justify-content:center;padding:10px 0}
.guide-strip .gmedia img{width:min(100%,280px);height:auto;border-radius:6px;transform:rotate(-3.5deg);
  box-shadow:0 24px 48px -18px rgba(23,21,19,.35),0 4px 14px rgba(23,21,19,.12)}
.guide-strip h2{font-size:clamp(23px,2.6vw,32px)}
.guide-strip p{margin-top:14px}
.guide-strip .btn-row{margin-top:26px}
@media(max-width:760px){.guide-strip{grid-template-columns:1fr}.guide-strip .gmedia img{width:min(58%,230px)}}

/* ---------- Support columns (nutrition / habits / consistency) ---------- */
.cols.c3 .col .media{aspect-ratio:4/5;border-radius:var(--r-md);overflow:hidden;margin-bottom:22px;background:#141210;box-shadow:0 18px 40px -20px rgba(23,21,19,.4),0 4px 12px rgba(23,21,19,.08)}
.cols.c3 .col .media img{width:100%;height:100%;object-fit:cover;filter:saturate(1.06) contrast(1.03)}
/* phone floats free (no card chrome), full device visible, soft drop shadow.
   flex:none + aspect-ratio pin the device's true proportions (Safari stretches
   auto-width flex images otherwise). */
.col .media.app{background:transparent;border:0;display:flex;align-items:center;justify-content:center;padding:0}
.cols.c3 .col .media.app{border-radius:0;overflow:visible}
.cols.c3 .col .media.app img{flex:none;height:100%;width:auto;aspect-ratio:1800/3728;object-fit:contain;
  filter:drop-shadow(0 20px 36px rgba(23,21,19,.24))}

/* ---------- R1 fresh-eyes review fixes (2026-07-03) ---------- */
/* Short pages: dark footer always closes the viewport */
body{min-height:100svh;display:flex;flex-direction:column}
body>footer.foot{margin-top:auto}
/* Paragraphs that follow a tick list get breathing room (privacy/terms) */
.ticks+p{margin-top:20px}
/* Unloaded lazy images look intentional, never like a broken page */
.col .media{background:#ECE9E3}
.guide-strip .gmedia img{background:#101010;min-height:200px}
/* Process connector stops at the last node (desktop right overrun, mobile tail) */
@media(min-width:761px){
  .flow-step:last-child::after{content:"";position:absolute;left:48px;right:0;top:24px;height:1px;background:var(--paper)}
  .flow-step h3{min-height:2.4em}
}
@media(max-width:760px){
  .flow-step:last-child::after{content:"";position:absolute;left:23px;top:48px;bottom:0;width:1px;background:var(--paper)}
}
/* FAQ aligns under its heading (owner call 2026-07-02, reaffirmed 2026-07-04) */
.faq{margin-inline:0}
/* Mobile: hero proof pairs stack without the orphan gap; footer links stack clean */
@media(max-width:560px){
  .proof br{display:none}
  .foot .foot-links{flex-direction:column;gap:10px}
}

/* R2 QA fixes */
.col .media.app{background:#ECE9E3}
@media(max-width:860px){
  .nav-links{visibility:hidden;transition:transform .35s ease,visibility 0s .35s}
  .nav-links.open{visibility:visible;transition:transform .35s ease,visibility 0s 0s}
}

/* R2 typography fixes */
@media(max-width:719px){.legal-block h2 .m{display:inline}}
@media(min-width:861px){.card .card-sub{min-height:2.7em}}

/* R3 accessibility fixes */
.nav.scrolled .nav-login{color:var(--white);border-color:rgba(245,244,241,.62)}
:is(a,button,summary,input,textarea):focus-visible{outline:2px solid var(--ink);outline-offset:3px;box-shadow:0 0 0 5px rgba(244,243,241,.9)}
.foot :is(a):focus-visible,.closer-panel :is(a):focus-visible,.dark :is(a):focus-visible{outline-color:var(--sand);box-shadow:none}
.field input:focus-visible,.field textarea:focus-visible{outline:2px solid var(--ink);outline-offset:2px;box-shadow:none}
.field ::placeholder{color:#767268}
.nav-toggle{padding:10px;margin:-10px}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition-duration:.01ms !important;animation-duration:.01ms !important}
}

/* R3 mobile UX fixes */
@media(max-width:860px){.hero-split .media{max-height:96svh}}
@media(max-width:560px){.proof .tick{display:none}}
.check input{width:20px;height:20px}

/* R3 designer fixes */
.hero-tri-text .lead{max-width:48ch}

/* R5 brand coherence: dark-surface headline turns are always sand */
.hero-tri h1 .m{color:var(--sand)}

/* R6 gate: hero credentials stay on the scrimmed zone */
.hero-tri-text .proof{max-width:48ch}

/* R6 rival teardown fixes */
.nav-links a[aria-current="page"]{text-decoration:underline;text-underline-offset:7px;text-decoration-thickness:1.5px}
.faq-item summary::after{color:#6E6E6C}

/* R6 CSS audit fixes */
body>section,body>main{width:100%}
.cols.c3 .col .media.app{border-radius:var(--r-md);overflow:hidden}
@media(max-width:860px){
  .nav.scrolled .nav-links.open a{color:var(--ink)}
  .nav.scrolled .nav-toggle[aria-expanded="true"]{color:var(--ink)}
}

/* R7 creative director trims */
.hero-tri-text .proof{text-shadow:0 1px 14px rgba(0,0,0,.5)}

/* habits tile: real three-screen app trio (authoritative override) */
.cols.c3 .col .media.app{background:#ECE9E3;border-radius:var(--r-md);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:clamp(14px,1.6vw,24px)}
.cols.c3 .col .media.app img{flex:none;width:100%;height:auto;max-height:100%;aspect-ratio:auto;object-fit:contain;filter:none}

/* section heading rhythm: ONE gap token everywhere */
.sechead{margin-bottom:var(--headgap)}
.offers-cta{margin:clamp(44px,5vw,72px) auto 0}

/* hero bottom credential line: gives the tall dark text column a grounded foot */
.hero-split .text{position:relative}
.hero-split .hero-creds{margin-top:clamp(28px,4.5vh,44px);
  font-family:var(--statement);font-weight:700;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(245,244,241,.5);line-height:2}

/* credential block: editorial, no widget box */
.cred-block{align-self:start;padding-top:0;border-top:0}
.cred-block .cred-logo{height:44px;width:auto;max-width:100%;margin:0 0 20px;align-self:flex-start;object-fit:contain}
.cred-block p{font-size:16px;line-height:1.62;color:#46423b}
.cred-block p + p{margin-top:12px}
.cred-block .textlink{display:inline-block;margin-top:22px}

.hero-split .hero-creds .sep-m{display:none}
.hero-split .hero-creds .nb{display:block}

/* ---- UNIFORMITY LAYER (2026-07-03): one scale, one frame. Keep LAST in file. ---- */
.rule-full{max-width:calc(var(--maxw) - var(--pad)*2);margin:0 auto}
.guide-strip h2{font-size:clamp(25px,3vw,37px)}                 /* h2 is h2 everywhere */
.col h3,.card h3,.cols.c3 .col h3{font-size:clamp(20px,2.1vw,24px)}  /* one card-title size */
.hero-split .text .lead,.hero-split.hero-pdf .text .lead{font-size:clamp(17px,1.6vw,21px);max-width:44ch}  /* hero leads on the body-lead scale */
.flow-step h3{font-size:clamp(20px,2.1vw,24px)}                 /* process titles on the card-title scale */
.btn{line-height:1.45}                                          /* anchors + buttons same height */
.gmedia img{border-radius:var(--r-sm)}                          /* token radius on the guide cover */
.legal-doc{margin:0 auto}                                       /* .wrap centering restored; frame via .wrap */

/* ---- habits triptych: ONE container spec (2026-07-04, supersedes scattered .media.app rules) ---- */
.cols.c3 .col .media.app{background:radial-gradient(115% 85% at 50% 22%,#F4F1EC 0%,#E8E3DB 100%);border:0;border-radius:var(--r-md);overflow:hidden;display:block;padding:0}
.cols.c3 .col .media.app img{width:100%;height:100%;max-height:none;object-fit:cover;object-position:50% 50%;aspect-ratio:auto;flex:initial;filter:none;transform:none}

/* Mobile: hero credential caps flow below the buttons instead of absolute-overlapping them (fix 2026-07-05) */

/* ---- Justified body copy sitewide (owner request 2026-07-05) ---- */
main p, main .lead, main .ticks li{text-align:justify;text-justify:inter-word}
main .center, main .center p, main .center .lead, main .center .measure,
.closer-panel, .closer-panel p, .closer-panel .lead, .closer-panel .fine{text-align:center}
/* the four-across "how it works" process reads better ragged, not justified (owner) */
.flow-step p{text-align:left}

/* Tighten + balance the space between stacked sections (was ~120px, bottom-heavy) */
main section:has(+ section), main section:has(+ .rule-full), main .rule-full:has(+ section){padding-bottom:clamp(20px,2.4vw,40px)}

/* ---- Cookie notice (informational, non-blocking) ---- */
.cookie-note{position:fixed;left:16px;right:16px;bottom:16px;z-index:200;max-width:660px;margin:0 auto;
  background:var(--dark);color:var(--grey);border-radius:var(--r-sm);padding:15px 20px;
  display:flex;align-items:center;gap:18px;box-shadow:0 14px 44px rgba(0,0,0,.4);
  font-family:var(--serif);font-size:14px;line-height:1.5}
.cookie-note p{margin:0;color:var(--grey);font-size:14px;line-height:1.5;max-width:none;text-align:left}
.cookie-note a{color:var(--sand);border-bottom:1px solid rgba(208,182,136,.45)}
.cookie-note a:hover{border-bottom-color:var(--sand)}
.cookie-note button{flex:none;background:var(--sand);color:#231d10;border:0;border-radius:999px;
  padding:9px 22px;font-family:var(--statement);font-weight:700;font-size:12px;letter-spacing:.03em;cursor:pointer;transition:background .2s}
.cookie-note button:hover{background:#c6a877}
@media(max-width:560px){.cookie-note{flex-direction:column;align-items:stretch;text-align:center}.cookie-note p{text-align:center}}
