
:root{
  --bg:#0d0c19;
  --panel:#171329;
  --panel-2:#21183a;
  --ink:#fff8f0;
  --muted:rgba(255,248,240,.74);
  --soft:rgba(255,248,240,.58);
  --line:rgba(255,255,255,.16);
  --pink:#ff3f9a;
  --cyan:#18c7d8;
  --gold:#ffcd4c;
  --violet:#785cff;
  --green:#83ff74;
  --orange:#ff7e3a;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at 8% 0%, rgba(255,63,154,.26), transparent 30%),
    radial-gradient(circle at 92% 6%, rgba(24,199,216,.22), transparent 34%),
    linear-gradient(180deg, #0d0c19 0%, #130f24 70%, #0d0c19 100%);
  color:var(--ink);
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height:1.55;
}
a{color:inherit}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;z-index:1000;padding:.7rem 1rem;border-radius:999px;background:var(--ink);color:var(--bg)}
.site-header{
  position:sticky;top:0;z-index:100;
  border-bottom:1px solid var(--line);
  background:rgba(13,12,25,.84);
  backdrop-filter:blur(18px);
}
.nav{
  width:min(1180px, calc(100% - 2rem));
  margin:auto;
  min-height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.brand{
  display:flex;align-items:center;gap:.7rem;
  text-decoration:none;font-weight:800;
}
.brand-mark{
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;
  color:#0d0c19;
  background:linear-gradient(135deg,var(--pink),var(--cyan));
}
.nav-menu{
  display:flex;flex-wrap:wrap;gap:1rem;
  margin:0;padding:0;list-style:none;
}
.nav-menu a{
  color:var(--muted);text-decoration:none;font-weight:750;font-size:.9rem;
}
.nav-menu a:hover,.nav-menu a:focus-visible{color:var(--ink)}
.section{
  width:min(1180px, calc(100% - 2rem));
  margin:auto;
  padding:4rem 0;
}
.hero{
  padding-top:clamp(4rem,10vw,8rem);
  padding-bottom:2rem;
}
.eyebrow{
  margin:0 0 .7rem;
  color:var(--cyan);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.78rem;
  font-weight:800;
}
h1, h2, h3 {
  line-height: 1.08;
  margin: 0;
  color: var(--ink)
}
h1, h2 {
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 800;
  letter-spacing: -.035em
}
h1 {
  font-size: clamp(2.45rem, 5vw, 4.65rem);
  max-width: 820px
}
.subtitle {
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(1.35rem, 2.3vw, 2.1rem);
  line-height: 1.2;
  color: var(--gold);
  margin: 1rem 0 0;
  font-weight: 700
}
h2 {
  font-size: clamp(2rem, 3.8vw, 3.35rem)
}
h3 {
  font-size: 1.18rem;
  margin-bottom: .5rem
}
.lead {
  font-size: clamp(1.07rem, 1.6vw, 1.28rem);
  max-width: 690px;
  color: var(--ink-soft);
  margin: 1.35rem 0 0
}
.lead-small, .section-note {
  font-size: 1.05rem;
  color: var(--ink-soft)
}
.section-note {
  max-width: 420px;
  margin: 0
}
.hero-actions{
  display:flex;flex-wrap:wrap;gap:.8rem;
  margin-top:1.5rem;
}
.button{
  display:inline-flex;align-items:center;gap:.45rem;
  border:1px solid var(--line);
  border-radius:999px;
  padding:.76rem 1rem;
  text-decoration:none;
  font-weight:800;
  background:rgba(255,255,255,.07);
}
.button:hover,.button:focus-visible{
  background:linear-gradient(135deg,rgba(255,63,154,.35),rgba(24,199,216,.25));
  border-color:rgba(255,255,255,.32);
}
.overview-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
}
.panel,.research-box,.gallery-intro,.exhibition-panel,.figure-notes{
  border:1px solid var(--line);
  border-radius:24px;
  padding:1.25rem;
  background:
    linear-gradient(90deg, rgba(255,255,255,.10) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.10) 1px, transparent 1px),
    radial-gradient(circle at 12% 15%, rgba(255,63,154,.34), transparent 35%),
    radial-gradient(circle at 88% 20%, rgba(24,199,216,.28), transparent 38%),
    rgba(255,255,255,.05);
  background-size:30px 30px,30px 30px,auto,auto,auto;
  box-shadow:0 24px 80px rgba(0,0,0,.23);
}
.panel p,.gallery-intro p,.exhibition-panel p,.figure-notes p,.figure-notes li{color:var(--muted)}
.project-card-grid,.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1rem;
  align-items:stretch;
}
.project-link-card,.image-card{
  position:relative;
  overflow:visible;
  min-height:480px;
  border:1px solid var(--line);
  border-radius:24px;
  padding:1rem;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  text-decoration:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.18) 1px, transparent 1px),
    radial-gradient(circle at 20% 18%, var(--cell-a,rgba(255,63,154,.58)), transparent 38%),
    radial-gradient(circle at 82% 12%, var(--cell-b,rgba(24,199,216,.52)), transparent 36%),
    radial-gradient(circle at 50% 90%, var(--cell-c,rgba(255,205,76,.36)), transparent 44%),
    rgba(13,12,25,.94);
  background-size:28px 28px,28px 28px,auto,auto,auto,auto;
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.project-link-card:nth-child(2),.image-card:nth-child(3n+2){
  --cell-a:rgba(120,92,255,.64);--cell-b:rgba(131,255,116,.38);--cell-c:rgba(255,63,154,.44);
}
.project-link-card:nth-child(3),.image-card:nth-child(3n){
  --cell-a:rgba(255,205,76,.60);--cell-b:rgba(255,63,154,.52);--cell-c:rgba(24,199,216,.36);
}
.project-link-card:hover,.project-link-card:focus-visible,.image-card:hover,.image-card:focus-within{
  transform:translateY(-6px);
  border-color:rgba(255,255,255,.34);
  box-shadow:0 30px 100px rgba(255,63,154,.22),0 0 60px rgba(24,199,216,.16);
}
.card-copy,.image-copy{
  margin-top:1rem;
  padding:1rem;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(13,12,25,.48),rgba(13,12,25,.90));
}
.card-copy p,.image-copy p{color:var(--muted)}
.project-meta{
  margin:0 0 .65rem;
  color:var(--gold);
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.card-image,.image-popout{
  display:block;
  width:84%;
  height:260px;
  align-self:center;
  margin:0 auto;
  border-radius:18px;
}
.card-image img,.image-popout img{
  width:100%;height:100%;
  object-fit:cover;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 24px 80px rgba(0,0,0,.35);
  background:#06050b;
}
.image-popout{
  position:relative;
  z-index:5;
  cursor:zoom-in;
  outline:none;
}
.image-popout:hover,
.image-popout:focus-visible,
.image-popout.is-open{z-index:1000}
.image-popout:hover img,
.image-popout:focus-visible img,
.image-popout.is-open img{
  position:absolute;
  left:50%;
  top:50%;
  width:min(82vw, 880px);
  height:min(76vh, 660px);
  object-fit:contain;
  transform:translate(-50%, -50%);
  padding:1rem;
  border-radius:22px;
  background:rgba(13,12,25,.97);
  box-shadow:0 30px 140px rgba(0,0,0,.82), 0 0 0 1px rgba(255,255,255,.22);
  filter:saturate(1.08) contrast(1.04);
  pointer-events:none;
  z-index:5000;
}
.image-card{min-height:540px}
.image-card:hover{z-index:900}
.image-copy h3{font-size:1.45rem;margin-bottom:.55rem}
.caption{font-size:.94rem}
.alt-text{
  margin-top:.6rem;
  font-size:.86rem;
  color:var(--soft)!important;
  border-top:1px solid rgba(255,255,255,.10);
  padding-top:.6rem;
}
.two-col{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:1rem;
}
.text-panel{
  border:1px solid var(--line);
  border-radius:24px;
  padding:1.25rem;
  background:rgba(255,255,255,.055);
}
.text-panel p,.text-panel li{color:var(--muted)}
.exhibition-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
}
.site-footer{
  width:min(1180px, calc(100% - 2rem));
  margin:auto;
  padding:2rem 0 4rem;
  color:var(--muted);
}
@media (max-width:980px){
  .project-card-grid,.gallery-grid,.overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .two-col,.exhibition-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .nav{align-items:flex-start;flex-direction:column;padding:1rem 0}
  .project-card-grid,.gallery-grid,.overview-grid{grid-template-columns:1fr}
  .image-card,.project-link-card{min-height:430px}
  .card-image,.image-popout{height:230px}
  .image-popout:hover img,.image-popout:focus-visible img,.image-popout.is-open img{
    width:calc(100vw - 2rem);height:min(72vh,620px)
  }
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}
