/* =====================================================================
   THE YORKSHIRE HYGIENIST - Facial Aesthetics, Wakefield
   Brand: quiet-luxury sage + elegant serif (matched to Laura's real logo)
   ===================================================================== */

:root{
  /* Sage family - drawn from the real logo */
  --sage:        #8c9488;
  --sage-deep:   #3f483f;   /* deep forest sage - dark sections & headings */
  --sage-mid:    #6c766b;
  --sage-light:  #aab2a3;
  --sage-mist:   #dfe2d8;

  /* Warm neutrals */
  --cream:   #f4f0e8;   /* page background */
  --ivory:   #fbf9f3;
  --oat:     #eae3d6;   /* soft warm section */
  --ink:     #32362e;   /* warm near-black text */
  --ink-soft:#5b6056;

  /* Single warm accent - sophisticated clay, never pink */
  --clay:      #b08869;
  --clay-deep: #976f4f;

  --line: rgba(63,72,63,.14);
  --line-light: rgba(255,255,255,.16);

  --ease: cubic-bezier(.16,1,.3,1);
  --ease-soft: cubic-bezier(.25,.46,.45,.94);

  --nav-h: 78px;
  --max: 1180px;
  --max-narrow: 940px;
  --gap: clamp(72px, 9vw, 128px);
}

/* ---------- reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}

/* Lenis smooth-scroll: let the library own scrolling. Native CSS smooth-scroll
   must stay OFF while Lenis is active or the two fight each other. */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-smooth iframe{pointer-events:none}
/* No Lenis (reduced-motion / load failure): fall back to native smooth scroll */
html:not(.lenis){scroll-behavior:smooth}
body{
  font-family:'Jost',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- type primitives ---------- */
.display{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(2rem,4.6vw,3.6rem);
  line-height:1.08;
  letter-spacing:.005em;
  color:var(--sage-deep);
}
.display--light{color:var(--ivory)}

.eyebrow{
  display:inline-block;
  font-family:'Jost',sans-serif;
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--clay-deep);
  margin-bottom:1.4rem;
}
.eyebrow--light{color:var(--sage-light)}

.lede{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.15rem,1.9vw,1.5rem);
  font-style:italic;
  font-weight:400;
  color:var(--ink-soft);
  max-width:42ch;
  margin-top:1.3rem;
  line-height:1.5;
}

.section{
  padding:var(--gap) clamp(20px,5vw,48px);
  max-width:var(--max);
  margin-inline:auto;
}
.section__head{max-width:var(--max-narrow);margin-inline:auto;text-align:center;margin-bottom:clamp(40px,5vw,64px)}
.section__head .lede{margin-inline:auto}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Jost',sans-serif;font-weight:500;font-size:.82rem;
  letter-spacing:.12em;text-transform:uppercase;
  padding:1rem 2rem;border-radius:2px;
  transition:transform .35s var(--ease), background .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease);
  cursor:pointer;border:1px solid transparent;white-space:nowrap;
}
.btn--solid{background:var(--clay);color:var(--ivory)}
.btn--solid:hover{background:var(--clay-deep);transform:translateY(-2px);box-shadow:0 14px 30px rgba(151,111,79,.26)}
.btn--ghost{background:transparent;border-color:var(--sage-deep);color:var(--sage-deep)}
.btn--ghost:hover{background:var(--sage-deep);color:var(--ivory);transform:translateY(-2px)}
.btn--cream{background:var(--ivory);color:var(--sage-deep)}
.btn--cream:hover{background:#fff;transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.18)}
.btn--linelight{background:transparent;border-color:var(--line-light);color:var(--ivory)}
.btn--linelight:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}

.link-arrow{
  font-family:'Jost',sans-serif;font-size:.78rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);
  display:inline-flex;align-items:center;gap:.6rem;
}
.link-arrow span{transition:transform .35s var(--ease)}
.link-arrow:hover span{transform:translateX(6px)}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:50;height:var(--nav-h);
  display:flex;align-items:center;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), height .4s var(--ease);
}
.nav.is-scrolled{
  background:rgba(244,240,232,.9);
  backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line);
  height:66px;
}
.nav__inner{
  width:100%;max-width:1320px;margin-inline:auto;
  padding:0 clamp(20px,5vw,48px);
  display:flex;align-items:center;justify-content:space-between;gap:1.4rem;
}

.wordmark{display:flex;flex-direction:column;line-height:.96;color:var(--sage-deep)}
.wordmark__l1{font-family:'Cormorant Garamond',serif;font-size:.86rem;letter-spacing:.42em;text-transform:uppercase;font-weight:500;padding-left:.06em}
.wordmark__l2{font-family:'Cormorant Garamond',serif;font-size:1.5rem;letter-spacing:.3em;text-transform:uppercase;font-weight:400;margin-top:.12em}

.nav__links{display:flex;gap:1.5rem}
.nav__links a{
  font-size:.72rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);position:relative;padding:.3rem 0;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--clay-deep);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);
}
.nav__links a:hover{color:var(--sage-deep)}
.nav__links a:hover::after{transform:scaleX(1)}

.nav__right{display:flex;align-items:center;gap:1.1rem}
.nav__gdc{
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-mid);
  border:1px solid var(--line);border-radius:2px;padding:.4rem .65rem;
}
.nav__cta{padding:.65rem 1.15rem;font-size:.68rem;letter-spacing:.1em}

.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:1.5px;background:var(--sage-deep);transition:.3s var(--ease)}

/* mobile drawer */
.drawer{
  position:fixed;top:0;right:0;height:100%;width:min(82vw,340px);z-index:60;
  background:var(--ivory);padding:6rem 2.2rem 2rem;
  transform:translateX(100%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;justify-content:space-between;
}
.drawer.is-open{transform:translateX(0)}
.drawer__links{display:flex;flex-direction:column;gap:1.6rem}
.drawer__links a{font-family:'Cormorant Garamond',serif;font-size:1.5rem;letter-spacing:.04em;color:var(--sage-deep)}
.drawer__links .btn{margin-top:1rem;font-family:'Jost',sans-serif;font-size:.8rem}
.drawer__meta{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage-mid)}
.drawer__scrim{position:fixed;inset:0;background:rgba(50,54,46,.4);z-index:55;opacity:0;pointer-events:none;transition:opacity .45s var(--ease)}
.drawer__scrim.is-open{opacity:1;pointer-events:auto}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;padding-top:var(--nav-h);overflow:hidden;background:var(--cream)}
.hero__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 82% 12%, rgba(140,148,136,.22), transparent 60%),
    radial-gradient(90% 70% at 10% 100%, rgba(176,136,105,.10), transparent 55%);
  pointer-events:none;
}
.hero__inner{
  position:relative;max-width:var(--max);margin-inline:auto;
  padding:clamp(40px,6vw,80px) clamp(20px,5vw,48px) clamp(48px,5vw,72px);
  display:grid;grid-template-columns:1.05fr .85fr;gap:clamp(32px,5vw,72px);align-items:center;
}
.hero__content{max-width:34rem}
.badge{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--sage-deep);color:var(--cream);
  font-size:.66rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  padding:.55rem 1rem;border-radius:2px;margin-bottom:1.8rem;
}
.badge__icon{width:15px;height:15px;flex-shrink:0}

.hero__title{font-family:'Cormorant Garamond',serif;color:var(--sage-deep);font-weight:300;margin-bottom:.4rem}
.hero__title-1{display:block;font-size:clamp(2.2rem,4.8vw,3.6rem);letter-spacing:.1em;text-transform:uppercase;line-height:1}
.hero__title-2{display:block;font-size:clamp(2.8rem,6.4vw,5rem);letter-spacing:.07em;text-transform:uppercase;line-height:.94;font-weight:400}

.hero__sub{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:clamp(1.2rem,2.2vw,1.65rem);color:var(--clay-deep);
  margin:1.2rem 0 1.6rem;line-height:1.4;max-width:30ch;
}
.hero__stats{
  font-size:.78rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:2.2rem;
}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}

/* hero media */
.hero__media{position:relative}
.portrait{
  position:relative;overflow:hidden;border-radius:3px;
  background:
    linear-gradient(150deg, var(--sage-light), var(--sage-mid) 70%);
  display:flex;align-items:flex-end;justify-content:center;
  box-shadow:0 24px 60px rgba(63,72,63,.16);
}
.portrait img{
  width:100%;height:100%;object-fit:cover;object-position:center 22%;
  position:relative;z-index:1;display:block;
}
.portrait--about img{object-position:center 30%}
/* diagonal texture only decorates the empty placeholder, never a real photo */
.portrait::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0 2px,transparent 2px 7px);
  mix-blend-mode:overlay;
}
.portrait:has(img)::after{display:none}
.portrait__cap{
  position:relative;z-index:1;font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:.95rem;letter-spacing:.06em;color:rgba(255,255,255,.82);padding:1.4rem;text-align:center;
}
.portrait--hero{aspect-ratio:4/5;border-left:2px solid var(--clay)}
.hero__seal{
  position:absolute;left:-22px;bottom:30px;z-index:2;
  background:var(--ivory);box-shadow:0 12px 34px rgba(50,54,46,.16);
  padding:.9rem 1.2rem;border-radius:2px;display:flex;flex-direction:column;line-height:1.2;
}
.hero__seal em{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.25rem;color:var(--clay-deep)}
.hero__seal strong{font-size:.6rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--sage-mid)}

.hero__rule{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,5vw,48px)}
.hero__rule span{display:block;height:1px;background:var(--line)}

/* =====================================================================
   TRUST BAR
   ===================================================================== */
.trust{background:var(--sage-deep)}
.trust__list{
  max-width:var(--max);margin-inline:auto;padding:1.3rem clamp(20px,5vw,48px);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.4rem 1.6rem;
}
.trust__list li{
  position:relative;color:var(--cream);font-size:.72rem;font-weight:400;
  letter-spacing:.16em;text-transform:uppercase;padding-right:1.6rem;
}
.trust__list li::after{content:"·";position:absolute;right:0;color:var(--sage-light)}
.trust__list li:last-child{padding-right:0}
.trust__list li:last-child::after{display:none}

/* =====================================================================
   WHY
   ===================================================================== */
.why{background:var(--cream)}
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.card{
  background:var(--ivory);border:1px solid var(--line);border-radius:3px;
  padding:2.4rem 1.7rem;text-align:left;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(63,72,63,.1)}
.card__icon{
  display:flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;background:var(--sage-mist);color:var(--sage-deep);
  margin-bottom:1.4rem;
}
.card__icon svg{width:26px;height:26px}
.card h3{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.45rem;color:var(--sage-deep);line-height:1.15;margin-bottom:.7rem}
.card p{font-size:.92rem;color:var(--ink-soft)}

/* =====================================================================
   ABOUT
   ===================================================================== */
.about{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,72px);align-items:center;
}
.portrait--about{aspect-ratio:4/5}
.about__media{position:relative}
.about__media::before{
  content:"";position:absolute;right:-16px;bottom:-16px;width:62%;height:62%;
  border:1px solid var(--clay);border-radius:3px;z-index:-1;
}
.about__body p{margin-bottom:1.1rem;color:var(--ink-soft);max-width:46ch}
.about__body .display{margin-bottom:1.6rem}
.ticks{display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.2rem;margin:1.8rem 0}
.ticks li{position:relative;padding-left:1.7rem;font-size:.86rem;letter-spacing:.02em;color:var(--ink)}
.ticks li::before{
  content:"";position:absolute;left:0;top:.5em;width:11px;height:6px;
  border-left:1.5px solid var(--clay);border-bottom:1.5px solid var(--clay);transform:rotate(-45deg);
}

/* =====================================================================
   SERVICES
   ===================================================================== */
.services{background:var(--oat);max-width:none;padding-inline:0}
.services .section__head,.services .filters,.services__grid,.services__note{
  max-width:var(--max);margin-inline:auto;padding-inline:clamp(20px,5vw,48px);
}
.filters{display:flex;justify-content:center;gap:.6rem;margin-bottom:2.6rem;flex-wrap:wrap}
.filter{
  font-family:'Jost',sans-serif;font-size:.74rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:.6rem 1.2rem;border:1px solid var(--line);border-radius:2px;background:transparent;color:var(--ink-soft);
  cursor:pointer;transition:.3s var(--ease);
}
.filter:hover{border-color:var(--sage-deep);color:var(--sage-deep)}
.filter.is-active{background:var(--sage-deep);border-color:var(--sage-deep);color:var(--cream)}

.services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.svc{
  background:var(--ivory);border:1px solid var(--line);border-radius:3px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.svc.is-hidden{display:none}
.svc:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(63,72,63,.12)}
.svc__img{
  position:relative;aspect-ratio:16/11;
  background:linear-gradient(150deg,var(--sage-light),var(--sage-mid));
  overflow:hidden;
}
.svc__img::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.04) 0 2px,transparent 2px 8px)}
.svc__tag{
  position:absolute;left:12px;top:12px;z-index:1;
  font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-deep);
  background:rgba(251,249,243,.92);padding:.32rem .6rem;border-radius:2px;
}
.svc__body{padding:1.5rem 1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}
.svc__body h3{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.35rem;color:var(--sage-deep);margin-bottom:.5rem;line-height:1.1}
.svc__body p{font-size:.85rem;color:var(--ink-soft);flex:1;margin-bottom:1.1rem}
.svc__foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line);padding-top:.9rem}
.svc__price{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.1rem;color:var(--clay-deep)}
.svc__more{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-mid);transition:color .3s var(--ease)}
.svc:hover .svc__more{color:var(--sage-deep)}
.services__note{text-align:center;margin-top:2.6rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.25rem;color:var(--ink-soft)}
.services__note a{color:var(--clay-deep);border-bottom:1px solid var(--clay)}

/* =====================================================================
   RESULTS / BEFORE-AFTER
   ===================================================================== */
.results{background:var(--cream)}
.results__head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:clamp(32px,4vw,52px);flex-wrap:wrap}
.results__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.ba{
  position:relative;aspect-ratio:4/3;border-radius:3px;overflow:hidden;
  border:1px solid var(--line);cursor:ew-resize;user-select:none;background:var(--sage-mist);
}
.ba__after,.ba__before{position:absolute;inset:0}
.ba__after{background:linear-gradient(150deg,#9aa291,#7e887b)}
/* before layer sits on top, revealed left-to-right via clip-path so both
   images stay pixel-aligned regardless of the divider position */
.ba__before{background:linear-gradient(150deg,#b9b1a2,#9b9384);clip-path:inset(0 50% 0 0)}
.ba__after img,.ba__before img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* small corner labels (empty placeholders keep a centred italic caption) */
.ba__after>span,.ba__before>span{
  position:absolute;top:12px;z-index:3;
  font-family:'Jost',sans-serif;font-style:normal;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--sage-deep);background:rgba(251,249,243,.9);padding:.3rem .6rem;border-radius:2px;
}
.ba__after>span{right:12px}
.ba__before>span{left:12px}
/* empty placeholder cards: show a soft centred caption instead of a corner pill */
.ba__after:not(:has(img))>span,.ba__before:not(:has(img))>span{
  top:50%;left:50%;right:auto;transform:translate(-50%,-50%);
  background:none;color:rgba(255,255,255,.85);font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:1.05rem;letter-spacing:.1em;padding:0;
}
.ba__handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--ivory);transform:translateX(-1px);z-index:2;
}
.ba__handle span{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:42px;height:42px;border-radius:50%;background:var(--ivory);border:2px solid var(--clay);
  box-shadow:0 4px 14px rgba(0,0,0,.18);
}
.ba__handle span::before,.ba__handle span::after{
  content:"";position:absolute;top:50%;width:0;height:0;border-block:5px solid transparent;
}
.ba__handle span::before{left:9px;border-right:7px solid var(--clay-deep);transform:translateY(-50%)}
.ba__handle span::after{right:9px;border-left:7px solid var(--clay-deep);transform:translateY(-50%)}
.ba figcaption{
  position:absolute;left:12px;bottom:12px;z-index:3;
  background:var(--sage-deep);color:var(--cream);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.34rem .7rem;border-radius:2px;
}
.results__legend{text-align:center;margin-top:2rem;font-size:.78rem;letter-spacing:.04em;color:var(--sage-mid)}

/* =====================================================================
   REVIEWS
   ===================================================================== */
.reviews{background:var(--sage-deep);max-width:none;color:var(--cream)}
.reviews .section,.reviews>*{max-width:var(--max)}
.reviews{padding:var(--gap) clamp(20px,5vw,48px)}
.reviews__head{text-align:center;margin:0 auto clamp(40px,5vw,60px);max-width:var(--max)}
.reviews .eyebrow{color:var(--sage-light)}
.reviews__rating{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.reviews__num{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,7vw,4.6rem);line-height:1;color:var(--ivory)}
.reviews__count{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage-light)}

.stars{display:inline-flex;gap:.35rem}
.stars i{width:18px;height:18px;background:var(--clay);clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.stars--sm i{width:13px;height:13px}

.reviews__grid{max-width:var(--max);margin-inline:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.quote{
  background:rgba(255,255,255,.05);border:1px solid var(--line-light);border-radius:3px;
  padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1.1rem;
}
.quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.22rem;line-height:1.5;color:var(--ivory)}
.quote cite{font-style:normal;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-light)}
.reviews__note{text-align:center;margin-top:2.2rem;font-size:.74rem;letter-spacing:.04em;color:var(--sage-light)}

/* =====================================================================
   PRICING
   ===================================================================== */
.pricing{background:var(--cream)}
.pricetable{max-width:660px;margin-inline:auto;background:var(--ivory);border:1px solid var(--line);border-radius:3px;overflow:hidden}
.price-row{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.6rem;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:none}
.price-row span{font-size:.96rem;color:var(--ink)}
.price-row strong{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:1.25rem;color:var(--clay-deep)}
.price-row--free{background:var(--sage-mist)}
.price-row--free span{font-weight:500;letter-spacing:.02em}
.price-row--free strong{color:var(--sage-deep);letter-spacing:.16em;font-family:'Jost',sans-serif;font-size:.95rem;font-weight:600}

/* =====================================================================
   CTA
   ===================================================================== */
.cta{
  max-width:none;
  background:linear-gradient(150deg,var(--sage-deep),#333a33);
  text-align:center;
}
.cta__inner{max-width:var(--max-narrow);margin-inline:auto}
.cta p{color:rgba(244,240,232,.8);max-width:40ch;margin:1.4rem auto 2rem;font-size:1.02rem}
.cta__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cta__fine{font-size:.72rem !important;letter-spacing:.06em;color:var(--sage-light) !important;margin-top:1.8rem !important}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--ink);color:rgba(244,240,232,.7)}
.footer__inner{
  max-width:var(--max);margin-inline:auto;padding:clamp(48px,6vw,76px) clamp(20px,5vw,48px) 2.4rem;
  display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:2.4rem;
}
.wordmark--footer{color:var(--cream)}
.wordmark--footer .wordmark__l1,.wordmark--footer .wordmark__l2{color:var(--cream)}
.footer__tag{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1rem;color:rgba(244,240,232,.55);margin:.8rem 0 1rem}
.footer__gdc{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-light);border:1px solid var(--line-light);padding:.4rem .7rem;border-radius:2px;display:inline-block}
.footer__col h4{font-family:'Jost',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--cream);margin-bottom:1.1rem}
.footer__col a,.footer__col p{display:block;font-size:.88rem;color:rgba(244,240,232,.66);margin-bottom:.65rem;transition:color .3s var(--ease)}
.footer__col a:hover{color:var(--cream)}
.footer__bar{
  border-top:1px solid var(--line-light);max-width:var(--max);margin:0 auto;
  padding:1.6rem clamp(20px,5vw,48px);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  font-size:.72rem;letter-spacing:.08em;color:rgba(244,240,232,.5);
}
.footer__reg{color:var(--sage-light)}

/* =====================================================================
   STICKY MOBILE BOOK
   ===================================================================== */
.sticky-book{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:45;
  display:none;justify-content:center;align-items:center;
  background:var(--clay);color:var(--ivory);
  font-family:'Jost',sans-serif;font-size:.82rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  padding:1rem;border-radius:3px;box-shadow:0 10px 28px rgba(50,54,46,.3);
  transform:translateY(140%);transition:transform .4s var(--ease);
}
.sticky-book.is-visible{transform:translateY(0)}

/* =====================================================================
   REVEAL
   ===================================================================== */
.reveal{opacity:0;transform:translateY(28px)}
.reveal.is-in{opacity:1;transform:none;transition:opacity .9s var(--ease), transform .9s var(--ease)}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
/* drop the GDC pill before it can crowd the bar */
@media (max-width:1240px){
  .nav__gdc{display:none}
}
/* collapse links + CTA to the hamburger BEFORE they overflow the right edge */
@media (max-width:960px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex}
}
@media (max-width:1024px){
  .why__grid{grid-template-columns:1fr 1fr}
  .services__grid{grid-template-columns:1fr 1fr}
  .reviews__grid{grid-template-columns:1fr;max-width:560px}
}
@media (max-width:820px){
  .hero__inner{grid-template-columns:1fr;text-align:center}
  .hero__content{max-width:none;margin-inline:auto}
  .hero__sub,.hero__stats{margin-inline:auto}
  .hero__cta{justify-content:center}
  .hero__media{max-width:420px;margin:2.4rem auto 0;order:-1}
  .about{grid-template-columns:1fr}
  .about__media{max-width:440px;margin-inline:auto}
  .results__grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr;text-align:center}
  .ticks{justify-content:center;max-width:380px;margin-inline:auto}
  .footer__gdc{margin-inline:auto}
  .sticky-book{display:flex}
  .footer__bar{justify-content:center;text-align:center}
}
@media (max-width:520px){
  .why__grid,.services__grid{grid-template-columns:1fr}
  .ticks{grid-template-columns:1fr}
  .results__head{flex-direction:column;align-items:flex-start;text-align:left}
  .btn{width:100%}
  .hero__cta,.cta__btns{flex-direction:column}
}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto !important}
}
