/* ============================================
   TEXT COLUMNS - Bloc texte 2 colonnes
   ============================================ */

.text-columns {
    width: 100%;
    padding-top: 160px;
    padding-bottom: 240px;
}

/* Wrapper fullwidth pour le titre */
.text-columns__title-wrapper {
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto 100px;
    padding-left: var(--container-padding-x-fluid);
    padding-right: var(--container-padding-x-fluid);
}

/* Titre optionnel - TT Commons Thin 64px */
.text-columns__title {
    font-family: 'tt-commons-pro-thin', 'TT Commons Pro', sans-serif;
    font-size: 64px;
    font-weight: 100;
    line-height: 1.2;
    text-align: left;
    margin: 0;
    color: var(--color-noir);
}

.text-columns__container {
    max-width: var(--container-max-width);
    margin: 0 auto;
    padding-left: var(--container-padding-x-fluid);
    padding-right: var(--container-padding-x-fluid);
}

.text-columns__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}

.text-columns__column {
    font-family: 'tt-commons-pro', 'TT Commons Pro', sans-serif;
    font-size: 22px;
    font-weight: 300;
    line-height: 42px;
    color: var(--color-noir);
}

.text-columns__column p {
    margin-bottom: var(--space-md);
}

.text-columns__column p:last-child {
    margin-bottom: 0;
}

/* Texte souligné dans le contenu */
.text-columns__column u {
    text-decoration: underline;
    text-decoration-color: var(--color-noir);
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}

/* ============================================
   RESPONSIVE
   ============================================ */

/* Tablet */
@media (max-width: 1024px) {
    .text-columns {
        padding-top: 120px;
        padding-bottom: 180px;
    }

    .text-columns__title-wrapper {
        margin-bottom: 60px;
    }

    .text-columns__title {
        font-size: 52px;
    }

    .text-columns__grid {
        gap: 40px;
    }

    .text-columns__column {
        font-size: 20px;
        line-height: 38px;
    }
}

/* Mobile */
@media (max-width: 768px) {
    .text-columns {
        padding-top: 80px;
        padding-bottom: 120px;
    }

    .text-columns__title-wrapper {
        margin-bottom: 40px;
    }

    .text-columns__title {
        font-size: 40px;
    }

    .text-columns__grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .text-columns__column {
        font-size: 18px;
        line-height: 34px;
    }
}
