:root{
  --bg: #07090a;
  --bg2: #050607;
  --ink: #0d1212;
  --mural: #c8d2d1;
  --mural2: #b7c5c4;
  --pearl: #f2efe7;
  --pearl2: #d9d3c7;
  --copper: #9a6a44;
  --copper2: #b17a4d;
  --verdigris: #2f7d75;
  --verdigris2: #4aa79b;
  --iridescent: #b6c6ff;
  --iridescent2: #e7c7ff;
  --shadow: 0 24px 90px rgba(0,0,0,.55);
  --shadow2: 0 16px 60px rgba(0,0,0,.55);
  --ring: 0 0 0 1px rgba(242,239,231,.16);
  --ring2: 0 0 0 1px rgba(47,125,117,.26);
  --radius: 18px;
  --radius2: 28px;
  --max: 1240px;
  --serif: "Cormorant Garamond", ui-serif, Georgia, serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
html{ overflow-x: hidden; }
body{
  margin:0;
  background:
    radial-gradient(1200px 900px at 18% 12%, rgba(242,239,231,.32), transparent 62%),
    radial-gradient(900px 700px at 78% 18%, rgba(154,106,68,.12), transparent 54%),
    linear-gradient(180deg, #d2dbda 0%, #b8c6c5 46%, #101313 100%);
  color: var(--pearl);
  font-family: var(--sans);
  letter-spacing: -0.01em;
  overflow-x: hidden;
}

::selection{ background: rgba(74,167,155,.26); color: var(--pearl); }

a{ color: inherit; text-decoration:none; }
button,input{ font: inherit; color: inherit; }
img{ max-width:100%; display:block; }

.skip{
  position:absolute;
  left:-999px;
  top:12px;
  padding:10px 14px;
  background: rgba(242,239,231,.08);
  border: 1px solid rgba(242,239,231,.16);
  border-radius: 999px;
}
.skip:focus{ left:12px; z-index: 9999; }

.wrap{ width:min(var(--max), calc(100% - 72px)); margin:0 auto; }

.topbar{
  position: fixed;
  z-index: 50;
  top: 14px;
  right: 14px;
  bottom: auto;
  left: 14px;
  width: auto;
  pointer-events: none;
}
.topbar__inner{
  pointer-events: auto;
  width: min(var(--max), calc(100% - 28px));
  margin: 0 auto;
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(7,9,10,.66), rgba(7,9,10,.34));
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow2);
}

.mark{
  display:flex;
  align-items:center;
  gap: 10px;
  font-family: var(--serif);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-weight: 500;
}
.mark__sigil{
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background:
    radial-gradient(12px 12px at 30% 30%, rgba(242,239,231,.7), transparent 55%),
    radial-gradient(18px 16px at 70% 70%, rgba(74,167,155,.5), transparent 60%),
    linear-gradient(135deg, rgba(154,106,68,.9), rgba(47,125,117,.6));
  box-shadow: 0 0 0 1px rgba(242,239,231,.18), 0 12px 40px rgba(0,0,0,.45);
}
.mark__word{ font-size: 14px; opacity: .96; }
.mark--footer .mark__word{ font-size: 16px; }

.nav{
  display:flex;
  gap: 14px;
  align-items:center;
}
.nav__link{
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  opacity: .84;
  position: relative;
  padding: 10px 8px;
}
.nav__link::after{
  content:"";
  position:absolute;
  left: 10px;
  right: 10px;
  bottom: 5px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(74,167,155,.9), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .38s ease;
}
.nav__link:hover{ opacity: 1; }
.nav__link:hover::after{ transform: scaleX(1); }

.navdrop{
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav__link--btn{
  background: transparent;
  border: 0;
  color: inherit;
  cursor: pointer;
  font: inherit;
  line-height: inherit;
}
.navdrop__menu{
  position: absolute;
  top: calc(100% + 8px);
  left: 2px;
  min-width: 220px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.68);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow2);
  padding: 8px;
  display: none;
  z-index: 50;
}
.navdrop.is-open .navdrop__menu{ display: block; }
.navdrop__item{
  display:flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  color: rgba(242,239,231,.86);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  border: 1px solid transparent;
  background: transparent;
}
.navdrop__item:hover{
  border-color: rgba(74,167,155,.26);
  background: rgba(74,167,155,.06);
  color: rgba(242,239,231,.96);
}
.navdrop__item:focus-visible{
  outline:none;
  box-shadow: var(--ring2);
}

.topbar__cta{ display:flex; gap: 10px; align-items:center; }

.topbar__cta a.quiet{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}
.nav__link[aria-current="page"],
.topbar__cta .quiet[aria-current="page"]{
  opacity: 1;
  border-color: rgba(74,167,155,.45);
  background: rgba(74,167,155,.08);
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 11px 14px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background:
    radial-gradient(120px 60px at 20% 10%, rgba(74,167,155,.22), transparent 60%),
    radial-gradient(180px 80px at 80% 120%, rgba(154,106,68,.26), transparent 56%),
    linear-gradient(180deg, rgba(242,239,231,.09), rgba(242,239,231,.05));
  box-shadow: 0 14px 54px rgba(0,0,0,.45);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor:pointer;
  transition: transform .25s ease, border-color .25s ease, filter .25s ease;
}
.button:hover{
  transform: translateY(-1px);
  border-color: rgba(74,167,155,.45);
  filter: saturate(1.06);
}

.quiet{
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(242,239,231,.04);
  border-radius: 999px;
  padding: 11px 14px;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor:pointer;
  opacity: .92;
  transition: opacity .2s ease, transform .25s ease, border-color .25s ease;
}
.quiet:hover{
  opacity: 1;
  transform: translateY(-1px);
  border-color: rgba(242,239,231,.22);
}

.icon-btn{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.18);
  background: linear-gradient(180deg, rgba(242,239,231,.08), rgba(242,239,231,.04));
  box-shadow: var(--shadow2);
  cursor:pointer;
  transition: transform .22s ease, border-color .22s ease;
}
.icon-btn:hover{ transform: translateY(-1px); border-color: rgba(74,167,155,.5); }

.hero{
  position: relative;
  min-height: 100vh;
  padding-top: 78px;
  display:grid;
  align-items:end;
  isolation: isolate;
  overflow: hidden;
}
.hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 540px at 66% 16%, rgba(242,239,231,.24), transparent 60%),
    radial-gradient(860px 560px at 18% 72%, rgba(47,125,117,.12), transparent 60%),
    linear-gradient(180deg, rgba(200,210,209,.44), rgba(7,9,10,.22) 78%, rgba(7,9,10,.58));
  z-index:-3;
}
.hero__spotlight{
  position:absolute;
  inset:0;
  background: radial-gradient(520px 520px at var(--mx, 55%) var(--my, 40%), rgba(242,239,231,.12), transparent 55%);
  z-index:-2;
  pointer-events:none;
  mix-blend-mode: screen;
  opacity:.9;
}

.hero__stack{
  position:absolute;
  inset:0;
  z-index:-1;
}
.hero__slide{
  position:absolute;
  inset:-2%;
  background-image: var(--img);
  background-size: cover;
  background-position: center 42%;
  background-repeat: no-repeat;
  background-color: var(--mural);
  filter: contrast(1.02) saturate(.96) brightness(1.08);
  opacity: 0;
  transform: scale(1.045);
  transition: opacity 900ms cubic-bezier(.2,.8,.2,1), transform 1100ms cubic-bezier(.2,.8,.2,1);
}
.hero__slide::before{
  content:"";
  position:absolute;
  inset: -26px;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px) saturate(1.12) contrast(1.02);
  opacity: .16;
  transform: scale(1.06);
}
.hero__slide::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(12,18,18,.68), rgba(12,18,18,.20) 44%, rgba(12,18,18,.06) 72%),
    radial-gradient(900px 600px at 55% 34%, rgba(255,255,255,.06), rgba(5,6,7,.28) 76%),
    linear-gradient(180deg, rgba(255,255,255,.14), rgba(0,0,0,.24));
}
.hero__slide.is-active{
  opacity: 1;
  transform: scale(1.01);
}

.hero__content{
  width:min(var(--max), calc(100% - 72px));
  margin: 0 auto;
  padding: 74px 0 72px 0;
  position: relative;
}

.kicker{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.86);
  margin: 0 0 14px 0;
}
.display{
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: 0;
  font-size: clamp(38px, 4.8vw, 72px);
  margin: 0 0 18px 0;
  max-width: 16ch;
  color: var(--pearl);
  text-shadow: 0 18px 70px rgba(0,0,0,.54);
}
.display__line{
  display:block;
}
.display__line--name,
.display__line--scope{
  font-style: italic;
  font-weight: 500;
}
.display__line--name{
  font-size: .86em;
  margin-bottom: .08em;
}
.display__line--scope{
  margin-top: .18em;
  font-size: .54em;
  line-height: 1.22;
}
.lead{
  max-width: 62ch;
  font-size: 16px;
  line-height: 1.7;
  color: rgba(242,239,231,.82);
  margin: 0 0 24px 0;
}

.hero__controls{
  display:flex;
  align-items:center;
  gap: 12px;
  margin-top: 18px;
  flex-wrap: wrap;
}
.hero__meta{
  flex: 1 1 220px;
  min-width: 0;
  margin-left: 0;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(7,9,10,.68), rgba(7,9,10,.38));
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow2);
}
.hero__meta-title{
  font-family: var(--serif);
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 14px;
}
.hero__meta-sub{
  margin-top: 4px;
  font-size: 12px;
  color: rgba(242,239,231,.74);
  letter-spacing: .02em;
}

.hero__thumbs{
  margin-top: 26px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}
.thumb{
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(242,239,231,.04);
  padding: 10px 12px;
  cursor:pointer;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.thumb:hover{
  transform: translateY(-1px);
  border-color: rgba(74,167,155,.45);
  background: rgba(74,167,155,.08);
}
.thumb__label{
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .92;
}
.thumb.is-active{
  border-color: rgba(74,167,155,.55);
  background:
    radial-gradient(120px 50px at 40% 20%, rgba(74,167,155,.22), transparent 60%),
    radial-gradient(160px 60px at 90% 110%, rgba(154,106,68,.16), transparent 60%),
    rgba(242,239,231,.05);
}

.hero__float{
  position:absolute;
  right: 0;
  top: 70px;
  width: min(540px, 44vw);
  pointer-events:none;
  opacity: .48;
}
.float{
  font-family: var(--serif);
  letter-spacing: .26em;
  text-transform: uppercase;
  color: rgba(242,239,231,.56);
  filter: drop-shadow(0 22px 70px rgba(0,0,0,.6));
}
.float--a{
  font-size: 78px;
  line-height: .9;
  opacity: .22;
  transform: translate3d(0,0,0) rotate(-6deg);
  margin-bottom: 22px;
}
.float--b{
  font-size: 14px;
  opacity: .58;
  transform: translate3d(0,0,0) rotate(2deg);
}

.section{
  padding: 92px 0;
  position: relative;
}
.section:not(.section--gallery){
  color: var(--archive-ink);
}
.section:not(.section--gallery):not(.section--artist){
  background:
    radial-gradient(900px 500px at 14% 0%, rgba(242,239,231,.28), transparent 62%),
    linear-gradient(180deg, rgba(204,216,215,.96), rgba(183,198,197,.94));
}
.section:not(.section--gallery):not(.section--artist) + .section:not(.section--gallery):not(.section--artist){
  border-top: 1px solid rgba(16,24,24,.10);
}
.section:not(.section--gallery) .section-note,
.section:not(.section--gallery) .intro__copy{
  color: var(--archive-muted);
}
.section--gallery,
.section--artist,
.gblock,
.tax-card,
.exp,
.acard{
  color: var(--pearl);
}
.section.section--artist,
.section.section--artist .section-title,
.section.section--artist .button,
.section.section--artist .quiet,
.section.section--artist .chip{
  color: var(--pearl);
}
.section--artist .section-note,
.section--artist .artist__copy,
.section--gallery .section-note,
.gblock__copy,
.gblock__meta,
.acard__sub,
.exp__sub{
  color: rgba(242,239,231,.72);
}
.section--intro{ padding-top: 72px; }
.section--gallery{ padding-bottom: 104px; }
.section-title{
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.02em;
  font-size: clamp(34px, 3vw, 46px);
  margin: 0;
}
.section-note{
  margin: 10px 0 0 0;
  color: rgba(242,239,231,.72);
  max-width: 70ch;
  line-height: 1.7;
}
.section-head{
  display:grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 24px;
  align-items: end;
}
.section-head .section-title{
  grid-column: 1;
  grid-row: 1;
  margin: 0;
}
.section-head .section-note{
  grid-column: 1;
  grid-row: 2;
  margin: 0;
  max-width: 70ch;
}
.section-head > .button{
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: end;
  justify-self: end;
}
.section-head--split{
  display:grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 24px;
  align-items: end;
}
.section-head__main{
  grid-column: 1;
  display:flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}
.section-head__actions{
  grid-column: 2;
  grid-row: 1;
  align-self: end;
  justify-self: end;
}
.section-head + .aindex,
.section-head + .explorer{
  margin-top: 34px;
}

.intro{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 40px;
  align-items:end;
}
.intro__copy{
  margin: 0;
  color: rgba(242,239,231,.78);
  line-height: 1.75;
  font-size: 16px;
}
.stats{
  margin-top: 44px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.stat{
  border-radius: var(--radius);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.03));
  padding: 18px 18px 16px 18px;
  box-shadow: var(--shadow2);
}
.stat__num{
  font-family: var(--serif);
  font-size: 30px;
  letter-spacing: .02em;
}
.stat__label{
  margin-top: 6px;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(242,239,231,.72);
}

.tax-grid{
  margin-top: 34px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.tax-groups{
  margin-top: 34px;
  display:flex;
  flex-direction: column;
  gap: 18px;
}
.tax-group{
  padding-top: 10px;
  border-top: 1px solid rgba(242,239,231,.10);
}
.tax-group:first-child{ border-top: 0; padding-top: 0; }
.tax-group__head{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 12px;
}
.tax-group__title{
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: 14px;
  color: rgba(16,24,24,.86);
}
.tax-group__note{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(16,24,24,.54);
  white-space: nowrap;
}
.tax-group .tax-grid{ margin-top: 0; }

.tax-card.is-seed{
  opacity: .86;
}
.tax-card.is-seed .tax-card__label{
  color: rgba(242,239,231,.78);
}
.tax-card{
  grid-column: span 3;
  border-radius: var(--radius2);
  overflow:hidden;
  position: relative;
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(0,0,0,.2);
  box-shadow: var(--shadow2);
  min-height: 180px;
  transition: transform .35s cubic-bezier(.2,.8,.2,1), border-color .35s ease, filter .35s ease;
}
.tax-card__media{
  position:absolute;
  inset:0;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
  filter: saturate(.98) contrast(1.02) brightness(1.12);
  transform: none;
}
.tax-card__media::before{
  content:"";
  position:absolute;
  inset: -22px;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px) saturate(1.12) contrast(1.02);
  opacity: .18;
  transform: scale(1.05);
}
.tax-card__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(400px 180px at 30% 20%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.62));
}
.tax-card__label{
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 14px;
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 13px;
  text-shadow: 0 20px 60px rgba(0,0,0,.6);
}
.tax-card:hover{
  transform: translateY(-4px);
  border-color: rgba(74,167,155,.40);
  filter: saturate(1.05);
}
.tax-card:focus-visible{
  outline:none;
  box-shadow: var(--ring2), var(--shadow2);
}

.gallery{
  margin-top: 36px;
  display:flex;
  flex-direction: column;
  gap: 26px;
}
.gblock{
  width:min(var(--max), calc(100% - 72px));
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.2fr .95fr;
  gap: 22px;
  align-items: stretch;
}
.gblock--reverse{ grid-template-columns: .95fr 1.2fr; }
.gblock__media{
  border-radius: calc(var(--radius2) + 6px);
  overflow:hidden;
  border: 1px solid rgba(242,239,231,.12);
  box-shadow: var(--shadow);
  position: relative;
  min-height: 520px;
}
.gblock__media img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: contrast(1.03) saturate(.98) brightness(1.08);
  transform: none;
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
  background: #050505;
}
.gblock__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(520px 360px at 55% 30%, rgba(242,239,231,.12), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.54));
  pointer-events:none;
}
.gblock:hover .gblock__media img{ transform: none; }
.gblock__panel{
  border-radius: calc(var(--radius2) + 6px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 26px 24px;
  display:flex;
  flex-direction: column;
  justify-content: center;
}
.gblock__tag{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.92);
}
.gblock__title{
  font-family: var(--serif);
  font-weight: 400;
  margin: 12px 0 10px 0;
  letter-spacing: -0.02em;
  font-size: 34px;
  line-height: 1.05;
}
.gblock__meta{
  margin: 0 0 14px 0;
  font-size: 13px;
  letter-spacing: .02em;
  color: rgba(242,239,231,.70);
}
.gblock__copy{
  margin: 0 0 18px 0;
  line-height: 1.75;
  color: rgba(242,239,231,.78);
}
.textlink{
  align-self:flex-start;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .9;
  position: relative;
  padding: 10px 0;
}
.textlink::after{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  bottom: 5px;
  height: 1px;
  background: linear-gradient(90deg, rgba(74,167,155,.95), rgba(242,239,231,.65), transparent);
  transform: scaleX(.4);
  transform-origin:left;
  transition: transform .35s ease;
}
.textlink:hover::after{ transform: scaleX(1); }

.section--artist{
  padding: 104px 0;
}
.artist{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items: stretch;
}
.artist__panel{
  border-radius: calc(var(--radius2) + 8px);
  border: 1px solid rgba(242,239,231,.12);
  background:
    radial-gradient(700px 420px at 30% 20%, rgba(74,167,155,.10), transparent 62%),
    radial-gradient(700px 420px at 80% 90%, rgba(154,106,68,.14), transparent 62%),
    linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 30px 28px;
  position: relative;
  overflow:hidden;
}
.artist__copy{
  margin: 12px 0 18px 0;
  color: rgba(242,239,231,.78);
  line-height: 1.75;
  max-width: 62ch;
}
.artist__actions{ display:flex; gap: 10px; align-items:center; margin-top: 16px; }
.artist__lines{
  position:absolute;
  inset: -2px;
  pointer-events:none;
  background:
    radial-gradient(240px 140px at 18% 18%, rgba(74,167,155,.22), transparent 65%),
    radial-gradient(220px 140px at 76% 80%, rgba(154,106,68,.22), transparent 62%),
    repeating-linear-gradient(115deg, rgba(242,239,231,.09) 0 1px, transparent 1px 16px);
  mix-blend-mode: overlay;
  opacity: .10;
  mask-image: radial-gradient(closest-side at 30% 20%, rgba(0,0,0,.9), transparent 70%);
}
.artist__media{
  border-radius: calc(var(--radius2) + 8px);
  border: 1px solid rgba(242,239,231,.12);
  overflow:hidden;
  box-shadow: var(--shadow);
  position: relative;
  min-height: 540px;
}
.artist__frame{
  position:absolute;
  inset:0;
}
.artist__frame img{
  width:100%;
  height:100%;
  object-fit: contain;
  filter: contrast(1.07) saturate(.92);
  transform: none;
  background: #050505;
}
.artist__frame::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(460px 320px at 65% 25%, rgba(242,239,231,.14), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.72));
}
.artist__floating{
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.chip{
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.52);
  backdrop-filter: blur(10px);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  box-shadow: var(--shadow2);
}

.explorer{
  margin-top: 34px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.exp{
  grid-column: span 4;
  border-radius: calc(var(--radius2) + 8px);
  overflow:hidden;
  position: relative;
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(0,0,0,.22);
  box-shadow: var(--shadow2);
  min-height: 300px;
  transition: transform .36s cubic-bezier(.2,.8,.2,1), border-color .36s ease, filter .36s ease;
}
.exp__img{
  position:absolute;
  inset:0;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
  filter: saturate(1) contrast(1.02) brightness(1.1);
  transform: none;
  transition: transform .8s cubic-bezier(.2,.8,.2,1);
}
.exp__img::before{
  content:"";
  position:absolute;
  inset: -26px;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px) saturate(1.12) contrast(1.02);
  opacity: .18;
  transform: scale(1.05);
}
.exp__img::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(520px 220px at 30% 22%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.64));
}
.exp__label{
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  display:flex;
  flex-direction: column;
  gap: 6px;
}
.exp__title{
  font-family: var(--serif);
  font-size: 20px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.exp__sub{
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(242,239,231,.70);
}
.exp:hover{
  transform: translateY(-4px);
  border-color: rgba(74,167,155,.45);
  filter: saturate(1.05);
}
.exp:hover .exp__img{ transform: none; }

.quote{
  padding: 110px 0 120px 0;
  position: relative;
}
.quote::before{
  content:"";
  position:absolute;
  inset: 0;
  background:
    radial-gradient(720px 260px at 50% 30%, rgba(74,167,155,.12), transparent 65%),
    radial-gradient(720px 260px at 50% 80%, rgba(154,106,68,.16), transparent 62%);
  pointer-events:none;
}
.quote__figure{
  margin:0;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background:
    linear-gradient(180deg, rgba(242,239,231,.07), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 44px 40px;
  position: relative;
  overflow:hidden;
}
.quote__figure::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(260px 160px at 18% 20%, rgba(182,198,255,.22), transparent 65%),
    radial-gradient(260px 160px at 82% 76%, rgba(231,199,255,.18), transparent 65%),
    repeating-linear-gradient(98deg, rgba(242,239,231,.10) 0 1px, transparent 1px 20px);
  opacity: .10;
  mix-blend-mode: overlay;
  pointer-events:none;
  mask-image: radial-gradient(closest-side at 50% 50%, rgba(0,0,0,.95), transparent 72%);
}
.quote__text{
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(26px, 2.4vw, 38px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
  max-width: 32ch;
  color: var(--archive-ink);
}
.quote__cap{
  margin-top: 16px;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--archive-muted);
}

.footer{
  padding: 66px 0 48px 0;
  border-top: 1px solid rgba(242,239,231,.10);
  background: linear-gradient(180deg, rgba(7,9,10,.2), rgba(7,9,10,.55));
}
.footer__grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
  gap: 18px;
}
.footer__copy{
  margin: 14px 0 0 0;
  color: rgba(242,239,231,.72);
  line-height: 1.7;
  max-width: 44ch;
}
.footer__head{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.78);
  margin-top: 2px;
}
.footer__link{
  display:block;
  padding: 10px 0;
  font-size: 13px;
  color: rgba(242,239,231,.74);
  letter-spacing: .02em;
  transition: color .25s ease;
}
.footer__link:hover{ color: rgba(74,167,155,.92); }
.footer__bottom{
  margin-top: 28px;
  padding-top: 18px;
  border-top: 1px solid rgba(242,239,231,.10);
  display:flex;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.footer__fine{
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(242,239,231,.60);
}

.dialog{
  width: min(720px, calc(100% - 28px));
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.18);
  background: linear-gradient(180deg, rgba(7,9,10,.88), rgba(7,9,10,.66));
  color: var(--pearl);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}
.dialog::backdrop{
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(3px);
}
.dialog__inner{ padding: 18px 18px 16px 18px; }
.dialog__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(242,239,231,.12);
}
.dialog__title{
  font-family: var(--serif);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 14px;
}
.field{ display:flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.dialog__grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.dialog__grid .field{ margin-top: 0; }
.dialog__grid .field__input{ width: 100%; }
.dialog__grid + .dialog__hint{ margin-top: 12px; }
.dialog__grid + .dialog__hint + .dialog__actions{ margin-top: 14px; }
.dialog__grid + .dialog__hint + .dialog__actions .button{ margin-left: 0; }
.field__label{
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.72);
}
.field__input,
.field__textarea,
select.field__input{
  padding: 14px 14px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.42);
  color: var(--pearl);
  outline:none;
  color-scheme: dark;
}
.field__textarea{
  min-height: 100px;
  resize: vertical;
}
.field__input::placeholder,
.field__textarea::placeholder{
  color: rgba(242,239,231,.48);
  opacity: 1;
}
select.field__input option{
  background: #07090a;
  color: var(--pearl);
}
.field__input:-webkit-autofill,
.field__input:-webkit-autofill:hover,
.field__input:-webkit-autofill:focus{
  -webkit-text-fill-color: var(--pearl);
  box-shadow: 0 0 0 1000px rgba(7,9,10,.42) inset;
  caret-color: var(--pearl);
}
.field__input:focus,
.field__textarea:focus,
select.field__input:focus{
  box-shadow: var(--ring2);
  border-color: rgba(74,167,155,.45);
}
.dialog__hint{
  margin-top: 12px;
  color: rgba(242,239,231,.66);
  line-height: 1.6;
  font-size: 13px;
}
.dialog__actions{
  margin-top: 14px;
  display:flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 0;
}

@media (max-width: 720px){
  .dialog__grid{ grid-template-columns: 1fr; }
}

/* Reveal */
[data-reveal]{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 700ms ease, transform 900ms cubic-bezier(.2,.8,.2,1);
  will-change: opacity, transform;
}
[data-reveal].is-in{
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1100px){
  .nav{ display:none; }
  .hero__float{ display:none; }
  .intro{ grid-template-columns: 1fr; }
  .stats{ grid-template-columns: 1fr; }
  .tax-card{ grid-column: span 4; min-height: 170px; }
  .gblock, .gblock--reverse{ grid-template-columns: 1fr; }
  .gblock__media{ min-height: 420px; }
  .artist{ grid-template-columns: 1fr; }
  .artist__media{ min-height: 420px; }
  .exp{ grid-column: span 6; }
  .footer__grid{ grid-template-columns: 1.2fr 1fr; }
}
@media (max-width: 720px){
  .wrap{ width: min(var(--max), calc(100% - 48px)); }
  .topbar{
    top: 10px;
    right: 10px;
    bottom: auto;
    left: 10px;
    width: auto;
  }
  .topbar__inner{
    width: 100%;
    padding: 10px 12px;
    gap: 12px;
  }
  .topbar__cta{ display:none; }
  .section-head{
    grid-template-columns: 1fr;
  }
  .section-head .section-title,
  .section-head .section-note,
  .section-head > .button,
  .section-head__main,
  .section-head__actions{
    grid-column: 1;
    grid-row: auto;
    justify-self: start;
  }
  .section-head > .button,
  .section-head__actions{
    margin-top: 4px;
  }
  .hero{
    min-height: auto;
    align-items: start;
    padding-top: 76px;
  }
  .hero__content{
    width: min(var(--max), calc(100% - 48px));
    padding-top: 42px;
    padding-bottom: 48px;
  }
  .lead,
  .taxo__note{
    font-size: 15px;
    line-height: 1.6;
    overflow-wrap: normal;
  }
  .hero__controls{
    align-items: flex-start;
  }
  .hero__meta{
    flex: 1 1 100%;
    width: 100%;
  }
  .hero__meta-sub{
    overflow-wrap: anywhere;
  }
  .thumb{
    max-width: 100%;
  }
  .thumb__label{
    white-space: normal;
    line-height: 1.25;
  }
  .hero__thumbs{
    display:grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .thumb{
    width: 100%;
    text-align: center;
  }
  .taxon-hero__cap{ flex-direction: column; align-items: flex-start; gap: 6px; }
  .display{ font-size: 42px; }
  .tax-card{ grid-column: span 6; }
  .tax-group__head{
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
  }
  .tax-group__note{
    white-space: normal;
    line-height: 1.4;
  }
  .exp{ grid-column: span 12; min-height: 260px; }
  .quote__figure{ padding: 34px 22px; }
}
@media (max-width: 520px){
  .tax-card{
    grid-column: span 12;
    min-height: 168px;
  }
  .tax-card__label{
    left: 14px;
    right: 14px;
    font-size: 12px;
    line-height: 1.25;
    overflow-wrap: anywhere;
  }
}
@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; }
  [data-reveal]{ transition: none !important; opacity: 1 !important; transform:none !important; }
  .hero__slide{ transition: none !important; }
}

/* ===========================
   Taxonomy Index Screen
   =========================== */
.page{ min-height: 100%; }
.page--taxon{
  background: linear-gradient(180deg, #050505, #070708);
}
.page--taxon .wrap{
  width: min(var(--max), calc(100% - 72px));
}

/* ===========================
   Taxonomy Landing Pages
   =========================== */
.taxon-wrap{ width: min(var(--max), calc(100% - 72px)); margin: 0 auto; }
.taxon-hero{
  min-height: 100vh;
  padding-top: 84px;
  position: relative;
  isolation: isolate;
}
.taxon-hero__bg{
  position:absolute;
  inset:0;
  z-index:-4;
  background:
    radial-gradient(1200px 820px at 70% 18%, rgba(var(--t1, 74 167 155) / .16), transparent 58%),
    radial-gradient(980px 760px at 18% 72%, rgba(var(--t2, 154 106 68) / .18), transparent 56%),
    radial-gradient(760px 520px at 80% 84%, rgba(var(--t3, 182 198 255) / .10), transparent 62%),
    linear-gradient(180deg, #050505, #070708);
}
.taxon-hero__film{
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:
    radial-gradient(900px 620px at 42% 16%, rgba(0,0,0,.0), rgba(0,0,0,.78) 66%),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.46));
}
.taxon-hero__spot{
  position:absolute;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background: radial-gradient(560px 560px at var(--cx, 52%) var(--cy, 36%), rgba(242,239,231,.12), transparent 56%);
  mix-blend-mode: screen;
  opacity: .85;
}
.taxon-hero__grid{
  width: min(var(--max), calc(100% - 72px));
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  align-items: start;
  padding: 30px 0 66px 0;
}
.taxon-hero__mast{ position: relative; padding-top: 8px; }
.taxon-hero__title{
  font-family: var(--serif);
  font-weight: 400;
  margin: 0;
  letter-spacing: -0.03em;
  line-height: .90;
  font-size: clamp(54px, 6vw, 92px);
}
.taxon-hero__sub{
  display:block;
  margin-top: 12px;
  font-size: 14px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(242,239,231,.66);
}
.taxon-hero__lead{
  margin: 16px 0 0 0;
  max-width: 76ch;
  font-size: 16px;
  line-height: 1.75;
  color: rgba(242,239,231,.78);
}
.taxon-hero__actions{
  margin-top: 18px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items:center;
}
.taxon-hero__float{
  position:absolute;
  right: -12px;
  top: -8px;
  width: min(560px, 44vw);
  pointer-events:none;
  opacity: .70;
}
.taxon-hero__figure{
  margin:0;
  border-radius: calc(var(--radius2) + 12px);
  overflow:hidden;
  border: 1px solid rgba(242,239,231,.12);
  box-shadow: var(--shadow);
  position: sticky;
  top: 86px;
}
.taxon-hero__img{
  width:100%;
  height: calc(100vh - 172px);
  min-height: 560px;
  max-height: 920px;
  /* Taxonomy plates are composed on black; preserve the full image without cropping. */
  object-fit: contain;
  object-position: center;
  filter: contrast(1.06) saturate(.92);
  transform: none;
}
.taxon-hero__figure::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(520px 360px at 58% 28%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.86));
}
.taxon-hero__cap{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
  padding: 12px 12px;
  display:flex;
  gap: 12px;
  align-items: baseline;
}

.taxon-section{
  padding: 62px 0;
}
.taxon-section--showcase{ padding-top: 40px; }
.taxon-essay{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 26px 22px;
}
.taxon-essay__cols{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  color: rgba(242,239,231,.76);
  line-height: 1.8;
  font-size: 15px;
}
.taxon-essay__cols p{ margin:0; }
.taxon-essay__rule{
  margin-top: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(242,239,231,.0), rgba(var(--t1, 74 167 155) / .55), rgba(242,239,231,.0));
}

.showcase{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  align-items: stretch;
}
.showcase__panel{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background:
    radial-gradient(700px 420px at 30% 20%, rgba(var(--t1, 74 167 155) / .10), transparent 62%),
    radial-gradient(700px 420px at 80% 90%, rgba(var(--t2, 154 106 68) / .12), transparent 62%),
    linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 28px 22px;
  overflow:hidden;
}
.showcase__meta{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.showcase__media{
  border-radius: calc(var(--radius2) + 12px);
  border: 1px solid rgba(242,239,231,.12);
  overflow:hidden;
  box-shadow: var(--shadow);
  position: relative;
  min-height: 520px;
}
.showcase__img{
  position:absolute;
  inset:0;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
  filter: contrast(1.06) saturate(.92);
  transform: none;
}
.showcase__img::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(520px 360px at 58% 28%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.86));
}
.showcase__chip{
  position:absolute;
  left: 14px;
  bottom: 14px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow2);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.78);
}
.showcase__chip--b{ left: auto; right: 14px; bottom: 58px; }

.vdetails{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}
.vdetail{
  grid-column: span 4;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  overflow:hidden;
  box-shadow: var(--shadow2);
  background: rgba(0,0,0,.20);
  position: relative;
  min-height: 320px;
}
.vdetail__media{
  position:absolute;
  inset:0;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
  filter: contrast(1.06) saturate(.92);
  transform: none;
}
.vdetail__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(420px 260px at 58% 28%, rgba(242,239,231,.12), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.88));
}
.vdetail__cap{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
  padding: 14px 14px;
}
.vdetail__t{
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.vdetail__s{
  margin-top: 6px;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(242,239,231,.70);
  line-height: 1.55;
}

.imggrid--taxon .tile img{ height: 300px; }

.taxon-related{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: start;
}
.makers{
  margin-top: 16px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.maker{
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  padding: 14px 14px;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.maker:hover{
  transform: translateY(-1px);
  border-color: rgba(var(--t1, 74 167 155) / .45);
  background: rgba(var(--t1, 74 167 155) / .06);
}
.maker__n{
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: -0.01em;
}
.maker__r{
  margin-top: 6px;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(242,239,231,.68);
}
.rtags{ margin-top: 14px; display:flex; gap: 10px; flex-wrap: wrap; }

.footer--taxon{
  border-top: 1px solid rgba(242,239,231,.10);
  background: linear-gradient(180deg, rgba(7,9,10,.22), rgba(7,9,10,.60));
}

/* Per-taxon atmospheric palettes */
.page--taxon-cephalopods{ --t1: 182 198 255; --t2: 74 167 155; --t3: 231 199 255; }
.page--taxon-frogs{ --t1: 74 167 155; --t2: 154 106 68; --t3: 47 125 117; }
.page--taxon-marine-fish{ --t1: 217 211 199; --t2: 74 167 155; --t3: 182 198 255; }
.page--taxon-fresh-fish{ --t1: 74 167 155; --t2: 182 198 255; --t3: 154 106 68; }
.page--taxon-birds{ --t1: 231 199 255; --t2: 74 167 155; --t3: 182 198 255; }
.page--taxon-insects{ --t1: 182 198 255; --t2: 154 106 68; --t3: 74 167 155; }
.page--taxon-arachnids{ --t1: 154 106 68; --t2: 74 167 155; --t3: 182 198 255; }
.page--taxon-gastropods{ --t1: 154 106 68; --t2: 74 167 155; --t3: 217 211 199; }
.page--taxon-mammals{ --t1: 154 106 68; --t2: 231 199 255; --t3: 74 167 155; }
.page--taxon-crustaceans{ --t1: 74 167 155; --t2: 154 106 68; --t3: 217 211 199; }
.page--taxon-echinoderms{ --t1: 74 167 155; --t2: 217 211 199; --t3: 154 106 68; }
.page--taxon-reptiles{ --t1: 154 106 68; --t2: 217 211 199; --t3: 74 167 155; }
.page--taxon-turtles{ --t1: 217 211 199; --t2: 154 106 68; --t3: 74 167 155; }
.page--taxon-snakes{ --t1: 154 106 68; --t2: 74 167 155; --t3: 47 125 117; }
.page--taxon-fantastical{ --t1: 231 199 255; --t2: 154 106 68; --t3: 74 167 155; }
.page--taxon-european{ --t1: 217 211 199; --t2: 182 198 255; --t3: 74 167 155; }

@media (max-width: 1100px){
  .taxon-hero__grid{ grid-template-columns: 1fr; }
  .taxon-hero__float{ display:none; }
  .taxon-hero__figure{ position: relative; top:auto; }
  .taxon-hero__img{ height: 58vh; min-height: 420px; max-height: none; }
  .taxon-essay__cols{ grid-template-columns: 1fr; }
  .showcase{ grid-template-columns: 1fr; }
  .showcase__media{ min-height: 420px; }
  .vdetail{ grid-column: span 12; min-height: 280px; }
  .taxon-related{ grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  .page--taxon .wrap,
  .taxon-wrap{
    width: min(var(--max), calc(100% - 48px));
  }
  .taxon-hero__grid{ width: min(var(--max), calc(100% - 48px)); }
  .taxon-hero__title{ font-size: 44px; }
  .taxon-hero{
    min-height: auto;
    padding-top: 76px;
  }
  .taxon-hero__grid{
    padding-top: 26px;
    padding-bottom: 42px;
    gap: 18px;
  }
  .taxon-hero__img{
    height: min(58vh, 340px);
    min-height: 300px;
    max-height: 360px;
  }
}

/* ===========================
   Advanced Search
   =========================== */
.page--search{
  background:
    radial-gradient(1200px 820px at 70% 18%, rgba(74,167,155,.12), transparent 58%),
    radial-gradient(980px 760px at 18% 72%, rgba(154,106,68,.16), transparent 56%),
    radial-gradient(760px 520px at 80% 84%, rgba(182,198,255,.08), transparent 62%),
    linear-gradient(180deg, #050505, #070708);
}
.swrap{ width: min(var(--max), calc(100% - 72px)); margin: 0 auto; }

.shead{
  padding-top: 92px;
  padding-bottom: 26px;
  position: relative;
  isolation: isolate;
}
.shead::after{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(242,239,231,.14), transparent);
  opacity: .9;
}
.shead__grid{
  display:grid;
  grid-template-columns: 1fr .9fr;
  gap: 18px;
  align-items: end;
}
.stitle{
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: .92;
  font-size: clamp(44px, 4.8vw, 72px);
  margin: 0;
}
.stitle__sub{
  display:block;
  margin-top: 12px;
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(242,239,231,.66);
}
.squery{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 16px 16px;
}
.squery__field{ display:flex; flex-direction: column; gap: 10px; }
.squery__label{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.72);
}
.squery__input{
  padding: 14px 14px;
  border-radius: 16px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.36);
  color: var(--pearl);
  outline: none;
}
.squery__input::placeholder{
  color: rgba(242,239,231,.48);
  opacity: 1;
}
.squery__input:focus{ box-shadow: var(--ring2); border-color: rgba(74,167,155,.45); }
.squery__meta{
  margin-top: 12px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.squery__count{
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.64);
}
.squery__sep{ opacity: .35; }
.squery__clear{ padding: 10px 12px; }

.sbody{ padding: 28px 0 82px 0; }
.sgrid{
  display:grid;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr) minmax(0, 420px);
  gap: 14px;
  align-items: start;
}
.filters{
  min-width: 0;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 18px 16px;
  position: sticky;
  top: 86px;
}
.filters__head{ padding-bottom: 14px; border-bottom: 1px solid rgba(242,239,231,.10); }
.filters__title{
  font-family: var(--serif);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 14px;
}
.filters__sub{
  margin-top: 8px;
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(242,239,231,.58);
  overflow-wrap: anywhere;
}
.filters__group{ margin-top: 16px; }
.filters__k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.86);
}
.filters__hint{
  margin-top: 10px;
  color: rgba(242,239,231,.62);
  font-size: 13px;
  line-height: 1.55;
}

.checks{
  margin-top: 10px;
  display:flex;
  flex-direction: column;
  gap: 10px;
  max-height: 260px;
  overflow: auto;
  padding-right: 4px;
}
.check{
  min-width: 0;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.30);
  cursor:pointer;
  transition: border-color .25s ease, background .25s ease, transform .25s ease;
}
.check:hover{
  transform: translateY(-1px);
  border-color: rgba(74,167,155,.34);
  background: rgba(74,167,155,.06);
}
.check__i{ position:absolute; opacity: 0; pointer-events:none; }
.check__b{
  width: 16px;
  height: 16px;
  border-radius: 4px;
  border: 1px solid rgba(242,239,231,.20);
  background: rgba(242,239,231,.03);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  position: relative;
}
.check__i:checked + .check__b{
  border-color: rgba(74,167,155,.55);
  background:
    radial-gradient(12px 12px at 30% 30%, rgba(242,239,231,.58), transparent 60%),
    linear-gradient(135deg, rgba(74,167,155,.85), rgba(154,106,68,.45));
}
.check__t{
  font-family: var(--serif);
  font-size: 16px;
  letter-spacing: -0.01em;
}

.sel{
  margin-top: 10px;
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.30);
  color: var(--pearl);
  outline: none;
  appearance: none;
  color-scheme: dark;
}
.sel option{
  background: #07090a;
  color: var(--pearl);
}
.sel:focus{ box-shadow: var(--ring2); border-color: rgba(74,167,155,.45); }

.yr{
  margin-top: 10px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.yr__f{ display:flex; flex-direction: column; gap: 8px; }
.yr__l{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.60);
}
.yr__i{
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.30);
  color: var(--pearl);
  outline: none;
  color-scheme: dark;
}
.yr__i::placeholder{
  color: rgba(242,239,231,.52);
  opacity: 1;
}
.yr__i:focus{ box-shadow: var(--ring2); border-color: rgba(74,167,155,.45); }

.results{
  min-width: 0;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 18px 16px;
  min-height: 520px;
}
.results__head{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(242,239,231,.10);
}
.results__title{
  font-family: var(--serif);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 14px;
}
.results__note{
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(242,239,231,.58);
}
.rgrid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.r{
  border-radius: calc(var(--radius2) + 8px);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(0,0,0,.20);
  overflow:hidden;
  box-shadow: var(--shadow2);
  position: relative;
  min-height: 240px;
  transition: transform .34s cubic-bezier(.2,.8,.2,1), border-color .34s ease, filter .34s ease;
}
.r__img{
  position:absolute;
  inset:0;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
  filter: contrast(1.06) saturate(.92);
  transform: none;
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
}
.r__img::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(420px 260px at 58% 28%, rgba(242,239,231,.12), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.88));
}
.r__meta{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
  padding: 14px 14px;
}
.r__t{
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.r__s{
  margin-top: 8px;
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(242,239,231,.70);
}
.r__k{
  margin-top: 8px;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.86);
}
.r:hover{
  transform: translateY(-3px);
  border-color: rgba(74,167,155,.40);
  filter: saturate(1.05);
}
.r:hover .r__img{ transform: none; }

.previewpane{
  min-width: 0;
  position: sticky;
  top: 86px;
  display:flex;
  flex-direction: column;
  gap: 12px;
}
.pmeta{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 14px 14px;
}
.pmeta__row{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.30);
  margin-top: 10px;
}
.pmeta__row:first-child{ margin-top: 0; }
.pmeta__k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(154,106,68,.86);
}
.pmeta__v{
  color: rgba(242,239,231,.76);
  line-height: 1.55;
  font-size: 13px;
}

@media (max-width: 1200px){
  .shead__grid{ grid-template-columns: 1fr; }
  .sgrid{ grid-template-columns: minmax(0, 1fr); }
  .filters, .previewpane{ position: static; }
  .rgrid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px){
  .swrap{ width: min(var(--max), calc(100% - 48px)); }
  .rgrid{ grid-template-columns: 1fr; }
  .yr{ grid-template-columns: 1fr; }
}
.page--object{
  background:
    radial-gradient(1100px 900px at 70% 18%, rgba(47,125,117,.14), transparent 58%),
    radial-gradient(900px 760px at 18% 70%, rgba(154,106,68,.18), transparent 56%),
    radial-gradient(760px 520px at 80% 84%, rgba(182,198,255,.08), transparent 62%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
.page--object .wrap{
  width: min(var(--max), calc(100% - 72px));
}

/* ===========================
   Object Page
   =========================== */
.obj{
  padding-top: 84px;
}
.obj__hero{
  position: relative;
  padding: 18px 0 58px 0;
  isolation: isolate;
}
.obj__bg{
  position:absolute;
  inset:0;
  z-index:-3;
  background:
    radial-gradient(900px 620px at 42% 16%, rgba(0,0,0,.0), rgba(0,0,0,.76) 66%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.42));
}
.obj__spot{
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background: radial-gradient(560px 560px at var(--ox, 52%) var(--oy, 36%), rgba(242,239,231,.12), transparent 56%);
  mix-blend-mode: screen;
  opacity: .85;
}
.obj__hero-grid,
.obj__grid{
  width:min(var(--max), calc(100% - 72px));
  margin:0 auto;
  display:grid;
  grid-template-columns: 1.18fr .92fr;
  gap: 18px;
  align-items: start;
}
.obj__figure,
.obj__hero-media{
  margin:0;
  border-radius: calc(var(--radius2) + 12px);
  overflow:hidden;
  border: 1px solid rgba(242,239,231,.12);
  box-shadow: var(--shadow);
  position: sticky;
  top: 86px;
  isolation: isolate;
}
.obj__hero-img{
  display:block;
  width:100%;
  height: calc(100vh - 172px);
  min-height: 560px;
  max-height: 900px;
  object-fit: contain;
  object-position: center;
  filter: contrast(1.06) saturate(.92);
  transform: none;
  cursor: zoom-in;
  background: #050505;
}
.obj__figure::after,
.obj__hero-media::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(520px 360px at 58% 28%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.82));
}
.obj__caption,
.obj__cap{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
  padding: 12px 12px;
  display:flex;
  gap: 12px;
  align-items: baseline;
  z-index: 2;
}
.cap__float{
  font-family: var(--serif);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(74,167,155,.92);
}
.cap__text{
  font-size: 12px;
  color: rgba(242,239,231,.72);
  line-height: 1.55;
}

.obj__mast{
  padding: 10px 0 0 0;
  position: relative;
}
.obj__title{
  font-family: var(--serif);
  font-weight: 400;
  margin: 0;
  letter-spacing: -0.03em;
  line-height: .92;
  font-size: clamp(44px, 4.6vw, 74px);
}
.obj__hero-left{
  padding: 10px 0 0 0;
  position: relative;
}
.obj__sub{
  margin: 18px 0 0 0;
  max-width: 66ch;
  color: rgba(242,239,231,.72);
  line-height: 1.7;
  font-size: 15px;
}
.obj__title-accent{
  display:block;
  margin-top: 10px;
  font-size: 18px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(242,239,231,.64);
}
.obj__byline{
  margin-top: 18px;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 18px 16px;
}
.obj__label{
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.68);
}
.obj__value{
  margin-top: 6px;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -0.01em;
}
.obj__meta4,
.obj__meta{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.kv{
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.34);
  padding: 12px 12px;
}
.kv__k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.86);
}
.kv__v{
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(242,239,231,.76);
}
.obj__actions{
  margin-top: 16px;
  display:flex;
  gap: 10px;
  align-items:center;
  flex-wrap: wrap;
}
.obj__chips{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.chip--link{
  cursor:pointer;
  transition: transform .25s ease, border-color .25s ease;
}
.chip--link:hover{
  transform: translateY(-1px);
  border-color: rgba(74,167,155,.45);
}
.obj__float{
  position:absolute;
  right: -12px;
  top: -8px;
  width: min(520px, 40vw);
  pointer-events:none;
  opacity: .72;
}

.obj__section{
  padding: 56px 0;
}
.obj__wrap{ width:min(var(--max), calc(100% - 72px)); margin:0 auto; }
.obj__cols{
  display:grid;
  grid-template-columns: 1.12fr .88fr;
  gap: 18px;
  align-items: start;
}
.obj__cols--stack{ grid-template-columns: 1fr 1fr; }
.obj__panel{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 22px 20px;
}
.obj__panel--wide{ padding: 26px 22px; }
.obj__panel--aside{ padding: 20px 18px; }
.obj__h{
  margin: 0;
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 14px;
}
.obj__p{
  margin: 14px 0 0 0;
  color: rgba(242,239,231,.76);
  line-height: 1.75;
  font-size: 15px;
}
.obj__aside{
  display:flex;
  flex-direction: column;
  gap: 14px;
}
.obj__callout{
  margin-top: 16px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.10);
  background:
    radial-gradient(320px 160px at 30% 20%, rgba(74,167,155,.10), transparent 64%),
    rgba(242,239,231,.03);
  padding: 14px 14px;
}
.obj__callout-k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(154,106,68,.86);
}
.obj__callout-v{
  margin-top: 8px;
  color: rgba(242,239,231,.78);
  line-height: 1.65;
}
.obj__tags{ display:flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.tag{
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(242,239,231,.04);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.tag:hover{
  transform: translateY(-1px);
  border-color: rgba(74,167,155,.45);
  background: rgba(74,167,155,.06);
}

.meta{
  margin-top: 14px;
  display:flex;
  flex-direction: column;
  gap: 12px;
}
.meta__row{
  display:grid;
  grid-template-columns: 180px 1fr;
  gap: 14px;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.34);
}
.meta dt{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.86);
}
.meta dd{
  margin: 0;
  color: rgba(242,239,231,.78);
  line-height: 1.65;
}
.fnref{
  color: rgba(242,239,231,.88);
  text-decoration:none;
}
.fnref:hover{ color: rgba(74,167,155,.92); }

.refs{
  margin: 14px 0 0 0;
  padding-left: 18px;
  display:flex;
  flex-direction: column;
  gap: 12px;
}
.refs li{
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.34);
  padding: 12px 12px;
}
.refs__k{
  display:block;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(154,106,68,.86);
}
.refs__v{
  display:block;
  margin-top: 8px;
  color: rgba(242,239,231,.76);
  line-height: 1.65;
}
.cite{
  display:inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.16);
  background: rgba(242,239,231,.05);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.citebox{
  margin-top: 14px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.34);
  padding: 12px 12px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.citebox__row{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  align-items: baseline;
}
.citebox__k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.86);
}
.citebox__v{
  color: rgba(242,239,231,.76);
  line-height: 1.6;
}

.imggrid{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}
.tile{
  --timg: none;
  grid-column: span 4;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  overflow:hidden;
  background: rgba(0,0,0,.20);
  box-shadow: var(--shadow2);
  position: relative;
  cursor: pointer;
  padding: 0;
  transition: transform .34s cubic-bezier(.2,.8,.2,1), border-color .34s ease, filter .34s ease;
}
.tile::before{
  content:"";
  position:absolute;
  inset: -28px;
  z-index: 0;
  background-image: var(--timg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px) saturate(1.12) contrast(1.02);
  opacity: .18;
  transform: scale(1.05);
  pointer-events:none;
}
.tile img{
  width:100%;
  height: 320px;
  /* Preserve plate compositions; avoid cropping labels/edges in source plates. */
  object-fit: contain;
  object-position: var(--focus, 50% 50%);
  filter: contrast(1.02) saturate(.98) brightness(1.1);
  transform: none;
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
  background: #050505;
  position: relative;
  z-index: 1;
}
.tile::after{
  content:"";
  position:absolute;
  inset:0;
  z-index: 2;
  pointer-events:none;
  background:
    radial-gradient(420px 260px at 58% 28%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.54));
}
.tile__cap{
  position:absolute;
  left: 12px;
  bottom: 12px;
  z-index: 3;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow2);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.78);
}
.tile:hover{
  transform: translateY(-3px);
  border-color: rgba(74,167,155,.40);
  filter: saturate(1.05);
}
.tile:hover img{ transform: none; }
.tile--hero{ grid-column: span 8; }
.tile--hero img{ height: 320px; }

.rel{
  margin-top: 22px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}
.rel__card{
  grid-column: span 4;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  overflow:hidden;
  box-shadow: var(--shadow2);
  background: rgba(0,0,0,.20);
  position: relative;
  min-height: 260px;
  transition: transform .34s cubic-bezier(.2,.8,.2,1), border-color .34s ease, filter .34s ease;
}
.rel__img{
  position:absolute;
  inset:0;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
  filter: contrast(1.05) saturate(.92);
  transform: none;
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
}
.rel__img::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(420px 260px at 58% 28%, rgba(242,239,231,.12), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.14), rgba(0,0,0,.86));
}
.rel__label{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
  padding: 14px 14px;
}
.rel__t{
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.rel__s{
  margin-top: 6px;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(242,239,231,.70);
}
.rel__card:hover{
  transform: translateY(-3px);
  border-color: rgba(74,167,155,.40);
  filter: saturate(1.05);
}
.rel__card:hover .rel__img{ transform: none; }

.footnotes{
  margin: 14px 0 0 0;
  padding-left: 18px;
  color: rgba(242,239,231,.76);
  line-height: 1.7;
}
.footnotes li{ margin: 10px 0; }
.backref{
  margin-left: 8px;
  color: rgba(74,167,155,.88);
  text-decoration:none;
}
.backref:hover{ color: rgba(242,239,231,.88); }

.lightbox{
  width: min(1200px, calc(100% - 28px));
  border-radius: calc(var(--radius2) + 12px);
  border: 1px solid rgba(242,239,231,.18);
  background: linear-gradient(180deg, rgba(7,9,10,.90), rgba(7,9,10,.72));
  color: var(--pearl);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}
.lightbox::backdrop{
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(3px);
}
.lightbox__inner{ padding: 16px; position: relative; }
.lightbox__close{
  position:absolute;
  right: 16px;
  top: 16px;
}
.lightbox__figure{ margin:0; }
.lightbox__img{
  width: 100%;
  height: min(78vh, 760px);
  object-fit: contain;
  object-position: 50% 50%;
  background: rgba(0,0,0,.28);
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  transition: opacity 220ms ease;
}
.lightbox__cap{
  margin-top: 12px;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.70);
}
.lightbox__nav{
  margin-top: 12px;
  display:flex;
  gap: 10px;
  justify-content: center;
  padding: 0;
}

@media (max-width: 1100px){
  .obj__hero-grid,
  .obj__grid{ grid-template-columns: 1fr; }
  .obj__figure,
  .obj__hero-media{ position: relative; top:auto; }
  .obj__hero-img{ height: 58vh; min-height: 420px; max-height: none; }
  .obj__cols, .obj__cols--stack{ grid-template-columns: 1fr; }
  .imggrid .tile{ grid-column: span 6; }
  .imggrid .tile--hero{ grid-column: span 12; }
  .rel__card{ grid-column: span 6; }
  .obj__float{ display:none; }
}
@media (max-width: 720px){
  .page--object .wrap,
  .obj__wrap{
    width: min(var(--max), calc(100% - 48px));
  }
  .obj{ padding-top: 76px; }
  .obj__hero{ padding-top: 8px; padding-bottom: 42px; }
  .obj__hero-grid,
  .obj__grid{
    width: min(var(--max), calc(100% - 48px));
    gap: 18px;
  }
  .obj__hero-img{
    height: min(58vh, 340px);
    min-height: 300px;
    max-height: 360px;
  }
  .meta__row{ grid-template-columns: 1fr; }
  .kv__v{ font-size: 12px; }
  .imggrid .tile{ grid-column: span 12; }
  .rel__card{ grid-column: span 12; }
}
.page--taxonomy{
  background:
    radial-gradient(1100px 800px at 70% 18%, rgba(47,125,117,.14), transparent 58%),
    radial-gradient(900px 700px at 22% 70%, rgba(154,106,68,.20), transparent 56%),
    radial-gradient(700px 500px at 80% 82%, rgba(182,198,255,.08), transparent 62%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
.page--taxonomy .wrap{
  width: min(var(--max), calc(100% - 72px));
}

.taxo{
  min-height: 100vh;
  padding-top: 84px;
  position: relative;
  isolation: isolate;
}
.taxo__bg{
  position:absolute;
  inset:0;
  z-index:-3;
  background:
    radial-gradient(1000px 520px at 40% 16%, rgba(0,0,0,.0), rgba(0,0,0,.72) 66%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.42));
}
.taxo__spot{
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background: radial-gradient(560px 560px at var(--tx, 42%) var(--ty, 32%), rgba(242,239,231,.12), transparent 56%);
  mix-blend-mode: screen;
  opacity: .85;
}
.taxo__head{
  padding-top: 28px;
  padding-bottom: 24px;
}
.taxo__title{
  font-family: var(--serif);
  font-weight: 400;
  margin: 0;
  letter-spacing: -0.03em;
  line-height: .92;
  font-size: clamp(54px, 6vw, 86px);
}
.taxo__title-accent{
  background: linear-gradient(90deg, rgba(74,167,155,.95), rgba(242,239,231,.9), rgba(154,106,68,.92));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.taxo__note{
  margin: 14px 0 0 0;
  color: rgba(242,239,231,.76);
  max-width: 74ch;
  line-height: 1.7;
}

.taxo__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 18px;
  align-items: start;
  padding-bottom: 76px;
}

.taxo__list{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 22px 20px;
  overflow: hidden;
}

.tree{
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: item;
}
.tree__item{
  position: relative;
  padding: 6px 0;
}
.tree__item::before{
  counter-increment: item;
  content: counter(item, decimal-leading-zero);
  position:absolute;
  left: 0;
  top: 16px;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.48);
}
.tree__item--has-children::before{
  /* Keep numbering aligned even with toggle button */
  left: 0;
}

.tree__toggle{
  position:absolute;
  left: 36px;
  top: 8px;
  width: 40px;
  height: 40px;
  z-index: 3;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(242,239,231,.04);
  cursor:pointer;
  display:grid;
  place-items:center;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.tree__toggle:hover{
  transform: translateY(-1px);
  border-color: rgba(74,167,155,.45);
  background: rgba(74,167,155,.08);
}
.tree__toggle.is-open{
  border-color: rgba(74,167,155,.52);
  background:
    radial-gradient(120px 50px at 40% 20%, rgba(74,167,155,.18), transparent 60%),
    rgba(242,239,231,.05);
}
.tree__chev{
  font-size: 18px;
  line-height: 1;
  color: rgba(242,239,231,.82);
}
.tree__toggle.is-open .tree__chev{ transform: rotate(45deg); }

.tree__row{
  position: relative;
  z-index: 1;
  display:flex;
  align-items: baseline;
  gap: 12px;
  padding: 16px 12px 16px 76px;
  border-radius: 16px;
  border: 1px solid transparent;
  transition: border-color .25s ease, background .25s ease, transform .25s ease;
}
.tree__row:hover,
.tree__row:focus-visible{
  outline:none;
  border-color: rgba(74,167,155,.34);
  background: rgba(74,167,155,.06);
  transform: translateY(-1px);
}
.tree__row.is-open{
  border-color: rgba(242,239,231,.14);
  background:
    radial-gradient(320px 160px at 30% 20%, rgba(74,167,155,.10), transparent 64%),
    rgba(242,239,231,.04);
}

.tree__name{
  font-family: var(--serif);
  font-size: 30px;
  letter-spacing: -0.02em;
  line-height: 1.05;
  flex: 0 1 auto;
}
.tree__dots{
  height: 1px;
  flex: 1 1 auto;
  background: linear-gradient(90deg, rgba(242,239,231,.12), rgba(242,239,231,.0));
  transform: translateY(-4px);
  opacity: .9;
}
.tree__meta{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(242,239,231,.60);
  flex: 0 0 auto;
  white-space: nowrap;
}

.tree--sub{
  counter-reset: subitem;
  padding-left: 38px;
  margin-top: 6px;
  margin-bottom: 6px;
}
.tree--sub .tree__item::before{
  counter-increment: subitem;
  content: counter(item, decimal-leading-zero) "." counter(subitem);
  left: 0;
  color: rgba(242,239,231,.38);
}
.tree__row--sub{
  padding-left: 76px;
}
.tree__row--sub .tree__name{
  font-size: 22px;
  letter-spacing: 0;
}

.tree__children{
  height: 0;
  overflow: hidden;
  transition: height 520ms cubic-bezier(.2,.8,.2,1);
}
.tree__children.is-open{ height: auto; }

.taxo__hint{
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(242,239,231,.10);
  color: rgba(242,239,231,.66);
  font-size: 13px;
  line-height: 1.6;
}
.kbd{
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(242,239,231,.04);
}

.taxo__preview{
  display:flex;
  flex-direction: column;
  gap: 14px;
  align-self: stretch;
}
.preview{
  --pimg: none;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  overflow:hidden;
  box-shadow: var(--shadow);
  background: rgba(0,0,0,.20);
  position: relative;
  min-height: 520px;
}
.preview::before{
  content:"";
  position:absolute;
  inset: -26px;
  z-index: 0;
  background-image: var(--pimg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(18px) saturate(1.12) contrast(1.02);
  opacity: .28;
  transform: scale(1.05);
  pointer-events:none;
}

.taxo__preview{
  position: sticky;
  top: 86px;
}
.preview{
  height: calc(100vh - 160px);
  min-height: 520px;
  max-height: 860px;
}
.preview__frame{
  position:absolute;
  inset:0;
  z-index: 1;
}
.preview__img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: contrast(1.06) saturate(.92);
  transform: none;
  transition: opacity 240ms ease;
}
.preview__overlay{
  position:absolute;
  inset:0;
  z-index: 2;
  background:
    radial-gradient(520px 360px at 58% 28%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.80));
  pointer-events:none;
}
.preview__label{
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  z-index: 3;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
  padding: 14px 14px;
}
.preview__title{
  font-family: var(--serif);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 14px;
}
.preview__sub{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(242,239,231,.72);
  letter-spacing: .02em;
  line-height: 1.55;
}

@media (max-width: 1100px){
  .taxo__grid{ grid-template-columns: 1fr; }
  .preview{ min-height: 420px; }
  .tree__name{ font-size: 26px; }
  .taxo__preview{ position: static; }
  .preview{ height: auto; max-height: none; }
}
@media (max-width: 720px){
  .page--taxonomy .wrap{
    width: min(var(--max), calc(100% - 48px));
  }
  .taxo__title{ font-size: 44px; }
  .taxo__head{
    padding-top: 22px;
    padding-bottom: 20px;
  }
  .taxo__list{
    padding: 16px 12px;
  }
  .tree__item{
    padding: 4px 0;
  }
  .tree__row{
    padding: 13px 10px 13px 52px;
    gap: 8px;
  }
  .tree__row--sub{
    padding-left: 52px;
  }
  .tree__toggle{
    left: 10px;
    top: 8px;
    width: 34px;
    height: 34px;
  }
  .tree__item::before{ display:none; }
  .tree--sub{ padding-left: 0; }
  .tree--sub .tree__item::before{ display:none; }
  .tree__name{
    font-size: 24px;
    overflow-wrap: anywhere;
  }
  .tree__row--sub .tree__name{
    font-size: 20px;
  }
  .tree__meta,
  .tree__dots{
    display:none;
  }
  .taxo__hint{
    display: none;
  }
  .preview{
    min-height: 360px;
  }
}

/* ===========================
   Artists & Simple Pages
   =========================== */
.page--artists{
  background:
    radial-gradient(1100px 780px at 72% 14%, rgba(74,167,155,.14), transparent 60%),
    radial-gradient(860px 640px at 18% 76%, rgba(154,106,68,.16), transparent 62%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
.ahead{
  padding: 94px 0 18px 0;
}
.ahead__title{
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: -0.02em;
  font-size: clamp(52px, 6.2vw, 84px);
  line-height: 0.95;
  margin: 10px 0 0 0;
}
.ahead__accent{
  color: rgba(74,167,155,.92);
  text-shadow: 0 40px 120px rgba(74,167,155,.14);
}
.ahead__note{
  margin-top: 16px;
  max-width: 72ch;
  color: rgba(242,239,231,.74);
  line-height: 1.65;
  font-size: 15px;
}
.section--artists{ padding-top: 22px; }
.aindex{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.acard{
  grid-column: span 4;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  overflow:hidden;
  box-shadow: var(--shadow2);
  position: relative;
  display:grid;
  grid-template-rows: 220px auto;
  text-decoration:none;
  color: inherit;
  transition: transform .34s cubic-bezier(.2,.8,.2,1), border-color .34s ease, filter .34s ease;
}
.acard__img{
  --img: none;
  position: relative;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  filter: contrast(1.02) saturate(.98) brightness(1.1);
}
.acard__img::before{
  content:"";
  position:absolute;
  inset:-26px;
  background-image: var(--img);
  background-size: cover;
  background-position: center;
  filter: blur(18px) saturate(1.14) contrast(1.02);
  opacity: .18;
  transform: scale(1.06);
}
.acard__img::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(420px 240px at 56% 26%, rgba(242,239,231,.14), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.58));
}
.acard__meta{
  padding: 14px 14px 16px 14px;
  display:flex;
  flex-direction: column;
  gap: 8px;
}
.acard__name{
  font-family: var(--serif);
  font-size: 20px;
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.acard__sub{
  font-size: 12px;
  color: rgba(242,239,231,.70);
  letter-spacing: .10em;
  text-transform: uppercase;
}
.acard__row{
  margin-top: 4px;
  display:flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.idpill{
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(242,239,231,.04);
  font-size: 11px;
  letter-spacing: .08em;
  color: rgba(242,239,231,.78);
  white-space: nowrap;
}
.idpill--rep{
  border-color: rgba(74,167,155,.28);
  background: rgba(74,167,155,.06);
  color: rgba(220,252,248,.82);
}
.idpill--type{
  border-color: rgba(154,106,68,.34);
  background: rgba(154,106,68,.08);
  color: rgba(255,236,215,.80);
}
.acard__tag{
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(74,167,155,.30);
  background: rgba(74,167,155,.06);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(74,167,155,.88);
  white-space: nowrap;
}
.acard:hover{
  transform: translateY(-4px);
  border-color: rgba(74,167,155,.42);
  filter: saturate(1.06);
}
.acard:focus-visible{
  outline:none;
  box-shadow: var(--ring2), var(--shadow2);
}

.page--artist{
  background:
    radial-gradient(1200px 900px at 70% 18%, rgba(47,125,117,.14), transparent 58%),
    radial-gradient(900px 760px at 18% 70%, rgba(154,106,68,.18), transparent 56%),
    radial-gradient(760px 520px at 80% 84%, rgba(182,198,255,.08), transparent 62%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
.adoc__hero{
  position: relative;
  padding-top: 94px;
  padding-bottom: 34px;
  isolation: isolate;
}
.adoc__bg{
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(900px 620px at 44% 20%, rgba(242,239,231,.06), rgba(0,0,0,.0) 44%),
    linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.46));
}
.adoc-wrap{ width: min(var(--max), calc(100% - 72px)); }
.adoc__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items: center;
}
.adoc__title{
  font-family: var(--serif);
  font-size: clamp(46px, 6.1vw, 78px);
  line-height: 0.96;
  letter-spacing: -0.02em;
  margin: 10px 0 0 0;
}
.adoc__lede{
  margin-top: 14px;
  color: rgba(242,239,231,.78);
  line-height: 1.7;
  max-width: 64ch;
  font-size: 15px;
}
.adoc__meta{
  margin-top: 18px;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  box-shadow: var(--shadow2);
  padding: 12px 12px;
}
.meta-row{
  display:grid;
  grid-template-columns: 160px 1fr;
  gap: 12px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid rgba(242,239,231,.10);
  background: rgba(7,9,10,.26);
  margin-top: 10px;
}
.meta-row:first-child{ margin-top: 0; }
.meta-k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(154,106,68,.86);
}
.meta-v{
  color: rgba(242,239,231,.78);
  line-height: 1.55;
  font-size: 13px;
}
.adoc__actions{
  margin-top: 14px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}
.adoc__figure{
  position: relative;
  margin: 0;
  border-radius: calc(var(--radius2) + 16px);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.22);
  overflow:hidden;
  box-shadow: var(--shadow2);
  min-height: 520px;
}
.adoc__figure::before{
  content:"";
  position:absolute;
  inset:-24px;
  background-image: linear-gradient(180deg, rgba(74,167,155,.10), rgba(0,0,0,0));
  filter: blur(18px);
  opacity: .7;
  pointer-events:none;
}
.adoc__img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: contain;
  filter: contrast(1.06) saturate(.92);
  background: #050505;
}
.adoc__cap{
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.56);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow2);
}
.cap__float{
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(74,167,155,.90);
}
.cap__text{
  font-size: 12px;
  color: rgba(242,239,231,.76);
  letter-spacing: .02em;
}
.adoc__cols{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  align-items: start;
}
.prose p{
  color: rgba(242,239,231,.76);
  line-height: 1.85;
  margin: 0;
  margin-top: 14px;
  max-width: 78ch;
}
.prose p:first-child{ margin-top: 0; }
.sidebox{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  box-shadow: var(--shadow2);
  padding: 14px 14px;
  position: sticky;
  top: 96px;
}
.sidebox__head{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(242,239,231,.72);
  margin-bottom: 10px;
}
.tax-card--mini{ min-height: 220px; }

.page--simple{
  background:
    radial-gradient(1100px 780px at 70% 18%, rgba(74,167,155,.12), transparent 60%),
    radial-gradient(860px 640px at 18% 78%, rgba(154,106,68,.16), transparent 62%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
.simple{
  padding: 104px 0 64px 0;
}
.simple-wrap{ width: min(980px, calc(100% - 72px)); }
.simple__title{
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: -0.02em;
  font-size: clamp(44px, 5.2vw, 64px);
  line-height: 0.98;
  margin: 10px 0 0 0;
}
.simple__note{
  margin-top: 14px;
  color: rgba(242,239,231,.74);
  line-height: 1.7;
  max-width: 78ch;
}
.simple__actions{
  margin-top: 22px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}
.crumbs{
  margin-top: 10px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  color: rgba(242,239,231,.70);
  font-size: 12px;
  letter-spacing: .02em;
}
.crumbs a{
  color: rgba(242,239,231,.82);
  text-decoration: none;
}
.crumbs a:hover{ text-decoration: underline; }
.crumbs__sep{
  opacity: .55;
}

@media (max-width: 1100px){
  .aindex{ grid-template-columns: repeat(6, 1fr); }
  .acard{ grid-column: span 3; }
  .adoc__grid{ grid-template-columns: 1fr; }
  .adoc__figure{ min-height: 460px; }
  .adoc__cols{ grid-template-columns: 1fr; }
  .sidebox{ position: static; }
}
@media (max-width: 720px){
  .adoc-wrap,
  .simple-wrap{
    width: min(var(--max), calc(100% - 48px));
  }
  .aindex{ grid-template-columns: 1fr; }
  .acard{ grid-column: span 12; }
  .meta-row{ grid-template-columns: 1fr; }
  .adoc__figure{ min-height: 420px; }
}

/* ===========================
   Filter screen
   =========================== */
.page--filter{
  background:
    radial-gradient(1200px 820px at 70% 18%, rgba(74,167,155,.12), transparent 58%),
    radial-gradient(980px 760px at 18% 72%, rgba(154,106,68,.16), transparent 56%),
    linear-gradient(180deg, #050505, #070708);
}
.shead__grid--single{ grid-template-columns: 1fr; }
.filter-screen{ padding: 8px 0 96px 0; }
.filter-panel{
  max-width: 640px;
  margin: 0 auto;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 26px 22px;
  display:flex;
  flex-direction: column;
  gap: 16px;
}
.filter-panel__hint{
  margin: 0;
  font-size: 13px;
  color: rgba(242,239,231,.68);
  line-height: 1.6;
}
.filter-panel__actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
  margin-top: 8px;
}

/* ===========================
   Utility / inquiry pages
   =========================== */
.page--utility{
  background:
    radial-gradient(1100px 780px at 72% 14%, rgba(74,167,155,.14), transparent 58%),
    radial-gradient(900px 680px at 12% 78%, rgba(154,106,68,.16), transparent 62%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
.utility-wrap{
  width: min(var(--max), calc(100% - 56px));
  margin: 0 auto;
}
.utility-hero{
  position: relative;
  padding: 96px 0 48px 0;
  isolation: isolate;
}
.utility-hero::before{
  content:"";
  position:absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(900px 520px at 68% 22%, rgba(74,167,155,.18), transparent 62%),
    radial-gradient(760px 480px at 18% 70%, rgba(154,106,68,.14), transparent 58%);
  pointer-events:none;
}
.utility-hero__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items: end;
}
.utility-hero__grid--solo{ grid-template-columns: 1fr; }
.utility-hero__title{
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: .92;
  font-size: clamp(48px, 5.4vw, 78px);
  margin: 0;
}
.utility-hero__sub{
  display:block;
  margin-top: 12px;
  font-size: 13px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(242,239,231,.66);
}
.utility-hero__lead{
  margin: 18px 0 0 0;
  max-width: 62ch;
  color: rgba(242,239,231,.78);
  line-height: 1.75;
  font-size: 16px;
}
.utility-hero__figure{
  margin:0;
  border-radius: calc(var(--radius2) + 12px);
  overflow:hidden;
  border: 1px solid rgba(242,239,231,.12);
  box-shadow: var(--shadow);
  position: relative;
  min-height: 320px;
}
.utility-hero__img{
  width:100%;
  height: min(52vh, 420px);
  object-fit: contain;
  object-position: center;
  background: #050505;
  filter: contrast(1.05) saturate(.92);
}
.utility-hero__figure::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.78));
}
.utility-hero__cap{
  position:absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(242,239,231,.14);
  background: rgba(7,9,10,.58);
  backdrop-filter: blur(12px);
  font-size: 12px;
  color: rgba(242,239,231,.74);
  letter-spacing: .04em;
}
.utility-section{
  padding: 24px 0 72px 0;
}
.utility-cards{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.utility-card{
  grid-column: span 4;
  border-radius: calc(var(--radius2) + 8px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 22px 20px;
  display:flex;
  flex-direction: column;
  gap: 12px;
  min-height: 200px;
}

.page--utility .topbar__inner,
.page--utility .utility-wrap{
  width: min(var(--max), calc(100% - 56px));
}
.page--utility .utility-hero{
  padding: 112px 0 54px 0;
}
.page--utility .utility-section{
  padding: 34px 0 86px 0;
}
.page--utility .utility-hero__grid,
.page--utility .utility-cards,
.page--utility .utility-split,
.page--utility .utility-newsletter-preview{
  gap: 18px;
}
.page--utility .utility-card,
.page--utility .utility-panel,
.page--utility .utility-specimen__meta,
.page--utility .utility-aside__card{
  padding: clamp(22px, 2.2vw, 30px);
}
.page--utility .utility-card{
  min-height: 220px;
}
.page--utility .utility-card__p,
.page--utility .utility-panel__note,
.page--utility .utility-kv__v{
  max-width: 68ch;
}
.utility-card__n{
  font-family: var(--serif);
  font-size: 34px;
  line-height: 1;
  letter-spacing: .04em;
  color: rgba(74,167,155,.75);
}
.utility-card__t{
  font-family: var(--serif);
  font-size: 26px;
  letter-spacing: -.02em;
  margin: 0;
}
.utility-card__p{
  margin: 0;
  color: rgba(242,239,231,.74);
  line-height: 1.7;
  font-size: 14px;
}
.utility-card__tags{
  margin-top: auto;
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}
.utility-tag{
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(242,239,231,.14);
  color: rgba(242,239,231,.78);
}
.utility-steps{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.utility-step{
  grid-column: span 3;
  border-radius: var(--radius2);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  padding: 18px 16px;
  box-shadow: var(--shadow2);
}
.utility-step__k{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(74,167,155,.9);
}
.utility-step__t{
  margin: 8px 0 0 0;
  font-family: var(--serif);
  font-size: 22px;
}
.utility-step__p{
  margin: 8px 0 0 0;
  font-size: 13px;
  line-height: 1.65;
  color: rgba(242,239,231,.72);
}
.utility-split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
  align-items: start;
}
.utility-panel{
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: linear-gradient(180deg, rgba(242,239,231,.06), rgba(242,239,231,.02));
  box-shadow: var(--shadow2);
  padding: 26px 22px;
}
.utility-panel__head{
  margin-bottom: 18px;
}
.utility-panel__title{
  font-family: var(--serif);
  font-size: 30px;
  margin: 0;
  letter-spacing: -.02em;
}
.utility-panel__note{
  margin: 8px 0 0 0;
  font-size: 14px;
  color: rgba(242,239,231,.72);
  line-height: 1.65;
}
.utility-form{
  display:flex;
  flex-direction: column;
  gap: 14px;
}
.utility-form__row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.utility-form .field{ margin-top: 0; }
.utility-form .field__input,
.utility-form .field__textarea,
.utility-form select.field__input{
  width: 100%;
}
.utility-form .field__textarea{
  min-height: 120px;
}
.utility-checks{
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.utility-check{
  display:flex;
  align-items:flex-start;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.28);
  cursor: pointer;
}
.utility-check input{
  margin-top: 3px;
  accent-color: var(--verdigris2);
}
.utility-check__t{
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(242,239,231,.86);
}
.utility-check__p{
  margin-top: 4px;
  font-size: 12px;
  color: rgba(242,239,231,.66);
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0;
}
.utility-aside{
  display:flex;
  flex-direction: column;
  gap: 14px;
}
.utility-aside__card{
  border-radius: var(--radius2);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  padding: 18px 16px;
  box-shadow: var(--shadow2);
}
.utility-aside__k{
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.68);
}
.utility-aside__v{
  margin-top: 8px;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: .02em;
}
.utility-aside__list{
  margin: 12px 0 0 0;
  padding: 0;
  list-style: none;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.utility-aside__list li{
  font-size: 13px;
  line-height: 1.6;
  color: rgba(242,239,231,.74);
  padding-left: 14px;
  position: relative;
}
.utility-aside__list li::before{
  content:"";
  position:absolute;
  left: 0;
  top: .55em;
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: rgba(74,167,155,.85);
}
.utility-specimen{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
}
.utility-specimen__visual{
  grid-column: span 5;
  border-radius: calc(var(--radius2) + 10px);
  overflow:hidden;
  border: 1px solid rgba(242,239,231,.12);
  min-height: 280px;
  position: relative;
  background: #050505;
}
.utility-specimen__visual img{
  width:100%;
  height:100%;
  min-height: 280px;
  object-fit: contain;
  object-position: center;
}
.utility-specimen__meta{
  grid-column: span 7;
  border-radius: calc(var(--radius2) + 10px);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  padding: 22px 20px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.utility-kv__k{
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(242,239,231,.62);
}
.utility-kv__v{
  margin-top: 6px;
  font-size: 15px;
  color: rgba(242,239,231,.88);
  line-height: 1.5;
}
.utility-actions{
  margin-top: 22px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items:center;
}
.utility-success{
  display:none;
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(74,167,155,.35);
  background: rgba(74,167,155,.08);
  color: rgba(242,239,231,.9);
  font-size: 14px;
  line-height: 1.6;
}
.utility-success.is-visible{ display:block; }
.utility-strip{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.utility-strip__item{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(242,239,231,.12);
  aspect-ratio: 4/3;
  background: #050505;
  position: relative;
}
.utility-strip__item img{
  width:100%;
  height:100%;
  object-fit: contain;
  object-position: center;
  filter: contrast(1.04) saturate(.9);
}
.utility-strip__item span{
  position:absolute;
  left: 10px;
  bottom: 10px;
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 8px;
  border-radius: 999px;
  background: rgba(7,9,10,.62);
  border: 1px solid rgba(242,239,231,.14);
  color: rgba(242,239,231,.82);
}
.utility-newsletter-preview{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.utility-preview{
  border-radius: var(--radius2);
  border: 1px solid rgba(242,239,231,.12);
  background: rgba(7,9,10,.34);
  overflow:hidden;
  box-shadow: var(--shadow2);
}
.utility-preview__img{
  height: 140px;
  background-image: var(--img);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #050505;
}
.utility-preview__body{
  padding: 14px 14px 16px 14px;
}
.utility-preview__t{
  font-family: var(--serif);
  font-size: 20px;
  margin: 0;
}
.utility-preview__p{
  margin: 8px 0 0 0;
  font-size: 12px;
  line-height: 1.6;
  color: rgba(242,239,231,.7);
}

@media (max-width: 1100px){
  .utility-hero__grid,
  .utility-split{ grid-template-columns: 1fr; }
  .utility-card{ grid-column: span 6; }
  .utility-step{ grid-column: span 6; }
  .utility-specimen__visual,
  .utility-specimen__meta{ grid-column: span 12; }
  .utility-strip{ grid-template-columns: repeat(2, 1fr); }
  .utility-newsletter-preview{ grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  .utility-wrap,
  .page--utility .topbar__inner,
  .page--utility .utility-wrap{ width: min(var(--max), calc(100% - 32px)); }
  .page--utility .utility-hero{ padding: 94px 0 34px 0; }
  .page--utility .utility-section{ padding: 22px 0 58px 0; }
  .page--utility .utility-card,
  .page--utility .utility-panel,
  .page--utility .utility-specimen__meta,
  .page--utility .utility-aside__card{ padding: 20px 18px; }
  .utility-card,
  .utility-step{ grid-column: span 12; }
  .utility-form__row{ grid-template-columns: 1fr; }
  .utility-specimen__meta{ grid-template-columns: 1fr; }
  .utility-hero__title{ font-size: 44px; }
}

/* Scholarly archive balance: keep object/gallery viewing dark, make reading records lighter. */
:root{
  --archive-paper: #c8d2d1;
  --archive-paper-2: #b8c5c4;
  --archive-ink: #101818;
  --archive-muted: #425152;
  --archive-line: rgba(16,24,24,.18);
}

.section--intro .wrap,
.taxon-essay,
.page--object .obj__section--reading .obj__panel{
  color: var(--archive-ink);
  border-color: rgba(16,24,24,.16);
  background:
    radial-gradient(760px 420px at 8% 0%, rgba(242,239,231,.32), transparent 60%),
    linear-gradient(180deg, rgba(207,218,217,.98), rgba(181,196,195,.96));
  box-shadow: 0 20px 70px rgba(0,0,0,.32);
}

.section--intro .wrap{
  border-radius: calc(var(--radius2) + 12px);
  padding: 34px;
  border: 1px solid rgba(16,24,24,.14);
}

.section--intro .section-title,
.section--intro .intro__copy,
.section--intro .stat__num,
.section--intro .stat__label,
.taxon-essay .section-title,
.taxon-essay__cols,
.page--object .obj__section--reading .obj__h,
.page--object .obj__section--reading .obj__p,
.page--object .obj__section--reading .meta dd,
.page--object .obj__section--reading .footnotes,
.page--object .obj__section--reading .maker__n,
.page--object .obj__section--reading .maker__r,
.page--object .obj__section--reading .tag{
  color: var(--archive-ink);
}

.section--intro .section-note,
.page--object .obj__section--reading .obj__p,
.page--object .obj__section--reading .maker__r,
.page--object .obj__section--reading .refs__v{
  color: var(--archive-muted);
}

.section--intro .stat,
.page--object .obj__section--reading .meta__row,
.page--object .obj__section--reading .refs li,
.page--object .obj__section--reading .citebox,
.page--object .obj__section--reading .maker,
.page--object .obj__section--reading .tag,
.pathlist{
  border-color: var(--archive-line);
  background: rgba(255,255,255,.24);
}

.section--intro .stat__label,
.page--object .obj__section--reading .meta dt,
.page--object .obj__section--reading .refs__k,
.page--object .obj__section--reading .citebox__k,
.pathsep{
  color: #2f6f69;
}

.page--object .obj__section--reading .textlink,
.page--object .obj__section--reading .fnref,
.page--object .obj__section--reading .backref,
.pathlink{
  color: #184f4b;
}

.page--object .obj__section--reading .textlink::after,
.pathlink::after{
  background: linear-gradient(90deg, #184f4b, transparent);
}

.obj__section--gallery{
  padding-top: 70px;
  padding-bottom: 70px;
}

.obj__h--mt{ margin-top: 24px; }
.obj__p--long{ max-width: 94ch; }
.kv--wide{ grid-column: span 2; }

.pathlist{
  margin-top: 14px;
  display:flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  border-radius: 18px;
  padding: 12px 12px;
  line-height: 1.5;
}
.pathlink{
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  position: relative;
}
.pathsep{
  font-size: 13px;
  opacity: .78;
}

.meta-k,
.pmeta__k{
  color: rgba(214,178,136,.92);
}

.acard{
  color: var(--pearl);
}

.acard__name{
  color: var(--pearl);
}

.acard__sub,
.acard__row,
.idpill{
  color: rgba(242,239,231,.76);
}

.acard__tag{
  color: rgba(162,225,217,.94);
  border-color: rgba(162,225,217,.34);
  background: rgba(74,167,155,.10);
}

.gblock__panel,
.artist__panel{
  color: var(--archive-ink);
  border-color: rgba(16,24,24,.16);
  background:
    radial-gradient(760px 420px at 8% 0%, rgba(242,239,231,.32), transparent 60%),
    linear-gradient(180deg, rgba(207,218,217,.94), rgba(181,196,195,.90));
}

.gblock__panel .gblock__title,
.artist__panel .section-title{
  color: var(--archive-ink);
}

.gblock__panel .gblock__meta,
.gblock__panel .gblock__copy,
.artist__panel .artist__copy{
  color: var(--archive-muted);
}

.gblock__panel .gblock__tag,
.artist__panel .kicker{
  color: #2f6f69;
}

.gblock__panel .textlink,
.artist__panel .button,
.artist__panel .quiet{
  color: var(--archive-ink);
  border-color: rgba(16,24,24,.18);
}

.gblock__panel .textlink::after{
  background: linear-gradient(90deg, #2f6f69, rgba(16,24,24,.2), transparent);
}

.section.section--artist .artist__panel .section-title,
.section.section--artist .artist__panel .button,
.section.section--artist .artist__panel .quiet{
  color: var(--archive-ink);
}

.section.section--artist .artist__panel .button,
.section.section--artist .artist__panel .quiet{
  background: rgba(255,255,255,.22);
  box-shadow: 0 14px 48px rgba(16,24,24,.16);
}
/* WordPress: content visible on first paint — never wait for scroll reveal */
body.has-site-chrome [data-reveal],
body.page [data-reveal],
body.page--taxon [data-reveal],
body.page--object [data-reveal],
body.page--taxonomy [data-reveal],
body.home [data-reveal] {
  opacity: 1 !important;
  transform: none !important;
}

body.has-site-chrome .hero__slide.is-active,
body.page .hero__slide.is-active,
body.home .hero__slide.is-active {
  opacity: 1 !important;
}

/* WordPress admin bar: keep topbar aligned on every page */
body.admin-bar .topbar {
  top: 32px;
}

@media screen and (max-width: 782px) {
  body.admin-bar .topbar {
    top: 46px;
  }
  body.admin-bar .hero {
    padding-top: calc(76px + 46px);
  }
  body.admin-bar .ahead {
    padding-top: calc(94px + 46px);
  }
}

/* Prevent WordPress core styles from overriding archive typography */
body.has-site-chrome,
body.page,
body.home {
  font-family: var(--sans);
  color: var(--pearl);
}
