/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: 'Inter', -apple-system, sans-serif;
    --font-serif: 'Cormorant Garamond', Georgia, serif;
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-white: #ffffff;
    --spacing: 0.25rem;
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --leading-relaxed: 1.625;
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-cream: #fafaf8;
    --color-sand: #fcfbf9;
    --color-ink: #111111;
    --color-body: #333333;
    --color-muted: #484848;
    --color-faint: #4a4a4a;
    --color-rule: #d9d3ca;
    --gap: clamp(2rem, 5vw, 4rem);
    --section-py: clamp(5rem, 12vh, 9rem);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .collapse {
    visibility: collapse;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .visible\! {
    visibility: visible !important;
  }
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .top-2 {
    top: calc(var(--spacing) * 2);
  }
  .bottom-1 {
    bottom: calc(var(--spacing) * 1);
  }
  .float-left {
    float: left;
  }
  .float-right {
    float: right;
  }
  .\!container {
    width: 100% !important;
    @media (width >= 40rem) {
      max-width: 40rem !important;
    }
    @media (width >= 48rem) {
      max-width: 48rem !important;
    }
    @media (width >= 64rem) {
      max-width: 64rem !important;
    }
    @media (width >= 80rem) {
      max-width: 80rem !important;
    }
    @media (width >= 96rem) {
      max-width: 96rem !important;
    }
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-15 {
    margin-top: calc(var(--spacing) * 15);
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .hidden\! {
    display: none !important;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-grid {
    display: inline-grid;
  }
  .table {
    display: table;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .shrink {
    flex-shrink: 1;
  }
  .grow {
    flex-grow: 1;
  }
  .border-collapse {
    border-collapse: collapse;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .resize {
    resize: both;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .justify-center {
    justify-content: center;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-rule {
    border-color: var(--color-rule);
  }
  .bg-body {
    background-color: var(--color-body);
  }
  .bg-cream {
    background-color: var(--color-cream);
  }
  .bg-faint {
    background-color: var(--color-faint);
  }
  .bg-ink {
    background-color: var(--color-ink);
  }
  .bg-muted {
    background-color: var(--color-muted);
  }
  .bg-rule {
    background-color: var(--color-rule);
  }
  .bg-sand {
    background-color: var(--color-sand);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .fill-rule {
    fill: var(--color-rule);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .text-center {
    text-align: center;
  }
  .font-sans {
    font-family: var(--font-sans);
  }
  .font-serif {
    font-family: var(--font-serif);
  }
  .text-6xl {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .text-wrap {
    text-wrap: wrap;
  }
  .text-body {
    color: var(--color-body);
  }
  .text-cream {
    color: var(--color-cream);
  }
  .text-faint {
    color: var(--color-faint);
  }
  .text-ink {
    color: var(--color-ink);
  }
  .text-muted {
    color: var(--color-muted);
  }
  .text-sand {
    color: var(--color-sand);
  }
  .text-white {
    color: var(--color-white);
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .ring {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .blur {
    --tw-blur: blur(8px);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .filter\! {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,) !important;
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }
  .select-all {
    -webkit-user-select: all;
    user-select: all;
  }
}
:root {
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter', -apple-system, sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --cream: #fafaf8;
  --sand: #fcfbf9;
  --body: #333333;
  --home-title-line-height: 1.15;
  --home-title-track: -0.01em;
  --home-oneliner-size: clamp(1.05rem, 1.35vw, 1.22rem);
  --home-oneliner-line: 1.6;
  --home-oneliner-weight: 450;
  --home-btn-font-size: 1.08rem;
  --home-btn-pad-y: 0.9rem;
  --home-btn-pad-x: 1.9rem;
  --home-btn-radius: 6px;
}
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--gap, 15px);
  padding-right: var(--gap, 15px);
}
html {
  font-size: 16px;
  scroll-behavior: auto;
  overflow-x: clip;
}
body {
  font-family: var(--sans);
  font-weight: 400;
  line-height: 1.6;
  color: var(--body);
  background: var(--cream);
  overflow-x: clip;
  -webkit-font-smoothing: antialiased;
}
img {
  display: block;
  height: auto;
  max-width: 100%;
}
a {
  color: inherit;
  text-decoration-line: none;
}
button {
  cursor: pointer;
  --tw-border-style: none;
  border-style: none;
  background-color: transparent;
  font: inherit;
}
::selection {
  background-color: var(--color-ink);
  color: var(--color-white);
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-ink);
  line-height: 1.15;
  text-wrap: balance;
}
h1 {
  font-size: clamp(3.8rem, 10vw, 9rem);
  letter-spacing: -0.035em;
}
h2 {
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
}
h3 {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
}
h2 em, h3 em {
  --tw-font-weight: var(--font-weight-light);
  font-weight: var(--font-weight-light);
  font-style: italic;
}
p {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.75;
  text-wrap: pretty;
}
.section-oneliner {
  font-family: var(--font-sans);
  font-size: clamp(1.05rem, 1.35vw, 1.22rem);
  line-height: 1.6;
  color: var(--body);
  font-weight: 450;
  max-width: 42rem;
  margin-inline: auto;
  text-wrap: pretty;
}
.section-title-ink {
  font-family: var(--font-serif);
  color: var(--color-ink);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  line-height: 1.15;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.label {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-faint);
  margin-bottom: 1rem;
}
a.label {
  text-decoration: none;
  transition: color 0.2s ease;
}
a.label:hover {
  color: var(--color-ink);
}
.mt-md {
  margin-top: 1rem;
}
.mt-lg {
  margin-top: 1.5rem;
}
.mt-xl {
  margin-top: 2rem;
}
.footer-address {
  margin-top: 0.5rem;
  line-height: 1.5;
}
.footer-ein {
  font-size: 0.9rem;
  color: var(--color-faint);
  margin-top: 0.3rem;
}
.footer-newsletter .footer-newsletter-title {
  font-family: var(--font-serif);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-ink);
  font-size: 2rem;
  margin-bottom: 0.3rem;
}
.btn {
  display: inline-block;
  font-family: var(--font-sans);
  text-transform: capitalize;
  font-size: 1.05rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.06em;
  padding: 0.75em 2.2em;
  border-radius: 6px;
  transition: all 0.35s var(--ease);
  cursor: pointer;
}
.btn-primary {
  background-color: var(--color-ink);
  color: var(--color-cream);
  border: 1.5px solid var(--color-ink);
}
.btn-primary:hover {
  background: transparent;
  color: var(--color-ink);
}
.btn-ghost {
  background: transparent;
  color: var(--color-white);
  border: 1.5px solid rgba(255, 255, 255, 0.4);
}
.btn-ghost:hover {
  background-color: var(--color-white);
  color: var(--color-ink);
}
.btn-ghost-dark {
  background: transparent;
  color: var(--color-ink);
  border: 1.5px solid var(--rule);
}
.btn-ghost-dark:hover {
  background-color: var(--color-ink);
  color: var(--color-cream);
}
.btn-white {
  background-color: var(--color-white);
  color: var(--color-ink);
  border: 1.5px solid var(--color-white);
}
.btn-white:hover {
  background: transparent;
  color: var(--color-white);
}
.btn:visited {
  color: inherit;
}
.btn-primary:visited {
  color: var(--color-cream);
}
.btn-primary:hover:visited {
  color: var(--color-ink);
}
.btn-ghost:visited {
  color: var(--color-white);
}
.btn-ghost:hover:visited {
  color: var(--color-ink);
}
.btn-ghost-dark:visited {
  color: var(--color-ink);
}
.btn-ghost-dark:hover:visited {
  color: var(--color-cream);
}
.btn-white:visited {
  color: var(--color-ink);
}
.btn-white:hover:visited {
  color: var(--color-white);
}
.nav-cta:visited {
  color: var(--color-cream);
}
.nav-cta:hover:visited {
  color: var(--color-ink);
}
:root {
  --rule: #b8b1a6;
  --rule-strong: #6f6a62;
  --muted: #484848;
  --faint: #4a4a4a;
}
h1, h2, h3, h4, h5, h6, .movement-section-heading, .brand-heading, .brand-tagline, .hscroll-outro h2, .faq-question, .movement-declaration, .movement-right h2, .hero-heading, .hero-sub, .final-cta-content h2, .work-card-info p, .impact-block-text h2, .impact-page-intro h1 {
  text-wrap: balance;
}
p, .carousel-card p, .faq-answer-inner, .link-card p {
  text-wrap: pretty;
}
.skip-link {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.skip-link:focus {
  width: auto;
  height: auto;
  padding: 0.75rem 1.5rem;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
  top: 0;
  left: 0;
  z-index: 10000;
  background-color: var(--color-ink);
  color: var(--color-cream);
  font-size: 1rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  text-decoration: none;
  outline: 2px solid var(--color-ink);
  outline-offset: 2px;
}
.nav {
  position: fixed;
  top: calc(var(--spacing) * 0);
  right: calc(var(--spacing) * 0);
  left: calc(var(--spacing) * 0);
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 3rem;
  background: transparent;
  transform: translateY(0);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), padding 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.nav.scrolled {
  background-color: var(--color-cream);
  padding: 0.5rem 3rem;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
}
.nav-hidden {
  transform: translateY(-100%);
}
.nav-solid {
  background: #fff;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
}
.nav-logo img {
  height: 88px;
  width: auto;
  transition: height 0.3s;
}
.nav.scrolled .nav-logo img {
  height: 72px;
}
.nav-links {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 2.2rem;
  justify-content: center;
}
.nav-links a {
  font-size: 1.1rem;
  --tw-font-weight: var(--font-weight-normal);
  font-weight: var(--font-weight-normal);
  color: var(--color-ink);
  letter-spacing: 0.04em;
  text-transform: capitalize;
  position: relative;
  transition: color 0.3s;
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1.5px;
  background-color: var(--color-ink);
  transition: width 0.3s ease;
}
.nav-links a:hover::after, .nav-links a.active::after {
  width: 100%;
}
.nav.hero-dark .nav-links a {
  color: rgba(255, 255, 255, 0.85);
}
.nav.hero-dark .nav-links a::after {
  background: rgba(255, 255, 255, 0.6);
}
.nav.hero-dark.scrolled .nav-links a {
  color: var(--color-body);
}
.nav.hero-dark.scrolled .nav-links a::after {
  background-color: var(--color-ink);
}
.nav-right {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.nav-help {
  font-size: 0.92rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-ink);
  transition: opacity 0.3s ease;
}
.nav-help:hover {
  opacity: 0.7;
}
.nav-cta-outline {
  font-size: 0.85rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-ink);
  letter-spacing: 0.06em;
  text-transform: capitalize;
  padding: 0.55rem 1.4rem;
  background: transparent;
  border: 1.5px solid var(--rule);
  border-radius: 6px;
  transition: all 0.3s var(--ease);
}
.nav-cta-outline:hover {
  background-color: var(--color-ink);
  color: var(--color-cream);
  border-color: var(--color-ink);
}
.nav-cta {
  font-size: 0.85rem;
  background-color: var(--color-ink);
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-cream);
  letter-spacing: 0.06em;
  text-transform: capitalize;
  padding: 0.55rem 1.4rem;
  border: 1.5px solid var(--color-ink);
  border-radius: 6px;
  transition: all 0.3s var(--ease);
}
.nav-cta:hover {
  background: transparent;
  color: var(--color-ink);
}
.nav-hamburger {
  display: none;
  position: relative;
  width: 44px;
  height: 44px;
  z-index: 101;
  flex-shrink: 0;
  background: none;
  cursor: pointer;
  --tw-border-style: none;
  border-style: none;
}
.nav-hamburger span {
  position: absolute;
  display: block;
  background-color: var(--color-ink);
  width: 22px;
  height: 1.5px;
  left: 11px;
  border-radius: 1px;
  transition: transform 0.38s var(--ease), opacity 0.22s ease;
  transform-origin: center;
}
.nav-hamburger span:nth-child(1) {
  top: 13px;
}
.nav-hamburger span:nth-child(2) {
  top: 21px;
}
.nav-hamburger span:nth-child(3) {
  top: 29px;
}
.nav-hamburger.active span:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}
.nav-hamburger.active span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.nav-hamburger.active span:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}
.nav-mobile {
  display: flex;
  background-color: var(--color-cream);
  position: fixed;
  inset: 0;
  z-index: 100;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  clip-path: circle(0% at calc(100% - 2.5rem) 2rem);
  transition: clip-path 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}
.nav-mobile.open {
  clip-path: circle(150% at calc(100% - 2.5rem) 2rem);
  pointer-events: auto;
}
.nav-mobile a {
  font-family: var(--font-serif);
  color: var(--color-ink);
  font-size: 2.5rem;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.4s ease, transform 0.5s var(--ease);
}
.nav-mobile.open a {
  opacity: 1;
  transform: translateY(0);
}
.nav-mobile.open a:nth-child(1) {
  transition-delay: 0.15s;
}
.nav-mobile.open a:nth-child(2) {
  transition-delay: 0.22s;
}
.nav-mobile.open a:nth-child(3) {
  transition-delay: 0.29s;
}
.nav-mobile.open a:nth-child(4) {
  transition-delay: 0.36s;
}
.nav-mobile.open a:nth-child(5) {
  transition-delay: 0.43s;
}
.nav-mobile.open a:nth-child(6) {
  transition-delay: 0.5s;
}
.nav-mobile-share {
  display: flex;
  gap: 1rem;
  margin-top: 1rem;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.4s ease 0.55s, transform 0.5s var(--ease) 0.55s;
}
.nav-mobile.open .nav-mobile-share {
  opacity: 1;
  transform: translateY(0);
}
.nav-mobile-share a {
  font-size: 1rem !important;
  width: 44px;
  height: 44px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rule);
  border-radius: 50%;
  opacity: 1 !important;
  transform: none !important;
}
.nav-mobile-share svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: var(--color-ink);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
html.gallery-page .nav {
  background: transparent;
}
html.gallery-page .nav.scrolled {
  background: rgba(12, 12, 12, 0.85);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.08);
}
html.gallery-page .nav-logo img {
  filter: brightness(0) invert(1);
}
html.gallery-page .nav-links a {
  color: rgba(255, 255, 255, 0.85);
}
html.gallery-page .nav-links a:hover {
  color: #fff;
}
html.gallery-page .nav-links a::after {
  background: rgba(255, 255, 255, 0.8);
}
html.gallery-page .nav-help {
  color: rgba(255, 255, 255, 0.85);
}
html.gallery-page .nav-help:hover {
  color: #fff;
  opacity: 1;
}
html.gallery-page .nav-cta {
  background: #fff;
  color: #0c0c0c;
  border-color: #fff;
}
html.gallery-page .nav-cta:hover {
  background: transparent;
  color: #fff;
}
html.gallery-page .nav-hamburger span {
  background: #fff;
}
.hero {
  position: relative;
  z-index: 2;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 8rem 3rem 4rem;
  background-color: var(--color-cream);
  overflow: hidden;
}
.hero-canvas {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.3;
}
.hero-content {
  max-width: none;
  position: relative;
  z-index: 2;
}
.hero-tag {
  font-family: var(--font-sans);
  font-size: 1rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 1.45rem;
}
.hero-heading {
  font-size: calc(clamp(3.2rem, 8vw, 7.5rem) - 5px);
  line-height: 0.98;
  margin-bottom: 2.2rem;
  max-width: 58vw;
}
.hero-heading .reveal-line + .reveal-line {
  margin-top: -0.06em;
}
.hero-heading .reveal-line:first-child > span {
  white-space: nowrap;
}
@media (max-width: 900px) {
  .hero-heading .reveal-line:first-child > span {
    white-space: normal;
  }
}
.reveal-line {
  display: block;
  overflow: hidden;
  padding-bottom: 0.15em;
  margin-bottom: -0.15em;
}
.reveal-line > span {
  display: block;
  transform: translateY(105%);
}
.hero-heading .reveal-line:first-child > span {
  transform: none !important;
}
.hero-line {
  display: inline-block;
  width: clamp(120px, 12vw, 240px);
  height: 3px;
  background-color: var(--color-ink);
  margin: 0 0.4em;
  transform-origin: left center;
  transform: scaleX(0);
  vertical-align: middle;
}
.outline-fill {
  -webkit-text-stroke: 1.5px var(--color-ink);
  color: var(--color-ink);
  --tw-font-weight: var(--font-weight-light);
  font-weight: var(--font-weight-light);
  display: inline-block;
  transition: color 0.2s ease;
}
.outline-fill.text-outlined {
  color: transparent;
}
.content-section.dark .outline-fill {
  -webkit-text-stroke-color: var(--cream);
  color: var(--color-cream);
}
.content-section.dark .outline-fill.text-outlined {
  color: transparent;
}
.hero-visual {
  position: absolute;
  top: 50%;
  right: clamp(1.5rem, 4vw, 4rem);
  transform: translateY(-50%);
  width: clamp(420px, 42vw, 600px);
  height: clamp(420px, 42vw, 600px);
  z-index: 1;
}
.hero-slideshow {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.12);
  z-index: 1;
}
.hero-slideshow img, .hero-slideshow picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.hero-slideshow picture img {
  position: static;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-slideshow > img, .hero-slideshow > picture {
  opacity: 0;
  will-change: transform;
  transition: opacity 1.2s ease;
}
.hero-slideshow > img.active, .hero-slideshow > picture.active {
  opacity: 1;
}
.hero-slideshow::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.03) 0%, rgba(0, 0, 0, 0.15) 100%);
  z-index: 1;
  pointer-events: none;
}
.hero-sub {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  color: var(--color-body);
  line-height: 1.75;
  max-width: 860px;
  margin-top: -20px;
}
.hero-heading .reveal-line:nth-child(2) .outline-fill {
  font-size: 115px;
  margin-top: 10px;
  display: inline-block;
}
.hero-foot {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2rem;
  opacity: 0;
  transform: translateY(20px);
}
.hero-partners {
  display: flex;
  align-items: center;
  gap: clamp(1.2rem, 3vw, 2.5rem);
  flex-wrap: wrap;
  margin-top: 0.5rem;
}
.hero-partners a {
  display: inline-flex;
  text-decoration: none;
  line-height: 0;
}
.hero-partners img {
  height: clamp(28px, 3.5vw, 42px);
  width: auto;
  object-fit: contain;
  filter: brightness(0);
  opacity: 0.7;
  transition: opacity 0.3s ease;
}
.hero-partners a:nth-child(6) img {
  height: clamp(52px, 6vw, 76px);
}
.hero-partners a:hover img {
  opacity: 1;
}
.rotating-badge {
  position: absolute;
  width: clamp(110px, 30%, 170px);
  aspect-ratio: 1;
  top: -3%;
  right: -3%;
  opacity: 0;
  filter: drop-shadow(0 6px 20px rgba(0, 0, 0, 0.22));
}
.badge-black {
  z-index: 0;
}
.badge-black svg text {
  fill: var(--color-ink);
}
.badge-black .center-dot {
  background-color: var(--color-ink);
}
.badge-white {
  z-index: 3;
}
.badge-white svg text {
  fill: var(--color-white);
}
.badge-white .center-dot {
  background-color: var(--color-white);
}
.rotating-badge svg {
  width: 100%;
  height: 100%;
  animation: spin 22s linear infinite;
}
.rotating-badge svg text {
  font-family: var(--font-sans);
  font-size: 7.5px;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.center-dot {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.scroll-cue {
  position: absolute;
  bottom: 2.5rem;
  right: clamp(2rem, 4vw, 4rem);
  opacity: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.scroll-cue-text {
  font-family: var(--font-sans);
  font-size: 0.6rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-faint);
  writing-mode: vertical-lr;
}
.scroll-cue-line {
  width: 1.5px;
  height: 48px;
  background: var(--rule);
  position: relative;
  overflow: hidden;
}
.scroll-cue-line::after {
  content: '';
  display: block;
  width: 100%;
  height: 50%;
  background-color: var(--color-ink);
  animation: scrollSlide 2.2s ease-in-out infinite;
}
@keyframes scrollSlide {
  0% {
    transform: translateY(-100%);
  }
  100% {
    transform: translateY(200%);
  }
}
.marquee {
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  background-color: var(--color-cream);
  padding: 0.6rem 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.marquee::before, .marquee::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
  pointer-events: none;
}
.marquee::before {
  left: 0;
  width: 12%;
  background: linear-gradient(to right, var(--cream), transparent);
}
.marquee::after {
  right: 0;
  width: 30%;
  background: linear-gradient(to left, var(--cream), transparent);
}
.marquee-track {
  display: inline-flex;
  white-space: nowrap;
  animation: marqueeScroll 35s linear infinite;
}
.marquee-track span {
  font-family: var(--font-serif);
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  font-style: italic;
  font-weight: 400;
  color: var(--color-ink);
  opacity: 0.12;
  padding: 0 2rem;
  flex-shrink: 0;
  transition: transform 0.15s ease;
}
@keyframes marqueeScroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.movement {
  background-color: var(--color-ink);
  color: var(--color-cream);
  padding: var(--section-py) var(--gap);
}
.movement-inner {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.movement-left {
  position: relative;
  border-radius: 2px;
  overflow: hidden;
  aspect-ratio: 4/5;
}
.movement-bg, .movement-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  will-change: transform;
}
.movement-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(17, 17, 17, 0.85) 0%, rgba(17, 17, 17, 0.2) 60%);
}
.movement-declaration {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  right: 2rem;
  font-family: var(--font-serif);
  font-size: clamp(1.3rem, 2.2vw, 1.7rem);
  font-weight: 400;
  font-style: italic;
  line-height: 1.6;
  color: rgba(255, 255, 255, 1);
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.6);
}
.movement-right .label {
  color: rgba(255, 255, 255, 0.55);
}
.movement-right h2 {
  color: var(--color-cream);
  margin-bottom: 1.5rem;
}
.movement-right p {
  color: rgba(255, 255, 255, 0.82);
  margin-bottom: 1rem;
}
.movement-tagline {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--cream) !important;
  font-style: italic;
  margin-top: 1.5rem;
}
.brand-section {
  padding: var(--section-py) var(--gap);
  background-color: var(--color-ink);
  color: var(--color-cream);
  text-align: center;
  position: relative;
  z-index: 2;
}
.brand-inner {
  max-width: 1040px;
  margin: 0 auto;
  padding-top: 15px;
}
.brand-heading {
  font-size: clamp(2.2rem, 4.8vw, 3.5rem);
  color: var(--color-cream);
  margin-bottom: 1rem;
  line-height: 1.15;
  --tw-font-weight: var(--font-weight-light);
  font-weight: var(--font-weight-light);
}
.brand-heading-top {
  display: block;
  font-size: 1.35em;
  line-height: 1.1;
  --tw-font-weight: var(--font-weight-light);
  font-weight: var(--font-weight-light);
}
.brand-heading em {
  font-style: italic;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
}
.brand-tagline {
  font-family: var(--font-serif);
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
  font-style: italic;
  --tw-font-weight: var(--font-weight-bold);
  font-weight: var(--font-weight-bold);
  color: #fff;
  margin: 1rem auto 0;
  max-width: 720px;
  line-height: 1.4;
}
.brand-founders {
  font-family: var(--font-sans);
  font-size: 1rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.7);
  margin-top: 0;
  margin-bottom: 0.8rem;
}
.brand-body p {
  font-size: clamp(1.12rem, 1.58vw, 1.3rem);
  color: #fff;
  font-weight: 400;
  max-width: 670px;
  margin-inline: auto;
  line-height: 1.65;
}
.brand-body p + p {
  margin-top: 1rem;
}
.brand-section .btn-ghost, .brand-overlay .btn-ghost {
  margin-top: 1.5rem;
  background-color: var(--color-ink);
  color: var(--color-cream);
  border: 1.5px solid transparent;
  font-size: 1.3rem;
  padding: 1rem 3rem;
}
.brand-section .btn-ghost:hover, .brand-overlay .btn-ghost:hover {
  background: transparent;
  color: var(--color-ink);
  border-color: var(--color-ink);
}
.carousel-section {
  padding: var(--section-py) 0;
  background-color: var(--color-cream);
  overflow: hidden;
}
.carousel-intro {
  max-width: 960px;
  margin: 0 auto clamp(2rem, 4vw, 3rem);
  text-align: center;
  padding: 0 var(--gap);
}
.carousel-intro > p {
  max-width: 36em;
  margin-inline: auto;
  font-size: 1.2rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-body);
}
.carousel-wrap {
  position: relative;
  padding: 1rem 0 5rem;
  margin-top: -1rem;
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image: linear-gradient( to right, transparent 0%, black 8%, black 92%, transparent 100% );
}
.carousel-track {
  display: flex;
  gap: 2.2rem;
  align-items: stretch;
  width: max-content;
  animation: carousel-scroll 72s linear infinite;
  padding-bottom: 2rem;
}
.carousel-track:hover {
  animation-play-state: paused;
}
.carousel-card {
  flex-shrink: 0;
  width: 380px;
  padding: 2.2rem 2.4rem;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  border-radius: 6px;
  text-decoration: none;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.5s ease;
  will-change: transform;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-self: stretch;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
}
.carousel-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 32px 64px rgba(0, 0, 0, 0.08);
}
.carousel-card h3 {
  font-size: clamp(2rem, 3.2vw, 2.6rem);
  margin-bottom: 1.2rem;
  color: var(--color-ink);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  line-height: 1.15;
}
.carousel-card p {
  font-size: 1.05rem;
  color: var(--color-body);
  line-height: 1.6;
  font-weight: 400;
}
@keyframes carousel-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
.breadth-reveal {
  overflow: hidden;
}
.breadth-reveal-line {
  display: block;
  clip-path: inset(0 0 100% 0);
}
.gallery {
  position: relative;
  background-color: var(--color-ink);
  color: var(--color-cream);
}
.gallery-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.gallery-frame {
  position: relative;
  width: 100%;
  height: 100%;
  max-width: none;
  overflow: hidden;
  border-radius: 0;
}
.gallery-img {
  position: absolute;
  inset: 0;
  opacity: 0;
}
.gallery-img:first-child {
  opacity: 1;
}
.gallery-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.gallery-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 2rem 2.5rem;
  background: linear-gradient( to top, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.3) 60%, transparent 100% );
}
.gallery-caption .label {
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}
.gallery-caption h3 {
  color: var(--color-white);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}
.gallery-progress {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  width: 120px;
  height: 2px;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 1px;
  overflow: hidden;
}
.gallery-progress-fill {
  height: 100%;
  width: 0%;
  background-color: var(--color-cream);
  border-radius: 1px;
}
.faq-section {
  padding: var(--section-py) var(--gap);
  background-color: var(--color-cream);
}
.faq-section .content-inner {
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.faq-list {
  max-width: 800px;
  margin: 0 auto;
}
.faq-item {
  border-bottom: 1px solid var(--rule);
}
.faq-question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 0;
  font-family: var(--font-serif);
  font-size: clamp(1.55rem, 2.8vw, 1.9rem);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-ink);
  text-align: left;
  cursor: pointer;
  background: none;
  --tw-border-style: none;
  border-style: none;
}
.faq-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  position: relative;
  margin-left: 1.5rem;
}
.faq-icon::before, .faq-icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 2px;
  background-color: var(--color-ink);
  transform: translate(-50%, -50%);
  transition: transform 0.4s var(--ease);
  border-radius: 1px;
}
.faq-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.faq-item.open .faq-icon::after {
  transform: translate(-50%, -50%) rotate(0deg);
}
.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s var(--ease);
}
.faq-answer-inner {
  padding: 0 0 1.5rem;
  color: var(--color-muted);
  font-size: clamp(1rem, 1.2vw, 1.1rem);
  line-height: 1.75;
}
.final-cta {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-align: center;
  padding: var(--section-py) var(--gap);
}
.final-cta-bg, .final-cta-bg img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  will-change: transform;
}
.final-cta::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(17, 17, 17, 0.75);
  z-index: 1;
}
.final-cta-content {
  position: relative;
  z-index: 2;
  max-width: 54rem;
  margin: 0 auto;
  text-align: center;
  opacity: 0;
  transform: translateY(30px);
}
.final-cta-content h2 {
  color: #fff;
  margin-bottom: 1.5rem;
  font-size: clamp(2.49rem, 5.34vw, 4.63rem);
}
.final-cta-content h2 em {
  color: rgba(255, 255, 255, 0.85);
  font-style: italic;
}
.final-cta-content p:not(.cta-tag) {
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 2rem;
  margin-inline: auto;
  max-width: 36rem;
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  line-height: 1.7;
}
.final-cta-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
@media (max-width: 1024px) {
  .final-cta-actions {
    flex-direction: column;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }
}
.footer {
  background-color: var(--color-white);
  color: var(--color-body);
  padding: clamp(3rem, 6vw, 5rem) var(--gap) 0;
  border-top: 1px solid var(--rule);
}
.footer-top {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--rule);
  text-align: left;
}
.footer-logo {
  height: 72px;
  width: auto;
  margin-bottom: 1rem;
  filter: brightness(0);
}
.footer-brand p {
  font-size: 1rem;
  line-height: 1.7;
  max-width: 340px;
  color: var(--color-muted);
}
.footer-brand small {
  color: var(--color-faint);
  font-size: 0.9rem;
}
.footer-col {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.footer-col h6 {
  font-family: var(--font-sans);
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-faint);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.3rem;
}
.footer-col a, .footer-col span {
  font-size: 1rem;
  color: var(--color-muted);
  line-height: 1.6;
  transition: color 0.3s;
}
.footer-col a:hover {
  color: var(--color-ink);
}
.footer-col a[data-cms='footer.privacyLink.href'] {
  text-decoration: underline;
  text-underline-offset: 3px;
}
.footer-newsletter {
  max-width: 1400px;
  margin: 0 auto;
  padding: 1rem 0 1.6rem;
  border-bottom: 1px solid var(--rule);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.footer > .footer-newsletter .footer-newsletter-title {
  line-height: 1.05;
  margin-bottom: 0.12rem;
}
.footer-newsletter p {
  font-size: 1rem;
  color: var(--color-muted);
}
.footer-newsletter-form {
  display: flex;
  gap: 0.5rem;
}
.footer-newsletter-form input {
  background-color: var(--color-white);
  font-family: var(--font-sans);
  color: var(--color-ink);
  font-size: 0.87rem;
  padding: 0.75rem 1.1rem;
  border: 1px solid var(--rule);
  min-width: 160px;
  transition: border-color 0.3s ease;
}
.footer-newsletter-form input:focus {
  outline: none;
  border-color: var(--color-ink);
}
.footer-newsletter-form input::placeholder {
  color: var(--color-faint);
}
.footer-newsletter-form .footer-newsletter-submit {
  display: inline-block;
  min-width: 9.5rem;
  text-align: center;
}
.footer-bottom {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  text-align: center;
  color: var(--color-faint);
  padding: 1.5rem 0;
  font-size: 0.87rem;
}
html.gallery-page .footer {
  background: #0c0c0c;
  color: rgba(255, 255, 255, 0.7);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  position: relative;
  z-index: 10;
}
html.gallery-page .footer-top {
  border-bottom-color: rgba(255, 255, 255, 0.08);
}
html.gallery-page .footer-logo {
  filter: brightness(0) invert(1);
}
html.gallery-page .footer-brand p {
  color: rgba(255, 255, 255, 0.65);
}
html.gallery-page .footer-brand small, html.gallery-page .footer-col h6 {
  color: rgba(255, 255, 255, 0.45);
}
html.gallery-page .footer-col a, html.gallery-page .footer-col span {
  color: rgba(255, 255, 255, 0.7);
}
html.gallery-page .footer-col a:hover {
  color: #fff;
}
html.gallery-page .footer-newsletter {
  border-bottom-color: rgba(255, 255, 255, 0.08);
}
html.gallery-page .footer-newsletter p, html.gallery-page .footer-bottom {
  color: rgba(255, 255, 255, 0.65);
}
html.gallery-page .footer-newsletter-form input {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.15);
  color: #fff;
}
html.gallery-page .footer-newsletter-form input::placeholder {
  color: rgba(255, 255, 255, 0.4);
}
html.gallery-page .footer-newsletter-form input:focus {
  border-color: #fff;
}
html.gallery-page .footer-newsletter-form button {
  background: #fff;
  color: #0c0c0c;
}
html.gallery-page .footer-bottom {
  color: rgba(255, 255, 255, 0.4);
}
.page-hero {
  position: relative;
  display: flex;
  overflow: hidden;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: var(--color-ink);
  text-align: center;
  min-height: 50vh;
  padding: 6rem var(--gap) 4rem;
}
.page-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.35;
  z-index: 0;
}
.page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient( to bottom, rgba(17, 17, 17, 0.55) 0%, rgba(17, 17, 17, 0.15) 40%, rgba(17, 17, 17, 0.5) 100% );
  pointer-events: none;
}
.page-hero > *:not(.page-hero-bg) {
  position: relative;
  z-index: 2;
}
.page-hero h1 {
  margin-bottom: 0;
  color: var(--color-cream);
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  line-height: 1.05;
}
.page-hero .reveal-line, .page-hero .reveal-line > span {
  display: inline;
  overflow: visible;
  transform: none;
}
.page-hero .hero-tag {
  display: block;
  font-family: var(--font-serif);
  --tw-font-weight: var(--font-weight-light);
  font-weight: var(--font-weight-light);
  font-style: italic;
  font-size: clamp(1rem, 1.8vw, 1.35rem);
  color: rgba(250, 250, 248, 0.75);
  letter-spacing: 0.02em;
  text-transform: none;
  margin-bottom: 1.75rem;
  order: -1;
}
.page-hero p:not(.hero-tag) {
  color: rgba(250, 250, 248, 0.88);
  max-width: 36rem;
  margin-inline: auto;
  font-size: clamp(0.95rem, 1.3vw, 1.1rem);
  line-height: 1.65;
}
.page-hero .outline-fill {
  -webkit-text-stroke-color: var(--cream);
  color: var(--color-cream);
}
.page-hero .outline-fill.text-outlined {
  color: transparent;
}
.page-hero.compact {
  min-height: 44vh;
  padding: 8rem var(--gap) 3rem;
}
.page-hero.compact h1 {
  font-size: clamp(2.8rem, 7vw, 5rem);
  margin-bottom: 0.5rem;
}
.content-section {
  padding: var(--section-py) var(--gap);
}
.content-section.alt {
  background: var(--sand);
}
.content-section.dark {
  background-color: var(--color-ink);
  color: var(--color-cream);
}
.content-section.dark h2, .content-section.dark h3 {
  color: var(--color-cream);
}
.content-section.dark p {
  color: rgba(255, 255, 255, 0.7);
}
.content-inner {
  max-width: 900px;
  margin: 0 auto;
}
.content-inner h2 {
  margin-bottom: 1.5rem;
}
.content-inner h3 {
  margin-bottom: 0.75rem;
}
.content-inner p {
  max-width: 42em;
}
.content-inner p + p {
  margin-top: 1rem;
}
.privacy-list {
  list-style: disc;
  padding-left: 1.5rem;
  margin: 0.75rem 0 1rem;
}
.privacy-list li {
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 0.4rem;
  color: var(--color-body);
}
.content-split {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: stretch;
}
.content-split img {
  width: 100%;
  height: 100%;
  border-radius: 2px;
  object-fit: cover;
  max-height: 560px;
}
.content-split.reverse > :first-child {
  order: 2;
}
.content-split.reverse > :last-child {
  order: 1;
}
.mobile-bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 999;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid var(--rule);
  padding: 0.5rem 0 calc(0.5rem + env(safe-area-inset-bottom, 0px));
  justify-content: space-around;
  align-items: center;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
.mobile-bottom-nav.visible {
  transform: translateY(0);
}
.mbn-item {
  display: flex;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-faint);
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 0.4rem 0.8rem;
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.mbn-item svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.mbn-item.active, .mbn-item:hover {
  color: var(--color-ink);
}
.page-impact .impact-story-row {
  grid-template-columns: 1.28fr 1fr;
  width: min(1200px, calc(100% - 2rem));
  max-width: 1200px;
}
.page-impact .impact-story-row.reverse {
  grid-template-columns: 1fr 1.28fr;
}
.page-impact .impact-story-gallery {
  gap: 6px;
  padding: 6px;
}
.page-impact .impact-story-card, .page-impact .impact-story-card.tile-white {
  padding: clamp(2rem, 4vh, 3rem) clamp(1.6rem, 3vw, 2.35rem);
}
.page-impact .impact-story-row .impact-story-gallery, .page-impact .impact-story-row.reverse .impact-story-gallery {
  min-width: 0;
}
.page-impact .impact-story-gallery img {
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.page-impact .impact-story-gallery .img-wrap:hover img {
  transform: scale(1.05);
}
@media (max-width: 768px) {
  .page-impact .impact-story-gallery {
    gap: 4px;
    padding: 4px;
  }
  .page-impact .impact-story-row {
    width: calc(100% - 1rem);
  }
}
.contact-section {
  padding: 0 var(--gap) var(--section-py);
  max-width: 1200px;
  margin: 0 auto;
}
.contact-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--rule);
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.contact-tab {
  cursor: pointer;
  font-family: var(--font-sans);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-faint);
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  padding: 1rem 1.5rem;
  border-bottom: 2px solid transparent;
  transition: color 0.3s, border-color 0.3s;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
}
.contact-tab:hover, .contact-tab.active {
  color: var(--color-ink);
}
.contact-tab.active {
  border-bottom-color: var(--color-ink);
}
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.contact-info h3 {
  margin-bottom: 1rem;
}
.contact-info p {
  margin-bottom: 1.5rem;
  color: var(--color-muted);
}
.contact-detail {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.8rem;
  font-size: 0.93rem;
}
.contact-detail svg {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  fill: none;
  stroke: var(--color-ink);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  margin-top: 2px;
}
.contact-detail a {
  text-decoration: underline;
  text-underline-offset: 2px;
}
.contact-form-panel {
  display: none;
}
.contact-form-panel.active {
  display: block;
}
.contact-form-panel label, .form-page-card label {
  display: block;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-ink);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.4rem;
}
.contact-tab-panel .form-cta, .contact-tab-panel .btn, .link-card .btn, .form-page-card .btn {
  min-width: min(100%, 17rem);
}
.form-page-card input, .form-page-card textarea, .form-page-card select, .contact-form-panel input, .contact-form-panel textarea, .contact-form-panel select {
  min-height: 3.2rem;
  color: var(--color-body);
}
.form-page-card select, .contact-form-panel select {
  line-height: 1.35;
}
.req {
  color: var(--color-faint);
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.btn-full {
  width: 100%;
  text-align: center;
}
.form-step {
  display: none;
}
.form-step.active {
  display: block;
}
.form-step-label {
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-body);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--rule);
}
.form-step-nav {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 0.5rem;
}
.form-step-nav .btn {
  flex: 1;
  text-align: center;
}
.checkbox-grid {
  gap: 0.7rem;
}
.checkbox-label {
  align-items: flex-start;
  gap: 0.7rem;
  line-height: 1.35;
}
.checkbox-label input[type='checkbox'] {
  flex: 0 0 1.15rem;
  width: 1.15rem;
  height: 1.15rem;
  margin-top: 0.15rem;
}
.form-success {
  text-align: center;
  padding: 3rem 1rem;
}
.form-success h3 {
  margin-bottom: 0.5rem;
}
.form-success p {
  color: var(--color-muted);
}
.form-container {
  max-width: 700px;
  margin: 2rem auto 0;
}
.form-container form {
  display: block;
}
.form-container label {
  display: block;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-faint);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.4rem;
}
.form-container input, .form-container textarea, .form-container select {
  width: 100%;
  background-color: var(--color-white);
  font-family: var(--font-sans);
  color: var(--color-ink);
  font-size: 0.93rem;
  padding: 0.8rem 1rem;
  border: 1px solid var(--rule);
  margin-bottom: 1rem;
  transition: border-color 0.3s ease;
  border-radius: 0;
  -webkit-appearance: none;
}
.form-container input:focus, .form-container textarea:focus, .form-container select:focus {
  outline: none;
  border-color: var(--color-ink);
}
.form-container textarea {
  min-height: 120px;
  resize: vertical;
}
.form-container select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23555' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}
.mb-lg {
  margin-bottom: 1.5rem;
}
.link-cards {
  max-width: 1200px;
  margin: 2rem auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  padding: 0 var(--gap);
}
.link-cards > template {
  display: none;
}
.link-card {
  display: flex;
  overflow: hidden;
  background-color: var(--color-white);
  flex-direction: column;
  border-radius: 4px;
  border: 1px solid var(--rule);
  transition: border-color 0.3s ease, transform 0.25s ease, box-shadow 0.3s ease;
}
.link-card:hover {
  border-color: var(--color-ink);
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
}
.link-card-img {
  position: relative;
  height: 140px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: flex-end;
  padding: 1.2rem 1.5rem;
}
.link-card-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.55) 0%, transparent 100%);
}
.link-card-img h3 {
  position: relative;
  z-index: 1;
  color: #fff;
  font-size: 1.35rem;
  margin: 0;
  line-height: 1.2;
}
.link-card-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.3rem 1.5rem 1.5rem;
}
.link-card h3 {
  font-size: 1.35rem;
  margin-bottom: 0.6rem;
}
.link-card p {
  font-size: 0.93rem;
  color: var(--color-muted);
  line-height: 1.7;
  margin-bottom: 1.2rem;
  flex: 1;
}
.link-card-action {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-ink);
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: auto;
}
.image-cards {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  padding: 0 var(--gap);
}
.image-card:nth-child(even) {
  direction: rtl;
}
.image-card:nth-child(even) > * {
  direction: ltr;
}
.image-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--rule);
  border-radius: 4px;
  overflow: hidden;
  background-color: var(--color-white);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.image-card:hover {
  border-color: var(--color-ink);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}
.image-card img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
}
.image-card-body {
  padding: clamp(1.8rem, 3.5vw, 2.8rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.image-card-body h3 {
  font-size: clamp(1.8rem, 3.2vw, 2.6rem);
  margin-bottom: 0.75rem;
  color: var(--color-ink);
}
.image-card-body p {
  font-size: clamp(1.02rem, 1.35vw, 1.15rem);
  color: var(--color-body);
  line-height: 1.75;
  margin-bottom: 1.5rem;
}
.image-card-body .btn {
  align-self: flex-start;
}
@media (max-width: 900px) {
  .image-card {
    grid-template-columns: 1fr;
  }
  .image-card img {
    min-height: 220px;
  }
}
.contact-social {
  display: flex;
  gap: 0.8rem;
  margin-top: 1.5rem;
}
.contact-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--rule);
  border-radius: 50%;
  transition: all 0.3s ease;
}
.contact-social a:hover {
  background-color: var(--color-ink);
  border-color: var(--color-ink);
}
.contact-social svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: var(--color-ink);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.contact-social a:hover svg {
  stroke: var(--color-white);
}
.support-section {
  background-color: var(--color-ink);
  text-align: center;
  color: var(--color-cream);
  padding: var(--section-py) var(--gap);
}
.support-section h2 {
  color: var(--color-cream);
  margin-bottom: 1rem;
}
.support-inner {
  max-width: 600px;
  margin: 0 auto;
}
.support-inner > p {
  color: rgba(255, 255, 255, 0.7);
  max-width: 32rem;
  margin: 0 auto 2rem;
}
.support-inner .btn {
  margin-bottom: 1rem;
}
.support-inner small {
  display: block;
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.4);
  margin-top: 0.5rem;
}
.share-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  padding: 1.5rem 0;
  flex-wrap: wrap;
}
.share-bar-label {
  font-family: var(--font-sans);
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-faint);
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-right: 0.5rem;
}
.share-bar a, .share-bar button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--rule);
  cursor: pointer;
  color: var(--color-muted);
  transition: all 0.3s ease;
  position: relative;
  background: none;
}
.share-bar a:hover, .share-bar button:hover {
  background-color: var(--color-ink);
  color: var(--color-white);
  border-color: var(--color-ink);
}
.share-bar svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.share-bar--dark .share-bar-label {
  color: rgba(255, 255, 255, 0.4);
}
.share-bar--dark a, .share-bar--dark button {
  border-color: rgba(255, 255, 255, 0.2);
  color: rgba(255, 255, 255, 0.6);
}
.share-bar--dark a:hover, .share-bar--dark button:hover {
  background-color: var(--color-white);
  color: var(--color-ink);
  border-color: var(--color-white);
}
.share-bar .copy-tooltip {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--color-ink);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  color: var(--color-white);
  font-size: 0.6rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 0.25em 0.6em;
  border-radius: 3px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.share-bar .copy-tooltip.visible {
  opacity: 1;
}
.about-team {
  max-width: 1000px;
  margin: 2rem auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  padding: 0 var(--gap);
}
.about-team > template {
  display: none;
}
.about-team-member {
  text-align: center;
  padding: 1.5rem 1rem 2rem;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  border-radius: 6px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.about-team-member:hover {
  border-color: var(--color-ink);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}
.about-team-photo {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto 1rem;
  display: block;
}
.about-team-member h3 {
  font-size: 1.3rem;
  margin-bottom: 0.15rem;
  color: var(--color-ink);
}
.about-team-member .label {
  font-size: 0.78rem;
  margin-bottom: 0.6rem;
  display: block;
}
.about-team-member p {
  font-size: 0.9rem;
  color: var(--color-muted);
  line-height: 1.6;
  max-width: 300px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .about-team {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 480px) {
  .about-team {
    grid-template-columns: 1fr;
  }
}
.page-about .about-team-heading {
  color: var(--color-ink);
  max-width: 12ch;
  margin: clamp(3rem, 6vw, 4.5rem) auto clamp(2rem, 4vw, 2.75rem);
  font-size: clamp(2.6rem, 5vw, 4.25rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-wrap: balance;
}
.page-about .about-team {
  max-width: 1180px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
  align-items: stretch;
}
.page-about .about-team-member {
  width: auto !important;
  min-height: 0;
  padding: 1.65rem 1.35rem 1.5rem;
  text-align: left;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0.35rem;
  border-radius: 14px;
}
.page-about .about-team-name {
  font-size: clamp(2rem, 2.4vw, 2.45rem);
  line-height: 1.04;
  margin-bottom: 0.15rem;
}
.page-about .about-team-role {
  padding-top: 0;
  padding-bottom: 0.2rem;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  color: var(--color-ink);
}
.page-about .about-team-bio {
  font-size: 1rem;
  line-height: 1.65;
  max-width: none;
  margin: 0;
  color: var(--color-body);
}
@media (max-width: 768px) {
  .page-about .about-team {
    grid-template-columns: 1fr;
    gap: 0.9rem;
  }
  .page-about .about-team-heading {
    max-width: 10ch;
    margin: 2.5rem auto 1.6rem;
  }
  .page-about .about-team-member {
    padding: 1.35rem 1.1rem 1.2rem;
  }
}
.exhibit, .exhibit-dark {
  padding: clamp(5rem, 10vh, 8rem) var(--gap);
  max-width: 1200px;
  margin: 0 auto;
}
.exhibit-dark {
  max-width: none;
  background-color: var(--color-ink);
  color: #fff;
}
.exhibit-dark .exhibit-inner {
  max-width: 1200px;
  margin: 0 auto;
}
.exhibit-plaque {
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.exhibit-plaque .label {
  margin-bottom: 0.5rem;
}
.exhibit-dark .exhibit-plaque .label {
  color: rgba(255, 255, 255, 0.6);
}
.exhibit-plaque h2 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 400;
  line-height: 1.1;
  margin-bottom: 1rem;
}
.exhibit-plaque p {
  max-width: 540px;
  color: var(--color-muted);
  font-size: 1.1rem;
  line-height: 1.75;
}
.exhibit-dark .exhibit-plaque p {
  color: rgba(255, 255, 255, 0.8);
}
.exhibit-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
  margin-bottom: clamp(3rem, 6vw, 5rem);
}
.exhibit-split-reverse {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
  margin-bottom: clamp(3rem, 6vw, 5rem);
}
.exhibit-split-reverse .exhibit-split-text {
  order: 2;
}
.exhibit-split-reverse .exhibit-split-media {
  order: 1;
}
.exhibit-split-text .label {
  margin-bottom: 0.5rem;
}
.exhibit-split-text h2 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 400;
  line-height: 1.1;
  margin-bottom: 1rem;
}
.exhibit-split-text p {
  color: var(--color-muted);
  font-size: 1.1rem;
  line-height: 1.75;
  max-width: 580px;
}
.exhibit-dark .exhibit-split-text h2 {
  color: #fff;
}
.exhibit-dark .exhibit-split-text .label {
  color: rgba(255, 255, 255, 0.6);
}
.exhibit-dark .exhibit-split-text p {
  color: rgba(255, 255, 255, 0.8);
}
.exhibit-split-media img {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 4px;
  object-fit: cover;
}
.exhibit-pano {
  overflow: hidden;
  border-radius: 4px;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-pano img {
  width: 100%;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  display: block;
}
.exhibit-before-after {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-before-after figure {
  position: relative;
  border-radius: 4px;
  overflow: hidden;
}
.exhibit-before-after img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.exhibit-before-after figcaption {
  position: absolute;
  bottom: 0.75rem;
  left: 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0, 0, 0, 0.55);
  padding: 0.3rem 0.65rem;
  border-radius: 3px;
}
.exhibit-feature {
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-feature img {
  width: 100%;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  display: block;
}
.exhibit-grid-2, .exhibit-grid-3 {
  display: grid;
  gap: 1.5rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-grid-2 {
  grid-template-columns: 1fr 1fr;
}
.exhibit-grid-3 {
  grid-template-columns: 1fr 1fr 1fr;
}
.exhibit-grid-2-1 {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1.5rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-grid-1-2 {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 1.5rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-grid-2 img, .exhibit-grid-3 img, .exhibit-grid-2-1 img, .exhibit-grid-1-2 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 4px;
  aspect-ratio: 4 / 3;
}
.exhibit-mosaic {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 200px;
  gap: 1rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}
.exhibit-mosaic img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}
.exhibit-mosaic .span-2-rows {
  grid-row: span 2;
}
.exhibit-mosaic .span-2-cols {
  grid-column: span 2;
}
.exhibit-divider {
  position: relative;
  height: 70vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.exhibit-divider picture, .exhibit-divider img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.exhibit-divider blockquote {
  position: relative;
  z-index: 2;
  color: #fff;
  text-align: center;
  max-width: 640px;
  padding: 0 2rem;
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.45;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.6);
}
.exhibit-divider::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 1;
}
.exhibit-stats {
  display: flex;
  gap: clamp(2rem, 4vw, 4rem);
  justify-content: center;
  text-align: center;
  padding: clamp(2rem, 4vw, 3rem) 0;
  margin-bottom: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.exhibit-dark .exhibit-stats {
  border-color: rgba(255, 255, 255, 0.15);
}
.exhibit-stat-num {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 400;
  line-height: 1;
  color: var(--color-ink);
  margin-bottom: 0.35rem;
}
.exhibit-dark .exhibit-stat-num {
  color: #fff;
}
.exhibit-stat-label {
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.exhibit-dark .exhibit-stat-label {
  color: rgba(255, 255, 255, 0.6);
}
.article {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--gap);
}
.article p {
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  line-height: 1.8;
  color: var(--color-body);
  margin-bottom: 1.6rem;
}
.article p.lead {
  font-size: clamp(1.2rem, 1.8vw, 1.4rem);
  color: var(--color-ink);
  line-height: 1.65;
}
.article h2 {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  line-height: 1.15;
  margin: clamp(3rem, 6vw, 5rem) 0 1.5rem;
  color: var(--color-ink);
}
.article h3 {
  font-family: var(--font-serif);
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 400;
  line-height: 1.25;
  margin: 2.5rem 0 1rem;
  color: var(--color-ink);
}
.article-wide {
  max-width: 1100px;
  margin: clamp(2rem, 4vw, 3.5rem) auto;
  padding: 0 var(--gap);
}
.article-wide img {
  width: 100%;
  border-radius: 4px;
  display: block;
}
.article-bleed {
  width: 100%;
  margin: clamp(2.5rem, 5vw, 4rem) 0;
  overflow: hidden;
}
.article-bleed img {
  width: 100%;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  display: block;
}
.article-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.article-pair img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 4px;
}
.article-pullquote {
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.4;
  color: var(--color-ink);
  border-left: 3px solid var(--color-ink);
  padding-left: clamp(1.2rem, 2vw, 2rem);
  margin: clamp(2.5rem, 5vw, 4rem) 0;
  max-width: 600px;
}
.article-stats {
  display: flex;
  gap: clamp(3rem, 6vw, 5rem);
  justify-content: center;
  text-align: center;
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  margin: clamp(2rem, 4vw, 3rem) 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.article-stat-num {
  font-family: var(--font-serif);
  font-size: clamp(2.8rem, 5vw, 4rem);
  font-weight: 400;
  line-height: 1;
  color: var(--color-ink);
  margin-bottom: 0.35rem;
}
.article-stat-label {
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted);
}
@media (max-width: 768px) {
  .article-pair {
    grid-template-columns: 1fr;
  }
  .article-stats {
    flex-direction: column;
    gap: 1.5rem;
  }
  .article-bleed img {
    aspect-ratio: 16 / 9;
  }
}
.impact-feed {
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(3rem, 6vw, 5rem) var(--gap);
}
.impact-moment {
  margin-bottom: clamp(5rem, 10vw, 8rem);
}
.impact-moment:last-child {
  margin-bottom: 0;
}
.impact-moment picture, .impact-moment > img {
  width: 100%;
  display: block;
}
.impact-moment img {
  width: 100%;
  object-fit: cover;
  border-radius: 3px;
}
.impact-caption {
  max-width: 720px;
  padding-top: clamp(1.5rem, 3vw, 2.2rem);
}
.impact-caption p {
  font-family: var(--font-serif);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  line-height: 1.6;
  color: var(--color-ink);
  margin: 0;
}
.impact-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(0.75rem, 1.5vw, 1.25rem);
}
.impact-pair img {
  aspect-ratio: 4 / 3;
}
.impact-trio {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: clamp(0.75rem, 1.5vw, 1.25rem);
}
.impact-trio img {
  aspect-ratio: 3 / 2;
}
.impact-trio .impact-stack {
  display: grid;
  gap: clamp(0.75rem, 1.5vw, 1.25rem);
}
.impact-trio .impact-stack img {
  aspect-ratio: auto;
  height: 100%;
}
@media (max-width: 768px) {
  .impact-pair {
    grid-template-columns: 1fr;
  }
  .impact-trio {
    grid-template-columns: 1fr;
  }
}
.impact-intro {
  padding: clamp(3rem, 6vw, 5rem) var(--gap);
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}
.impact-intro h2 {
  font-size: clamp(2.2rem, 4.5vw, 3.4rem);
  line-height: 1.15;
  margin-bottom: 1rem;
}
.impact-intro p {
  font-size: clamp(1.05rem, 1.5vw, 1.15rem);
  line-height: 1.7;
  color: var(--color-body);
}
.impact-notebook-section {
  position: relative;
  padding: clamp(2rem, 4vw, 4rem) 0;
}
.impact-notebook-wrap {
  max-width: 75%;
  margin: 0 auto;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--rule);
  height: clamp(420px, 52vh, 560px);
}
.impact-notebook {
  display: grid;
  grid-template-columns: 240px 1fr;
  height: 100%;
  background-color: var(--color-cream);
}
.impact-nav {
  border-right: 1px solid var(--rule);
  padding: 1.5rem 0;
  overflow-y: auto;
  background-color: var(--color-cream);
}
.impact-nav-item {
  display: block;
  padding: 1rem 1.5rem;
  cursor: pointer;
  --tw-border-style: none;
  border-style: none;
  border-left: 3px solid transparent;
  background: none;
  width: 100%;
  text-align: left;
  font-family: var(--font-serif);
  font-size: 1.15rem;
  color: var(--color-muted);
  transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
  line-height: 1.3;
}
.impact-nav-item:hover {
  color: var(--color-ink);
  background: var(--sand);
  border-left-color: var(--rule);
}
.impact-nav-item.active {
  color: var(--color-ink);
  background-color: var(--color-white);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  border-left-color: var(--color-ink);
}
.impact-nav-item .nav-label {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.6rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 0.15rem;
}
.impact-nav-item.active .nav-label {
  color: var(--color-body);
}
.impact-content {
  background-color: var(--color-white);
  overflow: hidden;
}
.impact-entry {
  display: none;
  animation: impactFadeIn 0.35s ease;
}
.impact-entry.active {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  height: 100%;
}
@keyframes impactFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.impact-entry-text {
  padding: clamp(1.2rem, 2.5vw, 2rem);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.impact-entry-header {
  margin-bottom: 1.2rem;
}
.impact-entry-header .label {
  margin-bottom: 0.25rem;
}
.impact-entry-header h3 {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  line-height: 1.15;
  margin-bottom: 0.5rem;
}
.impact-entry-header p {
  font-size: clamp(0.88rem, 1.2vw, 0.98rem);
  line-height: 1.6;
  color: var(--color-body);
}
.impact-entry-body {
  flex: 1;
}
.impact-entry-body p {
  font-size: clamp(0.85rem, 1.1vw, 0.95rem);
  line-height: 1.65;
  color: var(--color-body);
  margin-bottom: 0.8rem;
}
.impact-entry-body p:last-child {
  margin-bottom: 0;
}
.impact-entry-text::-webkit-scrollbar {
  width: 3px;
}
.impact-entry-text::-webkit-scrollbar-track {
  background: transparent;
}
.impact-entry-text::-webkit-scrollbar-thumb {
  background: var(--rule);
  border-radius: 2px;
}
.impact-entry-text {
  scrollbar-width: thin;
  scrollbar-color: var(--rule) transparent;
}
.impact-entry-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(40px, 100px);
  gap: 3px;
  padding: 0.5rem;
  border-left: 1px solid var(--rule);
  align-content: center;
  overflow: hidden;
}
.impact-entry-gallery picture {
  overflow: hidden;
  border-radius: 2px;
  cursor: pointer;
  min-height: 0;
  position: relative;
}
.impact-entry-gallery picture::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  transition: background 0.3s ease;
}
.impact-entry-gallery picture:hover::after {
  background: rgba(0, 0, 0, 0.08);
}
.impact-entry-gallery picture:first-child {
  grid-column: span 2;
  grid-row: span 2;
}
.impact-entry-gallery img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s ease;
}
.impact-entry-gallery picture:hover img {
  transform: scale(1.04);
}
.impact-entry-gallery picture:nth-child(n + 7) {
  display: none;
}
.share-widget {
  transition: opacity 0.4s ease;
}
.share-widget.hidden {
  opacity: 0 !important;
  pointer-events: none !important;
}
.impact-cta {
  padding: clamp(3rem, 6vw, 5rem) var(--gap);
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}
.impact-cta h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  line-height: 1.2;
  margin-bottom: 1rem;
}
.impact-cta p {
  font-size: clamp(0.95rem, 1.3vw, 1.1rem);
  line-height: 1.65;
  color: var(--color-body);
  margin-bottom: 2rem;
}
.impact-cta-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
@media (max-width: 1100px) {
  .impact-notebook-wrap {
    max-width: 90%;
  }
}
@media (max-width: 900px) {
  .impact-notebook-wrap {
    max-width: 100%;
    margin: 0;
    border-radius: 0;
    border-left: none;
    border-right: none;
    height: auto;
    min-height: 60vh;
  }
  .impact-notebook {
    grid-template-columns: 1fr;
    height: auto;
    min-height: inherit;
  }
  .impact-nav {
    border-right: none;
    border-bottom: 1px solid var(--rule);
    display: flex;
    overflow-x: auto;
    padding: 0;
    gap: 0;
  }
  .impact-nav-item {
    white-space: nowrap;
    padding: 0.9rem 1.1rem;
    font-size: 1rem;
    border-left: none;
  }
  .impact-nav-item .nav-label {
    display: none;
  }
  .impact-nav-item.active {
    background-color: var(--color-white);
    border-left: none;
    border-bottom: 2px solid var(--color-ink);
  }
  .impact-entry.active {
    grid-template-columns: 1fr;
    height: auto;
  }
  .impact-entry-gallery {
    border-left: none;
    border-top: 1px solid var(--rule);
    min-height: 200px;
    height: auto;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: minmax(60px, 90px);
    padding: 3px;
  }
}
.exhibit-reveal {
  opacity: 0;
  transform: translateY(40px);
}
.impact-page-intro {
  padding: clamp(9rem, 16vh, 12rem) var(--gap) clamp(3rem, 6vh, 4rem);
  text-align: center;
  max-width: 56rem;
  margin: 0 auto;
}
.impact-page-intro h1 {
  margin-bottom: 1.2rem;
}
.impact-page-intro p {
  max-width: 38rem;
  margin: 0 auto;
  color: var(--color-muted);
}
body.page-impact section h1 {
  font-size: 100px;
  line-height: 95px;
}
section.impact-page-intro {
  padding-top: 150px;
  padding-left: 0;
  padding-right: 0;
}
body.page-impact section p {
  width: 100%;
}
@media (max-width: 768px) {
  .exhibit-split, .exhibit-split-reverse {
    grid-template-columns: 1fr;
  }
  .exhibit-split-reverse .exhibit-split-text {
    order: 1;
  }
  .exhibit-split-reverse .exhibit-split-media {
    order: 2;
  }
  .exhibit-before-after, .exhibit-grid-2, .exhibit-grid-3, .exhibit-grid-2-1, .exhibit-grid-1-2 {
    grid-template-columns: 1fr;
  }
  .exhibit-mosaic {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 160px;
  }
  .exhibit-mosaic .span-2-cols {
    grid-column: span 1;
  }
  .exhibit-stats {
    flex-direction: column;
    gap: 1.5rem;
  }
  .exhibit-divider {
    height: 50vh;
  }
}
.form-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.form-page-body {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem var(--gap);
}
.form-page-card {
  width: 100%;
  max-width: 640px;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: clamp(2rem, 4vw, 3rem);
}
.form-page-card h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  margin-bottom: 0.5rem;
}
.form-page-card > p {
  color: var(--color-muted);
  margin-bottom: 2rem;
}
.form-page-progress {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2rem;
}
.form-page-progress-step {
  flex: 1;
  height: 3px;
  background: var(--rule);
  border-radius: 2px;
  transition: background 0.3s ease;
}
.form-page-progress-step.active {
  background-color: var(--color-ink);
}
.share-widget {
  position: fixed;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 900;
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}
.share-widget.visible {
  opacity: 1;
  pointer-events: auto;
}
.share-tab {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 0.35rem;
  background-color: var(--color-white);
  color: var(--color-body);
  border: 1px solid var(--rule);
  border-left: none;
  border-radius: 0 6px 6px 0;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background 0.2s ease;
  white-space: nowrap;
  writing-mode: vertical-lr;
  text-orientation: sideways;
}
.share-tab svg {
  width: 12px;
  height: 12px;
  fill: none;
  stroke: var(--body);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.share-tab:hover {
  background: var(--sand);
}
.share-panel {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%) translateX(-100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  border-left: none;
  border-radius: 0 8px 8px 0;
  box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.06);
  padding: 0.4rem 0.35rem;
  opacity: 0;
  pointer-events: none;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.share-panel.open {
  transform: translateY(-50%) translateX(0);
  opacity: 1;
  pointer-events: auto;
}
.share-panel-header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 0.1rem;
  width: 100%;
}
.share-panel-title {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
  white-space: nowrap;
}
.share-panel-close {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  cursor: pointer;
  color: var(--color-muted);
  border-radius: 50%;
  transition: background 0.2s ease;
  flex-shrink: 0;
  position: absolute;
  top: -8px;
  right: -8px;
  z-index: 2;
  padding: 0;
}
.share-panel-close:hover {
  background: var(--sand);
}
.share-panel-close svg {
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  fill: none;
}
.share-panel-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
}
.share-panel-links a, .share-panel-links button {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--rule);
  background-color: var(--color-white);
  color: var(--color-body);
  cursor: pointer;
  text-decoration: none;
  font-size: 0;
  position: relative;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.share-panel-links a:hover, .share-panel-links button:hover {
  background: var(--sand);
  border-color: var(--body);
}
.share-panel-links svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  fill: none;
  stroke: var(--body);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.share-panel-links .copy-tooltip {
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.55rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background-color: var(--color-ink);
  color: var(--color-white);
  padding: 0.25em 0.5em;
  border-radius: 3px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.share-panel-links .copy-tooltip.visible {
  opacity: 1;
}
@media (max-width: 768px) {
  .share-widget {
    display: none;
  }
}
.impact-story {
  position: relative;
  min-height: 85vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.impact-story img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.impact-story::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient( to top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.15) 50%, transparent 100% );
  z-index: 1;
}
.impact-story-text {
  position: relative;
  z-index: 2;
  max-width: 680px;
  padding: clamp(2rem, 5vw, 4rem) clamp(2rem, 5vw, 5rem);
}
.impact-story-text .label {
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 0.75rem;
}
.impact-story-text h2 {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  line-height: 1.15;
  color: #fff;
  margin-bottom: 1rem;
}
.impact-story-text p {
  font-size: clamp(0.95rem, 1.2vw, 1.1rem);
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.85);
}
.impact-offset {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(4rem, 8vw, 7rem) var(--gap);
}
.impact-offset-text {
  padding-right: clamp(2rem, 4vw, 4rem);
}
.impact-offset-text .label {
  margin-bottom: 0.5rem;
}
.impact-offset-text h2 {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 400;
  line-height: 1.15;
  color: var(--color-ink);
  margin-bottom: 1rem;
}
.impact-offset-text p {
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--color-body);
}
.impact-offset-media {
  position: relative;
}
.impact-offset-media img {
  width: 100%;
  border-radius: 4px;
  object-fit: cover;
  aspect-ratio: 3 / 4;
}
.impact-offset-media .impact-offset-secondary {
  position: absolute;
  bottom: -2rem;
  left: -3rem;
  width: 55%;
  border-radius: 4px;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.impact-narrative {
  max-width: 900px;
  margin: 0 auto;
  padding: clamp(5rem, 10vw, 8rem) var(--gap);
  text-align: center;
}
.impact-narrative h2 {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--color-ink);
  margin-bottom: 1.5rem;
}
.impact-narrative p {
  font-size: clamp(1.05rem, 1.4vw, 1.15rem);
  line-height: 1.8;
  color: var(--color-body);
  max-width: 720px;
  margin: 0 auto;
}
.impact-mosaic-wide {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--gap);
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: clamp(0.5rem, 1vw, 1rem);
}
.impact-mosaic-wide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 3px;
}
.impact-mosaic-wide img:first-child {
  grid-row: span 2;
}
@media (max-width: 768px) {
  .impact-story {
    min-height: 70vh;
  }
  .impact-offset {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .impact-offset-text {
    padding-right: 0;
  }
  .impact-offset-media .impact-offset-secondary {
    position: static;
    width: 100%;
    margin-top: 0.75rem;
    box-shadow: none;
  }
  .impact-mosaic-wide {
    grid-template-columns: 1fr;
  }
  .impact-mosaic-wide img:first-child {
    grid-row: auto;
  }
}
.impact-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 5vw, 4.5rem);
  align-items: center;
  max-width: 1320px;
  margin: 0 auto;
  padding: clamp(3rem, 6vw, 4.5rem) var(--gap);
}
.impact-block.reverse .impact-block-text {
  order: 2;
}
.impact-block.reverse .impact-block-gallery {
  order: 1;
}
.impact-block-text {
  max-width: 48ch;
}
.impact-block-text .label {
  margin-bottom: 0.5rem;
}
.impact-block-text h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.5rem, 2.8vw, 2.2rem);
  font-weight: 400;
  line-height: 1.15;
  margin-bottom: 1rem;
  color: var(--color-ink);
}
.impact-block-text h2 em {
  font-style: italic;
  --tw-font-weight: var(--font-weight-light);
  font-weight: var(--font-weight-light);
}
.impact-block-text p {
  font-size: clamp(0.95rem, 1.2vw, 1.08rem);
  line-height: 1.75;
  color: var(--color-body);
}
.impact-block-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.impact-block-gallery img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 3px;
}
.impact-block-gallery figure {
  position: relative;
  border-radius: 3px;
  overflow: hidden;
}
.impact-block-gallery figure img {
  border-radius: 0;
}
.impact-block-gallery figcaption {
  position: absolute;
  bottom: 0.4rem;
  left: 0.4rem;
  font-family: var(--font-sans);
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0, 0, 0, 0.55);
  padding: 0.2rem 0.5rem;
  border-radius: 2px;
}
@media (max-width: 768px) {
  .impact-block {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  .impact-block.reverse .impact-block-text {
    order: 1;
  }
  .impact-block.reverse .impact-block-gallery {
    order: 2;
  }
}
.pullquote-section {
  padding: calc(4rem + 72px) clamp(1.5rem, 4vw, 3rem) 4rem;
  text-align: center;
  background-color: var(--color-cream);
}
.pullquote-section blockquote {
  max-width: 760px;
  margin: 0 auto;
}
.pullquote-section blockquote p {
  font-family: var(--font-serif);
  font-size: clamp(1.8rem, 4.5vw, 3rem);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  font-style: italic;
  color: var(--color-ink);
  line-height: 1.3;
  margin-bottom: 1rem;
}
.pullquote-section blockquote cite {
  font-family: var(--font-sans);
  font-size: 21px;
  font-style: normal;
  color: var(--color-muted);
  line-height: 1.7;
  max-width: 640px;
  display: block;
  margin: 40px auto 0;
}
@media (max-width: 768px) {
  .pullquote-section {
    padding: calc(3rem + 60px) 1.25rem 3rem;
  }
}
.scrollstack-section {
  position: relative;
  z-index: 1;
  padding-top: 1.75rem;
}
.scrollstack-intro-wrap {
  position: sticky;
  top: 60px;
  z-index: 20;
  margin-top: 30px;
  padding-bottom: 0.35rem;
  margin-bottom: 60px;
  padding-top: 20px;
}
.scrollstack-intro {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
  padding: 1rem 1.5rem 0.3rem;
}
.scrollstack-intro .label {
  margin-bottom: 0.25rem;
  font-size: clamp(0.7rem, 1.2vw, 0.85rem);
}
.scrollstack-intro h2 {
  font-size: 60px;
  margin-bottom: 0.3rem;
}
.scrollstack-intro p {
  color: var(--body);
  max-width: 42rem;
  margin: 0 auto 1rem;
  font-weight: 450;
  font-size: clamp(1.05rem, 1.35vw, 1.22rem);
  line-height: 1.6;
}
.scrollstack {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 6rem;
}
.scrollstack-card {
  width: min(90%, 800px);
  flex-shrink: 0;
  border-radius: 14px;
  padding: 2.15rem clamp(1.35rem, 2vw, 2rem);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  color: var(--color-ink);
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.1);
  position: relative;
  z-index: 10;
  box-sizing: border-box;
  margin: 0 auto;
  min-height: 214px;
  transform-origin: top center;
  backface-visibility: hidden;
  will-change: transform, filter;
  transition: background 0.4s ease, color 0.4s ease, box-shadow 0.4s ease;
}
.scrollstack-end {
  width: 1px;
  height: 1px;
  pointer-events: none;
}
.scrollstack-card.scrollstack-dark .scrollstack-badge, .scrollstack-card.scrollstack-dark h2 {
  color: var(--color-white);
}
.scrollstack-card.scrollstack-dark p {
  color: rgba(255, 255, 255, 0.75);
}
.scrollstack-card.scrollstack-dark {
  background: #1a1a1a;
  color: rgba(255, 255, 255, 0.85);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}
.scrollstack-card-content {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2.5vw, 2rem);
  max-width: 100%;
  width: 100%;
}
.scrollstack-badge {
  font-family: var(--font-serif);
  font-size: clamp(7.6rem, 21vw, 16.5rem);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  line-height: 0.9;
  flex-shrink: 0;
  min-width: 1em;
  text-align: center;
}
.scrollstack-card-text h2 {
  font-family: var(--font-serif);
  font-size: clamp(1.56rem, 3.1vw, 2.47rem);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  margin-bottom: 0.4rem;
}
.scrollstack-card-text p {
  font-family: var(--font-sans);
  font-size: clamp(1.1rem, 1.56vw, 1.3rem);
  font-weight: 400;
  line-height: 1.55;
  opacity: 0.85;
}
.scrollstack-cta {
  text-align: center;
  margin-top: 22px;
  padding: 1.6rem 1.5rem 2.5rem;
  position: relative;
  z-index: 30;
}
.scrollstack-cta p {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--color-ink);
  margin-bottom: 18px;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
}
.scrollstack-cta .btn {
  display: inline-block;
  font-size: 1.2rem;
  padding: 1rem 2.5rem;
}
@media (max-width: 768px) {
  .scrollstack-intro-wrap {
    top: 60px;
  }
  .scrollstack-intro {
    padding: 0.3rem 1rem 0.2rem;
  }
  .scrollstack-intro h2 {
    font-size: clamp(1.3rem, 6vw, 2rem);
  }
  .scrollstack-card {
    width: min(92%, 520px);
    padding: 1.8rem 1.2rem;
    min-height: 200px;
  }
  .scrollstack-card-content {
    flex-direction: column;
    text-align: center;
    gap: 0.5rem;
  }
  .scrollstack-badge {
    font-size: clamp(3.5rem, 16vw, 6rem);
  }
  .scrollstack-card-text h2 {
    font-size: clamp(1rem, 4vw, 1.4rem);
  }
  .scrollstack-card-text p {
    font-size: 0.85rem;
    line-height: 1.45;
  }
}
.hscroll-section {
  overflow: hidden;
  background: transparent;
  position: relative;
}
.brand-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-ink);
  z-index: 5;
  opacity: 0;
  pointer-events: none;
  text-align: center;
  color: var(--color-cream);
  overflow: visible;
}
.brand-overlay-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0;
  transform-origin: center center;
  overflow: hidden;
  will-change: transform, clip-path, filter;
}
.brand-overlay-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.brand-overlay-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(17, 17, 17, 0.7);
}
.brand-inner {
  position: relative;
  z-index: 1;
  pointer-events: auto;
  padding: 1.2rem 0.2rem 0.7rem;
  max-width: 760px;
  will-change: transform;
  backface-visibility: hidden;
}
.brand-card {
  position: absolute;
  inset: -1.35rem -1.1rem;
  background: rgba(250, 250, 248, 0.96);
  border-radius: 12px;
  z-index: -1;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  will-change: transform, opacity;
  transform: translateZ(0);
}
.hscroll-track {
  display: flex;
  gap: 2.5rem;
  padding: 0 0 0 6vw;
  will-change: transform;
  height: 100vh;
  align-items: center;
}
.hscroll-intro {
  flex-shrink: 0;
  width: clamp(360px, 38vw, 520px);
  padding-right: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hscroll-intro p {
  max-width: 42rem;
  color: var(--body);
  font-size: clamp(1.05rem, 1.35vw, 1.22rem);
  line-height: 1.6;
  font-weight: 450;
  margin-top: 0.75rem;
}
.hscroll-outro {
  flex-shrink: 0;
  width: 100vw;
  margin-left: 0;
  padding-left: 0;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-ink);
  color: var(--color-cream);
  text-align: center;
}
.hscroll-outro-inner {
  padding: 3rem;
  max-width: 640px;
}
.hscroll-outro h2 {
  font-size: clamp(3rem, 7vw, 5.5rem);
  color: var(--color-cream);
  line-height: 1.1;
  margin-bottom: 1.25rem;
}
.hscroll-outro-inner > p {
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.7;
  margin-bottom: 2rem;
}
.hscroll-outro-actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
}
.hscroll-outro-contact {
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: 0.5rem;
}
.hscroll-outro-email {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-cream);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.3s ease;
}
.hscroll-outro-email:hover {
  opacity: 0.7;
}
.work-card {
  flex-shrink: 0;
  width: 520px;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--rule);
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 3px;
  transition: border-color 0.3s ease;
  align-self: center;
}
.work-card:hover {
  border-color: var(--color-ink);
}
.work-card-img {
  height: 380px;
  overflow: hidden;
}
.work-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.6s var(--ease);
}
.work-card:hover .work-card-img img {
  transform: scale(1.03);
}
.work-card-info {
  padding: 1.5rem 1.8rem;
}
.work-card-info .label {
  margin-bottom: 0.3rem;
}
.work-card-info h3 {
  font-size: clamp(1.7rem, 3vw, 2.15rem);
  margin-bottom: 0.5rem;
}
.work-card-sub {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-style: italic;
  font-weight: 400;
  color: var(--color-ink);
  margin-bottom: 0.6rem;
}
.work-card-info p:last-child {
  color: var(--color-body);
  font-size: 1.12rem;
  line-height: 1.7;
}
@media (max-width: 768px) {
  .work-card {
    width: 360px;
  }
  .work-card-img {
    min-height: 240px;
  }
  .hscroll-track {
    gap: 1.2rem;
    padding: 0 0 0 15px;
    min-height: auto;
  }
  .hscroll-intro {
    width: 280px;
    padding-right: 1rem;
  }
  .hscroll-outro {
    width: calc(100vw + 4rem);
    margin-left: -2rem;
  }
}
@media (max-width: 480px) {
  .work-card {
    width: 300px;
  }
  .work-card-img {
    min-height: 200px;
  }
  .work-card-info {
    padding: 1.2rem 1.4rem;
  }
  .hscroll-intro {
    width: 260px;
  }
}
.logo-bar {
  padding: clamp(2.5rem, 5vh, 4rem) var(--gap);
  background-color: var(--color-cream);
  overflow: hidden;
  position: relative;
}
.logo-bar::before, .logo-bar::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 15%;
  z-index: 2;
  pointer-events: none;
}
.logo-bar::before {
  left: 0;
  background: linear-gradient(to right, var(--cream), transparent);
}
.logo-bar::after {
  right: 0;
  background: linear-gradient(to left, var(--cream), transparent);
}
.logo-bar-label {
  text-align: center;
  margin-bottom: 1.5rem;
}
.logo-bar-track {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(3rem, 6vw, 6rem);
  flex-wrap: wrap;
}
.logo-bar-track img, .logo-bar-track picture img {
  height: clamp(28px, 3.5vw, 44px);
  width: auto;
  object-fit: contain;
  opacity: 0.35;
  filter: grayscale(100%);
  transition: opacity 0.4s ease, filter 0.4s ease;
}
.logo-bar-track img:hover, .logo-bar-track picture:hover img {
  opacity: 0.7;
  filter: grayscale(0%);
}
@media (max-width: 768px) {
  .logo-bar-track {
    gap: 2rem;
  }
  .logo-bar-track img, .logo-bar-track picture img {
    height: 24px;
  }
}
.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.92);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.gallery-lightbox.active {
  opacity: 1;
  pointer-events: auto;
}
.gallery-lightbox img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: 0.25rem;
}
.gallery-lightbox-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  cursor: pointer;
  z-index: 2;
}
.gallery-lightbox-close svg {
  width: 28px;
  height: 28px;
  stroke: #fff;
  stroke-width: 2;
  fill: none;
}
.gallery-lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  cursor: pointer;
  z-index: 2;
}
.gallery-lightbox-nav svg {
  width: 32px;
  height: 32px;
  stroke: #fff;
  stroke-width: 2;
  fill: none;
}
.gallery-lightbox-prev {
  left: 1rem;
}
.gallery-lightbox-next {
  right: 1rem;
}
.gallery-lightbox-caption {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255, 255, 255, 0.7);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  text-align: center;
  white-space: nowrap;
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track {
    animation-play-state: paused;
  }
  .carousel-track {
    animation-play-state: paused;
  }
  .rotating-badge svg {
    animation: none;
  }
  .scroll-cue-line::after {
    animation: none;
    opacity: 0.4;
    transform: translateY(0);
  }
  .jg-item {
    transition: none;
  }
  .jg-item img {
    transition: none;
  }
  .movement-bg {
    will-change: auto;
  }
  * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
}
.page-about .impact-page-intro, .page-get-involved .impact-page-intro {
  max-width: 1100px;
  padding-left: var(--gap);
  padding-right: var(--gap);
}
.page-about .impact-page-intro p, .page-get-involved .impact-page-intro p {
  max-width: 680px;
}
.page-about .about-story, .page-get-involved .image-cards {
  max-width: 1100px;
}
.page-about .about-story p {
  color: var(--color-body);
}
@media (max-width: 768px) {
  .page-about .about-story, .page-get-involved .image-cards {
    width: calc(100% - 2rem);
    padding-left: 0;
    padding-right: 0;
  }
}
.page-get-involved .image-card {
  opacity: 1 !important;
  transform: none !important;
  cursor: pointer;
}
.page-get-involved .image-card img, .page-get-involved .image-card > img {
  min-height: 340px;
  height: 340px;
}
.page-get-involved .image-card-body {
  min-height: 215px;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.page-get-involved .image-card-body .btn {
  pointer-events: none;
  margin-top: auto;
}
.page-get-involved .image-card p {
  color: var(--color-body);
}
@media (max-width: 768px) {
  .page-get-involved .image-card img, .page-get-involved .image-card > img {
    min-height: 300px;
    height: 300px;
  }
  .page-get-involved .image-card-body {
    min-height: 0;
  }
}
.page-community-support .split-copy, .page-sponsorship .split-copy, .page-special-donation .split-copy, .page-volunteer .split-copy, .page-message .split-copy, .page-contact .split-copy {
  text-align: left;
}
.page-community-support .split-copy p, .page-sponsorship .split-copy p, .page-special-donation .split-copy p, .page-volunteer .split-copy p, .page-message .split-copy p, .page-contact .split-copy p, .page-community-support .link-card p, .page-sponsorship .link-card p, .page-special-donation .link-card p, .page-volunteer .link-card p, .page-contact .link-card p {
  color: var(--color-body);
}
.page-community-support .split-copy h2, .page-sponsorship .split-copy h2, .page-special-donation .split-copy h2, .page-volunteer .split-copy h2, .page-message .split-copy h2, .page-contact .split-copy h2 {
  color: var(--color-ink);
}
@media (max-width: 768px) {
  .page-community-support .content-split.form-split .split-copy, .page-sponsorship .content-split.form-split .split-copy, .page-special-donation .content-split.form-split .split-copy, .page-volunteer .content-split.form-split .split-copy, .page-message .content-split.form-split .split-copy, .page-contact .content-split.form-split .split-copy {
    text-align: left;
  }
  .page-community-support .content-split.form-split .section-copy-lead, .page-sponsorship .content-split.form-split .section-copy-lead, .page-special-donation .content-split.form-split .section-copy-lead, .page-volunteer .content-split.form-split .section-copy-lead, .page-message .content-split.form-split .section-copy-lead, .page-contact .content-split.form-split .section-copy-lead {
    margin-left: 0;
    margin-right: 0;
    text-align: left;
  }
  .page-community-support .content-split.form-split .contact-stack, .page-sponsorship .content-split.form-split .contact-stack, .page-special-donation .content-split.form-split .contact-stack, .page-volunteer .content-split.form-split .contact-stack, .page-message .content-split.form-split .contact-stack, .page-contact .content-split.form-split .contact-stack {
    max-width: none;
    margin: 1.4rem 0 0;
  }
  .page-community-support .content-split.form-split .section-h2-tight, .page-sponsorship .content-split.form-split .section-h2-tight, .page-special-donation .content-split.form-split .section-h2-tight, .page-volunteer .content-split.form-split .section-h2-tight, .page-message .content-split.form-split .section-h2-tight, .page-contact .content-split.form-split .section-h2-tight {
    text-align: left;
  }
  .page-community-support .content-split.form-split .split-copy p, .page-sponsorship .content-split.form-split .split-copy p, .page-special-donation .content-split.form-split .split-copy p, .page-volunteer .content-split.form-split .split-copy p, .page-message .content-split.form-split .split-copy p, .page-contact .content-split.form-split .split-copy p, .page-community-support .content-split.form-split .split-copy .contact-text, .page-sponsorship .content-split.form-split .split-copy .contact-text, .page-special-donation .content-split.form-split .split-copy .contact-text, .page-volunteer .content-split.form-split .split-copy .contact-text, .page-message .content-split.form-split .split-copy .contact-text, .page-contact .content-split.form-split .split-copy .contact-text, .page-community-support .content-split.form-split .split-copy span:not(.label):not(.req), .page-sponsorship .content-split.form-split .split-copy span:not(.label):not(.req), .page-special-donation .content-split.form-split .split-copy span:not(.label):not(.req), .page-volunteer .content-split.form-split .split-copy span:not(.label):not(.req), .page-message .content-split.form-split .split-copy span:not(.label):not(.req), .page-contact .content-split.form-split .split-copy span:not(.label):not(.req) {
    text-align: left !important;
  }
}
.donate-immediate {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.donate-blurb h3 {
  margin-bottom: 1rem;
}
.donate-blurb ul {
  list-style-type: none;
  padding: 0;
  margin-bottom: 1.5rem;
}
.donate-blurb li {
  font-size: 1rem;
  color: var(--color-body);
  padding: 0.5rem 0;
  padding-left: 1.4rem;
  position: relative;
}
.donate-blurb li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.85rem;
  width: 6px;
  height: 6px;
  background-color: var(--color-ink);
  border-radius: 50%;
}
.donate-blurb .mail-option {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
  font-size: 0.93rem;
  color: var(--color-muted);
}
.donate-blurb .mail-option strong {
  display: block;
  color: var(--color-ink);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  margin-bottom: 0.3rem;
}
.donate-embed {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.donate-action-box {
  background: var(--sand);
  border-radius: 6px;
  padding: 2.5rem 2rem;
  text-align: center;
  width: 100%;
}
.donate-action-box h3 {
  margin-bottom: 0.75rem;
}
.donate-action-box > p {
  color: var(--color-muted);
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
}
.donate-action-sub {
  font-size: 0.82rem;
  color: var(--color-faint);
  margin-top: 0.75rem;
  margin-bottom: 1.5rem;
}
.donate-alt-links {
  display: flex;
  gap: 0.75rem;
  justify-content: center;
  flex-wrap: wrap;
}
.ways-section {
  position: relative;
}
.ways-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('Photos/nature-mountains.jpeg') center/cover no-repeat;
  opacity: 0.035;
  pointer-events: none;
  z-index: 0;
}
.ways-section > * {
  position: relative;
  z-index: 1;
}
.ways-grid {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.2rem;
}
.ways-item {
  padding: 1.8rem 2rem;
  border: 1px solid var(--rule);
  background-color: var(--color-white);
  transition: border-color 0.3s ease;
}
.ways-item:hover {
  border-color: var(--color-ink);
}
.ways-item h3 {
  font-size: 1.7rem;
  margin-bottom: 0.5rem;
}
.ways-item p {
  font-size: 1.05rem;
  color: var(--color-muted);
  line-height: 1.7;
}
.tax-info {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  padding: 2rem;
  font-size: 0.9rem;
  color: var(--color-faint);
}
.page-404 {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 8rem var(--gap) 4rem;
  background-color: var(--color-cream);
}
.page-404 img {
  width: 100%;
  max-width: 360px;
  border-radius: 4px;
  margin-bottom: 2.5rem;
}
.page-404 h1 {
  font-size: clamp(3rem, 7vw, 5rem);
  margin-bottom: 0.8rem;
}
.page-404 p {
  color: var(--color-muted);
  max-width: 28rem;
  margin-bottom: 2rem;
}
.page-404-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
}
.compare-section {
  padding: var(--section-py) var(--gap) clamp(2rem, 4vw, 3rem);
  background-color: var(--color-cream);
}
.compare-inner {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.compare-text .label {
  margin-bottom: 0.5rem;
}
.compare-text h2 {
  margin-bottom: 1rem;
}
.compare-text p {
  color: var(--color-muted);
  line-height: 1.75;
}
.compare-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.compare-images figure {
  position: relative;
  border-radius: 3px;
  overflow: hidden;
}
.compare-images img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4/5;
  display: block;
}
.compare-images figcaption {
  position: absolute;
  bottom: 0.75rem;
  left: 0.75rem;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0, 0, 0, 0.5);
  padding: 0.3rem 0.7rem;
  border-radius: 3px;
}
@media (max-width: 768px) {
  .compare-inner {
    grid-template-columns: 1fr;
  }
  .compare-images img {
    aspect-ratio: 3/4;
  }
}
.about-story {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 var(--gap) clamp(4rem, 8vw, 6rem);
}
.about-story-inner p {
  font-size: clamp(1.05rem, 1.3vw, 1.15rem);
  line-height: 1.85;
  color: var(--color-body);
  margin-bottom: 1.5rem;
}
.about-story-inner .about-lead {
  font-family: var(--font-serif);
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
  line-height: 1.55;
  color: var(--color-ink);
  margin-bottom: 2rem;
}
.about-story-img {
  border-radius: 4px;
  margin: 0.5rem 0 1.5rem;
}
.about-story-img.float-right {
  float: right;
  width: 45%;
  margin-left: 2rem;
  margin-bottom: 1rem;
}
.about-story-img.float-left {
  float: left;
  width: 45%;
  margin-right: 2rem;
  margin-bottom: 1rem;
}
.about-story-inner .clear {
  clear: both;
}
.about-story-inner .movement-section-heading {
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  line-height: 1.2;
  color: var(--color-ink);
  margin: 2.5rem 0 1rem;
  letter-spacing: -0.01em;
}
.about-story-inner .movement-section-heading:first-child {
  margin-top: 0;
}
@media (max-width: 768px) {
  .about-story-img.float-right, .about-story-img.float-left {
    float: none;
    width: 100%;
    margin: 1rem 0 1.5rem;
  }
  .about-story-inner .movement-section-heading {
    font-size: 1.5rem;
    margin: 2rem 0 0.75rem;
  }
}
.impact-logo-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(2rem, 4vw, 3.5rem);
  flex-wrap: nowrap;
  margin-top: 2.5rem;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.impact-logo-row a {
  display: inline-flex;
  line-height: 0;
  flex-shrink: 0;
}
.impact-logo-row img {
  height: 36px;
  width: auto;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.6;
  transition: opacity 0.3s ease;
}
.impact-logo-row a:hover img {
  opacity: 1;
}
@media (max-width: 768px) {
  .impact-logo-row {
    flex-wrap: wrap;
    gap: 1.5rem;
  }
  .impact-logo-row img {
    height: 26px;
  }
}
body.page-home {
  --home-title-line-height: 1.15;
  --home-title-track: -0.01em;
  --home-oneliner-size: clamp(1.05rem, 1.35vw, 1.22rem);
  --home-oneliner-line: 1.6;
  --home-oneliner-weight: 450;
  --home-btn-font-size: 1.08rem;
  --home-btn-pad-y: 0.9rem;
  --home-btn-pad-x: 1.9rem;
  --home-btn-radius: 6px;
}
body.page-home .section-title-ink, body.page-home .hscroll-intro h2, body.page-home .scrollstack-intro h2, body.page-home .pullquote-section blockquote p, body.page-home .faq-section .content-inner h2, .final-cta-content h2 {
  line-height: var(--home-title-line-height);
  letter-spacing: var(--home-title-track);
}
body.page-home .section-oneliner, body.page-home .hscroll-intro p, body.page-home .scrollstack-intro p {
  color: var(--body);
  max-width: 42rem;
  font-weight: var(--home-oneliner-weight);
  font-size: var(--home-oneliner-size);
  line-height: var(--home-oneliner-line);
}
body.page-home .hero-canvas {
  opacity: 0.3;
}
body.page-home .hero-heading {
  font-size: calc(clamp(3.2rem, 8vw, 7.5rem) - 5px);
  line-height: 0.98;
  margin-bottom: 2.2rem;
  max-width: 58vw;
}
body.page-home .hero-heading .reveal-line:nth-child(2) .outline-fill {
  font-size: 115px;
  margin-top: 10px;
  display: inline-block;
}
body.page-home .hero-sub {
  margin-top: -20px;
}
body.page-home .scrollstack-card {
  width: min(90%, 800px);
  padding: 2.15rem clamp(1.35rem, 2vw, 2rem);
  min-height: 214px;
}
body.page-home .scrollstack-badge {
  font-size: clamp(7.6rem, 21vw, 16.5rem);
}
body.page-home .scrollstack-cta {
  margin-top: 22px;
  padding: 1.6rem 1.5rem 2.5rem;
}
body.page-home .scrollstack-cta p {
  margin-bottom: 18px;
}
body.page-home .btn, body.page-impact .btn {
  font-size: var(--home-btn-font-size);
  padding: var(--home-btn-pad-y) var(--home-btn-pad-x);
  border-radius: var(--home-btn-radius);
}
body.page-home .hero-foot .btn, body.page-home .movement-right .btn, body.page-home .hscroll-outro-actions .btn, body.page-home .brand-overlay .btn, body.page-home .scrollstack-cta .btn, body.page-impact .final-cta-actions .btn, .final-cta-actions .btn, .footer-newsletter-form .btn {
  font-size: var(--home-btn-font-size);
  padding: var(--home-btn-pad-y) var(--home-btn-pad-x);
}
.footer > .footer-newsletter {
  padding: 1rem 0 1.6rem;
  gap: 1.25rem;
}
.footer > .footer-newsletter .footer-newsletter-title {
  line-height: 1.05;
  margin-bottom: 0.12rem;
}
.footer-newsletter-form {
  align-items: center;
  gap: 0.75rem;
}
.footer-newsletter-form input {
  height: 3.5rem;
  padding: 0 1rem;
  min-width: 16rem;
  box-sizing: border-box;
}
.footer-newsletter-form .footer-newsletter-submit {
  height: 3.5rem;
  padding: 0 2rem;
  min-width: 10rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.footer {
  padding: 25px clamp(1.25rem, 4vw, 2.25rem) 0;
}
.footer > .footer-newsletter, .footer > .footer-top, .footer > .footer-bottom {
  max-width: 1360px;
  margin-left: auto;
  margin-right: auto;
}
.footer > .footer-top {
  padding-top: 40px;
  padding-bottom: 40px;
  grid-template-columns: minmax(320px, 1.5fr) repeat(4, minmax(160px, 1fr));
  column-gap: clamp(2.8rem, 4vw, 4.4rem);
  row-gap: 1.4rem;
}
.footer-col {
  gap: 0.7rem;
}
.footer-brand {
  padding-right: clamp(1.2rem, 2.4vw, 2.5rem);
}
.footer-brand small {
  font-weight: 600;
}
.footer-newsletter-form input, .footer-newsletter-form input::placeholder {
  font-size: 1.1rem;
}
.footer-newsletter-form .footer-newsletter-submit {
  font-size: 1.1rem;
  letter-spacing: 0.04em;
}
@media (max-width: 900px) {
  body.page-home .hero {
    padding: 3.5rem 0 0;
  }
  body.page-home .hero-tag {
    font-size: clamp(0.68rem, 2.8vw, 0.82rem);
    letter-spacing: 0.12em;
    white-space: nowrap;
    margin-bottom: 0.5rem;
  }
  body.page-home .hero-heading {
    font-size: clamp(2.4rem, 10vw, 3.4rem);
    font-weight: 400;
    line-height: 1.04;
    max-width: 100%;
    margin-bottom: 0.8rem;
  }
  body.page-home .hero-heading .reveal-line:first-child > span {
    white-space: normal;
  }
  body.page-home .hero-heading .reveal-line:nth-child(2) .outline-fill {
    font-size: clamp(3.2rem, 15vw, 4.6rem);
    margin-top: 0;
  }
  body.page-home .hero-line {
    display: none;
  }
  body.page-home .hero-sub {
    font-size: clamp(0.92rem, 3.4vw, 1.05rem);
    line-height: 1.6;
    max-width: 32rem;
    margin: 0.4rem auto 0.8rem;
  }
  body.page-home .hero-visual {
    aspect-ratio: 4 / 5.5;
    max-height: 440px;
    margin: 0.4rem 0 1.8rem;
  }
  body.page-home .hero-partners {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.6rem;
    justify-items: center;
    align-items: center;
    max-width: 24rem;
    margin-left: auto;
    margin-right: auto;
  }
  body.page-home .hero-partners > span {
    grid-column: 1 / -1;
    text-align: center;
    font-size: 0.75rem;
    margin-right: 0;
  }
  body.page-home .hero-partners a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 42px;
    width: 100%;
  }
  body.page-home .hero-partners img, body.page-home .hero-partners a img, body.page-home .hero-partners a:nth-child(6) img {
    height: 28px;
    max-height: 28px;
    width: auto;
    object-fit: contain;
  }
  body.page-home .marquee-track span {
    font-size: clamp(1.8rem, 8vw, 2.8rem);
  }
  body.page-home .movement-overlay {
    inset: -1px;
  }
  body.page-home .movement {
    padding-bottom: 2rem;
  }
  body.page-home .brand-section {
    padding-top: 0.5rem;
    padding-bottom: 2.5rem;
  }
  body.page-home .brand-section .btn-ghost {
    font-size: 0.95rem;
    padding: 0.8rem 2rem;
  }
  body.page-home .brand-section .btn-ghost + * {
    font-size: clamp(0.85rem, 3.4vw, 1rem);
    line-height: 1.5;
    opacity: 0.85;
  }
  body.page-home .brand-section .brand-body p {
    font-size: clamp(0.92rem, 3.6vw, 1.05rem);
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.9);
  }
  body.page-home .pullquote-section blockquote p {
    font-size: clamp(1.6rem, 7.5vw, 2.4rem);
    line-height: 1.2;
  }
  body.page-home .pullquote-section blockquote cite {
    font-size: clamp(0.82rem, 3.2vw, 1rem);
  }
  body.page-home .carousel-intro h2 {
    font-size: clamp(2.2rem, 9vw, 3rem);
  }
  body.page-home .carousel-card h3 {
    font-size: clamp(1.5rem, 6vw, 2rem);
  }
  body.page-home .carousel-card p {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  body.page-home .scrollstack-intro h2 {
    font-size: clamp(2.2rem, 10vw, 3.2rem);
  }
  body.page-home .scrollstack-card-text h2 {
    font-size: clamp(1.2rem, 5vw, 1.6rem);
  }
  body.page-home .scrollstack-card-text p {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  body.page-home .scrollstack-cta p {
    font-size: clamp(1.4rem, 6.5vw, 2rem);
    line-height: 1.25;
  }
  body.page-home #hscrollTrack {
    scroll-snap-type: x mandatory;
    scroll-padding-left: 1rem;
  }
  body.page-home #hscrollTrack > .work-card {
    scroll-snap-align: start;
  }
  body.page-home .hscroll-intro p, body.page-home .carousel-intro > p, body.page-home .scrollstack-intro p {
    font-size: clamp(0.92rem, 3.4vw, 1.05rem);
    line-height: 1.6;
    color: var(--body);
  }
  body.page-home .hscroll-intro h2 {
    font-size: clamp(2rem, 9vw, 3rem);
  }
  .final-cta-content {
    padding-bottom: 1.5rem;
  }
  .final-cta-content h2 {
    margin-bottom: 0.7rem;
  }
  .final-cta-content p {
    margin-bottom: 1.2rem;
  }
  .footer {
    padding-top: 1.5rem;
  }
  .footer > .footer-top {
    text-align: left;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
  .footer-brand {
    grid-column: 1 / -1;
    padding-right: 0;
    text-align: center;
  }
  .footer-col {
    align-items: flex-start;
    text-align: left;
  }
  .footer-bottom {
    font-size: clamp(0.72rem, 2.8vw, 0.85rem);
    flex-wrap: wrap;
    justify-content: center;
  }
  .logo-bar-track {
    gap: 1.5rem;
  }
  .logo-bar-track img, .logo-bar-track picture img {
    height: 22px;
  }
}
@media (max-width: 768px) {
  html:not(.gallery-page) .nav {
    padding: 0.8rem 1rem;
    align-items: center;
    gap: 0.75rem;
  }
  html:not(.gallery-page) .nav-logo {
    flex: 0 0 auto;
  }
  html:not(.gallery-page) .nav-logo img {
    height: 54px !important;
    width: auto;
  }
  html:not(.gallery-page) .nav-links, html:not(.gallery-page) .nav-help, html:not(.gallery-page) .nav-cta, html:not(.gallery-page) .nav-cta-outline {
    display: none !important;
  }
  html:not(.gallery-page) .nav-right {
    margin-left: auto;
    width: auto;
    gap: 0 !important;
  }
  html:not(.gallery-page) .nav-hamburger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    right: 1rem;
    top: 0.8rem;
    width: 46px;
    height: 46px;
    border: 1.5px solid var(--rule);
    border-radius: 999px;
    background: var(--color-white);
    margin: 0 !important;
  }
  html:not(.gallery-page) .nav-hamburger span {
    left: 7px;
    width: 30px;
    height: 2px;
    background-color: var(--color-ink) !important;
  }
  html:not(.gallery-page) .nav-hamburger span:nth-child(1) {
    top: 14px;
  }
  html:not(.gallery-page) .nav-hamburger span:nth-child(2) {
    top: 22px;
  }
  html:not(.gallery-page) .nav-hamburger span:nth-child(3) {
    top: 30px;
  }
  html:not(.gallery-page) .impact-page-intro, html:not(.gallery-page) .impact-hero {
    padding-top: 6.4rem !important;
  }
}
.pullquote-section {
  padding-top: 172px;
  padding-bottom: 100px;
}
.pullquote-section blockquote p {
  font-size: 90px;
  line-height: 90px;
}
.pullquote-section blockquote cite {
  font-size: 21px;
}
button.faq-question, .faq-question {
  font-size: 24px;
}
section.faq-section div div p {
  font-size: 19px;
}
section.carousel-section {
  padding-bottom: 20px;
}
a.carousel-card {
  width: 400px;
  padding-right: 20px;
}
section.final-cta div p {
  font-size: 21px;
}
body.page-about article {
  padding-top: 30px;
}
h2.about-team-heading {
  text-align: center;
  margin-top: 80px;
  margin-bottom: 80px;
}
div.about-team-member {
  width: 350px;
}
p.about-team-role {
  font-weight: bold;
  padding-top: 6px;
  padding-bottom: 6px;
}
h3.about-team-name {
  font-size: 38px;
  font-style: italic;
}
p.about-team-bio {
  font-size: 17px;
}
.link-card-img {
  height: 660px;
}
.link-card h3, a div h3 {
  font-size: 36px;
}
.link-card p, a div p {
  font-size: 18px;
}
section.content-section {
  padding-top: 30px;
}
.content-section .content-split h2, .content-inner h2 {
  font-size: 60px;
  line-height: 76px;
}
div form p {
  text-align: left;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
}
.nav-cta, .nav-cta-outline {
  font-size: 18px;
}
.nav-help {
  font-size: 18px;
}
ul.nav-links li a span {
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  font-size: 18px;
}
nav.nav.nav-solid {
  padding-top: 10px;
  padding-bottom: 10px;
}
a.btn.btn-ghost:hover {
  color: #222222;
}
.brand-overlay a.btn.btn-ghost:hover, .brand-section a.btn.btn-ghost:hover {
  color: var(--color-ink);
}
a.btn.btn-white:hover {
  background-color: #222222;
  border-color: #222222;
  color: white;
}
.impact-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.impact-card {
  position: relative;
  overflow: hidden;
  border-radius: 2px;
  aspect-ratio: 4/3;
}
.impact-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.impact-card:hover img {
  transform: scale(1.04);
}
.impact-card-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.5rem 1.8rem;
  background: linear-gradient( to top, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.3) 60%, transparent 100% );
}
.impact-card-caption .label {
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 0.3rem;
  font-size: 0.75rem;
}
.impact-card-caption p {
  color: var(--color-white);
  font-family: var(--font-serif);
  font-size: 1.35rem;
  font-weight: 400;
  line-height: 1.3;
}
.gallery-cta-overlay {
  position: relative;
  max-width: 1400px;
  margin: 0.75rem auto 0;
  border: 1px solid var(--rule);
  background-color: var(--color-white);
  padding: 2rem 2.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.gallery-cta-overlay p {
  font-family: var(--font-serif);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  color: var(--color-ink);
  font-style: italic;
  font-weight: 400;
  line-height: 1.4;
  max-width: 32em;
  margin: 0;
}
.gallery-cta-overlay .btn-ghost-dark {
  flex-shrink: 0;
  white-space: nowrap;
}
.fade-up {
  opacity: 0;
  transform: translateY(40px);
}
@media (max-width: 1024px) {
  .nav {
    padding: 1rem 1.5rem;
  }
  .nav.scrolled {
    padding: 0.5rem 1.5rem;
  }
  .nav-logo img {
    height: 48px;
  }
  .nav.scrolled .nav-logo img {
    height: 48px;
  }
  .nav-links {
    display: none;
  }
  .nav-right {
    display: flex;
    align-items: center;
    gap: 0.8rem;
  }
  .nav-help {
    font-size: 0.82rem;
  }
  .nav-cta {
    font-size: 0.72rem;
    padding: 0.6rem 1.2rem;
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.08em;
  }
  .nav-hamburger {
    display: flex;
  }
  .mobile-bottom-nav {
    display: flex;
  }
  body {
    padding-bottom: calc(65px + env(safe-area-inset-bottom, 0px));
  }
  .movement-inner {
    grid-template-columns: 1fr;
  }
  .movement-left {
    max-height: 55vh;
    aspect-ratio: 3/4;
  }
  .content-split {
    grid-template-columns: 1fr;
  }
  .content-split.reverse > :first-child {
    order: 0;
  }
  .content-split.reverse > :last-child {
    order: 0;
  }
  .content-split img {
    max-height: 400px;
  }
  .gallery-sticky {
    align-items: stretch;
    justify-content: stretch;
  }
  .gallery-frame {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    border-radius: 0;
  }
  .hero {
    padding: 8rem 1.5rem 4rem;
  }
  .hero-heading {
    max-width: none;
  }
  .footer-top {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
  .donate-immediate {
    grid-template-columns: 1fr;
  }
  .contact-layout {
    grid-template-columns: 1fr;
  }
  .form-row {
    grid-template-columns: 1fr 1fr;
  }
  .checkbox-grid {
    grid-template-columns: 1fr 1fr;
  }
  .link-cards {
    grid-template-columns: 1fr;
  }
  .impact-grid {
    grid-template-columns: 1fr 1fr;
  }
  .hero-visual {
    position: relative;
    right: auto;
    top: auto;
    transform: none;
    width: 100%;
    height: clamp(300px, 55vw, 440px);
    margin: 0 0 2.5rem;
  }
  .hero-slideshow {
    border-radius: 0.35rem;
  }
  .hero-slideshow::after {
    border-radius: 0.35rem;
  }
  .hero-tag {
    margin-bottom: 1.5rem;
  }
  .hero-heading {
    margin-bottom: 2rem;
  }
  .btn {
    display: block;
    width: 100%;
    text-align: center;
  }
}
@media (min-width: 1025px) and (max-width: 1366px) and (orientation: landscape) and (pointer: coarse) {
  .hero {
    padding: 6.5rem 2.5rem 3rem;
    min-height: 100vh;
  }
  .hero-content {
    max-width: 56%;
    position: relative;
    z-index: 2;
  }
  .hero-tag {
    margin-bottom: 1.25rem;
    font-size: 0.9rem;
  }
  .hero-heading {
    font-size: clamp(2.6rem, 6.2vw, 4.6rem);
    line-height: 0.95;
    max-width: 100%;
    margin-bottom: 2rem;
  }
  .hero-foot {
    gap: 1.4rem;
  }
  .hero-sub {
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 1.55;
  }
  .hero-visual {
    position: absolute;
    right: 2.5rem;
    top: 50%;
    transform: translateY(-50%);
    width: 36vw;
    max-width: 480px;
    height: auto;
    aspect-ratio: 4/5;
    margin: 0;
  }
  .hero-partners {
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 0.5rem;
  }
  .hero-partners img {
    height: 18px;
  }
  .hero-foot .btn {
    display: inline-block;
    width: auto;
  }
}
@media (max-width: 768px) {
  h1 {
    font-size: clamp(2.8rem, 11vw, 5rem);
  }
  .hero-heading {
    line-height: 1.05;
  }
  .hero {
    padding: 7rem 15px 3rem;
  }
  .hero-foot {
    gap: 1.5rem;
  }
  .hero-partners {
    gap: 1rem;
    margin-top: 0.25rem;
  }
  .hero-partners img {
    height: 16px;
  }
  .scroll-cue {
    right: 15px;
    display: none;
  }
  .hero-visual {
    width: 100%;
    height: clamp(260px, 50vw, 360px);
    margin: 0 0 2rem;
  }
  .impact-grid {
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
  }
  .ways-grid {
    grid-template-columns: 1fr;
  }
  .footer-top {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .footer-bottom {
    flex-direction: column;
    gap: 0.5rem;
    text-align: center;
  }
  .footer-newsletter {
    flex-direction: column;
    text-align: center;
  }
  .footer-newsletter-form {
    flex-direction: column;
    width: 100%;
  }
  .footer-newsletter-form input {
    min-width: 0;
  }
  .gallery-frame {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    border-radius: 0;
  }
  .carousel-card {
    width: 380px;
  }
  .faq-question {
    font-size: clamp(1.3rem, 4vw, 1.6rem);
  }
  .form-row {
    grid-template-columns: 1fr;
  }
  .checkbox-grid {
    grid-template-columns: 1fr;
  }
  .page-hero {
    padding: 6.5rem 15px 3rem;
    min-height: 46vh;
  }
  .movement-left {
    max-height: 50vh;
  }
  .content-split img {
    max-height: 280px;
  }
  .gallery-cta-overlay {
    flex-direction: column;
    align-items: flex-start;
    padding: 1.5rem;
  }
  .justified-grid {
    grid-auto-rows: 150px;
  }
  .impact-page-intro {
    padding: 7rem 15px 2.5rem;
  }
  .impact-page-intro h1 {
    font-size: clamp(2.6rem, 9vw, 3.5rem);
  }
  .impact-page-intro p {
    font-size: 1.05rem;
  }
  .impact-block {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    padding: 2.5rem 15px;
  }
  .impact-block.reverse .impact-block-text {
    order: 1;
  }
  .impact-block.reverse .impact-block-gallery {
    order: 2;
  }
  .impact-block-text h2 {
    font-size: 1.8rem;
  }
  .impact-block-text p {
    font-size: 1.02rem;
  }
  .impact-block-gallery {
    gap: 0.75rem;
  }
  .about-story {
    padding: 0 15px 3rem;
  }
  .about-story-inner p {
    font-size: 1.05rem;
    line-height: 1.8;
  }
  .about-story-inner .about-lead {
    font-size: 1.35rem;
  }
  .image-cards {
    padding: 0 15px;
    gap: 1.5rem;
  }
  .image-card {
    grid-template-columns: 1fr;
  }
  .image-card:nth-child(even) {
    direction: ltr;
  }
  .image-card img {
    min-height: 200px;
  }
  .image-card-body h3 {
    font-size: 1.7rem;
  }
  .image-card-body p {
    font-size: 1rem;
  }
  .content-split {
    gap: 2.5rem;
  }
  .content-split > div:first-child {
    padding-right: 0 !important;
  }
  .form-page-card {
    padding: 1.5rem;
  }
  .form-page-card h2 {
    font-size: 1.6rem;
  }
  .hero-partners {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.5rem;
  }
  .hero-partners img {
    height: 20px;
    flex-shrink: 0;
  }
  .hero-partners a:nth-child(6) img {
    height: 36px;
  }
  .final-cta {
    min-height: 50vh;
  }
  .final-cta-content h2 {
    font-size: clamp(1.6rem, 5vw, 2.4rem);
    white-space: normal;
  }
  .final-cta-content h2 em {
    font-size: 0.85em;
  }
}
@media (max-width: 480px) {
  html {
    font-size: 15.5px;
  }
  :root {
    --gap: 15px;
    --section-py: 4rem;
  }
  .hero {
    min-height: 90vh;
    padding: 6rem 15px 3rem;
  }
  .nav {
    padding: 1rem 15px;
  }
  .nav.scrolled {
    padding: 0.5rem 15px;
  }
  .nav-logo img {
    height: 40px;
  }
  .nav.scrolled .nav-logo img {
    height: 40px;
  }
  .nav-cta {
    font-size: 0.63rem;
    padding: 0.55rem 0.9rem;
    letter-spacing: 0.06em;
  }
  .hero-visual {
    width: 100%;
    height: clamp(240px, 60vw, 320px);
  }
  .carousel-card {
    width: 300px;
  }
  .page-hero {
    padding: 5rem 15px 2.5rem;
    min-height: 40vh;
  }
  .gallery-frame {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    border-radius: 0;
  }
  .scroll-cue {
    right: 15px;
    display: none;
  }
  .impact-grid {
    grid-template-columns: 1fr;
    gap: 0.6rem;
  }
  .justified-grid {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 130px;
    gap: 4px;
  }
  .jg-wide {
    grid-column: span 2;
  }
  .contact-section {
    padding: 0 15px var(--section-py);
  }
  .content-section {
    padding: var(--section-py) 15px;
  }
  .justified-gallery-section {
    padding: var(--section-py) 15px;
  }
  .faq-section {
    padding: var(--section-py) 15px;
  }
  .movement {
    padding: var(--section-py) 15px;
  }
  .final-cta {
    padding: var(--section-py) 15px;
  }
  .support-section {
    padding: var(--section-py) 15px;
  }
  .gallery-cta-overlay {
    margin: 0.5rem 0 0;
  }
  .nav-help {
    font-size: 0.75rem;
  }
  .nav-cta {
    font-size: 0.65rem;
    padding: 0.5rem 0.85rem;
  }
  .impact-page-intro h1 {
    font-size: 2.4rem;
  }
  .impact-block-text h2 {
    font-size: 1.6rem;
  }
  .image-card-body h3 {
    font-size: 1.5rem;
  }
  .about-story-inner .about-lead {
    font-size: 1.25rem;
  }
  .image-cards {
    padding: 0 10px;
    gap: 1.2rem;
  }
  .impact-block-gallery {
    gap: 0.5rem;
  }
  .article-wide {
    padding: 0 10px;
  }
  .hscroll-outro {
    width: 100vw;
    margin-left: 0;
  }
}
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--color-ink);
  outline-offset: 3px;
}
.nav-cta:focus-visible, .btn:focus-visible {
  outline: 2px solid var(--color-ink);
  outline-offset: 4px;
}
.faq-question:focus-visible {
  outline: 2px solid var(--color-ink);
  outline-offset: 2px;
}
picture {
  display: block;
}
picture img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track {
    animation-play-state: paused;
  }
  .carousel-track {
    animation-play-state: paused;
  }
  .rotating-badge svg {
    animation: none;
  }
  .scroll-cue-line::after {
    animation: none;
    opacity: 0.4;
    transform: translateY(0);
  }
  .jg-item {
    transition: none;
  }
  .jg-item img {
    transition: none;
  }
  .movement-bg {
    will-change: auto;
  }
  * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
}
.impact-page-intro {
  padding: clamp(9rem, 16vh, 12rem) var(--gap) clamp(3rem, 6vh, 4rem);
  text-align: center;
  max-width: 56rem;
  margin: 0 auto;
}
.impact-page-intro h1 {
  margin-bottom: 1.2rem;
}
.impact-page-intro p {
  max-width: 38rem;
  margin: 0 auto;
  color: var(--color-muted);
}
body.page-impact section h1 {
  font-size: 100px;
  line-height: 95px;
}
section.impact-page-intro {
  padding-top: 150px;
  padding-left: 0;
  padding-right: 0;
}
body.page-impact section p {
  width: 100%;
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track {
    animation-play-state: paused;
  }
  .carousel-track {
    animation-play-state: paused;
  }
  .rotating-badge svg {
    animation: none;
  }
  .scroll-cue-line::after {
    animation: none;
    opacity: 0.4;
    transform: translateY(0);
  }
  .jg-item {
    transition: none;
  }
  .jg-item img {
    transition: none;
  }
  .movement-bg {
    will-change: auto;
  }
  * {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }
}
.nav .nav-logo img, .nav .nav-cta, .nav .nav-help {
  transition: all 0.3s var(--ease);
}
.nav.scrolled {
  padding: 0.45rem 3rem;
}
.nav.scrolled .nav-logo img {
  height: 48px;
}
.nav.scrolled .nav-cta, .nav.scrolled .nav-cta-outline {
  font-size: 0.82rem;
  padding: 0.45rem 1.4rem;
}
.nav.scrolled .nav-help {
  font-size: 0.82rem;
}
.nav {
  align-items: center;
}
.nav-right {
  align-items: center;
}
.nav-logo {
  display: inline-flex;
  align-items: center;
}
.nav-help {
  color: var(--color-ink);
}
.nav-hamburger {
  display: none;
}
html.gallery-page .nav {
  transition: transform 0.4s var(--ease), background 0.4s ease;
}
html.gallery-page .nav.nav-hidden {
  transform: translateY(-110%);
}
.nav-mobile {
  overflow-y: auto;
  padding: 5rem 1.5rem 8rem;
  justify-content: flex-start;
  gap: 1.4rem;
}
.nav-mobile-close {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 10003;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: var(--color-ink);
  color: var(--color-white);
  display: none;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--color-ink);
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
  transition: transform 0.25s var(--ease), background 0.2s ease;
}
.nav-mobile-close svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 2.4;
  fill: none;
}
.nav-mobile-close:hover {
  transform: rotate(90deg);
  background: #000;
}
body.nav-open .nav-mobile-close {
  display: flex;
}
.nav-mobile a {
  font-size: clamp(2rem, 8vw, 2.6rem);
  line-height: 1.15;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
}
.nav-mobile-extra {
  width: 100%;
  margin-top: 1.2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  text-align: center;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.4s ease 0.55s, transform 0.5s var(--ease) 0.55s;
}
.nav-mobile.open .nav-mobile-extra {
  opacity: 1;
  transform: translateY(0);
}
.nav-mobile-extra-row {
  font-family: var(--font-sans);
  font-size: 0.92rem;
  color: var(--color-muted);
  line-height: 1.65;
}
.nav-mobile-extra-row a {
  font-size: 0.95rem;
  font-family: var(--font-sans);
  color: var(--color-ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.nav-mobile-extra-row strong {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-faint);
  margin-bottom: 0.3rem;
}
.nav-mobile-extra-row.compact {
  font-size: 0.78rem;
  color: var(--color-faint);
  line-height: 1.6;
  margin-top: 0.3rem;
}
.nav-mobile-extra-row.compact a {
  font-size: 0.78rem;
  color: var(--color-faint);
  text-decoration: underline;
}
.nav-mobile-extra-social {
  display: flex;
  gap: 0.85rem;
  justify-content: center;
  margin-top: 0.4rem;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.4s ease 0.6s, transform 0.5s var(--ease) 0.6s;
}
.nav-mobile.open .nav-mobile-extra-social {
  opacity: 1;
  transform: translateY(0);
}
.nav-mobile-extra-social a {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1.5px solid var(--color-ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  transition: background 0.2s, transform 0.2s;
}
.nav-mobile-extra-social a:hover {
  background-color: var(--color-ink);
  transform: translateY(-2px);
}
.nav-mobile-extra-social svg {
  width: 20px;
  height: 20px;
  stroke: var(--color-ink);
  stroke-width: 1.8;
  fill: none;
}
.nav-mobile-extra-social a[aria-label='Facebook'] svg path {
  fill: var(--color-ink);
  stroke: none;
}
.nav-mobile-extra-social a[aria-label='Instagram'] svg circle:last-child {
  fill: var(--color-ink);
  stroke: none;
}
.nav-mobile-extra-social a:hover svg {
  stroke: var(--color-white);
}
.nav-mobile-extra-social a[aria-label='Facebook']:hover svg path, .nav-mobile-extra-social a[aria-label='Instagram']:hover svg circle:last-child {
  fill: var(--color-white);
}
.nav-mobile-share {
  display: none;
}
.nav-mobile-newsletter {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: 0.5rem;
}
.nav-mobile-newsletter strong {
  font-family: var(--font-sans);
  font-size: 0.78rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-faint);
}
.nav-mobile-newsletter input, .nav-mobile-newsletter button {
  font-family: var(--font-sans);
  font-size: 1rem;
  padding: 0.85rem 1rem;
  border-radius: 4px;
  border: 1.5px solid var(--rule);
  background-color: var(--color-white);
}
.nav-mobile-newsletter button {
  background-color: var(--color-ink);
  color: var(--color-cream);
  border-color: var(--color-ink);
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.04em;
  cursor: pointer;
}
.nav-mobile {
  z-index: 9990;
}
.nav-mobile-close {
  z-index: 9991;
}
.gallery-lightbox.active, .site-lightbox.active {
  z-index: 10010;
}
.site-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(12, 12, 12, 0.74);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(1rem, 2vw, 2rem);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.site-lightbox.active {
  opacity: 1;
  pointer-events: auto;
}
.site-lightbox img {
  width: auto;
  height: auto;
  max-width: min(88vw, 1240px);
  max-height: 88vh;
  object-fit: contain;
  border-radius: 10px;
  box-shadow: 0 22px 80px rgba(0, 0, 0, 0.28);
}
.mobile-bottom-nav {
  display: none;
}
body {
  padding-bottom: 0;
}
.gallery-lightbox-close, .site-lightbox-close {
  position: absolute;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.6);
  color: var(--color-white);
  border: 2px solid var(--color-white);
  top: 1rem;
  right: 1rem;
}
.gallery-lightbox-close svg, .site-lightbox-close svg {
  width: 24px;
  height: 24px;
  stroke-width: 2.6;
}
.site-lightbox-close {
  background: rgba(250, 250, 248, 0.95);
  color: #111;
  border: 0;
  box-shadow: 0 12px 35px rgba(0, 0, 0, 0.18);
}
.site-lightbox-close:hover {
  background: #fff;
  transform: scale(1.03);
}
.site-lightbox-close span {
  display: block;
  line-height: 1;
  font-size: 2rem;
  font-weight: 300;
  transform: translateY(-1px);
}
.gallery-mobile-grid {
  display: none;
}
html.gallery-page, html.gallery-page body {
  background: #0c0c0c;
  color: #fff;
}
html.gallery-page body {
  font-family: var(--font-sans);
}
.gallery-title-overlay {
  text-align: center;
  padding: 0 1.25rem;
}
.gallery-title-overlay h2 {
  text-wrap: balance;
}
.gallery-view-hint {
  text-align: center;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.78);
}
.demo-1__gallery__figure, .demo-1__gallery__image {
  cursor: pointer;
}
.final-cta .btn-ghost {
  color: var(--color-white);
  border-color: var(--color-white);
}
.link-card-img h3 {
  display: none;
}
.image-card img, .image-card > img {
  object-fit: cover;
  width: 100%;
}
.image-card {
  will-change: opacity, transform;
}
.image-card.revealed {
  transition: none;
}
.impact-block.fade-up {
  will-change: opacity, transform;
}
.brand-heading a, .brand-heading em a {
  color: inherit;
  border-bottom: 0;
  text-decoration: none;
  padding-bottom: 0;
  transition: opacity 0.25s;
}
.brand-heading a:hover {
  opacity: 0.7;
}
@media (min-width: 1024px) {
  .brand-heading {
    white-space: normal;
    max-width: 22ch;
    margin-inline: auto;
  }
}
.impact-block {
  padding-left: clamp(1rem, 5vw, 4rem);
  padding-right: clamp(1rem, 5vw, 4rem);
}
.impact-block-gallery img, .impact-block-gallery figure img {
  cursor: pointer;
  pointer-events: auto;
  position: relative;
  z-index: 1;
}
.impact-block-gallery {
  position: relative;
}
.impact-page-intro p {
  max-width: 36rem;
  margin: 1rem auto 0;
}
.impact-page-intro h1 {
  letter-spacing: -0.01em;
}
.share-panel-links a, .share-panel-links button {
  border-color: var\(--rule-strong\);
  border-radius: 6px;
}
.share-panel-links a svg, .share-panel-links button svg {
  stroke: var(--color-ink);
}
.contact-tabs {
  display: none;
}
.contact-tabs-mini {
  display: flex;
  gap: 0;
  margin-bottom: 1.2rem;
  border-bottom: 2px solid var(--rule);
}
.contact-tabs-mini button {
  font-family: var(--font-sans);
  font-size: 0.92rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-faint);
  padding: 0.85rem 1.2rem;
  background: transparent;
  --tw-border-style: none;
  border-style: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
}
.contact-tabs-mini button.active {
  color: var(--color-ink);
  border-bottom-color: var(--color-ink);
}
.contact-tab-panel {
  display: none;
}
.contact-tab-panel.active {
  display: block;
}
.contact-business-hours dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.4rem 1.2rem;
  margin-top: 0.8rem;
  font-size: 0.98rem;
}
.contact-business-hours dt {
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  color: var(--color-ink);
}
.contact-business-hours dd {
  color: var(--color-muted);
}
.contact-business-hours small {
  display: block;
  color: var(--color-faint);
  font-size: 0.85rem;
  margin-top: 0.6rem;
}
.faq-question {
  font-family: var(--font-sans);
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  padding: 1.6rem 1.2rem;
  line-height: 1.25;
  color: var(--color-ink);
  letter-spacing: -0.005em;
}
.faq-icon::before, .faq-icon::after {
  background-color: var(--color-ink);
  height: 2.4px;
}
.faq-answer-inner p {
  font-family: var(--font-sans);
  font-size: 1.05rem;
  font-weight: 400;
  line-height: 1.75;
  padding: 0 1.2rem 1.6rem;
  color: var(--color-ink);
}
.faq-section {
  padding: clamp(3.5rem, 8vw, 6rem) 1rem;
}
@media (min-width: 901px) {
  .btn {
    font-size: 1.1rem;
  }
}
.form-success {
  text-align: center;
  padding: 2rem 1.5rem;
  background: var(--sand);
  border: 1px solid var(--rule);
  border-radius: 4px;
}
.form-success h3 {
  font-size: 1.6rem;
  margin-bottom: 0.5rem;
}
.form-success p {
  font-size: 1rem;
  color: var(--color-muted);
}
@media (min-width: 1025px) and (max-width: 1366px) and (orientation: landscape) and (pointer: coarse) {
  .hero {
    padding: 6.5rem 2.5rem 3rem;
    min-height: 100vh;
  }
  .hero-content {
    max-width: 56%;
    position: relative;
    z-index: 2;
  }
  .hero-tag {
    margin-bottom: 1.25rem;
    font-size: 0.9rem;
  }
  .hero-heading {
    font-size: clamp(2.6rem, 6.2vw, 4.6rem);
    line-height: 0.95;
    max-width: 100%;
    margin-bottom: 2rem;
  }
  .hero-foot {
    gap: 1.4rem;
  }
  .hero-sub {
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 1.55;
  }
  .hero-visual {
    position: absolute;
    right: 2.5rem;
    top: 50%;
    transform: translateY(-50%);
    width: 36vw;
    max-width: 480px;
    height: auto;
    aspect-ratio: 4/5;
    margin: 0;
  }
  .hero-partners {
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 0.5rem;
  }
  .hero-partners img {
    height: 18px;
  }
  .hero-foot .btn {
    display: inline-block;
    width: auto;
  }
}
@media (max-width: 900px) {
  .nav {
    background: rgba(255, 255, 255, 0.96);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.08);
    padding: 0.85rem 1rem;
    align-items: center;
  }
  .nav.hero-dark .nav-links a, .nav .nav-help {
    color: var(--color-ink);
  }
  .nav .nav-cta {
    background-color: var(--color-ink);
    color: var(--color-cream);
  }
  .nav .nav-cta:hover {
    background: transparent;
    color: var(--color-ink);
  }
  .nav-logo img {
    height: 56px;
  }
  .nav-help {
    font-size: 1.02rem;
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.02em;
    color: var(--color-ink);
    padding: 0.45rem 0.6rem;
  }
  .nav-cta, .nav-cta-outline {
    font-size: 1.02rem;
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
    padding: 0.7rem 1.4rem;
    border-width: 2px;
    letter-spacing: 0.04em;
  }
  .nav-hamburger {
    display: inline-block;
    align-self: center;
    margin: 0 0 0 0.4rem;
    box-sizing: border-box;
  }
  .nav-hamburger span {
    width: 32px;
    height: 2.4px;
    background-color: var(--color-ink);
    border-radius: 2px;
  }
  .nav-right {
    gap: 0.85rem;
  }
  .nav.scrolled {
    padding: 0.4rem 1rem;
  }
  .nav.scrolled .nav-logo img {
    height: 36px;
  }
  .nav.scrolled .nav-cta, .nav.scrolled .nav-cta-outline {
    font-size: 0.78rem;
    padding: 0.4rem 1rem;
  }
  body.nav-open .nav-links a::after, body.nav-open .nav-mobile a::after {
    transition: none;
    width: 0;
  }
  .hero {
    min-height: auto;
    padding-top: 3.5rem;
    padding-bottom: 0.5rem;
  }
  .hero-content {
    text-align: center;
    padding: 0.4rem 1rem 0.5rem;
    align-items: center;
    gap: 0;
  }
  .hero-tag {
    font-size: 0.9rem;
    letter-spacing: 0.14em;
    margin-bottom: 0.4rem;
  }
  .hero-heading {
    font-size: clamp(2.8rem, 11vw, 3.6rem);
    font-weight: 400;
    line-height: 1.04;
    letter-spacing: -0.012em;
    margin-bottom: 1rem;
    max-width: 100%;
  }
  .hero-heading .reveal-line:first-child > span {
    white-space: normal;
  }
  .hero-heading .reveal-line:nth-child(2) > span {
    white-space: normal;
    font-weight: inherit;
    gap: 0.5rem;
  }
  .hero-heading .outline-fill {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
    -webkit-text-stroke: 1.5px var(--color-ink);
    line-height: inherit;
  }
  .hero-heading .reveal-line + .reveal-line {
    margin-top: 0.05em;
  }
  .hero-heading span, .hero-heading .reveal-line, .hero-heading .reveal-line > span, .hero-heading .outline-fill {
    font-size: inherit;
  }
  .hero-line {
    width: 36px;
    height: 2.5px;
  }
  .hero-sub {
    font-size: 0.95rem;
    line-height: 1.5;
    text-align: center;
    margin: 0.3rem auto 0.8rem;
    max-width: 28rem;
  }
  .hero-foot {
    align-items: center;
    gap: 0;
  }
  .hero-foot .btn {
    font-size: 1rem;
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
    padding: 0.85rem 1.2rem;
    letter-spacing: 0.04em;
  }
  .hero-visual {
    position: relative;
    inset: auto;
    transform: none;
    width: 100vw;
    max-width: none;
    height: auto;
    aspect-ratio: 4 / 5;
    max-height: 380px;
    margin: 0.6rem 0 2.5rem;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    overflow: visible;
  }
  .hero-slideshow {
    position: absolute;
    inset: 0;
    border-radius: 0;
    overflow: hidden;
  }
  .hero-visual .rotating-badge.badge-white {
    display: none;
  }
  .hero-visual .rotating-badge.badge-black {
    display: block;
    position: absolute;
    inset: auto;
    left: 50%;
    bottom: -64px;
    top: auto;
    right: auto;
    transform: translateX(-50%);
    width: 128px;
    height: 128px;
    background-color: var(--color-ink);
    border-radius: 50%;
    border: 2px solid var(--cream);
    padding: 8px;
    z-index: 10;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
    mix-blend-mode: normal;
    filter: none;
    opacity: 1;
  }
  .hero-visual .rotating-badge.badge-black svg text {
    fill: var(--cream);
    font-size: 9px;
    letter-spacing: 0.05em;
  }
  .hero-visual .rotating-badge.badge-black .center-dot {
    background-color: var(--color-cream);
    width: 4px;
    height: 4px;
  }
  .scroll-cue {
    display: none;
  }
  .hero-partners {
    gap: 1.4rem;
    row-gap: 1rem;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-top: 1.2rem;
  }
  .hero-partners > span {
    width: 100%;
    text-align: center;
    text-transform: lowercase;
    letter-spacing: 0.02em;
    font-weight: 400;
    font-size: 0.82rem;
    color: var(--color-muted);
    margin-right: 0;
  }
  .hero-partners a {
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .hero-partners img, .hero-partners a img, .hero-partners a:nth-child(6) img {
    height: 26px;
    max-height: 26px;
    width: auto;
    object-fit: contain;
  }
  .marquee {
    padding: 0.9rem 0;
  }
  .marquee-track span {
    font-size: clamp(2.4rem, 9vw, 3.4rem);
    padding: 0 1.5rem;
  }
  .marquee::before {
    width: 8%;
  }
  .marquee::after {
    width: 18%;
  }
  .movement {
    padding: clamp(3rem, 8vw, 5rem) 1.25rem;
  }
  .movement-inner {
    gap: 2rem;
    padding: 0;
  }
  .movement-left {
    aspect-ratio: 3 / 4.4;
    border-radius: 14px;
    margin-bottom: 0;
    max-height: none;
    margin: 0 15px;
  }
  .movement-bg img {
    object-position: center 30%;
    object-fit: cover;
    height: 100%;
    width: 100%;
  }
  .movement-overlay {
    background: linear-gradient( to top, rgba(17, 17, 17, 0.78) 0%, rgba(17, 17, 17, 0.18) 55%, transparent 80% );
  }
  .movement-declaration {
    bottom: 1.4rem;
    left: 1.25rem;
    right: 1.25rem;
    font-size: clamp(1.2rem, 4.5vw, 1.5rem);
    line-height: 1.4;
    font-weight: 400;
  }
  .movement-right {
    padding: 0;
    text-align: center;
  }
  .movement-right .label {
    display: block;
    text-align: center;
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.12em;
  }
  .movement-right h2 {
    font-size: clamp(2rem, 8vw, 2.6rem);
    line-height: 1.08;
  }
  .movement-right p {
    font-size: 1.06rem;
    line-height: 1.7;
  }
  .movement-right .btn, .movement-right .btn-ghost {
    display: block;
    width: 100%;
    text-align: center;
    padding: 1rem 1.5rem;
    margin-top: 1rem;
    font-size: 1.02rem;
  }
  .hscroll-intro {
    width: 78vw;
    max-width: 360px;
    padding: 1rem 0;
    margin-right: 1.5rem;
    text-align: center;
  }
  .hscroll-intro h2 {
    font-size: clamp(2.6rem, 10vw, 3.6rem);
    line-height: 1;
    white-space: normal;
    text-align: center;
    margin-bottom: 0.75rem;
  }
  .hscroll-intro p {
    text-align: center;
    max-width: 38ch;
    margin-inline: auto;
    font-size: 1.08rem;
    line-height: 1.65;
  }
  .work-card {
    width: 82vw;
    margin-right: 1.2rem;
    opacity: 1;
  }
  .work-card-img {
    height: 280px;
    min-height: 280px;
  }
  .work-card-info {
    padding: 1.5rem 1.2rem;
  }
  .work-card-info .label {
    font-size: 0.72rem;
  }
  .work-card-info h3 {
    font-size: 2rem;
    line-height: 1.15;
    margin: 0.4rem 0 0.7rem;
  }
  .work-card-info p {
    font-size: 1.02rem;
    line-height: 1.65;
  }
  .hscroll-track > .work-card {
    transform: none;
  }
  .hscroll-outro {
    width: 100vw;
    padding: 0 1.5rem;
    text-align: center;
  }
  .hscroll-outro-inner {
    max-width: none;
    width: 100%;
    padding: 0 0.5rem;
    will-change: opacity, transform;
  }
  .hscroll-outro h2 {
    font-size: clamp(2.6rem, 9.5vw, 3.6rem);
    margin-bottom: 1rem;
  }
  .hscroll-outro-inner > p {
    font-size: 1.05rem;
    line-height: 1.7;
    max-width: 32rem;
    margin-inline: auto;
  }
  .hscroll-outro-actions {
    flex-direction: column;
    width: 100%;
    gap: 0.7rem;
    align-items: stretch;
    margin: 1.5rem auto;
    max-width: 28rem;
  }
  .hscroll-outro-actions .btn {
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: 1.02rem;
  }
  .brand-overlay {
    align-items: center;
    padding: 1.5rem 0.75rem;
  }
  .brand-overlay .brand-inner {
    max-width: 100%;
    padding: 1.5rem 0.75rem 1rem;
  }
  .brand-founders {
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    margin: 0.5rem 0 0.4rem;
    padding-top: 0.3rem;
  }
  .brand-heading {
    font-size: clamp(2.2rem, 9.2vw, 3.2rem);
    line-height: 1.05;
    letter-spacing: -0.005em;
    margin: 0.4rem 0 0.6rem;
    max-width: 100%;
    text-wrap: balance;
  }
  .brand-heading em {
    display: inline;
  }
  .brand-tagline {
    font-size: clamp(1rem, 3.5vw, 1.2rem);
    line-height: 1.4;
    margin: 0.8rem auto 0;
    color: rgba(255, 255, 255, 0.92);
    max-width: 28em;
  }
  .brand-body p {
    font-size: 0.95rem;
    line-height: 1.55;
  }
  .brand-body p + p {
    margin-top: 0.4rem;
  }
  .brand-overlay .btn {
    width: 100%;
    padding: 0.85rem 1.25rem;
    font-size: 0.95rem;
    max-width: 18rem;
  }
  .brand-overlay .btn-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 100%;
    max-width: 18rem;
  }
  .brand-overlay .hscroll-outro-contact {
    font-weight: 400;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.72);
  }
  .carousel-section {
    padding: clamp(3.5rem, 9vw, 5rem) 0;
  }
  .carousel-intro {
    padding: 0 1.25rem;
    margin-bottom: 2.2rem;
  }
  .carousel-intro h2, .breadth-reveal h2 {
    font-size: clamp(2.6rem, 9vw, 3.4rem);
    line-height: 1.08;
  }
  .carousel-intro > p {
    font-size: 1.02rem;
    max-width: 36rem;
  }
  .carousel-card {
    width: 78vw;
    max-width: 420px;
    padding: 2rem 1.6rem;
  }
  .carousel-card h3 {
    font-size: 1.7rem;
  }
  .carousel-card p {
    font-size: 1rem;
    line-height: 1.6;
  }
  .faq-question {
    font-size: 1.4rem;
    padding: 1.5rem 1rem;
  }
  .faq-answer-inner p {
    padding: 0 1rem 1.4rem;
    font-size: 1rem;
  }
  .final-cta {
    padding: 4.5rem 1.25rem;
  }
  .final-cta-content h2 {
    font-size: clamp(2.2rem, 8vw, 2.8rem);
    line-height: 1.15;
    margin-bottom: 0.8rem;
  }
  .final-cta-content p:not(.cta-tag) {
    font-size: 1rem;
    margin-bottom: 1.4rem;
  }
  .final-cta-actions {
    flex-direction: column;
    width: 100%;
    max-width: 24rem;
    margin: 0 auto;
    gap: 0.7rem;
    align-items: stretch;
  }
  .final-cta-actions .btn {
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: 1.02rem;
  }
  .final-cta .hero-partners {
    display: none;
  }
  body.page-impact .impact-page-intro, html:not(.gallery-page) .impact-page-intro:first-of-type {
    padding-top: 7rem;
  }
  .impact-page-intro {
    padding: 5rem 1.25rem 1.25rem;
  }
  .impact-page-intro h1 {
    font-size: clamp(2.6rem, 9vw, 3.4rem);
    line-height: 1.02;
    margin-bottom: 0.6rem;
  }
  .impact-page-intro p {
    font-size: 1.02rem;
    line-height: 1.6;
  }
  .impact-page-intro .label {
    font-size: 0.78rem;
    letter-spacing: 0.14em;
  }
  .impact-block {
    padding: 1.5rem 1.25rem;
  }
  .impact-block + .impact-block {
    border-top: 1px solid var(--rule);
  }
  .impact-block-text {
    margin-bottom: 0.6rem;
  }
  .impact-block-text .label {
    font-size: 0.74rem;
    letter-spacing: 0.16em;
    color: var(--color-faint);
    margin-bottom: 0.5rem;
  }
  .impact-block-text h2 {
    font-size: clamp(2rem, 8vw, 2.6rem);
    line-height: 1.12;
    margin-bottom: 0.8rem;
  }
  .impact-block-text p {
    font-size: 1rem;
    line-height: 1.7;
  }
  .content-section.alt .impact-block {
    padding: 1.5rem 1.25rem;
  }
  .content-section.alt {
    padding: 0;
  }
  .content-section {
    padding: 1.5rem 0;
  }
  .impact-block-gallery {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
  }
  .impact-block-gallery img, .impact-block-gallery figure {
    aspect-ratio: 1;
    width: 100%;
    height: 100%;
  }
  .impact-block-gallery figure {
    display: block;
  }
  .impact-block-gallery figure img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
  }
  .impact-block-gallery figcaption {
    position: absolute;
    bottom: 8px;
    left: 8px;
    background: rgba(17, 17, 17, 0.78);
    color: var(--color-cream);
    padding: 0.25rem 0.6rem;
    font-size: 0.78rem;
    border-radius: 3px;
  }
  .about-story {
    padding: 2rem 1.25rem 3rem;
  }
  .about-story-inner .movement-section-heading, .about-story-inner h2 {
    font-size: clamp(2rem, 8vw, 2.6rem);
    margin-top: 2rem;
  }
  .about-story-inner p {
    font-size: 1.02rem;
    line-height: 1.7;
  }
  .about-story-img.float-right, .about-story-img.float-left {
    float: none;
    width: 100%;
    max-width: 100%;
    margin: 1.4rem 0;
    border-radius: 4px;
  }
  .link-cards {
    padding: 0 1.25rem;
    gap: 1.2rem;
  }
  .link-card {
    border-radius: 4px;
  }
  .link-card-img {
    height: 240px;
  }
  .link-card-inner {
    padding: 1.4rem 1.25rem;
  }
  .link-card h3 {
    font-size: 1.7rem;
    line-height: 1.18;
    margin-bottom: 0.5rem;
  }
  .link-card p {
    font-size: 1rem;
    line-height: 1.65;
    margin-bottom: 1.1rem;
  }
  .link-card-action {
    font-size: 0.84rem;
  }
  .image-cards {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding: 0 1.25rem;
    max-width: 100%;
  }
  .image-card {
    width: 100%;
    border-radius: 4px;
    overflow: hidden;
    text-align: center;
  }
  .image-card img {
    width: 100%;
    height: 240px;
    object-fit: cover;
    display: block;
  }
  .image-card-body {
    padding: 1.4rem 1.1rem 1.6rem;
    align-items: center;
    text-align: center;
  }
  .image-card-body h3 {
    font-size: 1.85rem;
    line-height: 1.1;
    margin-bottom: 0.5rem;
    text-align: center;
  }
  .image-card-body p {
    font-size: 1.02rem;
    line-height: 1.55;
    text-align: center;
  }
  .image-card-body .btn {
    display: inline-block;
    margin: 0.5rem auto 0;
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: 1.02rem;
    text-align: center;
  }
  .impact-page-intro + .content-section .content-split {
    grid-template-columns: 1fr;
    gap: 1.6rem;
    padding: 0 1rem;
  }
  .impact-page-intro + .content-section .content-split > div:first-child {
    padding-right: 0;
  }
  .impact-page-intro + .content-section .content-split > div:first-child h2 {
    font-size: clamp(2.4rem, 9vw, 3rem);
    text-align: center;
    line-height: 1.05;
    margin-bottom: 0.8rem;
  }
  .impact-page-intro + .content-section .content-split > div:first-child > p {
    text-align: center;
  }
  .contact-tabs-mini {
    gap: 0.4rem;
    border-bottom: 0;
    padding: 0.25rem 0 0.75rem;
    margin-bottom: 1rem;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex-wrap: nowrap;
  }
  .contact-tabs-mini::-webkit-scrollbar {
    display: none;
  }
  .contact-tabs-mini button {
    flex: 0 0 auto;
    background: transparent;
    border: 1px solid var(--rule);
    border-radius: 999px;
    padding: 0.55rem 1.05rem;
    font-size: 0.9rem;
    text-transform: none;
    letter-spacing: 0.01em;
    color: var(--color-body);
    transition: background 0.2s, color 0.2s, border-color 0.2s;
  }
  .contact-tabs-mini button.active {
    background-color: var(--color-ink);
    color: var(--color-cream);
    border-color: var(--color-ink);
  }
  .page-contact .link-card-img {
    height: 280px;
  }
  .page-contact .link-card h3 {
    font-size: 1.95rem;
    line-height: 1.1;
    margin-bottom: 0.55rem;
  }
  .page-contact .link-card p {
    font-size: 1.05rem;
    line-height: 1.55;
    margin-bottom: 1rem;
  }
  .page-contact .link-card-action {
    font-size: 0.88rem;
    letter-spacing: 0.02em;
  }
  .page-contact .link-cards {
    padding-bottom: 2.5rem;
  }
  .page-contact .footer {
    margin-top: 1rem;
  }
  .form-page-card {
    padding: 1.2rem 1rem;
  }
  .form-page-card .form-row {
    grid-template-columns: 1fr;
    gap: 0.9rem;
  }
  .form-page-card label {
    font-size: 0.95rem;
  }
  .form-page-card input, .form-page-card select, .form-page-card textarea {
    font-size: 1rem;
    padding: 0.85rem 1rem;
  }
  .form-page-card .btn {
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: 1.05rem;
  }
  .btn {
    font-size: 1.05rem;
    letter-spacing: 0.05em;
    padding: 0.85em 1.9em;
  }
  .nav-cta, .nav-cta-outline {
    font-size: 0.95rem;
    padding: 0.7rem 1.4rem;
  }
  body, p, li, span:not(.label):not(.faq-icon):not(.hero-heading span):not(.outline-fill):not(.hero-line):not( .reveal-line ):not(.reveal-line span):not(.hero-tag span):not(.hero-tag), .impact-block-text p, .about-story-inner p, .hero-sub, .movement-right p, .hscroll-outro-inner > p, .impact-page-intro p {
    font-size: 1.08rem;
  }
  .footer {
    padding: 3rem 1.25rem 0;
  }
  .footer-top {
    gap: 2rem;
  }
  .footer-col h6 {
    font-size: 1.05rem;
    color: var(--color-ink);
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
    letter-spacing: 0.04em;
    margin-bottom: 0.8rem;
  }
  .footer-col a, .footer-col span, .footer-col [data-cms='footer.privacyLink.href'], .footer-col [data-cms='footer.legal.status'], .footer-ein, .footer-address {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--color-body);
  }
  .footer-brand p {
    font-size: 1.05rem;
    line-height: 1.7;
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .footer-brand p strong {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .footer-newsletter-title {
    font-size: 1.6rem;
    line-height: 1.15;
    margin-bottom: 0.4rem;
  }
  .footer-newsletter {
    padding: 1.5rem 0;
    gap: 1rem;
  }
  .footer-newsletter > div > p {
    font-size: 1rem;
    line-height: 1.55;
  }
  .footer-newsletter-form {
    width: 100%;
  }
  .footer-newsletter-form input {
    flex: 1 1 60%;
    min-width: 0;
    padding: 0.85rem 1rem;
  }
  .footer-newsletter-form button {
    flex: 0 0 auto;
    padding: 0.85rem 1rem;
    font-size: 1rem;
  }
  .footer-bottom {
    font-size: 0.92rem;
    padding: 1.5rem 0;
  }
  .gallery-lightbox-nav {
    width: 44px;
    height: 44px;
  }
  .gallery-lightbox img, .site-lightbox img {
    max-width: 94vw;
    max-height: 78vh;
    border-radius: 4px;
  }
  .site-lightbox img {
    max-width: 92vw;
    max-height: 82vh;
  }
  html.gallery-page, html.gallery-page body {
    background: #0c0c0c;
    color: #fff;
  }
  html.gallery-page {
    font-size: 16px;
  }
  .gallery-mobile-grid {
    display: none;
  }
}
@media (max-width: 480px) {
  .nav-help {
    display: inline-block;
    font-size: 0.92rem;
    padding: 0.4rem 0.4rem;
  }
  .nav-cta, .nav-cta-outline {
    padding: 0.55rem 0.95rem;
    font-size: 0.92rem;
  }
  .nav-right {
    gap: 0.55rem;
  }
  .nav-mobile {
    padding: 4.5rem 1.25rem 7rem;
    gap: 1rem;
  }
  .nav-mobile a {
    font-size: clamp(1.85rem, 8vw, 2.4rem);
  }
  .nav-mobile-extra-row {
    font-size: 0.88rem;
  }
  .nav-mobile-newsletter input, .nav-mobile-newsletter button {
    font-size: 0.95rem;
    padding: 0.75rem 0.9rem;
  }
}
@media (min-width: 901px) {
  html.gallery-page canvas {
    position: fixed;
  }
  .footer-col h6 {
    color: var(--color-ink);
  }
  .footer-col a, .footer-col span {
    font-size: 1rem;
    line-height: 1.7;
  }
  .footer-ein, .footer-address {
    font-size: 1rem;
    line-height: 1.7;
  }
  .impact-page-intro {
    padding-top: clamp(7rem, 12vh, 10rem);
    padding-bottom: 2.5rem;
  }
}
.gallery-lightbox {
  z-index: 9999;
}
.gallery-lightbox.active {
  z-index: 10001;
}
.content-split-wide-top {
  max-width: 1320px;
  align-items: start;
}
.split-copy {
  padding-right: clamp(1rem, 3vw, 3rem);
}
.section-h2-tight {
  margin-bottom: 1rem;
}
.mt-15 {
  margin-top: 1.5rem;
}
.mt-20 {
  margin-top: 2rem;
}
.contact-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.contact-row.start {
  align-items: start;
}
.contact-row + .contact-row {
  margin-top: 1rem;
}
.contact-text {
  color: var(--color-ink);
  font-size: 1.05rem;
  line-height: 1.7;
}
.icon-shrink {
  flex-shrink: 0;
}
.icon-shrink.top-2 {
  margin-top: 2px;
}
.social-inline {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.5rem;
}
.social-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 2px solid var(--color-ink);
  border-radius: 50%;
}
.form-page-card.flush {
  margin: 0;
}
.bot-field-trap {
  display: none;
}
.givebutter-embed {
  width: 100%;
  min-height: 600px;
  display: block;
}
.mail-check-box {
  margin-top: 2rem;
  padding: 1.2rem 1.5rem;
  border: 1px solid var(--rule);
  border-radius: 4px;
  background-color: var(--color-white);
}
.mail-check-box-label {
  font-size: 0.9rem;
}
.mail-check-box-address {
  color: var(--color-ink);
  line-height: 1.7;
  font-size: 1rem;
}
.tax-line {
  margin-top: 1.5rem;
  font-size: 0.88rem;
  color: var(--color-ink);
}
.contact-hours-note {
  margin-top: 0.5rem;
  font-size: 0.95rem;
  color: var(--color-muted);
}
.faq-top-gap {
  margin-top: 0.75rem;
}
.share-widget {
  position: fixed;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 900;
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}
.share-widget.visible {
  opacity: 1;
  pointer-events: auto;
}
.share-tab {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 0.35rem;
  background-color: var(--color-white);
  color: var(--color-body);
  border: 1px solid var(--rule);
  border-left: none;
  border-radius: 0 6px 6px 0;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  --tw-font-weight: var(--font-weight-medium);
  font-weight: var(--font-weight-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: background 0.2s ease;
  white-space: nowrap;
  writing-mode: vertical-lr;
  text-orientation: sideways;
}
.share-tab svg {
  width: 12px;
  height: 12px;
  fill: none;
  stroke: var(--body);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.share-tab:hover {
  background: var(--sand);
}
.share-panel {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%) translateX(-100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  border-left: none;
  border-radius: 0 8px 8px 0;
  box-shadow: 2px 2px 12px rgba(0, 0, 0, 0.06);
  padding: 0.4rem 0.35rem;
  opacity: 0;
  pointer-events: none;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.share-panel.open {
  transform: translateY(-50%) translateX(0);
  opacity: 1;
  pointer-events: auto;
}
.share-panel-header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 0.1rem;
  width: 100%;
}
.share-panel-title {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  --tw-font-weight: var(--font-weight-semibold);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
  white-space: nowrap;
}
.share-panel-close {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  border: 1px solid var(--rule);
  cursor: pointer;
  color: var(--color-muted);
  border-radius: 50%;
  transition: background 0.2s ease;
  flex-shrink: 0;
  position: absolute;
  top: -8px;
  right: -8px;
  z-index: 2;
  padding: 0;
}
.share-panel-close:hover {
  background: var(--sand);
}
.share-panel-close svg {
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  fill: none;
}
.share-panel-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
}
.share-panel-links a, .share-panel-links button {
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--rule);
  background-color: var(--color-white);
  color: var(--color-body);
  cursor: pointer;
  text-decoration: none;
  font-size: 0;
  position: relative;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.share-panel-links a:hover, .share-panel-links button:hover {
  background: var(--sand);
  border-color: var(--body);
}
.share-panel-links svg {
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  fill: none;
  stroke: var(--body);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
@media (max-width: 768px) {
  .share-widget {
    display: none;
  }
}
.hscroll-outro-email {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-cream);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity 0.3s ease;
}
.hscroll-outro-email:hover {
  opacity: 0.7;
}
.work-card-last {
  margin-right: 1rem;
}
@media (max-width: 768px) {
  .nav-help {
    display: inline-block !important;
    font-size: 0.72rem !important;
    padding: 0.35rem 0.5rem !important;
    white-space: nowrap !important;
    color: var(--ink) !important;
  }
  .nav-right {
    gap: 0.5rem !important;
  }
  .nav-cta {
    font-size: 0.75rem !important;
    padding: 0.55rem 1rem !important;
  }
  .hero-partners {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 1.25rem 0.8rem !important;
    align-items: center !important;
    justify-items: center !important;
    overflow-x: visible !important;
    width: 100% !important;
    padding-bottom: 0 !important;
    margin-top: 1.5rem !important;
  }
  .hero-partners span {
    grid-column: span 3 !important;
    width: 100% !important;
    text-align: left !important;
    margin-bottom: 0.25rem !important;
  }
  .hero-partners img {
    height: clamp(26px, 6.5vw, 34px) !important;
    width: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
    opacity: 0.75 !important;
  }
  .hero-partners a:nth-child(6) img {
    height: clamp(42px, 10vw, 48px) !important;
  }
  .movement-overlay {
    inset: -2px !important;
  }
  .hscroll-section {
    overflow: hidden !important;
    height: auto !important;
  }
  .hscroll-track {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 2.5rem 1.25rem !important;
    height: auto !important;
    gap: 1.25rem !important;
    scrollbar-width: none !important;
  }
  .hscroll-track::-webkit-scrollbar {
    display: none !important;
  }
  .hscroll-intro {
    flex: 0 0 280px !important;
    scroll-snap-align: center !important;
    padding-right: 0 !important;
    justify-content: center !important;
  }
  .hscroll-intro h2 {
    font-size: clamp(2rem, 7vw, 2.6rem) !important;
  }
  .hscroll-intro p {
    font-size: 1.05rem !important;
    line-height: 1.6 !important;
  }
  .work-card {
    flex: 0 0 310px !important;
    scroll-snap-align: center !important;
    height: auto !important;
    align-self: stretch !important;
  }
  .work-card-info p:last-child {
    font-size: 1rem !important;
    line-height: 1.6 !important;
  }
  .hscroll-outro {
    flex: 0 0 310px !important;
    scroll-snap-align: center !important;
    width: auto !important;
    padding: 2.5rem 1.5rem !important;
    border-radius: 3px !important;
    margin-left: 0 !important;
    align-self: stretch !important;
  }
  .hscroll-outro h2 {
    font-size: 2.2rem !important;
  }
  .hscroll-outro-inner {
    padding: 0 !important;
  }
  .brand-overlay {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: 100% !important;
    height: auto !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    background: var(--ink) !important;
    padding: 4rem 1.25rem !important;
    margin-top: 1.5rem !important;
    display: block !important;
  }
  .brand-overlay-bg {
    display: none !important;
  }
  .brand-inner {
    padding: 0 !important;
    max-width: 100% !important;
    transform: none !important;
    opacity: 1 !important;
    scale: 1 !important;
    text-align: left !important;
  }
  .brand-card {
    position: relative !important;
    inset: 0 !important;
    background: rgba(250, 250, 248, 0.96) !important;
    border-radius: 12px !important;
    padding: 2rem 1.25rem !important;
    margin-bottom: 2rem !important;
    opacity: 1 !important;
    transform: none !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15) !important;
    text-align: left !important;
  }
  .brand-overlay .brand-heading {
    color: var(--ink) !important;
    text-align: left !important;
    font-size: clamp(1.8rem, 6.5vw, 2.4rem) !important;
    margin-bottom: 1.2rem !important;
  }
  .brand-overlay .brand-founders {
    color: var(--muted) !important;
    text-align: left !important;
    font-size: 0.85rem !important;
    margin-bottom: 0.5rem !important;
  }
  .brand-overlay .brand-body p {
    color: var(--body) !important;
    text-align: left !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    margin-bottom: 1rem !important;
  }
  .brand-overlay .brand-tagline {
    color: var(--ink) !important;
    text-align: left !important;
    font-size: 1.1rem !important;
    line-height: 1.5 !important;
    margin-top: 1.5rem !important;
  }
  .brand-overlay .btn-ghost {
    background-color: var(--ink) !important;
    color: var(--cream) !important;
    border-color: var(--ink) !important;
    width: 100% !important;
    text-align: center !important;
    display: block !important;
  }
  .scrollstack-card {
    width: 90% !important;
    padding: 1.6rem 1.25rem !important;
    min-height: auto !important;
  }
  .scrollstack-card-text h2 {
    font-size: 1.4rem !important;
    line-height: 1.2 !important;
  }
  .scrollstack-card-text p {
    font-size: 0.98rem !important;
    line-height: 1.55 !important;
    color: var(--body) !important;
  }
  .faq-section h2 {
    font-size: clamp(1.8rem, 6vw, 2.4rem) !important;
  }
  .footer {
    text-align: left !important;
    padding: 3rem 1.25rem 2rem !important;
  }
  .footer-top {
    text-align: left !important;
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
  .footer-col {
    align-items: flex-start !important;
  }
  .footer-col h6 {
    font-size: 0.85rem !important;
    margin-bottom: 0.6rem !important;
  }
  .footer-col a, .footer-col span {
    font-size: 1.05rem !important;
    line-height: 1.6 !important;
  }
  .footer-newsletter {
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
    padding: 2.5rem 0 !important;
    gap: 1.5rem !important;
  }
  .footer-newsletter-title {
    font-size: 1.8rem !important;
    margin-bottom: 0.5rem !important;
  }
  .footer-newsletter > div > p {
    margin-bottom: 1.2rem !important;
    font-size: 1.05rem !important;
    line-height: 1.6 !important;
  }
  .footer-newsletter-form {
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.8rem !important;
  }
  .footer-newsletter-form input {
    width: 100% !important;
    font-size: 1.05rem !important;
    padding: 0.9rem 1.1rem !important;
  }
  .footer-newsletter-form button {
    width: 100% !important;
    font-size: 1.05rem !important;
    padding: 0.9rem 1.1rem !important;
  }
  .footer-bottom {
    text-align: left !important;
    align-items: flex-start !important;
    font-size: 0.78rem !important;
    line-height: 1.5 !important;
    color: var(--faint) !important;
  }
  .impact-page-intro {
    padding: 6rem 1.25rem 2rem !important;
  }
}
.page-impact {
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  overflow-x: hidden;
}
.page-impact .impact-hero {
  padding: clamp(7rem, 14vh, 11rem) var(--gap) clamp(3rem, 6vh, 6rem);
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
}
.page-impact .impact-hero-container {
  max-width: 840px;
  margin: 0 auto clamp(3rem, 6vh, 5rem);
}
.page-impact .impact-hero .label {
  display: inline-block;
  font-family: var(--sans);
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--faint);
  margin-bottom: 1.2rem;
  font-weight: 600;
}
.page-impact .impact-hero h1 {
  font-family: var(--serif);
  font-size: clamp(2.8rem, 7vw, 4.8rem);
  line-height: 1.08;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 1.5rem;
  letter-spacing: -0.02em;
}
.page-impact .impact-hero-subtitle {
  font-family: var(--sans);
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.75;
  color: var(--body);
  font-weight: 400;
  max-width: 680px;
  margin: 0 auto;
  text-wrap: pretty;
}
.page-impact .impact-hero-grid-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
.page-impact .impact-hero-grid-3, .page-impact .impact-hero-grid-2 {
  display: grid;
  gap: 1rem;
  width: 100%;
}
.page-impact .impact-hero-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}
.page-impact .impact-hero-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}
.page-impact .impact-hero-grid-wrapper .img-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  aspect-ratio: 4 / 3;
}
.page-impact .impact-hero-grid-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  cursor: pointer;
}
.page-impact .impact-hero-grid-wrapper .img-wrap:hover img {
  transform: scale(1.05);
}
.page-impact .impact-highlight-section {
  padding: clamp(5rem, 10vh, 8rem) var(--gap);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: rgba(240, 238, 233, 0.25);
}
.page-impact .impact-highlight-text {
  font-family: var(--serif);
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  line-height: 1.25;
  font-weight: 900;
  max-width: 1050px;
  margin: 0 auto;
  text-align: center;
  color: #000;
}
.page-impact .highlight-muted {
  font-weight: 500;
}
.page-impact .blur-word {
  display: inline-block;
  will-change: transform, filter, opacity;
  opacity: 0;
  filter: blur(10px);
  transform: translateY(-50px);
  color: #000;
}
.page-impact .highlight-muted .blur-word {
  color: #52523e;
}
.page-impact .blur-word.animate {
  animation: blurTextAnimation 0.7s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@keyframes blurTextAnimation {
  0% {
    filter: blur(10px);
    opacity: 0;
    transform: translateY(-50px);
  }
  50% {
    filter: blur(5px);
    opacity: 0.5;
    transform: translateY(5px);
  }
  100% {
    filter: blur(0px);
    opacity: 1;
    transform: translateY(0);
  }
}
.page-impact span.label, .page-impact .label {
  color: #52523e;
}
.page-impact .impact-stats-section {
  padding: clamp(3.5rem, 7vh, 5.5rem) 0;
  margin-bottom: 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  width: 100%;
}
.page-impact .impact-stats-header {
  text-align: center;
  max-width: 620px;
  margin: 0 auto clamp(2.5rem, 5vh, 4rem);
}
.page-impact .impact-stats-header .label {
  font-family: var(--sans);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--faint);
  margin-bottom: 0.8rem;
}
.page-impact .impact-stats-header h2 {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  line-height: 1.12;
  font-weight: 500;
  color: var(--ink);
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  letter-spacing: -0.01em;
}
.page-impact .impact-stats-header h2 em {
  font-style: italic;
  font-weight: 300;
}
.page-impact .impact-stats-intro {
  font-family: var(--sans);
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.75;
  color: var(--body);
  font-weight: 400;
}
.page-impact .stats-tabs-widget {
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
}
.page-impact .stats-tabs-nav {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  background: #edece9;
  padding: 6px;
  border-radius: 30px;
  max-width: 620px;
  margin: 0 auto 2.5rem;
  width: 100%;
}
.page-impact .stats-tab-btn {
  font-family: var(--sans);
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--color-muted);
  white-space: nowrap;
  border: none;
  background: transparent;
  padding: 0.6rem 1.4rem;
  border-radius: 20px;
  cursor: pointer;
  transition: all 0.3s var(--ease);
  flex: 1;
  text-align: center;
}
.page-impact .stats-tab-btn:hover {
  color: var(--color-ink);
}
.page-impact .stats-tab-btn.active {
  background: #ffffff;
  color: var(--color-ink);
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}
.page-impact .stats-tabs-content {
  background-color: #F2EFE6;
  width: 1100px;
  max-width: 100%;
  margin: 0 auto;
  border: 1px solid rgba(17, 17, 17, 0.07);
  border-radius: 16px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.02);
  padding: clamp(2rem, 5vw, 3rem);
  box-sizing: border-box;
}
.page-impact .stats-tab-panel {
  display: none;
}
.page-impact .stats-tab-panel.active {
  display: block;
  animation: fadeIn 0.4s var(--ease);
}
.page-impact .stats-panel-grid {
  display: grid;
  grid-template-columns: 1fr 1.8fr;
  gap: clamp(2rem, 5vw, 3rem);
  align-items: center;
  background-color: #F2EFE6;
}
.page-impact .stats-panel-metric {
  border-right: 1px solid var(--rule);
  padding-right: clamp(1.5rem, 3vw, 2.5rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.page-impact .stats-big-number {
  font-family: var(--serif);
  font-size: 160px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 50px;
  letter-spacing: -0.02em;
}
.page-impact .stats-metric-label {
  font-family: var(--sans);
  color: #52523e;
  line-height: 23px;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.page-impact div.stats-tabs-content div div h3 {
  font-family: var(--sans);
  font-size: 46px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 0.8rem;
}
.page-impact .stats-panel-text p {
  font-family: var(--sans);
  color: black;
  font-size: 20px;
  line-height: 1.6;
  margin-bottom: 1rem;
}
.page-impact .stats-panel-text p:last-of-type {
  margin-bottom: 1.2rem;
}
.page-impact .stats-panel-citation {
  font-family: var(--sans);
  font-size: 15px;
  color: black;
  border-top: 1px dashed rgba(17, 17, 17, 0.08);
  padding-top: 0.75rem;
  margin-top: 0.5rem;
}
.page-impact .stats-link {
  color: var(--color-ink);
  font-weight: 500;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: opacity 0.2s var(--ease);
}
.page-impact .stats-link:hover {
  opacity: 0.7;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 767px) {
  .page-impact .stats-tabs-content {
    width: 100%;
    padding: 1.5rem;
  }
  .page-impact .stats-tabs-nav {
    max-width: 100%;
    border-radius: 20px;
  }
  .page-impact .stats-tab-btn {
    font-size: 0.85rem;
    padding: 0.5rem 0.8rem;
  }
  .page-impact .stats-panel-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
    text-align: center;
  }
  .page-impact .stats-panel-metric {
    border-right: none;
    border-bottom: 1px solid var(--rule);
    padding-right: 0;
    padding-bottom: 1.5rem;
  }
  .page-impact .stats-big-number {
    font-size: 80px;
    margin-bottom: 20px;
  }
  .page-impact .stats-panel-text h3 {
    text-align: center;
    font-size: 28px;
  }
  .page-impact .stats-panel-text p {
    font-size: 16px;
  }
}
.page-impact .impact-stories-container {
  padding: clamp(4rem, 8vh, 7rem) 0;
  background: var(--cream);
}
.page-impact .impact-story-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 0;
  align-items: stretch;
  margin-bottom: clamp(4rem, 8vh, 6rem);
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(17, 17, 17, 0.07);
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02), 0 8px 32px rgba(0, 0, 0, 0.03);
}
.page-impact .impact-story-row:last-child {
  margin-bottom: 0;
}
.page-impact .impact-story-row.reverse {
  grid-template-columns: 1fr 1.4fr;
}
.page-impact .impact-story-row.reverse .impact-story-card {
  order: 2;
}
.page-impact .impact-story-row.reverse .impact-story-gallery {
  order: 1;
}
.page-impact .impact-story-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(2.5rem, 5vh, 4rem) clamp(2rem, 4vw, 3rem);
  background: #ffffff;
  box-sizing: border-box;
  height: 100%;
}
.page-impact .impact-story-card.tile-white {
  padding-bottom: clamp(2.5rem, 5vh, 4rem);
}
.page-impact .story-body-text p:last-child, .page-impact .story-body-text > *:last-child {
  margin-bottom: 0 !important;
}
.page-impact .impact-story-card .label {
  font-family: var(--sans);
  font-size: 0.95rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #52523e;
  margin-bottom: 1rem;
  font-weight: 600;
}
.page-impact .impact-story-card h2 {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  line-height: 1.12;
  font-weight: 500;
  margin-bottom: 1.2rem;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.page-impact .impact-story-card h2 em {
  font-style: italic;
  font-weight: 600;
}
.page-impact .story-body-text, .page-impact .story-body-text p {
  font-family: var(--sans);
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  line-height: 1.75;
  color: var(--body);
  font-weight: 400;
}
.page-impact .story-body-text p {
  margin-bottom: 1rem;
}
.page-impact .story-body-text p:last-child {
  margin-bottom: 0;
}
.page-impact .impact-story-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  background: var(--sand);
  padding: 10px;
  aspect-ratio: 1 / 1;
  box-sizing: border-box;
  align-content: center;
}
.page-impact .impact-story-gallery .img-wrap {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
}
.page-impact .impact-story-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 8px;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  cursor: pointer;
}
.page-impact .impact-story-gallery .img-wrap:hover img {
  transform: scale(1.05);
}
.page-impact .impact-story-gallery .fig-label {
  position: absolute;
  bottom: 0.75rem;
  left: 0.75rem;
  background: rgba(17, 17, 17, 0.82);
  color: #fff;
  font-family: var(--sans);
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 0.22rem 0.55rem;
  border-radius: 4px;
  pointer-events: none;
  z-index: 2;
}
.page-impact .impact-story-row.scroll-fade-up {
  opacity: 1;
  transform: translateY(0);
}
.js-enabled .impact-story-row.scroll-fade-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1), transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}
.js-enabled .impact-story-row.scroll-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 991px) {
  .page-impact .impact-story-row, .page-impact .impact-story-row.reverse {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 767px) {
  .page-impact .impact-hero {
    padding: 6.5rem 1.25rem 2.5rem;
  }
  .page-impact .impact-hero-container {
    margin-bottom: 2rem;
  }
  .page-impact .impact-hero h1 {
    font-size: clamp(2.2rem, 8vw, 3rem);
  }
  .page-impact .impact-hero-grid-wrapper {
    gap: 0.5rem;
  }
  .page-impact .impact-hero-grid-3 {
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
  }
  .page-impact .impact-hero-grid-2 {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
  }
  .page-impact .impact-hero-grid-wrapper .img-wrap {
    aspect-ratio: 4 / 3;
    border-radius: 6px;
  }
  .page-impact .impact-highlight-section {
    padding: 3rem 1.25rem;
  }
  .page-impact .impact-highlight-text {
    font-size: clamp(1.4rem, 5vw, 1.8rem);
    line-height: 1.35;
  }
  .page-impact .impact-stats-section {
    padding: 3.5rem 1.25rem;
  }
  .page-impact .impact-stats-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding: 2.5rem 0;
  }
  .page-impact .impact-stories-container {
    padding: 2.5rem 0;
  }
  .page-impact .impact-story-row {
    grid-template-columns: 1fr;
    gap: 0;
    margin-bottom: 2rem;
    padding: 0;
    width: calc(100% - 2rem);
    margin-left: auto;
    margin-right: auto;
    border-radius: 12px;
  }
  .page-impact .impact-story-row, .page-impact .impact-story-row.reverse {
    display: flex;
    flex-direction: column;
  }
  .page-impact .impact-story-row .impact-story-gallery, .page-impact .impact-story-row.reverse .impact-story-gallery {
    order: 1;
    width: 100%;
    aspect-ratio: auto;
    grid-template-columns: 1fr;
    padding: 8px;
    gap: 8px;
  }
  .page-impact .impact-story-row .impact-story-card, .page-impact .impact-story-row.reverse .impact-story-card {
    order: 2;
    width: 100%;
    padding: clamp(1.5rem, 5vw, 2.5rem);
    aspect-ratio: auto;
    justify-content: center;
  }
}
.page-impact .final-cta {
  background: var(--cream) !important;
}
.page-impact .final-cta-bg {
  display: block !important;
  opacity: 0.18 !important;
}
.page-impact .final-cta::after {
  display: block !important;
  background: rgba(250, 250, 248, 0.9) !important;
}
.page-impact .final-cta-content h2 {
  color: var(--color-ink) !important;
}
.page-impact .final-cta-content h2 em {
  color: var(--color-ink) !important;
  opacity: 0.85;
}
.page-impact .final-cta-content p:not(.cta-tag) {
  color: var(--color-body) !important;
  opacity: 0.9;
}
.final-cta-actions .btn, .hscroll-outro-actions .btn {
  min-width: 13rem;
  text-align: center;
}
.footer p.footer-newsletter-title {
  font-size: 40px;
}
.footer div p small {
  color: black !important;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-font-weight: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-ease: initial;
      --tw-leading: initial;
    }
  }
}
