﻿/* Shared content / SEO landing page styles */

.hero-section,
.problem-section,
.process-section,
.final-cta {
    max-width: 1120px;
    margin: 0 auto;
    padding: 5rem 1.5rem;
}

/* Hero */

.hero-content {
    max-width: 860px;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #169657;
    font-weight: 900;
    font-size: .82rem;
    margin-bottom: 1.25rem;
    padding: .35rem .75rem;
    border: 1px solid rgba(22, 150, 87, .25);
    border-radius: 999px;
    background: rgba(22, 150, 87, .06);
}

.hero-section h1 {
    font-size: clamp(3rem, 6vw, 5.25rem);
    line-height: 1.04;
    color: #1f2e2a;
    margin: 0 0 1.5rem;
    max-width: 900px;
}

.hero-text {
    font-size: 1.15rem;
    line-height: 1.8;
    color: #4a5953;
    max-width: 760px;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 2rem;
}

/* Buttons */

.btn-primary-custom,
.btn-secondary-custom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .95rem 1.4rem;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 900;
    transition: all .2s ease;
}

.btn-primary-custom {
    background: #153f31;
    color: #fff;
    border: 2px solid #153f31;
    box-shadow: 0 14px 28px rgba(21, 63, 49, .18);
}

    .btn-primary-custom:hover {
        background: #0f3025;
        color: #fff;
        transform: translateY(-1px);
    }

.btn-secondary-custom {
    border: 2px solid #153f31;
    color: #153f31;
    background: transparent;
}

    .btn-secondary-custom:hover {
        background: #153f31;
        color: #fff;
    }

/* Section headings */

.section-heading {
    max-width: 760px;
    margin-bottom: 3rem;
}

    .section-heading h2,
    .final-cta-card h2 {
        font-size: clamp(2rem, 4vw, 3rem);
        line-height: 1.15;
        margin: 0 0 1rem;
        color: #1f2e2a;
    }

    .section-heading p,
    .final-cta-card p {
        color: #56645f;
        line-height: 1.75;
        font-size: 1.05rem;
    }

/* Problem cards */

.problem-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.5rem;
}

.problem-card {
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(21, 63, 49, .1);
    border-radius: 22px;
    padding: 2rem;
    box-shadow: 0 18px 40px rgba(21, 63, 49, .06);
}

    .problem-card h3 {
        margin: 0 0 1rem;
        color: #1f2e2a;
        font-size: 1.35rem;
    }

    .problem-card p {
        color: #56645f;
        line-height: 1.7;
        margin: 0;
    }

/* Process steps */

.process-steps {
    display: grid;
    gap: 1.25rem;
}

.process-step {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    background: rgba(255, 255, 255, .72);
    border: 1px solid rgba(21, 63, 49, .1);
    border-radius: 22px;
    padding: 2rem;
    box-shadow: 0 18px 40px rgba(21, 63, 49, .06);
}

.step-number {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: 999px;
    background: #153f31;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 900;
}

.process-step h3 {
    margin: 0 0 .6rem;
    color: #1f2e2a;
    font-size: 1.2rem;
}

.process-step p {
    margin: 0;
    color: #56645f;
    line-height: 1.7;
}

/* Final CTA */

.final-cta {
    padding-top: 3rem;
}

.final-cta-card {
    background: rgba(255, 255, 255, .76);
    border: 1px solid rgba(21, 63, 49, .1);
    border-radius: 26px;
    padding: 3rem;
    box-shadow: 0 18px 40px rgba(21, 63, 49, .07);
    max-width: 900px;
}

.cta-subtext {
    margin-top: 1.25rem;
    max-width: 720px;
}

/* Mobile */

@media (max-width: 900px) {
    .hero-section,
    .problem-section,
    .process-section,
    .final-cta {
        padding: 3rem 1rem;
    }

        .hero-section h1 {
            font-size: 3rem;
        }

    .problem-grid {
        grid-template-columns: 1fr;
    }

    .process-step {
        flex-direction: column;
    }

    .final-cta-card {
        padding: 2rem;
    }
}

@media (max-width: 520px) {
    .hero-section h1 {
        font-size: 2.55rem;
    }

    .btn-primary-custom,
    .btn-secondary-custom {
        width: 100%;
    }

    .problem-card,
    .process-step,
    .final-cta-card {
        border-radius: 18px;
        padding: 1.5rem;
    }
}
.workflow-next-section {
    max-width: 1120px;
    margin: 0 auto;
    padding: 2rem 1.5rem 4rem;
}

.workflow-next-card {
    background: rgba(21, 63, 49, .06);
    border: 1px solid rgba(21, 63, 49, .12);
    border-radius: 24px;
    padding: 2.5rem;
}

    .workflow-next-card h2 {
        color: #1f2e2a;
        font-size: clamp(1.8rem, 3vw, 2.5rem);
        margin: 0 0 1rem;
    }

    .workflow-next-card p {
        color: #56645f;
        line-height: 1.75;
        max-width: 720px;
        margin-bottom: 1.5rem;
    }

.hero-section {
    padding-bottom: 2.5rem;
}

.problem-section {
    padding-top: 2rem;
}