:root {
    --primary-h: 107;
    /* hue */
    --primary-s: 53%;
    /* saturation */
    --primary-l: 97%;
    /* lightness */
    --accent-h: 24;
    /* hue */
    --accent-s: 91%;
    /* saturation */
    --accent-l: 50%;
    /* lightness */
    --text-h: 0;
    /* hue */
    --text-s: 0%;
    /* saturation */
    --text-l: 24%;
    /* lightness */
    --background-h: 0;
    /* hue */
    --background-s: 0%;
    /* saturation */
    --background-l: 100%;
    /* lightness */
    --primary-font: "Montserrat", sans-serif;
    --secondary-font: "Manrope", sans-serif;
    --h1-font-size: 3.8125rem;
    --h2-font-size: 2rem;
    --h3-font-size: 1.5rem;
    --headings-line-height: 1.333333;
    --link-color: var(--primary-color-40);
    --border-radius: .5rem;
    --button-border-radius: .5rem;
    --transition: 0.3s all ease-in-out;
    --accent50: hsla(33, 100%, 96%, 1);
    --accent100: hsla(34, 96%, 89%, 1);
    --primary800: hsla(110, 43%, 24%, 1);
}

h1,
h2,
h3,
h4,
h5,
h6,
[class*="title"] {
    font-family: var(--secondary-font);
    font-weight: 800;
}

h1 em,
h2 em,
[class*="title"] em {
    font-style: normal;
    color: var(--accent-color);
}

.erreur .erreur,
.divGenerateurErreur .erreur {
    display: block;
    padding-bottom: .5rem;
    color: var(--error-color);
    float: right;
    font-size: 13px;
}

.relativer {
    position: relative;
}

.card {
    position: relative;
    display: block;
}

.card a::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    display: block;
    z-index: 4;
}

.card-image {
    position: relative;
    overflow: hidden;
    height: 100%;
}

.card:hover img {
    transform: scale(1.15);
    transition: var(--transition);
}

.nowrap {
    flex-wrap: nowrap;
}

.m-10 {
    margin-top: 10px;
}

.gap-12 {
    gap: 12px;
}

.relative {
    position: relative;
}

@media screen and (min-width: 993px) {
    .top-bar {
        padding: 24px 0 14px;
    }
    .fold .view-contact {
        display: none;
    }
    .index-page .section {
        padding-top: 7.5rem;
        padding-bottom: 7.5rem;
    }
}

@media screen and (max-width: 992px) {
    .fold .view-contact {
        margin-block: 8px;
        text-align: center;
    }
}


/* BRAND */


/* ===== */

.brand a {
    display: inline-block;
    transition: opacity .3s;
}

.brand a:hover {
    opacity: .75;
}

header .brand img.footer-only,
footer .brand img.header-only,
.rappel_telephonique .brand img.footer-only {
    display: none;
}


/* ==============================  BOUTON  ============================== */

.btn.secondary {
    background-color: transparent;
    color: var(--accent-color);
}

.btn.accent:hover,
.btn.secondary:hover {
    background-color: var(--primary800);
    color: white;
}

.btn-devis .btn .icon-btn,
.btn-contact .btn .icon-btn {
    display: inline-block;
    overflow: hidden;
    position: relative;
    height: 28px;
    width: 28px;
    text-align: center;
    background-color: var(--accent100);
    border-radius: var(--border-radius);
}

.btn-devis .btn .icon-btn .content,
.btn-contact .btn .icon-btn .content {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    transition: transform 0.4s ease;
}


/* Positionne le deuxième en dehors à gauche au départ */

.btn-devis .btn .icon-btn .content:last-child,
.btn-contact .btn .icon-btn .content:last-child {
    transform: translateX(-100%);
}


/* Survol : fait glisser les deux */

.btn-devis .btn:hover .icon-btn .content:first-child,
.btn-contact .btn:hover .icon-btn .content:first-child {
    transform: translateX(100%);
}

.btn-devis .btn:hover .icon-btn .content:last-child,
.btn-contact .btn:hover .icon-btn .content:last-child {
    transform: translateX(0);
}

@media screen and (min-width: 601px) {
    .btn.accent,
    .btn.secondary {
        width: auto;
    }
    .btn {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-weight: 600;
    }
}

@media screen and (max-width: 600px) {
    .btn-contact {
        margin-top: 20px;
    }
    .btn {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        font-weight: 600;
        justify-content: center;
    }
}


/* ==============================  HEADER ==============================  */

.top-bar {
    padding-block: 24px;
}

.header-content .nav ul li a.selected,
.header-content .nav ul li:hover>a {
    color: var(--accent-color);
    background: transparent;
}

.main-header-content {
    background-color: var(--accent-color);
}

@media screen and (min-width: 993px) {
    .header-content .nav#main-nav>ul>li>a {
        position: relative;
        padding: 0.75rem;
        color: white;
        height: 100%;
    }
    .header-content {
        z-index: 100;
        transition: all .3s;
    }
    .header-content .nav ul {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        width: auto;
    }
    .header-content .nav ul li.sous_menu ul.dropdown>li>a {
        border-bottom: none;
        font-size: 14px;
        color: var(--text-color);
    }
    .header-content .nav ul li.sous_menu ul.dropdown>li>a.selected,
    .header-content .nav ul li.sous_menu ul.dropdown>li>a:hover {
        color: var(--accent-color);
    }
    .header-content .nav#main-nav>ul>li>a::before {
        content: "";
        position: absolute;
        bottom: 0;
        left: 50%;
        height: 2px;
        background-color: var(--accent-color);
        width: 0;
        transition: var(--transition);
    }
    .header-content .nav#main-nav>ul>li>a.selected:before,
    .header-content .nav#main-nav>ul>li>a:hover:before {
        width: 100%;
        left: 0;
        right: 0;
    }
    .header-content .nav#topbar-nav>ul>li>a,
    .header-content .nav#topbar-nav .dropdown li a {
        padding: 0.5rem 0.35rem;
    }
}

@media screen and (max-width: 992px) {
    .menu-mobile {
        z-index: 10;
        background-color: var(--accent-color-90);
        transition: all .3s;
    }
    .header-content .nav ul li a {
        display: block;
        font-size: 16px;
    }
    .header-content .nav .sous_menu .btnMenuLevel2,
    .header-content .nav .sous_menu .btnMenuLevel3 {
        position: absolute;
        right: 0;
        top: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 3rem;
        height: 100%;
        color: var(--accent-color);
        border-left: solid 1px #ebebeb;
        z-index: 1;
    }
    .header-content .nav#topbar-nav li:not(.opened) a {
        padding: 0.5rem 5%;
        border-bottom: solid 1px #ebebeb;
    }
    .header-content .nav>ul>.sous_menu.opened>a,
    .header-content .nav .dropdown>.sous_menu.opened>a {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        width: calc(100% - 8rem);
        height: 3.5rem;
        margin: auto;
        padding: 0;
        line-height: 1.25;
        color: var(--text-color);
        border-bottom: none;
    }
    .menu-mobile .btn-menu {
        color: var(--accent-color);
        border: none;
        background: none;
        transition: color .3s;
    }
}


/* SLIDER */


/* ====== */

.slider-slick {
    width: 100%;
    height: 720px;
    background-color: var(--background-color);
    position: relative;
    z-index: 0;
}

.slider-slick .slick {
    height: 100%;
}

.slide-img {
    min-height: 720px;
    background-size: cover;
    background-position: center;
    position: relative;
}

.slide-img::before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    height: 100%;
    background-image: url('../assets/gifs/slider/x.png');
    width: 28vw;
}

.slide-img.slide-01 {
    background-image: url('../assets/gifs/slider/slide-01.jpg');
}

.slide-img.slide-02 {
    background-image: url('../assets/gifs/slider/slide-02.jpg');
}

.slide-img.slide-03 {
    background-image: url('../assets/gifs/slider/slide-03.jpg');
}

.slide-img.slide-04 {
    background-image: url('../assets/gifs/slider/slide-04.jpg');
}

.slide-img .container {
    min-height: 720px;
}

.slide-img .container .bloc {
    height: 720px;
}

.slick-dots li.slick-active button .slick-dot-icon {
    color: var(--accent-color);
    opacity: 1;
}

.slick-dots li button {
    display: block;
    height: 2rem;
    width: 1rem;
    line-height: 0px;
    font-size: 0px;
    color: transparent;
    border: 0;
    background: transparent;
    cursor: pointer;
}


/* ******************************************* BLOC 01 ******************************************** */

.label-titre {
    font-size: 28px;
    font-weight: 800;
    display: flex;
    align-items: center;
    gap: 5px;
}

h1.h1-geoloc {
    margin: 0;
}

@media screen and (min-width:993px) {
    #bloc-01 img.img-d {
        position: absolute;
        width: 49vw;
        top: 0;
        transform: translate(0%);
        left: 0;
        max-width: none;
        object-position: left;
        border-radius: var(--border-radius);
    }
    .b-info {
        position: absolute;
        bottom: 85px;
        left: -70px;
        background-color: var(--accent50);
        color: var(--accent-color);
        border: 10px solid white;
        border-radius: var(--border-radius);
        z-index: 2;
        font-size: 24px;
        font-weight: 800;
        width: 266px;
        padding: 27px 40px;
    }
}

@media screen and (max-width:992px) {
    .b-info {
        position: relative;
        bottom: 0;
        left: 0;
        background-color: var(--accent50);
        color: var(--accent-color);
        border: 10px solid white;
        border-radius: var(--border-radius);
        z-index: 2;
        font-size: 24px;
        font-weight: 800;
        width: 100%;
        padding: 27px 40px;
    }
}


/* ******************************************* ENCART POINT FORTS ******************************************** */

#point_fort {
    padding-block: 80px;
}

.head-point {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
}

.head-point .title-3 {
    font-size: 24px;
    font-weight: 800;
    margin: 0;
}

.point-content {
    text-align: left;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    background-size: cover;
    padding: 32px 16px;
    border-radius: var(--border-radius);
    background-color: var(--accent50);
}

.point-content p {
    margin: 0;
}

.point-content img {
    width: auto;
}


/* ******************************************* ENCART PRESTATIONS ******************************************** */

.prestations-card-image a::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(133, 205, 116, 0.069) 0%, rgba(250, 163, 62, 0.69) 100%);
    z-index: 1;
}

.prestations-card,
.prestations-card img {
    height: 321px;
    object-fit: cover;
    position: relative;
    clip-path: polygon(14% 0, 98% 0, 86% 100%, 0 99%);
}

.prestations-card-content a {
    color: white;
    text-decoration: none;
    position: relative;
}

.prestations-card-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 30px;
    width: 100%;
    text-align: center;
}

.prestations-card-title a {
    font-size: var(--h3-font-size);
    text-decoration: none;
    color: white;
}

.prestations-card-image a {
    position: relative;
    z-index: 0;
    display: block;
}

@media screen and (min-width: 993px) {
    .slick-prestations {
        margin-block: 60px;
    }
}


/* ******************************************* ENCART processus ******************************************** */

#encart-processus {
    padding-block: 80px;
}

.processus-card {
    position: relative;
}

.slick-processus {
    margin-block: 60px;
    row-gap: 40px;
}

.processus-card img {
    height: 155px;
    object-fit: cover;
    position: relative;
    clip-path: polygon(14% 0, 98% 0, 86% 100%, 0 99%);
}

.processus-card:hover img {
    transform: scale(1);
}

.number {
    position: absolute;
    top: -18px;
    background: var(--accent-color);
    width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    border-radius: var(--border-radius);
    left: 50%;
    z-index: 3;
}

#encart-processus .btn.secondary {
    background-color: white;
}

#encart-processus .btn.secondary:hover {
    color: var(--accent-color);
}


/* ******************************************* BLOC 02 ******************************************** */

@media screen and (min-width:993px) {
    h2 {
        margin-top: 0;
    }
    #bloc-02 img.img-g {
        position: absolute;
        width: 49vw;
        top: 0;
        transform: translate(0%);
        right: 0;
        max-width: none;
        object-position: left;
        border-radius: var(--border-radius);
    }
}


/* ******************************************** ENCART CONTACT ****************************************** */

#encart-contact {
    background: url(../assets/gifs/bg-encart-contact.jpg);
    background-size: cover;
    background-position: center;
    padding-block: 97px;
}

.bloc-wrapper {
    border-radius: var(--border-radius);
    overflow: hidden;
}

.contact-card-title {
    font-family: var(--primary-font);
    font-weight: 600;
    margin-top: 16px;
}

#encart-contact .btn.accent,
#encart-contact .btn.secondary {
    background-color: white;
    color: var(--accent-color);
    border: 1px solid white;
}

#encart-contact .btn.accent:hover,
#encart-contact .btn.secondary:hover {
    background-color: var(--primary800);
    color: white;
}

#encart-contact .reseaux-sociaux {
    margin-top: 24px;
}

#encart-contact .reseaux-sociaux svg {
    fill: white;
}

.contact-card {
    margin-bottom: 30px;
}

@media screen and (min-width:993px) {
    .bg-contact {
        background-color: var(--accent-color);
        clip-path: polygon(14% 0, 98% 0, 86% 100%, 0 99%);
        padding: 30px 166px;
    }
}

@media screen and (max-width:992px) {
    .bg-contact {
        background-color: var(--accent-color);
        padding: 30px;
    }
}


/* ******************************************* ENCART CATALOGUE ******************************************** */

#encart-catalogue .catalogue-nav a,
.catalogue-listing .btn-cat a {
    font-size: 24px;
    font-weight: 700;
}

.catalogue-nav,
.btn-cat {
    margin-block: 48px;
}

#encart-catalogue .catalogue-nav a:hover,
#encart-catalogue .catalogue-nav a:focus,
.catalogue-listing .btn-cat a:hover,
.catalogue-listing .btn-cat a:focus {
    background-color: var(--accent-color);
    color: white;
}

#encart-catalogue .top-left,
.catalogue-listing .btn-cat .top-left {
    top: 0;
    left: 0;
    border-top: 3px solid var(--accent-color);
    border-left: 3px solid var(--accent-color);
}

#encart-catalogue .top-right,
.catalogue-listing .btn-cat .top-right {
    top: 0;
    right: 0;
    border-top: 3px solid var(--accent-color);
    border-right: 3px solid var(--accent-color);
}

#encart-catalogue .bottom-left,
.catalogue-listing .btn-cat .bottom-left {
    bottom: 0;
    left: 0;
    border-bottom: 3px solid var(--accent-color);
    border-left: 3px solid var(--accent-color);
}

#encart-catalogue .bottom-right,
.catalogue-listing .btn-cat .bottom-right {
    bottom: 0;
    right: 0;
    border-bottom: 3px solid var(--accent-color);
    border-right: 3px solid var(--accent-color);
}

.catalogue-encart-card .catalogue-card-image {
    height: 100%;
    overflow: hidden;
}

.catalogue-card-image {
    position: relative;
    overflow: hidden;
}

.catalogue-card-image img {
    transition: 0.3s;
}

.card-content {
    padding-top: 20px;
    height: 10%;
}

.catalogue-card .card-content {
    position: absolute;
    padding: 0 24px;
    bottom: 15px;
    padding-bottom: 0;
    z-index: 2;
}

.catalogue-card:hover .catalogue-card-image a::before {
    background: linear-gradient(0deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0)), linear-gradient(180deg, rgba(0, 0, 0, 0.24) 0%, rgba(0, 0, 0, 0.6) 100%);
}

.card.catalogue-card {
    position: relative;
    z-index: 0;
    color: white;
    overflow: hidden;
}

.catalogue-card-title a {
    color: white;
    text-decoration: none;
    font-size: 24px;
    line-height: 34.2px;
    font-weight: 700;
}

.catalogue-card-content .catalogue-card-text,
.catalogue-card-content .btn-prestation {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.3s ease;
    pointer-events: none;
}

.catalogue-card:hover .catalogue-card-text,
.catalogue-card:hover .btn-prestation {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    overflow: hidden;
}

.catalogue-card:hover .card-content {
    bottom: 116px;
    transition: all 0.3s ease;
    padding-bottom: 48px;
}

.link-catalogue a {
    text-decoration: none;
    color: white;
    margin-top: 10px;
    display: block;
}

.catalogue-card-image a:before {
    position: absolute;
    content: "";
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    top: 0;
    z-index: 2;
    background: linear-gradient(0deg, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0)), linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
}

.catalogue-card:hover {
    margin: 0;
}

.slick-catalogue .catalogue-card,
.slick-catalogue .catalogue-card-image,
.slick-catalogue .catalogue-card img {
    height: 480px;
    position: relative;
    object-fit: cover;
    width: 100%;
}

.row.slick-catalogue .col {
    padding: 0 !important;
}

@media screen and (min-width: 993px) {
    .slick-catalogue {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: repeat(2, 1fr);
        grid-column-gap: 0px;
        grid-row-gap: 0px;
        margin-block: 60px;
    }
    .row.slick-catalogue .col:nth-of-type(1),
    .catalogue-item:nth-of-type(1),
    .bdd-detail-2 .col:nth-of-type(1) {
        grid-area: 1 / 1 / 2 / 4;
    }
    .row.slick-catalogue .col:nth-of-type(2),
    .catalogue-item:nth-of-type(2),
    .bdd-detail-2 .col:nth-of-type(2) {
        grid-area: 2 / 1 / 3 / 2;
    }
    .row.slick-catalogue .col:nth-of-type(3),
    .catalogue-item:nth-of-type(31),
    .bdd-detail-2 .col:nth-of-type(3) {
        grid-area: 2 / 2 / 3 / 3;
    }
    .row.slick-catalogue .col:nth-of-type(4),
    .catalogue-item:nth-of-type(4),
    .bdd-detail-2 .col:nth-of-type(4) {
        grid-area: 2 / 3 / 3 / 4;
    }
}

@media screen and (max-width: 992px) {
    .slick-catalogue .slick-dots {
        bottom: -8rem;
    }
    #encart-catalogue .slick-catalogue {
        margin-bottom: 9rem;
    }
}


/* ******************************************** BLOC 03 et BLOC 04 ****************************************** */

#bloc-03 .img-g {
    margin-bottom: 60px;
}

#bloc-03 .img-d {
    margin-top: 47px;
    min-height: 533px;
    object-fit: fill;
}

#bloc-03 p em {
    display: block;
    background: hsla(109, 58%, 93%, 1);
    padding: 17px 19px;
    color: hsla(110, 43%, 24%, 1);
    border-radius: var(--border-radius);
    font-style: normal;
}


/* ******************************************** ENCART AVIS ****************************************** */

.encart-avis {
    padding-block: 80px;
}

.slick-avis {
    margin-block: 60px;
}

.avis-card {
    background: hsla(0, 0%, 100%, 1);
    padding: 16px;
}

.encart-avis .avis-card-text {
    position: relative;
    margin-left: 21%;
}


/* ******************************************** BLOC 05 ****************************************** */

@media screen and (min-width:993px) {
    #bloc-05 img.img-d {
        position: absolute;
        width: 49vw;
        top: 0;
        transform: translate(0%);
        left: 0;
        max-width: none;
        object-position: left;
        border-radius: var(--border-radius);
    }
    #bloc-05 .b-info {
        position: absolute;
        bottom: 0;
        left: -4px;
        background-color: hsla(107, 53%, 97%, 1);
        color: hsla(110, 43%, 24%, 1);
        border: 10px solid white;
        border-radius: var(--border-radius);
        z-index: 2;
        font-size: 16px;
        width: 85%;
        padding: 27px 40px;
        font-weight: 400;
    }
}

@media screen and (max-width:992px) {
    #bloc-05 .b-info {
        position: relative;
        bottom: 0;
        left: 0;
        background-color: hsla(107, 53%, 97%, 1);
        color: hsla(110, 43%, 24%, 1);
        border: 10px solid white;
        border-radius: var(--border-radius);
        z-index: 2;
        font-size: 16px;
        width: 100%;
        padding: 27px 40px;
        font-weight: 400;
    }
}


/* ******************************************** FAQ ****************************************** */

.faq-item {
    border-bottom: 1px solid #ddd;
}

.faq-question {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    cursor: pointer;
}

.faq-question h3 {
    margin: 0;
    font-size: 16px;
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    padding: 0 1rem;
    transition: max-height 0.4s ease, padding 0.3s;
    text-align: left;
}

.faq-item.active .faq-answer {
    max-height: 300px;
    padding: 1rem;
}

.icon {
    font-size: 20px;
    transition: transform 0.3s;
    width: 25px;
    height: 25px;
    border: 1px solid var(--accent-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    font-weight: 700;
    line-height: 25px;
    color: var(--accent-color);
}

.faq-item.active .icon {
    transform: rotate(180deg);
}


/* ******************************************** ENCART ACTUALITES ****************************************** */

#encart-actualites {
    background-color: var(--background-color);
}

#encart-actualites .title-2 {
    margin-top: 60px;
    margin-bottom: 0;
}

#encart-actualites .label-titre,
#faq .label-titre,
#encart-prestations .label-titre,
#encart-processus .label-titre,
#encart-catalogue .label-titre {
    justify-content: center;
}

.actualites-card {
    transition: var(--transition);
}

.slick-actualites {
    margin-block: 60px;
}

.actualites-card-title a {
    font-size: 24px;
    text-decoration: none;
    color: hsla(0, 0%, 12%, 1);
    line-height: 24px;
}

.actualites-card-text {
    margin-block: 8px;
}

.lire-plus {
    text-decoration: none;
    color: hsla(0, 0%, 12%, 1);
}

.actualites-card-content {
    margin-top: 20px;
}

.actualites-card-image img {
    object-fit: cover;
    height: 324px;
    border-radius: var(--border-radius);
}


/* ******************************************* ENCART FORMULAIRE ******************************************** */

#encart-formulaire {
    background-color: hsla(0, 0%, 96%, 1);
}

#encart-formulaire .img-form {
    object-fit: cover;
    height: 100%;
    object-position: center;
    border-radius: var(--border-radius);
}

#encart-formulaire label {
    font-weight: 600;
}

#encart-formulaire .form {
    background-color: white;
    box-shadow: 0px 4px 24px 0px hsla(0, 0%, 0%, 0.1);
    padding: 25px;
    border-radius: var(--border-radius);
}

input:not([type]),
input[type=text],
input[type=password],
input[type=email],
input[type=url],
input[type=time],
input[type=date],
F input[type=datetime],
input[type=datetime-local],
input[type=tel],
input[type=number],
input[type=search],
textarea {
    border-color: hsla(0, 0%, 82%, 1);
}

@media screen and (min-width:993px) {
    .form_left .btn.outlined {
        width: auto;
    }
}

@media screen and (max-width:992px) {
    .img-form {
        padding-bottom: 24px;
    }
}


/* ******************************************* FOOTER ******************************************** */

footer {
    background-color: var(--accent50);
}

.footer-contact p {
    margin: 0 0 12px;
    font-weight: 600;
    color: var(--accent-color);
}

footer address {
    margin: 0;
}

footer .reseaux-sociaux svg {
    fill: hsla(0, 0%, 12%, 1);
}

.espace {
    min-height: 30px;
}

footer .tel svg {
    display: none;
}

.footer-2 {
    padding-bottom: 32px;
    font-weight: 700;
}

#footer-nav .nav ul li.no-menu {
    display: none;
}

#footer-nav .nav ul li.sous_menu ul.dropdown {
    position: absolute;
    left: 0;
    display: none;
    flex-direction: column;
    align-items: stretch;
    width: max-content;
    min-width: 100%;
    margin: 0;
    padding: 0;
    font-weight: normal;
    z-index: 1;
    background-color: #fff;
    border: 1px solid var(--primary-color);
}

#footer-nav .nav ul li.sous_menu>a::after {
    position: absolute;
    right: 0.625rem;
    display: block;
    font-family: var(--icon-font);
    line-height: 0;
    content: "\e5c5";
    position: static;
    display: inline-block;
    margin: -0.125em 0 0 0.25em;
    text-decoration: none;
}

#footer-nav nav a {
    font-weight: 400;
    line-height: 24px;
}

footer nav a:hover {
    color: var(--accent-color);
}

#footer-nav .nav ul li a.selected,
#footer-nav .nav ul li:hover>a {
    text-decoration: underline;
}

#footer-nav .nav>ul>li {
    margin-bottom: 8px;
}

#footer-nav .nav ul li.sous_menu ul.dropdown>li:not(:last-child) {
    border-bottom: 1px solid #e0e0e0;
}

#footer-nav .nav ul li.sous_menu {
    position: relative;
}

#footer-nav .nav ul li.sous_menu:hover ul.dropdown {
    display: flex;
}

#footer-nav .nav ul li.sous_menu ul.dropdown>li a {
    padding: 0.5rem;
    margin: 0;
    font-size: 13px;
    display: block;
    color: var(--accent-color)
}

.lien-maps:hover {
    opacity: 0.7;
}

.footer-contact p svg {
    margin-right: 10px;
}

@media screen and (min-width: 993px) {
    #footer-nav .nav>ul {
        display: flex;
        align-items: flex-start;
        justify-content: center;
        gap: 1.5rem;
        margin: 1.5rem 0;
    }
    footer #footer-nav .nav ul li.sous_menu ul.dropdown {
        bottom: 100%;
    }
}

@media screen and (max-width: 992px) {
    footer .brand,
    footer p {
        text-align: center;
    }
    .footer-contact {
        display: flex;
        flex-direction: column;
        row-gap: 0;
        text-align: center;
        margin-bottom: 30px;
    }
    #footer-nav .nav>ul {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        margin: 1.5rem 0;
        flex-direction: column;
    }
    footer #footer-nav .nav ul li.sous_menu ul.dropdown {
        display: none;
    }
    #footer-nav .nav ul li.sous_menu>a::after {
        display: none;
    }
    footer .reseaux-sociaux ul {
        display: flex;
        justify-content: center;
    }
}


/* ******************************************* PAGE INTERNE ******************************************** */

.bg-hero::before,
.hero-interne::before,
.hero-interne::after,
.bg-hero::after {
    position: absolute;
    content: "";
    background: url('../assets/gifs/slide-interne.jpg');
    background-size: cover;
    background-repeat: no-repeat;
    width: 100vw;
    left: 50%;
    transform: translateX(-50%);
    top: -10px;
    height: 100%;
    z-index: -1;
    background-position: center;
    margin: 0 auto;
}

.page-interne .bg-hero::after,
.hero-interne::after {
    background: linear-gradient(180deg, rgb(0 0 0 / 50%) 0%, rgb(0 0 0 / 50%) 100%);
}

.sc-content .ac-doubleColonne.bg-hero,
.hero-interne {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 470px;
    margin-bottom: 48px;
    margin-top: -1.4rem;
}

nav#fil_ariane,
#fil_ariane,
.fil-ariane {
    margin-bottom: 48px;
}

.contact-page .hero-interne {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 447px;
    margin-bottom: 48px;
    margin-top: 0;
}

.contact-page .hero-interne h1 {
    text-align: left;
    max-width: 74100%;
    margin: 0 auto;
}

.page-interne #encart-contact,
.page-interne #encart-formulaire {
    width: 100vw;
    left: 50%;
    transform: translate(-50%);
    top: 0;
    height: 100%;
    position: relative;
    padding-block: 6.5rem;
}

.page-interne #encart-formulaire {
    margin-bottom: -3rem;
}


/* PAGE ACTU DETAIL */

.container_actualite .clear_both {
    margin-bottom: 0px;
}

body.actualites-detail .listing-autres-actus-categorie {
    height: max-content;
    padding: 24px;
    margin-bottom: 24px;
    background-color: var(--primary-color);
    border-radius: var(--border-radius);
}

.listing-autres-actus-categorie a.btn {
    font-weight: 600;
    letter-spacing: 0px;
    padding: 13px 10px;
    width: fit-content;
    font-size: 14px;
}

body.actualites-detail .listing-autres-actus-categorie .detail-btn {
    text-align: center;
}

#listing-autres-actus-categorie ul li ul {
    padding-left: 0;
}

#listing-autres-actus-categorie ul li ul li {
    list-style: none !important;
}

#listing-autres-actus-categorie ul li a {
    text-decoration: none;
}

#listing-autres-actus-categorie ul li a:hover {
    text-decoration: underline;
}

.fb-like.fb_iframe_widget {
    position: relative;
    top: 6px;
}

.listing-autres-actus-categorie-mois {
    margin-block: 5px;
    display: block;
}


/* pagination actu*/

.paginationControl {
    letter-spacing: normal;
    text-align: center;
    padding: 40px 0 0;
}

.paginationControl a,
.paginationControl span {
    display: inline-block !important;
    padding: 0 10px;
    color: var(--text-color);
    font-size: 14px;
    line-height: 30px;
    background: var(--primary-color);
    border: 1px solid var(--accent50);
}

.paginationControl a:hover,
.paginationControl span.selected {
    color: white;
    background: var(--accent-color);
}

.paginationControl span.disabled {
    color: #353b48;
    background: #dcdde1;
}

form .btn.accent {
    width: 100%;
}

.block-txt .ac-colonne {
    border: 1px solid var(--primary-color-70);
    padding: 20px;
}

.contact-page-horaires .row {
    margin-block: .85rem;
}

.page-interne .ac-colonne em {
    display: block;
    font-style: normal;
    padding: 34px;
    background-color: var(--primary-color);
}

h1 span,
.title-1 span {
    color: var(--accent-color);
}


/* DEVIS */

fieldset {
    height: auto;
    border-color: var(--accent100);
    margin-top: 16px;
}

legend {
    padding: 0 15px;
    font-weight: 600;
}

#formulaire_11 h3 {
    font-size: 20px;
    margin-bottom: 0;
}

@media screen and (min-width: 993px) {
    .bg-hero .title-1,
    .hero-interne .title-1,
    .hero-interne h1 {
        font-size: 50px;
    }
    .sc-content .ac-doubleColonne .ac-colonne img {
        width: 100%;
        margin: 0;
        height: 100%;
        object-fit: cover;
    }
    .cp_ville {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 16px;
    }
    .page-interne h2 {
        margin: 15px 0;
    }
    .sc-content .ac-doubleColonne .img-right img {
        padding-left: 80px;
        height: 100%;
        object-fit: cover;
    }
    .sc-content .ac-doubleColonne .img-left img {
        padding-right: 80px;
        height: 100%;
        object-fit: cover;
    }
}

@media screen and (max-width: 992px) {
    .page-interne .ac-stat .ac-colonne {
        margin-bottom: 20px;
    }
    .contact-page .hero-interne {
        margin-top: 0;
    }
    .block-txt .ac-colonne {
        border: 1px solid var(--primary-500);
        padding: 20px;
        margin-bottom: 48px;
    }
    .page-interne #encart-formulaire {
        padding-block: 2.5rem;
    }
}

@media screen and (min-width: 601px) {
    .actualites-listing .recherche_actu #recherche_actu_submit {
        margin-left: .5rem;
        width: 3rem;
        padding: 7px;
    }
}

.contact-page-image{
    height: 462px!important;
}