/* =============================================================
   ULYSSES DE SANTI — Brazilian Modernist Design Dealer & Curator
   Design system. Warm, editorial, luxury. Built for legibility.
   ============================================================= */

/* ---------- Design tokens ---------- */
:root{
  /* Warm ivory / bone palette (brand) */
  --bg:        #F4ECDD;
  --bg-2:      #EFE6D4;
  --bg-3:      #EAE0CC;
  --paper:     #FBF7EE;
  --paper-2:   #F7F0E2;

  /* Espresso inks (warm, readable near-black) */
  --ink:       #251D15;
  --ink-2:     #564B3D;
  --ink-3:     #877B69;
  --ink-on-dark: #F1E8D8;

  /* Brazilian modernist accents */
  --forest:    #3C5A45;
  --olive:     #5E6F61;
  --terra:     #A1502F;
  --terra-2:   #C07E60;
  --gold:      #9A6B20;
  --gold-2:    #BC8838;
  --gold-soft: #D8BE86;

  /* Dark surfaces */
  --dark:      #211A12;
  --dark-2:    #2C2318;
  --dark-3:    #38301F;

  --line:      rgba(37,29,21,.14);
  --line-2:    rgba(37,29,21,.08);
  --line-light: rgba(241,232,216,.18);

  /* Type */
  --serif: "Fraunces", "Hoefler Text", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

  /* Rhythm */
  --container: 1280px;
  --container-wide: 1480px;
  --container-narrow: 820px;
  --gutter: clamp(20px, 5vw, 64px);
  --section: clamp(72px, 11vw, 168px);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --radius: 4px;

  --nav-h: 78px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--sans);
  font-size:clamp(16.5px, 1.05vw + 13px, 19px);
  line-height:1.72;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"kern" 1, "liga" 1, "calt" 1;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,video,svg{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul,ol{ list-style:none; }
::selection{ background:var(--gold-soft); color:var(--ink); }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; line-height:1.06; letter-spacing:-.012em; color:var(--ink); }
.display{
  font-size:clamp(2.7rem, 7.4vw, 6.6rem);
  line-height:.98; letter-spacing:-.02em; font-weight:400;
}
h1{ font-size:clamp(2.4rem, 5.6vw, 4.7rem); }
h2{ font-size:clamp(2rem, 3.9vw, 3.5rem); }
h3{ font-size:clamp(1.4rem, 2.3vw, 2.05rem); line-height:1.12; }
h4{ font-size:clamp(1.15rem, 1.6vw, 1.4rem); line-height:1.2; }
p{ font-size:1rem; }
strong{ font-weight:600; }
em{ font-style:italic; }

.lead{
  font-size:clamp(1.18rem, 1.7vw, 1.62rem);
  line-height:1.5; color:var(--ink-2); font-weight:400;
  letter-spacing:-.005em;
}
.serif-lead{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(1.5rem, 3vw, 2.5rem);
  line-height:1.28; letter-spacing:-.01em; color:var(--ink);
}

/* Eyebrow / kicker */
.eyebrow{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-weight:600;
  font-size:.72rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:currentColor; opacity:.7;
}
.eyebrow.no-line::before{ display:none; }
.eyebrow.centered{ justify-content:center; }

.muted{ color:var(--ink-2); }
.text-balance{ text-wrap:balance; }
.text-pretty{ text-wrap:pretty; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container.wide{ max-width:var(--container-wide); }
.container.narrow{ max-width:var(--container-narrow); }
.section{ padding-block:var(--section); }
.section.tight{ padding-block:clamp(54px, 7vw, 104px); }
.bg-paper{ background:var(--paper); }
.bg-2{ background:var(--bg-2); }
.bg-dark{ background:var(--dark); color:var(--ink-on-dark); }
.bg-forest{ background:var(--forest); color:var(--ink-on-dark); }
.center{ text-align:center; }
.divider{ height:1px; background:var(--line); border:0; }
.flow > * + *{ margin-top:1.1em; }
.flow-lg > * + *{ margin-top:1.5em; }

.section-head{ max-width:760px; }
.section-head.centered{ margin-inline:auto; text-align:center; }
.section-head .eyebrow{ margin-bottom:1.4rem; }
.section-head h2 + p, .section-head p.lead{ margin-top:1.5rem; }

/* ---------- Buttons / links ---------- */
.btn{
  --c:var(--ink);
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-weight:600; font-size:.82rem;
  letter-spacing:.12em; text-transform:uppercase;
  padding:1.05em 1.9em; border-radius:50px;
  border:1px solid var(--ink);
  color:var(--paper); background:var(--ink);
  transition:background .5s var(--ease), color .5s var(--ease), border-color .5s var(--ease), transform .5s var(--ease);
  will-change:transform;
}
.btn:hover{ background:transparent; color:var(--ink); transform:translateY(-2px); }
.btn .arrow{ transition:transform .5s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn.ghost{ background:transparent; color:var(--ink); }
.btn.ghost:hover{ background:var(--ink); color:var(--paper); }
.btn.on-dark{ border-color:var(--gold-soft); background:var(--gold-soft); color:var(--dark); }
.btn.on-dark:hover{ background:transparent; color:var(--gold-soft); }
.btn.gold{ background:var(--gold); border-color:var(--gold); color:#fff; }
.btn.gold:hover{ background:transparent; color:var(--gold); }

.link-arrow{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--sans); font-weight:600; font-size:.8rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--ink);
  padding-bottom:4px; position:relative;
}
.link-arrow::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.link-arrow:hover::after{ transform:scaleX(1); }
.link-arrow .arrow{ transition:transform .45s var(--ease); }
.link-arrow:hover .arrow{ transform:translateX(5px); }
.link-arrow.gold{ color:var(--gold); }

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:120; height:var(--nav-h);
  display:flex; align-items:center;
  transition:background .6s var(--ease), box-shadow .6s var(--ease), height .4s var(--ease);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:2rem; max-width:var(--container-wide); }
.brand{
  font-family:var(--serif); font-weight:400; font-size:1.18rem;
  letter-spacing:.04em; color:var(--ink); white-space:nowrap;
  transition:color .5s var(--ease); line-height:1;
}
.brand .sub{
  display:block; font-family:var(--sans); font-weight:500;
  font-size:.56rem; letter-spacing:.34em; text-transform:uppercase;
  opacity:.72; margin-top:.42em;
}
.nav{ display:flex; align-items:center; gap:2.1rem; }
.nav a{
  font-family:var(--sans); font-weight:500; font-size:.82rem;
  letter-spacing:.04em; color:var(--ink); position:relative; padding:.4em 0;
  transition:color .4s var(--ease); white-space:nowrap;
}
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:currentColor; transform:scaleX(0); transform-origin:center;
  transition:transform .45s var(--ease);
}
.nav a:hover::after, .nav a.current::after{ transform:scaleX(1); }
.nav .nav-cta{
  font-weight:600; border:1px solid var(--line); border-radius:40px;
  padding:.65em 1.3em; letter-spacing:.1em; text-transform:uppercase; font-size:.72rem;
}
.nav .nav-cta::after{ display:none; }
.nav .nav-cta:hover{ background:var(--gold-soft); color:var(--dark); border-color:var(--gold-soft); }

/* dark-hero pages: header is light text over the hero, until scrolled */
.dark-hero .site-header:not(.solid) .brand,
.dark-hero .site-header:not(.solid) .nav a{ color:var(--ink-on-dark); }
.dark-hero .site-header:not(.solid) .nav .nav-cta{ border-color:var(--line-light); }
.dark-hero .site-header:not(.solid) .burger span{ background:var(--ink-on-dark); }

/* scrolled / solid state */
.site-header.solid{
  background:rgba(248,243,233,.86);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  box-shadow:0 1px 0 var(--line), 0 12px 40px -28px rgba(37,29,21,.5);
  height:66px;
}
.site-header.solid .brand,
.site-header.solid .nav a{ color:var(--ink); }
.site-header.solid .nav .nav-cta{ border-color:var(--line); }
.site-header.solid .nav .nav-cta:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.site-header.solid .burger span{ background:var(--ink); }

/* mobile burger */
.burger{ display:none; width:42px; height:42px; position:relative; z-index:130; }
.burger span{
  position:absolute; left:9px; right:9px; height:1.6px; background:var(--ink);
  transition:transform .4s var(--ease), opacity .3s var(--ease), background .4s var(--ease);
}
.burger span:nth-child(1){ top:15px; }
.burger span:nth-child(2){ top:21px; }
.burger span:nth-child(3){ top:27px; }
body.menu-open .burger span:nth-child(1){ transform:translateY(6px) rotate(45deg); background:var(--ink); }
body.menu-open .burger span:nth-child(2){ opacity:0; }
body.menu-open .burger span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); background:var(--ink); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:115; background:var(--paper);
  padding:calc(var(--nav-h) + 24px) var(--gutter) 40px;
  display:flex; flex-direction:column; justify-content:space-between;
  transform:translateY(-100%); opacity:0; visibility:hidden;
  transition:transform .7s var(--ease-out), opacity .5s var(--ease), visibility .7s;
  overflow-y:auto;
}
body.menu-open .drawer{ transform:translateY(0); opacity:1; visibility:visible; }
.drawer-nav a{
  display:block; font-family:var(--serif); font-weight:400;
  font-size:clamp(1.7rem, 7vw, 2.6rem); color:var(--ink);
  padding:.32em 0; border-bottom:1px solid var(--line-2);
  opacity:0; transform:translateY(18px);
}
body.menu-open .drawer-nav a{ animation:drawerIn .6s var(--ease-out) forwards; }
body.menu-open .drawer-nav a:nth-child(1){ animation-delay:.12s; }
body.menu-open .drawer-nav a:nth-child(2){ animation-delay:.17s; }
body.menu-open .drawer-nav a:nth-child(3){ animation-delay:.22s; }
body.menu-open .drawer-nav a:nth-child(4){ animation-delay:.27s; }
body.menu-open .drawer-nav a:nth-child(5){ animation-delay:.32s; }
body.menu-open .drawer-nav a:nth-child(6){ animation-delay:.37s; }
body.menu-open .drawer-nav a:nth-child(7){ animation-delay:.42s; }
body.menu-open .drawer-nav a:nth-child(8){ animation-delay:.47s; }
@keyframes drawerIn{ to{ opacity:1; transform:translateY(0); } }
.drawer-foot{ display:flex; flex-wrap:wrap; gap:1.4rem 2rem; align-items:center; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-2); }
.drawer-foot a{ color:var(--ink-2); }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:var(--ink-on-dark); overflow:hidden; isolation:isolate;
}
.hero.short{ min-height:78svh; }
.hero-media{ position:absolute; inset:0; z-index:-2; overflow:hidden; }
.hero-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.08); }
.hero.loaded .hero-media img{ animation:kenburns 18s ease-out forwards; }
@keyframes kenburns{ from{ transform:scale(1.16); } to{ transform:scale(1.02); } }
.hero-media::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(20,15,10,.30) 0%, rgba(20,15,10,.05) 32%, rgba(20,15,10,.12) 58%, rgba(20,15,10,.74) 100%);
}
.hero-inner{ width:100%; padding-bottom:clamp(48px, 8vh, 110px); padding-top:calc(var(--nav-h) + 30px); }
.hero .eyebrow{ color:var(--gold-soft); }
.hero-title{ color:#fff; max-width:15ch; margin-top:1.3rem; text-shadow:0 2px 30px rgba(0,0,0,.25); }
.hero-title .tl{ display:block; }
.hero-sub{
  margin-top:1.7rem; max-width:40ch; color:rgba(255,255,255,.92);
  font-size:clamp(1.05rem, 1.5vw, 1.35rem); line-height:1.5;
}
.hero-meta{
  margin-top:2.2rem; display:flex; flex-wrap:wrap; gap:1.4rem 2.4rem; align-items:center;
}
.hero-locations{
  display:flex; gap:1.6rem; font-family:var(--sans); font-weight:500;
  font-size:.76rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.82);
}
.hero-locations span{ display:inline-flex; align-items:center; gap:.6em; }
.hero-locations span::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--gold-soft); }
.scroll-cue{
  position:absolute; right:var(--gutter); bottom:26px; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.7em;
  font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:rgba(255,255,255,.7);
}
@media (max-width:700px){ .scroll-cue{ display:none; } }

/* Hero load animation (independent of JS, always resolves visible) */
.rise{ opacity:0; transform:translateY(26px); animation:rise 1.1s var(--ease-out) both; }
.rise.r1{ animation-delay:.12s; } .rise.r2{ animation-delay:.24s; } .rise.r3{ animation-delay:.36s; }
@keyframes rise{ to{ opacity:1; transform:none; } }
.scroll-cue .bar{ width:1px; height:46px; background:linear-gradient(rgba(255,255,255,.7), rgba(255,255,255,0)); position:relative; overflow:hidden; }
.scroll-cue .bar::after{ content:""; position:absolute; top:-46px; left:0; width:100%; height:46px; background:rgba(255,255,255,.95); animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{ transform:translateY(0); } 60%,100%{ transform:translateY(92px); } }

/* page hero (interior pages, shorter) */
.page-hero{
  position:relative; padding-top:calc(var(--nav-h) + clamp(60px,12vh,140px));
  padding-bottom:clamp(40px,7vh,84px); overflow:hidden;
}
.page-hero.has-media{ color:var(--ink-on-dark); min-height:74svh; display:flex; align-items:flex-end; }
.page-hero.has-media .hero-media::after{
  background:linear-gradient(180deg, rgba(20,15,10,.34) 0%, rgba(20,15,10,.08) 40%, rgba(20,15,10,.72) 100%);
}
.page-hero.has-media .page-hero-title{ color:#fff; }
.page-hero-title{ max-width:18ch; margin-top:1.2rem; }
.breadcrumbs{ display:flex; flex-wrap:wrap; gap:.5em; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.page-hero.has-media .breadcrumbs{ color:rgba(255,255,255,.78); }
.breadcrumbs a:hover{ color:var(--gold); }
.breadcrumbs .sep{ opacity:.5; }

/* typographic exhibition "plate" hero (no photo) */
.plate-hero{
  position:relative; color:var(--ink-on-dark); overflow:hidden;
  min-height:72svh; display:flex; align-items:flex-end;
  background:
    radial-gradient(120% 90% at 78% 12%, rgba(154,107,32,.34), transparent 60%),
    linear-gradient(160deg, var(--dark-3), var(--dark) 62%);
}
.plate-hero::before{
  content:""; position:absolute; inset:0;
  background-image:linear-gradient(var(--line-light) 1px, transparent 1px), linear-gradient(90deg, var(--line-light) 1px, transparent 1px);
  background-size:clamp(60px,9vw,120px) clamp(60px,9vw,120px); opacity:.5; z-index:0;
}
.plate-hero .container{ position:relative; z-index:1; }
.plate-hero .page-hero-title{ color:var(--gold-soft); }
.plate-mark{
  position:absolute; right:var(--gutter); top:clamp(96px,16vh,180px); z-index:1;
  font-family:var(--serif); font-size:clamp(7rem,22vw,20rem); line-height:.8;
  color:rgba(216,190,134,.12); pointer-events:none; user-select:none;
}

/* ---------- Pillars ---------- */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,3vw,52px); }
.pillar{ display:flex; flex-direction:column; }
.pillar-media{ position:relative; aspect-ratio:4/5; overflow:hidden; border-radius:var(--radius); margin-bottom:1.7rem; }
.pillar-media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.pillar:hover .pillar-media img{ transform:scale(1.06); }
.pillar-num{ font-family:var(--serif); font-size:.95rem; color:var(--gold); letter-spacing:.1em; margin-bottom:.7rem; }
.pillar h3{ margin-bottom:.9rem; }
.pillar p{ color:var(--ink-2); margin-bottom:1.3rem; }
.pillar .link-arrow{ margin-top:auto; }

/* ---------- Feature / work grid ---------- */
.work-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(16px,1.6vw,30px); }
.work-card{ position:relative; overflow:hidden; border-radius:var(--radius); display:block; isolation:isolate; }
.work-card img{ width:100%; height:100%; object-fit:cover; aspect-ratio:3/4; transition:transform 1.2s var(--ease); }
.work-card.wide img{ aspect-ratio:16/11; }
.work-card.tall img{ aspect-ratio:3/4.4; }
.work-card::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(20,15,10,0) 38%, rgba(20,15,10,.66) 100%);
  opacity:.86; transition:opacity .6s var(--ease);
}
.work-card:hover img{ transform:scale(1.05); }
.work-card:hover::after{ opacity:1; }
.work-cap{ position:absolute; left:0; bottom:0; z-index:2; padding:clamp(20px,2vw,32px); color:#fff; width:100%; }
.work-cap .k{ font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-soft); display:block; margin-bottom:.6rem; }
.work-cap h3{ color:#fff; font-size:clamp(1.3rem,2vw,1.9rem); }
.work-cap .meta{ margin-top:.5rem; font-size:.82rem; color:rgba(255,255,255,.82); letter-spacing:.02em; }
.work-card .plus{
  position:absolute; top:18px; right:18px; z-index:2; width:42px; height:42px; border-radius:50%;
  border:1px solid rgba(255,255,255,.5); display:grid; place-items:center; color:#fff;
  opacity:0; transform:scale(.7); transition:opacity .5s var(--ease), transform .5s var(--ease), background .4s;
}
.work-card:hover .plus{ opacity:1; transform:scale(1); }
.work-card:hover .plus{ background:rgba(255,255,255,.12); }

/* span helpers */
.col-3{ grid-column:span 3; } .col-4{ grid-column:span 4; } .col-5{ grid-column:span 5; }
.col-6{ grid-column:span 6; } .col-7{ grid-column:span 7; } .col-8{ grid-column:span 8; } .col-12{ grid-column:span 12; }

/* ---------- Split / editorial blocks ---------- */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(34px,5vw,90px); align-items:center; }
.split.reverse .split-media{ order:2; }
.split.wide-media{ grid-template-columns:1.25fr 1fr; }
.split-media{ position:relative; overflow:hidden; border-radius:var(--radius); }
.split-media img{ width:100%; object-fit:cover; }
.split-media.framed{ box-shadow:0 40px 80px -50px rgba(37,29,21,.55); }
.split-body .eyebrow{ margin-bottom:1.5rem; }
.split-body h2{ margin-bottom:1.5rem; }
.split-body p + p{ margin-top:1.1em; }
.split-body .btn, .split-body .link-arrow{ margin-top:2rem; }

/* stat / facts row */
.facts{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:clamp(20px,3vw,48px); }
.fact{ }
.fact .n{ font-family:var(--serif); font-size:clamp(2.2rem,4vw,3.4rem); line-height:1; color:var(--ink); }
.fact .l{ margin-top:.7rem; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-2); }
.fact.gold .n{ color:var(--gold); }

/* ---------- Quote ---------- */
.quote{ max-width:var(--container-narrow); margin-inline:auto; text-align:center; }
.quote .mark{ font-family:var(--serif); font-size:5rem; line-height:.5; color:var(--gold-soft); display:block; margin-bottom:.3em; }
.quote blockquote{ font-family:var(--serif); font-weight:300; font-size:clamp(1.5rem,3.4vw,2.6rem); line-height:1.3; letter-spacing:-.01em; }
.quote cite{ display:block; margin-top:1.8rem; font-family:var(--sans); font-style:normal; font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-2); }

/* ---------- Press marquee ---------- */
.press-strip{ padding-block:clamp(40px,5vw,66px); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; }
.press-strip .label{ text-align:center; font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--ink-3); margin-bottom:2.2rem; }
.marquee{ display:flex; overflow:hidden; -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track{ display:flex; align-items:center; gap:clamp(40px,5vw,80px); padding-right:clamp(40px,5vw,80px); flex:0 0 auto; animation:marquee 42s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--serif); font-size:clamp(1.2rem,2vw,1.8rem); color:var(--ink-2); white-space:nowrap; opacity:.78; font-weight:400; }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- Press list ---------- */
.press-list{ border-top:1px solid var(--line); }
.press-item{
  display:grid; grid-template-columns:96px 1fr auto; gap:clamp(16px,3vw,48px); align-items:baseline;
  padding:clamp(20px,2.4vw,30px) 0; border-bottom:1px solid var(--line);
  transition:padding-left .5s var(--ease);
}
.press-item:hover{ padding-left:14px; }
.press-item .yr{ font-family:var(--serif); font-size:1.1rem; color:var(--gold); }
.press-item .ti{ font-size:clamp(1rem,1.5vw,1.28rem); line-height:1.4; color:var(--ink); max-width:62ch; }
.press-item .src{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); white-space:nowrap; }

/* ---------- Gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(14px,1.6vw,26px); }
.gallery .g-tall{ grid-row:span 2; }
.gallery figure{ position:relative; overflow:hidden; border-radius:var(--radius); cursor:zoom-in; }
.gallery img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.gallery figure:hover img{ transform:scale(1.05); }
.gallery.cols-3{ grid-template-columns:repeat(3,1fr); }
.figure-caption{ margin-top:.9rem; font-size:.82rem; color:var(--ink-2); letter-spacing:.01em; }

/* ---------- Index / list cards (exhibitions, spaces) ---------- */
.index-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:clamp(22px,2.6vw,42px); }
.index-card{ display:block; }
.index-card .ph{ position:relative; aspect-ratio:4/3; overflow:hidden; border-radius:var(--radius); background:var(--bg-3); }
.index-card .ph img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease); }
.index-card:hover .ph img{ transform:scale(1.05); }
.index-card .ph.plate{ display:grid; place-items:center; background:radial-gradient(120% 100% at 70% 20%, rgba(154,107,32,.3), transparent 60%), linear-gradient(160deg, var(--dark-3), var(--dark)); }
.index-card .ph.plate span{ font-family:var(--serif); font-size:clamp(1.6rem,3vw,2.3rem); color:var(--gold-soft); text-align:center; padding:1rem; line-height:1.1; }
.index-card .k{ display:block; margin-top:1.2rem; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.index-card h3{ margin-top:.7rem; font-size:clamp(1.25rem,1.8vw,1.6rem); }
.index-card .m{ margin-top:.5rem; font-size:.85rem; color:var(--ink-2); }

/* timeline list (exhibitions) */
.timeline{ border-top:1px solid var(--line); }
.tl-row{
  display:grid; grid-template-columns:170px 1fr auto; gap:clamp(16px,3vw,40px); align-items:center;
  padding:clamp(20px,2.4vw,30px) 0; border-bottom:1px solid var(--line);
  transition:padding-left .55s var(--ease), background .55s var(--ease);
}
.tl-row:hover{ padding-left:16px; }
.tl-row .when{ font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); }
.tl-row .what{ font-family:var(--serif); font-size:clamp(1.4rem,2.4vw,2.1rem); color:var(--ink); }
.tl-row .where{ font-size:.82rem; color:var(--ink-2); letter-spacing:.04em; text-align:right; }
.tl-row .arrow{ color:var(--gold); opacity:0; transform:translateX(-8px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.tl-row:hover .arrow{ opacity:1; transform:translateX(0); }
a.tl-row:hover .what{ color:var(--gold); }

/* ---------- FAQ ---------- */
.faq{ max-width:920px; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; display:flex; align-items:flex-start; justify-content:space-between; gap:2rem;
  padding:clamp(20px,2.3vw,30px) 0; text-align:left;
  font-family:var(--serif); font-size:clamp(1.18rem,1.8vw,1.5rem); color:var(--ink); line-height:1.25;
}
.faq-q .ic{ flex:0 0 auto; width:26px; height:26px; position:relative; margin-top:.35em; transition:transform .5s var(--ease); }
.faq-q .ic::before, .faq-q .ic::after{ content:""; position:absolute; background:var(--gold); transition:transform .5s var(--ease); }
.faq-q .ic::before{ top:50%; left:0; right:0; height:1.5px; transform:translateY(-50%); }
.faq-q .ic::after{ left:50%; top:0; bottom:0; width:1.5px; transform:translateX(-50%); }
.faq-item.open .faq-q .ic::after{ transform:translateX(-50%) scaleY(0); }
.faq-a{ overflow:hidden; max-height:0; transition:max-height .6s var(--ease); }
.faq-a-inner{ padding-bottom:clamp(20px,2.3vw,28px); color:var(--ink-2); max-width:72ch; }
.faq-a-inner > * + *{ margin-top:1em; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; }
.cta-band .container{ position:relative; z-index:1; text-align:center; }
.cta-band h2{ color:var(--ink-on-dark); max-width:18ch; margin-inline:auto; }
.cta-band p{ color:rgba(241,232,216,.78); max-width:52ch; margin:1.6rem auto 2.6rem; }
.cta-band .eyebrow{ color:var(--gold-soft); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--dark); color:var(--ink-on-dark); padding-top:clamp(70px,9vw,120px); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:clamp(30px,4vw,64px); padding-bottom:clamp(50px,7vw,90px); border-bottom:1px solid var(--line-light); }
.footer-brand .wm{ font-family:var(--serif); font-size:clamp(1.8rem,3vw,2.5rem); line-height:1; letter-spacing:.01em; }
.footer-brand .tg{ margin-top:1.3rem; color:rgba(241,232,216,.7); max-width:34ch; font-size:.95rem; line-height:1.6; }
.footer-brand .loc{ margin-top:1.8rem; display:flex; gap:1.6rem; font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); }
.footer-col h4{ font-family:var(--sans); font-weight:600; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:1.5rem; }
.footer-col a{ display:block; padding:.42em 0; color:rgba(241,232,216,.82); font-size:.95rem; transition:color .4s var(--ease), transform .4s var(--ease); }
.footer-col a:hover{ color:#fff; transform:translateX(4px); }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:1.2rem 2rem; align-items:center; justify-content:space-between; padding-block:2.2rem; font-size:.78rem; color:rgba(241,232,216,.6); letter-spacing:.04em; }
.footer-bottom .social{ display:flex; gap:1.5rem; }
.footer-bottom .social a{ color:rgba(241,232,216,.7); transition:color .4s; }
.footer-bottom .social a:hover{ color:var(--gold-soft); }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,80px); align-items:start; }
.contact-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(26px,3vw,44px); }
.contact-row{ padding:1.3rem 0; border-bottom:1px solid var(--line); }
.contact-row:last-child{ border-bottom:0; }
.contact-row .k{ font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.5rem; }
.contact-row .v{ font-size:1.05rem; color:var(--ink); }
.contact-row .v a:hover{ color:var(--gold); }
.field{ margin-bottom:1.3rem; }
.field label{ display:block; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); margin-bottom:.6rem; }
.field input, .field textarea, .field select{
  width:100%; padding:.95em 1.1em; font:inherit; font-size:.98rem; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  transition:border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(154,107,32,.12); }
.field textarea{ resize:vertical; min-height:130px; }

/* ---------- Lightbox ---------- */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(20,15,10,.92); display:none; align-items:center; justify-content:center; padding:clamp(16px,4vw,60px); opacity:0; transition:opacity .4s var(--ease); }
.lightbox.open{ display:flex; }
.lightbox.show{ opacity:1; }
.lightbox img{ max-width:100%; max-height:88vh; object-fit:contain; border-radius:2px; box-shadow:0 30px 90px rgba(0,0,0,.5); }
.lightbox .lb-close, .lightbox .lb-nav{ position:absolute; color:#fff; width:54px; height:54px; border:1px solid rgba(255,255,255,.3); border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.06); transition:background .3s; }
.lightbox .lb-close:hover, .lightbox .lb-nav:hover{ background:rgba(255,255,255,.18); }
.lightbox .lb-close{ top:24px; right:24px; }
.lightbox .lb-prev{ left:24px; top:50%; transform:translateY(-50%); }
.lightbox .lb-next{ right:24px; top:50%; transform:translateY(-50%); }

/* ---------- Scroll reveal (gated by .js so no-JS shows everything) ---------- */
.reveal{ transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); will-change:opacity, transform; }
.js .reveal{ opacity:0; transform:translateY(34px); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; } .reveal.d5{ transition-delay:.40s; }
.reveal-img{ overflow:hidden; }
.reveal-img img{ transition:transform 1.4s var(--ease-out); }
.js .reveal-img img{ transform:scale(1.12); }
.reveal-img.in img{ transform:scale(1); }

/* line mask reveal for big headings */
.mask-lines .ln{ display:block; overflow:hidden; }
.mask-lines .ln > span{ display:block; transition:transform 1s var(--ease-out); }
.js .mask-lines .ln > span{ transform:translateY(105%); }
.mask-lines.in .ln > span{ transform:translateY(0); }
.mask-lines.in .ln:nth-child(2) > span{ transition-delay:.09s; }
.mask-lines.in .ln:nth-child(3) > span{ transition-delay:.18s; }

@media (prefers-reduced-motion: reduce){
  .reveal, .reveal-img img, .mask-lines .ln > span, .rise, .js main{ opacity:1 !important; transform:none !important; transition:none !important; animation:none !important; }
  .hero.loaded .hero-media img{ animation:none; transform:scale(1.03); }
  .marquee-track{ animation:none; }
  .scroll-cue .bar::after{ animation:none; }
}

/* ---------- Progress bar ---------- */
.progress{ position:fixed; top:0; left:0; height:2px; background:var(--gold); z-index:140; width:0; transition:width .1s linear; }

/* ---------- Bespoke texture + page-load fade ---------- */
body::after{
  content:""; position:fixed; inset:0; z-index:9000; pointer-events:none;
  opacity:.045; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.js main{ animation:pageIn .7s var(--ease-out) both; }
@keyframes pageIn{ from{ opacity:0; transform:translateY(7px); } to{ opacity:1; transform:none; } }

/* ---------- Masonry gallery ---------- */
.masonry{ column-count:3; column-gap:clamp(14px,1.6vw,26px); }
.masonry figure{ break-inside:avoid; margin:0 0 clamp(14px,1.6vw,26px); position:relative; overflow:hidden; border-radius:var(--radius); cursor:zoom-in; }
.masonry img{ width:100%; transition:transform 1.2s var(--ease), filter 1s var(--ease); }
.masonry figure:hover img{ transform:scale(1.05); }
.masonry figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:clamp(16px,1.6vw,26px);
  color:#fff; font-size:.82rem; letter-spacing:.01em; line-height:1.4;
  background:linear-gradient(transparent, rgba(20,15,10,.78));
  opacity:0; transform:translateY(10px); transition:opacity .5s var(--ease), transform .5s var(--ease);
}
.masonry figure:hover figcaption{ opacity:1; transform:none; }
@media (max-width:900px){ .masonry{ column-count:2; } }
@media (max-width:560px){ .masonry{ column-count:1; } }

/* ---------- Journal article ---------- */
.article-meta{
  display:flex; flex-wrap:wrap; gap:1.2rem 1.8rem; align-items:center;
  font-size:.73rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3);
  padding-bottom:1.8rem; margin-bottom:2.4rem; border-bottom:1px solid var(--line);
}
.article-meta span:not(:last-child){ position:relative; padding-right:1.8rem; }
.article-meta span:not(:last-child)::after{ content:""; position:absolute; right:0; top:50%; width:5px; height:5px; border-radius:50%; background:var(--gold-soft); transform:translateY(-50%); }
.article-body h2{ font-size:clamp(1.5rem,2.4vw,2.05rem); margin:2.1em 0 .65em; }
.article-body h2:first-child{ margin-top:0; }
.article-body p{ font-size:1.08rem; line-height:1.8; color:var(--ink); }
.article-sign{ margin-top:2.8rem; padding-top:1.6rem; border-top:1px solid var(--line); font-family:var(--serif); font-style:italic; font-size:1.35rem; color:var(--ink-2); }
.index-card .ph img{ aspect-ratio:4/3; }

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .footer-top{ grid-template-columns:1fr 1fr; gap:40px 32px; }
  .footer-brand{ grid-column:span 2; }
}
@media (max-width:900px){
  .nav{ display:none; }
  .burger{ display:block; }
  .pillars{ grid-template-columns:1fr; gap:48px; max-width:460px; margin-inline:auto; }
  .split{ grid-template-columns:1fr; gap:32px; }
  .split.reverse .split-media{ order:0; }
  .split.wide-media{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8{ grid-column:span 12; }
  .work-grid .col-6{ grid-column:span 6; }
  .press-item{ grid-template-columns:64px 1fr; }
  .press-item .src{ grid-column:2; white-space:normal; }
  .tl-row{ grid-template-columns:1fr auto; gap:8px 18px; }
  .tl-row .when{ grid-column:1; }
  .tl-row .where{ grid-column:1/-1; text-align:left; }
  .plate-mark{ display:none; }
}
@media (max-width:560px){
  :root{ --nav-h:66px; }
  .work-grid .col-6{ grid-column:span 12; }
  .gallery{ grid-template-columns:1fr; }
  .gallery .g-tall{ grid-row:span 1; }
  .hero-locations{ flex-direction:column; gap:.6rem; }
  .footer-top{ grid-template-columns:1fr; }
  .footer-brand{ grid-column:span 1; }
  .press-item{ grid-template-columns:1fr; gap:.4rem; }
  .press-item .yr{ font-size:.95rem; }
}
