/* University of Georgia campus web platform prototype by Stoa.
   Built to UGA's published Visual Identity System: official palette names,
   the I-Bar pillar element, bordered photography, condensed display type.
   Signature interactive accent: Lake Herrick. */

/* ---------- Fonts (self-hosted, OFL) ---------- */
@font-face {
  font-family: "Barlow Condensed";
  src: url("/uga/assets/fonts/barlow-condensed-300.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Barlow Condensed";
  src: url("/uga/assets/fonts/barlow-condensed-500.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Merriweather";
  src: url("/uga/assets/fonts/merriweather-var.woff2") format("woff2");
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Merriweather";
  src: url("/uga/assets/fonts/merriweather-var-italic.woff2") format("woff2");
  font-weight: 300 900;
  font-style: italic;
  font-display: swap;
}

/* ---------- Tokens ---------- */
:root {
  --bulldog: #ba0c2f;            /* Bulldog Red, identity anchor, used sparingly */
  --glory: #e4002b;              /* Glory Glory, live state of red elements */
  --lake: #00a3ad;               /* Lake Herrick, the interactive layer */
  --hedges: #b4bd00;             /* Hedges, one sliver only */
  --olympic: #004e60;            /* Olympic, deep panel tone */
  --odyssey: #c8d8eb;            /* Odyssey, pale panel tint */
  --cream: #d6d2c4;              /* Creamery */
  --cream-soft: #e9e6dc;
  --sanford: #554f47;            /* Sanford, secondary text */
  --stegeman: #9ea2a2;           /* Stegeman, hairlines */
  --paper: #ffffff;              /* Chapel Bell White */
  --night: #131110;              /* dark room */
  --ink: #1b1817;
  --lake-ink: color-mix(in srgb, var(--lake) 56%, black);
  --lake-wash: color-mix(in srgb, var(--lake) 12%, white);
  --display: "Barlow Condensed", "Avenir Next Condensed", "Arial Narrow", sans-serif;
  --body: "Merriweather", Georgia, "Times New Roman", serif;
  --frame: 2px solid var(--ink);
  --measure: 64ch;
}

/* ---------- Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}
body {
  margin: 0;
  font-family: var(--body);
  font-size: 1.0625rem;
  line-height: 1.72;
  color: var(--ink);
  background: var(--paper);
}
img { max-width: 100%; height: auto; display: block; }
::selection { background: #00a3ad; color: #fff; }
:focus-visible { outline: 3px solid #00a3ad; outline-offset: 2px; }
a { color: var(--lake-ink); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--ink); text-decoration-thickness: 2px; }
.skiplink {
  position: absolute; left: -999px; top: 0; z-index: 60;
  background: var(--night); color: var(--paper);
  padding: 0.8rem 1.4rem; font-family: var(--display); font-weight: 500;
  font-size: 1.05rem; letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none;
}
.skiplink:focus { left: 0; color: var(--paper); }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 1.25rem; }
.measure { max-width: var(--measure); }

h1, h2, h3 { font-family: var(--display); font-weight: 500; line-height: 1.08; margin: 0 0 0.6em; letter-spacing: 0.012em; }
h1 { font-size: clamp(2.5rem, 6vw, 4.1rem); text-transform: uppercase; }
h2 { font-size: clamp(1.8rem, 3.6vw, 2.5rem); text-transform: uppercase; }
h3 { font-size: 1.3rem; }
p { margin: 0 0 1.1em; }

.kicker {
  font-family: var(--display); font-weight: 500; font-size: 0.98rem;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--sanford);
  display: block; margin-bottom: 0.9rem;
}

/* The I-Bar: a pillar of the Arch, straight from UGA's brand kit */
.pillar-h { position: relative; padding-bottom: 0.85rem; }
.pillar-h::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 72px; height: 6px; background: var(--bulldog);
}
.pillar-h.centered { text-align: center; }
.pillar-h.centered::after { left: 50%; transform: translateX(-50%); }

.tick-list { list-style: none; margin: 0 0 1.2rem; padding: 0; }
.tick-list li { position: relative; padding: 0.32rem 0 0.32rem 1.35rem; }
.tick-list li::before {
  content: ""; position: absolute; left: 0; top: 0.78em;
  width: 5px; height: 0.95em; background: var(--bulldog);
}

.arch-divider {
  display: flex; justify-content: center; align-items: flex-end; gap: 14px;
  margin: 3.2rem auto; height: 30px; border-top: 3px solid var(--ink);
  width: 110px; padding-top: 7px;
}
.arch-divider span { width: 9px; height: 20px; background: var(--ink); }
.arch-divider span:nth-child(2) { height: 20px; }

/* ---------- Proto banner ---------- */
.proto-note {
  background: var(--night); color: var(--cream);
  font-family: var(--display); font-weight: 300; font-size: 0.99rem;
  letter-spacing: 0.07em;
}
.proto-note .wrap {
  display: flex; align-items: center; gap: 0.7rem; min-height: 44px;
  padding-top: 0.35rem; padding-bottom: 0.35rem; flex-wrap: wrap;
}
.proto-note .tick { width: 5px; height: 1.15em; background: var(--bulldog); flex: none; }
.proto-note a { color: var(--paper); }
.proto-note a:hover { color: var(--odyssey); }

/* ---------- Header ---------- */
.pediment { background: var(--paper); border-bottom: 3px solid var(--ink); }
.pediment .wrap {
  display: flex; align-items: stretch; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap; padding-top: 0.9rem; padding-bottom: 0;
}
.lockup {
  display: flex; align-items: center; gap: 0.85rem;
  text-decoration: none; color: var(--ink); padding: 0.35rem 0 0.9rem;
}
.lockup .bar { width: 7px; height: 52px; background: var(--bulldog); flex: none; }
.lockup .word { font-family: var(--display); line-height: 1.06; }
.lockup .word strong {
  display: block; font-weight: 500; font-size: 1.62rem;
  letter-spacing: 0.045em; text-transform: uppercase;
}
.lockup .word span {
  display: block; font-weight: 300; font-size: 0.94rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--sanford);
}
.headside { display: flex; align-items: center; gap: 0.5rem; }
.menu-btn {
  display: none; align-items: center; gap: 0.55rem;
  background: none; border: 2px solid var(--ink); cursor: pointer;
  font-family: var(--display); font-weight: 500; font-size: 1rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink);
  padding: 0.55rem 0.95rem; margin: 0.4rem 0 0.9rem;
}
.menu-btn .glyph { display: inline-flex; flex-direction: column; gap: 3px; }
.menu-btn .glyph i { width: 17px; height: 2.5px; background: var(--ink); }
.search-open {
  display: inline-flex; align-items: center; gap: 0.55rem;
  background: var(--night); color: var(--paper); border: 2px solid var(--night);
  cursor: pointer; font-family: var(--display); font-weight: 500;
  font-size: 1rem; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.55rem 1.05rem; margin: 0.4rem 0 0.9rem;
}
.search-open:hover { background: var(--bulldog); border-color: var(--bulldog); }
.search-open svg { flex: none; }
.colonnade-nav { border-top: 1px solid var(--stegeman); flex-basis: 100%; }
.colonnade-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap;
}
.colonnade-nav li { display: flex; }
.colonnade-nav li + li { border-left: 1px solid var(--cream); }
.colonnade-nav a {
  display: inline-flex; align-items: center;
  font-family: var(--display); font-weight: 500; font-size: 1.08rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink); text-decoration: none;
  padding: 0.85rem 1.15rem; border-bottom: 5px solid transparent; min-height: 48px;
}
.colonnade-nav a:hover { border-bottom-color: var(--lake); color: var(--ink); }
.colonnade-nav a[aria-current="page"] { border-bottom-color: var(--bulldog); }

@media (max-width: 860px) {
  .menu-btn { display: inline-flex; }
  .colonnade-nav { display: none; border-top: 1px solid var(--stegeman); }
  .colonnade-nav.open { display: block; }
  .colonnade-nav ul { flex-direction: column; }
  .colonnade-nav li + li { border-left: 0; border-top: 1px solid var(--cream); }
  .colonnade-nav a { width: 100%; border-bottom: 0; border-left: 6px solid transparent; }
  .colonnade-nav a:hover { border-left-color: var(--lake); }
  .colonnade-nav a[aria-current="page"] { border-left-color: var(--bulldog); }
}

/* ---------- Mounted-print photo system ---------- */
.print { margin: 0; }
.print .matting {
  background: var(--paper); border: var(--frame); padding: 10px;
  box-shadow: 16px 16px 0 var(--cream);
}
.print.on-cream .matting { box-shadow: 16px 16px 0 var(--odyssey); }
.print img { width: 100%; object-fit: cover; }
.print figcaption {
  font-family: var(--display); font-weight: 500; font-size: 0.95rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--sanford);
  margin-top: 0.85rem; padding-left: 1.05rem; position: relative;
}
.print figcaption::before {
  content: ""; position: absolute; left: 0; top: 0.18em;
  width: 5px; height: 1em; background: var(--bulldog);
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  font-family: var(--display); font-weight: 500; font-size: 1.08rem;
  letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none;
  padding: 0.78rem 1.5rem; min-height: 48px; cursor: pointer; border: 2px solid transparent;
}
.btn-bulldog { background: var(--bulldog); color: var(--paper); border-color: var(--bulldog); }
.btn-bulldog:hover { background: #e4002b; border-color: #e4002b; color: var(--paper); }
.btn-line { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-line:hover { background: var(--ink); color: var(--paper); }
.btn-chalk { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.btn-chalk:hover { background: var(--odyssey); border-color: var(--odyssey); color: var(--ink); }

/* ---------- Sections ---------- */
.masthead { background: var(--cream-soft); border-bottom: 1px solid var(--stegeman); }
.masthead .wrap {
  display: grid; grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  gap: 3.5rem; align-items: center; padding-top: 4rem; padding-bottom: 4.4rem;
}
.masthead .lede { font-size: 1.16rem; color: var(--sanford); max-width: 56ch; }
@media (max-width: 860px) {
  .masthead .wrap { grid-template-columns: 1fr; gap: 2.6rem; padding-top: 2.6rem; padding-bottom: 3rem; }
}

.deskline {
  display: flex; border: var(--frame); background: var(--paper);
  max-width: 620px; margin-top: 1.8rem;
}
.deskline input {
  flex: 1; min-width: 0; border: 0; background: transparent;
  font-family: var(--body); font-size: 1.05rem; color: var(--ink);
  padding: 0.85rem 1.05rem;
}
.deskline input::placeholder { color: var(--sanford); opacity: 1; }
.deskline button {
  border: 0; background: var(--night); color: var(--paper); cursor: pointer;
  font-family: var(--display); font-weight: 500; font-size: 1.05rem;
  letter-spacing: 0.12em; text-transform: uppercase; padding: 0 1.4rem; min-width: 48px;
}
.deskline button:hover { background: var(--bulldog); }

.section { padding: 4.2rem 0; }
.section.on-cream { background: var(--cream-soft); border-top: 1px solid var(--stegeman); border-bottom: 1px solid var(--stegeman); }
.section.on-odyssey { background: var(--lake-wash); border-top: 1px solid var(--stegeman); }
.section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.section-head .more { font-family: var(--display); font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; font-size: 1.02rem; }

/* Wayfinding doors */
.doors { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; }
@media (max-width: 1000px) { .doors { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .doors { grid-template-columns: 1fr; } }
.door {
  display: block; background: var(--paper); border: var(--frame);
  border-top-width: 8px; padding: 1.5rem 1.4rem 1.6rem;
  text-decoration: none; color: var(--ink); position: relative;
}
.door:hover { border-color: var(--lake-ink); color: var(--ink); }
.door .who {
  font-family: var(--display); font-weight: 300; font-size: 0.95rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--sanford); display: block;
}
.door .go {
  font-family: var(--display); font-weight: 500; font-size: 1.5rem;
  letter-spacing: 0.03em; text-transform: uppercase; display: block; margin: 0.3rem 0 0.7rem;
}
.door p { font-size: 0.95rem; color: var(--sanford); margin: 0; }
.door::after {
  content: "\2192"; position: absolute; right: 1.2rem; bottom: 0.9rem;
  font-family: var(--display); font-weight: 500; font-size: 1.3rem; color: var(--bulldog);
}

/* Numbers band: the dark room */
.numbers-band { background: var(--night); color: var(--paper); padding: 4rem 0 3.4rem; }
.numbers-band h2 { color: var(--paper); }
.numbers-band .pillar-h::after { background: var(--bulldog); }
.numbers { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 2.4rem; }
@media (max-width: 900px) { .numbers { grid-template-columns: repeat(2, 1fr); row-gap: 2.4rem; } }
@media (max-width: 540px) { .numbers { grid-template-columns: 1fr; } }
.numbers > div { padding: 0.2rem 1.6rem; border-left: 1px solid var(--sanford); }
.numbers .figure {
  font-family: var(--display); font-weight: 300; font-size: clamp(2.6rem, 5vw, 3.7rem);
  line-height: 1; color: var(--paper); display: block;
}
.numbers .what {
  font-family: var(--display); font-weight: 500; font-size: 1.02rem;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--lake);
  display: block; margin-top: 0.55rem;
}
.numbers .since { font-size: 0.88rem; color: var(--stegeman); display: block; margin-top: 0.4rem; line-height: 1.5; }
.numbers-band .smallnote { color: var(--stegeman); font-size: 0.85rem; margin: 2.2rem 0 0; }

/* Colonnade cards (schools) */
.colonnade { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.3rem; }
@media (max-width: 1000px) { .colonnade { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .colonnade { grid-template-columns: 1fr; } }
.column-card {
  background: var(--paper); border: 1px solid var(--stegeman); border-bottom: 5px solid var(--ink);
  padding: 1.3rem 1.25rem 1.35rem; display: flex; flex-direction: column; gap: 0.45rem;
}
.column-card:hover { border-bottom-color: var(--lake); }
.column-card .field {
  font-family: var(--display); font-weight: 300; font-size: 0.9rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--sanford);
}
.column-card h3 { margin: 0; font-size: 1.22rem; text-transform: none; letter-spacing: 0.02em; }
.column-card h3 a { color: var(--ink); text-decoration: none; }
.column-card h3 a:hover { color: var(--lake-ink); text-decoration: underline; }
.column-card p { font-size: 0.92rem; color: var(--sanford); margin: 0; }
.column-card .est { font-size: 0.85rem; color: var(--lake-ink); font-style: italic; }

/* News ledger */
.ledger { border-top: 3px solid var(--ink); }
.ledger article { border-bottom: 1px solid var(--stegeman); padding: 1.6rem 0; display: grid; grid-template-columns: 160px minmax(0, 1fr); gap: 1.6rem; }
@media (max-width: 700px) { .ledger article { grid-template-columns: 1fr; gap: 0.5rem; } }
.ledger .chip {
  font-family: var(--display); font-weight: 500; font-size: 0.92rem;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--bulldog); align-self: start;
  padding-left: 0.9rem; position: relative;
}
.ledger .chip::before { content: ""; position: absolute; left: 0; top: 0.2em; width: 5px; height: 1em; background: var(--bulldog); }
.ledger h3 { margin: 0 0 0.4rem; font-size: 1.35rem; text-transform: none; }
.ledger p { margin: 0; color: var(--sanford); font-size: 0.98rem; max-width: 70ch; }

/* The hedge rule: one sliver of Hedges */
.hedge-rule { height: 7px; background: repeating-linear-gradient(90deg, #b4bd00 0 14px, color-mix(in srgb, var(--hedges) 60%, black) 14px 17px); border: 0; margin: 0; }

/* ---------- Footer ---------- */
.site-foot { background: var(--night); color: var(--cream); margin-top: 4.5rem; }
.site-foot .top-rule { border-top: 8px solid var(--bulldog); }
.site-foot .cols {
  display: grid; grid-template-columns: 1.3fr 0.9fr 1.3fr; gap: 2.6rem;
  padding: 3rem 0 2.4rem;
}
@media (max-width: 860px) { .site-foot .cols { grid-template-columns: 1fr; } }
.site-foot h2 {
  font-size: 1.05rem; font-weight: 500; letter-spacing: 0.18em;
  color: var(--paper); margin-bottom: 1rem;
}
.site-foot p { font-size: 0.93rem; line-height: 1.7; color: var(--cream); }
.site-foot a { color: var(--paper); }
.site-foot a:hover { color: var(--odyssey); }
.site-foot ul { list-style: none; margin: 0; padding: 0; }
.site-foot ul li { padding: 0.22rem 0; }
.site-foot ul a { font-family: var(--display); font-weight: 300; font-size: 1.04rem; letter-spacing: 0.1em; text-transform: uppercase; text-decoration: none; display: inline-block; padding: 0.15rem 0; }
.site-foot ul a:hover { text-decoration: underline; }
.site-foot .basement { border-top: 1px solid var(--sanford); padding: 1.1rem 0 1.4rem; font-size: 0.85rem; color: var(--stegeman); display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.site-foot .basement a { color: var(--cream); }

/* ---------- Search overlay ---------- */
.arch-search[hidden] { display: none; }
.arch-search {
  position: fixed; inset: 0; z-index: 80; background: rgba(19, 17, 16, 0.92);
  overflow-y: auto; padding: 4.5vh 1.25rem 6vh;
}
.arch-search .panel { max-width: 760px; margin: 0 auto; }
.arch-search .panel-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.1rem; }
.arch-search .panel-head .label {
  font-family: var(--display); font-weight: 500; font-size: 1.05rem;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream);
  padding-left: 0.95rem; position: relative;
}
.arch-search .panel-head .label::before { content: ""; position: absolute; left: 0; top: 0.16em; width: 5px; height: 1em; background: var(--bulldog); }
.search-close {
  background: none; border: 2px solid var(--cream); color: var(--paper); cursor: pointer;
  font-family: var(--display); font-weight: 500; font-size: 0.98rem;
  letter-spacing: 0.14em; text-transform: uppercase; padding: 0.5rem 1rem; min-height: 44px;
}
.search-close:hover { border-color: var(--paper); background: var(--bulldog); }
.arch-search .field { display: flex; border: 3px solid var(--paper); background: var(--paper); }
.arch-search .field input {
  flex: 1; min-width: 0; border: 0; font-family: var(--body); font-size: 1.18rem;
  padding: 1rem 1.15rem; color: var(--ink); background: transparent;
}
.arch-search .field input::placeholder { color: var(--sanford); opacity: 1; }
.search-hint { font-family: var(--display); font-weight: 300; font-size: 0.95rem; letter-spacing: 0.08em; color: var(--stegeman); margin: 0.7rem 0 0; }
.search-results { margin-top: 1.6rem; }
.results-group h3 {
  font-family: var(--display); font-weight: 300; font-size: 0.95rem;
  letter-spacing: 0.24em; text-transform: uppercase; color: var(--lake);
  margin: 1.7rem 0 0.5rem;
}
.results-group ol { list-style: none; margin: 0; padding: 0; }
.result-row a {
  display: block; background: var(--paper); border-left: 6px solid transparent;
  padding: 0.8rem 1.1rem; margin-bottom: 3px; text-decoration: none; color: var(--ink);
}
.result-row a:hover, .result-row a.kbd-active { border-left-color: var(--bulldog); background: var(--cream-soft); }
.result-row .r-title { font-family: var(--display); font-weight: 500; font-size: 1.18rem; letter-spacing: 0.03em; display: block; }
.result-row .r-desc { font-size: 0.88rem; color: var(--sanford); display: block; margin-top: 0.15rem; }
.result-row mark { background: var(--lake-wash); color: inherit; box-shadow: inset 0 -2px 0 var(--lake); }
.search-empty { background: var(--paper); padding: 2.6rem 1.5rem; text-align: center; }
.search-empty .arch-divider { margin: 0 auto 1.4rem; }
.search-empty p { margin: 0; color: var(--sanford); }
.search-empty .try { font-family: var(--display); font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; font-size: 1rem; color: var(--ink); margin-top: 0.5rem; }
body.search-locked { overflow: hidden; }

/* ---------- Page heads ---------- */
.pagehead { background: var(--cream-soft); border-bottom: 1px solid var(--stegeman); padding: 3rem 0 2.6rem; }
.pagehead p.lede { color: var(--sanford); font-size: 1.12rem; max-width: 62ch; margin: 0; }

/* ---------- Program finder ---------- */
.finder { background: var(--paper); border: var(--frame); padding: 1.6rem 1.5rem; margin: 0 0 2.4rem; }
.finder .deskline { margin-top: 0; max-width: none; }
.finder .deskline input { font-size: 1.02rem; }
.chips { display: flex; flex-wrap: wrap; gap: 0.55rem; margin-top: 1.1rem; }
.chip-btn {
  font-family: var(--display); font-weight: 500; font-size: 0.99rem;
  letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer;
  background: var(--cream-soft); color: var(--ink); border: 1px solid var(--stegeman);
  padding: 0.45rem 0.95rem; min-height: 40px;
}
.chip-btn:hover { border-color: var(--ink); }
.chip-btn[aria-pressed="true"] { background: var(--night); color: var(--paper); border-color: var(--night); box-shadow: inset 0 -4px 0 var(--lake); }
.finder-count { font-family: var(--display); font-weight: 300; font-size: 1.02rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sanford); margin: 1.2rem 0 0; }
.finder-count strong { color: var(--ink); font-weight: 500; }
.no-match { border: var(--frame); background: var(--cream-soft); padding: 2.4rem 1.5rem; text-align: center; }
.no-match p { color: var(--sanford); margin: 0; }

/* ---------- Component library ---------- */
.bench {
  position: sticky; top: 0; z-index: 30; background: var(--night); color: var(--paper);
  padding: 0.85rem 0;
}
.bench .wrap { display: flex; align-items: center; gap: 1.6rem; flex-wrap: wrap; }
.bench .group { display: flex; align-items: center; gap: 0.6rem; }
.bench .group-label { font-family: var(--display); font-weight: 300; font-size: 0.92rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--stegeman); }
.bench .seg { display: inline-flex; border: 1px solid var(--sanford); }
.bench .seg button {
  background: transparent; color: var(--cream); border: 0; cursor: pointer;
  font-family: var(--display); font-weight: 500; font-size: 0.95rem;
  letter-spacing: 0.1em; text-transform: uppercase; padding: 0.5rem 0.9rem; min-height: 40px;
}
.bench .seg button + button { border-left: 1px solid var(--sanford); }
.bench .seg button[aria-pressed="true"] { background: var(--lake); color: var(--night); }
.bench .xray-toggle {
  display: inline-flex; align-items: center; gap: 0.55rem; cursor: pointer;
  font-family: var(--display); font-weight: 500; font-size: 0.95rem;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--cream);
  border: 1px solid var(--sanford); padding: 0.5rem 0.9rem; background: transparent; min-height: 40px;
}
.bench .xray-toggle[aria-pressed="true"] { background: var(--bulldog); border-color: var(--bulldog); color: var(--paper); }

.block-exhibit { border: var(--frame); margin: 2.6rem 0; background: var(--paper); }
.block-exhibit > header {
  display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  background: var(--cream-soft); border-bottom: 1px solid var(--stegeman); padding: 0.9rem 1.4rem;
}
.block-exhibit > header h2 { margin: 0; font-size: 1.3rem; text-transform: uppercase; letter-spacing: 0.06em; }
.block-exhibit > header .blocktype { font-family: var(--display); font-weight: 300; font-size: 0.92rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sanford); }
.stagewrap { padding: 2rem 1.4rem; background: repeating-linear-gradient(45deg, var(--cream-soft) 0 1px, transparent 1px 12px); }
.stage { margin: 0 auto; transition: max-width 0.25s ease; background: var(--paper); outline: 1px dashed var(--stegeman); position: relative; }
.viewport-tablet .stage { max-width: 768px; }
.viewport-mobile .stage { max-width: 375px; }
.stage .pad { padding: 1.7rem 1.5rem; }
.block-exhibit .docket { border-top: 1px solid var(--stegeman); padding: 1.2rem 1.4rem; display: grid; grid-template-columns: 1fr 1fr auto; gap: 1.4rem; font-size: 0.9rem; }
@media (max-width: 800px) { .block-exhibit .docket { grid-template-columns: 1fr; } }
.docket h3 { font-family: var(--display); font-weight: 500; font-size: 0.9rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sanford); margin: 0 0 0.4rem; }
.docket ul { list-style: none; margin: 0; padding: 0; color: var(--sanford); }
.docket ul li { padding: 0.12rem 0 0.12rem 1.1rem; position: relative; }
.docket .can li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 5px; height: 0.85em; background: var(--lake); }
.docket .cant li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 5px; height: 0.85em; background: var(--bulldog); }
.contrast-badge {
  align-self: start; font-family: var(--display); font-weight: 500; font-size: 0.92rem;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink);
  border: 1px solid var(--stegeman); padding: 0.55rem 0.8rem; background: var(--lake-wash);
}
.contrast-badge strong { display: block; font-size: 1.25rem; letter-spacing: 0.03em; }

/* x-ray annotations */
.lock-note { display: none; }
.xray-on .lock-note {
  display: block; position: absolute; z-index: 5;
  background: var(--night); color: var(--paper);
  font-family: var(--display); font-weight: 500; font-size: 0.82rem;
  letter-spacing: 0.08em; text-transform: uppercase; padding: 0.25rem 0.6rem;
  border-left: 4px solid var(--bulldog); max-width: 240px;
}
.xray-on .stage { outline: 2px solid var(--bulldog); }

/* blocks rendered inside stages */
.b-masthead { background: var(--lake-wash); padding: 2.4rem 1.6rem; }
.b-masthead .kicker { color: var(--sanford); }
.b-masthead h3 { font-family: var(--display); font-weight: 500; font-size: 2rem; text-transform: uppercase; margin: 0 0 0.5rem; line-height: 1.05; }
.b-masthead p { color: var(--sanford); max-width: 52ch; }
.b-stats { background: var(--night); color: var(--paper); padding: 1.9rem 1.6rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.viewport-mobile .b-stats { grid-template-columns: 1fr; }
.b-stats .figure { font-family: var(--display); font-weight: 300; font-size: 2.1rem; display: block; line-height: 1; }
.b-stats .what { font-family: var(--display); font-weight: 500; font-size: 0.9rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--lake); display: block; margin-top: 0.4rem; }
.b-notice { display: flex; gap: 0.9rem; align-items: flex-start; padding: 1.1rem 1.3rem; border: 1px solid var(--stegeman); border-left: 8px solid var(--olympic); background: var(--lake-wash); margin: 1rem 1.5rem; }
.b-notice.urgent { border-left-color: var(--bulldog); background: var(--paper); }
.b-notice .n-label { font-family: var(--display); font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; font-size: 0.95rem; }
.b-notice p { margin: 0.2rem 0 0; font-size: 0.95rem; color: var(--sanford); }
.b-quote { margin: 1rem 1.5rem; padding: 0.4rem 0 0.4rem 1.5rem; border-left: 7px solid var(--bulldog); }
.b-quote blockquote { margin: 0; font-style: italic; font-size: 1.18rem; line-height: 1.6; }
.b-quote cite { display: block; margin-top: 0.7rem; font-style: normal; font-family: var(--display); font-weight: 500; font-size: 0.95rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sanford); }
.b-accordion { margin: 1rem 1.5rem; border-top: 3px solid var(--ink); }
.b-accordion details { border-bottom: 1px solid var(--stegeman); }
.b-accordion summary {
  cursor: pointer; font-family: var(--display); font-weight: 500; font-size: 1.12rem;
  letter-spacing: 0.05em; text-transform: uppercase; padding: 0.9rem 0.4rem;
  list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 1rem; min-height: 48px;
}
.b-accordion summary::-webkit-details-marker { display: none; }
.b-accordion summary::after { content: "+"; font-size: 1.4rem; color: var(--bulldog); flex: none; }
.b-accordion details[open] summary::after { content: "\2212"; color: var(--lake-ink); }
.b-accordion .a-body { padding: 0 0.4rem 1.1rem; color: var(--sanford); font-size: 0.97rem; }
.b-table { margin: 1rem 1.5rem; overflow-x: auto; }
.b-table table { border-collapse: collapse; width: 100%; font-size: 0.95rem; }
.b-table caption { text-align: left; font-family: var(--display); font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.95rem; color: var(--sanford); padding-bottom: 0.5rem; }
.b-table th { font-family: var(--display); font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; text-align: left; background: var(--night); color: var(--paper); padding: 0.6rem 0.8rem; }
.b-table td { border-bottom: 1px solid var(--stegeman); padding: 0.6rem 0.8rem; }
.b-table tbody tr:nth-child(even) td { background: var(--cream-soft); }
.b-cta { background: var(--bulldog); color: var(--paper); padding: 2rem 1.6rem; display: flex; align-items: center; justify-content: space-between; gap: 1.4rem; flex-wrap: wrap; }
.b-cta h3 { font-family: var(--display); font-weight: 500; font-size: 1.6rem; text-transform: uppercase; margin: 0; line-height: 1.1; color: var(--paper); }
.b-cta p { margin: 0.3rem 0 0; font-size: 0.95rem; color: var(--paper); }
.b-events { margin: 1rem 1.5rem; list-style: none; padding: 0; border-top: 3px solid var(--ink); }
.b-events li { display: flex; gap: 1.1rem; align-items: baseline; border-bottom: 1px solid var(--stegeman); padding: 0.85rem 0.2rem; }
.b-events .date { font-family: var(--display); font-weight: 500; font-size: 1.05rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--bulldog); flex: none; min-width: 88px; }
.b-events .what { font-size: 0.97rem; }
.b-events .where { display: block; font-size: 0.85rem; color: var(--sanford); }

/* ---------- Prose pages ---------- */
.prose { max-width: 70ch; }
.prose h2 { margin-top: 2.6rem; }
.prose table { border-collapse: collapse; width: 100%; font-size: 0.95rem; margin: 1.2rem 0 2rem; }
.prose th { font-family: var(--display); font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; text-align: left; border-bottom: 3px solid var(--ink); padding: 0.55rem 0.7rem; }
.prose td { border-bottom: 1px solid var(--stegeman); padding: 0.55rem 0.7rem; }
.note-card { border: var(--frame); border-left-width: 8px; background: var(--cream-soft); padding: 1.2rem 1.4rem; margin: 1.6rem 0; font-size: 0.97rem; }
.note-card p { margin: 0; }

/* ---------- Contact form ---------- */
.demo-form { border: var(--frame); background: var(--paper); padding: 1.8rem 1.6rem; max-width: 640px; }
.demo-form .f-row { margin-bottom: 1.2rem; }
.demo-form label { display: block; font-family: var(--display); font-weight: 500; font-size: 1rem; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.35rem; }
.demo-form input, .demo-form select, .demo-form textarea {
  width: 100%; border: 1px solid var(--sanford); background: var(--paper);
  font-family: var(--body); font-size: 1rem; color: var(--ink); padding: 0.7rem 0.85rem;
}
.demo-form .f-help { font-size: 0.85rem; color: var(--sanford); margin-top: 0.3rem; }
.form-confirm { border: var(--frame); border-left: 8px solid var(--lake); background: var(--lake-wash); padding: 1.4rem 1.5rem; }
.form-confirm h3 { margin-bottom: 0.4rem; }
.form-confirm p { margin: 0; color: var(--sanford); }

/* ---------- Two-column splits ---------- */
.split { display: grid; grid-template-columns: minmax(0, 7fr) minmax(0, 5fr); gap: 3rem; align-items: start; }
.split.flip { grid-template-columns: minmax(0, 5fr) minmax(0, 7fr); }
@media (max-width: 860px) { .split, .split.flip { grid-template-columns: 1fr; gap: 2.2rem; } }

.credits { font-size: 0.85rem; color: var(--sanford); }
.credits ul { list-style: none; margin: 0.5rem 0 0; padding: 0; }
.credits li { padding: 0.18rem 0 0.18rem 1.05rem; position: relative; }
.credits li::before { content: ""; position: absolute; left: 0; top: 0.55em; width: 4px; height: 0.8em; background: var(--stegeman); }
