:root{
  --ink:#1E2420;
  --ground:#FBF8F2;
  --surface:#F2EDE4;
  --sage:#9FB098;
  --terra:#C68A63;
  --terra-dk:#b07a55;
  --muted:#6B665E;
  --line:rgba(30,36,32,.14);
  --serif:"Playfair Display",Georgia,serif;
  --sans:"Mulish",system-ui,sans-serif;
  --label:"Montserrat",system-ui,sans-serif;
  --script:"Dancing Script",cursive;
  --maxw:1200px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--ground);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
  word-break:break-word;
}
img,svg,video,iframe{max-width:100%;height:auto;display:block}
a{color:inherit}
h1,h2,h3,h4{margin:0;line-height:1.12;font-weight:500}
p{margin:0 0 1rem}
ul{margin:0;padding:0;list-style:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

.eyebrow{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:600;
  color:var(--terra);
  display:inline-block;
  margin-bottom:1rem;
}
.eyebrow-light{color:#f3e4d8}
.sage-eyebrow{color:var(--ink)}

.display{
  font-family:var(--serif);
  font-weight:500;
  letter-spacing:-.01em;
}
.section .display{font-size:clamp(1.8rem,4.4vw,3rem)}
.serif-em,.display em{font-style:italic;color:var(--terra)}
.script-accent{
  font-family:var(--script);
  font-weight:600;
  color:var(--ink);
  font-size:clamp(2rem,5vw,3.2rem);
  line-height:1;
}

.lead{font-size:1.12rem;color:var(--muted);max-width:62ch}

.section{padding:clamp(3.5rem,7vw,6.5rem) 0}
.surface{background:var(--surface)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.74rem;
  font-weight:600;
  text-decoration:none;
  padding:.95em 1.7em;
  border-radius:2px;
  cursor:pointer;
  border:1px solid transparent;
  transition:background .2s,color .2s,transform .15s;
  min-height:44px;
  line-height:1.4;
}
.btn-cta{background:var(--terra);color:#fff}
.btn-cta:hover{background:var(--terra-dk)}
.btn-ink{background:var(--ink);color:var(--ground)}
.btn-ink:hover{background:#000}
.btn-lg{padding:1.1em 2.2em;font-size:.8rem}
.link-arrow{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.74rem;
  font-weight:600;
  text-decoration:none;
  color:var(--ink);
  border-bottom:1px solid var(--terra);
  padding-bottom:3px;
  display:inline-block;
  transition:color .2s;
}
.link-arrow span{transition:transform .2s;display:inline-block}
.link-arrow:hover{color:var(--terra)}
.link-arrow:hover span{transform:translateX(4px)}

a:focus-visible,button:focus-visible,input:focus-visible{
  outline:2px solid var(--terra);
  outline-offset:3px;
}

/* ---------- Promo ---------- */
.promo{
  background:var(--ink);
  color:#f0e7da;
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.64rem;
  font-weight:500;
  text-align:center;
  padding:.6rem 18px;
}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,248,242,.94);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
.site-header.scrolled{box-shadow:0 6px 24px rgba(30,36,32,.07)}
.header-inner{
  display:flex;align-items:center;gap:1.2rem;
  min-height:74px;
}
.logo img{height:42px;width:auto}
.primary-nav{margin-left:auto}
.primary-nav ul{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
.primary-nav a{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.7rem;
  font-weight:500;
  text-decoration:none;
  color:var(--ink);
  transition:color .2s;
  white-space:nowrap;
}
.primary-nav a:hover{color:var(--terra)}
.header-cta{padding:.7em 1.3em;font-size:.68rem}
.menu-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:44px;height:44px;flex-direction:column;justify-content:center;gap:5px;padding:0;
}
.menu-toggle span{display:block;height:2px;width:24px;background:var(--ink);margin:0 auto;transition:.25s}

/* ---------- Mobile menu ---------- */
.mobile-menu{
  position:fixed;top:0;right:0;height:100%;width:min(82%,330px);
  background:var(--ground);z-index:70;
  transform:translateX(110%);
  visibility:hidden;
  transition:transform .3s ease, visibility 0s linear .3s;
  padding:1.5rem 1.5rem 2rem;
  box-shadow:-12px 0 40px rgba(0,0,0,.12);
  display:flex;flex-direction:column;
}
.mobile-menu.open{
  transform:translateX(0);
  visibility:visible;
  transition:transform .3s ease, visibility 0s linear 0s;
}
.mobile-menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.mobile-menu-head .eyebrow{margin-bottom:0;color:var(--muted)}
.menu-close{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:var(--ink);width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.mobile-menu nav ul{display:flex;flex-direction:column;gap:.3rem}
.mobile-menu nav a{
  display:block;padding:.85rem 0;
  font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;
  font-size:.85rem;text-decoration:none;border-bottom:1px solid var(--line);
  color:var(--ink);
}
.mobile-menu nav a:hover{color:var(--terra)}
.mobile-cta{margin-top:auto;text-align:center}
.menu-overlay{position:fixed;inset:0;background:rgba(30,36,32,.45);z-index:60}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 45%}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(to top,rgba(20,30,18,.82) 0%,rgba(20,30,18,.2) 50%,rgba(20,30,18,.38) 100%)}
.hero-content{position:relative;z-index:2;color:#fff;padding-top:6rem;padding-bottom:clamp(3.5rem,8vw,7rem)}
.hero-title{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.8rem,8.5vw,6rem);
  letter-spacing:-.02em;
  line-height:1.06;
  text-shadow:0 2px 36px rgba(0,0,0,.28);
  margin-bottom:.4rem;
}
.hero-sub{
  font-size:1.12rem;max-width:36ch;margin:1.2rem 0 2rem;color:#f4ece2;line-height:1.55;
}

/* ---------- Problem ---------- */
.problem-top{text-align:center;max-width:840px;margin:0 auto 3.5rem}
.problem-top .lead{margin:1.4rem auto 0}
.problem-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:2.5rem;align-items:start}
.problem-card{
  background:var(--surface);padding:2.4rem;border-radius:4px;
  box-shadow:0 24px 56px -28px rgba(30,36,32,.22);
}
.painlist li{
  position:relative;padding-left:2rem;margin-bottom:1.1rem;color:var(--muted);line-height:1.5;
}
.painlist li::before{
  content:"✕";position:absolute;left:0;top:1px;
  color:var(--terra);font-weight:700;font-size:.78rem;
  width:1.25rem;height:1.25rem;border:1.5px solid var(--terra);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.problem-resolve{padding-top:.5rem}
.problem-resolve p{font-size:1.08rem;margin-bottom:1.8rem;line-height:1.7}

/* ---------- Bands ---------- */
.band{padding:clamp(3rem,6vw,5rem) 0;text-align:center}
.area-band{background:var(--surface)}
.area-band p{
  font-family:var(--serif);font-size:clamp(1.3rem,3vw,1.9rem);
  max-width:26ch;margin:0 auto;font-weight:400;line-height:1.45;color:var(--ink);
}
.area-band em{color:var(--terra);font-style:italic}
.sage-band{background:var(--sage);color:var(--ink)}
.sage-band .display{font-size:clamp(2rem,5vw,3.2rem);margin-bottom:.8rem}
.sage-band p{max-width:50ch;margin:0 auto 1.8rem;font-size:1.05rem;line-height:1.65}

/* ---------- Splits ---------- */
.split-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split-inner.reverse .split-media{order:2}
.split-media{margin:0;min-width:0;position:relative}
.split-media img{width:100%;border-radius:4px;object-fit:cover;
  box-shadow:0 30px 70px -34px rgba(30,36,32,.45)}

/* Decorative frame — opt-in per named section only */
.split-difference .split-media::after{
  content:"";display:block;position:absolute;
  width:44%;height:44%;border:1px solid var(--sage);
  z-index:-1;right:-16px;bottom:-16px;
}
.split-shanelle .split-media::after{
  content:"";display:block;position:absolute;
  width:44%;height:44%;border:1px solid var(--terra);
  z-index:-1;left:-16px;top:-16px;
}

.split-media.portrait img{aspect-ratio:3/3.6}
.split-text{min-width:0}
.split-text .display{margin-bottom:1.2rem}
.pullquote{
  margin:1.6rem 0 0;padding-left:1.3rem;border-left:3px solid var(--terra);
  font-family:var(--serif);font-style:italic;font-size:1.18rem;color:var(--ink);line-height:1.55;
}
.testi blockquote{
  margin:1rem 0 1.4rem;font-size:1.1rem;font-style:italic;color:var(--muted);
  font-family:var(--serif);line-height:1.6;
}
.testi-name{font-family:var(--label);text-transform:uppercase;letter-spacing:.14em;font-size:.76rem;color:var(--ink);font-weight:600;margin:0}
.testi-split .split-media img{aspect-ratio:4/3}

/* ---------- Goals + services ---------- */
.goals-head{max-width:840px;margin:0 auto 3rem;text-align:center}
.goals-head .lead{margin:1.3rem auto 1.8rem}
.goals-leadin{font-weight:600;color:var(--ink);margin-bottom:1rem}
.service-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem}
.service-tags li{
  background:var(--ground);border:1px solid var(--line);
  padding:.5rem 1rem;border-radius:30px;font-size:.82rem;color:var(--muted);
}
.worktitle{text-align:center;margin:1rem 0 2.5rem}
.service-cards{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.service-card{
  background:var(--ground);border-radius:6px;overflow:hidden;
  box-shadow:0 24px 60px -34px rgba(30,36,32,.4);
  display:flex;flex-direction:column;
}
.service-card-media{aspect-ratio:4/3;overflow:hidden}
.service-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.service-card:hover .service-card-media img{transform:scale(1.06)}
.service-card-body{padding:1.8rem}
.service-card-body h4{font-family:var(--serif);font-size:1.7rem;margin:.2rem 0 .5rem}
.service-card-body p{color:var(--muted);margin-bottom:1.2rem}

/* ---------- Gallery ---------- */
.gallery-section{padding-bottom:clamp(3.5rem,7vw,6.5rem)}
.gallery-head{text-align:center;margin-bottom:2.6rem}
.gallery-head .display{font-size:clamp(2rem,5vw,3rem)}
.gallery{
  column-count:4;column-gap:12px;
  padding:0 24px;max-width:1320px;margin:0 auto;
}
.gallery-item{
  display:block;width:100%;padding:0;margin:0 0 12px;border:none;background:none;
  cursor:pointer;overflow:hidden;border-radius:3px;break-inside:avoid;line-height:0;
  box-shadow:0 10px 28px -18px rgba(30,36,32,.38);
}
.gallery-item img{width:100%;transition:transform .55s ease;border-radius:3px}
.gallery-item:hover img{transform:scale(1.07)}

/* ---------- Blog ---------- */
.blog-title{text-align:center}
.blog-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.blog-card{background:var(--ground);border-radius:6px;overflow:hidden;
  box-shadow:0 20px 50px -32px rgba(30,36,32,.4);display:flex;flex-direction:column}
.blog-media{display:block;aspect-ratio:1/1;overflow:hidden}
.blog-media img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.blog-card:hover .blog-media img{transform:scale(1.06)}
.blog-body{padding:1.6rem;text-align:center;display:flex;flex-direction:column;gap:.8rem;flex:1}
.blog-body h3{font-family:var(--serif);font-size:1.32rem;font-weight:500;flex:1;line-height:1.3}
.blog-body .link-arrow{align-self:center}
.blog-viewall{text-align:right;margin-top:2.2rem}

/* ---------- Closing editorial split + newsletter ---------- */
.closing{}
.closing-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:520px;
}
.closing-content{
  background:var(--ink);
  color:var(--ground);
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  padding:clamp(3rem,6vw,5.5rem) clamp(2.5rem,5vw,5rem);
  gap:1.5rem;
}
.closing-title{
  color:var(--ground);
  font-size:clamp(2.2rem,5vw,3.8rem);
  line-height:1.05;
}
.closing-sub{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.8rem;
  color:rgba(251,248,242,.62);
  margin:0;
  line-height:1.6;
}
.closing-portrait{
  margin:0;
  overflow:hidden;
  min-height:400px;
}
.closing-portrait img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:52% 38%;
  display:block;
}
.newsletter-wrap{
  padding:clamp(3.5rem,7vw,6.5rem) 0;
}
.newsletter{
  display:grid;grid-template-columns:1.2fr .8fr;gap:3rem;align-items:center;
  background:var(--surface);border-radius:8px;padding:clamp(2rem,4vw,3.5rem);
}
.newsletter-text .display{font-size:1.9rem;margin-bottom:.4rem}
.newsletter-form{margin-top:1.4rem;max-width:520px}
.nf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.nf-field{display:block;margin-bottom:1rem}
.nf-field span{display:block;font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--muted);margin-bottom:.4rem;font-weight:600}
.nf-field input{
  width:100%;padding:.8rem .9rem;border:1px solid var(--line);border-radius:3px;
  background:var(--ground);font-family:var(--sans);font-size:.95rem;color:var(--ink);
  transition:border-color .2s;
}
.nf-field input:focus{border-color:var(--terra);outline:none;box-shadow:0 0 0 3px rgba(198,138,99,.15)}
.nf-error{display:block;color:#b04a3a;font-size:.74rem;font-style:normal;margin-top:.3rem;min-height:0}
.nf-success{color:#5a7a4f;font-weight:600;margin-top:1rem}
.newsletter-media{margin:0}
.newsletter-media img{margin:0 auto;max-width:300px}

/* ---------- Footer ---------- */
.site-footer{background:var(--ground);border-top:1px solid var(--line);padding-top:3.5rem}
.footer-top{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;padding-bottom:2.5rem;border-bottom:1px solid var(--line)}
.footer-logo img{height:60px;width:auto}
.footer-nav{margin-left:auto}
.footer-nav ul{display:flex;flex-wrap:wrap;gap:1.4rem}
.footer-nav a{font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;text-decoration:none;color:var(--muted);transition:color .2s}
.footer-nav a:hover{color:var(--terra)}
.footer-mid{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:2.5rem 24px}
.badges{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}
.badges img{height:76px;width:auto}
.socials{display:flex;gap:1.3rem;flex-wrap:wrap}
.socials a{font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;text-decoration:none;color:var(--muted);transition:color .2s}
.socials a:hover{color:var(--terra)}
.footer-bottom{background:var(--sage);text-align:center;padding:1.2rem 24px;margin-top:1rem}
.footer-bottom p{margin:0;font-family:var(--label);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--ink)}
.footer-bottom a{color:var(--ink)}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:100;background:rgba(16,20,17,.95);
  display:none;align-items:center;justify-content:center;padding:24px;
}
.lightbox.open{display:flex}
.lb-figure{margin:0;max-width:90vw;max-height:88vh;text-align:center}
.lb-figure img{max-width:100%;max-height:80vh;border-radius:3px;margin:0 auto}
.lb-figure figcaption{color:#e8ddd0;font-family:var(--label);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;margin-top:1rem}
.lb-close,.lb-prev,.lb-next{
  position:absolute;background:rgba(255,255,255,.14);border:none;color:#fff;
  cursor:pointer;width:50px;height:50px;border-radius:50%;font-size:1.8rem;line-height:1;
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.3)}
.lb-close{top:20px;right:20px}
.lb-prev{left:18px;top:50%;transform:translateY(-50%)}
.lb-next{right:18px;top:50%;transform:translateY(-50%)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  .gallery{column-count:3}
}
@media(max-width:980px){
  .primary-nav,.header-cta{display:none}
  .menu-toggle{display:flex}
  .header-inner{justify-content:space-between}
}
@media(max-width:820px){
  .problem-grid{grid-template-columns:1fr;gap:1.8rem}
  .split-inner{grid-template-columns:1fr;gap:2rem}
  .split-inner.reverse .split-media{order:0}
  .split-difference .split-media::after,
  .split-shanelle .split-media::after{display:none}
  .service-cards{grid-template-columns:1fr}
  .blog-cards{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .blog-viewall{text-align:center}
  .gallery{column-count:2}
  .newsletter{grid-template-columns:1fr;gap:2rem}
  .newsletter-media{order:-1}
  .footer-top{flex-direction:column;align-items:flex-start}
  .footer-nav{margin-left:0}
  /* Closing split stacks portrait on top, content below */
  .closing-split{grid-template-columns:1fr}
  .closing-portrait{min-height:300px;order:-1}
  .closing-content{align-items:center;text-align:center;padding:clamp(2.5rem,5vw,4rem) clamp(1.5rem,5vw,3rem)}
}
@media(max-width:560px){
  .testi-split .split-media img{aspect-ratio:3/2;width:100%}
}
@media(max-width:480px){
  .nf-row{grid-template-columns:1fr}
  .gallery{column-count:2;column-gap:8px;padding:0 16px}
  .gallery-item{margin-bottom:8px}
  .hero{min-height:82vh}
  .footer-mid{justify-content:center;text-align:center}
  .badges{justify-content:center}
  .badges img{height:62px}
  .socials{justify-content:center}
  .closing-portrait{min-height:260px}
}

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