/* ============================================================
   MOUSSA SALMAN — Quiet Gallery design system
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,400;0,8..60,500;0,8..60,600;0,8..60,700;1,8..60,400;1,8..60,500&family=Source+Sans+3:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  --paper:#F5F2EC;
  --paper-2:#EEEAE0;
  --paper-3:#E7E2D6;
  --ink:#1B1813;
  --ink-soft:#403B32;
  --ink-faint:#6B645A;
  --line:rgba(27,24,19,0.14);
  --line-soft:rgba(27,24,19,0.08);
  --accent:oklch(0.46 0.10 42);      /* muted oxblood/terracotta */
  --accent-deep:oklch(0.38 0.09 40);

  --serif:'Source Serif 4',Georgia,serif;
  --sans:'Source Sans 3',system-ui,-apple-system,sans-serif;
  --mono:'Space Mono','SFMono-Regular',monospace;

  --maxw:1320px;
  --textw:680px;
  --pad:clamp(20px,5vw,72px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:clip}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  font-size:18px;
  line-height:1.65;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.01em}
.display{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.6rem,7vw,5.6rem);
  line-height:.98;
  letter-spacing:-.015em;
}
.display em{font-style:italic;color:var(--accent)}
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-faint);
}
.lead{
  font-family:var(--serif);
  font-size:clamp(1.4rem,2.6vw,1.9rem);
  line-height:1.4;
  font-weight:400;
  color:var(--ink-soft);
}
p.body{font-size:1.05rem;line-height:1.75;color:var(--ink-soft)}
.prose p{font-size:1.08rem;line-height:1.8;color:var(--ink-soft);margin-bottom:1.4em}
.prose p:first-of-type::first-letter{
  font-family:var(--serif);
  font-size:4.4rem;
  float:left;
  line-height:.78;
  padding:.05em .12em 0 0;
  color:var(--ink);
  font-weight:500;
}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.narrow{max-width:var(--textw);margin-left:auto;margin-right:auto}
section{padding-block:clamp(56px,9vw,120px)}
.rule{height:1px;background:var(--line);border:0}

/* ---------- header ---------- */
.site-head{
  position:sticky;top:0;z-index:60;
  background:color-mix(in oklab,var(--paper) 86%,transparent);
  backdrop-filter:saturate(1.2) blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.01em}
.brand .sub{font-family:var(--mono);font-size:8.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-faint);margin-top:5px;white-space:nowrap}
@media(max-width:420px){.brand .sub{letter-spacing:.18em;font-size:8px}}
.nav{display:flex;align-items:center;gap:22px}
.nav a{
  font-size:13px;letter-spacing:.02em;color:var(--ink-soft);white-space:nowrap;
  position:relative;padding-block:4px;transition:color .25s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav a:hover{color:var(--ink)}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav a.active{color:var(--ink)}
.nav .cta{
  border:1px solid var(--ink);border-radius:100px;padding:9px 18px;color:var(--ink);
  transition:background .3s var(--ease),color .3s var(--ease);
}
.nav .cta::after{display:none}
.nav .cta:hover{background:var(--ink);color:var(--paper)}
.burger{display:none;width:30px;height:30px;position:relative;background:none;border:0;cursor:pointer}
.burger span{position:absolute;left:3px;right:3px;height:1.5px;background:var(--ink);transition:.3s var(--ease)}
.burger span:nth-child(1){top:9px}
.burger span:nth-child(2){bottom:9px}
.menu-open .burger span:nth-child(1){top:14px;transform:rotate(45deg)}
.menu-open .burger span:nth-child(2){bottom:14px;transform:rotate(-45deg)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:14px;letter-spacing:.04em;
  padding:14px 28px;border-radius:100px;cursor:pointer;
  border:1px solid var(--ink);background:var(--ink);color:var(--paper);
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease);
}
.btn:hover{background:transparent;color:var(--ink);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:clamp(16px,3vw,44px);padding-bottom:clamp(40px,6vw,72px)}
.hero-grid{display:grid;grid-template-columns:1.05fr 1.25fr;gap:clamp(28px,5vw,72px);align-items:start}
.hero-copy .display{margin:.18em 0 .5em}
.hero-meta{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-meta .stat .n{font-family:var(--serif);font-size:1.9rem;line-height:1}
.hero-meta .stat .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);margin-top:7px}
.hero-figure{position:relative}
.hero-figure img{width:100%;height:auto;box-shadow:0 40px 80px -40px rgba(27,24,19,.5)}
.hero-figure figcaption{
  display:flex;justify-content:space-between;gap:12px;margin-top:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);
}
.hero-figure figcaption .t{color:var(--ink)}
/* museum-style placard — below the work, aligned right */
.hero-slideshow{position:relative}
.hero-slideshow figcaption{
  position:static;display:block;width:fit-content;margin:18px 0 0 auto;text-align:left;max-width:85%;
  background:#fff;color:var(--ink);padding:14px 18px;
  border:1px solid rgba(27,24,19,.08);box-shadow:0 10px 28px -12px rgba(27,24,19,.4)}
.hero-slideshow figcaption .t{display:block;font-family:var(--serif);font-style:italic;
  font-size:clamp(1.02rem,1.4vw,1.3rem);line-height:1.18;letter-spacing:0;text-transform:none;color:var(--ink)}
.hero-slideshow figcaption #hsMeta{display:block;margin-top:5px;text-align:right;
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}
/* hero slideshow — paintings shown in full (no crop) on a soft mat */
.hero-slideshow .hero-slides{position:relative;aspect-ratio:4/3;overflow:hidden;background:#000;border:clamp(7px,1vw,12px) solid #000;
  box-shadow:0 40px 80px -40px rgba(27,24,19,.5);transition:aspect-ratio .7s var(--ease)}
.hero-slideshow .hs-img{position:absolute;inset:0;width:100%;height:100%;padding:0;box-sizing:border-box;object-fit:cover;opacity:0;transition:opacity 1.2s var(--ease)}
.hero-slideshow .hs-img.is-active{opacity:1}
.hero-slideshow figcaption .t,.hero-slideshow figcaption span{transition:opacity .5s var(--ease)}
@media(max-width:560px){
  .hero-slideshow .hs-img{padding:0}
  .hero-slideshow figcaption{margin-top:14px;padding:11px 14px;max-width:90%}
  .hero-slideshow figcaption .t{font-size:1rem}
  .hero-slideshow figcaption #hsMeta{font-size:9px}
}

/* ---------- section heading ---------- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:48px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(2rem,4vw,3.2rem)}
.sec-head .eyebrow{margin-bottom:16px}

/* ---------- page band ---------- */
.page-band{padding-top:clamp(48px,7vw,92px);padding-bottom:clamp(28px,4vw,44px);border-bottom:1px solid var(--line)}
.page-band .eyebrow{margin-bottom:20px}
.page-band h1{font-size:clamp(2.6rem,6vw,4.6rem);line-height:1}
.page-band .lead{margin-top:24px;max-width:46ch}

/* ---------- masonry gallery ---------- */
.gallery{columns:3;column-gap:clamp(14px,1.6vw,24px)}
.gallery .item{break-inside:avoid;margin-bottom:clamp(14px,1.6vw,24px);cursor:zoom-in;position:relative}
.gallery .item img{
  width:100%;height:auto;background:var(--paper-3);
  transition:transform .6s var(--ease),filter .6s var(--ease);
}
.gallery .item .cap{
  display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:12px 3px 2px;
  font-family:var(--serif);font-size:1.05rem;letter-spacing:0;text-transform:none;color:var(--ink-faint);
}
.gallery .item .cap .t{color:var(--ink);font-weight:600}
.gallery .item .cap span:last-child{color:var(--ink-soft);font-size:.95rem}
.gallery .item .price-tag{display:flex;flex-direction:column;gap:2px;padding:8px 3px 2px;
  font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.01em;color:var(--ink-soft);font-feature-settings:"tnum"}
.gallery .item .price-tag .ed{font-size:11.5px;letter-spacing:.02em;color:var(--ink-faint)}
.gallery .item .price-tag .pr{color:var(--ink);font-weight:600}
.gallery .item .price-tag span:last-child{color:var(--ink);font-weight:700}
.gallery .item:hover img{filter:brightness(.94)}
.gallery .item:hover .cap{opacity:1;transform:none}
@media(max-width:900px){.gallery{columns:2}}
@media(max-width:560px){.gallery{columns:1}}

/* selected works (home) — asymmetric */
.selected{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2vw,30px)}
.selected figure{position:relative;overflow:hidden}
.selected figure img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.selected figure:hover img{transform:scale(1.04)}
.selected figcaption{
  margin-top:12px;display:flex;justify-content:space-between;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);
}
.selected figcaption .t{color:var(--ink)}
.s-tall{grid-column:span 4}
.s-wide{grid-column:span 8}
.s-half{grid-column:span 6}
.s-third{grid-column:span 4}
@media(max-width:760px){
  .s-tall,.s-wide,.s-half,.s-third{grid-column:span 12}
}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:120;background:rgba(18,16,12,.94);
  display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,56px);
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.lb.open{opacity:1;visibility:visible}
.lb img{max-width:100%;max-height:82vh;width:auto;height:auto;box-shadow:0 30px 80px -30px #000}
.lb-cap{position:absolute;left:0;right:0;bottom:clamp(16px,3vw,32px);text-align:center;color:#EDE7DA;
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.lb-cap .t{color:#fff;font-weight:700}
.lb-close,.lb-nav{position:absolute;background:none;border:0;color:#EDE7DA;cursor:pointer;transition:color .25s,transform .25s}
.lb-close{top:clamp(14px,3vw,28px);right:clamp(16px,3vw,32px);font-size:30px;line-height:1}
.lb-close:hover{color:#fff;transform:rotate(90deg)}
.lb-nav{top:50%;transform:translateY(-50%);font-size:34px;padding:18px}
.lb-nav:hover{color:#fff}
.lb-prev{left:clamp(4px,1vw,18px)}
.lb-next{right:clamp(4px,1vw,18px)}
/* two-pane lightbox with edition pricing */
.lb-stage{display:flex;gap:clamp(22px,3.5vw,52px);align-items:center;justify-content:center;width:100%;max-width:1180px;max-height:86vh}
.lb-imgwrap{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:center}
.lb-stage img{max-width:100%;max-height:84vh;width:auto;height:auto;box-shadow:0 30px 80px -30px #000}
.lb-info{flex:0 0 clamp(260px,30vw,360px);align-self:center;text-align:left;color:#EDE7DA}
.lb-title{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;display:flex;flex-wrap:wrap;align-items:baseline;gap:8px}
.lb-title .t{color:#fff;font-weight:700;font-size:clamp(16px,1.4vw,20px);letter-spacing:.04em}
.lb-title .y{color:rgba(237,231,218,.55);font-size:12px}
.lb-medium{font-family:var(--mono);font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:rgba(237,231,218,.55);line-height:1.55;margin:12px 0 18px}
.lb-editions{display:flex;flex-direction:column;border-top:1px solid rgba(237,231,218,.16)}
.lb-ed{display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:baseline;padding:11px 0;border-bottom:1px solid rgba(237,231,218,.12);font-family:var(--mono)}
.lb-ed .n{color:rgba(237,231,218,.45);font-size:11px;letter-spacing:.04em}
.lb-ed .sz{color:rgba(237,231,218,.92);font-size:13px;letter-spacing:.03em}
.lb-ed .pr{color:#fff;font-weight:700;font-size:13px;letter-spacing:.03em;white-space:nowrap;justify-self:end}
.lb-ed .ed-inq{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(237,231,218,.7);text-decoration:none;border:1px solid rgba(237,231,218,.28);padding:5px 10px;border-radius:999px;white-space:nowrap;transition:color .25s,border-color .25s,background .25s}
.lb-ed .ed-inq:hover{color:var(--ink);background:#EDE7DA;border-color:#EDE7DA}
.lb-enquire{margin-top:22px}
@media(max-width:820px){
  .lb{align-items:flex-start;overflow:auto}
  .lb-stage{flex-direction:column;max-height:none;gap:20px}
  .lb-stage img{max-height:46vh}
  .lb-info{flex:none;width:100%;max-width:460px}
}

/* ---------- statement / quote ---------- */
.statement{background:var(--ink);color:var(--paper)}
.statement .eyebrow{color:rgba(245,242,236,.5)}
.statement blockquote{
  font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,3.6vw,2.9rem);
  line-height:1.32;letter-spacing:-.01em;max-width:20ch;
}
.statement .who{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,242,236,.55);margin-top:28px}

/* review cards */
.reviews{columns:2;column-gap:clamp(20px,3vw,40px)}
.review{break-inside:avoid;margin-bottom:clamp(20px,3vw,36px);padding:34px 32px;border:1px solid var(--line);background:var(--paper-2)}
.review .mark{font-family:var(--serif);font-size:3rem;line-height:.5;color:var(--accent);display:block;height:24px}
.review p{font-family:var(--serif);font-size:1.32rem;line-height:1.5;color:var(--ink);font-style:italic;margin:10px 0 18px}
.review .src{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}
@media(max-width:680px){.reviews{columns:1}}

/* ---------- list rows (exhibitions / awards) ---------- */
.rows{border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:120px 1fr auto;gap:24px;align-items:baseline;
  padding:26px 0;border-bottom:1px solid var(--line)}
.row .yr{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.05em}
.row .ti{font-family:var(--serif);font-size:1.5rem;line-height:1.2}
.row .pl{font-size:14px;color:var(--ink-faint);text-align:right}
@media(max-width:600px){
  .row{grid-template-columns:1fr;gap:6px}
  .row .pl{text-align:left}
}

/* memberships / chips */
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.chip{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:100px;padding:10px 18px;color:var(--ink-soft)}

/* ---------- two-col feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,80px);align-items:center}
.split.portrait{grid-template-columns:.9fr 1.1fr}
@media(max-width:820px){.split,.split.portrait{grid-template-columns:1fr;gap:36px}}
.split img{width:100%;box-shadow:0 30px 70px -40px rgba(27,24,19,.5)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px)}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:9px}
.field input,.field textarea{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:10px 0;font-family:var(--sans);font-size:1rem;color:var(--ink);transition:border-color .3s}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--ink)}
.contact-line{display:flex;gap:14px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--line)}
.contact-line .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);width:90px;flex:none}
.contact-line .v{font-family:var(--serif);font-size:1.35rem}
.contact-line a.v:hover{color:var(--accent)}

/* ---------- footer ---------- */
.site-foot{background:var(--ink);color:var(--paper);padding-block:clamp(48px,7vw,90px)}
.site-foot .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.site-foot .name{font-family:var(--serif);font-size:2.2rem;font-weight:500}
.site-foot .sub{font-family:var(--mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(245,242,236,.5);margin-top:10px}
.site-foot h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,242,236,.5);font-weight:400;margin-bottom:18px}
.site-foot a{color:rgba(245,242,236,.82);font-size:14px;display:block;padding:5px 0;transition:color .25s}
.site-foot a:hover{color:var(--paper)}
.foot-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:56px;padding-top:24px;border-top:1px solid rgba(245,242,236,.14);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:rgba(245,242,236,.45)}
@media(max-width:760px){.site-foot .grid{grid-template-columns:1fr 1fr}.site-foot .brandcol{grid-column:1/-1}}
@media(max-width:480px){.site-foot .sub{letter-spacing:.12em;font-size:9px;white-space:nowrap}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- mobile nav ---------- */
@media(max-width:1180px){
  .burger{display:block}
  .nav{
    position:fixed;top:0;right:0;bottom:auto;left:auto;height:100vh;height:100dvh;
    width:min(82vw,360px);
    background:var(--paper-2);border-left:1px solid var(--line);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:8px;overflow-y:auto;
    padding:40px var(--pad);transform:translateX(100%);visibility:hidden;transition:transform .45s var(--ease),visibility 0s linear .45s;z-index:55;
  }
  .menu-open .nav{transform:none;visibility:visible;transition:transform .45s var(--ease),visibility 0s}
  .nav a{font-family:var(--serif);font-size:1.5rem;line-height:1.15;color:var(--ink);padding:8px 0;white-space:normal;overflow-wrap:break-word;max-width:100%}
  .nav a::after{display:none}
  .nav .cta{margin-top:18px;font-size:1rem;padding:12px 26px}
  .nav-scrim{position:fixed;inset:0;background:rgba(27,24,19,.4);opacity:0;visibility:hidden;transition:.4s;z-index:54}
  .menu-open .nav-scrim{opacity:1;visibility:visible}
}
@media(min-width:1181px){.nav-scrim{display:none}}

/* hero responsive */
@media(max-width:860px){
  .hero{padding-top:clamp(20px,5vw,40px);padding-bottom:clamp(28px,6vw,48px)}
  .hero-grid{grid-template-columns:1fr;gap:clamp(22px,5vw,32px)}
  .hero-figure{order:-1}
  .hero-copy .display{font-size:clamp(2.2rem,8vw,3.4rem)!important;margin:.1em 0 .4em}
  .hero-meta{gap:18px 28px;margin-top:26px}
}
@media(max-width:560px){
  .hero-copy .display{font-size:clamp(2rem,8.6vw,2.8rem)!important}
  .hero-copy .lead{font-size:1.02rem}
  .hero-meta{gap:14px 20px;margin-top:22px}
  .hero-meta .stat{flex:1 1 40%}
  .hero-meta .stat .n{font-size:1.55rem}
  .hero-meta .stat .l{font-size:9px;letter-spacing:.1em;margin-top:5px}
  .hero-figure figcaption{font-size:10px}
}
