/*
Theme Name: Licorne
Theme URI: 
Author: Audouin Réalisations
Author URI: 
Description: Thème
Requires at least: WordPress 5.0
Version: 1.0
*/

.photo_vehicule{
	display:flex;
	flex-wrap: wrap;
	justify-content: center;
    margin: 2% 0%;
}

.global_vehicule{
	padding-top:4%;
}

body .global_vehicule h2{
	text-align:center;
	margin-bottom: 1% !important;
}

.inner_global_vehicule{
	display:flex;
	flex-wrap: wrap;
}

#footer .container{
	display: flex;
    max-width: 1400px;
    margin: auto;
    width: 100%;
}


#footer .container .bloc_widget{
	flex:0 0 24%;
}

#footer{
	background-color: #111827;
}

#footer{
	color:#fff !important;;
}

#footer a{
	color:#fff !important;;
}

.row_electricite .single_formation{
	border-bottom: solid #D4A017;
	background: linear-gradient(-0deg, #D4A017 48%, #fff 48%);
    background-size: 2500% 300%;
	transition:all linear 0.3s;
	background-position:  top;
}

.row_electricite .single_formation:hover{
	color:#fff;
	background-position: bottom;
}

body .row_electricite h3{
	color:#D4A017;
	font-size: 22px;
    text-align: center;
}

body .row_electricite h3 strong{
	background-color: #D4A017;
    color: #fff;
    padding: 5px;
}

body .row_formation  p{
	font-size:15px;
}
.row_incendie .cat-block__list,
.row_ergonomie .cat-block__list {
    background-color: #fdfaf7;
    border-radius: 12px;
}

.row_ergonomie .single_formation{
	border-bottom: solid #6363f9;
	background: linear-gradient(-0deg, #6363f9 48%, #fff 48%);
    background-size: 2500% 300%;
	transition:all linear 0.3s;
	background-position:  top;
}

.row_ergonomie .single_formation:hover{
	color:#fff;
	background-position: bottom;
}

body .row_ergonomie  h3{
	color:#6363f9;
	font-size: 22px;
    text-align: center;
}

body .row_ergonomie h3 strong{
	background-color: #6363f9;
    color: #fff;
    padding: 5px;
}

.row_incendie .single_formation{
	border-bottom: solid #cb2228;
	background: linear-gradient(-0deg, #cb2228 48%, #fff 48%);
    background-size: 2500% 300%;
	transition:all linear 0.3s;
	background-position:  top;
}

.row_incendie .single_formation:hover{
	color:#fff;
	background-position: bottom;
}

body .row_incendie h3{
	color:#cb2228;
	font-size: 22px;
    text-align: center;
}

.stats-desc{
	display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}

.color_blue .stats-number {
	color: #6363f9 !important;
}

.color_blue .counter_suffix  {
	color: #6363f9 !important;
}

.color_red .stats-number{
	color: #cb2228 !important;
}

.color_red .counter_suffix {
	color: #cb2228 !important;
}

.stats-desc .stats-number{
	order: 2;
}

.stats-desc .counter_suffix {
	order: 3;
}

.stats-desc .stats-text{
	    order: 1;
    flex: 0 0 100%;
}

body .row_incendie h3 strong{
	background-color: #cb2228;
    color: #fff;
    padding: 5px;
}


.row_secourisme .single_formation{
	border-bottom: solid #03ab30;
	background: linear-gradient(-0deg, #03ab30 48%, #fff 48%);
    background-size: 2500% 300%;
	transition:all linear 0.3s;
	background-position:  top;
}

.row_secourisme .single_formation:hover{
	color:#fff;
	background-position: bottom;
}

body .row_secourisme h3{
	color:#03ab30;
	font-size: 22px;
    text-align: center;
}

body .row_secourisme h3 strong{
	background-color: #03ab30;
    color: #fff;
    padding: 5px;
}

.vehicule_little_global{
	display: flex;
    flex: 0 0 100%;
	flex-wrap: wrap;
	margin-bottom: 8%;
}

.info_vehicule{
	flex: 0 0 100%;
}

.info_vehicule h4{
	color: #000000;
    padding: 5px;
    text-align: center;
    margin-top: 0%;
    font-size: 30px;
}

.all_little_photos{
	display: flex;
	flex: 0 0 100%;
    max-width: 100%;
	margin: 0% 1%;
	margin-top: 30px;
	justify-content: center;
}

.all_little_photos div{
	margin-right:10px;
}

.all_little_photos div:last-child{
	margin-right:0px;
}

.all_little_photos img{
	max-height:100px;
	margin: 2px 0px;
	max-width:100%;
	width: 100%;
	cursor:pointer;
}

.description_top{
	display: flex;
    justify-content: space-evenly;
	max-width:50%;
	margin:auto;
    align-items: center;
}

.description_top p{
	margin-bottom:0% !important;
}

.km_vehicule{
	font-weight: 600;
}

.description_bottom{
	margin-top:25px;
	max-width: 50%;
    margin: auto;
    text-align: center;
}

.prix_vehicule{
	width: max-content;
    color: #cb2228;
    padding: 5px 20px;
    font-size: 25px;
    font-weight: 600;
}

.global_vehicule span{
	color:#cb2228;
	display: block;
    text-align: center;
    margin-bottom: 3%;
    font-size: 88px;
    line-height: 40px;
}

body .menu .btn a{
	background: linear-gradient(-45deg, #b825ce, #b825ce,#dd4f21, #b825ce, #424242 );
    background-size: 400% 400%;
    animation: gradient 4s ease infinite;
    padding: 15px 36px;
    border-radius: 50px;
    display: block;
    color: #fff;	
	transition: all linear 0.3s;
}

body .menu .btn a:hover{
	color:#fff;
	transform: scale(1.1);
}

body div#sd-cmp div{
	font-size: 14px !important;
}

table {
	border:0;
	margin: auto;
	border-top: solid 1px #cfcece;
	border-left: solid 1px #cfcece;
}
table td{
	border-right: solid 1px #cfcece;
    border-bottom: solid 1px #cfcece;
	padding:10px;
}
table caption{
	font-size:12px;
	line-height: 15px;
    margin-bottom: 10px;
	margin-top: 20px;
}
.slider_realisations img{
	width:100%;
}

.area{
    background: #4e54c8;  
    background: -webkit-linear-gradient(to left, #8f94fb, #4e54c8);  
    width: 100%;
    height:100vh;
    
   
}



.circles{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}



.circles li{
    position: absolute;
    display: block;
    list-style: none;
    width: 20px;
    height: 20px;
	background: rgb(184 37 206);
    animation: animate 25s linear infinite;
    bottom: -350px;
    
}



.slider div hr{
	    max-width: 60%;
    margin-top: 6%;
    background-color: #0000001f;
    height: 1px;
    border: none;
}





@keyframes animate {

    0%{
        transform: translateY(0) rotate(0deg);
        opacity: 1;
        border-radius: 0;
    }

    100%{
        transform: translateY(-1000px) rotate(720deg);
        opacity: 0;
        border-radius: 50%;
    }

}


.img_avis_animation{
    color: #fcbf02;
    width:85px;
	position:absolute;
    max-width: 1400px;
    margin: auto;
	animation: avis_img 10s linear infinite;
}

.avis_footer{
	position:relative;
}
.bloc_article {
	background-color: #d2d2d233;
    padding: 5%;
    margin-bottom: 2em !important;
    color: #565454;
    border: dashed 2px #878787;
}
.bloc_article a {
    color: #565454;
	padding-left: 10px;
}
.bloc_article a:hover {
	color: #a60fbd !important;
}
.bloc_article ul {
  list-style: none; 
}

@keyframes avis_img {
	0%{
		left:2%;
		top:-5%;
		transform: rotate(0deg);
		opacity:1;
	}
	
	12%{
		left:2%;
		top:87%;
	}
	
	24%{
		left:13%;
		top:30%;
	}
	
	36%{
		left:25%;
		top:87%;
	}
	
	48%{
		left:37%;
		top:40%;
	}
	
	60%{
		left:49%;
		top:87%;
	}
	
	72%{
		left:61%;
		top:50%;
	}
	
	84%{
		left:76%;
		top:87%;
		opacity:1;
	}
	
	100%{
		left:95%;
		top:80%;
		opacity:0;
		transform: rotate(2500deg);
	}

	
}

.vc_col-has-fill>.vc_column-inner, .vc_row-has-fill+.vc_row-full-width+.vc_row>.vc_column_container>.vc_column-inner, .vc_row-has-fill+.vc_row>.vc_column_container>.vc_column-inner, .vc_row-has-fill>.vc_column_container>.vc_column-inner{
	padding-top:0% !important;
}

body h2{
	color: #1d1d1b;
    font-family: "Barlow Condensed", sans-serif;
    font-weight: 500;
	margin-top: 0%;
	font-size: 35px;
    font-weight: 700;
	line-height:normal;
}

body h3{
    margin-top: 0%;
    margin-bottom: 1%;
    font-size: 18px;
    font-weight: 600;
    color: #cb2228;
}

.row_formation p strong{
    text-decoration: underline;
}

header.sticky.active {
    border-bottom: solid 1px #d9d9d9;
}

header.sticky.active #global_header{
	background-color:#fff;
	padding:10px 0px;
}

.banniere_page{
	height: 600px;
	background-size:cover;
	background-position:center;
	background-repeat:no-repeat;
}

header.sticky.active #logo img {
	max-width: 230px;
}

header.sticky #global_header {
    position: fixed;
    top: 4%;
    width: 100%;
    z-index: 9999;
	transition: all linear 0.2s;
}

header.sticky.active #global_header {
    top: 0%;
}

.little_image_produit img{
	cursor:pointer;
}

body{
	font-size:18px;
	color: #444444;
	font-family: 'Nunito Sans', sans-serif;
}

.banner_right h4{
	font-weight: 400;
    color: #dd5120;
    font-size: 15px;
    letter-spacing: 1px;
	margin-bottom:0%;
}


.msg_copy{
	display: block;
    color: #dd5120;
    font-size: 14px;
    margin-top: 10px;
}

.banner_right .vc_column-inner .wpb_wrapper .wpb_wrapper{
	background-color: transparent;
}

.global_vignette img{
	max-width:37px !important;
	margin-bottom:15px;
}

.color_title p{
	color: #209a9c;
}

ul li{ 
	line-height: 21px;
    font-size: 17px;
	list-style: circle;
}

.row_half .wpb_column .vc_column-inner{
	background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: right;
	min-height: 215px;
}

.avis_footer{
	padding:6% 0%;
}

.bg_left_bottom {
	background-position:left bottom;
	background-repeat:no-repeat;
	background-size:contain;
}

#contact_form_subtitle p{
	color: #3a3a3a;
    text-align: center;
    font-weight: 600;
	margin-bottom: 3%;
}
	

.bg_yellow{
	background-color:#f4e661;
}

.bg_grey{
	background-color:#f8f8f8;
}

.row_half_second{
	justify-content: space-evenly;
    display: flex;
}

.row_half_second.vc_row:after,.row_half_second.vc_row:before {
    display:none;
}

.row_half_second .wpb_column {
	 flex:0 0 48%;
	max-width:48%;
}


.row_half .title_bloc{
	padding-bottom:30px;
}

.row_half .wpb_wrapper{
	max-width:55%;
}

.row_half .wpb_column {
    flex:0 0 48%;
	max-width:48%;
	flex: 0 0 49%;
    max-width: 49%;
    margin-bottom: 2%;
    border-radius: 6px;
    padding: 3% 2% 3% 3%;
	margin-bottom:1% !important;
}

.row_half .wpb_column.yelow {
	background-color: #ffe476b5;
}

.row_half .wpb_column.orange {
	background-color: #f0564ab0;
}

.row_half .wpb_column.violet {
	background-color: #f5b4ff;
}

.row_half .wpb_column.bleu {
	background-color: #7ed8ffa6;
}

body .row_half::before{
	display:none;
}

body .row_half::after{
	display:none;
}

.row_half  {
	display:flex;
	justify-content: space-between;
}


.three_bloc .wpb_text_column{
	padding-top: 15px;
}

.three_bloc h3{
    font-weight: 300;
    font-size: 27px;
}

.burger{ 
	display:none;
}

body h1{
	color: #1e2130;
    font-family: "Barlow Condensed", sans-serif;
	margin-top: 0%;
	font-size: 60px;
    font-weight: 700;
}

.wpb-content-wrapper ul li{ 
	list-style:none;
	display: flex;
    align-items: center;
	margin-bottom: 5px;
}

ul{ 
	padding-left: 0%;
}

.wpb-content-wrapper ul li::before{ 
	content:'\e5df';
	font-family: 'Material Symbols Outlined';
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
	color: #cb2228;
}
/* Désactiver la flèche sur les pages catégorie formation */
.fcat-page .wpb-content-wrapper ul li::before {
	content: none;
	display: none;
}

.bloc_fonce .wpb_column {
    background-color: #fff;
    padding: 10px 30px !important;
}

.bloc_fonce_half .col_white{
    background-color: #fff;
    padding: 45px !important;
}
	


form span.wpcf7-list-item.first.last{
	display: flex;
	font-size: 13px;
    font-style: italic;
}

body .wpcf7 form.sent .wpcf7-response-output {
    border-color: #46b450 !important;
    color: #000 !important;
    padding: 10px !important;
}

form span.wpcf7-list-item.first.last input{
	width: max-content;
    margin-right: 10px;
}

/* GLOBAL CSS*/

.slick-track figure{
	width:100%;
}

.slick-track .vc_single_image-wrapper{
	width:100%;
}

.slick-track .vc_single_image-wrapper img{
	width:100%;
}

.bloc_title{
	margin-bottom: 4% !important;
}

.global_all_fiche_produit {
    background-color: #f8f8f8;
}

#top_panel{
	background-color: #282828;
    padding: 10px 0px;
}

#top_panel .container{
	display: flex;
    justify-content: flex-end;
}

#top_panel a{
	color: #209a9c;
	font-size: 14px;
    font-weight: 300;
    padding: 0% 1.5%;
}

.description_produit_top {
    /*width: 1240px;*/
	padding-bottom:7%;
    margin: auto;
}

.global_fiche_produit {
    display: flex;
	padding-top:7%;
}

.ariane_container{
	background-color: #ededed;
}

body #breadcrumbs{
	font-size:14px;
	padding: 0.5rem 0;
	margin-bottom:0;
}

.global_img_product{
	max-width:48%;
	flex:0 0 48%;
}


.little_image_produit{ 
	display:flex;
	justify-content: space-between;
}

.bx-wrapper{
	background-color:transparent !important;
}

.slider_produit div{
	background-color:#fff;
	height: 100px;
    display: flex;
}

.little_image_produit div img{ 
	max-width:100%;
	max-height:100px;
	margin:auto;
}

body #breadcrumbs a{
	color:#3e3e3e;
	font-style:italic;
}

.breadcrumb_last{
	color: #dd4f21;
}

.global_onglets{
	padding:2% 3%;
	background-color:#fff;
	border-top: solid 12px #bd3c0f;
	margin-right: 2%;
}

.btn_copy{
	font-size: 13px;
    color: #fff;
    background-color: #dd5120;
    padding: 5px 10px;
	cursor:pointer;
}

.contenu_application {
	display:flex;
}

.contenu_application img{
	max-width:48%;
}

.global_btn_copy{
	text-align:right;
}

.contenu_onglets .onglet.active{
	background-color: #000;
    color: #fff; 
}

.contenu_onglets .onglet{
	display: block;
    width: max-content;
	cursor:pointer;
	transition: all linear 0.5s;
	padding: 10px 15px;
    margin-right: 15px;
	/*border-radius: 5px;*/
	background-color: #f2f2f2;
}

.contact_produit{
	border-top: solid 1px #dd512038;
    padding-top: 25px;
    margin-top: 31px;
    padding-bottom: 25px;
}

.contact_produit a{
	border: solid 1px #dd5120;
    color: #dd5120;
    padding: 1rem;
    font-size: 20px;
    transition: all linear 0.5s;
    display: block;
    text-align: center;
	background: linear-gradient(to right, #dd4f21 50%, transparent 50%) !important;
    background-size: 200% 100% !important;
    background-position: right bottom !important;
    transition: all .5s ease-out;
}

.contact_produit a:hover{
	background-position: left bottom !important;
	color:#fff;

}

.vignette_avis_google {
    background-color: #fff;
    border-radius: 5px;
    padding: 8px;
    display: flex;
    align-items: center;
    margin-right: 20px;
    width: max-content;
	border: solid 2px #cb2228;
}

.right_img .vc_column-inner{
	min-height: 700px;
}

.bloc_rouge_abs{
	box-shadow: inset 0 0 0 500px #cb2228de;
	color:#fff;
	padding-top:2%;
	padding-bottom:2%;
}

.bloc_rouge_abs p{
	font-weight:600;
}

.bg_opacity .upb_row_bg {
	opacity: 0.2;
}

.global_formation{
	display: flex;
    flex-wrap: wrap;
	margin-top: 2%;
}

.single_formation{
	flex: 0 0 29.5%;
    max-width: 29.5%;
    box-shadow: 0px 14px 34px 0px rgb(0 0 0 / 20%);
    background-color: #fff !important;
    border-radius: 8px;
    padding: 1% 1.5%;
   
	margin-bottom: 1% !important;
   
}

.single_formation:nth-child(3n+2){
	 margin-right: 1%;
	  margin-left: 1%;
}


.bloc_rouge_abs h2{
	color:#fff;
}

.abs_col .vc_column-inner{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: -10%;
	z-index: 9 !important;
}

.global_avis_banner .logo img {
    width: 40px;
}

.etoile img {
    width: 17px;
}

.vignette_avis_google p {
	font-size: 14px;
    line-height: 17px;
    color: #cb2228;
    font-weight: 600;
}

.global_avis_banner .logo {
    margin-right: 10px;
    padding-right: 10px;
    border-right: 1px #9ea8e3 solid;
}

.contenu.active{
	display:block;
}

.contenu_onglets{
	display:flex;
	border-bottom: solid 1px #dd512038;
    padding-bottom: 20px;
}

.description_fiche_produit h1{
	text-align:left;
	color: #dd5120;
    font-size: 40px;  
	line-height: initial;
	margin-bottom:15px;
}

.description_longue{
    border-top: solid 1px #dd512038;
    border-bottom: solid 1px #dd512038;
    padding-top: 25px;
    padding-bottom: 25px;
	margin-bottom: 25px;
	font-size: 16px;
    line-height: 23px;
}

.button_produit a{
	background-color: #000;
    color: #fff;
    padding: 10px 30px;
    font-size: 15px;
	transition:all linear 0.5s;
	margin-right:1rem;
	padding-left:20px;
	display:inline-block;
}

.button_produit a i{
	padding-right:10px;
}

.button_produit a:hover{
	background-color: #dd5120;
    color: #fff;
}

.little_global_fiche_produit {
    margin-top: auto;
    margin-bottom: auto;
	display: flex;
    justify-content: space-between;
}

.align_middle .wpb_wrapper{
	display: flex;
	margin-top: 20px;
    align-items: center;
}

.global_fiche_produit .titre_fiche_produit {
    margin-bottom: 4%;
}

.description_fiche_produit{
	flex:0 0 48%;
}

.logo_fournisseur {
    margin-top: 3%;
}

.image_fiche_produit {
    flex: 1;
    display: flex;
    justify-content: center;
    padding: 2%;
}

.single .titre_fiche_produit h1 {
    font-weight: 100;
    max-width: 100%;
    margin: 0;
    margin-bottom: 3%;
    line-height: 40px;
	text-align:left;
}

.description_produit_middle {
    margin: auto;
    display: flex;
    margin-top: 4%  !important;
    margin-bottom: 4% !important;
}

.table_produit {
    margin-right: 5%;
    width: 68%;
    max-width: 68%;
}

.global_description_produit_long {
    width: 1240px;
    margin: auto;
    display: flex;
}

.description_produit_long {
    flex: 2;
    font-size: 15px;
    width: 68%;
    max-width: 68%;
    margin-bottom: 4%;
}

.global_table_produit {
    border: solid 1px #e1e1e1;
}

.row_table {
    display: flex;
}

.global_table_produit .table_left {
    border-right: solid 1px #e1e1e1;
}

.row_table > div {
    padding: 4%;
}

.table_left {
    flex: 1;
}

.row_table div p {
    margin-bottom: 0%;
    font-size: 14px;
    font-weight: 500;
    word-break: keep-all;
}

.table_right {
    flex: 3;
}

.table_right p{
    font-size: 14px !important;
    font-weight: 300 !important;
}


.row_table.middle {
    border-top: solid 1px #e1e1e1;
    border-bottom: solid 1px #e1e1e1;
}

.global_donnees_techniques {
    margin: auto;
    margin-bottom: 4% !important;
    margin-top: 4% !important;
}

.document_produit {
    background-color: #f8f8f8;
}

.bx-wrapper{
	margin-bottom:0px !important;
}
.etiquette{
	padding: 2px 8px;
    color: #fff;
    text-transform: uppercase;
    font-size: 14px;
	margin-bottom: 10px;
	width: max-content;
}

.logo_etiquette{
    display: flex;
    flex-direction: column;
}

.etiquette.defense{
	background-color: #489d39;
}

.etiquette.nucleaire-demantelement{
	background-color: #ef562d;
}

.etiquette.tertiaire{
	background-color: #3b636b;
}

.etiquette.pharmaceutique-laboratoire-salle-propre{
	background-color: #209a9c;
}

.document_produit p a {
    color: #565656;
}

.document_produit p a img {
    margin-right: 15px;
    vertical-align: middle;
}

.document_produit p {
    text-align: center;
    font-size: 14px;
    font-weight: 300;
    margin-bottom: 0%;
    padding: 1%;
}

.donnees_techniques {
    font-size: 14px;
    font-weight: 300;
}

.donnees_techniques h3 {
    color: #626262;
    font-size: 15px;
    font-weight: 300;
}

.description_donnees_technique {
    background-color: #f8f8f8;
    border-top: solid 1px #d3d3d3;
 padding: 2%;
}

.titre_fiche_produit h1 {
    color: #2e2e2e;
    font-size: 24px;
	text-align:left;
}

@keyframes fondu {
  0% {
    opacity:0;
  }
  
  60% {
    opacity:0;
  }

  100% {
    opacity:1;
  }
}

body #footer .titre_infos{ 
	margin-bottom:6%;
}

body .global_historique .vc_single_image-wrapper::before {
    content: ' ';
    width: 120px;
    height: 1%;
    background-color: #209a9c;
    display: block;
    position: absolute;
    right: -70%;
    top: 49%;
    z-index: 2;
    animation-name: fondu;
    animation-duration: 3s;
}

body .global_historique .left .vc_single_image-wrapper::before {
    content: ' ';
    width: 120px;
    height: 1%;
    background-color: #209a9c;
    display: block;
    position: absolute;
    left: -70%;
    top: 49%;
    z-index: 2;
    animation-name: fondu;
    animation-duration: 3s;
}

body .global_historique .vc_single_image-wrapper::after {
    content: ' ';
    width: 0.5%;
    height: 120px;
    background-color: #cfcfcf;
    display: block;
    position: absolute;
    left: 49%;
    animation-name: fondu;
    animation-duration: 3s;
}

body .global_historique .last .vc_single_image-wrapper::after {
    content: ' ';
    width: 0.5%;
    height: 0px;
    background-color: transparent;
    display: block;
    position: absolute;
    left: 0%;
    animation-name: fondu;
    animation-duration: 3s;
}

body .global_historique .vc_single_image-wrapper{
	position: relative;
}

body .global_historique .vc_single_image-wrapper img{
	position: relative;
	z-index:5
}

body p{
	margin-top: 0%;
    margin-bottom: 10px;
	font-weight:400;
	font-size:17px;
	line-height:23px;
	/*font-family: 'PT Sans', sans-serif;*/
}


body div{
	font-weight:400;
	font-size:17px;
	line-height:23px;
	/*font-family: 'PT Sans', sans-serif;*/
}

body h5{
	margin-top:0%;
	margin-bottom:15px;
}

.flex .vc_row {
	display:flex;
}

body .wpb_button,body .wpb_content_element,body ul.wpb_thumbnails-fluid>li{
	margin-bottom:0% ;
}

.bg_clair{
	background-color: #209a9c;
    padding: 3%;
    color: #fff;
}

body .bg_clair h2{
	color:#fff;
}


.vc_row{
	margin-left:0% !important;
	margin-right:0% !important;
}

.vc_column_container>.vc_column-inner{
	padding-left:0% !important;
	padding-right:0% !important;
}


.agenda_home {
	background-color: #2c3c89;
}

.agenda_home .vc_column-inner{
	height:100%;
}

.agenda_home .wpb_wrapper{
	height:100%;
}



.agenda_home .wpb_text_column {
	height:100%;
}

.bloc_actu_home .date{
	margin-top:3%;
}

.bloc_actu_home .extrait p{
    font-size: 17px;
}

.bloc_actu_home .date{
	background-color: #209a9c;
    width: max-content;
    border-radius: 5px;
    padding: 5px 15px;
    font-size: 15px;
}

.big{
    color: #fff;
    font-size: 24px;
    font-weight: 500;
}

.agenda_little_global a{
	display:block;
	margin-top:40px;
	color:#fff;
}


.menu li:hover .sub-menu{
	left: 0px;
}

.menu li .sub-menu{
	padding: 1% calc((100% - 1400px) /2);
}

.menu li .sub-menu .sub-menu{
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    left: 0% !important;
    top: 35px !important;
    height: inherit !important;
    position: static !important;
    transform: translateX(0px);
}

body .sub-menu li:first-child {
    margin-left: 0%;
}

.sub-menu .sub-menu li a {
    padding: 2% 20px;
}

.sub-menu .sub-menu li {
    margin-left:0% !important;
}

.sub-menu li{
	padding-left:0% !important;
}

body .sub-menu li a{
	padding-left:0% !important;
	width: max-content;
	padding: 15px 2em;
}

#fil_ariane{
    padding: 15px 0px;
    font-size: 13px;
    font-weight: 400;
}

body .banner h1{
    margin-top: 15px;
    text-align: left;
	font-size: 60px;
	line-height:60px;
    margin-bottom: 25px !important;
    font-weight: 700;
}

.vc_tta-panel-body p::before{
	font-family: 'Material Symbols Outlined';
	content:'\ebcc';
	margin-right:5px;
	color: #cb2228;
}

.vc_tta-panel-body p{ 
	display:flex;
}

body .contain{ 
	width:1400px;
	margin:auto;
	max-width:100%;
}

#footer .big_bloc{ 
	color:#dbd9d9;
	font-size: 14px !important;
}

#footer .big_bloc .contain{
	display:flex;
	flex-wrap:wrap;
}

.bloc_footer.first{
    flex: 0 0 23%;
    text-align: center;
	display: flex;
    flex-direction: column;
    justify-content: center;
}

 .bloc_footer.second {
    flex: 0 0 50%;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
	justify-content: center;
}

.bloc_footer h4 {
    color: #fff;
    margin-bottom: 3%;
	font-weight: 600;
    font-size: 15px;
}

.infos_footer {
    margin-top: 15%;
}

.bloc_footer.first img{
    width: 100%;
    margin-bottom: 2%;
}

.global_bloc_third_left{
    border-left: solid 1px #fff;
    padding-top: 5%;
    padding-bottom: 4%;
    text-align: left;
    padding-left: 40px;
}

 .bloc_footer.second .bloc_middle{
	flex: 0 0 42%;
    padding: 4%;
 }
 
 .bloc_footer.third .bloc_middle{
	text-align:left;
 }
 
 .bloc_middle{ 
	 text-align:center;
	 font-size: 14px !important;
 }
 .bloc_footer.third {
    flex: 0 0 23%;
}

#footer .big_bloc p{
	color:#dbd9d9;
	font-size: 14px;
}

#footer .big_bloc a{
	color:#dbd9d9;
	font-size: 14px;
}

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

body .ult-carousel-wrapper{
	padding-bottom:0%;
}

.banner .slick-slide{
	line-height:auto !important;
}




.right_banner{
	padding-top:2%;
	padding-bottom:2%;
}

.right_banner  img{
	max-width:80% !important;
	padding-top:2%;
	padding-bottom:2%;
}


.bxslider{
	max-width:100%;
}



.block_img_arrow div.img_arrow_top::before{
	content: '';
    width: 50px;
    background-color: #fff;
    height: 1px;
    display: block;
    margin: auto;
    margin-top: 3%;
}


.background_orange .padd_little.diag {
	background-color: #dd5120;
}

.global_container_bottom_product{
	transform: skewY(3deg);
}



.block_img_arrow.black div.img_arrow_top::before{
	background-color:#000;
}

.block_img_arrow.black img.arrow{
	filter:invert(100%);
}

.block_img_arrow{
	text-align:center;
}

@keyframes margin {
  0% { transform:translateY(0) }
  50%   { transform:translateY(3px) }
  100%   { transform:translateY(0) }
}



img.arrow{
	width: 32px;
    padding-top: 10px;
    padding-right: 8px;
    padding-left: 8px;
	animation: linear 1.5s infinite margin;
}

.bloc_bg_abs .vc_column-inner{
	position: absolute;
    z-index: 9 !important;
    padding: 8% !important;
    color: #fff;
	top: 50%;
    left: 75%;
    transform: translate(-50%,-50%);
	background-image: url(/wp-content/uploads/2022/10/54396529-abstraite-de-la-lumiere-de-la-rue-en-noir-et-blanc.webp?id=174) !important;
	box-shadow: inset 0 0 0 500px #de5021fa;
    background-position: bottom;
}

.bloc_bg_abs h2{
	text-align: left;
	color:#fff;
}

.global_realisations_home .vc_column-inner{ 
    margin: 5% !important;
}



.global_realisations_home .wpb_wrapper{
	height:100%;
}

body .global_realisations_home .bx-controls{
	display:none !important;
}

.slider_realisations .bxslider div{
	background-size:cover;
}

.right_btn a{
	float: right !important;
    margin-top: 3% !important;
}


body .banner_bleue h1{
	text-transform: uppercase;
    color: #fff;
}
body .banner_bleue h2{
	text-transform: uppercase;
    color: #fff;
	margin-bottom: 0 !important;
}


.page_h1 h1 {
	color:#283486 !important;
	font-size: 30px;
	text-transform:uppercase;
	padding-bottom:3%;
	
}

@keyframes gradient {
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}

.btn.blanc a{
	background: linear-gradient(to right, #dd4f21 50%, #fff 50%);
    background-size: 200% 100%;
    background-position: right bottom;
    transition: all .5s ease-out;
    padding: 22px 54px;
    border-radius: 50px;
    font-size: 20px;
    color: #dd4f21;
    font-weight: 500;
}

.btn.blanc a:hover{
	background-position: left bottom;
	color:#fff;
}

.little.btn.blanc a{
	background: linear-gradient(to right, #dd4f21 50%, #fff 50%);
    background-size: 200% 100%;
    background-position: right bottom;
    transition: all .5s ease-out;
	padding: 13px 30px !important;
    border-radius: 50px;
    font-size: 19px;
    color: #dd4f21;
    font-weight: 500;
    border: solid 1px;
    margin: inherit;
}

.little.btn.blanc a:hover{
	background-position: left bottom;
	color:#fff;
}

#footer .big_bloc{
	width: 90%;
    margin: auto;
    padding: 2% 5%;
    background-color: #404751;
}

.footer_container{
	margin-top: 5% !important;
}

.three_bloc img{
	border-top-left-radius: 15px;
    border-top-right-radius: 15px;
}

#footer .footer_container a{
	color:#fff !important;
	margin-right: 15px;
}

.left_h2 h2 {
	text-align:left !important;
	margin-bottom:1% !important;
	margin-top:3% !important;
}

.banner{
	min-width:100%;
    display: flex;
}

.big_banner h2{
	font-family: 'PT Sans', sans-serif;
	font-weight:900;
	margin-top: 2%;
	text-align:left;
	color: #b825ce;
	font-size:32px;
}


.banner_bleue{
	height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
	background-color:#209a9c;
}
.big_valeur{
	padding-bottom: 20px;
}
.titre_bleu_clair h2 {
	color:#60c1d0;
}

.big_valeur p{
	text-align:center;
	font-size:20px;
	font-weight:bold;
}

.bloc_bleu .big_valeur p{
	color:#0070c0 ;
}

.bloc_bleu_clair .big_valeur p{
	color:#4bacc6 ;
}
.bloc_texte h3 {
	text-align:left !important;
}
.bloc_marron .big_valeur p{
	color:#953735 ;
}

.bloc_vert .big_valeur p{
	color:#04b052 ;
}

.global_valeur  img {
    vertical-align: middle;
    padding-right: 10px !important;
   max-width: 65px;
    height: auto;
}

.hauteur p{
	display: flex;
    align-items: center;
}

.global_valeur .wpb_column{
	padding: 0% 2%;
}

body .global_historique {
	margin-bottom: 100px !important;
}

body .global_historique p strong{
	color: #209a9c;
    font-size: 30px;
}

.hauteur{
	padding-bottom: 20px;
}

.width80 {
    width: 80%;
}

.banner .upb_row_bg {
	box-shadow: inset 0 0 0 500px rgb(0 0 0 / 42%);
}

.banner.img_fond_banner .upb_row_bg{
	box-shadow:none;
	background-size: auto 75% !important;
    height: auto;
    background-position: center bottom;
    background-color: #aae5ff !important;
	margin-top: 3%;
}

.banner.blue.img_fond_banner{
    background-color: #aae5ff !important;
}

.slider_realisations .bx-wrapper{
	min-height: 460px;
    width: 900px;
    margin: auto;
}

.bloc_realisation_left{
    max-width: 40px;
	background-color: #bc29bf;
    padding: 5px;
}

.infos_bloc_realisation.prestashop.prestashop .bloc_realisation_left{
	background-color: #b0deec !important;
}

.infos_bloc_realisation:nth-child(2) .bloc_realisation_left{
	background-color: #dd4f21;
}

.infos_bloc_realisation:nth-child(3) .bloc_realisation_left{
	background-color: #961e99;
}


.infos_bloc_realisation:nth-child(4) .bloc_realisation_left{
	background-color: #d56b49;
}

.infos_bloc_realisation:nth-child(5) .bloc_realisation_left{
	background-color: #df39e2;
}

.bloc_realisation_right{
	margin-left: 10px;
}

.infos_bloc_realisation .title_realisation{
	margin-bottom:0%;
	font-weight: 600;
}

.realisation_link{
    text-align: center;
	width: 100%;
    display: flex;
	margin-top: 3%;
    justify-content: center;
}

.realisation_link a{
	background-color: #424242;
    color: #fff !important;
	float:none;
    border-radius: 50px;
    padding: 10px 25px;
}

.realisation_link a i{
	color: #fff;
	transition:all linear 0.5s;
}

.realisation_link a:hover i{
	margin-left:10px;
}



.global_bloc_realisation{
	display: flex;
    flex-wrap: wrap;
	height: auto !important;
	margin-top: 4%;
	padding-bottom: 3%;
}

.global_realisations_full{
	display:flex;
	flex-wrap: wrap;
    justify-content: start;
}

.single_realisation img{
	max-width:100%;
}

.single_realisation{
	flex: 0 0 22%;
    display: flex;
    max-width: 22%;
	transition:all linear 0.5s;
	margin:1.5%;
}

.single_realisation:hover{
    transform: scale(1.10);
}

.infos_bloc_realisation{
	height: auto !important;
	margin-top: 2%;
    display: flex;
    flex-wrap: wrap;
	align-items: center;
	flex: 0 0 40%;
    max-width: 40%;
	margin: 1% 5%;
}

.bloc_realisation_right p{
	font-size: 15px;
}

.bloc_realisation_left img{
    max-width: 100%;
	border-radius: 5px;
}
.infos_bloc_realisation div{
	height:auto !important;
}

.slider_realisations .bx-viewport{
	height:100%;
}

.slider_realisations .slider{
	height:100%;
}

.slider_realisations .slider div{
	height:100%;
	border-radius: 10px;
	background-size:cover;
}

.tel_contact p{
	font-size:24px;
}

.bg_gris{
	background-color:#f3f3f3;
}

.adress_contact p{
	font-size:22px;
}


.banner.img_fond_banner{
	height: auto;
	padding:6% 0% !important;
	padding-top: 15%;
}

.banner_right{
	height:100%;
}

.max_300 img{
	max-width:300px !important;
}

.max_300 {
    margin-bottom: 2% !important;
    margin-top: 1% !important;
}



.banner_home .banner_left{
	height:80vh;
}

.banner_home .banner_left .vc_column-inner{
	height:80vh;
}

.banner_home .banner_right{
	height:80vh;
	background-color: #cb2228;
}



#global_header{
	background-color: #3a3a3a;
}

.banner_left .bx-wrapper{
	height:100%;
	width:100%;
	max-width:100% !important;
}

.banner_left .bx-viewport{
	height:100% !important;
}

.banner_left .bxslider div{
	height:100%;
	width:100% !important;
	background-size:cover;
	background-position:center;
}

.banner_left .bxslider{
	height:100%;
}

.banner_left .wpb_text_column {
	height:100%;
}

.banner_left .wpb_wrapper{
	height:100%;
}



.banner_right .wpb_text_column .wpb_wrapper h1{
	color:#fff;
	font-size: 55px;
	line-height:60px;
	text-align:center;
}


.banner_right .wpb_text_column .wpb_wrapper{
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
	color:#fff;
}

.global_padd{
	padding:6%;
}

.sub-menu li.first_menu {
    margin-left: 0%;
}

.sub-menu li{
    flex-direction: column;
}

.sub-menu li {
    margin-left: 5%;
}

.sub-menu .sous_menu_big  a {
    font-size: 16px !important;
    font-weight: 400 !important;
}

.sous_menu_big .sub-menu a {
    font-size: 13px !important;
    font-weight: 400 !important;
}

.sub-menu a {
    font-size: 13px !important;
    font-weight: 400 !important;
}

.sub-menu{
	visibility: visible;
	transition: 400ms linear;
    opacity: 1;
    position: absolute;
    z-index: 999;
    width: 100%;
    background-color: #fff !important;
    display: flex !important;
    align-items: baseline;
    justify-content: left;
    top: 88.5px !important;
	left: -9000px;
}
.agenda_little_global{
	width:100%;
}

.little_marg_bottom{
	margin-bottom:5% !important;
}


.half_section .text_left{ 
	padding-right: 4%;
}

.half_section .text_right{ 
	padding-left: 4%;
}

.ult-carousel-wrapper .slick-prev{
    left: 10px !important;
	color:#fff !important;
}

.ult-carousel-wrapper .slick-next{
    right: 10px !important;
	color:#fff !important;
}

body .wpb_wrapper .vc_btn3-container .vc_btn3{
	color: #fff;
    border-color: #ebebeb;
    background-color: #209a9c;
    font-size: 19px;
    border: none;
    margin-top: 3%;
}

body .wpb_wrapper .vc_btn3-container .vc_btn3:hover{
	background-color: #28367f;
	color: #fff;
	border: none;
}

body .creation_site {
    font-size: 16px;
    display: block;
    text-align: left;
    margin-bottom: 0% !important;
    margin-top: 3% !important;
	font-size: 14px;
}

.creation_site a{
	color:#209a9c !important;
}


.agenda_little_global .lieu_agenda{
	display: inline-block;
    background-color: #ffffff;
    padding: 5px 15px;
    color: #2c3c89;
    border-radius: 4px;
    text-transform: uppercase;
    margin-top: 10px;
}

.breadcrumbs a{
	color: #989898;
    font-weight: 300;
    font-size: 13px;
}

.breadcrumbs span{
	color: #989898;
    font-weight: 300;
    font-size: 13px;
}

.breadcrumbs .breadcrumb_last{
	color: #209a9c;
    font-weight: 500;
    font-size: 13px;
}

.agenda_little_global h5{
	font-size: 20px;
}

.agenda_little_global .extrait{
	font-size:16px;
}


.agenda_little_global a .date{
	font-size:23px;
}

.bloc_actu_home .image_actualite {
	background-size: cover;
    height: 400px;
    background-position: center;
	box-shadow: inset 0 0 0 500px rgb(0 0 0 / 42%);
}

.bloc_actu_home .image_actualite h5{
	font-weight: 400 !important;
}

.bloc_actu_home .extrait{
	font-size:16px;
}

.bloc_actu_home .image_actualite a{ 
	display: flex;
    height: 82%;
    padding: 30px;
    flex-direction: column;
    color: #fff;
    font-size: 24px;
    font-weight: 300;
}

div.header_right #recherche input[type="text"]{
	padding: 0px 5px;
	padding-left: 20px;
    border: solid 2px #209a9c;
    border-radius: 4px 0px 0px 4px;
    font-size: 14px;
    height: 36px;
	outline-color:#209a9c !important;
}

div.header_right #recherche input[type="submit"]{
    background-image: url(/wp-content/themes/licorne/loupe.png);
    background-size: 20px;
    background-position: center;
    background-repeat: no-repeat;
    width: 40px;
    height: 40px;
    background-color: #239a93;
    background-color: #209a9c;
    border: 0;
    border-radius: 0px 4px 4px 0px;
    color: #fff;
    padding: 0 5px;
    cursor: pointer;
}

#recherche form{
	display: flex;
    margin: auto;
}

a{
	text-decoration:none !important;
}

ul.slick-dots {
    bottom: -10px;
}

#footer{
	font-size:15px !important;
}


#footer li{
	list-style:none !important;
}

body{
	margin:0%;
	font-family: 'Nunito Sans', sans-serif;
}

body h4{
	font-weight: 500;
	margin-top: 0px;
    margin-bottom: 3% !important;
}

.intro{
	transform: skewY(3deg);
}

.intro p{
	text-align: center;
    font-size: 25px;
	font-family: 'Montserrat', sans-serif;
    line-height: 33px;
	text-transform:uppercase;
}

.page_content{
	margin-top:120px;
}

.image_produit{
	max-width: 100%;
    flex: 0 0 100%;
	margin-bottom:1%;
	    text-align: center;
    background-color: #fff;
}

.image_produit img{
	max-width:100%;
	max-height: 550px;
}

.youtube_video{
	padding-left:5px !important;
}

.youtube_video div{
	height:100%;
}

.youtube_video p{
	height:100%;
}

.youtube_video iframe{
	height:100%;
}

.map_real div{
	height:100%;
}

.second_line.fourth .wpb_column {
    max-width: 24%;
}

.map_real p{
	height:100%;
}

.map_real iframe{
	height:100%;
}

.diag{
	transform: skewY(-3deg);
    background-color: #fff;
    transform-origin: top left;
    padding-top: 5% !important;
	padding-bottom: 1% !important;
}

.separator.top hr{
	width: 100px;
    background-color: #dd5120;
    height: 2px;
    border: none;
    margin-bottom: 40px;
}

.separator.bottom hr{
	width: 100px;
    background-color: #dd5120;
    height: 2px;
    border: none;
    margin-top: 40px;
}

.intro h2{
	font-size: 50px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
	line-height:initial;
}

.wpcf7 .wpcf7-form-control-wrap input {
    width: 100%;
}

textarea {
    width: 100%;
    min-height: 150px;
    resize: vertical;
    overflow: auto;
}

form label br{ 
	display:none;
}

form input{
	padding: 10px 0px;
    font-size: 15px;
    text-indent: 10px;
    border: 1px solid #cecece;
 }
 
form textarea{
	padding: 15px 0px;
	font-size: 15px;
	text-indent: 10px;
	border: 1px solid #cecece;
	font-family: Arial, sans-serif;
}

#liste_produits {
    display: flex;
    flex-wrap: wrap;
}

#liste_produits .produit {
    flex: 3;
    padding: 0%;
    margin-right: 2%;
    min-width: 18%;
    margin-bottom: 7%;
    max-width: 18%;
}

.slogan{
	text-align: center;
    color: #ff8e00;
}

.slogan p{
    font-size: 34px;
    line-height: 36px;
}

.image {
    text-align: center;
    background-color: #f8f8f8;
    display: flex;
    height: 250px;
    position: relative;
    align-items: center;
    overflow: hidden;
}

.image img{
	min-width: 100%;
    height: 100%;
}

.image img.logo_produit{
	width: 50%;
    max-width: 50% !important;
    min-width: 50% !important;
    margin: auto;
}

.marg_top{
	margin-top:6%;
}

.info_produit h3{
	text-transform: uppercase;
    text-align: center;
    margin-bottom: 10px;
	font-size: 19px;
    font-weight: 300;
	min-height: 48px;
	margin-top:20px;
}

#tri_liste_produits {
    display: flex;
    flex-wrap: wrap;
	justify-content: center;
}

.global_tri_produit {
    background-color: #f2f2f2;
    display: flex;
    margin-bottom: 3%;
}

.content_form_tri select {
    border: none;
    border-radius: 5px;
    padding: 5px 10px 5px 10px;
    font-size: 15px;
    font-weight: 400;
    margin-right: 15px;
}

.button_envoi_form input {
    border: none;
    background-color: #209a9c;
    color: #fff;
    padding: 8px 35px;  
	border-radius: 5px;
    background-image: url(/wp-content/themes/tm-fabrique/assets/images/bg_filtre.png);
    background-repeat: no-repeat;
    background-position: 102px center;
    padding-right: 50px;
    font-size: 14px;
	cursor:pointer;
	margin-left:30px;
    font-weight: 400;
    transition: all linear 0.2s;
    -webkit-transition: all linear 0.2s;
    -moz-transition: all linear 0.2s;
}

.content_form_tri {
    margin: auto;
    display: flex;
    padding: 4% 0%;
}

.bottom a {
	text-align: right;
    font-size: 14px;
    font-weight: 300;
    display: block;
}

.info_produit h3 a{
	color:#209a9c;
}

.image a {
    display: flex;
    text-align: center;
    width: 100%;
}

.introduction {
    font-size: 16px;
    font-weight: 300;
    color: #2e2e2e;
    text-align: center;
}

.bottom {
    margin-top: 7%;
}

body a{
	color: #cb2228;
}

body a:hover{
	color: #cb2228;
}

p.center{
	width: 100%;
    text-align: center;
}

p.center input{
	cursor: pointer;
    padding: 15px 20px;
    text-align: center;
    text-indent: 0px;
}

p.center input:hover{
	background-color: #323f8d;
    border-color: #323f8d;
}

.wpcf7-spinner{ 
	display:none !important;
}

form .form_message{
	width:100%;
	flex:0 0 100%;
}
 
form p.form{
	width:48%;
	margin-bottom: 4%;
}
 
form{

}

.wpcf7-submit, .post-password-form label + input {
    color: #fff;
    background-color: #209a9c;
    border-color: #209a9c;
}

#footer .title_widget{
	font-family: 'Nunito Sans', sans-serif;
	color: #fff;
    font-size: 1.1em;
    margin-bottom: 10%;
    font-weight: 500;
}

.bloc_widget i{
	color:#61c2d0;
	margin-right:10px;
}


.footer_container span{
	font-weight:300;
}

#logo{
	width:18%;
    padding-top: 0.3rem;
	padding-bottom: 0.3rem;
}

#logo img{
	width: max-content;
	max-width:100%;
	transition: all 1s ease;
}

#global_header{
	 display: flex;
    align-items: center;
	flex-wrap: wrap;
	
}

.map{
	height:450px;
	overflow:hidden;
}

.menu-main-menu-container{
	flex: 0 0 100%;
	position:relative;
}

.menu-main-menu-container.active{
	display:block;
}

.header_right .menu-main-right-container{
	width:100%;
}

.contact_menu a{
	background-color: #cb2228;
	border:solid 1px #cb2228;
    transition: all .5s ease-out;
    color: #fff !important;
    padding: 15px 25px !important;
    border-radius: 0px;
}

.contact_menu a:hover{
	color:#cb2228 !important;
	background-color:transparent !important;
}

.horaire_banner{
	margin-top: 30px;
}

.horaire_banner a{
	color:#fff !important;
	display:flex;
	margin-top: 3%;
    margin-bottom: 3%;
}

.horaire_banner p em{
	text-decoration: underline;
    font-style: normal;
}

.bloc_rouge{
	background-color: #cb2228;
    color: #fff;
    padding: 20px;
}

.bloc_rouge h3{
	color:#fff;
}

.horaire_banner a::before{
	font-family: 'Material Symbols Outlined';
	content:'\e325';
	font-size: 24px;
}

.horaire_banner .wpb_wrapper{
	width: max-content;
    margin: auto;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    background-color: #231f20 !important;
    padding: 20px !important;
}

body strong{
	font-weight: 600 !important;
}

.header_center{
	flex: 0 0 60%;
	display: flex;
    justify-content: end;
    align-items: center;
}

.header_right{
	flex: 0 0 20%;
	display: flex;
    justify-content: end;
    align-items: center;
}

.menu li.btn_menu a{
	background-color: #7f2761;
    color: #fff;
    padding: 10px 15px;
	transition:all linear 0.2s;
}

.bg_cadre_droit{
	background-image:url(/wp-content/uploads/2024/11/cadre_droite.png);
	background-size:auto;
	background-position:top right;
	background-repeat:no-repeat;
}

.border_rose img{
	border: solid 10px #e5c6d7;
}

.border_purple img{
	border: solid 10px #7f2860;
}

.bg_cadre_droit_blanc_bottom .upb_row_bg{
	background-image:url(/wp-content/uploads/2024/11/cadre_droit_blanc.png) !important;
	background-size:auto !important;
	background-position:90% 80% !important;
	background-repeat:no-repeat !important;
}

.bg_cadre_gauche .upb_row_bg {
	background-size:auto !important;
	background-position:bottom left;
	background-repeat:no-repeat;
}

.menu li.btn_menu a:hover{
	color:#fff !important;
	background-color: #5c1e47;
}

.menu {
    display: flex;
    flex-wrap: wrap;
	list-style:none;
    display: flex;
    justify-content: center;
    margin: 0%;
}

#global_header .container{
	display:flex;
	width: 92%;
    max-width: 92%;
}

#global_header #logo{
	max-width: 20%;
    flex: 0 0 20%;
	display: flex;
    align-items: center;
}

#global_header #logo a{
	display: flex;
    align-items: center;
}

.btn_banner{
    margin-top: 8%;
}

.btn_banner .wpb_wrapper{
	display:flex;
}

.btn_banner p{
	display:flex;
	margin-bottom: 0%;
}


.btn_banner a{
    border-radius: 50px;
    padding: 10px 25px;
    color: #fff;
	width: max-content;
	margin-right: 20px;
	background: linear-gradient(to right, #323131 50%, #424242 50%);
    background-size: 201% 100%;
    background-position: right bottom;
	font-size: 20px;
	transition: all 0.3s ease-out;
}


.btn_banner p:first-child a{
    border-radius: 50px;
    padding: 10px 25px;
	font-size: 20px;
    color: #fff;
	width: max-content;
	margin-right: 20px;
	background: linear-gradient(to right, #981dab 50%, #80255e 50%);
    background-size: 201% 100%;
    background-position: right bottom;
	transition: all 0.3s ease-out;
}

.btn_banner p a span br{
	display:none;
}

.btn_banner p a span{
    margin-right: 4px;
}

.btn_banner p a{
	display: flex;
    align-items: center;
}

.btn_banner a:hover{
	background-position: left bottom !important;
	color:#fff;
}

.bandeau{
    background-color: #cb2228;
	padding: 2%;
}

.bandeau p{
	display: flex;
    justify-content: center;
    align-items: center;
}

.bandeau p img{
	max-width: 250px;
    margin-left: 20px;
}

.subtitle p{
	color: #cb2228;
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: 6%;
}

.icone_title span br{
	display:none;
}

.icone_title span i::before{
	content:'';
	height:2px;
	display:block;
	width:40px;
}

.inner_left_contact{
	margin:auto;
}

.global_contact{
	flex: 0 0 48%;
    display: flex;
    padding: 4% 0%;
}
.phone .left_contact{
    margin: 3% 0%;
}

#contact_footer .container{
	display:flex;
	max-width:1400px !important;
	flex-wrap: wrap;
}

#contact_footer h3{
	font-size: 55px;
    line-height: 60px;
    text-align: center;
	color:#fff;
	flex:0 0 100%;
}

.zone_actu .wpb_column {
	width: 25%;
}

.zone_actu h3{
    text-align: center;
    margin-top: 20px;
    margin-bottom: 15px !important;
}

.zone_actu .wpb_text_column {
	padding: 0% 3%;
}
.bandeau p{
	font-family: "Monda", sans-serif;
	color:#fff;
	text-align:center;
	font-size: 40px;
	line-height: normal;
	font-weight: 800;
}

.zone_actu{ 
	display:flex;
	justify-content: space-between;
}

body .phone a:hover{
	color: #444444
}

.bottom_footer{
	display: flex;
    justify-content: space-between;
    padding: 1%;
    background-color: #cb2228;
	color:#fff !important;
	font-size: 14px;
}

.bottom_footer a{
	color:#fff !important;
	font-size: 14px;
}

.phone span{
	font-size: 35px;
	color: #242424;
	margin-right: 15px;
}

.horaire span{
	font-size: 35px;
	color: #242424;
	margin-right: 15px;
}

.adresse span{
	margin-right: 15px;
	color: #242424;
	font-size: 35px;
}

.adresse{
	display:flex;
}

.phone{
	display:flex;
	margin: 20px 0px;
	align-items: center;
}


.horaire{
	display:flex;
}

.phone p{
	margin-bottom:0%;
}

.phone a{
	color:#444444;
}


.left_contact h3{
	color: #1d1d1b;
    font-family: 'PT Sans', sans-serif;
    font-weight: 500;
    margin-top: 0%;
    font-size: 35px;
    font-weight: 700;
}

.right_contact iframe{
	height:100% !important;
}

body .inner_left_contact h3{
	color: #231f20;
	margin-bottom: 30px !important;
}

ol li::marker{
	color:#cb2228;
	font-size:20px;
}

#contact_footer span.icone_big{
	display: block;
    text-align: center;
    margin-bottom: 1%;
    color: #ffffff;
    font-size: 60px;
    width: 100%;
}

.left_contact h4{
	color: #242424;
    font-weight: bold;
    margin-top: 20px;
	margin-bottom: 30px !important;
}

.inner_left_contact p{
	color: #242424 !important;
}

.inner_left_contact a{
	color: #242424 !important;
}

#contact_footer{
	display:flex;
	padding:4% 0%;
	background-color: #cb2228c9;
}

.right_contact{
	flex:0 0 48%;
	display:flex;
}

.left_contact{
	flex:0 0 48%;
	display:flex;
}

.icone_title span i::after{
	content:'';
	height:2px;
	display:block;
	width:40px;
}

.icone_title span{
	display: block;
    text-align: center;
    margin-bottom: 1%;
    color: #cb2228;
}

.menu li{
	padding: 0px 10px;
	display: flex;
	justify-content: center;
    align-items: center;
}

.header_right .menu li a{
    background-color: #cb2228 ;
	border:solid 1px #cb2228 !important;
    padding: 10px 15px !important;
    border-radius: 4px;
	 color:#fff !important;
}

.header_right .menu li a:hover{
    background-color: transparent;
	 color:#fff !important;
   
}

.menu li a{
	/*padding: 0.3em 0;*/
    color: #fff;
    position: relative;
    display: inline-block;
    letter-spacing: 1px;
    margin: 0;
    text-decoration: none;
	transition:all linear 0.2s;
    font-size: 16px;
	border-bottom: solid 2px transparent;
	text-transform:uppercase;
}

.menu li a:hover{
	border-bottom: solid 2px #fff;
}


.menu li.current-menu-item a{
	color: #fff;
}

.menu li.btn.current-menu-item a{
	color: #fff;
}

.global_form input{
	padding: 3% 1%;
    border-radius: 6px 6px 6px 6px;
    background-color: #FFFFFF;
    color: #2E2C39;
	max-width:98%;
    border-style: solid;
    font-size: 16px !important;
    border-width: 1px 1px 1px 1px;
    outline: none !important;
    border-color: #FFFFFF;
    box-shadow: 0px 14px 34px 0px rgb(0 0 0 / 7%);
    margin-bottom: 3% !important;
    margin-top: 1% !important;
}

.global_form div.full{
	flex: 0 0 100%;
    max-width: 100%;
}
	

.global_form textarea{
	padding: 3% 1%;
    border-radius: 6px 6px 6px 6px;
    background-color: #FFFFFF;
    color: #2E2C39;
	max-width:98%;
    border-style: solid;
    font-size: 16px !important;
    border-width: 1px 1px 1px 1px;
    outline: none !important;
    border-color: #FFFFFF;
    box-shadow: 0px 14px 34px 0px rgb(0 0 0 / 7%);
    margin-bottom: 3% !important;
    margin-top: 1% !important;
}

.global_form{
    display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
	max-width: 1024px;
    margin: auto;
}

.global_form div{
	flex:0 0 48%;
	max-width:48%;
}

body .banner .padd_right{
	padding-right:4%;
}

.container{
	max-width:1400px;
	width:1400px;
	margin:auto;
}

.vc_row[data-vc-full-width] .vc_column-inner{
	padding-right:0%;
	padding-left:0%;
}

.banner_video{
	height:500px;
	margin:0% !important;
}

.slider .slick-track .slick-slide p{
	margin-top:0%;
}


.slider .slick-track .slick-slide .wpb_text_column {
	height:100%;
}

.slider .slick-track .slick-slide .wpb_text_column .wpb_wrapper{
    height: 100%;
}

.slider .slick-track .slick-slide .wpb_text_column .wpb_wrapper p{
    height: 100%;
	line-height: inherit;
}

.banner_video h1{
    height: 100%;
    display: flex;
    color: #fff;
    text-align: center;
    justify-content: center;
    align-items: center;
	font-size: 2em !important;
    font-family: Lato, sans-serif;
    font-weight: 400;
}

.bloc_color{
	background-color: #209a9c;
	padding:2%;
}

.title{
	position: absolute !important;
    top: 0%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
	box-shadow: inset 0 0 0 500px rgb(0 0 0 / 42%);
}

.bloc_color p{
	color:#fff;
}

.three_bloc .wpb_column {
	padding: 1%;
}

.button a{
	color: #fff;
	background: linear-gradient(to right, #27357f 50%, #209a9c 50%);
    background-size: 200% 100%;
    padding: 10px 20px;
    border-radius: 24px;
    margin: auto;
    font-size: 18px;
	background-position: right bottom;
	transition: all .5s ease-out;
}



.button.sterigene a{
	background: linear-gradient(to right, #27357f 50%, #0069b4 50%);
	background-position: right bottom;
	background-size: 200% 100%;
	
}

.button.stauratec a{
	background: linear-gradient(to right, #27357f 49%, #61c2d0 50%);
	background-position: right bottom;
	background-size: 200% 100%;
}

.button a:hover{
	background-position: left bottom;
}

.four_bloc .wpb_column {
	max-width:25%;
	padding: 2%;
}

.search.container .result{
	margin:1% 0%;
}

.three_bloc{
	justify-content: space-evenly;
	display: flex;
}

.padd_little{
	padding-top:3% !important;
	padding-bottom:3% !important;
}

.padd{
	padding-top:3% !important;
	padding-bottom:3% !important;
}

.big_padd{
	padding-top:10% !important;
	padding-bottom:10% !important;
}

.bg_little .upb_row_bg {
	background-size:7% !important;
}

.big_padd_top{
	padding-top:10% !important;
}

.big_padd_bottom{
	padding-bottom:10% !important;
}

.top_page{
	display: flex;
    flex-direction: column;
	width: 50%;
    margin: auto;
}

.global_top_page .separator.bottom{
	margin-top:0%;
}

.top_page h1{
	font-size: 50px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    line-height: initial;
	color: #de5021;
	margin-bottom: 3% !important;
    margin-top: 0%;
}

.intro_page p{
    text-align: center;
    font-size: 25px;
    font-family: 'Montserrat', sans-serif;
    line-height: 33px;
    text-transform: uppercase;
}

.padd_line{
	padding-left:3% !important;
	padding-right:3% !important;
}

body h4.vc_tta-panel-title {
    font-weight: 500;
    margin-top: 0px;
    margin-bottom: 0% !important;
}

.padd_left{
	padding-left:4% !important;
}

.padd_right{
	padding-right:4% !important;
}

.big_padd_right{
	padding-right:10% !important;
}

.second_line::before{
	display:none !important;
}

.second_line::after{
	display:none !important;
}

.second_line{
	display: flex;
    justify-content: space-between;
}

.second_line .wpb_column {
	max-width:48%;
}

.second_line .little.btn.blanc a{
	padding: 7px 30px !important;
	font-size: 17px;
}


body .vc_row  .big_banner{
    min-height: 40px;
    position: relative;
    margin-bottom: 3%;
}

.bounce_from h2{
	opacity: 0;
  animation: bounce_from 10s ease infinite;
      position: absolute;
    top: 0%;
}

.bounce_from h2:nth-child(2){
	opacity: 0;
  animation: bounce_from_2 10s ease infinite;

}

.bounce_from h2:nth-child(3){
	opacity: 0;
  animation: bounce_from_3 10s ease infinite;
}

@keyframes bounce_from {
  0% {
    opacity: 0;
    transform: scale(.3);
  }
  15% {
    opacity: 1;
    transform: scale(1.05);
  }
  30% { 
	transform: scale(.9); 
	opacity: 0;
  }
  100% { 
	
  }
}

@keyframes bounce_from_2 {
  0% {
    opacity: 0;
    transform: scale(.3);
  }
  31% {
    opacity: 0;
    transform: scale(.3);
  }
  62% { 
	transform: scale(1.05); 
	opacity: 1;
  }
  63% {
    opacity: 0;
    transform: scale(.9);
  }
  100% { 
	
  }
}

@keyframes bounce_from_3 {
  0% {
    opacity: 0;
    transform: scale(.3);
  }
  63% {
    opacity: 0;
    transform: scale(.3);
  }
  98% { 
	transform: scale(1.05); 
	opacity: 1;
  }
  
  99% {
    opacity: 0;
    transform: scale(.9);
  }
  100% { 
	
  }
}


.bg_bleu {
    background-color: #abe6ff;
}


.bg_rose {
    background-color: #f9b9b4;
}

.btn a span{
	margin-right:10px;
}

.btn a{
	background-color: #e06260;
    padding: 15px 36px;
    border-radius: 4px;
    display: block;
    color: #fff;
    transition: all linear .2s;
    width: max-content;
    margin-top: 4%;
    font-size: 16px;
    font-weight: 600;
    display: flex;
    border: solid 1px #e06260;
}

body .btn a:hover{
	    background-color: transparent !important;
    color: #e06260 !important;
}

.btn.orange a{
	background: linear-gradient(to right, #000 50%, #dd5120 50%);
    background-size: 200% 100%;
    background-position: right bottom;
	color: #fff;
}

.big h2{
	color:#000;
}

.big h2 strong{
	font-weight: 400;
    font-size: 48px;
	color: #de5021;
}

.video video{
	height:auto !important;
}

.video p{
	display:flex;
}

.btn.orange a:hover{
	color: #fff;
   background-position: left bottom;
}

.padd_top{
	padding-top:6% !important;
}

.padd_bottom{
	padding-bottom:6% !important;
}

.little_padd_bottom{
	padding-bottom:3% !important;
}


.agenda_home .vc_column-inner{
	padding:0% !important;
}

.global_agenda{
	height:100%;
	display:flex;
	padding: 30px;
}
.bloc_blanc {
	background-color:#fff;
	padding:5% !important;
	
	}
.bloc_blanc p {
	text-align:justify;
}
.alignement p{
	text-align:justify;
}
.line {
	display:flex;
	justify-content: space-between;
}
.line .vc_column_container {
	max-width:47%;
}
.fond_img .vc_column-inner{
    box-shadow: inset 0 0 0 500px rgb(0 0 0 / 42%);
}
.hauteur .vc_column-inner h3 a{
	padding-top:200px;
	padding-bottom:200px;
	display:block;
}
.bloc_img a{
	color:#fff !important;
}
.little a {
	font-size:13px;
	text-align:center !important;
	padding:5%!important;
	color:#62c6d6;
}

.societe_bloc h3 {
	padding-top:200px;
	padding-bottom:200px;
	color:#fff;
}
.fond_img .vc_column-inner{
	transition: transform .2s; 
}
.fond_img .vc_column-inner:hover{
	transform: scale(1.1); 
}

.global_liste_actu .wpb_text_column .wpb_wrapper{
	display: flex;
	justify-content: flex-start;
}

.global_liste_actu .wpb_text_column .wpb_wrapper .actualite{
    display: flex;
    flex: 0 0 25%;
	max-width: 25%;
    flex-direction: column;
    background-color: #f7f7f7;
    padding: 2%;
    margin: 1%;
}

.global_actu h1{
	margin-bottom:3%;
}

.global_actu h2{ 
	text-align:left;
	font-size: 21px;
}

.global_liste_actu .wpb_text_column .wpb_wrapper .actualite h5 a{
	font-weight: 400;
    color: #2e3a8c;
}


.global_actu p{
	font-size: 16px;
}

body .stats-block, .wpb_row .wpb_column .wpb_wrapper .stats-block {
    display: block;
    margin-bottom: 25px !important;
}

.stats-block .stats-number {
    font-size: 73px !important;
    font-weight: 300 !important;
	font-family: "Monda", sans-serif;
}

.big_text .wpb_wrapper{
  text-align:center;
}

.big_text .wpb_wrapper p{
	font-size: 30px;
    margin: 68px 0% !important;
	line-height:30px;
}

.very_major_big_text strong{
	font-size: 93px;
    line-height: 93px;
	color:#fff;
	font-family: "Monda", sans-serif;
}


.bg_left_bottom.second_bg  .very_major_big_text strong{
	font-size: 80px;
    line-height: 80px;
}

.major_big_text strong{
	font-size: 65px;
    line-height: 65px;
	font-family: "Monda", sans-serif;
}

.major_big_text a strong{
	color:#424242;
}

.counter_suffix  {
    color: #b825ce !important;
}

.counter_prefix   {
    color: #b825ce !important;
}


.little_padd{
	padding-top:3% !important;
	padding-bottom:3% !important;
}

.little_padd_top{
	padding-top:3% !important;
}

.third_bloc_black a{
	color:#444444 !important;
}

.third_bloc_black .wpb_column {
	border-radius: 30px 0 30px 0;
    padding: 60px 0px;
    box-shadow: 0px 0px 5px 0px #00000021;
    transition: all linear 0.5s;
    max-width: 31%;
}

.third_bloc_black .wpb_column:hover{
	border-radius: 0px 30px 0 30px;
    box-shadow: 0px 0px 5px 0px #00000073;
}

.third_bloc_black{
	display: flex;
    justify-content: space-between;
}

.third_bloc_black .wpb_column.column_color{
   box-shadow: 0px 0px 5px 0px #80255eab;
}

.third_bloc_black .wpb_column.column_color:hover{
   border-radius: 0px 30px 0 30px;
    box-shadow: 0px 0px 5px 0px #80255e;
}

.little_padd_bottom{
	padding-bottom:3% !important;
}

.global_liste_actu .wpb_text_column .wpb_wrapper .actualite .date_actualite {
    background-color: #293984;
    width: max-content;
    padding: 5px 10px;
    font-size: 15px;
    color: #fff;
    margin-bottom: 15px;
}

.global_liste_actu .wpb_text_column .wpb_wrapper .actualite .image_actualite img{
	max-width: 100%;
	height:auto;
}

.besoin_renseignement{
	background-color: #209a9c;
    flex: 1;
    text-align: center;
    padding: 2% 3%;
    max-width: 25%;
    margin: auto;
    margin-top: 0%;
}


.besoin_renseignement.full{
    max-width: 96%;
	margin-left: 4%;
}

.besoin_renseignement form{
	justify-content: center;
}

.besoin_renseignement input{
	border-radius: 10px;
    border: none;
}

.besoin_renseignement p {
    color: #fff;
    font-size: 16px;
}

.besoin_renseignement input[type="submit"]{
	background-color: #27357f;
    border: none;
    border-radius: 8px;
    color: #fff;
    font-size: 16px;
    cursor: pointer;
    margin: auto;
    display: block;
    width: max-content;
	margin-top: 15px;
    padding: 15px 20px 15px 15px;
}

.besoin_renseignement form{
	padding:8%;
}

.besoin_renseignement h3 {
    font-size: 16px;
    margin-top: 0%;
    font-weight: 300;
    margin-bottom: 23px !important;
    color: #fff !important;
	text-align:center;
}

.besoin_renseignement .title_offre_form{
	flex:0 0 100%;
}

.besoin_renseignement .file_input{
	display: flex;
    flex-direction: column;
    margin-bottom: 7%;
	flex: 0 0 100%;
}

.besoin_renseignement .file_input input{
	width: 134px;
	cursor:pointer;
}

.civilite select {
    border: none;
    border-radius: 5px;
    padding: 5px 10px 5px 10px;
    font-size: 15px;
    font-weight: 400;
    margin-right: 15px;
}

.besoin_renseignement label {
    display: block;
    margin-bottom: 4%;
}

.actualite .btn{
	background-color: #293984;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50px;
    margin-top: 15px;
    margin: auto;
    margin-top: 15px;
}

.actualite .btn:hover{
	background-color: #209a9c;
}

.actualite .btn span{
	font-size: 37px;
    color: #fff;
}

.banner_title{
	padding-top:2% !important;
	padding-bottom:2% !important;
}

.banner_title h1::after{
	content: url("/wp-content/uploads/2021/11/arrow.png");
	display:block;
}

div.flex {
    display: flex;
}

div.space_between{
	justify-content: space-between;
}

div.wrap {
    flex-wrap: wrap;
}

div#liste_evenements div.evenement {
    width: 23%;
    margin-right: 2%;
    background-color: #f2f2f2;
    margin-bottom: 2%;
}

div#liste_evenements .top_evenement {
    align-items: center;
}

div#liste_evenements .date_evenement {
    flex: 3;
    background-color: #209a9c;
    color: #fff;
    padding: 4%;
    margin-left: 4%;
    text-align: center;
}

div#liste_evenements .jour {
    font-size: 26px;
}

div#liste_evenements .titre_evenement {
    flex: 10;
    text-align: center;
}

div#liste_evenements div.evenement div.evenement_content {
    padding: 6% 10%;
}

.evenement_content .description {
    margin-top: 5%;
    font-size: 15px;
}

div#liste_evenements .date_fin {
    font-size: 16px;
    margin-top: 14%;
    font-style: italic;
}

#liste_offres .offre {
    flex: 4;
    padding: 0%;
    margin-right: 2%;
    min-width: 31%;
    margin-bottom: 5%;
    max-width: 31%;
    padding: 2%;
    background-color: #fff;
    -webkit-transition: all 0.3s linear;
    transition: all 0.3s elinear;
    -moz-transition: all 0.3s elinear;
}

.offre a {
    display: block;
    text-align: center;
}

.contrat {
    width: 80px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 80px;
    border-radius: 50%;
    background-color: #209a9c;
    color: #fff;
    text-align: center;
    margin: auto;
    margin-bottom: 7%;
    margin-top: 7%;
}

.lieu_travail {
    text-align: center;
    color: #209a9c;
    min-height: 80px;
}

.little_col .vc_column-inner{
	max-width: 60%;
    margin: auto !important;
    display: flex
}

.offre h4 {
    min-height: 50px;
    text-transform: uppercase;
    text-align: center;
	margin-bottom: 10px;
}

body .offre h4 a{
	color: #293984;
}

.global_all_fiche_formation {
    background-color: #f8f8f8;
    padding: 3%;
}

.formation_entete {
    flex: 8;
    padding-right: 3%;
}

.offre_d_emploi-template-default.single h1 {
    font-weight: 100;
    max-width: 100%;
    margin: 0;
    margin-bottom: 3%;
    line-height: 40px;
}

.lieu_offre {
    color: #27357f;
}

.contrat_offre {
    color: #27357f;
    margin-top: 2%;
}

span.type_contrat {
    background-color: #27357f;
    color: #fff;
    padding: 5px 20px 5px 20px;
}

.offre_renseignements {
    flex: 4;
    background-color: #209a9c;
    margin-right: 0%;
    text-align: center;
    padding: 6% 3%;
    max-width: 25%;
    margin: auto;
    margin-top: 0%;
    font-size: 16px;
	color: #fff;
}

.aero{
    padding: 2% !important;
	margin-right: 2% !important;
	width:30% !important;
}

.aero.blue{
	background-color: #d9e2f3;
}

.global_all_contenu_formation {
    background-color: #fff;
    padding: 3%;
}

.aero.pink{
	background-color: #fbe4d5;
}

.aero.green{
	background-color: #e2efd9;
}

.aero.yellow{
	background-color: #fff2cc;
}

.wpcf7 form.sent .wpcf7-response-output {
    border-color: transparent !important;
    color: #fff !important;
    padding: 0px !important;
}

.empty_col{
	width:11% !important;
}

.global_table_formation {
    border: solid 1px #e1e1e1;
    flex: 6;
    margin-right: 5%;
    max-width: 68%;
}

.row_table_formations, .row_table_offre {
    display: flex;
}

.global_table_formation .table_left {
    border-right: solid 1px #e1e1e1;
}

.row_table_formations div, .row_table_offre div {
    padding: 4%;
}

.row_table_formations div.table_left p, .row_table_offre div.table_left p {
    margin-bottom: 0%;
    font-size: 14px;
    font-weight: 500;
    word-break: keep-all;
    text-transform: uppercase;
}

.salaire_offre {
    margin-top: 8%;
}

.row_global_formation {
    display: flex;
}

.table_right {
    flex: 3;
    font-size: 14px;
    font-weight: 300;
}

.container.entete_fiche_formation{
	display:flex;
}

.offre_renseignements span {
    display: block;
    font-weight: 700;
    padding-bottom: 1%;
}

.little_global_fiche_produit{
    /*padding: 3% 0%;*/
}

.table_right p {
    margin-left: 30px;
}

.menu_close{
	display:none;
}

.menu_open{
	display:none;
}

.bloc_home a{
	display: flex;
    justify-content: center;
    align-items: center;
    min-height: 300px;
    color: #fff;
    font-size: 25px;
    text-transform: uppercase;
    box-shadow: inset 0 0 0 500px rgb(0 0 0 / 42%);
	 transition: transform .2s;
	 font-weight:500;
}

.little_title p{
	color: #27357f;
}

.bloc_home .vc_col-sm-6 a{
	min-height: 400px;
}

.bloc_home .vc_column-inner .vc_column-inner{
	transition: transform .2s;
	position: relative;
}

.bloc_home .vc_column-inner .vc_column-inner:hover{
	 transform: scale(1.05);
	 z-index: 99;
    
}

.bloc_home .bg_green a{
	box-shadow:inset 0 0 0 500px rgb(66 66 66 / 42%);
}

.bloc_home .bg_blue a{
	box-shadow:inset 0 0 0 500px rgb(70 70 70 / 42%);
}

.bloc_color.center .vc_column-inner{
	display: flex;
    align-items: center;
    justify-content: center;
}

.wpb_text_column.phone{
	margin-bottom: 15px;
}

.wpb_text_column.phone a{
	color:#fff !important;
	font-size: 20px;
}

.wpb_text_column.phone{
	text-align:center;
}

.wpb_text_column.phone a::before{
	margin-bottom: 15px;
	color:#fff;
	font-family: "Font Awesome 6 Free";
    font-weight: 900;
	content: "\f095";
	margin-right:10px;
}

.wpb_text_column.mail p{
	font-size: 20px;
}

.slick-slide{
	margin:0px !important;
}

.slick-list{
	padding:0px !important;
}

.ult-carousel-wrapper{
	margin-bottom:0px !important;
	margin-top: 0px !important;
}

.wpb_text_column.mail p::before{
	margin-bottom: 15px;
	color:#fff;
	font-family: "Font Awesome 6 Free";
    font-weight: 900;
	content: "\f0e0";
	margin-right:10px;
}

.img_slide{ 
	display:none;
}

.img_slide.active{ 
	display:block;
}

.content_slide{
	padding:20px;
}

.number_slide{
	border-radius:50%;
	width: 40px;
    display: flex;
    height: 40px;
    justify-content: center;
    align-items: center;
	color:#fff;
	margin-bottom: 15px;
}

.number_1{
	background-color:#27357f;
}

.number_2{
	background-color:#00569d;
}

.number_3{
	background-color:#61c2d0;
}

.number_4{
	background-color:#1d9b8f;
}

.number_5{
	background-color:#61c2d0;
}

.number_6{
	background-color:#00569d;
}

.number_7{
	background-color:#00569d;
}

.bx-wrapper{
	box-shadow: 0 0 0px #ccc !important;
	border:none !important;
}

body .bx-wrapper .bx-prev {
    left: -170px;
	background:url(/wp-content/uploads/2023/03/left.png);
	width: 37px !important;
    height: 68px !important;
	background-position: 0 0 !important;
}

body .bx-wrapper .bx-next {
    right: -170px;
	background:url(/wp-content/uploads/2023/03/right.png);
	width: 37px !important;
    height: 68px !important;
	background-position: 0 0 !important;
}

.line_bloc .wpb_column {
	display: flex;
   flex: 0 0 31%;
    max-width: 31%;
    height: 300px;
    margin: 1%; 
    position: relative;
    overflow: hidden;
	
}

.line_bloc.second_one .wpb_column {
	display: flex;
   flex: 0 0 48%;
    max-width: 48%;
    margin: 1%; 
    position: relative;
    overflow: hidden;
	height:auto;
}

.line_bloc.second_one .wpb_column .wpb_text_column{
	height: 300px;
	background-position:center;
	background-size: 100% auto;
	transition: all linear .2s;
}

.line_bloc.second_one .wpb_column .wpb_text_column:first-child{
	margin-bottom:4%;
}

.line_bloc.second_one .wpb_column .wpb_text_column.full_height{
	height:100%;
}

.line_bloc .vc_column-inner{
	background-position: center;
	transition: all linear .2s;
	background-size: cover;
	background-size: 100% auto;
}

.line_bloc.second_one .wpb_column .wpb_text_column:hover{
	background-size: 110% auto;
}

.line_bloc .wpb_column div{
	width:100%;
	height:100%;
}

.line_bloc .wpb_column div p{
	width:100%;
	height:100%;
}

.line_bloc.second_one .wpb_column .wpb_text_column a{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
    font-size: 22px;
    font-weight: 500;
	box-shadow: inset 0 0 0 500px rgb(0 0 0 / 34%);
	transition: all linear .2s;
}

.banner_right .wpb_text_column .wpb_wrapper{
	padding: 0% 4%;
}


.line_bloc_second .wpb_column {
	display: flex;
   flex: 0 0 48%;
    max-width: 48%;
    height: 380px;
    margin: 1%; 
    position: relative;
    overflow: hidden;
}

.line_bloc_second .vc_column-inner{
	background-position: center;
	transition: all linear .2s;
	background-size: cover;
	background-size: 100% auto;
}

.line_bloc_second .vc_column-inner:hover{
	background-size: 110% auto;
}

.line_bloc_second .wpb_column div{
	width:100%;
	height:100%;
}

.line_bloc.full_line .wpb_column {
    display: flex;
    flex: 0 0 32%;
    max-width: 32%;
    height: 400px;
    margin: 0%;
    position: relative;
    overflow: hidden;
    margin-bottom: 1%;
}

.line_bloc.full_line .vc_column-inner:hover{
	background-size: 100% auto;
}

.line_bloc.full_line .vc_column-inner:hover a{
	box-shadow:inset 0 0 0 500px rgb(0 0 0 / 56%);
}

.bg_color{
	background-color: #de5021;
}

.line_bloc.full_line::before{
	display:none;
}

.line_bloc.full_line::after{
	display:none;
}

.line_bloc.full_line .wpb_column div p a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: rgb(255, 255, 255);
    text-transform: uppercase;
    font-size: 22px;
    font-weight: 500;
    box-shadow: rgba(0, 0, 0, 0.34) 0px 0px 0px 500px inset;
    transition: all 0.2s linear 0s;
}

.line_bloc.full_line{
	max-width: 100%;
	justify-content: space-evenly;
    display: flex;
}

.bg_color h2{
	color:#fff;
}

.line_bloc_second video{
	width:100%;
	height:100%;
}

.line_bloc_second .wpb_column div p{
	width:100%;
	height:100%;
}

.line_bloc_second .wpb_column div p a{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    color: #fff;
    text-transform: uppercase;
    font-size: 17px;
    font-weight: 500;
	box-shadow: inset 0 0 0 500px rgb(0 0 0 / 34%);
}

.button_produit{
	margin-bottom:1rem;
}

body div.sous_titre_produit h3{
	text-align: center;
    font-size: 30px;
	margin-bottom: 1% !important;
    margin-top: 2%;
    color: #fff;
}

.sous_titre_produit{
	margin-bottom: 2rem;
}

.background_orange{
	background-color:#dd5120;
}

body .others_products{
	background-color:#e7e7e7;
	padding-bottom: 8% !important;
}

.others_products h3{
	text-align:center;
	color: #dd5120;
    text-transform: uppercase;
}

.banniere_produit img{
	width:100%;
	height:auto;
	display:block;
}

.logo_marque img{
	max-width:200px;
}

.align_center{
	text-align:center;
}

#onglets_produit .global_onglets:first-child{
	max-width: 58%;
    flex: 0 0 58%;
}

#onglets_produit .global_onglets:last-child{
	max-width: 28%;
	margin-right:0%;
    flex: 0 0 28%;
}

.alignright{
	float:right;
}

.more_products h3 {
    text-align: center;
    color: #fff;
    font-size: 40px;
    line-height: initial;
    margin-bottom: 15px;
	transform: skewY(3deg);
}

body .container {
    max-width: 100%;
    width: 100%;
    margin: auto;
}

body .vc_row{
	max-width:1400px;
	margin:auto !important;
}

.vc_row[data-vc-full-width]{
	width:100% !important;
	max-width:100% !important;
	display: flex;
    justify-content: center;
    align-items: center;
}

.vc_row[data-vc-full-width][data-vc-stretch-content] .wpb_column.vc_column_container.vc_col-sm-12{
	width:100% !important;
	max-width:100% !important;
}

.vc_row[data-vc-full-width] .wpb_column.vc_column_container{
	max-width:1400px !important;
	margin:auto;
}

.related_products{
    display: flex;
    flex-wrap: wrap;
	transform: skewY(3deg);
}

.related_products .related_product{
	flex:0 0 21%;
	max-width:21%;
	margin:0% 1%;
	margin-top:1%;
	background-color: #fff;
	padding:1%;
}

.related_products .related_product a{
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    align-items: center;
    height: 100%;
	
}

.related_products .related_product img{
    max-width: 100%;
	margin-bottom: 20px;
}

.icone_title span{
	font-size:60px;
}

body .row_half.equipe_row .wpb_column.vc_column_container {
    margin: 0% auto;
}

body .row_half.equipe_row .wpb_column .vc_column-inner {
    background-size: auto;
}

body .row_half.equipe_row .wpb_wrapper {
    max-width: 70%;
}

body .row_half.equipe_row .wpb_wrapper .wpb_wrapper{
    max-width: 100%;
}

.row_half .wpb_wrapper .wpb_wrapper{
	max-width:100%
}

.row_half .title_bloc p{
	font-size:40px;
	line-height: 40px;
}

body .subtitle{
	margin-top: 3%;
    margin-bottom: 4%;
}

body .subtitle_h3{
	text-align: left;
    color: #ffd950;
	font-weight: 600;
    margin-bottom: 3%;
	text-transform:uppercase;
	
}

body .subtitle_h3 p{
	font-size:16px;
	font-weight:bold;
}

.big_title{
	text-align: center;
    font-size: 50px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 300;
    line-height: initial;
    color: #dd5120;
    margin-bottom: 0% !important;
    margin-top: 0%;
}

body .bloc_form {
    background-color: #f4e661;
    padding: 3%;
	 border-radius: 7px;
}

body .bloc_form form div{
	margin-bottom:2%;
	width:100%;
}



form p.center input{
	background-color: #e06260;
    padding: 15px 36px;
    border-radius: 4px;
    display: block;
    color: #fff;
    transition: all linear .2s;
    width: max-content;
    margin-top: 4%;
    font-size: 16px;
    font-weight: 600;
    display: flex;
    border: solid 1px #e06260;
}

form p.center input:hover{
	    background-color: transparent !important;
    color: #e06260 !important;
}

.material-symbols-outlined br{
	display:none;
}

.bloc_form #contact_form_title p{
    text-align: center !important;
    font-weight: 700;
    margin-top: 15px;
    margin-bottom: 10px;
    text-align: left;
    font-size: 26px;
	color: #80255e;
}

form p.center input:hover{
	   background-position: left bottom;
}

body .bloc_form form div.half_form{ 
	max-width:48%;
	flex:0 0 48%;
}

body .bloc_form form div.half_form input{
	padding:6% 1%;
}

body .bloc_form form{
	display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.bloc_form input, .bloc_form textarea{
	border: none;
    border-radius: 7px;
    background-color: #FFFFFF;
    color: #2E2C39;
    font-size: 16px !important;
    padding: 3% 1%;
    max-width: 98%;
    outline: none !important;
    border-color: #FFFFFF;
    box-shadow: 0px 14px 34px 0px rgb(0 0 0 / 15%);
}

body .big_title h2, body .big_title p {
    text-align: center !important;
    font-weight: 700;
    margin-top: 15px;
    margin-bottom: 10px;
    text-align: left;
    font-size: 60px;
    margin-bottom: 1% !important;
    color: #424242;
	line-height:60px;
}



.alignleft{
	float:left;
}

.aligncenter{
	display:block;
	margin:auto;
}

.galerie_photos div{
	background-color:#fff;
}

.galerie_photos div img{
	height: 100%;
    max-height: 100%;
    max-width: 100%;
    width: auto;
}

.little_sous_titre_produit{
	font-weight: 600;
	margin-bottom: 2rem;
	display:block;
}

#realisations_home{
	display:flex;
	justify-content: space-between;
}

.img_realisation img{
	width: 100%;
}


#realisations_home .realisation_single_global{
	width:24%;
	position:relative;
}

.description_realisation_in{
	padding:4% 10%;
}

.big_realisation{
	font-family: 'PT Sans', sans-serif;
    font-size: 25px;
    font-weight: 600;
    margin-bottom: 5% !important;
}

body .row_faq{
	display:flex;
	justify-content: space-between;
}

body .row_faq .wpb_column{
	margin-top:0% !important ;
}


.row_faq .vc_toggle .vc_toggle_title{
	display: flex;
    justify-content: space-between;
    align-items: center;
	background-color: #fff;
    border-radius: 14px;
    padding: 20px;
	-webkit-box-shadow: 0px 0px 12px -2px rgb(0 0 0 / 31%);
	transition:all linear 0.5s;
}

.elfsight-app-7b512d92-e790-4ce9-a555-7d8f4836edaa{
    max-width: 96%;
    margin: auto;
}

.row_faq .vc_toggle.vc_toggle_active .vc_toggle_title{
	background-color: #bb29c1;
	color:#fff;
	border-bottom-left-radius:0px;
	border-bottom-right-radius:0px;
}

.row_faq .vc_toggle.vc_toggle_active .vc_toggle_title ::before, .row_faq .vc_toggle.vc_toggle_active .vc_toggle_title ::after{
	border-color: #ffffff;
}

body .vc_toggle_content{
	background-color:#fff;
	margin-top:0%;
	margin-bottom:0%;
	-webkit-box-shadow: 0px 0px 12px -2px rgb(0 0 0 / 31%);
	padding: 20px;
	border-bottom-left-radius:14px;
	border-bottom-right-radius:14px;
}

.row_faq .vc_toggle .vc_toggle_title h4{
	margin-bottom:0% !important;
}

.row_faq .vc_toggle.vc_toggle_active{
    border-radius: 0px;
	border-top-right-radius:14px;
	border-top-left-radius:14px;
}


body .vc_tta-color-grey.vc_tta-style-modern .vc_active .vc_tta-panel-heading .vc_tta-controls-icon::after, body .vc_tta-color-grey.vc_tta-style-modern .vc_active .vc_tta-panel-heading .vc_tta-controls-icon::before{
    border-color: #fff;
}

body .vc_tta-color-grey.vc_tta-style-modern .vc_tta-controls-icon::after,body .vc_tta-color-grey.vc_tta-style-modern .vc_tta-controls-icon::before{
    border-color: #fff;
}

#realisations_home .description_realisation{
	position: absolute;
    background: #454545b3;
    background-image: radial-gradient(#ffffff1c 1px, transparent 0);
    background-size: 10px 10px;
    background-position: -19px -19px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    height: 100%;
	transition:all linear 0.5s;
	opacity:1;
    width: 100%;
	left:0%;
	top: 0%;
	bottom:0;
}

#realisations_home .realisation_single_global:nth-child(odd) .description_realisation{
	background-color:#424242ed;
}

#realisations_home .realisation_single_global:nth-child(even) .description_realisation{
	background-color:#b825cef2;
}


#realisations_home .realisation_single_global:hover > .description_realisation{
	opacity: 0; 
	top: 0;
    left: 0;
    bottom: 25%;
}

#prestations_blocs .title_bloc a{
	color:#444444;
	transition:all linear 0.5s;
}

#prestations_blocs .title_bloc a::after{
	content:"\f061";
	font-family: "Font Awesome 6 Pro";
	font-weight: 900;
	font-size:20px;
	line-height: inherit;
    vertical-align: middle;
    margin-left: 1rem;
	transition:all linear 0.5s;
	opacity:0;
}

#prestations_blocs .title_bloc a:hover::after{
	opacity:1;
	
}

body .ult_exp_section,
body .ult_exp_content.ult_active_section{
	background:none !important;
}

body .ult_exp_section .ult_expheader,
body .ult_exp_content.ult_active_section{
	text-transform:none !important;
	color: #858585;
}
 
.ult_ecpsub_cont .wpb_content_element p {
	text-align:left;
}

#toc_container{
	margin-top: 2rem;
}

.photo_principale img{
	max-width:100%;
}

.photo_principale{
	max-width:60%;
}

.global_actu header{
	padding: 5rem 0;
	background: linear-gradient(-45deg, #b825ce, #b825ce,#dd4f21, #b825ce, #424242);
	margin-bottom: 4rem;
	color:#fff;
}

.global_actu header h1{
	margin:0;
	font-size: 2.5rem;
	color:#fff;
	text-align:left;  
	line-height: initial;
}

.global_actu .date_article{
	font-style:italic;
	font-size: 0.8rem;
    border-radius: 5px;
    padding: 5px 15px;
    background-color: #fff;
    display: inline-block;
    color: #474747;
}

.global_actu .container{
	max-width:1400px;
	width:1400px;
	margin:auto;
	align-items: start;
}

.container_article .content_article{
	flex:9;
}

.container_article aside{
	flex:3;
	background-color: #d2d2d233;
	padding: 3rem;
    margin-bottom: 2em !important;
    color: #565454;
    border: dashed 2px #878787;
	margin-left:2rem;
}

.global_actu h3{
	font-size:1rem;
	color: #db4d27;
}

.global_actu #breadcrumbs a,
.global_actu #breadcrumbs span{
	color:#fff;
}

.global_actu #toc_container ul{
	margin-left:2rem;
}

.global_actu #toc_container li{
	text-indent: 10px;
}

.global_actu .wp-caption-text{
	font-style:italic;
	text-align:center;
	margin-bottom: 2rem;
    font-size: 0.9rem;
    color: #626262;
}

.global_actu .content_article img{
	max-width:100%;
}

.global_actu .content_article li{
	text-indent:10px;
	margin-bottom:10px;
}

.global_actu .content_article li ul{
	margin-top:10px;
}

.global_actu .wp-caption.alignnone{
	margin:2rem auto;
}

.global_actu h2{
	margin-top:3rem;
	font-size: 1.5rem;
    color: #db4d28;
}

.crp_related ul{
	margin-left:0;
}

.crp_related li{
	margin-bottom: 1.5rem;
}

.crp_related a{
    color: #565454;
    padding-left: 10px;
}

.crp_related ul{
	margin-left:0;
	padding-left:0;
}

.crp_related span.list_title{
	font-weight:bold;
}

#liste_articles{
	flex-wrap:wrap;
}

#liste_articles .liste_article{
	flex:4;
	max-width:24%;
	min-width:24%;
	background-color: #f8f8f8;
	margin-right:1%;
	margin-bottom:1%;
	-webkit-border-bottom-right-radius: 10px;
	-webkit-border-bottom-left-radius: 10px;
	-moz-border-radius-bottomright: 10px;
	-moz-border-radius-bottomleft: 10px;
	border-bottom-right-radius: 10px;
	border-bottom-left-radius: 10px;
	display:flex;
	flex-direction:column;
	border-radius: 10px;
}

#liste_articles .liste_article .liste_titre_article{
	font-size: 1.2rem;
	flex: 4;
	display: flex;
}

#liste_articles .liste_article .liste_image_article{
	background-size:cover;
	height:200px;
	background-repeat: no-repeat;
    background-position: center;
	-webkit-border-top-left-radius: 10px;
	-webkit-border-top-right-radius: 10px;
	-moz-border-radius-topleft: 10px;
	-moz-border-radius-topright: 10px;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
}

#liste_articles .liste_article .date_article{
	margin-top: 1rem;
    margin-left: 1rem;
	background-color: #db4c2c;
    color: #fff;
}

#liste_articles .liste_article a{
	color: #474747;
	padding:1rem;
	display:block;
	transition:all linear 0.2s;
	-webkit-border-bottom-right-radius: 10px;
	-webkit-border-bottom-left-radius: 10px;
	-moz-border-radius-bottomright: 10px;
	-moz-border-radius-bottomleft: 10px;
	border-bottom-right-radius: 10px;
	border-bottom-left-radius: 10px;
}

#liste_articles .liste_article a:hover{
	background-color: #e8e8e8;
}

p.description_archive{
	max-width: 1000px;
}

#acces_categories{
    padding-bottom: 3rem;
	flex-wrap:wrap;
}

#acces_categories .acces_categorie{
    margin-right: 1rem;
    font-size: 1.3rem;
}

#acces_categories .acces_categorie a{
	color:#fff;
	padding: 0.8rem 1.5rem;
    background-color: #424242;
    border-radius: 10px;
	transition:all linear 0.5s;
	display:block;
}

#acces_categories .acces_categorie a:hover{
	background-color:#000000;
}

.cta_bloc{
	background-color: #f8d98a;
    border-radius: 10px;
}

.cta_bloc.verticale .cta_text{
    padding: 3rem 2rem 0rem 2rem;
}

.cta_bloc.horizontale .cta_text{
    padding: 3rem;
}

.cta_bloc p{
	line-height: initial;
	font-size: 1.2rem;
}

.cta_bloc.verticale img{
	max-width:70%;
}

.cta_bloc.verticale{
	justify-content:space-between;
	text-align:center;
}

.cta_bloc.horizontale .cta_img{
	text-align:right;
	padding: 0.5rem 1rem;
    flex: 4;
}

.global_actu .content_article .cta_bloc.horizontale img,
.cta_bloc.horizontale img{
	max-width:50%;
}

.cta_bloc.horizontale{
	margin-bottom:1rem;
	margin-top:2rem;
}

.cta_bloc.horizontale a.button{
	margin-top:3rem;
}

.cta_bloc.verticale a.button{
	margin-top:1.2rem;
	margin-bottom:1.2rem;
}

.cta_bloc a.button{
	background-color: #d12f8f;
    border-radius: 5px;
    display: block;
    padding: 0.5rem 1rem;
    color: #fff;
	transition:all linear 0.5s;
	text-align: center;
	line-height:initial;
}

.cta_bloc a.button:hover{
	background-color:#fb1381;
}

.cta_bloc .cta_title{
	font-weight: bold;
    font-size: 1.5rem;
    margin-bottom: 0.8rem;
}

code{
	margin: 2rem 0;
    display: block;
    background-color: #4e4e4e;
    color: #fff;
    padding: 0.5rem;
}

.crp_related{
	margin-bottom:5rem;
}

iframe{
	max-width:100%;
}

@media screen and (max-width: 1420px){
	.container{
		max-width:1240px;
		width:1240px;
	}

}

@media screen and (max-width: 1240px){
	.container{
		max-width:1100px;
		width:1100px;
	}

}

@media screen and (max-width: 1100px){
	.container{
		max-width:1024px;
		width:1024px;
	}

}

@media screen and (max-width: 767px){
	div.flex.desktop_only{
		display: block;
	}
	
	.banner_home .banner_left .vc_column-inner {
		height: 50vh;
	}
	
	.banner_home .banner_left {
		height: 50vh;
	}
	
	.upb_row_bg{
		width:100% !important;
	}
	
	.info_vehicule h4{
		line-height: normal;
	}
	
	.padd_top_mob{
		padding-top: 8%;
	}
	
	.bandeau p {
		flex-direction: column;
	}
	
	.bloc_fonce_half .col_white {
		padding: 36px 10px !important;
	}
	
	.description_bottom {
		max-width: 95%;
	}
	
	
	
	.bottom_footer{
		flex-direction: column;
		padding-top: 7%;
		padding-bottom: 3%;
	}
	
	.left_contact {
		max-width: 80%;
		display: flex;
		margin: auto;
	}
	
	.description_top {
		max-width: 95%;
	}
	
	.bandeau p img{
		margin-left: 0px;
		margin-top: 20px;
		max-width: 100px;
		margin-bottom: 20px;
	}
	
	.bloc_fonce .wpb_column {
		padding: 10px 10px !important;
	}
	
	body h2{
		text-align:center;
	}
	
	body h3 {
        font-size: 24px !important;
        line-height: 28px !important;
        text-align: center;
    }
	
	.vc_row.vc_column-gap-35>.vc_column_container {
		padding: 0px !important;
	}
	
	body .wpb_single_image img{ 
		max-width:100% !important;
	}
	
	body .banner_home h3{
		text-align:center;
	}
	
	.photo_principale img{
		max-width:100%;
	}
	
	.global_contact {
		flex: 0 0 100%;
		display: flex	;
		flex-direction: column;
		padding: 4% 0%;
		margin-bottom: 10%;
	}
	
	body .vc_row.banner_home {
		padding:0% !important;
		flex-direction: column-reverse;
	}
	
	.banner_right .wpb_text_column .wpb_wrapper h1 {
		color: #fff;
		font-size: 44px;
		line-height: 44px;
		margin-bottom: 1% !important;
	}
	
	.burger i{
		color:#fff;
	}
	
	.container{
		max-width:100%;
		width:100%;
	}
	
	.img_avis_animation{
		display:none;
		animation: none !important;
	}
	
	#acces_categories .acces_categorie {
		margin-bottom: 4%;
	}
	
	
	
	#liste_articles .liste_article .date_article{ 
		margin-top:0%;
		margin-left:0%;
	}
	
	body .vc_row .big_banner {
		min-height: 100px;
	}
	
	
	body.home h1 {
		margin-bottom: 4% !important;
	}
	
	body .big_title p { 
		font-size: 40px;
		line-height: 40px;
	}
	
	body .row_half{
		flex-direction: column;
		flex-wrap: wrap;
	}
	
	.row_half .wpb_wrapper {
		max-width: 100%;
	}
	
	#realisations_home{
		flex-direction: column;
	}
	
	#realisations_home .realisation_single_global {
		width: 100%;
		position: relative;
		margin-bottom: 8%;
	}
	
	body .very_major_big_text{
		margin-bottom: 8% !important;
	}
	
	#footer .big_bloc {
		padding: 8% 5%;
		padding-bottom: 17%;
	}
	
	body h3 {
		font-size: 24px !important;
		margin: 6% 0%;
		line-height:24px;
		padding-left:0% !important;
	}
	
	.bloc_footer.first {
		margin-bottom: 8%;
	}
	
	body .row_half.equipe_row .wpb_wrapper {
		max-width: 100%;
	}
	
	body .big_title h2, body .big_title p {
		font-size: 45px;
		line-height: 45px;
	}
	
	.row_half_second{
		flex-direction: column;
	}
	
	.row_half_second .wpb_column {
		flex: 100%;
		max-width: 100%;
	}
	
	.bg_left_bottom.second_bg{
	    padding-bottom: 100px !important;
	}
	
	.bg_left_bottom.second_bg .upb_row_bg {
		background-position: left bottom !important;
	}
	
	.bg_left_bottom.second_bg .very_major_big_text strong {
		font-size: 50px;
		line-height: 50px;
	}
	
	body .banner h1 {
		font-size: 40px;
		line-height: 40px;
		overflow-wrap: break-word;
	}
	
	.global_bloc_third_left {
		border-left: solid 0px #fff;
		padding-left: 0%;
		text-align: center;
	}
	
	.bloc_footer.third .bloc_middle{
		text-align: center;
	}
	
	.avis_footer {
		padding: 6% 4%;
	}
	
	.row_faq.row_half_second .wpb_column {
		flex: 0 0 100%;
		max-width: 100% !important;
	}
	
	.bg_left_bottom .upb_row_bg{
		background-position: center bottom;
	}
	
	.btn a {
		display: block;
		max-width: 90%;
		padding: 5%;
		text-align: center;
		font-size: 16px;
	}
	
	.bloc_article{
		border:none;
	}
	
	.padd_left {
		padding-left: 0% !important;
	}

	.padd_right {
		padding-right: 0% !important;
	}
	
	.bloc_form {
		margin-top: 10%;
	}
	
	.bg_left_bottom.bg_bleu{
		padding-bottom: 70px !important;
	}
	
	 .big_text .wpb_wrapper p {
		font-size: 30px;
		line-height: 30px;
	}
	
	.empty{
		display:none !important;
	}
	
	.bg_left_bottom.bg_bleu .major_big_text strong {
		font-size: 40px;
		line-height: 40px;
	}
	
	.global_bloc_realisation{
		flex-direction: column;
	}
	
	body .bx-wrapper .bx-prev {
		left: 0px;
		background: url(/wp-content/uploads/2023/03/left.png);
		width: 23px !important;
		height: 40px !important;
		background-position: 0 0 !important;
		top: 60px !important;
		 background-size: cover;
	}
	
	.realisation_link {
		text-align: center;
		width: 100%;
		display: flex;
		margin-top: 3%;
	}
	
	body .bx-wrapper .bx-next {
		right: 0px;
		background: url(/wp-content/uploads/2023/03/right.png);
		width: 23px !important;
		height: 40px !important;
		background-position: 0 0 !important;
		top: 60px !important;
		background-size: cover;
	}
	
	.bg_grey iframe{
		max-width:100% !important;
	}
	
	.bloc_article ul{
		padding-left: 0%;
	}
	
	.bloc_article ul li{
		margin-bottom: 3%;
	}
	
	body .bloc_form form div.half_form {
		max-width: 100%;
		flex: 0 0 100%;
		
	}
	
	.bg_left_bottom.bg_bleu .wpb_column:nth-child(1){ 
		display:none;
	}
	
	.bg_left_bottom.bg_bleu .wpb_column:nth-child(3){
		display:none;
	}
	
	body .bloc_form form div.half_form input{
		padding:3% 1%;
	}
		
	
	.global_form div {
		flex: 0 0 100%;
		max-width: 100%;
	}

	.third_bloc_black{
		flex-direction: column;
	}
	
	.third_bloc_black .wpb_column.column_color {
		margin: 10% 0%;
	}
	
	.third_bloc_black .wpb_column {
		max-width: 100%;
	}
	
	.single_realisation {
		flex: 0 0 47%;
		max-width: 47%;
		margin: 1.5%;
	}
	
	.bloc_realisation_right{
		max-width: 79%;
	}
	
	.infos_bloc_realisation {
		flex: 0 0 100%;
		max-width: 100%;
		margin-bottom: 10px;
	}
	
	.bg_left_bottom.bg_rose{
		padding-bottom: 70px !important;
	}
	
	.bg_left_bottom.bg_rose .major_big_text strong {
		font-size: 40px;
		line-height: 40px;
	}
	
	.btn a span {
		margin-right: 5px;
	}
	
	.row_half .wpb_column .vc_column-inner{
		background-position: bottom center;
		background-size: auto 200px;
		padding-top: 4%;
		padding-bottom: 233px;
		padding-left: 2% !important;
		padding-right: 2% !important;
	}
	
	.row_half .title_bloc p {
		font-size: 32px;
		line-height: 32px;
	}
	
	.row_half .wpb_column {
		margin-bottom: 15% !important;
	}
	
	body .subtitle {
		margin-bottom: 10%;
	}
	
	body .banner .marg_top_mob{
		margin-top:10% !important;
	}
	
	body .banner{
		height:auto;
	}
	
	.btn_banner .wpb_wrapper {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
	}
	
	.btn_banner p {
		margin-bottom: 7%;
	}
	
	.btn_banner a{
		font-size: 14px;
		padding: 10px 10px;
	}
	
	#global_header .container{
	    position: relative;
	}
	
	.header_center{
		position: absolute;
		top: 100%;
		left:0%;
		width:100%;
	}
	
	.very_major_big_text strong {
		font-size: 65px;
		line-height: 65px;
	}
	
	.major_big_text strong {
		font-size: 48px;
		line-height: 48px;
	}
	
	.eapps-widget-toolbar{
		display:none !important;
	}
	
	#footer .big_bloc .contain{
		flex-direction: column;
	}
	
	.search.container .result{
		margin:4% 0%;
	}
	
	header.sticky #global_header {
		position: inherit;
	}
	
	.search.container{
		max-width: 96%;
		margin: 2%;
		margin-top: 7%;
	}
	
	.search.container h1{
	    margin-bottom: 10%;
	}

	#fil_ariane{
		display:none;
	}
	
	
	.menu li a {
		padding: 15px 2em;
		color: #3c3c3c;
		transition: all 0.3s ease-out;
		border-radius: 5px;
		font-size: 17px;
		font-weight: 300;
		width: 100%;
	}
	
	.burger{ 
		width: 35%;
		display: flex;
		justify-content: end;
		align-items: center;
		font-size: 23px;
		padding-right: 5%;
	}
	
	#menu-main-menu {
		position: absolute;
		z-index: 9;
		background-color: #fff;
		padding-top: 15px;
		padding-bottom: 15px;
	}
	
	.menu_close.active{
		display:block;
	}
	
	.menu_open.active{
		display:block;
	}
	
	#footer .container{
		flex-direction: column;
		padding-bottom: 5%;
	}
	
	.slider button{
		display:none !important;
	}
	 
	.bg_clair ul{
		padding-left:20px;
	}
	

	
	body .button_envoi_form input{
		margin-left:0%;
	}
	
	body .content_form_tri select{ 
		margin-right:0%;
	}
	
	body .actu_home .vc_row {
		padding-right:0% !important;
		padding-left:0% !important;
	}
	
	body.home .slider{
		padding-right:0% !important;
		padding-left:0% !important;
	}
	
	.three_bloc .wpb_column {
		max-width: 100%;
		padding: 6% 0%;
	}
	
	.four_bloc .wpb_column {
		max-width: 100%;
		padding: 8% 0%;
	}
	
	#footer .bloc_widget{
		text-align: center;
		margin-bottom: 15px;
	}
	
	#footer p, #footer a{
		text-align:center;
	}
	
	.header_right{
		display:none;
	}
	
	#logo img {
		width: max-content;
		max-width: 100%;
	}
	
	#global_header .container{
		padding:4%;
	}
	
	#global_header #logo {
		max-width: 100%;
		display:flex;
		align-items: center;
		flex: 0 0 100%;
	}
	
	.bg_blue{
		margin-bottom: 4% !important;
	}
	
	.marg_bot_mob .wpb_column  {
		margin-bottom: 4% !important;
	}
	
	
	
	.bloc_home .vc_col-sm-6 a {
		min-height: 300px;
	}
	
	
	body.home h1 {
		margin-bottom: 10% !important;
	}
	
	.slider .slick-track .slick-slide {
		height: 300px;
		margin: 0% !important;
	}
	
	.slider .slick-track .slick-slide .wpb_text_column .wpb_wrapper a {
		font-size: 18px;
		padding: 0px 10px;
	}
	
	body h3 {
		font-size: 19px;
		padding-right: 2%;
		padding-left: 2%;
	}
	
	.menu-main-menu-container{
		display:none;
	}
	
	.bg_clair {
		padding: 8% 3%;
	}
	
	.agenda_little_global .lieu_agenda{
		font-size:15px;
	}
	
	#top_panel {
		background-color: #282828;
		padding: 10px 10px;
	}
	
	#fil_ariane {
		padding: 2%;
		max-width: 96%;
	}
	
	.line {
		display: flex;
		justify-content: space-between;
		flex-direction: column;
	}
	
	.line .vc_column_container {
		max-width: 100%;
		margin-bottom: 5%;
	}
	
	.hauteur {
		padding-bottom: 0%;
	}
	
	body h1 {
		font-size: 22px;
	}
	
	.width80 {
		width: 100%;
	}
	
	body .vc_row{
		padding-left: 4% !important;
		padding-right: 4% !important;
	}
	
	.padd {
		padding-top: 8% !important;
		padding-bottom: 8% !important;
	}
	
	.menu li{
		width:100%;
	}

	.line.padd.no_padd_mob{
		padding-top: 0% !important;
		padding-bottom: 0% !important;
	}
	
	.line.padd_top.no_padd_mob{
		padding-top: 0% !important;
	}
	
	body h2 {
		margin-bottom: 5% !important;
		font-size: 1.2em;
	}
	
	.empty{
		display:none !important;
	}
	
	body .ult-carousel-wrapper {
		margin-bottom: 0px;
	}
	
	.slick-dots{
		display:none !important;
	}
	
	.bloc_actu_home .date {
		margin-bottom: 6%;
	}
	
	.bloc_actu_home .image_actualite h5 {
		margin-bottom: 20px;
	}
	
	.bloc_actu_home .extrait {
		font-size: 17px;
	}
	
	#footer{
		padding-top: 30px;
	}
	
	.flex .vc_row {
		display: flex;
		flex-direction: column;
	}
	
	.global_valeur .wpb_column {
		margin-bottom: 15%;
	}
	
	body .global_historique .vc_single_image-wrapper::before{
		width:0px;
		height:0px;
	}
	
	body .global_historique .left .vc_single_image-wrapper::before{
		width:0px;
		height:0px;
	}
	
	body .global_historique.inverse{
		flex-direction: column-reverse;
	}
	
	body .global_historique .wpb_wrapper{
		text-align: center;
		margin-bottom: 15px;
	}
	
	body .global_historique .wpb_wrapper p{
		text-align: center !important;
	}
	
	body .global_historique:last-child{
		margin-bottom:0% !important;
	}
	
	div#liste_evenements div.evenement {
		width: 100%;
		margin-right: 0%;
		background-color: #f2f2f2;
		margin-bottom: 5%;
	}
	
	body .banner_title h1::after {
		content: url(/wp-content/uploads/2021/11/arrow.png);
		display: block;
		margin-bottom: 3%;
		margin-top: 2%;
	}
	
	.padd_top {
		padding-top: 10% !important;
	}

	.padd_bottom {
		padding-bottom: 10% !important;
	}
	
	.banner_title {
		padding-top: 5% !important;
		padding-bottom: 5% !important;
	}
	
	.center_mob.wpb_single_image {
		text-align:center !important;
			margin-bottom: 5%;
	}
	
	#liste_produits .produit {
		flex: 3;
		padding: 0%;
		margin-right: 0%;
		min-width: 100%;
		margin-bottom: 45px;
		max-width: 100%;
	}
	
	.content_form_tri {
		margin: auto;
		display: flex;
		padding: 6% 0%;
		flex-direction: column;
		justify-content: center;
		align-items: center;
	}
	
	.content_form_tri .button_envoi_form{
		margin-top:4%;
	}
	
	.content_form_tri select {
		width: 80%;
	}
	
	.global_description_produit_long {
		width: 100%;
	}
	
	.description_produit_top {
		width: 100%;
	}
	
	.description_produit_top{
		flex-direction: column;
	}
	
	.little_global_fiche_produit{
		margin: 5% 4%;
		width: 92%;
	}
	
	.etiquette {
		font-size: 13px;
	}
	
	.description_produit_middle.container{
		flex-direction: column;
	}
	
	.document_produit {
		background-color: #f8f8f8;
		padding: 2%;
	}
	
	.table_produit {
		margin-right: 0%;
		width: 96%;
		max-width: 100%;
		margin-left: 2%;
	}
	
	.global_table_produit .table_left{
		flex:0 0 40%;
	}
	
	.table_right p {
		margin-left: 0%;
	}
	
	.besoin_renseignement {
		background-color: #209a9c;
		flex: 1;
		text-align: center;
		padding: 6% 3%;
		max-width: 100%;
		margin: auto;
		margin-top: 10%;
		margin-bottom: 10%;
	}
	
	.global_liste_actu .wpb_text_column .wpb_wrapper {
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
	}
	
	.invert_mob{
		flex-direction: column-reverse;
	}
	
	.half_section .text_right {
		padding-left: 0%;
	}
	
	.besoin_renseignement h3 {
		padding: 0%;
	}
	
	.little_col .vc_column-inner {
		max-width: 100%;
	}
	
	.aero {
		padding: 2% !important;
		margin-right: 2% !important;
		width: 48% !important;
		align-items: baseline !important;
	}
	
	.aero h3{
		word-wrap: break-word;
	}
	
	.global_lien .wpb_column {
		margin-bottom:40px;
	}
	
	.global_liste_actu .wpb_text_column .wpb_wrapper {
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
	}
	
	.global_liste_actu .wpb_text_column .wpb_wrapper .actualite {
		display: flex;
		flex: 0 0 90%;
		max-width: 90%;
		padding:5%;
		margin-bottom: 5%;
		margin-top: 5%;
	}
	
	.container.entete_fiche_formation {
		display: flex;
		flex-direction: column;
	}
	
	.offre_d_emploi-template-default.single h1 {
		margin-bottom: 5%;
		margin-top: 5%;
	}
	
	.offre_renseignements {
		flex: 4;
		background-color: #209a9c;
		margin-right: 0%;
		text-align: center;
		padding: 6% 3%;
		max-width: 100%;
		margin: auto;
		margin-top: 10%;
		margin-bottom: 10%;
		font-size: 16px;
		color: #fff;
	}
	
	form p.form {
		width: 100%;
		margin-bottom: 4%;
	}
	
	#wpcf7-f7-p243-o1 form{
		margin-top: 10%;
	}

	
	.row_table_offre {
		flex-direction: column;
	}
	
	.row_global_formation {
		flex-direction: column;
	}
	
	.row_global_formation{
		flex-wrap: wrap;
	}
	
	.global_table_formation {
		max-width: 100%;
		margin-right:0%;
	}

	.lieu_offre {
		color: #27357f;
		font-size: 15px;
	}
	
	.contrat_offre {
		color: #27357f;
		font-size: 15px;
	}
	
	#liste_offres .offre {
		flex: 4;
		padding: 0%;
		margin-right: 2%;
		min-width: 90%;
		margin-bottom: 5%;
		max-width: 100%;
		padding: 5%;
		margin-bottom: 4%;
		margin-top: 4%;
		background-color: #fff;
		-webkit-transition: all 0.3s linear;
		transition: all 0.3s elinear;
		-moz-transition: all 0.3s elinear;
	}
	
	body.single  article{
		max-width: 96%;
		margin: 2%;
	}
	
	.global_actu h1 {
		margin-bottom: 3%;
		padding: 0% 4%;
		margin-bottom: 5%;
	}
	
	.global_confiance .wpb_column {
		    max-width: 75%;
		margin: auto;
		margin-top: 8%;
		margin-top:4%;
	}
	
	.sub-menu li {
		margin-left: 5% !important;
		padding-left: 30px !important;
	}

	
	body  .menu-item-has-children{
		flex-direction: column;
	}
	
	.menu li .sub-menu {
		flex-direction: column;
	}
	
	.menu li {
		width: 100%;
		flex: 0 0 100%;
		padding: 0%;
		display: flex;
	}
	
	p.description_archive {
		max-width: 100%;
	}
	
	.global_actu .container{
		max-width:90%;
	}
	
	.global_actu header h1,
	.global_actu #breadcrumbs,
	.global_actu .description_archive{
		text-align:center;
	}
	
	#liste_articles .liste_article{
		width:100%;
		max-width:100%;
		margin-bottom:2rem;
	}
	
	.global_actu .date_article{
		text-align: center;
		display: block;
	}
	
	.global_actu #toc_container ul{
		margin-left:0;
	}
	
	.global_actu .content_article ul{
		padding-left: 1rem;
	}
	
	.global_actu #toc_container li {
		text-indent: 0px;
	}
	
	div.wp-caption{
		max-width:100%;
	}
	
	.container_article aside{
		margin-left:0;
		padding:2rem;
	}
	
	.cta_bloc.verticale .cta_text {
		padding: 2rem 1rem 0rem 1rem;
	}
	
	.cta_bloc.horizontale .cta_img{
		text-align:center;
	}
	
	.cta_bloc .cta_title,
	.cta_bloc p{
		text-align:center;
	}
	
	.menu{
		padding-right:3%;
	}
	
	.menu li.current-menu-item a{
		color: #3c3c3c !important;
	}
	
	body .menu .contact_menu a{
		color:#fff !important;
	}
}

@media screen and (min-width: 768px) and (max-width: 1023px) { 

	.container {
		max-width: 96%;
		width: 96%;
		margin:auto;
	}
	
	.description_bottom {
		max-width: 75%;
	}
	
	body .big_title h2, body .big_title p {
		font-size: 38px;
	}
	
	.global_contact {
		flex: 0 0 100%;
		display: flex	;
		padding: 4% 0%;
	}

	
	.bloc_fonce_half .col_white {
		background-color: #fff;
		padding: 45px !important;
		margin-left: 3% !important;
	}
	
	.bandeau p img {
		max-width: 100px;
	}
	
	body h2{
		line-height: normal;
	}
	
	.vc_row[data-vc-full-width].bloc_fonce .wpb_column.vc_column_container{ 
		max-width:80% !important;
	}
	
	body h3{
		text-align:center;
	}
	
	.photo_principale img{ 
		max-width:100% !important;
	}
	
	.menu{
		padding-right:3%;
	}
	
	.menu li.current-menu-item a{
		color: #3c3c3c !important;
	}
	
	body .menu .contact_menu a{
		color:#fff !important;
	}	
	
	
	.burger i{ 
		color:#fff !important;
	}
	
	body.category .global_actu{
		margin:0% 2%;
	}
	
	header.sticky #global_header{
		position:inherit;
	}
	
	body.single {
		margin: 0% 1%;
	}
	
	.global_actu.padd{
		padding-top:0% !important;
	}
	
	#global_header{
		padding: 2% 0%;
	}
	
	.global_actu header {
		padding: 5rem 2%;
	}
	
	.global_actu .container{
		max-width:100%;
		flex-wrap: wrap;
	}
	
	.container_article .content_article {
		flex: 0 0 100%;
	}
	
	.container_article aside {
		flex: 0 0 94%;
		padding:3%;
		margin-left:0%;
	}
	
	.bloc_footer.third {
		flex: 0 0 100%;
	}
	
	.global_bloc_third_left {
		border-left: solid 0px #fff;
		display: flex;
		max-width: 68%;
		margin-left: 32%;
		justify-content: space-between;
	}
	
	.global_bloc_third_left .bloc_middle{
		flex:0 0 48%;
	}
	
	.major_big_text strong {
		font-size: 56px;
		line-height: 56px;
	}
	
	.bg_left_bottom.second_bg .very_major_big_text strong {
		font-size: 72px;
		line-height: 72px;
	}
	
	body .banner h1 {
		font-size: 43px;
		line-height: 43px;
	}
	
	.infos_footer {
		margin-top: 0%;
	}

	
	.eapps-widget-show-toolbar{
		max-width: 96%;
		margin: auto;
	}
	
	.bloc_footer.first {
		flex: 0 0 32%;
	}
	
	.bloc_footer.second {
		flex: 0 0 68%;
	}
	
	body .vc_row .big_banner {
		min-height: 106px;
		position: relative;
		margin-bottom: 3%;
	}
	
	.row_half{
		flex-wrap:wrap;
	}
	
	.row_half_second {
		justify-content: space-evenly;
		display: flex;
		flex-wrap: wrap;
	}
	
	.empty{
		display:none;
	}
	
	.major_big_text strong {
		font-size: 51px;
		line-height: 51px;
	}
	
	
	#realisations_home {
		flex-wrap: wrap;
		justify-content: space-evenly;
	}
	
	.bg_left_bottom {
		padding-bottom: 15% !important;
	}
	
	#realisations_home .realisation_single_global {
		width: 48%;
		position: relative;
		flex: 0 0 48%;
		margin-bottom: 2%;
	}
	
	body .bx-wrapper .bx-prev {
		left: 10px;
	}
	
	body .bx-wrapper .bx-next{
		right:10px;
	}
	
	.global_form{
	    max-width: 96%;
		margin: auto;
	}
	
	.bloc_realisation_right{
		max-width:80%;
	}
	
	.bloc_realisation_left{
		max-width:13%;
	}
	
	.row_half .wpb_column {
		flex: 0 0 96%;
	}
	
	.menu li a {
		padding: 15px 2em;
		color: #3c3c3c;
		transition: all 0.3s ease-out;
		border-radius: 5px;
		font-size: 17px;
		font-weight: 300;
		width: 100%;
	}
	
	.menu-main-menu-container {
		display: none;
	}
	
	.menu-main-menu-container.active{
		display: block;
	}
	
	#global_header #logo{
		max-width: 100%;
		display: flex;
		align-items: center;
		flex: 0 0 100%;
		justify-content: space-between;
	}
	
	#global_header .container {
		flex-wrap: wrap;
	}
	
	.header_center {
		flex: 0 0 100%;
		display: flex;
		justify-content: end;
		align-items: center;
	}
	
	.burger{ 
		width: 35%;
		display: flex;
		justify-content: end;
		align-items: center;
		font-size: 23px;
		padding-right: 5%;
	}
	
	.menu li {
		justify-content: flex-start;
	}
	
	#menu-main-menu {
		position: absolute;
		z-index: 9;
		background-color: #fff;
		padding-top: 15px;
		padding-bottom: 15px;
		width:100%;
		flex-direction: column;
		
	}
	
	body .menu .btn a{
		margin-top:0%;
		width: max-content;
		margin: unset;
	}
	
	.menu_close.active{
		display:block;
	}
	
	.menu_open.active{
		display:block;
	}
	
	#logo a{
		display:inline-block;
	}
	
	body .menu li a {
		padding: 15px 0px;
	}
	
	body .menu li a {
		font-size: 14px;
	}
	
	.menu li .sub-menu{
		justify-content:center;
		top: 55.5px !important;
	}
	
	.global_valeur .wpb_column {
		padding: 0% 2%;
		width: 48%;
		margin-bottom: 5%;
	}
	
	body .global_historique .vc_single_image-wrapper::before{
		display:none;
	}
	
	body .global_historique .left .vc_single_image-wrapper::before{
		display:none;
	}
	
	div#liste_evenements div.evenement {
		width: 46%;
	}
	
	.hauteur .vc_column-inner h3 a {
		padding-top: 170px;
		padding-bottom: 170px;
	}
	
	.global_half .wpb_column {
		width:48%;
		flex:0 0 48%;
	}
	
	.width60 {
		width:60% !important;
		flex:0 0 60%  !important;
	}
	
	.width40 {
		width:40% !important;
		flex:0 0 40%  !important;
	}
	
	.global_half .wpb_column.empty_col{
		display:none !important;
	}
	
	#liste_produits .produit {
		flex: 3;
		padding: 0%;
		margin-right: 2%;
		min-width: 31%;
		margin-bottom: 7%;
		max-width: 31%;
	}
	
	.little_global_fiche_produit {
		margin-top: auto;
		margin-bottom: auto;
		padding: 5%;
		max-width: 50%;
		flex: 0 0 50%;
	}
	
	.besoin_renseignement {
		max-width: 35%;
	}
	
	.table_produit {
		margin-right: 5%;
		width: 55%;
		max-width: 55%;
	}
	
	.center_tab{
		margin: auto;
		margin-top: 6%;
	}
	
	.aero h3{
		word-wrap: break-word;
	}
	
	body .table_right p {
		margin-left: 0%;
	}
	
	.global_table_produit .table_left {
		flex: 0 0 30%;
	}
	
	.description_produit_top {
		width: 99%;
	}
	
	.global_description_produit_long {
		width: 100%;
		margin: auto;
		display: flex;
	}
	
	.description_produit_long {
		flex: 2;
		font-size: 15px;
		width: 100%;
		max-width: 100%;
		margin-bottom: 4%;
	}
	
	.line .vc_column_container {
		max-width: 47%;
		width: 47%;
	}
	
	.global_liste_actu .wpb_text_column .wpb_wrapper .actualite {
		display: flex;
		flex: 0 0 31%;
		max-width: 31%;
		flex-direction: column;
		background-color: #f7f7f7;
		padding: 2%;
	}
}


@media screen and (min-width: 1300px) and (max-width: 1550px) { 
	body .menu .btn a {
		padding: 11px 25px;
	}
	
	.menu li {
		padding: 0px 7px;
	}
	
	body .vc_row .big_banner {
		min-height: 72px;
	}
	
	#global_header .container {
		display: flex;
		width: 98%;
		max-width: 98%;
	}
	
	.menu {
		padding-left: 2%;
	}
	
	.menu li a {
		font-size: 16px;
	}
}

@media screen and (min-width: 1300px) and (max-width: 1390px) { 

	.menu li a {
		font-size: 14px;
	}
	
	.global_actu .container {
		max-width: 98%;
		flex-wrap: wrap;
	}
	
	.global_actu.padd{
		margin-top:2%;
	}
}

@media screen and (min-width: 1023px) and (max-width: 1300px) { 

	body .menu li a {
		padding: 30px 0em;
	}
	
	.vc_row[data-vc-full-width].bloc_fonce  .wpb_column.vc_column_container {
		max-width: 80% !important;
	}
	
	body #fil_ariane {
		padding: 15px 2%;
		font-size: 13px;
		font-weight: 400;
		max-width: 96% !important;
	}
	
	body #top_panel .container {
		max-width: 100%;
		width: 97%;
	}
	
	body .container {
		max-width: 100%;
		width: 100%;
	}
	
	body .menu li .sub-menu{
		justify-content: center;
	}
	
	body .bx-wrapper .bx-prev {
		left: -10px;
	}
	
	body .bx-wrapper .bx-next {
		right: -10px;
	}
	
	.global_form{
		max-width:96%;
	}
}


@media screen and (min-width: 1023px) and (max-width: 1300px) { 

	body .menu li a {
		padding: 30px 0em;
	}
	
	.banner.img_fond_banner .upb_row_bg {
		margin-top: 6%;
	}
	
	.banner.img_fond_banner {
		padding: 8% 0% !important;
	}
	
	body .banner h1 {
		font-size: 40px;
		line-height: 40px;
	}
	
	body .menu .btn a {
		padding: 10px 20px;
	}
	
	.menu li {
		padding: 0px 5px;
	}
	
	.menu {
		padding-left:1%;
	}
	
	.row_half .wpb_column .vc_column-inner {
		background-size: 50% auto;
	}
	
	.row_half_second {
		justify-content: space-evenly;
	}
	
	body .menu .btn a {
		margin: inherit;
	}
	
	header.sticky.active #logo img {
		max-width: 190px;
	}
	
	body .vc_row .big_banner {
		min-height: 100px;
	}

	
	#global_header .container {
		display: flex;
		width: 98%;
		max-width: 98%;
	}
	
	.global_actu .container {
		max-width: 98%;
		flex-wrap: wrap;
	}
	
	.menu li a {
		font-size: 13px;
	}
	
	.global_actu.padd{
		margin-top: 7%;
	}
	
	#acces_categories
	
	.header_center {
		flex: 0 0 79%;
	}
	
	#global_header #logo {
		max-width: 21%;
	}
	
	#logo a{
		display:inline-block;
	}
	
	body .menu li .sub-menu{
		justify-content: center;
	}
}

@media screen and (min-width: 1150px) and (max-width: 1300px) { 
	.header_center {
		flex: 0 0 72%;
	}
	
	#global_header #logo {
		max-width: 28%;
	}
	
	#global_header .container {
		justify-content: center;
	}
}


/* ===== Option C : soulignement rouge animé (glisse gauche→droite) ===== */

/* Supprime la bordure blanche existante */
.header_center .menu li a {
    border-bottom: none !important;
}
.header_center .menu li a:hover {
    border-bottom: none !important;
}

/* Pseudo-élément rouge, invisible par défaut */
.header_center .menu li a::after {
    content: "";
    position: absolute;
    bottom: -3px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #cb2228;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.28s ease;
}

/* Glissement au hover */
.header_center .menu li a:hover::after {
    transform: scaleX(1);
}

/* Page active : ligne rouge permanente */
.header_center .menu li.current-menu-item a {
    color: #fff;
}
.header_center .menu li.current-menu-item a::after {
    transform: scaleX(1);
}


/* ===== Top bar rouge ===== */
#top_bar {
    background-color: #cb2228;
    padding: 7px 0;
}
#top_bar .container {
    display: flex;
    justify-content: flex-end;
    max-width: 1400px;
    margin: auto;
    padding: 0 20px;
}
#top_bar .top_bar_menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 6px;
}
#top_bar .top_bar_menu li {
    padding: 0;
    display: flex;
    align-items: center;
}
#top_bar .top_bar_menu li + li::before {
    content: "|";
    color: rgba(255,255,255,0.45);
    margin-right: 6px;
    font-size: 11px;
}
#top_bar .top_bar_menu li a {
    color: #fff !important;
    font-size: 12.5px;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-transform: none;
    text-decoration: none;
    border-bottom: none !important;
    padding: 0 8px;
    transition: opacity 0.2s;
}
#top_bar .top_bar_menu li a:hover {
    opacity: 0.8;
    border-bottom: none !important;
}
#top_bar .top_bar_menu li a::after {
    display: none !important;
}
@media (max-width: 768px) {
    #top_bar { display: none; }
}



/* ===== Bouton Contact — ghost pill moderne ===== */

/* Poussé à droite dans la barre nav */
.header_center .menu li.menu-contact-btn {
    margin-left: auto;
}

/* Ghost pill : contour blanc semi-transparent, texte blanc */
.header_center .menu li.menu-contact-btn a {
    background-color: transparent !important;
    border: 1.5px solid rgba(255,255,255,0.55) !important;
    border-radius: 50px !important;
    color: #fff !important;
    padding: 7px 20px 7px 14px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    text-transform: uppercase;
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    transition: background-color 0.25s ease,
                border-color 0.25s ease,
                box-shadow 0.25s ease,
                transform 0.2s ease !important;
}

/* Icône Material Symbols "call" */
.header_center .menu li.menu-contact-btn a::before {
    font-family: 'Material Symbols Outlined';
    font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 20;
    content: '\e0cd';
    font-size: 17px;
    line-height: 1;
    color: #fff;
}

/* Hover : fond rouge + éclat + légère élévation */
.header_center .menu li.menu-contact-btn a:hover {
    background-color: #cb2228 !important;
    border-color: #cb2228 !important;
    box-shadow: 0 4px 18px rgba(220,78,75,0.50) !important;
    transform: translateY(-1px);
    color: #fff !important;
}

/* Pas de soulignement animé */
.header_center .menu li.menu-contact-btn a::after {
    display: none !important;
}


/* Fix alignement bouton Contact sur container */
.header_center {
    flex: 1 !important;
}
.header_right {
    flex: 0 0 auto !important;
}
.header_center .menu-main-menu-container,
.header_center > div {
    width: 100%;
}
.header_center .menu {
    width: 100%;
}


/* ===== Alignement container header sur 1400px ===== */

/* Header container identique à la top bar */
#global_header .container {
    max-width: 1400px !important;
    width: 100% !important;
    margin: auto !important;
    padding: 0 20px !important;
}

/* Bord droit du bouton Contact aligné sur celui de Règlementation */
.header_center .menu li.menu-contact-btn {
    margin-right: 0;
	padding-right: 0;
}
/* Supprime le padding droit résiduel du dernier item top bar */
#top_bar .top_bar_menu li:last-child a {
    padding-right: 0;
}


/* ================================================================
   MOCKUP — Top bar sombre, nav blanche, hero redesigné
   ================================================================ */

/* --- TOP BAR : fond très sombre, texte crème ---*/
#top_bar {
    background-color: #1e2130 !important;
}
#top_bar .top_bar_menu li a {
    color: #c5c2b5 !important;
}
#top_bar .top_bar_menu li a:hover {
    color: #fff !important;
    opacity: 1 !important;
}
#top_bar .top_bar_menu li + li::before {
    color: rgba(255,255,255,0.2) !important;
}

/* --- NAVIGATION : fond blanc ---*/
#global_header {
    background-color: #ffffff !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
    position: relative;
    z-index: 500;
}

/* Texte des liens : sombre */
.header_center .menu li a {
    color: #1e2130 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0.2px;
}
.header_center .menu li a:hover {
    color: #cb2228 !important;
}
.header_center .menu li.current-menu-item a {
    color: #cb2228 !important;
}

/* Soulignement animé rouge (déjà en place, juste confirmation couleur) */
.header_center .menu li a::after {
    background-color: #cb2228;
}

/* --- BOUTON NOUS CONTACTER : solide rouge sur blanc ---*/
.header_center .menu li.menu-contact-btn a {
    background-color: #cb2228 !important;
    border-color: #cb2228 !important;
    color: #fff !important;
}
.header_center .menu li.menu-contact-btn a::before {
    color: #fff !important;
}
.header_center .menu li.menu-contact-btn a:hover {
    background-color: #b83d3a !important;
    border-color: #b83d3a !important;
}

/* --- HERO BANNER --- */
.banner {
    background-color: #fff;
    min-height: 520px;
}

/* Badge certification */
.certif_top_badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background-color: #fef0f0;
    border: 1px solid #f5c6c5;
    border-radius: 50px;
    padding: 5px 14px;
    font-size: 13px;
    font-weight: 500;
    color: #c0392b;
    margin-bottom: 20px;
}
.certif_top_badge span {
    font-weight: 700;
}

/* H1 hero */
.banner h1 {
    text-transform: none !important;
}
.banner h1 .rouge {
    color: #cb2228;
}

/* Texte accroche */
.banner_accroche {
    font-size: 15px;
    color: #555;
    line-height: 1.7;
    margin-bottom: 28px;
    max-width: 420px;
}

/* Groupe de boutons CTA */
.banner_cta_group {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 32px;
    align-items: center;
}
a.btn_primary {
    display: inline-block;
    background-color: #cb2228;
    color: #fff !important;
    border-radius: 50px;
    padding: 12px 28px;
    font-weight: 700;
    font-size: 14.5px;
    text-decoration: none;
    transition: background-color 0.22s, box-shadow 0.22s;
    border: 2px solid #cb2228;
}
a.btn_primary:hover {
    background-color: #b83d3a;
    box-shadow: 0 4px 16px rgba(220,78,75,0.35);
    color: #fff !important;
}
a.btn_outline {
    display: inline-flex;
    align-items: center;
    background-color: transparent;
    color: #fff !important;
    border-radius: 50px;
    padding: 12px 28px;
    font-weight: 600;
    font-size: 14.5px;
    text-decoration: none;
    border: 2px solid #fff;
    transition: background-color 0.22s, color 0.22s;
}
a.btn_outline:hover {
    background-color: #fff;
    color: #1e2130 !important;
}
a.btn_outline .material-symbols-outlined {
    font-size: 17px !important;
    line-height: 1;
    margin-right: 6px;
}

/* Variante outline sur fond clair */
a.btn_outline_alt {
    display: inline-flex;
    align-items: center;
    background-color: transparent;
    color: #cb2228 !important;
    border-radius: 50px;
    padding: 12px 28px;
    font-weight: 600;
    font-size: 14.5px;
    text-decoration: none;
    border: 2px solid #cb2228;
    transition: background-color 0.22s, color 0.22s;
}
a.btn_outline_alt:hover {
    background-color: #cb2228;
    color: #fff !important;
}
a.btn_outline_alt .material-symbols-outlined {
    font-size: 17px !important;
    line-height: 1;
    margin-right: 6px;
}

/* Badges certifications bas de hero */
.certif_badges_row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 4px;
}
.certif_badge_pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    border: 1.5px solid #ddd;
    border-radius: 50px;
    padding: 5px 14px;
    font-size: 12.5px;
    font-weight: 500;
    color: #444;
    background: #fff;
}

/* Stats sur colonne droite */
.banner_stats_row {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(30,33,48,0.75);
    backdrop-filter: blur(4px);
    display: flex;
    justify-content: space-around;
    padding: 18px 20px;
}
.banner_stat_item {
    text-align: center;
    color: #fff;
}
.banner_stat_item .stat_val {
    font-size: 1.9em;
    font-weight: 800;
    color: #fff;
    display: block;
    line-height: 1.1;
}
.banner_stat_item .stat_label {
    font-size: 11.5px;
    color: rgba(255,255,255,0.75);
    display: block;
    margin-top: 3px;
}

/* Colonne droite : position relative pour les stats */
.banner .vc_col-sm-2-5,
.banner .vc_col-sm-8,
.banner [class*="vc_col-sm-"] + [class*="vc_col-sm-"] {
    position: relative;
}

@media (max-width: 900px) {
    .banner h1 { font-size: 1.8em !important; }
    .banner_stats_row { position: static; }
    .certif_badges_row { gap: 7px; }
}


/* ===== CORRECTIFS : logo, casse menu, séparateur ===== */

/* 1. Logo moins grand */
#global_header #logo img {
    max-height: 62px !important;
    width: auto !important;
    max-width: 100% !important;
}

/* 2. Menu : passer en mixed case (pas uppercase) */
.header_center .menu li a {
    text-transform: none !important;
    font-size: 15px !important;
}

/* 3. Séparateur gris sous le menu */
#global_header {
    border-bottom: 1px solid #e2e2e2 !important;
}

/* Style du brand tag au-dessus du H1 */
.banner_brand_tag {
    display: block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #cb2228;
    margin-bottom: 10px;
}


/* ===== CORRECTIFS v2 ===== */

/* 1. Logo : taille légèrement augmentée */
#global_header #logo img {
    max-height: 78px !important;
}

/* 2. AFPS Secourisme dans le H1 : style propre */
.banner h1 .h1_brand {
    display: block;
    font-size: 0.48em;
    font-weight: 600;
    color: #666;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-bottom: 6px;
    line-height: 1.4;
}

/* 3. Centrage du menu */
.header_center .menu {
    padding-left: 0 !important;
    justify-content: center !important;
}

/* 4. Badges logos : ajustements pour les images */
.certif_badge_pill img {
    display: inline-block;
    vertical-align: middle;
    max-height: 22px;
    width: auto;
}
.certif_badge_pill.badge_qualiopi {
    padding: 4px 10px;
}
.certif_badge_pill.badge_qualiopi img {
    max-height: 28px;
}


/* ===== Badges certifications : mix logo + texte ===== */
.certif_badges_row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
    align-items: center;
}
.certif_badge_pill {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    border: 1.5px solid #e0e0e0 !important;
    border-radius: 50px !important;
    padding: 6px 14px !important;
    font-size: 12.5px;
    font-weight: 500;
    color: #444;
    background: #fff;
    white-space: nowrap;
}
.certif_badge_pill img {
    display: block;
    width: auto;
    vertical-align: middle;
}
.certif_google img  { max-height: 16px; }
.certif_qualiopi img { max-height: 20px; }
.certif_qualiopi { padding: 5px 12px !important; }
.certif_veritas .certif_check {
    color: #cb2228;
    font-weight: 700;
}


/* Logo Qualiopi standalone sous les badges */
.qualiopi_logo_banner {
    margin-top: 14px;
    display: inline-block;
}
.qualiopi_logo_banner img {
    opacity: 0.9;
    transition: opacity 0.2s;
    display: block;
}
.qualiopi_logo_banner img:hover {
    opacity: 1;
}


/* ===== Centrage vertical colonne gauche bannière ===== */
.banner .vc_column-inner {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    height: 100% !important;
}

/* Logo Qualiopi inline dans la rangée de badges */
.certif_badges_row {
    align-items: center !important;
    flex-wrap: wrap;
}
.certif_qualiopi_logo {
    display: inline-flex;
    align-items: center;
    margin-left: 4px;
    opacity: 0.85;
    transition: opacity 0.2s;
}
.certif_qualiopi_logo:hover { opacity: 1; }
.certif_qualiopi_logo img {
    display: block;
    height: 32px;
    width: auto;
}
/* Supprime le CSS de l'ancien bloc standalone */
.qualiopi_logo_banner { display: none; }


/* Top bar : liens en gris clair */
#top_bar .top_bar_menu li a {
    color: #9da3ae !important;
}
#top_bar .top_bar_menu li a:hover {
    color: #d1d5db !important;
}
#top_bar .top_bar_menu li + li::before {
    color: rgba(255,255,255,0.15) !important;
}

/* ===== Centrage réel des items nav sur la pleine largeur ===== */
/* header_center couvre toute la largeur en absolu, hors du flux flex */
#global_header .container {
    position: relative !important;
}
.header_center {
    position: absolute !important;
    left: 20px !important;
    right: 20px !important;
    top: 0 !important;
    bottom: 0 !important;
    flex: unset !important;
    display: flex !important;
    align-items: center !important;
    pointer-events: none !important;
    z-index: 1;
}
.header_center .menu-main-menu-container,
.header_center > div {
    pointer-events: none !important;
    width: 100% !important;
    display: flex !important;
}
.header_center .menu {
    width: 100% !important;
    position: relative !important;
    justify-content: center !important;
    padding: 0 160px !important;
    pointer-events: none !important;
}
.header_center .menu li {
    pointer-events: auto !important;
}
/* Contact : positionné en absolu à droite du menu */
.header_center .menu li.menu-contact-btn {
    margin-left: 0 !important;
    position: absolute !important;
    right: 0 !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
}

/* ===== Espacement entre les items du menu ===== */
.header_center .menu li a {
    padding-left: 18px !important;
    padding-right: 18px !important;
}

/* ===== Espacement menu — ajustement ===== */
.header_center .menu li a {
    padding-left: 13px !important;
    padding-right: 13px !important;
}

/* ===== Alignement haut colonne gauche bannière ===== */
.banner .vc_column-inner {
    justify-content: flex-start !important;
    padding-top: 40px !important;
}

/* ===== Revert alignement vertical (retour centrage) ===== */
.banner .vc_column-inner {
    justify-content: center !important;
    padding-top: 0 !important;
}

/* ===== Alignement horizontal : banner container = même base que le header ===== */
/* Le container du banner avait width:1400px fixe → déborde sur écrans < 1400px */
/* On le passe en width:100% comme le header pour aligner le bord gauche au logo */
.banner .container {
    width: 100% !important;
    max-width: 1400px !important;
    margin: auto !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
}

/* ===== Alignement gauche banner avec le logo ===== */
/* Le vc_row-fluid n'a pas de container interne — on remplace padd_left:4%    */
/* par un calc() qui reproduit le centrage du container header (1440px total) */
.banner .padd_left {
    padding-left: max(20px, calc((100% - 1440px) / 2 + 20px)) !important;
}

/* ===== Deux boutons à droite : Devis + Téléphone ===== */

/* Padding droit du menu élargi pour 2 boutons */
.header_center .menu {
    padding-right: 370px !important;
}

/* Devis : outline rouge, positionné entre les items et le bouton tel */
.header_center .menu li.menu-devis-btn {
    margin-left: 0 !important;
    position: absolute !important;
    right: 175px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
	padding:0;
}
.header_center .menu li.menu-devis-btn a {
    background-color: transparent !important;
    border: 1.5px solid #cb2228 !important;
    border-radius: 50px !important;
    color: #cb2228 !important;
    padding: 7px 18px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 0.3px !important;
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    transition: background-color 0.25s ease, color 0.25s ease !important;
}
.header_center .menu li.menu-devis-btn a:hover {
    background-color: #cb2228 !important;
    color: #fff !important;
}
.header_center .menu li.menu-devis-btn a::after {
    display: none !important;
}
.header_center .menu li.menu-devis-btn a::before {
    display: none !important;
}

/* ===== Section Mission (rouge 2 colonnes) ===== */
.row_mission {
    color: #fff;
}
.mission_label {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    opacity: 0.75;
    margin-bottom: 14px;
}
.mission_h2 {
    font-size: 2em !important;
    font-weight: 800 !important;
    color: #fff !important;
    line-height: 1.2 !important;
    margin-bottom: 18px !important;
}
.mission_text {
    font-size: 15px;
    line-height: 1.7;
    opacity: 0.92;
    margin-bottom: 28px !important;
}
.btn_mission {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.15);
    border: 1.5px solid rgba(255,255,255,0.6);
    color: #fff !important;
    border-radius: 50px;
    padding: 10px 22px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none !important;
    transition: background 0.25s ease;
}
.btn_mission:hover {
    background: rgba(255,255,255,0.28);
}

/* Cartes droite */
.mission_cards {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.mission_card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    border-radius: 12px;
    padding: 18px 20px;
    backdrop-filter: blur(4px);
}
.mission_card_icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: rgba(255,255,255,0.18);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mission_card_icon .material-symbols-outlined {
    font-size: 20px;
    color: #fff;
    font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 20;
}
.mission_card_body strong {
    display: block;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 4px;
}
.mission_card_body p {
    color: rgba(255,255,255,0.82);
    font-size: 13px;
    line-height: 1.5;
    margin: 0 !important;
}

/* ===== Section Chiffres clés ===== */
.row_chiffres_globaux {
    background: #fff;
}
.row_chiffres_globaux h2 {
    color: #1e2130 !important;
    font-size: 1.6em !important;
    margin-bottom: 8px !important;
}
.chiffres_inner {
    display: flex !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    gap: 20px !important;
}
.chiffre_global_col {
    text-align: center !important;
    flex: 1 1 160px !important;
    max-width: 200px !important;
}
.chiffre_icon {
    margin-bottom: 10px;
}
.chiffre_icon .material-symbols-outlined {
    font-size: 32px;
    color: #cb2228;
    font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 32;
}
/* stat_counter override pour chiffres */
.chiffre_global_col .stat_counter_wrap .counter-value {
    color: #cb2228 !important;
    font-size: 2em !important;
    font-weight: 800 !important;
}
.chiffre_global_col .stat_counter_wrap .counter-label {
    font-size: 13px !important;
    color: #666 !important;
}

/* ===== Section Mission — centrage container (même base que header) ===== */
.row_mission .padd_left {
    padding-left: max(20px, calc((100% - 1440px) / 2 + 20px)) !important;
}
.row_mission .big_padd_right {
    padding-right: max(20px, calc((100% - 1440px) / 2 + 20px)) !important;
}

/* ===== 1. Section Mission — réduction marges verticales ===== */
.row_mission.vc_row {
    padding-top: 3% !important;
    padding-bottom: 3% !important;
}

/* ===== 2. Menu — icônes colorées + barre gauche au hover ===== */

/* Supprimer le sliding underline des 4 items principaux */
.header_center .menu li:not(.menu-contact-btn):not(.menu-devis-btn) a::after {
    display: none !important;
}

/* Flex + barre gauche transparente (évite le layout shift au hover) */
.header_center .menu li:not(.menu-contact-btn):not(.menu-devis-btn) a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    border-left: 3px solid transparent !important;
    padding-left: 10px !important;
    transition: color 0.2s ease, border-color 0.2s ease !important;
    border-radius: 0 !important;
}

/* Icône ::before via Material Symbols */
.header_center .menu li:not(.menu-contact-btn):not(.menu-devis-btn) a::before {
    font-family: 'Material Symbols Outlined' !important;
    font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 20;
    font-size: 17px !important;
    line-height: 1 !important;
    display: inline-block !important;
}

/* Secourisme — vert */
.menu-item-181 a::before { content: '\e548' !important; color: #16a34a; }
.menu-item-181 a:hover   { color: #16a34a !important; border-left-color: #16a34a !important; }

/* Incendie — orange */
.menu-item-178 a::before { content: '\e80e' !important; color: #cb2228; }
.menu-item-178 a:hover   { color: #cb2228 !important; border-left-color: #cb2228 !important; }

/* Électricité — jaune */
.menu-item-180 a::before { content: '\e1d3' !important; color: #ca8a04; }
.menu-item-180 a:hover   { color: #ca8a04 !important; border-left-color: #ca8a04 !important; }

/* Ergonomie — bleu */
.menu-item-179 a::before { content: '\e536' !important; color: #2563eb; }
.menu-item-179 a:hover   { color: #2563eb !important; border-left-color: #2563eb !important; }

/* ===== 3. Bouton Devis — bordure et texte gris ===== */
.header_center .menu li.menu-devis-btn a {
    border-color: #9ca3af !important;
    color: #6b7280 !important;
}
.header_center .menu li.menu-devis-btn a:hover {
    background-color: #6b7280 !important;
    border-color: #6b7280 !important;
    color: #fff !important;
}

/* ===== Menu — icônes SVG colorées avec fond + hover couleur texte ===== */

/* Reset ::before text-based icons */
.header_center .menu li:not(.menu-contact-btn):not(.menu-devis-btn) a::before {
    font-family: unset !important;
    font-size: 0 !important;
    content: '' !important;
    width: 22px !important;
    height: 22px !important;
    display: inline-block !important;
    background-size: 65% !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    flex-shrink: 0 !important;
    border-radius: 8px !important;
    color: transparent !important;
}

/* Secourisme — croix médicale, fond vert pastel */
.menu-item-181 a::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22'%3E%3Crect width='22' height='22' rx='4' fill='%23dcfce7'/%3E%3Crect x='9' y='4' width='4' height='14' fill='%2316a34a'/%3E%3Crect x='4' y='9' width='14' height='4' fill='%2316a34a'/%3E%3C/svg%3E") !important;
}
.menu-item-181 a:hover { color: #16a34a !important; border-left-color: #16a34a !important; }

/* Incendie — flamme, fond orange pastel */
.menu-item-178 a::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22'%3E%3Crect width='22' height='22' rx='6' fill='%23fee2e2'/%3E%3Cpath d='M11 3c0 0-1 3-3 4.5C6 9 5 10.5 5 12.5c0 3.3 2.7 6 6 6s6-2.7 6-6c0-2-1-3.5-2-4.5 0 1.5-1 2.5-2 2.5C13 7 12 4 11 3z' fill='%23cb2228'/%3E%3Ccircle cx='11' cy='14' r='2' fill='%23fca5a5'/%3E%3C/svg%3E") !important;
}
.menu-item-178 a:hover { color: #cb2228 !important; border-left-color: #cb2228 !important; }

/* Électricité — éclair, fond jaune pastel */
.menu-item-180 a::before {
    background-color: #fef9c3 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3.75 13.5l10.5-11.25L12 10.5h8.25L9.75 21.75 12 13.5H3.75z' fill='%23ca8a04'/%3E%3C/svg%3E") !important;
}
.menu-item-180 a:hover { color: #ca8a04 !important; border-left-color: #ca8a04 !important; }

/* Ergonomie — silhouette, fond bleu pastel */
.menu-item-179 a::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22'%3E%3Crect width='22' height='22' rx='6' fill='%23dbeafe'/%3E%3Ccircle cx='11' cy='5' r='2.2' fill='%232563eb'/%3E%3Cpath d='M7 9.5c0 0 1.5 1 4 1s4-1 4-1l-1 4-2 1v4h-2v-4l-2-1z' fill='%232563eb'/%3E%3Cpath d='M8.5 10.5l-2 4M13.5 10.5l2 4' stroke='%232563eb' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") !important;
}
.menu-item-179 a:hover { color: #2563eb !important; border-left-color: #2563eb !important; }

/* ===== Menu icônes SVG v2 — spécificité haute + hover corrigé ===== */

/* Override the base hover red rule with higher specificity */
.header_center .menu li.menu-item-181 a:hover,
.header_center .menu li.menu-item-178 a:hover,
.header_center .menu li.menu-item-180 a:hover,
.header_center .menu li.menu-item-179 a:hover {
    color: inherit !important; /* will be overridden below */
}

/* Secourisme — croix, vert */
.header_center .menu li.menu-item-181 a::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect width='24' height='24' rx='5' fill='%23dcfce7'/%3E%3Crect x='10' y='5' width='4' height='14' fill='%2316a34a'/%3E%3Crect x='5' y='10' width='14' height='4' fill='%2316a34a'/%3E%3C/svg%3E") !important;
}
.header_center .menu li.menu-item-181 a:hover {
    color: #16a34a !important;
    border-left-color: #16a34a !important;
}

/* Incendie — flamme, orange */
.header_center .menu li.menu-item-178 a::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect width='24' height='24' rx='7' fill='%23fee2e2'/%3E%3Cpath d='M12 3.5c-.3 1.8-1.2 3-2.5 4C8 8.7 7 10.2 7 12.5c0 2.8 2.2 5 5 5s5-2.2 5-5c0-1.8-.9-3.2-2-4-.1 1.2-.8 2-1.8 2.2C13.2 8.5 12.8 5.5 12 3.5z' fill='%23cb2228'/%3E%3Cellipse cx='12' cy='14.5' rx='2' ry='2.2' fill='%23fca5a5' opacity='0.7'/%3E%3C/svg%3E") !important;
}
.header_center .menu li.menu-item-178 a:hover {
    color: #cb2228 !important;
    border-left-color: #cb2228 !important;
}

/* Électricité — éclair, jaune */
.header_center .menu li.menu-item-180 a::before {
    background-color: #fef9c3 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3.75 13.5l10.5-11.25L12 10.5h8.25L9.75 21.75 12 13.5H3.75z' fill='%23ca8a04'/%3E%3C/svg%3E") !important;
}
.header_center .menu li.menu-item-180 a:hover {
    color: #ca8a04 !important;
    border-left-color: #ca8a04 !important;
}

/* Ergonomie — silhouette active, bleu */
.header_center .menu li.menu-item-179 a::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect width='24' height='24' rx='7' fill='%23dbeafe'/%3E%3Ccircle cx='12' cy='5.5' r='2.3' fill='%232563eb'/%3E%3Cpath d='M8.5 10.5c1 .7 2.2 1 3.5 1s2.5-.3 3.5-1L14.5 14l-1.5 1V19h-2v-4L9.5 14z' fill='%232563eb'/%3E%3Cpath d='M9.5 11.5L7.5 16M14.5 11.5L16.5 16' stroke='%232563eb' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E") !important;
}
.header_center .menu li.menu-item-179 a:hover {
    color: #2563eb !important;
    border-left-color: #2563eb !important;
}

/* S'assurer que la barre gauche est visible au hover */
.header_center .menu li.menu-item-181 a,
.header_center .menu li.menu-item-178 a,
.header_center .menu li.menu-item-180 a,
.header_center .menu li.menu-item-179 a {
    border-left: 3px solid transparent !important;
    transition: color 0.2s ease, border-color 0.2s ease !important;
}

/* ===== Menu icônes SVG v3 — plus de padding + formes affinées ===== */

/* Icône plus grande avec plus d'espace interne */
.header_center .menu li:not(.menu-contact-btn):not(.menu-devis-btn) a::before {
    width: 32px !important;
    height: 32px !important;
    border-radius: 8px !important;
    margin-right: 5px !important;
}

/* Secourisme — croix médicale arrondie sur vert pastel */
.header_center .menu li.menu-item-181 a::before {
    background-color: #dcfce7 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 26 26'%3E%3Crect x='11' y='6' width='4' height='14' fill='%2316a34a'/%3E%3Crect x='6' y='11' width='14' height='4' fill='%2316a34a'/%3E%3C/svg%3E") !important;
}

/* Incendie — flamme sur orange pastel */
.header_center .menu li.menu-item-178 a::before {
    background-color: #fee2e2 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 26 26'%3E%3Cpath d='M13 4c0 0-1.5 3.5-3.5 5C8 10.5 7 12 7 14c0 3.3 2.7 6 6 6s6-2.7 6-6c0-2-1-3.5-2.5-4.5.2 1.5-.8 2.8-2 3C14.5 9.5 14 6 13 4z' fill='%23cb2228'/%3E%3Cpath d='M13 16.5c0 0-2-1-2-3 0 1.1.9 2 2 2s2-.9 2-2c0 2-2 3-2 3z' fill='%23fca5a5'/%3E%3C/svg%3E") !important;
}

/* Électricité — éclair sur jaune pastel */
.header_center .menu li.menu-item-180 a::before {
    background-color: #fef9c3 !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3.75 13.5l10.5-11.25L12 10.5h8.25L9.75 21.75 12 13.5H3.75z' fill='%23ca8a04'/%3E%3C/svg%3E") !important;
}

/* Ergonomie — silhouette en mouvement sur bleu pastel */
.header_center .menu li.menu-item-179 a::before {
    background-color: #dbeafe !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 26 26'%3E%3Cg transform='translate(1,1)' fill='%232563eb'%3E%3Cpath d='M13.49 5.48c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-3.6 13.9 1-4.4 2.1 2v6h2v-7.5l-2.1-2 .6-3c1.3 1.5 3.3 2.5 5.5 2.5v-2c-1.9 0-3.5-1-4.3-2.4l-1-1.6c-.4-.6-1-1-1.7-1-.3 0-.5.1-.8.1l-5.2 2.2v4.7h2v-3.4l1.8-.7-1.6 8.1-4.9-1-.4 2 7 1.4z'/%3E%3C/g%3E%3C/svg%3E") !important;
}

/* ===== Item actif : même barre gauche que le hover, couleur de catégorie ===== */
.header_center .menu li.menu-item-181.current-menu-item a,
.header_center .menu li.menu-item-181.current-menu-ancestor a {
    color: #16a34a !important;
    border-left-color: #16a34a !important;
}
.header_center .menu li.menu-item-178.current-menu-item a,
.header_center .menu li.menu-item-178.current-menu-ancestor a {
    color: #cb2228 !important;
    border-left-color: #cb2228 !important;
}
.header_center .menu li.menu-item-180.current-menu-item a,
.header_center .menu li.menu-item-180.current-menu-ancestor a {
    color: #ca8a04 !important;
    border-left-color: #ca8a04 !important;
}
.header_center .menu li.menu-item-179.current-menu-item a,
.header_center .menu li.menu-item-179.current-menu-ancestor a {
    color: #2563eb !important;
    border-left-color: #2563eb !important;
}



/* ===== Section Mission — réduction padding top/bottom ===== */
/* Écraser le .padd (6%) sur le row ET sur les colonnes internes */
.row_mission.vc_row,
.row_mission.wpb_row {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
}
.row_mission .padd {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Espace entre les deux colonnes de la section mission */
.row_mission .big_padd_right {
    padding-left: 80px !important;
}

/* ===== Section Nos formations — redesign complet ===== */

/* En-tête catégorie */
.formation_cat_header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 40px !important;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid #f0f0f0;
}
.formation_cat_title {
    font-size: 1.15em !important;
    font-weight: 700 !important;
    color: #1e2130 !important;
    margin: 0 !important;
    text-align: left !important;
}
.formation_cat_count {
    background: #f3f4f6;
    color: #6b7280;
    font-size: 12px;
    padding: 3px 10px;
    border-radius: 20px;
    font-weight: 500;
    white-space: nowrap;
}

/* Icônes catégories (mêmes SVG que le menu) */
.formation_cat_icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    flex-shrink: 0;
    background-size: 65%;
    background-repeat: no-repeat;
    background-position: center;
}
.formation_icon_secourisme {
    background-color: #dcfce7;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 26 26'%3E%3Crect x='11' y='6' width='4' height='14' fill='%2316a34a'/%3E%3Crect x='6' y='11' width='14' height='4' fill='%2316a34a'/%3E%3C/svg%3E");
}
.formation_icon_incendie {
    background-color: #fee2e2;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 26 26'%3E%3Cpath d='M13 4c0 0-1.5 3.5-3.5 5C8 10.5 7 12 7 14c0 3.3 2.7 6 6 6s6-2.7 6-6c0-2-1-3.5-2.5-4.5.2 1.5-.8 2.8-2 3C14.5 9.5 14 6 13 4z' fill='%23cb2228'/%3E%3C/svg%3E");
}
.formation_icon_electricite {
    background-color: #fef9c3;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3.75 13.5l10.5-11.25L12 10.5h8.25L9.75 21.75 12 13.5H3.75z' fill='%23ca8a04'/%3E%3C/svg%3E");
}
.formation_icon_ergonomie {
    background-color: #dbeafe;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 26 26'%3E%3Cg transform='translate(1,1)' fill='%232563eb'%3E%3Cpath d='M13.49 5.48c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-3.6 13.9 1-4.4 2.1 2v6h2v-7.5l-2.1-2 .6-3c1.3 1.5 3.3 2.5 5.5 2.5v-2c-1.9 0-3.5-1-4.3-2.4l-1-1.6c-.4-.6-1-1-1.7-1-.3 0-.5.1-.8.1l-5.2 2.2v4.7h2v-3.4l1.8-.7-1.6 8.1-4.9-1-.4 2 7 1.4z'/%3E%3C/g%3E%3C/svg%3E");
}

/* Grille de cartes */
.global_formation {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 14px !important;
}
a.single_formation {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 20px 22px !important;
    text-decoration: none !important;
    color: #1e2130 !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
    transition: box-shadow 0.2s, transform 0.2s !important;
    min-height: 90px;
    box-sizing: border-box !important;
}
a.single_formation:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,0.10) !important;
    transform: translateY(-2px) !important;
    text-decoration: none !important;
}
.single_formation_title {
    font-size: 15px;
	font-weight:400;
    line-height: 1.35;
    color: #1e2130;
    flex: 1;
}

/* Badge audience sur les cartes formation */
.formation_badge {
    display: inline-block;
    margin-top: 10px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    line-height: 1.6;
    white-space: nowrap;
    align-self: flex-start;
}
/* Couleur badge selon la catégorie de la formation */
.row_secourisme  .formation_badge { background: #dcfce7; color: #16a34a; }
.row_incendie    .formation_badge { background: #fee2e2; color: #cb2228; }
.row_electricite .formation_badge { background: #fef9c3; color: #ca8a04; }
.row_ergonomie   .formation_badge { background: #dbeafe; color: #2563eb; }

/* Badges Format et Nb personnes — contour couleur catégorie */
.row_secourisme  .formation_badge_format,
.row_secourisme  .formation_badge_nb { background: transparent; color: #16a34a; border: 1.5px solid #16a34a; opacity: 0.85; }
.row_incendie    .formation_badge_format,
.row_incendie    .formation_badge_nb { background: transparent; color: #cb2228; border: 1.5px solid #cb2228; opacity: 0.85; }
.row_electricite .formation_badge_format,
.row_electricite .formation_badge_nb { background: transparent; color: #ca8a04; border: 1.5px solid #ca8a04; opacity: 0.85; }
.row_ergonomie   .formation_badge_format,
.row_ergonomie   .formation_badge_nb { background: transparent; color: #2563eb; border: 1.5px solid #2563eb; opacity: 0.85; }

/* Conteneur multi-badges */
.formation_badges_row { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.formation_badges_row .formation_badge { margin-top: 0; }

/* Accent couleur haut de carte selon catégorie */
.row_secourisme a.single_formation  { border-top: 3px solid #16a34a !important; }
.row_incendie a.single_formation    { border-top: 3px solid #cb2228 !important; }
.row_electricite a.single_formation { border-top: 3px solid #fef9c3 !important; }
.row_ergonomie a.single_formation   { border-top: 3px solid #2563eb !important; }

/* Espacement entre blocs catégories */
.row_formation {
    margin-bottom: 10px !important;
}
.row_formation + .row_formation {
    margin-top: 30px !important;
    padding-top: 10px !important;
}

/* Boxer et centrer titre/intro Nos formations */
.row_formations_intro .vc_column-inner {
    max-width: 1020px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100% !important;
}

/* Boxer et centrer les grilles de formations (-15% = 1020px) */
.row_formation > .vc_column_container > .vc_column-inner {
    max-width: 1020px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100% !important;
}



/* ===== Section Mission — padding vertical ajusté ===== */
.row_mission.vc_row,
.row_mission.wpb_row {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}

/* ===== Banner — agrandir la colonne photo ===== */
.banner .vc_column_container:first-child {
    flex: 0 0 50% !important;
    max-width: 50% !important;
}
.banner .vc_column_container:last-child {
    flex: 0 0 50% !important;
    max-width: 50% !important;
}

/* ===== Logo Qualiopi sous les badges ===== */
.qualiopi_logo_row {
    margin-top: 40px;
    display: flex;
    align-items: center;
    gap: 20px;
}
.qualiopi_logo_row img {
    opacity: 0.85;
    transition: opacity 0.2s;
}
.qualiopi_logo_row img:hover {
    opacity: 1;
}
.qualiopi_logo_row > img {
    height: 50px !important;
}

/* ===== Section Sessions inter-entreprises ===== */
.sessions_wrapper {
    max-width: 1020px;
    margin: 0 auto;
}

/* Top card */
.sessions_top_card {
    display: flex;
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 2px 16px rgba(0,0,0,0.07);
}
.sessions_top_left {
    flex: 1;
    padding: 40px 40px 40px 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.sessions_label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #16a34a;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.sessions_h2 {
    font-size: 26px;
    font-weight: 800;
    color: #1e2130;
    margin: 0 0 14px;
    line-height: 1.25;
}
.sessions_desc {
    color: #555;
    font-size: 14px;
    line-height: 1.6;
    margin: 0 0 24px;
}
.sessions_cta_group {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}
.sessions_btn_outline {
    display: inline-block;
    padding: 11px 22px;
    border: 2px solid #1e2130;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
    color: #1e2130 !important;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.sessions_btn_outline:hover {
    background: #1e2130;
    color: #fff !important;
}
.sessions_top_right {
    flex: 0 0 45%;
    max-width: 45%;
}
.sessions_top_right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Bottom sessions */
.sessions_bottom {
    margin-top: 32px;
}
.sessions_bottom_label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #888;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.sessions_cards_row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.session_card {
    background: #fff;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.session_card_head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.session_icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.session_icon .material-symbols-outlined {
    font-size: 20px !important;
}
.session_icon_secourisme { background: #dcfce7; color: #16a34a; }
.session_icon_incendie   { background: #fee2e2; color: #cb2228; }
.session_icon_electricite{ background: #fef9c3; color: #ca8a04; }
.session_icon_ergonomie  { background: #dbeafe; color: #2563eb; }
.session_name {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: #1e2130;
    line-height: 1.3;
    margin-bottom: 3px;
}
.session_meta {
    font-size: 12px;
    color: #888;
}
.session_dates {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.session_dates li {
    font-size: 13px;
    color: #666;
    padding-left: 16px;
    position: relative;
}
.session_dates li::before {
    content: ;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #d1d5db;
}
.session_dates li.session_date_next {
    color: #16a34a;
    font-weight: 600;
}
.session_dates li.session_date_next::before {
    background: #16a34a;
}
.session_link {
    font-size: 13px;
    font-weight: 600;
    color: #cb2228 !important;
    text-decoration: none;
    margin-top: auto;
}
.session_link:hover {
    text-decoration: underline;
}

/* ===== Sessions v2 — layout photo + accordéon ===== */
.sessions_v2 {
    display: flex;
    border-radius: 16px;
    overflow: hidden;
    max-width: 1020px;
    margin: 0 auto;
    box-shadow: 0 4px 24px rgba(0,0,0,0.10);
    min-height: 480px;
}
.sessions_v2_photo {
    flex: 0 0 36%;
    min-height: 100%;
    background-image: linear-gradient(rgba(15,20,35,0.65),rgba(15,20,35,0.65)), url('https://afpsecourisme.dev-audouin-realisations.com/wp-content/uploads/2026/02/formations-incendie-2.jpg');
    background-size: cover;
    background-position: center;
}
.sessions_v2_content {
    flex: 1;
    background: #fff;
    padding: 40px 36px;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.sessions_v2_label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #16a34a;
    text-transform: uppercase;
}
.sessions_v2_h2 {
    color: #1e2130;
    margin: 0 0 12px;
    line-height: 1.25;
}
.sessions_v2_desc {
    font-size: 13.5px;
    color: #555;
    line-height: 1.6;
    margin: 0 0 20px;
}
/* Accordion items */
.sessions_v2_list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 24px;
}
details.sessions_v2_item {
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    overflow: hidden;
}
details.sessions_v2_item summary {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 13px 16px;
    cursor: pointer;
    list-style: none;
    user-select: none;
}
details.sessions_v2_item summary::-webkit-details-marker { display: none; }
.sessions_v2_item_name {
    font-size: 14px;
    font-weight: 600;
    color: #1e2130;
    flex: 1;
}
.sessions_v2_item_duration {
    font-size: 12px;
    font-weight: 600;
    background: #f3f4f6;
    color: #555;
    border-radius: 20px;
    padding: 2px 10px;
}
details.sessions_v2_item summary::after {
    font-family: 'Material Symbols Outlined';
    content: 'expand_more';
    font-size: 20px;
    color: #888;
    transition: transform 0.2s;
    flex-shrink: 0;
}
details[open].sessions_v2_item summary::after {
    transform: rotate(180deg);
}
.sessions_v2_dates {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 4px 16px 16px;
}
.sessions_v2_date {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 12.5px;
    border: 1px solid #e5e7eb;
    color: #555;
}
.sessions_v2_date .material-symbols-outlined { font-size: 14px !important; }
.sessions_v2_date_next {
    background: #16a34a;
    color: #fff !important;
    border-color: #16a34a;
    font-weight: 600;
}
.sessions_v2_date_next .material-symbols-outlined { color: #fff !important; }
/* Couleur "Prochain" par catégorie */
.sessions_cat_incendie .sessions_v2_date_next   { background: #cb2228; border-color: #cb2228; }
.sessions_cat_electricite .sessions_v2_date_next { background: #ca8a04; border-color: #ca8a04; }
.sessions_cat_ergonomie .sessions_v2_date_next   { background: #2563eb; border-color: #2563eb; }
.sessions_v2_cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #cb2228;
    color: #fff !important;
    padding: 13px 24px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    align-self: flex-start;
    margin-top: auto;
    transition: background 0.2s;
}
.sessions_v2_cta:hover { background: #c03936; }
.sessions_v2_cta .material-symbols-outlined { font-size: 18px !important; }

/* ===== Sessions v3 — design Claude Design ===== */
.s3 {
    display: grid;
    grid-template-columns: 420px 1fr;
    min-height: 480px;
    column-gap: 32px;
}
.s3-photo {
    background-color: #1F2937;
    background-image: linear-gradient(rgba(15,20,35,0.45),rgba(15,20,35,0.45)), url('https://afpsecourisme.dev-audouin-realisations.com/wp-content/uploads/2026/02/formations-incendie-2.jpg');
    background-size: cover;
    background-position: center;
}
.s3-content {
    padding: 56px 36px;
    background: rgb(254,242,242);
}
.s3-eyebrow {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #16A34A;
    text-transform: uppercase;
    margin: 0 0 6px;
}
.s3-title {
    color: #0F172A;
    margin: 0 0 14px;
    line-height: 1.2;
}
.s3-lede {
    font-size: 14px;
    line-height: 1.6;
    color: #64748B;
    margin: 0 0 22px;
    max-width: none;
}
/* Course cards */
.s3-list { display: flex; flex-direction: column; gap: 10px; }
.s3-course {
    border: 1px solid #E5E7EB;
    border-radius: 12px;
    background: #fff;
    overflow: hidden;
    transition: border-color .18s, box-shadow .18s;
}
.s3-course:hover, .s3-open { border-color: #DDE1E7; box-shadow: 0 1px 4px rgba(15,23,42,0.06); }
.s3-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 13px 16px;
    cursor: pointer;
    background: #fff;
    border: 0;
    width: 100%;
    text-align: left;
    font: inherit;
    color: inherit;
}
.s3-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 36px;
}
.s3-icon-green { background: #16A34A; color: #fff; }
.s3-icon-amber { background: linear-gradient(180deg, #FCD34D, #F59E0B); color: #78350F; }
.s3-course-title { font-size: 14.5px; font-weight: 600; color: #0F172A; flex: 1; line-height: 1.3; }
.s3-duration {
    font-size: 12px; font-weight: 500; color: #64748B;
    background: #EEF0F3; padding: 3px 9px;
    border-radius: 999px; flex: 0 0 auto;
}
.s3-price {
    font-size: 12px; font-weight: 700; color: #16A34A;
    background: #ECFDF3; padding: 3px 9px;
    border-radius: 999px; flex: 0 0 auto;
    white-space: nowrap;
}
.s3-chev {
    width: 22px; height: 22px; border-radius: 6px;
    color: #94A3B8; display: inline-flex;
    align-items: center; justify-content: center;
    transition: transform .2s ease;
}
.s3-open .s3-chev { transform: rotate(180deg); color: #334155; }
/* Accordion body */
.s3-body {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .25s ease;
}
.s3-open .s3-body { grid-template-rows: 1fr; }
.s3-body-inner { overflow: hidden; min-height: 0; }
.s3-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 4px 16px 16px;
}
.s3-date {
    flex: 0 0 auto;
    width: auto;
}
/* Date items (div) */
.s3-date {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border: 1px solid #E5E7EB;
    border-radius: 10px;
    background: #fff;
    font-size: 13px;
    font-weight: 500;
    color: #334155;
    cursor: default;
    transition: border-color .15s, background .15s, color .15s;
    text-align: left;
    font-family: inherit;
    box-sizing: border-box;
    margin: 0;
    line-height: 1.4;
}
.s3-date:hover { border-color: #CBD5E1; background: #FAFBFC; }
.s3-date.s3-selected { border-color: #16A34A; background: #ECFDF5; color: #166534; }
.s3-date.s3-selected .s3-cal { color: #16A34A; }
.s3-cal { color: #94A3B8; flex: 0 0 auto; display: inline-flex; }
.s3-badge {
    font-size: 11px; font-weight: 600; color: #15803D;
    margin-left: auto; padding-left: 8px;
    border-left: 1px solid rgba(22,163,74,0.25);
}
.s3-date:not(.s3-selected) .s3-badge { display: none; }

/* ===== Sessions v3 — corrections ===== */
/* Photo collée haut/bas : supprimer le padding du row */
.row_sessions.vc_row,
.row_sessions.wpb_row {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
/* La colonne WPBakery ne doit pas avoir de padding vertical */
.row_sessions > .vc_column_container > .vc_column-inner {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
/* Le vc_column_text non plus */
.row_sessions .wpb_wrapper { padding: 0 !important; }
/* Photo s3 : height 100% forcé */
.s3 { align-items: stretch; }
.s3-photo { min-height: 480px; }
/* Icônes : réutiliser formation_cat_icon mais adapter la taille */
.s3 .formation_cat_icon {
    width: 36px !important;
    height: 36px !important;
    border-radius: 10px !important;
    flex: 0 0 36px !important;
    background-size: 60% !important;
}
/* Chevron Material Symbols */
.s3-chev {
    font-family: 'Material Symbols Outlined' !important;
    font-size: 20px !important;
    color: #94A3B8;
    transition: transform .2s ease, color .2s;
    flex: 0 0 auto;
}
.s3-open .s3-chev {
    transform: rotate(180deg);
    color: #334155;
}
/* Calendar icon */
.s3-cal {
    font-family: 'Material Symbols Outlined' !important;
    font-size: 14px !important;
    color: #94A3B8;
    flex: 0 0 auto;
    line-height: 1;
}
.s3-date.s3-selected .s3-cal { color: #16A34A; }
/* Date info avec lieu */
.s3-date-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
}
.s3-date-text {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.2;
}
.s3-lieu {
    font-size: 11px;
    color: #94A3B8;
    font-weight: 400;
}
.s3-date.s3-selected .s3-lieu { color: #16A34A; opacity: 0.8; }

/* s3 dates — non cliquables */
.s3-date { cursor: default !important; }
.s3-date:hover { border-color: #E5E7EB !important; background: #fff !important; color: #334155 !important; }
.s3-date.s3-selected:hover { border-color: #16A34A !important; background: #ECFDF5 !important; color: #166534 !important; }

/* CTA row en bas des sessions */
.s3-cta-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 24px;
    flex-wrap: wrap;
}
.s3-cta-text {
    font-size: 14px;
    color: #334155;
    font-weight: 500;
}
.s3-cta-btn {
    display: inline-block;
    background: #cb2228;
    color: #fff !important;
    padding: 10px 22px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    transition: background .2s;
}
.s3-cta-btn:hover { background: #c03936; }

/* ============================================================
   Indicateurs de Performance v2 — donut cards
   ============================================================ */
.row_indicateurs.vc_row, .row_indicateurs.wpb_row { background: #fff; }

/* ── Indicateurs de performance ── */
.skco-wrap { max-width: 790px; margin: 0 auto; }

.skco-header { text-align: center; margin-bottom: 40px; }
.skco-eyebrow {
    display: flex; align-items: center; justify-content: center; gap: 12px;
    color: #cb2228; font-size: 14px; font-weight: 700; letter-spacing: 2px;
    text-transform: uppercase; margin-bottom: 10px;
}
.skco-eyebrow::before, .skco-eyebrow::after {
    content: ''; display: inline-block; width: 28px; height: 1px; background: #cb2228;
}
.skco-header h2 { margin: 0 0 16px; }
.skco-legend {
    display: flex; align-items: center; justify-content: center; gap: 24px;
    font-size: 13px; color: #555;
}
.skco-legend span { display: flex; align-items: center; gap: 6px; }
.skco-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; }
.skco-dot-s { background: #2D3F55; }
.skco-dot-r { background: #2D3F55; }

.skco-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 25px; }
.skco-card {
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 12px;
    padding: 26px 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.skco-card-head { display: flex; align-items: center; gap: 10px; }
.skco-icon { width: 42px; height: 42px; flex: 0 0 42px; border-radius: 10px; background-size: 62%; }
.skco-cat-name { font-size: 15px; font-weight: 700; line-height: 1.1; }
.skco-cat-sub { font-size: 12px; color: #94A3B8; margin-top: 0; }

.skco-stats { display: flex; justify-content: space-around; gap: 12px; }
.stat-item { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.skco-stat-label {
    font-size: 10px; font-weight: 700; letter-spacing: 1px;
    text-transform: uppercase; color: #94A3B8;
}
.stat-ring { position: relative; width: 90px; height: 90px; }
.stat-ring svg { width: 90px; height: 90px; transform: rotate(-90deg); }
.ring-bg { fill: none; stroke-width: 3; }
.ring-fg { fill: none; stroke-width: 3; stroke-linecap: round; }
.stat-value {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 22px; font-weight: 500;
}
.stat-value .pct { font-size: 13px; font-weight: 400; }

/* Section eyebrow — style "NOTRE MISSION" / "SESSIONS OUVERTES" */
.section_eyebrow {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #cb2228;
    margin: 0;
}

/* =====================================================
   NOUVEAU PIED DE PAGE — bannière CTA + grille 4 cols
   ===================================================== */

/* --- Bannière devis au-dessus du footer --- */
#footer_devis_banner {
	background-color: #1a2035;
	padding: 40px 0;
	margin-bottom: 0;
}
.footer_devis_inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	flex-wrap: wrap;
	width: 100%;
}
.footer_devis_text {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.footer_devis_text strong {
	font-size: 22px;
	font-weight: 700;
	color: #fff;
}
.footer_devis_text span {
	font-size: 15px;
	color: #94a3b8;
}


/* --- Grille principale 4 colonnes --- */
#footer .container.footer_main_grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
	gap: 48px;
	padding: 52px 0 40px;
}

/* Colonne logo */
.footer_col_logo {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.footer_logo_img {
	max-width: 130px;
	height: auto;
	display: block;
}
.footer_tagline {
	font-size: 13px;
	color: #94a3b8 !important;
	line-height: 1.6;
	margin: 0;
	max-width: 200px;
}

/* Titres de colonnes */
.footer_col_title {
	font-size: 12px !important;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: #fff !important;
	margin: 0 0 20px !important;
}

/* Listes de liens */
.footer_links {
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.footer_links li,
.footer_links li a {
	font-size: 14px;
	color: #94a3b8 !important;
	text-decoration: none;
	transition: color 0.2s, padding-left 0.2s;
}
.footer_links li a:hover {
	color: #fff !important;
	padding-left: 4px;
}

/* Colonne contact — icônes alignées */
.footer_contact_list li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: #bbb !important;
}
.footer_contact_list li a {
	color: #bbb !important;
	transition: color 0.2s;
}
.footer_contact_list li a:hover {
	color: #fff !important;
}
.footer_icon {
	color: #cb2228 !important;
	flex-shrink: 0;
	font-size: 18px;
	line-height: 1;
	user-select: none;
}

/* Colonne contact */
.footer_col_contact {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}
.footer_col_contact .footer_contact_list li {
	justify-content: flex-start;
}

/* --- Barre du bas --- */
#footer_bottom {
	border-top: 1px solid rgba(255,255,255,0.1);
	padding: 18px 0;
}
.footer_bottom_inner {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 6px 12px;
	font-size: 13px;
	color: #94a3b8;
}
.footer_separator {
	color: #64748b;
	font-size: 13px;
}
.footer_siret {
	font-size: 13px;
	color: #94a3b8;
}
.footer_certif_badge {
	font-size: 13px;
	color: #94a3b8;
}

/* --- Responsive --- */
@media (max-width: 900px) {
	#footer .container.footer_main_grid {
		grid-template-columns: 1fr 1fr;
		gap: 32px;
		padding: 40px 0 32px;
	}
	.footer_col_logo {
		grid-column: 1 / -1;
	}
}
@media (max-width: 600px) {
	#footer .container.footer_main_grid {
		grid-template-columns: 1fr;
		gap: 28px;
		padding: 32px 0;
	}
	.footer_col_logo {
		grid-column: unset;
	}
	.footer_devis_inner {
		flex-direction: column;
		align-items: flex-start;
	}
	.footer_bottom_inner {
		gap: 4px 8px;
	}
}

/* =====================================================
   SECTION LABEL QUALITÉ (homepage)
   ===================================================== */

.section_label_qualite {
	padding: 80px 0;
	background: #fff;
}

/* Layout 2 colonnes */
.label_qualite_grid {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 56px;
	align-items: start;
}

/* --- Colonne gauche : aperçu certificat --- */
.lq_left {
	display: flex;
	justify-content: flex-end;
}
.lq_certif_link {
	display: block;
	text-decoration: none;
}
.lq_certif_card {
	position: relative;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 8px 32px rgba(0,0,0,0.12);
	transition: box-shadow 0.25s, transform 0.25s;
	max-width: 290px;
	margin: 0;
}
.lq_certif_link:hover .lq_certif_card {
	box-shadow: 0 14px 40px rgba(0,0,0,0.18);
	transform: translateY(-3px);
}
.lq_certif_img {
	display: block;
	width: 100%;
	height: auto;
}
.lq_certif_overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: rgba(220,78,75,0.9);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px;
	font-size: 14px;
	font-weight: 600;
	opacity: 0;
	transition: opacity 0.25s;
}
.lq_certif_link:hover .lq_certif_overlay {
	opacity: 1;
}
.lq_certif_overlay .material-symbols-outlined {
	font-size: 18px;
}

/* --- Carrousel certif --- */
.lq_certif_slider {
	max-width: 290px;
}
.lq_certif_slide {
	display: none;
}
.lq_certif_slide.active {
	display: block;
}
.lq_certif_nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-top: 14px;
}
.lq_certif_prev,
.lq_certif_next {
	background: none;
	border: 1px solid #ddd;
	border-radius: 50%;
	width: 32px;
	height: 32px;
	font-size: 22px;
	line-height: 1;
	cursor: pointer;
	color: #555;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, border-color 0.2s;
	padding: 0;
}
.lq_certif_prev:hover,
.lq_certif_next:hover {
	background: #f5f5f5;
	border-color: #bbb;
}
.lq_certif_dots {
	display: flex;
	gap: 6px;
	align-items: center;
}
.lq_certif_dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #ddd;
	cursor: pointer;
	transition: background 0.2s;
}
.lq_certif_dot.active {
	background: #dc4e4b;
}

/* --- Colonne droite --- */
.lq_title {
	font-size: 32px;
	font-weight: 700;
	margin: 0 0 12px;
	line-height: 1.2;
}
.lq_intro {
	font-size: 15px;
	color: #666;
	margin: 0 0 32px;
	line-height: 1.6;
}
.lq_sub_title {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #999;
	margin: 0 0 14px;
	padding-bottom: 8px;
	border-bottom: 1px solid #eee;
}

/* Grille des badges de certification */
.lq_badges_grid {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
	margin-bottom: 32px;
}
.lq_badge_card {
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #e5e5e5;
	border-radius: 10px;
	padding: 12px 10px;
	min-width: 130px;
	min-height: 70px;
	background: #fff;
	box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.lq_badge_logo {
	max-height: 57px;
	width: auto;
	display: block;
}
/* Agrandissement du logo SST-Habilitation (portrait) sans modifier la carte */
.lq_badge_logo[src*="SST-Habilitation"] {
	transform: scale(1.3);
}
.lq_badge_text_logo {
	font-weight: 700;
	font-size: 15px;
	line-height: 1.2;
	text-align: center;
}
.lq_badge_text_logo.datadock {
	color: #003DA5;
	font-size: 18px;
	font-style: italic;
}
.lq_badge_text_logo.veritas {
	color: #cc0000;
	font-size: 13px;
	letter-spacing: 0.5px;
}
.lq_badge_text_logo.veritas strong {
	display: block;
	font-size: 22px;
	margin-bottom: 2px;
}

/* Liste habilitations */
.lq_habilitations {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.lq_habilitations li {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 15px;
	color: #333;
}
.lq_habilitations li::before {
	content: none;
}
.lq_check {
	color: #22a06b;
	font-size: 20px !important;
	flex-shrink: 0;
}

/* Responsive */
@media (max-width: 900px) {
	.label_qualite_grid {
		grid-template-columns: 1fr;
		gap: 36px;
	}
	.lq_certif_card {
		max-width: 260px;
		margin: 0 auto;
	}
	.lq_title {
		font-size: 26px;
	}
}
@media (max-width: 600px) {
	.section_label_qualite {
		padding: 48px 0;
	}
	.lq_badges_grid {
		flex-direction: column;
	}
	.lq_badge_card {
		min-width: unset;
	}
}

/* =====================================================
   PAGES FORMATION — CATÉGORIE
   Variables injectées inline par le template PHP :
   --cat-color, --cat-soft
   ===================================================== */

.fcat-page {
	--cat-color: #16A34A;
	--cat-soft:  #ECFDF5;
	--fcat-ink-900: #0F172A;
	--fcat-ink-700: #334155;
	--fcat-ink-500: #64748B;
	--fcat-ink-400: #94A3B8;
	--fcat-line:    #E5E7EB;
	--fcat-line-2:  #F1F2F4;
	--fcat-coral:   #cb2228;
	--fcat-green:   #16A34A;
	--fcat-green-soft: #ECFDF5;
	--fcat-cream:   #FAFAF7;
}

/* Conteneur centré pour toutes les sections fcat
   (écrase body .container { max-width:100% }) */
.fcat-page .container {
	max-width: 1400px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	padding-left: 20px !important;
	padding-right: 20px !important;
	box-sizing: border-box;
	width: 100% !important;
}

/* Supprimer les flèches WPBakery sur les pages catégorie */
.fcat-page .wpb-content-wrapper ul li::before,
.fcat-points li::before,
.fcat-for-who ul li::before {
	content: none !important;
	display: none !important;
}
.fcat-page .wpb-content-wrapper .fcat-panel li::before {
	content: 'check' !important;
	font-family: 'Material Symbols Outlined' !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	min-width: 20px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--cat-color) 20%, white);
	color: var(--cat-color) !important;
	font-size: 13px !important;
	font-weight: 400;
	flex-shrink: 0;
}

/* --- Fil d'ariane --- */
.fcat-crumb {
	padding: 12px 0;
	border-bottom: 1px solid var(--fcat-line);
	background: #fff;
}
.fcat-crumb-inner {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: var(--fcat-ink-500);
}
.fcat-crumb-inner a {
	color: var(--fcat-ink-500);
	text-decoration: none;
}
.fcat-crumb-inner a:hover { color: var(--fcat-ink-900); }
.fcat-crumb-sep { color: var(--fcat-ink-400); }
.fcat-crumb-current { color: var(--fcat-ink-900); font-weight: 600; }

/* --- Hero --- */
.fcat-hero {
	background: rgb(254, 242, 242);
	border-bottom: 1px solid rgba(15,23,42,0.05);
	padding: 56px 0 72px;
}
.fcat-hero-container {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
}
.fcat-hero-eyebrow-row {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 16px;
}
.fcat-hero-icon {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background-size: 55%;
	background-repeat: no-repeat;
	background-position: center;
	flex-shrink: 0;
}

/* Override WPBakery dans le hero — layout 2 colonnes côte à côte */
.fcat-hero .fcat-hero-row {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: center;
	padding: 0 !important;
	margin: 0 !important;
}
/* Supprimer les floats WPBakery et laisser flex gérer la largeur */
.fcat-hero .fcat-hero-row > .vc_column_container {
	float: none !important;
	width: auto !important;
	min-width: 0;
}
.fcat-hero .fcat-hero-row > .vc_column_container:first-child { flex: 1.5; }
.fcat-hero .fcat-hero-row > .vc_column_container:last-child  { flex: 1; }
.fcat-hero .wpb-content-wrapper {
	padding: 0 !important;
	margin: 0 !important;
}
.fcat-hero .vc_row,
.fcat-hero .vc_row-fluid {
	margin-left: 0 !important;
	margin-right: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}
.fcat-hero .vc_column_container,
.fcat-hero .vc_column-inner,
.fcat-hero .wpb_column,
.fcat-hero .wpb_wrapper {
	padding: 0 !important;
	margin: 0 !important;
}

/* Titres hero WPBakery */
.fcat-hero h1 {
	line-height: 60px;
}
.fcat-hero h1 em {
	font-style: italic;
	color: var(--cat-color);
}
.fcat-color {
	color: var(--cat-color);
}
.fcat-hero .fcat-lede {
	font-size: 17px;
	line-height: 1.65;
	color: var(--fcat-ink-700);
	margin: 0 0 32px;
	max-width: 56ch;
}

/* Eyebrow dans hero */
.fcat-hero .section_eyebrow {
	color: var(--cat-color) !important;
}
.fcat-hero .section_eyebrow::before {
	content: "";
	display: inline-block;
	width: 18px;
	height: 1px;
	background: var(--cat-color);
	opacity: 0.5;
	vertical-align: middle;
	margin-right: 8px;
}

/* Stats hero */
.fcat-stats {
	display: flex;
	gap: 28px;
	padding-top: 4px;
	flex-wrap: wrap;
}
.fcat-stat-val {
	font-size: 26px;
	font-weight: 900;
	color: var(--fcat-ink-900);
	line-height: 1;
}
.fcat-stat-label {
	font-size: 11px;
	font-weight: 600;
	color: var(--fcat-ink-500);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-top: 6px;
}

/* Panneau "Pourquoi se former" */
.fcat-panel {
	background: #fff;
	border: 1px solid var(--fcat-line);
	border-radius: 16px;
	padding: 30px;
}
.fcat-panel h3 {
	font-weight: 600;
	margin: 0 0 14px;
	color: var(--fcat-ink-900);
}
.fcat-panel ul {
	list-style: none;
	padding: 0;
	margin: 12px 0 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}
.fcat-panel li {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--fcat-ink-700);
	line-height: 1.5;
	list-style: none;
}
.fcat-panel-ico {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--cat-color) 20%, white);
	color: var(--cat-color);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

/* --- Section principale formations --- */
.fcat-main {
	padding: 56px 0 32px;
}
.fcat-section-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 24px;
	margin-bottom: 24px;
}
.fcat-section-title {
	font-size: 28px;
	font-weight: 600;
	margin: 0;
	color: var(--fcat-ink-900);
	letter-spacing: -0.015em;
}
.fcat-section-meta {
	font-size: 13px;
	color: var(--fcat-ink-500);
	white-space: nowrap;
}

/* --- Cards grille --- */
.fcat-cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 45px;
	margin-bottom: 56px;
}
.fcat-card {
	background: #fff;
	border: 1px solid var(--fcat-line);
	border-radius: 16px;
	padding: 32px 32px 28px;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	position: relative;
	overflow: hidden;
	transition: border-color .15s, transform .15s, box-shadow .15s;
}
.fcat-card:hover {
	border-color: var(--fcat-coral);
	transform: translateY(-2px);
	box-shadow: 0 12px 32px rgba(15,23,42,0.07);
}
.fcat-card--featured::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: var(--fcat-coral);
	border-radius: 16px 16px 0 0;
}

/* Card head */
.fcat-card-head {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 12px;
}
.fcat-card-tag {
	display: inline-flex;
	align-items: center;
	padding: 4px 10px;
	border-radius: 99px;
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: none;
	background: var(--cat-soft);
	color: var(--cat-color);
}
.fcat-card-tag--coral {
	background: #FCE9E7;
	color: var(--fcat-coral);
}
.fcat-card-tag--format,
.fcat-card-tag--nb {
	background: transparent;
	color: var(--cat-color);
	border: 1.5px solid var(--cat-color);
	opacity: 0.75;
}
.fcat-featured-badge {
	display: inline-flex;
	align-items: center;
	background: var(--fcat-coral);
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.06em;
	padding: 4px 10px;
	border-radius: 99px;
	text-transform: uppercase;
	white-space: nowrap;
}

/* Card content */
.fcat-card-name {
	font-size: 21px;
	font-weight: 600;
	max-width:90%;
	margin: 4px 0 20px;
	color: var(--fcat-ink-900);
	line-height: 1.2;
	letter-spacing: -0.01em;
}
.fcat-card-desc {
	font-size: 14px;
	color: var(--fcat-ink-700);
	line-height: 1.6;
	margin: 0 0 16px;
}

/* Pour qui */
.fcat-for-who {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	padding: 12px 14px;
	border-radius: 10px;
	background: var(--fcat-line-2);
	margin-bottom: 16px;
}
.fcat-for-who-ic {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #fff;
	color: var(--fcat-ink-500);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.fcat-for-who-body {
	font-size: 15px;
	color: var(--fcat-ink-700);
	line-height: 1.5;
}
.fcat-for-who-label {
	display: block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--fcat-ink-400);
	margin-bottom: 4px;
}

/* Points objectifs */
.fcat-points {
	list-style: none;
	padding: 0;
	margin: 18px 0 18px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.fcat-points li {
	display: flex;
	gap: 9px;
	align-items: flex-start;
	font-size: 15px;
	color: var(--fcat-ink-700);
	line-height: 1.5;
}
.fcat-check {
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--cat-color) 20%, white);
	color: var(--cat-color);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	margin-top: 1px;
}

/* Meta pills */
.fcat-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--fcat-line-2);
	margin-top: auto;
}
.fcat-meta-pill {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 5px 10px;
	border-radius: 99px;
	background: var(--fcat-line-2);
	font-size: 11.5px;
	font-weight: 500;
	color: var(--fcat-ink-700);
}
.fcat-meta-pill-ic {
	display: inline-flex;
	color: var(--fcat-ink-500);
}
.fcat-meta-pill--cert {
	background: var(--fcat-green-soft);
	color: var(--fcat-green);
}
.fcat-meta-pill--cert .fcat-meta-pill-ic { color: var(--fcat-green); }

/* Card footer */
.fcat-card-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	padding-top: 14px;
}
.fcat-card-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
}
.fcat-btn-pdf {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 7px 14px;
	border-radius: 50px;
	border: 1px solid #E5E7EB;
	font-size: 12.5px;
	font-weight: 600;
	color: #334155;
	text-decoration: none;
	transition: border-color .2s, color .2s;
}
.fcat-btn-pdf .material-symbols-outlined { font-size: 15px !important; }
.fcat-btn-pdf:hover { border-color: #94A3B8; color: #0F172A; }
.fcat-btn-devis {
	display: inline-flex;
	align-items: center;
	padding: 7px 16px;
	border-radius: 50px;
	background: var(--cat-color);
	color: #fff !important;
	font-size: 12.5px;
	font-weight: 700;
	text-decoration: none;
	transition: background .2s, box-shadow .2s;
}
.fcat-btn-devis:hover {
	filter: brightness(0.88);
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.fcat-card-price {
	font-size: 18px;
	font-weight: 600;
	color: var(--fcat-ink-900);
}
.fcat-card-price-from {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 500;
	color: var(--fcat-ink-500);
	margin-right: 4px;
}
.fcat-card-arrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 600;
	color: var(--fcat-coral);
}
.fcat-card:hover .fcat-card-arrow svg { transform: translateX(3px); }
.fcat-card-arrow svg { transition: transform .2s; }

/* --- Autres catégories --- */
.fcat-other-cats {
	padding: 36px 32px;
	background: var(--fcat-cream, #FAFAF7);
	border-radius: 16px;
	margin-bottom: 32px;
}
.fcat-other-title {
	font-size: 22px;
	font-weight: 600;
	margin: 0 0 18px;
	color: var(--fcat-ink-900);
	letter-spacing: -0.01em;
}
.fcat-other-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
}
.fcat-other-link {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	background: #fff;
	border: 1px solid var(--fcat-line);
	border-radius: 12px;
	text-decoration: none;
	color: var(--fcat-ink-900);
	transition: border-color .15s, transform .15s;
}
body a.fcat-other-link:hover {
	border-color: var(--link-color, var(--fcat-coral));
	color: var(--link-color, var(--fcat-coral));
	transform: translateY(-1px);
}
.fcat-other-icn {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	flex-shrink: 0;
	background-size: 60%;
	background-repeat: no-repeat;
	background-position: center;
}
.fcat-other-name { font-weight: 600; font-size: 14px; }
.fcat-other-count { font-size: 11.5px; color: var(--fcat-ink-500); }

/* --- Responsive --- */
@media (max-width: 900px) {
	.fcat-cards { grid-template-columns: 1fr; }
	.fcat-other-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
	.fcat-hero .fcat-hero-row { flex-direction: column !important; flex-wrap: wrap !important; }
	.fcat-hero .fcat-hero-row > .vc_column_container { flex: 1 1 100% !important; }
	.fcat-hero h1 { font-size: 28px; }
}
@media (max-width: 600px) {
	.fcat-nav-inner { gap: 2px; }
	.fcat-nav-item { padding: 5px 10px; font-size: 12px; }
	.fcat-hero h1 { font-size: 28px; }
	.fcat-stats { gap: 16px; }
	.fcat-other-grid { grid-template-columns: 1fr; }
	.fcat-other-cats { padding: 24px 18px; }
}

/* =====================================================
   PAGE CONTACT
   ===================================================== */

/* --- Hero --- */
.cp-hero {
	background: rgb(254, 242, 242);
	padding: 60px 0 56px;
	text-align: center;
	border-bottom: 1px solid rgba(15,23,42,0.06);
}
.cp-hero-inner {
	max-width: 680px;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
}
.cp-eyebrow {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #cb2228;
	margin: 0 0 16px;
}
.cp-eyebrow span {
	display: block;
	width: 28px;
	height: 1px;
	background: #cb2228;
	opacity: 0.5;
}
.cp-title {
	font-size: 44px;
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: 0 0 16px;
	color: #0F172A;
}
.cp-title em {
	font-style: normal;
	color: #cb2228;
}
.cp-subtitle {
	font-size: 16px;
	line-height: 1.6;
	color: #334155;
	margin: 0;
}

/* --- Corps 2 colonnes --- */
.cp-body {
	display: grid;
	grid-template-columns: 1fr 1.7fr;
	gap: 40px;
	max-width: 1400px;
	margin: 0 auto;
	padding: 56px 20px 80px;
	box-sizing: border-box;
	align-items: start;
}

/* --- Carte coordonnées (sticky) --- */
.cp-coords-wrap {
	position: sticky;
	top: 24px;
}
.cp-coords-card {
	background: rgb(254, 242, 242);
	border: none;
	border-radius: 16px;
	padding: 32px 28px;
}
/* titre : hérite du thème, juste la marge */
.cp-coords-title {
	margin: 0 0 24px;
}
.cp-coord-row {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 18px;
}
.cp-coord-icon-box {
	width: 40px;
	height: 40px;
	min-width: 40px;
	border-radius: 10px;
	background: #fff;
	border: 1px solid #F1E8E8;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.cp-coord-icon {
	font-size: 18px !important;
	color: #cb2228;
}
.cp-coord-content {
	display: flex;
	flex-direction: column;
	gap: 4px;
	padding-top: 3px;
}
.cp-coord-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #94A3B8;
}
.cp-coord-value {
	font-weight:400;
	color: #334155;
	line-height: 1.5;
}
.cp-coord-value a {
	color: #334155;
	text-decoration: none;
	display: block;
}
.cp-coord-value a:hover { color: #cb2228; }

/* Horaires — séparés, sans icône */
.cp-horaires-section {
	border-top: 1px solid rgba(15,23,42,0.08);
	padding-top: 16px;
	margin-bottom: 16px;
}
.cp-horaires-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #94A3B8;
	margin-bottom: 8px;
}
.cp-horaires {
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 12px;
	color: #334155;
}
.cp-horaire-row {
	display: flex;
	justify-content: space-between;
	gap: 16px;
}
.cp-horaire-row span:last-child {
	text-align: right;
	white-space: nowrap;
}

/* Infos légales */
.cp-legal {
	border-top: 1px solid rgba(15,23,42,0.08);
	padding-top: 14px;
	margin-top: 4px;
}
.cp-legal p {
	font-size: 12px;
	color: #64748B;
	margin: 0 0 3px;
}
.cp-legal strong { color: #334155; font-weight: 700; }
.cp-legal-note {
	font-style: italic;
	color: #94A3B8 !important;
	font-size: 11px !important;
}

/* --- Carte formulaire --- */
.cp-form-card {
	background: #fff;
	border: 1px solid #E5E7EB;
	border-radius: 16px;
	padding: 36px 36px 32px;
	box-shadow: 0 2px 12px rgba(15,23,42,0.06);
}


/* --- CF7 styles --- */
/* Grille CF7 */
.cp-cf7-grid { display: flex; flex-direction: column; gap: 18px; }
.cp-cf7-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.cp-cf7-row > label,
.cp-cf7-row > p { min-width: 0; margin: 0; }
.cp-cf7-row > p > label { display: flex; flex-direction: column; gap: 7px; }
.cp-cf7-full { display: flex; flex-direction: column; }

/* Labels */
.cp-cf7-grid label {
	display: flex;
	flex-direction: column;
	gap: 7px;
	font-size: 13px;
	font-weight: 600;
	color: #334155;
}
/* Astérisque obligatoire en rouge */
.cp-cf7-grid .wpcf7-not-valid-tip { color: #cb2228; font-size: 12px; margin-top: 4px; }
.cp-page .wpcf7-form abbr { color: #cb2228; text-decoration: none; }

/* Champs texte / email / tel */
.cp-cf7-grid input[type="text"],
.cp-cf7-grid input[type="email"],
.cp-cf7-grid input[type="tel"] {
	width: 100%;
	padding: 11px;
	border: 1px solid #D1D5DB;
	border-radius: 10px;
	font-size: 14px;
	color: #0F172A;
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
	box-sizing: border-box;
	font-family: inherit;
}
.cp-cf7-grid input[type="text"]::placeholder,
.cp-cf7-grid input[type="email"]::placeholder,
.cp-cf7-grid input[type="tel"]::placeholder { color: #9CA3AF; }

/* Select */
.cp-cf7-grid select {
	width: 100%;
	padding: 11px 18px;
	border: 1px solid #D1D5DB;
	border-radius: 12px;
	font-size: 14px;
	color: #64748B;
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
	box-sizing: border-box;
	font-family: inherit;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	cursor: pointer;
}

/* Textarea */
.cp-cf7-grid textarea {
	width: 100%;
	padding: 12px 18px;
	border: 1px solid #D1D5DB;
	border-radius: 12px;
	font-size: 14px;
	color: #0F172A;
	background: #fff;
	transition: border-color .2s, box-shadow .2s;
	box-sizing: border-box;
	font-family: inherit;
	min-height: 130px;
	resize: vertical;
	line-height: 1.6;
}
.cp-cf7-grid textarea::placeholder { color: #9CA3AF; }

/* Focus */
.cp-cf7-grid input:focus,
.cp-cf7-grid select:focus,
.cp-cf7-grid textarea:focus {
	outline: none;
	border-color: #cb2228;
	box-shadow: 0 0 0 3px rgba(220,78,75,0.08);
}
/* Champ invalide */
.cp-cf7-grid input.wpcf7-not-valid,
.cp-cf7-grid select.wpcf7-not-valid,
.cp-cf7-grid textarea.wpcf7-not-valid {
	border-color: #cb2228;
}

/* RGPD */
.cp-cf7-rgpd {
	display: block;
	align-items: flex-start;
	gap: 10px;
	font-size: 13px;
	color: #64748B;
	line-height: 1.55;
	background: #F8FAFC;
	border-radius: 10px;
	padding: 14px 16px;
}
.cp-cf7-rgpd a { color: #cb2228; text-decoration: underline; }
.cp-cf7-rgpd .wpcf7-form-control-wrap { float: left; margin-right: 10px; }
.cp-cf7-rgpd .wpcf7-list-item { margin: 0; }
.cp-cf7-rgpd .wpcf7-list-item-label { display: none; }
.cp-cf7-rgpd input[type="checkbox"] {
	margin-top: 3px;
	flex-shrink: 0;
	accent-color: #cb2228;
	width: 16px;
	height: 16px;
	cursor: pointer;
}

/* Ligne submit : note + bouton */
.cp-cf7-submit-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
	padding-top: 4px;
}
.cp-form-footnote {
	font-size: 12px;
	color: #94A3B8;
}

/* Bouton submit */
.cp-cf7-grid .wpcf7-submit {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background-color: #cb2228 !important;
	color: #fff !important;
	border: 2px solid #cb2228 !important;
	border-radius: 50px;
	padding: 12px 28px;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
	transition: background-color .22s, box-shadow .22s;
	font-family: inherit;
	white-space: nowrap;
}
.cp-cf7-grid .wpcf7-submit:hover {
	background-color: #b83d3a;
	border-color: #b83d3a;
	box-shadow: 0 4px 16px rgba(220,78,75,0.35);
}

/* Message de confirmation CF7 */
.cp-form-card .wpcf7-response-output {
	margin: 16px 0 0;
	padding: 12px 16px;
	border-radius: 10px;
	font-size: 13px;
	border: none !important;
}
.cp-form-card .wpcf7 form.sent .wpcf7-response-output {
	background: #ECFDF5;
	color: #16A34A;
}
.cp-form-card .wpcf7 form.invalid .wpcf7-response-output,
.cp-form-card .wpcf7 form.failed .wpcf7-response-output {
	background: #FEF2F2;
	color: #cb2228;
}

/* --- Responsive --- */
@media (max-width: 900px) {
	.cp-body {
		grid-template-columns: 1fr;
		padding: 40px 20px 60px;
	}
	.cp-coords-wrap { position: static; }
	.cp-title { font-size: 32px; }
}
@media (max-width: 640px) {
	.cp-cf7-row { grid-template-columns: 1fr; }
	.cp-title { font-size: 28px; }
	.cp-form-card { padding: 24px 20px; }
}

/* =====================================================================
   Sous-menus formations — scroll ancre + dropdown
   ===================================================================== */

/* Scroll fluide + compenser le header fixe (~89px) */
html {
	scroll-behavior: smooth;
	scroll-padding-top: 100px;
}


/* Ancrer le sous-menu sous le li parent */
#menu-main-menu > .menu-item-has-children {
	position: relative !important;
}

/* Sous-menu : liste verticale de formations */
#menu-main-menu > .menu-item-has-children > .sub-menu {
	display: block !important;
	width: auto !important;
	min-width: 260px;
	max-width: 340px;
	top: 100% !important;
	padding: 10px 0 8px !important;
	background: #fff !important;
	box-shadow: 0 8px 24px rgba(0,0,0,0.12);
	border-top: 2px solid #f0f0f0;
	border-radius: 0 0 8px 8px;
}

#menu-main-menu > .menu-item-has-children:hover > .sub-menu {
	left: 0 !important;
}

/* Items de sous-menu formations */
#menu-main-menu > .menu-item-has-children > .sub-menu > li {
	display: block !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
}

#menu-main-menu > .menu-item-has-children > .sub-menu > li > a {
	display: block;
	width: 100% !important;
	box-sizing: border-box !important;
	padding: 10px 18px !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	color: #374151 !important;
	white-space: normal;
	line-height: 1.35;
	border-radius: 6px;
	transition: background 0.15s, color 0.15s;
}
#menu-main-menu > .menu-item-has-children > .sub-menu > li > a:hover {
	background: #f3f4f6;
	color: #111827 !important;
}

/* ===== Blocs catégories formations — layout grille ===== */

.cat-block--green  { --cat-color: #16a34a; --cat-bg: #dcfce7; --cat-bg-solid: #f0fdf4; }
.cat-block--red    { --cat-color: #cb2228; --cat-bg: #fee2e2; --cat-bg-solid: #fff5f5; }
.cat-block--amber  { --cat-color: #ca8a04; --cat-bg: #fef9c3; --cat-bg-solid: #fffbeb; }
.cat-block--blue   { --cat-color: #2563eb; --cat-bg: #dbeafe; --cat-bg-solid: #eff6ff; }

.cat-block {
    display: grid !important;
    grid-template-columns: 1fr 2fr !important;
    gap: 0 !important;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 32px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07);
    min-height: 320px;
}
.cat-block.reverse {
    grid-template-columns: 2fr 1fr !important;
}
.cat-block.reverse .cat-block__image { order: 2; }
.cat-block.reverse .cat-block__list  { order: 1; }

/* Colonne image */
.cat-block__image {
    position: relative;
    overflow: hidden;
    background: var(--cat-bg-solid);
    min-height: 240px;
}
.cat-block__image img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.cat-block__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.72) 0%, rgba(0,0,0,0.15) 55%, transparent 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 20px 18px;
    gap: 4px;
}
.cat-block__image--no-img .cat-block__overlay {
    background: var(--cat-bg);
    justify-content: center;
    align-items: center;
    text-align: center;
}
.cat-block__overlay-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background-size: 65%;
    background-repeat: no-repeat;
    background-position: center;
    margin-bottom: 10px;
    flex-shrink: 0;
    box-shadow: 0 0 0 2px rgba(255,255,255,0.5);
}
.cat-block__overlay-name {
    font-size: 22px;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.cat-block__overlay-count {
    font-size: 13px;
    color: rgba(255,255,255,0.85);
    font-weight: 500;
    text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.cat-block__image--no-img .cat-block__overlay-name,
.cat-block__image--no-img .cat-block__overlay-count {
    color: var(--cat-color);
    text-shadow: none;
}

/* Colonne liste */
.cat-block__list {
    background: #fff;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    max-height: 400px;
    padding: 6px 0;
}

/* Ligne formation */
a.cat-row {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 13px 20px !important;
    text-decoration: none !important;
    color: #1e2130 !important;
    border-bottom: 1px solid #f3f4f6 !important;
    transition: background 0.15s !important;
    box-sizing: border-box;
}
a.cat-row:last-child { border-bottom: none !important; }
a.cat-row:hover { background: var(--cat-bg-solid) !important; text-decoration: none !important; }

.cat-row__title {
    flex: 1;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.35;
    color: #1e2130;
}

/* Mention partenaire FFSFP (PSC, GQS, Formation de formateurs SST) */
.cat-row__partner {
    display: block;
    margin-left: 0;
    font-size: 12px;
    font-style: italic;
    font-weight: 400;
    color: #94a3b8;
}

.cat-row__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    flex-shrink: 0;
}
.cat-row__tag {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 20px;
    background: var(--cat-bg);
    color: var(--cat-color);
    font-weight: 600;
    white-space: nowrap;
}

/* Légende ERP sous la section catalogue (page d'accueil) */
.catalogue_erp_note, .catalogue_erp_note p {
    font-size: 13px;
    color: #94a3b8;
    font-style: italic;
    margin: 14px 0 0;
}

.cat-row__arrow {
    flex-shrink: 0;
    font-size: 16px;
    color: var(--cat-color);
    opacity: 0.6;
    transition: transform 0.15s, opacity 0.15s;
    line-height: 1;
}
a.cat-row:hover .cat-row__arrow {
    transform: translateX(4px);
    opacity: 1;
}

@media (max-width: 768px) {
    .cat-block,
    .cat-block.reverse {
        grid-template-columns: 1fr !important;
    }
    .cat-block.reverse .cat-block__image { order: 0; }
    .cat-block.reverse .cat-block__list  { order: 1; }
    .cat-block__image { min-height: 200px; }
    .cat-block__list  { max-height: none; }
}

/* ============================================================
   QUI SOMMES-NOUS
   ============================================================ */

/* --- Hero --- */
body .qsn-hero {
    background: linear-gradient(135deg, #0d1f3c 0%, #1a3a5c 60%, #0f4c35 100%) !important;
    padding: 90px 20px 80px !important;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}
body .qsn-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
body .qsn-hero-inner {
    position: relative;
    max-width: 720px;
    margin: 0 auto;
}
body .qsn-eyebrow {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 12px;
    font-size: 14px !important;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #03ab30 !important;
    margin-bottom: 20px !important;
}
body .qsn-eyebrow span {
    display: inline-block !important;
    width: 32px;
    height: 2px;
    background: #03ab30;
    font-size: 0;
}
body h1.qsn-hero-title {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(36px, 5vw, 58px) !important;
    font-weight: 700 !important;
    margin: 0 0 20px !important;
    line-height: 1.1 !important;
    color: #fff !important;
}
body .qsn-hero-subtitle {
    font-size: 18px;
    line-height: 1.6;
    color: rgba(255,255,255,0.85) !important;
    max-width: 560px;
    margin: 0 auto;
}

/* --- Sections génériques --- */
body .qsn-section {
    padding: 80px 20px !important;
}
body .qsn-section--light {
    background: #f8f9fa !important;
}
body .qsn-section-eyebrow {
    display: block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #03ab30 !important;
    margin: 0 0 10px !important;
}
body h2.qsn-section-title {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(26px, 3vw, 38px) !important;
    font-weight: 700 !important;
    color: #0d1f3c !important;
    margin: 0 0 40px !important;
}
body .qsn-centered {
    text-align: center !important;
}

/* --- Présentation --- */
body .qsn-pres-inner {
    display: flex !important;
    align-items: center;
    gap: 60px;
}
body .qsn-pres-image {
    flex: 0 0 400px;
    position: relative;
}
body .qsn-pres-image img {
    width: 100%;
    border-radius: 16px;
    object-fit: cover;
    max-height: 420px;
    display: block;
}
body .qsn-pres-badge {
    position: absolute;
    bottom: -20px;
    right: -20px;
    background: #03ab30 !important;
    color: #fff !important;
    border-radius: 50%;
    width: 100px;
    height: 100px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(3,171,48,0.4);
}
body .qsn-badge-annee {
    font-family: 'Kanit', sans-serif;
    font-size: 28px !important;
    font-weight: 700;
    line-height: 1;
    color: #fff !important;
}
body .qsn-badge-label {
    font-size: 10px !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #fff !important;
    opacity: 0.85;
}
body .qsn-pres-content {
    flex: 1;
}
body .qsn-pres-content--full {
    max-width: 800px;
    margin: 0 auto;
}
body .qsn-pres-content h2 {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(24px, 3vw, 36px) !important;
    font-weight: 700 !important;
    color: #0d1f3c !important;
    margin: 0 0 20px !important;
}
body .qsn-pres-texte {
    font-size: 16px;
    line-height: 1.8;
    color: #444;
    margin-bottom: 28px;
}
body .qsn-pres-texte p { margin: 0 0 14px; }
body .qsn-pres-pills {
    display: flex !important;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}
body .qsn-pill {
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    background: #eafaf0 !important;
    border: 1px solid #b3e6c0;
    color: #0f6b2d !important;
    border-radius: 50px;
    padding: 6px 16px;
    font-size: 13px !important;
    font-weight: 600;
}
body .qsn-pill .material-symbols-outlined {
    font-size: 16px !important;
    color: #03ab30 !important;
}

/* --- Avantages --- */
body .qsn-avantages-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 28px;
    margin-top: 48px;
}
body .qsn-av-card {
    background: #fff !important;
    border-radius: 16px;
    padding: 32px 24px !important;
    text-align: center;
    box-shadow: 0 2px 20px rgba(0,0,0,0.06);
    transition: transform 0.2s, box-shadow 0.2s;
}
body .qsn-av-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.1);
}
body .qsn-av-icon-wrap {
    width: 64px !important;
    height: 64px !important;
    background: linear-gradient(135deg, #eafaf0, #c8f0d6) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px !important;
}
body .qsn-av-icon {
    font-size: 30px !important;
    color: #03ab30 !important;
}
body h3.qsn-av-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #0d1f3c !important;
    margin: 0 0 10px !important;
}
body .qsn-av-texte {
    font-size: 14px !important;
    line-height: 1.6;
    color: #666 !important;
    margin: 0 !important;
}

/* --- Pédagogie --- */
body .qsn-ped-inner {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}
body .qsn-ped-head {
    text-align: center;
    width: 100%;
}
body .qsn-ped-head h2 {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(24px, 2.5vw, 34px) !important;
    font-weight: 700 !important;
    color: #0d1f3c !important;
    margin: 0 !important;
}
body .qsn-ped-list {
    width: 100%;
    max-width: 760px;
}
body .qsn-ped-list {
    display: flex !important;
    flex-direction: column;
    gap: 0;
}
body .qsn-ped-item {
    display: flex !important;
    gap: 24px;
    align-items: flex-start;
    padding: 24px 0 !important;
    border-bottom: 1px solid #eee !important;
}
body .qsn-ped-item:last-child { border-bottom: none !important; }
body .qsn-ped-num {
    font-family: 'Kanit', sans-serif !important;
    font-size: 48px !important;
    font-weight: 700 !important;
    color: #d4edda !important;
    line-height: 1;
    min-width: 60px;
}
body h3.qsn-ped-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #0d1f3c !important;
    margin: 0 0 8px !important;
}
body .qsn-ped-texte {
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: #555 !important;
    margin: 0 !important;
}

/* --- CTA --- */
body .qsn-cta {
    background: linear-gradient(135deg, #03ab30, #028a26) !important;
    padding: 80px 20px !important;
    text-align: center;
    color: #fff;
}
body .qsn-cta-inner {
    max-width: 640px;
    margin: 0 auto;
}
body h2.qsn-cta-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(26px, 3.5vw, 40px) !important;
    font-weight: 700 !important;
    margin: 0 0 16px !important;
    color: #fff !important;
}
body .qsn-cta-texte {
    font-size: 17px;
    line-height: 1.6;
    color: rgba(255,255,255,0.92) !important;
    margin: 0 0 36px !important;
}
body .qsn-cta-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 10px;
    background: #fff !important;
    color: #03ab30 !important;
    font-weight: 700;
    font-size: 16px;
    padding: 16px 36px;
    border-radius: 50px;
    text-decoration: none;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}
body .qsn-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0,0,0,0.2);
    color: #03ab30 !important;
}
body .qsn-cta-btn .material-symbols-outlined {
    font-size: 20px !important;
    color: #03ab30 !important;
}

/* --- Responsive --- */
@media (max-width: 900px) {
    body .qsn-pres-inner {
        flex-direction: column !important;
        gap: 40px;
    }
    body .qsn-pres-image {
        flex: none;
        width: 100%;
    }
    body .qsn-pres-badge {
        bottom: -14px;
        right: 14px;
    }
    body .qsn-ped-inner {
        grid-template-columns: 1fr !important;
        gap: 32px;
    }
}
@media (max-width: 600px) {
    body .qsn-hero { padding: 60px 16px !important; }
    body .qsn-section { padding: 60px 16px !important; }
    body .qsn-avantages-grid { grid-template-columns: 1fr !important; }
    body .qsn-ped-item { flex-direction: column !important; gap: 8px; }
    body .qsn-ped-num { font-size: 32px !important; }
}

/* ============================================================
   RÉGLEMENTATION
   ============================================================ */

/* --- Hero --- */
body .regl-hero {
    background: linear-gradient(135deg, #0d1f3c 0%, #1b3560 60%, #2a1a4e 100%) !important;
    padding: 90px 20px 80px !important;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}
body .regl-eyebrow {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 12px;
    font-size: 14px !important;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #7c83fd !important;
    margin-bottom: 20px !important;
}
body .regl-eyebrow span {
    display: inline-block !important;
    width: 32px;
    height: 2px;
    background: #7c83fd;
    font-size: 0;
}
body h1.regl-hero-title {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(36px, 5vw, 58px) !important;
    font-weight: 700 !important;
    margin: 0 0 20px !important;
    line-height: 1.1 !important;
    color: #fff !important;
}
body .regl-hero-subtitle {
    font-size: 18px;
    line-height: 1.6;
    color: rgba(255,255,255,0.82) !important;
    max-width: 720px;
    margin: 0 auto;
}

/* --- Sections --- */
body .regl-section {
    padding: 72px 20px !important;
}
body .regl-section--light {
    background: #f8f9fa !important;
}
body .regl-section-eyebrow {
    display: block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: #6363f9 !important;
    margin: 0 0 10px !important;
}
body .regl-centered {
    text-align: center !important;
}

/* --- Intro --- */
body .regl-intro-inner {
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
body h2.regl-intro-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(22px, 2.5vw, 32px) !important;
    font-weight: 700 !important;
    color: #0d1f3c !important;
    margin: 0 0 20px !important;
}
body .regl-intro-texte {
    font-size: 17px;
    line-height: 1.8;
    color: #444;
}
body .regl-intro-texte p { margin: 0 0 14px; }

/* --- Blocs réglementaires --- */
body .regl-blocs-section {
    background: #f0f2f8 !important;
    padding-left: 40px !important;
    padding-right: 40px !important;
}
body .regl-blocs-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 28px;
}
body .regl-bloc {
    background: #fff !important;
    border-radius: 16px;
    padding: 32px 28px !important;
    margin: 16px 12px !important;
    border-top: 4px solid var(--regl-color, #6363f9);
    box-shadow: 0 2px 16px rgba(0,0,0,0.06);
    transition: transform 0.2s, box-shadow 0.2s;
}
body .regl-bloc:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.1);
}
body .regl-bloc-header {
    display: flex !important;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 16px;
}
body .regl-bloc-icon-wrap {
    width: 48px !important;
    height: 48px !important;
    background: color-mix(in srgb, var(--regl-color, #6363f9) 12%, white) !important;
    border-radius: 12px !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
body .regl-bloc-icon {
    font-size: 24px !important;
    color: var(--regl-color, #6363f9) !important;
}
body h2.regl-bloc-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #0d1f3c !important;
    margin: 0 0 4px !important;
    line-height: 1.2;
}
body .regl-bloc-sous-titre {
    font-size: 13px !important;
    color: #888 !important;
    margin: 0 !important;
    font-style: italic;
}
body .regl-bloc-intro {
    font-size: 14px;
    line-height: 1.6;
    color: #555;
    margin: 0 0 20px !important;
    padding-bottom: 16px;
    border-bottom: 1px solid #eee;
}
body .regl-refs {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
body .regl-ref-item {
    padding: 10px 14px;
    background: #f9f9fb;
    border-radius: 8px;
    border-left: 3px solid var(--regl-color, #6363f9);
}
body .regl-ref-label {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: var(--regl-color, #6363f9) !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}
body .regl-ref-desc {
    font-size: 13px !important;
    color: #444 !important;
    line-height: 1.5;
}

/* --- Téléchargements --- */
body h2.regl-dl-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(22px, 2.5vw, 32px) !important;
    font-weight: 700 !important;
    color: #0d1f3c !important;
    margin: 0 0 40px !important;
}
body .regl-dl-inner {
    max-width: 860px;
    margin: 0 auto;
}
body .regl-dl-grid {
    display: flex !important;
    flex-direction: column;
    gap: 12px;
}
body .regl-dl-card {
    display: flex !important;
    align-items: center;
    gap: 16px;
    background: #fff !important;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    padding: 18px 20px !important;
    text-decoration: none;
    transition: border-color 0.2s, box-shadow 0.2s;
}
body .regl-dl-card:hover {
    border-color: #6363f9;
    box-shadow: 0 4px 16px rgba(99,99,249,0.12);
}
body .regl-dl-icon {
    font-size: 28px !important;
    color: #6363f9 !important;
    flex-shrink: 0;
}
body .regl-dl-body {
    flex: 1;
    display: flex;
    flex-direction: column;
}
body .regl-dl-name {
    font-weight: 700;
    font-size: 15px;
    color: #0d1f3c !important;
}
body .regl-dl-desc {
    font-size: 13px;
    color: #888 !important;
    margin-top: 2px;
}
body .regl-dl-arrow {
    font-size: 20px !important;
    color: #bbb !important;
    transition: color 0.2s, transform 0.2s;
}
body .regl-dl-card:hover .regl-dl-arrow {
    color: #6363f9 !important;
    transform: translateX(3px);
}

/* --- CTA --- */
body .regl-cta {
    background: linear-gradient(135deg, #0d1f3c, #1b3560) !important;
    padding: 80px 20px !important;
    text-align: center;
}
body .regl-cta-inner {
    max-width: 640px;
    margin: 0 auto;
}
body h2.regl-cta-titre {
    font-family: 'Kanit', sans-serif !important;
    font-size: clamp(26px, 3.5vw, 40px) !important;
    font-weight: 700 !important;
    margin: 0 0 16px !important;
    color: #fff !important;
}
body .regl-cta-texte {
    font-size: 17px;
    line-height: 1.6;
    color: rgba(255,255,255,0.85) !important;
    margin: 0 0 36px !important;
}
body .regl-cta-btn {
    display: inline-flex !important;
    align-items: center;
    gap: 10px;
    background: #6363f9 !important;
    color: #fff !important;
    font-weight: 700;
    font-size: 16px;
    padding: 16px 36px;
    border-radius: 50px;
    text-decoration: none;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 4px 20px rgba(99,99,249,0.4);
}
body .regl-cta-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(99,99,249,0.5);
    color: #fff !important;
}
body .regl-cta-btn .material-symbols-outlined {
    font-size: 20px !important;
    color: #fff !important;
}

/* --- Responsive --- */
@media (max-width: 768px) {
    body .regl-blocs-grid { grid-template-columns: 1fr !important; }
    body .regl-section { padding: 52px 16px !important; }
    body .regl-hero { padding: 60px 16px !important; }
}
