:root{
  --paper:#ffffff;
  --tint:#fafafa;
  --ink:#1a1a1a;        /* primary text on paper/tint */
  --ink-soft:#55524d;   /* secondary text — AA on white & #fafafa */
  --rule:#d9d6d0;       /* hairline rules (non-text) */
  --rule-strong:#1a1a1a;
  --measure:66ch;
  --sans:"Archivo", "Helvetica Neue", Helvetica, Arial, system-ui, sans-serif;
  --prose:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  scroll-padding-top:5.5rem;
}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--prose);
  font-size:clamp(1rem,0.96rem + 0.2vw,1.0625rem);
  line-height:1.65;
  font-feature-settings:"kern" 1, "liga" 1;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ---- layout shell: asymmetric, left-aligned ---- */
.wrap{
  width:100%;
  max-width:1280px;
  margin-inline:auto;
  padding-left:max(clamp(1.25rem,5vw,4.5rem), env(safe-area-inset-left));
  padding-right:max(clamp(1.25rem,5vw,4.5rem), env(safe-area-inset-right));
}

/* ---- skip link ---- */
.skip{
  position:absolute;
  left:-9999px;
  top:0;
  background:var(--ink);
  color:#fff;
  padding:.7rem 1.1rem;
  z-index:100;
  font-size:.8rem;
  letter-spacing:.06em;
  text-decoration:none;
}
.skip:focus{left:1rem;top:1rem}

/* ---- focus visibility ---- */
a:focus-visible,
button:focus-visible{
  outline:2px solid var(--ink);
  outline-offset:3px;
  border-radius:1px;
}

/* =========================================================
   TYPOGRAPHY GROUPS (DRY)
   Two clusters that recurred across the page are collapsed here.
   Members keep their own size / weight / letter-spacing below.
     · display      — elements set in the Archivo sans face
     · micro-label  — the uppercase, letter-spaced secondary-ink
                      eyebrows, data lines, captions and footer text
   ========================================================= */
.skip,
.nav,
h1,
.section-head h2,
.work__num,
.work__titleblock h3,
.cta,
.enquire h2{
  font-family:var(--sans);
}
.hero__kicker,
.hero__meta,
.label,
.section-head__count,
.work__num small,
.data,
figcaption,
.enquire__direct,
.foot-lines p,
.foot-top{
  font-family:var(--sans);
  text-transform:uppercase;
  color:var(--ink-soft);
}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-head{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,0.92);
  backdrop-filter:saturate(140%) blur(6px);
  border-bottom:1px solid var(--rule);
}
.site-head__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
  min-height:4.75rem;
}
.brand{
  display:flex;
  align-items:center;
  text-decoration:none;
  color:var(--ink);
}
.brand__logo{
  height:2.5rem;
  width:auto;
  display:block;
}

.nav{
  display:flex;
  align-items:center;
  gap:clamp(1rem,2.4vw,2.25rem);
}
.nav a{
  color:var(--ink);
  text-decoration:none;
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:.35rem 0;
  position:relative;
  white-space:nowrap;
}
.nav a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-2px;
  height:1px;
  background:var(--ink);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .28s ease;
}
.nav a:hover::after,
.nav a:focus-visible::after{transform:scaleX(1)}
.nav a.nav--cta{
  border:1px solid var(--ink);
  padding:.5rem .9rem;
}
.nav a.nav--cta::after{display:none}
.nav a.nav--cta:hover,
.nav a.nav--cta:focus-visible{
  background:var(--ink);
  color:#fff;
}
/* keep all nav links on phones — shrink to fit instead of hiding them,
   and grow the tap targets */
@media (max-width:560px){
  .nav{gap:.6rem}
  .nav a{font-size:.6rem;letter-spacing:.06em;padding:.7rem 0}
  .nav a.nav--cta{padding:.5rem .65rem;letter-spacing:.08em}
}
@media (max-width:380px){
  .nav{gap:.45rem}
  .nav a{font-size:.55rem;letter-spacing:.03em}
  .nav a.nav--cta{padding:.42rem .55rem}
}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  padding-top:clamp(3.5rem,9vw,7rem);
  padding-bottom:clamp(2.5rem,6vw,4.5rem);
  border-bottom:1px solid var(--rule);
}
.hero .wrap{position:relative;z-index:1}
.hero-fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero__kicker{
  font-size:.68rem;
  font-weight:500;
  letter-spacing:.26em;
  margin:0 0 1.4rem;
}
h1{
  font-weight:700;
  font-size:clamp(3rem,11vw,8.5rem);
  line-height:.92;
  letter-spacing:-.02em;
  margin:0;
  max-width:14ch;
}
.hero__sub{
  font-size:clamp(1.0625rem,1rem + 0.5vw,1.375rem);
  line-height:1.55;
  color:var(--ink);
  max-width:46ch;
  margin:clamp(1.6rem,4vw,2.4rem) 0 0;
  font-weight:400;
}
.hero__meta{
  margin:clamp(2rem,5vw,3rem) 0 0;
  padding:0;
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:1rem 2.5rem;
  font-size:.68rem;
  letter-spacing:.16em;
}
.hero__meta li{display:inline-flex;gap:.6rem;align-items:center}
.hero__meta li::before{
  content:"";
  width:1.6rem;height:1px;background:var(--rule-strong);display:inline-block;
}

/* =========================================================
   CURATORIAL NOTE / ABOUT (shared two-column label grid)
   ========================================================= */
.note{
  padding-block:clamp(3rem,7vw,5.5rem);
  border-bottom:1px solid var(--rule);
}
.note__grid{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:clamp(1.5rem,4vw,3rem);
}
@media (min-width:760px){
  .note__grid{grid-template-columns:minmax(8rem,18%) minmax(0,1fr)}
}
.label{
  font-size:.66rem;
  font-weight:600;
  letter-spacing:.24em;
  margin:0;
  padding-top:.4rem;
}
.note__body p{
  font-size:clamp(1.0625rem,1rem + 0.45vw,1.3125rem);
  line-height:1.6;
  max-width:var(--measure);
  margin:0 0 1.1rem;
  color:var(--ink);
}
.note__body p:last-child{margin-bottom:0}

/* =========================================================
   THE WORK
   ========================================================= */
.section-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:1rem;
  padding-block:clamp(3rem,7vw,5rem) clamp(1.5rem,3vw,2.5rem);
  border-bottom:1px solid var(--rule-strong);
  flex-wrap:wrap;
}
.section-head h2{
  font-weight:700;
  font-size:clamp(1.75rem,4vw,2.75rem);
  letter-spacing:-.015em;
  line-height:1;
  margin:0;
}
.section-head__count{
  font-size:.7rem;
  letter-spacing:.2em;
}

.work{
  padding-block:clamp(3.5rem,8vw,7rem);
  border-bottom:1px solid var(--rule);
}
.work:nth-of-type(even){background:var(--tint)}

/* row 1: index numeral + title block */
.work__head{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:clamp(.75rem,3vw,2rem);
  align-items:start;
  margin-bottom:clamp(2rem,5vw,3.5rem);
}
@media (min-width:760px){
  .work__head{grid-template-columns:minmax(6rem,12%) minmax(0,1fr)}
}
.work__num{
  font-weight:600;
  font-size:clamp(2.75rem,8vw,5.5rem);
  line-height:.85;
  letter-spacing:-.03em;
  color:var(--ink);
  font-feature-settings:"tnum" 1;
  margin:0;
}
.work__num small{
  display:block;
  font-size:.7rem;
  font-weight:500;
  letter-spacing:.2em;
  margin-top:.7rem;
}
.work__titleblock h3{
  font-weight:700;
  font-size:clamp(1.5rem,4.5vw,3rem);
  line-height:1.02;
  letter-spacing:-.015em;
  margin:0 0 1rem;
}
.work__titleblock h3 .roman{
  color:var(--ink-soft);
  font-weight:500;
  font-size:.62em;
  letter-spacing:.04em;
  margin-right:.45em;
}
.data{
  font-size:.72rem;
  font-weight:500;
  letter-spacing:.13em;
  line-height:1.9;
  margin:0;
  max-width:52ch;
}
.data .avail{color:var(--ink);font-weight:600}

/* body: text + figures, asymmetric */
.work__body{
  display:grid;
  grid-template-columns:minmax(0,1fr);
  gap:clamp(2rem,5vw,4rem);
}
@media (min-width:900px){
  .work__body{grid-template-columns:minmax(0,1fr) minmax(0,1.15fr)}
}
.work__text .caption{
  font-style:italic;
  color:var(--ink-soft);
  font-size:1.0625rem;
  margin:0 0 1.25rem;
  max-width:50ch;
  line-height:1.55;
}
.work__text p.desc{
  margin:0;
  max-width:var(--measure);
  color:var(--ink);
  line-height:1.7;
}

figure{margin:0}
.work-fig{
  display:flex;
  flex-direction:column;
  gap:clamp(1.25rem,3vw,2rem);
}
.work-fig img{
  display:block;
  width:100%;
  height:auto;
  background:var(--tint);
}
.work:nth-of-type(even) .work-fig img{background:#fff}
figcaption{
  font-size:.66rem;
  font-weight:500;
  letter-spacing:.16em;
  margin-top:.85rem;
  padding-top:.6rem;
  border-top:1px solid var(--rule);
  display:flex;
  justify-content:space-between;
  gap:1rem;
}
figcaption .tag{color:var(--ink)}

/* secondary pair under the lead image */
.fig-pair{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(11rem,100%),1fr));
  gap:clamp(1rem,2.5vw,1.5rem);
}

/* =========================================================
   ENQUIRE
   ========================================================= */
.enquire{
  padding-block:clamp(4rem,9vw,7.5rem);
  border-bottom:1px solid var(--rule);
}
.enquire h2{
  font-weight:700;
  font-size:clamp(2rem,6vw,4rem);
  letter-spacing:-.02em;
  line-height:.95;
  margin:0 0 1.6rem;
  color:var(--ink);
}
.enquire__body{max-width:72ch}
.enquire p{
  max-width:var(--measure);
  margin:0 0 2rem;
  line-height:1.7;
}
.enquire a.inline{
  color:var(--ink);
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-thickness:1px;
  font-weight:500;
}
.enquire a.inline:hover,
.enquire a.inline:focus-visible{text-decoration-thickness:2px}

.cta{
  display:inline-flex;
  align-items:center;
  gap:.9rem;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#fff;
  background:var(--ink);
  border:1px solid var(--ink);
  padding:1.05rem 1.8rem;
  text-decoration:none;
  transition:background .25s ease,color .25s ease,transform .25s ease;
}
.cta::after{
  content:"\2192";
  font-size:1.1em;
  transition:transform .25s ease;
}
.cta:hover,.cta:focus-visible{background:#fff;color:var(--ink)}
.cta:hover::after,.cta:focus-visible::after{transform:translateX(4px)}

.enquire__direct{
  margin-top:1.75rem;
  font-size:.72rem;
  letter-spacing:.12em;
}
.enquire__direct a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rule-strong)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-foot{
  padding-block:clamp(3rem,7vw,5rem);
}
.site-foot__grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:1.5rem 2rem;
  align-items:flex-end;
}
.site-foot .logo{
  width:120px;height:auto;display:block;
  filter:grayscale(1) contrast(1.05);
  margin-bottom:1.25rem;
}
.foot-lines p{
  margin:0;
  font-size:.72rem;
  letter-spacing:.1em;
  line-height:1.9;
}
.foot-lines a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rule)}
.foot-lines a:hover,.foot-lines a:focus-visible{border-color:var(--rule-strong)}
.foot-top{
  text-align:right;
  font-size:.66rem;
  letter-spacing:.2em;
  margin:0;
}
.foot-top a{color:var(--ink-soft);text-decoration:none}
.foot-top a:hover,.foot-top a:focus-visible{color:var(--ink)}

/* =========================================================
   INTERACTIVE (progressive enhancement — only active with JS)
   ========================================================= */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.is-visible{opacity:1;transform:none}

.nav a[aria-current="true"]{color:var(--ink)}
.nav a[aria-current="true"]::after{transform:scaleX(1)}
.nav a.nav--cta[aria-current="true"]::after{display:none}

.zoom-btn{display:block;width:100%;margin:0;padding:0;border:0;background:none;cursor:zoom-in;font:inherit;color:inherit}
.zoom-btn:focus-visible{outline:2px solid var(--ink);outline-offset:3px}

.lightbox[hidden]{display:none}
.lightbox{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(1rem,4vw,3rem);
  background:rgba(18,18,18,.93);
  opacity:0;transition:opacity .3s ease;
}
.lightbox.is-open{opacity:1}
.lightbox img{max-width:100%;max-height:90vh;width:auto;height:auto;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox__close{
  position:absolute;top:clamp(.75rem,3vw,1.5rem);right:clamp(.75rem,3vw,1.5rem);
  width:2.75rem;height:2.75rem;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.55);background:none;color:#fff;
  font-size:1.5rem;line-height:1;cursor:pointer;border-radius:50%;
}
.lightbox__close:hover,.lightbox__close:focus-visible{background:#fff;color:#111;outline:none}
body.no-scroll{overflow:hidden}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js .reveal{opacity:1;transform:none}
  .hero-fx{display:none}
  *,*::before,*::after{
    transition:none !important;
    animation:none !important;
  }
}
