/* Taymour Grahne Projects — white-cube editorial system */

:root{
  --bg:#FBFBF9;
  --surface:#F4F2ED;
  --surface-2:#EFEBE2;
  --text:#161616;
  --muted:#6E6A62;
  --primary:#1B1B1B;
  --secondary:#7A6A57;
  --accent:#8A3F2D;
  --border:#E2DFD8;
  --hairline:#D6D2C9;
  --focus:#2F6F73;

  --serif: "Cormorant Garamond", "Cormorant", "EB Garamond", Georgia, serif;
  --grotesque: "Helvetica Neue", Helvetica, Arial, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  --gutter: clamp(20px, 4vw, 56px);
  --maxw: 1480px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--grotesque);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern", "liga", "ss01";
}

img{display:block; max-width:100%; height:auto;}
button{font:inherit; color:inherit; background:none; border:0; padding:0; cursor:pointer;}
a{color:inherit; text-decoration:none;}

/* ===== Type primitives ===== */
.eyebrow{
  font-family:var(--grotesque);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
}
.eyebrow .dot{
  display:inline-block;
  width:5px; height:5px; border-radius:50%;
  background:var(--accent);
  margin:0 10px 2px 0;
  vertical-align:middle;
}
.display{
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:-0.01em;
  line-height:1.02;
  text-wrap:balance;
}
.display-1{ font-size:clamp(48px, 7.4vw, 112px); font-style:normal; }
.display-2{ font-size:clamp(36px, 4.6vw, 68px); }
.display-3{ font-size:clamp(28px, 3.2vw, 44px); }
.italic{ font-style:italic; font-variation-settings:"ital" 1; }

.lede{
  font-family:var(--serif);
  font-size:clamp(20px, 1.7vw, 26px);
  line-height:1.4;
  font-style:italic;
  color:var(--text);
  font-weight:400;
  max-width:38ch;
}

.meta{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.04em;
  color:var(--muted);
  text-transform:none;
}
.credit{
  font-family:var(--mono);
  font-size:10.5px;
  line-height:1.5;
  letter-spacing:0.01em;
  color:var(--muted);
}
.credit .name{ color:var(--text); }
.credit .title{ font-style:italic; }

/* ===== Layout ===== */
.shell{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 var(--gutter);
}
.shell-wide{ max-width:1680px; margin:0 auto; padding:0 var(--gutter); }
.rule{ border-top:1px solid var(--border); }
.rule-bottom{ border-bottom:1px solid var(--border); }

/* ===== Navbar ===== */
.nav{
  position:sticky; top:0; z-index:40;
  background:rgba(251,251,249,0.92);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  height:72px;
  gap:24px;
}
.wordmark{
  font-family:var(--serif);
  font-size:22px;
  letter-spacing:-0.005em;
  line-height:1;
  color:var(--text);
  display:inline-flex; gap:0; align-items:baseline;
}
.wordmark .amp{ color:var(--secondary); margin:0 4px; font-style:italic;}
.wordmark small{
  font-family:var(--grotesque);
  font-size:9.5px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-left:14px;
  font-weight:500;
  border-left:1px solid var(--hairline);
  padding-left:14px;
  line-height:1;
}
.nav-links{
  display:flex; gap:30px; justify-content:center;
  font-size:13px; letter-spacing:0.02em;
}
.nav-links button{
  color:var(--text);
  padding:6px 0;
  border-bottom:1px solid transparent;
  transition:border-color .2s ease, color .2s ease;
  font-weight:450;
}
.nav-links button:hover{ color:var(--accent); }
.nav-links button.active{ border-color:var(--text); }
.nav-right{
  display:flex; justify-content:flex-end; align-items:center; gap:18px;
  font-size:12px; letter-spacing:0.04em;
}
.locale{
  display:flex; gap:0; align-items:center;
  font-family:var(--mono);
  font-size:11px;
  border:1px solid var(--border);
  border-radius:999px;
  padding:3px;
  background:var(--bg);
}
.locale button{
  padding:4px 9px;
  border-radius:999px;
  color:var(--muted);
  letter-spacing:0.06em;
}
.locale button.on{
  background:var(--text);
  color:var(--bg);
}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 18px;
  font-size:12.5px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  font-weight:500;
  border:1px solid var(--text);
  background:var(--text);
  color:var(--bg);
  border-radius:999px;
  transition: background .25s ease, color .25s ease, border-color .25s ease, transform .15s ease;
}
.btn:hover{ background:var(--accent); border-color:var(--accent); }
.btn:active{ transform:translateY(1px); }
.btn-ghost{
  background:transparent; color:var(--text); border-color:var(--text);
}
.btn-ghost:hover{ background:var(--text); color:var(--bg); }
.btn-line{
  background:transparent;
  color:var(--text);
  border:0; border-bottom:1px solid var(--text);
  border-radius:0; padding:6px 0; letter-spacing:0.14em;
}
.btn-line:hover{ color:var(--accent); border-color:var(--accent); }
.btn-line .arrow{ transition: transform .25s ease; }
.btn-line:hover .arrow{ transform: translateX(4px); }

.btn .arrow{ display:inline-block; }

/* ===== Closure banner ===== */
.closure-bar{
  background:var(--text);
  color:var(--bg);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.04em;
  padding:8px 0;
  text-align:center;
}
.closure-bar .dot{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--accent); margin-right:10px; vertical-align:middle;
}

/* ===== Hero (museum-poster) ===== */
.hero{
  position:relative;
  padding-top:0;
  padding-bottom:0;
}
.hero-topline{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  padding:18px 0 24px;
  gap:24px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--muted);
  border-bottom:1px solid var(--border);
}
.hero-topline .l{ display:flex; align-items:center; gap:14px;}
.hero-topline .l .num{
  font-family:var(--serif); font-size:14px; font-style:italic; letter-spacing:0; color:var(--text); text-transform:none;
}
.hero-topline .c{ color:var(--text);}
.hero-topline .c .dot{
  display:inline-block; width:5px; height:5px; border-radius:50%;
  background:var(--accent); margin:0 14px 2px; vertical-align:middle;
  box-shadow:0 0 0 0 rgba(138,63,45,0.4); animation: pulse 2s infinite;
}
.hero-topline .r{ justify-self:end; color:var(--muted);}

.hero-poster{
  padding:64px 0 32px;
  display:grid;
  grid-template-columns: 1fr;
  gap:24px;
  text-align:center;
  position:relative;
}
.hero-poster .kicker{
  font-family:var(--serif); font-style:italic;
  font-size:22px; color:var(--secondary);
  letter-spacing:0;
}
.hero-poster .poster-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(72px, 14vw, 220px);
  line-height:0.86;
  letter-spacing:-0.025em;
  margin:0;
  text-wrap:balance;
}
.hero-poster .poster-title .amp{
  font-style:italic; color:var(--secondary);
  font-size:0.7em; vertical-align:0.15em; margin:0 0.06em;
}
.hero-poster .poster-artists{
  font-family:var(--serif);
  font-size:clamp(15px, 1.3vw, 19px);
  line-height:1.6;
  letter-spacing:0.04em;
  color:var(--text);
  max-width:62ch;
  margin:8px auto 0;
}
.hero-poster .poster-artists .sep{ color:var(--secondary); margin:0 10px;}
.hero-poster .poster-curator{
  font-family:var(--serif); font-style:italic;
  font-size:15px; color:var(--muted);
  margin-top:6px;
}
.hero-poster::before, .hero-poster::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  width:60px; height:1px; background:var(--secondary);
}
.hero-poster::before{ top:40px;}
.hero-poster::after{ bottom:8px;}

.hero-figure{
  position:relative;
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;
  aspect-ratio: 21/10;
  margin:0 calc(-1 * var(--gutter));
}
.hero-figure img{ width:100%; height:100%; object-fit:cover; display:block; }
.hero-credit{
  position:absolute; right:24px; bottom:20px;
  background:rgba(251,251,249,0.92);
  backdrop-filter: blur(8px);
  padding:10px 14px;
  border:1px solid var(--border);
  max-width:380px;
}
.hero-figure .stage-corner{
  position:absolute; left:24px; top:20px;
  background:rgba(22,22,22,0.78);
  backdrop-filter: blur(8px);
  color:var(--bg);
  padding:8px 12px;
  font-family:var(--mono); font-size:10px; letter-spacing:0.16em;
  text-transform:uppercase;
}
.hero-figure .stage-corner .accent-dot{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--accent); margin-right:8px; vertical-align:middle;
}

.hero-bar{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap:0;
  align-items:stretch;
  border-bottom:1px solid var(--border);
}
.hero-bar > div{
  padding:20px 24px;
  border-left:1px solid var(--border);
  display:flex; flex-direction:column; gap:4px;
}
.hero-bar > div:first-child{ border-left:0; padding-left:0;}
.hero-bar .k{
  font-family:var(--mono); font-size:10px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--muted);
}
.hero-bar .v{
  font-family:var(--serif); font-size:18px; line-height:1.25;
  color:var(--text);
}
.hero-bar .v small{
  display:block; font-family:var(--mono);
  font-size:10px; letter-spacing:0.04em; color:var(--muted);
  margin-top:4px;
}
.hero-bar .cta{
  align-items:center; justify-content:center;
  background:var(--text); color:var(--bg);
  padding:0 32px;
  cursor:pointer;
  transition: background .25s ease;
}
.hero-bar .cta:hover{ background:var(--accent);}
.hero-bar .cta .v{ color:var(--bg);}
.hero-bar .cta .k{
  color:rgba(251,251,249,0.55);
  text-align:center;
}

.hero-belt{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap:48px;
  align-items:center;
  padding:48px 0 96px;
}
.hero-belt .platform{
  font-family:var(--serif);
  font-size:clamp(22px, 2vw, 30px);
  line-height:1.3;
  font-style:italic;
  color:var(--text);
  max-width:42ch;
  text-wrap:balance;
}
.hero-belt .platform .em{ font-style:normal; color:var(--accent);}
.hero-belt .right{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:24px;
}
.hero-belt .stat .v{
  font-family:var(--serif);
  font-size:48px; line-height:1; font-weight:400;
  letter-spacing:-0.02em;
}
.hero-belt .stat .k{
  font-family:var(--mono);
  font-size:10px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--muted); margin-top:8px;
}

.figure-frame{
  background:var(--surface);
  border:1px solid var(--border);
  overflow:hidden;
  position:relative;
}
.figure-frame img{ width:100%; height:100%; object-fit:cover; }

/* ===== Marquee / metadata strip ===== */
.strip{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  margin-top:40px;
}
.strip > div{
  padding:18px 22px;
  border-left:1px solid var(--border);
  display:flex; flex-direction:column; gap:6px;
}
.strip > div:first-child{ border-left:0; padding-left:0; }
.strip .k{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--muted);
}
.strip .v{
  font-family:var(--serif); font-size:22px; line-height:1.1;
}
.strip .v small{ font-family:var(--grotesque); font-size:11px; color:var(--muted); letter-spacing:0.04em; display:block; margin-top:4px;}

/* ===== Section header ===== */
.section{ padding:96px 0 64px; }
.section-tight{ padding:64px 0 48px; }
.section-head{
  display:grid;
  grid-template-columns: 220px 1fr auto;
  gap:32px; align-items:end;
  margin-bottom:36px;
  padding-bottom:18px;
  border-bottom:1px solid var(--border);
}
.section-head .num{
  font-family:var(--mono); font-size:11px; color:var(--muted);
  letter-spacing:0.16em; text-transform:uppercase;
}
.section-head h2{
  font-family:var(--serif); font-weight:400; font-size:clamp(28px, 3.4vw, 48px);
  margin:0; letter-spacing:-0.01em; line-height:1.02;
}
.section-head .end{ justify-self:end; }

/* ===== Featured exhibition row ===== */
.feat{
  display:grid;
  grid-template-columns: 1.35fr 1fr;
  gap:48px;
  align-items:start;
}
.feat-figure{
  background:var(--surface);
  border:1px solid var(--border);
  position:relative;
  aspect-ratio: 4/3;
  overflow:hidden;
}
.feat-figure img{ width:100%; height:100%; object-fit:cover; transition: transform 1.4s ease; }
.feat:hover .feat-figure img{ transform: scale(1.02); }

.feat-meta .tag{
  display:inline-flex; gap:8px; align-items:center;
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.16em;
  text-transform:uppercase; color:var(--accent);
}
.feat-meta .tag .pulse{
  width:6px; height:6px; border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 0 rgba(138,63,45,0.4);
  animation: pulse 2s infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(138,63,45,0.4); }
  70%{ box-shadow:0 0 0 8px rgba(138,63,45,0); }
  100%{ box-shadow:0 0 0 0 rgba(138,63,45,0); }
}
.feat-meta h3{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(36px, 3.6vw, 56px);
  margin:14px 0 8px;
  letter-spacing:-0.01em; line-height:1.02;
}
.feat-meta .by{
  font-family:var(--serif); font-style:italic; font-size:18px; color:var(--secondary);
  margin-bottom:24px;
}
.feat-meta p{
  font-size:14.5px; line-height:1.65; color:var(--text);
  max-width:46ch;
}
.feat-meta .keyline{
  margin-top:24px;
  display:grid; grid-template-columns: max-content 1fr; row-gap:6px; column-gap:24px;
  font-family:var(--mono); font-size:11px; letter-spacing:0.06em;
}
.feat-meta .keyline dt{ color:var(--muted); text-transform:uppercase; letter-spacing:0.14em; }
.feat-meta .keyline dd{ margin:0; color:var(--text); }
.feat-meta .cta-row{
  margin-top:32px; display:flex; gap:20px; align-items:center; flex-wrap:wrap;
}

/* ===== Exhibition cards grid ===== */
.ex-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:48px 32px;
}
.ex-card{
  display:block; cursor:pointer;
}
.ex-card .frame{
  background:var(--surface);
  border:1px solid var(--border);
  aspect-ratio: 4/3;
  overflow:hidden;
  position:relative;
}
.ex-card .frame img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s ease, filter .6s ease;
}
.ex-card:hover .frame img{ transform:scale(1.03); }
.ex-card .meta{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-top:14px; gap:16px;
}
.ex-card .meta .l{ flex:1; }
.ex-card .meta .l h4{
  font-family:var(--serif); font-weight:400;
  font-size:22px; line-height:1.15; margin:0 0 4px;
  letter-spacing:-0.005em;
}
.ex-card .meta .l .by{
  font-family:var(--serif); font-style:italic; font-size:14.5px;
  color:var(--secondary);
}
.ex-card .meta .r{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:0.06em; color:var(--muted);
  text-align:right; white-space:nowrap; padding-top:4px;
}
.ex-card .meta .r .where{ display:block; margin-top:4px; color:var(--text);}
.ex-card .tag-pill{
  position:absolute; top:14px; left:14px;
  background:rgba(251,251,249,0.92);
  font-family:var(--mono); font-size:10px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--text);
  padding:5px 10px;
  border:1px solid var(--border);
}
.ex-card.current .tag-pill{ color:var(--accent); border-color:var(--accent); }

/* ===== Artist index ===== */
.artist-toolbar{
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:24px; flex-wrap:wrap; gap:18px;
  border-bottom:1px solid var(--border);
  padding-bottom:14px;
}
.artist-toolbar .alpha{
  display:flex; gap:4px; flex-wrap:wrap;
  font-family:var(--mono); font-size:11.5px;
}
.artist-toolbar .alpha button{
  width:26px; height:26px;
  border-radius:50%;
  color:var(--muted);
}
.artist-toolbar .alpha button.has{
  color:var(--text);
}
.artist-toolbar .alpha button.on{
  background:var(--text); color:var(--bg);
}
.artist-toolbar .alpha button:disabled{ color:var(--hairline); cursor:default; }
.artist-toolbar .view-toggle{
  display:flex; gap:0; align-items:center;
  font-family:var(--mono); font-size:11px;
  border:1px solid var(--border); border-radius:999px;
  padding:3px;
}
.artist-toolbar .view-toggle button{ padding:5px 12px; border-radius:999px; color:var(--muted); }
.artist-toolbar .view-toggle button.on{ background:var(--text); color:var(--bg); }

.artist-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:48px 28px;
}
.artist-card{ cursor:pointer; }
.artist-card .frame{
  aspect-ratio: 4/5;
  background:var(--surface);
  border:1px solid var(--border);
  overflow:hidden; position:relative;
}
.artist-card .frame img{ width:100%; height:100%; object-fit:cover; transition:transform 1s ease;}
.artist-card:hover .frame img{ transform:scale(1.03); }
.artist-card h5{
  font-family:var(--serif); font-weight:400; font-size:18px;
  margin:14px 0 2px;
}
.artist-card .sub{ font-family:var(--mono); font-size:10.5px; color:var(--muted); letter-spacing:0.06em;}
.artist-card .badge{
  position:absolute; top:12px; right:12px;
  background:rgba(251,251,249,0.92);
  border:1px solid var(--border);
  font-family:var(--mono); font-size:9.5px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--text);
  padding:4px 8px;
}
.artist-card .badge.now{ color:var(--accent); border-color:var(--accent);}

/* Artist list view */
.artist-list{
  display:grid;
  grid-template-columns: 1fr;
}
.artist-list .row{
  display:grid;
  grid-template-columns: 60px 1.4fr 1fr 0.6fr 1fr 80px;
  gap:24px;
  padding:18px 4px;
  border-bottom:1px solid var(--border);
  align-items:center;
  cursor:pointer;
  transition: background .2s ease;
}
.artist-list .row:hover{ background:var(--surface); }
.artist-list .row .num{ font-family:var(--mono); color:var(--muted); font-size:11px; letter-spacing:0.06em;}
.artist-list .row .name{ font-family:var(--serif); font-size:22px; font-weight:400; }
.artist-list .row .place{ font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:0.04em;}
.artist-list .row .born{ font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:0.04em;}
.artist-list .row .tag{ font-family:var(--mono); font-size:11px; color:var(--text); letter-spacing:0.04em;}
.artist-list .row .arrow{ justify-self:end; color:var(--muted); transition: transform .2s ease, color .2s ease;}
.artist-list .row:hover .arrow{ color:var(--accent); transform:translateX(4px); }
.artist-list .row.head{
  font-family:var(--mono); font-size:10.5px; color:var(--muted);
  text-transform:uppercase; letter-spacing:0.14em;
  cursor:default;
}
.artist-list .row.head:hover{ background:transparent;}
.artist-list .row.head .name{ font-family:var(--mono); font-size:10.5px;}

/* ===== Artist dossier ===== */
.dossier{
  display:grid;
  grid-template-columns: 320px 1fr;
  gap:64px;
  padding:48px 0 80px;
}
.dossier-side{
  position:sticky; top:96px; align-self:start;
}
.dossier-side .portrait{
  background:var(--surface);
  border:1px solid var(--border);
  aspect-ratio:4/5;
  overflow:hidden;
}
.dossier-side .portrait img{ width:100%; height:100%; object-fit:cover;}
.dossier-side dl{
  margin:24px 0 0; display:grid;
  grid-template-columns: max-content 1fr;
  row-gap:8px; column-gap:18px;
  font-family:var(--mono); font-size:11.5px;
}
.dossier-side dl dt{ color:var(--muted); text-transform:uppercase; letter-spacing:0.14em; font-size:10px;}
.dossier-side dl dd{ margin:0;}
.dossier-side .links{ margin-top:24px; display:flex; flex-direction:column; gap:10px;}

.dossier-main h1{
  font-family:var(--serif); font-weight:400; font-size:clamp(48px, 6vw, 92px);
  margin:0 0 8px; letter-spacing:-0.015em; line-height:0.98;
}
.dossier-main .role{
  font-family:var(--serif); font-style:italic; font-size:22px;
  color:var(--secondary); margin-bottom:32px;
}
.dossier-main .tabs{
  display:flex; gap:32px;
  border-bottom:1px solid var(--border);
  margin: 36px 0 24px;
}
.dossier-main .tabs button{
  padding:14px 0;
  font-family:var(--mono); font-size:11px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--muted);
  border-bottom:1px solid transparent;
  margin-bottom:-1px;
}
.dossier-main .tabs button.on{ color:var(--text); border-color:var(--text); }
.dossier-main .tabs button .count{ color:var(--muted); margin-left:6px; font-size:10px;}
.dossier-main p{ font-size:15px; line-height:1.7; max-width:64ch; color:var(--text); }
.dossier-main .pull-quote{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(22px, 2.2vw, 30px);
  line-height:1.3;
  color:var(--text);
  border-left:1px solid var(--secondary);
  padding:8px 0 8px 24px;
  margin:32px 0;
  max-width:48ch;
}

.works-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:36px 28px;
}
.work{
  position:relative;
}
.work .frame{
  background:var(--surface); border:1px solid var(--border);
  overflow:hidden;
  aspect-ratio: 1/1.1;
  position:relative;
}
.work .frame img{ width:100%; height:100%; object-fit:cover;}
.work .frame .enquire-hover{
  position:absolute; inset:0;
  display:flex; align-items:flex-end; justify-content:flex-end;
  padding:14px;
  opacity:0; transition: opacity .3s ease;
  background: linear-gradient(to top, rgba(22,22,22,0.7), transparent 50%);
}
.work:hover .frame .enquire-hover{ opacity:1; }
.work .frame .enquire-hover .btn{
  padding:8px 14px; font-size:10.5px;
  background:var(--bg); color:var(--text); border-color:var(--bg);
}
.work .frame .enquire-hover .btn:hover{
  background:var(--accent); color:var(--bg); border-color:var(--accent);
}
.work .credit-block{
  margin-top:12px;
}
.work .credit-block .name{
  font-family:var(--serif); font-size:14px; line-height:1.25;
}
.work .credit-block .title{
  font-family:var(--serif); font-style:italic; font-size:13.5px; color:var(--secondary);
}
.work .credit-block .spec{ font-family:var(--mono); font-size:10.5px; color:var(--muted); margin-top:4px; letter-spacing:0.02em;}
.work .credit-block .avail{
  font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase;
  margin-top:6px; color:var(--accent);
}
.work .credit-block .avail.sold{ color:var(--muted); }

/* ===== Online viewing room ===== */
.online-stage{
  background:var(--surface);
  padding:64px 0 80px;
  margin-top:0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.online-stage .stage{
  display:grid;
  grid-template-columns: 1fr 380px;
  gap:48px;
  align-items:start;
}
.online-stage .canvas{
  background:#FFFFFF;
  border:1px solid var(--border);
  aspect-ratio: 16/10;
  display:flex; align-items:center; justify-content:center;
  position:relative;
  overflow:hidden;
}
.online-stage .canvas img{ max-width:78%; max-height:80%; object-fit:contain; box-shadow:0 30px 60px -30px rgba(22,22,22,0.25); }
.online-stage .canvas .corner{
  position:absolute; top:14px; left:14px;
  font-family:var(--mono); font-size:10px; letter-spacing:0.14em; color:var(--muted);
}
.online-stage .canvas .scale{
  position:absolute; bottom:14px; right:14px;
  font-family:var(--mono); font-size:10px; color:var(--muted); letter-spacing:0.06em;
}
.online-stage .canvas .scale-line{
  display:inline-block; width:120px; height:1px; background:var(--muted);
  vertical-align:middle; margin-right:8px;
  position:relative;
}
.online-stage .canvas .scale-line::before,
.online-stage .canvas .scale-line::after{
  content:""; position:absolute; top:-3px; width:1px; height:7px; background:var(--muted);
}
.online-stage .canvas .scale-line::before{ left:0; }
.online-stage .canvas .scale-line::after{ right:0; }
.online-stage .panel h3{
  font-family:var(--serif); font-weight:400; font-size:32px;
  margin:0 0 6px;
}
.online-stage .panel .by{
  font-family:var(--serif); font-style:italic; font-size:18px; color:var(--secondary);
  margin-bottom:18px;
}
.online-stage .panel .credit-detail{
  font-family:var(--mono); font-size:11.5px; line-height:1.7;
  color:var(--muted);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:14px 0;
  margin:18px 0 24px;
}
.online-stage .panel .credit-detail .l{ color:var(--text); display:inline-block; min-width:90px; }
.online-stage .thumbs{
  display:flex; gap:8px; margin-top:18px;
}
.online-stage .thumbs button{
  flex:1; aspect-ratio: 1/1;
  background:var(--bg); border:1px solid var(--border);
  overflow:hidden; position:relative;
}
.online-stage .thumbs button.on{
  border-color:var(--text);
}
.online-stage .thumbs button img{ width:100%; height:100%; object-fit:cover; opacity:0.85;}
.online-stage .thumbs button.on img{ opacity:1; }

/* ===== Press grid ===== */
.press-feat{
  display:grid; grid-template-columns: 1.2fr 1fr; gap:48px;
  margin-bottom:64px;
}
.press-feat .pull{
  font-family:var(--serif); font-weight:400; font-style:italic;
  font-size:clamp(28px, 2.6vw, 40px);
  line-height:1.25;
  letter-spacing:-0.005em;
  color:var(--text);
}
.press-feat .pull::before{
  content:"\201C";
  font-size:120px; line-height:0.1; color:var(--secondary);
  vertical-align:-0.4em; margin-right:8px;
}
.press-feat .attribution{
  font-family:var(--mono); font-size:11.5px; color:var(--muted);
  letter-spacing:0.08em; margin-top:24px;
}
.press-feat .attribution strong{ color:var(--text); font-weight:500;}

.press-table{
  border-top:1px solid var(--border);
}
.press-table .row{
  display:grid;
  grid-template-columns: 110px 1fr 160px 60px;
  gap:32px;
  align-items:center;
  padding:22px 0;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition: background .2s ease, padding .2s ease;
}
.press-table .row:hover{
  background:var(--surface); padding-left:14px; padding-right:14px;
}
.press-table .row .date{ font-family:var(--mono); font-size:11px; color:var(--muted); letter-spacing:0.04em;}
.press-table .row .outlet{ font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent);}
.press-table .row .title{ font-family:var(--serif); font-size:22px; line-height:1.2; font-weight:400; margin-top:4px; max-width:42ch;}
.press-table .row .kind{ font-family:var(--mono); font-size:10.5px; color:var(--muted); letter-spacing:0.08em; text-transform:uppercase; }
.press-table .row .download{ justify-self:end; color:var(--muted); transition: color .2s ease, transform .2s ease;}
.press-table .row:hover .download{ color:var(--accent); transform: translateY(-2px);}

/* ===== Press releases / kit cards ===== */
.kits{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:24px;
  margin-top:24px;
}
.kit{
  background:var(--surface);
  border:1px solid var(--border);
  padding:24px;
  display:flex; flex-direction:column; gap:12px;
}
.kit h5{
  font-family:var(--serif); font-size:22px; font-weight:400; margin:0;
}
.kit .desc{ font-size:13px; color:var(--muted); flex:1;}
.kit .file{
  font-family:var(--mono); font-size:10.5px; color:var(--text);
  letter-spacing:0.04em;
  display:flex; justify-content:space-between; align-items:center;
  border-top:1px dashed var(--border);
  padding-top:12px;
}
.kit .file .size{ color:var(--muted);}

/* ===== About ===== */
.about-lede{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(28px, 3vw, 44px);
  line-height:1.22;
  letter-spacing:-0.005em;
  max-width:24ch;
}
.timeline{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  border-top:1px solid var(--border);
  margin-top:48px;
}
.timeline .t-col{
  padding:32px 24px 32px 0;
  border-right:1px solid var(--border);
  display:flex; flex-direction:column; gap:10px;
}
.timeline .t-col:last-child{ border-right:0;}
.timeline .yr{ font-family:var(--serif); font-size:36px; color:var(--accent); font-style:italic;}
.timeline .where{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted);}
.timeline p{ font-size:13.5px; line-height:1.6; max-width:32ch; margin:0;}

/* ===== Contact ===== */
.contact-grid{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:64px;
}
.location-card{
  border-top:1px solid var(--border);
  padding:32px 0;
  display:grid;
  grid-template-columns: 100px 1fr;
  gap:32px;
  align-items:start;
}
.location-card .city{
  font-family:var(--serif); font-size:32px; font-weight:400;
}
.location-card .city small{
  display:block;
  font-family:var(--mono); font-size:10px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--accent); margin-bottom:4px;
}
.location-card .body{ font-size:14px; line-height:1.7;}
.location-card .body .addr{ font-family:var(--serif); font-size:18px; line-height:1.4; margin-bottom:14px;}
.location-card .body .row{
  display:grid; grid-template-columns: 80px 1fr; gap:16px;
  font-family:var(--mono); font-size:11.5px; padding:4px 0;
}
.location-card .body .row dt{ color:var(--muted); text-transform:uppercase; letter-spacing:0.1em; font-size:10px; padding-top:3px;}

.map-frame{
  background:var(--surface);
  border:1px solid var(--border);
  aspect-ratio:1/1;
  position:relative;
  overflow:hidden;
}
.map-frame .grid-lines{
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(226,223,216,0.6) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(226,223,216,0.6) 1px, transparent 1px);
  background-size: 32px 32px;
}
.map-frame .pin{
  position:absolute; left:50%; top:50%; transform:translate(-50%, -50%);
  text-align:center;
}
.map-frame .pin .marker{
  width:16px; height:16px; border-radius:50%;
  background:var(--accent);
  margin:0 auto 8px;
  box-shadow: 0 0 0 6px rgba(138,63,45,0.18), 0 0 0 14px rgba(138,63,45,0.08);
}
.map-frame .pin .lbl{
  font-family:var(--mono); font-size:10.5px; letter-spacing:0.14em; text-transform:uppercase; color:var(--text);
}
.map-frame .corner-coord{
  position:absolute; left:14px; bottom:12px;
  font-family:var(--mono); font-size:10px; color:var(--muted); letter-spacing:0.06em;
}
.map-frame .corner-cardinal{
  position:absolute; right:14px; top:12px;
  font-family:var(--mono); font-size:14px; color:var(--muted);
}

/* ===== Mailing list / footer ===== */
.mailing{
  background:var(--text); color:var(--bg);
  padding:88px 0 64px;
  margin-top:96px;
}
.mailing-grid{
  display:grid; grid-template-columns: 1.2fr 1fr; gap:64px; align-items:end;
}
.mailing h3{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(36px, 4.4vw, 64px);
  margin:0; letter-spacing:-0.01em; line-height:1.0;
  color:var(--bg);
}
.mailing form{
  display:grid; grid-template-columns: 1fr auto; gap:14px;
  border-bottom:1px solid rgba(251,251,249,0.3);
  padding-bottom:14px;
}
.mailing form input{
  background:transparent; border:0; color:var(--bg);
  font:inherit; font-size:15px; padding:8px 0;
  outline:0;
}
.mailing form input::placeholder{ color:rgba(251,251,249,0.5);}
.mailing form button{
  font-family:var(--mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase;
  padding:8px 16px; border:1px solid var(--bg); border-radius:999px; color:var(--bg);
  transition: background .2s ease, color .2s ease;
}
.mailing form button:hover{ background:var(--bg); color:var(--text);}
.mailing-fine{
  font-family:var(--mono); font-size:10.5px; color:rgba(251,251,249,0.55);
  letter-spacing:0.04em; margin-top:18px; max-width:48ch;
}

.foot{
  background:var(--text); color:rgba(251,251,249,0.7);
  padding:48px 0 24px;
  border-top:1px solid rgba(251,251,249,0.12);
}
.foot-grid{
  display:grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap:32px;
}
.foot h6{
  font-family:var(--mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase;
  color:rgba(251,251,249,0.5); margin:0 0 16px;
  font-weight:500;
}
.foot ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px;}
.foot ul li{ font-size:13px;}
.foot ul li a:hover{ color:var(--bg); }
.foot .word{
  font-family:var(--serif); font-size:28px; color:var(--bg); line-height:1.05; margin-bottom:18px;
}
.foot .word .amp{ color:var(--secondary); font-style:italic; margin:0 2px;}
.foot-mini{
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--mono); font-size:10.5px; color:rgba(251,251,249,0.45);
  border-top:1px solid rgba(251,251,249,0.12);
  margin-top:48px; padding-top:18px; letter-spacing:0.04em;
}

/* ===== Enquiry drawer ===== */
.drawer-scrim{
  position:fixed; inset:0; background:rgba(22,22,22,0.4);
  z-index:50; opacity:0; pointer-events:none; transition: opacity .3s ease;
}
.drawer-scrim.on{ opacity:1; pointer-events:auto; }
.drawer{
  position:fixed; right:0; top:0; bottom:0;
  width:520px; max-width:100vw;
  background:var(--bg); z-index:60;
  transform:translateX(100%); transition: transform .35s cubic-bezier(.4,.0,.1,1);
  border-left:1px solid var(--border);
  display:flex; flex-direction:column;
  box-shadow:-30px 0 80px -40px rgba(22,22,22,0.3);
}
.drawer.on{ transform:translateX(0);}
.drawer-head{
  display:flex; justify-content:space-between; align-items:center;
  padding:24px 32px;
  border-bottom:1px solid var(--border);
}
.drawer-head .eyebrow{ color:var(--accent);}
.drawer-head button{ font-family:var(--mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted);}
.drawer-head button:hover{ color:var(--text);}
.drawer-body{
  flex:1; overflow:auto; padding:24px 32px;
}
.drawer-body h2{
  font-family:var(--serif); font-weight:400; font-size:34px; line-height:1.1;
  margin:0 0 6px;
}
.drawer-body .sub{ font-family:var(--serif); font-style:italic; color:var(--secondary); margin-bottom:24px; font-size:18px;}
.drawer-body .pre{
  background:var(--surface); border:1px solid var(--border);
  padding:14px 16px; margin-bottom:24px;
  display:flex; gap:14px; align-items:center;
}
.drawer-body .pre .thumb{
  width:64px; height:64px; background:var(--bg); border:1px solid var(--border);
  overflow:hidden;
}
.drawer-body .pre .thumb img{ width:100%; height:100%; object-fit:cover;}
.drawer-body .pre .info{ flex:1;}
.drawer-body .pre .info .credit{ font-family:var(--mono); font-size:10.5px; color:var(--muted); line-height:1.5;}
.drawer-body .pre .info .credit .name{ color:var(--text); display:block; }
.drawer-body .field{ display:flex; flex-direction:column; gap:6px; margin-bottom:16px;}
.drawer-body .field label{
  font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted);
}
.drawer-body .field input,
.drawer-body .field textarea{
  font:inherit; font-size:14px; padding:10px 12px;
  background:var(--bg); border:1px solid var(--border); color:var(--text);
  outline:0; transition: border-color .2s ease;
}
.drawer-body .field input:focus,
.drawer-body .field textarea:focus{ border-color:var(--focus); }
.drawer-body .field textarea{ min-height:90px; resize:vertical;}
.drawer-body .row2{ display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.drawer-body .check{
  display:flex; gap:10px; font-size:12.5px; color:var(--muted); margin:14px 0;
  align-items:flex-start;
}
.drawer-body .check input{ margin-top:3px; accent-color:var(--accent);}
.drawer-foot{
  padding:18px 32px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between; gap:16px; align-items:center;
}
.drawer-foot .note{ font-family:var(--mono); font-size:10.5px; color:var(--muted); letter-spacing:0.04em;}

/* ===== Art fairs ===== */
.fair-row{
  display:grid;
  grid-template-columns: 1.3fr 1.6fr 0.9fr 0.7fr 80px;
  gap:32px;
  padding:28px 0;
  border-bottom:1px solid var(--border);
  align-items:center;
}
.fair-row .fair-name{
  font-family:var(--serif); font-size:28px; font-weight:400; line-height:1.1;
}
.fair-row .fair-name small{
  display:block; font-family:var(--mono); font-size:10.5px;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); margin-top:8px;
}
.fair-row .presented{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--secondary); }
.fair-row .presented small{ display:block; font-family:var(--mono); font-style:normal; font-size:10.5px; color:var(--muted); letter-spacing:0.06em; margin-top:6px;}
.fair-row .booth{
  font-family:var(--mono); font-size:13px;
  border:1px solid var(--border); padding:8px 12px; display:inline-block; letter-spacing:0.04em;
}
.fair-row .when{ font-family:var(--mono); font-size:11.5px; color:var(--muted); letter-spacing:0.04em;}

/* ===== Visit cards (Home) ===== */
.visit{
  display:grid; grid-template-columns: 1fr 1fr; gap:48px;
}
.visit-card{
  background:var(--surface);
  border:1px solid var(--border);
  padding:36px;
  display:flex; flex-direction:column; gap:14px;
}
.visit-card h4{
  font-family:var(--serif); font-size:36px; font-weight:400; margin:0;
}
.visit-card h4 small{
  font-family:var(--mono); display:block;
  font-size:10px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--accent); margin-bottom:6px;
}
.visit-card .addr{ font-family:var(--serif); font-size:17px; line-height:1.45;}
.visit-card .hours{ font-family:var(--mono); font-size:11.5px; color:var(--muted); letter-spacing:0.04em;}
.visit-card .ph{ margin-top:auto; padding-top:18px; border-top:1px dashed var(--border); font-family:var(--mono); font-size:11.5px;}

/* ===== Press strip on home ===== */
.press-strip{
  display:flex; align-items:center; gap:48px; overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:24px 0;
}
.press-strip .lbl{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); flex-shrink:0;}
.press-strip .marquee{ display:flex; gap:64px; flex:1; }
.press-strip .marquee .item{ font-family:var(--serif); font-size:22px; color:var(--text); font-style:italic; white-space:nowrap;}
.press-strip .marquee .item span{ font-family:var(--mono); font-style:normal; font-size:11px; color:var(--muted); margin-left:14px; letter-spacing:0.06em;}

/* ===== Responsive ===== */
@media (max-width: 960px){
  .nav-inner{ grid-template-columns: 1fr auto; }
  .nav-links{ display:none; }
  .feat, .visit, .contact-grid, .press-feat, .online-stage .stage, .dossier, .mailing-grid{
    grid-template-columns: 1fr;
  }
  .ex-grid{ grid-template-columns: repeat(2, 1fr); }
  .artist-grid{ grid-template-columns: repeat(2, 1fr); }
  .strip{ grid-template-columns: repeat(2, 1fr); }
  .hero-bar{ grid-template-columns: 1fr 1fr; }
  .hero-belt{ grid-template-columns: 1fr; gap:24px;}
  .hero-belt .right{ grid-template-columns: repeat(3, 1fr);}
  .hero-topline{ grid-template-columns: 1fr; text-align:center; gap:8px;}
  .timeline{ grid-template-columns: 1fr 1fr; }
  .foot-grid{ grid-template-columns: 1fr 1fr; }
  .works-grid{ grid-template-columns: repeat(2, 1fr); }
  .drawer{ width:100vw;}
  .section-head{ grid-template-columns: 1fr; gap:12px;}
  .artist-list .row{ grid-template-columns: 30px 1fr 60px; gap:14px;}
  .artist-list .row .place, .artist-list .row .born, .artist-list .row .tag{ display:none;}
  .fair-row{ grid-template-columns: 1fr;}
}

/* ===== Utility ===== */
.spacer-lg{ height:96px; }
.spacer-md{ height:48px; }
.muted{ color:var(--muted); }
.accent{ color:var(--accent); }
.divider-dot{ color:var(--secondary); margin:0 8px;}
