@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;700&display=swap');

:root {
  --bs-primary: #d34522;
  --bs-primary-rgb: 211, 69, 34;
  --bs-body-font-family: 'Roboto', Arial, sans-serif;
  --bs-body-color: #1d1b20;
  --bs-body-line-height: 1.6;
  --bs-link-color: #d34522;
  --bs-link-hover-color: #e7672b;
  --site-accent: #e7672b;
  --site-light: #f5f5f5;
  --site-bg: #f6f5f2;
  --site-border: #d9d9d9;
  --site-muted: #979797;
  --site-dark: #101010;
  --site-section-space: clamp(4rem, 7vw, 7rem);
}

html,
body {
  min-height: 100vh;
}

body {
  display: flex;
  flex-direction: column;
  background: var(--site-bg);
}

.site-header.bg-white {
  background-color: var(--site-bg) !important;
}

.video-card-label {
  color: #fff;
  font-size: clamp(1.25rem, 2.5vw, 1.875rem);
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

#site_main {
  flex: 1 0 auto;
}

#site_footer {
  margin-top: auto;
}

/* Donate page */
.site-brand-group {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.site-back-link {
  font-size: 0.875rem;
  color: var(--site-muted);
  text-decoration: none;
  width: 100%;
}

.site-back-link:hover,
.site-back-link:focus-visible {
  color: var(--bs-primary);
  text-decoration: underline;
}

.site-header-campaign-id .site-footer-tagline {
  font-size: 0.875rem;
}

.site-header-campaign-id .site-footer-campaign {
  font-size: 0.75rem;
  color: var(--site-dark);
  margin-top: 0;
}

.body-content {
  padding: var(--site-section-space) 0;
}

.subpage-subheading {
  font-size: calc(1.3125rem + 0.75vw);
  color: var(--site-dark);
  margin-bottom: 1rem;
}

@media (min-width: 1200px) {
  .subpage-subheading { font-size: 2.1875rem; }
}

.donor-contact {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: 0.75rem;
}

.donor-contact__photo {
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  object-fit: cover;
  object-position: top;
  flex-shrink: 0;
}

.donate-widget {
  position: sticky;
  top: 5rem;
}

.donate-intro__heading {
    font-size: clamp(1.75rem, 4vw, 1.5rem);
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: -1rem;
    color: var(--bs-primary);
    font-family: var(--bs-body-font-family);
}

h2, .subpage-subheading {
    color: var(--bs-body-color);
    margin-top: 2.5rem;
    font-size: 3.125rem;
}

dbox-widget {
  display: block;
}

.site-container {
    width: min(100% - 2rem, 64.375rem);
    margin-inline: auto;
}

.site-footer {
  background: #000;
  color: #fff;
}

.site-footer-shell {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem 3rem;
  min-height: 15.75rem;
  padding: 3.5rem clamp(1rem, 4.2vw, 6.5625rem) 3.0625rem;
}

.site-footer-left {
  flex: 0 1 auto;
  min-width: 0;
}

.site-footer-tagline {
  color: var(--bs-primary);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.15;
}

.site-footer-campaign {
  margin-top: 0.35rem;
  font-size: 1.125rem;
  line-height: 1.2;
}

.site-footer-note {
  margin-top: 2.125rem;
  color: var(--site-muted);
  font-size: 0.9375rem;
  line-height: 1.2;
}

.site-footer-right {
  display: flex;
  flex: 0 0 auto;
  flex-direction: column;
  align-items: flex-end;
  width: min(100%, 23.375rem);
  min-width: 0;
  margin-left: auto;
}

.site-footer-logo-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.site-footer-logo {
  display: block;
  width: min(100%, 22.076rem);
  max-width: 100%;
  aspect-ratio: 353.222 / 36.9107;
  height: auto;
}

.site-footer-contact {
  margin-top: 1.125rem;
  font-style: normal;
  color: #fff;
  font-size: 1.125rem;
  line-height: 1.735;
  text-align: right;
}

.site-footer-link {
  color: inherit;
}

.site-footer-link:hover,
.site-footer-link:focus-visible {
  color: inherit;
}

img {
  max-width: 100%;
}

.section-padding {
  padding: var(--site-section-space) 0;
}

/* Heading scale — Bootstrap RFS pattern: calc(base + Nvw) below 1200px,
   locked at the max above. Use semantic h1–h6 elements; apply .h1/.h2/.h3
   etc. as a visual override when the desired size differs from the
   semantic level (e.g. <h2 class="h3"> for an h2 sized like an h3). */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  margin-top: 0;
  margin-bottom: 1rem;
  font-family: Georgia, 'Times New Roman', serif;
  font-weight: 400;
  line-height: 1.15;
  color: var(--bs-primary);
}

h1, .h1 { font-size: calc(1.9375rem + 2.92vw); }  /* max 4.125rem (66px), ~31px floor */
h2, .h2 { font-size: calc(2.25rem + 1.17vw);  }   /* max 3.125rem (50px) */
h3, .h3 { font-size: calc(1.625rem + 0.75vw); }   /* max 2.1875rem (35px) */
h4, .h4 { font-size: calc(1.25rem + 0.42vw);  }   /* max 1.5625rem (25px) */
h5, .h5 { font-size: calc(1.125rem + 0.17vw); }   /* max 1.25rem (20px) */
h6, .h6 { font-size: 1rem; }

@media (min-width: 1200px) {
  h1, .h1 { font-size: 4.125rem; }
  h2, .h2 { font-size: 3.125rem; }
  h3, .h3 { font-size: 2.1875rem; }
  h4, .h4 { font-size: 1.5625rem; }
  h5, .h5 { font-size: 1.25rem; }
}

/* Headings that follow prose content get extra top margin so the section
   break is visible without needing wrapper divs around heading + body. */
* + h2, * + .h2,
* + h3, * + .h3,
* + h4, * + .h4 {
  margin-top: 2.5rem;
}

.section-intro {
  font-size: clamp(1.05rem, 1.8vw, 1.25rem);
}

/* Inline content links — orange + underline. Scoped to prose elements so
   nav links, alt-link cards, buttons-as-links, etc. keep their own styling. */
p a, li a, dd a {
  color: var(--bs-primary);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

p a:hover, p a:focus-visible,
li a:hover, li a:focus-visible,
dd a:hover, dd a:focus-visible {
  color: var(--site-accent);
}

.site-brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex: 0 1 auto;
}

.site-brand-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
}

.site-brand-caption {
  margin-left: 0px;
  color: var(--bs-primary);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.25;
  text-align: left;
  width:100%;
}

.site-header-shell {
  padding-inline: clamp(1rem, 3.4vw, 5.625rem);
}

.site-header-bar {
  min-height: 6.875rem;
  gap: 1rem;
}

.site-logo {
  display: block;
  width: auto;
  height: clamp(1.55rem, 2.55vw, 2.307rem);
  max-width: min(100%, 22.076rem);
}

.menu-button {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex: 0 0 auto;
  gap: 0.625rem;
  padding: 0.625rem 0 0.625rem 0.875rem !important;
  border-radius: 0;
  background: transparent;
  color: var(--site-dark);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1;
  transition: color 0.2s ease;
}

.menu-button:hover,
.menu-button:focus-visible {
  color: var(--bs-primary) !important;
}

.menu-label {
  display: block;
  font-size: 1rem;
  line-height: 1;
}

.menu-icon {
  display: block;
  font-size: 1.65rem;
  line-height: 0.9;
  transform: translateY(-0.04em);
}

.offcanvas.offcanvas-end {
  --bs-offcanvas-width: 20.6875rem;
}

.hero {
  position: relative;
  overflow: hidden;
  background-repeat: no-repeat;
  background-size: cover;
}

.hero-home {
  --home-shell-max: 51.6875rem;
  --home-shell-gutter: 1rem;
  --home-text-left: max(var(--home-shell-gutter), calc((100vw - var(--home-shell-max)) / 2 + var(--home-shell-gutter)));
  --home-title-max: 42rem;
  --home-outline-right: 2.5rem;
  --home-right-gap: 1rem;
  min-height: 44rem;
  background-position: center 72%;
}

.hero-interior {
  min-height: 44.75rem;
  background-image: var(--interior-hero-image);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.hero-overview {
  --interior-hero-image: url('../images/campaign-overview-hero.jpg');
}

.hero-introduction {
  --interior-hero-image: url('../images/make-introduction-hero.webp');
  background-position: center 30%;
}

.hero-moments {
  --interior-hero-image: url('../images/moments-hero.webp');
}

.hero-amplify {
  --interior-hero-image: url('../images/amplify-our-reach-hero.webp');
}

.hero-home-inner {
  position: relative;
  width: 100%;
  max-width: none;
  min-height: inherit;
  margin: 0;
}

.hero-standard-inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  min-height: inherit;
  max-width: none;
  padding-inline: clamp(1rem, 4vw, 3.75rem);
}

.hero-panel {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.55);
}

.hero-panel-home {
  position: absolute;
  left: 0;
  bottom: 13.9375rem;
}

.hero-panel-standard {
  width: min(100%, 64.375rem);
  margin: 0 auto;
  padding: 2.5rem clamp(1.5rem, 4vw, 3.75rem) 0;
  text-align: center;
}

.hero-eyebrow {
  margin: 1.25rem 0 0;
  color: var(--bs-primary);
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  font-weight: 700;
  line-height: 1.2;
}

.hero-title {
  margin: 0;
  line-height: 1.03;
}

.hero-home .hero-title {
  color: #fff;
}

.hero-home-title {
  position: relative;
  display: block;
  width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
  max-width: 100%;
  margin-left: var(--home-text-left);
  padding: 0.3125rem 0 0.5625rem;
  z-index: 0;
}

.hero-home-title::before {
  content: '';
  position: absolute;
  top: -1rem;
  right: calc(-1 * var(--home-outline-right));
  bottom: -1.125rem;
  left: calc(-1 * var(--home-text-left));
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-left: 0;
  z-index: -1;
}

.hero-home-eyebrow {
  position: absolute;
  left: var(--home-text-left);
  bottom: 10.125rem;
  max-width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
  margin: 0;
}

@media (min-width: 992px) {
  .hero-home {
    --home-shell-gutter: 1.5rem;
  }

  .hero-interior {
    margin-bottom: clamp(1.25rem, 2.5vw, 2rem);
  }
}

.hero-interior .hero-title {
  width: min(100%, 53.4375rem);
  margin-inline: auto;
  color: var(--bs-primary);
}

.hero-interior .hero-panel-standard {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background-color: var(--site-bg);
}

.hero-subtitle {
  margin: 1.25rem auto 0;
  max-width: 50.4375rem;
  color: #101010;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  line-height: 1.35;
}

.hero-interior .hero-subtitle {
  margin-top: 0.5rem;
}

.content-shell {
  max-width: 64.5rem;
}

.home-content-shell {
  max-width: 51.6875rem;
}

.home-pathways-shell {
  max-width: 51.8125rem;
}

.home-pathways-title {
  margin-bottom: 0.4375rem;
}

.home-pathways-intro {
  max-width: 49.5625rem;
  font-size: 1.25rem;
  line-height: 1.485;
}

.overview-content-shell {
  max-width: 67.6875rem;
}

.feature-content-shell {
  max-width: 64.8125rem;
}

.interior-content-grid {
  display: grid;
  align-items: start;
  gap: 2.5rem;
}

.interior-main-copy,
.interior-step-copy,
.example-panel-intro,
.story-panel-copy,
.embed-placeholder-label,
.alt-link-card-copy {
  font-size: 1.25rem;
  line-height: 1.485;
}

.interior-main-copy,
.interior-step-copy {
  max-width: 31.375rem;
}

.example-cta-block {
  margin-top: 2.25rem;
  text-align: center;
}

.example-cta-title {
  margin: 0 0 0.75rem;
}

.example-cta-copy {
  margin: 0 0 1.5rem;
  font-size: 1.125rem;
  line-height: 1.485;
}

.example-stack-single {
  display: flex;
  justify-content: center;
}

.resource-panel,
.example-panel,
.story-panel {
  width: min(100%, 26.125rem);
  justify-self: end;
}

.resource-panel {
  padding: 2rem 1.6875rem 2.5rem;
}

.resource-panel-preview {
  display: block;
  width: min(100%, 22.6875rem);
  margin: 0 auto 2.3125rem;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.25);
}

.panel-action-stack {
  display: grid;
  gap: 1.625rem;
  justify-items: center;
}

.panel-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.8125rem;
  padding-inline: 1rem;
  font-size: 1rem;
  letter-spacing: 0.05em;
  line-height: 1.25;
}

.example-panel {
  padding: 1.125rem 2.0625rem 2.875rem;
}

.example-panel-intro {
  margin-bottom: 2.5rem;
}

.example-stack {
  display: grid;
  justify-content: center;
  gap: 2.625rem;
}

.story-panel {
  padding: 2.875rem 1.8125rem 2.8125rem;
}

.story-panel-title {
  max-width: 24.375rem;
  margin-inline: auto;
  margin-bottom: 1.25rem;
}

.story-panel-copy {
  margin-bottom: 1.375rem;
}

.embed-placeholder-panel {
  min-height: 76.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  text-align: center;
}

.embed-placeholder-label {
  margin: 0;
}

.key-facts-shell {
  max-width: 64.5rem;
}

.key-facts-intro {
  margin-top: 1.875rem;
  font-size: clamp(1.125rem, 1.6vw, 1.25rem);
  line-height: 1.485;
  color: var(--site-dark);
}

.key-facts-intro p {
  margin: 0 0 1.5rem;
}

.key-facts-intro p:last-child {
  margin-bottom: 0;
}

.fact-entry-list {
  display: grid;
  gap: 3.25rem;
  margin: 4rem 0 0;
  padding: 0;
  list-style: none;
}

.fact-entry {
  display: block;
}

.fact-entry-title {
  margin: 0 0 1.375rem;
}

.fact-entry-body {
  font-size: clamp(1.125rem, 1.6vw, 1.25rem);
  line-height: 1.485;
  color: var(--site-dark);
}

.fact-entry-body p {
  margin: 0 0;
}

.fact-entry-body p:last-child {
  margin-bottom: 0;
}

.fact-statement {
  display: block;
}

.fact-copy-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.3125rem 0.625rem;  
  background: transparent;
  border: 1px solid var(--site-border);
  border-radius: 0.25rem;
  color: var(--site-dark);
  cursor: pointer;
  transition: color 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.fact-copy-button:hover,
.fact-copy-button:focus-visible {
  background: rgba(211, 69, 34, 0.12);
  color: var(--bs-primary);
  outline: none;
}

.fact-copy-button[data-copied="true"] {
  color: var(--bs-primary);
}

.fact-copy-icon {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
}

.fact-copy-wrap {  
  margin-bottom: 1rem;
}

.fact-copy-text {
  font-size: 0.9375rem;
  text-transform: lowercase;
  color: inherit;
}

.fact-source {
  font-size: inherit;
  line-height: inherit;
  color: var(--site-dark);
}

.fact-source-label {
  font-weight: 600;
}

.fact-source-name {
  text-decoration: underline;
  text-underline-offset: 0.2em;
  color: inherit;
}

.alt-links-shell {
  max-width: 73.875rem;
}

.alt-links-heading-shell {
  max-width: 58.75rem;
  margin: 0 auto 4.9375rem;
  text-align: center;
}

.alt-links-grid {
  display: grid;
  gap: 2.5rem;
}

.alt-link-card {
  max-width: 19.75rem;
}

.alt-link-card-title {
  margin: 0 0 1.1875rem;
  font-family: var(--bs-body-font-family);
  font-weight: 700;
  line-height: 1.485;
  color: inherit;
}

.alt-link-card-copy {
  margin: 0 0 1.5rem;
}

.alt-link-card-link {
  color: inherit;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-decoration: none;
  text-underline-offset: 0.2em;
}

.alt-link-card-link:hover,
.alt-link-card-link:focus-visible {
  color: inherit;
  text-decoration: underline;
}

.info-panel,
.placeholder-panel,
.tally-panel {
  background: var(--site-light);
  border: 1px solid var(--site-border);
}

.lead-with-us,
#lead-with-us {
  background: linear-gradient(90deg, #e7672b 0%, #d34522 100%);
}

.lead-section-frame {
  max-width: 91.25rem;
}

.lead-section-row {
  min-height: 38.4375rem;
}

.pathway-list {
  display: grid;
  gap: 1.25rem;
}

.pathway-card {
  position: relative;
  display: block;
  min-height: 12.5rem;
  color: #000;
  text-decoration: none;
  background: #fff;
  border: 1px solid var(--site-border);
}

.pathway-card::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 0.625rem;
  background: var(--site-light);
  transition: background-color 0.2s ease;
}

.pathway-card-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  min-height: 12.5rem;
  gap: 1.5rem;
  padding: 2.875rem 1.6875rem 2.75rem 2.6875rem;
}

.pathway-card-copy-wrap {
  display: block;
  max-width: 39.8125rem;
}

.pathway-card-title,
.pathway-card-copy {
  display: block;
}

.pathway-card-title {
  margin: 0 0 0.3125rem;
  font-family: var(--bs-body-font-family);
  font-weight: 700;
  line-height: 1.4167;
  color: #000;
  transition: color 0.2s ease;
}

.pathway-card-copy {
  font-size: 1.125rem;
  line-height: 1.485;
}

.pathway-card-icon {
  flex: 0 0 auto;
  position: relative;
  width: 0.8125rem;
  height: 1.625rem;
}

.pathway-card-icon::before {
  content: '';
  position: absolute;
  top: -9.52%;
  right: -38.07%;
  bottom: -9.52%;
  left: -19.04%;
  background: url('../images/pathway-arrow.svg') center center / 100% 100% no-repeat;
}

.pathway-card:hover,
.pathway-card:focus-visible {
  color: #000;
  text-decoration: none;
}

.pathway-card:hover::before,
.pathway-card:focus-visible::before {
  background: var(--bs-primary);
}

.pathway-card:hover .pathway-card-title,
.pathway-card:focus-visible .pathway-card-title {
  color: var(--bs-primary);
}

.pathway-card:hover .pathway-card-icon,
.pathway-card:focus-visible .pathway-card-icon {
  background-image: none;
}

.pathway-card:hover .pathway-card-icon::before,
.pathway-card:focus-visible .pathway-card-icon::before {
  background-image: url('../images/pathway-arrow-active.svg');
}

.pathway-card:focus-visible {
  outline: 2px solid rgba(211, 69, 34, 0.35);
  outline-offset: 0.25rem;
}

/* Shared story card / moments styles */
.section-copy {
  font-size: 1rem;
  line-height: 1.6;
}

.home-moments-link {
  flex-shrink: 0;
  font-size: 0.9375rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--bs-primary);
  text-decoration: none;
}

.home-moments-link:hover,
.home-moments-link:focus-visible {
  text-decoration: underline;
}

.home-stories-track {
  position: relative;
  overflow: hidden;
}

.home-stories-inner {
  display: flex;
  gap: 1.25rem;
  width: max-content;
}

.stories-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 0.75rem;
}

.stories-nav-buttons {
  display: flex;
  gap: 0.5rem;
}

.stories-btn {
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border-radius: 50%;
  border: 2px solid var(--bs-primary);
  background: #fff;
  color: var(--bs-primary);
  font-size: 1.75rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.stories-btn:hover,
.stories-btn:focus-visible {
  background: var(--bs-primary);
  color: #fff;
  outline: none;
}

@media (prefers-reduced-motion: reduce) {
  .home-stories-inner {
    flex-wrap: wrap;
  }
}

.story-row {
  flex: 0 0 clamp(18rem, 35vw, 22rem);
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 0.5rem;
  border: 1px solid var(--site-border);
  padding: 1.5rem;
}

.story-row__media {
  margin-bottom: 1rem;
}

.story-row__media img {
  width: 4.5rem;
  height: 4.5rem;
  border-radius: 50%;
  object-fit: cover;
  object-position: top;
  display: block;
}

.story-row__name {
  font-size: 1.125rem;
  margin-bottom: 0.5rem;
}

.progress-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-color: #d34522;
}

.progress-section::before,
.progress-section::after {
  content: '';
  position: absolute;
  inset: 0;
}

.progress-section::before {
  z-index: 0;
  background: url('../images/home-progress-bg.webp') center top / cover no-repeat;
  opacity: 0.5;
}

.progress-section::after {
  z-index: 1;
  background: radial-gradient(55% 170% at 50% 56%, #e7672b 0%, #d34522 100%);
  mix-blend-mode: multiply;
}

.progress-section-inner {
  position: relative;
  z-index: 2;
  min-height: 37.0625rem;
  display: flex;
  flex-direction: column;
  padding-top: 4.0625rem;
}

.progress-section-heading {
  max-width: 51.6875rem;
}

.progress-section-updated {
  font-size: 1.125rem;
  letter-spacing: 0.03em;
  line-height: 1.444;
}

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

.pledge-banner {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-color: #d34522;
}

.pledge-banner::before,
.pledge-banner::after {
  content: '';
  position: absolute;
  inset: 0;
}

.pledge-banner::before {
  z-index: 0;
  background: url('../images/home-progress-bg.webp') center top / cover no-repeat;
  opacity: 0.5;
}

.pledge-banner::after {
  z-index: 1;
  background: radial-gradient(55% 170% at 50% 56%, #e7672b 0%, #d34522 100%);
  mix-blend-mode: multiply;
}

.pledge-banner-inner {
  position: relative;
  z-index: 2;
  padding: var(--site-section-space) 0;
}

.pledge-banner-quote {
  margin-bottom: 2rem;
  color: #fff;
}

.pledge-banner-btn {
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  min-height: 3.75rem;
  padding-inline: 2.5rem;
  display: inline-flex;
  align-items: center;
}

.progress-stats {
  position: relative;
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  width: 100%;
  min-height: 0;
  margin-top: 3.4375rem;
  border-top: 1px solid rgba(255, 255, 255, 0.48);
}

.progress-stats::before {
  display: none;
}

.progress-stat {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  min-width: 0;
  min-height: 100%;
  padding: 2rem clamp(1.25rem, 4vw, 3rem);
  text-align: center;
}

.progress-stat + .progress-stat {
  border-left: 1px solid rgba(255, 255, 255, 0.4);
}

.progress-stat-value {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0.125em;
  font-size: clamp(4.25rem, 9vw, 6.25rem);
  font-weight: 300;
  line-height: 0.95;
  letter-spacing: -0.02em;
}

.progress-stat-currency {
  font-size: clamp(2rem, 2.8vw, 2.375rem);
  line-height: 1;
  transform: translateY(0.9rem);
}

.progress-stat-label {
  max-width: 13.8125rem;
  font-size: 1.125rem;
  letter-spacing: 0.03em;
  line-height: 1.444;
}

.alt-links {
  background: linear-gradient(90deg, #e7672b 0%, #d34522 100%);
}

.alt-links h1, .alt-links h2, .alt-links h3,
.alt-links .h1, .alt-links .h2, .alt-links .h3 {
  color: inherit;
}

.lead-copy {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 38.4375rem;
  padding: 4.5rem clamp(1.5rem, 5.8vw, 5.3125rem) 3.5rem clamp(1.5rem, 6.5vw, 5.9375rem);
  background: transparent;
}

.lead-copy-title {
  color: #fff;
  max-width: 41.5625rem;
}

.lead-copy-text {
  margin-bottom: 1.85rem;
  font-size: 1.25rem;
  line-height: 1.485;
  max-width: 32.625rem;
}

.lead-copy-strong {
  font-size: 1.5625rem;
  line-height: 1.485;
}

.lead-art {
  overflow: hidden;
}

.lead-art-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
}

.placeholder-box {
  min-height: 10rem;
  background: #fff;
  border: 1px solid var(--site-border);
}

.placeholder-box-example {
  width: min(100%, 22rem);
  min-height: 16rem;
  margin-inline: auto;
}

.placeholder-box-story {
  width: min(100%, 19.9375rem);
  min-height: 12.8125rem;
  margin-inline: auto;
  margin-bottom: 1.75rem;
}

.story-panel .panel-action-button {
  display: flex;
  width: min(100%, 19.9375rem);
  margin-inline: auto;
}

@media (min-width: 992px) {
  .overview-content-grid {
    grid-template-columns: minmax(0, 41.5625rem) minmax(0, 26.125rem);
    gap: 0;
  }

  .interior-content-grid--feature {
    grid-template-columns: minmax(0, 35.625rem) minmax(0, 26.125rem);
    gap: 3.0625rem;
  }

  .alt-links-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7.5rem;
  }
}

.offcanvas-nav .nav-link {
  border-bottom: 1px solid rgba(0, 0, 0, 0.18);
  color: #656565;
  font-size: 1.25rem;
  line-height: 1.35;
  padding: 1rem 0;
  text-decoration: none;
  text-underline-offset: 0.22em;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.offcanvas-nav .nav-link:hover,
.offcanvas-nav .nav-link:focus-visible {
  color: var(--bs-primary) !important;
  text-decoration: underline;
  text-decoration-color: currentColor;
}

.offcanvas-ways-label {
  margin-top: 1.75rem;
  margin-bottom: 0;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--bs-primary);
}

.offcanvas-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 15rem;
  min-height: 3.75rem;
  margin-top: 1.25rem !important;
  font-size: 1.125rem;
  letter-spacing: 0.05em;
  line-height: 1.2;
}

@media (max-width: 991.98px) {
  .hero {
    min-height: auto;
  }

  .hero-home {
    --home-title-max: 34rem;
    --home-outline-right: 1.25rem;
    --home-right-gap: 1rem;
    min-height: clamp(34rem, 78vw, 48rem);
  }

  .hero-interior {
    min-height: auto;
    background-image: none;
    background-color: var(--site-bg);
    padding: clamp(14rem, 58vw, 21rem) 0 1.75rem;
  }

  .hero-interior::before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: clamp(14rem, 58vw, 21rem);
    background-image: var(--interior-hero-image);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
  }

  .hero-interior::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    width: min(calc(100% - 3rem), 38rem);
    height: 0.375rem;
    background: var(--site-border);
    transform: translateX(-50%);
  }

  .hero-standard-inner {
    display: block;
    min-height: 0;
    padding-inline: 1.5rem;
  }

  .progress-section-inner {
    padding-top: 3.5rem;
  }

  .progress-stats {
    margin-top: 2.75rem;
  }

  .progress-stat-value {
    font-size: clamp(3.75rem, 10vw, 5rem);
  }

  .progress-stat-currency {
    transform: translateY(0.7rem);
  }

  .hero-home-inner {
    width: 100%;
    min-height: inherit;
    padding: 0;
  }

  .hero-panel-home {
    position: absolute;
    left: 0;
    bottom: clamp(6.5rem, 16vw, 9rem);
  }

  .hero-panel-standard {
    min-height: auto;
    height: auto;
    padding-top: 1.75rem;
    padding-bottom: 1.25rem;
  }

  .interior-main-copy,
  .interior-step-copy {
    max-width: none;
  }

  .hero-home-title {
    width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
    max-width: 100%;
  }

  .hero-home-title::before {
    top: -0.875rem;
    bottom: -1rem;
  }

  .hero-home-eyebrow {
    position: absolute;
    left: var(--home-text-left);
    bottom: clamp(3.5rem, 10vw, 6rem);
    max-width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
    margin: 0;
  }

  .lead-section-row {
    min-height: 0;
  }

  .lead-copy {
    min-height: auto;
    padding: 3rem 1.5rem;
  }

  .lead-art-image {
    height: auto;
  }

  .lead-copy-text {
    font-size: 1.125rem;
    max-width: none;
  }

  .lead-copy-strong {
    font-size: 1.375rem;
  }

  .resource-panel,
  .example-panel,
  .story-panel {
    width: 100%;
    justify-self: stretch;
  }

  .embed-placeholder-panel {
    min-height: 36rem;
  }

  .alt-links-heading-shell {
    margin-bottom: 3rem;
  }

  .alt-link-card {
    max-width: none;
  }

  .site-footer-shell {
    min-height: 0;
    padding: 3rem 1.5rem;
  }

  .site-footer-right {
    width: min(100%, 22rem);
  }
}

@media (min-width: 768px) and (max-width: 899.98px) {
  .progress-stat {
    padding-inline: 1rem;
  }

  .progress-stat-value {
    font-size: clamp(3.15rem, 6.15vw, 4rem);
    gap: 0.08em;
  }

  .progress-stat-currency {
    font-size: clamp(1.55rem, 2.2vw, 1.95rem);
    transform: translateY(0.5rem);
  }

  .progress-stat-label {
    font-size: 1rem;
  }
}

@media (max-width: 767.98px) {
  .hero-home {
    --home-title-max: 31rem;
    --home-outline-right: 0.875rem;
    --home-right-gap: 1.5rem;
    min-height: 38rem;
  }

  .hero-home-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: inherit;
    padding: 2rem 0;
  }

  .hero-panel-home {
    position: relative;
    left: 0;
    bottom: 0;
  }

  .progress-section-inner {
    min-height: auto;
    padding: 3rem 0 0;
  }

  .progress-section-updated {
    font-size: 0.95rem;
  }

  .progress-section-title {
    font-size: clamp(2.15rem, 10vw, 2.75rem);
  }

  .progress-stats {
    display: block;
    margin: 2.25rem 0 0;
    border-top: 1px solid rgba(255, 255, 255, 0.48);
  }

  .progress-stats::before {
    display: none;
  }

  .progress-stat {
    min-height: 10rem;
    padding: 1.875rem 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.4);
  }

  .progress-stat + .progress-stat {
    border-left: 0;
  }

  .progress-stat:first-child {
    border-top: 0;
  }

  .progress-stat-value {
    font-size: clamp(3.5rem, 16vw, 5rem);
  }

  .progress-stat-currency {
    font-size: clamp(1.8rem, 7vw, 2.25rem);
    transform: translateY(0.55rem);
  }

  .progress-stat-label {
    font-size: 1rem;
  }

  .lead-section-row {
    min-height: 0;
  }

  .lead-copy {
    padding: 2.75rem 1rem;
  }

  .example-panel,
  .story-panel,
  .resource-panel {
    padding-inline: 1.25rem;
  }

  .panel-action-stack,
  .panel-action-button {
    width: 100%;
  }

  .embed-placeholder-panel {
    min-height: 28rem;
    padding: 1.5rem;
  }

  .alt-links-heading-shell {
    margin-bottom: 2.5rem;
  }

  .alt-links-grid {
    gap: calc(2.5rem + 10px);
  }

  .site-footer-shell {
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    padding: 2.5rem 1rem;
    text-align: center;
  }

  .site-footer-left {
    width: 100%;
  }

  .site-footer-right {
    align-items: center;
    width: 100%;
    margin-left: 0;
  }

  .site-footer-contact {
    text-align: center;
  }

  .hero-home-title {
    width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
    padding: 0.25rem 0 0.5rem;
  }

  .hero-home-title::before {
    top: -0.8125rem;
    bottom: -0.9375rem;
  }

  .hero-home-eyebrow {
    position: relative;
    left: var(--home-text-left);
    bottom: 0;
    max-width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
    margin: 1.625rem 0 0;
  }
}

@media (max-width: 575.98px) {
  .hero-home {
    --home-title-max: 23rem;
    --home-outline-right: 0.75rem;
    --home-right-gap: 0.75rem;
    min-height: 36rem;
  }

  .hero-interior {
    padding-top: clamp(12.5rem, 62vw, 18rem);
    padding-bottom: 1.5rem;
  }

  .hero-interior::before {
    height: clamp(12.5rem, 62vw, 18rem);
  }

  .hero-interior::after {
    width: calc(100% - 2rem);
  }

  .hero-home-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: inherit;
    padding: 1.5rem 0;
  }

  .hero-panel-standard {
    padding: 1.75rem 1rem 1.25rem;
  }

  .hero-panel-home {
    position: relative;
    left: 0;
    bottom: 0;
  }

  .hero-home-title {
    width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
    max-width: 100%;
    padding: 0.25rem 0 0.4375rem;
  }

  .hero-home-title::before {
    top: -0.75rem;
    bottom: -0.875rem;
  }

  .hero-home-eyebrow {
    position: relative;
    left: var(--home-text-left);
    bottom: 0;
    max-width: min(var(--home-title-max), calc(100vw - var(--home-text-left) - var(--home-outline-right) - var(--home-right-gap)));
    margin: 1.5rem 0 0;
  }

  .site-header-shell {
    padding-inline: 1rem;
  }

  .site-header-bar {
    min-height: 5rem;
    gap: 0.75rem;
  }

  .site-logo {
    height: 1.35rem;
    max-width: min(100%, 14.75rem);
  }

  .menu-button {
    gap: 0.5rem;
    padding: 0.75rem 0 0.75rem 0.75rem !important;
  }

  .menu-label {
    font-size: 0.9375rem;
  }

  .menu-icon {
    font-size: 1.5rem;
  }
}

