#portfolio_page footer {
    position: relative;

}

/*
 * Les titres de colonnes sont en inline-block (links.css, mode nav--bg / nav--underline).
 * Sans text-align sur les conteneurs, ils restent à gauche malgré footer.nav-center / nav-right.
 */
#portfolio_page footer.nav-left #footer-main,
#theme-visualiser #portfolio_page footer.nav-left #footer-main {
    text-align: left;
}

#portfolio_page footer.nav-center #footer-main,
#theme-visualiser #portfolio_page footer.nav-center #footer-main {
    text-align: center;
}

#portfolio_page footer.nav-right #footer-main,
#theme-visualiser #portfolio_page footer.nav-right #footer-main {
    text-align: right;
}

/* Plus fort que .text-align-* sur #footer-social (alignement typo des titres de page) */
#portfolio_page footer.nav-left #footer-main #footer-social,
#theme-visualiser #portfolio_page footer.nav-left #footer-main #footer-social {
    text-align: left;
}

#portfolio_page footer.nav-center #footer-main #footer-social,
#theme-visualiser #portfolio_page footer.nav-center #footer-main #footer-social {
    text-align: center;
}

#portfolio_page footer.nav-right #footer-main #footer-social,
#theme-visualiser #portfolio_page footer.nav-right #footer-main #footer-social {
    text-align: right;
}

#portfolio_page footer .footer-title {
    display: block;
    padding: 0px!important;
}

#portfolio_page #footer-pages li {
    margin-bottom: 15px;
    align-items: flex-start;
}

/* Colonnes / titres / réseaux : flex + texte. */
#portfolio_page footer.nav-left #footer-pages li,
#portfolio_page footer.nav-left .footer-title,
#portfolio_page footer.nav-left .social-medias {
    justify-content: flex-start;
    text-align: left;
}

#portfolio_page footer.nav-center #footer-pages li,
#portfolio_page footer.nav-center .footer-title,
#portfolio_page footer.nav-center .social-medias {
    justify-content: center;
    text-align: center;
}

#portfolio_page footer.nav-right #footer-pages li,
#portfolio_page footer.nav-right .footer-title,
#portfolio_page footer.nav-right .social-medias {
    justify-content: flex-end;
    text-align: right;
}

/*
 * Bloc « à propos » : le HTML (TinyMCE) impose souvent text-align en inline sur les <p> / <div>,
 * ce qui ignorait les règles du thème alors que les lignes contact (flex + svg) suivaient bien nav-left/center/right.
 */
#portfolio_page footer.nav-left #footer-about {
    text-align: left;
}

#portfolio_page footer.nav-left #footer-about a.footer-title,
#portfolio_page footer.nav-left #footer-about p,
#portfolio_page footer.nav-left #footer-about div,
#portfolio_page footer.nav-left #footer-about span,
#portfolio_page footer.nav-left #footer-about li {
    text-align: left !important;
}

#portfolio_page footer.nav-center #footer-about {
    text-align: center;
}

#portfolio_page footer.nav-center #footer-about a.footer-title,
#portfolio_page footer.nav-center #footer-about p,
#portfolio_page footer.nav-center #footer-about div,
#portfolio_page footer.nav-center #footer-about span,
#portfolio_page footer.nav-center #footer-about li {
    text-align: center !important;
}

#portfolio_page footer.nav-right #footer-about {
    text-align: right;
}

#portfolio_page footer.nav-right #footer-about a.footer-title,
#portfolio_page footer.nav-right #footer-about p,
#portfolio_page footer.nav-right #footer-about div,
#portfolio_page footer.nav-right #footer-about span,
#portfolio_page footer.nav-right #footer-about li {
    text-align: right !important;
}


#portfolio_page footer .contact-details {
    display: flex;
    align-items: center;
}

#portfolio_page footer .contact-details svg {
    width: 20px;
    margin-right: 15px;
}

#portfolio_page #legal {
    display: flex;
    position: relative;

}

#portfolio_page #legal ul {
    display: flex;
    flex-wrap: wrap;
}

#portfolio_page #legal ul li {
    margin: 0px 15px 2px 0px;
    transition: 0.2s linear;
}

#portfolio_page #legal ul li a {
    transition: 0.2s linear;
}

@media screen and (max-width: 600px) {

    #portfolio_page #legal ul {
        flex-wrap: wrap;
    }
    
}

#visitor_mode {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    bottom: 45px;
    padding-left: 15px;
    padding-right: 15px;
    font-family: 'Poppins', sans-serif;
}

@media screen and (max-width: 600px) {

    #visitor_mode .arkt-promo-btn {
        left: 25%;
        transform: translateX(-25%);
        width: 70vw;
    }
    
}