@font-face {
    font-family: 'Bellota Text-bold';
    src: url('../fonts/BellotaText-Bold.woff2') format('woff2'), url('../fonts/BellotaText-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Bellota Text-light';
    src: url('../fonts/BellotaText-Light.woff2') format('woff2'), url('../fonts/BellotaText-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Bellota Text-reg';
    src: url('../fonts/BellotaText-Regular.woff2') format('woff2'), url('../fonts/BellotaText-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
    --bs-body-color: #666365;
    --bs-body-bg: #fff;
    --bs-primary-color: #3e8d9a;
    --bs-secondary-bg: #489a6e;
    --bs-tertiary-color: #70cb55;
    --bs-tertiary-bg: #293c74;
    --dark-color: #000;
    --light-color: #6e6e6e;
    --bs-btn-padding-x: 20px;
    --bs-btn-padding-y: 10px;
    --border-color: #3e8d9a;
    --bs-nav-link-color: #ededed;
    --bs-nav-link-color-second: #3e8d9a;
    --bs-body-font-family: Bellota Text-reg;
    --bs-titles-font-family: 'Bellota Text-bold';
    --bs-body-font-weight: 300;
    --bs-body-line-height: 1.8em;
    --bs-body-font-size: 15px;
    --bs-nav-link-font-size: 1em;
    --bs-nav-link-font-weight: 400;
    --bs-nav-link-padding-y: 10px;
    --bs-nav-link-padding-x: 0;
    --bs-navbar-nav-link-padding-x: 0;
    --bs-dropdown-zindex: 99;
    --bs-dropdown-min-width: 200px;
    --bs-dropdown-padding-x: 20px;
    --bs-dropdown-padding-y: 15px;
    --bs-dropdown-font-size: 1em;
    --bs-dropdown-padding-y: 5px;
    --bs-dropdown-font-size: 1em
}
body {
 
    max-width: 1920px;
    margin: auto;
}
a {
    color: var(--bs-primary-color);
    transition: all .4s;
    outline: none
}

a:active,a:hover,a:focus {
    color: var(--bs-secondary-bg);
    text-decoration: none
}

hr {
    border-color: var(--bs-primary-color)
}

.image-left {
    margin: 0 35px 30px 0!important;
    float: left!important
}

.image-right {
    margin: 0 0 30px 35px!important;
    float: right!important
}

.btn-primary {
    background: var(--bs-primary-color);
    border-color: var(--bs-primary-color);
    color: var(--bs-body-bg)
}

.btn-primary:hover {
    background: var(--bs-secondary-bg);
    border-color: var(--bs-secondary-bg);
    color: var(--bs-body-bg)
}

span.phone-responsive {
    display: none
}

.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6 {
    font-family: var(--bs-titles-font-family);
    font-weight: 300;
    text-transform: uppercase;
    line-height: 1.35em
}

.animate.clip_ltr {
    clip-path: inset(0 100% 0 0);
    transition: clip-path 800ms ease-out
}

.animate.clip_rtl {
    clip-path: inset(0 0 0 100%);
    transition: clip-path 800ms ease-out
}
.bg-success {
    --bs-bg-opacity: 1;
    background-color: #3e8d9a !important;
    color: #fff;
    border-color: #3e8d9a;
}
.animate.clip_ttb {
    clip-path: inset(0 0 100% 0);
    transition: clip-path 800ms ease-out
}

.animate.fade_in {
    opacity: 0;
    transition: opacity 800ms ease-out;
    transition-delay: 0
}

.animate.fade_in.play {
    opacity: 1
}

.animate.delay-250 {
    transition-delay: 250ms
}

.animate.delay-500 {
    transition-delay: 500ms
}

.animate.clip_ttb.play {
    clip-path: inset(-1px -1px -1px -1px)
}

.animate.clip_ltr.play {
    clip-path: inset(-1px -1px -1px -1px)
}

.animate.clip_rtl.play {
    clip-path: inset(-1px -1px -1px -1px)
}

header.sticky-top.is-sticky nav.navbar.navbar-expand-lg {
    background: #fff;
    box-shadow: 0px 0px 10px rgba(0,0,0,.5);
    padding: 0;
}

.box-light {
    background: var(--bs-nav-link-color);
    padding: 15px 15px 10px;
    margin: 0 0 20px
}
.img-ct {
    float: right;
    margin-left: 50px;
    margin-bottom: 40px;
}
section.banner {
   height: 897px;
    background: #f3f1f2;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, .2);
}
section.banner.small-size {
  height: 700px;
}

section.banner .img {
    background: url(../images/photo-header.webp) no-repeat center fixed;
    background-size: cover
}

section.banner .img:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: url(../images/bg-photo.webp) no-repeat top center;
    background-size: cover
}

section.banner img {
    object-fit: cover
}

section.banner .slider {
inset:0;
}
section.banner .slider:before {position:absolute;content:'';top: 0;bottom: 0;right: 0;width: 100%;background: url(../images/bg-banner.jpg) left top no-repeat;}
header.sticky-top a.nav-link {
    position: relative;
    text-align: center;
    color: #22303c!important;
    padding: 19px 10px 13px 10px!important;
    font-size: 15px;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0;
    font-family: 'Bellota Text-reg';
    /* border-block: 5px solid rgba(0,0,0,0); */
    border-width: 5px;
    border-style: solid;
    border-image: linear-gradient(to right, #55aa39, #3c8aa1) 0;
    border-inline: 0;
    text-shadow: 0px 0px 0px currentColor;
}

.slide-box-message {
    top: 143px;
    left: 15px;
    text-align: center;
    z-index: 3;
}

.slide-box-message .s1 {
   color: #51a549;
}

.slide-box-message h3 {
   margin: 0;
   font-size: 30px;
   color: #22303c;
   font-family: 'Bellota Text-light';
   margin-block: 77px 31px;
   letter-spacing: -1px;
}

.slide-box-message .cta a {
    font-size: 22px;
    line-height: 1;
    text-shadow: none;
    display: block;
    text-decoration: none;
    color: #22303c;
    font-weight: 500;
    text-transform: none;
    box-shadow: none;
    margin: auto;
    
     /* this doesn't work */
    padding: 15px 15px 15px 15px;';;
;font-family: 'Bellota Text-bold';;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;background: url(../images/border.png) top center no-repeat;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;
;;;;;max-width: 469px;;;;;;
;;;;;;;border-radius: 10px;;;;;;;;
}

.slide-box-message .cta a:hover {
 background: #3d8b9f;
 color: #fff;
}

section.banner .carousel,.carousel-inner,.carousel-item {
    height: 100%
}

.carousel img {
    height: 100%;
    object-fit: cover
}

section.banner.small-size .slider {
 
}

header.sticky-top .navbar-expand-lg .navbar-nav {
    margin: 0!important;
    width: 100%!important;
    justify-content: space-between
}
header.sticky-top nav.navbar {
  padding:0;
}
header.sticky-top .inner-wrapper {
    display: grid;
    grid-template-columns: auto 27px;
    gap: 30px;
    align-items: center;
}

header.sticky-top .navbar-expand-lg .social {position: relative;top: 2px;}

header.sticky-top .navbar-expand-lg .social a {display: inline-block;width: 27px;height: 27px;background: url(../images/wats.png) top center no-repeat;font-size: 0;}
header.sticky-top .navbar-expand-lg .social a:hover {opacity: .6;}

header.sticky-top .navbar-nav > li > .nav-link:hover,header.sticky-top .navbar-nav > .selected > .nav-link {
    color: var(--bs-primary-color)!important;
    border-image: linear-gradient(to right, #55aa39, #3c8aa1) 1;
}

header.sticky-top .dropdown-toggle::after {
    content: '\f078';
    font-family: "Font Awesome 6 Pro";
    border-top: 0 solid;
    font-size: 7px;
    padding: 2px 0 0 2px;
    font-weight: 900;
    -webkit-text-stroke: 1px var(--bs-nav-link-color-second)
}

header.sticky-top .dropdown-menu .nav-link:hover,header.sticky-top .dropdown-menu .selected .nav-link {
    color: var(--bs-secondary-bg)!important;
    background: #fff;
}

header.sticky-top.is-sticky {
    background: #000;
    position: fixed!important
}
header.sticky-top .call {
    position: absolute;
    left: 0;
    right: 0;
    max-width: 1230px;
    margin: auto;
    bottom: -34px;
    text-align: right;
}
header.sticky-top .call p {
  margin:0;
}
header.sticky-top .call a {
   padding: 10px 15px;
   background: #3d8b9e;
   color: #fff;
   text-decoration: none;
    opacity: 0
}
header.sticky-top.is-sticky .call a {
    opacity: 1
    
}
header.sticky-top .call a:hover {
   background: #52a646;
}
header.sticky-top.is-sticky .logo {
    top: 10px
}

header.sticky-top .dropdown-item {
    position: absolute;
    right: 0;
    top: 10px;
    z-index: 999;
    cursor: pointer
}

header.sticky-top .navbar-expand-lg .navbar-nav .dropdown-menu {
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 99;
    text-align: center;
    margin-top: 0;
    min-width: 12em;
    background: var(--border-color);
    padding: 0;
}

header.sticky-top .navbar-expand-lg .navbar-nav .dropdown-menu > li {
}

header.sticky-top li.nav-item.dropdown > a {
}

header.sticky-top .dropdown-menu li.nav-item {
    padding: 0
}

header.sticky-top .dropdown-toggle {
    position: absolute;
    right: 50%;
    bottom: 5px;
    z-index: 999;
    cursor: pointer
}

header.sticky-top .dropdown-menu li.nav-item .dropdown-toggle {
    right: 9px;
    left: auto;
    top: 0
}

header.sticky-top ul.dropdown-menu {
    border: 0;
    border-radius: 0
}

header.sticky-top .dropdown-toggle.child::after {
    content: '\f054';
    font-family: "Font Awesome 6 Pro";
    border-top: 0 solid
}

header.sticky-top .dropdown-menu li {
    position: relative
}

header.sticky-top .nav-item .submenu-left {
    right: 100%;
    left: auto
}

header.sticky-top .dropdown-menu > li:hover > .submenu {
    display: block
}

header.sticky-top .dropdown-menu .nav-link {
    letter-spacing: .1em;
    padding: .5em 1.5em!important;
    transition: color .4s,padding .4s;
    text-align: center;
    white-space: nowrap;
    line-height: 1em
}

header.sticky-top .dropdown-menu .nav-link:before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 6px;
    height: 6px;
    display: inline-block;
    border-right: 1px solid var(--bs-nav-link-color-second);
    border-bottom: 1px solid var(--bs-nav-link-color-second);
    transform: translateY(-50%) rotate(-45deg) scale(0);
    transition: transform .4s
}

header.sticky-top .dropdown-menu .nav-link:hover:before,header.sticky-top .dropdown-menu .selected .nav-link:before {
    transform: translateY(-50%) rotate(-45deg) scale(1)
}

header.sticky-top .navbar-expand-lg .navbar-nav .dropdown-menu .level-2 {
    position: absolute;
    padding: 10px;
    left: 100%;
    top: 0;
    transform: translateX(0%)
}

.homepage .wrapper {
    padding: 50px 0 30px;
}

.photo-home {
    margin: 0 0 20px 100px
}

.photo-home > div:last-of-type {
    margin-top: -209px;
    border-radius: 50%;
    position: relative;
    margin-left: -60px;
    box-shadow: 0 0 6px #400000;
    width: 273px;
    height: 273px;
    overflow: hidden
}

.homepage .wrapper .content h1 {
    font-weight: 400
}

.content h1 {
    margin: 0 0 16px;
    position: relative;
    text-align: center;
    font-size: 30px;
    color: #22303c;
    font-family: 'Bellota Text-reg';
    text-transform: none;
    background: url(../images/bgh1.png) top center no-repeat;
    padding-top: 84px;
}

span.d-block.subtitle {
   line-height: 1.1em;
    background: -webkit-linear-gradient(#3c8aa1, #55aa38);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 50px;
    text-transform: uppercase;
}

 .content h1 span.sub-title {

    line-height: 1.1em;
    background: -webkit-linear-gradient(#3c8aa1, #55aa38);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 50px;
    text-transform: uppercase;
}
    .h2, h2 {
        font-size: 25px;
        color: #55aa38;
    }
article.content p {
    margin: 0 0 20px
}
.homepage .wrapper .content article.content p,.homepage .wrapper .content article.content h2 {
  text-align: center !important;
}
article.content ul {
    list-style: none;
    margin-left: 0;
    padding: 0
}

article.content ul li {
  position: relative;
    left: 0;
    margin-left: 5px;
    padding-right: 5px;
    background: url(../images/list-icon01.webp) left 7px no-repeat;
    padding-left: 20px;
}

article.content ul ul {
    list-style-type: circle
}

article.content .table-style {
    position: relative
}

article.content .table-style th {
    background: var(--bs-gray-200);
    color: var(--bs-body-color)
}

.fr-view table th {
    color: var(--bs-body-color)
}

article.content .table-style th,article.content .table-style td {
    border: 1px solid var(--bs-gray-400);
    padding: 2px 5px
}

article.content1 .grid-gallery {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    grid-gap: 20px
}

article.content1 .link-picture {
    background-size: cover;
    background-position: center;
    height: 337px;
    cursor: zoom-in;
    position: relative;
    display: block;
    box-shadow: 0 0 0 rgba(255,255,255,.2);
    transition: transform .4s,box-shadow .4s
}

article.content .link-subgallery {
    position: relative;
    background-size: cover;
    background-position: center;
    height: 337px;
    text-decoration: auto;
    cursor: pointer;
    box-shadow: 0 0 0 rgba(255,255,255,.2);
    transition: transform .4s,box-shadow .4s
}

article.content .link-subgallery:hover,article.content1 .link-picture:hover {
    transform: scale(.95)
}

.page-link {
    color: var(--bs-primary-color);
    text-decoration: none
}

.active>.page-link,.page-link.active,.page-link:hover {
    color: var(--bs-body-bg);
    background-color: var(--bs-primary-color);
    border-color: var(--bs-primary-color)
}

.disabled>.page-link,.page-link.disabled {
    color: red!important
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
 -webkit-appearance: none;
 margin: 0;
}

input[type=number] {
 -moz-appearance: textfield;
}

article.content .pagination {
    margin-top: 10px;
    justify-content: center
}

article.content .link-subgallery:hover:before,article.content .link-picture:hover::before {
    width: 100%;
    transition-delay: .4s
}
.news-article-back-col {
    text-align: right;  order: 4;
}
.news-article-photo-col {
    order: 2;
}
.news-article-share-col {
    order: 3;
}
.news-article-body-col.Actualits {
    order: 1;
}
article.content span.title-subgallery {
    color: var(--bs-body-bg);
    position: absolute;
    left: 5px;
    right: 5px;
    top: auto;
    bottom: 5px;
    background: var(--bs-primary-color);
    text-align: center;
    text-transform: uppercase;
    font-size: 1.6em;
    line-height: 1.5em;
    font-family: var(--bs-titles-font-family);
    box-shadow: 0 0 10px rgba(0,0,0,.2);
    transition: background .4s,transform .4s
}
ul.contact-news {
  margin: 30px 0 0;
  background: #0000000f;
  padding: 15px !important;
 
}
ul.contact-news li{
  

}
article.content .link-picture span.title-picture,article.content .link-picture span.text-picture {
    position: absolute;
    z-index: 10;
    left: 50px;
    right: 50px;
    bottom: 0;
    text-align: center;
    color: var(--bs-secondary-bg);
    display: block!important;
    opacity: 0;
    transition: bottom .6s,opacity .6s;
    transition-delay: 0
}

article.content .link-subgallery:hover span.title-subgallery {
    background: rgba(0,0,0,.75);
    transform: translate(10px,-10px)
}

article.content .link-picture span.title-picture {
    color: var(--bs-body-bg);
    text-transform: uppercase
}

article.content .link-picture:hover span.text-picture,article.content .link-picture:hover span.title-picture {
    bottom: 50px;
    opacity: 1;
    transition-delay: .4s
}

article.content .link-picture:hover span.title-picture {
    bottom: 70px
}

article.content .grid-gallery:after {
    content: '';
    display: block;
    clear: both
}

article.content .grid-sizer,.grid-item {
    width: 25%
}

.grid-item {
    margin-bottom: 2px
}

article.content .grid-item {
    float: left
}

article.content .grid-item img {
    display: block;
    width: 100%;
    max-width: 100%
}
section.contact-bottom {
    position: relative;
    background: url(../images/bg-news.jpg) top center no-repeat;
    padding-block: 80px;
    text-align: center;
    
    z-index: 0;
}
section.contact-bottom:before {
	content:'';
    position: absolute;
    z-index: 0;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
	background-image: linear-gradient(to bottom, #3c8aa1, #55aa37);
	z-index: -1;
	opacity: .8;
}
section.contact-bottom h3 {
 color: #fff;
 font-size: 40px;
 margin-bottom: 25px;
}

section.contact-bottom a  {
 color: #22303c;
 font-size: 24px;
 padding: 10px 20px;
 text-decoration: none;
 background: #fff;
}
section.contact-bottom a:hover {
 background: #22303c;
 color: #fff;
}

section.prestations {
    clear: both
}

section.prestations .box h3 {
    font-weight: 500;
    font-size: 21px;
    color: var(--light-color);
    font-family: var(--bs-body-font-family);
    letter-spacing: .06em;
    margin: 18px 0 0
}

.bg-boxes {
    background: var(--bs-body-bg) url(../images/bg-boxes2.webp) no-repeat bottom center
}

section.boxes {
    padding: 245px 0 50px
}

section.boxes:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 550px;
    background: url(../images/bg-boxes.webp) no-repeat center
}

section.boxes:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 550px;
    background: #000 url(../images/after-bx.webp) no-repeat top center
}

section.boxes .box {
    height: 500px
}

section.boxes .box:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 12px;
    right: 12px;
    background: url(../images/img-layer.webp) no-repeat center;
    transition: all .4s;
    background-size: cover;
    z-index: 1
}

section.boxes .box:hover:before {
    background: url(../images/img-layer-h.webp) no-repeat center;
    background-size: cover
}

section.boxes .box .text-bx p {
    height: 0;
    opacity: 0;
    transition: all .4s
}

section.boxes .box:hover p {
    height: auto;
    opacity: 1;
    padding-top: 20px
}

section.boxes h2 {
    font-size: 25px;
    color: var(--bs-body-bg);
    position: relative;
    padding: 0 30px 0 0;
    font-weight: 600;
    margin: 0
}

section.boxes h2:before {
    content: "";
    position: relative;
    display: block;
    height: 54px;
    width: 51px;
    background-position: bottom center;
    background-repeat: no-repeat;
    margin: 0 0 12px
}

section.boxes h2:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 3px;
    width: 25px;
    height: 25px;
    background: url(../images/plus.webp) no-repeat center
}

section.boxes .box:hover h2:after {
    background: url(../images/plus-h.webp) no-repeat center
}

section.boxes .box01 h2:before {
    background-image: url(../images/ico1.webp)
}

section.boxes .box02 h2:before {
    background-image: url(../images/ico2.webp)
}

section.boxes .box03 h2:before {
    background-image: url(../images/ico3.webp)
}

section.boxes .box04 h2:before {
    background-image: url(../images/ico4.webp)
}

section.boxes .box05 h2:before {
    background-image: url(../images/ico5.webp)
}

section.boxes a {
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    outline: none;
    font-size: 0;
    z-index: 2;
    height: 500px
}

section.boxes .box p:last-of-type {
    margin: 0;
    padding: 0
}
section.boxes-top {
    position: relative;
    min-height: 422px;
    background-image: linear-gradient(to bottom, #3c8aa1, #55aa37);
    border-radius: 10px;
    margin-top: -150px;
    z-index: 3;
    padding-top: 64px;
}
section.boxes-top h3 {margin: 0;text-align: center;font-size: 50px;color: #ffffff;line-height: 1em;}
section.boxes-top h4 {font-size: 20px;color: #ffffff;text-align: center;text-transform: none;font-family: 'Bellota Text-reg';line-height: 1em;letter-spacing: 5px;margin-bottom: 54px;}
section.boxes-top .boxs {max-width: 940px;margin: auto;display: flex;justify-content: space-between;}
section.boxes-top .boxs .bx {position: relative;width: 200px;text-align: center;}
section.boxes-top .boxs .bx .ic{width: 102px;height: 102px;border: 3px solid #fff;margin: auto;border-radius: 50%;}

section.boxes-top .boxs .bx1 .ic{
  background: url(../images/ic1.png) center center no-repeat;
}
section.boxes-top .boxs .bx2 .ic{
  background: url(../images/ic2.png) center center no-repeat;
}
section.boxes-top .boxs .bx3 .ic{
  background: url(../images/ic3.png) center center no-repeat;
}


section.boxes-top .boxs .bx1:hover .ic{
  background: #fff url(../images/ic1-h.png) center center no-repeat;
}
section.boxes-top .boxs .bx2:hover .ic{
  background: #fff url(../images/ic2-h.png) center center no-repeat;
}
section.boxes-top .boxs .bx3:hover .ic{
  background: #fff url(../images/ic3-h.png) center center no-repeat;
}


section.boxes-top .boxs .bx p{font-size: 16px;color: #ffffff;margin: 0;line-height: 22px;margin-top: 22px;}
section.etapes {
    position: relative;
    padding: 30px 0 100px;
    text-align: center
}

section.etapes h3 {
    margin: 0;
    font-size: 20px;
    color: var(--bs-tertiary-color);
    font-weight: 400;
    font-family: var(--bs-body-font-family);
    padding: 30px 0 40px;
    position: relative
}
#lien {
    position: absolute;
    top: 0px;
    left: 0;
    bottom: 0;
	right: 0;
       z-index: 12;
   
}
section.etapes h3 strong {
    font-size: 48px;
    color: var(--bs-primary-color);
    font-weight: 700;
    font-family: var(--bs-titles-font-family);
    line-height: 1.4em
}

section.etapes h3:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    width: 70px;
    height: 6px;
    background: var(--bs-secondary-bg);
    margin: auto
}

section.etapes .etape {
    border-bottom: 2px solid var(--bs-secondary-bg);
    padding-bottom: 80px
}

section.etapes .etape:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 21px;
    width: 2px;
    background: var(--bs-secondary-bg);
    margin: auto;
    transition: all .4s
}

section.etapes .etape h2 {
    margin: 0;
    font-weight: 500;
    font-size: 114px;
    font-family: var(--bs-body-font-family);
    color: var(--bs-tertiary-color);
    line-height: 1.1em;
    transition: all .4s
}

section.etapes .etape h4 {
    font-weight: 600;
    color: var(--bs-tertiary-bg);
    font-size: 31px;
    margin: 0 0 30px;
    line-height: 1.1em
}

section.etapes .etape p {
    margin: 0
}

section.etapes .etape a {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    font-size: 0;
    outline: none
}

section.etapes .etape:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 21px;
    height: 26px;
    width: 26px;
    background: var(--bs-primary-color);
    margin: auto;
    border-radius: 50%;
    transition: all .4s
}

section.etapes .etape:hover:after {
    bottom: 32px
}

section.etapes .etape:hover:before {
    height: 32px
}

section.photo-spacer {
    height: 450px
}
.title-news {
    position: relative;
    text-align: center;
    padding-top: 51px;
}
.title-news h4{
    position: relative;
    text-align: center;
    font-size: 30px;
    color: #22303c;
    background: url(../images/bgh3.png) top center no-repeat;
    padding-top: 85px;
    font-family: 'Bellota Text-reg';
    text-transform: none;
    margin: 0 auto 40px;
    display: table;
}
.title-news h4:hover{
 color: #479874;
}
.title-news .s2{
 font-size: 50px;
 text-transform: uppercase;
 font-family: 'Bellota Text-bold';
 display: inline-block;
 margin-top: 10px;
 background: -webkit-linear-gradient(#3c8aa1, #55aa38);
 -webkit-background-clip: text;
 -webkit-text-fill-color: transparent;
}
section.Home-news {min-height: 476px;background: url(../images/bg-news.jpg) top center no-repeat;padding-top: 107px;}
section.Home-news:before {
  position:absolute;
  content:'';
  height: 5px;
  left: 0;
  right: 0;
  top: -17px;
  background-image: linear-gradient(to right, #53a636, #3b879e);
}
section.Home-news div#AllNews1 {
}

section.Home-news div#AllNews1 .news-col{
}
section.Home-news div#AllNews1 .news-col .Item .photo {
  display: none;
}
section.Home-news div#AllNews1 .news-col .Item:before{position:absolute;content:'';inset:0;border-radius: 10px;background: rgba(255,255,255,.75);z-index: -1;transition: .4s;box-shadow: 0px 0px 15px rgba(0, 0, 0, .2);}
section.Home-news div#AllNews1 .news-col .Item:hover:before{
 background: rgba(255,255,255,1);
 transform: scaleY(1.2);
}
section.Home-news div#AllNews1 .news-col .Item{min-height: 262px;transition:.4s;border-radius: 10px;/* box-shadow: 0px 0px 15px rgba(0,0,0,.2); */padding: 45px 20px 20px 20px;text-align: center;position: relative;}
section.Home-news div#AllNews1 .news-col .Item h3{font-size: 17px;color: #22303c;font-family: 'Bellota Text-bold';text-transform: none;line-height: 1.2em;margin: auto;max-width: 260px;transition: .4s;}
section.Home-news div#AllNews1 .news-col .Item h3 br{
}
section.Home-news div#AllNews1 .news-col .Item:hover h3{
 /* transform: translateY(-19px); */
 margin: -20px auto 0px;
}
section.Home-news div#AllNews1 .news-col .Item:hover .read-more a{
 margin-top: 37px;
}
section.Home-news div#AllNews1 .news-col .Item .date{display: none;}
section.Home-news div#AllNews1 .news-col .Item .news-abstract{font-size: 14px;color: #534949;font-family: 'Bellota Text-reg';letter-spacing: .5px;max-width: 230px;display: inline-block;line-height: 22px;margin-block: 27px 9px;}
section.Home-news div#AllNews1 .news-col .Item .read-more a{background: transparent;border: 0;padding: 0;line-height: 14px;font-family: 'Bellota Text-bold';display: inline-block;background: -webkit-linear-gradient(#3c8aa1, #55aa38);-webkit-background-clip: text;-webkit-text-fill-color: transparent;font-style: italic;border-bottom: 1px solid #51a548;border-radius: 0;font-size: 16px;}
section.Home-news div#AllNews1 .news-col .Item .read-more a:hover{
}
section.services {background: url(../images/bgservices.jpg) top center no-repeat;margin-top: 50px;padding-top: 72px;}
section.services:before {
  position:absolute;
  content:'';
  height: 5px;
  left: 0;
  right: 0;
  top: -13px;
  background-image: linear-gradient(to right, #53a636 , #3b879e);
}
section.services:after {
  position:absolute;
  content:'';
}

section.services h4 {
   position: relative;
   text-align: center;
   font-size: 30px;
   color: #ffffff;
   background: url(../images/bgh3.png) top center no-repeat;
   padding-top: 80px;
   font-family: 'Bellota Text-light';
   text-transform: none;
   margin-bottom: 59px;
}

section.services h4 .s1 {
  font-size: 50px;
  text-transform: uppercase;
  font-family: 'Bellota Text-bold';
  display: inline-block;
  margin-top: 7px;
  background: -webkit-linear-gradient(#3c8aa1, #55aa38);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

section.services .grid-services {
    display: flex;
    justify-content: space-between;
}

section.services .grid-services .box {
    position: relative;
}
section.services .grid-services .box h3 {
  position: absolute;
  z-index: 1;
  bottom: 38px;
  margin: 0;
  color: #fff;
  text-transform: none;
  font-family: 'Bellota Text-reg';
  left: 48px;
  font-size: 30px;
  line-height: 1.2em;
}
section.services .grid-services .box h3:before {
   position:absolute;
   content:'';
   height: 129px;
   width: 1px;
   background: #fff;
   top: -156px;
   left: 8px;
}
section.services .grid-services .box .box-img {
    position:relative;
}
section.services .grid-services .box .box-img:before {
     position:absolute;
     content:'';
     inset: 0;
     background: url(../images/mask-bx.png) top center no-repeat;
     z-index: 1;
     border-radius: 10px;
     background-size: cover;
}
section.services .grid-services .box:hover .box-img:before {
background:#479874;
  opacity:.6;
}
section.services .grid-services .box .box-img img{
    border-radius: 10px;
    box-shadow: 0px 0px 15px rgba(0,0,0,.5);
}

section.contact {
    background: url(../images/bg-contact.webp) center fixed no-repeat
}

section.contact h2 {
    float: left;
    position: relative;
    color: var(--bs-body-bg);
    font-size: 44px;
    margin: 0
}

section.contact .container > div {
    float: right;
    position: relative
}

section.contact .container > div a {
    font-size: 16px;
    line-height: 1;
    text-shadow: none;
    padding: 20px 45px;
    display: inline-block;
    text-decoration: none;
    color: var(--bs-body-bg);
    font-weight: 400;
    text-transform: uppercase;
    box-shadow: none;
    margin: 0;
    border-radius: 30px;
    transition: all .4s;
    background: linear-gradient(to top,var(--bs-primary-color) 0%,var(--bs-primary-color) 50%,var(--bs-body-bg) 50%,var(--bs-body-bg) 100%);
    background-size: 100% 200%;
    background-position: 0 100%;
    transition: background 400ms ease-in-out
}

section.contact .container > div a:hover {
    color: var(--bs-secondary-bg);
    background-position: 0 0
}

section.contact:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: #4d0000
}

.contactForm h3.contact-field {
    display: none
}

.contactForm .contact-field-item {
    margin: 0 0 20px;
    position: relative;
    display: block;
    padding: 0;
    margin-bottom: 20px;
    width: 50%;
    float: left;
    clear: none
}

.contactForm .contact-field-item:nth-child(even) {
    padding-right: 10px
}

.contactForm .contact-field-item:nth-child(odd) {
    padding-left: 10px
}

.contactForm .contact-field-item::placeholder {
    text-transform: uppercase
}

.form-control {
    font-weight: 400;
    line-height: 2em;
    color: var(--bs-body-color);
    background: var(--bs-body-bg);
    border: 1px solid rgba(0,0,0,.2);
    padding: 5px 15px;
    transition: border-color .4s,color .4s;
    border-radius: 0
}

.contactForm .contact-field-item.fullwidth {
    width: 100%;
    padding: 0;
    float: none;
    clear: both
}

.form-control::placeholder {
    color: var(--bs-body-color)!important
}

.contactForm .g-recaptcha {
    float: left
}

.contactForm .contact-submit {
    float: right
}

.contact-col .containerOpening .openingDay {
    font-weight: 700;
    text-transform: uppercase;
    display: inline-block;
    width: 150px
}

.contact-col .containerOpening .openingDay::after {
    content: ': '
}

.gdpr.form-check {
    text-align: left;
    margin: 0 0 10px
}

.contactForm .contact-field-item textarea {
    height: 165px
}

.contactForm .contact-submit .btn-primary {
    font-size: 16px;
    line-height: 30px;
    font-weight: 400;
    color: var(--bs-body-bg);
    text-transform: uppercase;
    padding: 10px 30px;
    background: var(--bs-primary-color);
    border: none;
    border-radius: 30px;
    box-shadow: none;
    transition: background .4s,box-shadow .4s;
    margin: 0
}

.contactForm .contact-submit .btn-primary:hover {
    background: var(--bs-secondary-bg);
    color: var(--bs-body-bg);
    box-shadow: 0 5px 20px rgba(0,0,0,.25)
}

.contactForm .gdpr_policy label {
    font-weight: 400
}

div#AllNews .Item i.fa-duotone.fa-image {
    display: none
}

div#AllNews .Item {
    position: relative;
    width: 100%;
    padding: 15px;
    margin: 10px auto;
    background: var(--bs-nav-link-color);
    overflow: hidden;
}

div#AllNews .news-col {
    width: 100%
}

div#AllNews .Item .photo {
    max-width: 220px!important;
    float: right;
    margin: 0 0 15px 25px;
    height: 100%
}

div#AllNews .Item .date {
    display: none
}

div#AllNews .Item h3 {
    font-size: 22px;
    color: #55aa38;
}

div#AllNews .Item .read-more a {
    font-size: 15px;
    line-height: 1;
    text-shadow: none;
    padding: 13px 20px;
    display: inline-block;
    text-decoration: none;
    color: #fff;
    font-weight: 500;
    background: #3d8c9c;
    text-transform: uppercase;
    box-shadow: none;
    transition: box-shadow .4s;
    margin: 0;
    border-radius: 30px;
    background: linear-gradient(to top,#3d8c9c 0%,#3d8c9c 50%,#53a83e 50%,#53a83e 100%);
    background-size: 100% 200%;
    background-position: 0 100%;
    transition: background 400ms ease-in-out;
    margin-top: 15px;
}

div#AllNews .Item .read-more a:hover {
    background-position: 0 0
}

div#AllNews .Item .date:before {
    content: "- ";
    margin-left: 8px
}

div#AllNews .Item .date {
    color: #000f3c;
    position: relative
}

section.newsletter {
    padding: 100px 0;
    text-align: center;
    background: url(../images/bg-spacer.webp) fixed no-repeat center;
    background-size: cover
}

.form-newsletter label.form-label {
    display: none
}

.form-newsletter {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    grid-gap: 10px
}

section.newsletter .container {
    background: #000
}

.form-newsletter div#gdpr_policy {
    grid-column: 1 / 4;
    display: flex;
    justify-content: center
}

.form-newsletter div#gdpr_policy a {
    color: var(--bs-tertiary-bg)
}

.form-newsletter div#NewsletterSubmitHeader {
    grid-column: 1 / 4;
    text-align: center
}

div#NewsletterSubmitHeader input#subscriber-submit {
    font-family: var(--bs-titles-font-family);
    font-size: 1em;
    font-weight: 400;
    background: var(--bs-primary-color);
    text-transform: uppercase;
    color: var(--bs-body-bg);
    padding: 10px 30px;
    border: none;
    border-radius: 0
}

div#NewsletterSubmitHeader input#subscriber-submit:hover {
    background: var(--bs-nav-link-color-second)
}

section.newsletter .container h3 ~ div {
    padding-left: 30px;
    padding-right: 30px
}

footer.bottom {
      padding: 47px 0 30px;
      background: #22303c;
      min-height: 403px;
      font-size: 15px;
      color: #ffffff;
      font-family: 'Bellota Text-reg';
      letter-spacing: .3px;
      line-height: 29px;
}

footer.bottom .grid-footer{
 display: flex;
 justify-content: space-between;
 text-align: center;
 align-items: flex-start;
 max-width: 1110px;
 margin: auto;
}
footer.bottom .grid-footer .adr{
 background: url(../images/bgadr.png) top center no-repeat;
 padding-top: 86px;
 margin-top: 45px;
}
footer.bottom .grid-footer .infos{
 background: url(../images/bginfos.png) top center no-repeat;
 padding-top: 101px;
 margin-top: 45px;
}footer.bottom a {
  color: #439180;
}


footer.bottom a:hover {
 color: #fff;
}

.footer-b {
    position: fixed;
    bottom: 10px;
    right: 18px;
    color: #40938b;
}

a.btn-cookies-link {
    background-color: var(--bs-primary-color)!important;
    color: var(--bs-body-bg)!important
}

a.btn-cookies-link:hover {
    background-color: var(--bs-secondary-bg)!important
}

#scrollTopBtn {
    position: fixed;
    bottom: 37px;
    right: 21px;
    color: #fff;
    border-radius: 4px;
    opacity: 0;
    background-color: var(--bs-primary-color);
    padding: 6px 12px
}

.modal-content {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color)
}

#scrollTopBtn.Active {
    opacity: 1
}

.btn-cookies-pos,.footer-b,#scrollTopBtn {
    z-index: 1020
}

.carousel-control-next,.carousel-control-prev {
    width: 30px
}

.toast-news {
    width: 800px;
    background: rgba(0,0,0,.85)!important;
    color: var(--bs-body-bg)!important
}

.news-popup-image {
    flex: 0 0 auto;
    width: 33.33333333%
}

.news-popup-text {
    flex: 0 0 auto;
    width: 66.66666667%;
    color: var(--bs-tertiary-color);
    font-size: 1.15em;
    line-height: 1.3em;
    letter-spacing: .1em
}

.toast-header {
    position: relative;
    z-index: 1;
    font-size: 1.5rem;
    background: var(--dark-color)!important;
    color: var(--bs-tertiary-bg)!important
}

.toast-header::before {
    position: absolute;
    content: '';
    z-index: -1;
    right: 7px;
    top: calc(50% - 17px);
    bottom: auto;
    width: 33px;
    background: var(--bs-tertiary-bg);
    border-radius: 50%;
    height: 33px
}

.me-auto {
    font-weight: 300!important
}

.toast-header .btn-close {
    background-size: 40%
}

.news-popup-text small.news-date-popup {
    color: var(--bs-tertiary-bg);
    font-weight: 700
}
@media (min-width: 1400px) {
    .container {
        max-width: 1250px;
    }
}
@media only screen and (max-width : 1400px) {
     .container {
        max-width: 100%;
    }
}



@media only screen and (max-width : 1199.98px) {
 
}
@media only screen and (max-width : 1024px) {
  header.sticky-top a.nav-link {
   
    padding: 19px 5px 13px 5px !important;
    font-size: 14px;
  
 
}
  .img-ct {
    float: none;

    display: table;
    margin: 20px auto 40px;
}
  section.services .grid-services {

    gap: 25px;
}
  header.sticky-top .inner-wrapper {
 
    gap: 10px;

}
}
@media only screen and (max-width : 991.98px) {
    .toast-container {
        left:5%;
        width: 90%!important
    }

    .image-left,.image-right {
        margin: 0 auto 30px!important;
        float: none!important;
        display: table!important;
        max-width: 100%!important
    }

    article.content1 .grid-gallery {
        grid-template-columns: repeat(3,1fr)
    }

    .nav1 {
        display: none!important
    }

    header.sticky-top .navbar-collapse {
        position: absolute;
        top: 125%;
        left: 50%;
        transform: translateX(-50%);
        width: 100vw;
               background: #22303c;
        padding: 10px 0;
        text-align: left;
        z-index: 100
    }

    header.sticky-top .level-0 > li:not(:first-child) {
        margin-left: 0
    }

    header.sticky-top .navbar-collapse li a {
        color: var(--bs-body-bg)!important;
                text-align: center;        display: table;
        margin: auto;
    }

    header.sticky-top .navbar-collapse li a:hover,header.sticky-top .navbar-collapse li a.focus {
        color: var(--bs-primary-color)!important
    }

    header.sticky-top .nav-item .submenu {
        padding: 10px;
        width: 100%;
        background: var(--bs-body-bg);
        border-radius: 5px
    }

    header.sticky-top .dropdown-menu li.nav-item {
        padding: 0
    }

    header.sticky-top .dropdown-menu .nav-link {
        border-bottom: none!important;
        color: var(--bs-secondary-bg)!important;
        padding: 5px
    }

    header.sticky-top .dropdown-menu .nav-link:hover {
        background: var(--border-color)
    }

    header.sticky-top .nav-item .level-2 {
        background: var(--tertiary-color);
        left: 0;
        position: relative
    }

    header.sticky-top li.nav-item {
        padding: 1px 10px
    }

    header.sticky-top .nav-link {
        color: var(--bs-body-bg)
    }

    header.sticky-top .dropdown-toggle::after {
        -webkit-text-stroke: 1px var(--bs-body-bg);
        color: var(--bs-body-bg)
    }

    header.sticky-top .navbar-expand-lg .navbar-nav .dropdown-menu {
        transform: translateX(0%)
    }

    header.sticky-top .dropdown-menu .nav-link {
        text-align: left
    }

    nav.navbar.navbar-expand-lg {
        padding: 15px 0 15px!important
    }

    .sticky-top .logo {
        position: relative!important;
        transform: translateX(0%)!important;
        left: 0!important
    }

    .navbar-toggler {
    }

    .inner-wrapper {
        display: grid;
        grid-template-columns: auto auto;
        justify-content: space-between;
        align-items: center
    }

    header.sticky-top a.nav-link {
        padding: 5px 7px!important
    }

    header.sticky-top .dropdown-menu .nav-link {
        padding: .5em!important
    }

    section.banner .slider {
        width: 100%!important
    }

  

    .slide-box-message {
               right: 15px !important;
        margin-top: 0;
        top: 34px;
    }

.homepage .wrapper .content h1 span.sub-title {
  
    font-size: 40px;
   
}
  section.Home-news div#AllNews1 .news-col .Item h3 {
   
    max-width: 100%;
  
}
  section.Home-news div#AllNews1 .news-col .Item h3 br {
    display: none;
}
  section.Home-news div#AllNews1 .news-col {
    width: 33.33%;
}
}
@media only screen and (max-width : 850px) {
  .content h1 span.sub-title {

    font-size: 30px;

}
  footer.bottom .grid-footer .blc2 {
    
    order:1;
  }
   footer.bottom .grid-footer .blc1 {
    
    order:2;
  }
   footer.bottom .grid-footer .blc3 {
    
    order:3;
  }
      section.Home-news div#AllNews1 .news-col {
        width: 100%;
    
        margin-bottom: 20px;
    }
  section.Home-news {
    min-height: 476px;
    background: url(../images/bg-news.jpg) top center no-repeat;
    padding-top: 50px;
    /* background-size: cover; */
    padding-bottom: 50px;
}
  footer.bottom {
    padding: 30px 0 30px;
  
}footer.bottom .grid-footer .infos {
 
    margin-top: 0;
}section.boxes-top .boxs {
   
    flex-direction: column;
    align-items: center;
    gap: 30px;
}
  .title-news .s2 {
    font-size: 40px;
  
}
    

  section.boxes-top {
  
    padding-top: 40px;
    padding-bottom: 40px;
}
      section.services .grid-services {
        gap: 25px;
        flex-direction: column;
        align-items: center;
    }
  footer.bottom .grid-footer {
 
    flex-direction: column;
    align-items: center;
    gap: 40px;
}footer.bottom .grid-footer .adr {
   
    margin-top: 0;
}
  section.boxes-top h4 {
   
    letter-spacing: 0;
 
}
  section.Home-news div#AllNews1 .news-col .Item {
   
    max-width: 350px;
    margin: auto;
}
  section.boxes-top h3 {
    margin: 0;
 
    font-size: 40px;
 
}
}
@media only screen and (max-width : 767px) {
  .news-article-photo-col {
    order: 1;text-align: center;
}
  .news-article-share-col {
    order: 3;
    width: 50%;
}
  .news-article-back-col {
    text-align: right;
    order: 4;
    width: 50%;
}
  span.d-block.subtitle {
    
    font-size: 30px;

}
    article.content1 .grid-gallery {
        grid-template-columns:repeat(2,1fr)
    }
  .homepage .wrapper .content h1 span.sub-title {
        font-size: 30px;
    }
    .news-popup-text {
        width: 100%
    }

    .contactForm {
        grid-template-columns: repeat(1,1fr)
    }

    .contactForm .contact-field-item.fullwidth,.gdpr.form-check {
        grid-column: 1 / 1
    }

    .contactForm .contact-submit .btn-primary {
        float: left
    }

    div#AllNews .news-col {
        width: 100%
    }

    div#AllNews .Item {
        display: block
    }

    div#AllNews .Item .nophoto,div#AllNews .Item .photo {
        height: 250px
    }

    .phone {
        display: none
    }

    span.phone-responsive {
        display: inline-block
    }

    .slide-box-message h2 {
        font-size: 55px
    }

    section.prestations .box {
        margin: 0 0 30px
    }

    section.boxes {
        padding: 65px 0 50px
    }

    section.etapes .etape {
        margin: 0 0 50px
    }

    section.services .bx {
        margin: 0 0 40px
    }

    section.contact h2 {
        float: none;
        position: relative;
        color: var(--bs-body-bg);
        font-size: 34px;
        margin: 0;
        text-align: center
    }

    section.contact .container > div {
        float: none;
        display: table;
        margin: 10px auto
    }

section.contact-bottom h3 {

    font-size: 34px;

}
  section.contact-bottom a {



    display: inline-block;
}
}

@media only screen and (max-width : 480px) {
    .contact-form .g-recaptcha {
        transform:scale(.8);
        width: 250px;
        transform-origin: left
    }
  
.slide-box-message .cta a {
      font-size: 18px;

    background: transparent;

    border-radius: 10px;
    background-size: contain;
    border: 2px solid #48996e;
}
  section.boxes-top h3 {
  
    font-size: 34px;
  
}
    article.content1 .grid-gallery {
        grid-template-columns: repeat(1,1fr)
    }

    .g-recaptcha {
        width: 280px;
        transform: scale(.8);
        transform-origin: left
    }

    section.gallery-home .grid-gallery {
        grid-template-columns: repeat(1,1fr)
    }

    div#AllNews .Item .news-desc {
        padding: 30px 15px
    }

    .contactForm .contact-field-item {
        width: 100%;
        padding: 0!important
    }

    .homepage .wrapper .content h1 span.sub-title {
        font-size: 42px
    }

    section.etapes .etape h2 {
        font-size: 80px
    }

    section.etapes .etape h4 {
        font-size: 24px
    }

    section.boxes .box {
        min-width: 280px;
        max-width: 280px
    }
}

button.navbar-toggler::after,button.navbar-toggler::before {
    content: '';
    width: 1.5em;
    background: var(--bs-primary-color);
    position: absolute;
    left: 0;
    height: 2px;
    transition: .3s
}

button.navbar-toggler::before {
    top: 0;
    transform: rotate(-32deg);
    transform-origin: right
}

button.navbar-toggler::after {
    bottom: 0;
    transform: rotate(32deg);
    transform-origin: right
}

button.navbar-toggler .navbar-toggler-icon {
    display: block;
    height: 2px;
    background-image: none;
    background-color: var(--bs-primary-color);
    transition: .1s;
    opacity: 1;
    margin: 8px 0
}

button.navbar-toggler[aria-expanded=true] .navbar-toggler-icon {
    opacity: 0
}

button.navbar-toggler[aria-expanded=false]::after,button.navbar-toggler[aria-expanded=false]::before {
    transform: none
}
