/* Africa Hope Outreach — palette from brand (forest green + warm gold / orange) */
:root {
    --color-bg: #f6f4ef;
    --color-surface: #ffffff;
    --color-ink: #141413;
    --color-muted: #4a4540;
    --color-brand: #2d6a4f;
    --color-brand-dark: #1b4332;
    --color-accent-rgb: 249, 168, 37;
    --color-accent: rgb(var(--color-accent-rgb));
    --color-accent-dark: rgb(var(--color-accent-rgb));
    --color-sun: rgb(var(--color-accent-rgb));
    --color-dark: #1b4332;
    --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    /* Display stacks match sans — clean NGO-style headlines (single family, strong hierarchy). */
    --font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --shadow-soft: 0 12px 40px rgba(0, 0, 0, 0.12);
    --radius: 4px;
    --container: 1120px;
}
*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--color-ink);
    background: var(--color-bg);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
    border-radius: var(--radius);
}

a {
    color: var(--color-brand);
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

a:hover {
    color: var(--color-brand-dark);
}

.container {
    width: min(100% - 2.5rem, var(--container));
    margin-inline: auto;
}

.narrow {
    max-width: 720px;
    margin-inline: auto;
}

.skip-link {
    position: absolute;
    left: -9999px;
    z-index: 999;
    padding: 0.5rem 1rem;
    background: var(--color-surface);
}

.skip-link:focus {
    left: 1rem;
    top: 1rem;
}

.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;
}

/* Header */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: transparent;
    transition: box-shadow 0.35s ease;
}

.top-bar {
    background: rgba(27, 67, 50, 0.82);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    color: #f0ebe3;
    font-size: 0.85rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.branding {
    background: rgba(255, 255, 255, 0.78);
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.top-bar a {
    color: #e8e4dc;
    text-decoration: none;
}

.top-bar a:hover {
    color: #fff;
    text-decoration: underline;
}

.top-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 2.5rem;
}

.top-bar__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.25rem;
}

.branding__inner {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1rem;
    padding-block: 1rem;
    flex-wrap: wrap;
}

.branding__extras {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

@media (min-width: 769px) {
    .branding__inner {
        gap: 0.25rem;
    }

    .branding__extras {
        display: none;
    }

    .primary-nav {
        margin-left: auto;
        margin-right: 0;
        padding: 0.75rem 0 0.75rem 1.25rem;
    }
}

.logo {
    text-decoration: none;
    color: var(--color-ink);
    display: block;
    line-height: 0;
}

.logo--image:focus-visible {
    outline: 2px solid var(--color-brand);
    outline-offset: 4px;
    border-radius: 4px;
}

.logo__img {
    display: block;
    height: auto;
    max-height: 5.5rem;
    width: auto;
    max-width: min(100%, 200px);
    border-radius: 0;
    object-fit: contain;
}

@media (min-width: 640px) {
    .logo__img {
        max-height: 6rem;
        max-width: 220px;
    }
}

.primary-nav {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    padding: 0.75rem 1.25rem;
    background: var(--color-brand);
    border-radius: var(--radius);
    box-shadow: 0 10px 24px rgba(27, 67, 50, 0.16);
}

.primary-nav a {
    position: relative;
    font-weight: 600;
    font-size: 0.95rem;
    color: #fff;
    text-decoration: none;
}

.primary-nav a:hover {
    color: var(--color-accent);
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 0.5rem;
    background: transparent;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: var(--radius);
    cursor: pointer;
}

.nav-toggle__bar {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--color-ink);
}

@media (max-width: 768px) {
    .nav-toggle {
        display: flex;
    }

    .primary-nav {
        display: none;
        width: 100%;
        flex-direction: column;
        padding-top: 1rem;
        order: 3;
        flex-basis: 100%;
        margin-left: 0;
    }

    .primary-nav.is-open {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        max-height: min(70svh, calc(100svh - 10rem));
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        scrollbar-gutter: stable;
        padding-bottom: 0.5rem;
    }

    .primary-nav.is-open a {
        flex-shrink: 0;
        padding-block: 0.35rem;
    }

    .branding__inner {
        flex-wrap: wrap;
    }

    .logo {
        order: 1;
    }

    .branding__extras {
        order: 2;
        margin-left: auto;
    }
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.65rem 1.25rem;
    font-family: inherit;
    font-weight: 600;
    font-size: 0.95rem;
    border-radius: var(--radius);
    border: 2px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.btn--sm {
    padding: 0.35rem 0.75rem;
    font-size: 0.85rem;
}

.btn--lg {
    padding: 0.85rem 1.5rem;
    font-size: 1rem;
}

.btn--accent {
    background: var(--color-accent);
    color: #1f1303;
    border-color: var(--color-accent);
}

.btn--accent:hover {
    background: linear-gradient(rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.12)), var(--color-accent);
    border-color: var(--color-accent);
    color: #1a0f02;
}

.btn--outline {
    background: transparent;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.85);
}

.btn--outline:hover {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.btn--ghost {
    background: transparent;
    color: #e8e4dc;
    border-color: rgba(255, 255, 255, 0.35);
}

.btn--ghost:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
}

/* Hero */
.hero {
    position: relative;
    min-height: min(78vh, 720px);
    display: flex;
    align-items: center;
    color: #fff;
    overflow: hidden;
}

.hero__media {
    position: absolute;
    inset: 0;
    overflow: hidden;
}

.hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero__static-bg {
    display: none;
    position: absolute;
    inset: 0;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(27, 67, 50, 0.92), transparent 50%);
    pointer-events: none;
}

.hero__content {
    position: relative;
    z-index: 1;
    padding-block: 4rem 5rem;
}

.hero__eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.2em;
    font-size: 0.8rem;
    margin: 0 0 1rem;
    opacity: 0.9;
}

.hero__title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    line-height: 1.2;
    max-width: 28ch;
    margin: 0 0 2rem;
    text-transform: none;
    letter-spacing: -0.02em;
}

.hero__subtext {
    font-size: clamp(1rem, 2.1vw, 1.125rem);
    font-weight: 400;
    line-height: 1.5;
    max-width: 42ch;
    margin: -0.5rem auto 1.75rem;
    color: #000;
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

/* Hero — two columns (headline + photo, no video).
 Uses both .hero and .hero--split on the same element; chained selector
   overrides base .hero (video hero) so layout and colors stay correct. */
.hero.hero--split {
    position: relative;
    z-index: 1;
    min-height: 0;
    display: block;
    align-items: unset;
    color: #000;
    background: #fff;
    overflow: visible;
    margin-top: 0;
    padding-top: 0;
    box-shadow: 0 14px 32px -18px rgba(0, 0, 0, 0.1);
}

.hero.hero--split .hero--split-row {
    gap: clamp(0.25rem, 1vw, 0.5rem);
    width: 100%;
    max-width: none;
    margin-inline: 0;
    align-items: center;
}

.hero.hero--split .hero--split-inner {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding: 0 0 clamp(1.25rem, 3.5vw, 2.75rem);
    padding-inline: max(0px, env(safe-area-inset-left)) max(0px, env(safe-area-inset-right));
    box-sizing: border-box;
    background: linear-gradient(
        135deg,
        #fff 0%,
        #fff 48%,
        #dcc8e0 82%,
        #c5a9cb 100%
    );
}

.hero.hero--split .hero__content {
    position: static;
    padding-block: 0;
    margin-top: 0;
    margin-inline: auto;
    max-width: 36rem;
    width: 100%;
    text-align: center;
}

.hero.hero--split .hero__actions {
    justify-content: center;
}

.hero.hero--split .hero__eyebrow {
    color: #555e6d;
    opacity: 1;
    margin-top: 0;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0.01em;
    font-size: clamp(0.95rem, 2.2vw, 1.1rem);
    line-height: 1.5;
    max-width: 36ch;
    margin-inline: auto;
}

.hero.hero--split .hero__title {
    color: #1a1a1a;
    max-width: none;
    margin-bottom: 1rem;
}

.hero.hero--split .hero__subtext {
    max-width: 38ch;
    margin-inline: auto;
}

.hero.hero--split .btn--outline.btn--lg {
    border-color: #000;
    color: #000;
    background: transparent;
}

.hero.hero--split .btn--outline.btn--lg:hover {
    border-color: #000;
    color: #fff;
    background: #000;
}

.hero.hero--split .split__media {
    padding: 0;
    margin: 0;
}

.hero.hero--split .hero--split__img,
.hero--split__img {
    display: block;
    width: 100%;
    max-width: 100%;
    max-height: min(920px, 85vh);
    height: auto;
    margin: 0;
    object-fit: contain;
    object-position: center center;
    border-radius: 0;
    box-shadow: none;
}

@media (min-width: 768px) {
    .hero.hero--split .split__media {
        align-self: stretch;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
    }

    .hero.hero--split .hero--split__img {
        width: 100%;
        max-width: 100%;
        max-height: min(980px, 88vh);
        height: auto;
    }
}

/* Sections */
.section {
    padding: clamp(3rem, 6vw, 5rem) 0;
}

.section--muted {
    background: #ebe6dc;
}

/* 225deg: line runs toward bottom-left → #f2eaf3 at top-right, #fff at bottom-left */
#intro {
    background: linear-gradient(225deg, #f2eaf3 0%, #fff 100%);
}

.section--dark {
    background: var(--color-dark);
    color: #e8e4dc;
}

.section--dark a {
    color: var(--color-sun);
}

.section--stats {
    background: var(--color-surface);
}

.section--subscribe {
    background: #ebe6dc;
}

.section--login {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.section__title {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    margin: 0 0 1.25rem;
    font-weight: 700;
}

.section__title--center {
    text-align: center;
}

.lead {
    font-size: 1.15rem;
    color: var(--color-muted);
    margin: 0;
}

.prose {
    margin: 0;
    color: var(--color-muted);
}

.prose--center {
    text-align: center;
}

.split {
    display: grid;
    gap: 2.5rem;
    align-items: center;
}

@media (min-width: 768px) {
    .split {
        grid-template-columns: 1fr 1fr;
    }
}

.split__media img {
    border-radius: var(--radius);
}

.tax-note--split {
    margin-top: 0.75rem;
    font-size: 1rem;
}

.section--band {
    background-image:
        linear-gradient(
            135deg,
            rgba(27, 67, 50, 0.92) 0%,
            rgba(27, 67, 50, 0.72) 45%,
            rgba(var(--color-accent-rgb), 0.38) 100%
        ),
        var(--band-img);
    background-size: cover;
    background-position: center;
    color: #fff;
}

.section--band .section__title {
    color: #fff;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}

.section--band .section-lede {
    color: rgba(255, 255, 255, 0.93);
}

/* Areas you can support — light panel, image cards (no photo band) */
.section--ways {
    background: #f8f9fa;
    color: var(--color-ink);
}

.section--ways .section__title {
    color: var(--color-ink);
    text-shadow: none;
}

.section--ways .section-lede {
    color: var(--color-muted);
}

.section-lede--ways {
    font-size: clamp(1.08rem, 2vw, 1.22rem);
    max-width: 42rem;
    margin-inline: auto;
}

/* Mission / vision / values — three cards (heading → image → body) */
.section--mission-cards {
    background: var(--color-bg);
}

.mission-cards {
    display: grid;
    gap: clamp(1.35rem, 3vw, 1.85rem);
    margin-top: clamp(1.5rem, 3.5vw, 2.25rem);
}

@media (min-width: 900px) {
    .mission-cards {
        grid-template-columns: repeat(3, 1fr);
        align-items: stretch;
    }
}

.mission-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--color-surface);
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 12px 36px rgba(0, 0, 0, 0.07);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.mission-card__title {
    font-family: var(--font-display);
    font-size: clamp(1.2rem, 2.1vw, 1.4rem);
    font-weight: 800;
    margin: 0;
    padding: clamp(1rem, 2vw, 1.2rem) clamp(1rem, 2vw, 1.25rem);
    text-align: center;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: #000;
    background: var(--color-accent);
    border-radius: 20px 20px 0 0;
}

.mission-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: clamp(5.75rem, 13vw, 7.5rem);
    height: clamp(5.75rem, 13vw, 7.5rem);
    margin: clamp(0.85rem, 2vw, 1.1rem) auto 0;
    border-radius: 50%;
    background: linear-gradient(
        165deg,
        rgba(45, 106, 79, 0.16) 0%,
        rgba(249, 168, 37, 0.12) 100%
    );
    color: var(--color-brand);
    box-shadow: 0 6px 22px rgba(27, 67, 50, 0.1);
}

.mission-card__glyph {
    font-size: clamp(2rem, 4.5vw, 2.85rem);
    line-height: 1;
    opacity: 0.95;
}

.mission-card__body {
    flex: 1;
    padding: clamp(1.1rem, 2vw, 1.35rem) clamp(1.1rem, 2vw, 1.35rem) clamp(1.25rem, 2.2vw, 1.5rem);
}

.mission-card__text {
    margin: 0 0 0.85rem;
    font-size: clamp(0.98rem, 1.65vw, 1.05rem);
    line-height: 1.6;
    color: var(--color-muted);
}

.mission-card__text:last-child {
    margin-bottom: 0;
}

.mission-card__list {
    margin: 0;
    padding-left: 1.2rem;
    font-size: clamp(0.98rem, 1.65vw, 1.05rem);
    line-height: 1.55;
    color: var(--color-muted);
    text-align: left;
}

.mission-card__list li {
    margin-bottom: 0.55rem;
}

.mission-card__list li:last-child {
    margin-bottom: 0;
}

.mission-card__list li::marker {
    color: var(--color-accent);
}

.mission-card__list strong {
    color: var(--color-ink);
    font-weight: 700;
}

.mission-cards__footer {
    margin: clamp(1.75rem, 3.5vw, 2.5rem) 0 0;
    text-align: center;
    font-size: 1.05rem;
}

.mission-cards__footer a {
    font-weight: 600;
    color: var(--color-brand);
}

.mission-cards__footer a:hover {
    color: var(--color-brand-dark);
}

.ways-cards {
    display: grid;
    gap: clamp(1.5rem, 3vw, 2rem);
    margin-top: clamp(1.75rem, 4vw, 2.5rem);
}

@media (min-width: 768px) {
    .ways-cards {
        grid-template-columns: repeat(3, 1fr);
        align-items: stretch;
    }
}

.ways-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #fff;
    border-radius: 26px;
    overflow: hidden;
    box-shadow: 0 16px 44px rgba(0, 0, 0, 0.07);
    border: 1px solid rgba(0, 0, 0, 0.06);
    text-decoration: none;
    color: inherit;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ways-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 24px 56px rgba(0, 0, 0, 0.11);
}

.ways-card__figure {
    margin: 0;
    aspect-ratio: 4 / 3;
    background: var(--color-brand-dark);
    overflow: hidden;
}

.ways-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 0;
}

.ways-card__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: clamp(1.35rem, 2.5vw, 1.75rem);
    text-align: center;
}

.ways-card__title {
    font-family: var(--font-sans);
    font-size: clamp(1.35rem, 2.4vw, 1.55rem);
    font-weight: 700;
    margin: 0 0 0.65rem;
    color: var(--color-ink);
    line-height: 1.25;
}

.ways-card__lead {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: clamp(1.05rem, 1.85vw, 1.15rem);
    line-height: 1.55;
}

.ways-card__list {
    margin: 0 0 1.35rem;
    padding-left: 1.35rem;
    text-align: left;
    color: var(--color-muted);
    font-size: clamp(1rem, 1.65vw, 1.08rem);
    line-height: 1.6;
}

.ways-card__list li {
    margin-bottom: 0.35rem;
}

.ways-card__list li::marker {
    color: var(--color-accent);
}

.ways-card__cta {
    margin-top: auto;
    font-weight: 700;
    font-size: clamp(1rem, 1.6vw, 1.08rem);
    color: var(--color-accent);
}

/* Pillars — photo band + staggered ring stats */
.section--pillars {
    position: relative;
    background-color: var(--color-dark);
    background-image:
        linear-gradient(180deg, rgba(15, 35, 28, 0.78) 0%, rgba(15, 35, 28, 0.55) 40%, rgba(15, 35, 28, 0.68) 100%),
        var(--pillars-bg);
    background-size: cover;
    background-position: center;
    color: #fff;
    overflow: hidden;
}

.pillars-rings {
    display: flex;
    flex-direction: column;
    gap: clamp(2.25rem, 5vw, 3.5rem);
    max-width: 920px;
    margin: 0 auto;
}

.pillar-ring {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 1.25rem 1.5rem;
    align-items: center;
    width: 100%;
}

@media (min-width: 720px) {
    .pillar-ring {
        max-width: min(100%, 38rem);
    }

    .pillar-ring--offset {
        margin-left: auto;
        margin-right: 0;
    }

    .pillar-ring--offset-alt {
        margin-left: 0;
        margin-right: auto;
    }
}

.pillar-ring__visual {
    position: relative;
    width: clamp(132px, 26vw, 196px);
    flex-shrink: 0;
    color: var(--color-sun);
}

.pillar-ring__svg {
    display: block;
    width: 100%;
    height: auto;
    vertical-align: middle;
}

.pillar-ring__pct {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: clamp(1.4rem, 3.2vw, 2.1rem);
    letter-spacing: -0.02em;
    color: var(--color-sun);
    pointer-events: none;
}

.pillar-ring__title {
    font-family: var(--font-display);
    font-size: clamp(1.55rem, 2.85vw, 2rem);
    font-weight: 700;
    margin: 0 0 0.5rem;
    color: #fff;
    line-height: 1.25;
}

.pillar-ring__desc {
    margin: 0;
    color: rgba(255, 255, 255, 0.92);
    font-size: clamp(1.08rem, 2vw, 1.2rem);
    line-height: 1.6;
}

.cards {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .cards {
        grid-template-columns: repeat(3, 1fr);
    }
}

.card {
    display: block;
    padding: 1.75rem;
    background: var(--color-surface);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
    text-decoration: none;
    color: inherit;
    border: 1px solid rgba(0, 0, 0, 0.06);
    transition: transform 0.15s, box-shadow 0.15s;
}

.card:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.14);
}

.card__title {
    font-family: var(--font-display);
    font-size: 1.35rem;
    margin: 0 0 0.5rem;
}

.card__text {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: 0.98rem;
}

.card__cta {
    font-weight: 600;
    color: var(--color-accent-dark);
}

.stats {
    display: grid;
    gap: 2rem;
    margin-top: 2rem;
}

@media (min-width: 640px) {
    .stats {
        grid-template-columns: 1fr 1fr;
    }
}

.stat {
    text-align: center;
    padding: 1.5rem;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: var(--radius);
    background: var(--color-bg);
}

.stat__value {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 700;
    margin: 0 0 0.5rem;
    color: var(--color-accent-dark);
}

.stat__label {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.95rem;
}

.fine-print {
    margin-top: 1.5rem;
    text-align: center;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.fine-print code {
    font-size: 0.8rem;
}

.subscribe {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: center;
    margin-top: 1.5rem;
}

.subscribe__input {
    flex: 1 1 220px;
    max-width: 360px;
    padding: 0.75rem 1rem;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: var(--radius);
    font: inherit;
}

/* Footer */
.footer-cta {
    background: var(--color-dark);
    color: #e8e4dc;
    padding: 3rem 0;
    text-align: center;
}

.footer-cta__title {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2rem);
    margin: 0 0 1.5rem;
}

.footer-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

.footer-main {
    padding: 3rem 0;
    background: #161b22;
    color: #c8c2b6;
}

.footer-grid {
    display: grid;
    gap: 2.5rem;
}

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

.footer-brand {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1.25rem;
    color: #fff;
    margin: 0 0 0.5rem;
}

.footer-tagline {
    margin: 0;
    max-width: 36ch;
}

.footer-heading {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0 0 1rem;
    color: #fff;
}

.footer-meta {
    font-size: 0.9rem;
    opacity: 0.85;
}

.footer-main a {
    color: var(--color-sun);
    text-decoration: none;
}

.footer-main a:hover {
    text-decoration: underline;
}

.footer-legal {
    background: #0d1117;
    color: #8b8275;
    font-size: 0.85rem;
    padding: 1.5rem 0;
}

.footer-legal__inner {
    text-align: center;
}

.footer-legal p {
    margin: 0.35rem 0;
}

.footer-legal__links a {
    color: #c8c2b6;
}

/* Inner pages (colors unchanged — layout & typography only) */
.primary-nav a.is-active {
    color: #fff;
    font-weight: 700;
}

.page-header {
    background: linear-gradient(135deg, rgba(45, 106, 79, 0.12), rgba(var(--color-accent-rgb), 0.08));
    padding: clamp(2rem, 5vw, 3.5rem) 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.page-header--compact {
    padding: clamp(0.9rem, 2vw, 1.4rem) 0;
}

.page-header--compact .page-header__title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    margin-bottom: 0.2rem;
}

.page-header--compact .page-header__lede {
    font-size: 0.95rem;
}

.page-header__title {
    font-family: var(--font-display);
    font-size: clamp(1.85rem, 4vw, 2.75rem);
    font-weight: 700;
    margin: 0 0 0.35rem;
}

.page-header__lede {
    margin: 0;
    color: var(--color-muted);
    font-size: 1.1rem;
}

/* Children feed must stay visible — data loads via JS inside this section */
main > .children-feed-page.reveal,
.children-feed-page.reveal {
    opacity: 1;
    transform: none;
}

.children-feed-page {
    --care-search-sticky-top: var(--site-header-offset, 10.5rem);
    padding: clamp(2rem, 4vw, 3rem) 0 clamp(3rem, 6vw, 4rem);
    background: linear-gradient(180deg, #f7f8fb 0%, #f2f4f8 100%);
}

/* Care Villages model — two-column editorial (no embedded child feed) */
.care-villages-merge {
    padding: clamp(2rem, 4vw, 3rem) 0 clamp(3rem, 6vw, 4rem);
    background: linear-gradient(180deg, #f7f8fb 0%, #f2f4f8 100%);
}

.care-villages-merge__shell {
    display: flex;
    flex-direction: column;
    gap: clamp(1.25rem, 2.5vw, 1.75rem);
}

.care-villages-merge__layout {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.75rem, 3.5vw, 3rem);
    align-items: start;
}

.care-villages-merge__col {
    display: flex;
    flex-direction: column;
    gap: clamp(1.5rem, 3vw, 2.25rem);
    min-width: 0;
}

.care-villages-merge__narrative,
.care-villages-merge__detail {
    max-width: none;
    margin: 0;
    padding: 0;
    min-width: 0;
}

.children-feed__float-search {
    display: block;
    margin: 0;
    padding: 0.55rem 0.65rem;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: saturate(180%) blur(10px);
    -webkit-backdrop-filter: saturate(180%) blur(10px);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 999px;
    box-shadow: 0 14px 38px rgba(15, 23, 42, 0.12);
}

.children-feed__float-row {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1.35fr) minmax(0, 0.95fr) minmax(0, 0.75fr) minmax(max-content, auto);
    gap: 0.35rem;
    align-items: center;
}

.children-feed__float-field {
    position: relative;
    display: flex;
    align-items: center;
    min-width: 0;
}

.children-feed__float-field i {
    position: absolute;
    left: 0.75rem;
    color: rgba(27, 67, 50, 0.5);
    font-size: 0.85rem;
    pointer-events: none;
}

.children-feed__float-field input {
    width: 100%;
    min-width: 0;
    padding: 0.55rem 0.75rem 0.55rem 2rem;
    border: 1px solid transparent;
    border-radius: 999px;
    background: transparent;
    color: var(--color-ink);
    font: inherit;
    font-size: 0.92rem;
    transition: background 0.2s ease, border-color 0.2s ease;
}

.children-feed__float-field input::placeholder {
    color: rgba(0, 0, 0, 0.45);
}

.children-feed__float-field input:focus {
    outline: none;
    background: rgba(45, 106, 79, 0.06);
    border-color: rgba(45, 106, 79, 0.25);
}

.children-feed__float-field--select select {
    width: 100%;
    min-width: 0;
    padding: 0.55rem 1.85rem 0.55rem 2rem;
    border: 1px solid transparent;
    border-radius: 999px;
    background: transparent;
    color: var(--color-ink);
    font: inherit;
    font-size: 0.88rem;
    line-height: 1.25;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, rgba(27, 67, 50, 0.55) 50%), linear-gradient(135deg, rgba(27, 67, 50, 0.55) 50%, transparent 50%);
    background-position: calc(100% - 1rem) calc(50% - 0.12rem), calc(100% - 0.72rem) calc(50% - 0.12rem);
    background-size: 0.32rem 0.32rem, 0.32rem 0.32rem;
    background-repeat: no-repeat;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.children-feed__float-field--select select:focus {
    outline: none;
    background-color: rgba(45, 106, 79, 0.06);
    border-color: rgba(45, 106, 79, 0.25);
}

.children-feed__field select {
    width: 100%;
    padding: 0.65rem 0.85rem;
    border: 1px solid rgba(27, 67, 50, 0.18);
    border-radius: 12px;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
    font-size: 0.92rem;
    cursor: pointer;
}

.children-feed__field select:focus {
    outline: none;
    border-color: rgba(45, 106, 79, 0.45);
    box-shadow: 0 0 0 3px rgba(45, 106, 79, 0.12);
}

.children-feed__float-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.children-feed__float-submit,
.children-feed__float-clear {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.55rem 1.1rem;
    border-radius: 999px;
    font-size: 0.9rem;
    white-space: nowrap;
}

.children-feed__filter-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 0.25rem;
}

.children-feed__filter-actions .btn {
    flex: 1 1 auto;
    justify-content: center;
    gap: 0.45rem;
}

.children-feed__filter-clear,
.children-feed__float-clear {
    flex-shrink: 0;
    color: var(--color-brand-dark);
    background: #fff;
    border-color: rgba(27, 67, 50, 0.35);
}

.children-feed__filter-clear:hover:not(:disabled),
.children-feed__float-clear:hover:not(:disabled) {
    color: var(--color-brand-dark);
    background: rgba(45, 106, 79, 0.08);
    border-color: var(--color-brand);
}

.children-feed__filter-clear:disabled,
.children-feed__float-clear:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    color: var(--color-muted);
    border-color: rgba(27, 67, 50, 0.2);
}

.children-feed__filter-clear.is-active,
.children-feed__float-clear.is-active {
    opacity: 1;
}

@media (max-width: 1100px) {
    .care-villages-merge__layout {
        grid-template-columns: 1fr;
    }

}

@media (max-width: 640px) {
    .children-feed__float-search {
        border-radius: 20px;
        padding: 0.6rem;
    }

    .children-feed__float-row {
        grid-template-columns: 1fr 1fr;
    }

    .children-feed__float-field--select {
        grid-column: 1 / -1;
    }

    .children-feed__float-field input,
    .children-feed__float-field--select select {
        padding: 0.6rem 1.85rem 0.6rem 2rem;
    }

    .children-feed__float-actions {
        grid-column: 1 / -1;
        justify-content: stretch;
    }

    .children-feed__float-actions .btn {
        flex: 1 1 auto;
        justify-content: center;
        padding: 0.7rem 1rem;
    }
}

.children-feed__layout {
    display: grid;
    grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.children-feed__sidebar {
    position: sticky;
    top: 1.5rem;
}

.children-feed__filters {
    display: grid;
    gap: 1rem;
    padding: 1.2rem;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 22px;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
}

.children-feed__filters-title {
    margin: 0;
    font-size: 1.1rem;
}

.children-feed__field {
    display: grid;
    gap: 0.45rem;
    font-weight: 600;
}

.children-feed__field input {
    width: 100%;
    padding: 0.8rem 0.95rem;
    border: 1px solid rgba(27, 67, 50, 0.18);
    border-radius: 0.9rem;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
}

.children-feed__filters-submit {
    width: 100%;
}

.children-feed__filters .children-feed__filter-actions .children-feed__filters-submit {
    width: auto;
    flex: 1 1 55%;
}

.children-feed__content {
    min-width: 0;
}

.children-feed__stack {
    max-width: 610px;
    margin: 0 auto;
    display: grid;
    gap: 1.5rem;
}

.children-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(27, 67, 50, 0.1);
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.07);
    transition: box-shadow 0.22s ease, border-color 0.22s ease, transform 0.22s ease;
}

.children-card:hover {
    border-color: rgba(45, 106, 79, 0.2);
    box-shadow: 0 22px 48px rgba(15, 23, 42, 0.11);
}

.children-card__header {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    padding: 1.1rem 1.2rem 0.85rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.children-card__avatar {
    flex: 0 0 56px;
    width: 56px;
    height: 56px;
    border-radius: 999px;
    border: 3px solid #1877f2;
    padding: 2px;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 8px 18px rgba(24, 119, 242, 0.16);
}

.children-card__avatar-img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center 10%;
    border-radius: 999px;
}

.children-card__heading {
    flex: 1;
    min-width: 0;
}

.children-card__title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.children-card__title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(1.05rem, 1.8vw, 1.28rem);
    font-weight: 700;
    line-height: 1.2;
    color: var(--color-brand-dark);
}

.children-card__status {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    padding: 0.28rem 0.65rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    line-height: 1.2;
    white-space: nowrap;
}

.children-card__status--sponsored {
    background: rgba(45, 106, 79, 0.12);
    color: var(--color-brand-dark);
    border: 1px solid rgba(45, 106, 79, 0.22);
}

.children-card__status--waiting {
    background: rgba(var(--color-accent-rgb), 0.18);
    color: #7a4d00;
    border: 1px solid rgba(var(--color-accent-rgb), 0.45);
}

.children-card__status--neutral {
    background: #f1f3f6;
    color: var(--color-muted);
    border: 1px solid rgba(0, 0, 0, 0.08);
}

.children-card__child-id,
.children-card__location {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0.35rem 0 0;
    font-size: 0.84rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--color-muted);
}

.children-card__child-id i,
.children-card__location i {
    color: var(--color-brand);
    font-size: 0.78rem;
    opacity: 0.85;
}

.children-card__hero {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: 1fr;
    background: #f8fafc;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 16px;
    margin: 0 1.1rem 1.1rem;
    padding: 0.95rem 1rem;
}

@media (min-width: 720px) {
    .children-card__hero {
        grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
        align-items: center;
    }
}

.children-card__details {
    min-width: 0;
}

.children-card__figure {
    margin: 0;
    aspect-ratio: 4 / 5;
    max-height: min(72vw, 420px);
    background: #e8eeeb;
    overflow: hidden;
    display: block;
    padding: 0;
    max-width: 100%;
    width: 100%;
    margin-inline: auto;
    border: 0;
    border-radius: 18px;
    cursor: zoom-in;
}

.children-card__img {
    width: 100%;
    height: 100%;
    display: block;
    border-radius: 18px;
    object-fit: cover;
    object-position: center 15%;
}

.children-card__figure:focus-visible {
    outline: 3px solid rgba(24, 119, 242, 0.28);
    outline-offset: 4px;
}

@media (max-width: 960px) {
    .children-feed__layout {
        grid-template-columns: 1fr;
    }

    .children-feed__sidebar {
        top: 0.75rem;
        z-index: 2;
    }

    .children-feed__stack {
        max-width: none;
    }
}

.children-card__meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem 1rem;
}

.children-card__meta-grid dt {
    margin: 0;
    font-size: 0.64rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-muted);
}

.children-card__meta-grid dd {
    margin: 0.1rem 0 0;
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--color-ink);
}

.children-card__body {
    padding: 1rem 1.2rem 1.2rem;
}

.children-card__story {
    margin-bottom: 1rem;
}

.children-card__story-inner {
    position: relative;
}

.children-card__story.is-collapsed .children-card__story-inner {
    max-height: 7.5rem;
    overflow: hidden;
}

.children-card__story.is-collapsed .children-card__story-inner::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), #fff);
    pointer-events: none;
}

.children-card__summary {
    margin: 0 0 0.75rem;
    color: #4b5563;
    line-height: 1.65;
    font-size: 0.94rem;
}

.children-card__summary:last-child {
    margin-bottom: 0;
}

.children-card__read-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.5rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-brand);
    font-size: 0.88rem;
    font-weight: 700;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.children-card__read-toggle:hover {
    color: var(--color-brand-dark);
}

.children-card__action-bar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
    margin-bottom: 1rem;
    padding: 0.85rem;
    border-radius: 16px;
    background: linear-gradient(180deg, #f8faf9 0%, #f2f6f4 100%);
    border: 1px solid rgba(45, 106, 79, 0.12);
}

.children-card__comment-btn {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    min-height: 3.35rem;
    padding: 0.7rem 0.95rem;
    border: 1px solid rgba(45, 106, 79, 0.22);
    border-radius: 14px;
    background: linear-gradient(135deg, #ffffff 0%, #f4faf7 100%);
    color: var(--color-brand-dark);
    text-align: left;
    cursor: pointer;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.07);
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.children-card__comment-btn:hover {
    transform: translateY(-1px);
    border-color: rgba(45, 106, 79, 0.38);
    background: linear-gradient(135deg, #ffffff 0%, #ebf5f0 100%);
    box-shadow: 0 10px 24px rgba(45, 106, 79, 0.14);
}

.children-card__comment-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(45, 106, 79, 0.22), 0 8px 22px rgba(15, 23, 42, 0.1);
}

.children-card__comment-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 12px;
    background: rgba(45, 106, 79, 0.12);
    color: var(--color-brand);
    font-size: 1.05rem;
}

.children-card__comment-btn-copy {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    flex: 1 1 auto;
    min-width: 0;
}

.children-card__comment-btn-title {
    font-size: 0.95rem;
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-brand-dark);
}

.children-card__comment-btn-sub {
    font-size: 0.78rem;
    font-weight: 500;
    line-height: 1.35;
    color: var(--color-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.children-card__comment-btn-chevron {
    flex-shrink: 0;
    font-size: 0.8rem;
    color: rgba(27, 67, 50, 0.45);
    transition: transform 0.18s ease, color 0.18s ease;
}

.children-card__comment-btn:hover .children-card__comment-btn-chevron {
    transform: translateX(2px);
    color: var(--color-brand);
}

.children-card__action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    min-height: 2.65rem;
    padding: 0.55rem 1rem;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.18s ease, background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.children-card__action:hover {
    transform: translateY(-1px);
}

.children-card__action--ghost {
    background: #fff;
    color: var(--color-brand-dark);
    border-color: rgba(45, 106, 79, 0.22);
    box-shadow: 0 4px 14px rgba(15, 23, 42, 0.06);
}

.children-card__action--ghost:hover {
    background: rgba(45, 106, 79, 0.06);
}

.children-card__action--primary {
    background: var(--color-accent);
    color: #1a0f02;
    border-color: rgba(var(--color-accent-rgb), 0.5);
    box-shadow: 0 8px 22px rgba(var(--color-accent-rgb), 0.28);
}

.children-card__action--primary:hover {
    background: #e9a020;
    color: #1a0f02;
}

.children-card__sponsor-btn.is-disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
    filter: grayscale(0.2);
    box-shadow: none;
}

.children-card__sponsor-btn.is-disabled:hover {
    transform: none;
    background: var(--color-accent);
    color: #1a0f02;
}

.children-card__sponsor-hint {
    margin: 0;
    font-size: 0.78rem;
    line-height: 1.35;
    color: var(--color-muted);
}

.children-card__sponsor-wrap {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.55rem;
    flex: 1 1 12rem;
    min-width: min(100%, 12rem);
}

.children-card__sponsor-btn {
    width: 100%;
    justify-content: center;
}

.children-card__amount-menu {
    display: grid;
    gap: 0.4rem;
}

.children-card__amount-label {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-muted);
}

.children-card__amount-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.children-card__amount-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    border: 1px solid rgba(45, 106, 79, 0.2);
    background: #fff;
    color: var(--color-brand-dark);
    font: inherit;
    font-size: 0.82rem;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.children-card__amount-chip:hover,
.children-card__amount-chip:focus-visible {
    background: var(--color-brand);
    border-color: var(--color-brand);
    color: #fff;
}

.children-card__amount-chip.is-selected {
    background: var(--color-brand);
    border-color: var(--color-brand);
    color: #fff;
    box-shadow: 0 4px 12px rgba(45, 106, 79, 0.28);
}

.children-card__comments {
    margin-top: 0.25rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.children-card__comments-head {
    margin-bottom: 0.75rem;
}

.children-card__comments-title {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin: 0;
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--color-ink);
}

.children-card__comments-hint {
    margin: 0.35rem 0 0;
    font-size: 0.84rem;
    line-height: 1.45;
    color: var(--color-muted);
}

.children-card__comments-list {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: grid;
    gap: 0.75rem;
}

.children-card__comment {
    padding: 0.85rem 0.95rem;
    border-radius: 14px;
    background: #f8fafc;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.children-card__comment-text {
    margin: 0;
    color: var(--color-ink);
    line-height: 1.55;
    font-size: 0.94rem;
}

.children-card__comment-date {
    display: inline-block;
    margin-top: 0.45rem;
    font-size: 0.82rem;
    color: var(--color-muted);
}

.children-card__comments-empty {
    margin: 0;
    padding: 0.85rem 1rem;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px dashed rgba(45, 106, 79, 0.2);
    color: var(--color-muted);
    font-size: 0.9rem;
    line-height: 1.5;
    text-align: center;
}

@media (max-width: 640px) {
    .children-card__header {
        padding: 0.9rem 0.95rem 0.75rem;
    }

    .children-card__hero {
        margin: 0 0.85rem 0.85rem;
        padding: 0.75rem 0.85rem;
    }

    .children-card__body {
        padding: 0.85rem 0.95rem 1rem;
    }

    .children-card__title {
        font-size: 1.05rem;
        flex: 1 1 8rem;
        min-width: 0;
        overflow-wrap: anywhere;
    }

    .children-card__status {
        font-size: 0.68rem;
        padding: 0.22rem 0.5rem;
        white-space: normal;
        text-align: center;
        max-width: 100%;
    }

    .children-card__child-id,
    .children-card__location {
        font-size: 0.8rem;
        overflow-wrap: anywhere;
    }

    .children-card__figure {
        aspect-ratio: 3 / 4;
        max-height: min(85vw, 360px);
    }

    .children-card__summary {
        font-size: 0.9rem;
        overflow-wrap: anywhere;
    }

    .children-card__action-bar {
        padding: 0.75rem;
    }

    .children-card__comment-btn-sub {
        white-space: normal;
        overflow: visible;
        text-overflow: unset;
    }

    .children-card__sponsor-wrap {
        min-width: 100%;
        flex: 1 1 100%;
    }

    .children-card__meta-grid {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {
    .children-card:hover,
    .children-card__action:hover,
    .children-card__comment-btn:hover {
        transform: none;
    }
}

.children-comment-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.children-comment-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.52);
}

.children-comment-modal__dialog {
    position: relative;
    width: min(92vw, 560px);
    margin: min(10vh, 5rem) auto 0;
    background: #fff;
    border-radius: 22px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.24);
    padding: 1.5rem;
    z-index: 1;
}

.children-comment-modal__close {
    position: absolute;
    top: 0.9rem;
    right: 0.9rem;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: #f3f4f6;
    color: var(--color-ink);
    cursor: pointer;
}

.children-comment-modal__title {
    margin: 0 0 0.35rem;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--color-ink);
}

.children-comment-modal__child {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: 0.95rem;
}

.children-comment-modal__form {
    display: grid;
    gap: 0.8rem;
}

.children-comment-modal__input {
    width: 100%;
    min-height: 130px;
    resize: vertical;
    padding: 0.9rem 1rem;
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, 0.14);
    background: #fff;
    color: var(--color-ink);
    font: inherit;
}

.children-comment-modal__input:focus {
    outline: 2px solid rgba(45, 106, 79, 0.18);
    border-color: var(--color-brand);
}

.children-comment-modal__actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.children-comment-modal__status {
    color: var(--color-muted);
    font-size: 0.95rem;
}

body.modal-open {
    overflow: hidden;
}

.children-feed__status {
    max-width: 760px;
    margin: 1.25rem auto 0;
    padding: 0.95rem 1rem;
    text-align: center;
    color: var(--color-muted);
    font-weight: 600;
}

.children-feed__sentinel {
    height: 1px;
}

.children-image-modal {
    position: fixed;
    inset: 0;
    z-index: 1250;
}

.children-image-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.72);
}

.children-image-modal__dialog {
    position: relative;
    width: min(94vw, 860px);
    margin: min(6vh, 3rem) auto 0;
    background: #fff;
    border-radius: 24px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.3);
    padding: 1.25rem 1.25rem 1.35rem;
    z-index: 1;
}

.children-image-modal__close {
    position: absolute;
    top: 0.9rem;
    right: 0.9rem;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: #f3f4f6;
    color: var(--color-ink);
    cursor: pointer;
}

.children-image-modal__title {
    margin: 0 0 0.35rem;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--color-ink);
}

.children-image-modal__child {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: 0.95rem;
}

.children-image-modal__frame {
    display: flex;
    align-items: center;
    justify-content: center;
    max-height: 78vh;
    overflow: auto;
    background: #f8fafc;
    border-radius: 18px;
    padding: 0.75rem;
}

.children-image-modal__img {
    display: block;
    width: auto;
    max-width: 100%;
    max-height: 72vh;
    height: auto;
    border-radius: 14px;
}

/* Governance — board hero + trustee cards */
.governance-page {
    --gov-card-radius: 24px;
}

.gov-hero {
    position: relative;
    padding: clamp(3.25rem, 8vw, 5.25rem) 0 clamp(5.5rem, 12vw, 7.5rem);
    text-align: center;
    overflow: hidden;
}

.gov-hero__bg {
    position: absolute;
    inset: 0;
    background-color: var(--color-brand-dark);
    background-image: linear-gradient(
            180deg,
            rgba(27, 67, 50, 0.55) 0%,
            rgba(27, 40, 50, 0.82) 100%
        ),
        var(--gov-hero-img);
    background-size: cover;
    background-position: center;
}

.gov-hero__overlay {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 20%, rgba(249, 168, 37, 0.12), transparent 55%),
        linear-gradient(to top, rgba(27, 40, 50, 0.55), transparent 50%);
    pointer-events: none;
}

.gov-hero__inner {
    position: relative;
    z-index: 2;
    max-width: 44rem;
    margin-inline: auto;
}

.gov-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 1rem;
    padding: 0.35rem 0.85rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.2);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.92);
}

.gov-hero__eyebrow-dot {
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    background: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.35);
}

.gov-hero__title {
    margin: 0 0 1rem;
    font-family: var(--font-sans);
    font-weight: 800;
    font-size: clamp(2rem, 5vw, 3.15rem);
    line-height: 1.12;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.gov-hero__title--slate {
    color: #f0ebe3;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.45);
}

.gov-hero__title--accent {
    color: var(--color-sun);
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.35);
}

.gov-hero__lede {
    margin: 0 auto 1.35rem;
    max-width: 36rem;
    font-size: clamp(1.05rem, 2.2vw, 1.2rem);
    font-style: italic;
    color: rgba(240, 235, 227, 0.95);
    line-height: 1.55;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
}

.gov-hero__badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem 0.65rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.gov-hero__badges li {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.75rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.14);
    font-size: 0.82rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.92);
}

.gov-hero__badges i {
    color: var(--color-sun);
    font-size: 0.78rem;
}

.gov-hero__scroll {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin-top: 1.75rem;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.28);
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    text-decoration: none;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
    animation: gov-scroll-bounce 2.2s ease-in-out infinite;
}

.gov-hero__scroll:hover {
    background: rgba(255, 255, 255, 0.16);
    border-color: rgba(255, 255, 255, 0.45);
    transform: translateY(2px);
}

@keyframes gov-scroll-bounce {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(5px);
    }
}

.gov-hero__waves {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    line-height: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.gov-wave {
    display: block;
    width: 100%;
    height: clamp(48px, 8vw, 72px);
}

.gov-wave--brand {
    color: var(--color-brand);
    margin-bottom: -1px;
}

.gov-wave--dark {
    color: var(--color-brand-dark);
    height: clamp(40px, 6vw, 56px);
}

.gov-board {
    background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-surface) 12%, var(--color-surface) 100%);
    padding: clamp(2.75rem, 6vw, 4.25rem) 0 clamp(2.5rem, 5vw, 3.5rem);
    margin-top: -2px;
    scroll-margin-top: var(--site-header-offset, 6rem);
}

.gov-board__intro {
    max-width: 40rem;
    margin: 0 auto clamp(2rem, 5vw, 2.75rem);
    text-align: center;
}

.gov-board__eyebrow {
    margin: 0 0 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-brand);
}

.gov-board__title {
    margin: 0 0 0.75rem;
    font-family: var(--font-display);
    font-size: clamp(1.65rem, 3.5vw, 2.15rem);
    line-height: 1.2;
    color: var(--color-brand-dark);
}

.gov-board__lede {
    margin: 0;
    font-size: 1.02rem;
    line-height: 1.65;
    color: var(--color-muted);
}

.gov-principles {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem;
    margin: 0 0 clamp(2.25rem, 5vw, 3rem);
    padding: 0;
    list-style: none;
}

@media (min-width: 640px) {
    .gov-principles {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .gov-principles {
        grid-template-columns: repeat(4, 1fr);
        gap: 1rem;
    }
}

.gov-principles__item {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(45, 106, 79, 0.1);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.gov-principles__item:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.08);
}

.gov-principles__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 12px;
    background: rgba(45, 106, 79, 0.1);
    color: var(--color-brand);
    font-size: 0.95rem;
}

.gov-principles__name {
    margin: 0 0 0.2rem;
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--color-brand-dark);
}

.gov-principles__text {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--color-muted);
}

.gov-grid {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    display: grid;
    gap: clamp(1.5rem, 4vw, 2rem);
    grid-template-columns: 1fr;
    max-width: 52rem;
}

@media (min-width: 768px) {
    .gov-grid {
        grid-template-columns: repeat(2, 1fr);
        max-width: 56rem;
    }
}

.gov-grid__item {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.55s ease, transform 0.55s ease;
    transition-delay: var(--gov-card-delay, 0ms);
}

.gov-grid__item.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.gov-card {
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
    border-radius: var(--gov-card-radius);
    overflow: visible;
    background: var(--color-brand-dark);
    box-shadow: var(--shadow-soft);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.gov-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.22);
}

.gov-card__banner {
    height: clamp(5.5rem, 12vw, 7rem);
    border-radius: var(--gov-card-radius) var(--gov-card-radius) 0 0;
    background: linear-gradient(
        165deg,
        color-mix(in srgb, var(--color-accent) 70%, #fff) 0%,
        var(--color-accent) 52%,
        color-mix(in srgb, var(--color-accent) 80%, #000) 100%
    );
}

.gov-card__body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    padding: 0 1.35rem 1.65rem;
    text-align: center;
    color: #fff;
    border-radius: 0 0 var(--gov-card-radius) var(--gov-card-radius);
    background: var(--color-brand-dark);
}

.gov-card__avatar-wrap {
    width: clamp(6.25rem, 16vw, 7.25rem);
    height: clamp(6.25rem, 16vw, 7.25rem);
    margin: calc(clamp(3rem, 8vw, 3.6rem) * -1) auto 0.75rem;
    border-radius: 50%;
    border: 4px solid #fff;
    background: #fff;
    overflow: hidden;
    position: relative;
    z-index: 2;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.14);
}

.gov-card__avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.gov-card__initials {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    color: var(--color-brand-dark);
    background: linear-gradient(145deg, var(--color-bg), #ebe6dc);
}

.gov-card__content {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    align-items: center;
}

.gov-card__name {
    font-family: var(--font-sans);
    font-size: clamp(1.15rem, 2.2vw, 1.3rem);
    font-weight: 700;
    margin: 0 0 0.45rem;
    color: #fff;
    line-height: 1.25;
}

.gov-card__role {
    margin: 0 0 0.75rem;
}

.gov-card__role-badge {
    display: inline-block;
    padding: 0.28rem 0.65rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.22);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.92);
}

.gov-card__bio {
    margin: 0 0 1rem;
    font-size: 0.88rem;
    line-height: 1.55;
    color: rgba(232, 228, 220, 0.9);
    text-align: center;
    flex: 1 1 auto;
}

.gov-card__email {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    max-width: 100%;
    margin-top: auto;
    padding: 0.55rem 0.85rem;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.08);
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-sun);
    text-decoration: none;
    word-break: break-word;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.gov-card__email:hover {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.35);
    color: #fff9ec;
}

.gov-card__email i {
    flex-shrink: 0;
    font-size: 0.9rem;
}

.gov-cta {
    padding: clamp(2.5rem, 6vw, 3.5rem) 0 clamp(3.5rem, 8vw, 5rem);
    background: linear-gradient(135deg, var(--color-brand-dark) 0%, #163d2e 100%);
}

.gov-cta__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
    text-align: center;
}

@media (min-width: 768px) {
    .gov-cta__inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        text-align: left;
        gap: 2rem;
    }
}

.gov-cta__copy {
    max-width: 32rem;
}

.gov-cta__title {
    margin: 0 0 0.5rem;
    font-family: var(--font-display);
    font-size: clamp(1.35rem, 3vw, 1.75rem);
    color: #fff;
    line-height: 1.25;
}

.gov-cta__text {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.82);
}

.gov-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: center;
}

@media (min-width: 768px) {
    .gov-cta__actions {
        flex-shrink: 0;
        justify-content: flex-end;
    }
}

.gov-cta__btn-outline {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.45);
    background: transparent;
}

.gov-cta__btn-outline:hover {
    color: var(--color-brand-dark);
    background: #fff;
    border-color: #fff;
}

@media (prefers-reduced-motion: reduce) {
    .gov-hero__scroll {
        animation: none;
    }

    .gov-grid__item {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .gov-card:hover,
    .gov-principles__item:hover {
        transform: none;
    }
}

.content-prose {
    max-width: 760px;
    padding: clamp(2rem, 5vw, 3.5rem) 0 4rem;
    margin-inline: auto;
}

.content-prose h2 {
    font-family: var(--font-display);
    font-size: 1.65rem;
    margin: 2.25rem 0 0.75rem;
}

.content-prose h2:first-child {
    margin-top: 0;
}

.content-prose h3 {
    font-size: 1.15rem;
    margin: 1.75rem 0 0.5rem;
}

.content-prose p,
.content-prose address {
    margin: 0 0 1rem;
    color: var(--color-muted);
}

.content-prose__nav {
    margin-top: 2rem !important;
    text-align: center;
}

.about-page__content {
    max-width: 900px;
}

.about-page__content::after {
    content: "";
    display: block;
    clear: both;
}

.about-page__figure {
    float: right;
    width: clamp(280px, 52%, 520px);
    margin: 0 0 0.75rem 0.35rem;
    shape-outside: margin-box;
}

.about-page__figure img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 18px;
    -webkit-mask-image: linear-gradient(to left, #000 70%, transparent 100%),
                        linear-gradient(to top, #000 85%, transparent 100%);
    -webkit-mask-composite: source-in;
            mask-image: linear-gradient(to left, #000 70%, transparent 100%),
                        linear-gradient(to top, #000 85%, transparent 100%);
            mask-composite: intersect;
}

@media (max-width: 600px) {
    .about-page__figure {
        float: none;
        width: 100%;
        margin: 0 0 1.25rem;
    }

    .about-page__figure img {
        -webkit-mask-image: none;
                mask-image: none;
    }
}

.pillars__intro {
    margin-bottom: 1.5rem;
    color: var(--color-muted);
}

.pillars {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
    margin: 1rem 0 2.5rem;
    clear: both;
    overflow: clip;
    padding: 1rem 0;
}

.pillar {
    position: relative;
    padding: 2rem 1.5rem 1.75rem;
    background: var(--color-surface);
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 18px;
    box-shadow: 0 10px 25px -18px rgba(15, 23, 42, 0.3);
    transform-origin: left center;
    transition:
        transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1),
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.pillar:nth-child(1) { transform: translate(-70px,  -6px) rotate(-4deg); z-index: 4; }
.pillar:nth-child(2) { transform: translate(-155px, -2px) rotate(-2deg); z-index: 3; }
.pillar:nth-child(3) { transform: translate(-240px,  2px) rotate( 1deg); z-index: 2; }
.pillar:nth-child(4) { transform: translate(-325px,  6px) rotate( 3deg); z-index: 1; }

.pillars.is-visible .pillar {
    transform: translate(0, 0) rotate(0);
}

.pillars.is-visible .pillar:nth-child(1) { transition-delay: 0ms; }
.pillars.is-visible .pillar:nth-child(2) { transition-delay: 90ms; }
.pillars.is-visible .pillar:nth-child(3) { transition-delay: 180ms; }
.pillars.is-visible .pillar:nth-child(4) { transition-delay: 270ms; }

/* When leaving the viewport, cards stack back in reverse so card 4 re-enters last */
.pillars:not(.is-visible) .pillar:nth-child(1) { transition-delay: 270ms; }
.pillars:not(.is-visible) .pillar:nth-child(2) { transition-delay: 180ms; }
.pillars:not(.is-visible) .pillar:nth-child(3) { transition-delay: 90ms; }
.pillars:not(.is-visible) .pillar:nth-child(4) { transition-delay: 0ms; }

@media (max-width: 700px) {
    .pillar:nth-child(1),
    .pillar:nth-child(2),
    .pillar:nth-child(3),
    .pillar:nth-child(4) {
        transform: translate(-30px, 0) rotate(-2deg);
    }
}

.pillar::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, var(--color-brand), var(--color-accent));
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.5s ease;
}

.pillars.is-visible .pillar:hover {
    box-shadow: 0 26px 44px -20px rgba(15, 23, 42, 0.4);
    border-color: rgba(45, 106, 79, 0.3);
}

.pillar:hover::before {
    transform: scaleX(1);
}

.pillar__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    color: #fff;
    font-size: 1.4rem;
    background: linear-gradient(135deg, var(--color-brand), var(--color-brand-dark));
    box-shadow: 0 10px 20px -10px rgba(45, 106, 79, 0.6);
    transition: transform 0.45s cubic-bezier(0.2, 0.8, 0.2, 1), background 0.35s ease;
}

.pillar:hover .pillar__icon {
    transform: rotate(-6deg) scale(1.08);
    background: linear-gradient(135deg, var(--color-accent), #e38a00);
    animation: pillar-icon-bounce 0.7s ease;
}

.pillar__number {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    font-family: var(--font-display);
    font-size: 1.35rem;
    font-weight: 700;
    color: rgba(45, 106, 79, 0.18);
    letter-spacing: 0.05em;
    transition: color 0.35s ease;
}

.pillar:hover .pillar__number {
    color: rgba(var(--color-accent-rgb), 0.55);
}

.pillar__title {
    font-family: var(--font-display);
    font-size: 1.15rem;
    line-height: 1.3;
    margin: 1rem 0 0.75rem;
    color: var(--color-ink);
}

.pillar__list {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    color: var(--color-muted);
    font-size: 0.95rem;
}

.pillar__list li {
    position: relative;
    padding: 0.3rem 0 0.3rem 1.4rem;
    line-height: 1.45;
}

.pillar__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.65rem;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.18);
    transition: transform 0.3s ease;
}

.pillar:hover .pillar__list li::before {
    transform: scale(1.15);
}

.pillar__tagline {
    margin: 0.75rem 0 0;
    padding-top: 0.75rem;
    border-top: 1px dashed rgba(0, 0, 0, 0.1);
    font-style: italic;
    color: var(--color-brand-dark);
    font-weight: 500;
}

@keyframes pillar-icon-bounce {
    0% { transform: rotate(-6deg) scale(1.08); }
    40% { transform: rotate(8deg) scale(1.15); }
    70% { transform: rotate(-3deg) scale(1.1); }
    100% { transform: rotate(-6deg) scale(1.08); }
}

@media (prefers-reduced-motion: reduce) {
    .pillar,
    .pillar:nth-child(1),
    .pillar:nth-child(2),
    .pillar:nth-child(3),
    .pillar:nth-child(4) {
        transform: none;
        transition: none;
    }

    .pillar::before,
    .pillar__icon,
    .pillar__list li::before,
    .pillar__number {
        transition: none;
    }

    .pillar:hover .pillar__icon {
        animation: none;
    }
}

.content-list {
    margin: 0 0 1rem 1.1rem;
    padding: 0;
    color: var(--color-muted);
}

.content-list li {
    margin-bottom: 0.5rem;
}

.content-list--numbered {
    list-style: decimal;
}

.content-list--plain {
    list-style: none;
    margin-left: 0;
}

.contact-grid {
    display: grid;
    gap: 2rem;
    padding: clamp(2rem, 5vw, 3.5rem) 0 4rem;
}

@media (min-width: 768px) {
    .contact-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.contact-card {
    padding: 1.75rem;
    background: var(--color-surface);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
}

.contact-card__title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    margin: 0 0 1rem;
}

.contact-card p {
    margin: 0 0 0.75rem;
    color: var(--color-muted);
}

.contact-card__meta {
    font-size: 0.9rem;
    color: var(--color-muted);
}

.table-wrap {
    overflow-x: auto;
    padding: clamp(2rem, 5vw, 3.5rem) 0 4rem;
}

.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.98rem;
}

.data-table th,
.data-table td {
    padding: 0.75rem 1rem;
    text-align: left;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.data-table th {
    background: rgba(45, 106, 79, 0.1);
    font-weight: 600;
}

.postal-block {
    font-style: normal;
    padding: 1rem 1.25rem;
    background: #ebe6dc;
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
}

.donate-panel {
    margin: 2.5rem 0;
    padding: 1.75rem;
    background: var(--color-surface);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
}

.donate-panel__title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    margin: 0 0 0.5rem;
}

.donate-panel__note {
    font-size: 0.9rem;
    color: var(--color-muted);
    margin: 0 0 1.25rem;
}

.donate-fieldset {
    border: none;
    margin: 0 0 1.25rem;
    padding: 0;
}

.donate-fieldset legend {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.donate-option {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-right: 1.25rem;
    cursor: pointer;
}

.donate-amounts {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.donate-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.65rem;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: var(--radius);
    font-size: 0.9rem;
    cursor: pointer;
}

.donate-field {
    margin-bottom: 1rem;
}

.donate-field label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.35rem;
    font-size: 0.95rem;
}

.donate-field input[type="text"] {
    width: 100%;
    max-width: 280px;
    padding: 0.6rem 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.15);
    border-radius: var(--radius);
    font: inherit;
}

.donate-field--inline input {
    max-width: 160px;
}

.donate-actions {
    margin-top: 1.5rem;
}

.footer-grid--3 {
    grid-template-columns: 1fr;
}

@media (min-width: 900px) {
    .footer-grid--3 {
        grid-template-columns: 1.2fr 1fr 1fr;
    }
}

.prose-gap {
    margin-top: 1rem !important;
}

.cart-page__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.tax-note {
    margin-top: 1rem !important;
}

.section-lede {
    margin-bottom: 2rem !important;
}

/* ---------- Motion & animation (palette unchanged) ---------- */

.site-header--scrolled {
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

.site-header--scrolled .top-bar {
    background: rgba(27, 67, 50, 0.9);
}

.site-header--scrolled .branding {
    background: rgba(255, 255, 255, 0.9);
}

@keyframes heroFadeUp {
    from {
        opacity: 0;
        transform: translateY(1.5rem);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.hero__content--animate > * {
    opacity: 0;
    animation: heroFadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.hero__content--animate > *:nth-child(1) {
    animation-delay: 0.1s;
}

.hero__content--animate > *:nth-child(2) {
    animation-delay: 0.26s;
}

.hero__content--animate > *:nth-child(3) {
    animation-delay: 0.42s;
}

.hero__content--animate > *:nth-child(4) {
    animation-delay: 0.58s;
}

.reveal {
    opacity: 0;
    transform: translateY(1.75rem);
    transition:
        opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--reveal-delay, 0ms);
}

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

.primary-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -3px;
    width: 0;
    height: 2px;
    background: var(--color-accent);
    transition: width 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}

.primary-nav a:hover::after,
.primary-nav a.is-active::after {
    width: 100%;
}

.btn--accent,
.btn--outline {
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        background 0.15s ease,
        border-color 0.15s ease,
        color 0.15s ease;
}

.btn--accent:hover,
.btn--outline:hover {
    transform: translateY(-2px);
}

.cards .card {
    transition:
        transform 0.22s ease,
        box-shadow 0.22s ease,
        border-color 0.2s ease;
}

@media (max-width: 768px) {
    .primary-nav.is-open {
        animation: navDrop 0.35s cubic-bezier(0.22, 1, 0.36, 1) both;
    }
}

@keyframes navDrop {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .hero__video {
        display: none !important;
    }

    .hero__static-bg {
        display: block !important;
    }

    .hero__content--animate > * {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
    }

    .reveal {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }

    .primary-nav a::after {
        transition: none !important;
    }

    .btn--accent:hover,
    .btn--outline:hover {
        transform: none;
    }

    .primary-nav.is-open {
        animation: none !important;
    }
}

html.motion-reduced .hero__video {
    display: none !important;
}

html.motion-reduced .hero__static-bg {
    display: block !important;
}

html.motion-reduced .hero__content--animate > * {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
}

html.motion-reduced .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
}

html.motion-reduced .btn--accent:hover,
html.motion-reduced .btn--outline:hover {
    transform: none;
}

.header-auth-link,
.header-auth-logout__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.75rem;
    padding: 0.55rem 0.9rem;
    border: 1px solid rgba(27, 67, 50, 0.32);
    border-radius: var(--radius);
    background: var(--color-brand);
    color: #fff;
    font: inherit;
    font-weight: 600;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(27, 67, 50, 0.16);
    transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.header-auth-link:hover,
.header-auth-logout__button:hover,
.header-auth-link--active {
    color: #1f1303;
    background: var(--color-accent);
    border-color: rgba(var(--color-accent-rgb), 0.55);
    box-shadow: 0 12px 28px rgba(var(--color-accent-rgb), 0.24);
}

.header-auth-logout {
    margin: 0;
}

.auth-page {
    padding: 4rem 0 5rem;
}

.auth-page__container {
    display: flex;
    justify-content: center;
}

.auth-card {
    width: min(100%, 30rem);
    padding: 2rem;
    background: #fff;
    border: 1px solid rgba(27, 67, 50, 0.12);
    border-radius: 1.25rem;
    box-shadow: 0 24px 60px rgba(16, 24, 40, 0.08);
}

.auth-card__eyebrow {
    margin: 0 0 0.5rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.8rem;
    color: var(--color-brand);
}

.auth-card__title {
    margin: 0;
}

.auth-card__copy {
    margin: 0.75rem 0 1.5rem;
    color: var(--color-muted);
}

.auth-form {
    display: grid;
    gap: 1rem;
}

.auth-form__field,
.admin-form__field {
    display: grid;
    gap: 0.45rem;
    font-weight: 600;
}

.auth-form__field input,
.admin-form__field input,
.admin-form__field select,
.admin-form__field textarea,
.admin-comment-form textarea {
    width: 100%;
    padding: 0.8rem 0.95rem;
    border: 1px solid rgba(27, 67, 50, 0.18);
    border-radius: 0.9rem;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
}

.auth-form__submit {
    width: 100%;
}

.children-comment-modal__note {
    margin: -0.5rem 0 1rem;
    color: var(--color-muted);
}

.admin-body {
    background: #f4f6f3;
}

.admin-shell {
    display: grid;
    grid-template-columns: minmax(15rem, 18rem) minmax(0, 1fr);
    min-height: 100vh;
}

.admin-sidebar {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 2rem 1.5rem;
    background: #183f30;
    color: #fff;
}

.admin-sidebar__brand {
    color: #fff;
    text-decoration: none;
}

.admin-sidebar__eyebrow {
    display: block;
    margin-bottom: 0.35rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.75rem;
    opacity: 0.72;
}

.admin-sidebar__nav {
    display: grid;
    gap: 0.45rem;
}

.admin-sidebar__nav a {
    display: block;
    padding: 0.8rem 0.95rem;
    border-radius: 0.9rem;
    color: rgba(255, 255, 255, 0.85);
    text-decoration: none;
    font-weight: 600;
}

.admin-sidebar__nav a:hover,
.admin-sidebar__nav a.is-active {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.admin-sidebar__footer {
    margin-top: auto;
    display: grid;
    gap: 0.75rem;
}

.admin-sidebar__user {
    margin: 0;
    color: rgba(255, 255, 255, 0.8);
}

.admin-sidebar__logout {
    width: 100%;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.24);
}

.admin-main {
    padding: 2rem;
}

.admin-main__header {
    margin-bottom: 1.5rem;
}

.admin-main__title {
    margin: 0;
}

.admin-alert {
    margin-bottom: 1rem;
    padding: 0.9rem 1rem;
    border-radius: 0.9rem;
    border: 1px solid transparent;
}

.admin-alert--success {
    background: rgba(38, 166, 91, 0.12);
    border-color: rgba(38, 166, 91, 0.25);
    color: #14532d;
}

.admin-alert--error {
    background: rgba(220, 53, 69, 0.1);
    border-color: rgba(220, 53, 69, 0.18);
    color: #7f1d1d;
}

.admin-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.admin-stat,
.admin-panel {
    background: #fff;
    border: 1px solid rgba(27, 67, 50, 0.1);
    border-radius: 1.1rem;
    box-shadow: 0 18px 42px rgba(16, 24, 40, 0.05);
}

.admin-stat {
    padding: 1.1rem 1.25rem;
}

.admin-stat__label {
    display: block;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.admin-stat__value {
    display: block;
    margin-top: 0.3rem;
    font-size: 1.8rem;
}

.admin-stack {
    display: grid;
    gap: 1rem;
}

.admin-panel {
    padding: 1.25rem;
}

.admin-panel__title {
    margin: 0;
}

.admin-panel__subtitle {
    margin: 0.35rem 0 0;
    color: var(--color-muted);
}

.admin-comment-form,
.admin-form {
    display: grid;
    gap: 1rem;
}

.admin-comment-form {
    margin-top: 1rem;
}

.admin-comment-form__actions,
.admin-form__actions,
.admin-toolbar,
.admin-table__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.admin-toolbar {
    justify-content: space-between;
    margin-bottom: 1rem;
}

.admin-toolbar__copy {
    margin: 0;
    color: var(--color-muted);
}

.admin-form--two-column {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-form__field--full {
    grid-column: 1 / -1;
}

.admin-form__error {
    color: #b42318;
    font-weight: 500;
}

.admin-table-wrap {
    overflow-x: auto;
}

.admin-table-filters {
    margin-bottom: 1rem;
}

.admin-table-filters__field {
    display: grid;
    gap: 0.45rem;
    max-width: 28rem;
    font-weight: 600;
}

.admin-table-filters__input {
    width: 100%;
    padding: 0.8rem 0.95rem;
    border: 1px solid rgba(27, 67, 50, 0.18);
    border-radius: 0.9rem;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
}

.admin-table {
    width: 100%;
    border-collapse: collapse;
}

.admin-table tbody tr:nth-child(even) {
    background: rgba(27, 67, 50, 0.035);
}

.admin-table tbody tr:hover {
    background: rgba(var(--color-accent-rgb), 0.08);
}

.admin-table th,
.admin-table td {
    padding: 0.95rem 0.75rem;
    border-bottom: 1px solid rgba(27, 67, 50, 0.08);
    text-align: left;
    vertical-align: top;
}

.admin-table th {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-muted);
}

.admin-empty {
    margin: 0;
    color: var(--color-muted);
}

.admin-empty--compact {
    margin-top: 1rem;
}

.admin-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.3rem;
    height: 2.3rem;
    border: 1px solid rgba(27, 67, 50, 0.16);
    border-radius: 999px;
    background: #fff;
    color: var(--color-brand);
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.15s ease;
}

.admin-icon-button:hover {
    background: rgba(27, 67, 50, 0.06);
    color: var(--color-brand);
    border-color: rgba(27, 67, 50, 0.24);
    transform: translateY(-1px);
}

.admin-icon-button--danger {
    color: #b42318;
    border-color: rgba(180, 35, 24, 0.24);
}

.admin-icon-button--danger:hover {
    background: rgba(180, 35, 24, 0.08);
    color: #8a1c12;
    border-color: rgba(180, 35, 24, 0.32);
}

/* Data grid (admin tables) — see .cursor/rules/data-grids.mdc */
.data-grid {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.data-grid__toolbar {
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1rem 1.25rem;
}

.data-grid__toolbar-start {
    display: flex;
    flex: 1 1 18rem;
    flex-direction: column;
    gap: 0.75rem;
    min-width: min(100%, 16rem);
}

.data-grid__toolbar-end {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
}

.data-grid__search {
    position: relative;
    display: block;
    max-width: 36rem;
}

.data-grid__search i {
    position: absolute;
    left: 0.85rem;
    top: 50%;
    transform: translateY(-50%);
    color: rgba(27, 67, 50, 0.45);
    font-size: 0.9rem;
    pointer-events: none;
}

.data-grid__search-input {
    width: 100%;
    padding: 0.65rem 0.85rem 0.65rem 2.35rem;
    border: 1px solid rgba(16, 185, 129, 0.35);
    border-radius: 0.65rem;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
    font-size: 0.92rem;
}

.data-grid__search-input:focus {
    outline: none;
    border-color: var(--color-brand);
    box-shadow: 0 0 0 3px rgba(45, 106, 79, 0.15);
}

.data-grid__per-page {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--color-muted);
}

.data-grid__per-page select {
    padding: 0.45rem 0.65rem;
    border: 1px solid rgba(16, 185, 129, 0.35);
    border-radius: 0.5rem;
    background: #fff;
    font: inherit;
    font-size: 0.88rem;
    color: var(--color-ink);
}

.data-grid__table-shell {
    border: 1px solid rgba(16, 185, 129, 0.28);
    border-radius: 0.75rem;
    overflow: hidden;
    background: #fff;
}

.data-grid__table-wrap {
    margin: 0;
}

.data-grid__table {
    font-size: 0.8125rem;
}

.data-grid__table thead th {
    padding: 0.7rem 0.65rem;
    background: #0d9488;
    color: #fff;
    border-bottom: 1px solid rgba(16, 185, 129, 0.45);
    text-transform: none;
    letter-spacing: 0;
    font-size: 0.78rem;
    font-weight: 700;
    vertical-align: middle;
}

.data-grid__sort {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
}

.data-grid__sort:hover,
.data-grid__sort:focus-visible {
    color: #ecfdf5;
    outline: none;
}

.data-grid__sort.is-active {
    color: #fff;
}

.data-grid__sort-icon {
    opacity: 0.65;
    font-size: 0.72rem;
}

.data-grid__sort.is-active .data-grid__sort-icon {
    opacity: 1;
}

.data-grid__table tbody td {
    padding: 0.45rem 0.65rem;
    border-bottom: 1px solid rgba(16, 185, 129, 0.14);
    vertical-align: middle;
}

.data-grid__row--even {
    background: #fff;
}

.data-grid__row--odd {
    background: rgba(16, 185, 129, 0.04);
}

.data-grid__table tbody tr:hover {
    background: rgba(16, 185, 129, 0.1);
}

.data-grid__table tbody tr[data-grid-state] td {
    padding: 2rem 1rem;
    text-align: center;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.data-grid__table tbody tr[data-grid-state="error"] td {
    color: #b42318;
}

.data-grid__cell-truncate {
    max-width: 11rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.data-grid__col-actions {
    width: auto;
    min-width: 5.5rem;
    white-space: nowrap;
}

.data-grid__actions {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.4rem;
}

.data-grid__delete-form {
    display: inline-flex;
    align-items: center;
    margin: 0;
    vertical-align: middle;
}

.data-grid__badge {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1.3;
    background: rgba(27, 67, 50, 0.1);
    color: var(--color-brand-dark);
}

.data-grid__badge--success {
    background: rgba(45, 106, 79, 0.14);
    color: var(--color-brand-dark);
}

.data-grid__badge--warn {
    background: rgba(var(--color-accent-rgb), 0.18);
    color: #7a4e00;
}

.data-grid__badge--danger {
    background: rgba(180, 35, 24, 0.12);
    color: #8a1c12;
}

.data-grid__cell-comment {
    max-width: 18rem;
}

.admin-modal__subtitle {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: 0.92rem;
}

.data-grid__status-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.35rem;
}

.data-grid__status-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.75rem;
    border: 1px solid rgba(27, 67, 50, 0.18);
    border-radius: 999px;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.data-grid__status-pill:hover {
    border-color: rgba(27, 67, 50, 0.32);
    background: rgba(27, 67, 50, 0.04);
}

.data-grid__status-pill.is-active {
    background: var(--color-brand-dark);
    border-color: var(--color-brand-dark);
    color: #fff;
    box-shadow: 0 2px 8px rgba(27, 67, 50, 0.2);
}

.data-grid__status-pill.is-active .data-grid__status-pill-count {
    background: rgba(255, 255, 255, 0.2);
    color: #fff;
}

.data-grid__status-pill--pending.is-active {
    background: #7a4e00;
    border-color: #7a4e00;
}

.data-grid__status-pill--approved.is-active {
    background: var(--color-brand-dark);
    border-color: var(--color-brand-dark);
}

.data-grid__status-pill--deleted.is-active {
    background: #8a1c12;
    border-color: #8a1c12;
}

.data-grid__status-pill-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.35rem;
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
    background: rgba(27, 67, 50, 0.1);
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1.2;
}

.data-grid__footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.data-grid__range {
    margin: 0;
    font-size: 0.88rem;
    color: var(--color-muted);
}

.data-grid__pager {
    display: flex;
    gap: 0.5rem;
}

.btn--sm {
    padding: 0.45rem 0.85rem;
    font-size: 0.85rem;
}

/* Admin modal (child edit/create) */
body.admin-modal-open {
    overflow: hidden;
}

.admin-modal[hidden] {
    display: none !important;
}

.admin-modal {
    position: fixed;
    inset: 0;
    z-index: 1400;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
}

.admin-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(3px);
}

.admin-modal__dialog {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    width: min(100%, 52rem);
    max-height: min(92vh, 900px);
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 24px 64px rgba(15, 23, 42, 0.28);
    overflow: hidden;
}

.admin-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(27, 67, 50, 0.1);
    background: linear-gradient(180deg, #f8faf9 0%, #fff 100%);
}

.admin-modal__title {
    margin: 0;
    font-family: var(--font-display);
    font-size: 1.25rem;
    color: var(--color-brand-dark);
}

.admin-modal__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 1px solid rgba(27, 67, 50, 0.16);
    border-radius: 999px;
    background: #fff;
    color: var(--color-muted);
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.admin-modal__close:hover {
    background: rgba(27, 67, 50, 0.06);
    color: var(--color-brand-dark);
    border-color: rgba(27, 67, 50, 0.28);
}

.admin-modal__body {
    padding: 1.25rem;
    overflow: auto;
}

.admin-modal__loading,
.admin-modal__error {
    margin: 0;
    color: var(--color-muted);
    text-align: center;
}

.admin-modal__error {
    color: #b42318;
}

.admin-modal__form {
    margin: 0;
}

.admin-modal__form-actions {
    justify-content: flex-end;
}

.admin-form__picture {
    display: grid;
    gap: 0.65rem;
}

.admin-form__picture-preview-wrap {
    display: inline-flex;
    padding: 0.35rem;
    border-radius: 12px;
    border: 1px solid rgba(27, 67, 50, 0.14);
    background: #f8faf9;
}

.admin-form__picture-preview {
    display: block;
    width: 7.5rem;
    height: 7.5rem;
    object-fit: cover;
    border-radius: 10px;
}

.admin-form__file-input {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0.55rem 0.65rem;
    border: 1px solid rgba(27, 67, 50, 0.18);
    border-radius: 0.9rem;
    background: #fff;
    color: var(--color-ink);
    font: inherit;
    cursor: pointer;
}

.admin-form__picture input[type="file"] {
    position: static;
    opacity: 1;
    width: 100%;
    height: auto;
    padding: 0.55rem 0.65rem;
}

.admin-modal .btn--outline,
.admin-modal .btn--ghost {
    color: var(--color-ink);
    border-color: rgba(27, 67, 50, 0.16);
}

.admin-modal .btn--outline:hover,
.admin-modal .btn--ghost:hover {
    background: rgba(27, 67, 50, 0.06);
    color: var(--color-brand);
}

.admin-form__hint {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--color-muted);
}

.admin-form__hint code {
    font-size: 0.78rem;
    padding: 0.1rem 0.3rem;
    border-radius: 4px;
    background: rgba(27, 67, 50, 0.08);
}

.admin-form__location {
    display: grid;
    gap: 0.5rem;
}

.admin-form__location-custom {
    width: 100%;
}

.admin-form__location-custom[hidden],
.admin-form__location [data-location-select][hidden],
.admin-form__location-back[hidden] {
    display: none !important;
}

.admin-form__location[data-location-mode="new"] [data-location-select] {
    display: none !important;
}

.admin-form__location[data-location-mode="new"] [data-location-custom] {
    display: block !important;
}

.admin-form__location[data-location-mode="list"] [data-location-custom] {
    display: none !important;
}

.admin-form__location-back {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-brand);
    font: inherit;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.admin-form__location-back:hover {
    color: var(--color-brand-dark);
}

.admin-panel .btn--ghost,
.admin-panel .btn--outline,
.admin-sidebar .btn--ghost {
    color: var(--color-ink);
    border-color: rgba(27, 67, 50, 0.16);
}

.admin-sidebar .btn--ghost {
    color: #fff;
}

.admin-panel .btn--ghost:hover,
.admin-panel .btn--outline:hover {
    background: rgba(27, 67, 50, 0.06);
    color: var(--color-brand);
}

.admin-button--danger {
    color: #b42318;
    border-color: rgba(180, 35, 24, 0.24);
}

.admin-button--danger:hover {
    background: rgba(180, 35, 24, 0.08);
    color: #8a1c12;
}

@media (max-width: 960px) {
    .admin-shell {
        grid-template-columns: 1fr;
    }

    .admin-sidebar {
        padding-bottom: 1.25rem;
    }

    .admin-summary,
    .admin-form--two-column {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .branding__extras {
        gap: 0.4rem;
    }

    .header-auth-link,
    .header-auth-logout__button {
        padding-inline: 0.7rem;
    }

    .admin-main {
        padding: 1.25rem;
    }

    .auth-card {
        padding: 1.5rem;
    }
}

/* Story tabs — uses global brand colors (:root) */
.section--pr-tabs {
    padding: clamp(1.75rem, 4vw, 3rem) 0;
    overflow: visible;
}

.pr-tabs__intro {
    margin-bottom: clamp(1.25rem, 3vw, 2rem);
    text-align: center;
}

.pr-tabs__section-title {
    font-family: var(--font-display);
    font-size: clamp(1.65rem, 3.5vw, 2.35rem);
    font-weight: 700;
    line-height: 1.25;
    color: var(--color-ink);
    margin: 0;
    max-width: 42ch;
    margin-inline: auto;
}

/* Tab card: narrower than main .container for focus */
.section--pr-tabs .pr-tabs {
    width: min(100% - 2.5rem, 960px);
    max-width: 100%;
    margin-inline: auto;
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--shadow-soft);
    border: 1px solid rgba(45, 106, 79, 0.12);
}

.pr-tabs__nav-row {
    background: var(--color-surface);
    border-bottom: 1px solid rgba(45, 106, 79, 0.12);
}

.pr-tabs__nav-inner {
    width: 100%;
    max-width: none;
    padding: 0;
}

.pr-tabs__tablist {
    display: flex;
    width: 100%;
}

.pr-tabs__tab {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 0;
    min-width: 0;
    margin: 0;
    padding: 1.35rem 0.65rem;
    min-height: 4.25rem;
    font-family: var(--font-sans);
    font-size: clamp(0.95rem, 1.8vw, 1.15rem);
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: none;
    text-align: center;
    line-height: 1.3;
    text-decoration: none;
    color: var(--color-muted);
    background: var(--color-surface);
    border: none;
    border-right: 1px solid rgba(45, 106, 79, 0.12);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.pr-tabs__tab:last-child {
    border-right: none;
}

.pr-tabs__tab:hover {
    background: rgba(var(--color-accent-rgb), 0.18);
    color: var(--color-brand-dark);
}

.pr-tabs__tab.is-active {
    background: var(--color-accent);
    color: var(--color-ink);
    text-decoration: underline;
    text-underline-offset: 4px;
}

.pr-tabs__tab:focus-visible {
    outline: 2px solid var(--color-brand);
    outline-offset: -2px;
    z-index: 1;
}

.pr-tabs__body {
    position: relative;
}

.pr-tabs__split {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    min-height: min(70vh, 640px);
    width: 100%;
}

.pr-tabs__figure {
    margin: 0;
    min-height: 280px;
    background: var(--color-brand-dark);
}

.pr-tabs__figure img {
    width: 100%;
    height: 100%;
    min-height: 280px;
    object-fit: cover;
    display: block;
    border-radius: 0;
}

.pr-tabs__content-col {
    position: relative;
    background-color: var(--color-brand-dark);
    background-image:
        repeating-linear-gradient(
            90deg,
            transparent,
            transparent 10px,
            rgba(255, 255, 255, 0.05) 10px,
            rgba(255, 255, 255, 0.05) 11px
        ),
        linear-gradient(
            155deg,
            var(--color-brand-dark) 0%,
            var(--color-brand) 48%,
            var(--color-brand-dark) 100%
        );
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(1.75rem, 4vw, 3rem);
}

.pr-tabs__panel {
    margin: 0;
}

.pr-tabs__panel-title {
    font-family: "Great Vibes", cursive;
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 400;
    line-height: 1.15;
    color: #fff9ec;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.45);
    margin: 0 0 1.25rem;
    text-transform: none;
}

.pr-tabs__text {
    margin: 0 0 1rem;
    color: rgba(255, 255, 255, 0.95);
    font-size: 1.02rem;
    line-height: 1.75;
}

.pr-tabs__text:last-child {
    margin-bottom: 0;
}

.pr-tabs__text strong {
    color: var(--color-accent);
    font-weight: 700;
    letter-spacing: 0.04em;
}

@media (max-width: 900px) {
    .pr-tabs__split {
        grid-template-columns: 1fr;
        min-height: unset;
    }

    .pr-tabs__figure {
        min-height: 240px;
        max-height: 45vh;
    }

    .pr-tabs__figure img {
        max-height: 45vh;
    }

    .pr-tabs__tab {
        font-size: clamp(0.78rem, 2.5vw, 0.95rem);
        padding: 1.1rem 0.35rem;
        min-height: 3.75rem;
        letter-spacing: 0.02em;
    }
}

/* ============================================================
   GIVE PAGE — hero, impact tiles, donate card, areas, quote,
   involved cards, methods, FAQ, sticky bar
   ============================================================ */

.give-section__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-accent-dark);
    margin: 0 0 0.5rem;
}

.give-section__eyebrow::before {
    content: "";
    width: 1.75rem;
    height: 2px;
    background: currentColor;
    display: inline-block;
}

.give-section__title {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 2.5vw + 1rem, 2.4rem);
    line-height: 1.1;
    margin: 0 0 0.75rem;
    color: var(--color-brand-dark);
}

.give-section__lede {
    max-width: 58ch;
    color: var(--color-muted);
    margin: 0 0 2.25rem;
    font-size: 1.05rem;
}

/* Hero ----------------------------------------------------- */
.give-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(3rem, 6vw, 5.5rem) 0 clamp(3.5rem, 6vw, 6rem);
    isolation: isolate;
}

.give-hero__bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(1200px 600px at 85% -10%, rgba(var(--color-accent-rgb), 0.28), transparent 60%),
        radial-gradient(900px 500px at -10% 110%, rgba(45, 106, 79, 0.22), transparent 60%),
        linear-gradient(180deg, #fdfaf3 0%, var(--color-bg) 100%);
}

.give-hero__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(rgba(27, 67, 50, 0.08) 1px, transparent 1px);
    background-size: 22px 22px;
    mask-image: radial-gradient(ellipse at 50% 40%, #000 20%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 40%, #000 20%, transparent 75%);
    opacity: 0.8;
}

.give-hero__inner {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: clamp(1.5rem, 4vw, 4rem);
    align-items: center;
}

.give-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    background: rgba(var(--color-accent-rgb), 0.15);
    color: var(--color-accent-dark);
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 0.02em;
    margin: 0 0 1.25rem;
}

.give-hero__eyebrow i {
    color: #d9534f;
    animation: giveHeartbeat 1.6s ease-in-out infinite;
}

@keyframes giveHeartbeat {
    0%, 60%, 100% { transform: scale(1); }
    20% { transform: scale(1.18); }
    40% { transform: scale(0.95); }
}

.give-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.2rem, 4.5vw + 0.5rem, 4rem);
    line-height: 1.02;
    margin: 0 0 1rem;
    color: var(--color-brand-dark);
    letter-spacing: -0.015em;
}

.give-hero__title-accent {
    display: block;
    background: linear-gradient(100deg, var(--color-accent) 0%, #d97706 50%, var(--color-accent) 100%);
    background-size: 200% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    animation: giveShimmer 6s ease-in-out infinite;
}

@keyframes giveShimmer {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}

.give-hero__lede {
    max-width: 52ch;
    color: var(--color-muted);
    font-size: clamp(1rem, 0.5vw + 0.95rem, 1.2rem);
    margin: 0 0 1.75rem;
}

.give-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.give-hero__btn {
    border-radius: 999px;
    padding-inline: 1.5rem;
    box-shadow: 0 16px 40px -16px rgba(var(--color-accent-rgb), 0.55);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.give-hero__btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 48px -18px rgba(var(--color-accent-rgb), 0.65);
}

.give-hero__btn i {
    margin-right: 0.45rem;
}

.give-hero__btn--ghost {
    background: transparent;
    color: var(--color-brand-dark);
    border: 1.5px solid rgba(27, 67, 50, 0.2);
    box-shadow: none;
}

.give-hero__btn--ghost:hover {
    background: rgba(27, 67, 50, 0.06);
    border-color: var(--color-brand-dark);
    box-shadow: none;
}

.give-hero__trust {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 1.4rem;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.give-hero__trust li {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.give-hero__trust i {
    color: var(--color-brand);
}

.give-hero__figure {
    position: relative;
    margin: 0;
    justify-self: center;
    max-width: 520px;
    width: 100%;
}

.give-hero__figure::before {
    content: "";
    position: absolute;
    inset: 8% -4% -4% 8%;
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.35), rgba(45, 106, 79, 0.35));
    border-radius: 2rem;
    filter: blur(28px);
    z-index: -1;
    animation: giveFloat 6s ease-in-out infinite;
}

@keyframes giveFloat {
    0%, 100% { transform: translate(0, 0) rotate(0); }
    50% { transform: translate(6px, -8px) rotate(1deg); }
}

.give-hero__figure img {
    border-radius: 1.25rem;
    box-shadow: 0 40px 80px -24px rgba(27, 67, 50, 0.4);
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    object-position: center 20%;
}

.give-hero__badge {
    position: absolute;
    left: -0.5rem;
    bottom: 1.5rem;
    background: var(--color-surface);
    padding: 0.9rem 1.1rem;
    border-radius: 1rem;
    box-shadow: 0 24px 40px -20px rgba(0, 0, 0, 0.4);
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 9.5rem;
    border-left: 4px solid var(--color-accent);
    animation: giveFloat 7s ease-in-out infinite reverse;
}

.give-hero__badge-num {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--color-brand-dark);
    line-height: 1;
}

.give-hero__badge-text {
    font-size: 0.78rem;
    color: var(--color-muted);
    line-height: 1.3;
}

@media (max-width: 900px) {
    .give-hero__inner { grid-template-columns: 1fr; }
    .give-hero__figure { order: -1; max-width: 380px; }
    .give-hero__badge { left: 1rem; bottom: -0.5rem; }
}

/* Impact tiles -------------------------------------------- */
.give-impact {
    padding: 0 0 clamp(2.5rem, 4vw, 4rem);
}

.impact-tiles {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    background: var(--color-surface);
    padding: 1.75rem clamp(1rem, 2vw, 2rem);
    border-radius: 1.25rem;
    box-shadow: 0 30px 60px -30px rgba(27, 67, 50, 0.25);
    border: 1px solid rgba(27, 67, 50, 0.06);
    position: relative;
    margin-top: -3rem;
    z-index: 3;
}

.impact-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.45rem;
    padding: 0.5rem 0.75rem;
    border-right: 1px dashed rgba(27, 67, 50, 0.12);
}

.impact-tile:last-child { border-right: 0; }

.impact-tile__icon {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.18), rgba(var(--color-accent-rgb), 0.05));
    color: var(--color-accent-dark);
    font-size: 1.2rem;
    transition: transform 0.35s ease;
}

.impact-tile:hover .impact-tile__icon {
    transform: rotate(-6deg) scale(1.08);
}

.impact-tile__num {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 1vw + 1.3rem, 2.25rem);
    font-weight: 800;
    color: var(--color-brand-dark);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.impact-tile__suffix {
    color: var(--color-accent-dark);
    margin-left: 0.1rem;
}

.impact-tile__label {
    font-size: 0.82rem;
    color: var(--color-muted);
    max-width: 18ch;
    line-height: 1.3;
}

@media (max-width: 780px) {
    .impact-tiles { grid-template-columns: repeat(2, 1fr); margin-top: -1.5rem; }
    .impact-tile { border-right: 0; border-bottom: 1px dashed rgba(27, 67, 50, 0.12); padding-bottom: 1rem; }
    .impact-tile:nth-last-child(-n+2) { border-bottom: 0; padding-bottom: 0.5rem; }
}

/* Sponsor a child — two-column grid (+ lazy load) */
.sponsor-child-page {
    padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3rem, 5vw, 4.5rem);
    overflow-x: clip;
    background:
        radial-gradient(ellipse 85% 50% at 50% 0%, rgba(var(--color-accent-rgb), 0.08), transparent 55%),
        linear-gradient(180deg, var(--color-surface) 0%, #eef3f1 100%);
    border-bottom: 1px solid rgba(27, 67, 50, 0.06);
}

.sponsor-child-page__container {
    max-width: 1100px;
    margin-inline: auto;
    padding-inline: clamp(0.85rem, 3.5vw, 1.25rem);
    box-sizing: border-box;
}

.sponsor-child-page__search {
    position: sticky;
    top: var(--care-search-sticky-top, var(--site-header-offset, 6.5rem));
    z-index: 40;
    margin: 0 0 clamp(1.75rem, 3vw, 2.25rem);
    padding: 0.5rem 0 0.65rem;
    background: rgba(255, 255, 255, 0.94);
    border-bottom: 1px solid rgba(27, 67, 50, 0.08);
    box-shadow: 0 8px 24px -22px rgba(27, 67, 50, 0.4);
    transition: box-shadow 0.22s ease, background 0.22s ease, padding 0.22s ease;
}

.sponsor-child-page__search-toggle {
    display: none;
    width: 100%;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    box-sizing: border-box;
    margin: 0 0 0.65rem;
    padding: 0.75rem 1rem;
    border: 1px solid rgba(27, 67, 50, 0.2);
    border-radius: 999px;
    background: #fff;
    color: var(--color-brand-dark, #1b4332);
    font: inherit;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 8px 20px -12px rgba(27, 67, 50, 0.35);
    transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.sponsor-child-page__search-toggle:hover,
.sponsor-child-page__search-toggle:focus-visible {
    background: rgba(45, 106, 79, 0.06);
    border-color: rgba(45, 106, 79, 0.35);
    outline: none;
}

.sponsor-child-page__search-toggle-chevron {
    margin-left: auto;
    font-size: 0.8rem;
    transition: transform 0.22s ease;
}

.sponsor-child-page__search.is-search-open .sponsor-child-page__search-toggle-chevron {
    transform: rotate(180deg);
}

.sponsor-child-page__search.is-stuck {
    padding-top: 0.4rem;
    padding-bottom: 0.55rem;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: saturate(160%) blur(12px);
    -webkit-backdrop-filter: saturate(160%) blur(12px);
    box-shadow: 0 12px 32px -16px rgba(27, 67, 50, 0.3);
}

.sponsor-child-page__float-search {
    max-width: 1100px;
    margin-inline: auto;
}

.sponsor-child-page .children-feed__float-row {
    grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr) minmax(0, 0.95fr) minmax(0, 0.9fr) minmax(max-content, auto);
}

.sponsor-child-page__stack {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.5rem);
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
}

.sponsor-child-page__stack > .children-card {
    min-width: 0;
}

@media (max-width: 760px) {
    .sponsor-child-page__search-toggle {
        display: inline-flex;
    }

    .sponsor-child-page__search:not(.is-search-open) .sponsor-child-page__search-panel {
        display: none;
    }

    .sponsor-child-page__search.is-search-open {
        display: flex;
        flex-direction: column;
        max-height: calc(100svh - var(--site-header-offset, 6.5rem) - 0.5rem);
        padding-bottom: 0.85rem;
        overflow: hidden;
    }

    .sponsor-child-page__search.is-search-open .sponsor-child-page__search-toggle {
        flex-shrink: 0;
    }

    .sponsor-child-page__search.is-search-open .sponsor-child-page__search-panel {
        display: block;
        flex: 1 1 auto;
        min-height: 0;
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch;
        scrollbar-gutter: stable;
        padding-bottom: 0.25rem;
    }

    .sponsor-child-page__float-search {
        max-width: 100%;
        width: 100%;
        box-sizing: border-box;
        border-radius: 16px;
        padding: 0.75rem;
    }

    .sponsor-child-page .children-feed__float-row {
        grid-template-columns: 1fr;
        gap: 0.5rem;
    }

    .sponsor-child-page .children-feed__float-field--select {
        grid-column: auto;
    }

    .sponsor-child-page .children-feed__float-actions {
        grid-column: auto;
        flex-direction: column;
        width: 100%;
    }

    .sponsor-child-page .children-feed__float-actions .btn {
        width: 100%;
    }

    .sponsor-child-page .children-feed__float-field input,
    .sponsor-child-page .children-feed__float-field--select select {
        max-width: 100%;
        box-sizing: border-box;
    }

    .sponsor-child-page__stack {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .sponsor-child-page .children-card {
        border-radius: 18px;
    }

    .sponsor-child-page .children-card__hero {
        margin-inline: 0.75rem;
    }
}

@media (min-width: 761px) and (max-width: 960px) {
    .sponsor-child-page__stack {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 961px) {
    .sponsor-child-page__stack {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 761px) {
    .sponsor-child-page__search-panel {
        display: block;
    }
}

.sponsor-child-page__status {
    text-align: center;
    margin-top: 1.25rem;
    font-weight: 600;
    font-size: 0.92rem;
    color: var(--color-muted);
}

.sponsor-child-page__sentinel {
    height: 1px;
    margin-top: 1rem;
}

/* Donate card -------------------------------------------- */
.give-donate {
    padding: clamp(2.5rem, 5vw, 5rem) 0;
    position: relative;
}

.give-donate__grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: clamp(1.5rem, 3vw, 3rem);
    align-items: start;
}

.give-donate__intro {
    position: sticky;
    top: 8rem;
}

.give-donate__eyebrow {
    color: var(--color-accent-dark);
    font-size: 0.82rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 700;
    margin: 0 0 0.5rem;
}

.give-donate__title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 2.5vw + 1rem, 3rem);
    line-height: 1.05;
    color: var(--color-brand-dark);
    margin: 0 0 1rem;
}

.give-donate__lede {
    color: var(--color-muted);
    font-size: 1.05rem;
    margin: 0 0 1.5rem;
    max-width: 40ch;
}

.give-donate__promises {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    font-size: 0.95rem;
    color: var(--color-muted);
}

.give-donate__promises i {
    color: var(--color-brand);
    margin-right: 0.5rem;
}

.donate-card {
    background: var(--color-surface);
    border-radius: 1.25rem;
    padding: clamp(1.25rem, 2vw, 2rem);
    box-shadow: 0 40px 80px -30px rgba(27, 67, 50, 0.28);
    border: 1px solid rgba(27, 67, 50, 0.08);
    position: relative;
    overflow: hidden;
}

.donate-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, var(--color-brand), var(--color-accent), var(--color-brand));
    background-size: 200% 100%;
    animation: giveShimmer 4s linear infinite;
}

.donate-card__freq {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem;
    background: rgba(27, 67, 50, 0.05);
    padding: 0.35rem;
    border-radius: 999px;
    margin-bottom: 1.5rem;
    position: relative;
}

.donate-card__freq-tab {
    appearance: none;
    border: 0;
    background: transparent;
    padding: 0.65rem 0.75rem;
    border-radius: 999px;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.1rem;
    color: var(--color-muted);
    transition: background 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
}

.donate-card__freq-tab i { font-size: 0.95rem; }

.donate-card__freq-tab.is-active {
    background: var(--color-brand-dark);
    color: #fff;
    box-shadow: 0 10px 24px -10px rgba(27, 67, 50, 0.5);
}

.donate-card__freq-hint {
    font-size: 0.7rem;
    font-weight: 500;
    opacity: 0.8;
    letter-spacing: 0.02em;
}

.donate-card__panel-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-muted);
    letter-spacing: 0.02em;
    margin: 0 0 0.75rem;
    text-transform: uppercase;
}

.donate-amount-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.6rem;
    margin-bottom: 1.25rem;
}

.donate-amount {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: 0.85rem 0.75rem;
    border-radius: 0.9rem;
    border: 1.5px solid rgba(27, 67, 50, 0.12);
    cursor: pointer;
    background: #fff;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
    overflow: hidden;
}

.donate-amount input {
    position: absolute;
    opacity: 0;
    inset: 0;
    cursor: pointer;
}

.donate-amount:hover {
    border-color: rgba(var(--color-accent-rgb), 0.6);
    transform: translateY(-1px);
    box-shadow: 0 10px 28px -12px rgba(var(--color-accent-rgb), 0.35);
}

.donate-amount:has(input:checked) {
    border-color: var(--color-accent);
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.12), rgba(var(--color-accent-rgb), 0.04));
    box-shadow: 0 14px 30px -12px rgba(var(--color-accent-rgb), 0.45);
}

.donate-amount:has(input:focus-visible) {
    outline: 2px solid var(--color-brand);
    outline-offset: 2px;
}

.donate-amount__value {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--color-brand-dark);
    letter-spacing: -0.01em;
}

.donate-amount__value small {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--color-muted);
    margin-left: 0.15rem;
}

.donate-amount__impact {
    font-size: 0.78rem;
    color: var(--color-muted);
    line-height: 1.3;
}

.donate-amount__flag {
    position: absolute;
    top: 0.4rem;
    right: 0.4rem;
    font-size: 0.62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    background: var(--color-accent);
    color: #1b4332;
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
}

.donate-amount.is-popular { border-color: rgba(var(--color-accent-rgb), 0.5); }

.donate-amount--custom .donate-amount__value {
    color: var(--color-brand);
}

.donate-card__custom {
    margin: -0.5rem 0 1.25rem;
}

.donate-card__custom label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    margin-bottom: 0.4rem;
    color: var(--color-muted);
}

.donate-card__custom-input {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.15rem 0.9rem;
    border: 1.5px solid rgba(27, 67, 50, 0.15);
    border-radius: 0.75rem;
    background: #fff;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    max-width: 18rem;
}

.donate-card__custom-input:focus-within {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.2);
}

.donate-card__custom-input span {
    font-weight: 700;
    color: var(--color-brand-dark);
}

.donate-card__custom-input input {
    flex: 1;
    min-width: 0;
    border: 0;
    outline: 0;
    padding: 0.7rem 0;
    font: inherit;
    background: transparent;
}

.donate-card__field { margin-bottom: 1.25rem; }

.donate-card__field label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-muted);
    margin-bottom: 0.4rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.donate-card__select-wrap {
    position: relative;
}

.donate-card__select-wrap select {
    appearance: none;
    width: 100%;
    padding: 0.85rem 2.25rem 0.85rem 1rem;
    border: 1.5px solid rgba(27, 67, 50, 0.15);
    border-radius: 0.75rem;
    background: #fff;
    font: inherit;
    color: var(--color-ink);
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.donate-card__select-wrap select:focus-visible {
    outline: 0;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(var(--color-accent-rgb), 0.2);
}

.donate-card__select-wrap i {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--color-brand);
}

.donate-card--simple {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.donate-card--simple .donate-card__field {
    margin: 0;
}

.donate-card--simple .donate-card__submit {
    margin-top: 0.25rem;
}

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

/* Givebutter checkout loading (shown until iframe reports ready) */
.givebutter-loading {
    position: fixed;
    inset: 0;
    z-index: 99990;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background: rgba(15, 26, 20, 0.55);
    backdrop-filter: blur(4px);
}

.givebutter-loading__panel {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    max-width: 20rem;
    padding: 1.5rem 1.75rem;
    border-radius: 1rem;
    background: #fff;
    box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.35);
    text-align: center;
}

.givebutter-loading__spinner {
    width: 2.25rem;
    height: 2.25rem;
    border: 3px solid rgba(27, 67, 50, 0.15);
    border-top-color: var(--color-accent, #e9a227);
    border-radius: 50%;
    animation: givebutter-spin 0.75s linear infinite;
}

.givebutter-loading__text {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text, #1a2e24);
}

@keyframes givebutter-spin {
    to { transform: rotate(360deg); }
}

body.givebutter-loading-active {
    overflow: hidden;
}

@media (prefers-reduced-motion: reduce) {
    .givebutter-loading__spinner {
        animation: none;
        border-top-color: rgba(27, 67, 50, 0.35);
    }
}

.donate-card__submit {
    width: 100%;
    border-radius: 999px;
    padding: 1rem 1.25rem;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.05rem;
    box-shadow: 0 22px 50px -18px rgba(var(--color-accent-rgb), 0.6);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.donate-card__submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 28px 56px -20px rgba(var(--color-accent-rgb), 0.75);
}

.donate-card__submit i {
    transition: transform 0.2s ease;
}

.donate-card__submit:hover i { transform: translateX(4px); }

.donate-card__trust {
    font-size: 0.82rem;
    color: var(--color-muted);
    margin: 0.9rem 0 0;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.4rem;
}

.donate-card__trust i { color: var(--color-brand); }

.donate-card__note {
    margin: 0.75rem 0 0;
    padding: 0.65rem 0.9rem;
    background: rgba(var(--color-accent-rgb), 0.14);
    color: var(--color-brand-dark);
    border-radius: 0.6rem;
    font-size: 0.9rem;
    text-align: center;
}

@media (max-width: 900px) {
    .give-donate__grid { grid-template-columns: 1fr; }
    .give-donate__intro { position: static; }
    .donate-amount-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Areas (cause cards) ------------------------------------ */
.give-areas { padding: clamp(2.5rem, 5vw, 5rem) 0; background: linear-gradient(180deg, transparent, rgba(var(--color-accent-rgb), 0.06)); }

.area-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.area-card {
    position: relative;
    padding: 1.5rem;
    background: var(--color-surface);
    border-radius: 1rem;
    border: 1px solid rgba(27, 67, 50, 0.08);
    box-shadow: 0 18px 40px -24px rgba(27, 67, 50, 0.25);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    overflow: hidden;
}

.area-card::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-brand), var(--color-accent));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.35s ease;
}

.area-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--color-accent-rgb), 0.35);
    box-shadow: 0 28px 56px -24px rgba(27, 67, 50, 0.35);
}

.area-card:hover::after { transform: scaleX(1); }

.area-card__icon {
    width: 3rem;
    height: 3rem;
    border-radius: 0.85rem;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.18), rgba(var(--color-accent-rgb), 0.04));
    color: var(--color-accent-dark);
    font-size: 1.2rem;
    margin-bottom: 1rem;
    transition: transform 0.35s ease, background 0.35s ease, color 0.35s ease;
}

.area-card:hover .area-card__icon {
    background: var(--color-brand-dark);
    color: #fff;
    transform: rotate(-6deg) scale(1.05);
}

.area-card__title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    margin: 0 0 0.4rem;
    color: var(--color-brand-dark);
}

.area-card__blurb {
    margin: 0 0 1rem;
    font-size: 0.92rem;
    color: var(--color-muted);
    line-height: 1.45;
}

.area-card__cta {
    font-weight: 600;
    color: var(--color-brand);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.9rem;
}

.area-card__cta i { transition: transform 0.2s ease; }
.area-card:hover .area-card__cta i { transform: translateX(3px); }

/* Quote --------------------------------------------------- */
.give-quote {
    padding: clamp(2rem, 4vw, 4rem) 0;
}

.give-quote__inner {
    max-width: 820px;
    margin-inline: auto;
}

.give-quote__figure {
    margin: 0;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: clamp(1rem, 2vw, 2rem);
    align-items: center;
    padding: clamp(1.5rem, 3vw, 2.25rem);
    background: var(--color-brand-dark);
    color: #f7f3ea;
    border-radius: 1.25rem;
    position: relative;
    overflow: hidden;
    box-shadow: 0 40px 80px -30px rgba(27, 67, 50, 0.45);
}

.give-quote__figure::before {
    content: "\201C";
    position: absolute;
    top: -2rem;
    right: 0.5rem;
    font-family: "Great Vibes", serif;
    font-size: 16rem;
    line-height: 1;
    color: rgba(var(--color-accent-rgb), 0.25);
    pointer-events: none;
}

.give-quote__portrait {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    overflow: hidden;
    border: 3px solid var(--color-accent);
    box-shadow: 0 12px 30px -10px rgba(0, 0, 0, 0.4);
    flex-shrink: 0;
}

.give-quote__portrait img {
    width: 100%; height: 100%;
    object-fit: cover;
    border-radius: 0;
}

.give-quote__body {
    margin: 0;
    font-family: var(--font-display);
}

.give-quote__body p {
    font-size: clamp(1.05rem, 1vw + 0.9rem, 1.3rem);
    line-height: 1.5;
    margin: 0 0 0.75rem;
    font-weight: 500;
}

.give-quote__body figcaption {
    font-size: 0.9rem;
    color: rgba(247, 243, 234, 0.75);
    font-weight: 600;
}

.give-quote__body figcaption span {
    font-weight: 400;
    color: rgba(247, 243, 234, 0.55);
}

@media (max-width: 600px) {
    .give-quote__figure { grid-template-columns: 1fr; text-align: center; }
    .give-quote__portrait { margin-inline: auto; }
}

/* Involved cards ----------------------------------------- */
.give-involved { padding: clamp(2.5rem, 5vw, 5rem) 0; }

.involved-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}

.involved-card {
    padding: 1.75rem 1.5rem;
    background: var(--color-surface);
    border-radius: 1rem;
    border: 1px solid rgba(27, 67, 50, 0.08);
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.involved-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 50px -24px rgba(27, 67, 50, 0.3);
}

.involved-card__icon {
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--color-brand-dark);
    color: var(--color-accent);
    font-size: 1.3rem;
    margin-bottom: 0.25rem;
    transition: background 0.3s ease, transform 0.3s ease;
}

.involved-card:hover .involved-card__icon {
    background: var(--color-accent);
    color: var(--color-brand-dark);
    transform: scale(1.06);
}

.involved-card__title {
    font-family: var(--font-display);
    font-size: 1.15rem;
    margin: 0;
    color: var(--color-brand-dark);
}

.involved-card__blurb {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.5;
    flex: 1;
}

.involved-card__cta {
    align-self: flex-start;
    font-weight: 600;
    color: var(--color-brand);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.9rem;
    margin-top: 0.5rem;
    border-bottom: 2px solid transparent;
    padding-bottom: 2px;
    transition: border-color 0.2s ease;
}

.involved-card__cta:hover { border-color: var(--color-accent); }
.involved-card__cta i { transition: transform 0.2s ease; }
.involved-card__cta:hover i { transform: translateX(3px); }

/* Methods ------------------------------------------------ */
.give-methods { padding: clamp(2.5rem, 5vw, 4rem) 0; }

.methods-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.method-card {
    padding: 1.5rem;
    background: var(--color-surface);
    border-radius: 1rem;
    border: 1px solid rgba(27, 67, 50, 0.08);
    box-shadow: 0 14px 32px -20px rgba(27, 67, 50, 0.25);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.method-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 48px -24px rgba(27, 67, 50, 0.3);
}

.method-card__head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 0 0 1rem;
}

.method-card__head h3 {
    font-family: var(--font-display);
    font-size: 1.1rem;
    margin: 0;
    color: var(--color-brand-dark);
}

.method-card__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.7rem;
    display: grid;
    place-items: center;
    background: rgba(var(--color-accent-rgb), 0.18);
    color: var(--color-accent-dark);
    font-size: 1.05rem;
}

.method-card__note {
    margin: 0 0 0.75rem;
    color: var(--color-muted);
    font-size: 0.95rem;
}

.method-card__address {
    font-style: normal;
    line-height: 1.6;
    color: var(--color-ink);
    font-size: 0.95rem;
}

.method-card__dl {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.method-card__dl > div {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.35rem 0;
    border-bottom: 1px dashed rgba(27, 67, 50, 0.1);
    font-size: 0.92rem;
}

.method-card__dl > div:last-child { border-bottom: 0; }

.method-card__dl dt { color: var(--color-muted); margin: 0; }
.method-card__dl dd { margin: 0; font-weight: 600; color: var(--color-brand-dark); }

.method-card--highlight {
    background: linear-gradient(140deg, var(--color-brand-dark), #0d2f20);
    color: #f7f3ea;
    border: 0;
}

.method-card--highlight .method-card__head h3 { color: #fff; }
.method-card--highlight .method-card__icon { background: rgba(var(--color-accent-rgb), 0.25); color: var(--color-accent); }
.method-card--highlight .method-card__note { color: rgba(247, 243, 234, 0.82); }

.method-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: 600;
    color: var(--color-accent);
    text-decoration: none;
    padding: 0.55rem 0;
    border-bottom: 2px solid rgba(var(--color-accent-rgb), 0.4);
}

.method-card__cta:hover {
    color: #fff;
    border-bottom-color: var(--color-accent);
}

.method-card__cta i { transition: transform 0.2s ease; }
.method-card__cta:hover i { transform: translateX(3px); }

/* FAQ ---------------------------------------------------- */
.give-faq {
    padding: clamp(2.5rem, 5vw, 5rem) 0 clamp(4rem, 8vw, 7rem);
}

.give-faq__inner {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    gap: clamp(1.5rem, 3vw, 3rem);
    align-items: start;
}

.give-faq__head {
    position: sticky;
    top: 8rem;
}

.give-faq__list {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.faq-item {
    background: var(--color-surface);
    border: 1px solid rgba(27, 67, 50, 0.1);
    border-radius: 0.85rem;
    overflow: hidden;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.faq-item[open] {
    border-color: rgba(var(--color-accent-rgb), 0.4);
    box-shadow: 0 14px 32px -22px rgba(27, 67, 50, 0.3);
}

.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 1rem 1.15rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-weight: 600;
    color: var(--color-brand-dark);
}

.faq-item summary::-webkit-details-marker { display: none; }

.faq-item__icon {
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(var(--color-accent-rgb), 0.15);
    color: var(--color-accent-dark);
    font-size: 0.75rem;
    transition: transform 0.3s ease, background 0.3s ease, color 0.3s ease;
    flex-shrink: 0;
}

.faq-item[open] .faq-item__icon {
    background: var(--color-brand-dark);
    color: #fff;
    transform: rotate(45deg);
}

.faq-item__a {
    padding: 0 1.15rem 1rem;
    color: var(--color-muted);
    font-size: 0.96rem;
    line-height: 1.6;
}

.faq-item__a p { margin: 0; }

@media (max-width: 860px) {
    .give-faq__inner { grid-template-columns: 1fr; }
    .give-faq__head { position: static; }
}

/* Sticky mini-donate ------------------------------------- */
.give-sticky {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 45;
    background: var(--color-brand-dark);
    color: #f7f3ea;
    padding: 0.75rem 0;
    border-top: 3px solid var(--color-accent);
    box-shadow: 0 -20px 40px -20px rgba(0, 0, 0, 0.35);
    transform: translateY(120%);
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.give-sticky.is-visible { transform: translateY(0); }

.give-sticky__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.give-sticky__text {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
}

.give-sticky__text strong {
    font-family: var(--font-display);
    font-size: 1rem;
}

.give-sticky__text span {
    font-size: 0.82rem;
    color: rgba(247, 243, 234, 0.75);
}

.give-sticky__actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.give-sticky__actions .btn {
    border-radius: 999px;
    padding-inline: 1.15rem;
}

.give-sticky__close {
    appearance: none;
    border: 0;
    background: rgba(255, 255, 255, 0.08);
    color: #f7f3ea;
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 50%;
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: background 0.2s ease;
}

.give-sticky__close:hover { background: rgba(255, 255, 255, 0.18); }

@media (max-width: 520px) {
    .give-sticky__text span { display: none; }
}

@media (prefers-reduced-motion: reduce) {
    .give-hero__eyebrow i,
    .give-hero__title-accent,
    .donate-card::before,
    .give-hero__figure::before,
    .give-hero__badge { animation: none !important; }
    .give-hero__btn:hover,
    .donate-amount:hover,
    .area-card:hover,
    .method-card:hover,
    .involved-card:hover,
    .donate-card__submit:hover { transform: none !important; }
}

/* ============================================================
   ABOUT (Who we are) — hero, story, needs, timeline, values,
   verse block, final CTA
   ============================================================ */

.about-section__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--color-accent-dark);
    margin: 0 0 0.6rem;
}

.about-section__eyebrow::before {
    content: "";
    width: 1.75rem;
    height: 2px;
    background: currentColor;
    display: inline-block;
}

.about-section__eyebrow--light {
    color: rgba(var(--color-accent-rgb), 0.9);
}

.about-section__title {
    font-family: var(--font-display);
    font-size: clamp(1.7rem, 2.5vw + 1rem, 2.6rem);
    line-height: 1.08;
    margin: 0 0 0.85rem;
    color: var(--color-brand-dark);
    letter-spacing: -0.01em;
}

.about-section__title--light { color: #fff; }

.about-section__lede {
    max-width: 62ch;
    color: var(--color-muted);
    margin: 0 0 2.25rem;
    font-size: 1.05rem;
}

/* Override the auto-injected page-header since this page has its own hero */
body:has(.about-hero) .page-header { display: none; }

/* ----- Hero ----- */
.about-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(3rem, 6vw, 5rem) 0 0;
    isolation: isolate;
    color: var(--color-ink);
}

.about-hero__bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(900px 500px at 85% 10%, rgba(var(--color-accent-rgb), 0.28), transparent 60%),
        radial-gradient(1100px 600px at 10% 90%, rgba(45, 106, 79, 0.28), transparent 60%),
        linear-gradient(180deg, #fdfaf3 0%, var(--color-bg) 100%);
}

.about-hero__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(27, 67, 50, 0.1) 1px, transparent 1px);
    background-size: 26px 26px;
    mask-image: radial-gradient(ellipse at 50% 50%, #000 10%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 50%, #000 10%, transparent 70%);
    opacity: 0.75;
}

.about-hero__inner {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: clamp(1.5rem, 4vw, 4rem);
    align-items: center;
    padding-bottom: clamp(2rem, 4vw, 3.5rem);
}

.about-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.4rem 0.95rem;
    border-radius: 999px;
    background: rgba(27, 67, 50, 0.1);
    color: var(--color-brand-dark);
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 1.25rem;
}

.about-hero__eyebrow-dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--color-accent);
    box-shadow: 0 0 0 0 rgba(var(--color-accent-rgb), 0.6);
    animation: aboutPulse 2.2s ease-out infinite;
}

@keyframes aboutPulse {
    0%   { box-shadow: 0 0 0 0 rgba(var(--color-accent-rgb), 0.6); }
    70%  { box-shadow: 0 0 0 10px rgba(var(--color-accent-rgb), 0); }
    100% { box-shadow: 0 0 0 0 rgba(var(--color-accent-rgb), 0); }
}

.about-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.2rem, 4.5vw + 0.5rem, 4rem);
    line-height: 1.03;
    letter-spacing: -0.02em;
    color: var(--color-brand-dark);
    margin: 0 0 1rem;
}

.about-hero__rotator {
    display: inline-block;
    position: relative;
    vertical-align: baseline;
    height: 1em;
    min-width: 5ch;
    overflow: hidden;
    background: linear-gradient(100deg, var(--color-accent) 0%, #d97706 50%, var(--color-accent) 100%);
    background-size: 200% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    animation: giveShimmer 7s ease-in-out infinite;
}

.about-hero__rotator-word {
    position: absolute;
    left: 0;
    top: 0;
    transform: translateY(110%);
    opacity: 0;
    transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.35s ease;
    white-space: nowrap;
}

.about-hero__rotator-word.is-active {
    transform: translateY(0);
    opacity: 1;
}

.about-hero__rotator-word.is-leaving {
    transform: translateY(-110%);
    opacity: 0;
}

.about-hero__title-tail {
    display: block;
    font-size: 0.55em;
    color: var(--color-muted);
    font-weight: 500;
    letter-spacing: 0;
    margin-top: 0.15em;
}

.about-hero__lede {
    max-width: 54ch;
    color: var(--color-muted);
    font-size: clamp(1rem, 0.5vw + 0.95rem, 1.2rem);
    margin: 0 0 1.5rem;
}

.about-hero__badges {
    list-style: none;
    margin: 0 0 1.75rem;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.4rem;
    font-size: 0.85rem;
    color: var(--color-muted);
}

.about-hero__badges li {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.about-hero__badges i { color: var(--color-brand); }

.about-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.about-hero__btn {
    border-radius: 999px;
    padding-inline: 1.5rem;
    box-shadow: 0 16px 40px -16px rgba(var(--color-accent-rgb), 0.5);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.about-hero__btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 22px 48px -18px rgba(var(--color-accent-rgb), 0.65);
}

.about-hero__btn i { margin: 0 0.45rem; }

.about-hero__btn--ghost {
    background: transparent;
    color: var(--color-brand-dark);
    border: 1.5px solid rgba(27, 67, 50, 0.22);
    box-shadow: none;
}

.about-hero__btn--ghost:hover {
    background: rgba(27, 67, 50, 0.06);
    border-color: var(--color-brand-dark);
    box-shadow: none;
}

/* Hero media — portrait + orbits + floating chips */
.about-hero__media {
    position: relative;
    justify-self: center;
    width: min(440px, 100%);
    aspect-ratio: 1 / 1;
}

.about-hero__orbit {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 1.5px dashed rgba(27, 67, 50, 0.22);
    animation: aboutSpin 30s linear infinite;
}

.about-hero__orbit--2 {
    inset: 12%;
    border-color: rgba(var(--color-accent-rgb), 0.4);
    animation-duration: 20s;
    animation-direction: reverse;
}

@keyframes aboutSpin {
    to { transform: rotate(360deg); }
}

.about-hero__portrait {
    position: absolute;
    inset: 7%;
    margin: 0;
    border-radius: 50%;
    overflow: hidden;
    box-shadow: 0 30px 60px -24px rgba(27, 67, 50, 0.55);
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.2), rgba(45, 106, 79, 0.2));
}

.about-hero__portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 28% center;
    border-radius: 0;
    display: block;
    transform: scale(1.05);
}

.about-hero__chip {
    position: absolute;
    background: var(--color-surface);
    padding: 0.65rem 0.9rem;
    border-radius: 999px;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    box-shadow: 0 20px 40px -16px rgba(27, 67, 50, 0.4);
    border: 1px solid rgba(27, 67, 50, 0.08);
    font-size: 0.82rem;
    color: var(--color-muted);
    animation: giveFloat 6s ease-in-out infinite;
}

.about-hero__chip strong {
    color: var(--color-brand-dark);
    font-family: var(--font-display);
    font-size: 0.95rem;
    margin-right: 0.15rem;
}

.about-hero__chip i {
    color: var(--color-accent-dark);
    font-size: 0.9rem;
}

.about-hero__chip--top {
    top: 2%;
    right: -4%;
}

.about-hero__chip--bottom {
    bottom: 6%;
    left: -6%;
    animation-direction: reverse;
    animation-duration: 7.5s;
}

@media (max-width: 900px) {
    .about-hero__inner { grid-template-columns: 1fr; text-align: center; }
    .about-hero__eyebrow,
    .about-hero__actions,
    .about-hero__badges { justify-content: center; }
    .about-hero__lede { margin-inline: auto; }
    .about-hero__media { order: -1; width: min(340px, 80%); }
    .about-hero__chip--top { right: 2%; }
    .about-hero__chip--bottom { left: 2%; }
}

/* Hero marquee strip */
.about-hero__marquee {
    overflow: hidden;
    background: linear-gradient(90deg, transparent, rgba(27, 67, 50, 0.06) 20%, rgba(27, 67, 50, 0.06) 80%, transparent);
    border-top: 1px solid rgba(27, 67, 50, 0.1);
    border-bottom: 1px solid rgba(27, 67, 50, 0.1);
    padding: 0.9rem 0;
    margin-top: clamp(1rem, 3vw, 2rem);
    mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}

.about-hero__marquee-track {
    display: inline-flex;
    gap: 2rem;
    align-items: center;
    font-family: var(--font-display);
    font-size: clamp(1.2rem, 2vw + 0.5rem, 1.9rem);
    font-weight: 700;
    color: var(--color-brand-dark);
    white-space: nowrap;
    animation: aboutMarquee 28s linear infinite;
}

.about-hero__marquee-track span:nth-child(even) {
    color: var(--color-accent-dark);
    font-weight: 400;
}

.about-hero__marquee-track span:nth-child(odd) {
    font-style: italic;
}

@keyframes aboutMarquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ----- Story ----- */
.about-story {
    padding: clamp(3rem, 6vw, 5rem) 0;
}

.about-story__grid {
    display: grid;
    grid-template-columns: 1.35fr 0.85fr;
    gap: clamp(1.5rem, 4vw, 4rem);
    align-items: start;
}

.about-story__prose p {
    font-size: clamp(1rem, 0.3vw + 0.95rem, 1.1rem);
    color: var(--color-ink);
    line-height: 1.75;
    margin: 0 0 1.1rem;
}

.about-story__prose .about-section__title {
    margin-bottom: 1.5rem;
}

.about-story__drop { clear: left; }

.about-story__dropcap {
    float: left;
    font-family: var(--font-display);
    font-size: 4.5rem;
    line-height: 0.85;
    font-weight: 800;
    padding: 0.35rem 0.65rem 0.25rem 0;
    margin: 0.1rem 0.1rem 0 0;
    color: var(--color-brand-dark);
    background: linear-gradient(135deg, var(--color-brand), var(--color-accent));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.about-story__close {
    font-weight: 500;
    color: var(--color-brand-dark);
    border-left: 3px solid var(--color-accent);
    padding-left: 1rem;
    font-style: italic;
}

.about-story__aside {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    position: sticky;
    top: 7.5rem;
}

.about-story__pullquote {
    margin: 0;
    padding: 1.75rem 1.5rem 1.5rem;
    background: var(--color-brand-dark);
    color: #f7f3ea;
    border-radius: 1.25rem;
    position: relative;
    overflow: hidden;
    box-shadow: 0 30px 60px -25px rgba(27, 67, 50, 0.5);
}

.about-story__pullquote::before {
    content: "";
    position: absolute;
    inset: auto -20% -30% auto;
    width: 60%;
    aspect-ratio: 1;
    background: radial-gradient(closest-side, rgba(var(--color-accent-rgb), 0.35), transparent);
    z-index: 0;
}

.about-story__quote-mark {
    color: var(--color-accent);
    font-size: 2rem;
    opacity: 0.9;
    position: relative;
    z-index: 1;
}

.about-story__pullquote blockquote {
    margin: 0.75rem 0 1rem;
    font-family: var(--font-display);
    position: relative;
    z-index: 1;
}

.about-story__pullquote blockquote p {
    font-size: clamp(1.05rem, 1vw + 0.85rem, 1.3rem);
    line-height: 1.4;
    margin: 0 0 0.5rem;
}

.about-story__pullquote blockquote p:last-child {
    font-weight: 500;
    color: rgba(247, 243, 234, 0.78);
    font-size: 0.95rem;
    font-style: italic;
}

.about-story__pullquote figcaption {
    font-size: 0.85rem;
    color: rgba(247, 243, 234, 0.78);
    font-weight: 600;
    position: relative;
    z-index: 1;
}

.about-story__pullquote figcaption span {
    font-weight: 400;
    color: rgba(247, 243, 234, 0.55);
}

.about-story__image {
    margin: 0;
    border-radius: 1rem;
    overflow: hidden;
    position: relative;
    box-shadow: 0 24px 50px -28px rgba(27, 67, 50, 0.4);
}

.about-story__image img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: 58% center;
    display: block;
    border-radius: 0;
    transition: transform 0.7s ease;
}

.about-story__image:hover img { transform: scale(1.04); }

/* Cut-out (transparent-background) variant — show the full subject on a warm brand backdrop */
.about-story__image--cutout {
    background:
        radial-gradient(120% 80% at 50% 120%, rgba(var(--color-accent-rgb), 0.5), transparent 60%),
        linear-gradient(160deg, #fef3d6 0%, #fcd98a 40%, rgba(var(--color-accent-rgb), 0.85) 100%);
    position: relative;
    isolation: isolate;
    padding: 1.5rem 1.5rem 0;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    min-height: 460px;
}

.about-story__image--cutout::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(27, 67, 50, 0.1) 1px, transparent 1px);
    background-size: 22px 22px;
    mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 30%, #000 30%, transparent 80%);
    opacity: 0.8;
    z-index: 0;
    pointer-events: none;
}

.about-story__image--cutout::after {
    content: "";
    position: absolute;
    left: 18%;
    right: 18%;
    bottom: 14%;
    height: 16px;
    background: radial-gradient(ellipse at center, rgba(27, 67, 50, 0.4), transparent 70%);
    filter: blur(8px);
    z-index: 0;
    pointer-events: none;
}

.about-story__image--cutout img {
    position: relative;
    z-index: 1;
    display: block;
    width: auto;
    max-width: 80%;
    max-height: 88%;
    height: auto;
    aspect-ratio: auto;
    object-fit: contain;
    transform-origin: bottom center;
    transition: transform 0.5s ease;
}

.about-story__image--cutout:hover img { transform: scale(1.04) translateY(-3px); }

.about-story__image--cutout figcaption {
    background: rgba(27, 67, 50, 0.92);
    z-index: 2;
}

@media (max-width: 520px) {
    .about-story__image--cutout { min-height: 380px; }
    .about-story__image--cutout img { max-width: 70%; max-height: 86%; }
}

.about-story__image figcaption {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    padding: 0.4rem 0.75rem;
    background: rgba(27, 67, 50, 0.85);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    color: #fff;
    font-size: 0.78rem;
    border-radius: 999px;
    font-weight: 600;
}

@media (max-width: 900px) {
    .about-story__grid { grid-template-columns: 1fr; }
    .about-story__aside { position: static; }
}

/* ----- Needs (dark stat strip) ----- */
.about-needs {
    position: relative;
    overflow: hidden;
    padding: clamp(3rem, 5vw, 4.5rem) 0;
    background: linear-gradient(140deg, var(--color-brand-dark), #0d2f20);
    color: #f7f3ea;
    isolation: isolate;
}

.about-needs::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background-image:
        radial-gradient(600px 300px at 10% 0%, rgba(var(--color-accent-rgb), 0.18), transparent 60%),
        radial-gradient(700px 400px at 100% 100%, rgba(var(--color-accent-rgb), 0.1), transparent 60%),
        radial-gradient(rgba(255, 255, 255, 0.06) 1px, transparent 1px);
    background-size: auto, auto, 26px 26px;
    opacity: 0.95;
}

.about-needs__head {
    max-width: 680px;
    margin: 0 auto 2.25rem;
    text-align: center;
}

.about-needs__head .about-section__eyebrow { justify-content: center; }

.about-needs__lede {
    color: rgba(247, 243, 234, 0.78);
    margin: 0 auto;
    font-size: 1.05rem;
    max-width: 52ch;
}

.about-needs__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.need-tile {
    padding: 1.5rem 1.25rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    transition: transform 0.25s ease, background 0.25s ease, border-color 0.25s ease;
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.need-tile:hover {
    transform: translateY(-3px);
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(var(--color-accent-rgb), 0.5);
}

.need-tile__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.7rem;
    display: grid;
    place-items: center;
    background: rgba(var(--color-accent-rgb), 0.2);
    color: var(--color-accent);
    font-size: 1.1rem;
}

.need-tile__num {
    font-family: var(--font-display);
    font-size: clamp(2rem, 1.5vw + 1.5rem, 3rem);
    font-weight: 800;
    color: #fff;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.need-tile__literal { color: var(--color-accent); }

.need-tile__suffix {
    color: var(--color-accent);
    margin-left: 0.15rem;
    font-size: 0.65em;
}

.need-tile__label {
    font-size: 0.9rem;
    color: rgba(247, 243, 234, 0.78);
    line-height: 1.4;
}

@media (max-width: 900px) { .about-needs__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .about-needs__grid { grid-template-columns: 1fr; } }

/* ----- Timeline ----- */
.about-timeline {
    padding: clamp(3rem, 6vw, 5rem) 0;
    position: relative;
}

.about-timeline__head {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 2.75rem;
}

.about-timeline__head .about-section__eyebrow { justify-content: center; }
.about-timeline__head .about-section__lede { margin-inline: auto; }

.timeline {
    list-style: none;
    padding: 0;
    margin: 0;
    position: relative;
    max-width: 920px;
    margin-inline: auto;
}

.timeline::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 3rem;
    left: 50%;
    transform: translateX(-50%);
    width: 2px;
    background: linear-gradient(180deg, transparent, rgba(27, 67, 50, 0.18) 8%, rgba(27, 67, 50, 0.18) 92%, transparent);
}

.timeline__item {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 2.75rem 1fr;
    align-items: start;
    margin-bottom: 2rem;
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.timeline__item.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.timeline__dot {
    grid-column: 2 / 3;
    grid-row: 1;
    justify-self: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    background: var(--color-surface);
    border: 2px solid var(--color-brand);
    display: grid;
    place-items: center;
    position: relative;
    z-index: 1;
    box-shadow: 0 8px 20px -10px rgba(27, 67, 50, 0.4);
    transition: transform 0.4s ease, background 0.4s ease, border-color 0.4s ease;
}

.timeline__dot-inner {
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 50%;
    background: var(--color-accent);
    transition: transform 0.4s ease;
}

.timeline__item.is-visible .timeline__dot { transform: scale(1.1); }
.timeline__item:hover .timeline__dot {
    background: var(--color-brand);
    border-color: var(--color-accent);
}
.timeline__item:hover .timeline__dot-inner {
    transform: scale(1.2);
    background: #fff;
}

.timeline__card {
    grid-column: 1 / 2;
    grid-row: 1;
    padding: 1.25rem 1.5rem;
    background: var(--color-surface);
    border: 1px solid rgba(27, 67, 50, 0.08);
    border-radius: 1rem;
    box-shadow: 0 16px 36px -24px rgba(27, 67, 50, 0.35);
    position: relative;
    margin-right: 0.75rem;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.timeline__item:hover .timeline__card {
    transform: translateY(-3px);
    box-shadow: 0 26px 50px -22px rgba(27, 67, 50, 0.4);
    border-color: rgba(var(--color-accent-rgb), 0.35);
}

.timeline__card::before {
    content: "";
    position: absolute;
    top: 1.25rem;
    right: -0.5rem;
    width: 1rem;
    height: 1rem;
    background: var(--color-surface);
    border-top: 1px solid rgba(27, 67, 50, 0.08);
    border-right: 1px solid rgba(27, 67, 50, 0.08);
    transform: rotate(45deg);
}

.timeline__item--right .timeline__card {
    grid-column: 3 / 4;
    margin-right: 0;
    margin-left: 0.75rem;
}

.timeline__item--right .timeline__card::before {
    right: auto;
    left: -0.5rem;
    border-top: 1px solid rgba(27, 67, 50, 0.08);
    border-right: 0;
    border-left: 1px solid rgba(27, 67, 50, 0.08);
    border-bottom: 0;
    transform: rotate(-135deg);
}

.timeline__year {
    display: inline-block;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 0.85rem;
    padding: 0.2rem 0.7rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--color-brand), var(--color-accent));
    color: #fff;
    margin: 0 0 0.6rem;
    letter-spacing: 0.04em;
}

.timeline__title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    margin: 0 0 0.35rem;
    color: var(--color-brand-dark);
    line-height: 1.25;
}

.timeline__text {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.55;
}

.timeline__text > p {
    margin: 0 0 0.85rem;
}

.timeline__text > p:last-child {
    margin-bottom: 0;
}

.timeline__spoken {
    margin: 0.5rem 0 1rem;
    padding: 1.1rem 1.15rem 1rem 1.35rem;
    position: relative;
    border: none;
    border-radius: 0.85rem;
    background: linear-gradient(
        145deg,
        rgba(249, 168, 37, 0.14) 0%,
        rgba(27, 67, 50, 0.07) 55%,
        rgba(247, 243, 234, 0.95) 100%
    );
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.85),
        0 10px 28px -18px rgba(27, 67, 50, 0.45);
    border-left: 4px solid var(--color-accent);
}

.timeline__spoken-icon {
    display: block;
    margin-bottom: 0.45rem;
    font-size: 1.1rem;
    color: var(--color-brand);
    opacity: 0.75;
}

.timeline__spoken-line {
    margin: 0;
    font-family: var(--font-display);
    font-size: 1.02rem;
    font-style: italic;
    font-weight: 600;
    line-height: 1.5;
    color: var(--color-brand-dark);
}

.timeline__spoken-cite {
    display: block;
    margin-top: 0.65rem;
    font-family: var(--font-body, inherit);
    font-size: 0.82rem;
    font-style: normal;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-brand);
}

.timeline__spoken-cite::before {
    content: "— ";
    font-weight: 400;
    opacity: 0.7;
}

.timeline__terminus {
    text-align: center;
    list-style: none;
    margin-top: -0.5rem;
}

.timeline__terminus span {
    display: inline-grid;
    place-items: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--color-accent);
    color: var(--color-brand-dark);
    font-size: 1rem;
    box-shadow: 0 12px 24px -12px rgba(var(--color-accent-rgb), 0.6);
    animation: aboutPulse 2.4s ease-out infinite;
}

@media (max-width: 760px) {
    .timeline::before { left: 1.25rem; transform: none; }
    .timeline__item,
    .timeline__item--right {
        grid-template-columns: 2.75rem 1fr;
    }
    .timeline__dot { grid-column: 1 / 2; justify-self: start; }
    .timeline__card,
    .timeline__item--right .timeline__card {
        grid-column: 2 / 3;
        margin: 0 0 0 1rem;
    }
    .timeline__card::before,
    .timeline__item--right .timeline__card::before {
        left: -0.5rem;
        right: auto;
        top: 1.25rem;
        border-top: 1px solid rgba(27, 67, 50, 0.08);
        border-left: 1px solid rgba(27, 67, 50, 0.08);
        border-right: 0;
        border-bottom: 0;
        transform: rotate(-45deg);
    }
    .timeline__terminus { text-align: left; padding-left: 0.25rem; }
}

/* ----- Work section wrapper for pillars ----- */
.about-work {
    padding: clamp(3rem, 6vw, 5rem) 0;
    background:
        linear-gradient(180deg, transparent, rgba(var(--color-accent-rgb), 0.05));
}

.about-work__head {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 2rem;
}

.about-work__head .about-section__eyebrow { justify-content: center; }
.about-work__head .about-section__lede { margin-inline: auto; }

/* Flagship pillars — richer card content */
.pillars--flagship {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    align-items: stretch;
}

.pillars--flagship .pillar {
    display: flex;
    flex-direction: column;
    padding: 2rem 1.65rem 1.75rem;
}

.pillars--flagship .pillar__title {
    font-size: 1.2rem;
    line-height: 1.25;
    margin: 0.25rem 0 0.35rem;
}

.pillar__subtitle {
    font-family: var(--font-display);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-accent-dark);
    margin: 0 0 0.5rem;
    letter-spacing: -0.005em;
    line-height: 1.35;
}

.pillar__desc {
    margin: 0 0 1rem;
    color: var(--color-muted);
    font-size: 0.92rem;
    line-height: 1.55;
}

.pillar__list-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-brand);
    margin: 0 0 0.55rem;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.pillar__list-label::before {
    content: "";
    width: 1.1rem;
    height: 2px;
    background: currentColor;
    display: inline-block;
}

.pillar__list--rich {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    flex: 1;
}

.pillar__list--rich li {
    padding: 0.6rem 0.8rem;
    border-radius: 0.65rem;
    background: rgba(var(--color-accent-rgb), 0.07);
    border-left: 3px solid rgba(var(--color-accent-rgb), 0.45);
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    transition: background 0.25s ease, transform 0.25s ease, border-left-color 0.25s ease;
}

.pillar__list--rich li:hover {
    background: rgba(var(--color-accent-rgb), 0.14);
    border-left-color: var(--color-accent);
    transform: translateX(2px);
}

.pillar__list--rich li strong {
    color: var(--color-brand-dark);
    font-size: 0.92rem;
    font-weight: 700;
    line-height: 1.3;
}

.pillar__list--rich li span {
    color: var(--color-muted);
    font-size: 0.8rem;
    line-height: 1.4;
}

.pillars--flagship .pillar__tagline {
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px dashed rgba(27, 67, 50, 0.15);
    font-style: italic;
    color: var(--color-brand-dark);
    font-size: 0.92rem;
    line-height: 1.5;
}

/* ----- Values triad ----- */
.about-values {
    padding: clamp(3rem, 6vw, 5rem) 0;
}

.about-values__head {
    text-align: center;
    margin-bottom: 2rem;
}

.about-values__head .about-section__eyebrow { justify-content: center; }

.value-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
}

.value-card {
    position: relative;
    padding: 2rem 1.5rem 1.5rem;
    background: var(--color-surface);
    border: 1px solid rgba(27, 67, 50, 0.08);
    border-radius: 1.25rem;
    box-shadow: 0 18px 40px -28px rgba(27, 67, 50, 0.3);
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.value-card::before {
    content: "";
    position: absolute;
    inset: auto -20% -40% auto;
    width: 60%;
    aspect-ratio: 1;
    background: radial-gradient(closest-side, rgba(var(--color-accent-rgb), 0.12), transparent 70%);
    opacity: 0;
    transition: opacity 0.35s ease;
}

.value-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 30px 60px -28px rgba(27, 67, 50, 0.35);
    border-color: rgba(var(--color-accent-rgb), 0.35);
}

.value-card:hover::before { opacity: 1; }

.value-card__num {
    position: absolute;
    top: 1rem;
    right: 1.25rem;
    font-family: var(--font-display);
    font-size: 3rem;
    font-weight: 800;
    line-height: 1;
    color: rgba(27, 67, 50, 0.07);
    letter-spacing: -0.02em;
    transition: color 0.3s ease;
}

.value-card:hover .value-card__num { color: rgba(var(--color-accent-rgb), 0.28); }

.value-card__icon {
    display: inline-grid;
    place-items: center;
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 0.9rem;
    background: linear-gradient(135deg, var(--color-brand), var(--color-brand-dark));
    color: #fff;
    font-size: 1.25rem;
    margin-bottom: 1rem;
    box-shadow: 0 14px 24px -12px rgba(45, 106, 79, 0.55);
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.value-card:hover .value-card__icon {
    transform: rotate(-8deg) scale(1.05);
}

.value-card__title {
    font-family: var(--font-display);
    font-size: 1.2rem;
    margin: 0 0 0.5rem;
    color: var(--color-brand-dark);
}

.value-card__text {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.97rem;
    line-height: 1.6;
    position: relative;
    z-index: 1;
}

.value-card__text em {
    color: var(--color-brand-dark);
    font-style: italic;
    font-weight: 500;
}

/* ----- Verse ----- */
.about-verse {
    position: relative;
    overflow: hidden;
    padding: clamp(3.5rem, 6vw, 5rem) 0;
    isolation: isolate;
    text-align: center;
}

.about-verse__bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(700px 400px at 20% 20%, rgba(var(--color-accent-rgb), 0.22), transparent 60%),
        radial-gradient(800px 500px at 80% 80%, rgba(45, 106, 79, 0.28), transparent 60%),
        linear-gradient(140deg, #1b4332, #0d2f20);
}

.about-verse__bg::after {
    content: "\201C";
    position: absolute;
    right: 4vw;
    top: -5rem;
    font-family: "Great Vibes", serif;
    font-size: clamp(12rem, 20vw, 22rem);
    line-height: 1;
    color: rgba(var(--color-accent-rgb), 0.18);
    pointer-events: none;
}

.about-verse__inner {
    max-width: 820px;
    margin-inline: auto;
    color: #f7f3ea;
    position: relative;
}

.about-verse__icon {
    color: var(--color-accent);
    font-size: 1.75rem;
    margin-bottom: 0.75rem;
}

.about-verse__inner .about-section__eyebrow { justify-content: center; }

.about-verse__quote {
    margin: 1rem 0 1.25rem;
    font-family: var(--font-display);
}

.about-verse__quote p {
    font-size: clamp(1.25rem, 1.2vw + 1rem, 2rem);
    line-height: 1.3;
    margin: 0 0 1rem;
    font-weight: 500;
    letter-spacing: -0.005em;
}

.about-verse__quote cite {
    display: block;
    font-style: normal;
    font-size: 0.9rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-accent);
    font-weight: 700;
}

.about-verse__note {
    margin: 0 auto;
    color: rgba(247, 243, 234, 0.78);
    max-width: 48ch;
    font-size: 1rem;
}

/* ----- Final CTA ----- */
.about-cta {
    padding: clamp(3rem, 6vw, 5rem) 0 clamp(4rem, 7vw, 6rem);
    text-align: center;
}

.about-cta__title { margin: 0 auto 0.5rem; }

.about-cta__lede {
    color: var(--color-muted);
    font-size: 1.05rem;
    margin: 0 auto 2rem;
    max-width: 48ch;
}

.about-cta__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
    max-width: 840px;
    margin-inline: auto;
    text-align: left;
}

.about-cta__card {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.75rem;
    background: var(--color-surface);
    border: 1px solid rgba(27, 67, 50, 0.1);
    border-radius: 1.25rem;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 18px 40px -24px rgba(27, 67, 50, 0.3);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    position: relative;
    overflow: hidden;
}

.about-cta__card::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 4px;
    background: linear-gradient(90deg, var(--color-brand), var(--color-accent));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
}

.about-cta__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 28px 56px -24px rgba(27, 67, 50, 0.35);
    border-color: rgba(var(--color-accent-rgb), 0.4);
}

.about-cta__card:hover::after { transform: scaleX(1); }

.about-cta__icon {
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(var(--color-accent-rgb), 0.15);
    color: var(--color-accent-dark);
    font-size: 1.3rem;
    margin-bottom: 0.5rem;
    transition: transform 0.35s ease;
}

.about-cta__card:hover .about-cta__icon { transform: rotate(-6deg) scale(1.05); }

.about-cta__card h3 {
    font-family: var(--font-display);
    font-size: 1.2rem;
    margin: 0;
    color: var(--color-brand-dark);
}

.about-cta__card p {
    margin: 0 0 0.25rem;
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.5;
    flex: 1;
}

.about-cta__link {
    font-weight: 700;
    color: var(--color-brand);
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.92rem;
    margin-top: 0.35rem;
}

.about-cta__link i { transition: transform 0.2s ease; }
.about-cta__card:hover .about-cta__link i { transform: translateX(3px); }

/* Accent (dark) variant — must come AFTER base rules so color wins */
.about-cta__card--accent {
    background: linear-gradient(140deg, #2d6a4f, #1b4332);
    color: #f7f3ea;
    border-color: transparent;
}

.about-cta__card--accent h3 { color: #fff; }
.about-cta__card--accent p { color: rgba(247, 243, 234, 0.88); }
.about-cta__card--accent .about-cta__link { color: var(--color-accent); }
.about-cta__card--accent .about-cta__icon {
    background: rgba(var(--color-accent-rgb), 0.22);
    color: var(--color-accent);
}

/* Motion-reduce niceties */
@media (prefers-reduced-motion: reduce) {
    .about-hero__eyebrow-dot,
    .about-hero__orbit,
    .about-hero__chip,
    .about-hero__rotator,
    .about-hero__marquee-track,
    .timeline__terminus span { animation: none !important; }
    .about-hero__rotator-word { transition: none !important; }
    .timeline__item { opacity: 1 !important; transform: none !important; }
}


/* =========================================================
   HOME — Hero enhancements (kinetic rotator, chips, trust)
   Layered on top of existing .hero.hero--split
   ========================================================= */

.home-hero {
    position: relative;
    overflow: hidden;
}

.home-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(900px 500px at 88% 12%, rgba(15, 111, 110, 0.14), transparent 62%),
        radial-gradient(700px 420px at 10% 92%, rgba(232, 109, 30, 0.10), transparent 60%);
}

.hero.hero--split.home-hero .hero--split-inner {
    background: linear-gradient(
        135deg,
        #fff 0%,
        #fff 44%,
        #f1e6f2 78%,
        #dcc8e0 100%
    );
}

.hero.hero--split.home-hero .hero__content {
    max-width: 40rem;
    text-align: left;
    padding-left: clamp(1.25rem, 4vw, 3.5rem);
    padding-right: clamp(0.75rem, 2vw, 1.5rem);
    margin-inline: 0;
}

.hero.hero--split.home-hero .hero__actions {
    justify-content: flex-start;
}

.home-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.4rem 0.9rem;
    background: rgba(15, 111, 110, 0.08);
    color: var(--color-brand, #0f6f6e) !important;
    border: 1px solid rgba(15, 111, 110, 0.16);
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.85rem !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    max-width: none !important;
    margin-inline: 0 !important;
    line-height: 1.2 !important;
    width: fit-content;
}

.home-hero__eyebrow-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-accent, #e86d1e);
    box-shadow: 0 0 0 0 rgba(232, 109, 30, 0.7);
    animation: homeHeroPulse 2s ease-in-out infinite;
}

@keyframes homeHeroPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(232, 109, 30, 0.55); }
    50% { box-shadow: 0 0 0 8px rgba(232, 109, 30, 0); }
}

.home-hero__title {
    font-size: clamp(2rem, 4.6vw, 3.6rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.02em;
    display: block;
    margin-top: 1rem !important;
    margin-bottom: 1.25rem !important;
}

.home-hero__title-tail {
    display: block;
    margin-top: 0.35rem;
    font-weight: 600;
    color: #2b2b2b;
    font-size: 0.6em;
    letter-spacing: -0.005em;
}

.home-hero__rotator {
    position: relative;
    display: inline-block;
    vertical-align: baseline;
    min-width: 8ch;
    height: 1.05em;
    overflow: hidden;
    color: var(--color-brand, #0f6f6e);
}

.home-hero__rotator-word {
    position: absolute;
    inset: 0;
    opacity: 0;
    transform: translateY(60%) rotate(3deg);
    transition: opacity 0.55s ease, transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
    font-style: italic;
    background: linear-gradient(95deg, #0f6f6e 0%, #e86d1e 92%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    white-space: nowrap;
}

.home-hero__rotator-word.is-active {
    opacity: 1;
    transform: translateY(0) rotate(0);
}

.home-hero__rotator-word.is-leaving {
    opacity: 0;
    transform: translateY(-60%) rotate(-3deg);
}

.hero.hero--split.home-hero .hero__subtext.home-hero__subtext {
    max-width: 46ch;
    margin-inline: 0;
    font-size: clamp(1rem, 1.6vw, 1.15rem);
    color: #3f4854;
}

.home-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    margin-top: 1.5rem;
}

.home-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.home-hero__btn--ghost {
    background: transparent;
    border: 2px solid var(--color-brand, #0f6f6e) !important;
    color: var(--color-brand, #0f6f6e) !important;
}
.home-hero__btn--ghost:hover {
    background: var(--color-brand, #0f6f6e) !important;
    color: #fff !important;
}

.home-hero__trust {
    list-style: none;
    padding: 0;
    margin: 1.75rem 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.5rem;
    font-size: 0.9rem;
    color: #4f5864;
}

.home-hero__trust li {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.home-hero__trust i {
    color: var(--color-brand, #0f6f6e);
    font-size: 0.95rem;
}

/* Floating chips on the hero image — anchored inside the media container */
.hero.hero--split.home-hero .split__media.home-hero__media {
    position: relative;
    overflow: visible;
}

.home-hero__chip {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.6rem 0.9rem;
    background: rgba(255, 255, 255, 0.96);
    color: #1a1a1a;
    border-radius: 14px;
    box-shadow: 0 10px 28px -10px rgba(0, 0, 0, 0.28), 0 2px 8px -4px rgba(0, 0, 0, 0.15);
    font-weight: 500;
    font-size: 0.88rem;
    backdrop-filter: blur(6px);
    z-index: 3;
    animation: homeHeroChipFloat 5s ease-in-out infinite;
    max-width: calc(100% - 1.5rem);
    white-space: nowrap;
}

.home-hero__chip strong {
    color: var(--color-brand, #0f6f6e);
    font-weight: 800;
    font-size: 1rem;
}

.home-hero__chip i {
    color: var(--color-accent, #e86d1e);
    font-size: 1.05rem;
}

.home-hero__chip--top {
    top: 8%;
    left: 0.75rem;
    animation-delay: 0.4s;
}

.home-hero__chip--bottom {
    bottom: 10%;
    right: 0.75rem;
    animation-delay: 1.6s;
}

@keyframes homeHeroChipFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

@media (max-width: 900px) {
    .home-hero__chip--top { left: 0.5rem; top: 4%; }
    .home-hero__chip--bottom { right: 0.5rem; bottom: 5%; }
    .home-hero__chip { font-size: 0.78rem; padding: 0.5rem 0.7rem; }
    .home-hero__chip strong { font-size: 0.9rem; }
    .hero.hero--split.home-hero .hero__content {
        text-align: center;
        padding-left: 1.25rem;
        padding-right: 1.25rem;
        margin-inline: auto;
    }
    .hero.hero--split.home-hero .hero__actions { justify-content: center; }
    .home-hero__eyebrow { margin-inline: auto !important; }
    .home-hero__trust { justify-content: center; }
    .hero.hero--split.home-hero .hero__subtext.home-hero__subtext { margin-inline: auto; }
}

@media (max-width: 520px) {
    .home-hero__chip { display: none; }
}


/* =========================================================
   HOME — Impact stats ribbon (floating over hero bottom)
   Reuses .impact-tiles / .impact-tile classes
   ========================================================= */

.home-impact {
    position: relative;
    z-index: 5;
    padding: 0;
    margin-top: clamp(-3rem, -4vw, -2rem);
    margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.home-impact__tiles {
    background: #fff;
    box-shadow: 0 30px 60px -30px rgba(10, 20, 40, 0.22), 0 2px 10px -4px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(15, 111, 110, 0.08);
}


/* =========================================================
   HOME — Testimony block (between pillars & ways cards)
   ========================================================= */

.home-testimony {
    position: relative;
    padding: clamp(3.5rem, 6vw, 5.5rem) 0;
    overflow: hidden;
    isolation: isolate;
}

.home-testimony__bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(600px 500px at 85% 50%, rgba(232, 109, 30, 0.16), transparent 62%),
        radial-gradient(520px 420px at 12% 70%, rgba(15, 111, 110, 0.14), transparent 60%),
        linear-gradient(180deg, #fdf8f2 0%, #fff 100%);
}

.home-testimony__inner {
    position: relative;
}

.home-testimony__figure {
    margin: 0;
    display: grid;
    grid-template-columns: minmax(240px, 340px) 1fr;
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
}

.home-testimony__portrait {
    position: relative;
    border-radius: 28px;
    overflow: hidden;
    background: linear-gradient(140deg, #ffd89b 0%, #f59c4a 50%, #e86d1e 100%);
    min-height: 340px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 1rem 1rem 0;
    box-shadow: 0 28px 60px -22px rgba(232, 109, 30, 0.45);
}

.home-testimony__portrait::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 70% 18%, rgba(255, 255, 255, 0.45), transparent 52%),
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.06) 0 2px, transparent 2px 14px);
    mix-blend-mode: soft-light;
    pointer-events: none;
}

.home-testimony__portrait::after {
    content: "";
    position: absolute;
    left: 16%;
    right: 16%;
    bottom: 8%;
    height: 14px;
    background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.35), transparent 70%);
    filter: blur(8px);
    pointer-events: none;
}

.home-testimony__portrait img {
    position: relative;
    z-index: 1;
    max-width: 85%;
    max-height: 92%;
    width: auto;
    height: auto;
    object-fit: contain;
    object-position: center bottom;
}

.home-testimony__body {
    margin: 0;
    max-width: 58ch;
}

.home-testimony__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent, #e86d1e);
    margin-bottom: 1rem;
}

.home-testimony__quote {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.35rem, 2.3vw, 1.8rem);
    line-height: 1.35;
    color: #1a1f2b;
    font-style: italic;
    margin: 0 0 1.25rem;
    position: relative;
}

.home-testimony__body figcaption {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    font-size: 0.95rem;
    color: #3c4656;
    margin-bottom: 1.5rem;
}

.home-testimony__body figcaption strong {
    color: var(--color-brand, #0f6f6e);
    font-weight: 700;
    font-size: 1rem;
}

.home-testimony__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.home-testimony__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

@media (max-width: 820px) {
    .home-testimony__figure {
        grid-template-columns: 1fr;
        text-align: center;
    }
    .home-testimony__portrait {
        max-width: 320px;
        margin: 0 auto;
        min-height: 300px;
    }
    .home-testimony__eyebrow,
    .home-testimony__actions {
        justify-content: center;
    }
}


/* =========================================================
   HOME — Finale CTA band (dark, dramatic)
   Replaces flat stewardship section
   ========================================================= */

.home-finale {
    position: relative;
    padding: clamp(4rem, 7vw, 6.5rem) 0 clamp(3rem, 5vw, 4.5rem);
    overflow: hidden;
    isolation: isolate;
    color: #f6f8fb;
}

.home-finale__bg {
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(700px 500px at 85% 15%, rgba(232, 109, 30, 0.35), transparent 62%),
        radial-gradient(600px 440px at 12% 85%, rgba(15, 111, 110, 0.45), transparent 60%),
        linear-gradient(135deg, #0b1626 0%, #131f35 55%, #0c1a2a 100%);
}

.home-finale__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(rgba(255, 255, 255, 0.06) 1px, transparent 1px);
    background-size: 22px 22px;
    background-position: 0 0;
    mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
    opacity: 0.5;
    pointer-events: none;
}

.home-finale__marquee {
    position: absolute;
    top: 1.5rem;
    left: 0;
    right: 0;
    overflow: hidden;
    z-index: -1;
    opacity: 0.14;
    pointer-events: none;
    font-family: Georgia, "Times New Roman", serif;
    font-style: italic;
    font-weight: 400;
    font-size: clamp(3rem, 9vw, 7rem);
    line-height: 1;
    color: #fff;
    white-space: nowrap;
}

.home-finale__marquee-track {
    display: inline-flex;
    gap: 2rem;
    animation: homeFinaleMarquee 48s linear infinite;
    padding-left: 100%;
}

.home-finale__marquee-track span {
    display: inline-block;
}

@keyframes homeFinaleMarquee {
    from { transform: translate3d(0, 0, 0); }
    to { transform: translate3d(-100%, 0, 0); }
}

.home-finale__inner {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 56rem;
    margin: 0 auto;
}

.home-finale__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.45rem 0.95rem;
    background: rgba(232, 109, 30, 0.15);
    border: 1px solid rgba(232, 109, 30, 0.35);
    color: #ffc79c;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 1.5rem;
}

.home-finale__eyebrow-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #ff9a4d;
    box-shadow: 0 0 0 0 rgba(255, 154, 77, 0.7);
    animation: homeHeroPulse 2s ease-in-out infinite;
}

.home-finale__title {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2.1rem, 5vw, 3.75rem);
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: #fff;
    margin: 0 0 1.25rem;
    font-weight: 600;
}

.home-finale__title-accent {
    background: linear-gradient(95deg, #ffd89b 0%, #ff9a4d 60%, #ffd89b 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-style: italic;
}

.home-finale__lede {
    font-size: clamp(1rem, 1.6vw, 1.15rem);
    line-height: 1.65;
    color: #c8d3e2;
    max-width: 52ch;
    margin: 0 auto 2rem;
}

.home-finale__lede strong {
    color: #fff;
}

.home-finale__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.9rem;
    margin-bottom: 2rem;
}

.home-finale__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.home-finale__btn--ghost {
    background: transparent !important;
    border: 2px solid rgba(255, 255, 255, 0.6) !important;
    color: #fff !important;
}

.home-finale__btn--ghost:hover {
    background: #fff !important;
    color: #0b1626 !important;
    border-color: #fff !important;
}

.home-finale__trust {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.6rem 2rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
}

.home-finale__trust li {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.home-finale__trust i {
    color: #ff9a4d;
}


/* Home — reduced motion */
@media (prefers-reduced-motion: reduce) {
    .home-hero__eyebrow-dot,
    .home-hero__chip,
    .home-finale__marquee-track,
    .home-finale__eyebrow-dot { animation: none !important; }
    .home-hero__rotator-word { transition: none !important; }
}


/* =========================================================
   CARE VILLAGES — Hero
   ========================================================= */

body:has(.care-hero) .page-header { display: none; }

.care-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(3.5rem, 6vw, 6rem) 0 clamp(3.5rem, 5vw, 5rem);
    color: #f8f9fb;
    isolation: isolate;
}

.care-hero__bg {
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        linear-gradient(135deg, #0b2623 0%, #103836 40%, #0e2a38 100%);
}

.care-hero__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px);
    background-size: 22px 22px;
    mask-image: radial-gradient(ellipse at center, #000 35%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 35%, transparent 75%);
    opacity: 0.55;
}

.care-hero__glow {
    position: absolute;
    z-index: -1;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.55;
    pointer-events: none;
}

.care-hero__glow--brand {
    width: 560px;
    height: 560px;
    background: radial-gradient(circle, rgba(15, 111, 110, 0.9), transparent 60%);
    top: -15%;
    left: -10%;
    animation: careHeroGlow 12s ease-in-out infinite alternate;
}

.care-hero__glow--accent {
    width: 520px;
    height: 520px;
    background: radial-gradient(circle, rgba(232, 109, 30, 0.65), transparent 60%);
    bottom: -20%;
    right: -10%;
    animation: careHeroGlow 14s 2s ease-in-out infinite alternate-reverse;
}

@keyframes careHeroGlow {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(24px, -18px) scale(1.08); }
}

.care-hero__inner {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
    gap: clamp(2rem, 4vw, 3.5rem);
    align-items: center;
}

.care-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.45rem 0.95rem;
    background: rgba(232, 109, 30, 0.14);
    border: 1px solid rgba(232, 109, 30, 0.38);
    color: #ffc79c;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 1.25rem;
}

.care-hero__eyebrow-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #ff9a4d;
    box-shadow: 0 0 0 0 rgba(255, 154, 77, 0.7);
    animation: homeHeroPulse 2s ease-in-out infinite;
}

.care-hero__title {
    font-family: var(--font-display, Georgia, serif);
    font-size: clamp(2.1rem, 4.5vw, 3.75rem);
    line-height: 1.08;
    letter-spacing: -0.015em;
    color: #fff;
    margin: 0 0 1.25rem;
    font-weight: 700;
}

.care-hero__rotator {
    position: relative;
    display: inline-block;
    vertical-align: baseline;
    min-width: 6ch;
    height: 1.05em;
    overflow: hidden;
}

.care-hero__rotator-word {
    position: absolute;
    inset: 0;
    opacity: 0;
    transform: translateY(60%) rotate(3deg);
    transition: opacity 0.55s ease, transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
    font-style: italic;
    background: linear-gradient(95deg, #ffd89b 0%, #ff9a4d 60%, #ffd89b 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    white-space: nowrap;
}

.care-hero__rotator-word.is-active { opacity: 1; transform: translateY(0) rotate(0); }
.care-hero__rotator-word.is-leaving { opacity: 0; transform: translateY(-60%) rotate(-3deg); }

.care-hero__lede {
    font-size: clamp(1rem, 1.6vw, 1.2rem);
    line-height: 1.65;
    color: #cdd6d5;
    max-width: 58ch;
    margin: 0 0 2rem;
}

.care-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    margin-bottom: 1.5rem;
}

.care-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.care-hero__btn--ghost {
    background: transparent !important;
    border: 2px solid rgba(255, 255, 255, 0.6) !important;
    color: #fff !important;
}

.care-hero__btn--ghost:hover {
    background: #fff !important;
    color: #0b2623 !important;
    border-color: #fff !important;
}

.care-hero__trust {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1.5rem;
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.75);
}

.care-hero__trust li {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.care-hero__trust i { color: #ff9a4d; }

/* Hero visual — photo with orbital rings + floating pills */
.care-hero__visual {
    position: relative;
    aspect-ratio: 1 / 1;
    min-height: 320px;
    max-height: 520px;
}

.care-hero__ring {
    position: absolute;
    border-radius: 50%;
    inset: 0;
    animation: careHeroSpin 40s linear infinite;
    pointer-events: none;
}

/* Outer halo — prominent ring framing the picture */
.care-hero__ring--1 {
    inset: -2%;
    border: 2.5px dashed rgba(255, 215, 155, 0.85);
    box-shadow:
        0 0 28px rgba(232, 109, 30, 0.35),
        0 0 0 1px rgba(232, 109, 30, 0.18) inset;
}

/* Secondary halo — solid accent ring just inside the outer */
.care-hero__ring--2 {
    inset: 6%;
    border: 2px solid rgba(232, 109, 30, 0.65);
    box-shadow: 0 0 18px rgba(232, 109, 30, 0.35);
    animation-duration: 30s;
    animation-direction: reverse;
}

.care-hero__ring--3 {
    display: none;
}

@keyframes careHeroSpin {
    to { transform: rotate(360deg); }
}

/* Photo variant — circular golden-hour frame with cutout Mama+child */
.care-hero__visual--photo {
    aspect-ratio: 1 / 1;
    max-height: 560px;
}

.care-hero__photo {
    position: absolute;
    inset: 4%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    background: transparent;
}

.care-hero__photo::after {
    content: "";
    position: absolute;
    left: 22%;
    right: 22%;
    bottom: 3%;
    height: 16px;
    background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.45), transparent 70%);
    filter: blur(10px);
    pointer-events: none;
}

.care-hero__photo img {
    position: relative;
    z-index: 1;
    width: auto;
    height: auto;
    max-width: 118%;
    max-height: 118%;
    object-fit: contain;
    object-position: center bottom;
    display: block;
    filter: drop-shadow(0 14px 22px rgba(0, 0, 0, 0.35));
    border-radius: 0;
    transform: translateY(-10%);
}

.care-hero__pill {
    position: absolute;
    background: rgba(255, 255, 255, 0.97);
    color: #0b2623;
    padding: 0.65rem 0.95rem;
    border-radius: 16px;
    box-shadow: 0 14px 32px -12px rgba(0, 0, 0, 0.45), 0 2px 8px -4px rgba(0, 0, 0, 0.25);
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-size: 0.85rem;
    font-weight: 500;
    line-height: 1.1;
    animation: homeHeroChipFloat 6s ease-in-out infinite;
}

.care-hero__pill i {
    color: var(--color-accent, #e86d1e);
    font-size: 1.1rem;
}

.care-hero__pill strong {
    color: var(--color-brand, #0f6f6e);
    font-weight: 800;
}

.care-hero__pill-num {
    font-family: var(--font-display, Georgia, serif);
    font-weight: 800;
    font-size: 1.5rem;
    color: var(--color-brand, #0f6f6e);
    line-height: 1;
}

.care-hero__pill-label {
    font-size: 0.78rem;
    color: #3c4a49;
}

.care-hero__pill--1 { top: 4%; left: -6%; animation-delay: 0s; }
.care-hero__pill--2 { top: 18%; right: -4%; animation-delay: 1.5s; background: linear-gradient(135deg, #fff, #fff3e3); }
.care-hero__pill--3 { bottom: 20%; left: -4%; animation-delay: 2.5s; }
.care-hero__pill--4 { bottom: 2%; right: 4%; animation-delay: 3.5s; }

@media (max-width: 960px) {
    .care-hero__inner { grid-template-columns: 1fr; }
    .care-hero__visual {
        max-width: 340px;
        margin: 0 auto;
        min-height: 260px;
    }
    .care-hero__text { text-align: center; }
    .care-hero__eyebrow { margin-inline: auto; }
    .care-hero__actions { justify-content: center; }
    .care-hero__trust { justify-content: center; }
    .care-hero__lede { margin-inline: auto; }
    .care-hero__pill--1 { left: -2%; }
    .care-hero__pill--2 { right: -2%; }
    .care-hero__pill--3 { left: -2%; }
}

@media (max-width: 540px) {
    .care-hero__pill { font-size: 0.75rem; padding: 0.5rem 0.7rem; }
    .care-hero__pill-num { font-size: 1.15rem; }
}


/* =========================================================
   CARE VILLAGES — Impact ribbon
   ========================================================= */

.care-impact {
    position: relative;
    z-index: 5;
    padding: 0;
    margin-top: clamp(-3rem, -4vw, -2rem);
    margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.care-impact__tiles {
    background: #fff;
    box-shadow: 0 30px 60px -30px rgba(10, 28, 40, 0.28), 0 2px 10px -4px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(15, 111, 110, 0.08);
}


/* =========================================================
   CARE VILLAGES — Narrative sections
   ========================================================= */

.care-narrative {
    display: grid;
    gap: clamp(2rem, 4vw, 3.25rem);
}

.care-narrative__intro {
    font-size: clamp(1.05rem, 1.4vw, 1.2rem);
    line-height: 1.7;
    color: #2a3340;
    padding: 1.25rem 1.5rem;
    background: linear-gradient(135deg, rgba(15, 111, 110, 0.06), rgba(232, 109, 30, 0.04));
    border-left: 4px solid var(--color-accent, #e86d1e);
    border-radius: 0 14px 14px 0;
    margin: 0;
}

.care-narrative__intro strong {
    color: var(--color-brand-dark, #0a4a49);
}

.care-section__eyebrow {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-accent, #e86d1e);
    margin: 0 0 0.5rem;
}

.care-section__title {
    font-family: var(--font-display, Georgia, serif);
    font-size: clamp(1.5rem, 2.4vw, 2.1rem);
    line-height: 1.2;
    color: var(--color-ink, #1a1a1a);
    margin: 0 0 1.5rem;
    letter-spacing: -0.01em;
}

/* Philosophy cards */
.care-philosophy__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.care-philosophy__card {
    padding: 1.4rem;
    background: #fff;
    border: 1px solid rgba(15, 111, 110, 0.12);
    border-radius: 18px;
    box-shadow: 0 10px 26px -18px rgba(10, 28, 40, 0.25);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.care-philosophy__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 38px -18px rgba(10, 28, 40, 0.3);
}

.care-philosophy__icon {
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 14px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(15, 111, 110, 0.14), rgba(232, 109, 30, 0.12));
    color: var(--color-brand, #0f6f6e);
    font-size: 1.15rem;
    margin-bottom: 0.85rem;
}

.care-philosophy__card h3 {
    font-size: 1.1rem;
    margin: 0 0 0.5rem;
    color: var(--color-brand-dark, #0a4a49);
}

.care-philosophy__card p {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.55;
    color: #3c4656;
}

/* Components */
.care-components__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.care-component {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    padding: 1.2rem;
    background: #fafbfc;
    border-radius: 16px;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.care-component__badge {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: var(--color-brand, #0f6f6e);
    color: #fff;
    font-size: 0.95rem;
    flex-shrink: 0;
}

.care-component__badge--alt {
    background: var(--color-accent, #e86d1e);
}

.care-component > :not(.care-component__badge) {
    grid-column: 2;
}

.care-component h3 {
    font-size: 1rem;
    margin: 0 0 0.35rem;
    color: var(--color-ink, #1a1a1a);
    text-wrap: balance;
    min-width: 0;
    line-height: 1.25;
}

.care-component p {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.55;
    color: #4a5463;
}

/* Strategic approach — numbered flow */
.care-approach__list {
    display: grid;
    gap: 0.9rem;
    position: relative;
}

.care-approach__list::before {
    content: "";
    position: absolute;
    left: 1.95rem;
    top: 0.5rem;
    bottom: 0.5rem;
    width: 2px;
    background: linear-gradient(to bottom, var(--color-accent, #e86d1e), rgba(15, 111, 110, 0.35));
    border-radius: 2px;
}

.care-approach__item {
    display: grid;
    grid-template-columns: 3.8rem 1fr;
    gap: 1rem;
    padding: 1rem 1.2rem 1rem 0;
    position: relative;
}

.care-approach__num {
    font-family: var(--font-display, Georgia, serif);
    font-size: 1.1rem;
    font-weight: 800;
    color: #fff;
    background: var(--color-brand, #0f6f6e);
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    box-shadow: 0 6px 14px -6px rgba(15, 111, 110, 0.55), 0 0 0 4px #fff;
    position: relative;
    z-index: 1;
    letter-spacing: -0.01em;
}

.care-approach__item:nth-child(even) .care-approach__num {
    background: var(--color-accent, #e86d1e);
    box-shadow: 0 6px 14px -6px rgba(232, 109, 30, 0.55), 0 0 0 4px #fff;
}

.care-approach__body h3 {
    font-size: 1.1rem;
    margin: 0.4rem 0 0.5rem;
    color: var(--color-brand-dark, #0a4a49);
}

.care-approach__body ul {
    margin: 0;
    padding-left: 1.2rem;
    font-size: 0.94rem;
    line-height: 1.55;
    color: #3c4656;
}

.care-approach__body ul li {
    margin-bottom: 0.3rem;
}

/* Programs grid */
.care-programs__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 0.9rem;
}

.care-program-card {
    padding: 1.2rem;
    background: #fff;
    border: 1px solid rgba(15, 111, 110, 0.1);
    border-radius: 14px;
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
    position: relative;
    overflow: hidden;
}

.care-program-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(to bottom, var(--color-accent, #e86d1e), var(--color-brand, #0f6f6e));
    transform: scaleY(0);
    transform-origin: top;
    transition: transform 0.35s ease;
}

.care-program-card:hover {
    transform: translateY(-3px);
    border-color: rgba(232, 109, 30, 0.3);
    box-shadow: 0 14px 32px -18px rgba(10, 28, 40, 0.25);
}

.care-program-card:hover::before {
    transform: scaleY(1);
}

.care-program-card__icon {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(15, 111, 110, 0.15), rgba(232, 109, 30, 0.08));
    color: var(--color-brand, #0f6f6e);
    font-size: 1rem;
    margin-bottom: 0.75rem;
}

.care-program-card h3 {
    font-size: 1rem;
    margin: 0 0 0.4rem;
    color: var(--color-brand-dark, #0a4a49);
    letter-spacing: -0.005em;
}

.care-program-card p {
    margin: 0;
    font-size: 0.89rem;
    line-height: 1.5;
    color: #4a5463;
}

.care-program-card--wide { grid-column: 1 / -1; }
@media (min-width: 720px) {
    .care-program-card--wide {
        grid-column: span 2;
        background: linear-gradient(135deg, rgba(15, 111, 110, 0.05), rgba(232, 109, 30, 0.04));
    }
}

.care-programs__nav {
    text-align: right;
    margin: 1.25rem 0 0;
}

.care-programs__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: var(--color-accent, #e86d1e);
    text-decoration: none;
    transition: gap 0.3s ease, color 0.3s ease;
}

.care-programs__link:hover {
    color: var(--color-brand, #0f6f6e);
    gap: 0.8rem;
    text-decoration: underline;
    text-underline-offset: 4px;
}


/* =========================================================
   CARE VILLAGES — Finale CTA
   ========================================================= */

.care-finale {
    position: relative;
    padding: clamp(4rem, 7vw, 6rem) 0 clamp(3rem, 5vw, 4rem);
    overflow: hidden;
    isolation: isolate;
    color: #f6f8fb;
    margin-top: clamp(3rem, 5vw, 4.5rem);
}

.care-finale__bg {
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(700px 480px at 15% 15%, rgba(15, 111, 110, 0.45), transparent 60%),
        radial-gradient(600px 440px at 85% 85%, rgba(232, 109, 30, 0.4), transparent 60%),
        linear-gradient(135deg, #0a1e1c 0%, #0f2a3e 55%, #091a27 100%);
}

.care-finale__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, 0.06) 1px, transparent 1px);
    background-size: 22px 22px;
    mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
    opacity: 0.5;
    pointer-events: none;
}

.care-finale__marquee {
    position: absolute;
    top: 1.5rem;
    left: 0;
    right: 0;
    overflow: hidden;
    z-index: -1;
    opacity: 0.12;
    pointer-events: none;
    font-family: Georgia, "Times New Roman", serif;
    font-style: italic;
    font-size: clamp(3rem, 9vw, 7rem);
    line-height: 1;
    color: #fff;
    white-space: nowrap;
}

.care-finale__marquee-track {
    display: inline-flex;
    gap: 2rem;
    animation: homeFinaleMarquee 48s linear infinite;
    padding-left: 100%;
}

.care-finale__inner {
    position: relative;
    z-index: 1;
    text-align: center;
    max-width: 56rem;
    margin: 0 auto;
}

.care-finale__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.45rem 0.95rem;
    background: rgba(232, 109, 30, 0.15);
    border: 1px solid rgba(232, 109, 30, 0.35);
    color: #ffc79c;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin: 0 0 1.25rem;
}

.care-finale__eyebrow-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #ff9a4d;
    animation: homeHeroPulse 2s ease-in-out infinite;
}

.care-finale__title {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2rem, 4.5vw, 3.4rem);
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: #fff;
    margin: 0 0 1.25rem;
    font-weight: 600;
}

.care-finale__title-accent {
    background: linear-gradient(95deg, #ffd89b 0%, #ff9a4d 60%, #ffd89b 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-style: italic;
}

.care-finale__lede {
    font-size: clamp(1rem, 1.6vw, 1.15rem);
    line-height: 1.65;
    color: #c8d3e2;
    max-width: 54ch;
    margin: 0 auto 2rem;
}

.care-finale__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.9rem;
    margin-bottom: 2rem;
}

.care-finale__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.care-finale__btn--ghost {
    background: transparent !important;
    border: 2px solid rgba(255, 255, 255, 0.6) !important;
    color: #fff !important;
}

.care-finale__btn--ghost:hover {
    background: #fff !important;
    color: #0a1e1c !important;
    border-color: #fff !important;
}

.care-finale__trust {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.6rem 2rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
}

.care-finale__trust li {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.care-finale__trust i {
    color: #ff9a4d;
}


/* Care Villages — reduced motion */
@media (prefers-reduced-motion: reduce) {
    .care-hero__glow,
    .care-hero__ring,
    .care-hero__pill,
    .care-hero__eyebrow-dot,
    .care-finale__marquee-track,
    .care-finale__eyebrow-dot { animation: none !important; }
    .care-hero__rotator-word { transition: none !important; }
}

/* Across Borders */
body:has(.ab-page) .page-header { display: none; }

.ab-page {
    --ab-dark: var(--color-brand-dark);
    --ab-mid: var(--color-brand);
}

.ab-hero {
    position: relative;
    overflow: hidden;
    background: var(--ab-dark);
}

.ab-hero__bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 90% at 15% 80%, rgba(45, 106, 79, 0.35) 0%, transparent 55%),
        radial-gradient(ellipse 50% 70% at 85% 50%, rgba(27, 67, 50, 0.4) 0%, transparent 60%),
        linear-gradient(180deg, #0d1f18 0%, var(--ab-dark) 40%, #0a1612 100%);
    pointer-events: none;
}

.ab-hero__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.22fr) minmax(0, 1.08fr) minmax(0, 1.05fr);
    align-items: stretch;
    gap: clamp(0.35rem, 1.5vw, 1rem);
    min-height: clamp(6.175rem, 11.4vw, 9.025rem);
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 clamp(0.75rem, 2.5vw, 2rem);
}

.ab-hero__col {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.ab-hero__col--left {
    position: relative;
    align-self: stretch;
    justify-content: flex-start;
    min-height: 100%;
    padding: 0;
    overflow: visible;
}

.ab-hero__logo {
    display: block;
    width: min(11rem, 90%);
    margin-bottom: 0.5rem;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.35));
}

.ab-hero__logo img {
    display: block;
    width: 100%;
    height: auto;
}

.ab-hero__scene {
    margin: 0;
    padding: 0;
    flex: 1 1 auto;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    align-self: stretch;
    min-height: 0;
    height: 100%;
    overflow: visible;
}

.ab-hero__photo--family {
    display: block;
    width: auto;
    height: auto;
    max-width: 145%;
    max-height: 100%;
    margin: 0;
    padding: 0;
    object-fit: contain;
    object-position: top center;
    filter: drop-shadow(0 10px 28px rgba(0, 0, 0, 0.45));
}

.ab-hero__label {
    position: absolute;
    bottom: 0.5rem;
    left: 0;
    z-index: 2;
    display: inline-block;
    margin: 0;
    padding: 0.35rem 0.85rem;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #fff;
    background: var(--color-brand-dark);
    border-radius: 3px;
    box-shadow: 0 2px 8px rgba(27, 67, 50, 0.35);
}

.ab-hero__col--center {
    position: relative;
    justify-content: flex-start;
    align-self: stretch;
    align-items: center;
    text-align: center;
    padding: 0 0.5rem;
}

.ab-hero__birds {
    position: absolute;
    top: 0;
    right: 0;
    display: flex;
    gap: 0.35rem;
    font-size: 0.85rem;
    color: var(--color-accent);
    opacity: 0.9;
}

.ab-hero__birds i:nth-child(1) { transform: translateY(0) scale(0.85); opacity: 0.7; }
.ab-hero__birds i:nth-child(2) { transform: translateY(-4px) scale(0.95); }
.ab-hero__birds i:nth-child(3) { transform: translateY(-8px) scale(1.05); }
.ab-hero__birds i:nth-child(4) { transform: translateY(-12px) scale(1.1); }

.ab-hero__title {
    margin: 0;
    padding: 0;
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 3.8vw, 2.75rem);
    font-weight: 800;
    line-height: 0.9;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #fff;
    text-shadow: 0 4px 24px rgba(0, 0, 0, 0.35);
}

.ab-hero__arc {
    width: min(100%, 18rem);
    height: 3px;
    margin: 0.35rem auto 0.45rem;
    border: none;
    border-radius: 50%;
    background: transparent;
    box-shadow: 0 0 0 999px inset transparent;
    position: relative;
}

.ab-hero__arc::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 100%;
    height: 14px;
    border-top: 3px solid var(--color-accent);
    border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}

.ab-hero__kicker {
    margin: 0 0 0.25rem;
    font-size: clamp(0.65rem, 1.2vw, 0.8rem);
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.88);
}

.ab-hero__mission {
    margin: 0;
    font-size: clamp(0.78rem, 1.35vw, 0.92rem);
    font-weight: 600;
    line-height: 1.35;
    color: var(--color-accent);
    max-width: 28rem;
}

.ab-hero__col--right {
    justify-content: flex-start;
    align-self: stretch;
    align-items: stretch;
    min-height: 100%;
    padding: 0;
}

.ab-hero__portrait {
    margin: 0;
    padding: 0;
    flex: 1 1 auto;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    align-self: stretch;
    min-height: 0;
    height: 100%;
}

.ab-hero__photo--child {
    display: block;
    width: auto;
    height: auto;
    max-width: 115%;
    max-height: 100%;
    margin: 0;
    padding: 0;
    object-fit: contain;
    object-position: top right;
    filter: drop-shadow(-8px 8px 28px rgba(0, 0, 0, 0.5));
}

.ab-section__title {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 3vw, 2.35rem);
    font-weight: 700;
    line-height: 1.15;
    margin: 0 0 1rem;
    color: var(--color-brand-dark);
}

.ab-section__title--center { text-align: center; }

.ab-section__title--light { color: #fff; }

.ab-section__eyebrow {
    margin: 0 0 0.35rem;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent);
}

/* Across Borders — infographic body (green + yellow-orange accent) */
.ab-body {
    background:
        linear-gradient(180deg, rgba(var(--color-accent-rgb), 0.06) 0%, transparent 12rem),
        #f4f6f3;
}

/* Reveal-on-scroll */
[data-ab-reveal] {
    opacity: 0;
    transform: translateY(18px);
    transition:
        opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1) var(--ab-reveal-delay, 0s),
        transform 0.7s cubic-bezier(0.22, 1, 0.36, 1) var(--ab-reveal-delay, 0s);
    will-change: opacity, transform;
}

[data-ab-reveal].is-revealed {
    opacity: 1;
    transform: none;
}

/* Safety fallback: if JS reveal fails on mobile, show content immediately */
@media (max-width: 760px) {
    [data-ab-reveal] {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* Sticky in-page nav */
.ab-pagenav {
    position: sticky;
    top: 0;
    z-index: 30;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: saturate(140%) blur(10px);
    -webkit-backdrop-filter: saturate(140%) blur(10px);
    border-bottom: 1px solid rgba(27, 67, 50, 0.08);
    box-shadow: 0 8px 24px -18px rgba(27, 67, 50, 0.35);
}

.ab-pagenav__inner {
    padding-block: 0.5rem;
}

.ab-pagenav__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: nowrap;
    gap: 0.4rem;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(var(--color-accent-rgb), 0.4) transparent;
    -webkit-overflow-scrolling: touch;
}

.ab-pagenav__list::-webkit-scrollbar { height: 4px; }
.ab-pagenav__list::-webkit-scrollbar-thumb {
    background: rgba(var(--color-accent-rgb), 0.4);
    border-radius: 999px;
}

.ab-pagenav__link {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.85rem;
    border: 1px solid rgba(27, 67, 50, 0.12);
    border-radius: 999px;
    background: #fff;
    color: var(--color-brand-dark);
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
    text-decoration: none;
    transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease,
        border-color 0.2s ease, box-shadow 0.2s ease;
}

.ab-pagenav__link i {
    color: var(--color-accent);
    font-size: 0.78rem;
    transition: color 0.2s ease;
}

.ab-pagenav__link:hover,
.ab-pagenav__link:focus-visible {
    background: linear-gradient(120deg, var(--color-brand-dark) 0%, var(--color-brand) 100%);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 8px 20px -10px rgba(27, 67, 50, 0.55);
    transform: translateY(-1px);
}

.ab-pagenav__link:hover i,
.ab-pagenav__link:focus-visible i {
    color: var(--color-accent);
}

.ab-pagenav__link:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
}

.ab-icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.25rem;
    height: 3.25rem;
    flex-shrink: 0;
    border-radius: 50%;
    font-size: 1.2rem;
    color: #fff;
}

.ab-icon-badge--alert,
.ab-icon-badge--brand {
    background: linear-gradient(165deg, var(--color-brand-dark) 0%, var(--color-brand) 90%, rgba(var(--color-accent-rgb), 0.55) 100%);
    box-shadow:
        0 4px 12px rgba(27, 67, 50, 0.2),
        inset 0 -2px 0 rgba(var(--color-accent-rgb), 0.4);
}

.ab-icon-badge--mid {
    width: 2.75rem;
    height: 2.75rem;
    font-size: 1rem;
    background: linear-gradient(165deg, var(--color-brand-dark) 0%, var(--color-brand) 94%);
    box-shadow:
        0 3px 10px rgba(27, 67, 50, 0.18),
        inset 0 0 0 2px rgba(var(--color-accent-rgb), 0.28),
        inset 0 -2px 0 rgba(var(--color-accent-rgb), 0.42);
}

.ab-icon-badge--dark {
    background: linear-gradient(165deg, var(--color-brand-dark) 0%, var(--color-brand) 92%);
    box-shadow:
        0 3px 10px rgba(27, 67, 50, 0.16),
        inset 0 -2px 0 rgba(var(--color-accent-rgb), 0.32);
}

.ab-icon-badge--gold {
    width: 3.5rem;
    height: 3.5rem;
    font-size: 1.25rem;
    color: var(--color-brand-dark);
    background: var(--color-accent);
}

.ab-problem {
    padding: clamp(2rem, 4vw, 3rem) 0;
    background:
        radial-gradient(ellipse 90% 55% at 50% 0%, rgba(var(--color-accent-rgb), 0.12), transparent 58%),
        linear-gradient(180deg, #f9f6ef 0%, #eef2ef 100%);
}

.ab-problem__inner {
    max-width: 1100px;
}

.ab-problem__title {
    margin: 0 0 1.25rem;
    padding: 0.45rem 1rem;
    font-family: var(--font-display);
    font-size: clamp(1.1rem, 2.2vw, 1.45rem);
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
    background: linear-gradient(120deg, var(--color-brand-dark) 0%, var(--color-brand) 48%, var(--color-accent) 100%);
    border-radius: 0.35rem;
    box-shadow: 0 8px 24px rgba(27, 67, 50, 0.18), 0 4px 18px rgba(var(--color-accent-rgb), 0.25);
}

.ab-problem__intro {
    margin: 0 0 1.75rem;
    font-size: clamp(0.95rem, 1.5vw, 1.08rem);
    line-height: 1.65;
    color: var(--color-ink);
    text-align: center;
}

.ab-problem__intro strong {
    color: var(--color-brand-dark);
    background: linear-gradient(transparent 65%, rgba(var(--color-accent-rgb), 0.35) 65%);
}

.ab-problem__facts {
    margin: 0 0 1.5rem;
    padding: 0;
    list-style: none;
}

/* Stacked deck → fans out on scroll (same behavior as Who we are pillars) */
.ab-problem__facts.ab-problem-facts-deck {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
    clear: both;
    overflow: clip;
    padding: 1rem 0;
}

.ab-problem__fact {
    position: relative;
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 1.1rem 1.1rem 1.15rem;
    background: #fff;
    border: 1px solid rgba(27, 67, 50, 0.06);
    border-radius: 0.85rem;
    box-shadow: 0 12px 30px -22px rgba(27, 67, 50, 0.25);
    overflow: hidden;
    transition:
        transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.3s ease,
        border-color 0.3s ease;
}

.ab-problem__fact::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-brand) 0%, var(--color-accent) 100%);
    opacity: 0.85;
}

.ab-problem-facts-deck .ab-problem__fact {
    transform-origin: left center;
    transition:
        transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1),
        box-shadow 0.35s ease,
        border-color 0.35s ease;
}

.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(1) { transform: translate(-70px, -6px) rotate(-4deg); z-index: 4; }
.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(2) { transform: translate(-155px, -2px) rotate(-2deg); z-index: 3; }
.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(3) { transform: translate(-240px, 2px) rotate(1deg); z-index: 2; }
.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(4) { transform: translate(-325px, 6px) rotate(3deg); z-index: 1; }

.ab-problem-facts-deck.is-visible .ab-problem__fact {
    transform: translate(0, 0) rotate(0);
}

.ab-problem-facts-deck.is-visible .ab-problem__fact:nth-child(1) { transition-delay: 0ms; }
.ab-problem-facts-deck.is-visible .ab-problem__fact:nth-child(2) { transition-delay: 90ms; }
.ab-problem-facts-deck.is-visible .ab-problem__fact:nth-child(3) { transition-delay: 180ms; }
.ab-problem-facts-deck.is-visible .ab-problem__fact:nth-child(4) { transition-delay: 270ms; }

.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(1) { transition-delay: 270ms; }
.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(2) { transition-delay: 180ms; }
.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(3) { transition-delay: 90ms; }
.ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(4) { transition-delay: 0ms; }

@media (max-width: 700px) {
    .ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(1),
    .ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(2),
    .ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(3),
    .ab-problem-facts-deck:not(.is-visible) .ab-problem__fact:nth-child(4) {
        transform: translate(-30px, 0) rotate(-2deg);
    }
}

.ab-problem-facts-deck.is-visible .ab-problem__fact:hover,
.ab-problem-facts-deck.is-visible .ab-problem__fact:focus-within {
    transform: translateY(-4px);
    box-shadow: 0 22px 42px -22px rgba(27, 67, 50, 0.32);
    border-color: rgba(var(--color-accent-rgb), 0.35);
}

.ab-problem__fact .ab-icon-badge {
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.ab-problem-facts-deck.is-visible .ab-problem__fact:hover .ab-icon-badge {
    transform: scale(1.08) rotate(-3deg);
}

.ab-problem__fact-copy h3 {
    margin: 0 0 0.35rem;
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1.25;
    color: var(--color-brand-dark);
}

.ab-problem__fact-copy p {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.5;
    color: var(--color-muted);
}

.ab-family {
    padding: clamp(2rem, 4vw, 3rem) 0 clamp(2rem, 4vw, 3rem);
    background:
        radial-gradient(ellipse 70% 80% at 50% 100%, rgba(var(--color-accent-rgb), 0.1), transparent 65%),
        linear-gradient(180deg, #eef2ef 0%, #f4f6f3 100%);
}

.ab-family__inner {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2.25rem);
    align-items: center;
    max-width: 1180px;
    margin-inline: auto;
}

@media (min-width: 860px) {
    .ab-family__inner {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
    }
}

.ab-family__figure {
    position: relative;
    margin: 0;
    width: min(100%, 540px);
    margin-inline: auto;
    line-height: 0;
    display: grid;
    place-items: end center;
}

.ab-family__halo {
    position: absolute;
    inset: auto 5% 0 5%;
    height: 75%;
    border-radius: 50%;
    background:
        radial-gradient(circle at 50% 60%, rgba(var(--color-accent-rgb), 0.32) 0%, rgba(var(--color-accent-rgb), 0.16) 35%, transparent 70%);
    filter: blur(8px);
    z-index: 0;
}

.ab-family__photo {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 28px 36px rgba(27, 67, 50, 0.28));
}

.ab-family__panel {
    padding: clamp(0.5rem, 1vw, 1rem);
}

.ab-family__eyebrow {
    margin-bottom: 0.6rem;
}

.ab-family__heading {
    margin: 0 0 0.85rem;
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 2.6vw, 1.95rem);
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-brand-dark);
}

.ab-family__copy {
    margin: 0 0 1.1rem;
    font-size: clamp(0.95rem, 1.4vw, 1.02rem);
    line-height: 1.65;
    color: var(--color-ink);
    max-width: 38rem;
}

.ab-family__quote {
    margin: 0;
    padding: 1rem 1.1rem 1rem 1.25rem;
    border-left: 4px solid var(--color-accent);
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.12) 0%, rgba(27, 67, 50, 0.04) 100%);
    border-radius: 0 0.6rem 0.6rem 0;
    max-width: 36rem;
}

.ab-family__quote p {
    margin: 0 0 0.45rem;
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.45;
    color: var(--color-brand-dark);
}

.ab-family__quote cite {
    display: block;
    font-style: normal;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-accent);
}

/* Process — Prevent / Rescue / Restore / Reintegrate */
.ab-process {
    padding: clamp(2.5rem, 5vw, 4rem) 0;
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(var(--color-accent-rgb), 0.1), transparent 60%),
        #fff;
}

.ab-process__inner {
    max-width: 1200px;
}

.ab-process__head {
    text-align: center;
    margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
}

.ab-process__title {
    margin: 0.25rem 0 0.6rem;
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2.1rem);
    font-weight: 800;
    line-height: 1.18;
    color: var(--color-brand-dark);
}

.ab-process__lede {
    margin: 0 auto;
    max-width: 42rem;
    font-size: clamp(0.92rem, 1.4vw, 1.02rem);
    line-height: 1.6;
    color: var(--color-muted);
}

.ab-process__steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 1rem;
    counter-reset: ab-step;
    position: relative;
}

@media (min-width: 720px) {
    .ab-process__steps {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .ab-process__steps {
        grid-template-columns: repeat(4, 1fr);
        gap: 1.25rem;
    }

    .ab-process__steps::before {
        content: "";
        position: absolute;
        top: 2.6rem;
        left: 11%;
        right: 11%;
        height: 2px;
        background: linear-gradient(
            90deg,
            transparent 0%,
            rgba(var(--color-accent-rgb), 0.45) 18%,
            rgba(var(--color-accent-rgb), 0.45) 82%,
            transparent 100%
        );
        z-index: 0;
    }
}

.ab-process__step {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas:
        "num icon"
        "title title"
        "text text";
    align-items: center;
    gap: 0.4rem 0.85rem;
    padding: 1.25rem 1.1rem 1.2rem;
    background: #fff;
    border: 1px solid rgba(27, 67, 50, 0.08);
    border-radius: 0.95rem;
    box-shadow: 0 18px 36px -26px rgba(27, 67, 50, 0.3);
    transition:
        transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.3s ease,
        border-color 0.3s ease;
}

.ab-process__step:hover {
    transform: translateY(-5px);
    box-shadow: 0 28px 48px -26px rgba(27, 67, 50, 0.35);
    border-color: rgba(var(--color-accent-rgb), 0.4);
}

.ab-process__num {
    grid-area: num;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 0.85rem;
    letter-spacing: 0.1em;
    color: var(--color-accent);
}

.ab-process__icon {
    grid-area: icon;
    justify-self: end;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: linear-gradient(165deg, var(--color-brand-dark) 0%, var(--color-brand) 95%);
    color: #fff;
    font-size: 1.1rem;
    box-shadow:
        0 8px 20px -10px rgba(27, 67, 50, 0.55),
        inset 0 -2px 0 rgba(var(--color-accent-rgb), 0.4);
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.ab-process__step:hover .ab-process__icon {
    transform: rotate(-6deg) scale(1.08);
}

.ab-process__step-title {
    grid-area: title;
    margin: 0.35rem 0 0.2rem;
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--color-brand-dark);
}

.ab-process__step-text {
    grid-area: text;
    margin: 0;
    font-size: 0.85rem;
    line-height: 1.55;
    color: var(--color-muted);
}

.ab-problem__banner {
    margin: 0;
    padding: 0.85rem 1.25rem;
    font-size: clamp(0.95rem, 1.6vw, 1.12rem);
    font-weight: 700;
    line-height: 1.45;
    text-align: center;
    color: #fff;
    background: linear-gradient(120deg, var(--color-brand-dark) 0%, var(--color-brand) 42%, var(--color-accent) 100%);
    border-radius: 0.35rem;
    box-shadow: 0 8px 24px rgba(27, 67, 50, 0.16), 0 4px 16px rgba(var(--color-accent-rgb), 0.22);
}

.ab-board {
    padding: 0 0 clamp(2rem, 4vw, 3rem);
    background: #fff;
}

.ab-board__inner {
    display: grid;
    max-width: 1280px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.28);
    border-radius: 0.5rem;
    overflow: hidden;
    box-shadow: 0 18px 50px rgba(27, 67, 50, 0.08), 0 0 0 1px rgba(var(--color-accent-rgb), 0.08) inset;
}

@media (min-width: 1024px) {
    .ab-board__inner {
        grid-template-columns: 1fr 1.15fr 1fr;
    }
}

.ab-board__col {
    padding: clamp(1.25rem, 2.5vw, 1.75rem);
}

.ab-board__col--programs {
    background: linear-gradient(180deg, rgba(var(--color-accent-rgb), 0.05) 0%, transparent 100%);
}

.ab-board__col--havens {
    background: linear-gradient(180deg, rgba(var(--color-accent-rgb), 0.1) 0%, rgba(var(--color-accent-rgb), 0.03) 100%);
}

.ab-board__col--serve {
    background: linear-gradient(180deg, rgba(var(--color-accent-rgb), 0.04) 0%, transparent 100%);
}

.ab-board__col + .ab-board__col {
    border-top: 1px dashed rgba(27, 67, 50, 0.22);
}

@media (min-width: 1024px) {
    .ab-board__col + .ab-board__col {
        border-top: none;
        border-left: 1px dashed rgba(27, 67, 50, 0.22);
    }
}

.ab-board__heading {
    margin: 0 0 1rem;
    font-family: var(--font-display);
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-align: center;
    color: var(--color-brand-dark);
}

.ab-board__heading::before,
.ab-board__heading::after {
    content: "—";
    margin: 0 0.35rem;
    color: var(--color-accent);
    font-weight: 400;
}

.ab-board__heading--accent {
    color: var(--color-brand-dark);
    background: linear-gradient(transparent 70%, rgba(var(--color-accent-rgb), 0.32) 70%);
}

.ab-board__heading--dark {
    color: #1b4332;
}

.ab-board__subhead {
    margin: 0 0 0.5rem;
    font-size: 1rem;
    font-weight: 700;
    text-align: center;
    color: var(--color-accent);
}

.ab-board__lede {
    margin: 0 0 1.25rem;
    font-size: 0.88rem;
    line-height: 1.55;
    text-align: center;
    color: var(--color-muted);
}

.ab-board__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 1rem;
}

.ab-board__item {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.55rem 0.45rem;
    border-radius: 0.55rem;
    transition: background 0.25s ease, transform 0.25s ease;
}

.ab-board__item:hover {
    background: rgba(var(--color-accent-rgb), 0.07);
    transform: translateX(2px);
}

.ab-board__item .ab-icon-badge {
    transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.ab-board__item:hover .ab-icon-badge {
    transform: scale(1.06);
}

.ab-board__item h3 {
    margin: 0 0 0.2rem;
    font-size: 0.9rem;
    font-weight: 800;
    line-height: 1.25;
    color: var(--color-brand-dark);
    border-left: 3px solid var(--color-accent);
    padding-left: 0.45rem;
}

.ab-board__item p {
    margin: 0;
    font-size: 0.8rem;
    line-height: 1.45;
    color: var(--color-muted);
}

.ab-board__item--compact {
    align-items: center;
}

.ab-board__item--compact p {
    font-size: 0.86rem;
    font-weight: 600;
    color: var(--color-ink);
}

.ab-haven-hub {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 0.65rem 0.5rem;
    align-items: center;
    margin-bottom: 1rem;
}

.ab-haven-hub__side {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.85rem;
}

.ab-haven-hub__side li {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    text-align: center;
    font-size: 0.72rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--color-brand-dark);
}

.ab-haven-hub .ab-icon-badge--mid {
    background: linear-gradient(165deg, var(--color-brand-dark) 0%, var(--color-brand) 96%);
    box-shadow:
        0 3px 10px rgba(27, 67, 50, 0.2),
        0 0 0 1px rgba(var(--color-accent-rgb), 0.35),
        inset 0 -2px 0 rgba(var(--color-accent-rgb), 0.38);
}

.ab-haven-hub__label {
    display: block;
    max-width: 8.75rem;
    font-size: 0.7rem;
    line-height: 1.35;
    text-wrap: balance;
}

.ab-haven-hub__side li:nth-child(3) .ab-haven-hub__label {
    max-width: 9.25rem;
}

.ab-haven-hub__center {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.25rem;
}

.ab-haven-hub__house {
    display: flex;
    align-items: center;
    justify-content: center;
    width: clamp(5.5rem, 12vw, 7.5rem);
    height: clamp(5.5rem, 12vw, 7.5rem);
    border: 3px solid var(--color-brand);
    border-radius: 0.65rem 0.65rem 0.35rem 0.35rem;
    background: linear-gradient(160deg, rgba(45, 106, 79, 0.14) 0%, rgba(var(--color-accent-rgb), 0.08) 100%);
    color: var(--color-brand);
    font-size: clamp(2.25rem, 5vw, 3rem);
    box-shadow:
        inset 0 0 0 2px rgba(var(--color-accent-rgb), 0.22),
        0 6px 18px rgba(27, 67, 50, 0.15);
}

.ab-haven-hub__lines {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.35rem;
    text-align: center;
}

.ab-haven-hub__lines li {
    font-size: 0.82rem;
    font-style: italic;
    font-weight: 600;
    line-height: 1.4;
    color: var(--color-brand-dark);
}

.ab-haven-hub__lines li::before {
    content: "◆";
    margin-right: 0.35rem;
    font-size: 0.55rem;
    color: var(--color-accent);
    font-style: normal;
}

.ab-board__quote {
    margin: 1.25rem 0 0;
    padding: 1rem 1.1rem;
    border: 2px solid rgba(var(--color-accent-rgb), 0.45);
    border-radius: 0.35rem;
    background: linear-gradient(135deg, rgba(var(--color-accent-rgb), 0.1) 0%, rgba(45, 106, 79, 0.06) 100%);
}

.ab-board__quote p {
    margin: 0 0 0.5rem;
    font-size: 0.88rem;
    font-weight: 600;
    line-height: 1.5;
    color: var(--color-brand-dark);
}

.ab-board__quote cite {
    display: block;
    font-size: 0.78rem;
    font-style: normal;
    font-weight: 700;
    color: var(--color-accent);
}

.ab-impact {
    position: relative;
    padding: clamp(2.75rem, 5.5vw, 4rem) 0;
    background:
        radial-gradient(circle at 15% 85%, rgba(var(--color-accent-rgb), 0.22), transparent 20rem),
        radial-gradient(circle at 85% 15%, rgba(var(--color-accent-rgb), 0.18), transparent 22rem),
        linear-gradient(135deg, #0a1612 0%, var(--color-brand-dark) 55%, #1f4d38 100%);
    color: #fff;
    overflow: hidden;
}

.ab-impact__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 60% 40% at 50% 0%, rgba(var(--color-accent-rgb), 0.16), transparent 60%),
        repeating-linear-gradient(
            -45deg,
            rgba(255, 255, 255, 0.025) 0,
            rgba(255, 255, 255, 0.025) 1px,
            transparent 1px,
            transparent 14px
        );
    opacity: 0.85;
}

.ab-impact__inner {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    text-align: center;
}

.ab-impact__eyebrow {
    color: var(--color-accent);
    margin-bottom: 0.5rem;
}

.ab-impact__title {
    margin: 0 0 0.75rem;
    font-family: var(--font-display);
    font-size: clamp(1.35rem, 3vw, 2rem);
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #fff;
}

.ab-impact__title span {
    color: var(--color-accent);
}

.ab-impact__lede {
    max-width: 42rem;
    margin: 0 auto 1.75rem;
    font-size: 0.95rem;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.85);
}

.ab-impact__ways {
    display: grid;
    gap: 1rem;
    margin: 0 0 1.75rem;
    padding: 0;
    list-style: none;
}

@media (min-width: 640px) {
    .ab-impact__ways {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .ab-impact__ways {
        grid-template-columns: repeat(3, 1fr);
        gap: 0;
    }

    .ab-impact__way + .ab-impact__way {
        border-left: 1px dashed rgba(255, 255, 255, 0.2);
    }
}

.ab-impact__way {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.65rem;
    padding: 1rem 0.65rem;
    border-radius: 0.75rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

.ab-impact__way:hover {
    transform: translateY(-4px);
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(var(--color-accent-rgb), 0.5);
    box-shadow: 0 18px 36px -22px rgba(0, 0, 0, 0.6);
}

.ab-impact__way .ab-icon-badge {
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.ab-impact__way:hover .ab-icon-badge {
    transform: scale(1.08) rotate(4deg);
}

.ab-impact__way h3 {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 700;
    line-height: 1.35;
    color: var(--color-accent);
    text-wrap: balance;
}

@media (min-width: 1024px) {
    .ab-impact__ways {
        gap: 0.9rem;
    }

    .ab-impact__way + .ab-impact__way {
        border-left: 1px solid rgba(255, 255, 255, 0.08);
    }
}

.ab-impact__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.ab-impact__btn-ghost {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.45);
}

.ab-impact__btn-ghost:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.1);
}

.ab-impact__tagline {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    font-style: italic;
    color: rgba(var(--color-accent-rgb), 0.85);
}

/* Floating donate FAB */
.ab-fab {
    position: fixed;
    right: clamp(0.85rem, 2vw, 1.4rem);
    bottom: clamp(0.85rem, 2vw, 1.4rem);
    z-index: 60;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.85rem 1.15rem;
    border-radius: 999px;
    background: linear-gradient(120deg, var(--color-brand-dark) 0%, var(--color-brand) 60%, var(--color-accent) 100%);
    color: #fff;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 0.85rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-decoration: none;
    box-shadow:
        0 14px 30px -10px rgba(27, 67, 50, 0.55),
        0 0 0 1px rgba(var(--color-accent-rgb), 0.35) inset;
    opacity: 0;
    transform: translateY(20px) scale(0.95);
    pointer-events: none;
    transition: opacity 0.3s ease, transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s ease;
}

.ab-fab i {
    font-size: 0.95rem;
    color: var(--color-accent);
}

.ab-fab.is-visible {
    opacity: 1;
    transform: none;
    pointer-events: auto;
}

.ab-fab:hover,
.ab-fab:focus-visible {
    box-shadow:
        0 22px 40px -12px rgba(27, 67, 50, 0.65),
        0 0 0 1px rgba(var(--color-accent-rgb), 0.55) inset;
    transform: translateY(-2px) scale(1.02);
}

.ab-fab:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
}

.ab-fab:hover i { color: #fff; }

@media (max-width: 540px) {
    .ab-fab__label { display: none; }
    .ab-fab { padding: 0.85rem; width: 3rem; height: 3rem; justify-content: center; }
    .ab-fab i { font-size: 1.1rem; }
}

/* Focus visibility (a11y) */
.ab-page a:focus-visible,
.ab-page button:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
    border-radius: 0.35rem;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    [data-ab-reveal] {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
    .ab-problem__fact,
    .ab-process__step,
    .ab-board__item,
    .ab-impact__way,
    .ab-fab,
    .ab-pagenav__link {
        transition: none !important;
    }
    .ab-problem__fact:hover,
    .ab-process__step:hover,
    .ab-board__item:hover,
    .ab-impact__way:hover {
        transform: none !important;
    }

    .ab-problem-facts-deck .ab-problem__fact {
        transform: none !important;
        transition-delay: 0ms !important;
    }

    .ab-problem-facts-deck.is-visible .ab-problem__fact:hover .ab-icon-badge {
        transform: none !important;
    }
}

/* legacy ab-intro (unused) */
.ab-intro {
    padding: clamp(3rem, 6vw, 5rem) 0 2rem;
    background: #f8faf9;
}

.ab-intro__grid {
    display: grid;
    gap: 2rem;
    margin-bottom: 2rem;
}

@media (min-width: 900px) {
    .ab-intro__grid {
        grid-template-columns: 1fr 1fr;
        align-items: start;
    }
}

.ab-intro__deck {
    font-size: clamp(1.05rem, 1.8vw, 1.2rem);
    line-height: 1.65;
    color: var(--color-muted);
    margin: 0;
}

.ab-intro__stakes,
.ab-intro__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.75rem;
}

.ab-intro__stakes li,
.ab-intro__list li {
    position: relative;
    padding-left: 1.25rem;
    line-height: 1.55;
    color: var(--color-ink);
}

.ab-intro__stakes li::before,
.ab-intro__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 0.4rem;
    height: 0.4rem;
    border-radius: 50%;
    background: var(--color-brand);
}

.ab-callout {
    padding: 1.25rem 1.5rem;
    border-radius: var(--radius);
    margin-bottom: 1.5rem;
}

.ab-callout--warn {
    background: rgba(180, 35, 24, 0.08);
    border-left: 4px solid #b42318;
}

.ab-callout--warn p {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    line-height: 1.55;
    color: #7a1c12;
}

.ab-intro__list--dark li {
    font-weight: 600;
}

.ab-intro__why {
    margin: 1.5rem 0 0;
    font-size: 1.15rem;
    text-align: center;
}

.ab-mission {
    padding: clamp(3rem, 6vw, 4.5rem) 0;
    background: linear-gradient(135deg, var(--color-brand-dark) 0%, var(--color-brand) 55%, #2d6a4f 100%);
    color: #fff;
    text-align: center;
}

.ab-mission__inner {
    max-width: 52rem;
}

.ab-mission__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.5rem;
    height: 3.5rem;
    margin-bottom: 1rem;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    font-size: 1.35rem;
    color: var(--color-accent);
}

.ab-mission__text {
    margin: 0;
    font-size: clamp(1.05rem, 1.8vw, 1.2rem);
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.9);
}

.ab-beliefs {
    padding: clamp(3rem, 5vw, 4rem) 0;
    background: #fff;
}

.ab-beliefs__grid {
    display: grid;
    gap: 1rem;
    margin: 2rem 0 0;
    padding: 0;
    list-style: none;
}

@media (min-width: 768px) {
    .ab-beliefs__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ab-belief {
    padding: 1.5rem;
    border-radius: var(--radius);
    background: linear-gradient(160deg, #f4f8f6 0%, #e8f0ec 100%);
    border: 1px solid rgba(27, 67, 50, 0.1);
    text-align: center;
}

.ab-belief__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    margin-bottom: 0.75rem;
    border-radius: 50%;
    background: var(--color-brand-dark);
    color: #fff;
    font-size: 0.85rem;
}

.ab-belief p {
    margin: 0;
    font-weight: 700;
    font-size: 1.02rem;
    line-height: 1.45;
    color: var(--color-brand-dark);
}

.ab-havens {
    padding: clamp(3rem, 6vw, 5rem) 0;
    background: #ebe6dc;
}

.ab-havens__grid {
    display: grid;
    gap: 2.5rem;
    align-items: start;
}

@media (min-width: 960px) {
    .ab-havens__grid {
        grid-template-columns: 1.05fr 0.95fr;
    }
}

.ab-havens__copy p {
    margin: 0 0 1rem;
    line-height: 1.65;
    color: var(--color-muted);
}

.ab-havens__note {
    font-weight: 600;
    color: var(--color-ink) !important;
}

.ab-quote {
    margin: 1.5rem 0 0;
    padding: 1.25rem 1.5rem;
    border-left: 4px solid var(--color-accent);
    background: rgba(255, 255, 255, 0.65);
    border-radius: 0 var(--radius) var(--radius) 0;
}

.ab-quote p {
    margin: 0 0 0.5rem;
    font-size: 1.05rem;
    line-height: 1.55;
    color: var(--color-brand-dark);
}

.ab-quote p:last-child { margin-bottom: 0; }

.ab-havens__card {
    padding: 1.75rem;
    background: #fff;
    border-radius: var(--radius);
    box-shadow: var(--shadow-soft);
    border: 1px solid rgba(27, 67, 50, 0.1);
}

.ab-havens__card-title {
    margin: 0 0 1rem;
    font-size: 1.15rem;
    color: var(--color-brand-dark);
}

.ab-checklist {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.65rem;
}

.ab-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    line-height: 1.5;
    color: var(--color-ink);
}

.ab-checklist i {
    color: var(--color-brand);
    margin-top: 0.2rem;
    flex-shrink: 0;
}

.ab-checklist--light li { color: rgba(255, 255, 255, 0.92); }

.ab-checklist--light i { color: var(--color-accent); }

.ab-programs {
    padding: clamp(3rem, 6vw, 5rem) 0;
    background: #fff;
}

.ab-programs__grid {
    display: grid;
    gap: 1rem;
    margin: 2rem 0 0;
    padding: 0;
    list-style: none;
}

@media (min-width: 640px) {
    .ab-programs__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .ab-programs__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ab-program {
    padding: 1.35rem;
    border-radius: var(--radius);
    background: #f8faf9;
    border: 1px solid rgba(27, 67, 50, 0.1);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ab-program:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 32px rgba(27, 67, 50, 0.12);
}

.ab-program__icon {
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.65rem;
    border-radius: 0.65rem;
    background: rgba(27, 67, 50, 0.1);
    color: var(--color-brand-dark);
}

.ab-program__title {
    margin: 0 0 0.35rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-brand-dark);
}

.ab-program p {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.5;
    color: var(--color-muted);
}

.ab-partner {
    padding: clamp(3rem, 6vw, 4.5rem) 0;
    background: linear-gradient(160deg, #142820 0%, var(--color-brand) 100%);
    color: #fff;
}

.ab-partner__grid {
    display: grid;
    gap: 2rem;
    align-items: start;
}

@media (min-width: 900px) {
    .ab-partner__grid {
        grid-template-columns: 1fr 1fr;
    }
}

.ab-partner .ab-section__title {
    color: #fff;
}

.ab-partner__intro p {
    margin: 0;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.88);
}

.ab-partner__helps {
    padding: 1.5rem;
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius);
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.ab-partner__helps-title {
    margin: 0 0 1rem;
    font-size: 1.05rem;
    color: var(--color-accent);
}

.ab-ways {
    padding: clamp(3rem, 5vw, 4rem) 0;
    background: #f4f6f3;
}

.ab-ways__lede {
    max-width: 42rem;
    margin: 0 auto 2rem;
    text-align: center;
    color: var(--color-muted);
    line-height: 1.6;
}

.ab-ways__grid {
    display: grid;
    gap: 0.85rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

@media (min-width: 640px) {
    .ab-ways__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 960px) {
    .ab-ways__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.ab-way {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.15rem;
    background: #fff;
    border-radius: var(--radius);
    border: 1px solid rgba(27, 67, 50, 0.1);
    font-weight: 600;
    color: var(--color-brand-dark);
}

.ab-way__icon {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(27, 67, 50, 0.1);
    color: var(--color-brand);
    flex-shrink: 0;
}

.ab-finale {
    padding: clamp(3.5rem, 7vw, 5.5rem) 0;
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(45, 106, 79, 0.35) 0%, transparent 70%),
        linear-gradient(180deg, #0a1210 0%, #142820 100%);
    text-align: center;
    color: #fff;
}

.ab-finale__brand {
    margin: 0 0 0.5rem;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.ab-finale__title {
    margin: 0 0 1rem;
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    color: #fff;
}

.ab-finale__lede,
.ab-finale__closing {
    max-width: 48rem;
    margin: 0 auto 1rem;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.88);
}

.ab-finale__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
    margin: 2rem 0 1.5rem;
}

.ab-finale__btn-ghost {
    color: #fff;
    border-color: rgba(255, 255, 255, 0.45);
}

.ab-finale__btn-ghost:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.ab-finale__tagline {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    font-style: italic;
    color: rgba(255, 255, 255, 0.65);
}

@media (max-width: 960px) {
    .ab-hero__inner {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
        min-height: auto;
        padding-bottom: 1rem;
    }

    .ab-hero__col--left {
        grid-column: 1;
        grid-row: 1;
    }

    .ab-hero__col--center {
        grid-column: 1 / -1;
        grid-row: 2;
        padding-top: 0;
    }

    .ab-hero__col--right {
        grid-column: 2;
        grid-row: 1;
    }

    .ab-hero__inner {
        min-height: clamp(4.99rem, 9.5vw, 7.6rem);
    }

    .ab-hero__photo--family {
        height: auto;
        max-height: 100%;
        max-width: 130%;
        object-position: top center;
    }

    .ab-hero__photo--child {
        height: auto;
        max-height: 100%;
        max-width: 110%;
        object-position: top right;
    }
}

@media (max-width: 560px) {
    .ab-hero__inner {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }

    .ab-hero__col--left,
    .ab-hero__col--center,
    .ab-hero__col--right {
        grid-column: 1;
        grid-row: auto;
    }

    .ab-hero__title {
        font-size: 2rem;
    }

    .ab-hero__birds {
        position: static;
        justify-content: center;
        margin-bottom: 0.5rem;
    }
}

/* Across Borders professional refresh */
.ab-page {
    background:
        linear-gradient(180deg, rgba(var(--color-accent-rgb), 0.04) 0%, transparent 8rem),
        #f6f8f4;
}

.ab-hero {
    isolation: isolate;
    border-bottom: 1px solid rgba(198, 166, 74, 0.28);
}

.ab-hero::before,
.ab-hero::after {
    content: "";
    position: absolute;
    inset: auto;
    z-index: 0;
    pointer-events: none;
    border-radius: 999px;
    filter: blur(6px);
}

.ab-hero::before {
    top: -7rem;
    left: -5rem;
    width: 18rem;
    height: 18rem;
    background: rgba(198, 166, 74, 0.16);
}

.ab-hero::after {
    right: -8rem;
    bottom: -10rem;
    width: 24rem;
    height: 24rem;
    background: rgba(82, 140, 111, 0.28);
}

.ab-hero__bg {
    background:
        linear-gradient(90deg, rgba(10, 22, 18, 0.2), rgba(10, 22, 18, 0.02) 20%, rgba(10, 22, 18, 0.16)),
        radial-gradient(ellipse 75% 100% at 20% 95%, rgba(198, 166, 74, 0.12) 0%, transparent 58%),
        radial-gradient(ellipse 56% 70% at 85% 28%, rgba(45, 106, 79, 0.44) 0%, transparent 64%),
        linear-gradient(135deg, #081510 0%, #123326 48%, #0a1813 100%);
}

.ab-hero__inner {
    min-height: clamp(10.45rem, 18.05vw, 14.725rem);
    max-width: 1440px;
    gap: clamp(0.5rem, 2vw, 1.8rem);
}

.ab-hero__col--left,
.ab-hero__col--right {
    z-index: 1;
}

.ab-hero__scene,
.ab-hero__portrait {
    position: relative;
}

.ab-hero__photo--family {
    height: auto;
    max-height: 100%;
    max-width: 132%;
    object-position: top center;
    filter: drop-shadow(0 16px 30px rgba(0, 0, 0, 0.5));
}

.ab-hero__photo--child {
    height: auto;
    max-height: 100%;
    max-width: 112%;
    object-position: top right;
    filter: drop-shadow(-12px 14px 30px rgba(0, 0, 0, 0.52));
}

.ab-hero__label {
    bottom: 0.65rem;
    left: clamp(0rem, 2vw, 1.25rem);
    padding: 0.42rem 0.9rem;
    background: linear-gradient(135deg, var(--color-brand-dark) 0%, var(--color-brand) 100%);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    box-shadow: 0 10px 24px rgba(27, 67, 50, 0.25);
}

.ab-hero__col--center {
    z-index: 2;
    max-width: 34rem;
    margin: 0 auto;
    justify-content: flex-start;
    padding: 0 0.5rem;
}

.ab-hero__birds {
    top: 0.4rem;
    right: 0.4rem;
    color: rgba(198, 166, 74, 0.78);
}

.ab-hero__title {
    margin: 0;
    padding: 0;
    font-size: clamp(2.1rem, 5vw, 4.15rem);
    letter-spacing: 0.045em;
    line-height: 0.88;
}

.ab-hero__title-line {
    display: block;
    margin: 0;
    padding: 0;
}

.ab-hero__title-line:first-child {
    margin-top: 0;
}

.ab-hero__arc {
    width: min(100%, 20rem);
    margin: 0.45rem auto 0.55rem;
}

.ab-hero__kicker {
    margin-bottom: 0.35rem;
    font-size: clamp(0.68rem, 1.25vw, 0.88rem);
}

.ab-hero__mission {
    max-width: 30rem;
    font-size: clamp(0.84rem, 1.45vw, 1rem);
    color: #ead79a;
}

.ab-hero__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    width: min(100%, 31rem);
    margin: clamp(0.75rem, 1.5vw, 1rem) auto 0;
    padding: 0;
    list-style: none;
}

.ab-hero__stats li {
    padding: 0.55rem 0.65rem;
    border: 1px solid rgba(var(--color-accent-rgb), 0.35);
    border-radius: 0.85rem;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.1) 0%, rgba(var(--color-accent-rgb), 0.12) 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(10px);
}

.ab-hero__stats strong,
.ab-hero__stats span {
    display: block;
}

.ab-hero__stats strong {
    font-size: clamp(0.75rem, 1.2vw, 0.92rem);
    color: var(--color-accent);
}

.ab-hero__stats span {
    margin-top: 0.12rem;
    font-size: clamp(0.62rem, 0.9vw, 0.72rem);
    line-height: 1.3;
    color: rgba(255, 255, 255, 0.72);
}

.ab-section__title {
    letter-spacing: -0.02em;
}

.ab-section__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.ab-section__eyebrow::before {
    content: "";
    width: 1.75rem;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
}

@media (max-width: 960px) {
    .ab-hero__inner {
        min-height: auto;
        padding-top: 0;
    }

    .ab-hero__col--left,
    .ab-hero__col--right {
        min-height: clamp(7.6rem, 20.9vw, 11.4rem);
    }

    .ab-hero__col--center {
        max-width: 42rem;
        padding: 0 0.5rem 1rem;
    }

    .ab-hero__photo--family {
        max-width: 118%;
    }

    .ab-hero__photo--child {
        max-width: 100%;
    }
}

@media (max-width: 640px) {
    .ab-hero__inner {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        gap: 0;
        padding-inline: 0;
    }

    .ab-hero__col--right {
        display: none;
    }

    .ab-hero__col--left {
        grid-column: 1;
        grid-row: auto;
        width: 100%;
        min-height: auto;
    }

    .ab-hero__col--center {
        order: -1;
        padding: 1rem 1rem 0.75rem;
    }

    .ab-hero__scene {
        width: 100%;
    }

    .ab-hero__stats {
        grid-template-columns: 1fr;
    }

    .ab-hero__label {
        bottom: 0.35rem;
        font-size: 0.65rem;
    }

    .ab-hero__photo--family {
        display: block;
        width: 100%;
        max-width: 100%;
        max-height: none;
        height: auto;
        object-fit: cover;
        object-position: center center;
    }
}


