/*

Fichier de style charger sur tout le site

*/

@font-face {
  font-family: 'Outfit';
  src: url('../fonts/outfit-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

.outfit {
  font-family: 'Outfit';
}


:root{

    --noir: #000000;

    --bleu : #FC8B00;

    --bleu-h4 : #FF650B;

    --blanc : #ffffff;

    --orange : #FF8900;

    --bleu-logo : #FC8B00;

    --vert-logo : #22AD13;

    --bleu-biz : #FF650B;

    --gris-text : #363636;

    --noir-footer : #021217;

}



.adresse{

    display: none;

}

.top-header{

    padding: 4px 16px 4px 16px;

    background-color: var(--bleu);

     font-family: 'Outfit';

    font-size: 12px;

    font-weight: 500;

    line-height: 18px;

    letter-spacing: 0em;

    text-align: left;

    



}

.top-header>div{

    display: flex;

    align-items: center;

    flex-direction: row;

    flex-wrap: wrap;

    justify-content: space-between;

}

.top-header>div>div{

    display: flex;

    align-items: center;

    flex-direction: row;

    flex-wrap: wrap;

    column-gap: 1em;

}

.top-header p{

    margin-bottom: 0;

}
.top-header p img{
    height: 20px;
}
.top-header a{

    color: var(--blanc);

    text-decoration: none;

    

}



p{

     font-family: 'Outfit';

    font-size: 16px;

    font-weight: 400;

    line-height: 21px;

    letter-spacing: 0em;

    text-align: left;

    color: var(--gris-text);

}

.btn-custom>a{

      font-family: 'Outfit';

    font-size: 18px;

    font-weight: 500;

    line-height: 25px;

    letter-spacing: 0em;

    text-align: center;

    text-decoration: none;

    color: var(--blanc);

        padding: 5px 30px 7px 30px;

    border: 2px solid var(--orange);

    border-radius: 8px;

    transition: all 0.3s ease-in-out;

}

.bottom-header{

    padding: 12px 32px 12px 32px;

}





#mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-block-1 a.mega-menu-logo{

    width: 200px;

}

#mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-block-1 a.mega-menu-logo>img.mega-menu-logo{

    width: 100%;

}



#mega-menu-wrap-primary .mega-menu-toggle + #mega-menu-primary{

    padding: 12px 32px 12px 32px;

    background-color: var(--blanc);

}

.bottom-header>.logo{

    width: 100%;

    max-width: 114px;

}

.navbar-toggler-icon{

    width: unset;

    height: unset;

}

.text-de-ref{

    padding: 24px 32px 24px 32px;

}

.text-de-ref h2, .text-de-ref h3{

    text-align: left;

}

.text-de-ref p {

     font-family: 'Outfit';

    font-size: 16px;

    font-weight: 500;

    line-height: 24px;

    letter-spacing: 0em;

    text-align: left;

}

div.btn-voir-plus{



    margin-top: 32px;

    color: var(--blanc);

}

div.btn-voir-plus>a{

    padding: 5px 30px 7px 30px;
    border: 3px solid var(--bleu-logo);
    border-radius: 5px;

  font-family: 'Outfit';

    font-weight: 700;

    font-size: 18px;

    line-height: 25.2px;

    text-align: center;

    color: var(--blanc);

    background-color: var(--bleu-logo);

    text-decoration: none;

    cursor: pointer;

    display:inline-block

}

footer{

    background-color: var(--noir-footer);

    padding: 64px 32px 1px 32px;

}

.div-footer{

    display: flex;

    flex-direction: column;

    justify-content: space-between;

    align-items: start;

}



footer p{

    color: var(--blanc);

}

footer hr{

    border-top: 2px solid var(--bleu-logo);

    opacity: 1;

}

footer .follow-us{

     font-family: 'Outfit';

    font-size: 18px;

    font-weight: 600;

    line-height: 27px;

    letter-spacing: 0em;

    text-align: left;

    margin-bottom: 10px;

}

.rs-footer{

    display: flex;

    flex-direction: row;

    flex-wrap: wrap;

    align-items: center;

    column-gap: 1rem;

    margin-bottom: 10px;

}

.rs-footer>a{

    background-color: var(--bleu-logo);

    border-radius: 50%;

    width: 32px;

    height: 32px;

    display: flex;

    align-items: center;

    justify-content: center;

}

.ctn, .props, .domaine{

     font-family: 'Outfit';

    font-size: 16px;

    font-weight: 600;

    line-height: 24px;

    letter-spacing: 0em;

    text-align: left;

  font-family: 'Outfit';

    font-size: 16px;

    font-weight: 600;

    line-height: 24px;

    letter-spacing: 0em;

    text-align: left;



}

.desc-courte{

    font-weight: 500;

}

footer .ctn-div, footer .domaine-div, footer .props-div{

    margin: 20px 0;

}

footer .ctn-div a, footer .domaine-div a, footer .props-div a{

    color: var(--blanc);

    text-decoration: none;

     font-family: 'Outfit';

    font-size: 14px;

    font-weight: 400;

    line-height: 21px;

    letter-spacing: 0em;

    text-align: left;

    

}

.invisible-mobile{

    display: none;

}

.aussi{

    margin-top: 72px;

    margin-bottom: 32px;

}
.chiffre-cle-container>div>img {
    margin-top: 1rem;
}
.avis {

    width: 85%;

    margin: 0 auto;

    box-shadow: 0px 4px 6px -1px #0000001A;

    /* box-shadow: 0px 2px 4px -2px #00000080; */

    border-radius: 16px;

    padding: 28px 20px 28px 20px;

    border: 1px solid rgb(0 0 0 / 5%);

}

.parti-haut-avis{

    display: flex;

    flex-direction: row;

    flex-wrap: wrap;

    justify-content: flex-start;

    align-items: flex-start;

}

.parti-haut-avis>img{

    margin-right: 1rem;

    width: 51px;

    height: 51px;

    object-fit: cover;

    aspect-ratio: 1/1;

}

.parti-haut-avis>div{

    display: flex;

    flex-direction: column;

    flex-wrap: wrap;

}

.titre-avis{

  font-family: 'Outfit';

    font-size: 20px;

    font-weight: 500;

    line-height: 23px;

    letter-spacing: 0em;

    text-align: left;

    color: black;

    margin-bottom: 0;

}

.text-avis{

    margin-top: 0.5rem;

}

.aussi>div{

    display: flex;

    flex-direction: column-reverse;

    row-gap: 30px;

}

.chiffre{

    width: 85%;

    margin: 0 auto;

}

.chiffre-cle-container>div{

    width: 50%;

    display: flex;

    flex-direction: column;

    align-items: center;

}

.chiffre-cle-container{

    display: flex;

    flex-wrap: wrap;

    flex-direction: row;

    justify-content: space-evenly;

}

.chiffre-cle-container>div>p:nth-child(1){

  font-family: 'Outfit';

    font-size: 32px;

    font-weight: 700;

    line-height: 48px;

    letter-spacing: 0em;

    text-align: center;

    color: var(--bleu-logo);

    margin-bottom: 0;

}

.chiffre-cle-container>div>p:nth-child(2){

  font-family: 'Outfit';

    font-size: 16px;

    font-weight: 500;

    line-height: 24px;

    letter-spacing: 0em;

    text-align: center;

    margin-bottom: 0;

}

.conteneur-image-par-quattre{

    display: flex;

    flex-direction: row;

    flex-wrap: wrap;

    justify-content: space-between;

    row-gap: 1rem;

    column-gap: 1rem;


}

.conteneur-image-par-quattre>img{

    width: calc(50% - 0.5rem);

    border-radius: 8px;

}

.conteneur-image-par-quattre>img:nth-child(even){

    transform: translateY(60px);

}



h1{

  font-family: 'Outfit';

    font-size: 40px;

    font-weight: 900;

    line-height: 48px;

    letter-spacing: -0.02em;

    text-align: left;

    text-transform: uppercase;

}

h1>span{

    color: var(--bleu-logo);

}

header{

    border-bottom: 2px solid #FF650B;

    position: sticky;

    top: 0;

    left: 0;

    width: 100%;

    z-index: 99;

    background-color: white;

}
#mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link{
  font-family: 'Outfit';
    font-weight: 400;
}
h1 span.orange{

    color: var(--orange);

}

.btn-custom>a:hover{

    background-color: var(--orange);

    color: var(--blanc);

}

.text-de-ref-section h1, .text-de-ref-section p, .text-de-ref-section h2, .text-de-ref-section h3, .text-de-ref-section h4, .text-de-ref-section h2>span{

    color: var(--noir);
    color: inherit;

}

.text-de-ref-section h2>span.bleu{

    color: var(--bleu-logo);

}

#mega-menu-wrap-primary #mega-menu-primary[data-effect="fade_up"] li.mega-menu-item.mega-toggle-on > ul.mega-sub-menu>li.mega-menu-item{

    width: 100%;

}

#mega-menu-wrap-primary #mega-menu-primary[data-effect="fade_up"] li.mega-menu-item.mega-toggle-on > ul.mega-sub-menu>li.mega-menu-item>a{

    text-align: left;

}

.text-de-ref .cacher-lire-plus, .text-de-ref .cacher-lire-plus span, .cacher-lire-plus{

    display: none;

}

.animation{

    transition: 0.6s;

}

.rs-footer>a>svg path, .rs-footer>a, footer .ctn-div a, footer .domaine-div a, footer .props-div a, .top-header a, .top-header a svg path{

    transition: 0.6s;

}

.rs-footer>a:hover{

    background-color: var(--blanc);

}

.rs-footer>a:hover>svg path{

    fill: var(--bleu-logo);

}

.top-header a:hover svg path{

    fill: #000

}

.top-header a:hover {
    color:#000;
}

footer .ctn-div a:hover, footer .domaine-div a:hover, footer .props-div a:hover{

    color: var(--bleu-logo);

}

#mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link{

    transition: 0.6s;

}

#mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item, #mega-menu-wrap-primary #mega-menu-primary:hover > li.mega-menu-item > a.mega-menu-link:hover{

    color: var(--bleu-logo);

}

#mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-flyout ul.mega-sub-menu li.mega-menu-item a.mega-menu-link{

    transition: 0.6s;

}



.mySwiper2.swiper-3d{

    perspective: 1300px;

}

/* .text-avis p{

    max-width: 300px;

} */

.mySwiper2.swiper-3d{

    max-width: 100%;

}
.container-custo-real {
    max-width: 1350px;
    margin: 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    column-gap: 40px;
    row-gap: 40px;
    padding: 0 32px;
    margin-bottom: 40px;
}
img.img-real {
    flex: 1;
    max-width: calc(100% / 2 - 20px);
    aspect-ratio: 1;
    object-fit: cover;
    cursor: pointer;
}
.overlay {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 70%;
    max-height: 70%;
    cursor: pointer;
}
img.image-en-grand {
    max-width: 100%;
    max-height: 500px;
    object-fit: cover;
    cursor: pointer;
}
.close-button{
    position: absolute;
    top: 0;
    right: 0px;
    width: 20px;
    height: 20px;
    background-color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    cursor: pointer;
}
@media screen and (min-width: 769px){

    .invisible-mobile{

        display: block;

    }

    /* .text-avis p{

        max-width: unset;

    } */

    .bottom-header{

        display: flex;

        justify-content: space-between;

        align-items: center;

    }

    #mega-menu-wrap-primary{

        width: fit-content;

    }

    #mega-menu-wrap-primary .mega-menu-toggle + #mega-menu-primary{

        padding: 0;

    }

    #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item.mega-toggle-on > a.mega-menu-link, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:hover, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link:focus{

        color: var(--noir);

    }



    #mega-menu-wrap-primary #mega-menu-primary li.mega-menu-item, #mega-menu-wrap-primary #mega-menu-primary > li.mega-menu-item > a.mega-menu-link{

        width: fit-content;

    }




    .adresse{

        display: block;

    }

}

@media screen and (min-width:1024px){
    img.img-real{
        max-width: calc(100% / 3 - 30px);
    }
    
    .aussi>div {

        display: flex;

        flex-direction: row;

        flex-wrap: wrap;

        justify-content: space-between;

        align-items: center;

    }

    .chiffre, .mySwiper2{

        width: 45%;

    }

    .chiffre h2{

        text-align: center;

    }

    .chiffre-cle-container>div{

        width: calc(100% / 3 - 1rem);

    }
    
    .div-footer {

        flex-direction: row;

        justify-content: space-between;

        align-items: flex-start;

        flex-wrap: wrap;

        max-width: 1350px;

        margin: 0 auto;

        padding: 0px 32px 0px 32px;

    }

    .div-footer>div:nth-child(1){

        width: 30%;

    }

    .aussi{

        margin-top: 0;

        margin-bottom: 0;

        max-width: 1350px;

        margin: 0 auto;

    }

    .home .aussi{

        margin-top: 32px;

        margin-bottom: 32px;

    }

    .renovation, .intro, .text-de-ref-section{

        max-width: 1350px;

        margin: 0 auto;

    }

    .bottom-header, .max-width-1350{

        margin: 0 auto;

        max-width: 1350px;

    }

    .top-header{

        padding: 0;

    }

    .top-header>div{

        padding: 4px 32px 4px 32px;

    }

}
@media screen and (min-width:1350px){
    .container-custo-real{
        padding: 0;
    }
}


.bottom-header>.logo {
	max-width: 220px;
}

.img-fluid,
.img-fluid img,
.img-fluid picture,
.img-fluid picture img {
	display: block;
	max-width: 100%;
	height: auto;
}

@media screen and (min-width: 1024px) {

	.service>img,
	.service picture {
		width: 48%;
		object-fit: cover;
		border-radius: 8px;
	}


	.renovation>img,
	.renovation>div,
	.renovation>picture {
		width: 48%;
	}

	.renovation>picture>img {
		max-height: 485px;
		object-fit: cover;
		width: 100%;
	}
}

#gform_submit_button_1 {
	color: var(--orange);
	text-decoration: none;
	padding: 16px 32px;
	font-size: 16px;
	line-height: 16px;
	border: 1px solid var(--orange);
	border-radius: 8px;
	background: unset;
}

#gform_submit_button_1:hover {
	color: var(--blanc);
	background-color: var(--orange);
}

.gform-theme--framework .field_sublabel_above .gform-field-label--type-sub {
	font-weight: 500;
	color: #112337;
}

.gform-theme--foundation .gform_footer,
.gform-theme--foundation .gform_page_footer {
	justify-content: center;
}

.gform_heading {
	display: none !important;
}

.service>img,
.service picture img {
	border-radius: 8px;
}

.ctn-tit>img,
.ctn-tit>picture {
	width: 20%;
	max-width: 74px;
	max-height: 74px;
}


.competences p a,
.expertise  p a {
    color:#000
}

.competences p a:hover,
.expertise  p a:hover {
    text-decoration:none
}

a {
    color:var(--bleu-logo);
}

a:hover {
    text-decoration: none
}

.text-de-ref-section h2 {
    font-size:25px;
    line-height: normal;
        margin-bottom:0px;
}

.text-de-ref-section h3 {
    font-size:20px;
    line-height: normal;
    margin-bottom:0px;
}

.gform-theme--foundation .gform_fields {
    row-gap:10px !important;
}


.btn-morineau {
    padding: 5px 30px 7px 30px;
    border: 2px solid var(--bleu-logo);
    border-radius: 5px;
    font-family: 'Outfit';
    font-weight: 500;
    font-size: 18px;
    text-align: center;
    color: var(--blanc);
    background-color: var(--bleu-logo);
    text-decoration: none;
    cursor: pointer;
    display: inline-block;
}

.btn-morineau:hover {
    color: var(--bleu-logo);
    background-color: #FFF 

}

.btn-morineau-outline{
    padding: 5px 30px 7px 30px;
    border: 2px solid var(--bleu-logo);
    border-radius: 5px;
    font-family: 'Outfit';
    font-weight: 500;
    font-size: 18px;
    text-align: center;
    color: var(--bleu-logo);
    background-color:  var(--blanc);
    text-decoration: none;
    cursor: pointer;
    display: inline-block;   
}

.btn-morineau-outline:hover{
    color: var(--blanc);
    background-color:   var(--bleu-logo);
}

.bg-cta-footer,
.depannage-home {
  border-radius: 6px;
}

.bg-cta-footer p,
.depannage-home p,
.depannage-home h2
 {
  color: #fff;
}

.depannage-home p {
    text-align:center;
}

.trombi-card {
    position: relative;
    overflow: hidden;
    border-radius: 1rem;
    background: #EDEDED;
    color: white;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
    display:inline-block;
        padding-bottom: 50px;
}

.trombi-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 25px 50px rgba(253, 139, 0, 0.3);
}

.trombi-card .btn-absolute {
    position: absolute;
    bottom: 5%;
    left: 50%;
    transform: translateX(-50%);
    width:max-content;
}


.trombi-img {
    height: 250px;
    overflow: hidden;
    position: relative;
    background-color: #FFF;
}

.trombi-seminaire .trombi-img {
    height: initial;
}

.trombi-hebergement .trombi-img {
    height: initial;
}

.trombi-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease, filter 0.6s ease;
}

.point-location .trombi-img img,
.trombi-hebergement .trombi-img img {
    object-fit: cover;
}

.trombi-card:hover .trombi-img img {
    transform: scale(1.1) rotate(1deg);
    filter: grayscale(0%);
}

.trombi-content {
    padding: 1.5rem;
    background: #EDEDED
}

.trombi-content li {
    color: #292d32;
}

.trombi-content .name {
    font-size: 1.1rem;
    font-weight: 600;
    color: #292d32;
    margin-bottom: 0.3rem;
    text-align:left;
}

.trombi-content .societe {
    font-size: 0.85rem;
    letter-spacing: 0.5px;
    margin-bottom: 0.25rem;
}

.trombi-content .secteur {
    font-size: 0.75rem;
    color: #1E2120;
    margin-bottom: 1rem;
    font-style: italic;
}

.trombi-content .icons a {
    display: inline-block;
    color: #5a5c4f;
    background: rgba(255, 255, 255, 0.1);
    padding: 0.5rem;
    border-radius: 50%;
    transition: all 0.3s ease;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.trombi-content .icons a:hover {
    background: #5a5c4f;
    color: #fff;
}

.trombi-content .icons a:hover svg path {
    stroke: #fff;
}


.sticky-button {
  display: flex;
  width: 125px;
  height: 125px;
  padding: 15px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 15px;
  position: fixed;
  border-radius: 10px 0 0 10px;
  background: #fff;
  box-shadow: 0 4px 15px 0 rgba(0, 0, 0, 0.1);
  text-decoration: none;
  transition: width 0.3s ease; /* ← animation fluide */
  z-index: 1000;
}


.sticky-button:hover {
  width: 140px;
}

.sticky-button span {
  color: #787899;
  text-align: center;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

.sticky-button.call-button {
  top: 45%;
  right: 0;
}

.depannage-home {
   background: linear-gradient(0deg, rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0.45)), url('/wp-content/uploads/2025/12/cta-morineau-couverture-01.jpg') 
}

@media only screen and (max-width: 768px) {
    #mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-blocks-center {
      display:none
    }

    .expertise,
    .competences {
    padding: 50px 16px 50px 16px !important;
}
}

#backToTop {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 60px;
  height: 60px;
  border: none;
  background: white;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
  opacity: 0;
  transition: opacity 0.3s ease;
  visibility: inherit;
  padding: 0px;
}

#backToTop .arrow-up {
  color: #FC8B00;
  font-size: 1.5rem;
  position: absolute;
}

#backToTop svg {
  position: absolute;
  width: 60px;
  height: 60px;
  transform: rotate(-90deg);
}

#backToTop circle {
  fill: none;
  stroke-width: 5;
}

#backToTop .bg {
  stroke: #eee;
}

#backToTop .progress {
  stroke: #FC8B00;
  stroke-dasharray: 283;
  stroke-dashoffset: 283;
  transition: stroke-dashoffset 0.2s ease-out;
}

.col-inner-ref {
      height: 250px;
    overflow-x: auto;
     -webkit-overflow-scrolling: touch; /* pour un scroll fluide sur iOS */
  scrollbar-width: thin; /* Firefox */
  scrollbar-color: #ccc transparent; /* Firefox */
}

.col-inner-ref h2 {
   text-align:left;
}

.col-inner-ref h3 {
    color: #000;
    font-size:20px;
    line-height:normal
}

#mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-block-2 .mega-toggle-animated-inner, #mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-block-2 .mega-toggle-animated-inner::before, #mega-menu-wrap-primary .mega-menu-toggle .mega-toggle-block-2 .mega-toggle-animated-inner::after {
    background:#FC8B00;
}

.competences .btn-custom a, 
.expertise .btn-custom a {
    background: #FFF;
    color: var(--orange);
}

.competences .btn-custom a:hover, 
.expertise .btn-custom a:hover {
    background: var(--bleu-logo);
    border: 2px solid var(--bleu-logo);
    color: #FFF
}

@media screen and (max-width: 789px) {
.page-id-25 h1 {
	font-size: 27px;
  line-height: 30px;
}
}

@media screen and (max-width: 789px) {
 #backToTop {
    bottom: 4rem;
    right: 1rem;
}
}