.hero-copy {
    color: #fff;
    max-width: 640px;
    margin: -10px 0 30px;
    font-size: clamp(1.05rem, 1.5vw, 1.28rem);
    font-weight: 400;
    line-height: 1.55;
    text-shadow: 0 8px 24px #06222c59;
}

.seo-section {
    position: relative;
    padding: 78px 24px;
    color: #0b2d3a;
    background: #eefbffcc;
}

.seo-section:nth-of-type(2n) {
    background: #d7f4fbcc;
}

.seo-section--intro {
    padding-top: 86px;
}

.seo-section--faq {
    padding-bottom: 110px;
}

.seo-inner {
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
}

.section-kicker {
    color: #1a8197;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: 14px;
    font-size: .78rem;
    font-weight: 700;
}

.seo-section h2 {
    max-width: 820px;
    margin: 0;
    color: #06222c;
    font-size: clamp(2rem, 3.5vw, 3.35rem);
    font-weight: 500;
    line-height: 1.08;
}

.section-lede {
    max-width: 840px;
    margin: 24px 0 0;
    color: #174656;
    font-size: 1.08rem;
    line-height: 1.75;
}

.feature-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 34px;
}

.feature-card,
.faq-list article {
    border: 1px solid #ffffffa8;
    background: #ffffff70;
    box-shadow: 0 16px 44px #0b51641c;
}

.feature-card {
    border-radius: 8px;
    padding: 24px;
    min-height: 205px;
}

.feature-card h3,
.faq-list h3 {
    color: #06222c;
    margin: 0 0 12px;
    font-size: 1.18rem;
    font-weight: 600;
    line-height: 1.25;
}

.feature-card p,
.faq-list p,
.copy-stack p {
    color: #174656;
    margin: 0;
    font-size: 1rem;
    line-height: 1.7;
}

.seo-split {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 56px;
    align-items: start;
}

.copy-stack {
    display: grid;
    gap: 18px;
}

.pill-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 30px 0;
}

.pill-list span {
    color: #06222c;
    background: #ffffff78;
    border: 1px solid #ffffffb8;
    border-radius: 999px;
    padding: 9px 14px;
    font-size: .95rem;
    font-weight: 500;
    box-shadow: 0 8px 24px #0b516414;
}

.faq-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 32px;
}

.faq-list article {
    border-radius: 8px;
    padding: 24px;
}

@media (max-width: 900px) {
    .feature-grid,
    .faq-list,
    .seo-split {
        grid-template-columns: 1fr;
    }

    .seo-split {
        gap: 24px;
    }

    .seo-section {
        padding: 62px 22px;
    }

    .seo-section--faq {
        padding-bottom: 82px;
    }
}

@media (max-width: 640px) {
    .hero-copy {
        max-width: 100%;
        margin: -12px 0 24px;
        font-size: 1rem;
    }

    .hero-actions {
        flex-wrap: wrap;
    }

    .seo-section {
        padding: 52px 18px;
    }

    .seo-section h2 {
        font-size: 2rem;
    }

    .section-lede {
        font-size: 1rem;
        line-height: 1.65;
    }

    .feature-card,
    .faq-list article {
        padding: 20px;
    }
}
