#intro_accueil {
	z-index:1;
}
#intro_accueil h1 {
	color:#000000;
}
#intro_accueil h2 {
	color:#344D98;
}
#sticky-interieur {
	width:420px;
	position: fixed;
    background: #FFFFFF;
    display: flex;
    flex-direction: row;
    container-widget-width: calc((1 - var(--container-widget-flex-grow))* 100%);
    container-widget-height: 100%;
    container-widget-flex-grow: 1;
    container-widget-align-self: stretch;
    flex-wrap-mobile: wrap;
    justify-content: center;
    align-items: center;
    gap: 0px 10px;
    row-gap: 0px;
    column-gap: 10px;
    margin-top: 0px;
    margin-bottom: 0px;
    margin-left: 0px;
    margin-right: 0px;
    padding-top: 7px;
    padding-bottom: 7px;
    padding-left: 10px;
    padding-right: 10px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
	z-index:2;
}
#container_logo {
	margin: 0px 15px 0px 15px;
    padding: 5px 20px 5px 0px;
    border-style: solid;
    border-width: 0px 1px 0px 0px;
    border-color: #AAAAAA;
    flex-grow:0;
    flex-shrink: 5;
}
#container_logo img {
	height:90px;
}
#img_menu_interieur {
	margin: 0px 5px 0px 5px;
    padding: 0px 10px 0px 0px;
}
#menu_interieur {
    position: absolute;
    width: 420px;
    margin-top: 0px;
    margin-bottom: 0px;
    top: 108px;
    background:#FFFFFF;
}
#section_presentation {
	position:relative;
    z-index:0;
}
#fond_img_accueil {
    line-height:0;
}
#fond_img_accueil_mobile {
    display:none;
}
#intro_accueil {
	position:absolute;
	width: var(--container-widget-width, 40%);
    max-width: 40%;
    container-widget-width: 40%;
    container-widget-flex-grow: 0;
	left:10%;
    bottom: 15%;
    font-family: "Montserrat", Sans-serif;
    font-weight: normal;
}
#logo_accueil {
    position:absolute;
    top:0;
    left: 42%;
    z-index: 2;
    text-align: center;
    opacity:0;
    animation: slide-down 1.5s ease-out forwards;
}
@keyframes slide-down {
    0% {
      top: 0;
      opacity: 0;
    }
    100% {
      top: 8%; /* Position finale */
      opacity: 1;
    }
}
#logo_accueil img {
    /*width:80%;*/
    width:350px;
}
#section_paves {
    display: flex;
    /*display:none;*/
    padding-top: 0px;
    padding-bottom: 0px;
    padding-left: 0px;
    padding-right: 0px;
    flex-direction: row;
    flex-basis: auto;
    flex-grow: 0;
    flex-shrink: 1;
    justify-content: space-between;
    gap: 0px;
    font-family: "Montserrat", Sans-serif;
    color: #FFFFFF;
    /*transition: margin-left 1.5s ease-out, opacity 1.5s ease-out;*/
    z-index:0;
    font-size:120%;
}
#section_paves.anime {
    margin-left: -100%;
    opacity: 0;
}
#section_paves.visible {
      margin-left:0; /* Position finale */
      opacity: 1;
}
#section_paves h3 {
    font-weight: 600;
    color: #FFFFFF;
    text-align:center;
    margin:0;
    padding: 30px 20px 40px 20px;
}
#section_paves h3 a {
    color: #FFFFFF;
}
#qui_sommes_nous {
    background-image: var(--fond-qui);
    background-position: center center;
    background-size: cover;
    flex:1;
    min-height:400px;
}
#texte_qui_sommes_nous {
    text-align: left;
    max-width: 100%;
    padding: 0px 80px 20px 80px;
}
#notre_savoir_faire {
    background-image: var(--fond-savoir-faire);
    background-position: center center;
    background-size: cover;
    flex:1;
    min-height:400px;
}
#texte_savoir_faire {
    text-align: center;
    font-weight: 500;
    text-transform: uppercase;
    padding: 0px 20px 20px 20px;
}
#nos_references {
    background-image: var(--fond-references);
    background-position: center center;
    background-size: cover;
    flex:1;
    min-height:400px;
}
#nos_references a {
    display:block;
    height:100%;
    color:#FFFFFF;
}
#texte_references {
    text-align: center;
    font-weight: 500;
    text-transform: uppercase;
    padding: 0px 20px 20px 20px;
}
#texte_references li::before {
    content: "";
    background-image:var(--picto-references);
    background-repeat:no-repeat;
    background-size:150px 30px;
    width:30px;
    height:30px;
    display: inline-block;
    position: relative;
    margin:0 5px 0 0;
    vertical-align:bottom;
}
#texte_references li:nth-child(1)::before {
    background-position: 0 0;
}
#texte_references li:nth-child(2)::before {
    background-position: -30px 0;
}
#texte_references li:nth-child(3)::before {
    background-position: -60px 0;
}
#texte_references li:nth-child(4)::before {
    background-position: -90px 0;
}
#texte_references li:nth-child(5)::before {
    background-position: -120px 0;
}
.contenu_texte {
    display: flex;
    flex-direction: row;
    font-family: "Montserrat", Sans-serif;
    color:#000000;
    padding-top: 30px;
    padding-bottom: 20px;
    padding-left: 15%;
    align-items:center;
}
#contenu_source {
    padding-left:0;
    padding-right:15%;
}
#contenu_ia {
    padding-left:0;
    padding-right:15%;
}
#illus_clref {
    position:relative;
    background-image: var(--fond-section2);
    background-position: center center;
    background-size: cover;
    align-self:stretch;
}
#img_resp_section2 {
    display:none;
}
#img_client_reference {
    position: absolute;
    width: auto;
    top: -60px;
    left: 25%;
}
#contenu_clref {
    padding-left:0;
    align-items: self-start;
    margin:20px 0;
}
#texte_clref {
    background:#EEEEEE;
    padding:40px;
}
.contenu_texte h3 {
    color: var(--e-global-color-primary);
    font-size:180%;
    font-weight: 800;
    text-transform: uppercase;
}
.contenu_texte p {
margin-bottom: 20px;
line-height: 160%;
}
.contenu_texte img {
    width:100%;
}
.texte_texte {
    flex:1;
}
.illus_texte {
    flex:1;
}
#parlez_nous {
    font-family: "Montserrat", Sans-serif;
    margin-right: -100%;
    opacity: 0;
    transition: margin-right 1.5s ease-out, opacity 1.5s ease-out;
    z-index:0;
}
#parlez_nous.anime {
    margin-right: -100%;
    opacity: 0;
}
#parlez_nous.visible {
      margin-right:0; /* Position finale */
      opacity: 1;
}
#titre_projet {
    color: var(--e-global-color-primary);
    padding: 80px 40px 10px 40px;
    text-align: center;
}
#titre_projet h3 {
    font-weight: 800;
}
#texte_projet {
    color:#2F96CF;
    width: var(--container-widget-width, 50%);
    margin: 0 auto;
}
#cadre_footer {
    display: grid;
    background: var(--e-global-color-primary);
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(1, 1fr);
    gap: 20px 4px;
    row-gap: 20px;
    column-gap: 4px;
    grid-auto-flow: row;
    justify-items: center;
    align-items: center;
    padding-top: 30px;
    padding-bottom: 30px;
    padding-left: 40px;
    padding-right: 40px;
    font-family: "Montserrat", Sans-serif;
    z-index:0;
}
#cadre_footer a:hover {
    text-decoration:underline;
}
#logo_footer {
    text-align:center;
    align-self:initial;
}
#logo_footer img {
    width:65%;
}
#geo_footer {
    padding: 0px 0px 16px 0px;
    font-weight: bold;
    color:#FFFFFF;
    align-self:flex-end;
    font-size:80%;
}
.liens_footer {
    align-self:flex-end;
}
#bouton_contact_footer {
    color:#000000;
    font-weight:bold;
    align-self:flex-end;
    padding-bottom:10px;
}
#bouton_contact_footer a {
    color:#000000;
    padding: 8px 22px;
    background: #FFFFFF;
    border-radius: 30px;
    display:block;
    font-size:70%;
}
.note_eco a:hover {
    text-decoration:none !important;
}
.ecoindex {
    background:#2f96cf;
    border-radius:30px;
    padding:2px 4px;
}
/* RESPONSIVE */
@media (max-width: 1300px) and (min-width: 769px)  {
    #sticky-interieur {
        width:100vw;
    }
    #section_presentation {
        padding-top:110px;
    }
    #logo_accueil {
        display:none;
    }
    #cadre_footer {
        font-size:80% !important;
    }
    #section_paves {
        flex-direction: column;
    }
}
@media (max-width: 1024px) and (min-width: 767px)  {
#img_client_reference {
    top: -10px;
    left: 10%;
}
}
@media (max-width: 768px)  and (min-width: 768px) {
    #sticky-interieur {
        width:100vw;
    }
    #section_presentation {
        padding-top:127px;
    }
    #logo_accueil {
        display:none;
    }
    #intro_accueil {
        bottom:12%;
    }
    #cadre_footer {
        font-size:50% !important;
    }
    #section_paves {
        flex-direction: column;
    }
}
@media (max-width: 767px) {
    #sticky-interieur {
        width:100vw;
    }
    #section_presentation {
        padding-top:113px;
    }
    #logo_accueil {
        display:none;
    }
    #intro_accueil {
        max-width: 50%;
        width: 50%;
    }
    #section_paves {
        flex-direction: column;
    }
    #texte_qui_sommes_nous {
    padding: 0px 20px 20px 20px;
    }
    #cadre_footer {
        font-size:125% !important;
        grid-template-columns: repeat(1, 1fr);
    }
    #fond_img_accueil {
        display:none;
    }
    #fond_img_accueil_mobile {
        display:block;
        line-height: 0;
    }
    .contenu_texte {
        flex-direction: column;
        padding-left:10px !important;
        padding-right:10px !important;
        justify-content:center;
    }
    #contenu_virtuel {
        flex-direction: column-reverse;
    }
    #contenu_innover {
        flex-direction: column-reverse;
    }
    .illus_texte {
        width: 100%;
    }
    .contenu_texte p {
    line-height: 140%;
    }
    #texte_projet {
        width:90%;
    }
    #contenu_clref {
        padding-left:0px !important;
        padding-right:0px !important;
    }
    #img_resp_section2 {
        display:block;
    }
    #img_client_reference {
        width: 160px;
        top: -40px;
    }
}
/******* ACCUEIL *****************/

@media screen and (max-width: 767px){
#intro_accueil h1 {
	font-size:14px !important;
}
#intro_accueil h2 {
	font-size:12px !important;
}
}
/*#texte_qui_sommes_nous {
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

#texte_qui_sommes_nous:hover {
    opacity: 1;
}
#texte_savoir_faire {
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
	  font-size:130%;
}

#texte_savoir_faire:hover {
    opacity: 1;
}*/
#texte_savoir_faire ul {
   margin:0;
	 padding:0;
}
#texte_savoir_faire li {
    list-style-type:none;
		margin-bottom:10px;
}
#texte_savoir_faire li a {
    color:#FFFFFF;
}
/*
#texte_references {
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

#texte_references:hover {
    opacity: 1;
}*/
#texte_references ul {
    text-align: left;
    margin: 0 20%;
	padding:0;
}
@media screen and (max-width: 1366px){
#texte_references ul {
    margin: 0 10%;
}
}
#texte_references li {
    list-style-type:none;
		margin-bottom:10px;
}
#texte_references li img {
    vertical-align:middle;
}
#texte_references li:nth-child(1) img {
    padding-bottom:4px;
}
#texte_references a {
	color:#FFFFFF;
}
#texte_references a:hover {
	color:#FFFFFF;
	text-decoration:underline;
}
#titre_projet h3 {
	font-size:260%;
	line-height:120%;
}
#texte_projet {
	font-size:120%;
}
#bouton_projet .elementor-button-text {
	font-size:120%;
}
@media screen and (max-width: 1024px){
#intro_accueil h1 {
	font-size:160%;
}
#intro_accueil h2 {
	font-size:140%;
}
}
@media screen and (min-width: 1921px){
#fond_img_accueil img {
	width:100% !important;
}
}
