/* =====================================================================
   Chloe + Mint — shared design system
   Editorial restraint: warm paper, photography-forward, Cormorant + Jost
   ===================================================================== */
:root{
  --paper:#F4F1EA;
  --paper-2:#ECE6DA;
  --paper-3:#E4DDCD;
  --ink:#211E19;
  --ink-soft:#5B554B;
  --line:#D7D0C2;
  --accent:#3C4A39;          /* deep muted botanical — used sparingly */
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Jost','Helvetica Neue', Arial, sans-serif;
  --container:1320px;
  --gut:clamp(20px,5vw,76px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}

/* ---- type primitives ---- */
.eyebrow{font-family:var(--sans);font-weight:400;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft)}
.serif{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:.005em}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.05;letter-spacing:.005em}
.display{font-size:clamp(3rem,8.4vw,7.6rem)}
h2{font-size:clamp(2.3rem,5vw,4.2rem)}
h3{font-size:clamp(1.5rem,2.4vw,2.05rem)}
p{font-size:clamp(1rem,1.15vw,1.12rem);color:var(--ink-soft);font-weight:300}
.lede{font-size:clamp(1.25rem,1.9vw,1.6rem);line-height:1.5;color:var(--ink);font-weight:300}

/* ---- link / button ---- */
.link{font-family:var(--sans);font-weight:400;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);display:inline-block;padding-bottom:6px;border-bottom:1px solid var(--ink);transition:opacity .35s ease}
.link:hover{opacity:.55}
.link--light{color:#fff;border-color:rgba(255,255,255,.7)}
.btn{display:inline-block;font-family:var(--sans);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;padding:16px 30px;border:1px solid var(--ink);color:var(--ink);background:none;cursor:pointer;transition:background .35s ease,color .35s ease}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:transparent;color:var(--ink)}
.btn--light{border-color:#fff;color:#fff}
.btn--light:hover{background:#fff;color:var(--ink)}

.container{max-width:var(--container);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.narrow{max-width:880px}
.rule{height:1px;background:var(--line);border:0;margin:0}
.sec{padding:clamp(80px,11vw,150px) 0}
.sec--alt{background:var(--paper-2)}
.sec--tight{padding:clamp(56px,7vw,96px) 0}

.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(40px,6vw,76px);flex-wrap:wrap}
.sec-head h2{max-width:16ch}
.sec-head .eyebrow{display:block;margin-bottom:14px}

/* =====================  NAV  ===================== */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gut);
  transition:background .5s ease, padding .5s ease, color .5s ease, border-color .5s ease;
  border-bottom:1px solid transparent;color:#fff;
}
header.nav.solid{background:rgba(244,241,234,.94);backdrop-filter:saturate(120%) blur(8px);color:var(--ink);border-bottom:1px solid var(--line);padding:16px var(--gut)}
/* interior pages start with a solid nav (no full-bleed hero behind it) */
header.nav.fixed-solid{position:fixed;background:rgba(244,241,234,.94);backdrop-filter:saturate(120%) blur(8px);color:var(--ink);border-bottom:1px solid var(--line)}
.brand{font-family:var(--serif);font-size:1.5rem;letter-spacing:.02em;white-space:nowrap}
.brand b{font-weight:500}
nav.links{display:flex;gap:34px;align-items:center}
nav.links a{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;opacity:.92;transition:opacity .3s ease;position:relative;padding:4px 0}
nav.links a:hover{opacity:.6}
nav.links a.active{opacity:1}
nav.links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:currentColor;opacity:.6}
.nav-right{display:flex;gap:26px;align-items:center}
.nav-utility{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;opacity:.9;cursor:pointer}
.burger{display:none;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;background:none;border:0;color:inherit;cursor:pointer;position:relative;z-index:62}
@media(max-width:1080px){
  nav.links,.nav-utility{display:none}
  .burger{display:block}

  /* ---- mobile menu overlay ---- */
  nav.links{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
    position:fixed;inset:0;z-index:58;background:var(--paper);
    transform:translateY(-100%);transition:transform .5s cubic-bezier(.2,.7,.2,1);
    pointer-events:none;opacity:0;
  }
  body.menu-open nav.links{transform:none;pointer-events:auto;opacity:1}
  nav.links a{
    color:var(--ink)!important;font-family:var(--serif);font-size:2.4rem;line-height:1.5;
    letter-spacing:0;text-transform:none;opacity:1;padding:6px 0;
  }
  nav.links a.active::after{display:none}

  /* surface Shop / Inquire at the foot of the open menu */
  body.menu-open .nav-right{
    display:flex;position:fixed;left:0;right:0;bottom:clamp(40px,8vh,72px);z-index:59;
    justify-content:center;gap:44px;
  }
  body.menu-open .nav-right .nav-utility{display:inline-block;color:var(--ink)!important;opacity:1}

  /* keep the bar legible (brand + close button) while menu is open, even over a hero */
  body.menu-open header.nav{background:var(--paper);color:var(--ink);border-bottom:1px solid var(--line)}
  body.menu-open{overflow:hidden}
}

/* =====================  HERO (home, full-bleed)  ===================== */
.hero{position:relative;height:100vh;min-height:620px;width:100%;overflow:hidden}
.hero img{transform:scale(1.04)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,15,.42) 0%,rgba(20,18,15,.06) 32%,rgba(20,18,15,.10) 62%,rgba(20,18,15,.5) 100%)}
.hero-copy{position:absolute;left:0;right:0;bottom:clamp(48px,8vh,96px);z-index:5;padding:0 var(--gut);color:#fff}
.hero-copy .eyebrow{color:rgba(255,255,255,.82)}
.hero-copy h1{color:#fff;margin:18px 0 30px;max-width:14ch}
.hero-actions{display:flex;gap:34px;align-items:center;flex-wrap:wrap}
.scroll-hint{position:absolute;bottom:26px;right:var(--gut);z-index:5;color:rgba(255,255,255,.8);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;writing-mode:vertical-rl}

/* =====================  PAGE HERO (interior pages)  ===================== */
.page-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.page-hero img{position:absolute;inset:0;z-index:0}
.page-hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(18,16,12,.45),rgba(18,16,12,.15) 45%,rgba(18,16,12,.6))}
.page-hero .ph-copy{position:relative;z-index:2;padding:0 var(--gut) clamp(48px,7vw,84px);max-width:var(--container);margin:0 auto;width:100%}
.page-hero .eyebrow{color:rgba(255,255,255,.82)}
.page-hero h1{color:#fff;font-size:clamp(2.6rem,6.4vw,5.4rem);margin-top:16px;max-width:18ch}
.page-hero p{color:rgba(255,255,255,.86);max-width:52ch;margin-top:22px}
/* simple paper page-intro (no image hero) */
.page-intro{padding:clamp(140px,16vw,210px) 0 clamp(40px,6vw,72px)}
.page-intro h1{font-size:clamp(2.6rem,6.4vw,5.4rem);max-width:18ch}
.page-intro p{max-width:56ch;margin-top:22px}
.page-intro .eyebrow{display:block;margin-bottom:14px}

/* =====================  SERVICES list  ===================== */
.svc-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(36px,5vw,72px);align-items:start}
.svc-list{border-top:1px solid var(--line)}
.svc-item{display:grid;grid-template-columns:auto 1fr;gap:28px;padding:30px 4px;border-bottom:1px solid var(--line);align-items:baseline}
.svc-item .num{font-size:.72rem;letter-spacing:.18em;color:var(--ink-soft);font-weight:400;padding-top:8px}
.svc-item h3{margin-bottom:8px}
.svc-item p{max-width:42ch}
.svc-media{position:relative;aspect-ratio:3/4;background:var(--paper-3);overflow:hidden}
.svc-media .tag{position:absolute;left:18px;bottom:16px;color:#fff;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase}
@media(max-width:880px){.svc-grid{grid-template-columns:1fr}.svc-media{order:-1;aspect-ratio:4/3}}

/* detailed service blocks (alternating) */
.svc-block{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center;padding:clamp(48px,7vw,90px) 0;border-bottom:1px solid var(--line)}
.svc-block:last-child{border-bottom:0}
.svc-block .media{aspect-ratio:4/5;background:var(--paper-3);overflow:hidden}
.svc-block .num{font-size:.72rem;letter-spacing:.2em;color:var(--ink-soft);margin-bottom:14px}
.svc-block h2{font-size:clamp(2rem,3.4vw,3rem);margin-bottom:18px}
.svc-block p{max-width:46ch;margin-bottom:14px}
.svc-block ul{list-style:none;margin-top:22px;border-top:1px solid var(--line)}
.svc-block li{padding:12px 0;border-bottom:1px solid var(--line);font-size:.95rem;color:var(--ink-soft);display:flex;gap:14px;align-items:baseline}
.svc-block li::before{content:"—";color:var(--accent)}
.svc-block:nth-child(even) .media{order:2}
@media(max-width:820px){.svc-block{grid-template-columns:1fr;gap:30px}.svc-block:nth-child(even) .media{order:0}}

/* =====================  PROCESS steps  ===================== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,46px);counter-reset:step}
.step{border-top:2px solid var(--ink);padding-top:22px}
.step .n{font-size:.72rem;letter-spacing:.2em;color:var(--ink-soft);margin-bottom:14px}
.step h3{font-size:1.5rem;margin-bottom:10px}
.step p{font-size:.95rem}
@media(max-width:820px){.process{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.process{grid-template-columns:1fr}}

/* =====================  WORK / PORTFOLIO grid  ===================== */
figure{position:relative;overflow:hidden;background:var(--paper-3);margin:0}
figure .ph{position:relative;overflow:hidden;width:100%;height:100%}
figure img{transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
figure:hover img{transform:scale(1.045)}
figcaption{margin-top:14px}
figcaption .cl{font-family:var(--serif);font-size:1.32rem;color:var(--ink)}
figcaption .mt{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}
.ar43{aspect-ratio:4/3}.ar34{aspect-ratio:3/4}.ar1610{aspect-ratio:16/10}.ar11{aspect-ratio:1/1}.ar45{aspect-ratio:4/5}

/* home feature work grid */
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.6vw,26px)}
.w-a{grid-column:1/7}.w-b{grid-column:7/13}.w-c{grid-column:1/5}.w-d{grid-column:5/13}
@media(max-width:760px){.w-a,.w-b,.w-c,.w-d{grid-column:1/13}.ar34,.ar1610{aspect-ratio:4/3}}

/* portfolio masonry-ish grid + filter */
.filter{display:flex;flex-wrap:wrap;gap:10px 28px;margin-bottom:clamp(34px,4vw,56px);border-bottom:1px solid var(--line);padding-bottom:24px}
.filter button{background:none;border:0;font-family:var(--sans);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer;padding:6px 0;transition:color .3s;position:relative}
.filter button:hover{color:var(--ink)}
.filter button.active{color:var(--ink)}
.filter button.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--ink)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,34px)}
.pf-grid figure{transition:opacity .4s ease}
@media(max-width:900px){.pf-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pf-grid{grid-template-columns:1fr}}

/* =====================  FEATURE BREAK  ===================== */
.feature{position:relative;height:clamp(520px,82vh,860px);overflow:hidden}
.feature img{object-position:50% 32%}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(14,13,10,.88) 0%,rgba(14,13,10,.62) 34%,rgba(14,13,10,.46) 70%,rgba(14,13,10,.5) 100%)}
.feature-copy{position:absolute;z-index:3;left:0;right:0;bottom:clamp(46px,7vh,80px);padding:0 var(--gut);max-width:880px;color:#fff;text-shadow:0 1px 40px rgba(0,0,0,.55)}
.feature-copy .q{font-family:var(--serif);font-size:clamp(2rem,4.4vw,3.6rem);line-height:1.16;font-weight:400}
.feature-copy .by{margin-top:24px;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* =====================  TRUSTED  ===================== */
.trusted{text-align:center}
.trusted .eyebrow{display:block;margin-bottom:34px}
.clients{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 52px;align-items:center}
.clients span{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,2rem);color:var(--ink);opacity:.82}

/* =====================  STUDIO / ABOUT split  ===================== */
.split{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,6vw,90px);align-items:center}
.split.rev .media{order:2}
.split .media{aspect-ratio:5/6;background:var(--paper-3);overflow:hidden}
.split .copy h2{margin:16px 0 26px;max-width:14ch}
.split .copy p{max-width:46ch;margin-bottom:20px}
@media(max-width:880px){.split{grid-template-columns:1fr}.split.rev .media{order:0}}

/* values / stat row */
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(30px,4vw,60px)}
.cols-3 .col h3{font-size:1.45rem;margin-bottom:10px}
.cols-3 .col .num{font-family:var(--serif);font-size:clamp(2.6rem,4vw,3.4rem);line-height:1;margin-bottom:8px}
@media(max-width:760px){.cols-3{grid-template-columns:1fr;max-width:460px}}

/* press row */
.press{display:flex;flex-wrap:wrap;justify-content:center;gap:18px 48px;align-items:center}
.press span{font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.7rem);opacity:.7}

/* =====================  JOURNAL  ===================== */
.j-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,46px)}
.j-card .j-media{aspect-ratio:4/5;background:var(--paper-3);overflow:hidden}
.j-card .j-media img{transition:transform 1.1s cubic-bezier(.2,.7,.2,1)}
.j-card:hover .j-media img{transform:scale(1.05)}
.j-cat{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin:18px 0 8px}
.j-card h3{font-size:1.45rem;max-width:24ch}
@media(max-width:760px){.j-grid{grid-template-columns:1fr;max-width:440px}}

/* featured journal entry */
.j-feature{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(34px,5vw,72px);align-items:center;margin-bottom:clamp(48px,6vw,90px)}
.j-feature .media{aspect-ratio:4/3;background:var(--paper-3);overflow:hidden}
.j-feature h2{font-size:clamp(2rem,3.6vw,3.2rem);margin:14px 0 18px}
@media(max-width:820px){.j-feature{grid-template-columns:1fr}}

/* =====================  SHOP  ===================== */
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,34px)}
.product .p-media{aspect-ratio:4/5;background:var(--paper-3);overflow:hidden;margin-bottom:16px;position:relative}
.product .p-tag{position:absolute;top:14px;left:14px;background:var(--paper);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px;color:var(--ink)}
.product h3{font-size:1.25rem;margin-bottom:4px}
.product .p-price{font-family:var(--sans);font-size:.85rem;color:var(--ink-soft);letter-spacing:.04em}
@media(max-width:900px){.shop-grid{grid-template-columns:1fr 1fr}}
.cat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,30px)}
.cat{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--paper-3);display:flex;align-items:flex-end}
.cat::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(16,14,11,.6),rgba(16,14,11,0) 55%)}
.cat .lbl{position:relative;z-index:2;color:#fff;padding:24px;font-family:var(--serif);font-size:1.7rem}
@media(max-width:760px){.cat-row{grid-template-columns:1fr}}

/* =====================  CONTACT  ===================== */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,90px)}
.field{margin-bottom:26px}
.field label{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.field input,.field select,.field textarea{width:100%;background:none;border:0;border-bottom:1px solid var(--line);padding:10px 2px;font-family:var(--sans);font-weight:300;font-size:1rem;color:var(--ink);outline:none;transition:border-color .3s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink)}
.field textarea{resize:vertical;min-height:90px}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.contact-info dt{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:8px}
.contact-info dd{font-family:var(--serif);font-size:1.4rem;margin-bottom:30px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}.field-2{grid-template-columns:1fr}}

/* =====================  CTA band  ===================== */
.cta{background:var(--accent);color:#F4F1EA;text-align:center}
.cta h2{color:#F4F1EA;max-width:18ch;margin:0 auto 22px}
.cta p{color:rgba(244,241,234,.74);max-width:46ch;margin:0 auto 34px}

/* =====================  NEWSLETTER  ===================== */
.signup{background:var(--accent);color:#F4F1EA;text-align:center}
.signup h2{color:#F4F1EA;max-width:18ch;margin:0 auto 14px}
.signup p{color:rgba(244,241,234,.74);max-width:46ch;margin:0 auto}
.signup form{margin:42px auto 0;max-width:520px;display:flex;border-bottom:1px solid rgba(244,241,234,.5)}
.signup input{flex:1;background:none;border:0;color:#F4F1EA;font-family:var(--sans);font-weight:300;font-size:1rem;padding:14px 4px;outline:none}
.signup input::placeholder{color:rgba(244,241,234,.6)}
.signup button{background:none;border:0;color:#F4F1EA;font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;padding:0 6px}

/* =====================  FOOTER  ===================== */
footer.foot{background:var(--paper);padding:clamp(70px,8vw,110px) 0 40px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.foot-brand .serif{font-size:2.4rem}
.foot-brand p{max-width:34ch;margin-top:18px}
.foot-col h4{font-family:var(--sans);font-weight:400;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);margin-bottom:20px}
.foot-col a{display:block;color:var(--ink-soft);font-size:.95rem;padding:7px 0;transition:color .3s}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:28px}
.foot-bottom span{font-size:.72rem;letter-spacing:.1em;color:var(--ink-soft)}
@media(max-width:880px){.foot-top{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/3}}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity 1.1s cubic-bezier(.2,.7,.2,1),transform 1.1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
