.services {
    background-color: var(--color-primary);
    color: var(--text-color-inverse);
    font-weight: 400;
    font-size: 15px;
}

.services h2 {
    padding-top: 90px;
    text-align: center;
    text-transform: uppercase;
    font-size: 40px;
    margin: 25px;
}

.services_title {
    text-align: center;
    text-transform: uppercase;
}

.service_intro {
    font-weight: 400;
    font-size: 15px;
    margin-top: 10px;
}


.service {
    padding: 25px;
    max-width: 500px;
    margin: 0 auto;
}

@media (min-width: 950px) {
    .services {
        background-color: var(--color-primary);
        color: var(--text-color-inverse);
    }

    .services_title {
        text-align: center;
        text-transform: uppercase;
        font-size: 30px;
        margin: 25px;
    }

    .service_intro {
        font-weight: 400;
        font-size: 15px;
        margin-top: 10px;
    }

    .service {
        padding: 0;
    }

    .services-grid {
        display: grid;
        grid-template-columns: auto 2px auto;
        gap: 20px 70px;
        padding: 70px;
        justify-content: center;
    }

    .line {
        background-color: var(--text-color-inverse);
        position: relative;
    }

    .line::before,
    .line::after {
        content: "";
        display: block;
        width: 20px;
        height: 20px;
        background-color: var(--text-color-inverse);
        border-radius: 50%;
        position: absolute;
        top: -20px;
        left: -9px;
    }

    .line::after {
        top: 100%;
    }
}
