@font-face{font-family:'Helvetica Neue LT Pro';src:url('fonts/HelveticaNeueLTProTh.woff2') format('woff2');font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:'Helvetica Neue LT Pro';src:url('fonts/HelveticaNeueLTProLt.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Helvetica Neue LT Pro';src:url('fonts/HelveticaNeueLTProRoman.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Helvetica Neue LT Pro';src:url('fonts/HelveticaNeueLTProRoman-Oblique.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Helvetica Neue LT Pro';src:url('fonts/HelveticaNeueLTPro-Md.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Helvetica Neue LT Pro';src:url('fonts/HelveticaNeueLTPro-Bd.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
:root{--ink:#101010;--grey:#6f6f6f;--line:#e8e6e2;--paper:#fff;
  --shadow:0 1px 2px rgba(0,0,0,.05),0 14px 34px -16px rgba(0,0,0,.22);
  --shadow-lift:0 2px 4px rgba(0,0,0,.05),0 26px 54px -20px rgba(0,0,0,.3)}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Helvetica Neue LT Pro','Helvetica Neue',Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;animation:pagein .6s ease both}
@keyframes pagein{from{opacity:0}to{opacity:1}}
a{color:inherit;text-decoration:none}
img{display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}

/* ---------- hero (index) ---------- */
.hero{min-height:66vh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:64px 24px 40px}
.hero>*{opacity:0;animation:rise 1s cubic-bezier(.22,.61,.36,1) forwards}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.hero .logo{width:min(220px,56vw);height:auto}
.hero .artist{margin-top:44px;animation-delay:.25s;font-weight:100;
  font-size:clamp(30px,5.4vw,58px);letter-spacing:.2em;text-transform:uppercase;
  padding-left:.2em}/* balance tracking */
.hero .note{margin-top:18px;animation-delay:.45s;color:var(--grey);font-size:13px;
  letter-spacing:.34em;text-transform:uppercase;font-weight:300;padding-left:.34em}
.hero .cue{margin-top:56px;animation-delay:.8s;width:1px;height:54px;
  background:linear-gradient(var(--ink),transparent);transform-origin:top}

/* ---------- masonry grid (index) ---------- */
.grid{columns:3 300px;column-gap:56px;padding:26px 0 90px}
figure.card{break-inside:avoid;margin:0 0 66px}
.card a{display:block}
.card img{width:100%;height:auto;box-shadow:var(--shadow);
  transition:transform .5s cubic-bezier(.22,.61,.36,1),box-shadow .5s cubic-bezier(.22,.61,.36,1)}
.card a:hover img{transform:translateY(-5px);box-shadow:var(--shadow-lift)}
figcaption{margin-top:16px}
.card .t{font-size:15.5px;font-weight:400;letter-spacing:.01em}
.card .m{margin-top:4px;color:var(--grey);font-size:13px;font-weight:300}
.card .p{margin-top:7px;font-size:13.5px;font-weight:500;letter-spacing:.05em}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(26px);
  transition:opacity .85s ease,transform .85s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- work page ---------- */
header.mini{padding:42px 0 8px;text-align:center}
header.mini img{width:120px;height:auto;margin:0 auto;opacity:.94;transition:opacity .3s}
header.mini a:hover img{opacity:.7}
.work{max-width:960px;margin:0 auto;padding:34px 24px 70px;text-align:center}
.stage{display:flex;justify-content:center}
.work img.art{max-width:100%;max-height:72vh;width:auto;height:auto;
  box-shadow:var(--shadow);cursor:zoom-in;
  transition:box-shadow .5s cubic-bezier(.22,.61,.36,1)}
.work img.art:hover{box-shadow:var(--shadow-lift)}
.work h1{margin-top:52px;font-weight:100;font-size:clamp(26px,4vw,38px);letter-spacing:.02em}
.work h1:before{content:'\2018'} .work h1:after{content:'\2019'}
.work .cz{margin-top:10px;color:var(--grey);font-size:17px;font-weight:400;font-style:italic}
.work .artist{margin-top:26px;font-size:15.5px;letter-spacing:.03em}
.work .tech{margin-top:6px;color:var(--grey);font-size:14.5px;font-weight:300}
.work .price{margin-top:26px;font-size:20px;font-weight:500;letter-spacing:.05em}
.work .inv{margin-top:12px;color:var(--grey);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase}
.enquire{display:inline-block;margin-top:36px;font-size:12.5px;letter-spacing:.26em;
  text-transform:uppercase;border:1px solid var(--ink);padding:13px 30px 12px;
  transition:background .35s,color .35s}
.enquire:hover{background:var(--ink);color:#fff}

/* prev / next */
.worknav{display:flex;justify-content:space-between;align-items:baseline;gap:18px;
  max-width:960px;margin:0 auto;padding:0 24px 90px;font-size:13px;color:var(--grey)}
.worknav a{transition:color .3s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:38%}
.worknav a:hover{color:var(--ink)}
.worknav .home{letter-spacing:.22em;text-transform:uppercase;font-size:11.5px}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(255,255,255,.97);display:flex;
  align-items:center;justify-content:center;opacity:0;pointer-events:none;
  transition:opacity .35s ease;z-index:50;cursor:zoom-out;padding:3vmin}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:94vw;max-height:94vh;width:auto;height:auto;box-shadow:var(--shadow)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:52px 24px 64px;text-align:center;
  color:var(--grey);font-size:13px;letter-spacing:.06em;font-weight:300}
footer a{border-bottom:1px solid var(--line);padding-bottom:2px;transition:color .3s,border-color .3s}
footer a:hover{color:var(--ink);border-color:var(--ink)}
footer .tag{margin-top:18px;letter-spacing:.34em;text-transform:uppercase;font-size:10.5px;padding-left:.34em}

hr{border:0;border-top:1px solid var(--line);margin:0 0 30px}
@media(max-width:640px){
  .hero{min-height:58vh}
  .grid{column-gap:36px}
  figure.card{margin-bottom:52px}
  .worknav a{max-width:32%}
}
@media(prefers-reduced-motion:reduce){
  *,*:before,*:after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .hero>*{opacity:1}
}
