:root{
  --bg:#ffffff;
  --fg:#000000;
  --muted:rgba(0,0,0,.62);
  --hair:rgba(0,0,0,.12);
  --hair2:rgba(0,0,0,.08);
  --serif:"Bodoni Moda","Didot","Bodoni MT","Bodoni 72","Times New Roman",serif;
  --sans:"Inter","Helvetica Neue",Arial,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --max:1120px;
  --pad:20px;
  --r:18px;
  --ease:cubic-bezier(.2,.9,.2,1);
  --dur:900ms;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family:var(--sans);
  font-weight:300;
  letter-spacing:.01em;
  line-height:1.55;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;height:auto;display:block}

a{color:inherit;text-decoration:none}

.skip-link{
  position:absolute;
  left:-999px;
  top:12px;
  background:var(--bg);
  color:var(--fg);
  border:1px solid var(--hair);
  padding:10px 12px;
  border-radius:999px;
}
.skip-link:focus{left:12px;z-index:20}

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.nav{
  max-width:var(--max);
  margin:0 auto;
  padding:14px var(--pad);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}

.nav__brand{display:flex;align-items:center;gap:10px;min-width:0}
.nav__brandMark{
  width:10px;height:10px;
  border:1px solid var(--fg);
  border-radius:999px;
  flex:0 0 auto;
}
.nav__brandText{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.nav__links{display:flex;align-items:center;gap:18px}
.nav__link{
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(0,0,0,.72);
  position:relative;
  transition:color 700ms var(--ease), transform 500ms var(--ease);
}
.nav__link::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:100%;
  height:1px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 700ms var(--ease);
}
.nav__link:hover,.nav__link:focus-visible{
  color:rgba(0,0,0,.88);
  transform:translateY(-1px);
}
.nav__link:hover::after,.nav__link:focus-visible::after{transform:scaleX(1)}



.section{
  padding:60px 0;
  content-visibility:auto;
  contain-intrinsic-size: 1px 900px;
}
.section--alt{background:#fff}
.section.artist{padding-bottom:40px}

#portfolio.section{padding-top:18px}

.section__head{
  max-width:var(--max);
  margin:0 auto 20px;
  padding:0 var(--pad);
}
.section__title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  font-size:28px;
  line-height:1.12;
}
.section__lead{margin:10px 0 0;color:var(--muted);max-width:64ch}

.projects{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:flex;
  flex-direction:column;
  gap:34px;
}

.project{
  border-top:1px solid var(--hair2);
  padding-top:22px;
}
.project__meta{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.project__title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  font-size:22px;
  line-height:1.15;
}
.project__desc{margin:0;color:var(--muted);max-width:70ch}

.carousel{
  display:flex;
  gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 2px 14px;
}
.carousel::-webkit-scrollbar{height:6px}
.carousel::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px}
.carousel::-webkit-scrollbar-track{background:transparent}

.slide{
  scroll-snap-align:start;
  flex:0 0 86%;
  border-radius:calc(var(--r) + 4px);
  border:1px solid var(--hair);
  background:#fff;
  overflow:hidden;
  position:relative;
}

.slide__btn{
  width:100%;
  border:0;
  padding:0;
  background:transparent;
  display:block;
  cursor:pointer;
}

.slide__img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  transform:scale(1);
  transition:transform 1200ms var(--ease), filter 800ms var(--ease), box-shadow 600ms var(--ease);
  box-shadow:0 0 0 rgba(0,0,0,0);
}
.slide__btn:hover .slide__img,
.slide__btn:focus-visible .slide__img{transform:scale(1.015)}
.slide__btn:active .slide__img{
  transform:scale(0.98);
  box-shadow:0 8px 24px rgba(0,0,0,0.14);
  filter:brightness(0.96);
}

.slide__caption{
  position:absolute;
  left:14px;
  bottom:14px;
  right:14px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#000;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(0,0,0,.08);
  border-radius:999px;
  padding:10px 12px;
  display:inline-flex;
  width:fit-content;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.artist{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  align-items:start;
}
.artist__media{
  border-radius:calc(var(--r) + 6px);
  border:1px solid var(--hair);
  overflow:hidden;
}
.artist__img{width:100%;aspect-ratio:4/5;object-fit:cover}
.artist__copy{padding:6px 0}
.artist__text{margin:10px 0 0;color:rgba(0,0,0,.72);max-width:68ch}
.artist__signature{
  display:block;
  width:200px;
  height:auto;
  margin-top:12px;
  margin-left:auto;
  margin-right:0;
  opacity:0.85;
}

.contact{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}

.contact__block{border:1px solid var(--hair2);border-radius:calc(var(--r) + 8px);padding:18px}
.contact__label{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(0,0,0,.55)}
.contact__value{
  display:inline-block;
  margin-top:10px;
  font-size:18px;
  font-weight:300;
  letter-spacing:.01em;
  position:relative;
  transition:color 700ms var(--ease), transform 500ms var(--ease), opacity 600ms var(--ease);
}
.contact__value::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:100%;
  height:1px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 700ms var(--ease);
  opacity:.6;
}
.contact__value:hover,.contact__value:focus-visible{
  color:rgba(0,0,0,.92);
  transform:translateY(-2px);
  opacity:1;
}
.contact__value:hover::after,.contact__value:focus-visible::after{transform:scaleX(1)}

.social{display:flex;gap:12px;margin-top:10px}
.social__link{
  width:46px;height:46px;
  border-radius:999px;
  border:1px solid var(--hair2);
  display:grid;
  place-items:center;
  transition:transform 700ms var(--ease),border-color 700ms var(--ease), opacity 600ms var(--ease), background-color 700ms var(--ease);
}
.social__link:hover,.social__link:focus-visible{
  transform:translateY(-2px) scale(1.04);
  border-color:rgba(0,0,0,.24);
  background:rgba(0,0,0,.02);
  opacity:1;
}
.social__link svg{width:22px;height:22px}
.social__link svg [stroke]{stroke-width:2.2}

.exclusive{
  max-width:var(--max);
  margin:22px auto 0;
  padding:0 var(--pad);
  color:rgba(0,0,0,.62);
  font-size:13px;
  letter-spacing:.02em;
}

.footer{padding:34px 0;border-top:1px solid var(--hair2)}
.footer__inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:flex;justify-content:space-between;align-items:center;gap:16px}
.footer__small{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(0,0,0,.55)}

.lightbox{
  position:fixed;
  inset:0;
  display:flex;
  align-items:stretch;
  justify-content:stretch;
  z-index:30;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity 700ms var(--ease), visibility 700ms var(--ease);
}
.lightbox.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.lightbox__backdrop{position:absolute;inset:0;background:rgba(255,255,255,.96)}

.lightbox__panel{
  position:relative;
  width:100vw;
  height:100vh;
  border:0;
  border-radius:0;
  background:#fff;
  overflow:hidden;
  box-shadow:none;
  transform:translateY(10px) scale(.985);
  transition:transform 700ms var(--ease);
}

.lightbox.is-open .lightbox__panel{transform:translateY(0) scale(1)}

.lightbox__content{
  height:100%;
  display:flex;
  flex-direction:column;
  --lb-pad:18px;
  padding:var(--lb-pad);
  gap:12px;
}

.lightbox__header{
  display:flex;
  flex-direction:column;
  gap:12px;
  position:relative;
  padding-top:60px; /* more space for absolute back arrow */
}

.lightbox__back{
  position:absolute;
  top:12px;
  left:12px;
  width:40px;height:40px;
  border-radius:999px;
  border:1px solid var(--hair2);
  background:rgba(255,255,255,.92);
  cursor:pointer;
  font-size:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:3;
  padding:12px;
  margin:-12px;
}

.lightbox__titleWrap{display:flex;align-items:center;gap:12px;justify-content:space-between}
.lightbox__title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:.01em;
  line-height:1.05;
  font-size:34px;
  flex:1;min-width:0;
}

.lightbox__logo{
  width:25%;
  height:auto;
  object-fit:contain;
  flex:0 0 auto;
  max-width:120px;
}

.lightbox__figureWrap{
  margin:0 calc(-1 * var(--lb-pad));
  padding:0 8px;
}
.lightbox__figure{margin:0;flex:1;min-height:0;display:grid;grid-template-rows:1fr auto;position:relative}
.lightbox__img{width:100%;height:100%;object-fit:contain;background:#fff;transform:scale(1);filter:none;opacity:1;transition:opacity 520ms var(--ease),transform 520ms var(--ease),filter 520ms var(--ease)}
.lightbox.is-switching .lightbox__img{opacity:0;transform:scale(.992);filter:blur(2px)}
.lightbox.is-tap .lightbox__img{transform:scale(1.006)}

.lightbox__logoContainer{
  display:flex;
  justify-content:center;
  padding-top:20px;
  padding-bottom:12px;
}

.lightbox__logo{
  width:25%;
  height:auto;
  object-fit:contain;
  max-width:120px;
  pointer-events:none;
}
.lightbox__caption{
  padding:14px 16px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(0,0,0,.62);
}

.lightbox__bullets{margin:0;padding-left:18px;color:rgba(0,0,0,.72)}
.lightbox__bullet{margin:0}

.lightbox__details{
  padding:14px 16px 0;
  color:rgba(0,0,0,.72);
  font-size:13px;
  letter-spacing:.01em;
}

.lightbox__detailsTitle{display:none}

.lightbox__detailsList{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.lightbox__detailsItem{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:baseline}
.lightbox__detailsKey{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(0,0,0,.55)}
.lightbox__detailsVal{margin:0}
.lightbox__detailsNote{margin:10px 0 0;color:rgba(0,0,0,.62)}

.link-lavis{color:#1b4fd6;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.link-lavis:hover,.link-lavis:focus-visible{color:#133aa6}

body.is-lightbox-open .site-header{display:none}

.link-projectTitle{color:inherit;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.link-projectTitle:hover,.link-projectTitle:focus-visible{text-decoration-thickness:2px}

.lightbox__close{
  position:absolute;
  top:10px;
  right:10px;
  z-index:3;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid var(--hair2);
  background:rgba(255,255,255,.92);
  cursor:pointer;
  font-size:22px;
  line-height:1;
}

.lightbox__tap{
  position:absolute;
  top:0;
  bottom:0;
  width:18vw;
  min-width:90px;
  max-width:220px;
  border:0;
  padding:0;
  background:transparent;
  cursor:pointer;
  z-index:2;
}
.lightbox__tap--prev{left:0;height:66.6%} /* reduce height to avoid back arrow */
.lightbox__tap--next{right:0}

[data-reveal]{
  opacity:0;
  transform:translateY(10px);
  transition:opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.is-visible{opacity:1;transform:translateY(0)}

@media (min-width:720px){
  :root{--pad:26px}
  .carousel{gap:14px}
  .slide{flex-basis:52%}
}

@media (min-width:960px){
  .section{padding:84px 0}
  .section__title{font-size:34px}
  .projects{gap:46px}
  .project{display:grid;grid-template-columns:1fr;gap:14px}
  .project__title{font-size:24px}
  .carousel{padding-bottom:16px}
  .slide{flex-basis:38%}
  .artist{grid-template-columns:420px 1fr;gap:34px;align-items:center}
  .artist__signature{width:260px}
  .contact{grid-template-columns:1fr 1fr 1fr}
  #portfolio.section{padding-top:26px}
  .lightbox__content{--lb-pad:26px;padding:var(--lb-pad);gap:14px}
  .lightbox__title{font-size:46px}
  .lightbox__back{
  top:16px;
  left:16px;
}
.lightbox__header{padding-top:70px}
.lightbox__logoContainer{padding-top:24px;padding-bottom:16px}
.lightbox__logo{max-width:150px}
.lightbox__figureWrap{
  margin:0 calc(-1 * var(--lb-pad));
  padding:0 8px;
}
.lightbox__figure{margin:0;width:100%;height:auto;max-height:100%}
.lightbox__img{
  width: 100%;
  height: auto;
  object-fit: cover;
}
/* Disable carousel clicks on desktop only */
.slide__btn{pointer-events:none}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  [data-reveal]{transition:none;opacity:1;transform:none}
  .slide__img{transition:none}
  .nav__link::after,.contact__value::after{transition:none}
  .lightbox{transition:none}
  .lightbox__panel{transition:none;transform:none}
  .lightbox__img{transition:none;filter:none;transform:none;opacity:1}
}
