/* A Museum Unchanged — editorial museum system */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,300..600&family=Hanken+Grotesk:wght@300..700&family=Spline+Sans+Mono:wght@400;500&display=swap');

:root{
  --paper:#f3ede1; --paper-2:#ece4d4; --ink:#1d1a15; --ink-soft:#4a4438;
  --blue:#1f4f6d; --blue-deep:#143a52; --teal:#2c6f6f; --clay:#b1542b;
  --brass:#a8843c; --green:#3d6b54; --line:#d6cbb6; --line-2:#c7b99e;
  --gallery:#16130f; --maxw:1180px;
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Spline Sans Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;
  background-image:radial-gradient(circle at 1px 1px,rgba(29,26,21,.025) 1px,transparent 0);background-size:22px 22px;}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:430;line-height:1.08;letter-spacing:-.01em;margin:0}
.serif-italic{font-style:italic}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);margin:0 0 14px}
.mono{font-family:var(--mono)}
.muted{color:var(--ink-soft)}

/* protect imagery */
.protect{user-select:none;-webkit-user-drag:none;pointer-events:none}
.imgshell{position:relative;overflow:hidden;background:var(--paper-2);margin:0}
.imgshell::after{content:"";position:absolute;inset:0}/* transparent grab-guard */

/* header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(243,237,225,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hdr{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:13px;font-family:var(--serif);font-size:20px;letter-spacing:-.01em}
.brand .mark{width:34px;height:34px;flex:none}
.nav{display:flex;align-items:center;gap:26px;font-size:14.5px}
.nav a{color:var(--ink-soft);transition:color .2s}
.nav a:hover,.nav a[aria-current=page]{color:var(--ink)}
.nav .cartlink{font-family:var(--mono);font-size:13px;border:1px solid var(--line-2);
  padding:7px 13px;border-radius:2px;color:var(--ink)}
.nav .cartlink:hover{background:var(--ink);color:var(--paper)}
.controls{display:flex;gap:8px;align-items:center}
.pick{font-family:var(--mono);font-size:12px;background:transparent;border:1px solid var(--line-2);
  color:var(--ink-soft);padding:6px 8px;border-radius:2px;cursor:pointer}
.pick:focus{outline:1px solid var(--blue)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:13px;
  letter-spacing:.04em;padding:13px 22px;border:1px solid var(--ink);background:var(--ink);
  color:var(--paper);cursor:pointer;border-radius:2px;transition:.18s}
.btn:hover{background:transparent;color:var(--ink)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--paper)}
.btn.clay{background:var(--clay);border-color:var(--clay)}
.btn.clay:hover{background:transparent;color:var(--clay)}

/* hero */
.hero{padding:74px 0 30px;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(38px,5.4vw,68px);max-width:13ch}
.hero .lede{font-size:19px;max-width:46ch;margin:22px 0 30px;color:var(--ink-soft)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art .imgshell{border:1px solid var(--line-2);box-shadow:0 30px 60px -30px rgba(29,26,21,.5)}
.hero-art figcaption{font-family:var(--mono);font-size:11px;color:var(--ink-soft);margin-top:10px;letter-spacing:.04em}

/* section */
section{padding:46px 0}
.sec-head{max-width:60ch;margin-bottom:30px}
.sec-head h2{font-size:clamp(26px,3.4vw,40px)}
.sec-head p{color:var(--ink-soft);margin:14px 0 0}
.rule{height:1px;background:var(--line);border:0;margin:0}

/* now-showing band */
.now-band{background:var(--gallery);color:var(--paper);border-radius:3px;overflow:hidden;
  display:grid;grid-template-columns:1.1fr 1fr}
.now-band .txt{padding:46px 44px}
.now-band .kicker{color:#d8a06b}
.now-band h2{color:var(--paper);font-size:clamp(28px,3.6vw,42px)}
.now-band p{color:#cabfa8;margin:16px 0 26px;max-width:42ch}
.now-band .btn{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.now-band .btn:hover{background:transparent;color:var(--paper)}
.now-band .strip{display:grid;grid-template-columns:1fr 1fr}
.now-band .strip .imgshell{aspect-ratio:1}

/* portal cards */
.portals{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.portal{border:1px solid var(--line-2);padding:34px;border-radius:3px;background:var(--paper-2);
  transition:.2s;display:flex;flex-direction:column;gap:10px;min-height:200px}
.portal:hover{transform:translateY(-3px);box-shadow:0 22px 40px -28px rgba(29,26,21,.55)}
.portal .pn{font-family:var(--mono);font-size:12px;color:var(--clay);letter-spacing:.2em}
.portal h3{font-size:26px}
.portal span.d{color:var(--ink-soft);font-size:15px}

/* how-made note */
.note{border-left:3px solid var(--brass);padding:6px 0 6px 24px;max-width:62ch}
.note h3{font-size:21px;margin-bottom:8px}
.note p{color:var(--ink-soft);font-size:15.5px;margin:0}

/* gallery grid */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.search{font-family:var(--sans);font-size:15px;padding:11px 15px;border:1px solid var(--line-2);
  background:var(--paper);border-radius:2px;min-width:260px;color:var(--ink)}
.count{font-family:var(--mono);font-size:12px;color:var(--ink-soft);letter-spacing:.08em}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tile{cursor:pointer;background:var(--paper-2);border:1px solid var(--line);border-radius:2px;
  overflow:hidden;transition:.2s}
.tile:hover{transform:translateY(-3px);box-shadow:0 24px 44px -30px rgba(29,26,21,.6);border-color:var(--line-2)}
.tile .imgshell{aspect-ratio:1}
.tile .meta{padding:14px 15px 16px}
.tile .meta h3{font-size:18px;line-height:1.15}
.tile .meta .by{font-size:13px;color:var(--ink-soft);margin-top:5px}
.tile .meta .pr{font-family:var(--mono);font-size:12.5px;color:var(--clay);margin-top:9px;letter-spacing:.03em}
.tile .cat{font-family:var(--mono);font-size:10.5px;color:var(--ink-soft);letter-spacing:.18em}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(20,17,14,.95);display:none;
  grid-template-columns:1.25fr .75fr;}
.lb.open{display:grid}
.lb-stage{display:flex;align-items:center;justify-content:center;padding:38px;position:relative}
.lb-stage .imgshell{max-width:min(74vh,640px);width:100%;aspect-ratio:1;border:1px solid #2c2620;
  box-shadow:0 40px 80px -30px #000}
.lb-side{background:var(--paper);padding:46px 42px;overflow-y:auto;position:relative}
.lb-side .kicker{color:var(--clay)}
.lb-side h2{font-size:30px;margin-bottom:6px}
.lb-side .credit{color:var(--ink-soft);font-size:15px;margin:16px 0}
.lb-side .by a{color:var(--blue);border-bottom:1px solid var(--line-2)}
.lb-meta{font-family:var(--mono);font-size:12px;color:var(--ink-soft);letter-spacing:.04em;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0;margin:18px 0;display:flex;flex-direction:column;gap:6px}
.lb-toggle{position:absolute;left:38px;bottom:38px;display:flex;gap:8px}
.lb-toggle button{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(243,237,225,.1);color:var(--paper);border:1px solid rgba(243,237,225,.35);
  padding:8px 13px;border-radius:2px;cursor:pointer}
.lb-toggle button.on{background:var(--paper);color:var(--ink)}
.lb-close{position:fixed;top:14px;right:14px;z-index:120;width:40px;height:40px;border-radius:50%;
  background:rgba(20,17,14,.55);border:0;color:#fff;font-size:24px;cursor:pointer;line-height:1;
  font-family:var(--serif);display:flex;align-items:center;justify-content:center;padding:0;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}
.lb-close:hover{background:rgba(20,17,14,.8)}
.fmt{margin-top:8px}
.fmt h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 10px}
.fmt-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 0;border-bottom:1px dotted var(--line-2);font-size:14.5px}
.fmt-row .price{font-family:var(--mono);color:var(--ink)}
.fmt-row button{font-family:var(--mono);font-size:11px;letter-spacing:.06em;border:1px solid var(--ink);
  background:transparent;padding:7px 11px;cursor:pointer;border-radius:2px;transition:.15s;white-space:nowrap}
.fmt-row button:hover{background:var(--ink);color:var(--paper)}
.fulfil{font-family:var(--mono);font-size:11px;color:var(--green);margin-top:14px;letter-spacing:.02em}

/* artists */
.artgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.acard{border:1px solid var(--line);background:var(--paper-2);border-radius:2px;overflow:hidden;transition:.2s}
.acard:hover{transform:translateY(-3px);box-shadow:0 22px 40px -30px rgba(29,26,21,.55)}
.acard .imgshell{aspect-ratio:1}
.acard .ac-meta{padding:16px 17px 18px}
.acard h3{font-size:20px}
.acard .role{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--clay);margin-top:6px}
.acard .city{font-size:13.5px;color:var(--ink-soft);margin-top:4px}

/* artist detail */
.artist-hero{display:grid;grid-template-columns:.8fr 1.2fr;gap:44px;align-items:start;padding-top:56px}
.artist-hero .bio{font-size:18px;color:var(--ink-soft);max-width:48ch}
.dl{font-family:var(--mono);font-size:13px;display:grid;grid-template-columns:auto 1fr;gap:6px 18px;margin:22px 0}
.dl dt{color:var(--clay);letter-spacing:.1em;text-transform:uppercase;font-size:11px;align-self:center}
.dl dd{margin:0;color:var(--ink)}

/* cart */
.cart-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:40px;align-items:start;padding-top:48px}
.line{display:grid;grid-template-columns:84px 1fr auto;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);align-items:center}
.line .imgshell{width:84px;height:84px;border:1px solid var(--line-2)}
.line h4{font-family:var(--serif);font-size:18px;margin:0}
.line .sub{font-size:13px;color:var(--ink-soft);margin-top:3px}
.line .lp{font-family:var(--mono);font-size:14px;text-align:right}
.qtybox{display:inline-flex;align-items:center;border:1px solid var(--line-2);border-radius:2px;margin-top:7px}
.qtybox button{width:26px;height:26px;border:0;background:transparent;cursor:pointer;font-size:15px}
.qtybox span{width:30px;text-align:center;font-family:var(--mono);font-size:13px}
.rm{font-family:var(--mono);font-size:11px;color:var(--clay);background:none;border:0;cursor:pointer;margin-top:6px;letter-spacing:.05em}
.summary{border:1px solid var(--line-2);background:var(--paper-2);padding:28px;border-radius:3px;position:sticky;top:90px}
.summary h3{font-size:22px;margin-bottom:16px}
.summary .row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:14px;padding:8px 0}
.summary .tot{border-top:1px solid var(--line-2);margin-top:8px;padding-top:14px;font-size:17px}

.conf{max-width:760px;margin:0 auto;padding:56px 0}
.conf h1{font-size:clamp(26px,3vw,40px);margin:6px 0 4px}
.conf-ref{font-family:var(--mono);font-size:14px;color:var(--ink-soft);margin-bottom:14px}
.conf-note{color:var(--ink-soft);max-width:62ch;margin-bottom:22px;line-height:1.55}
.conf-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.invoice-box{font-family:var(--mono);font-size:12.5px;line-height:1.55;white-space:pre-wrap;word-break:break-word;
  background:var(--paper-2);border:1px solid var(--line-2);border-radius:3px;padding:18px;max-height:440px;overflow:auto;color:var(--ink);margin:0}

.field{display:block;margin:12px 0}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:15px;
  padding:10px 12px;border:1px solid var(--line-2);background:var(--paper);border-radius:2px;color:var(--ink)}
.field textarea{min-height:74px;resize:vertical}
.cnote{font-size:12.5px;color:var(--ink-soft);margin:14px 0;line-height:1.5}

/* footer */
.site-footer{border-top:1px solid var(--line);margin-top:60px;padding:40px 0 60px}
.foot{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;align-items:end}
.foot .tag{font-family:var(--serif);font-style:italic;font-size:19px;max-width:34ch}
.foot .rights{font-family:var(--mono);font-size:11px;color:var(--ink-soft);letter-spacing:.04em}
.foot .mark{width:42px;height:42px;opacity:.8}

.page-title{padding:60px 0 18px;max-width:64ch}
.page-title h1{font-size:clamp(32px,4.6vw,56px)}
.page-title .lede{font-size:18px;color:var(--ink-soft);margin-top:18px}
/* exhibit topmatter: full-width, compact, collapsible so first works show */
.exhibit-head{max-width:var(--maxw);padding:40px 28px 14px}
.exhibit-head h1{font-size:clamp(27px,3.4vw,42px)}
.exhibit-head .lede{font-size:15.5px;line-height:1.55;max-width:none;margin-top:10px}
.schools-note{font-family:var(--mono);font-size:12.5px;line-height:1.5;color:var(--ink);
  background:var(--paper-2);border:1px solid var(--line-2);border-left:3px solid var(--clay);
  padding:11px 15px;border-radius:2px;margin:16px 0 4px;max-width:82ch}
.intro-clamp{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.intro-clamp.open{display:block;-webkit-line-clamp:unset;overflow:visible}
.more-btn{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--clay);
  background:none;border:0;padding:6px 0 0;cursor:pointer;text-decoration:underline;text-underline-offset:3px}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:13px;padding:13px 20px;
  border-radius:3px;z-index:200;transition:.3s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:900px){
  .hero,.now-band,.portals,.artist-hero,.cart-grid{grid-template-columns:1fr}
  .grid,.artgrid{grid-template-columns:repeat(2,1fr)}
  .now-band .strip{grid-template-columns:1fr 1fr}
  /* header: brand on row 1, nav wraps to row 2 (no off-screen controls) */
  .site-header .hdr{flex-wrap:wrap;height:auto;padding-top:11px;padding-bottom:11px;row-gap:10px}
  .brand{flex:1 1 auto}
  .brand span{font-size:16px}
  .nav{flex:1 1 100%;justify-content:flex-start;flex-wrap:wrap;gap:10px 16px;font-size:13.5px}
  .nav .cartlink{margin-left:auto}
  /* lightbox: single scrollable column, image fits viewport width */
  .lb.open{display:block;overflow-y:auto}
  .lb-stage{display:block;padding:56px 16px 6px}
  .lb-stage .imgshell{max-width:min(100%,70vh);width:100%;margin:0 auto;box-shadow:0 20px 50px -22px #000}
  .lb-side{padding:22px 18px 70px}
  .lb-toggle{position:static;margin-top:14px;justify-content:center}
  .summary{position:static}
}
@media(max-width:560px){
  .grid,.artgrid{grid-template-columns:1fr}
  .wrap{padding:0 18px}
  .exhibit-head{padding:30px 18px 12px}
  .hero{padding:38px 0 8px}
}
