/*
Theme Name: Astra Child
Description: Child theme for Astra. You can now safely customize it and not risk losing your customizations.
Author: WPTurbo
Author URI: https://wpturbo.dev
Template: astra
Version: 1.0
Text Domain: astra-child
*/

.filters {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.filters button {
    background: #B0CADF;
    border: none;
    padding: 10px 10px;
    cursor: pointer;
    border-radius: 24px;
    transition: 0.3s;
    margin: 5px 5px 30px;
    color: #0D3D63;
}

.filters .filter-sector {
    background-color: transparent;
    color: #E8327C;
    border: 1px solid #ff4081;
    border-radius: 0;
}

.one-element img {
    border-radius: 12px;
}

.contenu {
    margin-top: 50px;
}

.info-block p {
    color: #ffffff;
}

.info-block h2 {
    color: #ffffff;
}

.container-actions {
    padding-top: 4.538rem; /* 72.6px */;
}

.container-actions .trait {
    margin-top: 0;
}

.container-actions h1 {
    text-align: center;
}

.trait {
    width: 14px;
    height: 2px;
    background-color: #e91e63;
    margin: 15px auto;
}

.nos-bureaux {
    text-align: center;
}


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

.slide-bureaux {
    position: relative;
    width: 100%;
    margin-bottom: 80px;
}

.forme-rose {
    position: absolute;
    top: -65px;
    right: 50px;
    width: 180px;
    height: auto;
    z-index: 10;
}


.slides li {
    max-width: 33%;
    padding: 10px;
}

.slides li h4 {
    margin-top: 18px;
    margin-bottom: 10px;
}

.slides li p {
    margin: 0;
    line-height: 1.2em;
}

.slides li a {
    /*    color: #d81b60;
        text-decoration: underline;
        margin-top: 15px;
        display: inline-block;
        font-size: 0.75rem;
        font-weight: 600;*/
}

.career-block {
    display: flex;
    align-items: center;
    width: 100%;

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

.title-career h1, .title-career p {
    color: #FFFFFF;
}

.why-join-kea {
    width: 50%;
    margin: 0 auto;
    text-align: center;
}

.job-offer {
    text-align: center;
}

.container-career {
    background-color: #F4FAFF;
}

.PBM-block {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.PBM-block .contenu-block {
    padding: 9.15rem 0 14.7rem 0; /* 146.4px 0 235.2px 0 */
}

.contenu-block h1 {
    color: #FFFFFF;
}

.contenu-block p {
    color: #FFFFFF;
}

.PBM-block .contenu-block h1 {
    margin-top: 0;
}

.PBM-block .contenu-block p {
    margin-bottom: 0;
    max-width: 37.4rem; /* 599.2px */
}

.pbm-action {
    text-align: center;
}

.pbm-action h2 {
    margin-bottom: 2.7rem; /* 43.2px */
}

.pbm-image {
    margin-top: 2.7rem; /* 43.2px */
    text-align: center;
}

.pbm-image img {
    display: inline-block;
    max-height: 27.4rem; /* 438.4px */
}

.contenu-pbm {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    list-style: none;
    margin: 0;
    row-gap: 2.7rem; /* 43.2px */
    column-gap: 2.7rem; /* 43.2px */
    margin-top: 2.7rem; /* 43.2px */;
    padding-bottom: 4.538rem; /* 72.6px */
}

.contenu-pbm__title {
    margin-top: 0;
    margin-bottom: 1rem; /* 16px */
    font-size: 1.2rem; /* 19.2px */
    line-height: 1.4rem; /* 22.4px */
}

.list-pbm ul {
    margin-bottom: 0;
    margin-left: 1.5rem; /* 24px */
}

.contenu-pbm__item {
    max-width: 22.15rem; /* 354.4px */
}

.contenu-pbm h3 {
    color: #E8327C;

}

.slide-pbm {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.slide-pbm .contenu-slide {
    color: #FFFFFF;
    padding-top: 9rem; /* 144px */
    padding-bottom: 10.65rem; /* 171.6px */
    text-align: center;
    max-width: 912px;
}

.contenu-slide .pbm-slide__title > * {
    color: #FFFFFF;
    font-family: "Inter", sans-serif;
    font-weight: 300;
    font-style: normal;
    font-size: 1.2rem; /* 19.2px */
    line-height: 1.4rem; /* 22.4px */
    margin-bottom: 0;
}

.contenu-slide .pbm-slide__title {
    margin-bottom: 2.1rem; /* 33.6px */
}

.pbm-slide__sub-title > *:last-child {
    margin-bottom: 0;
}

.container-pbm {
    background-color: #F4FAFF;
}

.profile-photo {
    width: 250px;
    height: 250px;
    margin-right: 1.55rem;
    border-radius: 180px;
    overflow: hidden;
    margin-top: -70px;
    margin-bottom: -70px;
    border: 10px solid #fff;
}

.profile-photo img {
    transform: scale(1.4);
    transform-origin: top;
}

.profile-info h2 {
    font-family: 'Playfair Display', serif;
    font-style: normal;
    font-weight: 500;
    margin-bottom: 10px;
    font-size: 1.168rem; /* 18.7x */
    line-height: 1.428rem; /* 22.8px */
    margin-top: 0;
}

.single-team-links a.rose {
    margin-top: 0;
    font-size: 0.7rem; /* 11.2px */
    line-height: 0.9rem; /* 14.4px */
}

.team-role {
    font-weight: bold;
    margin-top: 8px;
    font-size: 0.7rem; /* 11.2px */
    line-height: 0.9rem;
}

.single-team-links {
    color: #E8327C;
    text-decoration: underline;
    display: flex;
    text-transform: uppercase;
    margin-top: 8px;
    gap: 1.25rem; /* 20px */
    justify-content: start;
    flex-wrap: wrap;
    row-gap: 8px;
}

.single-team-links a {
    color: #E8327C;
}

.info-team__title {
    font-size: 1.2rem; /* 19.2px */
    line-height: 1.4rem; /* 22.4px */
    margin-top: 2.2rem; /* 35.2px */
    margin-bottom: 1rem; /* 16px */
}

.single-team-text p {
    line-height: 1.3rem; /* 20.8px */
}

.info-team h4 {
    margin-top: 30px;
    margin-bottom: 15px;
}

.info-team p {
    margin: 0;
}

.info-team b {
    font-weight: 600;
}

.title-transfers {
    text-align: center;
}

.slide-discover-kea {
    position: relative;
    background-color: #D5DFE8;
}

.slide-discover-kea .bg-letters-top-discover {
    margin-left: 100px;
    width: 52%;
    right: 0;
    position: absolute;
}

.slide-discover-kea .bg-letters-bot-discover {
    position: absolute;
    bottom: -1px;
    left: 2%;
    transform-origin: bottom;
    width: 25%;
}

.title-new-article {
    text-align: center;
}

.title-slide-discover .trait {
    margin-top: 15px;
    margin-left: 0;
}

.title-slide-discover a {
    color: #E8327C;
    text-decoration: underline;
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
}

.slide_container {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    padding-bottom: 70px;
}

.logo-discover img {
    width: 35px;
}

.contenu-video {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    cursor: pointer;
}

.contenu-video img {
    max-width: 702.4px;
    height: auto;
    border-radius: 8px;
}

.icon-vid {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.icon-vid img {
    width: 45px;
}

.slide {
    padding: 40px;
    display: flex;
    justify-content: center;
}

.flex-container {
    display: flex;
    flex-wrap: wrap;
    max-width: 392.8px;
    gap: 12px;
}

.box.box1 {
    width: calc(62% - 6px);
}

.box.box2 {
    width: calc(38% - 6px);
}

.box.box3 {
    width: calc(50% - 6px);
}

.box.box4 {
    width: calc(50% - 6px);
}

.box .trait {
    margin: 0 0 0 auto;
}

.flex-container .forme-rose {
    position: static;
}

.full {
    position: relative;
}

.box {
    text-align: right;
    border-radius: 12px;
    background-color: #fff;
    padding: 25px 18px 20px;
}

.box.full {
    display: flex;
    justify-content: space-between;
    position: relative;
    z-index: 110;
    border-radius: 12px 12px 12px 0;
}

.main-text {
    font-size: 2.2rem;
    color: #e5006e;
    font-family: 'Playfair Display', serif;
}

.main-text .number {
    font-size: 2.8rem;
    font-weight: 600;
}

.sub-text {
    margin: 10px 0;
}

.sub-text b {
    font-family: 'IvyPresto Display', sans-serif;
    font-weight: 600;
    font-style: italic;
}

.expertise-job {
    text-align: center;
}

.sector-expertise-title {
    text-align: center;
    margin-top: 50px;
}

.block-left, .block-right {
    width: 50%;
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
}

.text-info {
    color: white;
    padding: 30px;
}

.text-info h2 {
    color: white;
    font-size: 1.65rem;
    line-height: 1em;
    margin-bottom: 12px;
}

.text-info a {
    color: white;
    text-decoration: underline;
}

.text-info .trait {
    margin: 0;
    background-color: white;
}

.section-info {
    height: 640px;
    display: flex;
}

.block-right .text-info {
    margin-top: auto;
    max-width: 280px;
    margin-left: 22%;
    margin-bottom: 8%;
}

.block-left .text-info {
    margin-top: 2%;
    max-width: 330px;
    margin-left: 22%;
    position: relative;
}

.bg-letters-info .bg-letters-topp {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 64%;
    transform-origin: top;
}

.bg-letters-info .bg-letters-bott {
    position: absolute;
    width: 82%;
    right: 0;
    transform-origin: bottom;
}

.international-hero__overlay {
    height: 100%;
    display: flex;
    align-items: center;
}

.international-hero__container h1 {
    color: white;
}

.international-hero p {
    line-height: 1.6;
    /*max-width: 600px;*/
}

.international-hero.innovation p {
    max-width: inherit;
}

.kea-worldmap-section {
    text-align: center;
}

.img-maps-international {
    text-align: center;
}

.wrapper-international {
    background-color: #F4FAFF;
}

.worldmap-legend {
    display: flex;
    margin-top: 20px;
}

.slides_world_legend {
    display: flex;
    gap: 6%;
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left;
}

.slides_world_legend li {
    display: flex;
    gap: 10px;
    width: 25%;
    margin-bottom: 12px;
}

.legend-dot {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: inline-block;

}

.clients-worldwide {
    text-align: center;
    margin: 0 auto;
    max-width: 780px;
}

.col-withe > div {
    background-color: #fff;
    padding: 20px;
}

span.legend-text {
    flex: 1;
}

.legend-item {
    margin-top: 35px;
    margin-bottom: 25px;
}

.worldmap-intro p {
    text-align: justify;
}

.page-template-page-international .expertise-support .bg-letters__top {
    width: auto;
    height: 170px;
    left: 0;
    top: 0;
}

.texte_clients p {
    text-align: justify;
}

.title-nos-societes {
    text-align: center;
    margin-bottom: 30px;
}

.societes-wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px;
    max-width: 1000px;
    margin: 0 auto;
}

.societe {
    width: calc(50% - 20px);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
    background: #F4FAFF;
    padding: 20px 20px;
    border-radius: 12px;
    transition: box-shadow 0.3s ease;
}

.societe .logo, .societe .text {
    width: calc(50% - 10px);
}

.societe:hover {
    box-shadow: 0 0 25px rgba(0, 0, 0, 0.08);
}

.societe h3 {
    font-size: 18px;
    font-weight: bold;
    margin: 10px 0;
}

.societe p {
    font-size: 14px;
    color: #444;
}

.expertis-reseau {
    text-align: center;
    margin-top: 50px;
    margin-bottom: 80px;
}

.expertis-reseau .description {
    max-width: 600px;
    margin: 0 auto;
}


.world_map_client {
    background-color: #F4FAFF;
    text-align: center;
}

.clients-worldwide__container h2 {
    text-align: center;
}

.clients-worldwide__content {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: space-between;
}

.clients-worldwide__column {
    flex: 1 1 48%;
    font-size: 16px;
    line-height: 1.8;
}

.auteur-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 2em;
    align-items: flex-start;
}

.auteur-card {
    display: flex;
    align-items: center;
    background: #F4FAFF;
    border-radius: 40px;
}

.auteur-card:nth-child(3) {
    margin-left: 0;
}

.auteur-nom {
    font-weight: bold;
    font-size: 1.1em;
    margin-bottom: 0.2em;
}

.auteur-role,
.auteur-formation,
.auteur-expertise {
    font-size: 0.9em;
    margin: 0;
}

/* Scroll container */
.expertises-scroll-container {
    margin-top: 40px;
    padding-bottom: 20px;
}

.expertises-scroll-track {
    display: inline-flex;
    gap: 30px;
    padding: 0 20px;
}

.expertise-img-container {
    position: relative;
    display: inline-block;
}

.expertise-img {
    width: auto;
    max-width: 100%;
    height: auto;
    display: block;
}

/* Forme rose positionnée sur la 2ème image */
.forme-rose-deco {
    position: absolute;
    top: -100px;
    left: -100px;
    z-index: 2;
    pointer-events: none;
}

.en-savoir-plus {
    text-transform: uppercase;
    display: inline-block;
}

.image-expertise-container {
    position: relative;
    overflow: hidden;
}

.image-expertise {
    display: block;
    width: 100%;
    height: auto;
    transition: all 0.3s ease;
}

.texte-survol {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0, 0, 0, 0.3);
    color: white;
    padding: 10px;
    text-align: center;
    opacity: 0;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.image-expertise-container:hover .texte-survol {
    opacity: 1;
}

.image-expertise-container:hover .image-expertise {
    filter: blur(5px);
}

.title-slide-discover {
    padding-top: 35px;
    margin-bottom: 30px;
}

.title-slide-discover p {
    max-width: 507px;
    font-size: 1.2rem;
    line-height: 1.2em;
}

.title-slide-discover h3 {
    margin-bottom: 5px;
    font-size: 1.7rem;
}

.global-box {
    position: relative;
    width: calc(100% - 70px);
}

.global-box.svg-bubble::after {
    content: "";
    top: -21px;
    right: -72px;
    position: absolute;
    width: 102px;
    height: 68px;
}

.last-box {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
}

.global-box .sub-text {
    margin-top: -8px;
}

.slide-video {
    flex: 1;
    display: flex;
    justify-content: flex-end;
    align-items: flex-start;
}

.main-text .number sup {
    font-size: 1.5rem;
    top: -14px;
    font-weight: 400;
}

.video-responsive {
    position: relative;
    padding-bottom: 56.25%; /* Ratio 16:9 */
    height: 0;
    overflow: hidden;
    max-width: 100%;
    background: #000;
}

.video-responsive iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.expertise-grid {
    margin-top: 80px;
}

.expertise-grid .description {
    max-width: 520px;
    margin: auto;
}

.slide-expertise-job .carrousel-swiper,
.liste-expertises-sectorielles .carrousel-swiper2 {
    padding: 0 22px;
}

.slide-expertise-job .swiper-button-prev,
.liste-expertises-sectorielles .swiper-button-prev {
    left: 0;
}

.slide-expertise-job .swiper-button-next,
.liste-expertises-sectorielles .swiper-button-next {
    right: 0;
}

.slide-expertise-job .swiper-button-next:after,
.slide-expertise-job .swiper-button-prev:after,
.liste-expertises-sectorielles .swiper-button-next:after,
.liste-expertises-sectorielles .swiper-button-prev:after {
    font-size: 26px;
}

.slide-expertise-job .swiper-button-next,
.slide-expertise-job .swiper-button-prev,
.liste-expertises-sectorielles .swiper-button-next,
.liste-expertises-sectorielles .swiper-button-prev {
    color: #fc00ff;
    top: 40%;
    width: 15px;
}

.expertises-sectorielles-section {
    margin-top: 20px;
    margin-bottom: 35px;
}

.expertises-sectorielles-section .description {
    max-width: 550px;
    margin: auto;
    padding: 0 15px;
}

.nos-societes {
    margin-top: 50px;
}

.mission-histoiric__container {
    text-align: center;
    color: white;
}

.mission-histoiric__container h2 {
    color: white;
}

.bloc-promesse {

    background: linear-gradient(90deg, rgba(176, 202, 223, 0.3) 70%, rgba(232, 50, 124, 0.1) 100%);
    border-radius: 16px;
    padding: 40px;
    max-width: 857.6px;
    margin: 80px auto;
    position: relative;
}

.bloc-promesse .contenu-texte p {
    font-weight: 400;
}

.forme-rose img {
    width: 100%;
    height: auto;
    display: block;
}

.contenu-texte {
    width: 50%;
    position: relative;
    z-index: 5;
}

.lettre-k {
    position: absolute;
    z-index: 1;
    pointer-events: none;
    top: clamp(-8.5625rem, 8.0273rem + -21.4062vw, 0rem);
    right: clamp(-7.8125rem, 9.3269rem + -22.1154vw, -0.625rem); /* https://utopia.fyi/clamp/calculator?a=720,1240,-10%E2%80%94-125 */
}


.lettre-k img {
    height: clamp(15.625rem, 6.9033rem + 43.6087vw, 40.7rem);

}


@media screen and (max-width: 700px) {
    .lettre-k {
        right: 50px;
        top: 10px;
    }

    .lettre-k img {
        height: 100px;
    }

    .contenu-texte {
        width: 100%;
    }
}

.k-gauche,
.k-droite {
    position: absolute;
    bottom: 0;
    height: 100%;
}


.k-droite {
    right: -80px;
    z-index: 1;
}

.k-gauche {
    right: 140px;
    z-index: 2;
}

.mission-historique {
    padding: 80px 20px;
    background-color: #fdfdfd;
    position: relative;
    overflow: hidden;
}

.forme-rose {
    position: absolute;
    top: -40px;
    left: 50px;
    z-index: 0;
}

.mission-historique {
    display: flex;
    justify-content: space-between;
    gap: 60px;
    z-index: 1;
    align-items: center;
    flex-wrap: wrap;
}

.mission-historique_image {
    flex: 1 1 45%;
    max-width: 392px;
    position: relative;
}

.mission-historique_image .mission-historique_image__img {
    width: 100%;
    border-radius: 8px;
    display: block;
}

.mission-historique_image .forme-rose {
    position: absolute;
    right: -120px;
    top: -30px;
    left: unset;
    z-index: 1;
    width: 192.8px;
}

@media screen and (max-width: 750px) {
    .mission-historique {
        flex-direction: column-reverse;
        gap: 20px;
    }
}

.mission-historique__texte {
    flex: 1 1 45%;
    max-width: 496px;
}

section.notre-metier h2 {
    text-align: center;
}

section.notre-metier h2 {
    font-size: 32px;
    font-weight: 600;
    margin-bottom: 20px;
}

section.notre-metier .intro, section.notre-metier .paragraphe-final, .entreprise-mission .container {
    font-size: 18px;
    max-width: 804px;
    margin: 0 auto 72px auto;
}

.metier-blocs {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    position: relative;
    margin-bottom: 30px;
    margin-top: 60px;
}

.metier-blocs .bloc {
    position: relative;
    width: 30%;
    z-index: 2;
    min-width: 250px;
    padding: 50.4px 30.4px;
    background-color: #F4FAFF;
    border-radius: 24px;
}

.metier-blocs img {
    position: absolute;
    left: 58%;
    z-index: 1;
}

.paragraphe-final {
    font-size: 17px;
    font-style: italic;
    max-width: 700px;
    margin: 0 auto;
}

.entreprise-mission h2 {
    text-align: center;
}

.timeline {
    display: flex;
}

.timeline-section {
    padding: 60px 20px;
    background-color: #F4FAFF;
    position: relative;
}

.timeline-container {
    margin: 0 auto;
}

.timeline-items {
    display: flex;
    justify-content: space-between;
    position: relative;
    z-index: 2;
}

.timeline-item {
    width: 23%;
    position: relative;
}

.timeline-dot {
    background-color: #e6007e;
    border-radius: 50%;
    position: relative;
    z-index: 3;
}

.timeline-icon {
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
}

.circle-icon {
    width: 34px;
    height: 34px;
    background-color: #007bff;
    color: white;
    font-weight: bold;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

.timeline-points {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 20px;
}

.timeline-section h2 {
    text-align: center;
    margin-bottom: 20px;
}

.timeline-content h4 {
    font-family: "Inter", sans-serif;
    font-weight: 300;
    font-style: normal;
}

.section-service-direction-generale {
    margin-top: 72px;
    margin-bottom: 72px;
}

.container-service-direction-generale {
    max-width: 1200px;
    margin: 0 auto;
}

.titre-section-service-direction-generale {
    text-align: center;
}

.blocs-wrapper-service-direction-generale {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.bloc-item-service-direction-generale {
    display: flex;
    align-items: stretch;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}

.bloc-img-service-direction-generale {
    width: 100%;
    max-width: 304px;
}

.bloc-img-service-direction-generale img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 4px;
}

.bloc-content-service-direction-generale {
    flex: 1;
    min-width: 300px;
    background-color: var(--light-blue);
    padding: 65.6px 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-radius: 10px;
}

.bloc-item-service-direction-generale.bloc-inverse-service-direction-generale {
    flex-direction: row-reverse;
}

.bloc-content-service-direction-generale .bloc-titre-service-direction-generale {
    margin-top: 0;
    margin-bottom: 8px;
    font-size: 19.2px;
    line-height: 22.4px;
}

.bloc-texte-service-direction-generale {
    font-weight: 400;
}

.bloc-texte-service-direction-generale p {
    line-height: 17.6px;
}

.bloc-content-service-direction-generale .bloc-texte-service-direction-generale p:last-child,
.bloc-content-service-direction-generale .bloc-texte-service-direction-generale ul:last-child {
    margin-bottom: 0;
}


.section-research_innovation {
    padding: 60px 20px;
    background-color: #F4FAFF;
}

.section-research_innovation h2 {
    text-align: center;
    margin-bottom: 20px;
}

.carte-research_innovation {
    justify-content: center;
    margin-top: 40px;
    margin-bottom: 30px;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;

}

.card-innovation {
    width: 100%;
    max-width: 350px;
    flex: 1 1 300px;
    position: relative;
}

.card-img {
    position: relative;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    display: flex;
    align-items: flex-end;
}

.card-overlay {
    color: white;
    padding: 15px;
    width: 100%;
    transition: all 0.3s ease;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}

.card-overlay h3 {
    margin: 0 0 8px;
    font-size: 1.2rem;
    color: white;
}

.card-overlay p {
    font-size: 1rem;
    line-height: 1.2em;
    text-overflow: ellipsis;
    overflow: hidden;
    width: 100%;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.btn-overlay {
    display: inline-block;
    padding: 6px 12px;
    color: #E8327C;
    text-transform: uppercase;
}

.btn-link-innovation {
    color: #E8327C;
    font-weight: 600;
    text-decoration: underline;
    text-transform: uppercase;
    text-align: center;
}


.academic-research {
    padding: 60px 20px;
}

.academic-research h2 {
    text-align: center;
}

.academic-research .intro {

    margin: 0 auto 40px;
}

.research-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 920px;
    margin: 0 auto 20px;
}

.bottom-text {
    text-align: center;
}

.research-card {
    padding: 10px;
    text-align: center;
    width: 20%;
    min-width: 180px;
}

.logos {
    display: flex;
    flex-flow: wrap;
    justify-content: center;
    gap: 25px;
    margin-top: 20px;
}

.logos > div {
    position: relative;
    box-shadow: 0 0 2px 0 #00000040;
    padding: 56px 20px;
    text-align: center;
    border-radius: 12px;
    width: 380px;
}

.logos .overlay-content p {
    font-size: 0.75rem;
    margin-bottom: 5px;
    line-height: 1.3em;
}

.rayonner-logos .overlay-content p {
    font-size: 0.75rem;
    margin-bottom: 5px;
    line-height: 1.2em;
}

.logos .overlay-content .read-more, .rayonner-logos .overlay-content .read-more {
    font-size: 0.75rem;
}

.rayonner-logos .overlay {
    padding: 5px;
}

.logos > div:hover .overlay {
    opacity: 1;
}

.logos img {
    max-height: 75px;
    transition: all 0.3s;
}

.logos > div:hover img {
    filter: blur(5px);
}

.image-wrapper {
    position: relative;
}

.overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(255, 255, 255, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    opacity: 0;
    transition: opacity 0.3s ease;
    border-radius: 100px;
    padding: 20px;
}


.image-wrapper:hover img {
    filter: blur(5px) brightness(1.2);
}

.image-wrapper:hover .overlay {
    opacity: 1;
}

.overlay-content h3.nom {
    font-size: 0.8rem;
    color: #E8327C;
    font-family: 'Inter', sans-serif;
    font-style: normal;
    font-weight: 400;
    text-decoration: underline;
    margin-bottom: 10px;
}

.overlay-content .fonction {
    margin-bottom: 5px;
    color: inherit;
    font-weight: 600;
}

.overlay-content .description {
    font-weight: 400;
    font-size: 0.75rem;
    margin-bottom: 10px;
}

.image-wrapper .overlay {
    padding: 10px;
}

.parcours {
    padding: 60px 20px 0;
    background-color: #F4FAFF;
    margin-bottom: 60px;
    overflow-x: clip;
}


.container + + {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.dimension-section {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px;
    max-width: 1140px;
    margin: 0 auto 0;
}

@media screen and (max-width: 700px) {
    .dimension-section {
        flex-direction: column;
    }
}

.dimension-bloc {
    position: relative;
    flex: 1 1 30%;
    background-color: white;
    padding: 20px 20px 2px;
    border-radius: 12px;

}

.dimension-numero {
    position: absolute;
    bottom: 45px;
    right: 10px;
    font-size: 100px;
    font-weight: bold;
    color: #ec008c;
    opacity: 0.2;
    font-family: 'IvyPresto Display', sans-serif;
}

.dimension-contenu span {
    font-style: italic;
    color: #ec008c;
}

.texte-etaps {
    margin-top: 40px;
    text-align: center;
}

.intro-parcours {
    text-align: center;
}

.international-hero {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    color: white;
    min-height: 346px;
    display: flex;
    align-items: center;
    padding-top: 30px;
    padding-bottom: 30px;
}

.contenu-expertise h4 {
    /*min-height: 50px;*/
}

.slide-expertise-job .swiper-wrapper,
.liste-expertises-sectorielles .swiper-wrapper {
    align-items: stretch;
}

.slide-expertise-job .swiper-slide,
.liste-expertises-sectorielles .swiper-slide {
    height: auto;
}

.slide-expertise-job .swiper-wrapper .en-savoir-plus,
.liste-expertises-sectorielles .swiper-wrapper .en-savoir-plus {
    margin-top: auto;
}

.rayonner-intro, .temps-avance-intro {
    text-align: center;
}

.rayonner-logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 25px;
    max-width: 850px;
    margin: 30px auto 35px;
}

.rayonner-logos .logo-item {
    position: relative;
    width: calc(33.333% - 25px);
    min-width: 250px;
    box-shadow: 0 0 2px 0 #00000040;
    padding: 20px 20px;
    text-align: center;
    border-radius: 12px;
}

.rayonner-logos .logo-item img {
    transition: opacity 0.3s ease;
}

.rayonner-logos .logo-item:hover img {
    filter: blur(5px);
}

.rayonner-logos .logo-item:hover .overlay {
    opacity: 1;
}

.avance-item {
    background-color: #F4FAFF;
    /* border-radius: 12px; */
    padding: 10px 3%;
    margin-bottom: 35px;
}

.avance-item h3 {
    font-size: 1.2rem;
    margin-top: 2px;
    margin-bottom: 10px;
}

.avance-item .read-more {
    text-transform: uppercase;
    font-size: 0.75rem;
    font-weight: 400;
}

.section-research_innovation .read-more {
    text-transform: uppercase;
    font-size: 0.75rem;
    font-weight: 400;
}

.card-innovation .texte-survol {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    padding: 15px;
    color: #fff;
}

.card-innovation .texte-survol h3 {
    color: #fff;
}

.card-innovation:hover .texte-survol {
    opacity: 1;
}

.card-innovation:hover .card-overlay {
    opacity: 0;
}

.card-innovation:hover img {
    filter: blur(5px);
}

.timeline-content-carriere p {
    text-align: justify;
}

.dimension-contenu {
    text-align: justify;
}

.dimension-contenu em {
    font-style: italic;
    color: #ec008c;
    font-family: 'IvyPresto Display', sans-serif;
}

.live-consultant {
    margin-bottom: 30px;
}


.contenu-mission .support-insights__item {
    text-align: center;
}


.intro-mission h3 {
    text-align: center;
}


.intro-affaires h3 {
    text-align: center;
}


.affaires-blocs {
    max-width: 1100px;
    margin: 0 auto;
    padding: 40px 20px;
}

.affaires-ligne {
    display: flex;
    justify-content: center;
    gap: 15px;
    flex-wrap: wrap;
    margin-bottom: 15px;
}

.bloc {
    background-color: #F4FAFF;
    padding: 20px;
    border-radius: 24px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 160px;

}

.bloc-small {
    flex: 0 1 calc(30% - 20px);
}

.bloc-large {
    flex: 0 1 calc(30% - 40px);
}


@media (max-width: 768px) {
    .bloc-small,
    .bloc-large {
        flex: 1 1 100%;
    }
}


.intro-engagement h3 {
    text-align: center;
}

.affaires-logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
    padding: 20px 0;
}

.logo-item img {
    height: 80px;
    width: auto;

}


.certifications {
    padding: 60px 20px;
}

.intro-certification {
    text-align: center;
}

.certifications h2 {
    text-align: center;
    font-size: 2em;
    margin-bottom: 40px;
}

.certifications-list {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.certification-item {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 30px;
    flex-wrap: wrap;
}

.certification-item.normal {
    flex-direction: row;
}

.certification-item.reverse {
    flex-direction: row-reverse;
}

.certification-image {
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    padding: 20px;
    width: 280px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.certification-image img {
    max-width: 100%;
    height: auto;
    display: block;
}

.certification-text {
    background-color: #F4FAFF;
    padding: 20px;
    border-radius: 10px;
    font-size: 0.95em;
    color: #333;
    line-height: 1.6;
    flex: 1;
    text-align: left;
    display: flex;
    align-items: center;
}

.ethique-affaires .support__container-affaires .affaires-logos {
    margin-top: 0;
    margin-bottom: 0;
}

section.engagement {
    margin-top: 40px;
}
.intro-contibutions h3 {
    text-align: center;
}
.intro-signalement h3 {
    text-align: center;
}















































