@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@100;200;300;400;500;600;700&family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap');

.vi-ver-option {
    background: #f9f9f9;
}

.vi-ver-sing .elementor-widget-image {
    position: absolute;
    top: -20px;
    left: -20px;
    background: #fff;
    height: 80px;
    width: 80px;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%);
}

.vi-ver-sing .elementor-widget-wrap {
    background: #fff;
    padding: 10px 30px 0 30px!important;
    color: #000;
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%);
    border-radius: 10px;
    max-width: 90%;
    margin: 0 auto 35px 0;
}

.vi-ver-sing img {
    max-width: 60%;
}

.vi-ver-sing h3 {
    font-size: 20px;
    max-width: 310px;
    margin: 10px 0 15px 40px;
}

.vi-ver-sing-1 .elementor-widget-text-editor {
    margin-bottom: 6px;
}

.vi-ver-sing .elementor-widget-wrap p {
    font-size: 14px;
}

.vi-ver-sing-1 .elementor-widget-wrap {
    max-width: 93%;
    padding-bottom: 30px!important;
}

/*******************/
.vi-pictos-cat {
    padding: 0 0 1em 0;
    z-index: 3;
}

.vi-pictos-cat .elementor-container {
    max-width: 1360px!important;
}

.vi-pictos-cat .elementor-widget-image {
    padding: 20px 20px 0 20px;
    width: 145px;
    height: 145px;
    display: flex;
    align-items: center;
    overflow: hidden;
    margin: 0;
}

.vi-pictos-cat .elementor-widget-text-editor {
    text-align: center;
}

.vi-pictos-cat .elementor-widget-text-editor a {
    text-decoration: none!important;
    text-transform: uppercase;
    font-weight: 800!important;
    color: #000!important;
    font-size: 14px;
}

.vi-pictos-cat .elementor-widget-image:before {
    content: "";
    width: 88px;
    height: 110px;
    background: url(../icons/villemin-logo-favicon-g.svg);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 54%;
    left: 50%;
    transform: translate(-50%,-50%);
    opacity: 0.1;
    z-index: -1;
}

.vi-pictos-cat a {
    transition: 0.3s;
    transform: scale(1);
}

.vi-pictos-cat a:hover {
    transform: scale(1.08);
}

.vi-pictos-cat img {
    max-width: 80%;
}

.vi-pictos-cat:before {
    content: "";
    width: 150%;
    height: 100%;
    position: absolute;
    background: #fff;
    border-radius: 100%;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 0;
}

.elementor-element.elementor-element-1289ab3.eldo.elementor-widget.elementor-widget-html {
    margin: 0;
}

.mainfoot .elementor-container:first-of-type {
    padding: 5px 0 20px 0!important;
}



footer {
    position: relative;
}

footer:before {
    content: "";
    width: 280%;
    height: 100%;
    position: absolute;
    background: #1D1D1D;
    border-radius: 100%;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 0;
}

.vi-partenaires .elementor-container,
.eldo-1 .elementor-container {
    z-index: 2;

}

/*.vi-partenaires:before {
    content: "";
    width: 250%;
    height: 100%;
    position: absolute;
    background: #F8F8F8;
    border-radius: 100%;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}

.eldo-1:before {
    content: "";
    width: 250%;
    height: 100%;
    position: absolute;
    background: #1d1d1d;
    border-radius: 100%;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}*/

.vi-nos-gammes:after {
    content: "";
    width: 210%;
    height: 100%;
    position: absolute;
    background: #4B4952;
    border-radius: 100%;
    bottom: -38px;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
}

/*******************/

p {
    font-size: 16px;
    line-height: 160%;
}
.vi-home-header .elementor-container {
    max-width: 1640px;
    width: 100%;
    margin: 0;
    padding: 0 20px 0 0;
    flex-direction: row-reverse;
}

.vi-home-header .elementor-container .elementor-column.coltxthead {
    max-width: 590px;
    width: 100%;
    padding-left: 40px!important;
}
.vi-home-header .elementor-container .elementor-column.colimghead {
    width: 100%!important;
    height: 77vh;
}

.vi-home-header .elementor-container .elementor-column.colimghead .elementor-widget-wrap {
    padding: 0!important;
}

.vi-home-header .elementor-container .elementor-column.colimghead .elementor-widget-wrap>.elementor-element,
.vi-home-header .elementor-container .elementor-column.colimghead .elementor-widget-container {
    height: 100%;
    position: relative;
}

.vi-home-header:before {
    content: "";
    width: 425px;
    height: 540px;
    background-image: url(../icons/villemin-v-favicon.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: -210px;
    top: 50%;
    transform: translateY(-50%);
}

.vi-home-header .elementor-container .elementor-column.colimghead .elementor-widget-wrap>.elementor-element:after {
    content: "";
    width: inherit;
    height: 100%;
    background-image: url(../icons/before-header.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 1px;
    top: 1px;
    transform: scale(-1);
}

.vi-home-header .elementor-container .elementor-column.colimghead .elementor-widget-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.vi-fef {
    margin: 2em 0 5px 0!important;
}

.vi-fef p {
    margin: 0;
}

.vi-home-header h1 strong {
    font-size: calc(28px + (40 - 28) * ((100vw - 400px) / (1920 - 400)));
    line-height: 100%;
    font-weight: bold;
    margin: 0 0 20px 0;
    max-width: 450px;
    color: #000;
    display: block;
}
.vi-home-header h1 {
    font-size: 20px;
    line-height: 110%;
    color: #C21F22;
    margin-top: 0;
}

.vi-home-header p {
    max-width: 650px;
    font-size: calc(14px + (16 - 14) * ((100vw - 400px) / (1920 - 400)));
    line-height: 150%;
}

.vi-chevron .elementor-widget-container {
    width: 52px;
    height: 52px;
    border: 2px solid #000;
    border-radius: 100%;
    margin: 2em auto;
    display: flex;
    align-items: center;
    justify-content: center;
}

.vi-chevron img {
    width: 30px;
    height: 16px;
    margin-top: 4px;
}

.vi-vp {
    padding: 1em 0 0 0;
    margin-top: -100px;
    z-index: 2;
}

.vi-vp .elementor-widget-container {
    position: relative;
    max-width: 355px;
    margin: 0 auto;
}

.vi-vp .elementor-element.elementor-widget-text-editor {
    max-width: 93%;
}

.vi-vp .elementor-widget-container:before {
    content: "";
    width: 60px;
    height: 45px;
    background: #C21F22;
    display: block;
    position: absolute;
    top: -5px;
    left: -5px;
}

.vi-vp .elementor-widget-container:after {
    content: "";
    width: 60px;
    height: 45px;
    background: #C21F22;
    display: block;
    position: absolute;
    bottom: -5px;
    right: -5px;
    z-index: -1;
}

.vi-vp .elementor-column .elementor-widget-wrap {
    justify-content: center;
}

.vi-vp p {
    text-align: center;
    position: relative;
    font-size: 16px;
    font-weight: bold;
    background: #fff;
    line-height: 130%;
    color: #000;
    margin: 0 auto 40px auto;
    padding: 10px 15px 0 15px;
    min-height: 150px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 355px;
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%);
}

.vi-vp .elementor-column:first-child p:after {
    content: "";
    width: 208px;
    height: 167px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-1.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 94%;
    top: 0%;
    margin: 0;
    transform: rotate(-10deg);
    z-index: -1;
}

.vi-vp .elementor-column:nth-child(2) p:after {
    content: "";
    width: 208px;
    height: 167px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-1.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 95%;
    top: 1%;
    margin: 0;
    transform: rotate(15deg) scaleX(-1);
    z-index: -1;
}

.vi-vp p:before {
    content: "";
    width: 50px;
    height: 50px;
    background: url(../icons/villemin-logo-favicon-g.svg) #fff;
    background-size: 24px;
    border-radius: 100%;
    background-position: center;
    background-repeat: no-repeat;
    display: block;
    margin: 15px auto 10px auto;
    position: absolute;
    top: -7%;
    left: 50%;
    transform: translate(-50%,-50%);
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%);
}


.vi-actu-en-avant {
    background: #f9f9f9;
    padding: 1em 0 2em 0;
}

.vi-actu-en-avant h2:after,
.vi-partenaires h2:after {
    content: "";
    width: 80px;
    height: 3px;
    background-color: #C21F22;
    display: block;
    margin: 10px auto;
}

.vi-actu-en-avant .vil-swiperinit.swiper-horizontal {
    overflow: hidden;
    min-height: 450px;
    margin-left: -15px;
}

.vi-actu-en-avant .swiper-slide {
    width: 28%;
    padding: 0 15px;
}

.vi-actu-en-avant .swiper-slide:first-child {
    padding: 0 15px 0 0;
}

.vi-actu-en-avant .swiper-slide a {
    /*max-width: 90%;*/
    overflow: hidden;
    display: block;
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%);
    border-radius: 10px;
}

.vi-actu-en-avant .service-imgslg {
    height: 185px;
    overflow: hidden;
    position: relative;
}

.inner-sgl {
    padding: 20px;
    background: #fff;
}

.inner-sgl h3 {
    margin-top: 0;
    font-size: 18px;
    line-height: 115%;
    font-weight: bold;
    color: #000;
    min-height: 41px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.inner-sgl p {
    font-size: 14px;
    line-height: 160%;
    color: #000;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.swiper-button-prev.prev-sil {
    /*background: #4B4952;*/
    width: 60px;
    height: 40px;
    top: -18px;
    left: 0;
}

.swiper-button-prev.prev-sil:after {
    content: "";
    width: 48px;
    height: 23px;
    background-image: url(../icons/vil-arrow-r.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.swiper-button-prev,
.swiper-button-next {
    background-image: inherit;
}

.swiper-button-next.next-sil {
    /*background: #4B4952;*/
    width: 60px;
    height: 40px;
    top: -18px;
    right: 0;
}

.swiper-button-next.next-sil:after {
    content: "";
    width: 48px;
    height: 23px;
    background-image: url(../icons/vil-arrow-r.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    top: 25%;
    left: 25%;
    transform: rotate(180deg) translate(7%,0%)!important;
}

.elementor-button {
    transition: 0.3s;
}

.elementor-button:hover {
    background: #1D1D1D;
}

.elementor-button:hover .elementor-button-text:after, .vil-cta:hover:after {
    content: "";
    width: 6px;
    height: 12px;
    background: url(../icons/vil-chevron.svg) no-repeat;
    background-size: contain;
    position: relative;
    display: inline-block;
    margin: 2px 0 0 15px;
}

.vi-actu-en-avant p.vil-cta {
    background-color: #C21F22;
    border-radius: 0;
    font-weight: bold;
    font-size: 14px;
    padding: 10px 30px;
    color: #fff;
    text-align: center;
    margin: 0 auto;
    width: 210px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.3s;
}

.vi-actu-en-avant p.vil-cta:hover {
    background: #1D1D1D;
}

.vi-pcv-single .elementor-container {
    position: relative;
    background: #fff;
}

.vi-actu-en-avant .service-imgslg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.vil-3-col {
    margin: 4em auto 3em auto;
}

.vil-3-col h2:after {
    margin: 12px auto;
}

.vi-nos-gammes {
    background: #4B4952;
    padding: 3em 0 0 0;
    color: #fff;
}
.home .vi-nos-gammes h2 {
    max-width: 460px;
    margin-bottom: 20px;
}

.vi-nos-gammes h2:after {
    display: none!important;
}

.vi-gamme-head {
    margin: 0 0 15px 0;
}

.vi-nos-gammes .elementor-col-33 .elementor-widget-image .elementor-widget-container {
    overflow: hidden;
    height: 200px;

}

.vi-nos-gammes .elementor-col-33 .elementor-widget-image .elementor-widget-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;

}

.vi-nos-gammes p {
    text-align: left!important;
    margin: 0 auto 10px auto;
}
.vi-nos-gammes .elementor-col-33,
.vil-3-col .elementor-col-33,
.vil-3-col .elementor-col-25 {
    padding: 0 15px;
    margin-bottom: 30px;
}

.eldo-1 {
    margin-bottom: 0!important;
    margin-top: 0!important;
    background: #1d1d1d;
    padding: 0 0 30px 0;
}

.eldo-1 .sectioneldo .colavis .elementor-element-populated {
    padding-left: 20px;
}

.eldo-1 .sectioneldo .colavis .avissgl p:last-of-type {
    font-size: 13px!important;
    line-height: 150%!important;
}

.headeldo h2 {
    color: #fff;
    margin-bottom: 5px;
}

.eldo-1 h4 {
    font-size: 14px!important;
}

.headeldo a.elementor-button {
    background: transparent;
    color: #fff;
    padding: 0;
    font-size: 14px;
    display: flex;
    align-items: center;
}

@media (min-width: 768px) {
    .vil-3-col .elementor-column.elementor-col-16,
    .vi-nos-gammes .elementor-column.elementor-col-16 {
        width: 31.33%;
        margin: 1%;
    }
}

.vi-nos-gammes .elementor-col-33 .elementor-widget-wrap,
.vi-nos-gammes .elementor-col-16 .elementor-widget-wrap,
.vil-3-col .elementor-col-33 .elementor-widget-wrap,
.vil-3-col .elementor-col-25 .elementor-widget-wrap,
.vil-3-col .elementor-col-16 .elementor-widget-wrap {
    background: #fff;
    padding: 0 ;
    color: #000;
    box-shadow: 0 1px 5px 4px rgba(2, 2, 2, .06);
    border-radius: 10px;
    overflow: hidden;
}

.vi-nos-gammes .elementor-col-33 .elementor-widget-wrap img,
.vi-nos-gammes .elementor-col-16 .elementor-widget-wrap img,
.vil-3-col .elementor-col-33 .elementor-widget-wrap img,
.vil-3-col .elementor-col-25 .elementor-widget-wrap img,
.vil-3-col .elementor-col-16 .elementor-widget-wrap img {
    width: 100%;
}

.vil-3-col .elementor-container.elementor-column-gap-default,
.vi-nos-gammes .elementor-container.elementor-column-gap-default {
    flex-wrap: wrap;
}

.vi-nos-gammes .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor,
.vi-nos-gammes .elementor-col-16 .elementor-widget-wrap .elementor-widget-text-editor,
.vil-3-col .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor,
.vil-3-col .elementor-col-25 .elementor-widget-wrap .elementor-widget-text-editor,
.vil-3-col .elementor-col-16 .elementor-widget-wrap .elementor-widget-text-editor {
    padding: 10px 20px 10px 20px;
    margin-bottom: 0;
    min-height: 171px;
}

.vil-3-col .elementor-col-16 .elementor-widget-wrap .elementor-widget-text-editor p {
    font-size: 14px;
}


.vil-3-col .elementor-col-25 .elementor-widget-wrap .elementor-widget-text-editor p {
    font-size: 13px;
}

.vi-nos-gammes .elementor-widget-image {
    margin: 0;
}

.vil-3-col .elementor-widget-image {
    margin: 0;
}

.vi-nos-gammes h3,
.vil-3-col h3 {
    font-size: 18px;
    font-weight: bold;
    line-height: 110%;
    text-align: center;
    margin: 0 0 10px 0;
}

.vi-nos-gammes h3 strong,
.vil-3-col h3 strong {
    display: block;
    text-transform: uppercase;
    color: #C21F22;
    font-size: 18px;
    line-height: 120%;
}

.vi-nos-gammes .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor p,
.vil-3-col .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor p {
    font-size: 14px;
}


.vi-nos-gammes:before {
    content: "";
    width: 410px;
    height: 350px;
    background-image: url(../icons/villemin-v-favicon-w.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: -25%;
    top: 50%;
    transform: translate(-50%, -50%);
    opacity: 0.05;
}

.home .vi-gamme-single-head {
    background: #C21F22;
    color: #fff;
    padding: 15px 15px 5px 15px!important;
}

.home .vi-nos-gammes .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor .elementor-widget-container {
    position: relative;
}

/*.home .vi-gamme-single-head:before {
    content: "";
    width: 180%;
    height: 100%;
    position: absolute;
    background: #C21F22;
    border-radius: 100%;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 0;
}*/

/*.home .vi-nos-gammes .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor:last-child:before {
    content: "";
    width: 180%;
    height: 100%;
    position: absolute;
    background: #fff;
    border-radius: 100%;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 0;
}*/

.vi-vp:before {
    content: "";
    width: 150%;
    height: 100%;
    position: absolute;
    background: #fff;
    border-radius: 100%;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 0;
}

.home .vi-gamme-single-head .elementor-widget-container {
    display: flex;
    align-items: center;
    z-index: 1;
    position: relative;
}

.home .vi-gamme-single-head a,
.home .vi-gamme-single-head strong {
    color: #fff!important;
}

.home .vi-gamme-single-head h3 {
    text-align: left;
    font-weight: 300;
    width: 72%;
}

.home .vi-gamme-single-head p {
    text-align: right!important;
    margin: 0;
    width: 28%;
}

.home .vi-gamme-single-head a {
    text-decoration: none!important;
}

.home .vi-gamme-single-head a:after {
    content: "";
    width: 6px;
    height: 12px;
    background: url(../icons/vil-chevron.svg) no-repeat;
    background-size: contain;
    position: relative;
    display: inline-block;
    margin: 0 0 -2px 6px;
}

.home .vi-nos-gammes .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor{
    min-height: inherit;
}

.vi-nos-gammes h2 {
    font-size: 32px!important;
    line-height: 120%;
}

.vi-pcv-single {
    max-width: 375px;
    padding: 0!important;
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 8%);
    margin: 0 0 4em 0;
    background: #fff;
    border-radius: 10px;
}

.vi-pcv-single .elementor-widget-wrap,
.vi-pcv-single .elementor-container {
    padding: 0!important;
}

.vi-pcv-title {
    background: #C21F22;
}

.vi-pcv-title h3 {
    color: #fff;
    text-align: center;
    text-transform: uppercase;
    font-weight: bold;
    line-height: 130%;
    font-size: 18px;
    margin: 12px 20px;
}

.vi-pcv-single p {
    font-size: 14px;
    text-align: center;
    padding: 0 20px;
}

.vi-pcv-single:after {
    content: "";
    width: 29px;
    height: 37px;
    background-image: url(../icons/villemin-logo-favicon-g.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    margin: 0 auto 20px auto;
}

.vi-pcv .elementor-column.elementor-col-50:first-child {
    margin-right: 9em;
}

.vi-pcv-single.reveal-3 {
    z-index: 3;
}

.vi-pcv-single.reveal-4 {
    z-index: 4;
}

.vi-pcv-single.reveal-2 {
    z-index: 2;
}

.vi-pcv .elementor-column.elementor-col-50:first-last {
    margin-left: 9em;
}

.vi-pcv .elementor-column.elementor-col-50:first-child .elementor-widget-wrap {
    justify-content: end;
}

.vi-pcv .elementor-column.elementor-col-50:last-child {
    margin-top: 9em;
}

.vi-pcv:before {
    content: "";
    width: 594px;
    height: 387px;
    background-image: url(../icons/villemin-fenetre-illu.svg);
    background-size: contain;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: -14%;
    top: 4%;
}

.vi-pcv:after {
    content: "";
    width: 902px;
    height: 600px;
    background-image: url(../icons/villemin-pcv-after.svg);
    background-size: contain;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: -22%;
    top: 23%;
    z-index: -1;
}

.vi-pcv .elementor-column.elementor-col-50:first-child .vi-pcv-single:first-child:before {
    content: "";
    width: 330px;
    height: 291px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-1.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 86%;
    top: -14%;
    margin: 0;
}

.vi-pcv .elementor-column.elementor-col-50:last-child .vi-pcv-single:first-child:before {
    content: "";
    width: 330px;
    height: 291px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-2.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: 75%;
    top: 30%;
    margin: 0;
    z-index: -1;
}

.vi-pcv .elementor-column.elementor-col-50:first-child .vi-pcv-single:last-child:before {
    content: "";
    width: 330px;
    height: 291px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-3.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 77%;
    top: 34%;
    margin: 0;
    z-index: -1;
}
.vi-partenaires {
    background:#F8F8F8;
    padding: 2em 0;
}

.vi-partenaires section {
    max-width: 1090px;
    margin: 0 auto;
}
.vi-partenaires section img {
    vertical-align: middle;
    display: inline-block;
    max-width: 100%;
    width: auto;
    max-height: 80px;
    height: auto;
}

.vi-partenaires p {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    text-align: center;
    font-size: 14px;
}

.vil-prefoot {
    background: #F9F9F9;
    padding: 30px 0 0 0;
}

.vil-prefoot .elementor-container {
    max-width: 800px!important;
    width: 100%;
    margin: 0 auto;
}

.vil-prefoot p {
    font-size: 16px;
    text-transform: uppercase;
    text-align: center;
}

.vil-prefoot p strong{
    display: block;
}

/*********************
Pergolas
*********************/

.vil-header .elementor-container {
     max-width: 870px!important;
 }

.vil-header {
     text-align: center;
     padding: 5em 0;
}

.vil-header h1 {
    font-size: 40px;
    line-height: 120%;
    color: #fff;
    margin-bottom: 10px;
    font-weight: bold;
}

 .vil-header p {
     font-size: 16px;
     line-height: 140%;
     font-weight: 400;
     color: #fff;
 }

.vil-av {
    margin: 3em 0;
}

.vil-av .elementor-container {
    max-width: 1360px!important;
}

.home .vil-av h2 {
    max-width: 360px!important;
    line-height: 120%;
}
.vil-av .elementor-container .elementor-column:last-child .elementor-widget-wrap>.elementor-element {
    position: relative;
    overflow: hidden;
}

.vil-av .elementor-container .elementor-column:last-child .elementor-widget-wrap>.elementor-element:after {
    content: "";
    width: 200px;
    height: 137%;
    background: #fff;
    background-size: contain!important;
    background-repeat: no-repeat;
    border-radius: 100%;
    display: block;
    position: absolute;
    left: -20%;
    top: 50%;
    transform: translateY(-50%);
}
.vil-av .elementor-container .elementor-column:last-child .elementor-widget-wrap>.elementor-element img {
    width: 100%;
}

.vil-conseils {
    text-align: center;
    padding: 3em 20px!important;
    color: #fff;
}

.vil-conseils > .elementor-container{
    max-width: 1050px!important;
    background-color: rgba(255,255,255,.15);
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
}

.vil-conseils .elementor-container section {
    background-color: #C21F22;
    border-radius: 5px;
    margin-top: 30px;
}

.vil-conseils .elementor-column-gap-default>.elementor-column>.elementor-element-populated {
    max-width: 950px;
    margin: 1em auto 2em auto;
    padding: 0 10px 10px 10px;
}

.vil-conseils section .elementor-column-gap-default>.elementor-column>.elementor-element-populated {
    margin: 0 auto;
}

.vil-conseils-1:before {
    content: "";
    width: 220px;
    height: 52px;
    background-image: url(../icons/vil-before-conseils-1.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 13%;
    top: 0;
    transform: translate(-50%,-50%);
    z-index: 1;
}

.vil-conseils .elementor-container:before {
    content: "";
    width: 110px;
    height: 8px;
    background-image: url(../icons/vil-before-conseils.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
}

.vil-conseils section .elementor-container:before {
    content: "";
    width: 73px;
    height: 75px;
    background-image: url(../icons/vil-before-conseils-chauffage.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 6%;
    top: 3%;
    transform: translateY(-50%);
}

.vil-conseils h2:after,
.vil-besoin-devis h2:after,
.vil-part h2:after {
    content: "";
    width: 80px;
    height: 3px;
    background-color: #C21F22;
    display: block;
    margin: 12px auto 0 auto;
}

.vil-part {
    text-align: center;
    padding: 1em 0 2em 0;
}

.vil-besoin-devis {
    text-align: center;
    padding: 1em 0 4em 0;
}

.vil-part {
    background: #f9f9f9;
}

.vil-part p {
    max-width: 725px;
    margin: 0 auto;
}

.vil-types {
    margin: 3em auto;
}

.vil-types section:first-child {
    max-width: 1270px!important;
    margin: 0 auto;
    position: absolute;
    z-index: 1;
}

.vil-types section:first-child .elementor-column-gap-default>.elementor-column>.elementor-element-populated {
    padding: 0;
}

.vil-types section:first-child h2 {
    background: #fff;
    display: inline-block;
    padding: 10px 10px 0 10px;
    margin: 0;
}


.vil-types section:last-child {
    max-width: 1070px!important;
    margin: 0 auto;
    z-index: 0;
}
.vil-types .elementor-column.elementor-col-50,
.vil-types .elementor-column.elementor-col-33 {
    min-height: 680px;
    margin: 0 0.2%;
    width: 49.6%;
    height: 100%;
}

.vil-types .elementor-col-50 .elementor-element-populated,
.vil-types .elementor-col-33 .elementor-element-populated {
    color: #fff;
    padding: 20px;
    position: relative;
    z-index: 2;
    min-height: 230px;
}

.vil-types .elementor-col-50 p,
.vil-types .elementor-col-33 p {
    color: #fff;
    font-size: 15px;
}

.vil-types h3 {
    font-size: 24px;
    line-height: 115%;
    color: #fff;
    font-weight: 400;
    margin: 0;
}

.vil-types .elementor-column.elementor-col-50:before,
.vil-types .elementor-column.elementor-col-33:before {
    content: "";
    background: black;
    height: 100%;
    width: 100%;
    position: absolute;
    z-index: 1;
    opacity: 0.5;
}

.vil-partenaires-logos .elementor-column {
    max-width: 350px;
}

.vil-partenaires-logos .elementor-container.elementor-column-gap-default {
    display: flex;
    align-items: center;
    justify-content: center;
}

.vil-breadcumb .elementor-container {
    max-width: 1360px!important;
    font-size: 14px;
}

.vil-breadcumb .elementor-container a {
    color: #000;
    font-weight: bold;
}

.popupeclient .innerpopup form label,
input#input-title {
    max-width: 100%;
}

/********************
HISTOIRE
********************/

.vil-hist-text {
    max-width: 300px;
    padding: 0!important;
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 8%);
    margin: 0;
    background: #fff;
}
.vil-hist-text h2 {
    background: #C21F22;
    color: #fff;
    text-align: center;
    text-transform: uppercase;
    font-weight: bold;
    line-height: 130%;
    font-size: 18px;
    padding: 12px 20px;
    margin: 0 0 20px 0;
}

.vil-hist-text h2:after {
    display: none;
}

.vil-hist-text p {
    font-size: 14px;
    text-align: center;
    padding: 0 20px;
    margin-bottom: 15px;
}

.vil-hist-text p:after {
    content: "";
    width: 29px;
    height: 37px;
    background-image: url(../icons/villemin-logo-favicon-g.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    margin: 10px auto 20px auto;
}

.vil-sec-hist .elementor-column {
    width: 50%!important;
}

.vil-sec-hist .elementor-column:nth-child(even) {
    margin-top: 15em;
}

.vil-sec-hist .elementor-container {
    display: flex;
    flex-wrap: wrap;
}

.vil-sec-hist .elementor-column:nth-child(odd) .elementor-widget-wrap .vil-hist-text {
    margin-left: auto;
}

.vil-sec-hist .elementor-column:nth-child(odd) .elementor-widget-wrap {
    display: flex;
    justify-content: end;
    padding: 0 13em 0 0;
    height: fit-content;
}

.vil-sec-hist .elementor-column:nth-child(even) .elementor-widget-wrap {
    display: flex;
    justify-content: start;
    padding: 0 0 0 13em;
    height: fit-content;
}

.vil-sec-hist .elementor-column:nth-child(odd) {
    margin-top: 2em;
}

.vil-sec-hist .elementor-column .vil-hist-anne {
    position: absolute;
    width: 110px!important;
    height: 110px;
    background: #4B4952;
    display: flex;
    border-radius: 100%;
    align-items: center;
    justify-content: center;
}

.vil-sec-hist .elementor-column:nth-child(odd) .vil-hist-anne {
    right: 0;
    top: 50%;
    transform: translate(50%,-50%);
}

.vil-sec-hist .elementor-column:nth-child(even) .vil-hist-anne {
    left: 0;
    top: 50%;
    transform: translate(-50%,-50%);
}

.vil-hist-anne p {
    margin: 0;
    color: #fff;
    font-weight: bold;
    font-size: 29px;
}

.vil-sec-hist .elementor-column .elementor-widget-wrap {
    position: relative;
}

.vil-sec-hist .elementor-column:nth-child(odd) .elementor-widget-wrap:before {
    content: "";
    width: 228px;
    height: 174px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-1.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: 7px;
    top: 0;
    margin: 0;
    transform: rotate(-26deg);
}

.vil-sec-hist .elementor-column:nth-child(even) .elementor-widget-wrap:before {
    content: "";
    width: 228px;
    height: 174px;
    background-image: url(/wp-content/themes/tothemoon/assets/icons/vil-before-trait-1.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: 7px;
    top: 0;
    margin: 0;
    transform: rotate(-26deg);
}

.vil-sec-hist-global:before {
    content: "";
    width: 837px;
    height: 500px;
    background-image: url(../icons/villemin-maison-illu.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: -4%;
    top: 5%;
    -moz-transform: matrix(-1, 0, 0, 1, 0, 0);
    -webkit-transform: matrix(-1, 0, 0, 1, 0, 0);
    -o-transform: matrix(-1, 0, 0, 1, 0, 0);
}

.vil-sec-hist-global:after {
    content: "";
    width: 989px;
    height: 657px;
    background-image: url(../icons/villemin-pcv-after.svg);
    background-size: contain;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: -10%;
    top: 23%;
    z-index: -1;
}

.vil-sec-hist-global > .elementor-container:before {
    content: "";
    width: 594px;
    height: 387px;
    background-image: url(../icons/villemin-fenetre-illu.svg);
    background-size: contain;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    left: -23%;
    top: 53%;
}

.vil-sec-hist-global > .elementor-container:after {
    content: "";
    width: 694px;
    height: 452px;
    background-image: url(../icons/villemin-portail-illu.svg);
    background-size: contain;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: -21%;
    top: 79%;
    z-index: -1;
}

.vil-sec-hist-global > .elementor-container .elementor-col-100:before {
    content: "";
    width: 2px;
    height: 90%;
    background: #C21F22;
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    z-index: -1;
}

.vil-sec-hist-global {
    margin: 3em auto;
}

.elementor-tab-title.elementor-active {
    background: #C21F22;
    color: #fff;
    border-width: 0!important;
}

.elementor-widget-tabs .elementor-tab-desktop-title {
    padding: 13px 35px!important;
}

.elementor-tab-content {
    padding: 30px 0 20px 0!important;
    border: inherit!important;
}

.global-tab {
    display: flex!important;
    flex-wrap: wrap;
}

.global-tab .single-co {
    width: 50%;
    margin: 0 0 20px 0;
}

.single-co strong {
    display: flex;
    font-size: 20px;
}

.single-co a, .single-co span {
    color: #000;
    font-size: 16px;
    text-decoration: none;
}

span.loc strong {
    font-size: 16px;
    display: inline-block;
}

.elementor-tab-title {
    border: 1px solid #dedede!important;
}

.elementor-widget-tabs .elementor-tab-content,
.elementor-widget-tabs .elementor-tab-title:after,
.elementor-widget-tabs .elementor-tab-title:before,
.elementor-widget-tabs .elementor-tabs-content-wrapper {
    border: 0 #d4d4d4!important;
}

.vi-mail strong:before {
    content: "";
    width: 25px;
    height: 25px;
    background-image: url(../icons/vil-icon-mail.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: inline-block;
    margin: 0 5px 0 0;
}

.vi-tel strong:before {
     content: "";
     width: 25px;
     height: 25px;
     background-image: url(../icons/vil-icon-phone.svg);
     background-size: contain!important;
     background-repeat: no-repeat;
     display: inline-block;
     margin: 0 5px 0 0;
 }

.vi-loc > strong:before {
    content: "";
    width: 26px;
    height: 26px;
    background-image: url(../icons/vil-icon-location.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: inline-block;
    margin: 0 5px 0 0;
}

.vi-horaire > strong:before {
    content: "";
    width: 25px;
    height: 25px;
    background-image: url(../icons/vil-icon-horaires.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: inline-block;
    margin: 0 5px 0 0;
}

.vil-contact .elementor-column:last-child {
    padding: 30px 0 0 3em;
    max-width: 675px;
}

.vil-contact .elementor-column:last-child .vil-breadcumb * {
    padding: 0!important;

}

.vil-contact h1 {
    font-size: 25px;
    margin: 15px 0 15px 0;
}

.vil-contact:before {
    content: "";
    width: 425px;
    height: 540px;
    background-image: url(../icons/villemin-v-favicon.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translate(50%, -50%);
}

.vil-contact .elementor-container.elementor-column-gap-default {
    max-width: 100%!important;
    padding: 0!important;
}

.vil-map .elementor-widget-wrap.elementor-element-populated {
    padding: 0!important;
}

body .vil-map iframe {
    height: calc(130vh - 90px)!important;
}

form .vil-inline-form {
    margin-bottom: 15px;
}

.vil-inline-form label.col-md-6:first-child {
    padding-right: 10px;
}

.row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.col-md-6 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
}

.col-md-12 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
}

.vil-header p a {
    color: #fff!important;
}

form .vil-inline-form input:not([type=submit]),
form .vil-inline-form textarea,
select.wpcf7-form-control.wpcf7-select {
    border-radius: 0;
    border: 1px solid black;
    padding: 10px 15px;
    margin: 0;
    width: 100%;
}

form .vil-inline-form label {
    width: 100%;
    font-size: 14px;
}

form .vil-inline-form .contact-acceptance {
    margin-bottom: 5px;
}

form .vil-inline-form .contact-acceptance a {
    text-decoration: underline;
    font-weight: bold;
    color: #000;
    font-size: 14px;
}

.wpcf7-submit {
    background-color: #C21F22 !important;
    font-weight: bold !important;
    font-size: 16px;
    padding: 15px 20px;
    display: table;
    border-radius: 0;
    color: white;
    text-align: center;
    border: 0;
    -webkit-transition: .4s;
    transition: .4s;
}

.wpcf7-acceptance > span > label > input {
    width: 30px !important;
    margin: 6px 7px 0 0 !important;
}

.wpcf7-acceptance > span > label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

span.wpcf7-form-control.wpcf7-acceptance span.wpcf7-list-item {
    margin: 7px 0 0 0;
}

.mainfoot .footliensutiles ul li {
    display: inline-block;
}

.eldo iframe {
    width: 120px!important;
    bottom: 10px!important;
    right: 10px!important;
}

.eldo-1 iframe {
    height: 423px;
    overflow: hidden!important;
}

.vil-header:before {
    content: "";
    background: black;
    height: 100%;
    width: 100%;
    position: absolute;
    z-index: 1;
    opacity: 0.62;
    top: 0;
    left: 0;
}

.vil-header .elementor-container {
    z-index: 1;
}

.vil-conseils:after {
    content: "";
    background: black;
    height: 100%;
    width: 100%;
    position: absolute;
    z-index: 0;
    opacity: 0.4;
    top: 0;
    left: 0;
}

.vi-partenaires section .elementor-column {
    max-width: 150px;
}

.vi-partenaires section .elementor-container {
    justify-content: center;
}

.vil-conseils .elementor-container {
    z-index: 1;
}

.vil-certifs .elementor-widget-container {
    display: flex!important;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.vil-certifs .elementor-widget-container a {
    padding: 10px;
    display: flex;
    align-items: center;
    height: auto;
}

.vil-certifs img {
    vertical-align: middle;
    display: inline-block;
    max-width: 100px;
    width: auto;
    max-height: 80px;
    height: auto;
    filter: brightness(2.5) grayscale(1);
}

.error404-content {
    text-align: center;
    padding: 9em 0 6em 0;
}

.error404-content {
    color:#4b4a53;
    margin: 0 0 1em 0;
}

.error404-content img {
    max-width: 900px;
    width: 100%;
}

.error404-content p {
    max-width: 600px;
    width: 100%;
    margin: 1em auto 3em auto;
}

.error404-content a {
    background-color: #C21F22;
    border-radius: 0;
    font-weight: bold;
    font-size: 16px;
    color: #fff;
    padding: 15px 30px;
    text-decoration: none;
}

.copyrightfoot a {
    color: #fff!important;
    text-decoration: none!important;
}

.single .elementor-widget-container ul {
    padding: 0 0 0 18px;
}

.elementor-button-text {
    display: flex;
    align-items: center;
    justify-content: center;
}

.elementor-button-text:after,
.vil-cta:after {
    content: "";
    width: 6px;
    height: 12px;
    background: url(../icons/vil-chevron.svg) no-repeat;
    background-size: contain;
    position: relative;
    display: inline-block;
    margin: 2px 0 0 9px;
    transition: 0.3s;
}

.headeldo a.elementor-button:after {
    content: "";
    width: 6px;
    height: 12px;
    background: url(../icons/vil-chevron.svg) no-repeat;
    background-size: contain;
    position: relative;
    display: inline-block;
    margin: 1px 0 0 9px;
}
/** Changer dans style Fab **/

.eldo-1 .headeldo > div {
    align-items: end!important;
}

.eldo-1 .sectioneldo .colavis .avissgl {
    box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%)!important;
    -webkit-box-shadow: 0 1px 5px 4px rgb(2 2 2 / 4%)!important;
    padding: 20px!important;
    border-radius: 10px;
    background: #3d3d3d;
    color: #fff;
}

h2, h2.elementor-heading-title {
    font-weight: 800!important;
}

.eldo-1 .sectioneldo .colgbleldo {
    border-radius: 10px;
}

.eldo-1 .sectioneldo .colavis .avissgl h4 {
    margin: 0 0 10px!important;
}

.eldo-1 .sectioneldo .colgbleldo:after {
    width: 50%!important;
    height: 39px!important;
}

.vi-home-header .vi-head-vid .elementor-container,
.vi-head-vid,
.vi-home-header .vi-head-vid .elementor-container .elementor-column:last-child .elementor-widget-wrap>.elementor-element,
.vi-home-header .vi-head-vid .elementor-column-gap-default>.elementor-column>.elementor-element-populated,
.vi-head-vid .elementor-element {
    height: 100%;
}

/********************
Test Header
********************/

.vi-home-header-1.vi-home-header .elementor-container .elementor-column.coltxthead {
    max-width: 100%;
    width: 100%;
    padding: 0!important;
}

.vi-home-header-1.vi-home-header .elementor-container .elementor-column.colimghead .elementor-widget-wrap>.elementor-element:after {
    display: none;
}
.vi-home-header-1.vi-home-header .elementor-container {
    max-width: 100%!important;
    width: 100%;
    margin: 0;
    padding: 0!important;
    flex-direction: row-reverse;
}

.vi-home-header .elementor-widget-container {
    height: 100%;
}

.vi-home-header-1 h1 strong {
    font-size: calc(28px + (40 - 28) * ((100vw - 400px) / (1920 - 400)));
    line-height: 100%;
    font-weight: bold;
    margin: 0 0 20px 0;
    max-width: 450px;
    color: #fff;
    display: block;
}

.vi-home-header-1 h1 {
    font-size: 20px;
    line-height: 110%;
    color: #fff;
    margin: 0;
}

.vi-head-txt {
    position: absolute;
    max-width: 580px;
    left: 15%;
    padding: 30px;
    background-color: rgba(255,255,255,.15);
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
    z-index: 2;
    border-left: 4px solid #fff;
    border-radius: 0 30px 30px 0;
}

.vi-head-vid .elementor-element,
.vi-head-vid .elementor-widget-wrap,
.vi-home-header-1 .elementor-widget-wrap {
    padding: 0!important;

}

.vi-home-header-1:after {
    content: "";
    width: 425px;
    height: 540px;
    background-image: url(../icons/villemin-v-favicon-w.svg);
    background-size: contain!important;
    background-repeat: no-repeat;
    display: block;
    position: absolute;
    right: -210px;
    top: 50%;
    opacity: 0.4!important;
    transform: translateY(-50%);
}

.vi-home-header-1 .vi-fef {
    margin: 1em 0 5px 0!important;
    max-width: 210px;
}

.vi-head-txt .elementor-element p {
    color: #fff;
    font-size: 14px!important;
}
.vi-head-vid {
    height: 85vh;
    min-height: 610px;
    overflow: hidden;
}

.vil-headnav .navheadcol .elementor-element-populated .navcollink ul a {
    font-size: 14px;
}

.coltopmenu ul a {
    color: #dedede!important;
    font-size: 12px!important;
    font-weight: 400!important;
    position: relative;
}

.coltopmenu ul a:after {
    content: "";
    width: 1px;
    height: 50%;
    background: #aaa!important;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

.popupeclient .innerpopup form > div.selectize-control.selectsearch.single {
    padding: 0!important;
}

/*************************
Responsive
*************************/

@media (max-width: 1400px) {
    .vil-contact .elementor-column:last-child {
        padding: 0 10px 0 10px;
    }
    .vil-conseils-1:before {
        content: "";
        width: 220px;
        height: 52px;
        background-image: url(../icons/vil-before-conseils-1.svg);
        background-size: contain !important;
        background-repeat: no-repeat;
        display: block;
        position: absolute;
        left: 0;
        margin-left: 20px;
        top: 0;
        transform: translate(0, -50%);
        z-index: 1;
    }
}

@media (max-width: 1250px) {
    .vi-vp p {
        font-size: 15px;
        padding: 30px 10px;
    }
    .vi-home-header-1:after {
        display: none!important;
    }
}

@media (max-width: 1150px) {

    .vi-head-vid {
        min-height: 510px;
    }
    .vi-head-txt {
        left: 50%!important;
        top: 45%;
        transform: translate(-50%, -50%)!important;
        animation: revealAnimationLeftMarg 1s cubic-bezier(.5, 0, 0, 1) both!important;
    }
    .vi-head-vid .elementor-widget-container {
        height: 100%;
    }
}

@media (max-width: 1024px) {

    .single .elementor-widget-container ul {
        font-size: 14px;
    }
    .vi-nos-gammes section .elementor-container.elementor-column-gap-default {
        flex-wrap: wrap;
        justify-content: center;
    }
    .vi-nos-gammes .elementor-col-33{
        width: 50%;
    }
    .vil-sec-hist .elementor-column:nth-child(odd) .elementor-widget-wrap {
        padding: 0 9em 0 0;
    }
    .vil-sec-hist .elementor-column:nth-child(even) .elementor-widget-wrap {
        padding: 0 0 0 9em;
    }
    .vil-header h1 {
        font-size: 30px;
    }
    h2, h2.elementor-heading-title {
        font-size: 24px;
    }
    p {
        font-size: 14px;
        line-height: 160%;
    }
    .vi-pcv .elementor-column.elementor-col-50:first-child {
        margin-right: 2em;
    }
    .vi-pcv.elementor-section .elementor-container {
        -ms-flex-wrap: inherit;
        flex-wrap: inherit;
    }
    .vi-pcv .elementor-column.elementor-col-50:first-child .vi-pcv-single:first-child:before,
    .vi-pcv .elementor-column.elementor-col-50:first-child .vi-pcv-single:last-child:before,
    .vi-pcv .elementor-column.elementor-col-50:last-child .vi-pcv-single:first-child:before,
    .vi-pcv:before {
        display:none;
    }
    
    .vi-home-header p {
        max-width: 100%;
    }

    .vi-home-header > .elementor-widget {
        height: 100%;
    }

    /*.vi-head-vid {
        height: 60vh;
    }*/
    .vi-home-header .elementor-container {
        padding: 0 20px 0 20px;
    }
    .vi-home-header .elementor-container .elementor-column:last-child .elementor-widget-wrap>.elementor-element, .vi-home-header .elementor-container .elementor-column:last-child .elementor-widget-container {
        overflow: hidden;
    }
    .vi-home-header .elementor-column-gap-default>.elementor-column>.elementor-element-populated,
    .vi-vp .elementor-column-gap-default>.elementor-column>.elementor-element-populated{
        padding: 0;
    }
    .vi-chevron {
        margin: -120px 0 0 0;
    }
    .vi-home-header {
        text-align: center;
    }
    .vi-home-header h1 strong {
        margin: 0 auto 20px auto;
    }
    .vi-fef img {
        max-width: 190px;
    }
    .vi-home-header h1 {
        margin-top: 5px;
    }
    .vi-chevron .elementor-widget-container {
        border: 2px solid #fff;
    }
    .vi-chevron img {
        filter: brightness(16);
    }
}

/************************

Connexion Espace Client

************************/

.elementor-2436 {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    border-radius: 10px;
    box-shadow: 0 0 15px 0 rgb(0 0 0 / 12%);
}

.elementor-2436 > section {
    padding: 30px 0 30px 0;
    max-width: 450px;
    width: 100%;
    margin: 0 auto;
}

#loginform input#user_login,
#loginform input#user_pass {
    border: 1px solid #dedede;
    height: 40px;
    padding: 15px;

}
.login-username, .login-password {
    display: flex;
    flex-direction: column;
}

.elementor-2436 h1 {
    text-align: center;
    font-size: 30px;
}

.elementor-2436 h1:after {
    content: "";
    width: 80px;
    height: 3px;
    background-color: #C21F22;
    display: block;
    margin: 10px auto 0 auto;
}

#loginform input#wp-submit {
    background-color: #C21F22;
    font-weight: bold;
    font-size: 14px;
    padding: 10px 30px;
    color: #fff;
    text-align: center;
    margin: 0 auto;
    width: 210px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0!important;
    transition: 0.3s;
    -webkit-appearance: none;
}

.elementor-2436 p {
    font-size: 14px;
    text-align: center;
    margin-bottom: 21px;
}

#loginform p label {
    font-weight: 800;
}

#loginform p.login-remember {
    display: flex;
    align-items: center;
    justify-content: center;
}

#loginform p.login-remember label {
    font-weight: 400;
    display: flex;
}

#loginform input#rememberme {
    margin-right: 9px;
}

p.infoerreurlog {
    color: #C21F22;
    font-weight: 600;
    border: 1px solid #C21F22;
}

input#wp-submit {
    -webkit-appearance: none;
}

.popupeclient .innerpopup {
    max-width: 95%;
}

.popupcreaprojet.popupactive form {
    flex-direction: column;
    padding: 0 20px;
}

input#input-title {
    height: 40px;
    margin-top: 4px;
}

.selectize-control.selectsearch.single {
    padding: 0;
    margin: 4px 0 25px 0;
}

.popupeclient .innerpopup .popupbannertitle .closepopupclient {
    margin: 0;
}

.popupeclient .overlaypopup {
    background-color: rgba(0,0,0,0.8)!important;
    /*-webkit-backdrop-filter: blur(20px)!important;
    backdrop-filter: blur(20px)!important;*/
}

.popupeclient .innerpopup form hr {
    margin: 34px auto!important;
    max-width: 94%;
}

/*.popupeclient .innerpopup form > div:nth-child(6) {
    width: 40%!important;
}

.popupeclient .innerpopup form > div:nth-child(7) {
    width: 60%!important;
}*/
.popupeclient .innerpopup form > div {
    padding: 8px 10px!important;
}

.popupeclient .innerpopup form input[type=submit] {
    display: flex;
    align-items: center;
    justify-content: center;
}

/**********************/

@media (min-width: 993px) {
    .navlnkrs {
        width: auto !important;
        position: absolute;
        right: 30px;
        top: -28px;
        height: 28px;
        z-index: 1;
    }
    .navlnkrs > div, .navlnkrs > div > div {
        height: 100%;
    }
    .navlnkrs ul {
        height: 100%;
        margin: 0;
        padding: 0;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        list-style: none;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .navlnkrs ul li {
        width: 24px;
        height: 100%;
        margin-right: 7px;
    }
    .navlnkrs ul li a {
        font-size: 0;
        width: 30px;
        height: 30px;
        position: relative;
        display: block;
    }

    .navlnkrs ul li a:before {
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%,-50%);
        -ms-transform: translate(-50%,-50%);
        transform: translate(-50%,-50%);
        font-size: 17px;
        font-family: "Font Awesome 5 Brands";
        font-weight: 400;
        color: #fff;
    }
    .navlnkrs ul li:nth-child(1) a:before {
        content: "\f167";
    }
    .navlnkrs ul li:nth-child(2) a:before {
        content: "\f09a";
    }
    .navlnkrs ul li:nth-child(3) a:before {
        content: "\f08c";
    }
    .navlnkrs ul li:nth-child(4) a:before {
        content: "\f16d";
    }
}

@media (max-width: 992px) {
    footer:before {
        content: "";
        width: 500%;
        height: 100%;
        position: absolute;
        background: #1D1D1D;
        border-radius: 100%;
        top: -25px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 0;
    }
    .eldo-1 .sectioneldo .colavis .elementor-element-populated {
        padding-left: 0;
    }
    .vilactuavant .vilactuexecrpt {
        min-height: inherit!important;
    }
    section.elementor-section.vilactuavant {
        padding: 0 10px 0 10px;
    }
    .villistactu {
        margin: 0 -5px!important;
    }
    .vilactuavant {
        margin-bottom: 15px!important;
    }
    .villistactu .vil-cardsglblog {
        padding: 0 5px!important;
        margin-bottom: 10px!important;
    }
    .villistactu .vil-cardsglblog .vilactuimg {
        height: 17vw!important;
    }
    .villistactu .vil-cardsglblog h2 {
        font-size: 16px!important;
    }
    .vi-actu-en-avant .swiper-button-next, .vi-actu-en-avant .swiper-button-prev {
        display: none;
    }

    .eldo-1 {
        margin-bottom: 15px!important;
    }
    .colavis .elementor-widget-wrap.elementor-element-populated {
        padding: 0;
    }
    .eldo-1 .sectioneldo .colavis {
        width: 100%!important;
        margin: 20px 0;
    }
    .eldo-1 .elementor-container.elementor-column-gap-default {
        flex-direction: column;
    }
    .eldo-1 .sectioneldo .colgbleldo p:first-of-type {
        font-size: 27px!important;
        margin-bottom: 10px!important;
    }
    .eldo-1 .sectioneldo .colgbleldo p:first-of-type:after {
        content: "";
        background: url(../icons/vil-stars-note.svg) no-repeat;
        background-size: contain;
        background-position: center;
        width: 80%;
        height: 20px!important;
        display: block;
        margin: 0 auto;
    }
    .eldo-1 .sectioneldo .colgbleldo:after {
        display: none!important;
    }
    .eldo-1 .sectioneldo .colgbleldo {
        width: 100%!important;
    }
    .eldo-1 .sectioneldo .colgbleldo p {
        font-size: 14px!important;
        margin-bottom: 4px;
    }
    .vil-hist-text h2 {
        font-size: 16px!important;
    }
    body .vil-map iframe {
        height: 400px;
    }
    .vil-contact .elementor-column:last-child {
        width: 100%;
        max-width: 100%;
        order: 1;
    }
    .vil-contact .elementor-column:first-child {
        order: 2;
        width: 100%;
    }
    .vil-3-col .elementor-column.elementor-col-16, .vi-nos-gammes .elementor-column.elementor-col-16 {
        width: 48%;
        margin: 1%;
    }
    .vi-nos-gammes section .elementor-container {
        padding: 0!important;
    }
    .vi-nos-gammes h2 {
        font-size: 24px!important;
    }
    .elementor-471 .elementor-element.elementor-element-21f1cf1,
    .elementor-471 .elementor-element.elementor-element-839d9e7 {
        width: 100%;
    }
    .vil-certifs img {
        max-width: 60px;
        max-height: 55px;
    }
    .elementor-social-icons-wrapper.elementor-grid {
        text-align: center;
    }
    .vi-actu-en-avant .swiper-slide {
        width: 40%;
    }
    footer .elementor-19 .elementor-element.elementor-element-7a5415c {
        width: 100%;
        text-align: center;
    }
    .elementor-19 .elementor-element.elementor-element-47c3289 {
        width: 100%;
        padding: 0;
    }
    .mainfoot .colfoot-agence .elementor-widget-text-editor:not(.elementor-element-f5bca90) {
        padding: 0 15px 0 0;
    }
}

@media (max-width: 900px) {
    .vi-ver-sing {
        width: 100%!important;
    }
    .vi-ver-sing .elementor-widget-wrap {
        max-width: 100%;
    }
}

@media (max-width: 768px) {
    .vil-av .elementor-container .elementor-column:last-child .elementor-widget-wrap>.elementor-element:after {
        display: none;
    }
    .vi-nos-gammes:after {
        content: "";
        width: 500%;
        height: 100%;
        position: absolute;
        background: #4B4952;
        border-radius: 100%;
        bottom: -15px;
        left: 50%;
        transform: translateX(-50%);
        z-index: -1;
    }
    .vi-vp:before {
        content: "";
        width: 250%;
        height: 100%;
        position: absolute;
        background: #fff;
        border-radius: 100%;
        top: 60px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 0;
    }
    .vi-pictos-cat:before {
        content: "";
        width: 500%;
        height: 100%;
        position: absolute;
        background: #fff;
        border-radius: 100%;
        bottom: -30px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 0;
    }
    .vilblog .vilblogallshare {
        max-width: 81px!important;
    }
    .blog .vilblog .vilblogallshare {
        max-width: 110px!important;
    }
    .elementor-section.vilsharblog .vilblogallshare {
        max-width: 153px!important;
        margin: 0 auto;
    }
    .villistactu .vil-cardsglblog h2 {
        font-size: 14px!important;
    }
    .vilactuavant .ineractu {
        flex-direction: column;
    }
    .vilheadblogarch .vilarchpres > div {
        max-width: 100%!important;
    }
    .vilactuavant .elementor-col-50:first-of-type .elementor-element-populated {
        padding: 15px 15px 20px 15px!important;
        margin-bottom: 0;
    }
    .vilactuavant .elementor-col-50:last-of-type {
        height: 40vw;
        padding: 10px;
    }
    .vi-nos-gammes .elementor-col-33{
        width: 100%;
    }
    .vi-nos-gammes .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor, .vi-nos-gammes .elementor-col-16 .elementor-widget-wrap .elementor-widget-text-editor, .vil-3-col .elementor-col-33 .elementor-widget-wrap .elementor-widget-text-editor, .vil-3-col .elementor-col-25 .elementor-widget-wrap .elementor-widget-text-editor, .vil-3-col .elementor-col-16 .elementor-widget-wrap .elementor-widget-text-editor {
        min-height: inherit;
    }
    .vi-vp .elementor-column:nth-child(1) .elementor-widget-container,
    .vi-vp .elementor-column:nth-child(3) .elementor-widget-container{
        margin: 0 auto 0 0;
    }
    .vi-vp .elementor-column:nth-child(2) .elementor-widget-container {
        margin: 0 0 0 auto;
    }
    .vi-vp .elementor-element.elementor-widget-text-editor {
        max-width: 600px;
    }
    .vi-vp .elementor-column:nth-child(2) p:after{
        right: 71px;
        left: inherit;
        top: inherit;
        bottom: -100px;
        transform: rotate(-25deg) scaleX(-1);
    }
    .vi-vp .elementor-column:first-child p:after{
        right: inherit;
        top: inherit;
        left: 70px;
        bottom: -110px;
        transform: rotate(20deg);
    }
    .vi-partenaires section .elementor-column {
        max-width: 80px;
    }
    .vi-nos-gammes:before {
        display: none;
    }
    .vil-sec-hist .elementor-container {
        padding: 0!important;
    }
    .vil-hist-text p {
        margin-bottom: 42px;
    }
    .vil-hist-text {
        max-width: 100%;
        margin: 0 4%;
    }
    .vil-hist-anne p {
        font-size: 18px;
    }
    .vil-sec-hist .elementor-column .vil-hist-anne {
        right: auto!important;
        left: 50%!important;
        top: auto!important;
        transform: translate(-50%,82%)!important;
        bottom: 0;
        z-index: 1;
    }
    .vil-sec-hist .elementor-column .vil-hist-anne {
        width: 60px!important;
        height: 60px;
    }
    .vil-sec-hist .elementor-column .elementor-widget-wrap {
        padding: 0!important;
    }
    .vil-sec-hist .elementor-column:nth-child(even),
    .vil-sec-hist .elementor-column:nth-child(odd) {
        margin-top: 0;
    }
    .vil-sec-hist .elementor-column {
        margin-bottom: 55px;
    }
    .vil-sec-hist .elementor-column:nth-child(odd) .elementor-widget-wrap:before,
    .vil-sec-hist .elementor-column:nth-child(even) .elementor-widget-wrap:before,
    .vil-sec-hist-global > .elementor-container .elementor-col-100:before {
        display: none;
    }
    .vil-types section .elementor-container {
        padding: 0!important;
    }
    .vil-types {
        margin: 2em auto 0 auto;
    }
    .vil-types .elementor-column.elementor-col-50, .vil-types .elementor-column.elementor-col-33 {
        min-height: 460px;
        margin: 0 0 20px 0;
        width: 100%;
    }
    .vil-besoin-devis, .vil-part {
        padding: 0 0 1em 0;
    }
    .vil-av {
        margin: 1em 0;
    }
    h2, h2.elementor-heading-title {
        font-size: 22px!important;
    }
    .vi-nos-gammes h2 {
        font-size: 24px!important;
        margin-bottom: 0;
    }
    .vi-vp > div {
        padding: 0 20px!important;
    }
    .vil-header h1 {
        font-size: 25px;
    }
    body .mainfoot .footliensutiles ul li:not(:last-of-type) a:after {
        content: "";
        width: 10px!important;
        height: 1px;
        background-color: white;
        display: inline-block;
        margin-left: 10px!important;
        margin-right: 10px!important;
        vertical-align: middle;
    }
    .mainfoot .elementor-container:first-of-type img {
        max-width: 200px;
    }
    .vi-nos-gammes .elementor-col-33, .vil-3-col .elementor-col-33, .vil-3-col .elementor-col-25 {
        padding: 0;
    }
    .vi-vp p {
        min-height: 150px;
    }
    .vil-3-col {
        margin: 2em auto 0 auto;
    }
    .vil-3-col .elementor-widget-wrap.elementor-element-populated {
        padding: 0;
    }
    .single-co a,
    .single-co span,
    span.loc strong {
        font-size: 14px;
    }
    .single-co strong {
        font-size: 16px;
    }
}

@media (max-width: 700px) {
    .vi-actu-en-avant .swiper-slide {
        width: 60%;
    }
    .elementor-2436 {
        box-shadow: inherit;
    }.elementor-2436 .elementor-element.elementor-element-d354bb2 {
         margin-top: 0;
         margin-bottom: 20px;
     }

}

@media (max-width: 600px) {
    .popupeclient .innerpopup form > div {
        width: 100%!important;
    }
    .popupeclient .innerpopup form > div.selectize-control.selectsearch.single {
        width: 100%!important;
        padding: 0!important;
    }
    .popupeclient .innerpopup .popupbannertitle .closepopupclient {
        width: auto!important;
        margin: 0 0 0 15px!important;
    }
    .popupeclient .innerpopup .popupbannertitle {
        position: relative;
        left: 0!important;
        top: -56px!important;
        width: 100%!important;
        justify-content: center!important;
        margin: 0!important;
    }
    .popupeclient .innerpopup form {
        margin: 0 auto 20px auto!important;
        padding: 0 15px;
    }
    .popupeclient .innerpopup form input[type=submit] {
        padding: 0 30px!important;
        width: 220px!important;
    }
    .popupgestioncompte button {
        margin: 15px auto 0 auto!important;
        width: 200px!important;
    }
    .popupeclient .innerpopup {
        max-width: 95%!important;
        width: 100%!important;
        padding: 20px 0 0 0!important;
    }
    .popupcreaprojet form > div {
        width: 100%!important;
    }
    .vi-head-vid {
        height: 70vh!important;
    }
    .vi-head-txt {
        max-width: 95%!important;
    }
    .eldo-1 .sectioneldo .colavis .avissgl {
        margin: 0 0 10px 0;
        width: 100% !important;
    }

    .eldo-1 .sectioneldo .colavis .elementor-widget-wrap {
        flex-direction: column;
    }
    .vil-hist-text {
        margin: 0;
    }
    .vil-sec-hist .elementor-column {
        width: 100%!important;
    }
    .mainfoot .colfoot-agence .elementor-element-f5bca90 p {
        margin: 20px 0 15px 0;
        text-align: center;
        font-weight: 400;
    }
    .mainfoot .colfoot-agence .elementor-widget-text-editor:not(.elementor-element-f5bca90) {
        width: 100%!important;
        padding: 0;
        text-align: center;
    }
    .vi-pcv.elementor-section .elementor-container {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .vi-pcv .elementor-column.elementor-col-50:first-child {
        margin-right: 0;
    }
    .vi-pcv .elementor-column.elementor-col-50:last-child {
        margin-top: 0;
    }
    .vi-pcv-single {
        max-width: 100%;
        margin: 0 0 2em 0;
    }
    .villistactu .vil-cardsglblog {
        width: 50%!important;
        margin-bottom: 20px!important;
    }
    .villistactu .vil-cardsglblog .vilactuimg {
        height: 25vw!important;
    }
    .vilblog-headtitle {
        flex-direction: column;
    }
}

@media (max-width: 500px) {
    .eldo-1 .headeldo > div {
        align-items: center!important;
    }
    .eldo-1 h2:after {
        margin: 10px auto 0 auto!important;
    }
    .global-tab {
        display: flex!important;
        flex-wrap: wrap;
        flex-direction: column;
    }
    .vi-actu-en-avant .swiper-slide {
        width: 100%;
    }
    .vil-3-col .elementor-column.elementor-col-16, .vi-nos-gammes .elementor-column.elementor-col-16 {
        width: 100%;
        margin: 0 10px 20px 10px;
    }
    .vi-ver-sing h3 {
        font-size: 18px;
    }
}
