/*VARIABLES*/

:root {
    /*--Colors--*/
	--express_primary: #fff;
    --express_secondary: #fec216;
    --express_neutral: #eeeeee;
    --express_body: #194772;
    --express_items: #194772;
    --express_background: #fff;
    --header-icons-brigtness: brightness(0); /* 1=blanc 0=noir*/
    --img-radius: 0;
    --btn-radius: 0;
    --content_width: 1100px;
    --container_width: 100%;
    /**/
    
    /*--Fonts--*/
    
    --font_def: 'Montserrat', Arial, sans-serif;
	--font_price: 'Montserrat', Arial, sans-serif;
	--font_title: 'Montserrat', Arial, sans-serif;
    --font_dates: 'Montserrat', Arial, sans-serif;
    
    /**/

    --width_header: 1500px
}

/*//VARIABLES//*/

/*-------------------*/


/*#region global*/
    /*#region header*/
    header.head-content {
        flex-wrap: wrap;
        align-content: baseline;
        gap: 15px;
        z-index: 15;
        .barre-info-top {
            width: 100%;
            padding: 10px 25px;
            border-bottom: 1px solid var(--express_background);
            color: var(--express_primary);
        }
        .barre-banner {
            z-index: 1;
            width: 100%;
            margin: 1em auto 5em;
            order: 2;
            text-align: center;
            color: var(--express_primary);
            font-size: clamp(20px, 3vw, 4em);
            letter-spacing: .3em;
            font-family: var(--font_title);
        }
        .second {
            justify-content: center;
            flex-wrap: wrap;
            z-index: 4;
            padding-bottom: 0;
            order: 2;
            .barre-banner {
                z-index: 1;
                width: 100%;
                margin: 1em auto 5em;
                order: 3;
                text-align: center;
                color: var(--express_primary);
                font-size: clamp(20px, 3vw, 4em);
                letter-spacing: .3em;
                font-family: var(--font_title);
            }
            .navbar {
                &::before, &::after {
                    display: none;
                }
                display: flex;
                justify-content: space-between;
                gap: 10px;
                max-width: 98%;
                width: var(--width_header);
                padding: 15px 25px;
                filter: none;
                order: 4;
                .navbar-collapse {
                    width: fit-content;
                    .navbar-nav {
                        &::before, &::after {
                            display: none;
                        }
                        align-items: center;
                        justify-content: start;
                        flex-wrap: wrap !important;
                        flex-direction: row !important;
                        gap: 10px 20px;
                        float: initial;
                        padding: 0;
                        background: initial;
                        > li {
                            flex: initial;
                            width: initial;
                            background-color: transparent;
                            transition: .2s ease-in-out;
                            &:hover, &.active {
                                background-color: var(--express_neutral);
                                a {
                                    border-bottom: 0;
                                }
                            }
                            &:hover > ul {
                                opacity: 1;
                                pointer-events: all;
                            }
                            > a {
                                padding: 0;
                                > span.libelle {
                                    display: flex;
                                    justify-content: center;
                                    align-items: center;
                                    gap: 5px;
                                    letter-spacing: 1px;
                                    font-family: var(--font_title);
                                    color: var(--express_body);
                                    text-transform: uppercase;
                                    transition: .2s ease-in-out;
                                    &::after {
                                        content: ">";
                                        display: block;
                                        color: var(--express_secondary);
                                    }
                                }
                            } 
                            > ul {
                                display: block !important;
                                top: 100%;
                                left: 0;
                                opacity: 0;
                                pointer-events: none;
                                text-align: left;
                                transition: .2s ease-in-out;
                                > li {
                                    &.active a .libelle {
                                        color: var(--express_secondary);
                                    }
                                    a .libelle {
                                        text-transform: uppercase;
                                        color: var(--express_body);
                                        font-weight: normal;
                                        letter-spacing: 1px;
                                    }
                                }
                            }
                        } 
                        .logo {
                            width: auto;
                            height: 160px;
                            text-align: center;
                            img {
                                width: fit-content;
                                height: 100%;
                                object-fit: contain;
                            }
                        }
                    }
                }
                a.barre-connexion-btn {
                    &::before {
                        content: ">";
                        display: block;
                    }
                    display: flex;
                    align-items: center;
                    gap: 5px;
                    padding: 10px;
                    border-radius: 0;
                    text-transform: uppercase;
                    font-weight: bold;
                    color: var(--express_body);
                    border: 1px solid var(--express_body);
                    letter-spacing: 1.5px;
                    transition: .4s ease-in-out;
                    &:hover {
                        background-color: var(--express_body);
                        color: var(--express_background);
                    }
                }
            }
            .block-user {
                display: none;
                /* order: 2;
                .identification {
                    display: none;
                } */
            }
        }
        .menu-site-vitrine {
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 9999;
            width: 100%;
            order: 1;
            > ul {
                display: flex;
                align-items: center;
                justify-content: center;
                width: 100%;
                > li {
                    &::before {
                        content: "";
                        position: absolute;
                        top: 0;
                        left: 0;
                        z-index: -1;
                        width: 0;
                        height: 100%;
                        background-color: var(--express_body);
                        transition: .2s ease-in-out;
                    }
                    flex: 0 1 10%;
                    position: relative;
                    padding: 5px;
                    text-align: center;
                    &.dropdown.cart {
                        display: flex;
                        justify-content: center;
                        transform: translateY(-50%);
                        width: fit-content;
                        margin: 0;
                        border: 0;
                        border: none;
                        &:hover .dropdown-menu {
                            opacity: 1;
                            pointer-events: all;
                        }
                        #cart-btn {
                            content: "";
                            display: block;
                            width: 30px;
                            height: 60px;
                            padding: 0;
                            background: url(../images/ice-cream.png) no-repeat center center / contain;
                            filter: none;
                            span {
                                position: absolute;
                                top: 0;
                                left: 50%;
                                transform: translate(-50%, 50%);
                                width: 100%;                            
                                text-align: center;
                                font-family: var(--font_title);
                                color: var(--express_body);
                            }
                            .nav-bar-user-libelle {
                                position: absolute;
                                top: 100%;
                                left: 50%;
                                transform: translateX(-50%);
                                max-width: initial;
                                width: initial;
                            }
                        }
                        .dropdown-menu {
                            display: block;
                            right: 0;
                            min-width: min(350px, 50vw);
                            text-align: center;
                            opacity: 0;
                            pointer-events: none;
                            box-shadow: 0px 0px 20px #00000080;
                            transition: .2s ease-in-out;
                            span {
                                color: var(--express_body);
                                text-transform: none;
                            }
                        }
                    } 
                    &:hover:not(.dropdown), &:has(span):not(.dropdown) {
                        &::before {
                            width: 100%;
                        }
                    }
                    a, span {
                        font-size: 16px;
                        white-space: break-spaces;
                        text-transform: uppercase;
                        color: var(--express_primary);
                    }
                }
                .logo {
                    width: auto;
                    height: 160px;
                    text-align: center;
                    a {
                        height: 100%;
                        margin: 0;
                        img {
                            width: fit-content;
                            height: 100%;
                            object-fit: contain;
                        }   
                    }
                }
            }
        }
    }
    @media (max-width: 1290px) {
        header.head-content {
            position: relative !important;
            .menu-site-vitrine > ul > li {
                a, span {
                    &:first-letter {
                        text-transform: uppercase;
                    }
                    display: block;
                    font-size: 12px;
                    text-transform: none;
                    letter-spacing: 0;
                }
            } 
        }
    }
    @media (min-width: 700px) {
        header.head-content .menu-site-vitrine .only-on-resp {
            display: none;
        }
    }
    @media (max-width: 700px) {
        header.head-content .menu-site-vitrine {
            > ul {
                .logo {
                    margin-left: 0;
                }
                & > li:not(.only-on-resp) {
                    display: none;
                }
                .only-on-resp {
                    flex: initial;
                    margin: auto;
                    order: 2;
                }
                .dropdown.cart {
                    margin: auto !important;
                    order: 3;
                }
            } 
            .back-to-root {
                display: block;
                padding: 5px 10px;
                border: solid 1px var(--express_body);
                text-transform: uppercase;
                color: var(--express_body);
                text-align: center;
                background-color: var(--express_primary);
                transition: .2s ease-in-out;
                &:hover {
                    background-color: var(--express_body);
                    color: var(--express_background);
                }
            }
        } 
    }
    @media (max-width: 600px) {
        header.head-content .second .navbar {
            justify-content: center;
            flex-wrap: wrap;
            .navbar-collapse {
                width: 100%;
                .nav.navbar-nav {
                    justify-content: center;
                }
            }
        }
    }
    /*#endregion header*/
    /*#region body*/
    body {
        &::before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: var(--express_background);
            border: solid 15px var(--express_body);
            z-index: -1;
        }
        position: relative;
        padding: 15px;
        background-color: var(--express_background);
        > .main-content {
            &::before {
                content: "";
                position: absolute;
                top: 15px;
                left: 15px;
                max-height: calc(175vh - 30px);
                width: calc(100% - 30px);
                height: calc(100% - 30px);
                background: linear-gradient(#194772 0%, #ffffff4a 30%, #fff 40%);
            }
            position: static !important;
            max-width: 100%;
            min-height: initial;
            width: var(--width_header);
            margin: auto auto 5%;
            padding: 0 20px !important;
            border-top: 0 !important;
            background-color: var(--express_background);
            > .row > .content > .row.module-haut >.module-rayons > ul.row {
                display: flex;
                gap: 25px;
                padding: 25px;
                > li {
                    min-width: 250px;
                    max-width: calc((100% / 3) - (50px / 3));
                    a {
                        &::before {
                            content: "";
                            position: absolute;
                            top: 0;
                            left: 0;
                            width: 100%;
                            height: 100%;
                            z-index: 10;
                        }
                        position: relative;
                    }
                }
            }
            &::after {
                content: "";
                position: absolute;
                top: 15px;
                left: 15px;
                max-height: 100vh;
                width: calc(100% - 30px);
                height: calc(100% - 30px);
                background: url('../images/background.jpg') no-repeat center center/cover;
                z-index: -1;
            }
        }
    }
    /*#endregion body*/
    /*#region page login*/
    body.etape1 .content {
        .head .title {
            display: none;
        }
        .connexion {
            padding: 0;
            > .row {
                display: flex;
                justify-content: center;
                form {
                    width: 50%;
                    padding: 30px;
                    &:first-child {
                        border-right: 1px solid var(--express_body);
                    }
                    span.title span {
                        text-transform: uppercase;
                        font-weight: bold;
                        font-size: 16px;
                    }
                    input[type="text"] {
                        box-shadow: none;
                        background-color: var(--express_neutral);
                    }
                    a.login[href*='envoi-lien-mot'] {
                        text-transform: uppercase;
                        color: var(--express_body);
                        text-decoration: none;
                        letter-spacing: 1.5px;
                        span {
                            display: block;
                            margin: 15px 0;
                        }
                        &::after {
                            content: "Si vous possédez déjà un compte en boutique, veuillez cliquer sur <<mot de passe oublé>>.";
                            pointer-events: none;
                        }
                    }
                }
                &:last-child {
                    display: none;
                }
            }
        } 
    } 
    @media (max-width: 700px) {
        body.etape1 .content .connexion > .row {
            flex-direction: column;
            form {
                width: 100%;
                &:first-child {
                    border-right: none;
                    border-bottom: 1px solid var(--express_body);
                }
            }
        }
    }
    /*#endregion page login*/
    /*#region rayons*/
    .boxModule.module-rayons li.item, .listeSousRayons li.item {
        a h3 label {
            font-size: 15px;
            font-weight: bold;
            text-transform: uppercase;
        }
        .ray-description {
            padding: 5px 10px;
            text-align: left;
            font-size: 15px;
            letter-spacing: 3px;
        }
    }
    body[class*='rayon-'] .main-content {
        overflow: clip;
        .row.avec-agencement {
            &::before {
                content: "";
                position: absolute;
                top: -5vh;
                left: -5vw;
                width: calc(100% + 10vw);
                height: calc(100% + 10vw);
                background-color: var(--express_background);
            }
            position: relative;
            ul.agencement {
                display: none;
            }
            .content {
                float: initial;
                width: 100%;
                margin-right: 0;
                .grid-content {
                    float: initial;
                    width: 100%;
                    margin-right: 0;
                    .listeSousRayons > ul, > ul.bloc.row {
                        justify-content: center;
                        grid-template-columns: repeat(auto-fit, clamp(22%, 320px, 100%));
                        margin: 0;
                    }
                    /* li.item {
                        width: 100%;
                    } */
                }
            }
        }
    } 
    /*#endregion rayons*/
    /*#region single produit*/
    body[class*="article"] .main-content {
        ul.agencement {
            display: none;
        }
        .content .droite {
            .top h1 {
                text-transform: uppercase;
                font-size: clamp(1.5rem, 30px, 2.5rem);
            }
            .detail {
                display: flex;
                flex-direction: column;
                padding: 0;
                .short-desc {
                    order: 2;
                }
                .description {
                    padding: 15px;
                    order: 3;
                    font-size: 13px;
                    font-family: var(--font_title);
                    background-color: var(--express_neutral);
                    .ui-tabs-panel {
                        padding: 0;
                        background-color: initial;
                        border: none;
                        &.tab_dispo {
                            display: none !important;
                        }
                        li {
                            border: none;
                            background: initial;
                            a.ui-tabs-anchor {
                                font-weight: bold;
                                font-size: 13px;
                                font-family: var(--font_title);
                                color: #707070;
                                pointer-events: none;
                            }
                        }
                        table.horaire {
                            border: none;
                            background-color: initial;
                            th {
                                color: inherit;
                                background-color: inherit;
                                padding: 0;
                                font-size: 13px;
                                font-family: var(--font_title);
                                text-align: left;
                            }
                        }
                    }
                }
                form {
                    order: 1;
                }
            }
        }
    } 
    .ariane {
        position: relative;
        z-index: 9;
        margin: 0;
    }
    /*#endregion single produit*/
    /*#region panier*/
    .article-ajout .data {
        font-family: var(--font_def);
        .libelle {
            font-size: 15px;
            font-weight: bold;
            text-transform: uppercase;
            color: var(--express_body);
        }
    }
    body.etapes .content {
        .etape-panier .commentaire span {
            color: var(--express_body);
        }
        .action.row {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            justify-content: end;
            a.continue {
                margin-right: auto;
                order: 1;
            }
            a.anonyme {
                background-color: var(--express_body);
                order: 2;
            }
            a.login {
                order: 3;
            }
        } 
    }
    /*#endregion panier*/
    /*#region page point de retrait*/
    body.choix-points-vente-details .head, body.choix-points-vente {
        .head {
            .title, .sub-title, message {
                max-width: 100%;
                color: var(--express_body);
                line-height: 1.5;
            }
        }
        .head ~ .row ul.bloc .item .boxStore  {
            border: px solid var(--express_body);
            transition: .2s ease-in-out;
            .lien-details {
                transition: .2s ease-in-out;
            }
        }
    } 
    /*#endregion page point de retrait*/
    /*#region iframe order*/
    #link-modal-overlay {
        display: none; position: fixed; inset: 0;
        background: rgba(0,0,0,0.5); z-index: 9999;
        align-items: center; justify-content: center;
        &.open { display: flex; }
        #link-modal {
            background: #fff; border-radius: 8px;
            width: 90vw; height: 80vh;
            display: flex; flex-direction: column; overflow: hidden;
        }
        #link-modal-header {
            display: flex; justify-content: flex-end;
            padding: 8px; border-bottom: 1px solid #eee;
            #link-modal-close {
                cursor: pointer; font-size: 20px; background: none;
                border: none; line-height: 1;
            }
        }
        #link-modal-iframe { flex: 1; border: none; width: 100%; }
    }
    #modal-begin-order {
        &::before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: white;
        }
        &::before, &::after {
            opacity: 0;
            pointer-events: none;
            transition: .2s ease-in-out;
        }
        &.loading {
            &::before, &::after {
                opacity: 1;
            }
            * {
                pointer-events: none;
            }
        }
        position: fixed;
        top: 50%;
        left: 50%;
        z-index: 999;
        transform: translate(-50%, -50%);
        max-width: 90%;
        max-height: 98%;
        width: 1200px;
        padding: 5%;
        opacity: 0;
        pointer-events: none;
        box-shadow: 0px 0px 20px #00000080;
        background-color: white;
        transition: .4s ease-in-out;
        &.open {
            opacity: 1;
            pointer-events: all;
        }
        .close-modal {
            &::before {
                content: "";
                position: absolute;
                top: 7.5px;
                right: 7.5px;
                width: 15px;
                height: 15px;
                background-color: white;
                clip-path: polygon(10% 0%, 0% 10%, 40% 50%, 0% 90%, 10% 100%, 50% 60%, 90% 100%, 100% 90%, 60% 50%, 100% 10%, 90% 0%, 50% 40%);
            }
            position: absolute;
            top: 0;
            right: 0;
            transform: translate(50%, -50%);
            width: 30px;
            height: 30px;
            border-radius: 50%;
            background-color: var(--express_body);
            border-radius: 50%;
            cursor: pointer;
        }
        .choix-points-vente-liste.row {
            &::before {
                content: "Votre commande à emporter";
                display: block;
                margin-bottom: 20px;
                text-align: center;
                letter-spacing: 3px;
                text-transform: uppercase;
                font-size: clamp(1.5rem, 40px, 2.5rem);
            }
            text-align: center;
            text-transform: uppercase;
            > ul {
                display: flex;
                align-content: center;
                flex-wrap: wrap;
                justify-content: center;
                gap: 15px;
                height: 100%;
                padding: 2.5%;
                > li {
                    align-content: center;
                    max-width: 100%;
                    width: 300px;
                    padding: 2.5%;
                    background-color: var(--express_body);
                    .boxStore {
                        color: var(--express_primary);
                        .selection a {
                            display: block;
                            margin-top: 10px;
                            padding: 5px 10px;
                            text-transform: uppercase;
                            color: var(--express_body);
                            text-align: center;
                            font-size: 15px;
                            letter-spacing: 2px;
                            border: solid 1px var(--express_body);
                            background-color: var(--express_background);
                            transition: .2s ease-in-out;
                            &:hover {
                                border: solid 1px var(--express_background);
                                background-color: var(--express_body);
                                color: white;
                            }
                        }
                    }
                }
            }
            .recap-store {
                margin-top: 10px;
                margin-bottom: 30px;
                font-weight: bold;
                .selected-store span {
                    margin: 5px;
                }
            }
            .blocSelect {
                &::before {
                    content: "À QUEL MOMENT SOUHAITEZ-VOUS RÉCUPÉRER VOTRE COMMANDE ?";
                    display: block;
                    text-align: center;
                    text-transform: uppercase;
                    letter-spacing: 1px;
                    font-weight: bold;
                }
                .date-retrait::before {
                    content: "Date";
                }
                .heure-retrait::before {
                    content: "Heure";
                }
                .date-retrait, .heure-retrait {
                    display: flex !important;
                    justify-content: center;
                    align-items: center;
                    flex-direction: column;
                    margin-top: 15px;
                    text-align: center;
                    text-transform: uppercase;
                    letter-spacing: 1px;
                    font-weight: bold;
                    input, select {
                        max-width: 98%;
                        width: 350px;
                        margin: auto;
                        padding: 5px;
                        text-align: center;
                        background-color: var(--express_neutral);
                        border-radius: 0;
                        border: none;
                    }
                }
            }
            .retour-liste, .submit button {
                display: block;
                width: fit-content;
                margin: 10px auto;
                padding: 5px 10px;
                text-align: center;
                background-color: var(--express_body);
                border: solid 1px var(--express_body);
                color: var(--express_primary);
                text-transform: uppercase;
                letter-spacing: 1px;
                transition: .2s ease-in-out;
                &:hover {
                    background-color: var(--express_primary);
                    color: var(--express_body);
                }
            }
        }
        &::after {
            content: "Chargement...";
            position: absolute;
            top: 50%;
            left: 50%;
            z-index: 999;
            transform: translate(-50%, -50%);
        }
    }
    /*#endregion iframe order*/
    /*#region footer*/
    footer {
        position: relative;
        .pageStatique {
            display: flex;
            align-items: center;
            justify-content: center;
            flex-wrap: wrap;
            gap: 40px;
            .pre_footer {
                display: flex;
                align-items: center;
                justify-content: space-around;
                flex-wrap: wrap;
                gap: 40px;
                width: 100%;
                padding: 20px;
                text-align: center;
                text-transform: uppercase;
                font-weight: bold;
                letter-spacing: 2px;
                line-height: 1.5;
                background-color: var(--express_neutral);
            }
            .logo_footer {
                width: 140px;
            }
            .map.ligne.third ul {
                column-count: 2;
                gap: 40px;
                li {
                    display: block;
                    margin-bottom: 10px;
                    text-align: left;
                    a {
                        color: var(--express_background);
                        text-transform: uppercase;
                        font-family: var(--font_title);
                    }
                }
            }
        }
    }
    /*#endregion footer*/
/*#endregion global*/

.share-pinterest {
    display: none !important;
}

/*IMAGES*/

    /*BG*/

    .back-left, .back-right{
        background: var(--express_body);
    }

    /**/

    /*Header*/
    header {
		padding: 0;
	}

    header .header-search form i{
        background-image: url('../images/recherche.svg');
    }

    /**/

    /*Accordion*/

    .agencement.accordion li.liparent.active > a .opener{
        background-image: url(../images/accordion-moins.svg);
    }

    .agencement.accordion li.liparent > a .opener{
        background-image: url(../images/accordion-plus.svg);
    }

    /**/

    /*Fiche Produit*/
	.article .droite .pu .ttcCalc.hidden + .ttcPu .unite {
		font-size: 25px;
	}
	.article .droite .pu .ttcCalc.hidden + .ttcPu .unite {
		display: inline-block;
	}

    .article .droite .price{
        margin: 0;
    }

    .article .droite .commentaire{
        margin-bottom: 2rem;
    }

    .boxArticle div.cadencier a, .article .droite div.cadencier a{
        background-image: url('../images/liste-envie.svg');
    }

	.rayon-00610 .boxArticle .spin,
	.rayon-00610 .article .spin,
	.rayon-00612 .boxArticle .spin,
	.rayon-00612 .article .spin {
	    display: none !important;
	}
	.boxArticle .ajoutPanier {
		display: none;
	}
	.boxArticle .ajoutPanier.non-disponible {
		display: block;
	}
	.boxArticle .spin {
	    display: block;
		width: 100px;
		text-align: center;
		margin: 0 auto 15px auto;
		height: auto;
	}
	.boxArticle .spin .libQte {
		display: none;
	}
	.boxArticle div.spin input {
		float: none;
	}
	.boxArticle .spin .spin-minus {
		left: 0;
		right: auto;
	}
	.boxArticle .spin .spin-minus,
	.boxArticle .spin .spin-plus {
		top: 0;
		height: 2em;
		width: 2em;
		font-weight: bold;
	}
	.boxArticle .in_cart {
	    display: block;
		z-index: 1;
        color: var(--express_primary);
	}

	.dropdown-menu > li> a {
		white-space : normal;
	}

	.choix-points-vente-details .boxStore .nom,
	.choix-points-vente-details .boxStore .fax,
	.choix-points-vente .boxStore .nom,
	.choix-points-vente .boxStore .fax {
		display: block;
		text-align: left;
		font-weight: bold;
		font-size: 1.5em;
        margin-bottom: 0.5rem;
	}

    .article .droite div.spin button{
        aspect-ratio: 1 /1;
    }

    div.spin button.spin-minus, div.spin button.spin-plus{
        color: var(--express_background) !important;
        background: var(--express_body) !important;
    }

    /**/

    /*Champs*/

    /*Champs*/

    .choix-enlevement-express .column-right .choix-date .r_conso, .choix-enlevement-express .column-right .choix-date .r_jour, .choix-enlevement-express .column-right .choix-date .r_heure, .choix-points-vente-details .date-retrait select, .express.choix-points-vente-details .heure-retrait, .choix-livraison-traiteur .choix-mag .choose-delivery .date-retrait select, .choix-livraison-traiteur .choix-mag .choose-delivery .heure-retrait select{
        background-image: url('../images/select-button.svg')
    }
	.express.choix-livraison-traiteur .choix_libelle {
        background: none;
	}


    /**/

    /*Formulaires*/

    input[type="radio"]:checked + label{
        background-image: url('../images/radio-checked.svg')
    }

    input[type="checkbox"]:checked + label{
        background-image: url('../images/checkbox-checked.svg')
    }

    /**/

    /*Point de vente*/
    .choix-points-vente-details .row > .column-middle .column-right > .nom, .points-vente-details .row > .column-middle .column-right > span, .etape4 .row > .column-middle .column-right > .nom, .points-vente-details .modalLink > .column-right > .nom, .points-vente-details .row > .column-middle .column-right > .nom, .points-vente-details .modalLink > .column-right > .ville, .points-vente-details .row > .column-middle .column-right > .ville,
	.etape4 .row > .column-middle .column-right > .ville {
        background-image: url("../images/points-vente/logo.png");
    }

    .lien-fdf{
        display: none !important;
    }

    header .map.ligne{
        display: none !important;
        width: 0;
        opacity: 0;
        height: 0;
        position: absolute;
    }

    .choix-enlevement-express .column-right .choix-date .r_conso, 
	.choix-enlevement-express .column-right .choix-date .r_jour, 
	.choix-enlevement-express .column-right .choix-date .r_heure, 
	.choix-points-vente-details .date-retrait select,
	.express.choix-points-vente-details .heure-retrait,
	.choix-livraison-traiteur .choix-mag .choose-delivery .date-retrait select,
	.choix-livraison-traiteur .choix-mag .choose-delivery .heure-retrait select{
        background-image: url('../images/select-button.svg');
    }

    /**/

    /*Formulaires*/

    input[type="radio"]:checked + label{
        background-image: url('../images/radio-checked.svg');
    }

    input[type="checkbox"]:checked + label{
        background-image: url('../images/checkbox-checked.svg');
    }

    /**/

    /*Point de vente*/
    .choix-points-vente-details .row > .column-middle .column-right > .nom, .points-vente-details .row > .column-middle .column-right > span, .etape4 .row > .column-middle .column-right > .nom, .points-vente-details .modalLink > .column-right > .nom, .points-vente-details .row > .column-middle .column-right > .nom, .points-vente-details .modalLink > .column-right > .ville, .points-vente-details .row > .column-middle .column-right > .ville,
	.etape4 .row > .column-middle .column-right > .ville {
        background-image: url("../images/points-vente/logo.png");
    }

    .lien-fdf{
        display: none !important;
    }

	.choix-points-vente .conso-3,
	.choix-points-vente .conso-4,
	.choix-points-vente-details .conso-3,
	.choix-points-vente-details .conso-4 {
		display: none !important;
	}

    header .map.ligne {
        display: none !important;
        width: 0;
        opacity: 0;
        height: 0;
        position: absolute;
    }
	
	.choix-livraison-traiteur .pv-livraison .title-pv-livraison label {
		content: "Livraison chez vous ! ";
	}

	.express .module-droite .boxCarrousel .boxArticle, 
	.express .module-droite .boxModule .boxArticle {
		height: 100%;
	}

/*//IMAGES//*/


/*-------------------*/

/*SURCHARGE*/

body.choix-points-vente .ariane,
header .first {
	display: none;
}
body.choix-points-vente > .main-content {
	margin-bottom: 0;
	padding: 70px;
	background-image: url('../images/bg-03.jpg');
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}

.choix-points-vente-details .choose-title {
	background-color: transparent;
	font-size: 3em;
	font-weight: bold;
}

.boxModule.module-promotion .boxArticle .pu,
.boxArticle .details .pu,
.article-ajout .pu,
.article .droite .pu {
	font-family: var(--font_price);
}

.boxModule.module-promotion .boxArticle .pu h2:first-child .currency,
.boxArticle .details .currency,
.article-ajout .prix .currency,
.article .droite .pu .currency {
	font-family: var(--font_price);
	top: 0;
	font-size: 1em;
}

.article .description .ui-tabs-panel,
.article .description > ul.tabs li {
    border-radius: var(--btn-radius);
}
.article .description .ui-tabs-panel {
	font-size: 1.2em;
	padding: 1.5em;
}
.ui-tabs .ui-tabs-nav li a {
	text-transform: unset;
    color: var(--express_body);
}

.article .non-disponible {
	font-size: 1.3em;
}
.article .non-disponible span {
	font-weight: normal;
}

.article .droite div.spin {
	height: 35px;
	justify-content: center;
    background: var(--express_body);
    border-radius: var(--btn-radius);
	margin-right: 20px;
}
.article .droite div.spin input {
	font-weight: normal;
	width: 150px;
    color: var(--express_primary);
    background: var(--express_body);
	font-size: 1.5em;
}
.article .droite div.acheter,
.article .droite div.acheter a {
	text-align : center;
	width: 100%;
}

.article-ajout .data {
	width: 50%;
}
.article-ajout .data .libelle {
	font-weight: bold;
}

/*Header*/

/*header, .agencement.horizontal, .express .agencement.horizontal .navbar-nav > li:hover{
    background: var();
}*/
@media (max-width: 1024px) {
    header .navbar.agencement.horizontal {
        height: initial;
    }
}
.agencement.horizontal .navbar-collapse > ul{
    background: var(--express_primary);
	float: right;
	width: auto;
}
.agencement.horizontal .navbar-nav > li {
	padding: 7px;
}
.agencement.horizontal .navbar-nav > li .opener-child {
	display: none;
}
.agencement.horizontal .navbar-nav > li > a{
	border: 0;
}
.agencement.horizontal .navbar-nav > li.active > a {
	border-bottom: 1px solid var(--express_body);
}

.agencement.horizontal li.niveau_0 > a span{
    color: var(--express_body);
}

.express .agencement.horizontal .navbar-nav > li:hover {
    background: var(--express_neutral);
}
.express .agencement.horizontal .navbar-nav > li:hover span{
    color: var(--express_primary);
}

.agencement.horizontal li.niveau_0 > a label, .agencement.horizontal li.niveau_0 > a span{
    font-size: 1.6rem !important;
}

.express .agencement.horizontal .dropdown-menu{
    background: var(--express_neutral);
}

.agencement.horizontal .count {
	display: none;
}

header .second {
	padding: 1% 0;
}
header .second {
	width: 100%;
}
header .second .block-user {
	width: 10%;
	padding: 0;
}
header .second .logo {
	width: 20%;
	text-align: left;
}
header .second .logo a {
	margin: 0;
}
header .second .logo a img{
    width: 25rem; /*Logo du header plus grand*/
}

header .navbar-user > li{
    background: transparent; /*Passer les icones du menu en blanc*/
    border: 1px solid var(--express_background);
}
header .navbar-user > li:hover{
    background: initial !important;
}

header .navbar-user li ul.dropdown-menu.pull-right, header .cadencier > ul, header .cart > div{
    min-width: 190px;
}

header .navbar-user li.account .dropdown-menu.pull-right{
    left: 0; /*Corrige la position du menu déroulant du compte*/
}

header .magasin ul a, header .magasin ul span, header .account ul a, header .account ul span, header .identification ul a, header .identification ul span{
    color: var(--express_body);
}

header .header-search form.f_search .input-group input{
    border: 1px solid var(--express_body) !important;
    color: var(--express_body);
}
header .agencement.horizontal {
	position: inherit;
	width: 50%;
	margin: 0;
	
}

body > .agencement.horizontal {
	z-index: 4;
}

.navbar-form .form-control{
    color: var(--express_background); /*Couleur du texte de recherche en blanc*/
}

.express header .magasin ul .point-retrait:hover{
    background: transparent;
}

.dropdown.end-delai{ /*Masquer le minuteur du panier*/
    display: none !important;
}

/**/

/*Boutons*/

.choix-points-vente-details .row > .column-middle > .column-right,
.choix-points-vente-details .boxStore, 
.choix-points-vente .boxStore {
    border-radius: var(--btn-radius);
	color: var(--express_body) !important;
	background-color: var(--express_background) !important;
	padding: 1.8em;
	margin: auto;
	border: 0;
    &:hover{
		background-color: var(--express_body) !important;
		color: var(--express_background) !important;
    }
}

.choix-points-vente-details .boxStore:hover span, 
.choix-points-vente .boxStore:hover span {
		color: var(--express_background) !important;
}

.choix-points-vente .boxStore:hover .selection a {
	color: var(--express_body) !important;
	background: var(--express_background) !important;
	border: 1px solid var(--express_body) !important;
}

.express.choix-points-vente-details .row > .column-middle,
.express.choix-points-vente-details .row > .column-right {
	padding-right: 140px;
	width: 500px;
}
.choix-points-vente-details .valider,
.choix-points-vente-details .heure-retrait,
.choix-points-vente-details .date-retrait {
	display: block;
	margin-bottom: 10px;
	width: 100%;
}
.express.choix-points-vente-details .heure-retrait select {
	border: 0;
	font-size: 1em;
}
.express.choix-points-vente-details .heure-retrait {
	margin-top: 27px;
}
.express.choix-points-vente-details .heure-retrait,
.express.choix-points-vente-details .date-retrait input {
    border-radius: var(--btn-radius);
    border: 1px solid var(--express_body);
	background-color: white !important;
	font-size: 1.5em;
	padding: 0.6em;
}

.choix-points-vente-details .row > .column-middle > .column-left {
	margin-top: 9px;
	padding: 0;
}
.choix-points-vente-details .row > .column-middle > .column-right {
	text-align: left;
	background-color: var(--express_body) !important;
	color: var(--express_background) !important;
}

.choix-points-vente-details .row > .column-middle .column-right > .nom, .points-vente-details .row > .column-middle .column-right > span, .etape4 .row > .column-middle .column-right > .nom, .points-vente-details .modalLink > .column-right > .nom, .points-vente-details .row > .column-middle .column-right > .nom, .points-vente-details .modalLink > .column-right > .ville, .points-vente-details .row > .column-middle .column-right > .ville, .etape4 .row > .column-middle .column-right > .ville {
	background: none;
	padding: 0;
}

.choix-points-vente-details .column-middle .choose-title span,
.choix-points-vente-details .column-right .choose-title span {
	display: none;
}
.choix-points-vente-details .column-middle .choose-title:after {
    content: "Point de retrait";
	display: block;
}
.choix-points-vente-details .column-right .choose-title:after {
    content: "Date de retrait";
	display: block;
}

.article .evenements .radio label {
	font-size: 1.5em;
	padding-left: 25px;
}

input[type="radio"]:checked + label {
	background-size: 18px;
	background-position: 0 5px;
}

.envoi-photo div.acheter button, 
.boxArticle div.acheter a, 
.choix-points-vente .boxStore .selection a,
header .magasin ul .point-retrait span,
.express.choix-points-vente-details .submit button,
.article-ajout .cart,
.express.etapes .content .action a.login,
.express.etapes .content .action a.anonyme,
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset button[idx="1"],
header .cart ul .commande a,
.etape1 .main-content .content button,
.informations button,
.etapes .valider-commande,
.express.etapes .valider-commande,
footer .footer-widgets .btn__carte-cadeau{
    padding: 10px 15px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
	border: 1px solid var(--express_body) !important;
    background: var(--express_body);
    color: var(--express_background) !important;
    &:hover{
		color: var(--express_body) !important;
        background: var(--express_background) !important;
		border: 1px solid var(--express_body) !important;
    }
}

.article .droite div.acheter a, #open-modal-begin-order {
	color: var(--express_body) !important;
	background-color: var(--express_background) !important;
	border: 1px solid var(--express_body) !important;
    padding: 0.5em 2em;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    cursor: pointer;
    transition: .2s ease-in-out;
    &:hover{
		color: var(--express_background) !important;
		background-color: var(--express_body) !important;
		border: 1px solid var(--express_body) !important;
    }
}

.boxArticle .commentaire input,
.article .commentaire input {
	width: auto;
	text-align: center;
}

.choix-points-vente-details .submit button{
    float: none;
}

.express.choix-points-vente-details .date-retrait input{
    width: 100%;
    border: 1px solid var(--express_body);
    background: url(../images/calendar.svg) right 0.5em top 0.5em no-repeat;
	background-size: 1.5em;
}

.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span{
    filter: brightness(0);
}

header .magasin ul .point-retrait span, header .cart ul .commande a{
    padding: .5em 1em;
}

.choix-livraison-traiteur .pv-livraison div.nom {
	width: 100%;
}

.etapes .selection-paiement .paiement_0 .libelle { 
	display: inline-block;
}

.etape1 .main-content button{
    margin-bottom: .5rem;
}

.etape1 .main-content .login{
    display: inline-block;
    margin-bottom: 2rem;
}

.etape1 .main-content .login span{
    text-decoration: underline;
}

/**/

/*Index*/
.index .boxModule.module-rayons h3 {
    padding: 0 10px;
    letter-spacing: 1px;
    color: var(--express_body);
    font-weight: bold;
	text-align: left;
}

.index .boxModule.module-rayons,
.index .main-content .module-haut .module-rayons {
	padding: 0;
	margin-top: 0;
}

.index .main-content .module-haut .module-rayons ul.row{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0;
    padding: 0;
    max-width: 100%;
    margin: auto;
}

.index .main-content .module-haut .module-rayons ul.row:before, .index .main-content .module-haut .module-rayons ul.row:after{
    display: none;
}

.index .main-content .module-haut .module-rayons ul.row li.item{
    width: 100%;
    margin: 0;
}


.grid .bloc .sousRayon, .grid .bloc .sousRayon img,
.boxArticle .hrefImage img,
.index .boxModule.module-rayons img{
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 0;
    object-fit: contain;
}

.index .boxModule.module-rayons label {
	text-transform: capitalize;
}

.boxModule .item:hover .boxRayon img {
	transform: initial;
    filter: none;
}

.boxModule .item .boxRayon h3 {
	transform: none !important;
    label {
        transform: none !important;
        color: var(--express_body) !important;
        font-size: 15px !important;
        font-weight: bold !important;
        border: 0 !important;
        filter: none !important;
    }
}

.choix-points-vente-details .map-wrapper ,
.choix-points-vente .map-wrapper { 
	display: none;
}
.choix-points-vente-details .head .title, 
.choix-points-vente .head .title {
    color: var(--express_primary);
	display: block;
	font-size: 1.2em;
	line-height: 1.4em;
	font-family: var(--font_title);
	margin-left: -5px;
}

.choix-points-vente-details .head .sub-title, 
.choix-points-vente .head .sub-title {
    color: var(--express_primary);
	display: block;
	font-size: 3em;
	line-height: 0.9em;
	font-family: var(--font_title);
	font-weight: bold;
	max-width: 230px;
	margin-left: -5px;
}

/**/

/*Agencement Accordion*/

.agencement.accordion li.niveau_0 > a span.libelle{
	font-size: 1.5em;
	font-weight: bold;
    white-space: break-spaces;
    margin-left: 0;
}

@media (min-width: 991px) {
    .agencement.accordion{
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    .agencement.accordion li.niveau_0 a, .agencement.accordion li.niveau_0.active.liparent > a, .agencement.accordion li.niveau_0 > a {
        margin: 0 !important;
        color: var(--express_items);
        padding: .5rem;
        margin-bottom: .5rem;
        border-bottom: 2px solid #fff;
    }

    .agencement.accordion li.niveau_0:last-of-type a, .agencement.accordion li.niveau_0:last-of-type{
        border-bottom: none;
    }

    .express .agencement.accordion li.niveau_0 > a:hover, .agencement.accordion li.niveau_0.active > a{
        background: transparent;
        color: var(--express_items);
    }

    .agencement.accordion li.liparent > a .opener{
        top: unset;
        bottom: unset;
        left: unset;
        bottom: 50%;
        transform: translateY(50%);
    }

    .agencement.accordion li.niveau_0 .smenu li{
        background: var(--express_background);
        color: var(--express_body);
        border-bottom-color: var(--express_body);
    }

    .agencement.accordion li.niveau_0 .smenu li:last-of-type{
        border-bottom: none;
    }

    .agencement.accordion li.niveau_0 .smenu li a{
        color: var(--express_body);
    }

    .express .agencement.accordion li.niveau_1.active > a label, .express .agencement.accordion li.niveau_1.active > a span{
        color: var(--express_body);
        font-weight: bold;
    }
}
/**/

/*Fiches Produits*/

.article > .row{
    display: flex;
    gap: 2rem;
    padding: 1rem;
}

.article .gauche, .article .droite{
    width: auto;
    flex: 1;
    float: none;
    margin: 0;
    padding: 0;
}

.article .gauche .owl-wrapper-outer {
	max-width: 500px;
}

.article .gauche .image{
    text-align: center;
}

.article .droite .short-desc{
    font-size: 1.2em;
    line-height: 1.35;
}

.article-ajout .return, .article-ajout .return:hover, .express.etapes .content .action a.continue{
    padding: 0 !important;
    background: transparent !important;
    color: var(--express_body) !important;
    text-decoration: underline !important;
}

    /*Onglets*/

    .article .description > ul.tabs{
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        align-items: start;
    }

    .article .description > ul.tabs::before{
        display: none;
    }

    .article .description > ul.tabs li{
        height: auto;
        padding: .6em 1.2em;
        border: 1px solid var(--express_body);
        transition: .2s ease-in-out;
    }

    .article .description > ul.tabs li.ui-state-active, .article .description > ul.tabs li:hover{
        background: var(--express_body);
    }

    .article .description > ul.tabs li.ui-state-active a, .article .description > ul.tabs li:hover a{
        color: var(--express_primary);
    }

    .article .description > ul.tabs li a, .article .description > ul.tabs li.ui-state-active a{
		font-weight: normal;
        padding: 0;
    }

    .article .description .ui-tabs-panel{
        display: block !important;
        padding: 1.3rem;
        background: #a9a9a95b;
        border-left: 3px solid var(--express_primary);
    }

    /**/

/**/

/*Choix Magasin*/

.choix-points-vente-details .choix_libelle select, .choix-points-vente-details .heure-retrait select, .choix-points-vente-details .date-retrait select{
    width: 120%;
}

.choix-points-vente .boxStore .horaire{
    margin-bottom: 0;
}

.choix-points-vente .boxStore .fermer{
    color: #da3c3c;
    position: relative;
    width: 100%;
}

/**/
.unite {
	display: none !important;
}
.item .boxRayon h3 label, .item .sousRayon h3 label{ /*Titre de produits en boucle*/
	font-weight: 500 !important;
    font-family: var(--font_title) !important;
    font-size: 2rem !important
}

.grid-article .bloc.row .item .short-desc{
    /*max-height: 90px;
    min-height: 90px;*/
    display: none;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 5;
    text-overflow: ellipsis;
    overflow: hidden;
    margin-bottom: 1em;
    font-size: 1.3rem; 
}

.grid-article .bloc.row .item .disponibilite{
    margin-bottom: 1rem;
}

.grid-article .bloc.row .item .lib{
	margin-top: 5px;
    text-transform: uppercase;
    font-weight: normal;
	font-size: 15px;
}

/*.boxArticle .details{
    min-height: 263px;
}*/
.boxArticle .details .pu{
	text-align: left;
	font-size: 1em;
}
.boxArticle .details .pu *{
	font-weight: bold;
}

.boxArticle .details .hrefInfos{
    display: none;
}

.fiche-produit .article .droite .reseau-sociaux{
    display: none;
}

.article .droite .lib{
    font-size: 3rem;
    font-weight: bold;
}

.fiche-produit .article .droite .price{
    margin: 1em 0;
}
.express .article .allergene,
.express .article .allergene td {
	border: 0;
}

.module-cross-selling-article-associe .boxArticle .details{
    min-height: 0;
}

.grid.grid-article .grid-content .bloc.row .item .boxArticle{
    justify-content: initial;
    width: 100%;
    /* max-width: 400px; */
}

.grid.grid-article .grid-content .bloc.row .item .boxArticle .menu{
    display: none; /*Masquer le menu dans la liste d'articles*/
}

/*Liste Articles*/
.grid-content .navigationBar {
	display: none;
}

.grid-content ul.bloc.row{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 0rem 4rem;
}

.grid .bloc .item{
    margin: 0;
}

/*
.grid .bloc .sousRayon, .grid .bloc .sousRayon img{
    width: 100%;
    height: auto;
}

.boxArticle .hrefImage img{
    width: 100% !important;
    height: auto !important;
}
*/


/**/

.points-vente-details .column-right .adr-cp{
    background-image: none !important;
}


.boxModule h4{
    background: transparent;
    color: var(--express_items);
}

.liste-cadencier.ui-dialog{
    background: var(--express_background);
}

.liste-cadencier.ui-dialog form {
    display: flex;
    flex-direction: column;
}

.liste-cadencier.ui-dialog form .selector{
    margin: 12px 0;
}

.liste-cadencier.ui-dialog span, .liste-cadencier.ui-dialog .msg .nom{
    color: var(--express_body) !important;
}

header .cadencier > ul{
    background: transparent;
}
header .navbar-user > li > a.lidentification {
	background-image: url("../images/header/compte.png");
}
header .navbar-user > li > a.lcart {
	background-image: url("../images/header/panier.png");
}
header .navbar-user > li > a.lmagasin {
	background-size: 23px;
}

.express header .cadencier ul li{
    padding: 10px 18px;
    filter: drop-shadow(1px 1px 2px rgba(0,0,0,0.5));
    border: none;
}

.express .boxCarrousel .boxArticle .hrefImage, .express .boxModule .boxArticle .hrefImage{
    height: auto;
}

.express header .cadencier ul li a:hover, .express header .cadencier ul li:hover, .express header .cadencier ul li a, .express header .cadencier ul li{
    background: var(--express_background);
    color: var(--express_body);
}

.etape-panier .menu .libelle{
    display: inline-block;
}

.action.row .anonyme{
    float: right !important;
    margin-right: 1em;
}

.action.row .continue{
    opacity: .8;
}

.select-mag-proximite .ville{
    display: none;
}

.choix-livraison-traiteur .select-mag-proximite .ville{
    display: inherit;
}

.choix-livraison-traiteur.client-b2b .choose-delivery{
    flex-direction: row-reverse;
}

.choix-livraison-traiteur.client-b2b .choose-delivery .liste-type-livraison{
    display: none;
}

.choix-livraison-traiteur.client-b2b .choose-delivery label{
    display: flex;
    flex-direction: column;
    gap: .5rem;
    background-position: left top;
}

.choix-livraison-traiteur .select-livraison-mode label > span.livraison-1 {
	display: none;
}

.choix-livraison-traiteur .pv-livraison .title-pv-livraison label, .choix-livraion .liste-mag-proximite{
    font-size: 2rem !important;
    color: var(--express_primary);
    font-weight: bold;
    font-family: var(--font_title);
}

.choix-livraison-traiteur .select-livraison-mode input[type="radio"] + label {
	background: none;
}
.choix-livraison-traiteur .select-livraison-mode label > span.mini-ttc-cde{
    margin: 0;
	font-size: 1.1em;
}

.ui-dialog.points-vente-details .ui-dialog-titlebar-close{
    filter: drop-shadow(1px 1px 2px);
}

.edition-compte .date-mariage, 
.edition-compte .prenom-conjoint,
.nouveau-compte .date-mariage, 
.nouveau-compte .prenom-conjoint{
    display: none;

}
.choix-livraison-traiteur .pv-livraison div.input-group-btn {
	display: none;
}

/*Choix Magasin*/

.choix-points-vente .main-content .column-right{
    display: flex;
    flex-direction: column-reverse;
    gap: 2rem;
}

.choix-livraion .column-left .select-cp{
    display: none;
}

.choix-livraion .liste-mag-proximite{
    position: relative;
    display: block;
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 2.5rem;
}
.choix-livraison-traiteur.client-b2b .select-livraison-mode {
	margin-top: 0;
	width: 75%;
}
.choix-livraison-traiteur .column-right .valid-adresse .submit {
	margin-top: -60px;
}

/*Panier*/

.commandes .total .mnt *, .commande .total .mnt *, .etapes .total .mnt, .commande thead > tr span, .etapes thead > tr span, .commandes thead > tr span, .commandes thead > tr *, .commande thead > tr *, .etapes thead > tr *{
    color: var(--express_primary);
}
.commandes .liste thead > tr:first-child,
.commandes .details thead > tr:first-child {
	background-color: var(--express_body);
    border-left: 3px solid var(--express);
}

.commande .itemsDetails td, .etapes .itemsDetails td{
    padding: 1rem 0 !important;
}

.commande .total .mnt, .commande thead > tr:first-child, .etapes .total .mnt, .etapes thead > tr:first-child{
    border: none;
}

.etapes thead > tr:first-child{
    background: var(--express_body);
}

.etapes .total span{
    color: var(--express_body);
}

.etapes.client-b2b .mini-cde{
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 1rem;
    background: #ff0000;
    color: #fff;
    text-align: center;
    font-size: 1.3rem;
    font-weight: bold;
    z-index: 99;
}

.etapes .etape-panier table .montant{
    font-size: 1.25em;
}

/*Spins Quantités*/

.etapes .qte .spin, .cadencier.lister .content tr form .spin{
    display: flex;
    flex-direction: row;
    width: 100%;
    justify-content: center;
    align-items: center;
    gap: 1rem;
}

.etapes .qte .spin .spin-minus, .etapes .qte .spin .spin-plus, .cadencier.lister .content tr form .spin .spin-minus, .cadencier.lister .content tr form .spin .spin-plus{
    position: relative;
    aspect-ratio: 1 / 1;
    height: auto;
    top: unset;
    right: unset;
    left: unset;
}

.etapes .qte .spin .spin-minus, .cadencier.lister .content tr form .spin .spin-minus{
    order: 1;
}

.etapes .qte .spin input, .cadencier.lister .content tr form .spin input{
    order: 2;
}

.etapes .qte .spin .spin-plus, .cadencier.lister .content tr form .spin .spin-plus{
    order: 3;
}

/**/

/**/

/*Menus*/

.niveau.liste.vignette li.item{
    margin-bottom: 20px;
}

.liste .row .item form, .multi_colonne .row .item form{
    border: none;
    border-radius: 20px;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
}

.liste .row .item form:hover, .multi_colonne .row .item form:hover{
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
}

.liste .row .item form img, .multi_colonne .row .item form img{
    border: none;
    border-radius: 20px;
}

.etape-menu a.passee .etape{
    background: var(--express_secondary);
}

.confirmation-menu .title, .menu .libelle, .table-choix .libelle, .etape-table .libelle .libelle, .client-profil, .ui-dialog .modalLink .module-haut{
    display: none;
}

.confirmation-menu .etape li{
    font-size: 1.5rem;
}

.confirmation-menu .etape li:before{
    content: "\2022";
    color: var(--express_primary);
    font-weight: bold;
    display: inline-block;
    width: 1em
}

.boxArticle .menu .etape a{
    display: none;
}

/**/

/*Edition de compte*/

.edition-compte .head .title, .nouveau-compte .head .title, .informations .title{
	font-size: 2em;
    color: var(--express_body);
}

/**/

/*Footer*/

footer .main-content{
    background: var(--express_body);
}

footer .main-content *,
footer .third a{
    color: var(--express_body);
}
footer .footer-paiements {
	height: 25px;	
}

footer .footer-widgets {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
    background: var(--express_body);
}

footer .footer-widgets .footer-column{
    gap: 10px;
}

footer .footer-widgets .btn__carte-cadeau{
    display: flex;
    gap: 1rem;
    align-items: center;
}

footer .footer-widgets .btn__carte-cadeau svg{
    width: 32px;
    height: auto;
    fill: var(--express_background);
}
/**/

/*Favoris*/

.cadencier.lister .content{
    tbody{
        display: flex;
        flex-direction: column;
        gap: 2rem;
    }
}

.cadencier.lister .content tr.even, .cadencier.lister .content tr.odd{
    display: flex;
    align-items: center;
    max-width: 1100px;
}

.cadencier.lister .content tr.even .info, .cadencier.lister .content tr.odd .info, .cadencier.lister .content tr.even td:last-of-type, .cadencier.lister .content tr.odd td:last-of-type{
    flex: 1;
}

.cadencier.lister .content tr.even td:last-of-type{
    padding: 0;
}

.cadencier.lister .content tr form{
    display: flex;
    gap: 20px;
    justify-content: flex-end;
    align-items: center;
}

.cadencier.lister .content tr form .acheter{
    order: 2;
    padding: 0;
}

.cadencier.lister .content tr form .spin{
    order: 1;
    width: auto;
    margin: 0;
}

/**/

/*Cross sell*/

.ui-dialog-content .module-cross-selling-article-associe .row{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.ui-dialog-content .module-cross-selling-article-associe .row:after, .ui-dialog-content .module-cross-selling-article-associe .row:before{
    display: none;
}

.ui-dialog-content .module-cross-selling-article-associe .row .item .boxArticle{
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    height: 100%;
}

.ui-dialog-content .module-cross-selling-article-associe .row .item .boxArticle .details{
    margin: 0;
    padding: 0;
    flex-grow: 1;
}

.ui-dialog-content .module-cross-selling-article-associe .row .item .spin{
    overflow: visible;
}

.ui-dialog-content .module-cross-selling-article-associe .row .item .acheter a{
    font-size: 1rem;
}

/**/

/*Mobile*/

@media(max-width: 991px){

    header button.toggle-nav {
        display: none !important;
    }

    header button.toggle-nav:after, header button.toggle-nav span, .glyphicon-align-justify:before{
        border-color: var(--express_items);
    }
    
    header .second .block-user{
        width: 100%;
    }

    .article > .row{
        flex-direction: column;
    }

    .article .droite .lib{
        padding: 0;
    }

    .article .droite .detail {
        display: flex;
        flex-direction: column;
        padding: 0;
    }

    .article .droite .detail .short-desc{
        order: 1;
    }

    .article .droite .detail form{
        order: 2;
        margin-bottom: 1em;
    }

    .article .droite .detail form .acheter a{
        width: 100%;
        text-align: center;
    }

    .article .droite .detail form .price{
        margin: 1em 0;
    }

    .article .droite .detail .description{
        order: 3;
    }

    .etapes .etape-panier{
        padding: 0;
    }

    .etapes .etape-panier thead th span{
        font-size: .8rem;
    }

    .etapes .etape-panier thead tr > th:first-of-type, .etapes .etape-panier tbody .img {
        display: none; /*Masque l'image du produit dans le panier sur mobile*/
    }

    .express.commande div.title .step, .express.etapes div.title .step{
        display: none;
    }

    .etapes .action.row{
        width: 70%;
        margin: auto;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 10px;
    }

    .etapes .action.row a{
        text-align: center;
        margin: 0;
    }

    .etapes .action.row .login{
        order: 1;
    }

    .etapes .action.row .anonyme{
        order: 2;
    }

    .etapes .action.row .continue{
        order: 3;
    }

    .choix-livraison-traiteur.client-b2b .choose-delivery{
        flex-direction: column-reverse;
    }

    .choix-livraison-traiteur.client-b2b .choose-delivery .column-left, .choix-livraison-traiteur.client-b2b .choose-delivery .column-right{
        width: 100%;
    }

    .commande .etape-expedition .adresse-retrait, .etapes .etape-expedition .adresse-retrait{
        width: 100%;
    }

    footer .main-content{
        padding: 0 !important;
    }

    footer .footer-boite-contact ul{
        align-items: center;
        gap: 1.5rem;
    }

    footer .footer-boite-contact ul li{
        flex-direction: column;
        align-items: center;
        gap: .5rem;
    }

    .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.ui-dialog-buttons, .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.fiche-produit, .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.points-vente-details, .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.choix-enlevement-express{
        width: 100% !important;
    }

    /*Favoris*/

    .cadencier .itemsDetails .details td.image{
        display: none;
    }
    
    .cadencier .itemsDetails .details .libelle, .cadencier .itemsDetails .details .pu, .cadencier .itemsDetails .details .date, .cadencier .itemsDetails .details .pu span{
        font-size: 1rem;
    }

    .cadencier .itemsDetails .details .libelle{
        background: none;
        padding-right: 0;
    }

    .cadencier .itemsDetails .details .hrefInfo{
        display: none;
    }

    .cadencier .itemsDetails table a.suppr{
        font-size: 1rem;
        margin-top: 1rem;
        display: block;
        color: red;
    }

    .cadencier.lister .content tr form{
        gap: 10px;
    }

    .cadencier .itemsDetails .details .spin, .cadencier .itemsDetails .details .ajout{
        font-size: 1rem;
    }

    .cadencier .itemsDetails .details table td.infos{
        max-width: 170px;
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 0;
    }

    /*Modales*/

    .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.ui-dialog-buttons, .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.fiche-produit, .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.points-vente-details, .ui-dialog.ui-widget.ui-widget-content.ui-corner-all.ui-front.ui-draggable.choix-enlevement-express{
        max-height: 500px;
        overflow: scroll;
    }

    .ui-dialog .ui-dialog-titlebar button, .ui-dialog .ui-dialog-titlebar-close{
        right: 0 !important;
    }

    .ui-dialog-content .module-cross-selling-article-associe .row{
        grid-template-columns: repeat(2, 1fr);
    }

    /**/
    }
    /**/

/**/

/*//SURCHARGE//*/

.autocomplete-suggestion strong{
    color: var(--express_body) !important;
}
