/* ============================================================================
   PAGE SECTIONS  —  homepage strips + painting detail page
   Shared across all three directions (kept deliberately calm/consistent).
   ========================================================================== */

/* ---- Generic section spacing ------------------------------------------- */
.section { padding-block: clamp(2.5rem, 2rem + 4vw, 5.5rem); }
.section--sink { background: var(--paper-sink); border-block: 1px solid var(--line-soft); }

/* ---- Collection listing page ------------------------------------------- */
.breadcrumb { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.5rem;
  padding-top: clamp(1rem, 0.8rem + 0.8vw, 1.6rem);
  font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-soft); }
.breadcrumb a { color: var(--ink-soft); text-decoration: none; }
.breadcrumb a:hover { color: var(--ink); }
.breadcrumb__sep { color: var(--line); }
.breadcrumb__current { color: var(--ink); }
.collection-head { padding-top: clamp(1.25rem, 0.9rem + 1.4vw, 2rem);
  padding-bottom: clamp(1rem, 0.7rem + 1vw, 1.6rem); max-width: 72rem;
  margin-inline: auto; text-align: center; }
.collection-head .eyebrow { display: inline-block; white-space: nowrap; }
.collection-head__title { font-family: var(--serif); font-weight: 500; letter-spacing: -0.01em;
  font-size: clamp(2.4rem, 1.6rem + 3vw, 4rem); margin: 0.6rem 0 1.2rem; text-wrap: balance; }
.collection-head__statement { max-width: 90ch; margin-inline: auto; }
.collection-grid {
  columns: 3; column-gap: clamp(1.2rem, 0.8rem + 1.6vw, 2.4rem);
  padding-bottom: clamp(2rem, 1.5rem + 2vw, 3.5rem);
}
.collection-grid .pcard { break-inside: avoid; margin-bottom: clamp(1.8rem, 1.2rem + 2vw, 3.2rem);
  display: inline-block; width: 100%; }
.pcard__price { color: var(--ink-soft); }
@media (max-width: 900px) { .collection-grid { columns: 2; } }
@media (max-width: 520px) { .collection-grid { columns: 1; } }
/* Studies / plein-air: uniform small cards read better as real rows (3 across)
   than as balanced masonry columns. display:grid overrides the multicol above. */
.collection-grid--rows { display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.8rem, 1.2rem + 2vw, 3.2rem) clamp(1.2rem, 0.8rem + 1.6vw, 2.4rem);
  align-items: start; }
.collection-grid--rows .pcard { display: block; width: auto; margin-bottom: 0; }
@media (max-width: 900px) { .collection-grid--rows { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .collection-grid--rows { grid-template-columns: 1fr; } }

.collection-cta { text-align: center; padding-block: clamp(2.5rem, 2rem + 3vw, 4.5rem); }
.collection-cta__inner { max-width: 720px; margin-inline: auto; }
.collection-cta__note { color: var(--ink-soft); font-family: var(--serif); font-style: italic;
  font-size: var(--fs-lead); line-height: 1.5; margin: 0 0 1.4rem; text-wrap: pretty; }
/* The inquiry band closes the page — drop the footer's large top gap here. */
body:has(.collection-cta) .site-foot { margin-top: 0; }


/* ---- About strip -------------------------------------------------------- */
.about {
  display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem, 1rem + 4vw, 5rem);
  align-items: center;
}
.about__portrait { aspect-ratio: 4 / 5; }
.about__portrait .frame { height: 100%; }
.about__body h2 { font-family: var(--serif); font-size: var(--fs-h1); font-weight: 500; margin-bottom: 1.2rem; max-width: 16ch; }
.about__body p { color: var(--ink-soft); max-width: 46ch; font-size: var(--fs-lead); line-height: 1.6; }
.about__body .btn { margin-top: 1.6rem; }

/* ---- Exhibitions teaser ------------------------------------------------- */
.exhibits { display: grid; gap: 0; border-top: 1px solid var(--line); }
.exhibit {
  display: grid; grid-template-columns: 5rem 1fr minmax(11rem, auto); gap: clamp(1rem, 0.5rem + 2vw, 2.5rem);
  align-items: start; padding-block: 1.2rem; border-bottom: 1px solid var(--line-soft);
}
.exhibit__year { font-family: var(--serif); font-size: 1.4rem; color: var(--ink-mute); }
.exhibit__title { font-family: var(--serif); font-size: var(--fs-h3); font-weight: 500; }
.exhibit__kind { font-size: var(--fs-label); letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 0.3rem; }
.exhibit__venue { color: var(--ink-soft); font-size: 0.95rem; margin-top: 0.2rem; }
/* Quiet "More information" link — muted, with a small external arrow; underlines
   only on hover. Reads as a soft aside, not a call to leave the page. */
.exhibit__more { display: inline-block; margin-top: 0.5rem; font-size: var(--fs-small);
  color: var(--ink-mute); text-decoration: none;
  border-bottom: 1px solid transparent; transition: color 0.2s, border-color 0.2s; }
.exhibit__more::after { content: " \2197"; font-size: 0.85em; opacity: 0.65; }
.exhibit__more:hover, .exhibit__more:focus-visible {
  color: var(--ink); border-bottom-color: color-mix(in oklab, var(--ink) 28%, transparent); }
.exhibit__meta { text-align: right; display: grid; gap: 1rem; justify-items: end; }
.exhibit__dates { color: var(--ink-mute); font-size: var(--fs-small); white-space: nowrap; }
.exhibit__plan { display: grid; gap: 0.12rem; justify-items: end; text-align: right; }
.exhibit__plan-label { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-mute); }
.exhibit__plan > span:not(.exhibit__plan-label) { color: var(--ink-soft); font-size: var(--fs-small); }
.exhibit__now { display: inline-block; margin-left: 0.7rem; font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-deep);
  border: 1px solid color-mix(in oklab, var(--accent) 50%, transparent); padding: 0.18rem 0.45rem; vertical-align: middle; }
.exhibit__now--soon { color: var(--ink-soft); border-color: var(--line); }
.exhibit-group { margin-top: 0; }
.exhibit-group:first-of-type { margin-top: 0; }
.exhibit-group .section-head { margin-bottom: clamp(0.8rem, 0.5rem + 1vw, 1.4rem); }
.exhibit-group .exhibits { border-top: 1px solid var(--line); }
.exhibits .exhibit:last-child { border-bottom: 0; }
.exhibit__hours { display: grid; gap: 0.15rem; justify-items: end; text-align: right;
  padding-top: 0.85rem; border-top: 1px solid var(--line-soft); }
.exhibit__hours span { font-size: var(--fs-small); color: var(--ink-soft); font-variant-numeric: tabular-nums; white-space: nowrap; }
.exhibit__hours-label { font-size: var(--fs-label) !important; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-mute) !important; margin-bottom: 0.25rem; }

/* Opening reception block (right meta column) */
.exhibit__reception { display: grid; gap: 0.15rem; justify-items: end; text-align: right;
  padding-top: 0.85rem; border-top: 1px solid var(--line-soft); }
.exhibit__reception span { font-size: var(--fs-small); color: var(--ink-soft); white-space: nowrap; }
.exhibit__reception-label { font-size: var(--fs-label) !important; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--accent-deep) !important; margin-bottom: 0.25rem; }

/* Description / context line under the title */
.exhibit__desc, .exhibit-feature__desc { color: var(--ink-soft); font-size: 0.95rem; margin-top: 0.55rem;
  max-width: 46ch; font-style: italic; font-family: var(--serif); font-size: 1.05rem; line-height: 1.5; }
.exhibit-feature__desc { margin-top: 0.7rem; max-width: 52ch; }

/* ---- On-view feature card (rich) --------------------------------------- */
.exhibits-grouplabel { margin: clamp(1.5rem, 1rem + 1.5vw, 2.5rem) 0 0.2rem; }
.exhibits-grouplabel:first-child { margin-top: 0; }
.exhibit-feature--solo { grid-template-columns: 1fr; max-width: 760px; }

/* ---- Home Exhibitions: one shared two-column grid -----------------------
   The right column (section link, on-view gallery info, upcoming dates) is
   narrow and flush-right, aligning with the page's right-hand elements
   ("View painting →", the collections count). */
#exhibitions { --exh-cols: minmax(0, 1fr) minmax(11rem, 13.5rem);
  --exh-gap: clamp(1.5rem, 1rem + 2.5vw, 3.25rem); }
#exhibitions .section-head { display: grid; grid-template-columns: var(--exh-cols);
  gap: var(--exh-gap); align-items: baseline; }
#exhibitions .section-head .textlink { justify-self: end; }
#exhibitions .exhibit-feature { grid-template-columns: var(--exh-cols); gap: var(--exh-gap); }
#exhibitions .exhibit--lean-2col { display: grid; grid-template-columns: var(--exh-cols);
  gap: var(--exh-gap); align-items: start; padding-block: clamp(1.3rem, 1rem + 1vw, 2rem);
  border-bottom: 1px solid var(--line-soft); }
#exhibitions .exhibit--lean-2col:last-child { border-bottom: 0; }

/* right column: flush-right content */
#exhibitions .exhibit-feature__gallery { text-align: right; }
#exhibitions .exhibit-feature__gallery .exhibit-feature__venue,
#exhibitions .exhibit-feature__gallery .exhibit-feature__address { max-width: none; margin-left: auto; }
#exhibitions .exhibit-feature__gallery-hours .exhibit-feature__hours span { white-space: nowrap; }
#exhibitions .exhibit--lean-2col .exhibit__meta { text-align: right; justify-items: end;
  display: grid; gap: 0.3rem; }
#exhibitions .exhibit__dates-label { font-size: var(--fs-label); font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); }
#exhibitions .exhibit--lean-2col .exhibit__dates { color: var(--ink-soft); white-space: nowrap; }
#exhibitions .exhibits { border-top: 1px solid var(--line); }

@media (max-width: 720px) {
  #exhibitions .section-head,
  #exhibitions .exhibit--lean-2col { grid-template-columns: 1fr; gap: 0.6rem; }
  #exhibitions .section-head .textlink { justify-self: start; }
  #exhibitions .exhibit-feature__gallery { text-align: left; }
  #exhibitions .exhibit-feature__gallery .exhibit-feature__venue,
  #exhibitions .exhibit-feature__gallery .exhibit-feature__address { margin-left: 0; }
  #exhibitions .exhibit--lean-2col .exhibit__meta { text-align: left; justify-items: start; margin-top: 0.4rem; }
  #exhibitions .exhibit--lean-2col .exhibit__plan { justify-items: start; text-align: left; }
}

/* Gallery-info aside (homepage on-view card, right column) */
.exhibit-feature__gallery { align-self: start; }
.exhibit-feature__gallery .exhibit-feature__venue { font-family: var(--serif);
  font-size: var(--fs-lead); color: var(--ink); margin: 0.7rem 0 0; }
.exhibit-feature__gallery .exhibit-feature__address { color: var(--ink-soft);
  font-size: var(--fs-small); margin-top: 0.3rem; max-width: 26ch; line-height: 1.5; }
.exhibit-feature__gallery-hours { margin-top: 1.1rem; }
.exhibit-feature__gallery-hours .exhibit-feature__hours-label,
.exhibit-feature__hours-label { display: block; font-size: var(--fs-label); font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 0.4rem; }
.exhibit-feature__gallery-hours .exhibit-feature__hours span { display: block;
  font-size: var(--fs-small); color: var(--ink-soft); font-variant-numeric: tabular-nums; }
.exhibit-feature { display: grid; grid-template-columns: 1.15fr 0.85fr;
  gap: clamp(1.8rem, 1.2rem + 3vw, 4.5rem); align-items: start;
  padding-block: clamp(1.3rem, 1rem + 1vw, 2rem);
  border-top: 1px solid var(--line); }
.exhibit-feature .exhibit__now { margin-left: 0; }
#exhibitions .exhibit-feature { grid-template-columns: 1.4fr 1fr; }
.exhibit-feature__when { text-align: right; }
.exhibit-feature__when .exhibit-feature__facts { margin-top: 0; gap: 0.9rem; }
.exhibit-feature__when .exhibit-feature__facts > div { display: block; }
.exhibit-feature__when .exhibit-feature__facts dt { margin-bottom: 0.35rem; }
.exhibit-feature__when .exhibit-feature__facts dd { line-height: 1.45; }
.exhibit-feature__hours-facts dd { display: grid; gap: 0.12rem; font-variant-numeric: tabular-nums; }
.exhibit-feature__hours-facts dd span { display: block; }
.exhibit-feature__address { color: var(--ink-mute); font-size: var(--fs-small); margin: 0.35rem 0 0; }
.exhibit__org { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-mute); margin: 0 0 0.5rem; }
.exhibit-feature__kind { font-size: var(--fs-small); color: var(--ink-mute); margin: 0.4rem 0 0; }
.exhibit-feature__title { font-size: clamp(1.3rem, 1.05rem + 0.95vw, 1.75rem); font-weight: 500;
  line-height: 1.16; letter-spacing: -0.005em; margin: 0.5rem 0 0.35rem; text-wrap: balance; }
.exhibit-feature__venue { color: var(--ink); font-size: var(--fs-base); font-weight: 600; margin: 0.5rem 0 0; }
.exhibit-feature__kind + .exhibit-feature__venue { margin-top: 0.5rem; }
.exhibit-feature__venue + .exhibit-feature__address { margin-top: 0.2rem; }
.exhibit-feature__kind + .exhibit-feature__address { margin-top: 0.5rem; }
.exhibit-feature__address { color: var(--ink-mute); font-size: var(--fs-small); margin-top: 0.25rem; }
.exhibit-feature__facts { margin-top: clamp(1rem, 0.8rem + 0.8vw, 1.5rem);
  display: grid; gap: 0.45rem; }
.exhibit-feature__facts > div { display: grid; grid-template-columns: 5.5rem 1fr;
  gap: 0.9rem; align-items: baseline; }
.exhibit-feature__facts dt { font-size: var(--fs-label); font-weight: 700;
  letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-mute); }
.exhibit-feature__facts dd { margin: 0; color: var(--ink); font-size: var(--fs-small);
  line-height: 1.5; }

.exhibit-feature__aside-label { display: block; font-size: var(--fs-label); font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); }
.exhibit-feature__thumbs { display: grid; gap: clamp(0.7rem, 0.4rem + 1vw, 1.2rem); margin-top: 1rem; }
.exhibit-feature__thumbs[data-count="2"] { grid-template-columns: 1fr 1fr; }
.exhibit-feature__thumbs[data-count="3"] { grid-template-columns: 1fr 1fr 1fr; }
.exhibit-feature__thumbs[data-count="1"] { max-width: none; }
.exhibit-feature__thumb { display: block; }
.exhibit-feature__thumb-frame { display: block; overflow: hidden; }
.exhibit-feature__thumb-frame .frame { transition: transform 0.55s var(--ease); }
.exhibit-feature__thumb:hover .exhibit-feature__thumb-frame .frame { transform: scale(1.035); }
.exhibit-feature__thumb-cap { display: block; margin-top: 0.45rem; font-size: var(--fs-small);
  color: var(--ink-soft); font-family: var(--serif); font-style: italic; line-height: 1.3; }
.exhibit-feature__works-note { margin-top: 1rem; color: var(--ink-soft); font-family: var(--serif);
  font-style: italic; font-size: var(--fs-lead); max-width: 28ch; line-height: 1.45; }

/* ---- Lean line (upcoming / past) --------------------------------------- */
.exhibit__kind--after { text-transform: none; letter-spacing: 0.01em; font-size: var(--fs-small);
  color: var(--ink-soft); margin: 0.35rem 0 0; }
.exhibit--lean .exhibit__venue { margin-top: 0.3rem; }

@media (max-width: 860px) {
  .exhibit-feature,
  #exhibitions .exhibit-feature { grid-template-columns: 1fr; gap: 1.6rem; }
  /* Right-aligned "when" column reads left-aligned once stacked. */
  .exhibit-feature__when { text-align: left; }
}

/* ---- Inquire band ------------------------------------------------------- */
.cta-band { text-align: center; }
.cta-band h2 { font-family: var(--serif); font-size: var(--fs-h1); font-weight: 500; margin-bottom: 1rem; max-width: 20ch; margin-inline: auto; }
.cta-band p { color: var(--ink-soft); max-width: 42ch; margin-inline: auto; margin-bottom: 2rem; }
.cta-band__actions { display: flex; gap: 0.9rem; justify-content: center; flex-wrap: wrap; }

/* ---- Mailing-list signup ------------------------------------------------ */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }
.newsletter { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 1rem + 4vw, 5rem);
  align-items: center; }
.newsletter__intro h2 { font-family: var(--serif); font-size: var(--fs-h1); font-weight: 500;
  margin-bottom: 0.9rem; max-width: 14ch; }
.newsletter__blurb { color: var(--ink-soft); max-width: 42ch; font-size: var(--fs-lead); line-height: 1.55; }
.newsletter__form { width: 100%; }
.newsletter__row { display: flex; gap: 0.7rem; flex-wrap: wrap; }
.newsletter__input {
  flex: 1 1 14rem; min-width: 0; font-family: var(--sans); font-size: 1rem; color: var(--ink);
  background: var(--paper-2); border: 1px solid var(--line); border-radius: 1px;
  padding: 0.85rem 1rem; transition: border-color 0.25s var(--ease);
}
.newsletter__input::placeholder { color: var(--ink-mute); }
.newsletter__input:focus { outline: none; border-color: var(--accent); }
.newsletter__form .btn { flex: 0 0 auto; }
.newsletter__note { min-height: 1.2em; margin: 0.8rem 0 0; font-size: var(--fs-small); color: var(--ink-mute); }
.newsletter__note[data-state="ok"] { color: var(--accent-deep); }
.newsletter__note[data-state="error"] { color: oklch(0.5 0.12 28); }
@media (max-width: 760px) {
  .newsletter { grid-template-columns: 1fr; gap: 1.6rem; }
}

/* ============================================================================
   PAINTING DETAIL PAGE
   ========================================================================== */
.work { display: grid; grid-template-columns: 1.55fr 1fr; gap: clamp(2rem, 1rem + 4vw, 5rem);
  align-items: start; padding-top: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.work__media { position: sticky; top: 6rem;
  /* Trailing space so the media column (image + caption + any "On view at …"
     notice) never butts against the Acquire band when it is the taller column. */
  margin-bottom: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.work__media .frame { background: var(--paper-2); border: 1px solid var(--line-soft);
  box-shadow: 0 40px 80px -50px oklch(0.3 0.02 60 / 0.5); }
.work__media .frame img { height: auto; object-fit: contain; position: relative; }
.work__media .ph { background-image: repeating-linear-gradient(135deg,
  oklch(0.92 0.005 80) 0 14px, oklch(0.95 0.004 80) 14px 28px); }
.work__caption { margin-top: 0.9rem; font-size: clamp(0.95rem, 0.88rem + 0.35vw, 1.1rem); color: var(--ink-mute); font-style: italic; font-family: var(--serif); }
.work__caption strong { font-weight: 600; font-style: normal; color: var(--ink); }

/* "On view at …" — a quiet timely notice below the artwork caption */
.work__onview { display: flex; align-items: baseline; gap: 0.5rem; margin: 0.7rem 0 0;
  font-size: var(--fs-small); font-weight: 600; letter-spacing: 0.04em; color: var(--accent-deep); }
.work__onview-dot { flex: none; width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); align-self: center; }
.work__onview-when { font-weight: 400; color: var(--ink-mute); letter-spacing: 0.01em; }

/* Zoom trigger on the hero image */
.work__zoom { display: block; width: 100%; padding: 0; border: 0; background: none;
  cursor: zoom-in; position: relative; }
.work__zoom .frame { transition: filter 0.4s var(--ease); }
.work__zoom:hover .frame { filter: brightness(0.97); }
.work__zoom-hint { position: absolute; bottom: 0.9rem; right: 0.9rem; z-index: 3;
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-family: var(--sans); font-size: 0.66rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink); background: color-mix(in oklab, var(--paper-2) 88%, transparent);
  border: 1px solid var(--line); padding: 0.4rem 0.6rem; border-radius: 1px;
  opacity: 0; translate: 0 4px; transition: opacity 0.3s var(--ease), translate 0.3s var(--ease); }
.work__zoom:hover .work__zoom-hint,
.work__zoom:focus-visible .work__zoom-hint { opacity: 1; translate: 0 0; }
.work__zoom svg { display: block; }

/* ---- Lightbox ----------------------------------------------------------- */
.lightbox { position: fixed; inset: 0; z-index: 120;
  background: oklch(0.17 0.008 70 / 0.975);
  display: grid; place-items: center; padding: clamp(0.8rem, 0.4rem + 2vw, 2.5rem);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.32s var(--ease), visibility 0.32s var(--ease); }
.lightbox.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.lightbox__figure { margin: 0; position: relative; display: flex; flex-direction: column; align-items: center;
  max-width: 100%; max-height: 100%; }
.lightbox__stage { position: relative; height: 86vh; max-height: 86vh; max-width: 94vw;
  transform: scale(0.985); transition: transform 0.32s var(--ease);
  box-shadow: 0 40px 110px -30px rgba(0,0,0,0.7); }
.lightbox.is-open .lightbox__stage { transform: scale(1); }
.lightbox__stage .ph { position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, oklch(0.3 0.01 70) 0 16px, oklch(0.34 0.01 70) 16px 32px); }
.lightbox__stage .ph__tag { background: oklch(0.22 0.01 70 / 0.85); color: oklch(0.82 0.01 80);
  border-color: oklch(0.45 0.01 70); }
.lightbox__img { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain; display: block; }
/* subtle legend over the foot of the artwork */
.lightbox__legend { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  display: flex; flex-direction: column; gap: 0.25rem; text-align: left;
  padding: 2.4rem 1.6rem 1.1rem;
  background: linear-gradient(to top, oklch(0.12 0.01 70 / 0.82), transparent);
  opacity: 0; transition: opacity 0.4s var(--ease) 0.1s; }
.lightbox.is-open .lightbox__legend { opacity: 1; }
.lightbox__legend-title { color: oklch(0.97 0.005 85); font-size: 1.25rem; font-weight: 500; line-height: 1.1; }
.lightbox__legend-meta { color: oklch(0.84 0.006 82); font-size: var(--fs-small); letter-spacing: 0.01em;
  line-height: 1.4; text-wrap: pretty; }
.lightbox__close { position: fixed; top: clamp(0.8rem, 0.5rem + 1vw, 1.5rem); right: clamp(0.8rem, 0.5rem + 1vw, 1.5rem);
  z-index: 3; width: 2.9rem; height: 2.9rem; display: grid; place-items: center;
  border-radius: 50%; border: 1px solid oklch(0.5 0.01 70 / 0.5); cursor: pointer;
  background: oklch(0.22 0.01 70 / 0.6); color: oklch(0.92 0.005 82);
  transition: background 0.25s var(--ease), transform 0.25s var(--ease); }
.lightbox__close:hover { background: oklch(0.3 0.01 70 / 0.85); transform: rotate(90deg); }
@media (prefers-reduced-motion: reduce) {
  .lightbox, .lightbox__stage, .lightbox__legend { transition: none; }
  .lightbox__stage { transform: none; }
  .lightbox__close:hover { transform: none; }
}
@media (max-width: 700px) {
  .lightbox__stage { height: auto; max-height: 78vh; width: 94vw; }
  .lightbox__legend { position: static; opacity: 1; background: none;
    padding: 0.9rem 0.2rem 0; text-align: center; align-items: center; }
  .lightbox__legend-title { color: var(--paper); }
  .lightbox__legend-meta { color: oklch(0.8 0.006 82); }
}

.work__info { padding-top: 0.5rem; }
.work__collection { font-size: var(--fs-label); letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent-deep); margin-bottom: 0.9rem; }
.work__title { font-family: var(--serif); font-weight: 500;
  line-height: 1.06; letter-spacing: -0.01em; text-wrap: pretty; }
/* length tiers — long titles step down so they never sprawl, yet always stay
   larger than the year/story text that follows */
.work__title[data-len="s"] { font-size: clamp(2.2rem, 1.5rem + 2vw, 3rem); }
.work__title[data-len="m"] { font-size: clamp(1.9rem, 1.35rem + 1.6vw, 2.45rem); line-height: 1.08; }
.work__title[data-len="l"] { font-size: clamp(1.6rem, 1.25rem + 1vw, 2rem); line-height: 1.14; }
.work__series { font-family: var(--sans); font-size: var(--fs-label); font-weight: 700;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-mute); margin: 0.7rem 0 0; }
.work__series + .work__year { margin-top: 0.3rem; }
.work__year { font-family: var(--serif); font-style: italic; color: var(--ink-mute); font-size: 1.3rem; margin-top: 0.3rem; }

.work__status { display: flex; align-items: baseline; gap: 1rem; flex-wrap: wrap;
  margin: 1.6rem 0; padding: 1.1rem 0; border-block: 1px solid var(--line); }
.work__price { font-family: var(--serif); font-size: 1.7rem; color: var(--ink); }
.work__avail { font-size: var(--fs-small); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; }
.work__avail[data-state="for-sale"] { color: var(--accent-deep); }
.work__avail[data-state="sold"],
.work__avail[data-state="nfs"],
.work__avail[data-state="reserved"] { color: var(--ink-mute); }
.work__avail .dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); margin-right: 0.5rem; vertical-align: middle; }
.work__avail[data-state="sold"] .dot,
.work__avail[data-state="nfs"] .dot { background: var(--ink-mute); }
.work__avail[data-state="reserved"] .dot { background: var(--accent); opacity: 0.55; }

.work__cta { display: flex; gap: 0.8rem; flex-wrap: wrap; margin-bottom: 2rem; }
.work__story { color: var(--ink-soft); font-size: var(--fs-lead); line-height: 1.65; max-width: 42ch; margin-bottom: 2rem; }
/* A Spanish passage (e.g. a photo credit) set apart as a quiet aside. */
.work__story--es { font-style: italic; color: var(--ink-mute); font-size: 0.96rem; }
.work__label { margin-top: 0.5rem; }

/* Top meta row: collection eyebrow + availability hint */
.work__topline { display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem; margin-bottom: 0.9rem; }
.work__topline .work__collection { margin-bottom: 0; }

/* Availability hint → links down to the Acquire band */
.work__hint { display: inline-flex; align-items: center; gap: 0.5rem; flex: none;
  font-size: var(--fs-small); font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft); transition: color 0.25s var(--ease); }
.work__hint:hover { color: var(--accent-deep); }
.work__hint-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-mute); flex: none; }
.work__hint-dot[data-on="true"] { background: var(--accent); }
.work__hint-arrow { transition: transform 0.25s var(--ease); }
.work__hint:hover .work__hint-arrow { transform: translateY(2px); }

/* ---- Acquire band (sales, separated from the artwork) ------------------- */
.acquire { padding-block: clamp(2.5rem, 2rem + 3vw, 4.5rem); scroll-margin-top: 5rem; }
.acquire__inner { display: grid; grid-template-columns: minmax(0, 17rem) 1fr;
  gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: start; }
.acquire__head .eyebrow { margin-bottom: 0.8rem; }
.acquire__head h2 { font-family: var(--serif); font-size: var(--fs-h2); font-weight: 500; }
.acquire__note { color: var(--ink-soft); font-size: 0.98rem; max-width: 34ch; margin: 0; }
.acquire__options { display: flex; flex-direction: column; border-top: 1px solid var(--line); }
.acquire__row { display: grid; grid-template-columns: 1fr auto; gap: 1.2rem 2rem;
  align-items: center; padding: 1.5rem 0; border-bottom: 1px solid var(--line-soft); }
.acquire__row-main { display: flex; flex-direction: column; gap: 0.4rem; }
.acquire__kind { font-size: var(--fs-h3); font-weight: 500; }
.acquire__detail { font-size: var(--fs-small); color: var(--ink-mute); max-width: 44ch; line-height: 1.5; }
.acquire__buy { display: flex; align-items: center; gap: clamp(1rem, 0.6rem + 1.4vw, 2rem); }
.acquire__pricing { display: flex; flex-direction: column; gap: 0.2rem; align-items: flex-end; text-align: right; }
.acquire__price { font-size: 1.45rem; color: var(--ink); white-space: nowrap; }
.acquire__buy .btn { white-space: nowrap; }

@media (max-width: 980px) {
  .acquire__inner { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .acquire__row { grid-template-columns: 1fr; gap: 1rem; min-width: 0; }
  .acquire__buy { flex-wrap: wrap; justify-content: space-between; gap: 0.9rem 1.2rem; }
  .acquire__pricing { align-items: flex-start; text-align: left; }
  .acquire__buy .btn { flex: 1 1 100%; justify-content: center; }
}

/* ---- About page --------------------------------------------------------- */
.aboutpage { max-width: 1060px; margin-inline: auto;
  padding-top: clamp(2rem, 1.5rem + 3vw, 4rem);
  display: grid; grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  column-gap: clamp(2rem, 1rem + 4vw, 5rem); row-gap: 0;
  align-items: start; }
.aboutpage__body { grid-column: 1; grid-row: 1; }
.aboutpage__title { font-size: var(--fs-h1); line-height: 1.1; font-weight: 500;
  margin: 0 0 clamp(1.2rem, 1rem + 1vw, 2rem); }
.aboutpage__text p { color: var(--ink-soft); font-size: var(--fs-lead); line-height: 1.7;
  max-width: 60ch; margin: 0 0 1.2rem; }
.aboutpage__text p:first-child { color: var(--ink); font-size: clamp(1.3rem, 1.05rem + 1vw, 1.75rem);
  line-height: 1.5; margin-bottom: 1.6rem; }
.aboutpage__media { grid-column: 2; grid-row: 1 / span 2; margin: 0; max-width: 100%;
  position: sticky; top: clamp(2rem, 1rem + 4vw, 5rem); }
.aboutpage__media .frame { opacity: 0.82; box-shadow: 0 24px 50px -42px oklch(0.3 0.02 60 / 0.3);
  border: 1px solid var(--line-soft); }
.aboutpage__media figcaption { margin-top: 0.7rem; font-family: var(--serif); font-style: italic;
  font-size: var(--fs-small); color: var(--ink-mute); }
.aboutpage__cta { grid-column: 1; grid-row: 2;
  display: flex; gap: 0.8rem; flex-wrap: wrap; margin-top: clamp(2rem, 1.5rem + 1.5vw, 3rem); }
@media (max-width: 720px) {
  .aboutpage { display: block; max-width: 840px; }
  .aboutpage__media { position: static; max-width: 440px;
    margin: clamp(2.5rem, 2rem + 3vw, 4rem) 0 0; }
  .aboutpage__cta { flex-direction: column; align-items: stretch; }
}

/* ---- For Collectors page ----------------------------------------------- */
.collectors-overview { padding-block: clamp(0.5rem, 0.5rem + 1vw, 1.5rem) clamp(2.5rem, 2rem + 3vw, 4rem); }
.collectors-overview__inner { display: grid; grid-template-columns: 1fr minmax(170px, 230px);
  gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: start;
  max-width: 1000px; margin-inline: auto; }
.collectors-overview__text p { color: var(--ink-soft); font-size: var(--fs-lead);
  line-height: 1.7; margin: 0 0 1.1rem; }
.collectors-overview__text p:last-child { margin-bottom: 0; }
.collectors-jump { position: sticky; top: 6.5rem; display: flex; flex-direction: column;
  align-items: stretch; }
.collectors-jump__label { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-mute); text-align: right;
  margin-bottom: 0; padding-bottom: 0.9rem; border-bottom: 1px solid var(--line); }
.collectors-jump__link { display: flex; align-items: center; justify-content: flex-end;
  gap: 1rem; padding: 0.85rem 0; border-bottom: 1px solid var(--line-soft);
  font-family: var(--serif); font-size: 1.2rem; color: var(--ink); text-align: right;
  transition: color 0.22s var(--ease); }
.collectors-jump__link span { color: var(--ink-mute); transition: transform 0.25s var(--ease); }
.collectors-jump__link:hover { color: var(--accent-deep); }
.collectors-jump__link:hover span { transform: translateY(2px); color: var(--accent-deep); }

.collectors-section { padding-block: clamp(2.5rem, 2rem + 3vw, 4.5rem); scroll-margin-top: 5rem; }
.collectors-section__inner { display: grid; grid-template-columns: minmax(170px, 230px) 1fr;
  gap: clamp(1.5rem, 1rem + 3vw, 4rem); max-width: 1000px; margin-inline: auto;
  align-items: start; }
.collectors-section__title { position: sticky; top: 6.5rem; font-size: clamp(1.35rem, 1.15rem + 0.85vw, 1.85rem);
  font-weight: 500; line-height: 1.08; letter-spacing: -0.01em; margin: 0; }
.collectors-section__body { max-width: none; }
.collectors__subhead { font-size: clamp(1.2rem, 1.05rem + 0.5vw, 1.45rem); font-weight: 500;
  color: var(--ink); margin: 2rem 0 0.7rem; }
.collectors__subhead:first-child { margin-top: 0; }
.collectors__p { color: var(--ink-soft); font-size: var(--fs-body); line-height: 1.7; margin: 0 0 1rem; }
.collectors__lead { color: var(--ink); font-weight: 700; }
.collectors__list { margin: 0.4rem 0 1rem; display: grid; gap: 0.7rem; }
.collectors__list li { position: relative; padding-left: 1.4rem; color: var(--ink-soft);
  font-size: var(--fs-body); line-height: 1.65; }
.collectors__list li::before { content: ""; position: absolute; left: 0; top: 0.62em;
  width: 6px; height: 6px; background: var(--accent); border-radius: 50%; }

.collectors-cta { text-align: center;
  padding-block: clamp(2.5rem, 2rem + 3vw, 4.5rem); }
.collectors-cta__inner { max-width: 1000px; margin-inline: auto; }
/* The CTA already closes the page — trim the footer's large top gap here. */
body:has(.collectors-cta) .site-foot { margin-top: 0; }
.collectors-cta__note { color: var(--ink-soft); font-family: var(--serif); font-style: italic;
  font-size: var(--fs-lead); margin: 0 0 1.4rem; }

@media (max-width: 760px) {
  .collectors-overview__inner { grid-template-columns: 1fr; gap: 1.6rem; }
  .collectors-jump { position: static; }
  .collectors-section__inner { grid-template-columns: 1fr; gap: 0.8rem; }
  .collectors-section__title { position: static; }
}


/* Quiet links under the Acquire note (left column), stacked */
.acquire__links { margin: 1.2rem 0 0; font-size: var(--fs-small);
  display: flex; flex-direction: column; align-items: flex-start; gap: 0.55rem; }
.acquire__links a { white-space: nowrap; }
.acquire__links-sep { display: none; }

/* ---- Legal / prose pages (Privacy, Intellectual Property) -------------- */
.legal { max-width: 720px; margin-inline: auto;
  padding-top: clamp(0.5rem, 0.5rem + 1vw, 1.5rem); }
.legal__updated { font-size: var(--fs-small); letter-spacing: 0.06em; color: var(--ink-mute);
  margin-top: 0.9rem; }
.legal__lead { color: var(--ink); font-family: var(--serif);
  font-size: clamp(1.25rem, 1.05rem + 0.9vw, 1.65rem); line-height: 1.45;
  margin: 0 0 1.8rem; }
.legal__body .collectors__subhead { margin-top: 2.2rem; }
.legal__body .collectors__subhead:first-child { margin-top: 0; }

/* ---- Contact page ------------------------------------------------------- */
.contact { display: grid; grid-template-columns: 0.82fr 1.18fr;
  gap: clamp(2rem, 1.2rem + 4vw, 5rem); align-items: start;
  max-width: 1060px; margin-inline: auto;
  padding-top: clamp(0.5rem, 0.5rem + 1vw, 1.5rem);
  padding-bottom: clamp(1rem, 0.5rem + 2vw, 2.5rem); }
.contact__intro { position: sticky; top: 6.5rem; }
.contact__lead { color: var(--ink); font-family: var(--serif);
  font-size: clamp(1.3rem, 1.05rem + 1vw, 1.75rem); line-height: 1.45; margin: 0 0 1.8rem;
  text-wrap: balance; }
.contact__details { display: grid; gap: 0; border-top: 1px solid var(--line); }
.contact__detail { display: grid; gap: 0.3rem; padding: 1rem 0; border-bottom: 1px solid var(--line-soft); }
.contact__detail-label { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-mute); }
.contact__detail-value { color: var(--ink); }
.contact__copy { display: inline-flex; align-items: baseline; gap: 0.7rem; background: none; border: 0;
  padding: 0; cursor: pointer; font: inherit; color: var(--ink); text-align: left; }
.contact__copy-value { border-bottom: 1px solid var(--line); transition: border-color 0.2s var(--ease); }
.contact__copy:hover .contact__copy-value { border-color: var(--accent); }
.contact__copy-hint { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--accent-deep); }
.contact__copy[data-copied="true"] .contact__copy-hint { color: var(--ink-mute); }
.contact__social { display: flex; gap: 1.2rem; }
.contact__social a { border-bottom: 1px solid var(--line); transition: border-color 0.2s var(--ease), color 0.2s var(--ease); }
.contact__social a:hover { color: var(--accent-deep); border-color: var(--accent); }
.contact__response { margin: 1.3rem 0 0; font-family: var(--serif); font-style: italic;
  color: var(--ink-mute); font-size: var(--fs-small); }

.contact-form { display: grid; gap: 1.1rem; }
.contact-form[hidden] { display: none; }
.contact-form__bot { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { display: grid; gap: 0.4rem; }
.field__label { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute); }
.field input, .field textarea, .field select { font: inherit; color: var(--ink); background: var(--paper-2);
  border: 1px solid var(--line); border-radius: 2px; padding: 0.75rem 0.85rem;
  transition: border-color 0.2s var(--ease), box-shadow 0.2s var(--ease); width: 100%; resize: none; }
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 16%, transparent); }
.field input[readonly] { background: var(--paper); color: var(--ink-soft); cursor: default; }
.field input[readonly]:focus { border-color: var(--line); box-shadow: none; }
.field-check { display: flex; gap: 0.7rem; align-items: flex-start; cursor: pointer;
  font-size: var(--fs-small); color: var(--ink-soft); line-height: 1.5; margin-top: 0.2rem; }
.field-check input { margin-top: 0.2rem; accent-color: var(--accent); width: 1rem; height: 1rem; flex: none; }
.contact-form__foot { display: flex; align-items: center; gap: 1.2rem; flex-wrap: wrap; margin-top: 0.4rem; }
.contact-form__status { margin: 0; font-size: var(--fs-small); color: var(--ink-mute); }
.contact-form__status[data-state="error"] { color: var(--accent-deep); }
.contact-form__status[data-state="ok"] { color: var(--ink); }
.contact-form__privacy { margin: 0.3rem 0 0; font-size: var(--fs-small); color: var(--ink-mute); line-height: 1.5; }
.contact-form__thanks { padding: 2rem 0; }
.contact-form__thanks-title { margin: 0 0 0.5rem; font-size: 1.5rem; color: var(--ink); }
.contact-form__thanks-body { margin: 0; color: var(--ink-mute); line-height: 1.6; }

/* Purchase inquiry form */
.inquire-fieldset { display: grid; gap: 1.1rem; margin: 0; padding: 1rem 1.1rem 1.2rem;
  border: 1px solid var(--line); border-radius: 4px; background: var(--paper); }
.inquire-fieldset > legend.field__label { padding: 0 0.45rem; }
.inquire-note { margin: 0; font-size: var(--fs-small); color: var(--ink-mute); line-height: 1.5; }
.inquire-framing { display: grid; gap: 1.1rem; }
/* display:grid above beats the bare [hidden] attribute — restore it so site.js
   can toggle the framing-choice and already-framed variants. */
.inquire-framing[hidden], .inquire-spec[hidden] { display: none; }
.inquire-spec { display: grid; gap: 0.3rem; padding: 0.85rem 1rem;
  background: var(--paper); border-left: 2px solid var(--accent); border-radius: 2px; }
.inquire-spec__label { font-size: var(--fs-label); font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute); }
.inquire-spec__detail { margin: 0; color: var(--ink); font-weight: 600; }
.inquire-spec__detail:empty { display: none; }
.inquire-spec__text { margin: 0; color: var(--ink-soft); line-height: 1.55; }
.field__opt { font-weight: 400; letter-spacing: 0; text-transform: none; color: var(--ink-soft); }
.inquire__back { margin: 0.7rem 0 0; font-size: var(--fs-small); }

@media (max-width: 760px) {
  .contact { grid-template-columns: 1fr; gap: 2.2rem; }
  .contact__intro { position: static; }
  .contact-form__row { grid-template-columns: 1fr; }
}

/* ---- More from collection (masonry — true ratios) ---------------------- */
.more { margin-top: clamp(3rem, 2rem + 4vw, 6rem); }
.more__grid { columns: 4; column-gap: clamp(1rem, 0.6rem + 1.4vw, 2rem); }
.more__grid .pcard { break-inside: avoid; margin-bottom: clamp(1rem, 0.6rem + 1.4vw, 2rem);
  display: inline-block; width: 100%; }
.pcard { display: block; }
.pcard__frame { position: relative; transition: transform 0.5s var(--ease); }
.pcard:hover .pcard__frame { transform: translateY(-4px); }
.pcard__title { font-family: var(--serif); font-size: 1.1rem; font-weight: 500; margin-top: 0.7rem; }
.pcard__spec { font-size: var(--fs-small); color: var(--ink-soft); margin: 0.35rem 0 0; line-height: 1.4; }
.pcard__price { font-size: var(--fs-small); color: var(--ink-mute); margin: 0.35rem 0 0; }
/* Quiet "Prints available" cue, shown where the price would be once the original
   is no longer for sale. Italic serif keeps it a soft aside, not a sales shout. */
.pcard__prints { font-size: var(--fs-small); color: var(--ink-mute); margin: 0.35rem 0 0;
  font-family: var(--serif); font-style: italic; }
.pcard__state { font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  font-size: 0.7rem; color: var(--ink-mute); }

/* Study / plein-air cards — informational, not clickable */
.pcard--note { cursor: default; }
.pcard--note:hover .pcard__frame { transform: none; }
.pcard__kind { font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute); margin: 0.7rem 0 0; }
.pcard--note .pcard__title { margin-top: 0.15rem; }
.pcard__note-info { font-size: var(--fs-small); color: var(--ink-soft); font-style: italic;
  margin: 0.35rem 0 0; line-height: 1.45; }

@media (max-width: 860px) {
  .about { grid-template-columns: 1fr; }
  .work { grid-template-columns: 1fr; }
  /* Stacked layout: the grid row-gap already separates image from details, so
     drop the desktop-only trailing space. */
  .work__media { position: static; margin-bottom: 0; }
  .more__grid { columns: 2; }
  .exhibit { grid-template-columns: 3.5rem 1fr; }
  .exhibit__meta { grid-column: 2; text-align: left; justify-items: start; margin-top: 0.6rem; }
  .exhibit__hours { justify-items: start; text-align: left; }
  .exhibit__plan { justify-items: start; text-align: left; }
}
@media (max-width: 480px) {
  .more__grid { columns: 2; }
}
