/* =====================================================================
   Ascent & Co — styles.css
   Editorial restraint · bone + terracotta · 8-px grid
   Sections:
     01 Reset & base
     02 Tokens (custom properties)
     03 Typography
     04 Layout primitives
     05 Top bar + Nav
     06 Mobile menu
     07 Buttons
     08 Footer
     09 Forms
     10 Hero
     11 Services index
     12 Work grid + featured
     13 Stats band
     14 Process timeline
     15 About masthead + values
     16 Case study layout
     17 Reveal animation states
     18 Page chrome (hero band, breadcrumbs)
     19 Reduced-motion overrides
   ===================================================================== */

/* 01 RESET --------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:auto; /* Lenis owns scrolling */
}
body{
  font-family:var(--sans);
  font-size:16px;line-height:1.55;
  color:var(--ink);
  background:var(--bone);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern","liga","calt";
}
img,picture,video,svg{display:block;max-width:100%;}
img{height:auto;}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer;}
input,select,textarea{font:inherit;color:inherit;}
a{color:inherit;text-decoration:none;}
ul,ol{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4,h5,h6,p,figure{margin:0;}

/* selection — premium signal #1 */
::selection{background:var(--terracotta);color:var(--bone);}
::-moz-selection{background:var(--terracotta);color:var(--bone);}

/* focus rings — tinted to brand */
:focus{outline:none;}
:focus-visible{
  outline:2px solid var(--terracotta);
  outline-offset:3px;
  border-radius:2px;
}

/* skip link */
.skip{
  position:absolute;left:-9999px;top:0;
  background:var(--ink);color:var(--bone);
  padding:12px 20px;font-family:var(--mono);font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;z-index:100;
}
.skip:focus{left:8px;top:8px;}

/* 02 TOKENS -------------------------------------------------------- */
:root{
  /* color */
  --bone:#F2ECE0;
  --bone-2:#EAE3D4;
  --bone-3:#E1D8C5;
  --ink:#15110D;
  --ink-2:#2A241D;
  --ink-3:#5C5246;
  --ink-4:#8B8275;
  --terracotta:#B4501F;
  --terracotta-deep:#8A3B14;
  --terracotta-soft:#D6896A;
  --ochre:#C8923A;

  --rule:rgba(21,17,13,.18);
  --rule-soft:rgba(21,17,13,.10);
  --rule-strong:rgba(21,17,13,.40);

  /* type */
  --serif:"Instrument Serif",Georgia,"Times New Roman",serif;
  --sans:"Geist","Helvetica Neue",Helvetica,Arial,sans-serif;
  --mono:"Geist Mono","SFMono-Regular",ui-monospace,Menlo,monospace;

  /* type scale */
  --fs-mono:11px;
  --fs-caption:13px;
  --fs-body:16px;
  --fs-body-l:18px;
  --fs-lede:clamp(18px, 1.4vw, 22px);
  --fs-h4:clamp(22px, 2vw, 28px);
  --fs-h3:clamp(28px, 3vw, 40px);
  --fs-h2:clamp(36px, 5vw, 68px);
  --fs-h1:clamp(56px, 9vw, 148px);

  /* spacing — 8-px grid */
  --s-1:8px;  --s-2:16px; --s-3:24px;
  --s-4:32px; --s-5:40px; --s-6:48px;
  --s-7:64px; --s-8:80px; --s-9:96px;
  --s-10:120px; --s-11:144px; --s-12:192px;

  /* layout */
  --maxw:1440px;
  --maxw-text:72ch;
  --gutter:clamp(20px, 4vw, 56px);

  /* motion */
  --ease:cubic-bezier(.2,.7,0,1);
  --dur-1:200ms;
  --dur-2:400ms;
  --dur-3:700ms;
}

/* 03 TYPOGRAPHY ---------------------------------------------------- */
.serif{font-family:var(--serif);font-weight:400;}
.sans{font-family:var(--sans);}
.mono{
  font-family:var(--mono);
  font-size:var(--fs-mono);
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--ink-3);
  font-weight:400;
}
.italic{font-style:italic;}
.tabular{font-variant-numeric:tabular-nums;}

.h-display{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-h1);line-height:.94;
  letter-spacing:-.025em;
  text-wrap:balance;
}
.h-display em{font-style:italic;color:var(--terracotta);}
.h-2{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-h2);line-height:1.0;
  letter-spacing:-.02em;
  text-wrap:balance;
}
.h-2 em{font-style:italic;color:var(--terracotta);}
.h-3{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-h3);line-height:1.05;
  letter-spacing:-.015em;
}
.h-3 em{font-style:italic;color:var(--terracotta);}
.h-4{
  font-family:var(--serif);font-weight:400;
  font-size:var(--fs-h4);line-height:1.15;
  letter-spacing:-.01em;
}
.lede{
  font-size:var(--fs-lede);
  line-height:1.5;
  color:var(--ink-2);
  max-width:62ch;
  text-wrap:pretty;
}
.body{
  font-size:var(--fs-body-l);
  line-height:1.6;
  color:var(--ink-2);
  max-width:62ch;
  text-wrap:pretty;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);
  font-size:var(--fs-mono);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-3);
}
.eyebrow .dot{
  width:6px;height:6px;border-radius:50%;background:var(--terracotta);
}

/* 04 LAYOUT PRIMITIVES -------------------------------------------- */
.wrap{
  width:100%;max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{
  padding:var(--s-10) 0;
  border-top:1px solid var(--rule);
}
.section--first{border-top:0;}
.section--lg{padding:var(--s-12) 0;}
.section--sm{padding:var(--s-8) 0;}

.section-head{
  display:grid;grid-template-columns:1fr;
  gap:var(--s-3);margin-bottom:var(--s-7);
}
@media(min-width:900px){
  .section-head{grid-template-columns:200px 1fr;gap:var(--s-6);align-items:baseline;}
}
.section-head .idx{
  font-family:var(--mono);font-size:var(--fs-mono);
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);
}
.section-head h2{margin:0;}

hr.rule{border:0;border-top:1px solid var(--rule);margin:0;}

/* 05 TOP BAR + NAV ------------------------------------------------ */
.topbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px var(--gutter);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-3);
  border-bottom:1px solid var(--rule-soft);
}
.topbar .left,.topbar .right{display:flex;gap:var(--s-3);align-items:center;}
.topbar .dot{width:6px;height:6px;border-radius:50%;background:var(--terracotta);}
@media(max-width:680px){
  .topbar .right > *:not(:last-child){display:none;}
}

.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(242,236,224,.86);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--rule-soft);
  transition:border-color var(--dur-2) var(--ease);
}
.nav.is-scrolled{border-bottom-color:var(--rule);}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  max-width:var(--maxw);margin:0 auto;
}
.brand{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--serif);font-size:24px;letter-spacing:-.01em;
  line-height:1;
}
.brand .amp{font-style:italic;color:var(--terracotta);}
.brand .mark{
  width:24px;height:24px;border-radius:50%;
  background:var(--ink);position:relative;
  display:inline-flex;align-items:center;justify-content:center;
  flex:0 0 24px;
}
.brand .mark::after{
  content:"";position:absolute;
  width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;
  border-bottom:6px solid var(--terracotta);
  transform:translateY(-1px);
}
.nav-links{
  display:flex;gap:var(--s-5);align-items:center;
  font-size:14px;
}
.nav-links a{
  position:relative;color:var(--ink-2);
  transition:color var(--dur-1) var(--ease);
  padding:6px 0;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink);}
.nav-links a[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--terracotta);
}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:10px 16px;border:1px solid var(--ink);border-radius:999px;
  color:var(--ink);
  transition:background var(--dur-2) var(--ease),color var(--dur-2) var(--ease);
}
.nav-cta:hover{background:var(--ink);color:var(--bone);}
.nav-burger{
  display:none;width:44px;height:44px;
  align-items:center;justify-content:center;border-radius:999px;
  border:1px solid var(--rule);background:transparent;
}
.nav-burger span{
  display:block;width:18px;height:1.5px;background:var(--ink);
  position:relative;
}
.nav-burger span::before,.nav-burger span::after{
  content:"";position:absolute;left:0;right:0;height:1.5px;background:var(--ink);
}
.nav-burger span::before{top:-6px;}
.nav-burger span::after{top:6px;}
@media(max-width:880px){
  .nav-links,.nav-cta{display:none;}
  .nav-burger{display:inline-flex;}
}

/* 06 MOBILE MENU --------------------------------------------------- */
.menu{
  position:fixed;inset:0;z-index:60;
  background:var(--ink);color:var(--bone);
  padding:var(--s-5) var(--gutter) var(--s-7);
  display:flex;flex-direction:column;gap:var(--s-7);
  transform:translateY(-100%);
  transition:transform var(--dur-3) var(--ease);
  visibility:hidden;
  overflow-y:auto;
}
.menu.is-open{transform:translateY(0);visibility:visible;}
.menu-top{
  display:flex;align-items:center;justify-content:space-between;
}
.menu .brand{color:var(--bone);}
.menu .brand .mark{background:var(--bone);}
.menu .brand .mark::after{border-bottom-color:var(--terracotta);}
.menu-close{
  width:44px;height:44px;border-radius:999px;border:1px solid rgba(242,236,224,.25);
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:14px;color:var(--bone);
}
.menu-list{
  display:flex;flex-direction:column;gap:var(--s-2);
}
.menu-list a{
  font-family:var(--serif);font-size:clamp(40px,11vw,80px);
  line-height:1;letter-spacing:-.02em;color:var(--bone);
  display:flex;justify-content:space-between;align-items:baseline;
  padding:var(--s-2) 0;border-bottom:1px solid rgba(242,236,224,.12);
}
.menu-list a .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:#a39a8b;
  text-transform:uppercase;
}
.menu-list a em{font-style:italic;color:var(--terracotta-soft);}
.menu-foot{
  margin-top:auto;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s-3);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:#a39a8b;
}
.menu-foot a{color:var(--bone);}
body.menu-open{overflow:hidden;}

/* 07 BUTTONS ------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:18px 28px;
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  border-radius:999px;
  transition:transform var(--dur-2) var(--ease),background var(--dur-2) var(--ease),color var(--dur-2) var(--ease);
  position:relative;will-change:transform;
}
.btn--ink{background:var(--ink);color:var(--bone);}
.btn--ink:hover{background:var(--terracotta);}
.btn--bone{background:var(--bone);color:var(--ink);border:1px solid var(--ink);}
.btn--bone:hover{background:var(--ink);color:var(--bone);}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--rule);}
.btn--ghost:hover{border-color:var(--ink);}
.btn .arrow{
  display:inline-block;transition:transform var(--dur-2) var(--ease);
}
.btn:hover .arrow{transform:translate(2px,-2px);}

/* magnetic wrapper — JS positions inner via transform */
.magnetic{display:inline-block;will-change:transform;}

/* link-arrow — used inline */
.link-arrow{
  display:inline-flex;align-items:baseline;gap:10px;
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);
  border-bottom:1px solid var(--rule);
  padding-bottom:6px;
  transition:color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease);
}
.link-arrow .arrow{transition:transform var(--dur-2) var(--ease);}
.link-arrow:hover{color:var(--terracotta);border-color:var(--terracotta);}
.link-arrow:hover .arrow{transform:translate(2px,-2px);}

/* 08 FOOTER -------------------------------------------------------- */
.foot{
  background:var(--ink);color:var(--bone);
  padding:var(--s-9) 0 var(--s-5);
  position:relative;
}
.foot ::selection{background:var(--bone);color:var(--ink);}
.foot a{color:var(--bone);}
.foot-mast{
  display:grid;grid-template-columns:1fr;gap:var(--s-7);
  padding-bottom:var(--s-9);border-bottom:1px solid rgba(242,236,224,.12);
}
.foot-mast .big{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(48px,8vw,120px);line-height:.95;letter-spacing:-.02em;
}
.foot-mast .big em{font-style:italic;color:var(--terracotta-soft);}
.foot-mast .ask{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:#a39a8b;display:flex;align-items:flex-end;gap:8px;
}
.foot-cta{
  display:grid;grid-template-columns:1fr;gap:var(--s-3);
  align-items:end;justify-items:start;
}
@media(min-width:900px){.foot-cta{grid-template-columns:1fr auto;align-items:end;}}
.foot-cta .pre{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#a39a8b;
}
.foot-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5) var(--s-4);
  padding:var(--s-7) 0;
}
@media(min-width:900px){
  .foot-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s-6);}
}
.foot-col h5{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:#a39a8b;font-weight:400;margin:0 0 var(--s-2);
}
.foot-col ul{display:flex;flex-direction:column;gap:6px;}
.foot-col li{font-size:14px;color:var(--bone);}
.foot-col a:hover{color:var(--terracotta-soft);}
.foot-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s-3);
  padding-top:var(--s-4);border-top:1px solid rgba(242,236,224,.12);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:#a39a8b;
}

/* 09 FORMS --------------------------------------------------------- */
.field{display:flex;flex-direction:column;gap:8px;position:relative;}
.field label{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);
}
.field input,.field textarea,.field select{
  width:100%;
  background:transparent;
  border:0;border-bottom:1px solid var(--rule);
  padding:14px 0;
  font-size:18px; /* >=16 prevents iOS zoom */
  font-family:var(--sans);
  color:var(--ink);
  border-radius:0;
  transition:border-color var(--dur-2) var(--ease);
  outline:none;
  -webkit-appearance:none;
}
.field select{
  appearance:none;-webkit-appearance:none;
  background:transparent url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='none' stroke='%23151110' stroke-width='1.4' d='M1 1l5 5 5-5'/></svg>") right 4px center / 12px 8px no-repeat;
  padding-right:24px;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.5;}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-4);}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--ink);
}
.field input:focus-visible,.field textarea:focus-visible,.field select:focus-visible{
  outline:none;border-color:var(--terracotta);
}
.field--hp{position:absolute;left:-9999px;visibility:hidden;}

/* 10 HERO ---------------------------------------------------------- */
.hero{
  padding:var(--s-9) 0 var(--s-9);
  position:relative;
  overflow:hidden;
}
@media(min-width:900px){.hero{padding:var(--s-11) 0 var(--s-10);}}
.hero-eyebrow{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:var(--s-5);}
.hero-eyebrow .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 12px;border:1px solid var(--rule);border-radius:999px;color:var(--ink-2);
}
.hero h1{margin:0;}
.hero-meta{
  display:grid;grid-template-columns:1fr;gap:var(--s-4);
  margin-top:var(--s-7);
  align-items:end;
}
@media(min-width:900px){
  .hero-meta{grid-template-columns:1fr 1fr 1fr;gap:var(--s-5);}
}
.hero-meta .col{
  border-top:1px solid var(--rule);padding-top:var(--s-3);
}
.hero-meta .col h5{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);font-weight:400;margin:0 0 var(--s-2);
}
.hero-meta .col p{font-size:15px;line-height:1.55;color:var(--ink-2);max-width:42ch;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:var(--s-5);}
.hero-scroll{
  display:none;
  position:absolute;left:var(--gutter);bottom:var(--s-5);
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);transform-origin:left bottom;
}
@media(min-width:900px){.hero-scroll{display:block;}}

/* split-text rise: the wrapping span used by reveal.js.
   IMPORTANT: hide the inner only when JS is active. If JS fails / is slow,
   the headline shows in its natural state instead of a blank page. */
.rise-mask{display:inline-block;overflow:hidden;vertical-align:bottom;line-height:inherit;}
.rise-mask > .rise-inner{display:inline-block;will-change:transform;}
html.js .rise-mask > .rise-inner{transform:translateY(110%);}
html.js .is-revealed .rise-mask > .rise-inner{transform:translateY(0);transition:transform var(--dur-3) var(--ease);}

/* 11 SERVICES INDEX ----------------------------------------------- */
.svc-index{display:flex;flex-direction:column;}
.svc-row{
  display:grid;
  grid-template-columns:60px 1fr auto;
  gap:var(--s-3);
  align-items:baseline;
  padding:var(--s-4) 0;
  border-top:1px solid var(--rule);
  position:relative;
  cursor:default;
  transition:background var(--dur-2) var(--ease);
}
.svc-row:last-child{border-bottom:1px solid var(--rule);}
.svc-row:hover{background:transparent;}
.svc-row .pn{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-3);}
.svc-row .name{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px,5vw,64px);line-height:1.05;letter-spacing:-.02em;
  margin:0;color:var(--ink);
  transition:transform var(--dur-2) var(--ease),color var(--dur-2) var(--ease);
}
.svc-row .name em{font-style:italic;color:var(--terracotta);}
.svc-row .desc{
  display:none;
  max-width:36ch;font-size:14px;color:var(--ink-2);line-height:1.55;
}
@media(min-width:900px){.svc-row{grid-template-columns:80px 1.2fr 1fr 200px;} .svc-row .desc{display:block;}}
.svc-row .meta{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);
  text-align:right;display:flex;align-items:center;gap:10px;justify-content:flex-end;
}
.svc-row .meta .arrow{transition:transform var(--dur-2) var(--ease);}
.svc-row:hover .name{color:var(--terracotta);}
.svc-row:hover .meta .arrow{transform:translate(3px,-3px);}

/* services page detailed — same row reused with extra body */
.svc-detail{
  padding:var(--s-7) 0;border-top:1px solid var(--rule);
}
.svc-detail > .wrap{
  display:grid;grid-template-columns:1fr;gap:var(--s-3);
}
@media(min-width:900px){.svc-detail > .wrap{grid-template-columns:80px 240px 1fr 1fr;gap:var(--s-5);align-items:start;}}
.svc-detail .pn{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-3);text-transform:uppercase;}
.svc-detail .label{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta-deep);
  margin-bottom:var(--s-2);
}
.svc-detail h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px,4vw,56px);line-height:1.0;letter-spacing:-.02em;margin:0;
}
.svc-detail h3 em{font-style:italic;color:var(--terracotta);}
.svc-detail .copy p{font-size:16px;line-height:1.6;color:var(--ink-2);max-width:42ch;margin:0 0 var(--s-2);}
.svc-detail .deliv h4{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);font-weight:400;margin:0 0 var(--s-2);
}
.svc-detail .deliv ul{display:flex;flex-direction:column;}
.svc-detail .deliv li{
  display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-2);
  padding:12px 0;border-top:1px solid var(--rule-soft);
  font-size:15px;color:var(--ink-2);
}
.svc-detail .deliv li:first-child{border-top:0;}
.svc-detail .deliv li .n{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.08em;}

/* 12 WORK GRID + FEATURED ----------------------------------------- */
.work-grid{
  display:grid;grid-template-columns:1fr;gap:var(--s-7) var(--s-4);
}
@media(min-width:700px){.work-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:1100px){.work-grid{grid-template-columns:1fr 1fr 1fr;}}
.work-card{
  display:flex;flex-direction:column;gap:var(--s-2);
  text-decoration:none;color:inherit;
  position:relative;
}
.work-card .thumb{
  aspect-ratio:4 / 5;
  background:var(--bone-2);
  overflow:hidden;
  position:relative;
}
.work-card .thumb img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.05);
  transition:transform 1200ms var(--ease);
}
.work-card:hover .thumb img{transform:scale(1.0);}
.work-card .meta{
  display:flex;justify-content:space-between;align-items:baseline;gap:var(--s-2);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);
  padding-top:6px;
}
.work-card h3{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(28px,3vw,40px);line-height:1.05;letter-spacing:-.015em;
  margin:0;
}
.work-card h3 em{font-style:italic;color:var(--terracotta);}
.work-card .tags{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;
}
.work-card .tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-3);
  padding:4px 10px;border:1px solid var(--rule);border-radius:999px;
}

/* mask reveal for images — JS-gated so images show with no JS */
.mask-reveal{position:relative;overflow:hidden;}
html.js .mask-reveal::after{
  content:"";position:absolute;inset:0;background:var(--bone);
  transform:translateY(0);transform-origin:top;
  transition:transform 900ms var(--ease);
  pointer-events:none;
}
html.js .is-revealed.mask-reveal::after,
html.js .is-revealed .mask-reveal::after{transform:translateY(101%);}

/* featured row: editorial 2-up */
.feat{
  display:grid;grid-template-columns:1fr;gap:var(--s-7);
  padding:var(--s-5) 0;
}
@media(min-width:1000px){.feat{grid-template-columns:7fr 5fr;gap:var(--s-9);align-items:end;}}
.feat .thumb{aspect-ratio:5 / 4;}
.feat-r{display:grid;grid-template-columns:1fr;gap:var(--s-7);align-items:end;}
@media(min-width:1000px){.feat-r{grid-template-columns:5fr 7fr;}}
.feat .info h3{font-size:clamp(36px,5vw,68px);line-height:1.0;letter-spacing:-.02em;}
.feat .info .result{
  font-family:var(--serif);font-style:italic;color:var(--terracotta);
  font-size:clamp(28px,3vw,40px);line-height:1.1;margin-top:var(--s-3);
}
.feat .info p{margin-top:var(--s-2);max-width:46ch;color:var(--ink-2);font-size:16px;line-height:1.55;}

/* portfolio filter chips */
.filter{
  display:flex;flex-wrap:wrap;gap:8px;
  padding:var(--s-3) 0 var(--s-7);
  border-bottom:1px solid var(--rule);
  margin-bottom:var(--s-7);
}
.chip{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:8px 14px;border:1px solid var(--rule);border-radius:999px;
  color:var(--ink-2);background:transparent;
  transition:background var(--dur-2) var(--ease),color var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease);
}
.chip:hover{border-color:var(--ink);}
.chip[aria-pressed="true"]{background:var(--ink);color:var(--bone);border-color:var(--ink);}
.chip .count{margin-left:8px;color:var(--ink-3);}
.chip[aria-pressed="true"] .count{color:#a39a8b;}

/* hidden state when filtered out */
.work-card[hidden]{display:none;}

/* 13 STATS BAND --------------------------------------------------- */
.stats{
  background:var(--ink);color:var(--bone);
  padding:var(--s-9) 0;
}
.stats ::selection{background:var(--bone);color:var(--ink);}
.stats-grid{
  display:grid;grid-template-columns:1fr;gap:var(--s-5);
}
@media(min-width:760px){.stats-grid{grid-template-columns:repeat(3,1fr);gap:var(--s-4);}}
.stat{
  display:flex;flex-direction:column;gap:var(--s-2);
  padding-top:var(--s-3);
  border-top:1px solid rgba(242,236,224,.18);
}
.stat .num{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(72px,12vw,180px);line-height:.92;letter-spacing:-.025em;
  font-variant-numeric:tabular-nums;
  color:var(--bone);
}
.stat .num em{font-style:italic;color:var(--terracotta-soft);}
.stat .num .suffix{font-style:italic;color:var(--terracotta-soft);}
.stat .label{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:#a39a8b;
}

/* 14 PROCESS TIMELINE --------------------------------------------- */
.phase{
  display:grid;grid-template-columns:1fr;gap:var(--s-3);
  padding:var(--s-7) 0;
  border-top:1px solid var(--rule);
  position:relative;
}
@media(min-width:900px){
  .phase{grid-template-columns:80px 240px 1fr 1fr;gap:var(--s-5);align-items:start;}
}
.phase .pn{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-3);text-transform:uppercase;}
.phase h3{font-family:var(--serif);font-weight:400;font-size:clamp(36px,4vw,56px);line-height:1.0;letter-spacing:-.02em;margin:0;}
.phase h3 em{font-style:italic;color:var(--terracotta);}
.phase .copy p{font-size:16px;line-height:1.6;color:var(--ink-2);max-width:42ch;margin:0 0 var(--s-2);}
.phase .deliv ul{display:flex;flex-direction:column;}
.phase .deliv li{
  padding:10px 0;border-top:1px solid var(--rule-soft);
  display:flex;justify-content:space-between;font-size:14px;color:var(--ink-2);
}
.phase .deliv li:first-child{border-top:0;}
.phase .deliv li .n{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.08em;}
.phase .week{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta-deep);
  margin-bottom:var(--s-2);
}

/* 15 ABOUT ------------------------------------------------------- */
.manifesto{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(32px,4.4vw,60px);line-height:1.15;letter-spacing:-.015em;
  max-width:24ch;
  text-wrap:balance;
}
.manifesto em{font-style:italic;color:var(--terracotta);}
.manifesto .drop{
  font-size:1.5em;float:left;line-height:.85;padding:6px 12px 0 0;font-style:italic;color:var(--terracotta);
}

.team{display:grid;grid-template-columns:1fr;gap:var(--s-7) var(--s-4);}
@media(min-width:760px){.team{grid-template-columns:1fr 1fr;}}
@media(min-width:1100px){.team{grid-template-columns:repeat(4,1fr);}}
.member .portrait{
  aspect-ratio:4 / 5;
  background:var(--bone-2);
  overflow:hidden;margin-bottom:var(--s-2);
  filter:saturate(.85);
}
.member .portrait img{width:100%;height:100%;object-fit:cover;filter:contrast(1.02) brightness(.97);}
.member h4{font-family:var(--serif);font-weight:400;font-size:24px;letter-spacing:-.01em;margin:0;}
.member .role{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-top:4px;}

.values{display:grid;grid-template-columns:1fr;gap:0;}
.values .v{
  display:grid;grid-template-columns:60px 1fr;gap:var(--s-3);
  padding:var(--s-5) 0;border-top:1px solid var(--rule);
}
@media(min-width:900px){.values .v{grid-template-columns:60px 320px 1fr;gap:var(--s-5);align-items:baseline;}}
.values .v:last-child{border-bottom:1px solid var(--rule);}
.values .v .n{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--ink-3);}
.values .v h4{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3vw,40px);letter-spacing:-.015em;margin:0;}
.values .v h4 em{font-style:italic;color:var(--terracotta);}
.values .v p{font-size:16px;color:var(--ink-2);line-height:1.55;max-width:48ch;margin:0;}

/* 16 CASE STUDY LAYOUT -------------------------------------------- */
.cs-hero{padding:var(--s-9) 0 var(--s-7);}
.cs-meta{
  display:flex;flex-wrap:wrap;gap:var(--s-3);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);
  margin-bottom:var(--s-4);
}
.cs-title{font-family:var(--serif);font-weight:400;font-size:var(--fs-h1);line-height:.94;letter-spacing:-.025em;margin:0;text-wrap:balance;}
.cs-title em{font-style:italic;color:var(--terracotta);}
.cs-lede{margin-top:var(--s-5);font-size:var(--fs-lede);line-height:1.5;color:var(--ink-2);max-width:60ch;}

.cs-cover{
  aspect-ratio:16 / 9;background:var(--bone-2);
  margin:var(--s-7) 0;
}
.cs-cover img{width:100%;height:100%;object-fit:cover;}

.cs-grid{
  display:grid;grid-template-columns:1fr;gap:var(--s-5);
  padding:var(--s-7) 0;border-top:1px solid var(--rule);
}
@media(min-width:900px){.cs-grid{grid-template-columns:200px 1fr;gap:var(--s-7);align-items:start;}}
.cs-grid h3{font-family:var(--serif);font-weight:400;font-size:clamp(32px,3.2vw,44px);letter-spacing:-.015em;margin:0;}
.cs-grid h3 em{font-style:italic;color:var(--terracotta);}
.cs-grid .label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.cs-grid p{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:62ch;margin:0 0 var(--s-2);}

.outcomes{
  display:grid;grid-template-columns:1fr;gap:var(--s-3);
  padding:var(--s-7) 0;border-top:1px solid var(--rule);
}
@media(min-width:760px){.outcomes{grid-template-columns:repeat(3,1fr);}}
.outcome{
  border-top:1px solid var(--rule);padding-top:var(--s-3);
}
@media(min-width:760px){.outcome{border-top:0;border-left:1px solid var(--rule);padding:0 0 0 var(--s-3);}}
.outcome .n{font-family:var(--serif);font-weight:400;font-size:clamp(48px,7vw,96px);line-height:.95;letter-spacing:-.02em;}
.outcome .n em{font-style:italic;color:var(--terracotta);}
.outcome .lab{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-top:var(--s-2);}

.cs-nav{
  display:grid;grid-template-columns:1fr;gap:var(--s-3);
  padding:var(--s-7) 0;border-top:1px solid var(--rule);
}
@media(min-width:760px){.cs-nav{grid-template-columns:1fr 1fr;}}
.cs-nav a{
  display:flex;flex-direction:column;gap:var(--s-1);
  padding:var(--s-3) 0;
}
.cs-nav .label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.cs-nav h4{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3vw,40px);letter-spacing:-.015em;margin:0;}
.cs-nav h4 em{font-style:italic;color:var(--terracotta);}
.cs-nav a.next{text-align:right;align-items:flex-end;}

/* 17 REVEAL STATES (set initially, lifted by .is-revealed) -------- */
.reveal{
  /* image mask handled via .mask-reveal class */
}
html.js .fade-up{opacity:0;transform:translateY(24px);transition:opacity var(--dur-3) var(--ease),transform var(--dur-3) var(--ease);}
html.js .is-revealed.fade-up,html.js .is-revealed .fade-up{opacity:1;transform:translateY(0);}

/* prevent layout shift while web fonts swap */
.fonts-pending .h-display,.fonts-pending .h-2,.fonts-pending .cs-title{visibility:hidden;}

/* 18 PAGE CHROME (page hero band, breadcrumb) --------------------- */
.page-hero{
  padding:var(--s-9) 0 var(--s-7);
  border-bottom:1px solid var(--rule);
}
.page-hero .crumb{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);
  margin-bottom:var(--s-5);display:flex;gap:10px;flex-wrap:wrap;
}
.page-hero .crumb a{color:var(--ink-3);}
.page-hero .crumb a:hover{color:var(--terracotta);}
.page-hero .crumb .sep{color:var(--ink-4);}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:var(--fs-h1);line-height:.94;letter-spacing:-.025em;margin:0;text-wrap:balance;}
.page-hero h1 em{font-style:italic;color:var(--terracotta);}
.page-hero .desc{margin-top:var(--s-5);font-size:var(--fs-lede);color:var(--ink-2);max-width:62ch;line-height:1.5;}

/* large CTA band */
.cta-band{
  padding:var(--s-10) 0;
  display:grid;grid-template-columns:1fr;gap:var(--s-5);
  align-items:end;
}
@media(min-width:900px){.cta-band{grid-template-columns:1fr auto;}}
.cta-band h2{font-family:var(--serif);font-weight:400;font-size:clamp(48px,7vw,120px);line-height:.95;letter-spacing:-.025em;margin:0;text-wrap:balance;}
.cta-band h2 em{font-style:italic;color:var(--terracotta);}

/* 19 REDUCED MOTION ----------------------------------------------- */
@media(prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  .rise-mask > .rise-inner{transform:translateY(0) !important;}
  .mask-reveal::after{display:none;}
  .fade-up{opacity:1 !important;transform:none !important;}
}
