/* ============================== TOKENS ============================== */
:root{
  --paper:#F2EDE4;          /* warm bone background        */
  --paper-2:#FBF8F2;        /* lighter surface             */
  --ink:#1B1813;            /* near-black warm             */
  --ink-soft:#6B6256;       /* muted body text             */
  --line:rgba(27,24,19,.15);
  --line-soft:rgba(27,24,19,.09);
  --char:#1A1713;           /* dark section background     */
  --char-2:#13110D;
  --walnut:#7C5230;         /* accent — from the mantel    */
  --clay:#B0824F;           /* lighter accent / hover      */
  --cream:#ECE4D6;          /* text on dark                */
  --muted-dark:#9C9183;     /* muted text on dark          */

  --gutter:clamp(20px,5vw,64px);
  --maxw:1320px;
  --header-h:86px;

  --ff-display:"Fraunces",Georgia,serif;
  --ff-sans:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ============================== RESET ============================== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 10px);-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--walnut);color:var(--paper-2)}

/* ============================== GRAIN ============================== */
.grain{
  position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.04;mix-blend-mode:multiply;
  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");
}

/* ============================== LAYOUT ============================== */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative}
.eyebrow{
  font-family:var(--ff-sans);
  font-size:.72rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;
  color:var(--walnut);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.eyebrow.no-rule::before{display:none}

/* ============================== BUTTONS ============================== */
.btn{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--ff-sans);font-weight:600;font-size:.92rem;letter-spacing:.01em;
  padding:1.05em 1.6em;border-radius:100px;
  transition:transform .5s var(--ease-out),background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease);
  will-change:transform;
}
.btn iconify-icon{font-size:1.1em;transition:transform .5s var(--ease-out)}
.btn--solid{background:var(--ink);color:var(--paper-2)}
.btn--solid:hover{background:var(--walnut)}
.btn--solid:hover iconify-icon{transform:translate(3px,-3px)}
.btn--ghost{border:1px solid var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper-2)}
.btn--ghost:hover iconify-icon{transform:translate(3px,-3px)}
.btn--light{background:var(--cream);color:var(--char)}
.btn--light:hover{background:#fff}
.btn--light:hover iconify-icon{transform:translate(3px,-3px)}

/* ============================== HEADER ============================== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-h);
  display:flex;align-items:center;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),height .4s var(--ease);
}
.header__inner{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;flex-direction:column;line-height:.92;letter-spacing:.02em}
.brand b{font-family:var(--ff-display);font-weight:500;font-size:1.42rem;letter-spacing:.04em}
.brand span{font-family:var(--ff-sans);font-size:.6rem;font-weight:600;letter-spacing:.42em;
  text-transform:uppercase;color:var(--ink-soft);margin-top:.34em;padding-left:.06em}
.nav{display:flex;align-items:center;gap:2.4rem}
.nav a{font-size:.86rem;font-weight:500;letter-spacing:.02em;position:relative;padding:.3em 0;color:var(--ink)}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--walnut);transition:width .4s var(--ease)}
.nav a:hover::after,.nav a.is-active::after{width:100%}
.nav a.is-active{color:var(--walnut)}
.header__cta{display:flex;align-items:center;gap:1.4rem}
.header.scrolled{background:rgba(242,237,228,.86);backdrop-filter:blur(14px);height:72px;
  box-shadow:0 1px 0 var(--line-soft)}
.burger{display:none;width:30px;height:18px;position:relative}
.burger span{position:absolute;left:0;height:1.6px;width:100%;background:var(--ink);transition:.4s var(--ease)}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:8px}
.burger span:nth-child(3){top:16px}
body.menu-open .burger span:nth-child(1){top:8px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:8px;transform:rotate(-45deg)}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:999;background:var(--char);color:var(--cream);
  display:flex;flex-direction:column;justify-content:center;padding:var(--gutter);
  clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease-out);
  pointer-events:none;
}
body.menu-open .mobile-menu{clip-path:inset(0 0 0 0);pointer-events:auto}
.mobile-menu a{font-family:var(--ff-display);font-weight:400;font-size:clamp(2rem,9vw,3.4rem);
  padding:.18em 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}
.mobile-menu a span{font-family:var(--ff-sans);font-size:.7rem;color:var(--muted-dark);letter-spacing:.2em}
.mobile-menu .mm-foot{margin-top:auto;padding-top:2rem;color:var(--muted-dark);font-size:.85rem;display:flex;flex-wrap:wrap;gap:.4rem 1.4rem}
.mobile-menu .mm-foot a{font-family:var(--ff-sans);font-size:.85rem;border:none;padding:0;color:var(--cream)}

/* ============================== HERO (home) ============================== */
.hero{position:relative;min-height:100vh;min-height:100svh;display:grid;
  grid-template-columns:1.04fr .96fr;align-items:stretch}
.hero__content{
  grid-column:1;display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--header-h) + 3vh) clamp(2rem,4vw,5rem) 4vh var(--gutter);
  max-width:760px;
}
.hero__eyebrow{margin-bottom:clamp(1.4rem,3vh,2.4rem)}
.hero h1{
  font-family:var(--ff-display);font-weight:340;
  font-size:clamp(2.9rem,6.4vw,6rem);line-height:.98;letter-spacing:-.022em;
  font-variation-settings:"opsz" 140;
}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln i{display:block;font-style:normal;transform:translateY(110%);
  transition:transform 1s var(--ease-out)}
.hero h1 em{font-style:italic;color:var(--walnut);font-variation-settings:"opsz" 144}
.hero__sub{
  margin-top:clamp(1.6rem,3.4vh,2.4rem);max-width:46ch;
  font-size:1.06rem;line-height:1.65;color:var(--ink-soft);
}
.hero__actions{margin-top:clamp(2rem,4vh,2.8rem);display:flex;flex-wrap:wrap;gap:1rem}
.hero__meta{margin-top:clamp(2.4rem,5vh,3.6rem);display:flex;flex-wrap:wrap;gap:0;
  border-top:1px solid var(--line)}
.hero__meta div{padding:1.1rem 1.6rem 0 0;margin-right:1.6rem}
.hero__meta dt{font-family:var(--ff-display);font-size:1.5rem;font-weight:400;line-height:1}
.hero__meta dd{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:.5em}

/* hero image */
.hero__media{grid-column:2;position:relative;overflow:hidden;background:#ddd6ca}
.hero__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 38%;
  transform:scale(1.16);transition:transform 1.6s var(--ease-out)}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(27,24,19,.10),transparent 40%)}
.hero__cap{
  position:absolute;left:1.6rem;bottom:1.6rem;z-index:2;
  background:rgba(20,17,13,.5);backdrop-filter:blur(8px);color:var(--cream);
  padding:.85rem 1.1rem;border-radius:12px;max-width:280px;
  opacity:0;transform:translateY(14px);transition:.9s var(--ease-out) .9s;
}
.hero__cap b{display:block;font-family:var(--ff-display);font-weight:400;font-size:1rem;margin-bottom:.2em}
.hero__cap span{font-size:.72rem;letter-spacing:.06em;color:var(--muted-dark)}
.hero__scroll{
  position:absolute;left:var(--gutter);bottom:1.8rem;z-index:3;
  display:flex;align-items:center;gap:.7em;font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-soft);
  opacity:0;transition:opacity 1s var(--ease) 1.3s}
.hero__scroll iconify-icon{font-size:1.2em;animation:bob 2.4s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* hero load sequence */
body.loaded .hero h1 .ln:nth-child(1) i{transform:translateY(0);transition-delay:.15s}
body.loaded .hero h1 .ln:nth-child(2) i{transform:translateY(0);transition-delay:.28s}
body.loaded .hero h1 .ln:nth-child(3) i{transform:translateY(0);transition-delay:.41s}
body.loaded .hero__media img{transform:scale(1)}
body.loaded .hero__cap{opacity:1;transform:translateY(0)}
body.loaded .hero__scroll{opacity:1}
.hero__fade{opacity:0;transform:translateY(20px);transition:opacity 1s var(--ease),transform 1s var(--ease-out)}
body.loaded .hero__fade{opacity:1;transform:translateY(0)}
body.loaded .hero__eyebrow{transition-delay:.1s}
body.loaded .hero__sub{transition-delay:.5s}
body.loaded .hero__actions{transition-delay:.62s}
body.loaded .hero__meta{transition-delay:.74s}

/* ============================== PAGE HERO (sub-pages) ============================== */
.phero{padding:calc(var(--header-h) + clamp(4rem,9vw,8rem)) 0 clamp(3rem,6vw,5.5rem);
  border-bottom:1px solid var(--line)}
.phero__grid{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(1.6rem,4vw,4rem);align-items:end}
.phero h1{font-family:var(--ff-display);font-weight:320;
  font-size:clamp(2.6rem,6.4vw,5.4rem);line-height:1.0;letter-spacing:-.025em;max-width:15ch}
.phero h1 em{font-style:italic;color:var(--walnut)}
.phero__eyebrow{margin-bottom:clamp(1.4rem,3vw,2rem)}
.phero__intro{color:var(--ink-soft);font-size:1.08rem;line-height:1.65;max-width:48ch;padding-bottom:.5rem}

/* ============================== MARQUEE ============================== */
.marquee{border-block:1px solid var(--line);overflow:hidden;background:var(--paper-2)}
.marquee__track{display:flex;white-space:nowrap;width:max-content;animation:scroll 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--ff-display);font-weight:350;font-style:italic;
  font-size:clamp(1.3rem,2.6vw,2.1rem);padding:1.1rem 0;color:var(--ink)}
.marquee__track i{display:inline-block;width:9px;height:9px;border-radius:50%;
  background:var(--walnut);margin:0 1.6rem;transform:translateY(-.35em);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================== HORIZONTAL WORK STRIP ============================== */
.strip{background:var(--char);color:var(--cream);padding-block:clamp(4rem,8vw,7rem);overflow:hidden}
.strip__head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;
  margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.strip .eyebrow{color:var(--clay)}
.strip__title{font-family:var(--ff-display);font-weight:330;font-size:clamp(2rem,4.4vw,3.5rem);
  line-height:1.04;letter-spacing:-.02em;margin-top:1rem}
.strip__title em{font-style:italic;color:var(--clay)}
.strip__nav{display:flex;align-items:center;gap:1.4rem;flex-shrink:0}
.strip__hint{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-dark)}
.strip__btn{width:54px;height:54px;border-radius:50%;border:1px solid rgba(236,228,214,.3);
  display:grid;place-items:center;color:var(--cream);font-size:1.25rem;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),transform .3s var(--ease)}
.strip__btn:hover{background:var(--cream);color:var(--char);border-color:var(--cream)}
.strip__btn:active{transform:scale(.93)}
.strip__btn:disabled{opacity:.3;cursor:default;pointer-events:none}

.strip__scroller{overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;
  scroll-padding-left:var(--gutter);scrollbar-width:none;-ms-overflow-style:none;
  cursor:grab;-webkit-overflow-scrolling:touch}
.strip__scroller::-webkit-scrollbar{display:none}
.strip__scroller.dragging{cursor:grabbing;scroll-snap-type:none}
.strip__track{display:flex;gap:clamp(.9rem,1.4vw,1.5rem);padding-inline:var(--gutter);width:max-content}

.scard{position:relative;flex:0 0 auto;height:clamp(400px,64vh,680px);overflow:hidden;
  scroll-snap-align:start;border-radius:5px;background:#26221c}
.scard img{display:block;height:100%;width:auto;max-width:none;object-fit:cover;
  user-select:none;-webkit-user-drag:none;pointer-events:none;
  transition:transform 1.1s var(--ease-out)}
.scard:hover img{transform:scale(1.045)}
.scard__cap{position:absolute;inset:auto 0 0 0;z-index:2;padding:2.4rem 1.6rem 1.4rem;
  background:linear-gradient(to top,rgba(14,11,8,.82),rgba(14,11,8,.1) 75%,transparent)}
.scard__cap span{display:block;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--clay);font-weight:600;margin-bottom:.5em}
.scard__cap b{font-family:var(--ff-display);font-weight:400;font-size:1.3rem;letter-spacing:-.01em;line-height:1.1}
/* end card */
.scard--end{width:clamp(260px,22vw,340px);display:grid;place-items:center;text-align:center;
  background:#211e19;border:1px solid rgba(236,228,214,.14)}
.scard--end__inner{display:inline-flex;align-items:center;gap:.6em;font-family:var(--ff-display);
  font-style:italic;font-size:1.4rem;color:var(--cream);padding:0 1.5rem;
  transition:gap .4s var(--ease),color .4s var(--ease)}
.scard--end:hover .scard--end__inner{gap:1em;color:var(--clay)}
.scard--end iconify-icon{font-size:.85em}

/* ============================== SECTION HEADS ============================== */
.shead{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:end;
  margin-bottom:clamp(3rem,6vw,5rem)}
.shead h2{font-family:var(--ff-display);font-weight:330;
  font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.04;letter-spacing:-.02em;max-width:14ch}
.shead h2 em{font-style:italic;color:var(--walnut)}
.shead__aside{color:var(--ink-soft);max-width:42ch;font-size:1.02rem;padding-bottom:.4rem}

/* ============================== APPROACH ============================== */
.approach{padding-block:clamp(6rem,12vw,11rem)}
.approach__grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(2rem,6vw,6rem);align-items:start}
.approach__lead{font-family:var(--ff-display);font-weight:330;
  font-size:clamp(1.7rem,2.9vw,2.5rem);line-height:1.22;letter-spacing:-.01em}
.approach__lead em{font-style:italic;color:var(--walnut)}
.approach__body p{color:var(--ink-soft);font-size:1.06rem;line-height:1.7;margin-bottom:1.2rem;max-width:54ch}
.approach__sticky{position:sticky;top:calc(var(--header-h) + 2rem)}

/* ============================== WHY / LEDGER ============================== */
.why{padding-block:clamp(4rem,8vw,7rem);border-top:1px solid var(--line)}
.ledger{display:grid;gap:0}
.ledger__row{
  display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1.2rem,4vw,3.4rem);
  align-items:baseline;padding:clamp(1.6rem,3vw,2.4rem) 0;border-top:1px solid var(--line);
  transition:padding-left .5s var(--ease)}
.ledger__row:last-child{border-bottom:1px solid var(--line)}
.ledger__row:hover{padding-left:clamp(.4rem,1.5vw,1.4rem)}
.ledger__num{font-family:var(--ff-sans);font-size:.78rem;font-weight:600;letter-spacing:.15em;
  color:var(--walnut);padding-top:.6em}
.ledger__title{font-family:var(--ff-display);font-weight:360;
  font-size:clamp(1.45rem,3vw,2.3rem);line-height:1.12;letter-spacing:-.01em}
.ledger__desc{color:var(--ink-soft);font-size:.98rem;max-width:34ch;justify-self:end;text-align:right}

/* ============================== SERVICES (home snapshot) ============================== */
.services{padding-block:clamp(6rem,12vw,11rem)}
.svc-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(2rem,5vw,4.5rem)}
.svc-group h3{font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);padding-bottom:1.2rem;margin-bottom:.4rem;border-bottom:1px solid var(--line)}
.svc-item{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.95rem 0;border-bottom:1px solid var(--line-soft);
  font-family:var(--ff-display);font-weight:380;font-size:clamp(1.05rem,1.5vw,1.3rem);
  letter-spacing:-.01em;color:var(--ink);
  transition:color .4s var(--ease),padding-left .45s var(--ease);position:relative;cursor:default}
.svc-item iconify-icon{font-size:1rem;opacity:0;transform:translateX(-6px);color:var(--walnut);
  transition:.45s var(--ease)}
.svc-item:hover{color:var(--walnut);padding-left:.8rem}
.svc-item:hover iconify-icon{opacity:1;transform:translateX(0)}
.services__foot{margin-top:clamp(3rem,6vw,4.5rem);display:flex;flex-wrap:wrap;gap:1.4rem;align-items:center;justify-content:space-between}
.services__foot p{color:var(--ink-soft);max-width:48ch;font-size:1rem}

/* cursor-follow preview */
.svc-preview{
  position:fixed;top:0;left:0;z-index:500;width:300px;height:380px;border-radius:14px;overflow:hidden;
  pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.92);
  box-shadow:0 30px 60px -20px rgba(20,17,13,.5);
  transition:opacity .45s var(--ease),transform .55s var(--ease-out);will-change:transform}
.svc-preview img{width:100%;height:100%;object-fit:cover}
.svc-preview.show{opacity:1}

/* ============================== SERVICES DETAIL (services page) ============================== */
.svc-cat{padding-block:clamp(3.5rem,7vw,6rem);border-top:1px solid var(--line)}
.svc-cat__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.svc-cat__media{position:sticky;top:calc(var(--header-h) + 1.5rem)}
.svc-cat__num{font-family:var(--ff-sans);font-size:.75rem;font-weight:600;letter-spacing:.2em;color:var(--walnut)}
.svc-cat__media h2{font-family:var(--ff-display);font-weight:330;font-size:clamp(1.8rem,3.4vw,2.8rem);
  line-height:1.05;letter-spacing:-.02em;margin:.9rem 0 1.6rem;max-width:12ch}
.svc-cat__media h2 em{font-style:italic;color:var(--walnut)}
.svc-cat__img{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:5px;background:#ddd6ca}
.svc-list{display:grid;gap:0}
.srow{padding:clamp(1.4rem,2.6vw,2.2rem) 0;border-top:1px solid var(--line-soft)}
.srow:first-child{border-top:none;padding-top:0}
.srow h3{font-family:var(--ff-display);font-weight:400;font-size:clamp(1.25rem,2.1vw,1.7rem);
  letter-spacing:-.01em;display:flex;align-items:baseline;gap:.7em}
.srow h3 .i{font-family:var(--ff-sans);font-size:.72rem;font-weight:600;letter-spacing:.12em;color:var(--clay)}
.srow p{color:var(--ink-soft);font-size:1.02rem;line-height:1.65;margin-top:.7rem;max-width:56ch}

/* material supply callout */
.supply{background:var(--char);color:var(--cream);padding-block:clamp(4rem,8vw,6.5rem)}
.supply__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.supply .eyebrow{color:var(--clay)}
.supply h2{font-family:var(--ff-display);font-weight:330;font-size:clamp(1.9rem,3.8vw,3rem);
  line-height:1.08;letter-spacing:-.02em;margin:1.2rem 0}
.supply h2 em{font-style:italic;color:var(--clay)}
.supply p{color:var(--muted-dark);font-size:1.05rem;line-height:1.7;max-width:50ch}

/* ============================== WORK GRID ============================== */
.work{padding-block:clamp(5rem,9vw,8rem);background:var(--paper-2);border-block:1px solid var(--line)}
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1rem,2vw,1.8rem)}
.wcard{overflow:hidden;position:relative}
.wcard a{display:block;position:relative}
.wcard__img{overflow:hidden;background:#ddd6ca}
.wcard__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.wcard:hover .wcard__img img{transform:scale(1.05)}
.wcard__meta{padding-top:1rem;display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.wcard__meta b{font-family:var(--ff-display);font-weight:420;font-size:1.15rem;letter-spacing:-.01em}
.wcard__meta span{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:right}
.wcard--a{grid-column:span 7}
.wcard--a .wcard__img{aspect-ratio:7/5}
.wcard--b{grid-column:span 5}
.wcard--b .wcard__img{aspect-ratio:4/5}
.wcard--c{grid-column:span 4}
.wcard--c .wcard__img{aspect-ratio:3/4}
.wcard--d{grid-column:span 4}
.wcard--d .wcard__img{aspect-ratio:3/4}
.wcard--e{grid-column:span 4}
.wcard--e .wcard__img{aspect-ratio:3/4}
.work__foot{margin-top:clamp(2.4rem,5vw,3.6rem);display:flex;justify-content:center}

/* ============================== PORTFOLIO GALLERY ============================== */
.gallery-wrap{padding-block:clamp(3rem,6vw,5rem)}
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:clamp(2.4rem,5vw,3.4rem)}
.filter-btn{font-family:var(--ff-sans);font-size:.82rem;font-weight:600;letter-spacing:.02em;
  padding:.7em 1.25em;border-radius:100px;border:1px solid var(--line);color:var(--ink-soft);
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease)}
.filter-btn:hover{border-color:var(--ink);color:var(--ink)}
.filter-btn.active{background:var(--ink);color:var(--paper-2);border-color:var(--ink)}
.gallery{column-count:3;column-gap:clamp(.8rem,1.5vw,1.4rem)}
.gitem{break-inside:avoid;margin-bottom:clamp(.8rem,1.5vw,1.4rem);position:relative;cursor:zoom-in;
  overflow:hidden;border-radius:4px;background:#ddd6ca;display:block}
.gitem img{width:100%;display:block;transition:transform 1s var(--ease-out)}
.gitem:hover img{transform:scale(1.045)}
.gitem__cap{position:absolute;inset:auto 0 0 0;padding:1.6rem 1.1rem .9rem;z-index:2;
  background:linear-gradient(to top,rgba(14,11,8,.8),transparent);color:var(--cream);
  opacity:0;transform:translateY(8px);transition:.4s var(--ease)}
.gitem:hover .gitem__cap{opacity:1;transform:translateY(0)}
.gitem__cap span{display:block;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);font-weight:600;margin-bottom:.3em}
.gitem__cap b{font-family:var(--ff-display);font-weight:400;font-size:1.05rem;line-height:1.1}
.gitem.hide{display:none}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(12,10,7,.95);
  display:flex;align-items:center;justify-content:center;padding:clamp(1rem,4vw,4rem);
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:100%;max-height:84vh;object-fit:contain;border-radius:3px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.lb-cap{position:absolute;left:0;right:0;bottom:clamp(1rem,3vw,2.2rem);text-align:center;color:var(--cream);
  font-family:var(--ff-display);font-style:italic;font-size:1.05rem;letter-spacing:.02em}
.lb-cap span{color:var(--muted-dark)}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;
  border:1px solid rgba(236,228,214,.3);display:grid;place-items:center;color:var(--cream);font-size:1.3rem;
  transition:background .35s var(--ease),color .35s var(--ease)}
.lb-btn:hover{background:var(--cream);color:var(--char)}
.lb-prev{left:clamp(.8rem,3vw,2.5rem)}
.lb-next{right:clamp(.8rem,3vw,2.5rem)}
.lb-close{position:absolute;top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);width:50px;height:50px;
  border-radius:50%;border:1px solid rgba(236,228,214,.3);display:grid;place-items:center;color:var(--cream);
  font-size:1.3rem;transition:background .35s var(--ease),color .35s var(--ease)}
.lb-close:hover{background:var(--cream);color:var(--char)}

/* ============================== IMAGE BAND (about) ============================== */
.imgband{width:100%;height:clamp(360px,58vh,640px);overflow:hidden;background:#cfc8bb}
.imgband img{width:100%;height:100%;object-fit:cover;object-position:center 44%}

/* ============================== ABOUT ============================== */
.about-lead{padding-block:clamp(5rem,10vw,9rem)}
.about-lead__grid{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(2rem,6vw,6rem);align-items:start}
.about-lead__statement{font-family:var(--ff-display);font-weight:320;
  font-size:clamp(1.7rem,3vw,2.6rem);line-height:1.2;letter-spacing:-.01em}
.about-lead__statement em{font-style:italic;color:var(--walnut)}
.about-lead__body p{color:var(--ink-soft);font-size:1.06rem;line-height:1.72;margin-bottom:1.2rem;max-width:56ch}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.5rem);
  padding-block:clamp(3rem,6vw,5rem);border-top:1px solid var(--line)}
.about-stat dt{font-family:var(--ff-display);font-weight:380;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1;letter-spacing:-.02em}
.about-stat dd{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:.8em}

/* ============================== CONTACT PAGE ============================== */
.contact{padding-block:clamp(4rem,8vw,7rem)}
.contact__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.contact__info .eyebrow{margin-bottom:1.4rem}
.contact__info h2{font-family:var(--ff-display);font-weight:330;font-size:clamp(1.9rem,3.6vw,2.8rem);
  line-height:1.1;letter-spacing:-.02em;margin-bottom:1.4rem}
.contact__info h2 em{font-style:italic;color:var(--walnut)}
.contact__info p{color:var(--ink-soft);font-size:1.05rem;line-height:1.7;max-width:42ch;margin-bottom:2.4rem}
.contact__lines{display:grid;gap:1.4rem}
.cline{display:flex;align-items:flex-start;gap:1em}
.cline iconify-icon{font-size:1.3rem;color:var(--walnut);margin-top:.1em}
.cline b{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.3em;font-weight:600}
.cline a,.cline span{font-family:var(--ff-display);font-size:1.15rem;color:var(--ink)}
.cline a{transition:color .35s var(--ease)}
.cline a:hover{color:var(--walnut)}

.cform{background:var(--paper-2);border:1px solid var(--line);border-radius:14px;
  padding:clamp(1.6rem,4vw,2.8rem);display:grid;gap:1.3rem}
.cform__fields{display:grid;gap:1.3rem}
.cform__row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
.field{display:flex;flex-direction:column;gap:.55rem}
.field label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
.field input,.field select,.field textarea{
  font-family:var(--ff-sans);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:9px;padding:.9em 1em;
  transition:border-color .3s var(--ease),box-shadow .3s var(--ease);width:100%}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--walnut);box-shadow:0 0 0 3px rgba(124,82,48,.12)}
.cform__submit{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.cform__note{font-size:.82rem;color:var(--ink-soft);max-width:32ch}
.cform.sent .cform__fields{display:none}
.cform__thanks{display:none;text-align:center;padding:1rem 0}
.cform.sent .cform__thanks{display:block}
.cform__thanks iconify-icon{font-size:2.6rem;color:var(--walnut)}
.cform__thanks h3{font-family:var(--ff-display);font-weight:400;font-size:1.6rem;margin:.6rem 0 .4rem}
.cform__thanks p{color:var(--ink-soft);font-size:1rem}

/* ============================== CONTACT CTA (shared band) ============================== */
.cta{background:var(--char);color:var(--cream);padding-block:clamp(6rem,13vw,12rem);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.16;
  background:radial-gradient(120% 90% at 80% 10%,rgba(176,130,79,.5),transparent 55%)}
.cta__inner{position:relative;text-align:center;max-width:880px;margin-inline:auto}
.cta .eyebrow{color:var(--clay)}
.cta h2{font-family:var(--ff-display);font-weight:320;
  font-size:clamp(2.4rem,6vw,5rem);line-height:1.02;letter-spacing:-.02em;margin:1.6rem 0 1.4rem}
.cta h2 em{font-style:italic;color:var(--clay)}
.cta p{color:var(--muted-dark);font-size:1.1rem;max-width:46ch;margin:0 auto 2.6rem}
.cta__actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;align-items:center}
.cta__mail{display:inline-flex;align-items:center;gap:.6em;font-family:var(--ff-display);
  font-style:italic;font-size:1.2rem;color:var(--cream);border-bottom:1px solid rgba(255,255,255,.3);
  padding-bottom:.2em;transition:border-color .4s var(--ease)}
.cta__mail:hover{border-color:var(--clay)}

/* ============================== FOOTER ============================== */
.footer{background:var(--char-2);color:var(--cream);padding-top:clamp(4rem,8vw,6rem);padding-bottom:2.4rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem;
  padding-bottom:clamp(3rem,6vw,5rem);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand b{font-family:var(--ff-display);font-weight:400;font-size:clamp(2.2rem,5vw,3.4rem);
  letter-spacing:.03em;display:block;line-height:1}
.footer__brand p{color:var(--muted-dark);max-width:34ch;margin-top:1.4rem;font-size:.96rem;line-height:1.6}
.footer__col h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-dark);margin-bottom:1.4rem}
.footer__col a,.footer__col p{display:block;color:var(--cream);font-size:.96rem;margin-bottom:.8rem;
  transition:color .35s var(--ease)}
.footer__col a:hover{color:var(--clay)}
.footer__bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  padding-top:2rem;color:var(--muted-dark);font-size:.8rem;letter-spacing:.04em}
.footer__bottom a{color:var(--muted-dark)}
.totop{display:inline-flex;align-items:center;gap:.5em;color:var(--cream)}
.totop iconify-icon{transition:transform .4s var(--ease)}
.totop:hover iconify-icon{transform:translateY(-3px)}

/* ============================== REVEAL ============================== */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity 1s var(--ease),transform 1.1s var(--ease-out);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important}
  .reveal{opacity:1;transform:none}
}

/* ============================== RESPONSIVE ============================== */
@media (max-width:1080px){
  .approach__grid{grid-template-columns:1fr;gap:2.5rem}
  .approach__sticky{position:static}
  .ledger__desc{display:none}
  .ledger__row{grid-template-columns:auto 1fr}
  .svc-cat__grid{grid-template-columns:1fr;gap:2rem}
  .svc-cat__media{position:static}
  .svc-cat__img{aspect-ratio:16/9;max-height:340px}
  .about-lead__grid{grid-template-columns:1fr;gap:2rem}
  .contact__grid{grid-template-columns:1fr;gap:2.5rem}
  .gallery{column-count:2}
}
@media (max-width:900px){
  .nav{display:none}
  .header__cta .btn{display:none}
  .burger{display:block}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__content{grid-column:1;padding:calc(var(--header-h) + 7vh) var(--gutter) 3rem;max-width:none}
  .hero__media{grid-column:1;height:64vh;order:2}
  .hero__scroll{display:none}
  .svc-groups{grid-template-columns:1fr;gap:2.4rem}
  .shead{grid-template-columns:1fr;gap:1.2rem}
  .phero__grid{grid-template-columns:1fr;gap:1.4rem;align-items:start}
  .supply__grid{grid-template-columns:1fr;gap:1.6rem}
  .about-stats{grid-template-columns:1fr;gap:1.6rem;text-align:left}
  .cform__row{grid-template-columns:1fr}
  .work-grid>*{grid-column:1/-1!important}
  .work-grid .wcard__img{aspect-ratio:4/3!important}
  .footer__top{grid-template-columns:1fr;gap:2.4rem}
  .strip__head{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .scard{height:clamp(360px,54vh,540px)}
  .strip__hint{display:none}
  .strip__btn{width:46px;height:46px;font-size:1.05rem}
  .scard--end{width:clamp(200px,60vw,300px)}
}
@media (max-width:560px){
  .hero__meta div{padding-right:1rem;margin-right:1rem}
  .hero__meta dt{font-size:1.25rem}
  .cta__actions{flex-direction:column}
  .gallery{column-count:1}
}
