/*
 * @author  Agence Dn'D <contact@dnd.fr>
 * @license https://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
 * @link    https://www.dnd.fr/
 */

.section-footer__row-container {
    border-top: unset;

    @media (max-width: 767.98px) {
        padding-inline: var(--gutter-lg);
    }

    .section-footer__row--blocks {
        padding-block: var(--gutter-3xl);

        @media (max-width: 768px) {
            .section-footer__row__col {
                &:not(:last-child) {
                    margin-block-end: 0;
                }

                &.section-footer__newsletter-block {
                    margin-block-end: var(--gutter-3xl);
                    padding: 0;
                }
            }
        }

        @media (min-width: 768px) {
            margin-block-end: 0;
            padding-block-start: 80px;
            padding-block-end: 64px;
        }

        @media (min-width: 1024px) {
            gap: var(--gutter-mobile);

            .section-footer__row__col {
                margin: 0;
                padding-inline: 0;

                &.section-footer__newsletter-block {
                    flex: 0 1 660px;
                }

                &.section-footer__menu-block,
                &.section-footer__text-block {
                    flex: 0 0 calc(50% / 3 - (var(--gutter-mobile) * 2));
                    max-width: 210px;
                }

                &.section-footer__text-block {
                    flex-grow: unset;
                    flex-basis: unset;
                }
            }
        }
    }

    .section-footer__row-lower {
        border-top: 1px solid var(--color-white-opacity-3);
        padding-block-start: var(--gutter-3xl);
        padding-block-end: var(--gutter-lg);
        font-size: var(--base-text-size);

        @media (min-width: 768px) {
            margin-inline: 0;
            padding-block-start: var(--gutter-2xl);
        }

        .section-footer__row__col {
            padding: 0;

            + .section-footer__row__col {
                @media (max-width: 767.98px) {
                    padding-block-start: var(--gutter-xl);
                }
            }
        }
    }

    /* Links */

    a:not(.social__link) {
        position: relative;
        font-weight: var(--font-weight-500);
        text-decoration: unset;

        &::after {
            position: absolute;
            bottom: -1px;
            left: 0;
            z-index: 1;
            transition:
                right 0.3s,
                width 0.3s;
            background-color: currentColor;
            width: 0;
            height: 1px;
            content: "";
        }

        &:hover {
            text-decoration: unset;

            &::after {
                right: 0;
                width: 100%;
            }
        }
    }

    /* Section footer title */

    .section-footer__title {
        margin-block-end: var(--gutter-lg);
        font-weight: var(--font-weight-600);
        font-size: var(--font-size-lg);

        @media (min-width: 768px) {
            svg {
                display: none;
            }
        }
    }

    /* Newsletter */

    .section-footer__newsletter-block {
        > * {
            width: 100%;
            max-width: 550px;
        }

        .section-footer__title,
        .section-footer__text,
        .signup-form {
            margin-block-end: var(--gutter-lg);
        }

        .section-footer__title {
            font-weight: var(--font-weight-600);
            font-size: var(--font-size-lg);
            line-height: var(--heading-line-height);

            @media (min-width: 768px) {
                font-size: var(--font-size-xl);
            }
        }

        .contact-form {
            display: flex;

            > p {
                flex: 1;
                margin: 0;
            }
        }

        .signup-form__email {
            border: 1px solid var(--color-white);
            background: transparent;
            padding: var(--gutter-2sm) var(--gutter-2md);
            height: 40px;
            color: var(--color-white);

            &::placeholder {
                color: var(--color-white);
            }
        }

        .signup-form__button {
            display: grid;
            place-content: center;
            padding: var(--gutter-sm) var(--gutter-2md);
            max-height: 40px;

            @media (max-width: 767.98px) {
                width: fit-content;
            }
        }
    }

    /* Menus */

    .section-footer__menu-block__menu {
        > li {
            margin-block-end: var(--gutter-md);
        }
    }

    .section-footer__lower-menu {
        margin: 0;
    }

    .section-footer__lower-menu__list {
        display: flex;
        flex-direction: column;
        gap: var(--gutter-lg);
        margin: 0;

        @media (min-width: 768px) {
            flex-direction: row;
        }

        li {
            margin: 0;
        }
    }

    @media (max-width: 767.98px) {
        .section-footer__menu-block {
            margin: 0;
            padding: 0;
        }

        .disclosure {
            border: none;

            &[open] {
                .disclosure__title {
                    .section-footer__title {
                        svg {
                            transform: scaleY(-1);
                        }
                    }
                }
            }
        }

        .disclosure__title {
            padding-block: 0;
            padding: 0;

            &::before,
            &::after {
                display: none;
            }

            .section-footer__title {
                display: flex;
                justify-content: space-between;

                svg {
                    transition: transform 0.3s;
                }
            }
        }
    }

    /* Text block */

    .section-footer__text-block--with-text {
        padding-block: 0;

        .section-footer__title {
            margin-block-end: 0;
        }

        .section-footer__text {
            margin-block-start: var(--gutter-lg);

            p {
                font-weight: var(--font-weight-500);

                &:not(:last-child) {
                    margin-block-end: var(--gutter-md);
                }
            }

            strong {
                display: block;
                font-weight: var(--font-weight-500);
            }
        }
    }
}
