@charset "UTF-8";
:root {
  --red: #ee2e2f;
  --red-soft: #ffe1de;
  --red-deep: #c41f20;
  --ink: #0a0a0a;
  --ink-2: #2a2a2a;
  --ink-3: #5a5a5a;
  --ink-4: #8a8a8a;
  --paper: #fafaf7;
  --paper-2: #f1ece4;
  --paper-3: #e7e2d8;
  --line: #1a1a1a;
  --line-soft: rgba(10, 10, 10, 0.08);
  --maxw: 1320px;
  --pad: clamp(20px, 4vw, 56px);
}

* {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
}

html {
  overflow-x: hidden;
}

body {
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

button {
  font: inherit;
}

html {
  font-size: 17px;
}

body {
  font-family: "Strawford", system-ui, sans-serif;
  background: var(--paper);
  color: var(--ink);
  font-size: 1rem;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.647rem, 4vw, 3.294rem);
  letter-spacing: -0.025em;
  line-height: 1;
  text-transform: uppercase;
  margin: 18px 0 28px;
  color: var(--ink);
}

h1.small-title {
  font-size: clamp(1.059rem, 2.5vw, 1.882rem);
}

h1.big-title {
  font-size: clamp(2.824rem, 7vw, 6.118rem);
  letter-spacing: -0.035em;
  line-height: 0.92;
}

.mono {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  letter-spacing: 0.02em;
}

.narrow {
  font-family: "Strawford", sans-serif;
}

body.hc {
  --paper: #1a1a1a;
  --paper-2: #222222;
  --paper-3: #2a2a2a;
  --ink: #ffed00;
  --ink-2: #ffed00;
  --ink-3: #cccc00;
  --ink-4: #cccc00;
  --line-soft: rgba(255,237,0,0.25);
  --red: #ffed00;
}

body.hc * {
  border-color: rgba(255, 237, 0, 0.35) !important;
}

body.hc .header {
  background: #1a1a1a !important;
}

body.hc .icon-btn {
  color: #ffed00 !important;
}

body.hc .icon-btn.active,
body.hc .icon-btn:hover {
  background: #ffed00 !important;
  color: #1a1a1a !important;
}

body.hc .mobile-menu-toggle {
  background: #ffed00 !important;
  color: #1a1a1a !important;
}

body.hc .nav {
  background: #1a1a1a !important;
  border-bottom-color: rgba(255, 237, 0, 0.3) !important;
}

body.hc .nav-list li a,
body.hc .nav-list li.active a {
  color: #ffed00 !important;
}

body.hc .subnav > ul,
body.hc .subnav2 > ul {
  background: #222222 !important;
  box-shadow: 0 12px 32px -8px rgba(0, 0, 0, 0.6) !important;
}

body.hc .subnav li a,
body.hc .subnav2 li a {
  color: #ffed00 !important;
}

body.hc .subnav li a:hover,
body.hc .subnav2 li a:hover {
  background: #2a2a2a !important;
  color: #ffed00 !important;
}

body.hc .breadcrumb {
  background: #1a1a1a !important;
}

body.hc .breadcrumbs a,
body.hc .breadcrumbs .current,
body.hc .breadcrumbs .sep {
  color: #ffed00 !important;
}

body.hc h1, body.hc h2, body.hc h3, body.hc h4, body.hc h5 {
  color: #ffed00 !important;
}

body.hc p, body.hc li {
  color: #ffed00 !important;
}

body.hc a {
  color: #ffed00 !important;
}

body.hc .article-body,
body.hc .article-body h2,
body.hc .article-body h3,
body.hc .article-body h4 {
  color: #ffed00 !important;
}

body.hc .article-body a {
  color: #ffed00 !important;
  text-decoration: underline !important;
}

body.hc .events,
body.hc .newsletter {
  background: #222222 !important;
  color: #ffed00 !important;
}

body.hc .events .section-title,
body.hc .events .section-sub,
body.hc .events .section-eyebrow,
body.hc .newsletter .section-title,
body.hc .newsletter p {
  color: #ffed00 !important;
}

body.hc .pillars {
  background: #1a1a1a !important;
}

body.hc .pillar-card {
  background: #222222 !important;
  color: #ffed00 !important;
}

body.hc .pillar-card:hover {
  background: #2a2a2a !important;
  color: #ffed00 !important;
}

body.hc .pillar-num, body.hc .pillar-desc, body.hc .pillar-meta {
  color: #cccc00 !important;
}

body.hc .pillar-arrow {
  color: #ffed00 !important;
}

body.hc .news-card {
  background: #222222 !important;
  color: #ffed00 !important;
}

body.hc .news-card:hover {
  background: #2a2a2a !important;
}

body.hc .news-cover,
body.hc .news-cover.alt-1,
body.hc .news-cover.alt-2,
body.hc .news-cover.alt-3 {
  background: #2a2a2a !important;
  background-image: none !important;
}

body.hc .news-title,
body.hc .news-excerpt,
body.hc .news-meta,
body.hc .news-footer {
  color: #ffed00 !important;
}

body.hc .news-tag {
  background: #ffed00 !important;
  color: #1a1a1a !important;
  border-color: #ffed00 !important;
}

body.hc .news-tag.outline {
  background: transparent !important;
  color: #ffed00 !important;
  border-color: #ffed00 !important;
}

body.hc .news-tabs {
  border-bottom-color: rgba(255, 237, 0, 0.3) !important;
}

body.hc .news-tab {
  color: #cccc00 !important;
}

body.hc .news-tab.active {
  color: #ffed00 !important;
}

body.hc .news-tab.active::after {
  background: #ffed00 !important;
}

body.hc .material-card {
  background: #222222 !important;
  color: #ffed00 !important;
}

body.hc .material-icon {
  background: #2a2a2a !important;
  color: #ffed00 !important;
  border-color: rgba(255, 237, 0, 0.35) !important;
}

body.hc .material-name, body.hc .material-meta {
  color: #ffed00 !important;
}

body.hc .btn-primary {
  background: #ffed00 !important;
  color: #1a1a1a !important;
  border-color: #ffed00 !important;
}

body.hc .btn-secondary {
  background: transparent !important;
  color: #ffed00 !important;
  border-color: #ffed00 !important;
}

body.hc footer {
  background: #1a1a1a !important;
  color: #ffed00 !important;
}

body.hc .footer-col h4,
body.hc .footer-col ul li a,
body.hc .footer-brand p,
body.hc .footer-brand .address,
body.hc .footer-bottom,
body.hc .footer-bottom a,
body.hc .funding-note {
  color: #ffed00 !important;
}

body.hc .photo-stage {
  background: #222222 !important;
}

body.hc .member-stats {
  background: #222222 !important;
  color: #ffed00 !important;
}

body.hc .member-card:hover {
  background: #2a2a2a !important;
  color: #ffed00 !important;
}

body.hc .member-card.tone-ink .member-portrait-inner {
  background: #222222 !important;
}

body.hc .pagination-link.active {
  background: #ffed00 !important;
  color: #1a1a1a !important;
  border-color: #ffed00 !important;
}

body.hc .mobile-nav {
  background: #1a1a1a !important;
  color: #ffed00 !important;
}

body.hc .mobile-nav-list li a,
body.hc .mobile-nav-list .m-parent,
body.hc .mobile-nav-list .m-parent2,
body.hc .mobile-nav-list .m-sub > li > a,
body.hc .mobile-nav-list .m-sub2 li a {
  color: #ffed00 !important;
}

body.hc .mobile-a11y .icon-btn {
  color: #ffed00 !important;
}

body.hc .mobile-a11y .icon-btn.active {
  background: #ffed00 !important;
  color: #1a1a1a !important;
}

:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 2px;
}

body.hc :focus-visible {
  outline: 2px solid #ffed00;
  outline-offset: 2px;
}

.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

body.no-anim .reveal {
  opacity: 1;
  transform: none;
  transition: none;
}

/* Text-size scaling — 5 levels, 2 steps each way from 17px base */
html.text-p2 {
  font-size: 21px;
}

html.text-p1 {
  font-size: 19px;
}

/* default: 17px (set in _typography.scss) */
html.text-n1 {
  font-size: 15px;
}

html.text-n2 {
  font-size: 13px;
}

.mobile-a11y {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--pad);
  padding-right: var(--pad);
}

.container--flush {
  padding-left: 0;
  padding-right: 0;
}

.header {
  background: var(--paper);
  border-bottom: 1px solid var(--line-soft);
  overflow: hidden;
}

.header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  grid-template-rows: auto auto auto auto;
  column-gap: clamp(24px, 4vw, 64px);
  row-gap: 0;
  align-items: center;
  padding-top: 32px;
  padding-bottom: 32px;
}

.header-stack {
  display: contents;
  text-decoration: none;
}

.hs-ghost,
.hs-wordmark {
  display: block;
  width: 100%;
  height: auto;
  grid-column: 1;
  align-self: start;
  justify-self: center;
  margin-bottom: 4px;
}

.hs-row-1 {
  grid-row: 1;
}

.hs-row-2 {
  grid-row: 2;
}

.hs-row-3 {
  grid-row: 3;
}

.hs-row-4 {
  grid-row: 4;
}

.header-right {
  display: contents;
}

.header-right .header-icons {
  grid-column: 2;
  grid-row: 2;
  justify-self: end;
  align-self: start;
  margin: 0;
}

.header-right .partner-mark {
  grid-column: 2;
  grid-row: 3;
  justify-self: end;
  align-self: start;
  display: inline-flex;
  align-items: flex-start;
}

.header-right .partner-mark img {
  vertical-align: top;
}

.header-icons {
  display: flex;
  align-items: center;
  gap: 8px;
}

.header-icons .group {
  display: flex;
  align-items: center;
  gap: 6px;
}

.header-icons .sep {
  width: 1px;
  height: 20px;
  background: var(--ink);
  margin: 0 6px;
}

.icon-btn {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--ink);
  border-radius: 6px;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 0.765rem;
  padding: 0;
}

.icon-btn.social {
  border-radius: 50%;
}

.icon-btn:hover {
  color: var(--red);
  border-color: var(--red);
  background: transparent;
}

.icon-btn.active {
  color: var(--red);
  border-color: var(--red);
  background: transparent;
}

.icon-btn svg {
  width: 14px;
  height: 14px;
  display: block;
}

.partner-mark {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.partner-mark img {
  display: block;
  height: 70px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
  object-position: left top;
}

.mobile-menu-toggle {
  display: none;
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  background: var(--ink);
  color: #fff;
  border: none;
  padding: 10px 16px;
  min-height: 44px;
  border-radius: 999px;
  font-family: "Strawford", sans-serif;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  align-items: center;
  gap: 8px;
}

@media (max-width: 960px) {
  .header-inner {
    grid-template-columns: 1fr auto;
    column-gap: 16px;
    padding-top: 24px;
    padding-bottom: 20px;
  }
  .mobile-menu-toggle {
    display: inline-flex;
  }
  .header-right .partner-mark img {
    height: 36px;
  }
}
@media (max-width: 720px) {
  .partner-mark img {
    height: 40px;
  }
}
@media (max-width: 480px) {
  .hs-ghost {
    display: none;
  }
  .header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding-top: 12px;
    padding-bottom: 12px;
  }
  .header-stack {
    display: flex;
    align-items: center;
    flex: 1 1 0;
    min-width: 0;
  }
  .hs-wordmark {
    grid-column: unset;
    grid-row: unset;
    justify-self: unset;
    margin-bottom: 0;
    width: auto;
    max-width: 100%;
    height: clamp(20px, 5vw, 26px);
  }
  .header-right {
    display: none;
  }
  .mobile-menu-toggle {
    grid-column: unset;
    grid-row: unset;
    justify-self: unset;
    flex-shrink: 0;
  }
}
.nav {
  background: var(--paper);
  border-bottom: 1px solid var(--line-soft);
  position: sticky;
  top: 0;
  z-index: 90;
  backdrop-filter: blur(8px);
  background: rgba(250, 250, 247, 0.94);
}

.nav-inner {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-top: 0;
  padding-bottom: 0;
  position: relative;
}

.nav-list {
  display: flex;
  gap: 4px;
  list-style: none;
  padding: 0;
  margin: 0;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
}

.nav-list li:first-child a {
  padding-left: 0;
}

.nav-list li a {
  display: inline-flex;
  align-items: center;
  padding: 22px 16px;
  font-family: "Strawford", sans-serif;
  font-weight: 400;
  font-size: 0.824rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink);
  transition: color 0.15s;
  position: relative;
  white-space: nowrap;
}

.nav-list li a:hover {
  color: var(--red);
}

.nav-list li.active a {
  color: var(--red);
  background: transparent;
  font-weight: 500;
}

@media (max-width: 1080px) {
  .nav {
    display: none;
  }
}
.mobile-nav {
  position: fixed;
  inset: 0;
  background: var(--ink);
  color: #fff;
  z-index: 999;
  display: flex;
  flex-direction: column;
  padding: 24px var(--pad);
  transform: translateX(100%);
  transition: transform 0.3s ease;
  overflow-y: auto;
}

.mobile-nav.open {
  transform: translateX(0);
}

.mobile-nav-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.mobile-nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1;
}

.mobile-nav-list li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.mobile-nav-list li a {
  display: block;
  padding: 18px 0;
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 1.294rem;
  letter-spacing: -0.01em;
  color: #fff;
}

.mobile-nav-list li a:hover {
  color: var(--red);
}

.close-btn {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.3);
  width: 40px;
  height: 40px;
  min-width: 44px;
  min-height: 44px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 1.059rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.nav-inner, .nav-list {
  overflow: visible;
}

.nav-list li.has-sub {
  position: relative;
}

.nav-list li a .caret {
  width: 10px;
  height: 7px;
  margin-left: 7px;
  display: inline-block;
  transition: transform 0.2s ease;
}

.nav-list li.has-sub:hover > a .caret,
.nav-list li.has-sub:focus-within > a .caret {
  transform: rotate(180deg);
}

.subnav {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  padding-top: 6px;
  min-width: 250px;
  z-index: 200;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.18s ease;
}

.nav-list li.has-sub:hover > .subnav,
.nav-list li.has-sub:focus-within > .subnav {
  opacity: 1;
  visibility: visible;
}

.subnav > ul {
  list-style: none;
  margin: 0;
  padding: 7px;
  background: var(--paper);
  border: 1px solid var(--line-soft);
  box-shadow: 0 22px 50px -18px rgba(10, 10, 10, 0.3);
  display: flex;
  flex-direction: column;
  gap: 2px;
  transform: translateY(6px);
  transition: transform 0.18s ease;
}

.nav-list li.has-sub:hover > .subnav > ul,
.nav-list li.has-sub:focus-within > .subnav > ul {
  transform: translateY(0);
}

.subnav li {
  margin: 0;
  position: relative;
}

.subnav li a {
  display: block;
  padding: 11px 14px;
  font-family: "Strawford", sans-serif;
  font-weight: 500;
  font-size: 0.824rem;
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
  color: var(--ink);
  border-radius: 6px;
  transition: background 0.15s, color 0.15s;
}

.subnav li a:hover {
  background: var(--paper-2);
  color: var(--red);
}

.subnav li.has-sub2 > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.subnav .caret-r {
  width: 7px;
  height: 11px;
  flex-shrink: 0;
  transition: transform 0.15s ease;
  color: var(--ink-4);
}

.subnav li.has-sub2:hover > a .caret-r,
.subnav li.has-sub2:focus-within > a .caret-r {
  transform: translateX(2px);
  color: var(--red);
}

.subnav li.has-sub2:hover > a,
.subnav li.has-sub2:focus-within > a {
  background: var(--paper-2);
  color: var(--red);
}

.subnav2 {
  position: absolute;
  top: -7px;
  left: 100%;
  padding-left: 7px;
  min-width: 232px;
  z-index: 210;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.16s ease;
}

.subnav2.flip {
  left: auto;
  right: 100%;
  padding-left: 0;
  padding-right: 7px;
}

.subnav li.has-sub2:hover > .subnav2,
.subnav li.has-sub2:focus-within > .subnav2 {
  opacity: 1;
  visibility: visible;
}

.subnav2 > ul {
  list-style: none;
  margin: 0;
  padding: 7px;
  background: var(--paper);
  border: 1px solid var(--line-soft);
  box-shadow: 0 22px 50px -18px rgba(10, 10, 10, 0.3);
  display: flex;
  flex-direction: column;
  gap: 2px;
  transform: translateX(-6px);
  transition: transform 0.16s ease;
}

.subnav2.flip > ul {
  transform: translateX(6px);
}

.subnav li.has-sub2:hover > .subnav2 > ul,
.subnav li.has-sub2:focus-within > .subnav2 > ul {
  transform: translateX(0);
}

.subnav2 li a {
  display: block;
  padding: 10px 14px;
  font-family: "Strawford", sans-serif;
  font-weight: 500;
  font-size: 0.824rem;
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
  color: var(--ink);
  border-radius: 6px;
  transition: background 0.15s, color 0.15s;
}

.subnav2 li a:hover {
  background: var(--paper-2);
  color: var(--red);
}

.mobile-nav-list .m-parent {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 18px 0;
  color: #fff;
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 1.294rem;
  letter-spacing: -0.01em;
  text-align: left;
}

.mobile-nav-list .m-parent .caret {
  width: 16px;
  height: 10px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
  color: rgba(255, 255, 255, 0.65);
}

.mobile-nav-list li.has-sub.open > .m-parent {
  color: var(--red);
}

.mobile-nav-list li.has-sub.open > .m-parent .caret {
  transform: rotate(180deg);
  color: var(--red);
}

.mobile-nav-list .m-sub {
  list-style: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.32s ease;
}

.mobile-nav-list li.has-sub.open > .m-sub {
  max-height: 2000px;
}

.mobile-nav-list .m-sub > li {
  border: none !important;
}

.mobile-nav-list .m-sub > li > a {
  display: block;
  padding: 12px 0 12px 18px;
  font-family: "Strawford", sans-serif;
  font-weight: 500;
  font-size: 0.941rem;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.78);
  border-left: 2px solid rgba(255, 255, 255, 0.18);
}

.mobile-nav-list .m-sub > li > a:hover {
  color: #fff;
  border-left-color: var(--red);
}

.mobile-nav-list .m-parent2 {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 12px 0 12px 18px;
  text-align: left;
  font-family: "Strawford", sans-serif;
  font-weight: 500;
  font-size: 0.941rem;
  letter-spacing: 0;
  color: rgba(255, 255, 255, 0.78);
  border-left: 2px solid rgba(255, 255, 255, 0.18);
}

.mobile-nav-list .m-parent2 .caret {
  width: 13px;
  height: 8px;
  flex-shrink: 0;
  transition: transform 0.25s ease;
  color: rgba(255, 255, 255, 0.5);
}

.mobile-nav-list li.has-sub2.open > .m-parent2 {
  color: #fff;
  border-left-color: var(--red);
}

.mobile-nav-list li.has-sub2.open > .m-parent2 .caret {
  transform: rotate(180deg);
  color: var(--red);
}

.mobile-nav-list .m-sub2 {
  list-style: none;
  margin: 0;
  padding: 0;
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease;
}

.mobile-nav-list li.has-sub2.open > .m-sub2 {
  max-height: 800px;
}

.mobile-nav-list .m-sub2 li a {
  display: block;
  padding: 10px 0 10px 36px;
  font-family: "Strawford", sans-serif;
  font-weight: 500;
  font-size: 0.882rem;
  color: rgba(255, 255, 255, 0.6);
  border-left: 2px solid rgba(255, 255, 255, 0.12);
}

.mobile-nav-list .m-sub2 li a:hover {
  color: #fff;
  border-left-color: var(--red);
}

.mobile-social,
.mobile-a11y {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 0;
}
.mobile-social .icon-btn,
.mobile-a11y .icon-btn {
  border-color: rgba(255, 255, 255, 0.4);
  color: #fff;
}
.mobile-social .icon-btn:hover,
.mobile-a11y .icon-btn:hover {
  border-color: var(--red);
  color: var(--red);
  background: transparent;
}

.mobile-social {
  margin-top: 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.mobile-a11y {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

footer {
  background: var(--ink);
  color: #c9c9c9;
  padding: 72px 0 24px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

@media (max-width: 880px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 520px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }
}
.footer-brand .wordmark {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: 1.882rem;
  letter-spacing: -0.02em;
  color: #fff;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.footer-brand .wordmark .red {
  color: var(--red);
}

.footer-brand p {
  font-size: 0.824rem;
  line-height: 1.6;
  max-width: 320px;
  color: #a0a0a0;
}

.footer-brand .address {
  margin-top: 20px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.706rem;
  line-height: 1.6;
  letter-spacing: 0.04em;
  color: #c9c9c9;
}

.footer-col h4 {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.5);
  margin: 0 0 16px;
  font-weight: 500;
}

.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer-col ul li a {
  font-size: 0.824rem;
  color: #c9c9c9;
  transition: color 0.15s;
}

.footer-col ul li a:hover {
  color: var(--red);
}

.footer-patronage {
  padding: 40px 0;
  margin-bottom: 56px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-patronage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.4fr;
  gap: 40px;
  align-items: start;
}

@media (max-width: 800px) {
  .footer-patronage-grid {
    grid-template-columns: 1fr;
  }
}
.patron-block .ttl {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(255, 255, 255, 0.4);
  margin-bottom: 14px;
}

.patron-block .marks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: #fff;
}

.patron-block .mark-line {
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 0.824rem;
  line-height: 1.25;
}

.patron-block .mark-line .sub {
  display: block;
  font-weight: 400;
  font-size: 0.706rem;
  color: rgba(255, 255, 255, 0.6);
  margin-top: 2px;
}

.funding-note {
  font-size: 0.706rem;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.55;
  max-width: 460px;
}

.footer-patronage .funding-note {
  margin-top: 20px;
}

.footer-patronage--light {
  border-color: rgba(0, 0, 0, 0.1);
  margin-left: calc(-1 * var(--pad));
  margin-right: calc(-1 * var(--pad));
  padding-left: var(--pad);
  padding-right: var(--pad);
}

.footer-patronage--light .patron-block .ttl {
  color: rgba(0, 0, 0, 0.45);
}

.footer-patronage--light .patron-block .mark-line {
  color: #111;
}

.footer-patronage--light .patron-block .mark-line .sub {
  color: rgba(0, 0, 0, 0.5);
}

.footer-patronage--light .funding-note {
  color: rgba(0, 0, 0, 0.65);
}

.patron-logo {
  display: block;
  max-width: 100%;
  width: auto;
  height: auto;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  padding-top: 24px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  color: rgba(255, 255, 255, 0.45);
  letter-spacing: 0.08em;
}

.footer-bottom .links {
  display: flex;
  gap: 24px;
}

.footer-bottom a:hover {
  color: var(--red);
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 28px;
  border-radius: 999px;
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 0.824rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-primary {
  background: var(--ink);
  color: #fff;
}

.btn-primary:hover {
  background: var(--red);
  transform: translateY(-2px);
}

.btn-secondary {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}

.btn-secondary:hover {
  background: var(--ink);
  color: #fff;
}

.btn-red {
  background: var(--red);
  color: #fff;
}

.btn-red:hover {
  background: var(--red-deep);
  transform: translateY(-2px);
}

.btn .arrow {
  display: inline-flex;
  transition: transform 0.2s;
}

.btn:hover .arrow {
  transform: translateX(4px);
}

/* ------------ Pillars ------------ */
.pillars {
  background: var(--paper-2);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}

.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-left: 1px solid var(--line-soft);
}

@media (max-width: 920px) {
  .pillars-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 520px) {
  .pillars-grid {
    grid-template-columns: 1fr;
  }
}
.pillar-card {
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  padding: 36px 28px;
  background: var(--paper-2);
  transition: background 0.2s;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 280px;
}

.pillar-card:hover {
  background: var(--ink);
  color: var(--paper);
}

.pillar-card:hover .pillar-num,
.pillar-card:hover .pillar-meta,
.pillar-card:hover .pillar-desc {
  color: rgba(255, 255, 255, 0.7);
}

.pillar-card:hover .pillar-arrow {
  color: var(--red);
  transform: translate(4px, -4px);
}

.pillar-num {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  color: var(--ink-3);
  margin-bottom: 32px;
}

.pillar-title {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: 1.529rem;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 12px;
}

.pillar-desc {
  color: var(--ink-3);
  font-size: 0.824rem;
  line-height: 1.5;
  flex: 1;
}

.pillar-meta {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-3);
  margin-top: 16px;
}

.pillar-arrow {
  position: absolute;
  top: 28px;
  right: 28px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  color: var(--ink);
}

/* ------------ News ------------ */
.news-tabs {
  display: flex;
  gap: 6px;
  align-items: center;
  border-bottom: 1px solid var(--line-soft);
  margin-bottom: 32px;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.news-tabs::-webkit-scrollbar {
  display: none;
}

.news-tab {
  background: transparent;
  border: none;
  padding: 14px 18px;
  font-family: "Strawford", sans-serif;
  font-weight: 600;
  font-size: 0.765rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  position: relative;
  white-space: nowrap;
}

.news-tab:hover {
  color: var(--ink);
}

.news-tab.active {
  color: var(--ink);
}

.news-tab.active::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: -1px;
  height: 2px;
  background: var(--red);
}

.news-tab .count {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  color: var(--ink-4);
  margin-left: 6px;
}

.news-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--line-soft);
  border-left: 1px solid var(--line-soft);
}

@media (max-width: 960px) {
  .news-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 600px) {
  .news-grid {
    grid-template-columns: 1fr;
  }
}
.news-card {
  padding: 0;
  background: var(--paper);
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  transition: background 0.2s;
  cursor: pointer;
}

.news-card:hover {
  background: var(--paper-2);
}

.news-card.featured {
  grid-row: span 2;
}

@media (max-width: 960px) {
  .news-card.featured {
    grid-row: auto;
    grid-column: span 2;
  }
}
@media (max-width: 600px) {
  .news-card.featured {
    grid-column: auto;
  }
}
.news-cover {
  aspect-ratio: 16/10;
  background: var(--paper-3);
  position: relative;
  overflow: hidden;
  background-image: repeating-linear-gradient(45deg, #e7e2d8 0 2px, transparent 2px 16px);
}

.news-cover.alt-1 {
  background-color: #1a1a1a;
  background-image: repeating-linear-gradient(45deg, #1f1f1f 0 2px, transparent 2px 16px);
}

.news-cover.alt-2 {
  background-color: var(--red);
  background-image: repeating-linear-gradient(135deg, #d92829 0 2px, transparent 2px 16px);
}

.news-cover.alt-3 {
  background-color: #f1ece4;
}

.placeholder-label {
  position: absolute;
  bottom: 10px;
  left: 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.529rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.4;
  color: #fff;
}

.news-body {
  padding: 24px 24px 28px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.news-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 14px;
}

.news-tag {
  padding: 4px 10px;
  background: var(--ink);
  color: #fff;
  border-radius: 999px;
  font-weight: 700;
}

.news-tag.red {
  background: var(--red);
}

.news-tag.outline {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
}

.news-title {
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 1.294rem;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 0 10px;
}

.news-card.featured .news-title {
  font-size: 1.882rem;
  line-height: 1.05;
}

.news-excerpt {
  color: var(--ink-3);
  font-size: 0.824rem;
  line-height: 1.5;
  flex: 1;
}

.news-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line-soft);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  color: var(--ink-3);
}

.news-footer .read {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ink);
  font-weight: 700;
}

/* ------------ Materials ------------ */
.materials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

@media (max-width: 880px) {
  .materials-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 520px) {
  .materials-grid {
    grid-template-columns: 1fr;
  }
}
.material-card {
  background: var(--paper);
  border: 1px solid var(--line-soft);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: all 0.2s;
  cursor: pointer;
  position: relative;
}

.material-card:hover {
  border-color: var(--ink);
  transform: translateY(-3px);
  box-shadow: 0 12px 28px -16px rgba(0, 0, 0, 0.2);
}

.material-icon {
  width: 56px;
  height: 56px;
  background: var(--paper-2);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line-soft);
  font-family: "JetBrains Mono", monospace;
  font-weight: 700;
  font-size: 0.765rem;
  letter-spacing: 0.04em;
}

.material-icon.red {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}

.material-icon.dark {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.material-name {
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin: 0;
}

.material-meta {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  color: var(--ink-3);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: flex;
  gap: 12px;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--line-soft);
}

.material-meta .size {
  margin-left: auto;
}

.ticker {
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  background: var(--ink);
  color: var(--paper);
  overflow: hidden;
  padding: 20px 0;
}

.ticker-track {
  display: flex;
  gap: 48px;
  animation: ticker 40s linear infinite;
  white-space: nowrap;
  width: max-content;
}

@media (prefers-reduced-motion: reduce) {
  .ticker-track {
    animation: none;
  }
}
.ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: 1.059rem;
  text-transform: uppercase;
  letter-spacing: -0.01em;
}

.ticker-item .dot {
  width: 10px;
  height: 10px;
  background: var(--red);
  border-radius: 50%;
  flex-shrink: 0;
}

.ticker-item a {
  color: inherit;
  text-decoration: none;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
}
.ticker-item a:hover {
  color: var(--red);
}

.ticker-item .outline-my {
  color: transparent;
  -webkit-text-stroke: 1px var(--red);
  font-weight: 800;
}

@keyframes ticker {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(var(--ticker-end, -50%));
  }
}
/* ------------ Hero ------------ */
.hero {
  position: relative;
  overflow: hidden;
  padding-top: clamp(1.882rem, 4vw, 3.294rem);
  padding-bottom: clamp(2.824rem, 6vw, 5.647rem);
}

.hero-stage {
  position: relative;
  border: none;
  background: var(--paper);
  padding: clamp(1.412rem, 3vw, 2.824rem);
}

.hero-graphic {
  width: 100%;
  display: block;
  aspect-ratio: 2.05/1;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.hero-eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--ink);
}

.hero-title {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: clamp(2.824rem, 7vw, 6.353rem);
  letter-spacing: -0.04em;
  line-height: 0.88;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0;
  position: relative;
  display: inline-block;
}

.hero-title .line {
  display: block;
}

.hero-title .my-accent {
  color: var(--red);
}

.hero-title .my-stack {
  position: absolute;
  left: 100%;
  top: 0;
  margin-left: 0.12em;
  display: flex;
  flex-direction: column;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px var(--red);
  opacity: 0.55;
  font-size: 0.5em;
  pointer-events: none;
  user-select: none;
}

.hero-title .my-stack span {
  display: block;
}

.hero-lead {
  font-size: clamp(0.882rem, 1.2vw, 1.059rem);
  color: var(--ink-2);
  max-width: 460px;
  margin: 0;
  line-height: 1.55;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 40px;
  margin-top: 12px;
  padding-top: 24px;
  border-top: 1px solid var(--line-soft);
}

.hero-meta-item .label {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-4);
  margin-bottom: 6px;
}

.hero-meta-item .value {
  font-family: "Strawford", sans-serif;
  font-size: clamp(1.176rem, 2vw, 1.529rem);
  font-weight: 800;
  letter-spacing: -0.02em;
}

.hero-meta-item .value .small {
  font-size: 0.765rem;
  color: var(--ink-3);
  font-weight: 500;
  margin-left: 6px;
}

/* ------------ Sections ------------ */
section {
  padding: clamp(3.294rem, 7vw, 6.588rem) 0;
}

.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 48px;
  flex-wrap: wrap;
}
@media (max-width: 600px) {
  .section-head {
    gap: 20px;
    margin-bottom: 36px;
  }
}

.section-head .left {
  flex: 1;
}

.section-eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 14px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.section-eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--red);
}

.section-title {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: clamp(2rem, 5vw, 3.765rem);
  letter-spacing: -0.035em;
  line-height: 0.95;
  text-transform: uppercase;
  margin: 0;
}

.section-title .accent {
  color: var(--red);
}

.section-sub {
  color: var(--ink-3);
  max-width: 540px;
  margin-top: 18px;
  font-size: 1rem;
  line-height: 1.55;
}

/* ------------ Events ------------ */
.events {
  background: var(--ink);
  color: var(--paper);
}

.events .section-title {
  color: #fff;
}

.events .section-sub {
  color: rgba(255, 255, 255, 0.6);
}

.events .section-eyebrow {
  color: rgba(255, 255, 255, 0.6);
}

.events .section-eyebrow::before {
  background: var(--red);
}

.filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 32px;
}

.chip {
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 8px 16px;
  border-radius: 999px;
  font-family: "Strawford", sans-serif;
  font-weight: 500;
  font-size: 0.765rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all 0.15s;
}

.chip:hover {
  border-color: #fff;
  color: #fff;
}

.chip.active {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}

.events-list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.event-row {
  display: grid;
  grid-template-columns: 120px 1fr 200px 180px 48px;
  gap: 24px;
  align-items: center;
  padding: 24px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  cursor: pointer;
  transition: background 0.2s;
}

.event-row:hover {
  background: rgba(255, 255, 255, 0.04);
  padding-left: 12px;
  padding-right: 12px;
}

.event-date {
  display: flex;
  flex-direction: column;
}

.event-date .day {
  font-family: "Strawford", sans-serif;
  font-size: 2.588rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
}

.event-date .month {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.6);
  margin-top: 4px;
}

.event-info .event-title {
  font-family: "Strawford", sans-serif;
  font-size: 1.294rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  margin: 0 0 6px;
}

.event-info .event-meta {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.765rem;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.event-place {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.706rem;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.6);
  text-transform: uppercase;
}

.event-type-tag {
  padding: 6px 12px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 999px;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #fff;
  width: max-content;
  font-family: "JetBrains Mono", monospace;
}

.event-type-tag.red {
  background: var(--red);
  border-color: var(--red);
}

.event-arrow {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.event-row:hover .event-arrow {
  background: var(--red);
  transform: rotate(-45deg);
}

@media (max-width: 880px) {
  .event-row {
    grid-template-columns: 80px 1fr 40px;
    row-gap: 8px;
  }
  .event-place, .event-type-tag {
    grid-column: 2;
  }
  .event-date .day {
    font-size: 1.882rem;
  }
}
@media (max-width: 480px) {
  .event-row {
    grid-template-columns: 56px 1fr;
    gap: 12px 14px;
  }
  .event-arrow {
    display: none;
  }
}
.events-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 32px;
  flex-wrap: wrap;
  gap: 16px;
}

/* ------------ Manifesto ------------ */
.manifesto {
  position: relative;
  overflow: hidden;
}

.manifesto-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2.353rem, 6vw, 5.647rem);
  align-items: center;
}

@media (max-width: 880px) {
  .manifesto-grid {
    grid-template-columns: 1fr;
  }
}
.manifesto-text h2 {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: clamp(1.882rem, 4.5vw, 3.294rem);
  letter-spacing: -0.035em;
  line-height: 1;
  text-transform: uppercase;
  margin: 0 0 28px;
}

.manifesto-text h2 .accent {
  color: var(--red);
}

.manifesto-text p {
  color: var(--ink-2);
  font-size: 1.059rem;
  line-height: 1.6;
  max-width: 540px;
  margin: 0 0 16px;
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 32px;
}

.stat-card {
  background: var(--paper-2);
  padding: 24px;
  border: 1px solid var(--line-soft);
}

.stat-card .v {
  font-family: "Strawford", sans-serif;
  font-size: 2.824rem;
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
}

.stat-card .v .unit {
  font-size: 1.059rem;
  color: var(--red);
  margin-left: 4px;
}

.stat-card .l {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-3);
  margin-top: 8px;
}

.manifesto-visual {
  position: relative;
  aspect-ratio: 4/5;
  background: var(--paper-2);
  border: 1px solid var(--line-soft);
  overflow: hidden;
}

.manifesto-visual .marquee {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  padding: 32px;
}

.manifesto-quote {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: clamp(1.882rem, 3.5vw, 3.294rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-transform: uppercase;
}

.manifesto-quote .red {
  color: var(--red);
}

.manifesto-quote .outline {
  color: transparent;
  -webkit-text-stroke: 1.5px var(--ink);
}

.manifesto-cite {
  margin-top: 28px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-3);
}

@media (max-width: 600px) {
  .manifesto-visual {
    aspect-ratio: 3/2;
  }
}
@media (max-width: 480px) {
  .manifesto-quote {
    font-size: clamp(1.294rem, 7vw, 1.882rem);
  }
}
/* ------------ Newsletter ------------ */
.newsletter {
  background: var(--red);
  color: #fff;
  padding: clamp(3.294rem, 7vw, 5.647rem) 0;
}

.newsletter-inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center;
}

@media (max-width: 800px) {
  .newsletter-inner {
    grid-template-columns: 1fr;
  }
}
.newsletter h2 {
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: clamp(1.882rem, 4.5vw, 3.294rem);
  letter-spacing: -0.03em;
  line-height: 0.95;
  text-transform: uppercase;
  margin: 0 0 16px;
}

.newsletter p {
  font-size: 1rem;
  opacity: 0.9;
  max-width: 480px;
  line-height: 1.5;
  margin: 0;
}

/* ------------ Materials ------------ */
.materials {
  background: var(--paper-2);
}

/* ------------ Partners ------------ */
.partners {
  background: var(--paper);
  padding: 64px 0;
  border-top: 1px solid var(--line-soft);
}

.partners-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 32px;
}

.partners-head h3 {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-3);
  margin: 0;
  font-weight: 500;
}

.partners-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-soft);
  border-left: 1px solid var(--line-soft);
}

@media (max-width: 880px) {
  .partners-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 520px) {
  .partners-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.partner-cell {
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  transition: background 0.2s;
  cursor: pointer;
  text-align: center;
}

.partner-cell:hover {
  background: var(--paper-2);
}

.partner-cell .label {
  font-family: "Strawford", sans-serif;
  font-weight: 600;
  font-size: 0.647rem;
  letter-spacing: 0.04em;
  color: var(--ink-2);
  text-transform: uppercase;
  line-height: 1.25;
}

.partner-cell .label.dim {
  color: var(--ink-4);
  font-weight: 500;
}

/* ------------ Newsletter overrides ------------ */
.newsletter .section-eyebrow {
  color: #fff;
  opacity: 0.85;
}

/* ------------ Events overrides ------------ */
.events .btn-secondary {
  border-color: rgba(255, 255, 255, 0.3);
  color: #fff;
}

.events .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}

.events-footer-count {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ------------ Placeholder pages ------------ */
.page-placeholder {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.765rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 24px;
}

/* ------------ Subpage navigation ------------ */
.subpage-nav {
  margin-top: 32px;
}

.subpage-nav__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.subpage-nav__list li a {
  color: var(--ink);
  text-decoration: none;
  font-family: "Strawford", sans-serif;
  font-size: 1rem;
  font-weight: 500;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s, color 0.15s;
}
.subpage-nav__list li a:hover {
  color: var(--red);
  border-bottom-color: var(--red);
}

.team-list-placeholder {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.team-list-placeholder li {
  font-family: "Strawford", sans-serif;
  font-size: 1.059rem;
}
.team-list-placeholder a {
  color: var(--ink);
  text-decoration: none;
  font-weight: 600;
}
.team-list-placeholder a:hover {
  color: var(--red);
}
.team-list-placeholder span {
  font-weight: 400;
  color: var(--ink-3);
}

.page-content .mod-section > .container {
  padding-inline: 0;
  max-width: none;
}

.newsletter-form {
  display: flex;
  gap: 0;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 999px;
  padding: 8px;
}

.newsletter-form input {
  flex: 1;
  background: transparent;
  border: none;
  color: #fff;
  font-family: "Strawford", sans-serif;
  font-size: 0.882rem;
  padding: 14px 20px;
  outline: none;
}
.newsletter-form input:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.8);
  outline-offset: 2px;
  border-radius: 999px;
}

.newsletter-form input::placeholder {
  color: rgba(255, 255, 255, 0.6);
}

.newsletter-form button {
  background: #fff;
  color: var(--red);
  border: none;
  padding: 14px 24px;
  border-radius: 999px;
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 0.765rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.newsletter-form button:hover {
  background: var(--ink);
  color: #fff;
}

.newsletter-checks {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}

.newsletter-checks label {
  font-size: 0.706rem;
  opacity: 0.85;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.newsletter-checks input {
  margin-top: 3px;
  accent-color: #fff;
}

.page-intro {
  padding: clamp(1.176rem, 2vw, 2.353rem) 0 0;
}

.page-intro-grid {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: clamp(1.882rem, 5vw, 5.647rem);
  align-items: end;
}
@media (max-width: 900px) {
  .page-intro-grid {
    grid-template-columns: 1fr;
  }
}

.page-title .my-accent {
  color: var(--red);
}

.page-lead {
  font-size: clamp(0.882rem, 1.2vw, 1.059rem);
  color: var(--ink-2);
  max-width: 520px;
  margin: 0;
  line-height: 1.55;
}

.meta-card {
  background: var(--paper);
  border: 1px solid var(--line-soft);
  padding: 8px 20px;
}

.meta-card-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 16px 0;
  border-bottom: 1px solid var(--line-soft);
  gap: 16px;
}
.meta-card-row:last-child {
  border-bottom: 0;
}
.meta-card-row .lbl {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-3);
  white-space: nowrap;
}
.meta-card-row .val {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 0.882rem;
  color: var(--ink);
  text-align: right;
}
.meta-card-row .val a {
  color: var(--ink);
  text-decoration: none;
  transition: color 0.15s;
}
.meta-card-row .val a:hover {
  color: var(--red);
}

.team-section {
  padding: clamp(2.824rem, 6vw, 5.647rem) 0;
}
.team-section--current {
  background: var(--paper);
}
.team-section--archive {
  background: var(--paper-2);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}

.team-head {
  margin-bottom: clamp(2.118rem, 4vw, 3.765rem);
}
@media (max-width: 900px) {
  .team-head {
    grid-template-columns: 1fr;
  }
}
.team-head .section-title {
  margin: 0;
}

.team-head-right {
  color: var(--ink-3);
  font-size: 0.882rem;
  max-width: 460px;
  margin: 0;
  justify-self: end;
  line-height: 1.55;
}
@media (max-width: 900px) {
  .team-head-right {
    justify-self: start;
  }
}

.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
@media (max-width: 1080px) {
  .team-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 760px) {
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .team-grid {
    grid-template-columns: 1fr;
  }
}

.member-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--paper);
  text-decoration: none;
  color: var(--ink);
  transition: background 0.2s, color 0.2s;
  overflow: hidden;
}
.team-section--archive .member-card {
  background: var(--paper-2);
}
.member-card:hover {
  background: var(--ink);
  color: var(--paper);
}
.member-card:hover .member-role {
  color: rgba(255, 255, 255, 0.65);
}
.member-card:hover .member-cta {
  color: var(--red);
}
.member-card:hover .portrait-tag {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.4);
  background: rgba(255, 255, 255, 0.06);
}
.member-card:hover .member-portrait-inner {
  transform: scale(1.04);
}
.member-card:hover .member-cta svg {
  transform: translateX(3px);
}

.member-portrait {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--paper-3);
}

.member-portrait-inner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.35s ease;
}

.member-card.tone-red .member-portrait-inner {
  background: var(--red);
}
.member-card.tone-red .member-portrait-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.08) 0 2px, transparent 2px 14px);
}

.member-card.tone-ink .member-portrait-inner {
  background: var(--ink);
}
.member-card.tone-ink .member-portrait-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(45deg, #1f1f1f 0 2px, transparent 2px 14px);
}

.member-card.tone-paper .member-portrait-inner {
  background: var(--paper-3);
}
.member-card.tone-paper .member-portrait-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(10, 10, 10, 0.07) 0 2px, transparent 2px 14px);
}

.member-portrait .initials {
  position: relative;
  z-index: 1;
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(2.824rem, 5.5vw, 4.941rem);
  letter-spacing: -0.04em;
  color: rgba(255, 255, 255, 0.95);
}

.member-card.tone-paper .member-portrait .initials {
  color: var(--ink);
  opacity: 0.85;
}

.member-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  transition: transform 0.4s ease, filter 0.25s ease;
  z-index: 0;
}

.member-card.has-photo .member-portrait {
  background: var(--ink);
}

.member-card.has-photo:hover .member-photo {
  transform: scale(1.05);
  filter: grayscale(0.15) contrast(1.04);
}

.portrait-tag {
  position: absolute;
  left: 14px;
  top: 14px;
  z-index: 2;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 8px;
  background: rgba(250, 250, 247, 0.92);
  border: 1px solid var(--line-soft);
  color: var(--ink);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.member-meta {
  padding: 22px 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.member-name {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.118rem;
  letter-spacing: -0.01em;
  line-height: 1.18;
  margin: 0;
}

.member-role {
  font-size: 0.765rem;
  line-height: 1.45;
  color: var(--ink-3);
  margin: 0;
  transition: color 0.2s;
  flex: 1;
}

.member-cta {
  margin-top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
  transition: color 0.2s;
}
.member-cta svg {
  transition: transform 0.2s;
}

.team-divider {
  padding: clamp(2.353rem, 5vw, 4.235rem) 0;
  background: var(--paper);
}
.team-divider .container {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: center;
}
.team-divider .divider-rule {
  height: 1px;
  background: var(--line-soft);
}
.team-divider .divider-label {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-3);
  white-space: nowrap;
}

.member-hero {
  padding: 0;
  position: relative;
  overflow: hidden;
  background: var(--paper);
}

.member-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
  gap: clamp(1.882rem, 5vw, 5.647rem);
  align-items: start;
}
@media (max-width: 900px) {
  .member-hero-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

.photo-stage {
  position: relative;
  overflow: hidden;
  background: var(--ink);
  aspect-ratio: 4/5;
  width: 100%;
  margin-top: clamp(2.824rem, 6vw, 5.647rem);
}
.photo-stage:hover .photo-stage-img {
  transform: scale(1.03);
}

.photo-stage-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 32%;
  position: absolute;
  inset: 0;
  transition: transform 0.9s cubic-bezier(0.2, 0.7, 0.2, 1);
  will-change: transform;
}

.photo-stage-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 60%, rgba(0, 0, 0, 0.25) 100%);
}

.photo-stage-edition,
.photo-stage-credit {
  position: absolute;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  z-index: 3;
  padding: 6px 10px;
  background: rgba(0, 0, 0, 0.42);
  backdrop-filter: blur(8px);
}

.photo-stage-edition {
  top: 28px;
  left: 28px;
}

.photo-stage-credit {
  bottom: 28px;
  right: 28px;
  opacity: 0.75;
  background: transparent;
  padding: 0;
}

.member-hero-info {
  position: relative;
  z-index: 5;
  align-self: center;
  padding: clamp(2.824rem, 6vw, 5.647rem) 0;
}
@media (max-width: 900px) {
  .member-hero-info {
    padding: clamp(1.882rem, 5vw, 3.765rem) 0;
  }
}
.member-hero-info .hero-eyebrow {
  margin-bottom: 0;
}

.member-title .given {
  color: var(--ink);
  display: inline-block;
}
.member-title .surname {
  color: var(--red);
  display: inline-block;
}
.member-title .dash {
  color: var(--ink);
  font-weight: 400;
}

.member-role-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.706rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 32px;
}
.member-role-pill .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
  flex-shrink: 0;
}

.contact-list {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
  border-top: 1px solid var(--line-soft);
}
.contact-list li {
  display: grid;
  grid-template-columns: 140px 1fr;
  align-items: baseline;
  padding: 18px 0;
  border-bottom: 1px solid var(--line-soft);
  gap: 16px;
}
@media (max-width: 540px) {
  .contact-list li {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}
.contact-list .lbl {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.contact-list a,
.contact-list .val {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 600;
  font-size: 1rem;
  color: var(--ink);
  text-decoration: none;
  transition: color 0.15s;
}
.contact-list a:hover {
  color: var(--red);
}

.hero-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.member-stats {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(2.353rem, 5vw, 4.235rem) 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1.176rem, 3vw, 2.824rem);
}
@media (max-width: 900px) {
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px;
  }
}

.stat-num {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(2.824rem, 6vw, 5.176rem);
  letter-spacing: -0.03em;
  line-height: 0.95;
  color: #fff;
  margin-bottom: 12px;
}

.stat:nth-child(odd) .stat-num {
  color: var(--red);
}

.stat-lbl {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.55;
}

.member-bio {
  padding: clamp(3.294rem, 7vw, 6.588rem) 0;
  background: var(--paper);
}

.bio-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.6fr;
  gap: clamp(1.882rem, 5vw, 5.647rem);
  align-items: start;
}
@media (max-width: 900px) {
  .bio-grid {
    grid-template-columns: 1fr;
  }
}

.bio-aside {
  position: sticky;
  top: 100px;
}
@media (max-width: 900px) {
  .bio-aside {
    position: static;
  }
}

.bio-h {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(2.118rem, 4.5vw, 3.765rem);
  letter-spacing: -0.025em;
  line-height: 0.95;
  text-transform: uppercase;
  margin: 14px 0 24px;
}

.bio-pull {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 500;
  font-style: italic;
  font-size: clamp(1rem, 1.4vw, 1.235rem);
  line-height: 1.4;
  color: var(--ink-2);
  border-left: 3px solid var(--red);
  padding-left: 18px;
  margin: 0;
}

.bio-body p {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 18px;
  max-width: 70ch;
}
.bio-body strong {
  color: var(--ink);
  font-weight: 700;
}
.bio-body em {
  font-style: italic;
  color: var(--ink);
}

.bio-sub {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 0.765rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 36px 0 14px;
  padding-top: 24px;
  border-top: 1px solid var(--line-soft);
  display: flex;
  align-items: center;
  gap: 12px;
}
.bio-sub::before {
  content: "";
  width: 18px;
  height: 1px;
  background: var(--red);
  flex-shrink: 0;
}

.bio-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.bio-list li {
  padding: 12px 0 12px 28px;
  border-bottom: 1px dashed var(--line-soft);
  color: var(--ink-2);
  font-size: 0.882rem;
  line-height: 1.5;
  position: relative;
}
.bio-list li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 12px;
  color: var(--red);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-weight: 700;
}
.bio-list li:last-child {
  border-bottom: 0;
}

.related-people {
  background: var(--paper-2);
  border-top: 1px solid var(--line-soft);
  padding: clamp(3.294rem, 6vw, 5.647rem) 0;
}
.related-people .team-grid {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 760px) {
  .related-people .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 480px) {
  .related-people .team-grid {
    grid-template-columns: 1fr;
  }
}

.related-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: clamp(1.647rem, 3vw, 2.824rem);
}
.related-head .section-title {
  margin: 0;
}

.related-all {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.related-all svg {
  transition: transform 0.2s;
}
.related-all:hover {
  background: var(--ink);
  color: #fff;
}
.related-all:hover svg {
  transform: translateX(3px);
}

.staff-list {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0;
}
.staff-list__item {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--line-soft);
}
.staff-list__item:first-child {
  border-top: 1px solid var(--line-soft);
}
.staff-list__link {
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
}
.staff-list__link:hover {
  color: var(--red);
}
.staff-list__role {
  color: var(--ink-3);
  font-size: 0.9rem;
}

@media (max-width: 600px) {
  .photo-stage {
    aspect-ratio: unset;
    height: clamp(12.941rem, 56vw, 18.824rem);
  }
}
@media (max-width: 480px) {
  .member-title {
    font-size: clamp(1.882rem, 9vw, 2.824rem);
    word-break: break-word;
  }
}
.news-tabs {
  display: flex;
  gap: 6px;
  align-items: center;
  border-bottom: 1px solid var(--line-soft);
  overflow-x: auto;
  scrollbar-width: none;
  padding-bottom: 0;
  margin-bottom: 32px;
}

.news-tabs::-webkit-scrollbar {
  display: none;
}

.news-tab {
  background: transparent;
  border: none;
  padding: 12px 18px;
  font-family: "Strawford", sans-serif;
  font-size: 0.824rem;
  font-weight: 600;
  color: var(--ink-3);
  cursor: pointer;
  position: relative;
  transition: color 0.15s;
  white-space: nowrap;
  text-decoration: none;
}
.news-tab .count {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  letter-spacing: 0.05em;
  margin-left: 6px;
}

.news-tab:hover {
  color: var(--ink);
}

.news-tab.active {
  color: var(--ink);
}
.news-tab.active::after {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: -1px;
  height: 2px;
  background: var(--red);
}

.news-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  border-right: 1px solid var(--line-soft);
  border-top: 1px solid var(--line-soft);
  border-left: 1px solid var(--line-soft);
}
@media (max-width: 960px) {
  .news-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 600px) {
  .news-grid {
    grid-template-columns: 1fr;
  }
}

.news-card {
  padding: 0;
  background: var(--paper);
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
  cursor: pointer;
  position: relative;
  transition: background 0.15s;
}
.news-card:hover {
  background: var(--paper-2);
}
.news-card.featured {
  grid-row: span 2;
}
@media (max-width: 960px) {
  .news-card.featured {
    grid-row: auto;
    grid-column: span 2;
  }
}
@media (max-width: 600px) {
  .news-card.featured {
    grid-column: auto;
  }
}
.news-card.featured .news-title {
  font-size: 1.882rem;
  line-height: 1.05;
}

.news-cover {
  aspect-ratio: 16/10;
  background: var(--paper-3);
  position: relative;
  overflow: hidden;
  background-image: repeating-linear-gradient(45deg, #e7e2d8 0 2px, transparent 2px 16px);
}
.news-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.news-cover a {
  display: block;
  width: 100%;
  height: 100%;
}
.news-cover .placeholder-label {
  position: absolute;
  bottom: 12px;
  left: 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.8);
  color: var(--ink);
  padding: 4px 8px;
  border-radius: 4px;
}
.news-cover.alt-1 {
  background-color: #1a1a1a;
  background-image: repeating-linear-gradient(45deg, #1f1f1f 0 2px, transparent 2px 16px);
}
.news-cover.alt-1 .placeholder-label {
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
}
.news-cover.alt-2 {
  background-color: var(--red);
  background-image: repeating-linear-gradient(135deg, #d92829 0 2px, transparent 2px 16px);
}
.news-cover.alt-2 .placeholder-label {
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
}
.news-cover.alt-3 {
  background-color: #f1ece4;
  background-image: none;
}

.news-body {
  padding: 24px 24px 28px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.news-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  margin-bottom: 14px;
}

.news-tag {
  padding: 4px 10px;
  background: var(--ink);
  color: #fff;
  font-size: 0.588rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  text-decoration: none;
}
.news-tag.red {
  background: var(--red);
}
.news-tag.outline {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
}
.news-tag:hover {
  opacity: 0.85;
}

.news-title {
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 1.176rem;
  line-height: 1.2;
  color: var(--ink);
  margin: 0 0 10px;
}
.news-title a {
  color: inherit;
  text-decoration: none;
}
.news-title a:hover {
  text-decoration: underline;
}

.news-excerpt {
  color: var(--ink-3);
  font-size: 0.824rem;
  line-height: 1.5;
  flex: 1;
}

.news-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line-soft);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  color: var(--ink-3);
}
.news-footer .read {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ink);
  font-weight: 700;
  text-decoration: none;
}
.news-footer .read:hover {
  color: var(--red);
}

.news-pagination {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 40px;
  flex-wrap: wrap;
}

.pagination-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--line-soft);
  color: var(--ink-3);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}
.pagination-btn:hover {
  background: var(--paper-2);
  color: var(--ink);
}

.pagination-page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 8px;
  border: 1px solid var(--line-soft);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.765rem;
  color: var(--ink-3);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}
.pagination-page:hover {
  background: var(--paper-2);
  color: var(--ink);
}
.pagination-page.active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
  font-weight: 700;
  pointer-events: none;
}

.pagination-info {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  color: var(--ink-4);
  letter-spacing: 0.05em;
  margin-left: 8px;
}

.no-articles {
  color: var(--ink-3);
  font-size: 0.941rem;
  padding: 32px 0;
}

.news-filter-label {
  font-size: 0.824rem;
  color: var(--ink-3);
  margin: 0 0 16px;
}
.news-filter-label strong {
  color: var(--ink);
}
.news-filter-label .news-filter-clear {
  margin-left: 8px;
  color: var(--ink-3);
  text-decoration: none;
  font-size: 0.706rem;
  border: 1px solid var(--ink-4);
  border-radius: 4px;
  padding: 1px 6px;
}
.news-filter-label .news-filter-clear:hover {
  color: var(--red);
  border-color: var(--red);
}

.article-detail, .material-detail {
  padding-bottom: clamp(3.765rem, 7vw, 7.059rem);
}
.article-detail > .container, .material-detail > .container {
  padding-top: clamp(0.706rem, 1.5vw, 1.176rem);
}

.article-header {
  margin-bottom: clamp(1rem, 2vw, 1.882rem);
}

.article-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.706rem;
  letter-spacing: 0.05em;
  color: var(--ink-3);
  text-decoration: none;
  margin-bottom: 28px;
}
.article-back:hover {
  color: var(--ink);
}

.article-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  letter-spacing: 0.04em;
  color: var(--ink-3);
  margin-bottom: 20px;
}

.article-date {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.824rem;
  color: var(--ink-2);
  margin-left: auto;
}

.article-location {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.824rem;
  color: var(--ink-2);
}

.article-title {
  margin: 40px 0 auto;
}

.article-lead {
  font-size: 1.059rem;
  line-height: 1.55;
  color: var(--ink-2);
  font-weight: 400;
  margin: 0;
}

.article-cover {
  margin-bottom: clamp(1.882rem, 4vw, 3.294rem);
  border: 1px solid var(--line-soft);
  overflow: hidden;
  aspect-ratio: 2050/1000;
}
.article-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.article-body {
  margin-bottom: clamp(1.882rem, 4vw, 3.294rem);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink-2);
}
.article-body h2, .article-body h3, .article-body h4 {
  font-family: "Strawford", sans-serif;
  color: var(--ink);
  margin-top: 2em;
  margin-bottom: 0.5em;
}
.article-body h2 {
  font-size: 1.529rem;
}
.article-body h3 {
  font-size: 1.235rem;
}
.article-body p {
  margin: 0 0 1.2em;
}
.article-body ul, .article-body ol {
  margin: 0 0 1.2em 1.6em;
}
.article-body a {
  color: var(--red);
  text-decoration: underline;
}
.article-body a:hover {
  text-decoration: none;
}
.article-body img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1.5em 0;
  border: 1px solid var(--line-soft);
}
.article-body blockquote {
  border-left: 3px solid var(--red);
  margin: 1.5em 0;
  padding: 0.5em 0 0.5em 1.2em;
  color: var(--ink-2);
  font-style: italic;
}

.article-blocks {
  max-width: 100%;
  margin-bottom: clamp(1.882rem, 4vw, 3.294rem);
}

.article-author {
  margin-bottom: 32px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.706rem;
  color: var(--ink-4);
  letter-spacing: 0.04em;
  padding-top: 24px;
  border-top: 1px solid var(--line-soft);
}

.article-footer {
  padding-top: 32px;
  border-top: 1px solid var(--line-soft);
}

.article-gallery {
  margin-bottom: clamp(1.882rem, 4vw, 3.294rem);
}
.article-gallery .gallery-heading {
  font-family: "Strawford", sans-serif;
  font-size: 1.294rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 20px;
}
.article-gallery .gallery-caption {
  font-size: 0.765rem;
  color: var(--ink-3);
  font-style: italic;
  margin: 12px 0 0;
}

.gallery-grid {
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
@media (min-width: 600px) {
  .gallery-grid.gallery-grid--1 {
    grid-template-columns: 1fr;
  }
  .gallery-grid.gallery-grid--2 {
    grid-template-columns: 1fr 1fr;
  }
  .gallery-grid.gallery-grid--3 {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .gallery-grid.gallery-grid--4 {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 800px) {
  .gallery-grid.gallery-grid--5, .gallery-grid.gallery-grid--6 {
    grid-template-columns: repeat(3, 1fr);
  }
  .gallery-grid.gallery-grid--7, .gallery-grid.gallery-grid--8, .gallery-grid.gallery-grid--9 {
    grid-template-columns: repeat(4, 1fr);
  }
}

.gallery-item {
  overflow: hidden;
  aspect-ratio: 1/1;
  background: var(--paper-3);
}
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.25s ease;
}
.gallery-item img:hover {
  transform: scale(1.04);
}

.article-video {
  margin-bottom: clamp(1.882rem, 4vw, 3.294rem);
}
.article-video .video-heading {
  font-family: "Strawford", sans-serif;
  font-size: 1.294rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 16px;
}
.article-video .video-caption {
  font-size: 0.765rem;
  color: var(--ink-3);
  font-style: italic;
  margin: 12px 0 0;
}

.video-embed {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  background: #000;
}
.video-embed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.article-richtext-block {
  margin-bottom: clamp(1.412rem, 3vw, 2.353rem);
}
.article-richtext-block .block-heading {
  font-family: "Strawford", sans-serif;
  font-size: 1.294rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 16px;
}
.article-richtext-block .rich-text {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink-2);
}

.file-badge {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: var(--red);
  color: #fff;
  white-space: nowrap;
}

.material-download {
  margin-bottom: clamp(1.412rem, 3vw, 2.353rem);
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  padding: 20px 0;
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
}

.article-downloads {
  margin-bottom: clamp(1.412rem, 3vw, 2.353rem);
  background: var(--paper-2);
  border: 1px solid var(--line-soft);
  padding: 24px 28px;
}
.article-downloads .downloads-heading {
  font-family: "Strawford", sans-serif;
  font-size: 1.059rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 8px;
}
.article-downloads .downloads-description {
  font-size: 0.824rem;
  color: var(--ink-3);
  margin: 0 0 16px;
}
.article-downloads .downloads-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.article-downloads .downloads-item {
  border-bottom: 1px solid var(--line-soft);
}
.article-downloads .downloads-item:last-child {
  border-bottom: 0;
}
.article-downloads .downloads-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  font-size: 0.882rem;
  color: var(--ink);
  text-decoration: none;
  font-weight: 500;
}
.article-downloads .downloads-link:hover {
  color: var(--red);
}

.homepage-timeline {
  background: var(--paper);
  padding: clamp(3.765rem, 7vw, 7.059rem) 0 clamp(2.824rem, 6vw, 5.647rem);
  border-bottom: 1px solid var(--line-soft);
}
.homepage-timeline .section-head {
  margin-bottom: clamp(2.118rem, 4vw, 3.294rem);
}

.timeline {
  position: relative;
  --tl-axis-w: 2px;
  --tl-day-size: 56px;
  padding: 0;
}

.tl-months {
  position: relative;
  padding: 56px 0;
}
.tl-months::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: var(--tl-axis-w);
  background: var(--ink);
  transform: translateX(-50%);
}
.tl-months::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 16px;
  height: 16px;
  border: 2px solid var(--ink);
  border-radius: 50%;
  background: var(--paper);
  transform: translate(-50%, -50%);
}

.tl-month {
  display: none;
}

.tl-month.is-active,
.tl-month:not([hidden]).is-active {
  display: block;
}

.tl-month:not([hidden]) {
  display: block;
}

.tl-month-head {
  display: flex;
  justify-content: center;
  position: relative;
  margin: -12px 0 36px;
  z-index: 2;
}

.tl-month-pill {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  padding: 14px 28px;
  background: var(--ink);
  color: #fff;
  border-radius: 999px;
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: 1.059rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: 0 12px 30px -12px rgba(0, 0, 0, 0.4);
}
.tl-month-pill .tl-month-year {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.765rem;
  color: var(--red);
  letter-spacing: 0.12em;
}

.tl-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(2.353rem, 4vw, 4.235rem);
}

.tl-entry {
  position: relative;
  display: grid;
  grid-template-columns: 1fr var(--tl-day-size) 1fr;
  align-items: start;
  column-gap: clamp(0.941rem, 2.5vw, 1.882rem);
  --connector-top: calc(var(--tl-day-size) / 2);
  --connector-span: clamp(0.941rem, 2.5vw, 1.882rem);
}
.tl-entry .tl-day {
  grid-column: 2;
  width: var(--tl-day-size);
  height: var(--tl-day-size);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--ink);
  color: #fff;
  font-family: "Strawford", sans-serif;
  font-weight: 800;
  font-size: 1.176rem;
  letter-spacing: -0.01em;
  position: relative;
  z-index: 2;
  box-shadow: 0 0 0 6px var(--paper);
}
.tl-entry .tl-card {
  background: var(--paper-2);
  border: 1px solid var(--line-soft);
  padding: 22px 24px;
  position: relative;
  transition: background 0.2s, transform 0.2s, border-color 0.2s;
}
.tl-entry .tl-card::before {
  content: "";
  position: absolute;
  top: var(--connector-top);
  width: var(--connector-span);
  height: 1px;
  background: var(--ink);
  opacity: 0.85;
}
.tl-entry .tl-card::after {
  content: "";
  position: absolute;
  top: calc(var(--connector-top) - 5px);
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  background: var(--paper-2);
  border-top: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
}
.tl-entry .tl-card:hover {
  background: #fff;
  border-color: var(--ink);
  transform: translateY(-2px);
}
.tl-entry .tl-card:hover::after {
  background: #fff;
}

.tl-entry--left .tl-card {
  grid-column: 1;
  text-align: right;
}
.tl-entry--left .tl-card::before {
  right: calc(-1 * var(--connector-span));
}
.tl-entry--left .tl-card::after {
  right: -6px;
  transform: rotate(45deg);
  border-top: none;
  border-left: none;
  border-bottom: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
}
.tl-entry--left .tl-more {
  flex-direction: row-reverse;
}
.tl-entry--left .tl-more svg {
  transform: rotate(180deg);
}

.tl-entry--right .tl-card {
  grid-column: 3;
  text-align: left;
}
.tl-entry--right .tl-card::before {
  left: calc(-1 * var(--connector-span));
}
.tl-entry--right .tl-card::after {
  left: -6px;
  transform: rotate(-135deg);
  border-top: 1px solid var(--line-soft);
  border-right: 1px solid var(--line-soft);
  border-bottom: none;
  border-left: none;
}

.tl-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.588rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 14px;
}
.tl-tag--red {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}

.tl-card-title {
  font-family: "Strawford", sans-serif;
  font-weight: 700;
  font-size: clamp(0.882rem, 1.1vw, 1rem);
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin: 0 0 10px;
  color: var(--ink);
}

.tl-card-text {
  font-size: 0.794rem;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 14px;
}

.tl-more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--red);
  text-decoration: none;
  transition: gap 0.2s;
}
.tl-more:hover {
  gap: 14px;
}

.tl-nav {
  position: relative;
  display: flex;
  justify-content: center;
  z-index: 3;
}
.tl-nav-top {
  margin-bottom: 0;
}
.tl-nav-bottom {
  margin-top: 0;
}

.tl-nav-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border: 1px solid var(--ink);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.706rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.15s;
}
.tl-nav-btn:hover {
  background: var(--ink);
  color: #fff;
  transform: translateY(-1px);
}
.tl-nav-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  background: var(--paper);
  color: var(--ink);
}
.tl-nav-btn:disabled:hover {
  background: var(--paper);
  color: var(--ink);
  transform: none;
}

.tl-loading {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 48px 0;
}
.tl-loading[hidden] {
  display: none;
}

.tl-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid var(--line-soft);
  border-top-color: var(--ink);
  border-radius: 50%;
  animation: tl-spin 0.7s linear infinite;
}

@keyframes tl-spin {
  to {
    transform: rotate(360deg);
  }
}
.tl-empty {
  text-align: center;
  color: var(--ink-3);
  font-size: 0.824rem;
  padding: 32px 0;
  list-style: none;
}

.tl-error {
  text-align: center;
  padding: 32px 0;
}
.tl-error p {
  color: var(--ink-2);
  font-size: 0.824rem;
  margin: 0 0 16px;
}

.tl-footnote {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--line-soft);
  font-family: "JetBrains Mono", monospace;
  font-size: 0.647rem;
  color: var(--ink-3);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.tl-footnote .tl-position {
  color: var(--ink);
  font-weight: 700;
  font-size: 0.706rem;
  white-space: nowrap;
}

.tl-axis-track {
  flex: 1;
  height: 2px;
  background: var(--line-soft);
  position: relative;
  border-radius: 1px;
  overflow: hidden;
}

.tl-axis-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: var(--red);
  width: 0%;
  transition: width 0.3s ease;
}

.tl-months--loading {
  opacity: 0.45;
  pointer-events: none;
  transition: opacity 0.15s;
}

@media (max-width: 760px) {
  .timeline {
    --tl-day-size: 44px;
  }
  .tl-months::before {
    left: 28px;
    transform: none;
  }
  .tl-months::after {
    left: 28px;
    transform: translate(-50%, -50%);
  }
  .tl-entry {
    grid-template-columns: var(--tl-day-size) 1fr;
    column-gap: 14px;
  }
  .tl-entry .tl-day {
    grid-column: 1;
    box-shadow: 0 0 0 4px var(--paper);
  }
  .tl-entry--left .tl-card,
  .tl-entry--right .tl-card {
    grid-column: 2;
    text-align: left;
  }
  .tl-entry--left .tl-card::before,
  .tl-entry--right .tl-card::before {
    left: calc(-1 * var(--connector-span));
    right: auto;
  }
  .tl-entry--left .tl-card::after,
  .tl-entry--right .tl-card::after {
    left: -6px;
    right: auto;
    transform: rotate(-135deg);
    border: 0;
    border-top: 1px solid var(--line-soft);
    border-right: 1px solid var(--line-soft);
  }
  .tl-entry--left .tl-more {
    flex-direction: row;
  }
  .tl-entry--left .tl-more svg {
    transform: none;
  }
  .tl-month-head {
    margin-left: -8px;
    justify-content: flex-start;
    padding-left: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .tl-spinner {
    animation: none;
    opacity: 0.5;
  }
  .tl-axis-fill {
    transition: none;
  }
  .tl-nav-btn,
  .tl-entry .tl-card,
  .tl-more {
    transition: none;
  }
}
.mod-section {
  padding: clamp(1.647rem, 3.5vw, 2.824rem) 0 clamp(3.294rem, 7vw, 5.647rem);
}

.mod-eyebrow {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.mod-eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--red);
  flex-shrink: 0;
}

.mod-title {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.647rem, 3.4vw, 2.706rem);
  letter-spacing: -0.03em;
  line-height: 0.98;
  text-transform: uppercase;
  margin: 0;
}
.mod-title .accent {
  color: var(--red);
}

.ph {
  background-color: var(--paper-3);
  background-image: repeating-linear-gradient(45deg, #ddd6c8 0 2px, transparent 2px 16px);
  position: relative;
  overflow: hidden;
}
.ph.dark {
  background-color: #1a1a1a;
  background-image: repeating-linear-gradient(45deg, #222 0 2px, transparent 2px 16px);
}
.ph.red {
  background-color: var(--red);
  background-image: repeating-linear-gradient(135deg, var(--red-deep) 0 2px, transparent 2px 18px);
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 999px;
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 0.882rem;
  cursor: pointer;
  transition: all 0.15s;
  border: 1.5px solid transparent;
  text-decoration: none;
}
.btn svg {
  width: 17px;
  height: 17px;
}

.btn-primary {
  background: var(--red);
  color: #fff;
}
.btn-primary:hover {
  background: var(--red-deep);
}

.btn-dark {
  background: var(--ink);
  color: #fff;
}
.btn-dark:hover {
  background: #000;
}

.btn-ghost-light {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.5);
}
.btn-ghost-light:hover {
  background: #fff;
  color: var(--ink);
  border-color: #fff;
}

.btn-outline {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn-outline:hover {
  background: var(--ink);
  color: #fff;
}

.btn-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.m-hero {
  position: relative;
  aspect-ratio: 2050/1000;
  min-height: 280px;
  display: flex;
  align-items: flex-end;
  color: #fff;
  overflow: hidden;
  background-color: #161616;
  background-image: repeating-linear-gradient(45deg, #1d1d1d 0 2px, transparent 2px 22px);
  background-size: cover;
  background-position: center;
}
.m-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.72), rgba(0, 0, 0, 0.12) 60%);
}
.m-hero .hero-inner {
  position: relative;
  z-index: 1;
  padding: 56px 0;
  width: 100%;
}
.m-hero .hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--red);
  color: #fff;
  border-radius: 999px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  padding: 6px 14px;
  margin-bottom: 20px;
}
.m-hero h2 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(2.353rem, 6.5vw, 5.412rem);
  letter-spacing: -0.04em;
  line-height: 0.92;
  text-transform: uppercase;
  margin: 0 0 18px;
  max-width: 14ch;
}
.m-hero p {
  font-size: clamp(0.882rem, 1.4vw, 1.118rem);
  max-width: 540px;
  color: rgba(255, 255, 255, 0.85);
  margin: 0 0 28px;
  line-height: 1.5;
}
.m-hero--cover {
  min-height: 400px;
  background-position: center top;
}
.m-hero--cover::after {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.35));
}

.rich img {
  max-width: 100%;
  height: auto;
  width: auto;
}
.rich h3 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: 1.529rem;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 32px 0 14px;
}
.rich h4 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.118rem;
  letter-spacing: -0.01em;
  margin: 24px 0 10px;
}
.rich p {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink-2);
  margin: 0 0 18px;
}
.rich a {
  color: var(--red);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.rich ul, .rich ol {
  margin: 0 0 20px;
  padding-left: 0;
}
.rich ul {
  list-style: none;
}
.rich ul li {
  position: relative;
  padding-left: 26px;
  margin-bottom: 10px;
  line-height: 1.6;
  color: var(--ink-2);
}
.rich ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 14px;
  height: 1px;
  background: var(--red);
}
.rich ol {
  padding-left: 22px;
}
.rich ol li {
  margin-bottom: 10px;
  line-height: 1.6;
  color: var(--ink-2);
}
.rich blockquote {
  margin: 28px 0;
  padding: 4px 0 4px 24px;
  border-left: 3px solid var(--red);
  font-style: italic;
  color: var(--ink);
  font-size: 1.118rem;
  line-height: 1.5;
}
.rich .lead-p {
  font-size: 1.235rem;
  line-height: 1.55;
  color: var(--ink);
  font-weight: 500;
}
.rich table {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-collapse: collapse;
  margin: 0 0 20px;
  font-size: 0.882rem;
}
.rich th, .rich td {
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line-soft);
}
.rich th {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.gallery-section {
  background: var(--paper-2);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  padding: clamp(3.294rem, 7vw, 5.647rem) 0;
}

.gallery-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  margin-bottom: 40px;
}
.gallery-head .left {
  flex: 1;
}

.gallery-meta {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.gallery-footer {
  margin-top: 32px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.video-wrap {
  position: relative;
  aspect-ratio: 16/9;
  background-color: #111;
  background-image: repeating-linear-gradient(45deg, #181818 0 2px, transparent 2px 22px);
  overflow: hidden;
}
.video-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

.video-caption {
  margin-top: 12px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.faq-list {
  border-top: 1px solid var(--ink);
}

.faq-item {
  border-bottom: 1px solid var(--line-soft);
}

.faq-q {
  width: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 24px 0;
  text-align: left;
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1rem, 1.8vw, 1.294rem);
  letter-spacing: -0.01em;
  color: var(--ink);
}
.faq-q .q-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border: 1.5px solid var(--ink);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}
.faq-q .q-icon svg {
  width: 14px;
  height: 14px;
  transition: transform 0.25s;
}

.faq-item.open .faq-q .q-icon {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}
.faq-item.open .faq-q .q-icon svg {
  transform: rotate(45deg);
}

.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.faq-a-inner {
  padding: 0 52px 24px 0;
  color: var(--ink-2);
  font-size: 0.941rem;
  line-height: 1.65;
}

.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.882rem, 5vw, 4.235rem);
  align-items: center;
}
.two-col.reverse .tc-media {
  order: 2;
}
.two-col .tc-media {
  aspect-ratio: 4/3;
  overflow: hidden;
}
.two-col .tc-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.two-col .tc-text p {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 18px;
}
@media (max-width: 800px) {
  .two-col {
    grid-template-columns: 1fr;
  }
  .two-col.reverse .tc-media {
    order: 0;
  }
}

.cta {
  background: var(--ink);
  color: #fff;
  padding: clamp(2.824rem, 6vw, 4.706rem) clamp(1.647rem, 5vw, 4.235rem);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.cta::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -10%;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: var(--red);
  opacity: 0.16;
  filter: blur(20px);
}
.cta .cta-content {
  position: relative;
  z-index: 1;
}
.cta .cta-content h2 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.647rem, 4vw, 3.059rem);
  letter-spacing: -0.03em;
  line-height: 0.98;
  text-transform: uppercase;
  margin: 0 0 14px;
}
.cta .cta-content p {
  color: rgba(255, 255, 255, 0.8);
  font-size: 1rem;
  line-height: 1.55;
  margin: 0;
  max-width: 460px;
}
.cta .cta-actions {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (max-width: 760px) {
  .cta {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .cta .cta-actions {
    flex-direction: row;
    flex-wrap: wrap;
  }
}

.feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-left: 1px solid var(--line-soft);
  border-top: 1px solid var(--line-soft);
}
@media (max-width: 820px) {
  .feature-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 520px) {
  .feature-grid {
    grid-template-columns: 1fr;
  }
}

.feature-cell {
  padding: 32px 28px;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background 0.2s;
}
.feature-cell:hover {
  background: var(--paper-2);
}
.feature-cell .f-icon {
  width: 52px;
  height: 52px;
  border: 1.5px solid var(--ink);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red);
  flex-shrink: 0;
}
.feature-cell .f-icon svg {
  width: 24px;
  height: 24px;
}
.feature-cell h3 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.176rem;
  letter-spacing: -0.01em;
  margin: 0;
}
.feature-cell p {
  font-size: 0.882rem;
  line-height: 1.55;
  color: var(--ink-3);
  margin: 0;
}
.feature-cell .f-num {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.14em;
  color: var(--ink-4);
  margin-top: auto;
}

.testi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-left: 1px solid var(--line-soft);
  border-top: 1px solid var(--line-soft);
}
@media (max-width: 720px) {
  .testi-grid {
    grid-template-columns: 1fr;
  }
}

.testi-cell {
  padding: 36px 32px;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.testi-cell .quote-mark {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: 3.294rem;
  line-height: 0.6;
  color: var(--red);
}
.testi-cell blockquote {
  margin: 0;
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 500;
  font-size: clamp(1.059rem, 1.8vw, 1.294rem);
  line-height: 1.4;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.testi-cell .testi-author {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: auto;
}
.testi-cell .testi-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
}
.testi-cell .ta-name {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 0.882rem;
}
.testi-cell .ta-role {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 2px;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.12);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}
@media (max-width: 720px) {
  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.stat-cell {
  padding: 36px 28px;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.stat-cell .stat-num {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(2.588rem, 5vw, 4rem);
  letter-spacing: -0.04em;
  line-height: 1;
  color: #fff;
}
.stat-cell .stat-num .suf {
  color: var(--red);
}
.stat-cell .stat-label {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  margin-top: 14px;
  line-height: 1.4;
}

.big-quote {
  max-width: 1000px;
}
.big-quote .bq-mark {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: 7.059rem;
  line-height: 0.5;
  color: var(--red);
  display: block;
  margin-bottom: 12px;
}
.big-quote blockquote {
  margin: 0 0 28px;
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: clamp(1.529rem, 4vw, 3.294rem);
  letter-spacing: -0.03em;
  line-height: 1.08;
  color: var(--ink);
}
.big-quote .bq-author {
  display: flex;
  align-items: center;
  gap: 16px;
}
.big-quote .bq-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
}
.big-quote .bq-name {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1rem;
}
.big-quote .bq-role {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 2px;
}

.timeline {
  position: relative;
  max-width: 860px;
}
.timeline::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 8px;
  bottom: 8px;
  width: 1.5px;
  background: var(--line-soft);
}

.tl-item {
  position: relative;
  padding: 0 0 36px 56px;
}
.tl-item:last-child {
  padding-bottom: 0;
}
.tl-item .tl-dot {
  position: absolute;
  left: 0;
  top: 2px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--paper);
  border: 1.5px solid var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
}
.tl-item.active .tl-dot {
  background: var(--red);
  border-color: var(--red);
}
.tl-item.active .tl-dot::after {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
}
.tl-item .tl-date {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--red);
  font-weight: 700;
  margin-bottom: 6px;
}
.tl-item h3 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.235rem;
  letter-spacing: -0.01em;
  margin: 0 0 8px;
}
.tl-item p {
  font-size: 0.882rem;
  line-height: 1.6;
  color: var(--ink-3);
  margin: 0;
  max-width: 560px;
}

.info-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-left: 1px solid var(--line-soft);
  border-top: 1px solid var(--line-soft);
}
@media (max-width: 720px) {
  .info-strip {
    grid-template-columns: 1fr;
  }
}

.info-item {
  padding: 30px 28px;
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.info-item .i-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--ink);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.info-item .i-icon svg {
  width: 20px;
  height: 20px;
}
.info-item .i-label {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-top: 6px;
}
.info-item .i-value {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.059rem;
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.info-item .i-value a:hover {
  color: var(--red);
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-left: 1px solid var(--line-soft);
  border-top: 1px solid var(--line-soft);
}
.cards-grid.cards-grid--2 {
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 820px) {
  .cards-grid {
    grid-template-columns: 1fr 1fr;
  }
  .cards-grid.cards-grid--2 {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 540px) {
  .cards-grid {
    grid-template-columns: 1fr;
  }
}

.card-cell {
  background: var(--paper);
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  transition: background 0.2s;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.card-cell:hover {
  background: var(--paper-2);
}
.card-cell .card-media {
  aspect-ratio: 16/10;
  overflow: hidden;
}
.card-cell .card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card-cell .card-body {
  padding: 22px 22px 26px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.card-cell .card-cat {
  display: inline-flex;
  align-self: flex-start;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  background: var(--red);
  color: #fff;
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 12px;
}
.card-cell h3 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 700;
  font-size: 1.118rem;
  letter-spacing: -0.015em;
  line-height: 1.2;
  margin: 0 0 10px;
}
.card-cell p {
  font-size: 0.824rem;
  line-height: 1.5;
  color: var(--ink-3);
  margin: 0;
  flex: 1;
}
.card-cell .card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--line-soft);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.card-cell .card-foot svg {
  width: 14px;
  height: 14px;
}

.banner {
  background: var(--red);
  color: #fff;
  padding: clamp(1.647rem, 4vw, 2.588rem) clamp(1.647rem, 5vw, 3.294rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;
}
.banner .banner-text {
  display: flex;
  align-items: center;
  gap: 20px;
}
.banner .banner-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.banner .banner-icon svg {
  width: 26px;
  height: 26px;
}
.banner h3 {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.176rem, 2.4vw, 1.765rem);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
  text-transform: uppercase;
}
.banner p {
  margin: 4px 0 0;
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.882rem;
}

.file-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--line-soft);
}

.file-item {
  border-bottom: 1px solid var(--line-soft);
}

.file-link {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 0;
  color: var(--ink);
  text-decoration: none;
  transition: color 0.15s;
}
.file-link:hover {
  color: var(--red);
}
.file-link .file-ext {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--ink);
  color: #fff;
  padding: 3px 8px;
  border-radius: 4px;
  flex-shrink: 0;
}
.file-link:hover .file-ext {
  background: var(--red);
}
.file-link .file-name {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 600;
  font-size: 0.941rem;
  flex: 1;
}
.file-link svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: 0.5;
}

.lightbox-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.92);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.2s ease;
}
@media (prefers-reduced-motion: reduce) {
  .lightbox-overlay {
    transition: none;
  }
}

.lightbox-img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  display: block;
}

.lightbox-close,
.lightbox-prev,
.lightbox-next {
  position: absolute;
  background: transparent;
  border: 1.5px solid rgba(255, 255, 255, 0.4);
  color: #fff;
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  z-index: 1001;
}
.lightbox-close svg,
.lightbox-prev svg,
.lightbox-next svg {
  width: 20px;
  height: 20px;
  display: block;
}
.lightbox-close:hover,
.lightbox-prev:hover,
.lightbox-next:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: #fff;
}
.lightbox-close:disabled,
.lightbox-prev:disabled,
.lightbox-next:disabled {
  opacity: 0.3;
  cursor: not-allowed;
  pointer-events: none;
}

.lightbox-close {
  top: 20px;
  right: 20px;
}

.lightbox-prev {
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.lightbox-next {
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.gallery-cell {
  cursor: pointer;
  aspect-ratio: 1/1;
  overflow: hidden;
  position: relative;
}
.gallery-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gallery-cell .num {
  position: absolute;
  bottom: 6px;
  left: 8px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.529rem;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.7);
  pointer-events: none;
}

.gallery-grid--pub {
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 600px) {
  .gallery-grid--pub {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 380px) {
  .gallery-grid--pub {
    grid-template-columns: 1fr;
  }
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 22px;
}
.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--red);
}

.page-title .accent {
  color: var(--red);
}

.page-lede {
  font-size: clamp(1rem, 1.5vw, 1.235rem);
  color: var(--ink-2);
  line-height: 1.6;
  max-width: 600px;
  margin: 0;
}

section.primary {
  padding-top: clamp(2.824rem, 6vw, 5.176rem);
  padding-bottom: clamp(2.824rem, 6vw, 5.176rem);
}

.primary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--ink);
}
@media (max-width: 760px) {
  .primary-grid {
    grid-template-columns: 1fr;
  }
}

.pc-cell {
  padding: 32px 32px 36px 0;
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.pc-cell + .pc-cell {
  padding-left: clamp(1.412rem, 3vw, 2.824rem);
  border-left: 1px solid var(--line-soft);
}
@media (max-width: 760px) {
  .pc-cell {
    padding: 26px 0;
  }
  .pc-cell + .pc-cell {
    padding-left: 0;
    border-left: none;
  }
}

.pc-label {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-4);
}

.pc-value {
  font-family: "Strawford", system-ui, sans-serif;
  font-size: clamp(1.176rem, 1.8vw, 1.529rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--ink);
  text-decoration: none;
}
.pc-value.sm {
  font-size: 1.059rem;
  font-weight: 500;
  line-height: 1.45;
}
.pc-value:is(a) {
  transition: color 0.15s;
  word-break: break-word;
}
.pc-value:is(a):hover {
  color: var(--red);
}

.pc-sub {
  font-size: 0.824rem;
  color: var(--ink-3);
  line-height: 1.5;
}

section.people {
  padding-top: 0;
  padding-bottom: clamp(4.235rem, 9vw, 7.529rem);
}

.people-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.people-count {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.647rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-4);
}

.people-list {
  margin-top: 40px;
  border-top: 1px solid var(--ink);
}

.person {
  display: grid;
  grid-template-columns: 56px minmax(0, 1.1fr) minmax(0, 1fr);
  align-items: center;
  gap: 24px;
  padding: 26px 8px;
  border-bottom: 1px solid var(--line-soft);
  transition: background 0.18s, padding-left 0.18s;
}
.person:hover {
  background: var(--paper-2);
  padding-left: 18px;
}
.person .idx {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.706rem;
  color: var(--ink-4);
  letter-spacing: 0.08em;
}
.person .who {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.person .role {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--red);
  font-weight: 700;
  line-height: 1.4;
}
.person .name {
  font-family: "Strawford", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(1.294rem, 2.2vw, 1.765rem);
  letter-spacing: -0.02em;
  line-height: 1.04;
}
.person .contacts {
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-self: start;
}
.person .contacts a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.941rem;
  color: var(--ink-2);
  text-decoration: none;
  transition: color 0.15s;
  word-break: break-all;
}
.person .contacts a:hover {
  color: var(--red);
}
.person .contacts a:hover svg {
  color: var(--red);
}
.person .contacts svg {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
  color: var(--ink-4);
  transition: color 0.15s;
}
@media (max-width: 720px) {
  .person {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 24px 0;
  }
  .person:hover {
    padding-left: 0;
  }
  .person .idx {
    order: -1;
  }
}

.text-red {
  color: var(--red);
}

.breadcrumbs {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.588rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-4);
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.breadcrumbs a {
  color: var(--ink-4);
  text-decoration: none;
  transition: color 0.15s;
}
.breadcrumbs a:hover {
  color: var(--red);
}
.breadcrumbs .sep {
  color: var(--ink-4);
  opacity: 0.5;
}
.breadcrumbs .current {
  color: var(--ink-3);
  font-weight: 600;
}

.breadcrumb {
  background: var(--paper);
}
.breadcrumb .container {
  display: flex;
  align-items: center;
  padding-top: 10px;
  padding-bottom: 10px;
}
