/* =====================================================================
   GINA LAUREN INTERIORS  ·  Editorial Atelier Design System
   Warm ivory canvas · espresso ink · brass accent · stone neutrals
   Type: Fraunces (display) · Marcellus (labels) · Hanken Grotesk (body)
   ===================================================================== */

/* ---------- 1. Tokens ---------- */
:root{
  /* Palette */
  --ink:#211c16;            /* espresso text */
  --ink-soft:#41382e;
  --stone:#6f6557;          /* muted taupe */
  --stone-2:#938776;
  --line:#d9cfbe;           /* hairline on cream */
  --line-soft:#e7dece;
  --cream:#f6f1e7;          /* page canvas */
  --cream-2:#efe7d8;        /* panel */
  --paper:#fbf8f1;          /* cards / light surfaces */
  --brass:#9a7b43;          /* primary accent */
  --brass-deep:#85673400;   /* unused guard */
  --brass-2:#b89a63;        /* lighter brass */
  --brass-ink:#7c6234;
  --espresso:#1c1813;       /* dark sections */
  --espresso-2:#262019;
  --sage:#434a40;           /* secondary deep ground (drawn from foliage) */
  --sage-2:#515a4b;
  --on-dark:#efe6d6;
  --on-dark-soft:#bdb09a;
  --white:#ffffff;

  /* Type scale (fluid) */
  --fs-eyebrow:clamp(.72rem,.68rem + .2vw,.82rem);
  --fs-body:clamp(1.02rem,.98rem + .25vw,1.18rem);
  --fs-lead:clamp(1.18rem,1.05rem + .6vw,1.5rem);
  --fs-h4:clamp(1.2rem,1.05rem + .7vw,1.6rem);
  --fs-h3:clamp(1.5rem,1.2rem + 1.4vw,2.3rem);
  --fs-h2:clamp(2rem,1.5rem + 2.6vw,3.6rem);
  --fs-h1:clamp(2.6rem,1.7rem + 4.4vw,5.6rem);
  --fs-display:clamp(3.2rem,1.8rem + 7vw,8.5rem);

  /* Space */
  --gutter:clamp(1.25rem,5vw,7rem);
  --section:clamp(4.5rem,4rem + 6vw,9.5rem);
  --maxw:1480px;
  --measure:62ch;

  /* Motion */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.1,1);
  --dur:.9s;

  --radius:2px;
  --shadow:0 30px 70px -40px rgba(40,30,15,.5);
  --shadow-soft:0 18px 50px -32px rgba(40,30,15,.45);
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-size:var(--fs-body);
  line-height:1.72;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-weight:400;
  overflow-x:hidden;
}
img,picture,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
ul{list-style:none}
::selection{background:var(--brass);color:var(--paper)}

/* Grain overlay for depth */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4,h5{font-family:"Fraunces",Georgia,serif;font-weight:430;line-height:1.04;letter-spacing:-.012em;color:var(--ink);font-optical-sizing:auto;text-wrap:balance}
p{text-wrap:pretty}
.display{font-size:var(--fs-display);line-height:.96;letter-spacing:-.02em;font-weight:400}
h1,.h1{font-size:var(--fs-h1)}
h2,.h2{font-size:var(--fs-h2)}
h3,.h3{font-size:var(--fs-h3)}
h4,.h4{font-size:var(--fs-h4);line-height:1.12}
em,.italic{font-style:italic}
.serif{font-family:"Fraunces",Georgia,serif}
p{max-width:var(--measure)}
strong{font-weight:600;color:var(--ink)}

.eyebrow{
  font-family:"Marcellus",serif;
  font-size:var(--fs-eyebrow);
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--brass-ink);
  display:inline-flex;align-items:center;gap:.85em;
  font-weight:400;
}
.eyebrow::before{content:"";width:2.4em;height:1px;background:var(--brass);opacity:.7}
.eyebrow.center::after{content:"";width:2.4em;height:1px;background:var(--brass);opacity:.7}
.eyebrow.no-rule::before{display:none}

.label{font-family:"Marcellus",serif;letter-spacing:.28em;text-transform:uppercase;font-size:.78rem}
.lead{font-size:var(--fs-lead);line-height:1.52;color:var(--ink-soft);max-width:46ch;font-weight:460}

/* ---------- 4. Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wrap-narrow{max-width:1040px;margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative}
.section{padding-block:var(--section)}
.section-sm{padding-block:clamp(3rem,3rem + 3vw,6rem)}
.grid{display:grid;gap:clamp(1.5rem,3vw,3.5rem)}
.center{text-align:center}
.center .eyebrow,.center .lead{margin-inline:auto}
.center .lead{max-width:54ch}
.hr{height:1px;background:var(--line);border:0}
.stack>*+*{margin-top:1.1em}

/* section index numeral */
.sect-no{font-family:"Fraunces",serif;font-size:.95rem;letter-spacing:.05em;color:var(--brass);font-feature-settings:"tnum"}

/* ---------- 5. Buttons & links ---------- */
.btn{
  --bg:var(--ink);--fg:var(--paper);--bd:var(--ink);
  display:inline-flex;align-items:center;gap:.8em;
  font-family:"Marcellus",serif;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;
  padding:1.12em 2.1em;border:1px solid var(--bd);background:var(--bg);color:var(--fg);
  border-radius:var(--radius);position:relative;overflow:hidden;isolation:isolate;
  transition:color .5s var(--ease),border-color .5s var(--ease);
}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--brass);transform:translateY(101%);transition:transform .55s var(--ease)}
.btn:hover{color:var(--paper);border-color:var(--brass)}
.btn:hover::before{transform:translateY(0)}
.btn .ar{transition:transform .5s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}
.btn--ghost{--bg:transparent;--fg:var(--ink);--bd:var(--ink)}
.btn--light{--bg:transparent;--fg:var(--on-dark);--bd:rgba(239,230,214,.4)}
.btn--light:hover{color:var(--espresso)}
.btn--light::before{background:var(--on-dark)}
.btn--solidbrass{--bg:var(--brass);--fg:var(--paper);--bd:var(--brass)}
.btn--solidbrass::before{background:var(--ink)}

/* animated text link */
.link{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.76rem;color:var(--ink);
  padding-bottom:.35em;position:relative;
}
.link::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .55s var(--ease)}
.link:hover::after{transform:scaleX(1);transform-origin:left}
.link .ar{transition:transform .5s var(--ease);color:var(--brass)}
.link:hover .ar{transform:translateX(5px)}
.link--brass{color:var(--brass-ink)}
.link--light{color:var(--on-dark)}

/* ---------- 6. Header / Nav ---------- */
.header{position:fixed;inset:0 0 auto;z-index:200;padding:clamp(1rem,2.2vw,1.7rem) 0;transition:background .6s var(--ease),padding .6s var(--ease),box-shadow .6s var(--ease);}
.header__bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}
.header__nav{display:flex;gap:clamp(1.1rem,2vw,2.4rem);justify-self:start}
.header__nav--right{justify-self:end}
.nav-link{font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--on-dark);position:relative;padding:.4em 0;transition:color .4s}
.nav-link::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.nav-link:hover::after,.nav-link[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.brand{justify-self:center;display:flex;flex-direction:column;align-items:center;gap:.25em;line-height:1}
.brand__name{font-family:"Fraunces",serif;font-weight:430;letter-spacing:.02em;font-size:clamp(1.15rem,1.6vw,1.5rem);color:var(--on-dark);white-space:nowrap}
.brand__sub{font-family:"Marcellus",serif;letter-spacing:.42em;text-transform:uppercase;font-size:.52rem;color:var(--brass-2);padding-left:.42em}
/* scrolled / solid state */
.header.is-solid{background:rgba(246,241,231,.9);backdrop-filter:blur(14px) saturate(1.1);box-shadow:0 1px 0 var(--line-soft);padding-top:.85rem;padding-bottom:.85rem}
.header.is-solid .nav-link,.header.is-solid .brand__name{color:var(--ink)}
.header.is-solid .brand__sub{color:var(--brass-ink)}
.header.is-solid .header__cta{color:var(--ink);border-color:var(--ink)}
/* light pages (no dark hero) start solid-ish */
.header--light .nav-link,.header--light .brand__name{color:var(--ink)}
.header--light .brand__sub{color:var(--brass-ink)}

.header__cta{font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.72rem;border:1px solid rgba(239,230,214,.45);padding:.7em 1.3em;border-radius:var(--radius);color:var(--on-dark);transition:.4s var(--ease)}
.header__cta:hover{background:var(--brass);border-color:var(--brass);color:var(--paper)}
.header--light .header__cta{color:var(--ink);border-color:var(--ink)}

.menu-toggle,.mobile-only{display:none}

/* Mobile menu */
.mnav{position:fixed;inset:0;z-index:300;background:var(--espresso);color:var(--on-dark);transform:translateY(-100%);transition:transform .7s var(--ease);display:flex;flex-direction:column;padding:1.4rem var(--gutter) 2rem;visibility:hidden}
.mnav.open{transform:translateY(0);visibility:visible}
.mnav__top{display:flex;justify-content:space-between;align-items:center}
.mnav__links{margin-top:auto;margin-bottom:auto;display:flex;flex-direction:column;gap:.1em}
.mnav__links a{font-family:"Fraunces",serif;font-size:clamp(2rem,9vw,3.2rem);line-height:1.2;color:var(--on-dark);opacity:0;transform:translateY(18px);transition:.6s var(--ease)}
.mnav.open .mnav__links a{opacity:1;transform:none}
.mnav__links a:nth-child(1){transition-delay:.12s}.mnav__links a:nth-child(2){transition-delay:.17s}.mnav__links a:nth-child(3){transition-delay:.22s}.mnav__links a:nth-child(4){transition-delay:.27s}.mnav__links a:nth-child(5){transition-delay:.32s}.mnav__links a:nth-child(6){transition-delay:.37s}.mnav__links a:nth-child(7){transition-delay:.42s}.mnav__links a:nth-child(8){transition-delay:.47s}
.mnav__foot{display:flex;flex-direction:column;gap:.3em;color:var(--on-dark-soft);font-size:.9rem}
.mnav__foot a{color:var(--brass-2)}

/* ---------- 7. Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:var(--on-dark);overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);will-change:transform}
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(20,16,12,.62) 0%,rgba(20,16,12,0) 20%),
  linear-gradient(96deg,rgba(20,16,12,.74) 0%,rgba(20,16,12,.46) 34%,rgba(20,16,12,.14) 60%,rgba(20,16,12,0) 80%),
  linear-gradient(180deg,rgba(20,16,12,0) 42%,rgba(20,16,12,.42) 86%,rgba(20,16,12,.7) 100%)}
.hero__inner{width:100%;padding-bottom:clamp(3rem,7vh,7rem);padding-top:8rem}
.hero__eyebrow{color:#dcc69c}
.hero__eyebrow::before{background:#dcc69c}
.hero h1{color:#fdfaf3;font-weight:440;max-width:15ch;font-size:clamp(3.1rem,1.7rem + 5.4vw,6.7rem);line-height:1.0;letter-spacing:-.022em;text-shadow:0 2px 50px rgba(15,11,7,.4)}
.hero h1 em{font-weight:430}
.hero__lede{color:#f5efe4;max-width:44ch;margin-top:1.9rem;font-size:var(--fs-lead);font-weight:480;line-height:1.5;text-shadow:0 1px 26px rgba(15,11,7,.5)}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:2.2rem;align-items:center;margin-top:3rem;padding-top:1.8rem;border-top:1px solid rgba(239,230,214,.22)}
.hero__meta .stars{color:var(--brass-2);letter-spacing:.15em}
.scrollcue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.7em;color:var(--on-dark-soft);font-family:"Marcellus",serif;letter-spacing:.3em;text-transform:uppercase;font-size:.6rem;z-index:2}
.scrollcue .ln{width:1px;height:46px;background:linear-gradient(var(--brass-2),transparent);position:relative;overflow:hidden}
.scrollcue .ln::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--paper);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{top:-50%}60%,100%{top:100%}}

/* page hero (interior pages) */
.phero{position:relative;padding-top:clamp(9rem,16vh,13rem);padding-bottom:clamp(2.5rem,6vh,5rem);background:var(--espresso);color:var(--on-dark);overflow:hidden}
.phero--cream{background:var(--cream);color:var(--ink)}
.phero__eyebrow{color:var(--brass-2)}
.phero--cream .phero__eyebrow{color:var(--brass-ink)}
.phero h1{color:inherit;font-weight:400;max-width:18ch}
.phero--cream h1{color:var(--ink)}
.phero__crumb{font-family:"Marcellus",serif;letter-spacing:.2em;text-transform:uppercase;font-size:.66rem;color:var(--on-dark-soft);margin-bottom:1.4rem;display:flex;gap:.6em;flex-wrap:wrap}
.phero--cream .phero__crumb{color:var(--stone)}
.phero__crumb a:hover{color:var(--brass-2)}
.phero--cream .phero__crumb a:hover{color:var(--brass-ink)}

/* ---------- 8. Reveal animations ---------- */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal="fade"]{transform:none}
[data-reveal="left"]{transform:translateX(-40px)}
[data-reveal="right"]{transform:translateX(40px)}
[data-reveal].in{transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}[data-delay="5"]{transition-delay:.5s}[data-delay="6"]{transition-delay:.6s}
/* clip reveal for images */
.clip{overflow:hidden}
.clip img{transform:scale(1.18);transition:transform 1.6s var(--ease)}
.clip.in img{transform:scale(1)}
/* line draw */
.draw{position:relative}
.draw::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--line);transform:scaleX(0);transform-origin:left;transition:transform 1.3s var(--ease)}
.draw.in::after{transform:scaleX(1)}
/* word reveal headline */
.reveal-lines .ln-mask{overflow:hidden;display:block}
.reveal-lines .ln-in{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
.reveal-lines.in .ln-in{transform:none}
.reveal-lines.in .ln-mask:nth-child(2) .ln-in{transition-delay:.08s}
.reveal-lines.in .ln-mask:nth-child(3) .ln-in{transition-delay:.16s}
.reveal-lines.in .ln-mask:nth-child(4) .ln-in{transition-delay:.24s}

/* ---------- 9. Section heading block ---------- */
.shead{display:grid;grid-template-columns:1fr;gap:1.2rem;margin-bottom:clamp(2.4rem,5vw,4.2rem)}
.shead__top{display:flex;justify-content:space-between;align-items:baseline;gap:2rem;flex-wrap:wrap}
.shead h2{max-width:18ch}
.shead .lead{max-width:50ch}
.shead--split{grid-template-columns:1fr;align-items:end}
@media(min-width:880px){.shead--split{grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,5rem)}.shead--split .lead{margin-bottom:.3em}}

/* ---------- 10. Intro / editorial spreads ---------- */
.spread{display:grid;gap:clamp(2rem,5vw,5.5rem);align-items:center}
@media(min-width:900px){.spread{grid-template-columns:1fr 1fr}.spread--wide-img{grid-template-columns:1.15fr .85fr}.spread--text-first .spread__media{order:2}}
.spread__media{position:relative}
.spread__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.spread__media .tag{position:absolute;left:0;bottom:0;background:var(--cream);color:var(--ink);font-family:"Marcellus",serif;letter-spacing:.2em;text-transform:uppercase;font-size:.66rem;padding:.9em 1.4em}
.spread__body .eyebrow{margin-bottom:1.5rem}
.spread__body h2{margin-bottom:1.4rem}
.figure-stack{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.figure-stack img{aspect-ratio:3/4}
.figure-stack .tall{grid-row:span 2;aspect-ratio:auto;height:100%}

/* pull quote */
.pullquote{font-family:"Fraunces",serif;font-size:clamp(1.7rem,1.2rem + 2.4vw,3.1rem);line-height:1.18;font-weight:400;letter-spacing:-.01em;max-width:18ch}
.pullquote .amp{color:var(--brass)}

/* ---------- 11. Services list (editorial rows) ---------- */
.svc-row{display:grid;gap:1.5rem;padding-block:clamp(2.2rem,4vw,3.6rem);border-top:1px solid var(--line);align-items:start}
@media(min-width:860px){.svc-row{grid-template-columns:5.5rem 1fr 1.1fr;gap:clamp(2rem,4vw,4.5rem)}}
.svc-row__no{font-family:"Fraunces",serif;font-size:1.3rem;color:var(--brass)}
.svc-row__title{font-size:var(--fs-h3)}
.svc-row__title .sub{display:block;font-family:"Marcellus",serif;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--stone);margin-top:.9em}
.svc-row__body p{margin-bottom:1.4rem}
.svc-feats{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-family:"Marcellus",serif;letter-spacing:.1em;text-transform:uppercase;font-size:.66rem;color:var(--ink-soft);border:1px solid var(--line);border-radius:100px;padding:.55em 1.1em;background:var(--paper)}

/* ---------- 12. Project grid / portfolio ---------- */
.proj-grid{display:grid;gap:clamp(1.4rem,2.5vw,2.6rem) clamp(1.4rem,2.5vw,2.6rem)}
@media(min-width:760px){.proj-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:760px){
  .proj-grid--editorial .proj:nth-child(6n+1){grid-column:1/-1}
  .proj-grid--editorial .proj:nth-child(6n+1) .proj__media{aspect-ratio:16/7.6}
  .proj-grid--editorial .proj:nth-child(6n+4){transform:translateY(3.4rem)}
}
.proj{position:relative;display:block;overflow:hidden;background:var(--cream-2)}
.proj__media{overflow:hidden;aspect-ratio:4/5}
.proj.is-wide .proj__media{aspect-ratio:16/10}
.proj__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.5s var(--ease);transform:scale(1.02)}
.proj:hover .proj__media img{transform:scale(1.07)}
.proj__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,16,12,.62),rgba(20,16,12,.05) 45%,transparent);opacity:.85;transition:opacity .6s}
.proj__cap{position:absolute;left:0;right:0;bottom:0;padding:clamp(1.3rem,2.4vw,2.2rem);color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;z-index:2}
.proj__no{font-family:"Marcellus",serif;letter-spacing:.2em;font-size:.66rem;color:var(--brass-2);margin-bottom:.5em;display:block}
.proj__name{font-family:"Fraunces",serif;font-size:clamp(1.3rem,1rem + 1.4vw,2rem);line-height:1.05;font-weight:430;color:#fff}
.proj__loc{font-family:"Marcellus",serif;letter-spacing:.18em;text-transform:uppercase;font-size:.62rem;color:rgba(255,255,255,.78);margin-top:.6em;display:block}
.proj__go{width:3rem;height:3rem;flex:none;border:1px solid rgba(255,255,255,.5);border-radius:50%;display:grid;place-items:center;color:#fff;transition:.5s var(--ease);transform:translateY(6px);opacity:0}
.proj:hover .proj__go{transform:none;opacity:1;background:var(--brass);border-color:var(--brass)}

/* ---------- 13. Marquee ---------- */
.marquee{overflow:hidden;border-block:1px solid var(--line);padding-block:clamp(1.2rem,2vw,1.8rem);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:3.5rem;width:max-content;animation:scrollx 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{font-family:"Fraunces",serif;font-style:italic;font-size:clamp(1.2rem,2.2vw,1.9rem);color:var(--stone);display:inline-flex;align-items:center;gap:3.5rem;white-space:nowrap}
.marquee__item::after{content:"\00B7";color:var(--brass)}
@keyframes scrollx{to{transform:translateX(-50%)}}
.marquee--dark{background:var(--espresso);border-color:var(--espresso-2)}
.marquee--dark .marquee__item{color:var(--on-dark-soft)}

/* ---------- 14. Stats ---------- */
.stats{display:grid;gap:2.5rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:780px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{border-top:1px solid var(--line);padding-top:1.4rem}
.stat__num{font-family:"Fraunces",serif;font-size:clamp(2.4rem,1.6rem + 2.6vw,3.8rem);line-height:1;font-weight:400;color:var(--ink)}
.stat__num .u{color:var(--brass);font-size:.6em;vertical-align:super}
.stat__lab{font-family:"Marcellus",serif;letter-spacing:.18em;text-transform:uppercase;font-size:.68rem;color:var(--stone);margin-top:.9em}

/* ---------- 15. Process steps ---------- */
.steps{display:grid;gap:1.5rem;counter-reset:step}
@media(min-width:760px){.steps{grid-template-columns:repeat(4,1fr)}}
.step{border-top:1px solid var(--line);padding-top:1.5rem}
.step__no{font-family:"Fraunces",serif;color:var(--brass);font-size:1.1rem;letter-spacing:.05em}
.step h4{margin:.7em 0 .5em}
.step p{font-size:.97rem;color:var(--stone)}

/* ---------- 16. Dark / espresso section ---------- */
.dark{background:var(--espresso);color:var(--on-dark)}
.dark h1,.dark h2,.dark h3,.dark h4{color:#f4ecdc}
.dark .eyebrow{color:var(--brass-2)}.dark .eyebrow::before,.dark .eyebrow.center::after{background:var(--brass-2)}
.dark .lead{color:var(--on-dark)}
.dark .hr,.dark .svc-row,.dark .stat,.dark .step{border-color:rgba(239,230,214,.16)}
.dark .chip{color:var(--on-dark);border-color:rgba(239,230,214,.22);background:transparent}
.dark p{color:var(--on-dark-soft)}
.dark strong{color:#f4ecdc}

/* ---------- 17. Press ---------- */
.press-row{display:grid;gap:1rem;padding-block:clamp(1.6rem,3vw,2.6rem);border-top:1px solid var(--line);align-items:center;transition:padding-left .5s var(--ease)}
@media(min-width:820px){.press-row{grid-template-columns:auto 1fr auto;gap:clamp(1.5rem,4vw,4rem)}}
.press-row:hover{padding-left:.6rem}
.press-row__pub{font-family:"Marcellus",serif;letter-spacing:.2em;text-transform:uppercase;font-size:.72rem;color:var(--brass-ink)}
.press-row__title{font-family:"Fraunces",serif;font-size:clamp(1.2rem,1rem + 1vw,1.7rem);line-height:1.15;font-weight:430}
.press-row__go{justify-self:end;color:var(--stone);transition:.5s var(--ease)}
.press-row:hover .press-row__go{color:var(--brass);transform:translateX(5px)}

/* ---------- 18. FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;text-align:left;padding:clamp(1.3rem,2.5vw,1.9rem) 0;font-family:"Fraunces",serif;font-size:clamp(1.1rem,1rem + .7vw,1.45rem);font-weight:430;color:var(--ink);line-height:1.25}
.faq__icon{flex:none;width:2.4rem;height:2.4rem;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;position:relative;transition:.5s var(--ease)}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--brass-ink);transition:.45s var(--ease)}
.faq__icon::before{width:13px;height:1.5px}.faq__icon::after{width:1.5px;height:13px}
.faq__item.open .faq__icon{background:var(--brass);border-color:var(--brass)}
.faq__item.open .faq__icon::before,.faq__item.open .faq__icon::after{background:var(--paper)}
.faq__item.open .faq__icon::after{transform:rotate(90deg);opacity:0}
.faq__a{overflow:hidden;height:0;transition:height .5s var(--ease)}
.faq__a-in{padding-bottom:1.8rem;color:var(--stone);max-width:68ch}

/* ---------- 19. Gallery / lightbox ---------- */
.gallery{display:grid;gap:clamp(.8rem,1.4vw,1.4rem)}
.gallery--2{grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.gallery--3{grid-template-columns:repeat(3,1fr)}.gallery--2{grid-template-columns:repeat(2,1fr)}}
.gallery--masonry{columns:2;column-gap:clamp(.8rem,1.4vw,1.4rem)}
@media(min-width:900px){.gallery--masonry{columns:3}}
.gallery--masonry .gitem{margin-bottom:clamp(.8rem,1.4vw,1.4rem);break-inside:avoid}
.gitem{overflow:hidden;cursor:zoom-in;position:relative;background:var(--cream-2)}
.gitem img{width:100%;transition:transform 1.3s var(--ease),filter .6s;display:block}
.gitem:hover img{transform:scale(1.05)}
.gitem::after{content:"\002B";position:absolute;right:1rem;bottom:1rem;width:2.4rem;height:2.4rem;display:grid;place-items:center;background:rgba(20,16,12,.5);color:#fff;font-family:"Marcellus",serif;opacity:0;transform:translateY(8px);transition:.5s var(--ease);backdrop-filter:blur(3px)}
.gitem:hover::after{opacity:1;transform:none}
.gspan-2{grid-column:span 2}
@media(max-width:759px){.gspan-2{grid-column:auto}}

.lightbox{position:fixed;inset:0;z-index:500;background:rgba(18,14,10,.94);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .5s var(--ease);backdrop-filter:blur(6px)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:90vw;max-height:84vh;object-fit:contain;box-shadow:0 40px 120px -30px rgba(0,0,0,.8);transform:scale(.96);transition:transform .5s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lb-btn{position:absolute;background:none;color:var(--on-dark);width:3.4rem;height:3.4rem;display:grid;place-items:center;font-size:1.4rem;border:1px solid rgba(239,230,214,.25);border-radius:50%;transition:.4s;top:50%;transform:translateY(-50%)}
.lb-btn:hover{background:var(--brass);border-color:var(--brass);color:#fff}
.lb-prev{left:clamp(1rem,3vw,3rem)}.lb-next{right:clamp(1rem,3vw,3rem)}
.lb-close{top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);transform:none;width:3rem;height:3rem}
.lb-count{position:absolute;bottom:clamp(1rem,3vw,2rem);left:50%;transform:translateX(-50%);color:var(--on-dark-soft);font-family:"Marcellus",serif;letter-spacing:.2em;font-size:.74rem}
@media(max-width:680px){.lb-prev{left:.5rem}.lb-next{right:.5rem}.lb-btn{width:2.8rem;height:2.8rem}}

/* ---------- 20. Cards (blog / shop) ---------- */
.cards{display:grid;gap:clamp(1.6rem,3vw,2.8rem)}
@media(min-width:680px){.cards--2{grid-template-columns:repeat(2,1fr)}}
@media(min-width:760px){.cards--3{grid-template-columns:repeat(3,1fr)}}
@media(min-width:920px){.cards--4{grid-template-columns:repeat(4,1fr)}}
.card{display:flex;flex-direction:column;group:card}
.card__media{overflow:hidden;aspect-ratio:4/5;margin-bottom:1.3rem;background:var(--cream-2)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.card:hover .card__media img{transform:scale(1.06)}
.card__meta{font-family:"Marcellus",serif;letter-spacing:.2em;text-transform:uppercase;font-size:.64rem;color:var(--brass-ink);margin-bottom:.8rem}
.card__title{font-family:"Fraunces",serif;font-size:clamp(1.15rem,1rem + .7vw,1.5rem);line-height:1.18;font-weight:430;margin-bottom:.7rem;transition:color .4s}
.card:hover .card__title{color:var(--brass-ink)}
.card__excerpt{font-size:.96rem;color:var(--stone);margin-bottom:1.1rem}
.card__foot{margin-top:auto}
/* shop */
.product .card__media{aspect-ratio:1/1}
.product__price{font-family:"Fraunces",serif;font-size:1.1rem;color:var(--ink)}
.product__row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}

/* ---------- 21. Forms / newsletter ---------- */
.field{position:relative;margin-bottom:1.6rem}
.field input,.field textarea,.field select{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);padding:.9em 0;font:inherit;color:var(--ink);font-size:1.05rem}
.dark .field input,.dark .field textarea{color:var(--on-dark);border-color:rgba(239,230,214,.28)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brass)}
.field label{font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.66rem;color:var(--stone);display:block;margin-bottom:.4em}
.field textarea{resize:vertical;min-height:120px}
.form-grid{display:grid;gap:0 2rem}
@media(min-width:640px){.form-grid--2{grid-template-columns:1fr 1fr}}
.newsletter{display:flex;gap:.8rem;flex-wrap:wrap;max-width:440px}
.newsletter input{flex:1;min-width:200px;background:transparent;border:0;border-bottom:1px solid rgba(239,230,214,.4);color:var(--on-dark);padding:.8em 0;font:inherit}
.newsletter input::placeholder{color:var(--on-dark-soft)}
.newsletter input:focus{outline:none;border-color:var(--brass-2)}

/* ---------- 22. CTA band ---------- */
.cta-band{position:relative;overflow:hidden;color:var(--on-dark);text-align:center;padding-block:clamp(5rem,9vw,9rem)}
.cta-band__bg{position:absolute;inset:0;z-index:-2}
.cta-band__bg img{width:100%;height:100%;object-fit:cover}
.cta-band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(20,16,12,.78),rgba(20,16,12,.82))}
.cta-band h2{color:#f6eedd;max-width:20ch;margin-inline:auto}
.cta-band .lead{color:var(--on-dark);margin-inline:auto;max-width:50ch}

/* ---------- 23. Footer ---------- */
.footer{background:var(--espresso);color:var(--on-dark-soft);padding-top:clamp(4rem,7vw,7rem)}
.footer a:hover{color:var(--brass-2)}
.footer__top{display:grid;gap:3rem;padding-bottom:4rem;border-bottom:1px solid rgba(239,230,214,.14)}
@media(min-width:900px){.footer__top{grid-template-columns:1.4fr 1fr 1fr 1.2fr}}
.footer__brand .brand__name{color:#f4ecdc;font-size:1.6rem}
.footer__brand p{color:var(--on-dark-soft);margin-top:1.2rem;font-size:.98rem;max-width:34ch}
.footer__col h5{font-family:"Marcellus",serif;letter-spacing:.22em;text-transform:uppercase;font-size:.68rem;color:var(--brass-2);font-weight:400;margin-bottom:1.3rem}
.footer__col ul{display:flex;flex-direction:column;gap:.7em}
.footer__col a{color:var(--on-dark-soft);transition:color .3s;font-size:.98rem}
.footer__bot{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;padding-block:2rem;font-size:.82rem;color:var(--on-dark-soft)}
.footer__social{display:flex;gap:1.4rem}
.footer__social a{font-family:"Marcellus",serif;letter-spacing:.14em;text-transform:uppercase;font-size:.68rem}
.addr{font-style:normal}
.addr a{color:var(--on-dark)}

/* ---------- 24. Misc ---------- */
.tagrow{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.divider-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--brass);vertical-align:middle;margin-inline:.7em}
.kicker-line{width:64px;height:2px;background:var(--brass);margin-bottom:1.6rem}
.dark .kicker-line{background:var(--brass-2)}
.rich p{margin-bottom:1.3rem}
.rich p:last-child{margin-bottom:0}
.rich h2,.rich h3{margin:2.2rem 0 1rem}
.rich strong{color:var(--ink)}
.note{font-size:.82rem;color:var(--stone);font-style:italic}
.back-link{display:inline-flex;align-items:center;gap:.6em;font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.7rem;color:var(--stone)}
.back-link:hover{color:var(--brass-ink)}
.pagenav{display:flex;justify-content:space-between;gap:1rem;border-top:1px solid var(--line);padding-top:2rem;margin-top:3rem}
.pagenav a{display:flex;flex-direction:column;gap:.3em;max-width:45%}
.pagenav .l{font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.62rem;color:var(--stone)}
.pagenav .t{font-family:"Fraunces",serif;font-size:1.1rem;color:var(--ink)}
.pagenav .next{text-align:right;margin-left:auto}

/* selection of contact split */
.contact-split{display:grid;gap:clamp(2.5rem,5vw,5rem)}
@media(min-width:920px){.contact-split{grid-template-columns:.9fr 1.1fr}}
.info-row{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;padding-block:1.5rem;border-top:1px solid var(--line);align-items:start}
.info-row .ic{color:var(--brass);margin-top:.2em}
.info-row h5{font-family:"Marcellus",serif;letter-spacing:.18em;text-transform:uppercase;font-size:.68rem;color:var(--stone);font-weight:400;margin-bottom:.4em}
.info-row a,.info-row p{font-size:1.05rem;color:var(--ink)}

/* responsive header → mobile */
@media(max-width:980px){
  .header__nav{display:none}
  .header__bar{grid-template-columns:auto 1fr auto}
  .brand{justify-self:start}
  .header__cta{display:none}
  .menu-toggle{display:inline-flex;align-items:center;gap:.7em;justify-self:end;font-family:"Marcellus",serif;letter-spacing:.2em;text-transform:uppercase;font-size:.7rem;color:var(--on-dark)}
  .header.is-solid .menu-toggle,.header--light .menu-toggle{color:var(--ink)}
  .menu-toggle .bars{width:26px;display:inline-flex;flex-direction:column;gap:5px}
  .menu-toggle .bars span{height:1.5px;background:currentColor;display:block}
}
@media(max-width:520px){
  .hero__meta{gap:1.2rem}
  .pagenav .t{font-size:.95rem}
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* progress bar */
.scrollbar{position:fixed;top:0;left:0;height:2px;background:var(--brass);width:0;z-index:400;transition:width .1s linear}

/* page-load intro (first visit per session) */
.intro{position:fixed;inset:0;z-index:2000;background:var(--espresso);display:grid;place-items:center;transition:transform 1.15s var(--ease)}
.intro.done{transform:translateY(-101%)}
.intro__inner{display:flex;flex-direction:column;align-items:center;gap:.55rem;opacity:0;animation:introIn 1s var(--ease) .15s forwards}
.intro__name{font-family:"Fraunces",serif;color:#f4ecdc;font-size:clamp(1.9rem,4.5vw,3.2rem);font-weight:430;letter-spacing:.01em}
.intro__sub{font-family:"Marcellus",serif;letter-spacing:.5em;text-transform:uppercase;font-size:.66rem;color:var(--brass-2);padding-left:.5em}
.intro__bar{width:0;height:1px;background:var(--brass-2);margin-top:1.1rem;animation:introBar 1.5s var(--ease) .3s forwards}
@keyframes introIn{to{opacity:1}}
@keyframes introBar{to{width:130px}}
@media(prefers-reduced-motion:reduce){.intro{display:none}}

/* ============ Premium upgrades (benchmark pass) ============ */

/* Depth: subtle elevation on imagery over cream */
.card__media,.proj,.spread__media,.gitem,.cta-band__bg{box-shadow:var(--shadow-soft)}
.proj{box-shadow:var(--shadow)}

/* Section theme utilities (replace inline backgrounds) */
.section--panel{background:var(--cream-2)}
.section--sage{background:var(--sage);color:var(--on-dark)}
.section--sage h2,.section--sage h3,.section--sage h4{color:#f1ecdf}
.section--sage .eyebrow{color:#cdbf94}.section--sage .eyebrow::before,.section--sage .eyebrow.center::after{background:#cdbf94}
.section--sage p{color:#d7d1c0}
.section--sage .hr{border-color:rgba(239,230,214,.16)}

/* Press logo wall (static, credible) */
.logo-wall{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(1.6rem,4vw,3.6rem);border-block:1px solid var(--line);padding-block:clamp(1.8rem,3vw,2.6rem)}
.logo-wall span{font-family:"Marcellus",serif;letter-spacing:.22em;text-transform:uppercase;font-size:clamp(.66rem,.6rem + .3vw,.82rem);color:var(--stone);white-space:nowrap;transition:color .4s var(--ease)}
.logo-wall span:hover{color:var(--brass-ink)}

/* Testimonials */
.tmurb{position:relative}
.tm-grid{display:grid;gap:clamp(1.4rem,2.4vw,2.2rem)}
@media(min-width:760px){.tm-grid{grid-template-columns:repeat(3,1fr)}}
.tm{background:transparent;border:1px solid rgba(239,230,214,.18);padding:clamp(1.8rem,2.6vw,2.6rem);display:flex;flex-direction:column;gap:1.3rem;border-radius:2px}
.tm__stars{color:var(--brass-2);letter-spacing:.18em;font-size:.9rem}
.tm__quote{font-family:"Fraunces",serif;font-size:clamp(1.05rem,.95rem + .5vw,1.28rem);line-height:1.4;font-weight:430;color:#f3ecdc}
.tm__by{font-family:"Marcellus",serif;letter-spacing:.2em;text-transform:uppercase;font-size:.64rem;color:var(--brass-2);margin-top:auto}
.tm--feature{grid-column:1/-1}
@media(min-width:760px){.tm--feature{grid-column:span 3}}
.tm-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2rem,4vw,3.4rem)}
.tm-rating{display:flex;align-items:baseline;gap:.8rem}
.tm-rating b{font-family:"Fraunces",serif;font-size:2.4rem;font-weight:430;color:#f3ecdc;line-height:1}
.tm-rating span{font-family:"Marcellus",serif;letter-spacing:.16em;text-transform:uppercase;font-size:.7rem;color:var(--on-dark-soft)}

/* Founder signature line */
.signature{display:flex;align-items:center;gap:1rem;margin-top:2rem}
.signature__name{font-family:"Fraunces",serif;font-style:italic;font-size:1.3rem;color:var(--ink)}
.signature__role{font-family:"Marcellus",serif;letter-spacing:.18em;text-transform:uppercase;font-size:.62rem;color:var(--stone)}
.signature__rule{width:42px;height:1px;background:var(--brass)}

/* hero image: real parallax target */
.hero__img{width:100%;height:100%;object-fit:cover;transform:scale(1.1);will-change:transform}

/* proj caption legibility */
.proj__loc{color:rgba(255,255,255,.85)}
.proj__name{font-weight:450}
.cta-band .lead{font-weight:480}

/* ============ Cinematic motion layer ============ */

/* Hero: living Ken Burns zoom */
.hero__img{animation:kenburns 20s cubic-bezier(.22,1,.36,1) forwards}
@keyframes kenburns{from{transform:scale(1.18)}to{transform:scale(1.04)}}
@media (prefers-reduced-motion:reduce){.hero__img{animation:none;transform:scale(1.04)}}

/* Custom cursor (desktop, fine pointer only) */
@media (hover:hover) and (pointer:fine){
  body.has-cursor{cursor:none}
  .has-cursor a,.has-cursor button,.has-cursor .faq__q,.has-cursor .gitem,.has-cursor .proj,.has-cursor input,.has-cursor textarea,.has-cursor select,.has-cursor label{cursor:none}
  .cursor{position:fixed;top:0;left:0;width:38px;height:38px;border:1px solid rgba(154,123,67,.85);border-radius:50%;pointer-events:none;z-index:1500;transform:translate(-50%,-50%);transition:width .45s var(--ease),height .45s var(--ease),background .45s var(--ease),border-color .45s var(--ease),opacity .4s;will-change:transform}
  .cursor-dot{position:fixed;top:0;left:0;width:5px;height:5px;background:var(--brass);border-radius:50%;pointer-events:none;z-index:1501;transform:translate(-50%,-50%);transition:opacity .3s,transform .15s}
  .cursor.is-hover{width:62px;height:62px;background:rgba(154,123,67,.1);border-color:rgba(154,123,67,.5)}
  .cursor.is-view{width:92px;height:92px;background:rgba(20,16,12,.32);border-color:transparent;backdrop-filter:blur(2px)}
  .cursor.is-view::after{content:"View";font-family:"Marcellus",serif;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:#fff}
  .cursor.is-down{transform:translate(-50%,-50%) scale(.82)}
  .cursor.on-dark{border-color:rgba(231,222,206,.8)}
  body.cursor-hidden .cursor,body.cursor-hidden .cursor-dot{opacity:0}
}
@media (hover:none),(pointer:coarse){.cursor,.cursor-dot{display:none}}

/* Page transition curtain */
.curtain{position:fixed;inset:0;z-index:1800;background:var(--espresso);transform:translateY(100%);pointer-events:none;display:grid;place-items:center}
.curtain__mark{font-family:"Fraunces",serif;color:#f1e9d8;font-size:clamp(1.5rem,3vw,2.4rem);font-weight:430;opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease) .12s,transform .6s var(--ease) .12s}
.curtain__mark em{color:var(--brass-2);font-style:italic}
.curtain.cover{transform:translateY(0);transition:transform .72s var(--ease)}
.curtain.cover .curtain__mark{opacity:1;transform:none}
.curtain.lift{transform:translateY(-100%);transition:transform .8s var(--ease)}
.curtain.instant{transition:none}
@media (prefers-reduced-motion:reduce){.curtain{display:none}}

/* Magnetic wrap (set via JS transform) */
.btn,.proj__go{will-change:transform}

/* Section numerals for editorial rhythm */
.shead__index{font-family:"Fraunces",serif;font-size:.95rem;color:var(--brass);letter-spacing:.05em;display:inline-block;margin-bottom:1rem}

/* Statement / manifesto section */
.manifesto{padding-block:clamp(6rem,11vw,13rem);overflow:hidden}
.manifesto__text{font-family:"Fraunces",serif;font-weight:400;font-size:clamp(2rem,1.1rem + 4.6vw,5.2rem);line-height:1.1;letter-spacing:-.02em;max-width:20ch;text-wrap:normal;color:var(--ink)}
.manifesto__text .w{display:inline-block;opacity:0;transform:translateY(40%) rotate(2deg);transition:opacity .7s var(--ease),transform .9s var(--ease)}
.manifesto.in .manifesto__text .w{opacity:1;transform:none}
.manifesto__text em{color:var(--brass);font-style:italic}
.manifesto__foot{margin-top:clamp(2.5rem,5vw,4rem);display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}

/* heavier feature image reveal (mask wipe) */
.clip--mask{overflow:hidden;clip-path:inset(0 0 0 0)}
.clip--mask>img{transform:scale(1.22);transition:transform 1.7s var(--ease)}
.clip--mask.in>img{transform:scale(1.02)}
