@charset "UTF-8";
:root {
  --font1: Inter Tight, sans-serif;
  --font2: Cormorant Garamond, serif;
  --font-code: JetBrains Mono, sans-serif;
  --f1: 45px;
  --g1: 71px;
  --f2: 35px;
  --g2: 56px;
  --f3: 28px;
  --g3: 46px;
  --f4: 22px;
  --g4: 37px;
  --f5: 17px;
  --g5: 30px;
  --f6: 13px;
  --g6: 24px;
  --x1: 49px;
  --x2: 30px;
  --x3: 19px;
  --x4: 12px;
  --x5: 7px;
  --x6: 4px;
  --phi: 1.6180339887;
  --w-content: 680px;
  --w-total: 1280px;
  --bg1: rgb(247, 241, 230);
  --bg2: rgb(236, 223, 202);
  --c1: rgb(35, 25, 20);
  --c2: rgb(123, 111, 100);
  --ca: rgb(168, 66, 31);
  --border1: 1px solid #d4c5ad;
  --border2: 2px solid #a8421f;
  --border3: 1px solid #b8a482;
  --gutter-full: 49px;
  --gutter-mobile: 19px;
  --bg-header: rgba(247, 241, 230, 0.92);
  --c-header: #231914;
  --p-header-top: 16px;
  --p-header-bottom: 16px;
  --bg-content: #f7f1e6;
  --c-content: #3a342f;
  --p-content-top: var(--x1);
  --p-content-bottom: var(--x1);
  --bg-footer: #231914;
  --c-footer: #f7f1e6;
  --p-footer-top: var(--x1);
  --p-footer-bottom: var(--x6);
  --font-footer: var(--font1);
  --f-footer: 16px;
  --g-footer: 26px;
  --font-title: var(--font2);
  --f-title: 19px;
  --g-title: 20px;
  --c-title: #231914;
  --font-menu: var(--font1);
  --f-menu: 16px;
  --g-menu: var(--g5);
  --c-menu: #231914;
  --p-menu-top: var(--x5);
  --p-menu-bottom: var(--x5);
  --m-menu-spacing: var(--x3);
  --font-headline: var(--font2);
  --font-byline: var(--font1);
  --f-byline: 13px;
  --g-byline: 24px;
  --c-byline: #7b6f64;
  --font-heading: var(--font2);
  --font-drop-cap: var(--font2);
  --c-drop-cap: #a8421f;
  --font-caption: var(--font1);
  --c-caption: #7b6f64;
  --m-caption: var(--x5);
  --m-caption-h2-m: var(--x5);
  --m-caption-h3: var(--x5);
  --m-caption-h3-m: var(--x5);
  --list-style: disc;
  --list-margin: var(--x3);
  --list-item-margin: var(--x5);
  --list-nested-margin: var(--x3);
  --font-blockquote: var(--font2);
  --f-blockquote: 24px;
  --g-blockquote: 35px;
  --bg-blockquote: transparent;
  --c-blockquote: #231914;
  --font-impact: var(--font2);
  --c-impact: #382b22;
  --g-impact-f3: var(--g3);
  --g-impact-f4: var(--g4);
  --bg-highlight: #ecdfca;
  --bg-callout: #ecdfca;
  --bg-callout-note: #f1e8d6;
  --bg-callout-alert: #f7e3d8;
  --c-callout: #231914;
  --c-callout-note: #231914;
  --c-callout-alert: #7d2f15;
  --p-callout: var(--x3);
  --bg-pre: #231914;
  --c-pre: #f7f1e6;
  --f5c: 15px;
  --f6c: 12px;
  --font-label: var(--font1);
  --c-required: #a8421f;
  --p-input: var(--x5) var(--x4);
  --b-input: var(--border3);
  --p-textarea: var(--x5) var(--x4);
  --b-textarea: var(--border3);
  --b-select: var(--border3);
  --bg-button: #a8421f;
  --bg-button-save: #3a7d54;
  --bg-button-delete: #7d2f15;
  --bg-button-action: transparent;
  --bg-button-update: transparent;
  --c-button: #f7f1e6;
  --c-button-save: #f7f1e6;
  --c-button-delete: #f7f1e6;
  --c-button-action: #231914;
  --c-button-update: #a8421f;
  --p-button-x: var(--x2);
  --p-button-y: var(--x4);
  --cream-soft: #f1e8d6;
  --terracotta-deep: #7d2f15;
  --terracotta-soft: #c9663f;
  --ochre: #c89545;
  --ochre-deep: #a5783a;
  --ink-soft: #382b22;
  --body: #3a342f;
  --white: #ffffff;
  --rule: #d4c5ad;
  --rule-strong: #b8a482;
  --transition-fast: 120ms ease;
  --transition: 220ms ease;
  --transition-slow: 420ms ease;
  --shadow-sm: 0 1px 2px rgba(35, 25, 20, 0.06);
  --shadow-md: 0 8px 24px rgba(35, 25, 20, 0.1);
  --shadow-lg: 0 24px 60px rgba(35, 25, 20, 0.14);
}

/* Reset */
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  word-break: normal;
}

img, fieldset {
  border: 0;
}

abbr {
  text-decoration: none;
}

img, picture, svg, video {
  max-width: 100%;
  height: auto;
  display: block;
}

iframe, embed, object {
  display: block;
  max-width: 100%;
}

.center {
  display: block;
  float: none;
  text-align: center;
  margin-right: auto;
  margin-left: auto;
}

button, input[type=submit] {
  cursor: pointer;
  overflow: visible;
}

/* Body and structural foundations */
body {
  font-family: var(--font1);
  font-size: var(--f5);
  line-height: var(--g5);
  color: var(--body);
  background-color: var(--bg1);
  font-feature-settings: "ss01", "cv11";
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

::selection {
  background: var(--ca);
  color: var(--bg1);
}

:focus-visible {
  outline: 3px solid var(--ochre);
  outline-offset: 3px;
}

.section {
  padding-block: clamp(var(--x1) * 1.3, 8vw, var(--x1) * var(--phi));
}

.section--tight {
  padding-block: clamp(var(--x1), 5vw, var(--x1) * 1.6);
}

.section--cream-deep {
  background: var(--bg2);
}

.section--cream-soft {
  background: var(--cream-soft);
}

.section--ink {
  background: var(--c1);
  color: var(--bg1);
}
.section--ink h1, .section--ink h2, .section--ink h3, .section--ink h4 {
  color: var(--bg1);
}
.section--ink a {
  color: var(--ochre);
  text-decoration-color: rgba(200, 149, 69, 0.4);
}
.section--ink a:hover {
  color: #e0b870;
}

.container {
  box-sizing: border-box;
  width: 100%;
  max-width: var(--w-total);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gutter-mobile);
  padding-right: var(--gutter-mobile);
}
@media all and (min-width: 778px) {
  .container {
    padding-left: var(--gutter-full);
    padding-right: var(--gutter-full);
  }
}

.container--narrow {
  max-width: calc(var(--w-content) * var(--phi));
}

.text {
  max-width: var(--w-content);
}

/* Common content elements */
h1, h2, h3, h4 {
  font-family: var(--font2);
  font-weight: 400;
  color: var(--c1);
  letter-spacing: -0.005em;
}

h1 {
  font-size: clamp(2.5rem, 1.5rem + 4vw, 5rem);
  line-height: 1.08;
  letter-spacing: -0.02em;
}

h2 {
  font-size: clamp(2rem, 1.4rem + 2.5vw, 3.25rem);
  line-height: 1.08;
  letter-spacing: -0.015em;
}

h3 {
  font-size: var(--f3);
  line-height: var(--g3);
}

h4 {
  font-size: var(--f4);
  line-height: var(--g4);
  font-weight: 500;
}

a {
  color: var(--ca);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: rgba(168, 66, 31, 0.4);
  transition: color var(--transition-fast), text-decoration-color var(--transition-fast);
}
a:hover {
  color: var(--terracotta-deep);
  text-decoration-color: currentColor;
}

strong {
  font-weight: 600;
  color: var(--c1);
}

em {
  font-style: italic;
}

blockquote {
  font-family: var(--font-blockquote);
  font-size: var(--f-blockquote);
  line-height: var(--g-blockquote);
  font-style: italic;
  color: var(--c-blockquote);
  background-color: var(--bg-blockquote);
  border-left: var(--border2);
  padding-left: var(--x3);
}
blockquote > :last-child {
  margin-bottom: 0;
}

sub, sup {
  color: var(--c2);
  line-height: 0.5em;
}

code, pre, kbd {
  font-family: var(--font-code);
  font-size: var(--f5c);
  line-height: var(--g5);
}

code {
  line-height: 1em;
  background-color: rgba(35, 25, 20, 0.08);
  padding: var(--x5);
  border-radius: var(--x5);
  margin: 0 1px;
}
strong code {
  font-weight: normal;
}

pre {
  overflow: auto;
  word-wrap: normal;
  tab-size: 4;
  color: var(--c-pre);
  background-color: var(--bg-pre);
  padding: var(--x3);
  border-radius: 0 var(--x4) var(--x4) 0;
}

hr {
  border: var(--border1);
  border-width: 0 0 1px 0;
  margin: var(--x2) 0;
}

.drop-cap {
  font-family: var(--font-drop-cap);
  font-size: var(--f1);
  line-height: 1em;
  color: var(--c-drop-cap);
  margin-right: var(--x5);
  float: left;
}

.small {
  font-family: var(--font-caption);
  font-size: var(--f6);
  line-height: var(--g6);
  color: var(--c-caption);
}

.callout {
  color: var(--c-callout);
  background-color: var(--bg-callout);
  padding: var(--p-callout);
  border-left: var(--border2);
  border-radius: 0 var(--x4) var(--x4) 0;
}
.callout.alert {
  color: var(--c-callout-alert);
  background-color: var(--bg-callout-alert);
  border-left-color: var(--ca);
}
.callout.note {
  color: var(--c-callout-note);
  background-color: var(--bg-callout-note);
  border-left-color: var(--ochre);
}

.highlight {
  background-color: var(--bg-highlight);
  padding: var(--x6) 0;
}

.impact {
  font-family: var(--font-impact);
  font-size: var(--f4);
  line-height: var(--g-impact-f4);
  font-weight: 300;
  color: var(--c-impact);
}

.pop {
  box-shadow: 0 0 var(--x4) rgba(35, 25, 20, 0.4);
}

.caption {
  font-family: var(--font-caption);
  font-size: var(--f6);
  line-height: var(--g6);
  color: var(--c-caption);
}
.caption code {
  font-size: var(--f6c);
  line-height: var(--g6);
}
.center + .caption {
  text-align: center;
}
blockquote + .caption {
  padding-left: calc(var(--x3) + var(--x5));
}

@media all and (min-width: 718px) {
  h3 {
    font-size: var(--f2);
    line-height: var(--g2);
  }
  h4 {
    font-size: var(--f3);
    line-height: var(--g3);
  }
  .impact {
    font-size: var(--f3);
    line-height: var(--g-impact-f3);
  }
  .left:not(.bar) {
    float: left;
    clear: both;
    margin-right: var(--x2);
  }
  .right:not(.bar) {
    float: right;
    clear: both;
    margin-left: var(--x2);
  }
}
/* Dynamic page content */
.page-container + .page-container {
  margin-top: var(--x1);
}

.page-content {
  word-break: break-word;
  max-width: var(--w-content);
}
.page-content h1 {
  font-size: var(--f2);
  line-height: var(--g2);
  margin-bottom: var(--x2);
}
.page-content h2 {
  font-size: var(--f3);
  line-height: var(--g3);
  margin-top: var(--x1);
  margin-bottom: var(--x2);
}
.page-content h3 {
  margin-top: var(--x2);
  margin-bottom: var(--x3);
}
.page-content h4 {
  margin-bottom: var(--x4);
}
.page-content h1 + h2, .page-content h2 + h3, .page-content h1:first-child, .page-content h2:first-child, .page-content h3:first-child, .page-content hr + h2 {
  margin-top: 0;
}
.page-content > :last-child {
  margin-bottom: 0;
}
.page-content ul {
  list-style-type: var(--list-style);
}
.page-content ul, .page-content ol {
  margin-left: var(--list-margin);
}
.page-content ul ul, .page-content ul ol, .page-content ol ul, .page-content ol ol {
  margin-top: var(--list-item-margin);
  margin-bottom: 0;
  margin-left: var(--list-nested-margin);
}
.page-content li {
  margin-bottom: var(--list-item-margin);
}
.page-content li:last-child {
  margin-bottom: 0;
}
.page-content .callout > :last-child {
  margin-bottom: 0;
}
.page-content .caption {
  margin-top: var(--m-caption);
}
h1 + .page-content .caption, h2 + .page-content .caption {
  margin-top: var(--m-caption-h2-m);
}
h3 + .page-content .caption {
  margin-top: var(--m-caption-h3-m);
  margin-bottom: var(--x3);
}
.page-content p, .page-content ul, .page-content ol, .page-content blockquote, .page-content pre, .page-content img, .page-content .callout, .page-content .caption {
  margin-bottom: var(--x2);
}
.page-content p:last-child, .page-content ul:last-child, .page-content ol:last-child, .page-content blockquote:last-child, .page-content pre:last-child, .page-content img:last-child, .page-content .callout:last-child, .page-content .caption:last-child {
  margin-bottom: 0;
}
@media all and (min-width: 718px) {
  .page-content h1 + .caption, .page-content h2 + .caption {
    margin-top: var(--m-caption);
  }
  .page-content h3 + .caption {
    margin-top: var(--m-caption-h3);
  }
}

.page-title {
  font-family: var(--font-headline);
}
.page-title a {
  color: var(--c1);
}
.page-title a:hover {
  color: var(--ca);
}

.page-title:has(+ .byline) {
  margin-bottom: 0;
}

.byline {
  font-family: var(--font-byline);
  font-size: var(--f-byline);
  line-height: var(--g-byline);
  color: var(--c-byline);
  margin-bottom: var(--x2);
}

.page-author {
  font-weight: 600;
  color: var(--c1);
}

.page-date {
  color: var(--c2);
}

.page-container, .headline-area, .page-content {
  display: flow-root;
}

.page-content + .modular-content {
  margin-top: var(--x2);
}
.modular-content > :last-child {
  margin-bottom: 0;
}

/* Forms */
label {
  display: block;
  font-family: var(--font-label);
}
label .required {
  font-weight: normal;
  color: var(--c-required);
}

input, textarea, select {
  display: block;
  width: auto;
  max-width: 100%;
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
  line-height: 1em;
  font-weight: inherit;
  color: var(--c1);
  background: var(--white);
  padding: var(--p-input);
  border: var(--b-input);
  transition: border-color var(--transition-fast);
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--ca);
  box-shadow: 0 0 0 3px rgba(168, 66, 31, 0.15);
}

input[type=checkbox], input[type=radio], input[type=image], input[type=submit], select {
  width: auto;
}

input[type=checkbox], input[type=radio] {
  display: inline-block;
}
input[type=checkbox] + label, input[type=radio] + label {
  display: inline;
  font-weight: normal;
  margin-left: var(--x6);
  user-select: none;
}

textarea {
  line-height: inherit;
  resize: vertical;
  min-height: 140px;
}

button, input[type=submit], .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65em;
  width: auto;
  font-family: var(--font1);
  font-size: var(--f5);
  line-height: 1em;
  font-weight: 600;
  letter-spacing: 0.02em;
  vertical-align: top;
  color: var(--c-button);
  text-decoration: none;
  background-color: var(--bg-button);
  padding: var(--p-button-y) var(--p-button-x);
  border: 1px solid var(--bg-button);
  cursor: pointer;
  user-select: none;
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}
button:hover, button:active, input[type=submit]:hover, input[type=submit]:active, .button:hover, .button:active {
  color: var(--c-button);
  text-decoration: none;
  background-color: var(--terracotta-deep);
  border-color: var(--terracotta-deep);
  transform: translateY(-1px);
}
button svg, input[type=submit] svg, .button svg {
  width: var(--f4);
  height: var(--f4);
  vertical-align: inherit;
}

button.save, .button.save {
  color: var(--c-button-save);
  background-color: var(--bg-button-save);
  border-color: var(--bg-button-save);
}
button.save:hover, button.save:active, .button.save:hover, .button.save:active {
  color: var(--c-button-save);
  background-color: #2f6645;
  border-color: #2f6645;
}
button.delete, .button.delete {
  color: var(--c-button-delete);
  background-color: var(--bg-button-delete);
  border-color: var(--bg-button-delete);
}
button.delete:hover, button.delete:active, .button.delete:hover, .button.delete:active {
  color: var(--c-button-delete);
  background-color: #5f2410;
  border-color: #5f2410;
}
button.action, .button.action {
  color: var(--c-button-action);
  background-color: var(--bg-button-action);
  border-color: var(--c1);
}
button.action:hover, button.action:active, .button.action:hover, .button.action:active {
  color: var(--bg1);
  background-color: var(--c1);
  border-color: var(--c1);
}
button.update, .button.update {
  color: var(--c-button-update);
  background-color: var(--bg-button-update);
  padding: var(--x5) 0;
  font-size: 0.82rem;
  line-height: 1em;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: none;
  border-bottom: 1px solid currentColor;
}
button.update:hover, button.update:active, .button.update:hover, .button.update:active {
  color: var(--terracotta-deep);
  background-color: transparent;
  transform: none;
}
button.update::after, .button.update::after {
  content: " →";
}
button.is-compact, .button.is-compact {
  padding: 0.55em 1.1em;
  font-size: 0.85rem;
  line-height: 1em;
}

.button--block {
  display: flex;
  width: 100%;
  margin-top: var(--x3);
}

.section--ink .button.action,
.hero__ctas .button.action {
  color: var(--bg1);
  border-color: var(--bg1);
}
.section--ink .button.action:hover, .section--ink .button.action:active,
.hero__ctas .button.action:hover,
.hero__ctas .button.action:active {
  color: var(--c1);
  background-color: var(--bg1);
  border-color: var(--bg1);
}

/* Header and navigation */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bg-header);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: var(--border1);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--x2);
  padding-top: var(--p-header-top);
  padding-bottom: var(--p-header-bottom);
}

.brand {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  text-decoration: none;
  color: var(--c1);
}
.brand:hover {
  color: var(--c1);
}

.brand__mark {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
}

.brand__type {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.brand__name {
  font-family: var(--font2);
  font-size: 1.15rem;
  line-height: 1.05;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: var(--c1);
}

.brand__sub {
  font-family: var(--font1);
  font-size: 0.7rem;
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c2);
  margin-top: 2px;
}

.primary-nav {
  display: flex;
  align-items: center;
  gap: 1.75rem;
}

.primary-nav__list {
  display: none;
  list-style: none;
  gap: 1.75rem;
  padding: 0;
  margin: 0;
}
.primary-nav__list a {
  font-size: 0.95rem;
  line-height: var(--g5);
  font-weight: 500;
  letter-spacing: 0.01em;
  color: var(--c1);
  text-decoration: none;
  white-space: nowrap;
  padding-block: 0.4rem;
  position: relative;
}
.primary-nav__list a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: var(--ca);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}
.primary-nav__list a:hover::after, .primary-nav__list a[aria-current=page]::after {
  transform: scaleX(1);
}
.primary-nav__list a[aria-current=page] {
  color: var(--ca);
}
.primary-nav__list .button {
  white-space: nowrap;
}
.primary-nav__list .button::after {
  content: none;
}

.nav-toggle {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 0.6rem;
  margin: -0.6rem;
  background: none;
  border: none;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--c1);
  transition: transform var(--transition), opacity var(--transition);
}
.nav-toggle[aria-expanded=true] span:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.nav-toggle[aria-expanded=true] span:nth-child(2) {
  opacity: 0;
}
.nav-toggle[aria-expanded=true] span:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

.mobile-nav {
  display: none;
  border-top: var(--border1);
  background: var(--bg1);
  padding: 1.5rem var(--gutter-mobile) 2.5rem;
}
.mobile-nav[data-open=true] {
  display: block;
}
.mobile-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.mobile-nav li {
  border-bottom: var(--border1);
}
.mobile-nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 0;
  font-family: var(--font2);
  font-size: 1.5rem;
  line-height: 1.2;
  text-decoration: none;
  color: var(--c1);
}
.mobile-nav a::after {
  content: "→";
  color: var(--ca);
}

@media (min-width: 880px) {
  .primary-nav__list {
    display: flex;
  }
  .nav-toggle {
    display: none;
  }
  .mobile-nav {
    display: none;
  }
}
/* Hero */
.hero {
  position: relative;
  overflow: hidden;
}

.hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(35, 25, 20, 0.05) 0%, rgba(35, 25, 20, 0.55) 75%, rgba(35, 25, 20, 0.78) 100%);
}

.hero__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: clamp(560px, 78vh, 820px);
  padding-block: clamp(4rem, 8vw, 7rem);
  color: var(--bg1);
}
.hero__content .kicker {
  color: var(--ochre);
}
.hero__content .kicker::before {
  background: var(--ochre);
}

.hero__title {
  color: var(--bg1);
  max-width: 22ch;
  font-weight: 300;
  letter-spacing: -0.02em;
}
.hero__title em {
  color: var(--ochre);
  font-style: italic;
}

.hero__sub {
  font-family: var(--font2);
  font-weight: 300;
  font-size: clamp(1.15rem, 0.9rem + 0.8vw, 1.5rem);
  line-height: 1.4;
  max-width: 52ch;
  margin-top: 1.5rem;
  color: var(--bg1);
  opacity: 0.92;
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 2.5rem;
}

.hero--page {
  position: relative;
  overflow: hidden;
}
.hero--page .hero__content {
  min-height: clamp(420px, 56vh, 580px);
}
.hero--page .hero__title {
  max-width: 28ch;
}

/* Kicker and lede */
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font1);
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ca);
  margin-bottom: 1.25rem;
}
.kicker::before {
  content: "";
  display: block;
  width: 2.5rem;
  height: 2px;
  background: var(--ca);
}

.eyebrow {
  font-family: var(--font1);
  font-size: 0.78rem;
  line-height: 1.2;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ca);
}

.lede {
  font-family: var(--font2);
  font-size: clamp(1.3rem, 1rem + 0.9vw, 1.75rem);
  line-height: 1.4;
  font-weight: 300;
  color: var(--ink-soft);
  max-width: calc(var(--w-content) * 1.1);
  margin-block: 1.25rem;
}

.section--ink .lede {
  color: var(--bg1);
}

.lede--cta {
  margin-bottom: 2.5rem;
}

/* Footer */
.site-footer {
  background: var(--bg-footer);
  color: var(--c-footer);
  padding-block: clamp(4rem, 6vw, 6rem) 2rem;
}
.site-footer a {
  color: var(--bg1);
  text-decoration: none;
}
.site-footer a:hover {
  color: var(--ochre);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem 2.5rem;
  margin-bottom: 4rem;
}
@media all and (min-width: 778px) {
  .footer-grid {
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
  }
}

.footer-brand .brand__name {
  color: var(--bg1);
}
.footer-brand .brand__sub {
  color: var(--ochre);
}
.footer-brand p {
  font-size: 0.92rem;
  line-height: var(--g5);
  opacity: 0.78;
  max-width: 38ch;
  margin-top: 1.5rem;
}

.footer-col .footer-col__heading, .footer-col h4 {
  font-family: var(--font1);
  font-size: 0.78rem;
  line-height: 1.2;
  letter-spacing: 0.16em;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 1.25rem;
}
.footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.footer-col li {
  font-size: 0.95rem;
  line-height: var(--g5);
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(247, 241, 230, 0.15);
  font-size: 0.82rem;
  line-height: var(--g6);
  opacity: 0.7;
  justify-content: space-between;
  align-items: center;
}

.footer-bottom__links {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}

/* Pillars */
.pillars {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--rule);
  border-block: var(--border1);
}
@media all and (min-width: 778px) {
  .pillars {
    grid-template-columns: repeat(3, 1fr);
  }
}

.pillar {
  position: relative;
  display: block;
  background: var(--bg1);
  padding: clamp(2rem, 4vw, 3rem);
  text-decoration: none;
  color: var(--c1);
  overflow: hidden;
  transition: background var(--transition);
}
.pillar:hover {
  background: var(--bg2);
}
.pillar:hover .pillar__media img {
  transform: scale(1.03);
}

.pillar__media {
  aspect-ratio: 4/5;
  overflow: hidden;
  margin-bottom: 2rem;
}
.pillar__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.pillar__title {
  font-family: var(--font2);
  font-size: clamp(1.75rem, 1.2rem + 1.5vw, 2.5rem);
  line-height: 1.08;
  font-weight: 400;
  color: var(--c1);
  margin-bottom: 0.75rem;
}

.pillar__lede {
  color: var(--body);
  margin-bottom: 1.5rem;
  max-width: 38ch;
}

.pillar__cta {
  font-family: var(--font1);
  font-size: 0.82rem;
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ca);
}
.pillar__cta::after {
  content: " →";
}

/* Impact numbers (home stat grid) */
.impact:has(.impact__item) {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3rem 2rem;
}
@media all and (min-width: 778px) {
  .impact:has(.impact__item) {
    grid-template-columns: repeat(4, 1fr);
  }
}

.impact__item {
  text-align: left;
}

.impact__num {
  font-family: var(--font-code);
  font-weight: 300;
  font-size: clamp(2.5rem, 1.5rem + 3.5vw, 4.25rem);
  line-height: 1;
  color: var(--c1);
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.impact__num small {
  font-size: 0.5em;
  line-height: 1;
  margin-left: 0.1em;
  color: var(--ca);
}

.impact__label {
  font-family: var(--font1);
  font-size: 0.88rem;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--c2);
  margin-top: 0.75rem;
  max-width: 22ch;
}

.section--ink .impact__num {
  color: var(--bg1);
}
.section--ink .impact__num small {
  color: var(--ochre);
}

.section--ink .impact__label {
  color: var(--bg2);
  opacity: 0.85;
}

/* Narrative */
.narrative {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(3rem, 5vw, 5rem);
  align-items: start;
}
@media (min-width: 880px) {
  .narrative {
    grid-template-columns: 1fr 1fr;
  }
}

.narrative__intro h2 {
  max-width: 14ch;
}
.narrative__intro h2 em {
  color: var(--ochre);
  font-style: italic;
}
.narrative__intro .lede {
  margin-top: 1.5rem;
}

.narrative__body p + p {
  margin-top: 1em;
}

/* Featured */
.featured {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}
@media (min-width: 880px) {
  .featured {
    grid-template-columns: 1.1fr 1fr;
  }
}

.featured__media {
  aspect-ratio: 16/10;
  overflow: hidden;
}
.featured__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.featured__body {
  max-width: 52ch;
}

.featured__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-family: var(--font1);
  font-size: 0.82rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c2);
  margin-bottom: 1rem;
}
.featured__meta strong {
  color: var(--ca);
  font-weight: 600;
}

.featured__quote {
  font-family: var(--font2);
  font-size: clamp(1.2rem, 1rem + 0.5vw, 1.5rem);
  line-height: 1.4;
  font-style: italic;
  color: var(--c1);
  border-left: var(--border2);
  padding-left: 1.25rem;
  margin-block: 1.75rem;
  max-width: 48ch;
}

/* Voices */
.voices {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
}
@media all and (min-width: 778px) {
  .voices {
    grid-template-columns: repeat(3, 1fr);
  }
}

.voice {
  display: flex;
  flex-direction: column;
  background: var(--bg1);
  border: var(--border1);
}

.voice__media {
  aspect-ratio: 6/7;
  overflow: hidden;
}
.voice__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.voice__body {
  padding: 1.75rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.voice__quote {
  font-family: var(--font2);
  font-size: 1.15rem;
  line-height: 1.45;
  color: var(--c1);
  flex: 1;
}
.voice__quote::before {
  content: "“";
}
.voice__quote::after {
  content: "”";
}

.voice__attrib {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: var(--border1);
  font-family: var(--font1);
  font-size: 0.92rem;
  line-height: var(--g5);
}

.voice__name {
  font-weight: 600;
  color: var(--c1);
  display: block;
}

.voice__role {
  font-size: 0.82rem;
  line-height: 1.3;
  color: var(--c2);
  letter-spacing: 0.04em;
  margin-top: 2px;
  display: block;
}

/* Partners */
.partners {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.5rem 2rem;
  align-items: center;
}
@media all and (min-width: 778px) {
  .partners {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media all and (min-width: 1280px) {
  .partners {
    grid-template-columns: repeat(5, 1fr);
  }
}

.partner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  padding: 1rem;
  text-align: center;
}
.partner svg, .partner .partner__mark {
  height: 44px;
  width: auto;
  color: var(--ink-soft);
  opacity: 0.85;
}

.partner__name {
  font-family: var(--font1);
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--c2);
  text-transform: uppercase;
}

/* News feed */
.news-feed {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media all and (min-width: 778px) {
  .news-feed {
    grid-template-columns: repeat(3, 1fr);
  }
}

.news-card {
  display: flex;
  flex-direction: column;
  background: var(--bg1);
  text-decoration: none;
  color: var(--c1);
  border: var(--border1);
  transition: border-color var(--transition);
}
.news-card:hover {
  border-color: var(--ca);
}
.news-card:hover .news-card__media img {
  transform: scale(1.03);
}

.news-card__media {
  aspect-ratio: 16/10;
  overflow: hidden;
}
.news-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.news-card__body {
  padding: 1.5rem 1.5rem 1.75rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.news-card__meta {
  font-family: var(--font1);
  font-size: 0.74rem;
  line-height: 1.3;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ca);
  margin-bottom: 0.75rem;
  font-weight: 600;
}

.news-card__title {
  font-family: var(--font2);
  font-size: 1.4rem;
  line-height: 1.2;
  font-weight: 400;
  color: var(--c1);
  margin-bottom: 0.75rem;
  flex: 1;
}

.news-card__date {
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--c2);
}

/* Audiences */
.audiences {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: rgba(247, 241, 230, 0.12);
  border: 1px solid rgba(247, 241, 230, 0.18);
}
@media all and (min-width: 718px) {
  .audiences {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media all and (min-width: 1280px) {
  .audiences {
    grid-template-columns: repeat(3, 1fr);
  }
}

.audience {
  background: var(--c1);
  padding: 2rem;
  text-decoration: none;
  color: var(--bg1);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 220px;
  transition: background var(--transition);
}
.audience:hover {
  background: var(--ink-soft);
  color: var(--bg1);
}

.audience__label {
  font-family: var(--font1);
  font-size: 0.78rem;
  line-height: 1.3;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-bottom: 0.75rem;
  font-weight: 600;
}

.audience__title {
  font-family: var(--font2);
  font-size: 1.65rem;
  line-height: 1.15;
  font-weight: 400;
  color: var(--bg1);
}

.audience__cta {
  font-family: var(--font1);
  font-size: 0.82rem;
  line-height: 1.3;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-top: 1.5rem;
}
.audience__cta::after {
  content: " →";
}

/* Prose (interior pages) */
.prose {
  max-width: calc(var(--w-content) * 1.1);
}
.prose h2 {
  margin-top: 3rem;
  margin-bottom: 1rem;
}
.prose h3 {
  margin-top: 2.25rem;
  margin-bottom: 0.75rem;
  color: var(--c1);
}
.prose h3:first-child {
  margin-top: 0;
}
.prose p {
  margin-block: 0.85em;
}
.prose ul, .prose ol {
  padding-left: 1.4em;
  margin-block: 1em;
}
.prose li {
  margin-block: 0.35em;
}

/* Two-column content */
.two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: start;
}
@media (min-width: 880px) {
  .two-col {
    grid-template-columns: 1.4fr 1fr;
  }
}

.two-col__aside {
  background: var(--bg2);
  padding: 2rem;
  border-left: var(--border2);
}
.two-col__aside h4 {
  margin-bottom: 0.75rem;
}
.two-col__aside ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.two-col__aside li {
  padding-block: 0.6rem;
  border-bottom: var(--border3);
  font-size: 0.95rem;
  line-height: var(--g5);
}
.two-col__aside li:last-child {
  border-bottom: none;
}

.two-col__aside--ink {
  background: rgba(247, 241, 230, 0.06);
  border-left-color: var(--ochre);
}
.two-col__aside--ink h4 {
  color: var(--ochre);
}

.aside-note {
  font-family: var(--font1);
  font-size: 0.88rem;
  line-height: var(--g5);
  color: var(--c2);
  margin-top: 1.5rem;
}

/* Programme cards */
.programmes {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--rule);
  border: var(--border1);
}
@media all and (min-width: 778px) {
  .programmes {
    grid-template-columns: repeat(2, 1fr);
  }
}

.programme {
  background: var(--bg1);
  padding: 2rem;
  display: flex;
  flex-direction: column;
}

.programme__tag {
  font-family: var(--font1);
  font-size: 0.72rem;
  line-height: 1.3;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ca);
  margin-bottom: 1rem;
}

.programme__title {
  font-family: var(--font2);
  font-size: 1.45rem;
  line-height: 1.15;
  font-weight: 400;
  color: var(--c1);
  margin-bottom: 0.5rem;
}

.programme__meta {
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--c2);
  margin-bottom: 1rem;
}

.programme__desc {
  font-size: 0.95rem;
  line-height: var(--g5);
  flex: 1;
}

.programme__cta {
  margin-top: 1.5rem;
  font-family: var(--font1);
  font-size: 0.82rem;
  line-height: 1.3;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ca);
}
.programme__cta::after {
  content: " →";
}

/* Departments / generic card grid */
.depts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media all and (min-width: 718px) {
  .depts {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media all and (min-width: 1280px) {
  .depts {
    grid-template-columns: repeat(3, 1fr);
  }
}

.dept {
  padding: 1.5rem;
  background: var(--bg1);
  border: var(--border1);
  display: flex;
  flex-direction: column;
}

.dept__num {
  font-family: var(--font-code);
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--c2);
  letter-spacing: 0.06em;
  margin-bottom: 0.75rem;
}

.dept__title {
  font-family: var(--font2);
  font-size: 1.25rem;
  line-height: 1.15;
  font-weight: 500;
  color: var(--c1);
  margin-bottom: 0.5rem;
}

.dept__desc {
  font-size: 0.92rem;
  line-height: var(--g5);
  color: var(--body);
}

/* Themes list (research) */
.themes {
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: var(--rule);
}

.theme {
  background: var(--bg1);
  padding: 2rem clamp(1rem, 3vw, 2rem);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 2rem;
  align-items: center;
}
@media (max-width: 720px) {
  .theme {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
}

.theme__num {
  font-family: var(--font-code);
  font-size: 1.5rem;
  line-height: 1.2;
  font-weight: 300;
  color: var(--ca);
  font-variant-numeric: tabular-nums;
}

.theme__title {
  font-family: var(--font2);
  font-size: 1.4rem;
  line-height: 1.15;
  font-weight: 400;
  color: var(--c1);
  margin-bottom: 0.25rem;
}

.theme__desc {
  font-size: 0.95rem;
  line-height: var(--g5);
  color: var(--body);
  max-width: var(--w-content);
}

.theme__link {
  font-family: var(--font1);
  font-size: 0.82rem;
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ca);
}
.theme__link::after {
  content: " →";
}

/* Steps */
.steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media all and (min-width: 778px) {
  .steps {
    grid-template-columns: repeat(4, 1fr);
  }
}

.step {
  border-top: var(--border2);
  padding-top: 1rem;
}

.step__num {
  font-family: var(--font-code);
  font-size: 0.85rem;
  line-height: 1.4;
  letter-spacing: 0.06em;
  color: var(--ca);
  margin-bottom: 0.5rem;
}

.step__title {
  font-family: var(--font2);
  font-size: 1.2rem;
  line-height: 1.2;
  font-weight: 500;
  color: var(--c1);
  margin-bottom: 0.5rem;
}

.step__desc {
  font-size: 0.92rem;
  line-height: var(--g5);
}

/* News list (long) */
.news-list {
  display: grid;
  gap: 0;
}

.news-item {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  padding-block: 2.5rem;
  border-bottom: var(--border1);
  text-decoration: none;
  color: var(--c1);
}
@media all and (min-width: 778px) {
  .news-item {
    grid-template-columns: 220px 1fr auto;
    align-items: start;
  }
}
.news-item:hover .news-item__title {
  color: var(--ca);
}

.news-item__media {
  aspect-ratio: 4/3;
  overflow: hidden;
}
.news-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-item__meta {
  font-family: var(--font1);
  font-size: 0.74rem;
  line-height: 1.3;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ca);
  margin-bottom: 0.5rem;
}

.news-item__title {
  font-family: var(--font2);
  font-size: clamp(1.4rem, 1.1rem + 0.8vw, 1.75rem);
  line-height: 1.2;
  font-weight: 400;
  color: var(--c1);
  margin-bottom: 0.75rem;
  transition: color var(--transition-fast);
}

.news-item__excerpt {
  font-size: 0.95rem;
  line-height: var(--g5);
  max-width: var(--w-content);
  color: var(--body);
}

.news-item__date {
  font-family: var(--font-code);
  font-size: 0.85rem;
  line-height: 1.4;
  color: var(--c2);
  white-space: nowrap;
  margin-top: 0.5rem;
}

/* Form layout */
.form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  max-width: 560px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.field label {
  font-family: var(--font1);
  font-size: 0.82rem;
  line-height: 1.3;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--c1);
  text-transform: uppercase;
}
.field input, .field select, .field textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  font-size: 1rem;
  line-height: 1em;
}

.field--row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 600px) {
  .field--row {
    grid-template-columns: 1fr;
  }
}

.form__actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 0.5rem;
}

.form__status {
  margin: 0;
  font-size: 0.88rem;
  line-height: var(--g5);
  color: var(--ca);
}

.form__note {
  font-size: 0.82rem;
  line-height: var(--g6);
  color: var(--c2);
  margin-top: 1rem;
}

/* Section heads */
.section-head {
  max-width: var(--w-content);
  margin-bottom: clamp(3rem, 5vw, 5rem);
}

.section-head--center {
  margin-inline: auto;
  text-align: center;
}
.section-head--center .kicker {
  display: inline-flex;
}

.section-head--split {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 2rem;
  flex-wrap: wrap;
}

.section-head--audiences {
  margin-bottom: 3rem;
}

.section-head--tight {
  margin-bottom: 2.5rem;
}

/* Measure utilities and citation */
.measure-18 {
  max-width: 18ch;
}

.measure-22 {
  max-width: 22ch;
}

.measure-50 {
  max-width: 50ch;
}

.citation {
  font-family: var(--font1);
  font-size: 0.85rem;
  line-height: var(--g5);
  color: var(--c2);
}

/* Utilities */
.flow > * + * {
  margin-top: 1rem;
}

.flow--lg > * + * {
  margin-top: 2rem;
}

.center-text {
  text-align: center;
}
.center-text .kicker {
  display: inline-flex;
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  padding: 0.75rem 1rem;
  background: var(--ca);
  color: var(--bg1);
  z-index: 1000;
  text-decoration: none;
}
.skip-link:focus {
  left: 0;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms;
    transition-duration: 0.01ms;
    scroll-behavior: auto;
  }
}