/*
Theme Name: Astra Child
Description: Thème enfant d'Astra
Template: astra
Version: 1.0
*/

@import url("../astra/style.css");

/* Vos CSS personnalisés ici */



/* ==============================
   MENU
   ==============================*/

.site-title{
	display:none !important;
}


/* Styles généraux (desktop et mobile) */
.main-navigation li a {
    color: #0A2540 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    font-family: "Open sans", Sans serif !important;
}

.elementor-kit-5 a {
    font-family: 'Poppins' !important;
}

.ast-primary-header-bar {
    border: none !important;
}

/* STYLES DESKTOP UNIQUEMENT */
@media (min-width: 922px) {
    /* Fond arrondi au survol - ajustement de la hauteur */
    .main-header-menu > li > a {
        transition: all 0.3s ease !important;
        border-radius: 20px !important;
        padding: 6px 12px !important;
        margin: 0 4px !important;
        display: inline-block !important;
        line-height: 1.4 !important;
    }
    
    .main-header-menu > li > a:hover {
        background-color: #F5F5F5 !important;
    }
    
    /* Garder les flèches visibles */
    .main-header-menu > li > a:hover .ast-arrow-svg {
        fill: #0A2540 !important;
    }
    
    /* Correction pour le survol fluide */
    .main-header-menu > li {
        position: relative !important;
    }
    
    .sub-menu {
        border-radius: 20px !important;
        overflow: hidden !important;
        background-color: #F5F5F5 !important;
        top: calc(100% + 4px) !important; /* Plus petit gap */
        margin-top: 0 !important; /* Supprimé le margin-top */
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important; /* Ombre pour séparer visuellement */
    }
    
    /* Créer une zone invisible pour faciliter le survol */
    .main-header-menu > li::after {
        content: "" !important;
        position: absolute !important;
        top: 100% !important;
        left: 0 !important;
        right: 0 !important;
        height: 8px !important; /* Zone de transition invisible */
        z-index: 999 !important;
    }
    
    .sub-menu li:first-child a {
        border-radius: 20px 20px 0 0 !important;
    }
    
    .sub-menu li:last-child a {
        border-radius: 0 0 20px 20px !important;
    }
    
    .sub-menu li:only-child a {
        border-radius: 20px !important;
    }
    
    .sub-menu li:hover a,
    .sub-menu li a:hover {
        color: white !important;
        background-color: #0097B2 !important;
    }
    
    .sub-menu li a {
        position: relative !important;
        transition: all 0.3s ease !important;
    }
    
    .sub-menu li a:hover::after {
        content: "" !important;
        position: absolute !important;
        right: 15px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        width: 12px !important;
        height: 12px !important;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='white' viewBox='0 0 24 24'%3E%3Cpath d='M8.59 16.59L10 18l6-6-6-6-1.41 1.41L13.17 12l-4.58 4.59z'/%3E%3C/svg%3E") !important;
        background-size: contain !important;
        background-repeat: no-repeat !important;
    }
    
    .sub-menu li a:hover {
        padding-right: 40px !important;
    }
}

/* STYLES MOBILE UNIQUEMENT */
@media (max-width: 921px) {
    /* Reset des styles desktop pour mobile */
    .main-header-menu > li > a {
        border-radius: 0 !important;
        padding: 12px 20px !important;
        margin: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        line-height: normal !important;
        background-color: transparent !important;
        position: relative !important;
        transition: all 0.3s ease !important;
    }
    
    .main-header-menu > li > a:hover {
        background-color: rgba(0, 151, 178, 0.1) !important;
    }
    
    /* Style du menu principal quand il est ouvert - avec plus de sélecteurs */
    .main-header-menu > li.menu-item-has-children.ast-menu-hover > a,
    .main-header-menu > li.menu-item-has-children[aria-expanded="true"] > a,
    .main-header-menu > li.menu-item-has-children.current-menu-ancestor > a,
    .main-header-menu > li.menu-item-has-children.current-menu-parent > a,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children.ast-menu-hover > a,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children[aria-expanded="true"] > a {
        background-color: #0097B2 !important;
        color: #FFFFFF !important;
    }
    
    .main-header-menu > li::after {
        display: none !important;
    }
    
    /* Suppression complète du style des flèches - ciblage plus précis */
    .main-header-menu > li.menu-item-has-children > a .dropdown-menu-toggle,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children > a .dropdown-menu-toggle,
    .main-header-menu > li > a .ast-menu-toggle,
    .ast-hf-mobile-menu .main-header-menu > li > a .ast-menu-toggle {
        background: none !important;
        border: none !important;
        box-shadow: none !important;
        border-radius: 0 !important;
        padding: 0 !important;
        margin-left: 10px !important;
        position: relative !important;
        width: auto !important;
        height: auto !important;
    }
    
    .main-header-menu > li.menu-item-has-children > a .dropdown-menu-toggle .ast-icon,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children > a .dropdown-menu-toggle .ast-icon,
    .main-header-menu > li > a .ast-menu-toggle .ast-icon,
    .ast-hf-mobile-menu .main-header-menu > li > a .ast-menu-toggle .ast-icon {
        background: none !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        border: none !important;
        padding: 0 !important;
        margin: 0 !important;
        width: 16px !important;
        height: 16px !important;
    }
    
    /* Style des flèches - ciblage élargi */
    .main-header-menu > li.menu-item-has-children > a .ast-arrow-svg,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children > a .ast-arrow-svg,
    .main-header-menu > li > a .ast-arrow-svg,
    .ast-hf-mobile-menu .main-header-menu > li > a .ast-arrow-svg {
        fill: #0A2540 !important;
        transition: fill 0.3s ease !important;
        width: 16px !important;
        height: 16px !important;
    }
    
    /* Flèche blanche quand le menu est ouvert/actif - ciblage élargi */
    .main-header-menu > li.menu-item-has-children.ast-menu-hover > a .ast-arrow-svg,
    .main-header-menu > li.menu-item-has-children[aria-expanded="true"] > a .ast-arrow-svg,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children.ast-menu-hover > a .ast-arrow-svg,
    .ast-hf-mobile-menu .main-header-menu > li.menu-item-has-children[aria-expanded="true"] > a .ast-arrow-svg {
        fill: #FFFFFF !important;
    }
    
    .sub-menu {
        border-radius: 0 !important;
        background-color: #f8f9fa !important;
        box-shadow: none !important;
        margin-top: 0 !important;
        position: static !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }
    
    .sub-menu li a {
        padding: 8px 30px !important;
        border-radius: 0 !important;
        font-size: 12px !important;
    }
    
    .sub-menu li a:hover {
        background-color: rgba(0, 151, 178, 0.1) !important;
        color: #0A2540 !important;
        padding-right: 30px !important;
    }
    
    .sub-menu li a:hover::after {
        display: none !important;
    }
    
    /* Supprimer les flèches dans les sous-menus mobiles */
    .sub-menu li a .ast-icon.icon-arrow {
        display: none !important;
    }
    
    /* Réduire l'espacement général du menu mobile */
    #ast-hf-mobile-menu .main-header-menu {
        margin: 0 !important;
        padding: 0 !important;
    }
    
    #ast-hf-mobile-menu .main-header-menu > li {
        margin: 0 !important;
        border-bottom: 1px solid #eee !important;
    }
    
    #ast-hf-mobile-menu .main-header-menu > li:last-child {
        border-bottom: none !important;
    }
    
    /* Style pour le menu hamburger mobile */
    .ast-mobile-header-content {
        background-color: white !important;
    }
    
    .ast-mobile-menu-trigger-minimal {
        color: #0A2540 !important;
    }
}

/* ==============================
   FOOTER
   ==============================*/

.site-footer-section li, .site-footer-section p, .site-footer-section h3{
	color:white;
}

.site-primary-footer-wrap {
	border-radius:20px !important;
	border:none !important;
}

.wp-image-392 {
    filter: brightness(0) invert(1) !important;
}


/* Responsive */

@media (max-width: 544px) {
    .ast-builder-grid-row-container.ast-builder-grid-row-mobile-full .ast-builder-grid-row {
        padding: 20px;
    }
	
	.ast-builder-footer-grid-columns.site-above-footer-inner-wrap.ast-builder-grid-row{
		height:200px;
	}
}


/* ==============================
   Page d'accueil
   ==============================*/

p {
    font-weight: 400 !important;
}

.elementor-button:hover{
	 transform: translateY(-2px) !important;
}


.header-hero{
    backdrop-filter: blur(5px) !important;
    -webkit-backdrop-filter: blur(5px) !important;
}



/* ==============================
   BLOCS AVEC EFFET DE SURVOL
   ==============================*/

.bloc-hover {
    position: relative !important;
    overflow: hidden !important; /* Important pour masquer le débordement */
}

.bloc-hover::before {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important; /* Depuis le bas au lieu du haut */
    left: 0 !important;
    width: 100% !important;
    height: 0 !important;
    background-color: #0097B2 !important;
    transition: height 0.4s ease !important;
}

.bloc-hover:hover::before {
    height: 100% !important;
}

.bloc-hover > * {
    position: relative !important;
    z-index: 2 !important;
}

.bloc-hover .e-con-full {
    height: 100% !important;
}

/* ==============================
   CARROUSEL GÉNÉRIQUE
   ============================== */

/* Navigation des secteurs */
.secteurs-nav-inline {
    display: flex;
    align-items: center;
    gap: 10px;
}

.nav-arrow-inline {
    background: rgba(0, 151, 178, 0.1);
    border: 2px solid #0097B2;
    border-radius: 50%;
    width: 45px;
    height: 45px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    font-size: 18px;
    color: #0097B2;
    font-weight: bold;
}

.nav-arrow-inline:hover {
    background: #0097B2;
    color: white;
    transform: scale(1.05);
}

.nav-arrow-inline:disabled {
    opacity: 0.3;
    cursor: not-allowed;
    transform: scale(1) !important;
    background: rgba(0, 151, 178, 0.05);
    color: #ccc;
    border-color: #ccc;
}

/* Container principal du carrousel */
.carrousel {
    display: flex !important;
    flex-wrap: nowrap !important;
    transition: transform 0.4s ease !important;
    overflow: visible !important;
}

.carrousel-wrapper {
    overflow: hidden !important;
    position: relative !important;
}

/* Chaque item du carrousel */
.carrousel-item {
  flex: 0 0 24% !important;
    width: 24% !important;
    min-width: 24% !important;
    max-width: 24% !important;
    margin: 0 !important;
    padding: 0px !important;
    box-sizing: border-box !important;
}

.carrousel-item a {
	text-decoration:none !important;
} 



.carrousel-item h3 {
    font-size: 1em !important;
    font-weight: normal !important;
    padding: 20px 0px 20px 20px;
}

/* Changement de couleur du titre au survol */
.carrousel-item:hover h3 {
    color: white !important;
    transition: color 0.2s ease 0.1s;
}

/* Navigation du carrousel */
.nav-inline {
    display: flex;
    align-items: center;
}

.nav-arrow {
    background: rgba(0, 151, 178, 0.1);
    border: 2px solid #0097B2;
    border-radius: 50%;
    width: 45px;
    height: 45px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    font-size: 18px;
    color: #0097B2;
    font-weight: bold;
}

.nav-arrow:hover {
    background: #0097B2;
    color: white;
    transform: scale(1.05);
}

.nav-arrow:disabled {
    opacity: 0.3;
    cursor: not-allowed;
    transform: scale(1) !important;
    background: rgba(0, 151, 178, 0.05);
    color: #ccc;
    border-color: #ccc;
}

/* =================================
   ICÔNES GÉNÉRIQUES
   ================================= */

.icon .elementor-icon{
	background: #0A2540 !important;
    padding: 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    width: 60px !important;
    height: 60px !important;
    box-sizing: border-box !important;
}

.icon .elementor-icon svg{
	 width: 24px !important;
    height: 24px !important;
}


/* Icônes carroussel */
.icon-hex {
    position: absolute !important;
    top: 15px !important;
    left: 15px !important;
    z-index: 500 !important;
}


.icon-hex .elementor-icon-wrapper {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 60px !important;
    height: 60px !important;
}

.icon-hex .elementor-icon {
    background: #FFF !important;
    padding: 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    width: 60px !important;
    height: 60px !important;
    box-sizing: border-box !important;
}

.icon-hex .elementor-icon svg {
    width: 24px !important;
    height: 24px !important;
    fill: #0097B2 !important;
}

/* Icônes circulaires avec animation */
.icon-circle {
    background: white !important;
    border-radius: 50px !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    max-width: 40px !important;
    max-height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.3s ease !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;
}

.icon-circle .elementor-widget-container {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100% !important;
}

.icon-circle .elementor-icon {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 20px !important;
    height: 20px !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.icon-circle .elementor-icon svg {
    width: 16px !important;
    height: 16px !important;

}


/* Animation de rotation sur l'icône au survol du parent */
.carrousel-item:hover .icon-circle {
    transform: rotate(35deg);
}

.carrousel-item:hover .icon-circle .elementor-icon {
    transform: rotate(-5deg);
}

.carrousel-item:hover .icon-circle {
    fill: #fff !important;
    color: white;
}

/* =================================
   RESPONSIVE - CARROUSEL
   ================================= */

@media (max-width: 768px) {
    /* 2 items sur tablette */
    .carrousel {
        width: calc(2 * (100% / 2)) !important;
    }
    
    .carrousel-item {
        flex: 0 0 50% !important;
        width: 50% !important;
        min-width: 50% !important;
        max-width: 50% !important;
        padding: 0px !important;
    }
    
    .nav-arrow {
        width: 35px;
        height: 35px;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    /* 1 item sur mobile */
    .carrousel {
        width: 100% !important;
    }
    
    .carrousel-item {
        flex: 0 0 100% !important;
        width: 100% !important;
        min-width: 100% !important;
        max-width: 100% !important;
        padding: 0px !important;
    }
    
    .nav-arrow {
        width: 30px;
        height: 30px;
        padding: 20px !important;
        font-size: 12px;
    }
    
    /* Icônes plus petites sur mobile */
    .icon-hex .elementor-icon-wrapper {
        width: 50px;
        height: 50px;
    }
    
    .icon-hex .elementor-icon {
        width: 50px;
        height: 50px;
        padding: 12px;
    }
    
    .icon-hex .elementor-icon svg {
        width: 20px;
        height: 20px;
    }
}


/* Responsive pour les flèches */
@media (max-width: 768px) {
    .nav-arrow-inline {
        width: 35px;
        height: 35px;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .nav-arrow-inline {
        width: 30px;
        height: 30px;
        font-size: 12px;
    }
}

/* =================================
   ACCORDÉON ELEMENTOR GÉNÉRIQUE
   ================================= */

.elementor-element.e-con-full.e-flex.e-con.e-child p {
    margin: 0;
}

.expertises .elementor-widget-image {
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.expertises img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 30px 0 0 30px !important;
}

.elementor-widget-n-accordion .e-n-accordion-item[open] .e-n-accordion-item-title{
	border-radius:20px 20px 0px 0px !important;
}

.expertises{
	margin:0 !important;
	padding: 0 !important;
}


/* Supprimer les marges du conteneur de l'image */
.elementor-element.elementor-element-390bb35.e-con-full.e-flex.e-con.e-child {
    margin: 0px !important;
    padding: 0px !important;
}

.accordeon p{
	font-size:1.15rem !important;
}

.accordeon .e-n-accordion-item-title-text {
    color: white !important;
	font-size:1.3em !important;
}

.accordeon .e-n-accordion-item[open] .e-n-accordion-item-title-icon {
    color: white !important;
}


.accordeon .e-n-accordion-item[open] .e-n-accordion-item-title-icon {
    color: white !important;
}

.e-opened svg {
    fill: white !important;
}

.e-n-accordion-item-title:hover svg {
    fill: white !important;
}

/* =================================
   SECTIONS SPÉCIFIQUES
   ================================= */

.section-image img {
    -webkit-mask-position: left !important;
}

.image-container {
    padding: 0;
}

.image-container > .e-con-inner {
    padding: 0;
}

/* =================================
   CARROUSEL TÉMOIGNAGES BEE-I
   ================================= */

.testimonial-item::before {
    content: "Retours de besoins" !important; /* Changez le titre ici */
    position: absolute !important;
    top: 20px !important;
    left: 20px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: rgba(255, 255, 255, 0.7) !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    z-index: 3 !important;
}

.testimonial-item .elementor-widget-text-editor {
    align-self: flex-end !important;
    margin-bottom: auto !important;
    margin-top: 50px !important; /* Espace pour le titre */
}


.testimonial-text {
    flex: 0 0 40% !important;
    padding: 40px 0 !important;
}

.testimonial-text h2 {
    font-size: 2.8em !important;
    color: #0A2540 !important;
    line-height: 1.2 !important;
    margin-bottom: 30px !important;
    font-weight: 700 !important;
}

.testimonial-contenu {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
}

.testimonial-carousel {
    background: linear-gradient(135deg, #0A2540 0%, #0D2B48 100%) !important;
    border-radius: 30px !important;
    padding: 60px 50px !important;
    position: relative !important;
    overflow: hidden !important;
    min-height: 500px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.testimonial-carousel::before {
    content: '' !important;
    position: absolute !important;
    top: -300px !important;
    left: -150px !important;
    width: 700px !important;
    height: 700px !important;
    transform: rotate(15deg) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%) !important;
    z-index: 1 !important;
}

.testimonial-item {
    display: none !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    align-items: flex-end !important;
    width: 100% !important;
    position: relative !important;
    z-index: 2 !important;
    animation: fadeInUp 0.6s ease forwards;
    min-height: 300px !important;
    padding: 20px !important;
}

.testimonial-item.active {
    display: flex !important;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Texte en haut à droite, aligné à gauche, gras et plus gros */
.testimonial-item .elementor-widget-text-editor {
    align-self: flex-end !important;
    margin-bottom: auto !important;
}

.testimonial-item .elementor-widget-text-editor p {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: white !important;
    line-height: 1.4 !important;
    text-align: left !important;
    max-width: 100% !important;
    margin: 0 !important;
}

/* Bouton en bas, aligné à gauche par rapport au texte */
.testimonial-item .elementor-widget-button {
    align-self: flex-start !important;
    margin-top: auto !important;
    margin-right: 15% !important;
}

.testimonial-item .elementor-button {
    background: transparent !important;
    color: white !important;
    border: 2px solid white !important;
    border-radius: 25px !important;
    padding: 12px 24px !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    transition: all 0.3s ease !important;
}

.testimonial-item .elementor-button:hover {
    background: white !important;
    color: #0A2540 !important;
    transform: translateY(-2px) !important;
}

/* Navigation par points */
.nav-dots {
    display: flex !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-top: 20px !important;
}

.nav-dot {
    width: 12px !important;
    height: 12px !important;
    border-radius: 50% !important;
    background: rgba(0, 151, 178, 0.4) !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.nav-dot:hover {
    background: rgba(0, 151, 178, 0.7) !important;
    transform: scale(1.1) !important;
}

.nav-dot.active {
    background: #0097B2 !important;
    transform: scale(1.3) !important;
}

/* Responsive */
@media (max-width: 1200px) {
    .Testimonial {
        gap: 60px !important;
    }
	
	.testimonial-item .elementor-widget-text-editor {
        margin-top: 45px !important; /* Espace réduit sur mobile */
    }
    
    .Testimonial > .e-con-inner {
        gap: 60px !important;
    }
    
    .testimonial-text h2 {
        font-size: 2.5em !important;
    }
    
    .testimonial-item .elementor-widget-text-editor p {
        font-size: 22px !important;
        max-width: 90% !important;
    }
    
    .testimonial-item .elementor-widget-button {
        margin-right: 10% !important;
    }
}

@media (max-width: 768px) {
    .Testimonial {
        flex-direction: column !important;
        gap: 40px !important;
    }
    
    .Testimonial > .e-con-inner {
        flex-direction: column !important;
        gap: 40px !important;
    }
    
    .testimonial-text {
        flex: none !important;
        text-align: center !important;
    }
    
    .testimonial-text h2 {
        font-size: 2.2em !important;
    }
    
    .testimonial-carousel {
        padding: 40px 30px !important;
        min-height: 400px !important;
    }
    
    .testimonial-item {
        align-items: center !important;
        text-align: center !important;
        min-height: 250px !important;
    }
    
    .testimonial-item .elementor-widget-text-editor {
        align-self: center !important;
    }
    
    .testimonial-item .elementor-widget-text-editor p {
        font-size: 18px !important;
        text-align: center !important;
        max-width: 100% !important;
    }
    
    .testimonial-item .elementor-widget-button {
        align-self: center !important;
        margin-right: 0 !important;
    }
}
/* =================================
   Qui somme nous ?
   ================================= */

.elementor-element-3f5cb4e {
    margin: 0 !important;
    padding: 0 !important;
    height: 500px !important;
    max-height: 500px !important;
    overflow: hidden !important;
}

.elementor-element-3f5cb4e .elementor-widget-wrap {
    padding: 0 !important;
    margin: 0 !important;
    height: 500px !important;
}

.onglet-conteneur{
	padding:0!important;
}

/* Styles pour les widgets d'images dans les onglets - images grandes */
.e-n-tabs-content .elementor-widget-image {
    margin: 0 !important;
    padding: 0 !important;
    height: 500px !important;
}

.e-n-tabs-content .elementor-widget-image .elementor-widget-container {
    margin: 0 !important;
    padding: 0 !important;
    height: 500px !important;
    width: 100% !important;
}

.e-n-tabs-content .elementor-widget-image img {
    display: block !important;
    width: 100% !important;
    height: 500px !important;
    object-fit: cover !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Le reste de votre CSS reste identique */
.elementor-element-bf6fa69 .e-con-inner {
    padding: 0 !important;
    margin: 0 !important;
    height: 100% !important;
}

.e-n-tabs-heading {
    background: white !important;
    border-radius: 30px !important;
    padding: 6px !important;
    display: inline-flex !important;
    gap: 4px !important;
    margin-bottom: 20px !important;
    width: fit-content !important;
}

.e-n-tab-title {
    background: transparent !important;
    border-radius: 25px !important;
    padding: 12px 24px !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    transition: all 0.3s ease !important;
    color: #666 !important;
}

.e-n-tab-title:hover {
    background: #0a2540 !important;
    color: white !important;
}

.e-n-tab-title[aria-selected="true"] {
    background: #0097B2 !important;
    color: white !important;
}

@media (max-width: 768px) {
    .elementor-element-3f5cb4e {
        height: 300px !important;
    }
    
    .e-n-tabs-content .elementor-widget-image {
        height: 300px !important;
    }
    
    .e-n-tabs-content .elementor-widget-image .elementor-widget-container {
        height: 300px !important;
    }
    
    .e-n-tabs-content .elementor-widget-image img {
        height: 300px !important;
    }
}

/* =================================

    STRATEGIE

   ================================= */

/* =======================================================
   BULLE + POINÇON (utilise .bulle sur 8ffe8dd)
   ======================================================= */

.bulle-triangle{ 
	z-index: 2 !important;
	 margin-bottom: 28px !important;
}

.bulle-triangle .e-con-inner{
	padding:0px!important;
    left: 5% !important;
    POSITION: relative !important;
}

.bulle .e-con-inner{
	padding:0px!important;
}

.bulle-triangle img{ 
	fill:#0A2540!important;
	color:#0A2540!important;
}


/* bloc texte "glassmorphism" */
.elementor-element-c81ddd9{
  background: rgba(255,255,255,0.14) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(255,255,255,0.22) !important;
  border-radius: 20px !important;
  padding: clamp(24px,4vw,48px) !important;
  margin: clamp(12px,2vw,28px) !important;
}

/* chaque colonne : bordure gauche #F5F5F5 */
.chiffres-cle .e-child{
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 6px 8px 8px 14px !important;
  border-left: 3px solid #F5F5F5 !important;
}

/* pastille sous la valeur : #F5F5F5 */
.chiffres-cle .elementor-counter-number-wrapper{
  display: inline-flex !important;
  align-items: baseline !important;
  gap: 6px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  font-size: clamp(30px,6vw,56px) !important;
  padding: 12px 14px !important;
  background: #F5F5F5 !important;
  border-radius: 12px !important;
}

/* pré/suffixe : #0097B2 */
.chiffres-cle .elementor-counter-number-prefix,
.chiffres-cle .elementor-counter-number-suffix{
  color: #0097B2 !important;
  font-weight: 800 !important;
}

/* titre sous la valeur */
.chiffres-cle .elementor-counter-title{
  margin-top: 8px !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  opacity: .85 !important;
}


@media (max-width:1024px){
  .bulle::after{ left: 40px !important; }
}
@media (max-width:767px){
  .bulle::after{
    width: 30px !important; height: 30px !important; bottom: -15px !important; left: 26px !important;
  }
  .chiffres-cle .e-child{ margin-bottom: 18px !important; }
}


/* =======================================================
   Maitrise d'ouvrage
   ======================================================= */

/* Style des blocs individuels */
.blocs-grille .bloc-item {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 15px;
    padding: 25px 20px;
    backdrop-filter: blur(10px);
    transition: all 0.3s ease;
    text-align: center;
}

/* Texte dans les blocs */
.blocs-grille .bloc-item h3, .blocs-grille .bloc-item h2{
    color: white !important;
    font-size: 20px !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    margin: 0 !important;
}
/* =======================================================
   Section signature pédagogique - Flexbox avec hover et numérotation
   ======================================================= */

/* Container principal */
.elementor-element.elementor-element-32db12b {
  position: relative !important;
  min-height: 80vh !important;
  padding: 40px 20px !important;
}

/* Contour circulaire - plus éloigné */
.elementor-element.elementor-element-32db12b::before {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 420px !important;
  height: 420px !important;
  border: 3px solid #F5F5F5 !important;
  border-radius: 50% !important;
  z-index: 1 !important;
}

/* Rangées flexbox - alignement parfait avec hauteurs fixes */
.elementor-element.elementor-element-78edd63,
.elementor-element.elementor-element-1f278cd {
  display: flex !important;
  justify-content: space-between !important;
  align-items: stretch !important;
  width: 100% !important;
  gap: 40px !important;
  min-height: 140px !important;
}

/* Container vidéo centré avec hauteur fixe */
.elementor-element.elementor-element-d7017b8 {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 140px !important;
}

/* Ajustement de la taille de la vidéo */
.grid-video,
.elementor-element.elementor-element-46f8877 {
  max-width: 320px !important;
  max-height: 320px !important;
  width: 320px !important;
  height: 320px !important;
}

.grid-video video,
.elementor-element.elementor-element-46f8877 video,
.grid-video .elementor-video,
.elementor-element.elementor-element-46f8877 .elementor-video,
.grid-video .e-hosted-video,
.elementor-element.elementor-element-46f8877 .e-hosted-video {
  width: 320px !important;
  height: 320px !important;
  object-fit: cover !important;
  border-radius: 50% !important;
  overflow: hidden !important;
}

/* Styles des blocs de texte */
.grid-text-1,
.grid-text-2,
.grid-text-3,
.grid-text-4 {
  position: relative !important;
  background: #F5F5F5 !important;
  padding: 25px 20px !important;
  border-radius: 15px !important;
  box-shadow: none !important;
  transition: all 0.3s ease !important;
  z-index: 2 !important;
  max-width: 350px !important;
  min-height: 120px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Force le fond gris par défaut */
.elementor-element.elementor-element-0148710,
.elementor-element.elementor-element-a76c453,
.elementor-element.elementor-element-ebebd49,
.elementor-element.elementor-element-b9bbc30 {
  background: #F5F5F5 !important;
}

/* Alignement du texte */
.grid-text-1 { text-align: right !important; }
.grid-text-2 { text-align: left !important; }
.grid-text-3 { text-align: left !important; }
.grid-text-4 { text-align: right !important; }

/* Styles des titres */
.grid-text-1 .elementor-heading-title,
.grid-text-2 .elementor-heading-title,
.grid-text-3 .elementor-heading-title,
.grid-text-4 .elementor-heading-title,
.grid-text-1 h3,
.grid-text-2 h3,
.grid-text-3 h3,
.grid-text-4 h3 {
  font-weight: normal !important;
  font-size: 1.2em !important;
  color: #1a365d !important;
  margin-bottom: 10px !important;
  line-height: 1.3 !important;
  transition: color 0.3s ease !important;
}

/* Effets hover - Desktop uniquement */
@media (min-width: 769px) {
  .grid-text-1:hover,
  .grid-text-2:hover,
  .grid-text-3:hover,
  .grid-text-4:hover {
    background: #0097b2 !important;
  }
  
  .grid-text-1:hover .elementor-heading-title,
  .grid-text-2:hover .elementor-heading-title,
  .grid-text-3:hover .elementor-heading-title,
  .grid-text-4:hover .elementor-heading-title,
  .grid-text-1:hover h3,
  .grid-text-2:hover h3,
  .grid-text-3:hover h3,
  .grid-text-4:hover h3 {
    color: white !important;
  }
}

/* Numérotation - Pastilles bleues */
.grid-text-1::after,
.grid-text-2::after,
.grid-text-3::after,
.grid-text-4::after {
  content: '';
  position: absolute !important;
  width: 50px !important;
  height: 50px !important;
  background: #0097b2 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: white !important;
  font-weight: bold !important;
  font-size: 1.2em !important;
  z-index: 3 !important;
}

/* Position des numéros */
.grid-text-1::after {
  content: '1' !important;
  top: -25px !important;
  right: -45px !important;
}

.grid-text-2::after {
  content: '2' !important;
  top: -25px !important;
  left: -45px !important;
}

.grid-text-3::after {
  content: '3' !important;
  top: -25px !important;
  left: -45px !important;
}

.grid-text-4::after {
  content: '4' !important;
  top: -25px !important;
  right: -45px !important;
}

/* RESPONSIVE */

/* Tablettes */
@media (max-width: 1024px) {
  .elementor-element.elementor-element-32db12b {
    min-height: 70vh !important;
    padding: 30px 15px !important;
  }
  
  .elementor-element.elementor-element-32db12b::before {
    width: 280px !important;
    height: 280px !important;
  }
  
  .elementor-element.elementor-element-78edd63,
  .elementor-element.elementor-element-1f278cd {
    gap: 20px !important;
  }
  
  .grid-text-1,
  .grid-text-2,
  .grid-text-3,
  .grid-text-4 {
    max-width: 280px !important;
    text-align: center !important;
    min-height: 100px !important;
  }
  
  /* Pastilles plus petites sur tablette */
  .grid-text-1::after,
  .grid-text-2::after,
  .grid-text-3::after,
  .grid-text-4::after {
    width: 40px !important;
    height: 40px !important;
    font-size: 1em !important;
  }
  
  .grid-text-1::after {
    top: -20px !important;
    right: -35px !important;
  }
  
  .grid-text-2::after {
    top: -20px !important;
    left: -35px !important;
  }
  
  .grid-text-3::after {
    top: -20px !important;
    left: -35px !important;
  }
  
  .grid-text-4::after {
    top: -20px !important;
    right: -35px !important;
  }
}

/* Mobile */
@media (max-width: 768px) {
  .elementor-element.elementor-element-32db12b {
    min-height: auto !important;
    padding: 20px 10px !important;
  }
  
  .elementor-element.elementor-element-32db12b::before {
    display: none !important;
  }
  
  .elementor-element.elementor-element-78edd63,
  .elementor-element.elementor-element-1f278cd {
    flex-direction: column !important;
    gap: 30px !important;
  }
  
  .grid-text-1,
  .grid-text-2,
  .grid-text-3,
  .grid-text-4 {
    max-width: 100% !important;
    text-align: center !important;
    min-height: 80px !important;
  }
  
  .grid-text-1 .elementor-heading-title,
  .grid-text-2 .elementor-heading-title,
  .grid-text-3 .elementor-heading-title,
  .grid-text-4 .elementor-heading-title {
    font-size: 1.1em !important;
  }
  
  /* Pastilles repositionnées sur mobile */
  .grid-text-1::after,
  .grid-text-2::after,
  .grid-text-3::after,
  .grid-text-4::after {
    top: -20px !important;
    right: -20px !important;
    left: auto !important;
    width: 35px !important;
    height: 35px !important;
    font-size: 0.9em !important;
  }
}

/* Très petit mobile */
@media (max-width: 480px) {
  .elementor-element.elementor-element-32db12b {
    padding: 15px 8px !important;
  }
  
  .grid-text-1::after,
  .grid-text-2::after,
  .grid-text-3::after,
  .grid-text-4::after {
    width: 30px !important;
    height: 30px !important;
    font-size: 0.8em !important;
  }
}