/* ————————————————————————————————————————————————————————————
   Echo Arts Exhibitions — shared exhibition page styles
   Canonical template CSS for all individual exhibition pages.
   Show-specific overrides (accent color, custom grids, etc.)
   belong in the page's inline <style> block.
   ———————————————————————————————————————————————————————————— */

:root {
  --display: "Cormorant Garamond", Georgia, serif;
}
body { background: var(--bg); overflow-x: hidden; }

/* ============== MASTHEAD ============== */
.mast {
  padding: 140px var(--gutter) clamp(40px, 6vh, 64px);
  border-bottom: 1px solid var(--ink);
}
.mast .inner { max-width: var(--maxw); margin: 0 auto; }
.mast .top {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: baseline;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding-bottom: clamp(40px, 6vh, 64px);
}
.mast .top .num {
  color: var(--accent);
  font-family: var(--display);
  font-style: italic;
  font-size: 18px;
  letter-spacing: 0;
  text-transform: none;
}
.mast .top .pulse {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
}
.mast .top .pulse .dot {
  width: 7px; height: 7px;
  background: var(--accent);
  border-radius: 50%;
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.8); }
}
.mast h1 {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(3rem, 9vw, 11rem);
  line-height: 0.86;
  letter-spacing: -0.035em;
  color: var(--ink);
}
.mast h1 em {
  font-style: italic;
  color: var(--accent);
  display: block;
  margin-left: 0.06em;
  font-size: 0.7em;
  line-height: 1;
  margin-top: 0.08em;
}
.mast .byline {
  margin-top: clamp(40px, 5vh, 56px);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--rule);
}
.mast .byline .k {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-mute); margin-bottom: 8px;
}
.mast .byline .v {
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: clamp(1.05rem, 1.3vw, 1.3rem); line-height: 1.25;
}
.mast .byline .v a { color: var(--accent); border-bottom: 1px solid currentColor; }
@media (max-width: 800px) { .mast .byline { grid-template-columns: 1fr 1fr; } }

/* ============== HERO IMAGE ============== */
.lead {
  padding: 0 var(--gutter);
  margin: clamp(40px, 6vh, 64px) auto;
  max-width: var(--maxw);
}
.lead figure { margin: 0; }
.lead .frame {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: var(--bg-soft);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.lead .frame img { width: 100%; height: 100%; object-fit: cover; }
.lead figcaption {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}
.lead figcaption em {
  font-family: inherit; font-style: normal; font-size: inherit;
  letter-spacing: inherit; text-transform: inherit; color: inherit;
}

/* ============== STATEMENT — drop cap ============== */
.stmt {
  padding: clamp(100px, 14vh, 160px) var(--gutter);
  border-top: 1px solid var(--ink);
}
.stmt .inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 2.4fr;
  gap: clamp(40px, 5vw, 100px);
}
.stmt .head .label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.stmt .head h2 {
  margin-top: 16px;
  font-family: var(--display);
  font-weight: 300;
  font-style: italic;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  text-wrap: balance;
}
.stmt .head .sig {
  margin-top: 32px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  line-height: 1.7;
}
.stmt .body {
  font-family: var(--display);
  font-weight: 300;
  font-size: clamp(1.25rem, 1.5vw, 1.5rem);
  line-height: 1.45;
  color: var(--ink);
  max-width: 56ch;
}
.stmt .body em { font-style: italic; }
.stmt .body p + p { margin-top: 1em; }
.stmt .body p:first-child::first-letter {
  font-style: italic;
  font-weight: 400;
  float: left;
  font-size: 5.4em;
  line-height: 0.85;
  padding: 0.05em 0.12em 0 0;
  color: var(--accent);
}
.stmt .pull {
  display: block;
  margin: 1em 0;
  font-style: italic;
  font-size: clamp(1.8rem, 3.6vw, 3.2rem);
  line-height: 1.05;
  color: var(--accent);
  text-wrap: balance;
  max-width: 18ch;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 0.7em 0;
}
@media (max-width: 900px) { .stmt .inner { grid-template-columns: 1fr; } }

/* ============== WORKS — tile grid ============== */
.works {
  padding: 0 var(--gutter) clamp(120px, 16vh, 180px);
  border-top: 1px solid var(--ink);
}
.works .head {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(20px, 4vw, 60px);
  align-items: end;
  padding: clamp(60px, 8vh, 100px) 0 clamp(40px, 6vh, 60px);
}
.works .head .num {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem); line-height: 1;
  letter-spacing: -0.01em;
}
.works .head .meta {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-mute); text-align: right; line-height: 1.7;
}
.grid {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: clamp(20px, 2.5vw, 40px);
  row-gap: clamp(40px, 6vh, 72px);
}
.work {
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-decoration: none;
  color: inherit;
  cursor: zoom-in;
  background: none;
  border: none;
  padding: 0;
  text-align: left;
  font: inherit;
}
.work .tile {
  aspect-ratio: 4 / 5;
  background: oklch(95% 0.003 80);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
  transition: background .3s;
  margin-bottom: 8px;
}
.work .tile img {
  max-width: 80%;
  max-height: 80%;
  object-fit: contain;
  transition: transform 0.5s cubic-bezier(.2,.6,.2,1);
  box-shadow: 0 6px 18px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);
}
.work:hover .tile { background: oklch(92% 0.004 80); }
.work:hover .tile img { transform: scale(1.03); }
.work .num {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ink-mute);
}
.work .ttl {
  font-family: var(--display); font-style: italic; font-weight: 400;
  font-size: clamp(0.95rem, 1.05vw, 1.05rem); line-height: 1.18;
}
.work .det {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute); line-height: 1.55;
}
@media (max-width: 800px) {
  .grid { grid-template-columns: repeat(2, 1fr); row-gap: 40px; }
}
@media (max-width: 520px) {
  .grid { grid-template-columns: 1fr; }
}

/* ============== LIGHTBOX ============== */
.lb {
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(40px, 6vh, 80px) clamp(24px, 4vw, 80px);
  opacity: 0;
  transition: opacity .3s;
}
.lb.open { display: flex; opacity: 1; }
.lb-stage {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: clamp(24px, 4vw, 60px);
  width: 100%;
  max-width: 1400px;
  max-height: 100%;
  align-items: center;
}
.lb-img {
  background: var(--bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.lb-img img {
  max-width: 100%;
  max-height: 75vh;
  object-fit: contain;
  box-shadow: 0 12px 36px rgba(0,0,0,.3);
}
.lb-meta {
  color: var(--ink);
  align-self: end;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.lb-meta .num {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute);
}
.lb-meta .ttl {
  font-family: var(--display); font-style: italic; font-weight: 300;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
}
.lb-meta .det {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute); line-height: 1.7;
}
.lb-meta .inquire {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.22em; text-transform: uppercase;
  padding: 14px 22px; border: 1px solid var(--ink);
  color: var(--ink); text-decoration: none;
  align-self: start; margin-top: 10px;
  transition: background .2s, color .2s;
}
.lb-meta .inquire:hover { background: var(--ink); color: var(--bg); }
.lb-close {
  position: absolute; top: 24px; right: 24px;
  width: 48px; height: 48px;
  background: transparent;
  border: 1px solid var(--ink);
  color: var(--ink);
  border-radius: 50%;
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.lb-close:hover { background: var(--ink); color: var(--bg); }
.lb-nav {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px;
  border-radius: 50%;
  border: 1px solid var(--ink);
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.lb-nav:hover { background: var(--ink); color: var(--bg); }
.lb-nav.prev { left: 24px; }
.lb-nav.next { right: 24px; }
.lb-counter {
  position: absolute; left: 50%; transform: translateX(-50%);
  bottom: 24px;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute);
}
@media (max-width: 900px) {
  .lb-stage { grid-template-columns: 1fr; gap: 20px; }
  .lb-img img { max-height: 55vh; }
  .lb-nav { top: auto; bottom: 24px; transform: none; }
  .lb-counter { display: none; }
}

/* ============== INSTALLATION VIEWS — carousel (optional) ============== */
.install {
  padding: clamp(60px, 8vh, 100px) 0 clamp(120px, 16vh, 180px);
  border-top: 1px solid var(--ink);
}
.install-head {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex; align-items: end; justify-content: space-between;
  gap: 40px;
  margin-bottom: clamp(40px, 6vh, 60px);
}
.install-head .lbl {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-mute);
  margin-bottom: 14px;
}
.install-head h3 {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem); line-height: 1; letter-spacing: -0.01em;
  margin: 0;
}
.install-nav { display: flex; gap: 10px; flex-shrink: 0; }
.install-nav button {
  width: 56px; height: 56px; border-radius: 50%;
  border: 1px solid var(--ink); background: transparent;
  cursor: pointer; color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s, color 0.2s, opacity 0.2s;
  padding: 0; font: inherit;
}
.install-nav button:hover:not(:disabled) { background: var(--ink); color: var(--paper); }
.install-nav button:disabled { opacity: 0.3; cursor: not-allowed; }
.install-nav button svg { width: 20px; height: auto; display: block; }
.install-track-wrap { overflow: hidden; padding-left: var(--gutter); }
.install-track {
  display: flex; gap: 16px;
  transition: transform 0.7s cubic-bezier(0.7, 0, 0.2, 1);
  will-change: transform;
}
.install-slide { flex: 0 0 auto; position: relative; }
.install-slide.size-l { width: clamp(560px, 62vw, 980px); height: clamp(380px, 56vh, 620px); }
.install-slide.size-m { width: clamp(420px, 44vw, 700px); height: clamp(380px, 56vh, 620px); }
.install-slide.size-p { width: clamp(320px, 32vw, 480px); height: clamp(380px, 56vh, 620px); }
.install-slide .ph {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(135deg, oklch(94% 0.005 60) 0 14px, oklch(96% 0.004 60) 14px 28px);
  border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
}
.install-slide .ph span {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute);
  padding: 6px 14px; border: 1px solid var(--ink-mute);
  background: rgba(255,255,255,0.5);
}
.install-slide > img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  background: var(--bg-soft);
}
.install-cap {
  max-width: var(--maxw); margin: clamp(28px, 4vh, 40px) auto 0;
  padding: 0 var(--gutter);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-mute);
}
.install-cap .count { color: var(--ink); }
@media (max-width: 800px) {
  .install-slide.size-l,
  .install-slide.size-m,
  .install-slide.size-p { width: 86vw; height: 60vh; }
  .install-nav button { width: 44px; height: 44px; }
}

/* ============== ABOUT ============== */
.about {
  padding: clamp(100px, 14vh, 160px) var(--gutter);
  border-top: 1px solid var(--ink);
  background: var(--bg-soft);
}
.about .inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(40px, 5vw, 100px);
}
.about .label {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-mute);
}
.about h3 {
  margin-top: 14px;
  font-family: var(--display); font-weight: 300;
  font-size: clamp(2.2rem, 4.5vw, 4.2rem);
  line-height: 0.95; letter-spacing: -0.02em; text-wrap: balance;
}
.about h3 em { font-style: italic; color: var(--accent); }
.about .bio {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(1.15rem, 1.4vw, 1.4rem);
  line-height: 1.45; max-width: 56ch;
}
.about .bio p + p { margin-top: 1em; }
.about .cv {
  margin-top: 36px; padding-top: 28px;
  border-top: 1px solid var(--rule);
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px 40px;
}
.about .cv .k {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px;
}
.about .cv .v {
  font-family: var(--display); font-style: italic;
  font-size: clamp(1rem, 1.15vw, 1.15rem); line-height: 1.4;
}
@media (max-width: 900px) { .about .inner { grid-template-columns: 1fr; } }

/* ============== INQUIRE ============== */
.inquire {
  padding: clamp(100px, 14vh, 160px) var(--gutter);
  border-top: 1px solid var(--ink);
}
.inquire .inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1.4fr auto;
  gap: clamp(40px, 5vw, 80px); align-items: end;
}
.inquire h2 {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(2.4rem, 5vw, 5.4rem);
  line-height: 0.92; letter-spacing: -0.025em; text-wrap: balance;
}
.inquire h2 em { font-style: italic; color: var(--accent); }
.inquire .actions { display: flex; flex-direction: column; gap: 10px; }
.inquire .actions a {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em;
  text-transform: uppercase; padding: 18px 28px;
  border: 1px solid var(--ink); border-radius: 100px;
  text-align: center; transition: all 0.3s;
}
.inquire .actions a.solid {
  background: var(--ink); color: var(--bg);
}
.inquire .actions a.solid:hover { background: var(--accent); border-color: var(--accent); }
.inquire .actions a.outline:hover { background: var(--ink); color: var(--bg); }
@media (max-width: 800px) { .inquire .inner { grid-template-columns: 1fr; } }

/* ============== NEXT EXHIBITION (optional) ============== */
section.next {
  border-top: 1px solid var(--ink);
  padding: clamp(60px, 8vh, 100px) var(--gutter);
  background: oklch(72% 0.14 60);
  color: oklch(15% 0.02 60);
}
section.next .inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: end;
}
section.next .label {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase; color: oklch(28% 0.04 60); margin-bottom: 12px;
}
section.next h2 {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(1.8rem, 3.6vw, 3rem); line-height: 0.95;
  letter-spacing: -0.02em;
}
section.next h2 em { font-style: italic; color: oklch(35% 0.12 25); }
section.next .go {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em;
  text-transform: uppercase; padding: 14px 22px; border: 1px solid currentColor;
  border-radius: 100px; transition: all 0.3s;
  color: inherit; text-decoration: none;
}
section.next .go:hover { background: oklch(15% 0.02 60); color: oklch(72% 0.14 60); border-color: oklch(15% 0.02 60); }
@media (max-width: 700px) { section.next .inner { grid-template-columns: 1fr; } }

/* ============== VISIT FOOTER BAND ============== */
.visit {
  background: var(--bg-deep);
  color: var(--bg-paper);
  padding: clamp(100px, 14vh, 140px) var(--gutter) clamp(60px, 8vh, 80px);
  border-top: 1px solid var(--ink);
}
.visit .inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(40px, 6vw, 100px); align-items: start;
}
@media (max-width: 900px) { .visit .inner { grid-template-columns: 1fr; } }
.visit h2 {
  font-family: var(--display); font-weight: 300;
  font-size: clamp(2.6rem, 6vw, 6rem);
  line-height: 0.92; letter-spacing: -0.025em; text-wrap: balance;
  color: var(--bg-paper);
}
.visit h2 em { font-style: italic; color: var(--accent); }
.visit .blurb {
  font-family: var(--display); font-style: italic; font-weight: 300;
  font-size: clamp(1.1rem, 1.3vw, 1.3rem); line-height: 1.4;
  color: oklch(80% 0.005 60); margin-top: 32px; max-width: 50ch;
}
.visit-info { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 32px; }
.visit-info .k {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase; color: oklch(70% 0.005 60); margin-bottom: 8px;
}
.visit-info .v {
  font-family: var(--display); font-size: clamp(1rem, 1.2vw, 1.15rem);
  line-height: 1.4; color: var(--bg-paper);
}
.visit-actions { grid-column: 1 / -1; display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }
.visit-actions a {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.2em;
  text-transform: uppercase; padding: 14px 22px;
  border: 1px solid var(--bg-paper); border-radius: 100px;
  transition: background 0.3s, color 0.3s;
  color: var(--bg-paper); text-decoration: none;
}
.visit-actions a:hover { background: var(--accent); border-color: var(--accent); }
.visit-actions a.solid { background: var(--accent); border-color: var(--accent); }
.visit-actions a.solid:hover { background: var(--bg-paper); color: var(--bg-deep); border-color: var(--bg-paper); }
.visit-foot {
  max-width: var(--maxw); margin: clamp(80px, 12vh, 120px) auto 0;
  padding-top: 30px; border-top: 1px solid oklch(30% 0.005 60);
  display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: oklch(70% 0.005 60);
}
.visit-foot a { color: oklch(85% 0.005 60); }
.visit-foot a:hover { color: var(--accent); }
.visit-foot .sister {
  color: oklch(85% 0.005 60); border: 1px solid oklch(40% 0.005 60);
  padding: 10px 16px; border-radius: 100px; transition: all 0.3s;
  text-decoration: none;
}
.visit-foot .sister:hover { border-color: var(--accent); background: var(--accent); color: #fff; }
@media (max-width: 700px) { .visit-foot { grid-template-columns: 1fr; gap: 16px; } }

/* ═══ Prev / Next exhibition navigation ═══ */
.exnav {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(36px, 6vh, 64px) var(--gutter);
  border-top: 1px solid var(--ink);
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
}
.exnav a {
  display: flex; flex-direction: column; gap: 6px;
  color: inherit; text-decoration: none;
}
.exnav .exnav-next { text-align: right; align-items: flex-end; }
.exnav .k {
  font-family: var(--mono, ui-monospace, monospace); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 6px;
  transition: color 0.3s;
}
.exnav .artist {
  font-family: "Cormorant Garamond", Georgia, serif; font-weight: 400;
  font-size: clamp(1.2rem, 1.8vw, 1.6rem); line-height: 1.15;
  transition: color 0.3s;
}
.exnav .ttl {
  font-family: "Cormorant Garamond", Georgia, serif; font-style: italic; font-weight: 300;
  font-size: clamp(1rem, 1.3vw, 1.2rem); color: var(--ink-soft); line-height: 1.3;
}
.exnav a:hover .artist, .exnav a:hover .k { color: var(--accent); }
@media (max-width: 640px) {
  .exnav { grid-template-columns: 1fr; gap: 28px; }
  .exnav .exnav-next { text-align: left; align-items: flex-start; }
}

/* ═══ Selectable artwork captions ═══ */
.work .num, .work .ttl, .work .det {
  user-select: text;
  -webkit-user-select: text;
}

/* ═══ Installation slide expand affordance + lightbox ═══ */
.install-slide { position: relative; cursor: zoom-in; }
.install-slide::after {
  content: "+";
  position: absolute; top: 12px; right: 12px;
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono, ui-monospace, monospace); font-size: 20px; font-weight: 400;
  color: #fff; background: rgba(20, 20, 20, 0.35);
  border-radius: 50%;
  opacity: 0.55; transition: opacity 0.25s, background 0.25s;
  pointer-events: none;
}
.install-slide:hover::after { opacity: 1; background: rgba(20, 20, 20, 0.55); }
/* install lightbox caption */
#ilb .lb-meta .ttl { font-style: italic; }

/* ═══ Sahra design edits (Jun 2026) ═══ */
/* Byline: flex cluster (was 4-col grid) so 1–3 remaining fields sit naturally */
.mast .byline {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(30px, 5vw, 72px);
}
/* Inquire: no headline; center the two buttons */
.inquire .inner {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
}
.inquire .actions {
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
}
