@import url('https://fonts.googleapis.com/css2?family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Outfit:wght@200;300;400;500&family=DM+Mono:wght@300;400&display=swap');

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --black:   #080808;
  --white:   #f9f8f5;
  --grey:    #a8a6a0;
  --grey-lt: #e8e7e3;
  --grey-dk: #3a3935;
  --serif:   'Libre Baskerville', Georgia, serif;
  --sans:    'Outfit', system-ui, sans-serif;
  --mono:    'DM Mono', monospace;
  --nav-h:   68px;
  --gutter:  clamp(24px, 5vw, 72px);
  --max:     1380px;
  --ease:    cubic-bezier(.16,1,.3,1);
  --ecirc:   cubic-bezier(.85,0,.15,1);
}

/* ─── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--white);color:var(--black);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{border:none;background:none;cursor:pointer;font:inherit;color:inherit}

/* ─── LAYOUT ─────────────────────────────────────────────── */
.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}

/* ─── PAGE CURTAIN ───────────────────────────────────────── */
.curtain{
  position:fixed;inset:0;background:var(--black);
  z-index:9000;transform:scaleY(0);transform-origin:bottom;
  pointer-events:none;will-change:transform;
}
.curtain.in{transform:scaleY(1);transition:transform .55s var(--ecirc);pointer-events:all}
.curtain.out{transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ecirc) .05s}

/* ─── NAVIGATION — always visible ───────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);z-index:1000;
  transition:background .3s,border-color .3s,box-shadow .3s;
}
.nav.on-hero{
  /* on hero: transparent, white elements */
  background:transparent;
}
.nav.on-hero.scrolled{
  background:rgba(8,8,8,.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav.off-hero{
  /* on other pages: white frosted glass, always visible */
  background:rgba(249,248,245,.95);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(8,8,8,.07);
}
.nav.off-hero.scrolled{
  box-shadow:0 2px 20px rgba(8,8,8,.06);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:100%}

/* Logo */
.nav__logo{display:flex;align-items:center;flex-shrink:0}
.nav__logo img,
.nav__logo .custom-logo{height:40px;width:auto;transition:filter .3s;display:block}
/* Logo colour modes — set in Customizer → Logo & branding */
/* auto (default): CSS filter inverts to white on dark backgrounds */
.nav.on-hero  .logo-mode-auto { filter:brightness(0) invert(1) }
.nav.off-hero .logo-mode-auto { filter:none }
/* white: always white (SVG already white) */
.logo-mode-white { filter:brightness(0) invert(1) }
/* black: always natural */
.logo-mode-black { filter:none }

/* Links */
.nav__links{display:flex;align-items:center;gap:28px}
.nav__links a{
  font-family:var(--sans);font-size:11px;font-weight:400;
  letter-spacing:.13em;text-transform:uppercase;
  position:relative;transition:color .2s;
}
.nav__links a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:1px;background:currentColor;
  transition:width .25s var(--ease);
}
.nav__links a:hover::after{width:100%}
.nav.on-hero .nav__links a{color:rgba(255,255,255,.5)}
.nav.on-hero .nav__links a:hover{color:#fff}
.nav.off-hero .nav__links a{color:var(--grey-dk)}
.nav.off-hero .nav__links a:hover{color:var(--black)}

/* CTA */
.nav__cta{
  font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:10px 22px;border-radius:100px;
  transition:background .2s,color .2s,transform .2s var(--ease);
}
.nav__cta:hover{transform:translateY(-1px)}
.nav.on-hero .nav__cta{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.2)}
.nav.on-hero .nav__cta:hover{background:rgba(255,255,255,.22);color:#fff}
.nav.off-hero .nav__cta{background:var(--black);color:#fff}
.nav.off-hero .nav__cta:hover{background:var(--grey-dk);color:#fff}

/* Burger */
.nav__burger{display:none;flex-direction:column;gap:5px;width:26px;padding:3px 0}
.nav__burger span{display:block;height:1px;background:currentColor;border-radius:1px;transition:transform .35s var(--ease),opacity .2s,width .3s}
.nav__burger span:nth-child(2){width:18px}
.nav__burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0;width:0}
.nav__burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nav.on-hero .nav__burger{color:#fff}
.nav.off-hero .nav__burger{color:var(--black)}

/* Mobile overlay */
.nav__overlay{
  position:fixed;inset:0;background:var(--black);
  z-index:998;display:flex;flex-direction:column;
  justify-content:flex-end;padding:var(--gutter);padding-bottom:calc(var(--gutter)*1.5);
  opacity:0;pointer-events:none;transition:opacity .35s var(--ease);
}
.nav__overlay.open{opacity:1;pointer-events:all}
.nav__overlay a{
  font-family:var(--serif);font-size:clamp(2.2rem,7vw,4.5rem);
  font-weight:400;color:rgba(255,255,255,.15);
  display:block;line-height:1.2;
  transform:translateY(24px);opacity:0;
  transition:color .2s,transform .5s var(--ease),opacity .5s var(--ease);
}
.nav__overlay.open a{transform:translateY(0);opacity:1}
.nav__overlay.open a:nth-child(1){transition-delay:.06s}
.nav__overlay.open a:nth-child(2){transition-delay:.12s}
.nav__overlay.open a:nth-child(3){transition-delay:.18s}
.nav__overlay.open a:nth-child(4){transition-delay:.24s}
.nav__overlay a:hover{color:rgba(255,255,255,.8)}
.nav__overlay-cta{
  display:block;margin-top:40px;
  font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.28);
  transform:translateY(16px);opacity:0;
  transition:color .2s,transform .5s var(--ease) .28s,opacity .5s var(--ease) .28s;
}
.nav__overlay.open .nav__overlay-cta{transform:translateY(0);opacity:1}
.nav__overlay-cta:hover{color:rgba(255,255,255,.75)}

@media(max-width:768px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
}

/* ─── HERO ────────────────────────────────────────────────── */
.hero{
  position:relative;height:100svh;min-height:620px;
  background:var(--black);overflow:hidden;
  display:flex;align-items:flex-end;
}
.hero__photo{position:absolute;inset:0;overflow:hidden}
.hero__photo img{
  width:100%;height:100%;object-fit:cover;
  object-position:center top;
  filter:grayscale(1);
  opacity:.25;
  transform:scale(1.06);
  transition:transform 1.6s var(--ease);
  will-change:transform;
}
.hero__photo-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to top,rgba(8,8,8,.9) 0%,rgba(8,8,8,.35) 50%,rgba(8,8,8,.15) 100%),
    linear-gradient(to right,rgba(8,8,8,.3) 0%,transparent 60%);
}
.hero__content{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,7vh,88px)}
.hero__eyebrow{
  display:flex;align-items:center;gap:14px;margin-bottom:24px;
  opacity:0;transform:translateY(10px);
  transition:opacity .8s .3s,transform .8s var(--ease) .3s;
}
.hero__eyebrow-line{
  width:28px;height:1px;background:rgba(255,255,255,.28);flex-shrink:0;
}
.hero__eyebrow-text{
  font-family:var(--mono);font-size:10px;font-weight:300;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.38);
}
.hero__name{
  font-family:var(--serif);
  font-size:clamp(3.2rem,8.5vw,9rem);
  font-weight:400;line-height:1.0;letter-spacing:-.04em;
  color:#fff;
  padding-bottom:.12em; /* prevent descender clipping */
}
.hero__name-inner{display:block;overflow:visible} /* visible = no clipping */
.hero__name-inner span{
  display:block;
  transform:translateY(112%);
  transition:transform 1s var(--ease);
}
.hero__name-inner:nth-child(1) span{transition-delay:.08s}
.hero__name-inner:nth-child(2) span{transition-delay:.18s;font-style:italic;color:rgba(255,255,255,.45)}
.hero__bottom{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:40px;margin-top:36px;flex-wrap:wrap;
}
.hero__desc{
  font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.7;
  color:rgba(255,255,255,.45);max-width:360px;
  opacity:0;transform:translateY(14px);
  transition:opacity .8s .55s,transform .8s var(--ease) .55s;
}
.hero__actions{
  display:flex;align-items:center;gap:20px;flex-shrink:0;
  opacity:0;transform:translateY(14px);
  transition:opacity .8s .7s,transform .8s var(--ease) .7s;
}
.hero__scroll{
  position:absolute;bottom:28px;right:var(--gutter);
  z-index:2;display:flex;align-items:center;gap:10px;
  opacity:0;transition:opacity .6s 1.4s;
}
.hero__scroll-line{
  width:36px;height:1px;background:rgba(255,255,255,.2);
  transform-origin:left;
  animation:scrollPulse 2.2s var(--ease) 1.6s infinite;
}
@keyframes scrollPulse{
  0%{transform:scaleX(0);transform-origin:left}
  45%{transform:scaleX(1);transform-origin:left}
  55%{transform:scaleX(1);transform-origin:right}
  100%{transform:scaleX(0);transform-origin:right}
}
.hero__scroll-label{
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.2);
}

/* Loaded */
.hero.loaded .hero__photo img          {transform:scale(1)}
.hero.loaded .hero__eyebrow            {opacity:1;transform:translateY(0)}
.hero.loaded .hero__name-inner span    {transform:translateY(0)}
.hero.loaded .hero__desc               {opacity:1;transform:translateY(0)}
.hero.loaded .hero__actions            {opacity:1;transform:translateY(0)}
.hero.loaded .hero__scroll             {opacity:1}

/* ─── BUTTONS ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;
  border-radius:100px;padding:13px 28px;
  transition:transform .22s var(--ease),background .2s,color .2s,border-color .2s;
}
.btn:hover{transform:translateY(-2px)}
.btn svg{flex-shrink:0;transition:transform .22s var(--ease)}
.btn:hover svg{transform:translate(3px,-3px)}
.btn--white{background:#fff;color:var(--black)}
.btn--white:hover{background:var(--grey-lt);color:var(--black)}
.btn--outline-white{border:1px solid rgba(255,255,255,.28);color:rgba(255,255,255,.6)}
.btn--outline-white:hover{border-color:rgba(255,255,255,.65);color:#fff}
.btn--black{background:var(--black);color:#fff}
.btn--black:hover{background:var(--grey-dk);color:#fff}
.btn--outline{border:1px solid rgba(8,8,8,.18);color:var(--grey-dk)}
.btn--outline:hover{border-color:var(--black);color:var(--black)}

/* ─── SECTION HEADER ─────────────────────────────────────── */
.section-header{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:64px 0 36px;border-top:1px solid rgba(8,8,8,.07);
}
.section-header__title{
  font-family:var(--serif);font-size:clamp(1.8rem,3vw,3rem);
  font-weight:400;letter-spacing:-.03em;color:var(--black);
}
.section-header__label{
  font-family:var(--mono);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--grey);
}

/* ─── CLIENTS STRIP ──────────────────────────────────────── */
.clients{
  border-bottom:1px solid rgba(8,8,8,.07);
  padding:24px 0;overflow:hidden;
}
.clients .wrap{display:flex;align-items:center;gap:48px;flex-wrap:wrap}
.clients__label{
  font-family:var(--mono);font-size:9px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--grey);flex-shrink:0;
}
.clients__logos{display:flex;align-items:center;gap:36px;flex-wrap:wrap}
.clients__logos img{
  height:65px;width:auto;
  filter:grayscale(1) opacity(.26);
  transition:filter .3s;
}
.clients__logos img:hover{filter:grayscale(1) opacity(.55)}

/* ─── PORTFOLIO GRID ─────────────────────────────────────── */
.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px;
}
.grid__item{position:relative;overflow:hidden;background:var(--grey-lt)}
@media(max-width:720px){
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .grid{grid-template-columns:1fr;gap:2px}
}
/* 1:1 square on all cells */
.grid__inner{
  position:relative;
  aspect-ratio:1/1;
  width:100%;
  overflow:hidden;display:block;
}
.grid__img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1);
  transition:transform .65s var(--ease),filter .4s;
  will-change:transform;
}
.grid__item:hover .grid__img{transform:scale(1.05);filter:grayscale(.1)}
.grid__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,8,8,.75) 0%,rgba(8,8,8,.06) 55%,transparent 100%);
  opacity:0;transition:opacity .3s;
  display:flex;flex-direction:column;justify-content:flex-end;padding:26px;
}
.grid__item:hover .grid__overlay{opacity:1}
.grid__num{
  position:absolute;top:18px;left:20px;
  font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.35);
  opacity:0;transition:opacity .3s;
}
.grid__item:hover .grid__num{opacity:1}
.grid__title{
  font-family:var(--serif);font-size:17px;font-weight:400;
  color:#fff;line-height:1.2;
  transform:translateY(6px);transition:transform .3s var(--ease);
}
.grid__item:hover .grid__title{transform:translateY(0)}
.grid__cat{
  font-family:var(--mono);font-size:10px;
  letter-spacing:.13em;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin-top:4px;
  transform:translateY(6px);transition:transform .3s var(--ease) .04s;
}
.grid__item:hover .grid__cat{transform:translateY(0)}

/* ─── CASE STUDIES LIST ──────────────────────────────────── */
.posts-list{padding:0 0 80px}
.post-card{
  display:grid;grid-template-columns:200px 1fr auto;
  align-items:start;gap:32px;
  padding:32px 0;
  border-bottom:1px solid rgba(8,8,8,.07);
  transition:background .2s;
}
.post-card:first-child{border-top:1px solid rgba(8,8,8,.07)}
.post-card__thumb{
  aspect-ratio:3/2;overflow:hidden;background:var(--grey-lt);
  flex-shrink:0;
}
.post-card__thumb img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1);transition:filter .4s,transform .5s var(--ease);
}
.post-card:hover .post-card__thumb img{filter:grayscale(.2);transform:scale(1.04)}
.post-card__body{min-width:0}
.post-card__label{
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--grey);margin-bottom:8px;
}
.post-card__title{
  font-family:var(--serif);font-size:clamp(1.1rem,2vw,1.5rem);
  font-weight:400;letter-spacing:-.02em;color:var(--black);
  line-height:1.25;margin-bottom:10px;
}
.post-card__excerpt{
  font-family:var(--sans);font-size:14px;font-weight:300;
  line-height:1.7;color:var(--grey);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.post-card__arrow{
  font-family:var(--mono);font-size:18px;color:var(--grey-lt);
  flex-shrink:0;align-self:center;
  transition:color .2s,transform .2s var(--ease);
}
.post-card:hover .post-card__arrow{color:var(--black);transform:translate(4px,-4px)}
@media(max-width:640px){
  .post-card{grid-template-columns:1fr;gap:16px}
  .post-card__arrow{display:none}
  .post-card__thumb{max-width:100%}
}

/* ─── HOMEPAGE CASE STUDIES PREVIEW ─────────────────────── */
.cs-preview{padding-bottom:80px}
.cs-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:3px;
  margin-bottom:40px;
}
@media(max-width:760px){.cs-cards{grid-template-columns:1fr}}
.cs-card{
  background:var(--grey-lt);padding:32px 28px;
  transition:background .25s;display:block;
}
.cs-card:hover{background:var(--grey)}
.cs-card__label{
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--grey-dk);margin-bottom:12px;
  transition:color .2s;
}
.cs-card:hover .cs-card__label{color:var(--black)}
.cs-card__title{
  font-family:var(--serif);font-size:clamp(1rem,1.8vw,1.3rem);
  font-weight:400;letter-spacing:-.02em;color:var(--black);line-height:1.3;
}
.cs-card__thumb{
  width:100%;aspect-ratio:16/9;overflow:hidden;
  margin-bottom:20px;background:var(--grey);
}
.cs-card__thumb img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1);transition:filter .4s;
}
.cs-card:hover .cs-card__thumb img{filter:grayscale(.3)}

/* ─── ABOUT / BIO STRIP ─────────────────────────────────── */
.bio-strip{
  background:var(--black);padding:88px 0;
  border-top:none;
}
.bio-strip .wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.bio-strip__text .section-header__title{color:#fff}
.bio-strip__body{
  font-family:var(--sans);font-size:15px;font-weight:300;
  line-height:1.75;color:rgba(255,255,255,.42);
  margin-top:18px;max-width:420px;
}
.bio-strip__links{
  display:flex;align-items:center;gap:20px;margin-top:32px;flex-wrap:wrap;
}
.bio-strip__link{
  font-family:var(--mono);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.32);
  display:inline-flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.1);
  padding-bottom:2px;transition:color .2s,border-color .2s;
}
.bio-strip__link:hover{color:rgba(255,255,255,.75);border-color:rgba(255,255,255,.35)}
.bio-strip__stats{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
}
.stat{background:rgba(255,255,255,.04);padding:36px 28px}
.stat__num{
  font-family:var(--serif);font-size:3.6rem;font-weight:400;
  color:#fff;line-height:1;letter-spacing:-.04em;
}
.stat__label{
  font-family:var(--mono);font-size:9px;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(255,255,255,.22);margin-top:8px;
  line-height:1.7;
}
@media(max-width:768px){
  .bio-strip .wrap{grid-template-columns:1fr}
  .bio-strip__stats{grid-template-columns:1fr 1fr}
}

/* ─── FILTER BAR ─────────────────────────────────────────── */
.filter-bar{
  position:sticky;top:var(--nav-h);z-index:100;
  background:rgba(249,248,245,.95);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(8,8,8,.06);
  padding:13px 0;transition:box-shadow .3s;
}
.filter-bar.elevated{box-shadow:0 4px 24px rgba(8,8,8,.06)}
.filter-bar .wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.chip{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--grey-dk);border:1px solid rgba(8,8,8,.12);padding:7px 17px;
  border-radius:100px;transition:all .18s var(--ease);
}
.chip:hover{border-color:rgba(8,8,8,.3);color:var(--black)}
.chip.active{background:var(--black);border-color:var(--black);color:#fff}
.chip-sep{width:1px;height:15px;background:rgba(8,8,8,.08);margin:0 4px;flex-shrink:0}

/* ─── PAGE HERO (interior pages) ────────────────────────── */
.page-hero{
  padding-top:calc(var(--nav-h) + 72px);
  padding-bottom:48px;
}
.page-hero__eyebrow{
  font-family:var(--mono);font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--grey);margin-bottom:14px;
}
.page-hero__title{
  font-family:var(--serif);
  font-size:clamp(2.6rem,6vw,5.5rem);
  font-weight:400;letter-spacing:-.04em;line-height:.95;
}

/* ─── SINGLE WORK ────────────────────────────────────────── */
/* Work hero — full-screen image or video */
.work-hero{border-bottom:1px solid rgba(8,8,8,.07)}

/* Variant: no media — compact */
.work-hero--compact{padding-top:calc(var(--nav-h) + 96px);padding-bottom:56px}

/* Variant: full-screen image */
.work-hero--image{
  position:relative;height:75vh;min-height:480px;
  display:flex;align-items:flex-end;
  padding-bottom:0;background:var(--black);overflow:hidden;
}
.work-hero__bg{position:absolute;inset:0;overflow:hidden}
.work-hero__bg img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(.2);
  transform:scale(1.04);
  transition:transform 1.4s var(--ease);
}
.work-hero--image.loaded .work-hero__bg img{transform:scale(1)}
.work-hero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,8,8,.75) 0%,rgba(8,8,8,.1) 55%,transparent 100%);
}
.work-hero--image .work-hero__content{
  position:relative;z-index:2;width:100%;
  padding-bottom:48px;
}
.work-hero--image .work-meta .work-back,
.work-hero--image .work-meta .work-tag{color:rgba(255,255,255,.5)}
.work-hero--image .work-meta .work-back:hover{color:#fff}
.work-hero--image .work-title{color:#fff}

/* Variant: video embed */
.work-hero--video{padding-top:calc(var(--nav-h)+40px)}
.work-hero__video-wrap{
  position:relative;width:100%;padding-bottom:56.25%;
  height:0;overflow:hidden;margin-top:32px;background:var(--black);
}
.work-hero__video-wrap iframe{
  position:absolute;top:0;left:0;width:100%;height:100%;border:none;
}
.work-meta{display:flex;align-items:center;gap:18px;margin-bottom:18px;flex-wrap:wrap}
.work-back{
  font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--grey);display:flex;align-items:center;gap:7px;transition:color .2s;
}
.work-back:hover{color:var(--black)}
.work-tag{font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--grey)}
.work-title{
  font-family:var(--serif);font-size:clamp(2rem,4.5vw,4.5rem);
  font-weight:400;letter-spacing:-.04em;line-height:1.05;
  overflow:visible; /* prevent descender clipping */
  padding-bottom:.08em;
}
.work-body{padding:64px 0}
.work-body .wrap{display:grid;grid-template-columns:260px 1fr;gap:72px;align-items:start}
.work-sidebar{position:sticky;top:calc(var(--nav-h)+32px)}
.work-info{margin-bottom:24px}
.work-info__label{
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--grey);margin-bottom:4px;
}
.work-info__val{font-family:var(--sans);font-size:14px;color:var(--black);line-height:1.5}
.work-info__val a{border-bottom:1px solid rgba(8,8,8,.1);transition:border-color .2s}
.work-info__val a:hover{border-color:var(--black)}
.work-content{line-height:1.8;color:rgba(8,8,8,.6)}
.work-content p{margin-bottom:16px}
.work-content strong{font-weight:500;color:var(--black)}
.work-content h2,.work-content h3{font-family:var(--serif);font-weight:400;color:var(--black);margin:32px 0 12px}
.work-content h2{font-size:1.7rem;letter-spacing:-.02em}
.work-images{margin-top:32px}
.work-images img{width:100%;margin-bottom:3px}
.work-nav{border-top:1px solid rgba(8,8,8,.07);padding:36px 0}
.work-nav .wrap{display:flex;align-items:center;justify-content:space-between}
.work-nav__link{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--grey);display:flex;align-items:center;gap:8px;transition:color .2s;
}
.work-nav__link:hover{color:var(--black)}
@media(max-width:768px){.work-body .wrap{grid-template-columns:1fr}.work-sidebar{position:static}}

/* ─── CONTACT ────────────────────────────────────────────── */
.contact-body .wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;padding-bottom:88px}
.contact__desc{
  font-family:var(--sans);font-size:15px;font-weight:300;
  line-height:1.75;color:rgba(8,8,8,.5);max-width:360px;margin-top:20px;
}
.contact__info{margin-top:48px}
.contact__info-label{
  font-family:var(--mono);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--grey);margin-bottom:4px;
}
.contact__info-val{font-family:var(--sans);font-size:14px;color:var(--black);margin-bottom:20px}
.contact__info-val a:hover{color:var(--grey-dk)}
.form-group{margin-bottom:20px}
.form-group label{
  display:block;font-family:var(--mono);font-size:9px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--grey);margin-bottom:7px;
}
.form-group input,.form-group textarea{
  width:100%;font-family:var(--sans);font-size:15px;font-weight:300;
  color:var(--black);background:transparent;border:none;
  border-bottom:1px solid rgba(8,8,8,.1);padding:11px 0;outline:none;
  border-radius:0;-webkit-appearance:none;transition:border-color .2s;
}
.form-group input:focus,.form-group textarea:focus{border-bottom-color:var(--black)}
.form-group textarea{resize:vertical;min-height:110px}
.form-submit{margin-top:32px}
@media(max-width:768px){.contact-body .wrap{grid-template-columns:1fr}}

/* ─── ABOUT PAGE ─────────────────────────────────────────── */
.about-body{padding-bottom:88px}
.about-body .wrap{display:grid;grid-template-columns:320px 1fr;gap:72px;align-items:start}
.about-left{position:sticky;top:calc(var(--nav-h)+32px)}
.about-portrait{width:100%;aspect-ratio:2/3;object-fit:cover;filter:grayscale(1);transition:filter .5s}
.about-portrait:hover{filter:grayscale(.3)}
.about-right{padding-top:4px}
.about-right p{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.8;color:rgba(8,8,8,.55);margin-bottom:18px}
.about-right strong{font-weight:500;color:var(--black)}
@media(max-width:900px){.about-body .wrap{grid-template-columns:1fr}.about-left{position:static}.about-portrait{max-width:240px}}

/* ─── SINGLE POST (case study) ───────────────────────────── */
.post-hero{padding-top:calc(var(--nav-h) + 96px);padding-bottom:56px;border-bottom:1px solid rgba(8,8,8,.07)}
.post-body{padding:64px 0 88px}
.post-body .wrap{max-width:760px}
.post-thumb{width:100%;aspect-ratio:16/9;overflow:hidden;margin-bottom:48px;background:var(--grey-lt)}
.post-thumb img{width:100%;height:100%;object-fit:cover}
.entry-content p{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.85;color:rgba(8,8,8,.6);margin-bottom:20px}
.entry-content h2{font-family:var(--serif);font-size:1.7rem;font-weight:400;color:var(--black);margin:36px 0 14px;letter-spacing:-.02em}
.entry-content h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:var(--black);margin:28px 0 10px}
.entry-content strong{font-weight:500;color:var(--black)}
.entry-content em{font-style:italic}
.entry-content ul{list-style:disc;padding-left:20px;margin-bottom:18px}
.entry-content ol{list-style:decimal;padding-left:20px;margin-bottom:18px}
.entry-content li{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.8;color:rgba(8,8,8,.6);margin-bottom:6px}
.entry-content img{margin:28px 0;width:100%}
.entry-content a{border-bottom:1px solid rgba(8,8,8,.1);transition:border-color .2s}
.entry-content a:hover{border-color:var(--black)}
.entry-content blockquote{
  border-left:2px solid var(--black);padding-left:24px;margin:28px 0;
  font-family:var(--serif);font-size:1.2rem;font-weight:400;
  font-style:italic;color:var(--black);line-height:1.5;
}

/* ─── FOOTER ─────────────────────────────────────────────── */
.footer{border-top:1px solid rgba(8,8,8,.07);padding:28px 0}
.footer .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer__copy{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--grey)}
.footer__top{
  font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--grey);display:flex;align-items:center;gap:7px;transition:color .2s;
}
.footer__top:hover{color:var(--black)}

/* ─── SCROLL REVEAL ──────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}

/* ─── MISC ───────────────────────────────────────────────── */
::selection{background:var(--black);color:#fff}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-thumb{background:rgba(8,8,8,.12)}
::-webkit-scrollbar-thumb:hover{background:rgba(8,8,8,.28)}
.admin-bar .nav{top:32px}
@media(max-width:782px){.admin-bar .nav{top:46px}}
.view-all{text-align:center;padding:44px 0 72px}
