/* Go Ukraina: investor-grade editorial UI. WCAG-oriented contrast, Fraunces + Outfit. */

:root {
  /* Deeper ink on cream ≥ 4.5:1; gold/blue accents stay on-brand */
  --uk-blue: oklch(45% 0.14 255);
  --uk-blue-deep: oklch(28% 0.11 255);
  --uk-blue-mid: oklch(38% 0.12 255);
  --uk-gold: oklch(82% 0.15 92);
  --uk-gold-bright: oklch(88% 0.16 95);
  --uk-gold-muted: oklch(72% 0.11 92);
  --cream: oklch(99% 0.008 95);
  --cream-warm: oklch(97% 0.02 95);
  --ink: oklch(16% 0.03 255);
  --ink-muted: oklch(28% 0.04 255);
  --ink-soft: oklch(34% 0.035 255);
  --line: color-mix(in oklch, var(--uk-blue-deep) 22%, transparent);
  --line-strong: color-mix(in oklch, var(--uk-blue-deep) 35%, transparent);
  --focus-ring: oklch(55% 0.2 255);
  --font-display: "Fraunces", "Georgia", serif;
  --font-ui: "Outfit", system-ui, sans-serif;
  --space-2xs: 0.25rem;
  --space-micro: 0.375rem;
  --space-xs: clamp(0.5rem, 1.5vw, 0.75rem);
  --space-sm: clamp(0.75rem, 2vw, 1rem);
  --space-md: clamp(1.25rem, 3vw, 2rem);
  --space-lg: clamp(2rem, 5vw, 4rem);
  --space-xl: clamp(3rem, 8vw, 7rem);
  --radius: 0.35rem;
  --radius-lg: 0.75rem;
  --shadow-soft: 0 1rem 2.5rem oklch(18% 0.04 255 / 0.1);
  --shadow-elevated: 0 1.25rem 3rem oklch(15% 0.05 255 / 0.14);
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  /* Liquid notch / sheets (matches spec ~500ms Material ease) */
  --ease-nav: cubic-bezier(0.4, 0, 0.2, 1);
  --bottom-nav-h: 4.5rem;
  --header-h: 4.25rem;
  /* Full-height mobile drawer (avoid inset/top quirks) */
  --nav-drawer-h: calc(100dvh - var(--header-h));
  --nav-drawer-h-fallback: calc(100vh - var(--header-h));
  /* Editorial section rhythm (charity landing references) */
  --section-pad-y: clamp(3rem, 7vw, 5.75rem);
  --section-pad-y-tight: clamp(2.25rem, 5vw, 3.75rem);
  --pad-inline: clamp(1rem, 4vw, 2rem);
  /* Editorial column (~1152px at 16px); header, footer, and sections share this rail */
  --content-max: 72rem;
  /* Space between last page content and footer (one rhythm token; pair with main padding-bottom: 0 on dense pages) */
  --page-footer-gap: clamp(1.35rem, 3.5vw, 2.5rem);
}

@media (min-width: 1024px) {
  :root {
    --pad-inline: clamp(1.5rem, 5vw, 3rem);
  }
}

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

html {
  scroll-behavior: smooth;
}

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

body {
  margin: 0;
  font-family: var(--font-ui);
  font-weight: 400;
  font-size: clamp(1rem, 0.35vw + 0.92rem, 1.125rem);
  line-height: 1.6;
  color: var(--ink);
  background: var(--cream);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  touch-action: manipulation;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.035;
  z-index: 9998;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

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

a {
  color: var(--uk-blue-deep);
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.18em;
  transition: color 0.2s var(--ease-out), text-underline-offset 0.2s var(--ease-out);
}

a:hover {
  color: var(--uk-blue-mid);
}

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

.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 10001;
  padding: 0.75rem 1.25rem;
  background: var(--uk-blue-deep);
  color: var(--cream);
  font-weight: 600;
  border-radius: var(--radius);
}

.skip-link:focus {
  left: var(--space-sm);
  top: var(--space-sm);
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* -- Mobile nav backdrop -- */
.nav-backdrop {
  position: fixed;
  inset: 0;
  top: var(--header-h);
  background: oklch(12% 0.02 255 / 0.55);
  z-index: 1000;
  opacity: 0;
  transition: opacity 0.3s var(--ease-out);
  pointer-events: none;
}

body.nav-open .nav-backdrop {
  opacity: 1;
  pointer-events: auto;
}

.mobile-bottom-nav {
  display: none;
}

@media (min-width: 1024px) {
  .nav-backdrop {
    display: none !important;
  }

  .mobile-more-panel {
    display: none !important;
  }
}

/* -- Header -- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  min-height: var(--header-h);
  background: color-mix(in oklch, var(--cream) 94%, transparent);
  backdrop-filter: blur(16px) saturate(1.2);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 1px 0 color-mix(in oklch, var(--cream) 50%, transparent);
}

.header-inner {
  box-sizing: border-box;
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0.75rem var(--pad-inline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  position: relative;
  z-index: 1;
}

@media (max-width: 1023px) {
  /*
   * backdrop-filter on the header creates a containing block in WebKit/Safari that breaks
   * position:fixed children: the old full-screen “More” sheet lived inside <header> and
   * appeared stuck open while pointer-events stayed wrong. Disable blur on small viewports.
   */
  .site-header {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: color-mix(in oklch, var(--cream) 97%, oklch(96% 0.015 95));
  }

  .header-inner {
    padding: 0.75rem var(--pad-inline);
    min-height: 3.75rem;
  }
}

.logo-link {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  text-decoration: none;
  flex-shrink: 0;
  border-radius: var(--radius);
  position: relative;
  z-index: 1002;
}

.logo-link:focus-visible {
  outline-offset: 4px;
}

.logo-link img {
  height: clamp(2.35rem, 4vw, 3rem);
  width: auto;
}

@media (hover: hover) and (pointer: fine) {
  .logo-link {
    transition: transform 0.2s var(--ease-out);
  }

  .logo-link:hover {
    transform: scale(1.02);
  }

  .logo-link:active {
    transform: scale(0.99);
    transition-duration: 0.12s;
  }
}

.nav-main {
  display: flex;
  align-items: center;
  gap: clamp(0.25rem, 1.2vw, 1rem);
}

.nav-panel-label {
  display: none;
}

.nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.5rem 0.75rem;
  font-size: 0.9375rem;
  font-weight: 550;
  letter-spacing: 0.01em;
  text-decoration: none;
  color: var(--ink-soft);
  border-radius: var(--radius);
  transition: color 0.2s var(--ease-out), background 0.2s var(--ease-out);
}

.nav-link:hover {
  color: var(--ink);
  background: color-mix(in oklch, var(--uk-blue) 6%, transparent);
}

.nav-link[aria-current="page"] {
  color: var(--uk-blue-deep);
  font-weight: 650;
}

.nav-link[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 0.75rem;
  right: 0.75rem;
  bottom: 6px;
  height: 3px;
  border-radius: 2px;
  /* Hard stops: OKLCH hue-mix between gold and blue skews green; flag is yellow | blue */
  background: linear-gradient(
    90deg,
    var(--uk-gold) 0%,
    var(--uk-gold) 50%,
    var(--uk-blue) 50%,
    var(--uk-blue) 100%
  );
}

.nav-dropdown {
  position: relative;
  /* Prevent flex from stretching <details> full-width so the panel stays under the label */
  flex: 0 0 auto;
  width: fit-content;
  max-width: 100%;
}

.nav-dropdown-summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.5rem 0.65rem;
  font-size: 0.9375rem;
  font-weight: 550;
  font-family: var(--font-ui);
  color: var(--ink-soft);
  border-radius: var(--radius);
  transition: color 0.2s var(--ease-out), background 0.2s var(--ease-out);
}

.nav-dropdown-summary::-webkit-details-marker {
  display: none;
}

/* Down chevron always reserved so hover/open does not shift sibling nav items */
.nav-dropdown-summary::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: 0.35rem;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid currentColor;
  flex-shrink: 0;
  transform-origin: 50% 35%;
  transition: transform 0.2s var(--ease-out);
}

.nav-dropdown[open] .nav-dropdown-summary::after {
  transform: rotate(180deg);
}

.nav-dropdown-summary:hover,
.nav-dropdown[open] .nav-dropdown-summary {
  color: var(--ink);
  background: color-mix(in oklch, var(--uk-blue) 6%, transparent);
}

.dropdown-panel {
  position: absolute;
  top: calc(100% + 0.35rem);
  left: 0;
  min-width: 15rem;
  padding: 0.5rem;
  background: var(--cream);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-elevated);
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  z-index: 60;
  transform-origin: top left;
  transition: opacity 0.22s var(--ease-out), transform 0.22s var(--ease-out);
}

.nav-dropdown[open] .dropdown-panel {
  opacity: 1;
  transform: none;
}

@starting-style {
  .nav-dropdown[open] .dropdown-panel {
    opacity: 0;
    transform: translateY(-0.35rem) scale(0.96);
  }
}

.dropdown-panel .nav-link {
  width: 100%;
  /* Reserve gutter for optional current-page accent bar so labels align and text never crowds the bar */
  padding: 0.65rem 0.85rem 0.65rem 1.5rem;
  border-radius: var(--radius);
}

.dropdown-panel .nav-link[aria-current="page"]::after {
  left: 0.85rem;
  right: auto;
  width: 3px;
  top: 0.35rem;
  bottom: 0.35rem;
  height: auto;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    var(--uk-gold) 0%,
    var(--uk-gold) 50%,
    var(--uk-blue) 50%,
    var(--uk-blue) 100%
  );
}

.nav-donate.nav-donate {
  margin-left: 0.35rem;
  min-height: 44px;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

/* Header Donate: gold field + blue type (distinct from primary blue buttons elsewhere) */
.nav-donate.btn-gold[aria-current="page"] {
  box-shadow:
    0 0 0 2px var(--uk-blue-deep),
    0 0.15rem 0 color-mix(in oklch, var(--uk-gold-muted) 50%, transparent);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 44px;
  padding: 0.65rem 1.35rem;
  font-family: var(--font-ui);
  font-size: 0.8125rem;
  font-weight: 650;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  cursor: pointer;
  border-radius: var(--radius);
  transition: transform 0.22s var(--ease-out), box-shadow 0.22s var(--ease-out), background 0.22s var(--ease-out);
}

.btn:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 3px;
}

.btn:active {
  transform: scale(0.985);
  transition-duration: 0.12s;
}

.btn-primary:active {
  transform: translateY(0) scale(0.985);
}

.btn-gold:active {
  transform: scale(0.985);
}

.btn-primary {
  background: var(--uk-blue-deep);
  color: oklch(99% 0.01 95);
  box-shadow: 0 0.2rem 0 oklch(18% 0.06 255);
}

.btn-primary:hover {
  transform: translateY(-2px);
  color: oklch(99% 0.01 95);
  background: oklch(30% 0.11 255);
}

.btn-primary:hover:active {
  transform: translateY(0) scale(0.985);
}

.btn-primary[aria-current="page"] {
  box-shadow: 0 0 0 2px var(--uk-gold), 0 0.2rem 0 oklch(18% 0.06 255);
}

.btn-gold {
  background: var(--uk-gold-bright);
  color: var(--uk-blue-deep);
  box-shadow: 0 0.15rem 0 color-mix(in oklch, var(--uk-gold-muted) 50%, transparent);
}

.btn-gold:hover {
  background: var(--uk-gold);
  color: var(--uk-blue-deep);
}

.nav-toggle {
  display: none;
  position: relative;
  z-index: 1002;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  padding: 0;
  align-items: center;
  justify-content: center;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  cursor: pointer;
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.nav-toggle:hover {
  background: color-mix(in oklch, var(--uk-blue) 12%, var(--cream));
}

.nav-toggle:active {
  transform: scale(0.96);
  transition-duration: 0.12s;
}

.nav-toggle-icon {
  position: relative;
  display: block;
  width: 22px;
  height: 2px;
  background: var(--uk-blue-deep);
  border-radius: 1px;
  transition: background 0.2s var(--ease-out);
}

.nav-toggle-icon::before,
.nav-toggle-icon::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--uk-blue-deep);
  border-radius: 1px;
  transition: transform 0.28s var(--ease-out), top 0.28s var(--ease-out), background 0.2s var(--ease-out);
}

.nav-toggle-icon::before {
  top: -7px;
}

.nav-toggle-icon::after {
  top: 7px;
}

body.nav-open .nav-toggle-icon {
  background: transparent;
}

body.nav-open .nav-toggle-icon::before {
  top: 0;
  transform: rotate(45deg);
}

body.nav-open .nav-toggle-icon::after {
  top: 0;
  transform: rotate(-45deg);
}

@media (max-width: 1023px) {
  .nav-backdrop {
    top: 0;
    z-index: 5400;
  }

  main#main {
    padding-bottom: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom, 0px) + 0.75rem);
  }

  /*
   * Mobile: hide the desktop nav row; “More” opens #more-toolbar (after <header>):
   * compact horizontal icon strip above the liquid tab bar (not a full-screen list).
   */
  .nav-main--desktop {
    display: none !important;
  }

  body.nav-open .nav-backdrop {
    z-index: 5300;
  }

  body.nav-open .mobile-bottom-nav {
    z-index: 5600;
  }

  .mobile-more-panel {
    position: fixed;
    left: 0;
    right: 0;
    bottom: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom, 0px));
    z-index: 5450;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    /* Cap height so the sheet never grows under the status bar on short viewports */
    max-height: min(28rem, calc(100vh - var(--bottom-nav-h) - env(safe-area-inset-bottom, 0px) - env(safe-area-inset-top, 0px) - 0.75rem));
    padding: 0.35rem env(safe-area-inset-left, 0px) 0.55rem env(safe-area-inset-right, 0px);
    overflow-x: hidden;
    overflow-y: hidden;
    display: flex;
    flex-direction: column;
    background: linear-gradient(
      165deg,
      oklch(26% 0.1 255) 0%,
      var(--uk-blue-deep) 42%,
      oklch(20% 0.09 255) 100%
    );
    border-radius: 1.15rem 1.15rem 0 0;
    border: 1px solid color-mix(in oklch, var(--uk-gold) 28%, transparent);
    border-bottom: none;
    box-shadow: 0 -0.4rem 1.75rem oklch(8% 0.04 255 / 0.55);
    transform: translate3d(0, 115%, 0);
    visibility: hidden;
    pointer-events: none;
    touch-action: manipulation;
    transition:
      transform 0.45s var(--ease-nav),
      visibility 0.45s var(--ease-nav);
  }

  body.nav-open .mobile-more-panel {
    transform: translate3d(0, 0, 0);
    visibility: visible;
    pointer-events: auto;
    z-index: 5700;
  }

  .nav-panel-label--toolbar {
    display: block;
    margin: 0;
    padding: 0.35rem clamp(0.75rem, 3vw, 1rem) 0.4rem;
    font-family: var(--font-ui);
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: color-mix(in oklch, var(--uk-gold-bright) 75%, transparent);
    border-bottom: 1px solid color-mix(in oklch, oklch(98% 0.01 95) 12%, transparent);
    flex-shrink: 0;
  }

  .mobile-more-panel__track {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    gap: 0.35rem;
    min-width: 0;
    flex: 1 1 auto;
    padding: 0.45rem clamp(0.5rem, 2vw, 0.75rem) 0.35rem;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    scrollbar-color: color-mix(in oklch, var(--uk-gold-bright) 40%, transparent) transparent;
  }

  .nav-tile {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0.2rem;
    min-width: 4rem;
    max-width: 5.25rem;
    padding: 0.35rem 0.3rem 0.3rem;
    border-radius: var(--radius-lg);
    text-decoration: none;
    font-family: var(--font-ui);
    font-size: 0.6rem;
    font-weight: 650;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    line-height: 1.1;
    color: oklch(95% 0.015 95);
    background: color-mix(in oklch, oklch(98% 0.01 95) 6%, transparent);
    border: 1px solid color-mix(in oklch, oklch(98% 0.01 95) 10%, transparent);
    transition: background 0.2s var(--ease-out), color 0.2s var(--ease-out), transform 0.2s var(--ease-out);
  }

  .nav-tile:hover {
    background: color-mix(in oklch, oklch(98% 0.01 95) 12%, transparent);
    color: oklch(99% 0.01 95);
  }

  .nav-tile:active {
    transform: scale(0.96);
    transition-duration: 0.12s;
  }

  .nav-tile[aria-current="page"] {
    color: var(--uk-blue-deep);
    background: linear-gradient(
      160deg,
      var(--uk-gold-bright),
      color-mix(in oklch, var(--uk-gold) 85%, var(--uk-gold-muted))
    );
    border-color: color-mix(in oklch, var(--uk-gold-bright) 45%, transparent);
    box-shadow: 0 0.15rem 0 oklch(18% 0.05 255 / 0.35);
  }

  .nav-tile:focus-visible {
    outline: 2px solid var(--uk-gold-bright);
    outline-offset: 2px;
  }

  .nav-tile__ico {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 0.65rem;
    background: color-mix(in oklch, var(--uk-blue-deep) 35%, oklch(30% 0.08 255));
    color: var(--uk-gold-bright);
  }

  .nav-tile[aria-current="page"] .nav-tile__ico {
    background: color-mix(in oklch, var(--uk-blue-deep) 16%, transparent);
    color: var(--uk-blue-deep);
  }

  .nav-tile__svg {
    width: 1.15rem;
    height: 1.15rem;
  }

  .nav-tile__txt {
    text-align: center;
    max-width: 5.25rem;
  }

  /* -- Mobile tab bar: navy + cream + gold; Donate fixed center (equal 5-col grid) -- */
  .mobile-bottom-nav {
    display: block;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 5500;
    height: calc(var(--bottom-nav-h) + env(safe-area-inset-bottom, 0px));
    pointer-events: none;
  }

  .mobile-bottom-nav__solid {
    position: absolute;
    inset: 0;
    background: linear-gradient(
      180deg,
      color-mix(in oklch, var(--uk-blue-deep) 92%, oklch(12% 0.03 255)) 0%,
      oklch(9% 0.04 255) 55%,
      oklch(6% 0.03 255) 100%
    );
    box-shadow:
      0 -1px 0 color-mix(in oklch, var(--uk-gold-bright) 22%, transparent),
      inset 0 1px 0 color-mix(in oklch, oklch(98% 0.01 95) 8%, transparent);
    pointer-events: none;
  }

  .mobile-bottom-nav__svg {
    position: absolute;
    left: 0;
    right: 0;
    bottom: env(safe-area-inset-bottom, 0px);
    width: 100%;
    height: 56px;
    display: block;
    pointer-events: none;
    filter: drop-shadow(0 -2px 12px oklch(8% 0.05 255 / 0.35));
  }

  .mobile-bottom-nav__row {
    position: absolute;
    left: 0;
    right: 0;
    bottom: env(safe-area-inset-bottom, 0px);
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    align-items: end;
    justify-items: center;
    column-gap: 0;
    height: var(--bottom-nav-h);
    padding: 0 0.25rem 10px;
    box-sizing: border-box;
    pointer-events: auto;
  }

  .mb-item {
    display: flex;
    justify-content: center;
    width: 100%;
    max-width: 5rem;
    text-align: center;
    text-decoration: none;
    color: color-mix(in oklch, var(--cream) 55%, oklch(58% 0.03 255));
    padding: 0.2rem 0.1rem 0;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    transition:
      color 0.35s var(--ease-nav),
      transform 0.35s var(--ease-nav);
  }

  .mb-item[aria-current="page"] {
    color: var(--uk-gold-bright);
  }

  .mb-item__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 0.2rem;
    min-height: 2.75rem;
  }

  .mb-ico {
    display: block;
    width: 1.28rem;
    height: 1.28rem;
    opacity: 0.95;
  }

  .mb-label {
    font-family: var(--font-ui);
    font-size: 0.625rem;
    font-weight: 650;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.05;
    color: inherit;
  }

  .mb-slot--center {
    pointer-events: none;
    width: 100%;
    max-width: 5rem;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    min-height: 2.75rem;
  }

  .mb-slot__ghost {
    visibility: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
  }

  .mb-item--more {
    background: none;
    border: none;
    cursor: pointer;
    font: inherit;
    width: 100%;
    max-width: 5rem;
    color: color-mix(in oklch, var(--cream) 55%, oklch(58% 0.03 255));
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  .mb-item--more[aria-expanded="true"] {
    color: var(--uk-gold-bright);
  }

  .mobile-bottom-nav__fab {
    position: absolute;
    left: 50%;
    bottom: calc(0.42rem + env(safe-area-inset-bottom, 0px));
    z-index: 4;
    width: auto;
    max-width: 5.5rem;
    transform: translateX(-50%);
    pointer-events: auto;
    display: flex;
    justify-content: center;
    align-items: flex-end;
  }

  .mb-fab__link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    gap: 0.22rem;
    text-decoration: none;
    color: inherit;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  .mb-fab__link:focus-visible {
    outline: none;
  }

  .mb-fab__link:focus-visible .mb-fab__hit--donate {
    outline: 3px solid var(--focus-ring);
    outline-offset: 3px;
  }

  .mb-label--fab {
    font-family: var(--font-ui);
    font-size: 0.625rem;
    font-weight: 650;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.05;
    color: color-mix(in oklch, var(--cream) 55%, oklch(58% 0.03 255));
    text-decoration: none;
    text-align: center;
    max-width: 5rem;
  }

  .mb-fab__link[aria-current="page"] .mb-label--fab {
    color: var(--uk-gold-bright);
  }

  .mb-fab__hit--donate {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.35rem;
    height: 3.35rem;
    border-radius: 50%;
    text-decoration: none;
    border: 2px solid color-mix(in oklch, var(--uk-gold-bright) 65%, var(--cream));
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
    color: var(--uk-blue-deep);
    background: linear-gradient(
      155deg,
      oklch(92% 0.14 95),
      var(--uk-gold-bright) 45%,
      color-mix(in oklch, var(--uk-gold) 80%, var(--uk-gold-muted)) 100%
    );
    box-shadow:
      0 0 0 1px color-mix(in oklch, var(--uk-blue-deep) 35%, transparent),
      0 0.35rem 0 color-mix(in oklch, var(--uk-blue-deep) 45%, transparent),
      0 0.65rem 1.35rem oklch(12% 0.06 255 / 0.45),
      0 0 1.25rem color-mix(in oklch, var(--uk-gold-bright) 35%, transparent);
    transition:
      transform 0.35s var(--ease-nav),
      box-shadow 0.35s var(--ease-out),
      filter 0.35s var(--ease-out);
  }

  .mb-fab__link[aria-current="page"] .mb-fab__hit--donate {
    border-color: color-mix(in oklch, var(--cream) 40%, var(--uk-gold-bright));
    box-shadow:
      0 0 0 2px color-mix(in oklch, var(--uk-gold-bright) 50%, transparent),
      0 0.35rem 0 color-mix(in oklch, var(--uk-blue-deep) 45%, transparent),
      0 0.75rem 1.5rem oklch(10% 0.06 255 / 0.5),
      0 0 1.5rem color-mix(in oklch, var(--uk-gold-bright) 45%, transparent);
  }

  @media (hover: hover) and (pointer: fine) {
    .mb-fab__link:hover .mb-fab__hit--donate {
      transform: translateY(-2px);
      filter: brightness(1.04);
    }
  }

  .mb-fab__hit--donate .mb-ico {
    width: 1.5rem;
    height: 1.5rem;
  }
}

/* -- Hero -- */
main {
  position: relative;
  z-index: 1;
}

.hero {
  position: relative;
  min-height: min(90vh, 54rem);
  display: grid;
  align-items: end;
  padding: var(--space-xl) var(--space-md) var(--space-lg);
  overflow: hidden;
  background:
    radial-gradient(ellipse 100% 80% at 15% 0%, oklch(42% 0.1 255 / 0.35), transparent 50%),
    linear-gradient(168deg, var(--uk-blue-deep) 0%, oklch(30% 0.1 255) 42%, oklch(34% 0.09 255) 100%);
  color: oklch(99% 0.01 95);
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 40%, color-mix(in oklch, var(--uk-gold) 12%, transparent) 70%, transparent);
  pointer-events: none;
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 50% at 75% 15%, color-mix(in oklch, var(--uk-gold-bright) 28%, transparent), transparent 55%);
  pointer-events: none;
}

.hero-inner {
  position: relative;
  z-index: 2;
  max-width: var(--content-max);
  margin: 0 auto;
  width: 100%;
}

.hero-ribbon {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 650;
  /* Wide tracking was stretching “for” / FOR into awkward gaps; keep editorial but readable */
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--uk-gold-bright);
  margin-bottom: var(--space-sm);
  opacity: 1;
  animation: heroNudge 0.85s var(--ease-out) forwards 0.08s;
}

.hero h1 {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2.65rem, 5vw + 1rem, 4.5rem);
  font-weight: 550;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 var(--space-md);
  max-width: 16ch;
  text-wrap: balance;
  opacity: 1;
  animation: heroNudge 0.85s var(--ease-out) forwards 0.2s;
  font-synthesis: none;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern" 1, "liga" 1;
  font-variant-ligatures: common-ligatures;
}

.hero-lead {
  font-size: clamp(1.08rem, 1.1vw + 0.95rem, 1.35rem);
  max-width: 44ch;
  line-height: 1.55;
  color: oklch(94% 0.02 95);
  margin-bottom: var(--space-md);
  opacity: 1;
  animation: heroNudge 0.85s var(--ease-out) forwards 0.35s;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  opacity: 1;
  animation: heroNudge 0.85s var(--ease-out) forwards 0.48s;
}

.hero-deco {
  position: absolute;
  right: -6%;
  bottom: 8%;
  width: min(44vw, 30rem);
  height: min(44vw, 30rem);
  border: 1px solid color-mix(in oklch, var(--uk-gold-bright) 42%, transparent);
  border-radius: 50%;
  pointer-events: none;
  animation: drift 22s ease-in-out infinite;
}

/* Transform-only hero motion: text stays painted at full opacity for LCP / indexing (no opacity tricks). */
@keyframes heroNudge {
  from {
    transform: translateY(0.65rem);
  }
  to {
    transform: translateY(0);
  }
}

@keyframes drift {
  0%,
  100% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(6deg) scale(1.02);
  }
}

.section {
  padding: var(--section-pad-y) var(--pad-inline);
  max-width: var(--content-max);
  margin: 0 auto;
}

.section-alt {
  background: linear-gradient(180deg, color-mix(in oklch, var(--uk-blue) 5%, var(--cream)) 0%, var(--cream) 100%);
}

.section-title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2rem, 2.8vw + 0.75rem, 3.1rem);
  font-weight: 550;
  color: var(--uk-blue-deep);
  margin: 0 0 var(--space-md);
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.section-intro {
  max-width: 62ch;
  color: var(--ink-soft);
  margin-bottom: var(--space-lg);
}

.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: var(--space-md);
}

.stat-card {
  padding: var(--space-md);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--cream);
  position: relative;
  overflow: hidden;
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}

.stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--uk-blue-deep), var(--uk-gold));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.45s var(--ease-out);
}

.stat-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-soft);
}

.stat-card:hover::before {
  transform: scaleX(1);
}

.stat-value {
  font-family: var(--font-display);
  font-size: clamp(2.1rem, 3.5vw, 3rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  line-height: 1;
}

.stat-label {
  font-size: 0.8125rem;
  font-weight: 650;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-top: var(--space-xs);
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 17.5rem), 1fr));
  gap: var(--space-md);
}

.card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  background: var(--cream);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}

.card:hover {
  border-color: color-mix(in oklch, var(--uk-blue) 35%, var(--line));
  box-shadow: var(--shadow-soft);
}

.card h3 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 550;
  margin: 0;
  color: var(--uk-blue-deep);
}

.card p {
  margin: 0;
  flex: 1;
  color: var(--ink-soft);
  font-size: 0.98rem;
}

.article-hero {
  padding: var(--space-lg) var(--space-md);
  max-width: 48rem;
  margin: 0 auto;
}

.article-meta {
  font-size: 0.9rem;
  color: var(--ink-muted);
  margin-bottom: var(--space-sm);
}

.article-body {
  max-width: 42rem;
  margin: 0 auto;
  padding: 0 var(--space-md) var(--space-xl);
}

.article-body h2 {
  font-family: var(--font-display);
  font-size: 1.65rem;
  font-weight: 550;
  color: var(--uk-blue-deep);
  margin: var(--space-lg) 0 var(--space-sm);
}

.article-body p {
  margin: 0 0 var(--space-md);
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
}

.tag {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: var(--space-micro) var(--space-sm);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  color: var(--uk-blue-deep);
  background: color-mix(in oklch, var(--uk-blue) 4%, var(--cream));
}

/* ---- Blog: index + article (editorial rhythm, sharing, adjacent posts) ---- */
.blog-index-page {
  padding-bottom: 0;
}

.blog-breadcrumb {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-xs) var(--pad-inline) 0;
}

.blog-breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-xs);
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.blog-breadcrumb__list li {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
}

.blog-breadcrumb__list li + li::before {
  content: "/";
  font-weight: 500;
  opacity: 0.4;
  margin-right: var(--space-2xs);
}

.blog-breadcrumb a {
  color: var(--uk-blue-mid);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 0.2s var(--ease-out), border-color 0.2s var(--ease-out);
}

.blog-breadcrumb a:hover {
  color: var(--uk-blue-deep);
  border-bottom-color: color-mix(in oklch, var(--uk-gold) 55%, transparent);
}

.blog-breadcrumb [aria-current="page"] {
  color: var(--uk-blue-deep);
  max-width: 100%;
}

/* When main uses padding-bottom: 0, restore one rhythm unit above the footer (footer itself has margin-top: 0) */
main.site-inner.blog-index-page + .site-footer,
main.site-inner.donate-page + .site-footer,
main.site-inner.contact-page + .site-footer,
main.site-inner.summit-page + .site-footer,
main.site-inner.power-page + .site-footer {
  margin-top: var(--page-footer-gap);
}

/* Ukraine Dreamzzz: main also has .power-page — override so the dark finale meets the footer with no cream gutter */
main.site-inner.dreamzzz-page + .site-footer {
  margin-top: 0;
}

/* Blog index hero — editorial masthead (no glass cards; typographic + flag motif) */
.blog-index-hero {
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  padding: clamp(2.85rem, 7.5vw, 4.75rem) var(--pad-inline) clamp(2.85rem, 6.5vw, 4.15rem);
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 50% at 88% 0%, color-mix(in oklch, var(--uk-gold-bright) 9%, transparent), transparent 42%),
    linear-gradient(168deg, oklch(12% 0.062 260) 0%, oklch(17% 0.082 256) 48%, oklch(11.5% 0.058 262) 100%);
  color: oklch(96% 0.014 95);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-gold) 28%, transparent);
  box-shadow: 0 12px 36px color-mix(in oklch, var(--uk-blue-deep) 16%, transparent);
}

.blog-index-hero__wash {
  position: absolute;
  inset: 0;
  opacity: 0.18;
  background-image: radial-gradient(ellipse 55% 40% at 18% 22%, color-mix(in oklch, white 5%, transparent), transparent 50%);
  pointer-events: none;
}

.blog-index-hero__grid {
  position: absolute;
  inset: 0;
  opacity: 0.028;
  background-image:
    linear-gradient(color-mix(in oklch, var(--uk-gold-bright) 35%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in oklch, var(--uk-gold-bright) 35%, transparent) 1px, transparent 1px);
  background-size: 100% 32px, 32px 100%;
  mask-image: radial-gradient(ellipse 85% 75% at 28% 32%, black 12%, transparent 70%);
  pointer-events: none;
}

.blog-index-hero__inner {
  position: relative;
  z-index: 1;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  display: grid;
  gap: clamp(2rem, 4.5vw, 3rem);
  align-items: start;
  text-align: left;
}

@media (min-width: 56rem) {
  .blog-index-hero__inner {
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    column-gap: clamp(2.25rem, 5vw, 3.75rem);
    align-items: start;
  }
}

.blog-index-hero__intro {
  position: relative;
  padding-top: 0.15rem;
}

.blog-index-hero__mark {
  width: clamp(3rem, 9vw, 4.5rem);
  height: 3px;
  margin: 0 0 1.25rem;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    var(--uk-gold) 0%,
    var(--uk-gold) 50%,
    var(--uk-blue) 50%,
    var(--uk-blue) 100%
  );
}

.blog-index-hero__eyebrow {
  margin: 0 0 1rem;
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 78%, oklch(88% 0.02 95));
}

.blog-index-hero__title {
  margin: 0;
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2.5rem, 3.6vw + 1rem, 4rem);
  font-weight: 400;
  line-height: 1.03;
  letter-spacing: -0.038em;
  text-wrap: balance;
  max-width: 14ch;
  color: oklch(99.2% 0.008 95);
}

.blog-index-hero__title-accent {
  font-weight: 600;
  font-style: italic;
  color: color-mix(in oklch, var(--uk-gold-bright) 93%, white);
}

.blog-index-hero__aside {
  position: relative;
  padding: 0.35rem 0 0 clamp(1.35rem, 3vw, 1.75rem);
}

.blog-index-hero__aside::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  bottom: 0;
  width: 3px;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    var(--uk-gold-bright) 0%,
    var(--uk-gold-bright) 50%,
    var(--uk-blue) 50%,
    color-mix(in oklch, var(--uk-blue) 85%, var(--uk-blue-deep)) 100%
  );
}

.blog-index-hero__lead {
  margin: 0;
  max-width: 48ch;
  font-size: clamp(1.04rem, 0.4vw + 0.96rem, 1.16rem);
  line-height: 1.62;
  font-weight: 400;
  font-family: var(--font-ui);
  color: color-mix(in oklch, oklch(93% 0.022 95) 90%, oklch(55% 0.1 255));
}

.blog-index-hero__note {
  margin: clamp(1.15rem, 2.5vw, 1.5rem) 0 0;
  padding-top: clamp(1rem, 2vw, 1.2rem);
  border-top: 1px solid color-mix(in oklch, var(--uk-gold) 20%, transparent);
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 70%, oklch(78% 0.04 95));
}

.blog-index-hero__stat {
  color: color-mix(in oklch, var(--uk-gold-bright) 90%, white);
}

.blog-index-hero__note-sep {
  margin: 0 0.4rem;
  opacity: 0.5;
}

@media (max-width: 55.99rem) {
  .blog-index-hero__inner {
    max-width: min(36rem, 100%);
    margin: 0 auto;
  }

  .blog-index-hero__aside {
    padding: clamp(1.35rem, 3.5vw, 1.65rem) 0 0;
  }

  .blog-index-hero__aside::before {
    left: 0;
    right: 0;
    top: 0;
    bottom: auto;
    width: 100%;
    height: 3px;
    background: linear-gradient(
      90deg,
      var(--uk-gold) 0%,
      var(--uk-gold) 50%,
      var(--uk-blue) 50%,
      var(--uk-blue) 100%
    );
  }
}

.blog-index-featured {
  position: relative;
  max-width: var(--content-max);
  margin: 0 auto;
  padding-top: var(--section-pad-y-tight);
  padding-bottom: clamp(0.75rem, 2vw, 1.25rem);
}

.blog-index-featured::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: min(100% - 2 * var(--pad-inline), 56rem);
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in oklch, var(--uk-blue) 18%, var(--line)) 20%,
    color-mix(in oklch, var(--uk-gold) 45%, var(--uk-blue)) 50%,
    color-mix(in oklch, var(--uk-blue) 18%, var(--line)) 80%,
    transparent
  );
  pointer-events: none;
}

.blog-index-rest {
  max-width: var(--content-max);
  margin: 0 auto;
  padding-top: clamp(2rem, 4vw, 2.75rem);
  padding-bottom: 0;
}

/* Full-bleed archive band: distinct from featured, brand wash, no lazy side-border headline */
.blog-index-page .blog-archive.blog-index-rest {
  scroll-margin-top: calc(var(--header-h) + 0.75rem);
  max-width: none;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: clamp(2.75rem, 6vw, 4rem) var(--pad-inline) clamp(3rem, 7vw, 5rem);
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 11%, var(--line));
  background:
    radial-gradient(ellipse 78% 58% at 12% -5%, color-mix(in oklch, var(--uk-gold-bright) 20%, transparent) 0%, transparent 58%),
    radial-gradient(ellipse 55% 50% at 98% 25%, color-mix(in oklch, var(--uk-blue) 9%, transparent) 0%, transparent 52%),
    linear-gradient(185deg, color-mix(in oklch, var(--uk-blue) 5%, var(--cream)) 0%, var(--cream) 72%);
}

.blog-archive::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklch, var(--uk-gold) 65%, var(--uk-gold-bright)) 28%,
    var(--uk-gold-bright) 50%,
    color-mix(in oklch, var(--uk-gold) 65%, var(--uk-gold-bright)) 72%,
    transparent 100%
  );
  opacity: 0.88;
  pointer-events: none;
}

.blog-archive__shell {
  position: relative;
  z-index: 1;
  max-width: min(1200px, 100%);
  margin: 0 auto;
}

.blog-archive__head {
  margin-bottom: clamp(1.75rem, 4vw, 2.5rem);
  text-align: left;
}

@media (max-width: 47.99rem) {
  .blog-archive__head {
    text-align: center;
  }
}

.blog-archive__eyebrow {
  margin: 0 0 var(--space-xs);
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 750;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--uk-blue);
}

.blog-archive__title {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 2.5vw + 1rem, 2.85rem);
  font-weight: 650;
  letter-spacing: -0.038em;
  line-height: 1.06;
  color: var(--uk-blue-deep);
  max-width: 18ch;
}

@media (max-width: 47.99rem) {
  .blog-archive__title {
    max-width: none;
  }
}

.blog-archive__accent {
  box-decoration-break: clone;
  background: linear-gradient(
    transparent 62%,
    color-mix(in oklch, var(--uk-gold-bright) 50%, transparent) 62%,
    color-mix(in oklch, var(--uk-gold-bright) 50%, transparent) 90%,
    transparent 90%
  );
}

.blog-archive__lead {
  margin: 0;
  max-width: 52ch;
  font-size: clamp(0.96rem, 0.45vw + 0.85rem, 1.08rem);
  line-height: 1.65;
  color: var(--ink-soft);
}

@media (max-width: 47.99rem) {
  .blog-archive__lead {
    margin-left: auto;
    margin-right: auto;
  }
}

.blog-index-grid--archive {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 20.5rem), 1fr));
  gap: clamp(1.5rem, 3.5vw, 2.35rem);
}

.blog-section-head {
  margin-bottom: clamp(1.35rem, 3vw, 1.85rem);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 10%, var(--line));
  text-align: center;
}

.blog-section-head--editorial {
  position: relative;
  padding-left: clamp(0rem, 2vw, 0.5rem);
  text-align: left;
}

.blog-section-head--editorial::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.15rem;
  bottom: 0.35rem;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    color-mix(in oklch, var(--uk-gold) 55%, var(--uk-blue)) 0%,
    color-mix(in oklch, var(--uk-blue) 35%, var(--line)) 100%
  );
}

@media (max-width: 47.99rem) {
  .blog-section-head--editorial {
    text-align: center;
    padding-left: 0;
  }

  .blog-section-head--editorial::before {
    display: none;
  }
}

.blog-section-head__kicker {
  margin: 0 0 0.4rem;
  font-size: 0.65rem;
  font-weight: 750;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.blog-section-head__title {
  margin: 0 0 0.45rem;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 1.15vw + 1.05rem, 2rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  letter-spacing: -0.025em;
  line-height: 1.15;
}

.blog-section-head--editorial .blog-section-head__title {
  font-size: clamp(1.85rem, 2.2vw + 1.1rem, 2.45rem);
  font-weight: 600;
  letter-spacing: -0.035em;
}

.blog-section-head__sub {
  margin: 0 auto;
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 44ch;
}

.blog-section-head--editorial .blog-section-head__sub {
  margin: 0;
  max-width: 48ch;
}

.blog-index-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 18.5rem), 1fr));
  gap: clamp(1.35rem, 3.2vw, 2rem);
  align-items: stretch;
}

.blog-index-page .blog-card--archive {
  border-radius: calc(var(--radius-lg) + 2px);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 11%, var(--line));
  background: linear-gradient(
    168deg,
    oklch(100% 0 0) 0%,
    color-mix(in oklch, var(--uk-blue) 3.5%, var(--cream)) 100%
  );
  box-shadow:
    inset 0 3px 0 0 color-mix(in oklch, var(--uk-gold) 38%, var(--uk-blue)),
    0 2px 0 color-mix(in oklch, white 72%, transparent) inset,
    0 10px 32px color-mix(in oklch, var(--uk-blue-deep) 7%, transparent);
}

.blog-index-page .blog-card--archive:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 38%, var(--line));
  box-shadow:
    inset 0 3px 0 0 color-mix(in oklch, var(--uk-gold-bright) 45%, var(--uk-blue)),
    0 2px 0 color-mix(in oklch, white 82%, transparent) inset,
    0 16px 44px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
}

.blog-index-page .blog-archive .blog-card--archive .blog-card__title {
  font-size: clamp(1.05rem, 0.45vw + 0.92rem, 1.22rem);
  line-height: 1.28;
}

.blog-index-page .blog-card--archive .blog-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 55%,
    color-mix(in oklch, var(--uk-blue-deep) 25%, transparent) 100%
  );
  opacity: 0;
  transition: opacity 0.35s var(--ease-out);
  pointer-events: none;
}

.blog-index-page .blog-card--archive:hover .blog-card__media::after {
  opacity: 1;
}

.blog-index-page .blog-card__media {
  position: relative;
}

.blog-index-page .tag-row.blog-tags {
  gap: 0.35rem;
}

.blog-index-page .tag-row .tag {
  font-size: 0.625rem;
  letter-spacing: 0.1em;
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
  border-color: color-mix(in oklch, var(--uk-blue) 16%, var(--line));
  background: color-mix(in oklch, var(--uk-blue) 5%, white);
  color: var(--uk-blue-deep);
}

.blog-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: linear-gradient(180deg, oklch(100% 0 0) 0%, color-mix(in oklch, var(--uk-blue) 3%, var(--cream)) 100%);
  box-shadow: 0 2px 14px color-mix(in oklch, var(--uk-blue-deep) 5%, transparent);
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out), transform 0.25s var(--ease-out);
}

.blog-card:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 35%, var(--line));
  box-shadow: 0 10px 32px color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
  transform: translateY(-2px);
}

.blog-card__media {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
}

.blog-card--featured .blog-card__media {
  aspect-ratio: 21 / 9;
}

@media (max-width: 899px) {
  .blog-card--featured-editorial .blog-card__media {
    aspect-ratio: 16 / 10;
  }
}

.blog-card__media-link {
  display: block;
  height: 100%;
  line-height: 0;
}

.blog-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s var(--ease-out);
}

.blog-card:hover .blog-card__media img {
  transform: scale(1.04);
}

.blog-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: var(--space-md);
  flex: 1;
}

.blog-card--featured {
  max-width: min(100%, 52rem);
  margin-inline: auto;
  border-width: 1px;
  border-color: color-mix(in oklch, var(--uk-gold) 45%, var(--line-strong));
  background: linear-gradient(
    145deg,
    color-mix(in oklch, white 97%, var(--cream)) 0%,
    color-mix(in oklch, var(--uk-blue) 6%, var(--cream)) 55%,
    color-mix(in oklch, var(--uk-gold-bright) 8%, var(--cream)) 100%
  );
  box-shadow:
    0 4px 28px color-mix(in oklch, var(--uk-blue-deep) 9%, transparent),
    0 0 0 1px color-mix(in oklch, white 55%, transparent) inset,
    inset 0 1px 0 color-mix(in oklch, white 82%, transparent);
}

.blog-card--featured-editorial {
  overflow: hidden;
}

.blog-card--featured-editorial .blog-card__media {
  position: relative;
}

.blog-card--featured-editorial .blog-card__media::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    105deg,
    transparent 35%,
    color-mix(in oklch, var(--uk-blue-deep) 45%, transparent) 100%
  );
  opacity: 0.25;
  pointer-events: none;
  transition: opacity 0.35s var(--ease-out);
}

.blog-card--featured-editorial:hover .blog-card__media::before {
  opacity: 0.18;
}

.blog-card--featured .blog-card__body {
  padding: clamp(1.15rem, 3vw, 1.65rem);
}

.blog-card--featured-editorial .blog-card__ribbon {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.75rem;
  margin: 0 0 0.5rem;
  width: fit-content;
  font-size: 0.6rem;
  font-weight: 750;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--uk-blue-deep);
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-gold) 50%, var(--line));
  background: linear-gradient(
    135deg,
    color-mix(in oklch, var(--uk-gold-bright) 28%, white),
    color-mix(in oklch, white 94%, var(--cream))
  );
  box-shadow: 0 1px 0 color-mix(in oklch, white 90%, transparent);
}

.blog-card__ribbon {
  margin: 0 0 0.15rem;
  font-size: 0.62rem;
  font-weight: 750;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.blog-card .blog-tags,
.blog-card .tag-row {
  margin-bottom: 0.35rem;
}

.blog-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 0.8vw + 1rem, 1.45rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.blog-card--featured .blog-card__title {
  font-size: clamp(1.45rem, 1.2vw + 1.05rem, 1.85rem);
}

.blog-card--featured-editorial .blog-card__title {
  font-size: clamp(1.5rem, 1.35vw + 1rem, 2rem);
  font-weight: 550;
  letter-spacing: -0.028em;
  line-height: 1.18;
}

.blog-card--featured-editorial .blog-card__media-link {
  position: relative;
  z-index: 2;
}

@media (min-width: 900px) {
  .blog-card--featured-editorial {
    display: grid;
    grid-template-columns: minmax(0, 1.14fr) minmax(0, 1fr);
    gap: 0;
    max-width: min(100%, 68rem);
    align-items: stretch;
  }

  .blog-card--featured-editorial .blog-card__media {
    aspect-ratio: unset;
    min-height: 17.5rem;
  }

  .blog-card--featured-editorial .blog-card__media img {
    min-height: 17.5rem;
    height: 100%;
  }

  .blog-card--featured-editorial .blog-card__body {
    padding: clamp(1.35rem, 3.2vw, 2rem);
    justify-content: center;
  }
}

.blog-card__title a {
  color: var(--uk-blue-deep);
  text-decoration: none;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.12em;
}

.blog-card__title a:hover {
  color: var(--uk-blue);
}

.blog-card__excerpt {
  margin: 0;
  flex: 1;
  font-size: 0.95rem;
  line-height: 1.58;
  color: var(--ink-soft);
}

.blog-card__foot {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  margin-top: auto;
  padding-top: 0.25rem;
}

.blog-card__meta {
  font-size: 0.82rem;
  color: var(--ink-muted);
}

.blog-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.65rem;
}

.blog-card__read {
  font-size: 0.75rem;
  letter-spacing: 0.06em;
}

.blog-card__share-inline {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.blog-card__share-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  text-decoration: none;
  color: var(--uk-blue-deep);
  border-radius: 50%;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 16%, var(--line));
  background: color-mix(in oklch, white 94%, var(--cream));
  box-shadow: 0 1px 0 color-mix(in oklch, white 80%, transparent) inset;
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    color 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.blog-card__share-ico:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 50%, var(--uk-blue));
  background: color-mix(in oklch, var(--uk-gold-bright) 12%, white);
  transform: translateY(-1px);
}

.blog-card__share-ico:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.blog-card__share-ico .blog-ico {
  display: block;
}

.blog-card__read-more {
  font-size: 0.82rem;
  font-weight: 650;
  color: var(--uk-blue);
  text-decoration: none;
}

.blog-card__read-more:hover {
  color: var(--uk-blue-deep);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.blog-card__micro-share {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0.15rem;
  padding-top: 0.65rem;
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 8%, transparent);
}

.blog-card__micro-share-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  text-decoration: none;
  color: var(--uk-blue-deep);
  border-radius: 0.55rem;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, var(--line));
  background: oklch(100% 0 0);
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.blog-card__micro-share-link:hover {
  background: color-mix(in oklch, var(--uk-blue) 5%, var(--cream));
  border-color: color-mix(in oklch, var(--uk-gold) 40%, var(--uk-blue));
  transform: translateY(-1px);
}

.blog-card__micro-share-link:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.blog-card__micro-share-link .blog-ico {
  display: block;
}

.blog-post-page .blog-post-hero {
  padding-top: clamp(1.5rem, 4vw, 2.5rem);
}

.blog-post-hero__title {
  margin-bottom: 0.5rem !important;
  text-wrap: balance;
}

.blog-post-hero__meta {
  margin-bottom: 0 !important;
}

.blog-post-cover {
  margin: clamp(0.5rem, 2vw, 1rem) auto clamp(1.25rem, 3vw, 2rem);
  max-width: min(56rem, 100%);
  padding: 0 var(--pad-inline);
}

.blog-post-cover__frame {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, var(--line));
  aspect-ratio: 21 / 9;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  box-shadow:
    var(--shadow-elevated),
    0 0 0 1px color-mix(in oklch, white 55%, transparent) inset;
}

.blog-post-cover__frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
}

@media (max-width: 640px) {
  .blog-post-cover__frame {
    aspect-ratio: 16 / 10;
  }
}

/* Blog post: visible author byline (E-E-A-T); complements JSON-LD Person */
.blog-author-block {
  max-width: min(56rem, 100%);
  margin: 0 auto clamp(0.75rem, 2.5vw, 1.25rem);
  padding: 0 var(--pad-inline);
}

.blog-author-block__card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md);
  border-radius: calc(var(--radius-lg) + 2px);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, var(--line));
  background: linear-gradient(
    145deg,
    color-mix(in oklch, var(--uk-blue) 5.5%, var(--cream)) 0%,
    var(--cream) 100%
  );
  box-shadow:
    var(--shadow-soft),
    0 0 0 1px color-mix(in oklch, white 80%, transparent) inset;
}

.blog-author-block__avatar {
  flex-shrink: 0;
  width: 3.35rem;
  height: 3.35rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.05em;
  line-height: 1.1;
  text-align: center;
  color: var(--uk-blue-deep);
  background: color-mix(in oklch, var(--uk-gold-bright) 22%, var(--cream));
  border: 1px solid color-mix(in oklch, var(--uk-gold) 40%, transparent);
}

.blog-author-block__name {
  margin: 0 0 0.3rem;
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--uk-blue-deep);
  letter-spacing: -0.02em;
}

.blog-author-block__role {
  margin: 0 0 0.45rem;
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--ink-soft);
}

.blog-author-block__contact {
  font-size: 0.8125rem;
  font-weight: 600;
}

/* In-article mission CTA (replaces plain h2 + paragraph + button) */
.blog-article-body .blog-mission-card {
  position: relative;
  margin: var(--space-lg) 0;
  padding: clamp(1.5rem, 4vw, 2.15rem) clamp(1.25rem, 3vw, 1.75rem);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 20%, transparent);
  background: linear-gradient(
    158deg,
    color-mix(in oklch, var(--uk-blue-deep) 93%, oklch(16% 0.05 255)) 0%,
    oklch(23% 0.08 255) 100%
  );
  color: oklch(96% 0.02 95);
  text-align: center;
  box-shadow:
    0 1.1rem 2.75rem oklch(11% 0.06 255 / 0.3),
    inset 0 1px 0 color-mix(in oklch, oklch(98% 0.01 95) 11%, transparent);
  transition:
    transform 0.38s var(--ease-out),
    box-shadow 0.38s var(--ease-out),
    border-color 0.38s var(--ease-out);
}

/* Gold hairline — brightens when the panel is hovered (subtle “spotlight”) */
.blog-article-body .blog-mission-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklch, var(--uk-gold-bright) 55%, transparent) 50%,
    transparent 100%
  );
  opacity: 0.65;
  pointer-events: none;
  transition: opacity 0.38s var(--ease-out);
}

.blog-article-body .blog-mission-card:hover,
.blog-article-body .blog-mission-card:focus-within {
  transform: translateY(-3px);
  border-color: color-mix(in oklch, var(--uk-gold) 35%, var(--uk-blue-deep));
  box-shadow:
    0 1.35rem 3rem oklch(9% 0.055 255 / 0.38),
    0 0 0 1px color-mix(in oklch, var(--uk-gold-bright) 12%, transparent),
    inset 0 1px 0 color-mix(in oklch, oklch(98% 0.01 95) 14%, transparent);
}

.blog-article-body .blog-mission-card:hover::before,
.blog-article-body .blog-mission-card:focus-within::before {
  opacity: 1;
}

.blog-mission-card__eyebrow {
  margin: 0 0 0.5rem;
  font-family: var(--font-ui);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 88%, oklch(98% 0.01 95));
  transition: color 0.38s var(--ease-out), letter-spacing 0.38s var(--ease-out);
}

.blog-article-body .blog-mission-card:hover .blog-mission-card__eyebrow,
.blog-article-body .blog-mission-card:focus-within .blog-mission-card__eyebrow {
  color: color-mix(in oklch, var(--uk-gold-bright) 96%, white);
  letter-spacing: 0.24em;
}

/* Must beat .article-body h2 (section headings = dark blue on cream); card sits on navy */
.blog-article-body .blog-mission-card .blog-mission-card__title {
  margin: 0 0 0.65rem;
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1.8vw + 1rem, 1.85rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.12;
  color: oklch(99% 0.01 95);
  text-align: center;
  text-wrap: balance;
  scroll-margin-top: calc(var(--header-h) + 0.75rem);
}

/* Beat .article-body p (0,1,1) if it ever sets text-align; single-class .blog-mission-card__text (0,1,0) loses */
.blog-article-body .blog-mission-card p.blog-mission-card__text {
  margin: 0 auto var(--space-md);
  font-size: clamp(0.97rem, 0.3vw + 0.9rem, 1.05rem);
  line-height: 1.58;
  max-width: 38ch;
  text-align: center;
  color: oklch(87% 0.03 95);
  overflow-wrap: break-word;
}

.blog-article-body .blog-mission-card .blog-mission-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.85rem;
  min-width: 44px;
  padding: 0.55rem 1.65rem;
  background: var(--uk-gold);
  color: var(--uk-blue-deep);
  border: none;
  font-weight: 700;
  letter-spacing: 0.03em;
  border-radius: var(--radius);
  box-shadow: 0 2px 0 color-mix(in oklch, oklch(12% 0.05 255) 35%, transparent);
  touch-action: manipulation;
  -webkit-tap-highlight-color: color-mix(in oklch, var(--uk-gold-bright) 35%, transparent);
  transition:
    background 0.2s var(--ease-out),
    color 0.2s var(--ease-out),
    transform 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out);
}

.blog-article-body .blog-mission-card .blog-mission-card__btn:hover {
  background: var(--uk-gold-bright);
  color: oklch(15% 0.04 255);
  transform: translateY(-1px);
  box-shadow:
    0 3px 0 color-mix(in oklch, oklch(12% 0.05 255) 45%, transparent),
    0 6px 18px color-mix(in oklch, var(--uk-gold-bright) 25%, transparent);
}

.blog-article-body .blog-mission-card .blog-mission-card__btn:active {
  transform: translateY(1px);
  box-shadow:
    0 1px 0 color-mix(in oklch, oklch(12% 0.05 255) 50%, transparent),
    0 2px 8px color-mix(in oklch, oklch(8% 0.04 255) 30%, transparent);
}

.blog-article-body .blog-mission-card .blog-mission-card__btn:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .blog-article-body .blog-mission-card {
    transition: none;
  }

  .blog-article-body .blog-mission-card:hover,
  .blog-article-body .blog-mission-card:focus-within {
    transform: none;
  }

  .blog-article-body .blog-mission-card::before {
    transition: none;
  }

  .blog-article-body .blog-mission-card .blog-mission-card__eyebrow {
    transition: none;
  }

  .blog-article-body .blog-mission-card:hover .blog-mission-card__eyebrow,
  .blog-article-body .blog-mission-card:focus-within .blog-mission-card__eyebrow {
    letter-spacing: 0.22em;
  }

  .blog-article-body .blog-mission-card .blog-mission-card__btn {
    transition-duration: 0.01ms;
  }

  .blog-article-body .blog-mission-card .blog-mission-card__btn:hover,
  .blog-article-body .blog-mission-card .blog-mission-card__btn:active {
    transform: none;
    box-shadow: 0 2px 0 color-mix(in oklch, oklch(12% 0.05 255) 35%, transparent);
  }
}

.blog-ico {
  flex-shrink: 0;
  vertical-align: middle;
}

.blog-ico--stroke {
  stroke-linejoin: round;
}

/* Blog post: share rail (sticky left on wide viewports) + article column */
.blog-post-main {
  display: block;
}

.blog-post-main .blog-share {
  margin: 0 auto var(--space-md);
  max-width: 42rem;
}

.blog-share {
  position: relative;
  z-index: 8;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.blog-share__actions {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
}

.blog-share__btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  width: 2.75rem;
  height: 2.75rem;
  min-height: 2.75rem;
  padding: 0;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  text-decoration: none;
  color: var(--uk-blue-deep);
  border-radius: 50%;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 18%, var(--line));
  background: oklch(100% 0 0);
  cursor: pointer;
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.blog-share__btn-ico {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.blog-share__btn-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

a.blog-share__btn:hover,
button.blog-share__btn:hover {
  background: color-mix(in oklch, var(--uk-blue) 7%, var(--cream));
  border-color: color-mix(in oklch, var(--uk-gold) 45%, var(--uk-blue));
  box-shadow: 0 2px 10px color-mix(in oklch, var(--uk-blue-deep) 7%, transparent);
  transform: translateY(-1px);
}

a.blog-share__btn:focus-visible,
button.blog-share__btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.blog-share__btn:active {
  transform: translateY(0);
}

.blog-share__btn--native {
  border-color: color-mix(in oklch, var(--uk-gold) 38%, var(--uk-blue-deep));
  background: var(--uk-gold-bright);
  color: var(--uk-blue-deep);
}

a.blog-share__btn--native:hover,
button.blog-share__btn--native:hover {
  background: color-mix(in oklch, var(--uk-gold) 15%, var(--uk-gold-bright));
  border-color: color-mix(in oklch, var(--uk-gold) 55%, var(--uk-blue-deep));
  color: var(--uk-blue-deep);
}

.blog-share__toast {
  margin: 0.5rem 0 0;
  padding: 0.3rem 0.55rem;
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 650;
  color: var(--uk-blue-deep);
  border-radius: var(--radius);
  background: color-mix(in oklch, var(--uk-gold-bright) 22%, var(--cream));
  border: 1px solid color-mix(in oklch, var(--uk-gold) 35%, transparent);
}

@media (min-width: 768px) {
  .blog-post-main {
    display: grid;
    grid-template-columns: 2.75rem minmax(0, 42rem);
    gap: 0 1.15rem;
    align-items: start;
    box-sizing: border-box;
    width: 100%;
    max-width: min(calc(42rem + 2.75rem + 1.15rem + 2 * var(--pad-inline)), 100%);
    margin-inline: auto;
    padding-inline: var(--pad-inline);
  }

  .blog-post-main .blog-share {
    margin: 0;
    max-width: none;
    justify-self: end;
  }

  .blog-share {
    position: sticky;
    top: calc(var(--header-h) + 0.75rem);
    align-self: start;
    padding: 0.5rem 0.3rem;
    border-radius: var(--radius-lg);
    border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, var(--line));
    background: color-mix(in oklch, var(--cream) 97%, var(--uk-blue));
    box-shadow: 0 1px 0 color-mix(in oklch, white 80%, transparent) inset;
  }

  .blog-share__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: center;
    gap: 0.4rem;
  }

  .blog-share__toast {
    margin-left: 0;
    max-width: 12rem;
  }

  .site-inner.blog-post-page .blog-post-main .article-body.blog-article-body {
    max-width: none;
    padding-left: 0;
    padding-right: 0;
  }
}

.blog-pager {
  max-width: 56rem;
  margin: 0 auto var(--space-lg);
  padding: 0 var(--pad-inline);
}

.blog-pager__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
  gap: 0.75rem;
}

.blog-pager__link {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: var(--space-md);
  text-decoration: none;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, var(--line));
  background: linear-gradient(
    165deg,
    oklch(100% 0 0) 0%,
    color-mix(in oklch, var(--uk-blue) 3%, var(--cream)) 100%
  );
  transition:
    border-color 0.25s var(--ease-out),
    box-shadow 0.25s var(--ease-out),
    transform 0.25s var(--ease-out);
}

.blog-pager__link:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 35%, var(--line));
  transform: translateY(-2px);
  box-shadow: 0 12px 36px color-mix(in oklch, var(--uk-blue-deep) 9%, transparent);
}

.blog-pager__dir {
  font-size: 0.62rem;
  font-weight: 750;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.blog-pager__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--uk-blue-deep);
}

.blog-more {
  position: relative;
  max-width: var(--content-max);
  margin: clamp(1.5rem, 4vw, 2.5rem) auto 0;
  padding: clamp(2rem, 5vw, 3rem) 0 clamp(1.5rem, 4vw, 2.5rem);
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 9%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--uk-blue) 4%, var(--cream)) 0%, transparent 38%),
    var(--cream);
}

.blog-more__head {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: var(--space-md);
  padding: 0 var(--pad-inline) 0.35rem;
}

.blog-more__head::after {
  content: "";
  position: absolute;
  left: var(--pad-inline);
  bottom: 0;
  width: 3rem;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    var(--uk-gold),
    color-mix(in oklch, var(--uk-blue) 40%, var(--uk-gold-bright))
  );
}

.blog-more__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 1vw + 1.1rem, 1.75rem);
  font-weight: 600;
  letter-spacing: -0.028em;
  color: var(--uk-blue-deep);
}

.blog-more__all {
  font-size: 0.9rem;
  font-weight: 650;
  color: var(--uk-blue);
  text-decoration: none;
}

.blog-more__all:hover {
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.blog-more__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
  gap: clamp(1rem, 2vw, 1.25rem);
  padding: 0 var(--pad-inline);
}

.blog-more-card {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: oklch(100% 0 0);
  min-height: 100%;
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}

.blog-more-card:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 32%, var(--line));
  box-shadow: var(--shadow-soft);
}

.blog-more-card__media {
  display: block;
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  line-height: 0;
}

.blog-more-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.45s var(--ease-out);
}

.blog-more-card:hover .blog-more-card__media img {
  transform: scale(1.04);
}

.blog-more-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: var(--space-md);
  flex: 1;
}

.blog-more-card__meta {
  margin: 0;
  font-size: 0.78rem;
  color: var(--ink-muted);
}

.blog-more-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 600;
  line-height: 1.25;
}

.blog-more-card__title a {
  color: var(--uk-blue-deep);
  text-decoration: none;
}

.blog-more-card__title a:hover {
  color: var(--uk-blue);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

.blog-more-card__excerpt {
  margin: 0;
  flex: 1;
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.blog-more-card__share {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  padding-top: 0.35rem;
  margin-top: auto;
}

.blog-more-card__share-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.35rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.02em;
  text-decoration: none;
  color: var(--uk-blue-deep);
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 16%, var(--line));
  background: color-mix(in oklch, white 96%, var(--cream));
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.blog-more-card__share-btn:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 45%, var(--uk-blue));
  background: color-mix(in oklch, var(--uk-gold-bright) 12%, white);
  transform: translateY(-1px);
}

.blog-more-card__share-btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
}

.blog-more-card__share-ico {
  display: flex;
  align-items: center;
  justify-content: center;
}

.blog-more-card__share-ico .blog-ico {
  display: block;
}

.blog-more-card__share-lbl {
  line-height: 1;
}

/* ---------- Blog: modern editorial flow (501(c)-appropriate, not decorative noise) ---------- */

.site-inner.blog-index-page {
  position: relative;
  background:
    radial-gradient(ellipse 90% 55% at 15% -8%, color-mix(in oklch, var(--uk-gold-bright) 12%, transparent) 0%, transparent 50%),
    radial-gradient(ellipse 70% 45% at 92% 12%, color-mix(in oklch, var(--uk-blue) 7%, transparent) 0%, transparent 45%),
    linear-gradient(178deg, var(--cream) 0%, color-mix(in oklch, var(--cream-warm) 35%, var(--cream)) 100%);
}

.site-inner.blog-post-page {
  position: relative;
  background:
    radial-gradient(ellipse 100% 60% at 50% -15%, color-mix(in oklch, var(--uk-gold-bright) 11%, transparent) 0%, transparent 52%),
    linear-gradient(180deg, color-mix(in oklch, var(--cream-warm) 45%, var(--cream)) 0%, var(--cream) 28%, var(--cream) 100%);
}

.blog-post-page .blog-article {
  position: relative;
}

.blog-post-page .article-hero.blog-post-hero {
  position: relative;
  max-width: min(52rem, 100%);
  margin-inline: auto;
  padding: clamp(1.25rem, 3.5vw, 2rem) var(--pad-inline) clamp(1.5rem, 4vw, 2.35rem);
  text-align: center;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  background: linear-gradient(
    185deg,
    color-mix(in oklch, white 70%, var(--cream)) 0%,
    transparent 72%
  );
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 9%, var(--line));
  box-shadow: 0 1px 0 color-mix(in oklch, white 65%, transparent);
}

.blog-post-page .article-hero.blog-post-hero::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 50%);
  width: min(8rem, 42%);
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in oklch, var(--uk-gold) 70%, var(--uk-gold-bright)) 35%,
    color-mix(in oklch, var(--uk-gold-bright) 85%, white) 50%,
    color-mix(in oklch, var(--uk-gold) 70%, var(--uk-gold-bright)) 65%,
    transparent
  );
  pointer-events: none;
  opacity: 0.92;
}

.blog-post-page .blog-post-hero__title.section-title {
  margin-bottom: clamp(0.65rem, 2vw, 1rem) !important;
  font-size: clamp(2.05rem, 3.2vw + 1rem, 3rem) !important;
  font-weight: 600 !important;
  line-height: 1.06 !important;
  letter-spacing: -0.035em !important;
  color: var(--uk-blue-deep);
}

.blog-post-page .blog-post-hero__meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.35rem 0.65rem;
  margin-top: 0.25rem !important;
  margin-bottom: 0 !important;
  padding: 0.45rem 0.85rem;
  font-family: var(--font-ui);
  font-size: 0.7rem !important;
  font-weight: 650;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--ink-muted) 92%, var(--uk-blue));
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 10%, var(--line));
  background: color-mix(in oklch, white 88%, var(--cream));
}

.blog-post-page .blog-post-hero__meta time {
  color: var(--uk-blue-deep);
}

@media (prefers-reduced-motion: no-preference) {
  .blog-post-cover.reveal.is-visible .blog-post-cover__frame {
    animation: blog-cover-settle 0.85s var(--ease-out) both;
  }

  @keyframes blog-cover-settle {
    from {
      opacity: 0.88;
      transform: translateY(8px) scale(0.992);
    }
    to {
      opacity: 1;
      transform: translateY(0) scale(1);
    }
  }
}

/* Article body: hierarchy + trustworthy reading rhythm */
.blog-article-body a:not(.blog-mission-card__btn) {
  color: var(--uk-blue-mid);
  font-weight: 600;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 0.2em;
  transition: color 0.2s var(--ease-out), text-decoration-color 0.2s var(--ease-out);
}

.blog-article-body a:not(.blog-mission-card__btn):hover {
  color: var(--uk-blue-deep);
  text-decoration-color: color-mix(in oklch, var(--uk-gold) 55%, var(--uk-blue));
}

/* Rich CMS: images + video embeds (Quill) */
.blog-article-body img {
  max-width: 100%;
  height: auto;
  border-radius: 0.35rem;
}

.blog-article-body .ql-video,
.blog-article-body iframe.ql-video {
  display: block;
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  min-height: 12rem;
  margin: clamp(1.25rem, 3vw, 1.75rem) 0;
  border: 0;
  border-radius: 0.5rem;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
}

.blog-article-body .ql-divider {
  height: 0;
  margin: clamp(1.5rem, 4vw, 2.25rem) 0;
  padding: 0;
  border: none;
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 14%, var(--line));
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in oklch, var(--uk-gold) 35%, transparent),
    transparent
  );
}

.blog-article-body h2:not(.blog-mission-card__title) {
  position: relative;
  padding-bottom: 0.55rem;
  margin-top: clamp(2rem, 5vw, 2.75rem);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 8%, var(--line));
}

.blog-article-body h2:not(.blog-mission-card__title)::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: min(4.5rem, 28%);
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    color-mix(in oklch, var(--uk-gold) 55%, var(--uk-blue)),
    color-mix(in oklch, var(--uk-gold-bright) 40%, transparent)
  );
}

.blog-article-body > p:first-of-type:has(> em:only-child) {
  text-align: center;
  font-size: 0.8125rem;
  font-style: italic;
  letter-spacing: 0.01em;
  color: var(--ink-muted);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px dashed color-mix(in oklch, var(--uk-blue) 12%, var(--line));
}

/* Lead paragraph: first body graph, or line after optional photo credit */
.blog-article-body > p:first-of-type:not(:has(> em:only-child)),
.blog-article-body > p:first-of-type:has(> em:only-child) + p {
  font-size: clamp(1.04rem, 0.35vw + 0.98rem, 1.14rem);
  line-height: 1.72;
  color: var(--ink);
}

@media (prefers-reduced-motion: reduce) {
  .blog-post-cover.reveal.is-visible .blog-post-cover__frame {
    animation: none;
  }

  .blog-pager__link:hover {
    transform: none;
  }

  .blog-card:hover {
    transform: none;
  }

  .blog-card:hover .blog-card__media img {
    transform: none;
  }

  .blog-more-card:hover .blog-more-card__media img {
    transform: none;
  }

  .blog-share__btn:hover,
  .blog-card__share-ico:hover,
  .blog-card__micro-share-link:hover,
  .blog-more-card__share-btn:hover {
    transform: none;
  }

  .blog-card--featured-editorial .blog-card__media::before,
  .blog-index-page .blog-card--archive .blog-card__media::after {
    transition: none;
  }

  .blog-card--featured-editorial:hover .blog-card__media::before {
    opacity: 0.25;
  }

  .blog-index-page .blog-card--archive:hover .blog-card__media::after {
    opacity: 0;
  }
}

.donate-panel {
  padding: var(--space-lg);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, color-mix(in oklch, var(--uk-gold) 18%, var(--cream)), var(--cream));
  margin: var(--space-lg) 0;
  box-shadow: var(--shadow-soft);
}

givebutter-widget,
givebutter-giving-form {
  display: block;
  min-height: 4rem;
  margin-top: var(--space-md);
}

/* Footer: high contrast, clear hierarchy, donate CTA + link, responsive by viewport */
.site-footer {
  --footer-fg: oklch(96% 0.02 95);
  --footer-fg-muted: oklch(82% 0.04 95);
  background: var(--uk-blue-deep);
  color: var(--footer-fg-muted);
  /* Separation from content comes from main.site-inner padding-bottom; avoid stacking a second huge margin */
  margin-top: 0;
  padding: clamp(1.5rem, 4vw, 2.5rem) var(--pad-inline) clamp(1.25rem, 2.75vw, 1.75rem);
}

.footer-shell {
  max-width: var(--content-max);
  margin: 0 auto;
}

.footer-mast {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: center;
  gap: clamp(1.5rem, 4vw, 2.75rem);
  padding-bottom: clamp(1.5rem, 3.5vw, 2.25rem);
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  border-bottom: 1px solid color-mix(in oklch, var(--footer-fg) 18%, transparent);
}

.footer-mast__intro {
  flex: 0 1 min(36rem, 100%);
  min-width: min(100%, 16rem);
  text-align: center;
}

@media (min-width: 721px) {
  .footer-mast__intro {
    text-align: left;
  }
}

.footer-mast__lead {
  margin: 0 0 var(--space-sm);
  font-size: clamp(0.9375rem, 0.35vw + 0.88rem, 1.0625rem);
  line-height: 1.55;
  color: color-mix(in oklch, var(--footer-fg) 94%, transparent);
  max-width: 48ch;
}

.footer-mast__meta {
  margin: 0;
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  color: var(--footer-fg-muted);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-xs);
}

.footer-mast__badge {
  font-weight: 650;
  color: color-mix(in oklch, var(--uk-gold-bright) 88%, var(--footer-fg));
}

.footer-mast__dot {
  opacity: 0.65;
}

.footer-mast__cta {
  flex: 0 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  width: min(100%, 17rem);
}

.footer-mast__cta-label {
  margin: 0;
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--footer-fg) 78%, transparent);
  text-align: center;
}

.footer-donate-btn {
  justify-content: center;
  min-height: 48px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.site-footer .btn,
.site-footer .btn:hover {
  text-decoration: none;
}

.footer-nav {
  margin: 0;
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1.35rem, 3vw, 2rem);
}

.footer-col__h {
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 750;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--footer-fg) 72%, transparent);
  margin: 0 0 var(--space-sm);
}

.footer-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-list li {
  margin: 0;
  border-bottom: 1px solid color-mix(in oklch, var(--footer-fg) 10%, transparent);
}

.footer-list li:last-child {
  border-bottom: none;
}

.footer-list a {
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: var(--space-micro) 0;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--footer-fg);
  text-decoration: none;
  text-underline-offset: 0.2em;
  transition: color 0.2s var(--ease-out), background 0.2s var(--ease-out);
  border-radius: var(--radius);
  margin: 0 calc(-1 * var(--space-micro));
  padding-left: var(--space-micro);
  padding-right: var(--space-micro);
}

.footer-list a:hover {
  color: var(--uk-gold-bright);
  background: color-mix(in oklch, var(--uk-gold) 8%, transparent);
}

.footer-list a:focus-visible {
  outline: 2px solid var(--uk-gold-bright);
  outline-offset: 2px;
}

.footer-list a.footer-link-donate {
  font-weight: 700;
  color: var(--uk-gold-bright);
}

.footer-address {
  margin: 0 0 var(--space-sm);
  font-size: 0.9rem;
  line-height: 1.55;
  color: color-mix(in oklch, var(--footer-fg) 90%, transparent);
}

.footer-contact-lines {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-contact-lines li {
  margin: 0;
}

.footer-contact-link,
.footer-contact-lines a {
  display: inline-flex;
  min-height: 44px;
  align-items: center;
  font-size: 0.9375rem;
  font-weight: 650;
  color: var(--uk-gold-bright);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in oklch, var(--uk-gold-bright) 45%, transparent);
  padding-bottom: 0.1em;
  transition: color 0.2s var(--ease-out), border-color 0.2s var(--ease-out);
}

.footer-contact-link:hover,
.footer-contact-lines a:hover {
  color: color-mix(in oklch, var(--uk-gold-bright) 95%, white);
  border-bottom-color: var(--uk-gold-bright);
}

.footer-contact-link:focus-visible,
.footer-contact-lines a:focus-visible {
  outline: 2px solid var(--uk-gold-bright);
  outline-offset: 3px;
  border-radius: 2px;
}

.footer-social {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-social li {
  margin: 0;
  border-bottom: 1px solid color-mix(in oklch, var(--footer-fg) 10%, transparent);
}

.footer-social li:last-child {
  border-bottom: none;
}

.footer-social__link {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  min-height: 44px;
  padding: 0.35rem 0.35rem 0.35rem 0;
  font-size: 0.9375rem;
  color: var(--footer-fg);
  text-decoration: none;
  margin: 0 -0.35rem;
  border-radius: var(--radius);
  transition:
    color 0.2s var(--ease-out),
    background 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.footer-social__ico {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.35rem;
  height: 1.35rem;
  color: color-mix(in oklch, var(--uk-gold-bright) 92%, var(--footer-fg));
}

.footer-social__ico svg {
  display: block;
  width: 100%;
  height: 100%;
}

.footer-social__link:hover {
  color: var(--uk-gold-bright);
  background: color-mix(in oklch, var(--uk-gold) 8%, transparent);
}

@media (hover: hover) and (pointer: fine) {
  .footer-social__link:hover {
    transform: translateX(3px);
  }
}

.footer-social__link:hover .footer-social__ico {
  color: var(--uk-gold-bright);
}

.footer-social__link:focus-visible {
  outline: 2px solid var(--uk-gold-bright);
  outline-offset: 2px;
}

.footer-legal {
  max-width: var(--content-max);
  margin: clamp(1.25rem, 3vw, 1.75rem) auto 0;
  padding-top: clamp(1rem, 2.5vw, 1.35rem);
  border-top: 1px solid color-mix(in oklch, var(--footer-fg) 22%, transparent);
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--footer-fg-muted);
  display: grid;
  gap: 0.65rem 1rem;
  justify-items: center;
  text-align: center;
}

.footer-legal__copy {
  max-width: 40ch;
}

.footer-legal__meta {
  font-variant-numeric: tabular-nums;
}

.footer-legal__policies a {
  color: var(--footer-fg);
  text-decoration: underline;
  text-decoration-color: color-mix(in oklch, var(--uk-gold) 45%, transparent);
  text-underline-offset: 0.15em;
}

.footer-legal__policies a:hover {
  color: var(--uk-gold-bright);
  text-decoration-color: var(--uk-gold-bright);
}

.footer-legal__sep {
  margin: 0 0.35rem;
  opacity: 0.65;
}

@media (min-width: 640px) {
  .footer-legal {
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    justify-items: stretch;
    text-align: left;
  }

  .footer-legal__copy {
    justify-self: start;
    max-width: none;
  }

  .footer-legal__meta {
    justify-self: center;
  }

  .footer-legal__policies {
    justify-self: end;
    text-align: right;
  }
}

@media (max-width: 720px) {
  .footer-mast {
    align-items: stretch;
    justify-content: stretch;
  }

  .footer-mast__intro {
    text-align: left;
  }

  .footer-mast__cta {
    width: 100%;
    max-width: none;
    align-items: stretch;
  }

  .footer-mast__cta-label {
    text-align: left;
  }
}

@media (max-width: 900px) {
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

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

/* Visible by default for crawlers & no-JS; .js + IO adds motion without hiding copy from the DOM. */
.reveal {
  opacity: 1;
  transform: none;
  transition: opacity 0.65s var(--ease-out), transform 0.65s var(--ease-out);
}

.js .reveal:not(.is-visible) {
  opacity: 0;
  transform: translateY(1.25rem);
}

.reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* Staggered scroll reveals: section shell stays in flow; children use transform + opacity only */
.js .reveal.reveal--stagger:not(.is-visible) {
  opacity: 1;
  transform: none;
}

.js .home-pillars.reveal--stagger:not(.is-visible) .home-section-head,
.js .home-pillars.reveal--stagger:not(.is-visible) .home-pillar {
  opacity: 0;
  transform: translateY(1rem);
}

.home-pillars.reveal--stagger .home-section-head,
.home-pillars.reveal--stagger .home-pillar {
  transition: opacity 0.55s var(--ease-out), transform 0.55s var(--ease-out);
}

.home-pillars.reveal--stagger.is-visible .home-section-head,
.home-pillars.reveal--stagger.is-visible .home-pillar {
  opacity: 1;
  transform: none;
}

.home-pillars.reveal--stagger.is-visible .home-section-head {
  transition-delay: 0ms;
}

.home-pillars.reveal--stagger.is-visible .home-pillar-grid .home-pillar:nth-child(1) {
  transition-delay: 40ms;
}

.home-pillars.reveal--stagger.is-visible .home-pillar-grid .home-pillar:nth-child(2) {
  transition-delay: 80ms;
}

.home-pillars.reveal--stagger.is-visible .home-pillar-grid .home-pillar:nth-child(3) {
  transition-delay: 120ms;
}

.home-pillars.reveal--stagger.is-visible .home-pillar-grid .home-pillar:nth-child(4) {
  transition-delay: 160ms;
}

.js .home-campaigns.reveal--stagger:not(.is-visible) .home-campaigns__header,
.js .home-campaigns.reveal--stagger:not(.is-visible) .home-campaign-card {
  opacity: 0;
  transform: translateY(1rem);
}

.home-campaigns.reveal--stagger .home-campaigns__header,
.home-campaigns.reveal--stagger .home-campaign-card {
  transition: opacity 0.55s var(--ease-out), transform 0.55s var(--ease-out);
}

.home-campaigns.reveal--stagger.is-visible .home-campaigns__header,
.home-campaigns.reveal--stagger.is-visible .home-campaign-card {
  opacity: 1;
  transform: none;
}

.home-campaigns.reveal--stagger.is-visible .home-campaigns__header {
  transition-delay: 0ms;
}

.home-campaigns.reveal--stagger.is-visible .home-campaign-grid .home-campaign-card:nth-child(1) {
  transition-delay: 45ms;
}

.home-campaigns.reveal--stagger.is-visible .home-campaign-grid .home-campaign-card:nth-child(2) {
  transition-delay: 90ms;
}

.home-campaigns.reveal--stagger.is-visible .home-campaign-grid .home-campaign-card:nth-child(3) {
  transition-delay: 135ms;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-sm);
}

.gallery-grid figure {
  margin: 0;
  overflow: hidden;
  border-radius: var(--radius);
  aspect-ratio: 4/3;
}

.gallery-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s var(--ease-out);
}

.gallery-grid figure:hover img {
  transform: scale(1.04);
}

.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-lg);
}

.team-card {
  text-align: center;
}

.team-card img {
  width: 100%;
  max-width: 280px;
  margin: 0 auto var(--space-sm);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
}

.team-card h3 {
  font-family: var(--font-display);
  font-size: 1.35rem;
  margin: 0 0 0.25rem;
  color: var(--uk-blue-deep);
}

.team-card .role {
  font-size: 0.9rem;
  color: var(--ink-muted);
  margin-bottom: var(--space-sm);
}

.form-grid {
  display: grid;
  gap: var(--space-sm);
  max-width: 32rem;
}

label {
  font-size: 0.8125rem;
  font-weight: 650;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

input,
textarea {
  width: 100%;
  min-height: 48px;
  padding: 0.75rem 1rem;
  font-family: var(--font-ui);
  font-size: 1rem;
  border: 2px solid var(--line);
  border-radius: var(--radius);
  background: var(--cream);
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}

textarea {
  min-height: 10rem;
  resize: vertical;
}

input:focus,
textarea:focus {
  outline: none;
  border-color: var(--uk-blue-deep);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--uk-blue) 25%, transparent);
}

.partner-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  padding: var(--space-md) 0;
}

.partner-strip img {
  max-height: 3.5rem;
  width: auto;
  filter: grayscale(0.15);
  opacity: 0.95;
  transition: opacity 0.25s var(--ease-out);
}

.partner-strip img:hover {
  opacity: 1;
}

.page-hero {
  padding: clamp(3rem, 9vw, 5.5rem) var(--pad-inline) clamp(2.5rem, 6vw, 3.75rem);
  background: linear-gradient(135deg, var(--uk-blue-deep) 0%, oklch(30% 0.1 255) 100%);
  color: oklch(99% 0.01 95);
}

.site-inner .page-hero {
  margin-bottom: var(--section-pad-y-tight);
}

@media (min-width: 1024px) {
  .site-inner .page-hero {
    max-width: var(--content-max);
    margin-left: auto;
    margin-right: auto;
    border-radius: var(--radius-lg);
  }
}

.page-hero h1 {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2.1rem, 3.5vw + 0.75rem, 3.4rem);
  font-weight: 550;
  margin: 0 0 var(--space-sm);
  max-width: 22ch;
  letter-spacing: -0.02em;
}

.page-hero .lead {
  font-size: clamp(1.05rem, 0.8vw + 0.95rem, 1.2rem);
  max-width: 52ch;
  line-height: 1.55;
  color: oklch(93% 0.02 95);
  margin: 0;
}

/* Inner pages: section headings match centered bands (cards, grids, media) */
.site-inner .section .section-title {
  text-align: center;
  margin-bottom: var(--space-md);
}

.site-inner .section .section-intro {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-md);
}

.site-inner .power-split__main .section-title {
  text-align: left;
}

.site-inner .section .summit-h2 {
  text-align: center;
}

.site-inner .summit-notify.section .summit-notify__intro {
  text-align: center;
}

.site-inner .article-body {
  padding-bottom: var(--section-pad-y);
  padding-left: var(--pad-inline);
  padding-right: var(--pad-inline);
  max-width: 42rem;
}

.site-inner.blog-post-page .article-body.blog-article-body {
  padding-bottom: clamp(2rem, 5vw, 3rem);
}

.site-inner .team-grid {
  gap: clamp(1.5rem, 4vw, 2.5rem);
}

.site-inner {
  padding-bottom: var(--page-footer-gap);
}

.page-hero .hero-ribbon {
  animation: none;
  opacity: 1;
}

.alloc-item {
  margin-bottom: var(--space-md);
}

.alloc-label {
  display: flex;
  justify-content: space-between;
  font-size: 0.9375rem;
  font-weight: 550;
  color: var(--ink);
  margin-bottom: 0.4rem;
}

.alloc-bar {
  height: 0.55rem;
  background: color-mix(in oklch, var(--uk-blue) 12%, var(--cream));
  border-radius: 999px;
  overflow: hidden;
}

.alloc-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--uk-blue-deep), var(--uk-gold));
  border-radius: 999px;
  transform-origin: left;
  transform: scaleX(1);
}

@media (prefers-reduced-motion: no-preference) {
  .alloc-fill {
    transform: scaleX(0);
    animation: growBar 1s var(--ease-out) forwards;
  }
}

@keyframes growBar {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}

.video-grid {
  display: grid;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}

.video-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  background: var(--cream);
}

.video-card h3 {
  font-family: var(--font-display);
  margin-top: 0;
  color: var(--uk-blue-deep);
}

/* ReH2O initiative: hero uses shared .power-hero; keep crane photo focal point */
.reh2o-page .power-hero::before {
  background-position: center 40%;
}

.reh2o-page .reh2o-section {
  padding-top: var(--section-pad-y-tight);
  padding-bottom: var(--section-pad-y-tight);
}

.reh2o-page .reh2o-section__intro {
  margin-bottom: var(--space-md);
}

.reh2o-page .reh2o-card-grid {
  gap: var(--space-md);
}

.reh2o-solution-card {
  padding: 0;
  overflow: hidden;
}

.reh2o-solution-card__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 10%, var(--cream));
}

.reh2o-solution-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s var(--ease-out);
}

.reh2o-solution-card:hover .reh2o-solution-card__media img {
  transform: scale(1.03);
}

.reh2o-solution-card__body {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  flex: 1;
}

@media (prefers-reduced-motion: reduce) {
  .reh2o-solution-card:hover .reh2o-solution-card__media img {
    transform: none;
  }
}

.reh2o-page .section-title--sub {
  font-size: clamp(1.35rem, 2vw + 0.75rem, 1.85rem);
  margin-bottom: var(--space-sm);
}

.reh2o-page .reh2o-section--gallery .section-intro {
  margin-bottom: var(--space-md);
}

.reh2o-page .reh2o-section--150 {
  background: linear-gradient(
    180deg,
    var(--cream) 0%,
    color-mix(in oklch, var(--uk-blue) 5%, var(--cream)) 100%
  );
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 8%, transparent);
}

.reh2o-page .reh2o-150-plan__lead {
  margin-bottom: 0;
  font-size: clamp(1.02rem, 0.35vw + 0.95rem, 1.12rem);
  line-height: 1.65;
}

.reh2o-page .reh2o-150-plan__h {
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 1.1vw + 0.88rem, 1.45rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  margin: var(--space-md) 0 var(--space-sm);
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.reh2o-page .reh2o-150-plan__cta {
  margin-top: var(--space-md);
  margin-bottom: 0;
}

.reh2o-video-grid {
  display: grid;
  gap: var(--space-lg);
  margin-top: var(--space-sm);
}

@media (min-width: 768px) {
  .reh2o-video-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
    align-items: start;
  }
}

.reh2o-video {
  margin: 0;
}

.reh2o-video__frame {
  position: relative;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  background: oklch(14% 0.04 255);
  box-shadow: var(--shadow-soft);
}

.reh2o-video__frame video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.reh2o-video__cap {
  margin-top: var(--space-sm);
  padding: 0 0.15rem;
}

.reh2o-video__cap h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 600;
  margin: 0 0 0.35rem;
  color: var(--uk-blue-deep);
  letter-spacing: -0.02em;
}

.reh2o-video__cap p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.reh2o-gallery {
  margin-top: var(--space-sm);
}

.reh2o-gallery figure {
  border: 1px solid color-mix(in oklch, var(--line) 80%, transparent);
}

/* Advocacy initiative — editorial poster scale, asymmetric rhythm, numbered pillars (no card-template grid) */
.advocacy-page {
  --adv-font-display: "Archivo", system-ui, sans-serif;
  --adv-font-body: "Merriweather", "Georgia", serif;
  font-family: var(--adv-font-body);
}

.advocacy-page .section-title,
.advocacy-page .advocacy-pillars__body h3 {
  font-family: var(--adv-font-display);
}

.advocacy-page .advocacy-event__cta-label {
  font-family: var(--adv-font-body);
  margin-top: var(--space-sm);
  margin-bottom: 0;
}

.advocacy-page .section .section-title {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
  max-width: 28ch;
  text-wrap: balance;
}

.advocacy-page .section .section-intro {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
  max-width: 52ch;
}

.advocacy-page .advocacy-section--event .section-title {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  max-width: min(48ch, 100%);
  text-wrap: balance;
}

.advocacy-page .article-body.advocacy-article {
  max-width: min(48rem, 100%);
}

.advocacy-partner__main .advocacy-article {
  padding-left: 0;
  padding-right: 0;
}

.advocacy-page .power-hero__lead {
  font-family: var(--adv-font-body);
}

.advocacy-page .power-hero .power-hero__title {
  max-width: min(28ch, 100%);
}

.advocacy-section {
  padding-top: var(--section-pad-y-tight);
  padding-bottom: var(--section-pad-y-tight);
}

.advocacy-partner {
  display: grid;
  gap: clamp(1.75rem, 4vw, 3rem);
  align-items: start;
  padding: 0 var(--pad-inline);
  max-width: var(--content-max);
  margin: 0 auto;
}

@media (min-width: 900px) {
  .advocacy-partner {
    grid-template-columns: minmax(0, 1fr) minmax(14rem, 22rem);
    gap: clamp(2rem, 5vw, 4rem);
  }
}

.advocacy-partner__main .article-body {
  padding-bottom: 0;
}

.advocacy-partner__aside {
  position: relative;
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background: color-mix(in oklch, var(--uk-blue) 6%, var(--cream));
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
  box-shadow: var(--shadow-soft);
}

.advocacy-partner__logo-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-md);
  background: oklch(99% 0.008 95);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.advocacy-partner__logo-frame img {
  max-height: 5rem;
  width: auto;
  margin: 0 auto;
}

.advocacy-partner__tagline {
  margin: var(--space-sm) 0 0;
  font-family: var(--adv-font-display);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-align: center;
  line-height: 1.45;
}

.advocacy-pillars {
  list-style: none;
  margin: var(--space-lg) auto 0;
  padding: 0 var(--pad-inline);
  max-width: var(--content-max);
  display: flex;
  flex-direction: column;
  gap: 0;
}

.advocacy-pillars__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: start;
  padding: clamp(1.35rem, 3vw, 2rem) 0;
  border-top: 1px solid var(--line);
}

.advocacy-pillars__item:last-child {
  border-bottom: 1px solid var(--line);
}

.advocacy-pillars__n {
  font-family: var(--adv-font-display);
  font-size: clamp(2rem, 4vw + 0.5rem, 3.25rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  color: color-mix(in oklch, var(--uk-blue-deep) 35%, var(--cream));
  font-variant-numeric: tabular-nums;
}

.advocacy-pillars__body h3 {
  margin: 0 0 0.5rem;
  font-size: clamp(1.2rem, 1vw + 1rem, 1.45rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--uk-blue-deep);
}

.advocacy-pillars__body p {
  margin: 0;
  font-size: clamp(0.98rem, 0.25vw + 0.92rem, 1.05rem);
  line-height: 1.68;
  color: var(--ink-soft);
  max-width: 62ch;
}

.advocacy-section--event .article-body {
  padding-bottom: var(--space-md);
}

.advocacy-event__facts {
  margin: var(--space-md) 0;
  padding: var(--space-md) var(--space-md) var(--space-md) calc(var(--space-md) + 0.15rem);
  background: color-mix(in oklch, var(--uk-blue) 5.5%, var(--cream));
  border-radius: var(--radius);
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
}

.advocacy-event__facts li {
  margin-bottom: 0.4rem;
}

.advocacy-event__facts li:last-child {
  margin-bottom: 0;
}

.advocacy-event__photos {
  display: grid;
  gap: var(--space-md);
  margin-top: var(--space-md);
  padding: 0 var(--pad-inline);
  max-width: var(--content-max);
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 768px) {
  .advocacy-event__photos {
    grid-template-columns: 1.12fr 1fr;
    grid-template-rows: minmax(17rem, 52vh);
    align-items: stretch;
    gap: var(--space-md);
  }

  .advocacy-event__figure {
    margin: 0;
    height: 100%;
    min-height: 14rem;
    overflow: hidden;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-elevated);
    background: oklch(20% 0.04 255);
  }

  .advocacy-event__figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.65s var(--ease-out);
  }

  .advocacy-event__figure:hover img {
    transform: scale(1.03);
  }
}

@media (max-width: 767px) {
  .advocacy-event__figure {
    margin: 0;
    overflow: hidden;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-soft);
  }

  .advocacy-event__figure img {
    width: 100%;
    height: auto;
    display: block;
  }
}

@media (prefers-reduced-motion: reduce) {
  .advocacy-event__figure:hover img {
    transform: none;
  }
}

/* Tighter vertical rhythm: section padding + panel margins were stacking */
.advocacy-page .advocacy-section--donate {
  padding-top: clamp(1.5rem, 3.5vw, 2.25rem);
  padding-bottom: clamp(1.5rem, 3.5vw, 2.25rem);
}

.donate-panel--advocacy {
  margin: 0;
  max-width: min(40rem, 100%);
  margin-inline: auto;
  padding: clamp(1.35rem, 3vw, 1.85rem) clamp(1.25rem, 3.5vw, 1.75rem);
  border: none;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      155deg,
      color-mix(in oklch, var(--uk-blue-deep) 94%, oklch(20% 0.05 255)) 0%,
      oklch(22% 0.08 255) 100%
    );
  color: oklch(96% 0.02 95);
  box-shadow:
    0 1.25rem 3rem oklch(12% 0.06 255 / 0.35),
    inset 0 1px 0 color-mix(in oklch, oklch(98% 0.01 95) 12%, transparent);
  text-align: center;
}

.donate-panel--advocacy .section-title {
  color: oklch(99% 0.01 95);
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-sm);
  max-width: 22ch;
}

.donate-panel--advocacy .section-intro {
  color: oklch(86% 0.03 95);
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-md);
  max-width: 48ch;
}

.donate-panel--advocacy .btn-primary {
  margin-top: 0;
  background: var(--uk-gold);
  color: var(--uk-blue-deep);
  border-color: transparent;
  font-family: var(--adv-font-display);
  font-weight: 700;
  letter-spacing: 0.03em;
}

.donate-panel--advocacy .btn-primary:hover {
  background: var(--uk-gold-bright);
  color: oklch(16% 0.04 255);
}

/* Power generators initiative — industrial editorial, single placeholder until field photos ship */
.power-page {
  padding-bottom: 0;
}

.power-hero {
  --power-hero-bg: linear-gradient(145deg, oklch(22% 0.08 255), oklch(18% 0.06 255));
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: clamp(19rem, 44vw, 32rem);
  padding: clamp(3.25rem, 9vw, 5.75rem) var(--pad-inline) clamp(2.75rem, 7vw, 4.5rem);
  color: oklch(98% 0.01 95);
}

.power-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(
      118deg,
      oklch(14% 0.07 255 / 0.93) 0%,
      oklch(22% 0.08 255 / 0.78) 45%,
      oklch(32% 0.05 255 / 0.42) 100%
    ),
    var(--power-hero-bg);
  background-size: cover;
  background-position: center 38%;
}

.power-hero__noise {
  position: absolute;
  inset: 0;
  z-index: 1;
  opacity: 0.045;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

.power-hero__accent {
  position: absolute;
  bottom: -20%;
  right: -8%;
  width: min(52vw, 28rem);
  height: min(52vw, 28rem);
  z-index: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 40% 40%, color-mix(in oklch, var(--uk-gold-bright) 35%, transparent), transparent 68%);
  pointer-events: none;
  opacity: 0.55;
}

.power-hero__inner {
  position: relative;
  z-index: 2;
  max-width: min(46rem, 100%);
}

/* ReH2O, Power, Advocacy: same centered content rail as .contact-hero / .section (not full-bleed-left in the padded band). Dreamzzz keeps its own inner rules. */
.power-hero:not(.power-hero--dreamzzz) .power-hero__inner {
  box-sizing: border-box;
  width: min(100%, var(--content-max));
  max-width: min(var(--content-max), 100%);
  margin-inline: auto;
}

.power-hero__kicker {
  margin: 0 0 0.85rem;
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 88%, oklch(98% 0.01 95));
}

.power-hero__title {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.6vw + 0.85rem, 3.35rem);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -0.03em;
  max-width: 18ch;
}

.power-hero__lead {
  margin: 0;
  font-size: clamp(1.05rem, 0.55vw + 0.95rem, 1.2rem);
  line-height: 1.62;
  max-width: 48ch;
  color: color-mix(in oklch, oklch(98% 0.01 95) 88%, var(--uk-blue));
}

.power-metrics {
  margin-top: calc(-1 * clamp(1.5rem, 4vw, 2.5rem));
  padding: 0 var(--pad-inline) clamp(2rem, 5vw, 3rem);
  position: relative;
  z-index: 3;
}

.power-metrics__list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: 960px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 18%, var(--line));
  box-shadow: 0 18px 44px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
  background: var(--line);
}

.power-metrics__item {
  padding: clamp(1.15rem, 2.5vw, 1.65rem) clamp(1rem, 2vw, 1.35rem);
  background: oklch(100% 0 0);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  text-align: left;
}

.power-metrics__item--accent {
  background: linear-gradient(
    165deg,
    color-mix(in oklch, var(--uk-gold-bright) 14%, oklch(100% 0 0)),
    oklch(100% 0 0)
  );
}

.power-metrics__value {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.5vw + 1rem, 2.65rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--uk-blue-deep);
}

.power-metrics__item--accent .power-metrics__value {
  color: color-mix(in oklch, var(--uk-blue-deep) 92%, var(--uk-gold));
}

.power-metrics__label {
  font-size: 0.875rem;
  line-height: 1.45;
  color: var(--ink-soft);
  max-width: 28ch;
}

.power-split {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(14rem, 0.85fr);
  gap: clamp(1.5rem, 4vw, 2.75rem);
  align-items: start;
  max-width: 1080px;
  margin: 0 auto;
  padding: var(--section-pad-y-tight) var(--pad-inline);
}

.power-article {
  padding-left: 0;
  padding-right: 0;
  max-width: none;
}

.power-split__rail {
  position: relative;
  padding: var(--space-md) var(--space-md) var(--space-md) 1.15rem;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, var(--line));
  background: linear-gradient(
    180deg,
    color-mix(in oklch, var(--uk-blue) 5%, var(--cream)),
    oklch(100% 0 0)
  );
  box-shadow: var(--shadow-soft);
}

.power-split__rail::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1rem;
  bottom: 1rem;
  width: 4px;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--uk-gold-bright), var(--uk-blue-deep));
}

.power-split__stat {
  margin: 0 0 0.65rem;
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--uk-blue-deep);
}

.power-split__note {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.power-photo {
  margin: 0 auto;
  padding: 0 var(--pad-inline) var(--section-pad-y-tight);
  max-width: 1100px;
}

.power-photo__frame {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 15%, var(--line));
  box-shadow: 0 24px 56px color-mix(in oklch, var(--uk-blue-deep) 14%, transparent);
  background: oklch(18% 0.04 255);
}

.power-photo__img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.power-photo__cap {
  margin: 0.65rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--ink-muted);
  max-width: 62ch;
}

.power-ways {
  padding-top: var(--section-pad-y-tight);
  padding-bottom: var(--section-pad-y-tight);
}

.power-ways__intro {
  margin-bottom: var(--space-md);
}

.power-ways__list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: 52rem;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.power-way {
  display: grid;
  grid-template-columns: minmax(10rem, 14rem) minmax(0, 1fr);
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 10%, var(--line));
  align-items: baseline;
}

.power-way:first-child {
  padding-top: 0;
}

.power-way:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.power-way__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--uk-blue-deep);
  letter-spacing: -0.02em;
}

.power-way__desc {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.power-closer {
  padding: clamp(2rem, 5vw, 3.5rem) var(--pad-inline) clamp(2.5rem, 6vw, 4rem);
}

.power-closer__card {
  max-width: 720px;
  margin: 0 auto;
  padding: clamp(1.75rem, 4vw, 2.5rem);
  text-align: center;
  border-radius: 1.15rem;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, transparent);
  background: linear-gradient(
    155deg,
    color-mix(in oklch, white 94%, var(--cream)),
    color-mix(in oklch, var(--uk-gold-bright) 9%, var(--cream))
  );
  box-shadow: 0 20px 48px color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
}

.power-closer__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 1.2vw + 1rem, 1.85rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  letter-spacing: -0.02em;
}

.power-closer__text {
  margin: 0 0 var(--space-md);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 52ch;
  margin-inline: auto;
}

.power-closer__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: center;
}

@media (max-width: 820px) {
  .power-metrics__list {
    grid-template-columns: 1fr;
  }

  .power-split {
    grid-template-columns: 1fr;
  }

  .power-way {
    grid-template-columns: 1fr;
    gap: 0.35rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .power-hero__accent {
    opacity: 0.35;
  }
}

/* Ukraine Dreamzzz — arena editorial (scoped; gold/navy brand, no neon AI palette) */
.dreamzzz-page {
  padding-bottom: 0;
}

.power-hero--dreamzzz {
  min-height: clamp(22rem, 52vw, 38rem);
  padding-bottom: clamp(3rem, 8vw, 5rem);
}

.power-hero--dreamzzz::before {
  background-image:
    linear-gradient(
      105deg,
      oklch(8% 0.06 262 / 0.97) 0%,
      oklch(14% 0.09 258 / 0.88) 38%,
      oklch(22% 0.07 255 / 0.55) 72%,
      oklch(28% 0.06 95 / 0.25) 100%
    ),
    var(--power-hero-bg);
  background-position: center 35%;
}

.power-hero__veil--dreamzzz {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.4;
  background: repeating-linear-gradient(
    -18deg,
    transparent 0,
    transparent 14px,
    color-mix(in oklch, var(--uk-gold-bright) 6%, transparent) 14px,
    color-mix(in oklch, var(--uk-gold-bright) 6%, transparent) 15px
  );
  mix-blend-mode: soft-light;
}

.power-hero__accent--dreamzzz {
  width: min(70vw, 36rem);
  height: min(70vw, 36rem);
  bottom: -35%;
  right: -18%;
  opacity: 0.42;
  background: radial-gradient(
    circle at 35% 35%,
    color-mix(in oklch, var(--uk-gold-bright) 42%, transparent),
    transparent 62%
  );
}

.power-hero__inner--dreamzzz {
  max-width: min(52rem, 100%);
  margin-inline: auto;
  text-align: center;
}

.power-hero__kicker--dreamzzz {
  letter-spacing: 0.22em;
  font-weight: 600;
  color: color-mix(in oklch, var(--uk-gold-bright) 92%, white);
}

.dreamzzz-hero__mark {
  width: clamp(3.25rem, 10vw, 5rem);
  height: 4px;
  margin: 0 auto 1.1rem;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    var(--uk-gold) 0%,
    var(--uk-gold) 50%,
    var(--uk-blue) 50%,
    var(--uk-blue) 100%
  );
}

.power-hero__title--dreamzzz {
  max-width: 16ch;
  margin-inline: auto;
  font-size: clamp(2.65rem, 5.5vw + 1rem, 4.35rem);
  font-weight: 500;
  line-height: 0.98;
  letter-spacing: -0.045em;
  text-shadow: 0 2px 24px color-mix(in oklch, var(--uk-blue-deep) 55%, transparent);
}

.dreamzzz-hero__title-accent {
  display: inline-block;
  font-style: italic;
  font-weight: 700;
  color: color-mix(in oklch, var(--uk-gold-bright) 96%, white);
}

.power-hero__lead--dreamzzz {
  max-width: 46ch;
  margin-inline: auto;
  font-size: clamp(1.08rem, 0.65vw + 0.95rem, 1.28rem);
  line-height: 1.55;
  font-weight: 400;
  color: color-mix(in oklch, oklch(97% 0.015 95) 92%, var(--uk-blue));
}

.power-hero__lead--dreamzzz strong {
  font-weight: 600;
  color: oklch(99% 0.01 95);
}

.dreamzzz-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  margin: clamp(1.35rem, 3vw, 1.85rem) 0 0;
  padding: 0;
  list-style: none;
}

.dreamzzz-hero__chips li {
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-gold-bright) 45%, transparent);
  background: color-mix(in oklch, var(--uk-blue-deep) 35%, transparent);
  color: color-mix(in oklch, var(--uk-gold-bright) 88%, white);
}

.dreamzzz-h2 {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.4vw + 1rem, 2.65rem);
  font-weight: 600;
  letter-spacing: -0.035em;
  line-height: 1.12;
  color: var(--uk-blue-deep);
}

.dreamzzz-band {
  padding: clamp(2.75rem, 6vw, 4.5rem) var(--pad-inline);
}

.dreamzzz-band--story {
  background: linear-gradient(
    180deg,
    var(--cream) 0%,
    color-mix(in oklch, var(--uk-gold-bright) 7%, var(--cream)) 100%
  );
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 8%, var(--line));
}

.dreamzzz-band__inner {
  max-width: 42rem;
  margin: 0 auto;
}

.dreamzzz-lede {
  margin: 0 0 var(--space-md);
  font-size: clamp(1.05rem, 0.35vw + 0.98rem, 1.15rem);
  line-height: 1.65;
  color: var(--ink);
}

.dreamzzz-band__inner > p:last-of-type {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.65;
  color: var(--ink-soft);
}

.dreamzzz-quote {
  margin: var(--space-md) 0;
  padding: clamp(1.15rem, 2.5vw, 1.5rem) 0 clamp(1.15rem, 2.5vw, 1.5rem) clamp(1rem, 2.5vw, 1.35rem);
  border-left: 4px solid var(--uk-blue-deep);
  background: color-mix(in oklch, var(--uk-blue) 6%, white);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}

.dreamzzz-quote p {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1vw + 1rem, 1.5rem);
  font-style: italic;
  font-weight: 550;
  line-height: 1.35;
  color: var(--uk-blue-deep);
}

.dreamzzz-pillars {
  padding: clamp(2.5rem, 6vw, 4rem) var(--pad-inline) clamp(2rem, 5vw, 3.5rem);
  background: var(--cream);
}

.dreamzzz-pillars__head {
  max-width: 40rem;
  margin: 0 auto var(--space-lg);
  text-align: center;
}

.dreamzzz-pillars__sub {
  margin: 0.5rem 0 0;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.dreamzzz-pillars__list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: 960px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.25rem, 3vw, 1.75rem);
}

.dreamzzz-pillar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: clamp(1.15rem, 2.5vw, 1.45rem);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, var(--line));
  background: oklch(100% 0 0);
  box-shadow: 0 10px 32px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent);
}

.dreamzzz-pillar__n {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--uk-blue);
}

.dreamzzz-pillar__h {
  margin: 0 0 0.35rem;
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--uk-blue-deep);
}

.dreamzzz-pillar__p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.dreamzzz-figure {
  margin: 0;
  padding: 0 var(--pad-inline) clamp(2rem, 5vw, 3rem);
  max-width: 1000px;
  margin-inline: auto;
}

.dreamzzz-figure__frame {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 18%, var(--line));
  box-shadow: 0 20px 50px color-mix(in oklch, var(--uk-blue-deep) 14%, transparent);
  background: oklch(16% 0.04 255);
}

.dreamzzz-figure__frame img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.dreamzzz-figure__cap {
  margin: 0.75rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--ink-muted);
  max-width: 62ch;
}

.dreamzzz-finale {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  padding: clamp(2.75rem, 7vw, 4rem) var(--pad-inline);
  background: linear-gradient(
    168deg,
    oklch(14% 0.08 258) 0%,
    oklch(20% 0.09 255) 45%,
    oklch(11% 0.065 262) 100%
  );
  border-top: 1px solid color-mix(in oklch, var(--uk-gold) 30%, transparent);
  color: oklch(96% 0.02 95);
}

.dreamzzz-finale__inner {
  max-width: 38rem;
  margin: 0 auto;
  text-align: center;
}

.dreamzzz-finale__title {
  margin: 0 0 0.65rem;
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 2vw + 1rem, 2.15rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: oklch(99% 0.01 95);
}

.dreamzzz-finale__text {
  margin: 0 0 var(--space-md);
  font-size: 1.05rem;
  line-height: 1.55;
  color: color-mix(in oklch, oklch(94% 0.02 95) 88%, var(--uk-blue));
}

.dreamzzz-finale__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  margin-bottom: var(--space-sm);
}

.dreamzzz-finale .btn-primary {
  background: oklch(96% 0.02 95);
  color: var(--uk-blue-deep);
  box-shadow: 0 0.2rem 0 oklch(18% 0.06 255);
}

.dreamzzz-finale .btn-primary:hover {
  background: white;
  color: var(--uk-blue-deep);
}

.dreamzzz-finale .btn-gold {
  color: var(--uk-blue-deep);
}

.dreamzzz-finale__email {
  margin: 0;
  font-size: 0.9375rem;
  color: color-mix(in oklch, var(--uk-gold-bright) 85%, white);
}

.dreamzzz-finale__email a {
  color: oklch(99% 0.01 95);
  font-weight: 600;
}

@media (max-width: 640px) {
  .dreamzzz-pillars__list {
    grid-template-columns: 1fr;
  }

  .dreamzzz-pillar {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }

  .dreamzzz-pillar__n {
    font-size: 1.35rem;
  }
}

/* -- Home page (charity landing + Ukraine palette) -- */
/* Vertical rhythm uses --section-pad-y / --section-pad-y-tight; horizontal inset is only on .section (avoid double --pad-inline on nested rails). */
.home-main .section {
  padding-top: var(--section-pad-y);
  padding-bottom: var(--section-pad-y);
}

/* Tighter seam before split band */
.home-main .home-pillars.section {
  padding-bottom: var(--section-pad-y-tight);
}

/* Split band: paired tight rhythm with pillars above */
.home-main .home-split.section {
  padding-top: var(--section-pad-y-tight);
  padding-bottom: var(--section-pad-y-tight);
}

/* Impact + donate: full-bleed background; content stays on --content-max rail inside */
.home-main .home-impact.section,
.home-main .home-donate.section {
  max-width: none;
  width: 100%;
  margin-inline: 0;
  padding-inline: 0;
}

.home-h2 {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 3.2vw + 1rem, 2.75rem);
  font-weight: 550;
  letter-spacing: -0.02em;
  line-height: 1.12;
  color: var(--uk-blue-deep);
  margin: 0 0 var(--space-sm);
}

.home-sub {
  font-size: clamp(1rem, 0.4vw + 0.95rem, 1.125rem);
  color: var(--ink-soft);
  max-width: 52ch;
  margin: 0;
  line-height: 1.65;
}

.home-sub--center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.home-sub--tight {
  margin-top: 0.4rem;
  max-width: 42ch;
}

.home-section-kicker {
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-blue-mid) 92%, var(--ink-muted));
  margin: 0 0 0.5rem;
}

.home-section-kicker--left {
  text-align: left;
}

.home-section-kicker--light {
  color: color-mix(in oklch, oklch(98% 0.01 95) 72%, transparent);
}

.home-section-kicker--center {
  text-align: center;
  color: color-mix(in oklch, var(--uk-blue-deep) 65%, var(--ink-muted));
}

.home-section-head {
  max-width: var(--content-max);
  margin: 0 auto var(--section-pad-y-tight);
  padding: 0;
  text-align: center;
}

.home-section-head--split {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-md);
  text-align: left;
}

.home-section-head--split .home-section-head__text {
  flex: 1 1 min(100%, 28rem);
}

.home-section-head__text .home-h2 {
  margin-top: 0;
}

/* Pillars: editorial intro — centered column, width aligned with card grid below */
.home-section-head--pillars {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  padding: 0;
}

.home-section-kicker--pillars {
  margin-bottom: 0.65rem;
}

.home-section-kicker--pillars::after {
  content: "";
  display: block;
  width: 2.5rem;
  height: 2px;
  margin: 0.65rem auto 0;
  border-radius: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in oklch, var(--uk-gold-bright) 88%, var(--uk-blue-deep)),
    transparent
  );
}

.home-h2--pillars {
  max-width: min(36ch, 100%);
  text-wrap: balance;
  margin-bottom: 0.75rem;
  margin-left: auto;
  margin-right: auto;
}

.home-sub--pillars {
  max-width: min(48ch, 100%);
  margin-top: 0;
  margin-left: auto;
  margin-right: auto;
  text-wrap: balance;
}

.btn-home-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.75rem 1.65rem;
  font-family: var(--font-ui);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  background: var(--uk-gold-bright);
  color: var(--uk-blue-deep);
  box-shadow: 0 0.25rem 0 color-mix(in oklch, var(--uk-blue-deep) 35%, transparent);
  transition: transform 0.2s var(--ease-out), filter 0.2s var(--ease-out);
}

.btn-home-primary:hover {
  filter: brightness(1.03);
  transform: translateY(-1px);
  color: var(--uk-blue-deep);
}

.btn-home-primary:active {
  transform: translateY(0) scale(0.98);
  filter: brightness(0.99);
  transition-duration: 0.12s;
}

.btn-home-primary:hover:active {
  transform: translateY(0) scale(0.98);
}

.btn-home-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0.75rem 1.35rem;
  font-family: var(--font-ui);
  font-size: 0.8125rem;
  font-weight: 650;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--radius);
  background: var(--uk-blue-deep);
  color: oklch(99% 0.01 95);
  border: 2px solid transparent;
  transition: background 0.2s var(--ease-out), transform 0.2s var(--ease-out);
}

.btn-home-secondary:hover {
  background: oklch(32% 0.11 255);
  color: oklch(99% 0.01 95);
}

.btn-home-secondary:active {
  transform: scale(0.985);
  transition-duration: 0.12s;
}

.btn-home-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.6rem 1.25rem;
  font-family: var(--font-ui);
  font-size: 0.8125rem;
  font-weight: 650;
  letter-spacing: 0.05em;
  text-decoration: none;
  border-radius: var(--radius);
  border: 2px solid var(--uk-blue-deep);
  color: var(--uk-blue-deep);
  background: transparent;
  transition:
    background 0.2s var(--ease-out),
    color 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.btn-home-outline:hover {
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  color: var(--uk-blue-deep);
}

.btn-home-outline:active {
  transform: scale(0.985);
  transition-duration: 0.12s;
}

.btn-home-outline--light {
  border-color: color-mix(in oklch, oklch(98% 0.01 95) 55%, transparent);
  color: oklch(98% 0.01 95);
}

.btn-home-outline--light:hover {
  background: color-mix(in oklch, oklch(98% 0.01 95) 12%, transparent);
  color: oklch(99% 0.01 95);
}

/* Hero: editorial spacing + Ukraine SVG photo mask (Gainlove-style focal image) */
.home-hero {
  position: relative;
  overflow: hidden;
  padding: var(--section-pad-y) var(--pad-inline);
  background: var(--cream);
}

.home-hero-bg {
  position: absolute;
  inset: 0;
  opacity: 1;
  background-color: var(--cream);
  background-image:
    linear-gradient(
      165deg,
      color-mix(in oklch, oklch(99.5% 0.008 95) 88%, transparent) 0%,
      color-mix(in oklch, var(--cream) 78%, oklch(96% 0.02 95)) 45%,
      color-mix(in oklch, oklch(99% 0.01 95) 82%, transparent) 100%
    ),
    linear-gradient(
      90deg,
      color-mix(in oklch, var(--uk-blue-deep) 18%, transparent) 0%,
      transparent 50%
    ),
    url("https://www.goukraina.org/images/reh2o/station-interior.jpeg");
  background-size: cover, cover, cover;
  background-position: center, 30% 50%, center 38%;
  background-repeat: no-repeat;
  pointer-events: none;
}

.home-hero-map {
  position: absolute;
  inset: -5% -8%;
  opacity: 0.07;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 400'%3E%3Cpath fill='none' stroke='%23005299' stroke-width='0.6' d='M40 200 Q200 80 400 120 T760 180 M60 280 Q240 200 440 240 T780 300 M100 100 Q300 40 500 80'/%3E%3C/svg%3E");
  background-size: cover;
  background-position: 40% 30%;
}

.home-hero-dot {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.home-hero-dot--1 {
  width: 12px;
  height: 12px;
  background: color-mix(in oklch, var(--uk-gold-bright) 80%, transparent);
  top: 18%;
  left: 8%;
}

.home-hero-dot--2 {
  width: 8px;
  height: 8px;
  background: color-mix(in oklch, var(--uk-blue) 45%, transparent);
  top: 42%;
  right: 12%;
}

.home-hero-dot--3 {
  width: 14px;
  height: 14px;
  background: color-mix(in oklch, var(--uk-gold) 50%, transparent);
  bottom: 22%;
  left: 22%;
}

.home-hero-dot--4 {
  width: 10px;
  height: 10px;
  background: color-mix(in oklch, var(--uk-blue-mid) 55%, transparent);
  top: 62%;
  right: 28%;
}

.home-hero-grid {
  position: relative;
  z-index: 1;
  /* Match summit hero: keep copy + media grouped, not stretched to --content-max */
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(1.75rem, 4.5vw, 4rem);
  align-items: center;
}

.home-hero-kicker {
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
  margin: 0 0 var(--space-sm);
}

.home-hero-copy h1 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 4.5vw + 1rem, 3.65rem);
  font-weight: 550;
  line-height: 1.06;
  letter-spacing: -0.03em;
  color: var(--uk-blue-deep);
  margin: 0 0 var(--space-md);
  max-width: 16ch;
  text-wrap: balance;
}

.home-hero-lead {
  font-size: clamp(1.05rem, 0.5vw + 0.98rem, 1.2rem);
  color: var(--ink-soft);
  max-width: 44ch;
  line-height: 1.65;
  margin: 0 0 var(--space-md);
}

.home-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.home-hero-note {
  font-size: 0.875rem;
  color: var(--ink-muted);
  margin: 0;
  max-width: 40ch;
}

.home-hero-note strong {
  color: var(--uk-blue-deep);
}

.home-hero-media {
  position: relative;
  justify-self: end;
  width: min(100%, 32rem);
  margin: 0;
}

.home-hero-header-img {
  width: 100%;
  height: auto;
  max-height: min(82vh, 42rem);
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 1.25rem 2.5rem oklch(18% 0.06 255 / 0.18));
}

.home-hero-ua-svg {
  width: 100%;
  height: auto;
  max-height: min(82vh, 42rem);
  display: block;
  filter: drop-shadow(0 1.25rem 2.5rem oklch(18% 0.06 255 / 0.18));
}

.home-hero-ua-photo {
  transform: translateZ(0);
}

.home-hero-ua-edge {
  opacity: 0.92;
  pointer-events: none;
}

@media (min-width: 961px) {
  .home-hero-grid {
    grid-template-columns: minmax(0, 34rem) minmax(0, 32rem);
    justify-content: center;
    column-gap: clamp(2rem, 3.5vw, 3.25rem);
  }

  .home-hero-copy {
    max-width: 34rem;
    justify-self: end;
  }

  .home-hero-media {
    justify-self: start;
    width: min(100%, 32rem);
  }
}

@media (max-width: 900px) {
  .home-hero-grid {
    grid-template-columns: 1fr;
  }

  .home-hero-copy {
    max-width: none;
    justify-self: stretch;
  }

  .home-hero-media {
    justify-self: center;
    width: min(100%, 28rem);
    order: -1;
  }

  .home-hero-header-img {
    max-height: min(56vh, 28rem);
  }

  .home-hero-ua-svg {
    max-height: min(56vh, 28rem);
  }
}

@media (min-width: 901px) and (max-width: 1200px) {
  .home-hero-grid {
    gap: clamp(1.25rem, 3vw, 2.5rem);
  }
}

/* Pillars */
.home-pillars {
  background: var(--cream);
  display: flex;
  flex-direction: column;
  gap: var(--section-pad-y-tight);
}

.home-pillar-grid {
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1.15rem, 2.8vw, 1.75rem);
  align-items: stretch;
}

.home-pillar {
  display: flex;
  flex-direction: column;
  text-align: left;
  background: color-mix(in oklch, oklch(99% 0.01 95) 88%, oklch(100% 0 0));
  border: 1px solid color-mix(in oklch, var(--line) 85%, transparent);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}

.home-pillar:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-elevated);
}

.home-pillar-media {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
}

.home-pillar-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 45%,
    color-mix(in oklch, var(--uk-blue-deep) 12%, transparent) 100%
  );
  opacity: 0.35;
  pointer-events: none;
}

.home-pillar-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transform: scale(1.001);
  transition: transform 0.5s var(--ease-out);
}

.home-pillar:hover .home-pillar-media img {
  transform: scale(1.04);
}

.home-pillar-body {
  padding: clamp(1.1rem, 2.5vw, 1.45rem) clamp(1.05rem, 2.5vw, 1.35rem) clamp(1.2rem, 2.5vw, 1.5rem);
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}

.home-pillar-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 0.35vw + 0.98rem, 1.2rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  margin: 0 0 0.5rem;
  line-height: 1.25;
  letter-spacing: -0.02em;
  text-wrap: balance;
}

.home-pillar-body p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--ink-soft);
  line-height: 1.58;
}

@media (max-width: 1023px) {
  .home-pillar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .home-pillar-grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-pillar:hover .home-pillar-media img {
    transform: none;
  }
}

/* Split band (always used with .section — do not set horizontal padding here; .section already applies --pad-inline) */
.home-split {
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: clamp(1.5rem, 4vw, 3rem);
  row-gap: clamp(1.25rem, 3vw, 2rem);
  /* Top-align copy with photos — centering in a tall min-height column left huge dead space above the headline */
  align-items: start;
}

/* Photos are position:absolute — they don't give this box height. Old min-height forced a tall empty strip when media didn't paint. Height follows column width via aspect-ratio. */
.home-split-visual {
  position: relative;
  width: 100%;
  min-height: 0;
  aspect-ratio: 1;
}

.home-split-photo {
  position: absolute;
  border-radius: 50%;
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  border: 4px solid oklch(100% 0 0);
}

.home-split-photo--a {
  width: 72%;
  aspect-ratio: 1;
  left: 0;
  top: 0;
  z-index: 1;
}

.home-split-photo--b {
  width: 48%;
  aspect-ratio: 1;
  right: 0;
  bottom: 0;
  z-index: 2;
}

.home-split-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-split-dots {
  position: absolute;
  inset: 10% -5% auto auto;
  width: 40%;
  height: 50%;
  background-image: radial-gradient(color-mix(in oklch, var(--uk-blue) 18%, transparent) 1px, transparent 1px);
  background-size: 10px 10px;
  opacity: 0.6;
  z-index: 0;
  border-radius: var(--radius-lg);
}

.home-split-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 38rem;
}

.home-split-copy .home-h2 {
  max-width: 18ch;
  margin-bottom: 0.65rem;
}

.home-split-copy > p:not(.home-section-kicker) {
  margin: 0;
  font-size: clamp(1rem, 0.35vw + 0.92rem, 1.08rem);
  line-height: 1.62;
  color: var(--ink-soft);
}

.home-split-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
}

@media (max-width: 900px) {
  .home-split {
    grid-template-columns: 1fr;
  }

  .home-split-visual {
    max-width: min(20rem, 88vw);
    max-height: none;
    margin: 0 auto;
  }
}

/* Programs strip: card stack + category rails + explicit CTAs */
.home-campaigns {
  position: relative;
  background: linear-gradient(180deg, oklch(98.5% 0.012 95) 0%, var(--cream) 55%, color-mix(in oklch, var(--uk-blue) 4%, var(--cream)) 100%);
  overflow: hidden;
}

.home-campaigns::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in oklch, var(--uk-gold-bright) 45%, transparent),
    transparent
  );
  opacity: 0.85;
  pointer-events: none;
}

.home-campaigns__wrap {
  max-width: var(--content-max);
  margin: 0 auto;
}

.home-campaigns__header {
  max-width: 40rem;
  margin-bottom: var(--section-pad-y-tight);
  text-align: left;
}

.home-campaigns__header .home-section-kicker {
  margin-bottom: 0.5rem;
}

.home-campaigns__title {
  margin-bottom: 0.65rem;
}

.home-campaigns__lead {
  margin: 0;
  font-size: clamp(1rem, 0.35vw + 0.92rem, 1.12rem);
  line-height: 1.62;
  color: var(--ink-soft);
}

.home-campaign-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: stretch;
}

.home-campaign-card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: 1.15rem;
  overflow: hidden;
  background: oklch(100% 0 0);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 10%, var(--line));
  box-shadow:
    0 2px 3px color-mix(in oklch, var(--uk-blue-deep) 6%, transparent),
    0 14px 36px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent);
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}

.home-campaign-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 4px 6px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent),
    0 22px 48px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
}

.home-campaign-card__media {
  position: relative;
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
}

.home-campaign-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.55s var(--ease-out);
}

.home-campaign-card:hover .home-campaign-card__media img {
  transform: scale(1.045);
}

.home-campaign-card__cat {
  position: absolute;
  top: 0.65rem;
  left: 0.65rem;
  z-index: 2;
  padding: 0.28rem 0.65rem;
  font-family: var(--font-ui);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: oklch(98% 0.01 95);
  background: color-mix(in oklch, var(--uk-blue-deep) 78%, transparent);
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-gold-bright) 35%, transparent);
  box-shadow: 0 2px 10px oklch(8% 0.05 270 / 0.35);
}

.home-campaign-card__shine {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(
    145deg,
    transparent 40%,
    color-mix(in oklch, var(--uk-gold-bright) 12%, transparent) 100%
  );
  opacity: 0.65;
  mix-blend-mode: soft-light;
}

.home-campaign-card__body {
  padding: var(--space-md);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.home-campaign-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.home-campaign-card__status {
  font-family: var(--font-display);
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--uk-blue-deep);
}

.home-campaign-card__goal {
  font-weight: 600;
  color: var(--ink-muted);
  letter-spacing: 0.04em;
  text-transform: none;
  font-size: 0.78rem;
}

.home-campaign-bar {
  height: 5px;
  border-radius: 999px;
  background: color-mix(in oklch, var(--uk-blue) 10%, var(--cream));
  overflow: hidden;
}

.home-campaign-bar span {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--uk-blue-deep), var(--uk-gold-bright));
  box-shadow: 0 0 12px color-mix(in oklch, var(--uk-gold-bright) 40%, transparent);
}

.home-campaign-title {
  font-family: var(--font-display);
  font-size: clamp(1.08rem, 0.5vw + 1rem, 1.28rem);
  margin: 0.15rem 0 0;
  line-height: 1.25;
  letter-spacing: -0.02em;
}

.home-campaign-title a {
  color: var(--uk-blue-deep);
  text-decoration: none;
  transition: color 0.2s;
}

.home-campaign-title a:hover {
  color: var(--uk-blue);
}

.home-campaign-card__body > p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--ink-soft);
  flex: 1;
}

.home-campaign-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.35rem;
  font-family: var(--font-ui);
  font-size: 0.78rem;
  font-weight: 750;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--uk-blue-deep);
  border-bottom: 2px solid color-mix(in oklch, var(--uk-gold-bright) 70%, var(--uk-blue));
  padding-bottom: 0.1rem;
  align-self: flex-start;
  transition: color 0.2s, border-color 0.2s, gap 0.2s;
}

.home-campaign-card__cta:hover {
  color: var(--uk-blue);
  border-bottom-color: var(--uk-gold-bright);
  gap: 0.5rem;
}

.home-campaign-card__cta-ico {
  font-size: 1.05em;
  transition: transform 0.25s var(--ease-out);
}

.home-campaign-card__cta:hover .home-campaign-card__cta-ico {
  transform: translateX(3px);
}

@media (max-width: 960px) {
  .home-campaign-grid {
    grid-template-columns: 1fr;
    max-width: 22rem;
    margin: 0 auto;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-campaign-card,
  .home-campaign-card__media img,
  .home-campaign-card__cta-ico {
    transition: none !important;
  }

  .home-campaign-card:hover {
    transform: none;
  }

  .home-campaign-card:hover .home-campaign-card__media img {
    transform: none;
  }
}

/* Impact strip (.section supplies padding; do not duplicate) */
.home-impact {
  background: linear-gradient(
    145deg,
    oklch(22% 0.09 255) 0%,
    var(--uk-blue-deep) 40%,
    oklch(18% 0.08 255) 100%
  );
  color: oklch(98% 0.01 95);
}

.home-impact-inner {
  box-sizing: border-box;
  max-width: var(--content-max);
  margin: 0 auto;
  padding-inline: var(--pad-inline);
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(1.5rem, 4vw, 2.75rem);
  align-items: center;
}

.home-impact .home-h2 {
  color: oklch(99% 0.01 95);
}

.home-impact .home-sub {
  color: color-mix(in oklch, oklch(96% 0.02 95) 85%, transparent);
}

.home-impact-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}

.home-impact-num {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 2.5vw + 1rem, 2.5rem);
  font-weight: 600;
  color: var(--uk-gold-bright);
  line-height: 1.1;
}

.home-impact-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in oklch, oklch(96% 0.02 95) 75%, transparent);
  margin-top: 0.35rem;
}

.home-impact-map svg {
  width: 100%;
  height: auto;
  max-height: 14rem;
  filter: drop-shadow(0 0.5rem 1.5rem oklch(5% 0.03 255 / 0.4));
}

@media (max-width: 800px) {
  .home-impact-inner {
    grid-template-columns: 1fr;
  }

  .home-impact-stats {
    grid-template-columns: 1fr;
  }

  .home-impact-map {
    order: -1;
    max-width: 16rem;
    margin: 0 auto;
  }
}

/* -- Home donate card (editorial “atelier” frame + widget shell) -- */
.home-donate--atelier {
  position: relative;
  overflow: hidden;
}

.home-donate__aurora {
  position: absolute;
  inset: -25% -15% auto;
  height: min(55vh, 28rem);
  pointer-events: none;
  z-index: 0;
  opacity: 0.85;
  background:
    radial-gradient(ellipse 65% 55% at 50% 0%, color-mix(in oklch, var(--uk-gold-bright) 18%, transparent) 0%, transparent 58%),
    radial-gradient(ellipse 45% 50% at 15% 35%, color-mix(in oklch, var(--uk-blue) 14%, transparent) 0%, transparent 55%),
    radial-gradient(ellipse 40% 45% at 88% 40%, color-mix(in oklch, var(--uk-gold) 12%, transparent) 0%, transparent 50%);
}

@media (prefers-reduced-motion: no-preference) {
  .home-donate__aurora {
    animation: homeDonateAurora 20s ease-in-out infinite alternate;
  }
}

@keyframes homeDonateAurora {
  from {
    opacity: 0.78;
    transform: translate3d(0, 0, 0) scale(1);
  }
  to {
    opacity: 0.95;
    transform: translate3d(0, 8px, 0) scale(1.02);
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-donate__aurora {
    animation: none;
    opacity: 0.88;
  }
}

.home-donate-inner {
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  max-width: 40rem;
  margin: 0 auto;
  padding: 0 var(--pad-inline);
}

.home-donate-card {
  position: relative;
  border-radius: 1.35rem;
  padding: 1px;
  background: linear-gradient(
    140deg,
    color-mix(in oklch, var(--uk-gold-bright) 55%, transparent) 0%,
    color-mix(in oklch, var(--uk-blue-deep) 35%, transparent) 38%,
    color-mix(in oklch, var(--uk-gold) 40%, transparent) 100%
  );
  box-shadow:
    0 0 0 1px color-mix(in oklch, var(--uk-blue-deep) 14%, transparent),
    0 1.25rem 3rem oklch(16% 0.05 255 / 0.09),
    0 0.35rem 0 color-mix(in oklch, var(--uk-blue-deep) 8%, transparent);
}

.home-donate-card__shine {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    118deg,
    color-mix(in oklch, oklch(100% 0 0) 55%, transparent) 0%,
    transparent 45%,
    color-mix(in oklch, var(--uk-gold-bright) 14%, transparent) 100%
  );
  opacity: 0.55;
  pointer-events: none;
}

.home-donate-card__border {
  position: absolute;
  inset: 1px;
  border-radius: calc(1.35rem - 1px);
  box-shadow: inset 0 0 0 1px color-mix(in oklch, oklch(100% 0 0) 55%, transparent);
  pointer-events: none;
}

.home-donate-card__body {
  position: relative;
  padding: clamp(1.85rem, 4.5vw, 2.85rem) clamp(1.4rem, 3.5vw, 2.35rem) clamp(1.6rem, 3vw, 2.1rem);
  background: linear-gradient(
    178deg,
    oklch(100% 0 0) 0%,
    color-mix(in oklch, var(--cream) 55%, oklch(99.5% 0.008 95)) 45%,
    color-mix(in oklch, var(--uk-gold) 9%, var(--cream)) 100%
  );
  border-radius: calc(1.35rem - 1px);
}

.home-donate-card__header {
  text-align: center;
}

.home-donate-card__eyebrow {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
  margin: 0 0 0.9rem;
}

.home-donate-card__title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2rem, 4.2vw + 0.85rem, 2.95rem);
  font-weight: 600;
  letter-spacing: -0.035em;
  line-height: 1.06;
  color: var(--uk-blue-deep);
  margin: 0 auto 1rem;
  max-width: 18ch;
  text-wrap: balance;
}

.home-donate-card__lead {
  font-size: clamp(1.02rem, 0.55vw + 0.94rem, 1.18rem);
  line-height: 1.68;
  color: var(--ink-soft);
  margin: 0 auto 1.15rem;
  max-width: 38ch;
}

.home-donate-card__ornament {
  display: flex;
  justify-content: center;
  margin: 0 0 1.4rem;
}

.home-donate-card__ornament svg {
  display: block;
  max-width: 100%;
  height: auto;
}

.home-donate-card__trust {
  list-style: none;
  margin: 0 0 1.65rem;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.45rem 0.65rem;
}

.home-donate-card__trust li {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 650;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--uk-blue-deep);
  padding: 0.5rem 0.95rem;
  background: color-mix(in oklch, var(--uk-blue) 5%, oklch(100% 0 0));
  border: 1px solid color-mix(in oklch, var(--line) 70%, transparent);
  border-radius: 999px;
}

.home-donate-card__trust-ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  font-size: 0.55rem;
  font-weight: 800;
  line-height: 1;
  color: var(--uk-blue-deep);
  background: linear-gradient(145deg, var(--uk-gold-bright), color-mix(in oklch, var(--uk-gold) 85%, var(--uk-gold-muted)));
  box-shadow: 0 0.1rem 0 color-mix(in oklch, var(--uk-blue-deep) 22%, transparent);
}

.home-donate-card__widget-label {
  font-family: var(--font-ui);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0 0 0.7rem;
  text-align: center;
}

.home-donate-card__widget-surface {
  position: relative;
  padding: clamp(0.9rem, 2.2vw, 1.2rem);
  border-radius: var(--radius-lg);
  background: oklch(100% 0 0);
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 12%, var(--line));
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, oklch(100% 0 0) 90%, transparent),
    0 0.5rem 1.75rem oklch(17% 0.05 255 / 0.07);
}

.home-donate-card__widget-surface givebutter-widget,
.home-donate-card__widget-surface givebutter-giving-form {
  display: block;
  width: 100%;
  min-height: 22rem;
  margin: 0;
}

.home-donate-card__fallback {
  margin: 0.75rem 0 0;
  font-size: 0.82rem;
  text-align: center;
  color: var(--ink-muted);
}

.home-donate-card__fallback-link {
  color: var(--uk-blue);
  font-weight: 600;
}

.home-donate-card__fallback-link:hover {
  color: var(--uk-blue-deep);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}

/* Instagram: reels-style horizontal rail (Stories / short-form patterns) */
.home-ig-reels__head {
  max-width: var(--content-max);
  margin: 0 auto var(--section-pad-y-tight);
  padding: 0;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: var(--space-md);
}

.home-ig-reels__intro {
  flex: 0 1 auto;
  width: 100%;
  max-width: 38rem;
  margin-inline: auto;
}

.home-ig-reels__badge {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  margin-bottom: 0.75rem;
}

.home-ig-reels__ig {
  flex-shrink: 0;
  border-radius: 8px;
  box-shadow: 0 4px 14px color-mix(in oklch, var(--uk-blue-deep) 18%, transparent);
}

.home-ig-reels__pill {
  font-family: var(--font-ui);
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in oklch, white 92%, var(--cream)) 0%,
    color-mix(in oklch, var(--uk-blue) 5%, var(--cream)) 100%
  );
  box-shadow: 0 1px 0 color-mix(in oklch, white 80%, transparent) inset;
}

.home-ig-reels__title {
  margin-top: 0;
}

.home-ig-reels__lede {
  margin: 0.5rem auto 0;
  font-size: clamp(0.98rem, 0.4vw + 0.9rem, 1.08rem);
  line-height: 1.58;
  color: var(--ink-soft);
  max-width: 44ch;
}

.home-ig-reels__cta {
  flex-shrink: 0;
  align-self: center;
}

.home-ig-reels__dock {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  margin-top: 0;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  box-sizing: border-box;
  padding: var(--section-pad-y-tight) 0;
  background:
    radial-gradient(ellipse 90% 55% at 50% -15%, color-mix(in oklch, var(--uk-gold-bright) 16%, transparent), transparent 58%),
    linear-gradient(168deg, oklch(21% 0.052 262) 0%, oklch(12% 0.058 272) 48%, oklch(9% 0.04 275) 100%);
  border-top: 1px solid color-mix(in oklch, var(--uk-gold) 24%, transparent);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue-deep) 45%, transparent);
}

.home-ig-reels__viewport {
  position: relative;
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: max(var(--pad-inline), env(safe-area-inset-left, 0px));
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in oklch, var(--uk-gold-bright) 45%, transparent) transparent;
  box-shadow:
    inset 52px 0 40px -30px oklch(16% 0.055 268),
    inset -52px 0 40px -30px oklch(16% 0.055 268);
}

.home-ig-reels__viewport:focus-visible {
  outline: 2px solid var(--uk-gold-bright);
  outline-offset: 2px;
}

.home-ig-reels__viewport::-webkit-scrollbar {
  height: 6px;
}

.home-ig-reels__viewport::-webkit-scrollbar-thumb {
  background: color-mix(in oklch, var(--uk-gold-bright) 50%, transparent);
  border-radius: 999px;
}

.home-ig-reels__track {
  list-style: none;
  margin: 0;
  padding: 0.35rem max(var(--pad-inline), env(safe-area-inset-right, 0px)) 0.85rem
    max(var(--pad-inline), env(safe-area-inset-left, 0px));
  display: flex;
  gap: clamp(0.8rem, 2.2vw, 1.2rem);
  align-items: stretch;
  /* Center the card group when it’s narrower than the viewport; stay scroll-safe when it overflows */
  justify-content: center;
  justify-content: safe center;
}

.home-ig-reels__item {
  flex: 0 0 auto;
  scroll-snap-align: center;
  width: clamp(9.25rem, 26vw, 13.5rem);
}

.home-ig-reels__card {
  display: block;
  position: relative;
  text-decoration: none;
  padding: 3px;
  border-radius: 1.35rem;
  /* Ukrainian flag colors (blue + gold), not Instagram’s brand gradient */
  background: conic-gradient(
    from 0deg at 50% 50%,
    var(--uk-gold-bright) 0deg,
    var(--uk-gold) 90deg,
    var(--uk-blue) 180deg,
    var(--uk-blue-deep) 270deg,
    var(--uk-gold-bright) 360deg
  );
  box-shadow:
    0 12px 40px color-mix(in oklch, var(--uk-blue-deep) 45%, oklch(8% 0.06 270)),
    0 0 0 1px color-mix(in oklch, var(--uk-blue) 28%, oklch(22% 0.04 265 / 0.35)) inset;
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}

.home-ig-reels__card:hover {
  transform: translateY(-3px);
  box-shadow:
    0 20px 48px color-mix(in oklch, var(--uk-blue-deep) 52%, oklch(8% 0.06 270)),
    0 0 0 1px color-mix(in oklch, var(--uk-gold) 35%, oklch(30% 0.05 265 / 0.4)) inset;
}

.home-ig-reels__card:focus-visible {
  outline: 3px solid var(--uk-gold-bright);
  outline-offset: 4px;
}

.home-ig-reels__media {
  display: block;
  position: relative;
  border-radius: calc(1.35rem - 3px);
  overflow: hidden;
  aspect-ratio: 9 / 16;
  background: oklch(14% 0.05 265);
}

.home-ig-reels__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.001);
  transition: transform 0.5s var(--ease-out);
}

.home-ig-reels__veil {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 28%,
    color-mix(in oklch, oklch(12% 0.07 270) 55%, transparent) 100%
  );
  pointer-events: none;
}

.home-ig-reels__play {
  position: absolute;
  left: 50%;
  top: 40%;
  transform: translate(-50%, -50%);
  opacity: 0.9;
  filter: drop-shadow(0 6px 16px oklch(8% 0.06 270 / 0.55));
  transition: opacity 0.25s, transform 0.4s var(--ease-out);
  pointer-events: none;
}

.home-ig-reels__card:hover .home-ig-reels__play,
.home-ig-reels__card:focus-visible .home-ig-reels__play {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.05);
}

.home-ig-reels__card:hover .home-ig-reels__media img,
.home-ig-reels__card:focus-visible .home-ig-reels__media img {
  transform: scale(1.07);
}

.home-ig-reels__label {
  position: absolute;
  left: 0.55rem;
  right: 0.55rem;
  bottom: 0.5rem;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: oklch(97% 0.01 95);
  text-shadow: 0 1px 3px oklch(8% 0.05 270 / 0.9);
  pointer-events: none;
  line-height: 1.2;
}

.home-ig-reels__hint {
  margin: 1rem 0 0;
  padding: 0 var(--pad-inline);
  text-align: center;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: oklch(70% 0.04 250);
}

.home-ig-reels__hint-ico {
  opacity: 0.65;
  margin-right: 0.4rem;
}

@media (max-width: 640px) {
  .home-ig-reels__item {
    width: clamp(8.5rem, 42vw, 11rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-ig-reels__card,
  .home-ig-reels__media img,
  .home-ig-reels__play {
    transition: none !important;
  }

  .home-ig-reels__card:hover {
    transform: none;
  }

  .home-ig-reels__card:hover .home-ig-reels__media img,
  .home-ig-reels__card:focus-visible .home-ig-reels__media img {
    transform: none;
  }

  .home-ig-reels__card:hover .home-ig-reels__play,
  .home-ig-reels__card:focus-visible .home-ig-reels__play {
    transform: translate(-50%, -50%);
  }
}

/* Blog strip */
.home-blog .home-section-head--split {
  align-items: flex-end;
}

.home-blog-all {
  font-weight: 650;
  font-size: 0.9375rem;
}

.home-blog-grid {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.15rem, 3vw, 1.75rem);
}

.home-blog-card {
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: oklch(100% 0 0);
  display: flex;
  flex-direction: column;
}

.home-blog-card__media {
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 6%, var(--cream));
}

.home-blog-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-blog-card__body {
  padding: var(--space-md);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.home-blog-card h3 {
  font-family: var(--font-display);
  font-size: 1.15rem;
  margin: 0 0 0.5rem;
}

.home-blog-card h3 a {
  text-decoration: none;
  color: var(--uk-blue-deep);
}

.home-blog-card h3 a:hover {
  color: var(--uk-blue-mid);
}

.home-blog-card .article-meta {
  margin-top: auto;
}

@media (max-width: 800px) {
  .home-blog-grid {
    grid-template-columns: 1fr;
  }
}

.home-events-title {
  text-align: center;
  margin-bottom: var(--section-pad-y-tight);
}

.home-events-row {
  max-width: 56rem;
  margin: 0 auto;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.15rem, 3vw, 1.75rem);
}

.home-event-pill {
  text-align: center;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: oklch(100% 0 0);
  display: flex;
  flex-direction: column;
}

.home-event-pill__media {
  display: block;
  aspect-ratio: 21 / 9;
  overflow: hidden;
  background: color-mix(in oklch, var(--uk-blue) 6%, var(--cream));
}

.home-event-pill__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-event-pill__body {
  padding: var(--space-md);
  text-align: center;
  background: linear-gradient(180deg, oklch(100% 0 0) 0%, color-mix(in oklch, var(--uk-blue) 4%, var(--cream)) 100%);
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.home-event-pill h3 {
  font-family: var(--font-display);
  margin: 0 0 0.35rem;
  color: var(--uk-blue-deep);
}

.home-event-pill p {
  margin: 0 0 var(--space-sm);
  color: var(--ink-soft);
  font-size: 0.9375rem;
}

@media (max-width: 640px) {
  .home-events-row {
    grid-template-columns: 1fr;
  }
}

/* -- Summit event page -- */
.summit-page {
  overflow-x: hidden;
  padding-bottom: 0;
}

.summit-hero {
  position: relative;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  padding: clamp(2.5rem, 6vw, 5rem) var(--pad-inline) clamp(3rem, 7vw, 5.5rem);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  min-height: min(88vh, 52rem);
}

.summit-hero__aurora {
  position: absolute;
  inset: -20% -10% auto -10%;
  height: 70%;
  background: radial-gradient(
    ellipse 80% 60% at 50% 0%,
    color-mix(in oklch, var(--uk-blue) 22%, transparent),
    transparent 70%
  );
  pointer-events: none;
  z-index: 0;
}

.summit-hero__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(0.5px);
  pointer-events: none;
  z-index: 0;
  opacity: 0.55;
  animation: summitFloat 14s ease-in-out infinite;
}

.summit-hero__orb--1 {
  width: min(42vw, 18rem);
  height: min(42vw, 18rem);
  left: 5%;
  top: 18%;
  background: radial-gradient(circle at 30% 30%, oklch(88% 0.16 95 / 0.5), transparent 65%);
  animation-delay: 0s;
}

.summit-hero__orb--2 {
  width: min(36vw, 14rem);
  height: min(36vw, 14rem);
  right: 8%;
  top: 35%;
  background: radial-gradient(circle at 50% 50%, oklch(45% 0.14 255 / 0.35), transparent 60%);
  animation-delay: -4s;
}

.summit-hero__orb--3 {
  width: min(28vw, 10rem);
  height: min(28vw, 10rem);
  left: 40%;
  bottom: 12%;
  background: radial-gradient(circle at 50% 50%, oklch(72% 0.12 92 / 0.4), transparent 55%);
  animation-delay: -7s;
}

@keyframes summitFloat {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(12px, -18px) scale(1.04);
  }
}

.summit-hero__inner {
  position: relative;
  z-index: 1;
}

.summit-hero__eyebrow {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
  margin: 0 0 0.75rem;
}

.summit-hero__title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2.4rem, 4.5vw + 1rem, 4rem);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--uk-blue-deep);
  margin: 0 0 0.75rem;
  text-wrap: balance;
}

.summit-hero__tag {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.35rem, 2vw + 0.75rem, 2rem);
  color: color-mix(in oklch, var(--uk-blue-deep) 88%, var(--ink));
  margin: 0 0 var(--space-md);
}

.summit-hero__lead {
  font-size: clamp(1.05rem, 0.6vw + 0.95rem, 1.2rem);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 46ch;
  margin: 0 0 var(--space-md);
}

.summit-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: var(--space-md);
}

.summit-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  border: 1px solid var(--line);
  color: var(--uk-blue-deep);
}

.summit-pill--gold {
  background: linear-gradient(135deg, color-mix(in oklch, var(--uk-gold-bright) 35%, var(--cream)), var(--cream));
  border-color: color-mix(in oklch, var(--uk-gold) 40%, transparent);
}

.summit-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.summit-hero__cta {
  min-height: 48px;
}

.summit-hero__visual {
  position: relative;
  z-index: 1;
  justify-self: center;
  width: min(100%, 28rem);
}

.summit-hero__frame {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  border: 1px solid var(--line-strong);
  transform: rotate(-1.5deg);
  animation: summitFrame 10s ease-in-out infinite;
}

.summit-hero__frame img {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: middle;
}

@keyframes summitFrame {
  0%,
  100% {
    transform: rotate(-1.5deg) translateY(0);
  }
  50% {
    transform: rotate(-1deg) translateY(-6px);
  }
}

.summit-hero__ring {
  position: absolute;
  right: -8%;
  top: 50%;
  width: 120%;
  height: auto;
  transform: translateY(-50%);
  pointer-events: none;
  animation: summitSpin 48s linear infinite;
}

@keyframes summitSpin {
  to {
    transform: translateY(-50%) rotate(360deg);
  }
}

.summit-marquee {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--pad-inline);
  overflow: hidden;
  border-block: 1px solid var(--line);
  background: linear-gradient(90deg, var(--cream) 0%, color-mix(in oklch, var(--uk-blue) 5%, var(--cream)) 50%, var(--cream) 100%);
}

.summit-marquee__track {
  display: flex;
  gap: 3rem;
  width: max-content;
  padding: 0.85rem 0;
  font-family: var(--font-ui);
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
  animation: summitMarquee 32s linear infinite;
}

@keyframes summitMarquee {
  to {
    transform: translateX(-50%);
  }
}

.summit-stats {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--section-pad-y-tight) var(--pad-inline) var(--space-lg);
}

.summit-stats__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-md);
}

.summit-stat {
  text-align: center;
  padding: var(--space-md) var(--space-sm);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: oklch(100% 0 0);
  box-shadow: var(--shadow-soft);
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}

.summit-stat:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-elevated);
}

.summit-stat__num {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(2rem, 3vw + 1rem, 3rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  line-height: 1.1;
}

.summit-stat__label {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: var(--ink-soft);
  line-height: 1.45;
}

.summit-h2 {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.5vw + 0.75rem, 2.75rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  margin: 0 0 var(--space-md);
  letter-spacing: -0.02em;
}

.summit-lead {
  font-size: 1.1rem;
  color: var(--ink-soft);
  line-height: 1.65;
  margin: 0 0 var(--space-md);
}

.summit-split {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 0 var(--pad-inline) var(--section-pad-y-tight);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.75rem, 3.5vw, 2.75rem);
  align-items: center;
}

.summit-split__media {
  position: relative;
}

.summit-split__media img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-elevated);
  display: block;
}

.summit-split__accent {
  position: absolute;
  inset: 12% -8% -8% 12%;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, color-mix(in oklch, var(--uk-gold-bright) 25%, transparent), transparent);
  z-index: -1;
}

.summit-split__copy {
  min-width: 0;
}

.summit-split__copy .summit-h2 {
  margin-top: 0;
}

.summit-split__copy p {
  color: var(--ink-soft);
  line-height: 1.65;
  margin: 0 0 var(--space-sm);
}

.summit-split__copy p:last-of-type {
  margin-bottom: 0;
}

.summit-checks {
  margin: var(--space-md) 0 0;
  padding-left: 1.15rem;
  color: var(--ink-soft);
  line-height: 1.7;
}

.summit-checks li {
  margin-bottom: 0.35rem;
}

.summit-checks li:last-child {
  margin-bottom: 0;
}

.summit-gallery {
  padding: 0 var(--pad-inline) var(--section-pad-y);
  background: linear-gradient(180deg, var(--cream) 0%, color-mix(in oklch, var(--uk-blue) 4%, var(--cream)) 100%);
}

.summit-gallery__head {
  max-width: 720px;
  margin: 0 auto var(--space-md);
  text-align: center;
}

.summit-gallery__head .summit-h2 {
  margin-bottom: var(--space-xs);
}

.summit-gallery__sub {
  margin: 0;
  color: var(--ink-soft);
  font-size: 1.05rem;
  line-height: 1.55;
}

.summit-bento {
  max-width: var(--content-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-auto-rows: minmax(10rem, auto);
  gap: var(--space-md);
}

.summit-bento__item {
  margin: 0;
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  background: var(--cream);
}

.summit-bento__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s var(--ease-out);
}

.summit-bento__item:hover img {
  transform: scale(1.04);
}

.summit-bento__item figcaption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.65rem 0.85rem;
  font-size: 0.8125rem;
  color: oklch(99% 0.01 95);
  background: linear-gradient(transparent, oklch(12% 0.05 255 / 0.88));
  line-height: 1.4;
}

.summit-bento__item--tall {
  grid-column: span 2;
  grid-row: span 2;
}

.summit-bento__item:not(.summit-bento__item--tall):not(.summit-bento__item--wide) {
  grid-column: span 2;
  min-height: 12rem;
}

.summit-bento__item--wide {
  grid-column: span 4;
  min-height: 14rem;
}

.summit-timeline {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--pad-inline) var(--space-md);
}

.summit-timeline__title {
  text-align: center;
  margin-top: 0;
  margin-bottom: var(--space-md);
}

.summit-timeline__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.summit-timeline__step {
  display: grid;
  grid-template-columns: minmax(3.75rem, max-content) minmax(0, 1fr);
  column-gap: var(--space-md);
  row-gap: var(--space-xs);
  align-items: start;
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: oklch(100% 0 0);
  box-shadow: var(--shadow-soft);
}

.summit-timeline__step--future {
  border-color: color-mix(in oklch, var(--uk-gold) 45%, var(--line));
  background: linear-gradient(135deg, oklch(100% 0 0), color-mix(in oklch, var(--uk-gold-bright) 12%, var(--cream)));
}

.summit-timeline__year {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.4vw, 1.55rem);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--uk-blue-deep);
  white-space: nowrap;
  padding-top: 0.12em;
}

.summit-timeline__step p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.6;
  min-width: 0;
}

.summit-notify__card {
  max-width: 36rem;
  margin: 0 auto;
  padding: clamp(1.35rem, 3.5vw, 1.85rem);
  text-align: center;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line-strong);
  background: color-mix(in oklch, var(--cream) 92%, oklch(100% 0 0));
  box-shadow: var(--shadow-elevated);
  backdrop-filter: blur(8px);
}

.summit-notify__card .summit-h2 {
  font-size: clamp(1.45rem, 2vw + 0.85rem, 2.1rem);
  margin-bottom: var(--space-sm);
}

.summit-notify__intro {
  margin: 0 auto var(--space-md);
  max-width: 44ch;
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--ink-soft);
}

.summit-notify__form {
  max-width: 32rem;
  margin: 0 auto;
  text-align: left;
  display: grid;
  gap: var(--space-sm);
  align-items: end;
}

.summit-notify__form > div {
  min-width: 0;
}

@media (min-width: 520px) {
  .summit-notify__form {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-sm) var(--space-md);
  }

  .summit-notify__form .btn {
    min-height: 48px;
    padding-inline: 1.25rem;
  }
}

@media (max-width: 519px) {
  .summit-notify__form .btn {
    width: 100%;
    justify-content: center;
  }
}

#summit-notify {
  scroll-margin-top: 2rem;
}

/* Notify band: clear separation from timeline + room before footer (main has no bottom padding) */
.summit-page #summit-notify.section {
  padding-top: var(--section-pad-y-tight);
  padding-bottom: var(--section-pad-y);
}

.summit-page #summit-notify .summit-notify__intro {
  margin-bottom: var(--space-md);
}

@media (max-width: 380px) {
  .summit-timeline__step {
    grid-template-columns: 1fr;
    row-gap: var(--space-sm);
  }

  .summit-timeline__year {
    padding-top: 0;
  }
}

@media (min-width: 961px) {
  .summit-hero {
    grid-template-columns: minmax(0, 34rem) minmax(0, 26rem);
    justify-content: center;
    column-gap: clamp(2rem, 3.5vw, 3.25rem);
  }

  .summit-hero__inner {
    max-width: 34rem;
    justify-self: end;
  }

  .summit-hero__visual {
    justify-self: start;
  }
}

@media (max-width: 960px) {
  .summit-hero {
    grid-template-columns: 1fr;
    min-height: unset;
    max-width: 100%;
  }

  .summit-hero__inner {
    max-width: none;
    justify-self: stretch;
  }

  .summit-hero__visual {
    justify-self: center;
    order: -1;
  }

  .summit-stats__grid {
    grid-template-columns: 1fr;
  }

  .summit-split {
    grid-template-columns: 1fr;
  }

  .summit-bento {
    grid-template-columns: 1fr 1fr;
  }

  .summit-bento__item--tall {
    grid-column: span 2;
    grid-row: span 1;
    min-height: 16rem;
  }

  .summit-bento__item:not(.summit-bento__item--tall):not(.summit-bento__item--wide) {
    grid-column: span 1;
  }

  .summit-bento__item--wide {
    grid-column: span 2;
  }
}

@media (max-width: 520px) {
  .summit-bento {
    grid-template-columns: 1fr;
  }

  .summit-bento__item--tall,
  .summit-bento__item--wide,
  .summit-bento__item:not(.summit-bento__item--tall):not(.summit-bento__item--wide) {
    grid-column: span 1;
    min-height: 14rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .summit-hero__orb,
  .summit-hero__frame,
  .summit-hero__ring,
  .summit-marquee__track {
    animation: none !important;
  }

  .summit-hero__frame {
    transform: rotate(-1.5deg);
  }
}

/* -- Donate page -- */
/* Scoped palette + rhythm: all sections pull from the same blue/gold/cream system. */
.donate-page {
  --donate-line: color-mix(in oklch, var(--uk-blue) 12%, transparent);
  --donate-line-strong: color-mix(in oklch, var(--uk-blue-deep) 16%, transparent);
  --donate-wash-hero: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  --donate-wash-soft: color-mix(in oklch, var(--uk-blue) 6%, var(--cream));
  --donate-wash-deep: color-mix(in oklch, var(--uk-blue) 7%, var(--cream));
  --donate-accent-bar: linear-gradient(
    90deg,
    transparent 0%,
    color-mix(in oklch, var(--uk-gold) 75%, var(--uk-gold-bright)) 22%,
    var(--uk-gold-bright) 50%,
    color-mix(in oklch, var(--uk-gold) 75%, var(--uk-gold-bright)) 78%,
    transparent 100%
  );
  --donate-section-y: clamp(2.75rem, 6vw, 4.5rem);
  padding-bottom: 0;
  background-color: var(--cream);
  color: var(--ink);
}

/* Align “Other ways” band with hero / impact width + shared vertical rhythm */
.donate-page .section.donate-ways--channels {
  padding-top: var(--donate-section-y);
  padding-bottom: calc(var(--donate-section-y) + 0.35rem);
  max-width: min(var(--content-max), 100%);
}

.donate-page .donate-ways-grid {
  margin-bottom: var(--space-md);
}

.donate-page .donate-legal.section {
  padding-top: clamp(1.75rem, 4vw, 2.75rem);
  padding-bottom: clamp(1rem, 2.5vw, 1.5rem);
}

.donate-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(2.5rem, 5vw, 4rem) var(--pad-inline) clamp(2rem, 4vw, 3rem);
  background:
    radial-gradient(ellipse 90% 70% at 50% -20%, color-mix(in oklch, var(--uk-gold-bright) 22%, transparent) 0%, transparent 55%),
    linear-gradient(180deg, var(--donate-wash-hero) 0%, var(--cream) 100%);
  border-bottom: 1px solid var(--donate-line);
}

/* One Givebutter embed: copy left, checkout card right (desktop). No second form below. */
.donate-hero--split {
  padding-bottom: clamp(2.25rem, 4vw, min(3.25rem, var(--donate-section-y)));
}

.donate-hero__split {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(min(100%, 24rem), 28rem);
  gap: clamp(2.25rem, 5vw, 4rem);
  align-items: start;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
}

.donate-hero__copy {
  text-align: left;
}

.donate-hero--split .donate-hero__lead {
  margin-left: 0;
  margin-right: 0;
  margin-bottom: var(--space-sm);
  max-width: 38rem;
}

.donate-hero--split .donate-trust-row {
  justify-content: flex-start;
  margin-left: 0;
  margin-right: 0;
  margin-bottom: var(--space-md);
}

.donate-hero__form-wrap {
  width: 100%;
  min-width: 0;
  scroll-margin-top: calc(var(--header-h) + 0.75rem);
}

@media (min-width: 901px) {
  .donate-hero__form-wrap {
    position: sticky;
    top: 1rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .donate-hero__form-wrap {
    position: static;
  }
}

@media (max-width: 900px) {
  .donate-hero__split {
    grid-template-columns: 1fr;
  }

  .donate-hero__copy {
    text-align: center;
  }

  .donate-hero--split .donate-trust-row {
    justify-content: center;
  }

  .donate-hero--split .donate-hero__lead {
    margin-left: auto;
    margin-right: auto;
  }
}

.donate-hero__glow {
  position: absolute;
  inset: -30% 10% auto;
  height: 60%;
  pointer-events: none;
  background: radial-gradient(ellipse at 50% 0%, color-mix(in oklch, var(--uk-blue) 18%, transparent), transparent 70%);
  opacity: 0.85;
}

.donate-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 52rem;
  margin: 0 auto;
  text-align: center;
}

.donate-hero--split .donate-hero__eyebrow {
  text-align: left;
}

@media (max-width: 900px) {
  .donate-hero--split .donate-hero__eyebrow {
    text-align: center;
  }
}

.donate-hero__eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--uk-blue);
  margin: 0 0 var(--space-sm);
}

.donate-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 3vw + 0.75rem, 2.65rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  letter-spacing: -0.03em;
  line-height: 1.12;
  margin: 0 0 var(--space-md);
}

.donate-hero--split h1 {
  text-align: left;
}

@media (max-width: 900px) {
  .donate-hero--split h1 {
    text-align: center;
  }
}

.donate-hero__lead {
  margin: 0 auto var(--space-md);
  max-width: 38rem;
  font-size: 1.1rem;
  line-height: 1.65;
  color: var(--ink-soft);
}

.donate-trust-row {
  list-style: none;
  margin: 0 auto var(--space-md);
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.65rem 1.25rem;
  max-width: 40rem;
  font-size: 0.88rem;
  color: var(--ink-muted);
}

.donate-trust-row li {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.donate-trust-row li::before {
  content: "";
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--uk-gold-bright), color-mix(in oklch, var(--uk-gold) 70%, var(--uk-gold-bright)));
  box-shadow: 0 0 0 1px color-mix(in oklch, var(--uk-gold) 35%, transparent);
}

.donate-trust-row a {
  color: var(--uk-blue);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.donate-trust-row a:hover {
  color: var(--uk-blue-deep);
}

.donate-hero__figure {
  margin: 0 0 clamp(1.25rem, 2.5vw, 1.75rem);
  max-width: min(100%, 28rem);
}

.donate-hero__figure-frame {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  aspect-ratio: 16 / 10;
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
}

.donate-hero__figure-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  display: block;
}

.donate-hero__figure-cap {
  margin: 0.45rem 0 0;
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.donate-quote--hero {
  margin: 0 0 clamp(1.25rem, 3vw, 1.75rem);
}

.donate-hero__reach {
  margin-top: 0;
  padding: clamp(1.15rem, 2.5vw, 1.5rem) clamp(1.15rem, 2.5vw, 1.35rem);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, transparent);
  background: linear-gradient(
    165deg,
    color-mix(in oklch, white 92%, var(--cream)) 0%,
    color-mix(in oklch, var(--uk-blue) 5%, var(--cream)) 100%
  );
  box-shadow: 0 2px 16px color-mix(in oklch, var(--uk-blue) 8%, transparent);
}

.donate-hero__reach-title {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 0.8vw + 0.85rem, 1.2rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
  margin: 0 0 0.4rem;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.donate-hero__reach-note {
  margin: 0 0 var(--space-sm);
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.donate-hero__reach-channels.contact-channels {
  margin: 0 0 0.85rem;
}

.donate-hero__reach-channels .contact-channel {
  padding: 0.55rem 0.65rem;
}

.donate-hero__reach-cta {
  margin: 0 0 0.65rem;
}

.donate-hero__reach-cta .btn {
  width: 100%;
  justify-content: center;
}

.donate-hero__tiers-hint {
  margin: 0;
  font-size: 0.88rem;
  text-align: center;
}

.donate-hero__tiers-hint a {
  color: var(--uk-blue);
  font-weight: 650;
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.donate-hero__tiers-hint a:hover {
  color: var(--uk-blue-deep);
}

@media (min-width: 901px) {
  .donate-hero__reach-cta .btn {
    width: auto;
    display: inline-flex;
  }

  .donate-hero__tiers-hint {
    text-align: left;
  }
}

@media (max-width: 900px) {
  .donate-hero__figure {
    margin-left: auto;
    margin-right: auto;
  }

  .donate-hero__figure-cap {
    text-align: center;
  }

  .donate-quote--hero {
    margin-left: auto;
    margin-right: auto;
    max-width: 38rem;
  }
}

.donate-form-panel {
  margin: 0;
}

/* Donate hero: same shell + widget embed pattern as contact page */
.donate-page .contact-form-shell {
  width: 100%;
}

.donate-page .contact-form-shell__embed {
  min-height: 18rem;
}

.donate-page .contact-form-shell__embed givebutter-widget {
  min-height: 20rem;
}

.donate-impact {
  position: relative;
  overflow: hidden;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  padding: var(--donate-section-y) var(--pad-inline);
  border-top: 1px solid var(--donate-line);
  background:
    radial-gradient(ellipse 90% 55% at 88% 0%, color-mix(in oklch, var(--uk-gold-bright) 24%, transparent) 0%, transparent 55%),
    radial-gradient(ellipse 65% 50% at 0% 100%, color-mix(in oklch, var(--uk-blue) 12%, transparent) 0%, transparent 48%),
    linear-gradient(180deg, var(--donate-wash-deep) 0%, var(--cream) 100%);
}

.donate-impact::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--donate-accent-bar);
  opacity: 0.92;
  pointer-events: none;
}

.donate-impact__inner {
  position: relative;
  z-index: 1;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
}

.donate-impact__eyebrow {
  margin: 0 0 var(--space-xs);
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 750;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--uk-blue);
}

.donate-impact .donate-aside__h {
  font-size: clamp(1.85rem, 2.4vw + 1rem, 2.65rem);
  font-weight: 650;
  line-height: 1.06;
  letter-spacing: -0.035em;
  margin: 0 0 var(--space-sm);
}

.donate-impact__accent {
  box-decoration-break: clone;
  background: linear-gradient(
    transparent 62%,
    color-mix(in oklch, var(--uk-gold-bright) 55%, transparent) 62%,
    color-mix(in oklch, var(--uk-gold-bright) 55%, transparent) 92%,
    transparent 92%
  );
}

.donate-impact .donate-aside__intro {
  font-size: clamp(0.98rem, 0.5vw + 0.85rem, 1.08rem);
  line-height: 1.65;
  max-width: 38ch;
}

.donate-impact .donate-aside__h,
.donate-impact .donate-aside__intro {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.donate-impact__foot-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  text-align: center;
}

.donate-impact__give-link.btn {
  min-height: 48px;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 20px color-mix(in oklch, var(--uk-blue-deep) 22%, transparent);
}

.donate-impact__give-hint {
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--ink-muted);
  max-width: 36ch;
}

@media (min-width: 900px) {
  .donate-impact .donate-aside {
    display: grid;
    grid-template-columns: minmax(0, 26rem) minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: clamp(2.25rem, 4.5vw, 4rem);
    row-gap: var(--space-lg);
    align-items: start;
  }

  .donate-impact__lede {
    grid-column: 1;
    grid-row: 1;
  }

  .donate-impact .donate-aside__h,
  .donate-impact .donate-aside__intro {
    text-align: left;
    margin-left: 0;
    margin-right: 0;
  }

  .donate-impact .donate-aside__intro {
    max-width: none;
  }

  .donate-impact__foot-cta {
    grid-column: 1;
    grid-row: 2;
    align-items: flex-start;
    text-align: left;
    align-self: end;
  }

  .donate-impact__give-hint {
    text-align: left;
  }

  .donate-impact .donate-tiers {
    grid-column: 2;
    grid-row: 1 / -1;
    margin: 0;
    align-self: stretch;
    gap: var(--space-sm);
  }
}

.donate-aside__photo {
  position: relative;
  margin: 0 0 var(--space-md);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-elevated);
  aspect-ratio: 4 / 3;
}

.donate-aside__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.donate-aside__caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 0.5rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 650;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: oklch(98% 0.01 95);
  background: linear-gradient(transparent, oklch(22% 0.04 255 / 0.75));
}

.donate-aside__h {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--uk-blue-deep);
  margin: 0 0 var(--space-sm);
}

.donate-aside__intro {
  margin: 0 0 var(--space-md);
  font-size: 0.98rem;
  color: var(--ink-soft);
  line-height: 1.6;
}

.donate-tiers {
  list-style: none;
  margin: 0 0 var(--space-md);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.donate-tier {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5rem 1rem;
  padding: 1rem 1.15rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--donate-line);
  background: color-mix(in oklch, white 90%, var(--cream));
  box-shadow:
    inset 0 3px 0 0 color-mix(in oklch, var(--uk-blue) 38%, var(--uk-gold-bright)),
    0 2px 14px color-mix(in oklch, var(--uk-blue-deep) 6%, transparent);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out), border-color 0.2s;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .donate-tier:hover {
    transform: translateY(-3px);
    box-shadow:
      inset 0 3px 0 0 color-mix(in oklch, var(--uk-blue) 38%, var(--uk-gold-bright)),
      0 12px 32px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
    border-color: var(--donate-line-strong);
  }

  .donate-tier--featured:hover {
    box-shadow:
      inset 0 3px 0 0 color-mix(in oklch, var(--uk-gold) 55%, var(--uk-gold-bright)),
      0 14px 36px color-mix(in oklch, var(--uk-gold) 28%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .donate-tier:hover {
    transform: none;
  }
}

.donate-tier--featured {
  display: grid;
  grid-template-columns: minmax(4.5rem, 7rem) minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: start;
  column-gap: 1rem;
  row-gap: 0.35rem;
  padding: 1.1rem 1.2rem 1.15rem;
  border: 1px solid color-mix(in oklch, var(--uk-gold) 35%, var(--donate-line));
  background: linear-gradient(
    145deg,
    color-mix(in oklch, var(--uk-gold-bright) 18%, white) 0%,
    color-mix(in oklch, white 92%, var(--cream)) 48%,
    color-mix(in oklch, var(--uk-blue) 5%, white) 100%
  );
  box-shadow:
    inset 0 3px 0 0 color-mix(in oklch, var(--uk-gold) 55%, var(--uk-gold-bright)),
    0 4px 20px color-mix(in oklch, var(--uk-gold) 22%, transparent),
    inset 0 1px 0 color-mix(in oklch, white 70%, transparent);
}

.donate-tier__badge {
  grid-column: 1 / -1;
  grid-row: 1;
  justify-self: start;
  margin: 0 0 0.15rem;
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  font-family: var(--font-ui);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--uk-blue-deep);
  background: color-mix(in oklch, var(--uk-gold-bright) 45%, white);
  border: 1px solid color-mix(in oklch, var(--uk-gold) 35%, transparent);
}

.donate-tier--featured .donate-tier__amount {
  grid-column: 1;
  grid-row: 2;
  align-self: start;
}

.donate-tier--featured .donate-tier__text {
  grid-column: 2;
  grid-row: 2;
}

.donate-tier__amount {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.2rem, 1.2vw + 0.95rem, 1.65rem);
  font-variant-numeric: tabular-nums;
  color: var(--uk-blue-deep);
  min-width: 4.75rem;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.donate-tier--featured .donate-tier__amount {
  font-size: clamp(1.35rem, 1.5vw + 1rem, 1.85rem);
}

.donate-tier__text {
  flex: 1;
  min-width: 0;
  font-size: clamp(0.88rem, 0.35vw + 0.8rem, 0.98rem);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.5;
}

.donate-quote {
  margin: var(--space-md) 0 0;
  padding: 0 0 0 var(--space-md);
  border-left: 3px solid var(--uk-gold-bright);
}

.donate-quote p {
  margin: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--uk-blue-deep);
}

.donate-ways--channels {
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--donate-line);
  background:
    radial-gradient(ellipse 75% 50% at 12% 0%, color-mix(in oklch, var(--uk-gold-bright) 22%, transparent) 0%, transparent 52%),
    radial-gradient(ellipse 55% 40% at 100% 100%, color-mix(in oklch, var(--uk-blue) 10%, transparent) 0%, transparent 45%),
    linear-gradient(180deg, var(--donate-wash-soft) 0%, var(--cream) 100%);
}

.donate-ways--channels::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--donate-accent-bar);
  opacity: 0.9;
  pointer-events: none;
}

.donate-ways__header {
  position: relative;
  z-index: 1;
  max-width: 46rem;
  margin: 0 auto var(--space-lg);
  text-align: center;
}

.donate-ways__eyebrow {
  margin: 0 0 var(--space-xs);
  font-family: var(--font-ui);
  font-size: 0.7rem;
  font-weight: 750;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--uk-blue);
}

.donate-ways__title {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.2vw + 0.95rem, 2.75rem);
  font-weight: 650;
  line-height: 1.08;
  letter-spacing: -0.035em;
  color: var(--uk-blue-deep);
}

.donate-ways__accent {
  box-decoration-break: clone;
  background: linear-gradient(
    transparent 62%,
    color-mix(in oklch, var(--uk-gold-bright) 52%, transparent) 62%,
    color-mix(in oklch, var(--uk-gold-bright) 52%, transparent) 90%,
    transparent 90%
  );
}

.donate-ways__intro {
  margin: 0;
  font-size: clamp(0.98rem, 0.45vw + 0.86rem, 1.1rem);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 52ch;
  margin-left: auto;
  margin-right: auto;
}

.donate-ways-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: stretch;
  margin: 0;
  padding: 0;
}

@media (max-width: 899px) and (min-width: 560px) {
  .donate-ways-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 559px) {
  .donate-ways-grid {
    grid-template-columns: 1fr;
  }
}

.donate-way-card {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1.2rem 1.25rem 1.35rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--donate-line);
  background: linear-gradient(
    165deg,
    oklch(100% 0 0) 0%,
    color-mix(in oklch, var(--cream) 55%, white) 100%
  );
  box-shadow:
    inset 0 3px 0 0 color-mix(in oklch, var(--uk-gold) 42%, var(--uk-blue)),
    0 4px 22px color-mix(in oklch, var(--uk-blue-deep) 7%, transparent);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out), border-color 0.2s;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .donate-way-card:hover {
    transform: translateY(-4px);
    box-shadow:
      inset 0 3px 0 0 color-mix(in oklch, var(--uk-gold-bright) 55%, var(--uk-blue)),
      0 14px 36px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
    border-color: var(--donate-line-strong);
  }
}

@media (prefers-reduced-motion: reduce) {
  .donate-way-card:hover {
    transform: none;
  }
}

.donate-way-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 0.65rem;
  border-radius: 0.7rem;
  color: var(--uk-blue-deep);
  background: linear-gradient(
    145deg,
    color-mix(in oklch, var(--uk-gold-bright) 38%, white),
    color-mix(in oklch, var(--uk-blue) 8%, white)
  );
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, white 75%, transparent),
    0 2px 8px color-mix(in oklch, var(--uk-gold) 15%, transparent);
}

.donate-way-card__svg {
  width: 1.5rem;
  height: 1.5rem;
}

.donate-way-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.12rem, 0.7vw + 0.92rem, 1.35rem);
  font-weight: 650;
  color: var(--uk-blue-deep);
  margin: 0 0 0.45rem;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.donate-way-card__lead {
  margin: 0 0 0.6rem;
  font-size: clamp(0.9rem, 0.25vw + 0.82rem, 0.98rem);
  font-weight: 500;
  line-height: 1.5;
  color: var(--ink);
}

.donate-way-card__step {
  margin: 0 0 1rem;
  flex-grow: 1;
  font-size: 0.86rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.donate-way-card__step strong {
  font-weight: 700;
  color: var(--uk-blue-deep);
}

.donate-way-card__btn {
  margin-top: auto;
  width: 100%;
  justify-content: center;
  text-align: center;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  font-size: 0.72rem;
  letter-spacing: 0.055em;
  line-height: 1.25;
}

.donate-ways__footer {
  position: relative;
  z-index: 1;
  margin-top: var(--space-xl);
  padding: 0;
  border-radius: 1rem;
  border: 1px solid var(--donate-line);
  background: linear-gradient(
    125deg,
    color-mix(in oklch, var(--uk-blue) 9%, var(--cream)) 0%,
    color-mix(in oklch, white 88%, var(--cream)) 55%,
    color-mix(in oklch, var(--uk-gold-bright) 8%, var(--cream)) 100%
  );
  box-shadow: 0 8px 28px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent);
}

.donate-ways__footer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  align-items: stretch;
  padding: clamp(1.25rem, 3.5vw, 1.75rem) clamp(1.15rem, 3vw, 2rem);
}

@media (min-width: 800px) {
  .donate-ways__footer-inner {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    gap: clamp(1.5rem, 3vw, 2.5rem);
    align-items: center;
  }
}

.donate-ways__footer-copy {
  text-align: center;
}

@media (min-width: 800px) {
  .donate-ways__footer-copy {
    text-align: left;
  }

  .donate-ways__footer-desc {
    margin-left: 0;
    margin-right: 0;
  }
}

.donate-ways__footer-kicker {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 1.2vw + 0.95rem, 1.45rem);
  font-weight: 650;
  letter-spacing: -0.025em;
  line-height: 1.2;
  color: var(--uk-blue-deep);
}

.donate-ways__footer-desc {
  margin: 0 auto;
  font-size: clamp(0.9rem, 0.35vw + 0.82rem, 0.98rem);
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 42ch;
}

.donate-ways__footer-more {
  margin: 0.75rem 0 0;
}

.donate-ways__footer-form {
  font-family: var(--font-ui);
  font-size: 0.88rem;
  font-weight: 650;
  color: var(--uk-blue);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.donate-ways__footer-form:hover {
  color: var(--uk-blue-deep);
}

.donate-ways__footer-actions {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  min-width: 0;
}

@media (min-width: 800px) {
  .donate-ways__footer-actions {
    justify-self: end;
    width: 100%;
    max-width: 22rem;
  }
}

.donate-ways__contact-row {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--donate-line);
  background: color-mix(in oklch, white 92%, var(--cream));
  box-shadow: 0 2px 10px color-mix(in oklch, var(--uk-blue-deep) 5%, transparent);
  transition: transform 0.25s var(--ease-out), border-color 0.2s, box-shadow 0.25s var(--ease-out);
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .donate-ways__contact-row:hover {
    transform: translateY(-2px);
    border-color: color-mix(in oklch, var(--uk-gold) 40%, var(--uk-blue));
    box-shadow: 0 8px 22px color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
  }
}

.donate-ways__contact-row:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 3px;
}

.donate-ways__contact-ico {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.65rem;
  height: 2.65rem;
  border-radius: 0.65rem;
  color: var(--uk-blue-deep);
  background: linear-gradient(
    145deg,
    var(--uk-gold-bright),
    color-mix(in oklch, var(--uk-gold) 82%, var(--uk-gold-bright))
  );
  box-shadow: 0 0.12rem 0 color-mix(in oklch, var(--uk-blue-deep) 18%, transparent);
}

.donate-ways__contact-body {
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
  min-width: 0;
}

.donate-ways__contact-label {
  font-family: var(--font-ui);
  font-size: 0.62rem;
  font-weight: 750;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.donate-ways__contact-value {
  font-family: var(--font-display);
  font-size: clamp(1rem, 0.35vw + 0.88rem, 1.12rem);
  font-weight: 650;
  color: var(--uk-blue-deep);
  word-break: break-word;
}

.donate-legal__box {
  max-width: 42rem;
  margin: 0 auto;
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background: color-mix(in oklch, var(--uk-blue) 6%, var(--cream));
  border: 1px solid var(--donate-line);
}

.donate-legal__box p {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.6;
  color: var(--ink-muted);
  text-align: center;
}

@media (prefers-reduced-motion: reduce) {
  .donate-hero__glow {
    opacity: 0.5;
  }

  .contact-hero__aurora,
  .contact-hero__mesh {
    animation: none !important;
  }

  .contact-channel:hover {
    transform: none;
  }
}

/* Contact page: editorial atelier (hero + channels + framed form) */
.contact-page {
  padding-bottom: 0;
}

/* Field photo from goukraina.org (same asset as home hero Ukraine mask) + scrim for legibility */
.contact-hero {
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  padding: clamp(3.25rem, 9vw, 6rem) var(--pad-inline) clamp(4.5rem, 11vw, 8rem);
  background-color: oklch(12% 0.06 272);
  background-image:
    radial-gradient(ellipse 70% 55% at 20% 20%, color-mix(in oklch, var(--uk-blue) 38%, transparent), transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 30%, color-mix(in oklch, var(--uk-gold-bright) 20%, transparent), transparent 50%),
    linear-gradient(165deg, oklch(12% 0.06 272 / 0.82) 0%, oklch(18% 0.065 258 / 0.78) 45%, oklch(10% 0.055 275 / 0.88) 100%),
    url("https://www.goukraina.org/images/reh2o/station-interior.jpeg");
  background-size: cover, cover, cover, cover;
  background-position: center, center, center, center 38%;
  background-repeat: no-repeat;
  color: oklch(97% 0.012 95);
  overflow: hidden;
  /* Center hero copy on the same rail as .contact-studio (full-bleed + width:100% was pinning copy to the left edge). */
  display: flex;
  flex-direction: column;
  align-items: center;
}

.contact-hero__aurora {
  position: absolute;
  inset: -40% -20% auto -10%;
  height: 85%;
  background: radial-gradient(ellipse at 30% 40%, color-mix(in oklch, var(--uk-gold-bright) 25%, transparent), transparent 55%);
  opacity: 0.55;
  animation: contactAurora 22s ease-in-out infinite alternate;
  pointer-events: none;
}

.contact-hero__mesh {
  position: absolute;
  inset: 0;
  opacity: 0.07;
  background-image:
    linear-gradient(oklch(95% 0.02 95) 1px, transparent 1px),
    linear-gradient(90deg, oklch(95% 0.02 95) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 15%, transparent 70%);
  pointer-events: none;
}

@keyframes contactAurora {
  from {
    transform: translate(0, 0) scale(1);
  }
  to {
    transform: translate(3%, -2%) scale(1.05);
  }
}

.contact-hero__inner {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  width: min(100%, var(--content-max));
  flex-shrink: 0;
}

.contact-hero__eyebrow {
  margin: 0 0 0.75rem;
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 92%, oklch(96% 0.01 95));
}

.contact-hero__title {
  margin: 0 0 var(--space-md);
  max-width: min(38rem, 100%);
  font-family: var(--font-display);
  font-size: clamp(2.15rem, 4vw + 1rem, 3.35rem);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.035em;
  text-wrap: balance;
}

.contact-hero__lead {
  margin: 0;
  max-width: min(36ch, 100%);
  font-size: clamp(1.05rem, 0.5vw + 0.95rem, 1.2rem);
  line-height: 1.65;
  color: color-mix(in oklch, oklch(96% 0.02 95) 88%, oklch(45% 0.14 255));
}

.contact-hero__rule {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: min(var(--content-max), calc(100% - 2 * var(--pad-inline)));
  height: 3px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in oklch, var(--uk-gold-bright) 75%, transparent) 20%,
    color-mix(in oklch, var(--uk-gold-bright) 85%, transparent) 50%,
    color-mix(in oklch, var(--uk-gold-bright) 75%, transparent) 80%,
    transparent
  );
  opacity: 0.85;
}

.contact-studio {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: clamp(1.5rem, 3.5vw, 2.75rem);
  align-items: start;
  max-width: var(--content-max);
  margin: clamp(-2.75rem, -5vw, -1.75rem) auto 0;
  padding: 0 var(--pad-inline) clamp(1.5rem, 4vw, 2.5rem);
}

.contact-aside {
  container-type: inline-size;
  container-name: contact-aside;
  position: relative;
  padding: clamp(1.5rem, 3.2vw, 2.1rem);
  border-radius: 1.25rem;
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 14%, var(--line));
  background:
    radial-gradient(130% 80% at 0% 0%, color-mix(in oklch, var(--uk-gold-bright) 12%, transparent), transparent 58%),
    radial-gradient(90% 50% at 100% 100%, color-mix(in oklch, var(--uk-blue) 8%, transparent), transparent 50%),
    linear-gradient(
      168deg,
      oklch(100% 0 0) 0%,
      color-mix(in oklch, var(--cream) 50%, oklch(99.5% 0.008 95)) 100%
    );
  box-shadow:
    0 4px 6px color-mix(in oklch, var(--uk-blue-deep) 5%, transparent),
    0 28px 56px color-mix(in oklch, var(--uk-blue-deep) 11%, transparent);
}

.contact-aside::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  /* Brand only: deep blue → blue → gold (no mixed hues that read green) */
  background: linear-gradient(
    90deg,
    var(--uk-blue-deep) 0%,
    var(--uk-blue) 42%,
    var(--uk-gold-bright) 100%
  );
  opacity: 1;
}

.contact-aside__intro {
  position: relative;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 8%, transparent);
}

.contact-aside__eyebrow {
  margin: 0 0 0.5rem;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.contact-aside__h {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 1.5vw + 0.9rem, 1.65rem);
  font-weight: 650;
  letter-spacing: -0.03em;
  line-height: 1.12;
  color: var(--uk-blue-deep);
}

.contact-aside__note {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 36ch;
}

.contact-aside__reach {
  border-radius: calc(var(--radius-lg) + 2px);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 16%, var(--line));
  border-top: 3px solid var(--uk-gold-bright);
  background: oklch(100% 0 0);
  box-shadow: 0 2px 14px color-mix(in oklch, var(--uk-blue-deep) 7%, transparent);
  overflow: hidden;
}

.contact-channels {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.contact-aside .contact-channel {
  align-items: flex-start;
  padding: 0.85rem 1rem;
  border-radius: 0;
  border: none;
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 9%, transparent);
  background: transparent;
  transition:
    transform 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out),
    background 0.2s var(--ease-out);
}

.contact-aside__reach .contact-channels li:last-child .contact-channel {
  border-bottom: none;
}

.contact-aside .contact-channel:hover {
  background: color-mix(in oklch, var(--uk-blue) 3.5%, white);
  transform: none;
  box-shadow: none;
  border-color: transparent;
}

.contact-aside .contact-channel:active {
  background: color-mix(in oklch, var(--uk-gold-bright) 10%, white);
}

.contact-channel {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.85rem 1rem;
  text-decoration: none;
  color: inherit;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 10%, transparent);
  background: color-mix(in oklch, var(--uk-blue) 4%, white);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out), border-color 0.2s;
}

.contact-channel:hover {
  transform: translateY(-2px);
  /* Avoid gold⊕blue oklch mixes (can read teal); stay on blue + gold separately */
  border-color: color-mix(in oklch, var(--uk-blue) 28%, var(--line));
  box-shadow: 0 8px 24px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
}

.contact-channel:focus-visible {
  outline: 2px solid var(--uk-gold-bright);
  outline-offset: 3px;
}

.contact-aside .contact-channel__glyph {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 0.55rem;
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 15%, transparent);
  box-shadow: 0 0.12rem 0 color-mix(in oklch, var(--uk-blue-deep) 20%, transparent);
}

.contact-channel__glyph {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.65rem;
  color: var(--uk-blue-deep);
  background: var(--uk-gold-bright);
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
  box-shadow: 0 0.15rem 0 color-mix(in oklch, var(--uk-blue-deep) 22%, transparent);
}

.contact-channel__text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}

.contact-channel__label {
  font-size: 0.65rem;
  font-weight: 750;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.contact-channel__value {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--uk-blue-deep);
  word-break: break-word;
}

.contact-aside .contact-channel__value {
  font-family: var(--font-ui);
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.015em;
  line-height: 1.35;
  color: var(--uk-blue-deep);
}

.contact-hq {
  margin-top: var(--space-md);
  padding: var(--space-md);
  border-radius: calc(var(--radius-lg) + 2px);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 11%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in oklch, var(--uk-blue) 6%, white) 0%,
    color-mix(in oklch, var(--cream) 58%, white) 100%
  );
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, white 82%, transparent),
    0 4px 16px color-mix(in oklch, var(--uk-blue-deep) 6%, transparent);
}

.contact-hq__head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.45rem;
}

.contact-hq__pin {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 0.5rem;
  color: var(--uk-blue-deep);
  background: var(--uk-gold-bright);
  border: 1px solid color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
  box-shadow: 0 1px 0 color-mix(in oklch, var(--uk-blue-deep) 15%, transparent);
}

.contact-hq__pin svg {
  display: block;
}

.contact-hq__title {
  margin: 0;
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.contact-hq__address {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.55;
  font-style: normal;
  color: var(--ink-soft);
}

.contact-explore {
  margin-top: var(--space-md);
  padding: var(--space-md);
  border-radius: calc(var(--radius-lg) + 2px);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 10%, transparent);
  background: linear-gradient(
    125deg,
    color-mix(in oklch, var(--uk-blue) 7%, var(--cream)) 0%,
    color-mix(in oklch, white 90%, var(--cream)) 52%,
    color-mix(in oklch, var(--uk-gold-bright) 9%, var(--cream)) 100%
  );
  box-shadow: 0 8px 26px color-mix(in oklch, var(--uk-blue-deep) 7%, transparent);
}

.contact-explore__title {
  margin: 0 0 0.4rem;
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 0.8vw + 0.85rem, 1.2rem);
  font-weight: 650;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--uk-blue-deep);
  text-transform: none;
}

.contact-explore__lede {
  margin: 0 0 var(--space-sm);
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 36ch;
}

.contact-explore__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.55rem;
}

.contact-explore__tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  min-height: 5.5rem;
  padding: 0.6rem 0.4rem;
  text-decoration: none;
  color: var(--uk-blue-deep);
  text-align: center;
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 13%, transparent);
  background: linear-gradient(
    165deg,
    oklch(100% 0 0) 0%,
    color-mix(in oklch, var(--cream) 40%, white) 100%
  );
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, white 88%, transparent),
    0 2px 8px color-mix(in oklch, var(--uk-blue-deep) 5%, transparent);
  transition:
    border-color 0.2s var(--ease-out),
    background 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}

.contact-explore__tile:hover {
  border-color: color-mix(in oklch, var(--uk-gold) 50%, var(--uk-blue));
  background: oklch(100% 0 0);
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, white 95%, transparent),
    0 8px 22px color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
  transform: translateY(-2px);
}

.contact-explore__tile:focus-visible {
  outline: 2px solid var(--uk-gold-bright);
  outline-offset: 3px;
}

.contact-explore__tile--external {
  border-style: dashed;
  border-color: color-mix(in oklch, var(--uk-blue) 18%, transparent);
}

.contact-explore__tile--external:hover {
  border-style: solid;
}

.contact-explore__ico {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--uk-blue-deep);
}

.contact-explore__ico svg {
  display: block;
}

.contact-explore__tile-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
  min-width: 0;
}

.contact-explore__tile-label {
  font-size: 0.7rem;
  font-weight: 750;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--uk-blue-deep);
  line-height: 1.2;
}

.contact-explore__tile-hint {
  font-size: 0.65rem;
  font-weight: 550;
  letter-spacing: 0.04em;
  color: var(--ink-muted);
  line-height: 1.2;
}

@container contact-aside (max-width: 300px) {
  .contact-explore__list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 380px) {
  .contact-explore__list {
    grid-template-columns: 1fr;
  }

  .contact-explore__tile {
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 0.75rem;
    min-height: 3.25rem;
    padding: 0.65rem 0.85rem;
    text-align: left;
  }

  .contact-explore__tile-body {
    align-items: flex-start;
  }

  .contact-explore__tile-label {
    font-size: 0.8125rem;
    letter-spacing: 0.06em;
  }

  .contact-explore__tile-hint {
    font-size: 0.75rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .contact-explore__tile:hover {
    transform: none;
  }
}

.contact-form-shell {
  position: relative;
  border-radius: 1.25rem;
  padding: 2px;
  background: linear-gradient(
    135deg,
    color-mix(in oklch, var(--uk-gold-bright) 50%, var(--cream)),
    color-mix(in oklch, var(--uk-blue) 28%, var(--cream)) 42%,
    color-mix(in oklch, var(--uk-gold) 42%, var(--cream)) 100%
  );
  box-shadow:
    0 12px 40px color-mix(in oklch, var(--uk-blue-deep) 14%, transparent),
    inset 0 1px 0 color-mix(in oklch, white 75%, transparent);
}

.contact-form-shell__rim {
  display: none;
}

.contact-form-shell__body {
  position: relative;
  border-radius: calc(1.25rem - 2px);
  padding: clamp(1.5rem, 3.5vw, 2.25rem);
  background: linear-gradient(
    180deg,
    color-mix(in oklch, white 98%, var(--cream)) 0%,
    var(--cream) 100%
  );
  overflow-x: hidden;
  overflow-y: visible;
}

.contact-form-shell__embed {
  margin: var(--space-sm) 0;
  min-height: 14rem;
}

.contact-form-shell__embed--native {
  min-height: 0;
  margin-top: 0;
}

.contact-form-shell__embed givebutter-widget,
.contact-form-shell__embed givebutter-giving-form {
  display: block;
  width: 100%;
  margin-top: 0;
  min-height: 20rem;
}

.contact-form-shell__embed--native givebutter-widget,
.contact-form-shell__embed--native givebutter-giving-form {
  min-height: 0;
}

.contact-form-shell__seal {
  position: absolute;
  top: 1.25rem;
  right: 1.35rem;
  width: 3.25rem;
  height: 3.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 2px solid color-mix(in oklch, var(--uk-gold-bright) 65%, var(--uk-blue));
  background: color-mix(in oklch, var(--uk-blue) 6%, white);
  box-shadow: inset 0 1px 0 color-mix(in oklch, white 80%, transparent);
  transform: rotate(-8deg);
}

.contact-form-shell__seal span {
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--uk-blue-deep);
}

.contact-form-head {
  margin-bottom: var(--space-md);
  padding-right: 4rem;
}

.contact-form-head__kicker {
  margin: 0 0 0.35rem;
  font-size: 0.65rem;
  font-weight: 750;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.contact-form-head__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 1.2vw + 1.1rem, 1.85rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--uk-blue-deep);
}

.contact-form-head__lead {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.58;
  color: var(--ink-soft);
  max-width: 48ch;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.contact-form__names {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.contact-page .contact-form label {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
}

.contact-page .contact-form input,
.contact-page .contact-form textarea {
  border-radius: 0.5rem;
  border-width: 1.5px;
  background: oklch(100% 0 0);
}

.contact-page .contact-form textarea {
  min-height: 11rem;
}

.contact-form__optional {
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: none;
  color: var(--ink-muted);
  opacity: 0.85;
}

.contact-page .contact-form select {
  width: 100%;
  min-height: 52px;
  padding: 0.75rem 2.75rem 0.75rem 1rem;
  font-family: var(--font-ui);
  font-size: 1rem;
  border: 2px solid var(--line);
  border-radius: 0.5rem;
  border-width: 1.5px;
  background-color: oklch(100% 0 0);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%231e3a5f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  background-size: 1.1rem;
  appearance: none;
  cursor: pointer;
  color: var(--uk-blue-deep);
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}

.contact-page .contact-form select:focus {
  outline: none;
  border-color: var(--uk-blue-deep);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--uk-blue) 25%, transparent);
}

.contact-page .contact-form select:invalid {
  color: var(--ink-muted);
}

.contact-page .contact-form input:hover,
.contact-page .contact-form textarea:hover,
.contact-page .contact-form select:hover {
  border-color: color-mix(in oklch, var(--uk-blue) 32%, var(--line));
}

.contact-form__actions {
  margin-top: 0.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.contact-form__submit {
  align-self: flex-start;
  min-width: min(100%, 14rem);
  min-height: 52px;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.contact-form__fineprint {
  margin: var(--space-sm) 0 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--ink-muted);
  max-width: none;
}

.contact-form__fineprint a {
  color: var(--uk-blue);
  font-weight: 600;
}

@media (max-width: 900px) {
  .contact-studio {
    grid-template-columns: 1fr;
    margin-top: clamp(-1.5rem, -3vw, -0.75rem);
  }

  .contact-page .contact-form-head,
  .donate-page .contact-form-head {
    padding-right: 0;
    padding-top: 3.5rem;
  }

  .contact-page .contact-form-shell__seal,
  .donate-page .contact-form-shell__seal {
    top: 1rem;
    right: 1rem;
  }
}

@media (max-width: 520px) {
  .contact-form__names {
    grid-template-columns: 1fr;
  }
}

/* Impact page */
.impact-hero {
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  padding: clamp(2.5rem, 6vw, 4rem) var(--pad-inline) clamp(2.25rem, 5vw, 3.5rem);
  background:
    radial-gradient(ellipse 80% 60% at 15% 0%, color-mix(in oklch, var(--uk-gold-bright) 14%, transparent), transparent 55%),
    linear-gradient(180deg, color-mix(in oklch, var(--uk-blue) 7%, var(--cream)) 0%, var(--cream) 65%, color-mix(in oklch, var(--cream) 92%, white) 100%);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue) 10%, transparent);
  overflow: hidden;
}

.impact-hero__wash {
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 100 Q 50 40 100 100 T 200 100' fill='none' stroke='oklch(45%25 0.14 255)' stroke-width='0.5' opacity='0.2'/%3E%3C/svg%3E");
  background-size: 120% auto;
  background-position: 50% 80%;
  pointer-events: none;
}

.impact-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 40rem;
  margin: 0 auto;
  text-align: center;
}

.impact-hero__eyebrow {
  margin: 0 0 0.65rem;
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
}

.impact-hero__title {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw + 1rem, 3.15rem);
  font-weight: 550;
  letter-spacing: -0.035em;
  line-height: 1.08;
  color: var(--uk-blue-deep);
}

.impact-hero__lead {
  margin: 0 auto;
  max-width: 42ch;
  font-size: clamp(1.02rem, 0.35vw + 0.95rem, 1.15rem);
  line-height: 1.62;
  color: var(--ink-soft);
}

.impact-hero__stats {
  position: relative;
  z-index: 2;
  list-style: none;
  margin: clamp(1.75rem, 4vw, 2.5rem) auto 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(0.75rem, 2vw, 1.15rem);
  max-width: 52rem;
}

.impact-hero-stat {
  flex: 1 1 min(9.5rem, 100%);
  max-width: 16rem;
  padding: var(--space-sm) var(--space-md);
  text-align: center;
  border-radius: var(--radius-lg);
  background: oklch(100% 0 0);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 10%, transparent);
  box-shadow:
    0 1px 0 color-mix(in oklch, white 90%, transparent) inset,
    0 12px 32px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent);
}

.impact-hero-stat__num {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 2vw + 1rem, 2.15rem);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--uk-blue-deep);
  line-height: 1.1;
}

.impact-hero-stat__lbl {
  display: block;
  margin-top: 0.35rem;
  font-size: 0.78rem;
  font-weight: 650;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.impact-band {
  padding: clamp(2.5rem, 6vw, 4rem) var(--pad-inline);
}

.impact-band__inner {
  max-width: 920px;
  margin: 0 auto;
}

.impact-band__head {
  margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
  text-align: center;
  max-width: 46rem;
  margin-left: auto;
  margin-right: auto;
}

.impact-band__title {
  margin: 0 0 0.65rem;
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 1.5vw + 1.1rem, 2.15rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--uk-blue-deep);
}

.impact-band__intro {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--ink-soft);
}

.impact-alloc-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.35rem);
}

.impact-alloc-card {
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background: oklch(100% 0 0);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 10%, var(--line));
  box-shadow: 0 2px 16px color-mix(in oklch, var(--uk-blue-deep) 6%, transparent);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}

.impact-alloc-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
}

.impact-alloc-card__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.impact-alloc-card__name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.impact-alloc-card__name a {
  color: var(--uk-blue-deep);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s, color 0.2s;
}

.impact-alloc-card__name a:hover {
  color: var(--uk-blue);
  border-bottom-color: color-mix(in oklch, var(--uk-gold) 55%, var(--uk-blue));
}

.impact-alloc-card__pct {
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--uk-blue-deep);
  flex-shrink: 0;
}

.impact-alloc-card__bar {
  height: 0.5rem;
  margin-bottom: 0.65rem;
}

.impact-alloc-card__hint {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--ink-muted);
}

.impact-alloc-card:nth-child(1) .alloc-fill {
  animation-delay: 0.05s;
}

.impact-alloc-card:nth-child(2) .alloc-fill {
  animation-delay: 0.15s;
}

.impact-alloc-card:nth-child(3) .alloc-fill {
  animation-delay: 0.25s;
}

.impact-alloc-card:nth-child(4) .alloc-fill {
  animation-delay: 0.35s;
}

.impact-trust {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  padding: clamp(1.75rem, 4vw, 2.5rem) var(--pad-inline);
  background: linear-gradient(
    135deg,
    oklch(22% 0.085 258) 0%,
    var(--uk-blue-deep) 45%,
    oklch(16% 0.07 268) 100%
  );
  color: oklch(96% 0.015 95);
  border-top: 1px solid color-mix(in oklch, var(--uk-gold-bright) 28%, transparent);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-blue-deep) 50%, transparent);
}

.impact-trust__inner {
  max-width: 960px;
  margin: 0 auto;
}

.impact-trust__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(1rem, 3vw, 2rem);
}

.impact-trust__item {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0 var(--space-md);
  text-align: center;
}

.impact-trust__item--cta {
  padding: 0;
  flex: 0 0 auto;
}

.impact-trust__label {
  font-size: 0.65rem;
  font-weight: 750;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in oklch, oklch(96% 0.02 95) 72%, var(--uk-gold-bright));
}

.impact-trust__value {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 600;
}

/* High-contrast CTA on dark trust band: yellow field, white label (not navy btn-primary) */
.impact-trust .impact-trust__btn.btn-primary {
  background: oklch(74% 0.17 92);
  color: oklch(99% 0.01 95);
  border: 1px solid color-mix(in oklch, oklch(99% 0.01 95) 28%, transparent);
  box-shadow:
    0 0.2rem 0 oklch(48% 0.12 88),
    0 8px 24px color-mix(in oklch, var(--uk-gold-bright) 35%, transparent);
  letter-spacing: 0.08em;
  font-weight: 750;
  text-decoration: none;
}

.impact-trust .impact-trust__btn.btn-primary:hover {
  background: oklch(80% 0.17 92);
  color: oklch(99% 0.01 95);
  transform: translateY(-2px);
}

.impact-trust .impact-trust__btn.btn-primary:focus-visible {
  outline: 3px solid oklch(99% 0.01 95);
  outline-offset: 3px;
}

.impact-partners {
  padding: clamp(2.5rem, 6vw, 4rem) var(--pad-inline);
  background: linear-gradient(180deg, var(--cream) 0%, color-mix(in oklch, var(--uk-blue) 4%, var(--cream)) 100%);
}

.impact-partners__head {
  max-width: 40rem;
  margin: 0 auto clamp(1.75rem, 4vw, 2.5rem);
  text-align: center;
}

.impact-partners__title {
  margin: 0 0 0.65rem;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.2vw + 1.1rem, 2rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--uk-blue-deep);
}

.impact-partners__intro {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.impact-partners__strip {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: clamp(1rem, 3vw, 2rem);
}

.impact-partners__strip img {
  max-height: 3.25rem;
  width: auto;
  max-width: min(200px, 38vw);
  padding: 0.65rem 1rem;
  object-fit: contain;
  background: oklch(100% 0 0);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 8%, transparent);
  box-shadow: 0 2px 12px color-mix(in oklch, var(--uk-blue-deep) 6%, transparent);
  filter: grayscale(0.12);
  opacity: 0.92;
  transition: opacity 0.25s, filter 0.25s, transform 0.25s var(--ease-out);
}

.impact-partners__strip img:hover {
  opacity: 1;
  filter: grayscale(0);
  transform: translateY(-2px);
}

.impact-bottom {
  padding: clamp(2rem, 5vw, 3.5rem) var(--pad-inline) 0;
}

.impact-bottom__card {
  max-width: 640px;
  margin: 0 auto;
  padding: clamp(1.75rem, 4vw, 2.5rem);
  text-align: center;
  border-radius: 1.15rem;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in oklch, white 94%, var(--cream)),
    color-mix(in oklch, var(--uk-blue) 5%, var(--cream))
  );
  box-shadow: 0 16px 40px color-mix(in oklch, var(--uk-blue-deep) 10%, transparent);
}

.impact-bottom__title {
  margin: 0 0 0.65rem;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 1vw + 1.1rem, 1.65rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
}

.impact-bottom__text {
  margin: 0 0 var(--space-md);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.impact-bottom__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}

@media (max-width: 640px) {
  .impact-alloc-grid {
    grid-template-columns: 1fr;
  }

  .impact-trust__list {
    flex-direction: column;
  }

  .impact-hero-stat {
    max-width: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .impact-alloc-card:hover {
    transform: none;
  }

  .impact-partners__strip img:hover {
    transform: none;
  }
}

/* About page — editorial masthead (matches blog index: mark + rail, no glass) */
.about-hero {
  position: relative;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  max-width: 100vw;
  padding: clamp(2.85rem, 7.5vw, 4.75rem) var(--pad-inline) clamp(2.85rem, 6.5vw, 4.15rem);
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 50% at 88% 0%, color-mix(in oklch, var(--uk-gold-bright) 9%, transparent), transparent 42%),
    linear-gradient(168deg, oklch(12% 0.062 260) 0%, oklch(17% 0.082 256) 48%, oklch(11.5% 0.058 262) 100%);
  color: oklch(96% 0.014 95);
  border-bottom: 1px solid color-mix(in oklch, var(--uk-gold) 28%, transparent);
  box-shadow: 0 12px 36px color-mix(in oklch, var(--uk-blue-deep) 16%, transparent);
}

.about-hero__wash {
  position: absolute;
  inset: 0;
  opacity: 0.18;
  background-image: radial-gradient(ellipse 55% 40% at 18% 22%, color-mix(in oklch, white 5%, transparent), transparent 50%);
  pointer-events: none;
}

.about-hero__gridlines {
  position: absolute;
  inset: 0;
  opacity: 0.028;
  background-image:
    linear-gradient(color-mix(in oklch, var(--uk-gold-bright) 35%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in oklch, var(--uk-gold-bright) 35%, transparent) 1px, transparent 1px);
  background-size: 100% 32px, 32px 100%;
  mask-image: radial-gradient(ellipse 85% 75% at 28% 32%, black 12%, transparent 70%);
  pointer-events: none;
}

.about-hero__inner {
  position: relative;
  z-index: 1;
  max-width: min(var(--content-max), 100%);
  margin: 0 auto;
  display: grid;
  gap: clamp(2rem, 4.5vw, 3rem);
  align-items: start;
  text-align: left;
}

@media (min-width: 56rem) {
  .about-hero__inner {
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
    column-gap: clamp(2.25rem, 5vw, 3.75rem);
  }
}

.about-hero__intro {
  position: relative;
  padding-top: 0.15rem;
}

.about-hero__mark {
  width: clamp(3rem, 9vw, 4.5rem);
  height: 3px;
  margin: 0 0 1.25rem;
  border-radius: 2px;
  background: linear-gradient(
    90deg,
    var(--uk-gold) 0%,
    var(--uk-gold) 50%,
    var(--uk-blue) 50%,
    var(--uk-blue) 100%
  );
}

.about-hero__eyebrow {
  margin: 0 0 1rem;
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 78%, oklch(88% 0.02 95));
}

.about-hero__title {
  margin: 0;
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(2.15rem, 3.2vw + 0.95rem, 3.45rem);
  font-weight: 400;
  letter-spacing: -0.035em;
  line-height: 1.06;
  text-wrap: balance;
  max-width: 17ch;
  color: oklch(99.2% 0.008 95);
}

.about-hero__title-line {
  display: block;
}

.about-hero__title-line--accent {
  margin-top: 0.08em;
  font-weight: 600;
  font-style: italic;
  color: color-mix(in oklch, var(--uk-gold-bright) 93%, white);
}

.about-hero__aside {
  position: relative;
  padding: 0.35rem 0 0 clamp(1.35rem, 3vw, 1.75rem);
}

.about-hero__aside::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  bottom: 0;
  width: 3px;
  border-radius: 2px;
  background: linear-gradient(
    180deg,
    var(--uk-gold-bright) 0%,
    var(--uk-gold-bright) 50%,
    var(--uk-blue) 50%,
    color-mix(in oklch, var(--uk-blue) 85%, var(--uk-blue-deep)) 100%
  );
}

.about-hero__lead {
  margin: 0;
  max-width: 48ch;
  font-family: var(--font-ui);
  font-size: clamp(1.04rem, 0.4vw + 0.96rem, 1.16rem);
  line-height: 1.62;
  font-weight: 400;
  color: color-mix(in oklch, oklch(93% 0.022 95) 90%, oklch(55% 0.1 255));
}

.about-hero__meta-strip {
  margin: clamp(1.15rem, 2.5vw, 1.5rem) 0 0;
  padding-top: clamp(1rem, 2vw, 1.2rem);
  border-top: 1px solid color-mix(in oklch, var(--uk-gold) 20%, transparent);
  font-family: var(--font-ui);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--uk-gold-bright) 70%, oklch(78% 0.04 95));
}

.about-hero__meta-dot {
  margin: 0 0.35rem;
  opacity: 0.5;
}

@media (max-width: 55.99rem) {
  .about-hero__inner {
    max-width: min(36rem, 100%);
    margin: 0 auto;
  }

  .about-hero__aside {
    padding: clamp(1.35rem, 3.5vw, 1.65rem) 0 0;
  }

  .about-hero__aside::before {
    left: 0;
    right: 0;
    top: 0;
    bottom: auto;
    width: 100%;
    height: 3px;
    background: linear-gradient(
      90deg,
      var(--uk-gold) 0%,
      var(--uk-gold) 50%,
      var(--uk-blue) 50%,
      var(--uk-blue) 100%
    );
  }
}

.about-story {
  padding: clamp(2.5rem, 6vw, 4.5rem) var(--pad-inline);
}

.about-story__inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: clamp(2rem, 5vw, 3.5rem);
  align-items: start;
}

.about-story__h {
  margin: 0 0 var(--space-md);
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 1.2vw + 1.1rem, 2.1rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--uk-blue-deep);
}

.about-story__prose p {
  margin: 0 0 var(--space-md);
  font-size: 1.05rem;
  line-height: 1.68;
  color: var(--ink);
}

.about-story__prose p:last-child {
  margin-bottom: 0;
}

.about-pullquote {
  margin: var(--space-lg) 0 0;
  padding: 0 0 0 var(--space-md);
  border-left: 3px solid var(--uk-gold-bright);
}

.about-pullquote p {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 0.5vw + 1rem, 1.35rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.55;
  color: var(--uk-blue-deep);
}

.about-facts {
  position: sticky;
  top: calc(var(--header-h) + 1rem);
  padding: var(--space-md);
  border-radius: 1.1rem;
  background: linear-gradient(
    165deg,
    oklch(22% 0.075 260) 0%,
    var(--uk-blue-deep) 50%,
    oklch(14% 0.06 270) 100%
  );
  color: oklch(96% 0.015 95);
  border: 1px solid color-mix(in oklch, var(--uk-gold-bright) 25%, transparent);
  box-shadow: 0 20px 48px color-mix(in oklch, var(--uk-blue-deep) 22%, transparent);
}

.about-facts__label {
  margin: 0 0 var(--space-sm);
  font-size: 0.65rem;
  font-weight: 750;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: color-mix(in oklch, oklch(96% 0.02 95) 75%, var(--uk-gold-bright));
}

.about-facts__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.about-fact {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.65rem;
  align-items: start;
  padding-bottom: 1rem;
  border-bottom: 1px solid color-mix(in oklch, oklch(96% 0.02 95) 18%, transparent);
}

.about-fact:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.about-fact__mark {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--uk-gold-bright);
  opacity: 0.85;
  line-height: 1.4;
}

.about-fact__text {
  font-size: 0.9rem;
  line-height: 1.5;
  color: color-mix(in oklch, oklch(98% 0.01 95) 92%, transparent);
}

.about-team {
  padding: clamp(2.5rem, 6vw, 4rem) var(--pad-inline);
  background: linear-gradient(180deg, var(--cream) 0%, color-mix(in oklch, var(--uk-blue) 4%, var(--cream)) 100%);
  border-top: 1px solid color-mix(in oklch, var(--uk-blue) 8%, transparent);
}

.about-team__head {
  max-width: 40rem;
  margin: 0 auto clamp(2rem, 4vw, 2.75rem);
  text-align: center;
}

.about-team__title {
  margin: 0 0 0.6rem;
  font-family: var(--font-display);
  font-size: clamp(1.65rem, 1.3vw + 1.1rem, 2.15rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--uk-blue-deep);
}

.about-team__intro {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.about-team-grid {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.35rem, 3.5vw, 2rem);
}

.about-team-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: clamp(1.35rem, 3.5vw, 1.85rem) clamp(1rem, 2.5vw, 1.35rem) clamp(1.15rem, 2.5vw, 1.5rem);
  border-radius: 1.15rem;
  overflow: visible;
  background: oklch(100% 0 0);
  border: 1px solid color-mix(in oklch, var(--uk-blue) 11%, var(--line));
  box-shadow:
    0 2px 4px color-mix(in oklch, var(--uk-blue-deep) 5%, transparent),
    0 16px 36px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent);
  transition: transform 0.35s var(--ease-out), box-shadow 0.35s var(--ease-out);
}

.about-team-card:hover {
  transform: translateY(-4px);
  box-shadow:
    0 4px 8px color-mix(in oklch, var(--uk-blue-deep) 8%, transparent),
    0 24px 52px color-mix(in oklch, var(--uk-blue-deep) 12%, transparent);
}

.about-team-card__media {
  width: clamp(7.25rem, 20vw, 9.75rem);
  height: clamp(7.25rem, 20vw, 9.75rem);
  flex-shrink: 0;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 0 var(--space-md);
  background: color-mix(in oklch, var(--uk-blue) 8%, var(--cream));
  box-shadow:
    0 0 0 3px oklch(100% 0 0),
    0 0 0 4px color-mix(in oklch, var(--uk-blue) 16%, transparent),
    0 10px 28px color-mix(in oklch, var(--uk-blue-deep) 14%, transparent);
  transition: box-shadow 0.35s var(--ease-out), transform 0.45s var(--ease-out);
}

.about-team-card:hover .about-team-card__media {
  box-shadow:
    0 0 0 3px oklch(100% 0 0),
    0 0 0 4px color-mix(in oklch, var(--uk-gold) 45%, var(--uk-blue)),
    0 14px 36px color-mix(in oklch, var(--uk-blue-deep) 18%, transparent);
}

/* German: tall source portrait — favor upper face in circular crop */
.about-team-card__media--german img {
  object-position: 50% 18%;
}

/* Olena: portrait framing */
.about-team-card__media--olena img {
  object-position: 50% 22%;
}

.about-team-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 45%;
  transition: transform 0.55s var(--ease-out);
}

.about-team-card:hover .about-team-card__media img {
  transform: scale(1.06);
}

.about-team-card__body {
  padding: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  flex: 1;
}

.about-team-card__name {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--uk-blue-deep);
}

.about-team-card__role {
  margin: 0;
  display: inline-block;
  align-self: center;
  padding: 0.28rem 0.65rem;
  font-size: 0.65rem;
  font-weight: 750;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--uk-blue-mid);
  background: color-mix(in oklch, var(--uk-blue) 7%, var(--cream));
  border-radius: 999px;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, transparent);
}

.about-team-card__bio {
  margin: 0.25rem 0 0;
  max-width: 36ch;
  margin-inline: auto;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.about-cta {
  padding: clamp(2rem, 5vw, 3.5rem) var(--pad-inline) clamp(0.25rem, 1vw, 0.5rem);
}

.about-cta__card {
  max-width: 720px;
  margin: 0 auto;
  /* Slightly less bottom than top so the CTA block doesn’t feel sunk vs. the headline */
  padding: clamp(1.65rem, 3.5vw, 2.45rem) clamp(1.75rem, 4vw, 2.75rem)
    clamp(1.1rem, 2.5vw, 1.55rem);
  text-align: center;
  border-radius: 1.2rem;
  border: 1px solid color-mix(in oklch, var(--uk-blue) 12%, transparent);
  background: linear-gradient(
    145deg,
    color-mix(in oklch, white 95%, var(--cream)),
    color-mix(in oklch, var(--uk-gold-bright) 8%, var(--cream))
  );
  box-shadow: 0 18px 44px color-mix(in oklch, var(--uk-blue-deep) 11%, transparent);
}

.about-cta__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 1vw + 1.15rem, 1.75rem);
  font-weight: 600;
  color: var(--uk-blue-deep);
}

.about-cta__text {
  margin: 0 0 clamp(0.75rem, 2vw, 1.1rem);
  font-size: 1rem;
  line-height: 1.55;
  color: var(--ink-soft);
}

.about-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: center;
  margin: 0;
  padding: 0;
}

@media (max-width: 900px) {
  .about-story__inner {
    grid-template-columns: 1fr;
  }

  .about-facts {
    position: static;
  }
}

@media (max-width: 600px) {
  .about-team-grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .about-team-card:hover {
    transform: none;
  }

  .about-team-card:hover .about-team-card__media img {
    transform: none;
  }
}

