body.landing-page {
    background:
        radial-gradient(circle at top center, rgba(33, 105, 58, 0.12), transparent 36%),
        linear-gradient(180deg, #f6f8fc 0%, #eef2f7 100%);
    color: #162033;
    overflow-x: hidden;
}

body.landing-page.landing-page--grid {
    background:
        radial-gradient(circle at top center, rgba(33, 105, 58, 0.11), transparent 34%),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.4) 0 1px, transparent 1px 52px),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.4) 0 1px, transparent 1px 52px),
        linear-gradient(180deg, #f6f8fc 0%, #e9eef4 100%);
}

body.landing-page.landing-page--family {
    background:
        radial-gradient(circle at top center, rgba(33, 105, 58, 0.14), transparent 34%),
        radial-gradient(circle at 20% 12%, rgba(14, 100, 54, 0.06), transparent 24%),
        linear-gradient(180deg, #f7f8f5 0%, #eef3ee 42%, #e7efe8 100%);
}

body.landing-page.landing-page--family,
body.landing-page.landing-page--family h1,
body.landing-page.landing-page--family h2,
body.landing-page.landing-page--family h3 {
    font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
}

body.landing-page.landing-page--family p,
body.landing-page.landing-page--family a,
body.landing-page.landing-page--family button,
body.landing-page.landing-page--family span,
body.landing-page.landing-page--family input,
body.landing-page.landing-page--family textarea,
body.landing-page.landing-page--family select {
    font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.site-header {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    padding: 0.72rem clamp(0.85rem, 2.6vw, 2.25rem);
    border: 0;
    border-bottom: 1px solid rgba(223, 230, 240, 0.68);
    border-radius: 0;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(8px);
    box-shadow: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    border-left: 0;
    border-right: 0;
    z-index: 1000;  /* was: 40 */
}

.site-header__brand img {
    display: block;
    width: auto;
    max-width: 196px;
    height: 40px;
    object-fit: contain;
}

.site-header__nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
    flex-wrap: wrap;
    min-width: 0;
}

.site-header__nav a,
.landing-mobile-nav a {
    color: #3f4d69;
    font-size: 0.92rem;
    font-weight: 600;
    white-space: nowrap;
}

.site-header__nav a:hover,
.landing-mobile-nav a:hover {
    color: #21693A;
}

.site-header__nav a.is-active,
.landing-mobile-nav a.is-active,
.nav-link--dropdown-trigger.is-active {
    color: #21693A;
}

.site-header__nav > a.is-active,
.site-header__nav .nav-link--dropdown-trigger.is-active {
    position: relative;
}

.site-header__nav > a.is-active::after,
.site-header__nav .nav-link--dropdown-trigger.is-active::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -0.35rem;
    height: 2px;
    border-radius: 999px;
    background: #21693A;
}

.landing-mobile-nav a.is-active,
.nav-dropdown-item.is-active {
    background: #eef7f1;
    border-radius: 10px;
}

.site-header__actions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-shrink: 0;
}

.site-header__menu-button {
    display: none;
    width: 44px;
    height: 44px;
    border: 1px solid #d6ddeb;
    border-radius: 0;
    background: #fff;
    padding: 0.7rem;
    flex-direction: column;
    justify-content: center;
    gap: 0.24rem;
}

.site-header__menu-button span {
    display: block;
    width: 100%;
    height: 2px;
    border-radius: 999px;
    background: #2a3348;
}

/* Dropdown styles shared by landing pages (moved here to ensure consistency) */
.nav-item--dropdown { position: relative; display: inline-block; }
.nav-link--dropdown-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    text-decoration: none;
    cursor: pointer;
    color: inherit;
    background: none;
    border: none;
    padding: 0;
    font: inherit;
}

.nav-dropdown-arrow {
    display: inline-block;
    font-size: 0.75rem;
    transition: transform 0.2s ease;
}

.nav-link--dropdown-trigger[aria-expanded="true"] .nav-dropdown-arrow {
    transform: rotate(180deg);
}

.nav-dropdown {
    position: absolute;
    top: calc(100% + 1rem);
    left: 50%;
    transform: translateX(-50%);
    min-width: 320px;
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    box-shadow: 0 12px 32px rgba(0,0,0,0.12);
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-8px);
    transition: all 0.2s ease;
    pointer-events: none;
    z-index: 999;
}

.nav-dropdown::after {
    content: '';
    position: absolute;
    top: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-bottom: 8px solid #ffffff;
    z-index: 1000;
}

.nav-dropdown::before {
    content: '';
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 10px solid #e5e7eb;
    z-index: 999;
}

.nav-dropdown.is-open {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}

.nav-dropdown-item {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    padding: 0.85rem 1rem;
    text-decoration: none;
    color: #1f2937;
    transition: background-color 0.15s ease;
    border-radius: 10px;
    margin: 0 0.8rem;
}

.nav-dropdown-item:first-child { margin-top: 1rem; }
.nav-dropdown-item:last-child { margin-bottom: 1rem; }
.nav-dropdown-item:hover { background-color: #f9fafb; }

.nav-dropdown-icon { flex-shrink: 0; width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; color: #ffffff; }
.nav-dropdown-content { display: flex; flex-direction: column; gap: 0.25rem; }
.nav-dropdown-title { font-weight: 600; font-size: 0.98rem; color: #0f172a; }
.nav-dropdown-subtitle { font-size: 0.82rem; color: #6b7280; line-height: 1.4; }

@media (max-width: 768px) {
    .nav-dropdown {
        position: fixed;
        left: 1rem;
        right: 1rem;
        width: auto;
        max-width: calc(100vw - 2rem);
        top: auto;
        transform: translateX(0) translateY(-8px);
    }
    .nav-dropdown.is-open { transform: translateX(0) translateY(0); }
    .nav-dropdown::after, .nav-dropdown::before { display: none; }
}

.landing-mobile-nav {
    width: 100%;
    overflow: visible;
    box-sizing: border-box;
    margin: 0;
    padding: 1rem;
    border: 1px solid #dfe6f0;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.98);
    display: none;
    gap: 0.6rem;
    position: fixed;
    left: 0;
    right: 0;
    top: 72px;
    z-index: 39;
}

.landing-mobile-nav:not([hidden]) {
    display: grid;
}

.landing-main {
    width: min(1280px, calc(100% - 1.2rem));
    margin: 3.85rem auto 2rem;
    display: grid;
    gap: 1rem;
}

body.landing-page > main:not(.landing-main) {
    margin-top: 3.85rem !important;
}

.landing-hero,
.landing-section,
.landing-intro {
    border: 1px solid #dfe6f2;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

body.landing-page.landing-page--family .landing-hero,
body.landing-page.landing-page--family .family-panel,
body.landing-page.landing-page--family .family-quote,
body.landing-page.landing-page--family .family-step,
body.landing-page.landing-page--family .family-card,
body.landing-page.landing-page--family .family-callout {
    border: 1px solid rgba(33, 105, 58, 0.14);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
}

.landing-hero {
    padding: 0;
    overflow: hidden;
}

.landing-hero--full-width {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
}

.landing-hero__layout-image-wrap {
    width: 100%;
    display: block;
}

.landing-hero__layout-image {
    width: 100%;
    height: auto;
    display: block;
}

.family-hero {
    position: relative;
    overflow: hidden;
    border-radius: 20px;
    background:
        linear-gradient(135deg, rgba(12, 92, 48, 0.92), rgba(25, 118, 63, 0.86)),
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.2), transparent 35%);
    color: #ffffff;
    padding: clamp(1.4rem, 2.8vw, 2.1rem);
}

.family-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 54px),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 54px);
    opacity: 0.55;
    pointer-events: none;
}

.family-hero__content {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 1rem;
    align-items: start;
}

.family-hero__eyebrow {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 0.4rem;
    padding: 0.42rem 0.8rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.14);
    color: #f0fdf4;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.family-hero h1 {
    margin: 0;
    font-size: clamp(2.2rem, 5vw, 4.2rem);
    line-height: 1;
    letter-spacing: -0.06em;
    max-width: 11ch;
}

.family-hero__lead {
    margin: 0;
    max-width: 64ch;
    color: rgba(255, 255, 255, 0.86);
    font-size: 1.04rem;
    line-height: 1.7;
}

.family-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.2rem;
}

.family-hero .button--ghost {
    border-color: rgba(255, 255, 255, 0.3);
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
}

.family-hero .button {
    box-shadow: none;
}

.family-grid {
    display: grid;
    gap: 1.2rem;
}

.family-story {
    display: grid;
    grid-template-columns: minmax(96px, 140px) minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
    padding: 1.15rem 0;
    border-top: 1px solid rgba(33, 105, 58, 0.12);
}

.family-story:first-child {
    border-top: 0;
    padding-top: 0.35rem;
}

.family-story__number {
    color: rgba(31, 107, 74, 0.16);
    font-size: clamp(4rem, 7vw, 6.25rem);
    line-height: 0.8;
    font-weight: 700;
    letter-spacing: -0.08em;
    text-align: center;
    padding-top: 0.15rem;
}

.family-story__content {
    display: grid;
    gap: 1rem;
}

.family-panel__eyebrow {
    margin: 0;
    color: #1F6B4A;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.family-story__title,
.family-card h3,
.family-step h3,
.family-callout h3,
.family-quote h3 {
    margin: 0;
    color: #0f172a;
    letter-spacing: -0.03em;
    font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
}

.family-story__intro,
.family-card p,
.family-step p,
.family-callout p,
.family-quote p {
    margin: 0;
    color: #526277;
    line-height: 1.7;
}

.family-notice {
    display: grid;
    gap: 0.85rem;
}

.family-notice__list {
    display: grid;
    gap: 0.75rem;
}

.family-notice__item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.75rem;
    align-items: start;
    padding: 0.95rem 1rem;
    border-radius: 16px;
    background: rgba(33, 105, 58, 0.04);
    border: 1px solid rgba(33, 105, 58, 0.1);
}

.family-notice__icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #eaf4ed;
    color: #1F6B4A;
    font-size: 1rem;
    flex-shrink: 0;
}

.family-notice__item strong {
    display: block;
    margin-bottom: 0.18rem;
    color: #0f172a;
}

.family-quote {
    display: grid;
    gap: 0.95rem;
    background: linear-gradient(180deg, rgba(12, 54, 31, 0.98), rgba(18, 67, 37, 0.98));
    color: #f7faf8;
    padding: 1.45rem;
    border-radius: 16px;
    text-align: center;
}

.family-quote__verse {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.family-quote blockquote {
    margin: 0;
    padding: 0;
    color: #f4f8f4;
    font-size: clamp(1.15rem, 2vw, 1.65rem);
    line-height: 1.55;
    letter-spacing: -0.01em;
    font-style: italic;
}

.family-quote cite {
    font-style: normal;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.85rem;
    font-weight: 600;
}

.family-section {
    display: grid;
    gap: 1rem;
}

.family-section__header {
    display: grid;
    gap: 0.35rem;
    text-align: left;
}

.family-section__header h2 {
    margin: 0;
    font-size: clamp(1.55rem, 2.8vw, 2.35rem);
    letter-spacing: -0.04em;
}

.family-section__header .family-story__title {
    font-size: clamp(2rem, 4vw, 3.5rem);
    max-width: 12ch;
}

.family-section__header p {
    margin: 0;
    color: #5a6780;
    line-height: 1.7;
}

.family-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.family-card {
    display: grid;
    gap: 0.7rem;
    min-height: 100%;
    padding: 1.05rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(33, 105, 58, 0.12);
}

.family-card__tag {
    width: fit-content;
    padding: 0.34rem 0.68rem;
    border-radius: 999px;
    background: #eef5ff;
    color: #2e4f7a;
    font-size: 0.67rem;
    font-weight: 800;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.family-verse-card {
    padding: 1rem 1.05rem;
    border-radius: 16px;
    border: 1px solid rgba(33, 105, 58, 0.12);
    background: linear-gradient(180deg, rgba(33, 105, 58, 0.06), rgba(255, 255, 255, 0.94));
    display: grid;
    gap: 0.35rem;
}

.family-verse-card__reference {
    color: #1F6B4A;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.family-verse-card__text {
    margin: 0;
    color: #0f172a;
    font-size: 0.96rem;
    line-height: 1.7;
}

.family-steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.family-step {
    display: grid;
    gap: 0.72rem;
    padding: 1rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(33, 105, 58, 0.12);
}

.family-step__number {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #1F6B4A;
    color: #ffffff;
    font-weight: 800;
    box-shadow: 0 10px 22px rgba(31, 107, 74, 0.18);
}

.family-step__verse {
    color: #1F6B4A;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.family-callout {
    display: grid;
    gap: 0.75rem;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(33, 105, 58, 0.12);
}

.family-callout__row {
    display: grid;
    gap: 0.5rem;
}

.family-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.family-pill {
    padding: 0.44rem 0.7rem;
    border-radius: 999px;
    border: 1px solid rgba(33, 105, 58, 0.12);
    background: rgba(255, 255, 255, 0.9);
    color: #2f3f5b;
    font-size: 0.78rem;
    font-weight: 600;
}

.family-footer-card {
    display: grid;
    gap: 0.7rem;
    border-radius: 18px;
    padding: 1rem 1.05rem;
    background: rgba(31, 107, 74, 0.07);
    border: 1px solid rgba(31, 107, 74, 0.12);
}

.family-cta-strip {
    display: grid;
    gap: 0.6rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.family-cta-strip__item {
    border-radius: 16px;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(33, 105, 58, 0.12);
    display: grid;
    gap: 0.35rem;
}

.family-cta-strip__item h3 {
    margin: 0;
    font-size: 1.25rem;
}

.family-cta-strip__item p {
    margin: 0;
    color: #526277;
    line-height: 1.65;
}

.family-footer-card h3 {
    margin: 0;
    color: #0f172a;
}

.family-footer-card p {
    margin: 0;
    color: #526277;
}

.family-footer-card .button {
    width: fit-content;
}

.family-muted {
    color: #66778f;
}

@media (max-width: 1120px) {
    .landing-mobile-nav .nav-dropdown {
        position: static;
        transform: none;
        box-shadow: none;
        border: none;
        border-radius: 0;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        min-width: 0;
        width: 100%;
        background: #f9fafb;
        border-radius: 10px;
        margin-top: 0.4rem;
        display: none;
    }

    .landing-mobile-nav .nav-dropdown.is-open {
        display: block;
    }

    .landing-mobile-nav .nav-dropdown::before,
    .landing-mobile-nav .nav-dropdown::after {
        display: none;
    }
}

@media (max-width: 1120px) {
    .family-story,
    .family-grid,
    .family-card-grid {
        grid-template-columns: 1fr;
    }

    .family-steps {
        grid-template-columns: 1fr;
    }

    .family-cta-strip {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .landing-main {
        width: calc(100% - 0.6rem);
        margin-top: 4rem;
    }

    body.landing-page > main:not(.landing-main) {
        margin-top: 4rem !important;
    }

    .family-hero,
    .family-panel,
    .family-card,
    .family-quote,
    .family-callout,
    .family-step,
    .family-footer-card {
        padding: 0.95rem;
    }

    .family-hero h1 {
        max-width: 100%;
    }

    .family-story__number {
        text-align: left;
        font-size: clamp(3.25rem, 14vw, 4.5rem);
    }
}

.landing-hero__shell {
    display: grid;
    grid-template-columns: 1.15fr 0.95fr;
    gap: 1rem;
    align-items: center;
    height: min(560px, calc(100vh - 190px));
    border-radius: 12px;
    padding: 1.1rem;
    background:
        linear-gradient(135deg, rgba(17, 28, 55, 0.03), rgba(33, 105, 58, 0.04)),
        radial-gradient(circle at 20% 20%, rgba(33, 105, 58, 0.09), transparent 30%),
        radial-gradient(circle at 80% 20%, rgba(28, 182, 145, 0.09), transparent 28%);
}

.landing-hero__copy {
    display: grid;
    gap: 0.8rem;
    max-width: 640px;
    padding: 0.6rem 0 0.6rem 0.5rem;
}

.landing-hero__eyebrow,
.landing-section-heading .eyebrow {
    margin: 0;
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.8rem;
    border-radius: 0;
    background: #eff1ff;
    color: #21693A;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.landing-hero__copy h1 {
    margin: 0;
    font-size: clamp(2.2rem, 4.35vw, 4.45rem);
    line-height: 1.05;
    letter-spacing: -0.055em;
    max-width: 11ch;
    text-wrap: balance;
}

.landing-hero__lead,
.landing-intro__text,
.landing-card p {
    color: #5f6c85;
    font-size: 1.02rem;
    line-height: 1.65;
}

.landing-hero__lead {
    max-width: 54ch;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.landing-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.landing-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.landing-hero__chips span {
    padding: 0.46rem 0.72rem;
    border: 1px solid #dde4f1;
    border-radius: 0;
    background: rgba(255, 255, 255, 0.8);
    color: #48556f;
    font-size: 0.85rem;
    font-weight: 600;
}

.landing-hero__visual {
    display: grid;
    gap: 0.65rem;
}

.landing-hero__frame {
    position: relative;
    min-height: 440px;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #dce4f0;
    background:
        linear-gradient(180deg, rgba(7, 11, 24, 0.08), rgba(7, 11, 24, 0.26)),
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.2), transparent 26%);
}

.landing-hero__image {
    position: absolute;
    inset: 0;
    background-color: #171f33;
    background-size: cover;
    background-position: center;
    transform: scale(1.02);
}

.landing-hero__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(7, 11, 24, 0.18) 0%, rgba(7, 11, 24, 0.54) 100%),
        radial-gradient(circle at 20% 18%, rgba(255, 255, 255, 0.18), transparent 28%);
}

.landing-hero__glass {
    position: absolute;
    left: 0.9rem;
    right: 0.9rem;
    bottom: 0.9rem;
    z-index: 1;
    padding: 0.9rem 0.95rem;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 0;
    background: rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(16px);
    color: #fff;
}

.landing-hero__glass-title {
    margin: 0 0 0.25rem;
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.landing-hero__glass p:last-child {
    margin: 0;
    color: rgba(255, 255, 255, 0.9);
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.landing-hero__controls {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.45rem;
    align-items: center;
}

.landing-hero__control {
    width: 44px;
    height: 44px;
    border: 1px solid #d6ddeb;
    border-radius: 0;
    background: #fff;
    color: #263046;
    font-size: 1.05rem;
}

.landing-hero__dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.4rem;
    min-height: 44px;
}

.landing-hero__dot {
    width: 10px;
    height: 10px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: #c7d0e2;
}

.landing-hero__dot.is-active {
    width: 26px;
    background: #21693A;
}

.landing-intro {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    padding: 1.35rem;
    align-items: start;
}

.landing-intro--reference h2 {
    font-size: clamp(2rem, 3.7vw, 3.25rem);
    line-height: 1;
    margin: 0 0 1rem;
    max-width: 14ch;
}

.landing-intro--reference .button {
    border-radius: 999px;
    min-height: 38px;
    padding-inline: 1rem;
}

.landing-section-heading h2,
.landing-intro h2,
.landing-card h3,
.page-hero h1 {
    margin: 0;
    letter-spacing: -0.04em;
}

.landing-intro h2 {
    font-size: clamp(1.7rem, 3vw, 2.6rem);
    line-height: 1.06;
    max-width: 12ch;
}

.landing-intro__text {
    margin: 0;
    max-width: 58ch;
    padding-top: 0.45rem;
}

.landing-section {
    padding: 1.2rem 1.25rem 1.35rem;
}

.landing-feature-row {
    display: grid;
    grid-template-columns: 1.25fr 1fr 1fr;
    gap: 0.75rem;
}

.landing-feature-card {
    border: 1px solid #dfe6f2;
    background: #ffffff;
    padding: 1.2rem;
    min-height: 220px;
    display: grid;
    align-content: start;
    gap: 0.55rem;
    border-radius: 12px;
}

.landing-feature-card h3 {
    margin: 0;
    font-size: 2rem;
    line-height: 0.95;
    letter-spacing: -0.04em;
}

.landing-feature-card p {
    margin: 0;
    color: #5f6c85;
    line-height: 1.58;
}

.landing-feature-card--image {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 84% 74%, rgba(133, 127, 255, 0.22), rgba(133, 127, 255, 0) 52%),
        radial-gradient(circle at 73% 84%, rgba(183, 174, 255, 0.28), rgba(183, 174, 255, 0) 62%),
        linear-gradient(180deg, rgba(242, 245, 255, 0.94), rgba(235, 240, 251, 0.94)),
        #f3f6ff;
}

.landing-feature-card--dark {
    background: #262446;
    color: #f5f7ff;
    border-color: #262446;
}

.landing-feature-card--dark p {
    color: rgba(244, 247, 255, 0.86);
}

.landing-partners {
    border: 1px solid #dfe6f2;
    background: #ffffff;
    padding: 0.85rem 1rem;
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 0.65rem;
    border-radius: 10px;
}

.landing-partners span {
    font-size: 0.77rem;
    color: #7c889f;
    text-align: center;
    white-space: nowrap;
}

.landing-use-cases {
    border: 1px solid #dfe6f2;
    background: #ffffff;
    padding: 1.35rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    border-radius: 14px;
}

.landing-use-cases__copy .eyebrow {
    margin-bottom: 0.8rem;
}

.landing-use-cases__copy h2 {
    margin: 0 0 0.75rem;
    font-size: clamp(2rem, 3.8vw, 3.1rem);
    line-height: 0.95;
    letter-spacing: -0.05em;
}

.landing-use-cases__copy p {
    margin: 0;
    max-width: 52ch;
    color: #5f6c85;
    line-height: 1.62;
}

.landing-use-cases__card {
    border: 1px solid #dfe6f2;
    background: linear-gradient(180deg, #f9fbff 0%, #f0f4ff 100%);
    padding: 1.2rem;
    min-height: 320px;
    display: grid;
    align-content: start;
    gap: 0.7rem;
    border-radius: 12px;
}

.landing-use-cases__card h3 {
    margin: 0;
    font-size: 2rem;
    line-height: 0.94;
    letter-spacing: -0.04em;
}

.landing-use-cases__card > p {
    margin: 0;
    color: #5f6c85;
}

.landing-use-cases__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem 0.85rem;
    margin-top: 0.2rem;
}

.landing-use-cases__links a {
    color: #2f3e5f;
    font-weight: 600;
}

.landing-use-cases__links a:hover {
    color: #21693A;
}

.landing-section-heading {
    display: grid;
    gap: 0.55rem;
    margin-bottom: 1rem;
}

.landing-section-heading h2 {
    font-size: clamp(1.55rem, 2.5vw, 2.2rem);
    line-height: 1.08;
}

.landing-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.landing-card {
    padding: 1.15rem;
    border: 1px solid #dfe6f2;
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 250, 255, 0.96)),
        #fff;
    display: grid;
    gap: 0.7rem;
    min-height: 220px;
}

.landing-card span {
    color: #21693A;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.landing-card h3 {
    font-size: 1.35rem;
    line-height: 1.08;
}

.landing-card a {
    align-self: end;
    justify-self: start;
    color: #21693A;
    font-weight: 700;
}

.landing-card a:hover {
    text-decoration: underline;
}

/* In landing.css — override the broken page-hero trick globally */
.page-hero {
    position: relative !important;
    left: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.page-hero {
    padding: clamp(2.2rem, 4.8vw, 3.8rem) 1rem clamp(1.55rem, 3vw, 2.35rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.65rem;
    justify-items: center;
    text-align: center;
    overflow: hidden;
    isolation: isolate;
}

.page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(247, 250, 252, 0.98) 0, rgba(247, 250, 252, 0.92) 68px, rgba(247, 250, 252, 0.28) 150px, rgba(247, 250, 252, 0) 230px),
        radial-gradient(circle at 50% 24%, rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0.08) 44%, rgba(255, 255, 255, 0) 72%),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.46) 0 1px, transparent 1px 40px),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.46) 0 1px, transparent 1px 40px),
        linear-gradient(180deg, #edf2f6 0%, #e8eef3 100%);
    z-index: -2;
}

.page-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 18%, rgba(236, 242, 246, 0.16), transparent 62%);
    z-index: -1;
}

body.landing-page.landing-page--grid .page-hero::before {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.42) 0, rgba(255, 255, 255, 0.18) 120px, rgba(255, 255, 255, 0) 250px),
        radial-gradient(circle at 50% 24%, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.06) 44%, rgba(255, 255, 255, 0) 72%),
        repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.3) 0 1px, transparent 1px 52px),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.3) 0 1px, transparent 1px 52px);
}

body.landing-page.landing-page--grid .page-hero::after {
    background: radial-gradient(circle at 50% 16%, rgba(236, 242, 246, 0.12), transparent 62%);
}

.page-hero > * {
    position: relative;
    z-index: 1;
}

.page-hero h1 {
    margin: 0;
    font-size: clamp(1.85rem, 4vw, 3.35rem);
    line-height: 1.08;
    letter-spacing: -0.04em;
}

.page-hero > p {
    margin: 0;
    max-width: 760px;
    font-size: clamp(0.95rem, 1.55vw, 1.04rem);
}

.page-hero__panel {
    display: none;
}

.page-hero__panel,
.page-section,
.info-card,
.location-card,
.team-card,
.give-card,
.watch-card,
.mission-card,
.event-card,
.ministry-card,
.contact-card {
    border: 1px solid #dfe6f2;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.04);
}

.page-hero__panel,
.page-section {
    padding: 1.25rem;
}

.page-hero p,
.page-section p,
.info-card p,
.location-card p,
.team-card p,
.give-card p,
.watch-card p,
.mission-card p,
.event-card p,
.ministry-card p,
.contact-card p {
    color: #5f6c85;
    line-height: 1.65;
}

.page-grid,
.info-grid,
.team-grid,
.event-grid,
.ministry-grid,
.contact-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.page-shell {
    display: grid;
    gap: 1.6rem;
}

.page-shell .page-section:first-of-type {
    margin-top: 0.35rem;
}

main > .page-hero + .page-content {
    margin-top: clamp(1.45rem, 2.8vw, 2.35rem);
    padding-top: 0.15rem;
}

.event-card,
.mission-card,
.ministry-card,
.info-card,
.team-card,
.location-card,
.give-card,
.watch-card,
.contact-card {
    padding: 1.1rem;
}

.event-card--flip {
    position: relative;
    overflow: hidden;
    min-height: 200px;
    background: linear-gradient(135deg, #f9fbff, #edf2ff);
}

.event-card--flip:hover {
    transform: translateY(-2px);
}

.landing-footer {
    width: 100%;
    box-sizing: border-box;
    margin: clamp(2rem, 4.2vw, 3rem) 0 0;
    padding: 2.45rem 0 1.7rem;
    border: 1px solid #12451f;
    border-left: 0;
    border-right: 0;
    border-radius: 0;
    background: linear-gradient(180deg, #175225 0%, #12451f 100%);
    color: rgba(255, 255, 255, 0.88);
    box-shadow: 0 16px 34px rgba(10, 28, 15, 0.18);
}

.landing-footer__grid {
    width: min(1480px, calc(100% - 6rem));
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.25fr 1.75fr;
    gap: 3.6rem;
    align-items: start;
}

.landing-footer__brand {
    display: grid;
    gap: 1rem;
    max-width: 430px;
}

.landing-footer__logo img {
    display: block;
    width: auto;
    max-width: 240px;
    height: 68px;
    object-fit: contain;
}

.landing-footer__brand p {
    margin: 0;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.78);
}

.landing-footer__columns {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 2.1rem;
    align-items: start;
}

.landing-footer__columns div {
    display: grid;
    grid-template-rows: auto repeat(4, minmax(1.7rem, auto));
    gap: 0.2rem;
    align-content: start;
}

.landing-footer__columns h3 {
    margin: 0 0 0.2rem;
    font-size: 0.88rem;
    color: #f4fbf6;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.landing-footer__columns a {
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.92rem;
    font-weight: 500;
    line-height: 1.3;
}

.landing-footer__columns a:hover {
    color: #d8f0df;
}

.landing-footer__bottom {
    width: min(1480px, calc(100% - 6rem));
    margin-inline: auto;
    margin-top: 2rem;
    padding-top: 1.35rem;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.landing-footer__bottom p {
    margin: 0;
    text-align: center;
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.68);
}

@media (max-width: 1120px) {
    .site-header {
        grid-template-columns: auto auto 1fr;
    }

    .site-header__nav {
        display: none;
    }

    .site-header__menu-button {
        display: inline-flex;
    }

    .landing-mobile-nav {
        top: 68px;
    }

    .landing-hero__shell,
    .landing-intro,
    .page-hero,
    .landing-footer__grid,
    .landing-use-cases {
        grid-template-columns: 1fr;
    }

    .landing-footer__columns {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .landing-footer__grid,
    .landing-footer__bottom {
        width: calc(100% - 2.2rem);
    }

    .landing-hero__shell {
        height: 780px;
    }

    .landing-feature-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .landing-feature-card--image {
        grid-column: 1 / -1;
    }

    .landing-card-grid,
    .page-grid,
    .info-grid,
    .team-grid,
    .event-grid,
    .ministry-grid,
    .contact-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .landing-hero__copy h1 {
        max-width: 12ch;
    }
}

@media (max-width: 760px) {
    .site-header {
        width: 100%;
        grid-template-columns: auto 1fr auto;
        padding: 0.62rem 0.7rem;
    }

    .site-header__brand img {
        max-width: 150px;
        height: 34px;
    }

    .site-header__actions {
        gap: 0.4rem;
    }

    .site-header__actions .button {
        padding-inline: 0.85rem;
    }

    .landing-main {
        width: calc(100% - 0.6rem);
    }

    .landing-mobile-nav {
        width: 100%;
    }

    .landing-main {
        margin-top: 3.95rem;
        gap: 0.85rem;
    }

    body.landing-page > main:not(.landing-main) {
        margin-top: 3.95rem !important;
    }

    .landing-feature-row,
    .landing-partners,
    .landing-use-cases__links,
    .landing-footer__columns {
        grid-template-columns: 1fr;
    }

    .landing-partners span {
        text-align: left;
    }

    .landing-mobile-nav:not([hidden]) {
        display: grid;
    }

    .landing-hero,
    .landing-section,
    .landing-intro,
    .page-section,
    .page-hero,
    .landing-footer {
        width: 100%;
        margin: 0;
        padding: 1.65rem 0 1.35rem;
        border-radius: 0;
        border-left: 0;
        border-right: 0;
    }

    .landing-hero--full-width {
        padding: 0;
        border: 0;
        border-radius: 0;
        margin-left: -50vw;
        margin-right: -50vw;
    }

    .page-shell {
        gap: 1.05rem;
    }

    .page-shell .page-section:first-of-type {
        margin-top: 0.15rem;
    }

    main > .page-hero + .page-content {
        margin-top: 1.15rem;
        padding-top: 0.05rem;
    }

    .landing-footer__grid,
    .landing-footer__bottom {
        width: calc(100% - 1.1rem);
    }

    .landing-hero__shell {
        height: 700px;
        padding: 0.5rem;
    }

    .landing-hero__copy {
        padding: 0.6rem 0.2rem 0;
    }

    .landing-hero__copy h1 {
        font-size: clamp(2.15rem, 10vw, 3.2rem);
    }

    .landing-hero__frame {
        min-height: 360px;
    }

    .landing-card-grid,
    .page-grid,
    .info-grid,
    .team-grid,
    .event-grid,
    .ministry-grid,
    .contact-grid {
        grid-template-columns: 1fr;
    }

    .landing-hero__controls {
        grid-template-columns: 1fr;
    }

    .landing-hero__control {
        display: none;
    }
}
