.topografo-moduli-section {
    background: #000;
    color: #fff;
    padding: 60px 50px;
    font-family: Inter, sans-serif;
}

.topografo-moduli-container {
    max-width: 1400px;
    margin: auto;
}

.topografo-moduli-header {
    text-align: center;
}

.topografo-moduli-header h2 {
    font-size: 36px;
    line-height: 42px;
    font-weight: 600;
    margin-block-start: 0px !important;
    margin-block-end: 0px !important;
    color: white;
    padding-bottom: 10px;
}

.topografo-moduli-header p {
    font-size: 20px;
    line-height: 26px;
    font-weight: 400;
    margin-block-start: 0px !important;
    margin-block-end: 0px !important;
    font-family: Inter, sans-serif;
    padding-bottom: 60px;
}

/* GRID */

.topografo-moduli-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
}

/* CARD */

.topografo-modulo-card img {
    width: 100%;
    margin-bottom: 25px;
}



.modulo-label {
    font-family: Inter, sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 300;
    margin-block-start: 0px !important;
    margin-block-end: 0px !important;
}

.topografo-modulo-card h3 {
    font-family: Inter, sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 600;
    margin-block-start: 0px !important;
    margin-block-end: 0px !important;
    padding: 0px 0 15px 0;
}

.topografo-modulo-card ul {
    font-family: Inter, sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 300;
    margin-block-start: 0px !important;
    margin-block-end: 0px !important;
    padding: 0px 0px 20px 20px;
}

.modulo-note {
    font-family: Inter, sans-serif;
    font-size: 18px;
    line-height: 24px;
    font-weight: 300;
    margin-block-start: 0px !important;
    margin-block-end: 0px !important;
}

/* RESPONSIVE */

@media(max-width:1000px) {

    .topografo-moduli-grid {
        grid-template-columns: repeat(2, 1fr);
    }

}

@media(max-width:600px) {

    .topografo-moduli-grid {
        grid-template-columns: 1fr;
    }

}

@media (max-width: 409px) {
    .topografo-moduli-section {
        padding-left: 30px;
        padding-right: 30px;
    }
}

@media (min-width: 410px) and (max-width: 699px) {
    .topografo-moduli-section {
        padding-left: 50px;
        padding-right: 50px;
    }
}

@media (min-width: 700px) and (max-width: 870px) {
    .topografo-moduli-section {
        padding-left: 30px;
        padding-right: 30px;
    }
}


/* TITOLO */
@media (max-width: 369px) {
    .topografo-moduli-header h2 {
        font-size: 26px;
        line-height: 32px;
    }
}

@media (min-width: 370px) and (max-width: 375px) {
    .topografo-moduli-header h2 {
        font-size: 24px;
        line-height: 30px;
    }
}

@media (min-width: 376px) and (max-width: 409px) {
    .topografo-moduli-header h2 {
        font-size: 27px;
        line-height: 33px;
    }
}

@media (min-width: 410px) and (max-width: 414px) {
    .topografo-moduli-header h2 {
        font-size: 28px;
        line-height: 34px;
    }
}

@media (min-width: 415px) and (max-width: 430px) {
    .topografo-moduli-header h2 {
        font-size: 29px;
        line-height: 35px;
    }
}

@media (min-width: 431px) and (max-width: 791px) {
    .topografo-moduli-header h2 {
        font-size: 30px;
        line-height: 36px;
    }
}

@media (min-width: 792px) and (max-width: 810px) {
    .topografo-moduli-header h2 {
        font-size: 31px;
        line-height: 37px;
    }
}

@media (min-width: 811px) and (max-width: 830px) {
    .topografo-moduli-header h2 {
        font-size: 32px;
        line-height: 38px;
    }
}

@media (min-width: 831px) and (max-width: 849px) {
    .topografo-moduli-header h2 {
        font-size: 33px;
        line-height: 39px;
    }
}


@media (min-width: 850px) and (max-width: 964px) {
    .topografo-moduli-header h2 {
        font-size: 35px;
        line-height: 41px;
    }
}



/* DESCRIZIONE */
@media (max-width: 369px) {
    .topografo-moduli-header p {
        font-size: 14px;
        line-height: 20px;
    }
}

@media (min-width: 370px) and (max-width: 1200px) {
    .topografo-moduli-header p {
        font-size: 18px;
        line-height: 24px;
    }
}


/* TITOLETTO */
@media (max-width: 1128px) {

    .modulo-label,
    .topografo-modulo-card h3,
    .topografo-modulo-card ul,
    .modulo-note {
        font-size: 16px;
        line-height: 22px;
    }

    .modulo-label,
    .topografo-modulo-card h3,
    .topografo-modulo-card ul,
    .modulo-note {
        margin-block-start: 0px !important;
        margin-block-end: 0px !important;
    }
}

@media (max-width: 369px) {

    .modulo-label,
    .topografo-modulo-card h3,
    .topografo-modulo-card ul,
    .modulo-note {
        line-height: 20px;
        font-size: 14px;
    }
}