

/*--------------------------------------------------------------------- File Name: style.css ---------------------------------------------------------------------*/


/*--------------------------------------------------------------------- import Fonts ---------------------------------------------------------------------*/

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@300;400;500;600;700&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Raleway:wght@100;400;600;700;900&family=Baloo+Chettan+2&family=Open+Sans:ital,wght@0,400;0,600;0,700;0,800;1,600;1,700&display=swap');

/*****---------------------------------------- 1) font-family: 'Rajdhani', sans-serif;
 2) font-family: 'Poppins', sans-serif;
 ----------------------------------------*****/


/*--------------------------------------------------------------------- import Files ---------------------------------------------------------------------*/

@import url(animate.min.css);
@import url(normalize.css);
@import url(icomoon.css);
@import url(font-awesome.min.css);
@import url(meanmenu.css);
@import url(owl.carousel.min.css);
/*@import url(swiper.min.css);*/
@import url(slick.css);
/*@import url(jquery.fancybox.min.css);*/
@import url(jquery-ui.css);
@import url(nice-select.css);


/*--------------------------------------------------------------------- pop up ---------------------------------------------------------------------*/
#popup-overlay{
     position:fixed;
     top:0;
     left:0;
     right:0;
     bottom:0;
     z-index: 998;
     display: none;
     /*display:flex;
     align-items: center;
     justify-content: center;*/
}

#popup-overlay.open{
     display:block !important; 
}

.popup-content{
     max-width:600px;
     padding:30px;
     border-radius: 15px;
     box-sizing: border-box;
     background: #243C69;
     width: 100%;
     position: absolute;
     top:50%;
     left: 50%;
     transform:translate(-50%, -50%);

}
.popup-content h2{
     color:#e3aca8;
     margin: 20px 0;
}

.popup-exit{
     position:absolute;
     top:0;
     right:0;
   margin-right: 10px;
     color:#e3aca8;
     font-size: 24px; /* Ajuste la taille selon ton besoin */
     text-decoration: none; /* Supprime le soulignement */
     cursor: pointer; /* Change le curseur pour un effet interactif */
     
}

.promo_code {
     font-size: 17px;
     background-color: #e3aca8;
     color: #fff6ea;
     padding: 9px 0px;
     width: 100%;
     max-width: 177px;
     text-align: center;
     display: inline-block;
     transition: ease-in all 0.5s;
     font-weight: 500;
     border-radius: 30px;
}

.promo_code:hover {
     /*background: #ADD8E6;*/
     background: linear-gradient(to bottom, #243C69, #4F74B5);
     color: #e3aca8;
     transition: ease-in all 0.5s;
}

/*--------------------------------------------------------------------- connexion ---------------------------------------------------------------------*/


.user-icon {
    cursor: pointer;
    transition: all 0.3s ease;
}

.user-icon circle,
.user-icon path {
    transition: stroke 0.3s ease;
}

.user-icon:hover circle {
    stroke: #243C69;
}

.user-icon:hover path {
    stroke: #243C69;
}

.user-icon:hover {
    transform: scale(1.1);
}


/*--------------------------------------------------------------------- loading ---------------------------------------------------------------------*/

.loader_bg {
    position: fixed;
    z-index: 9999;
    background: #f8ccc3;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.loader {
    position: relative;
    width: 80px;
    height: 80px;
}

.loader::before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    border: 6px solid #f3f3f3;
    border-top: 6px solid #e3aca8;
    animation: spin 1s linear infinite;
}

.loader::after {
    content: '';
    position: absolute;
    width: 60%;
    height: 60%;
    top: 20%;
    left: 20%;
    border-radius: 50%;
    border: 4px solid transparent;
    border-bottom: 4px solid #ffa8a8;
    animation: spin 1.5s linear infinite reverse;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.loader_bg.fade-out {
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

/*--------------------------------------------------------------------- skeleton ---------------------------------------------------------------------*/

* {
     box-sizing: border-box !important;
}

.container {
     max-width: 1170px;
}

html {
     scroll-behavior: smooth;
}

body {
     color: #243C69;
     font-size: 14px;
     font-family: 'Poppins', sans-serif;
     line-height: 1.80857;
     font-weight: normal;
}

a {
     color: #1f1f1f;
     text-decoration: none !important;
     outline: none !important;
     -webkit-transition: all .3s ease-in-out;
     -moz-transition: all .3s ease-in-out;
     -ms-transition: all .3s ease-in-out;
     -o-transition: all .3s ease-in-out;
     transition: all .3s ease-in-out;
}

h1,
h2,
h3,
h4,
h5,
h6 {
     letter-spacing: 0;
     font-weight: normal;
     position: relative;
     padding: 0 0 10px 0;
     font-weight: normal;
     line-height: normal;
     color: #243C69;
     margin: 0
}

h1 {
     font-size: 24px;
}

h2 {
     font-size: 22px;
}

h3 {
     font-size: 18px;
}

h4 {
     font-size: 16px
}

h5 {
     font-size: 14px
}

h6 {
     font-size: 13px
}


.slogan {
     color: #fff6ea;
     padding-left: 30px;
     font-size: 16px;
}

*,
*::after,
*::before {
     -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
     box-sizing: border-box;
}

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
     color: #243C69;
     text-decoration: none!important;
     opacity: 1
}

button:focus {
     outline: none;
}

ul,
li,
ol {
     margin: 0px;
     padding: 0px;
     list-style: none;
}

p {
     margin: 0px;
     font-weight: 500;
     font-size: 15px;
     line-height: 24px;
}

a {
     color: #222222;
     text-decoration: none;
     outline: none !important;
}

a,
.btn {
     text-decoration: none !important;
     outline: none !important;
     -webkit-transition: all .3s ease-in-out;
     -moz-transition: all .3s ease-in-out;
     -ms-transition: all .3s ease-in-out;
     -o-transition: all .3s ease-in-out;
     transition: all .3s ease-in-out;
}

img {
     max-width: 100%;
     height: auto;
}

 :focus {
     outline: 0;
}

.btn-custom {
     margin-top: 20px;
     background-color: transparent !important;
     border: 2px solid #ddd;
     padding: 12px 40px;
     font-size: 16px;
}

.lead {
     font-size: 18px;
     line-height: 30px;
     color: #767676;
     margin: 0;
     padding: 0;
}

.form-control:focus {
     border-color: #ffffff !important;
     box-shadow: 0 0 0 .2rem rgba(255, 255, 255, .25);
}

.navbar-form input {
     border: none !important;
}

.badge {
     font-weight: 500;
}

blockquote {
     margin: 20px 0 20px;
     padding: 30px;
}

button {
     border: 0;
     margin: 0;
     padding: 0;
     cursor: pointer;
}

.full {
     float: left;
     width: 100%;
}

.full {
     width: 100%;
     float: left;
     margin: 0;
     padding: 0;
}


/**-- heading section --**/


/*---------------------------- preloader area 

.loader_bg {
     position: fixed;
     z-index: 9999999;
     background: #fff;
     width: 100%;
     height: 100%;
}

.loader {
     height: 100%;
     width: 100%;
     position: absolute;
     left: 0;
     top: 0;
     display: flex;
     justify-content: center;
     align-items: center;
}

.loader img {
     width: 280px;
}

----------------------------*/
/*-- header area --*/


/*--------------------------------------------------------------------- top banner area ---------------------------------------------------------------------*/


.logo a img {
        position: relative;
        z-index: 9999;
        width: 180px;
        height: 180px;
        

    }
    
    .logo::before {
        position: absolute;
        content: "";
        top: -15px;
       width: 310px;
        height: 138px;
        left: -30px;
        background-repeat: no-repeat;
    }


/*-- navigation--*/

.navigation.navbar {
     float: right;
     padding-top: 28px !important;
     padding: 0;
}

.navigation.navbar-dark .navbar-nav .nav-link {
     padding: 9px 22px;
     color: #fff;
     font-size: 16px;
     line-height: 20px;
     font-weight: 500;
     text-transform: uppercase;
}

.navigation.navbar-dark .navbar-nav .nav-link:focus,
.navigation.navbar-dark .navbar-nav .nav-link:hover {
     background: #243C69;
     border-radius: 6px;
}

.navigation.navbar-dark .navbar-nav .active>.nav-link,
.navigation.navbar-dark .navbar-nav .nav-link.active,
.navigation.navbar-dark .navbar-nav .nav-link.show,
.navigation.navbar-dark .navbar-nav .show>.nav-link {
     background: #243C69;
     border-radius: 6px;
}

.navbar-expand-md .navbar-nav {
     padding-right: 10px;
}

.header {
     width: 100%;
     height: 116px;
     padding: 15px 30px;
}


/** banner section **/

.full_bg {
     background: url(../images/bannerMama.png);
     background-size: 100% 100%;
     background-position: center;
     background-repeat: no-repeat;
}

.banner_main {
     position: relative;
     padding-bottom: 60px;
}

.yoga_box {
     text-align: left;
     padding-top: 18%;
}

.banner_po {
     position: inherit;
}

.yoga_box span {
     color: #fff6ea;
     font-size: 28px;
     line-height: 20px;
     font-weight: bold;
}

.yoga_box h1 {
     font-size: 150px;
     font-weight: bold;
     color: #e3aca8;
     line-height: 150px;
}
.yo_img figure {margin-top: 110px;}

.yoga_box h1 strong {
     color: #fff;
}

.yoga_box .yoga_btn {
     float: left;
     font-size: 18px;
     padding: 15px 0;
     text-transform: uppercase;
     font-weight: bold;
}

/** AJOUT pour centre femme section **/
.yoga_box {
     text-align: left;
     padding-top: 18%;
}

.banner_po {
     position: inherit;
}

.yoga_tagline {
    color: #e3aca8;
    font-size: 56px;
    line-height: 68px;
    font-weight: 500;
    margin-top: 0;
    margin-bottom: 25px;
}

.yoga_tagline strong {
    color: #fff;
    font-weight: bold;
}

.yoga_subtitle {
    color: #fff6ea;
    font-size: 22px;
    line-height: 32px;
    font-weight: normal;
    margin-bottom: 40px;
    max-width: 500px;
}

.yoga_box .yoga_btn {
     float: left;
     font-size: 18px;
     padding: 15px 0;
     text-transform: uppercase;
     font-weight: bold;
}

/** fin pour centre femme section **/

#myCarousel .carousel-control-prev,
#myCarousel .carousel-control-next {
     width: 80px;
     height: 80px;
     background: #e3aca8;
     opacity: 1;
     font-size: 20px;
     color: #fff6ea;
     top: 46%;
     border-radius: 40px;
}

#myCarousel .carousel-control-prev:hover,
#myCarousel .carousel-control-next:hover,
#myCarousel .carousel-control-prev:focus,
#myCarousel .carousel-control-next:focus {
     background: #001935;
     color: #fff6ea;
}

#myCarousel .carousel-control-prev {
     left: 9%;
}

#myCarousel .carousel-control-next {
     right: 9%;
}

.carousel-indicators {
     right: inherit;
     bottom: 53px;
     margin-left: 9%;
}


/** end banner section **/

.titlepage {
     text-align: center;
     padding-bottom: 40px;
}

.titlepageleft {
     text-align: left;
     padding-bottom: 40px;
  
}


.titlepage h2 {
     font-size: 50px;
     color: #e3aca8;
     line-height: 45px;
     font-weight: bold;
     padding: 0;
}

.titlepage span {
     font-size: 17px;
     line-height: 25px;
     color: #243C69;
     padding-top: 30px;
     display: block;
}

.d_flex {
     display: flex;
     align-items: center;
     flex-wrap: wrap;
}

.read_more {
     font-size: 17px;
     background-color: #e3aca8;
     color: #fff6ea;
     padding: 9px 0px;
     width: 100%;
     max-width: 177px;
     text-align: center;
     display: inline-block;
     transition: ease-in all 0.5s;
     font-weight: 500;
}

.read_more:hover {
     background: #243C69;
     color: #fff6ea;
     transition: ease-in all 0.5s;
}



/** Nos cours section **/

.classes {
     background-color: #fff6ea;
     padding: 40px 0;
}

.our_yoga {
     text-align: center;
}

.our_yoga img {
     width: 70%;
     height: 70%;
}

.our_yoga figure {
     margin: 0;
    
}

.our_yoga h3 {
     margin-top: 30px;
     font-size: 30px;
     line-height: 20px;
     color: #243C69;
     text-transform: uppercase;
     font-weight: bold;
     padding-bottom: 8px;
}

.our_yoga span {
     font-size: 17px;
     line-height: 20px;
     font-weight: bold;
     color: #b7b6b6;
}

.margin_bott {
     margin-bottom: -30px;
}

.margin_top {
     margin-top: -10px;
}

.yoga_btn {
     max-width: 292px;
     height: 60px;
     padding: 15px 0;
     margin-top: 45px;
     margin-top: 45px !important;
     border-radius: 30px;
     margin: 0 auto;
     display: block;
}

/** Nos horaires section **/

table, caption, th, td {

     border: 2px solid #243C69;
       border-collapse: collapse;
     
     }
     
     caption, th, td {
     padding: 8px;
     }
     
     th {
     
     background-color: #f8ccc3;
     
     }
     
     td {
     background-color: #e3aca8;
     }

/** end Nos cours section **/


/** middle section **/

.middle {
     background: #364A70;
     margin: 0 60px 0 60px;
}

.middle .titlepage {
     text-align: left;
     max-width: 554px;
     float: right;
     width: 80%;
}

.middle .titlepage h2 {
     color: #E0E0E1;
     padding-bottom: 30px;
}

.middle .titlepage p {
     color: #fff6ea;
     font-weight: normal;
     font-family: 'Open Sans', sans-serif;
     font-size: 16px;
     border-bottom: #fff solid 1px;
     padding-bottom: 35px;
}

.yoga_img figure {
     margin: 10;
}

.yoga_img figure img {
     width: 100%;
     height: auto;
}

.padding_right15 {
     padding-right: 40px;
}


/** end middle section **/


/** about section **/

.about {
     background-color: #fff6ea;
     padding: 30px 0;
}

.about .titlepage {
     text-align: center;
}

.about .titlepage span {
     font-family: 'Open Sans', sans-serif;
}


.about_img figure img {
     width: 40%;
     height: auto;
}


@media (max-width: 768px) {
     .about_coach {
         width: 100%; /* Sur les petits écrans, utiliser toute la largeur disponible */
         margin: 0 20px; /* Espacement réduit sur mobile */
     }
}
/** end about section **/


/** middle section **/


.yoga_img figure {
     margin: 0;
}

.yoga_img figure img {
     width: 100%
}

.padding_left0 {
     padding-left: 0;
}


/** end middle section **/

/* Titre avec image - Section À propos */
.title-with-image {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.title-image {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 50%;
    box-shadow: 0 4px 15px rgba(227, 172, 168, 0.3);
}

.back_re .title h2 {
    margin: 0;
}

@media (max-width: 768px) {
    .title-image {
        width: 60px;
        height: 60px;
    }
}
/** about section **/


         /* Styles spécifiques pour la page À propos */
         .mg-about-section {
            background-color: #fff6ea !important;
            padding: 60px 0 !important;
         }
         
         .mg-about-intro {
            max-width: 900px !important;
            margin: 0 auto 50px auto !important;
            text-align: center !important;
            padding: 0 20px !important;
         }
         
         .mg-about-intro p {
            font-size: 16px !important;
            line-height: 1.8 !important;
            color: #243C69 !important;
            margin-bottom: 15px !important;
         }
         
         .mg-about-image-section {
            text-align: center !important;
            margin: 40px 0 !important;
         }
         
         .mg-about-image-section img {
            max-width: 600px !important;
            width: 100% !important;
            border-radius: 15px !important;
            box-shadow: 0 8px 25px rgba(36, 60, 105, 0.15) !important;
         }
         
         .mg-about-team-section {
            max-width: 1100px !important;
            margin: 60px auto 0 auto !important;
            padding: 0 20px !important;
         }
         
         .mg-about-team-title {
            font-size: 28px !important;
            color: #243C69 !important;
            font-weight: 700 !important;
            margin-bottom: 30px !important;
            text-align: left !important;
         }
         
         .mg-about-roxane-section {
            display: grid !important;
            grid-template-columns: 300px 1fr !important;
            gap: 40px !important;
            align-items: start !important;
            margin-bottom: 60px !important;
            padding: 30px !important;
            background: #ffffff !important;
            border-radius: 15px !important;
            box-shadow: 0 6px 25px rgba(36, 60, 105, 0.1) !important;
         }
         
         .mg-about-roxane-photo {
            width: 300px !important;
            height: 300px !important;
            object-fit: cover !important;
            border-radius: 15px !important;
            box-shadow: 0 6px 20px rgba(227, 172, 168, 0.3) !important;
         }
         
         .mg-about-roxane-text {
            font-size: 16px !important;
            line-height: 1.8 !important;
            color: #243C69 !important;
            text-align: left !important;
         }
         
         .mg-about-roxane-text strong {
            color: #e3aca8 !important;
            font-size: 22px !important;
            display: block !important;
            margin-bottom: 15px !important;
         }
         
         .mg-about-team-text {
            font-size: 16px !important;
            line-height: 1.8 !important;
            color: #243C69 !important;
            margin-bottom: 20px !important;
            text-align: left !important;
         }
         
         .mg-about-coaches-title {
            font-size: 24px !important;
            color: #e3aca8 !important;
            font-weight: 700 !important;
            margin: 40px 0 20px 0 !important;
            text-align: left !important;
         }
         
         .mg-about-team-grid {
            display: grid !important;
            grid-template-columns: repeat(3, 1fr) !important;
            gap: 30px !important;
            margin-top: 30px !important;
         }
         
         .mg-about-coach-card {
            text-align: center !important;
         }
         
         .mg-about-coach-card img {
            width: 100% !important;
            max-width: 300px !important;
            height: 300px !important;
            object-fit: cover !important;
            border-radius: 15px !important;
            box-shadow: 0 6px 20px rgba(36, 60, 105, 0.15) !important;
            transition: transform 0.3s ease !important;
         }
         
         .mg-about-coach-card:hover img {
            transform: scale(1.05) !important;
         }
         
         .mg-about-coach-name {
            font-size: 18px !important;
            color: #243C69 !important;
            font-weight: 600 !important;
            margin-top: 15px !important;
            font-style: italic !important;
         }
         
         .mg-about-highlight {
            background: #f8ccc3 !important;
            padding: 20px 30px !important;
            border-radius: 10px !important;
            border-left: 5px solid #e3aca8 !important;
            margin: 30px 0 !important;
         }
         
         @media (max-width: 768px) {
            .mg-about-roxane-section {
               grid-template-columns: 1fr !important;
               gap: 20px !important;
               padding: 20px !important;
               text-align: center !important;
            }
            
            .mg-about-roxane-photo {
               width: 100% !important;
               max-width: 250px !important;
               height: 250px !important;
               margin: 0 auto !important;
            }
            
            .mg-about-roxane-text {
               text-align: center !important;
            }
            
            .mg-about-team-grid {
               grid-template-columns: 1fr !important;
               gap: 20px !important;
            }
            
            .mg-about-coach-card img {
               max-width: 250px !important;
               height: 250px !important;
            }
            
            .mg-about-intro,
            .mg-about-team-section {
               padding: 0 15px !important;
            }
         }
    

/* FIN Styles spécifiques pour la page À propos */

.pricing_main {
     background-color: #fff6ea;
     padding-top: 20px;
}

.pricing_main .titlepage {
     text-align: left;
}

.pricing_main .titlepage span {
     font-family: 'Open Sans', sans-serif;
}

.pricing {
     text-align: center;
     font-family: 'Open Sans', sans-serif;
     padding: 45px 40px 0px 40px;
}

.pricing h4 {
     color: #151515;
     font-size: 30px;
     line-height: 20px;
     font-weight: bold;
     padding-bottom: 30px;
}

.pricing h3 {
     margin-bottom: 40px;
     font-size: 55px;
     padding-bottom: 35px;
     color: #151515;
     line-height: 74px;
     font-weight: bold;
}

.pricing h3 span {
     color: #e3aca8;
}

.pricing h3::before {
     position: absolute;
     content: "";
     background-color: #f8ccc3;
     width: 88px;
     height: 9px;
     bottom: 0px;
     border-radius: 7px;
}

.pricing p {
     font-weight: bold;
     color: #151515;
     padding-bottom: 40px;
     font-size: 17px;
     line-height: 28px;
}

.dark_bg {
     background: #e3aca8;
     font-weight: normal;
     
}


.col-md-4 .read_more ,
.col-md-3 .read_more {
     background: #e3aca8;
     border: 2px solid #a86956;
}

.col-md-4 .read_more:hover {
     background: #f8ccc3;
}



/** end about section **/

/*----------------------------------------location---------------------------------------------------------------*/


/* Features grid */
.features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin: 30px 0;
}

.feature-card {
    background: #fff6ea;
    padding: 25px;
    border-radius: 8px;
    border-left: 4px solid #e3aca8;
    transition: all 0.3s ease;
}

.feature-card:hover {
    transform: translateX(5px);
    box-shadow: 0 4px 12px rgba(227, 172, 168, 0.3);
}

.feature-card h4 {
    color: #243C69;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 10px;
    padding: 0;
}

.feature-card p {
    color: #243C69;
    font-size: 15px;
    line-height: 24px;
}

/* Pricing highlight box */


.price {
    font-size: 55px;
    font-weight: bold;
    color: #e3aca8;
    margin: 20px 0;
}



/* Highlight box */
.highlight-box {
    background: linear-gradient(135deg, #fef5f3 0%, #f8ccc3 100%);
    padding: 30px;
    border-radius: 10px;
    margin: 30px 0;
    border-left: 5px solid #e3aca8;
}

.highlight-box h4 {
    color: #243C69;
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 15px;
    padding: 0;
}

/* CTA section */
.cta-section {
    background: white;
    padding: 50px 40px;
    text-align: center;
    margin: 40px 0;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(36, 60, 105, 0.1);
}

.cta-section h3 {
    color: #243C69;
    font-size: 32px;
    margin-bottom: 20px;
    padding: 0;
}

.cta-section .email {
    color: #e3aca8;
    font-size: 24px;
    font-weight: bold;
    margin: 20px 0;
}

/* Responsive pour location */
@media (max-width: 768px) {
    
    .features-grid {
        grid-template-columns: 1fr;
    }

    .price {
        font-size: 40px;
    }

    .cta-section {
        padding: 30px 20px;
    }
}


/** pepole section **/

.pepole {
     padding-top: 30px;
     background: #fff6ea;
}

.parile0 {
     padding-left: 0;
     padding-right: 0;
}

.relative2 {
     position: inherit;
     padding: 0px 50px 80px 50px;
     text-align: left;
     border-top: #e3aca8 solid 111px;
}

.relative2 i {
     margin-top: -54px;
     position: relative;
     display: block;
}

.relative2 span {
     color: #364A70;
     display: block;
     font-size: 30px;
     font-weight: 500;
     font-family: 'Open Sans', sans-serif;
}

.relative2 p {
     color: #364A70;
     font-size: 17px;
     line-height: 28px;
     font-family: 'Open Sans', sans-serif;
     font-weight: normal;
}

.testimo_ban_bg {
     background: #fff6ea;
     box-shadow: 0 0px 237px rgba(22, 22, 23, 0.11);
}

.qusright {
     padding-right: 10px
}

.qusleft {
     padding-left: 10px
}

.aliq {
     padding: 0px 0px 0px 40px;
}

#testimo .carousel-control-prev,
#testimo .carousel-control-next {
     width: 47px;
     height: 47px;
     background: #252525;
     opacity: 1;
     font-size: 20px;
     color: #fff6ea;
     top: 88%;
     border-radius: 40px;
}

#testimo .carousel-control-prev:hover,
#testimo .carousel-control-next:hover,
#testimo .carousel-control-prev:focus,
#testimo .carousel-control-next:focus {
     background: #e3aca8;
     color: #fff6ea;
}

#testimo .carousel-control-prev {
     left: 0px;
}

#testimo .carousel-control-next {
     right: inherit;
     left: 7%;
}

.banner .carousel-indicators li {
     width: 20px;
     height: 20px;
     border-radius: 30px;
     background: #000;
}

.carousel-indicators {
     display: none;
}


/** end pepole section **/

/** menu déroulant section **/

/* Couleur de fond du menu déroulant */
.dropdown-menu {
     background-color: #e3aca8; /* beige clair ou ta couleur principale */
     border: 1px solid #d9d9d9;
     border-radius: 8px;
   }
   
   /* Couleur du texte et padding */
   .dropdown-item {
     color: #243C69; /* texte foncé */
     padding: 10px 20px;
     font-weight: bold;
   }
   
   /* Survol d’un item */
   .dropdown-item:hover {
     background-color: #ffddcc; /* couleur douce au survol */
     color: #243C69;
   }
   
   /* Flèche du bouton "Voir tous les prix" */
   .dropdown-toggle::after {
     margin-left: 10px;
     vertical-align: middle;
   }

   .dropdown-toggle {
     padding: 10px 20px; /* Ajoute de l’espace autour du texte du bouton */
     cursor: pointer; /* ← Ajoutez juste cette ligne */
   }
   

   .dropdown-container {
     display: flex;
     justify-content: center;
   }


/**
   .yoga_btn {
     max-width: 292px;
     height: 60px;
     padding: 15px 0;
     margin-top: 45px;
     margin-top: 45px !important;
     border-radius: 30px;
     margin: 0 auto;
     display: block;
}**/

/** End of menu deroulant section**/   


/** contact section **/

.contact {
     background: #f8ccc3;
     margin-top: 0px;
     padding-bottom: 80px;
     padding-top: 90px;
}

.contact .titlepage {
     text-align: left;
}

.contact .titlepage h2 {
     color: #fff;
}

.main_form {
     padding: 40px 80px;
     background: #fff;
}

.main_form .contactus {
     border: #fff solid 1px;
     padding: 0px 20px;
     margin-bottom: 25px;
     width: 100%;
     height: 44px;
     background: #fff;
     color: #243C69;
     font-size: 17px;
     font-weight: normal;
     box-shadow: 0px 0px 18px rgba(22, 22, 23, 0.11);
}

.main_form .textarea {
     border: #fff solid 1px;
     margin-bottom: 25px;
     width: 100%;
     background: #fff;
     color: #243C69;
     font-size: 17px;
     font-weight: normal;
     padding: 25px 20px 0 20px;
     box-shadow: 0px 0px 18px rgba(22, 22, 23, 0.11);
     height: 86px;
}

.main_form .send_btn {
     font-size: 20px;
     transition: ease-in all 0.5s;
     background-color: #e3aca8;
     text-transform: uppercase;
     color: #fff;
     padding: 8px 0px;
     max-width: 144px;
     width: 100%;
     display: block;
     margin-top: 10px !important;
     font-weight: 500;
}

.main_form .send_btn:hover {
     background-color: #f8ccc3;
     transition: ease-in all 0.5s;
     color: #fff;
}

#request *::placeholder {
     color: #dadada;
     opacity: 1;
}

.map figure {
     margin: 0;
}

.map figure img {
     width: 100%;
}


/** end contact section **/

/** partenaire **/

        /* Styles spécifiques pour la section partenaires - Préfixe mg-ptn pour éviter les conflits */
         .mg-ptn-partners-grid {
            display: grid !important;
            grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
            gap: 30px !important;
            padding: 40px 0 !important;
            max-width: 1400px !important;
            margin: 0 auto !important;
         }
         
         .mg-ptn-partner-card {
            background: #ffffff !important;
            border-radius: 12px !important;
            padding: 35px 25px !important;
            box-shadow: 0 6px 25px rgba(36, 60, 105, 0.12) !important;
            transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
            text-align: center !important;
            border: 2px solid #f8ccc3 !important;
         }
         
         .mg-ptn-partner-card:hover {
            transform: translateY(-12px) !important;
            box-shadow: 0 12px 35px rgba(36, 60, 105, 0.2) !important;
            border-color: #e3aca8 !important;
         }
         
         .mg-ptn-partner-card .mg-ptn-figure {
            margin: 0 0 25px 0 !important;
            height: 200px !important;
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            overflow: hidden !important;
            border-radius: 10px !important;
            background: #fff6ea !important;
            padding: 15px !important;
         }
         
         .mg-ptn-partner-card .mg-ptn-figure img {
            max-width: 100% !important;
            max-height: 100% !important;
            width: auto !important;
            height: auto !important;
            object-fit: contain !important;
            transition: transform 0.4s ease !important;
         }
         
         .mg-ptn-partner-card:hover .mg-ptn-figure img {
            transform: scale(1.08) !important;
         }
         
         .mg-ptn-partner-card .mg-ptn-title {
            font-size: 24px !important;
            color: #243C69 !important;
            margin: 20px 0 12px 0 !important;
            font-weight: 700 !important;
            line-height: 1.3 !important;
            padding: 0 !important;
            text-transform: none !important;
            font-family: 'Poppins', sans-serif !important;
         }
         
         .mg-ptn-partner-card .mg-ptn-description {
            display: block !important;
            color: #555555 !important;
            font-size: 15px !important;
            line-height: 1.7 !important;
            margin-bottom: 15px !important;
            font-weight: 400 !important;
            padding: 0 !important;
         }
         
         .mg-ptn-discount-badge {
            background: linear-gradient(135deg, #e3aca8 0%, #f8ccc3 100%) !important;
            color: #243C69 !important;
            padding: 10px 20px !important;
            border-radius: 25px !important;
            font-size: 14px !important;
            font-weight: 700 !important;
            display: inline-block !important;
            margin-top: 12px !important;
            text-transform: uppercase !important;
            letter-spacing: 0.5px !important;
            box-shadow: 0 3px 10px rgba(227, 172, 168, 0.3) !important;
         }
         
         /* Accordéon pour texte long */
         .mg-ptn-expandable-text {
            max-height: 90px !important;
            overflow: hidden !important;
            transition: max-height 0.5s ease !important;
            position: relative !important;
         }
         
         .mg-ptn-expandable-text.mg-ptn-expanded {
            max-height: 2000px !important;
         }
         
         .mg-ptn-read-more-btn {
            background: transparent !important;
            border: 2px solid #e3aca8 !important;
            color: #243C69 !important;
            padding: 8px 20px !important;
            border-radius: 20px !important;
            font-size: 13px !important;
            font-weight: 600 !important;
            cursor: pointer !important;
            margin-top: 10px !important;
            transition: all 0.3s ease !important;
            display: inline-block !important;
            text-transform: uppercase !important;
            letter-spacing: 0.5px !important;
         }
         
         .mg-ptn-read-more-btn:hover {
            background: #e3aca8 !important;
            color: #ffffff !important;
            transform: translateY(-2px) !important;
            box-shadow: 0 4px 12px rgba(227, 172, 168, 0.3) !important;
         }
         
         .mg-ptn-specialty {
            color: #e3aca8 !important;
            font-size: 14px !important;
            font-weight: 600 !important;
            margin: 10px 0 15px 0 !important;
            font-style: italic !important;
         }
         
         @media (max-width: 768px) {
            .mg-ptn-partners-grid {
               grid-template-columns: 1fr !important;
               gap: 25px !important;
               padding: 30px 15px !important;
            }
            
            .mg-ptn-partner-card {
               padding: 25px 20px !important;
            }
            
            .mg-ptn-partner-card .mg-ptn-figure {
               height: 160px !important;
            }
         }

   
/** end partenaire **/
/** footer **/

.footer {
     background: #243C69;
     padding-top: 90px;
     text-align: center;
}

.border_top1 {
     border-top: #f8ccc3 solid 3px;
     padding-bottom: 60px;
}


.footer h3 {
     font-weight: 600;
     font-size: 20px;
     line-height: 24px;
     text-align: left;
     color: #fff6ea;
     margin-bottom: 15px;
     display: table;
}

ul.conta li {
     color: #e3aca8;
     text-align: left;
     padding-bottom: 20px;
     font-size: 16px;
}

ul.conta li i {
     padding-right: 15px;
     text-align: center;
     font-size: 20px;
}

ul.conta li a {
     color: #e3aca8;
}

ul.link_menu li {
     display: block;
     text-align: left;
}

ul.link_menu li.active a {
     color: #ff0909;
}

ul.link_menu li a {
     color: #e3aca8;
     font-size: 17px;
     line-height: 32px;
     display: block;
     width: -moz-max-content;
}

ul.link_menu li a:hover {
     color: #f8ccc3;
}

ul.social_icon {
     margin-left: 15px;
     padding-top: 15px;
     width: 100%;
     float: left;
     text-align: left;
}

ul.social_icon li {
     display: inline-block;
}

ul.social_icon li a {
     display: flex;
     align-items: center;
     justify-content: center;
     flex-wrap: wrap;
     font-size: 24px;
     border-radius: 30px;
     margin: 0 3px;
     color: #001935;
     background: #fff6ea;
     width: 40px;
     height: 39px;
}

ul.social_icon li a:hover {
     color: #e3aca8;
}

.copyright {
     margin-top: 60px;
     background-color: #243C69;
     box-shadow: 3px 0px 10px rgba(0, 0, 0, 0.42);

}


.copyright p {
     color: #f8ccc3;
     font-size: 17px;
     line-height: 22px;
     text-align: center;
     padding-top: 26px;
     font-weight: normal; padding-bottom: 20px;
}

.copyright a {
     color: #f8ccc3;
}




/** end footer **/


/** endinner page css **/

.inner_page .full_bg {background-color:#e3aca8 !important; background:transparent; }

.inner_page .navigation.navbar {padding-top: 24px !important;}
.back_re {
     background-color: #243C69;
}

.back_re .title {
     text-align: center;
}

.back_re .title h2 {
     color: #f8ccc3;
     font-size: 40px;
     padding: 40px 0;
     font-weight: 600;
     line-height: 35px;
}

.margin_0 {
     margin: 0 !important;
}

.inner_page .gallery {
     padding-top: 90px;
}

.inner_page .blog {
     margin-top: 90px;
}

/*Ajout FAQ onglet*/

/* Menu de sélection FAQ */ 
.faq-category-menu { 
     text-align: center; 
     margin-bottom: 50px; 
     padding: 30px; 
     background: linear-gradient(135deg, #f5f5f5 0%, #fff 100%); 
     border-radius: 15px; box-shadow: 0 4px 6px rgba(0,0,0,0.1); 
} 
     
.faq-category-menu h3 { 
          color: #243C69; 
          font-size: 24px; 
          margin-bottom: 25px; 
          font-weight: bold; 
     } 
     
.category-buttons { 
     display: flex; 
     justify-content: center; 
     gap: 20px; 
     flex-wrap: wrap; 
} 
     
.category-btn { 
     background-color: #e3aca8; 
     color: white; 
     border: none; 
     padding: 20px 30px; 
     font-size: 18px; 
     font-weight: bold; 
     border-radius: 10px; 
     cursor: pointer; 
     transition: all 0.3s ease; 
     box-shadow: 0 4px 8px rgba(0,0,0,0.1); 
     display: flex; 
     flex-direction: column; 
     align-items: center; 
     gap: 10px; min-width: 180px; 
} 

.category-btn:hover { 
     background-color: #243C69; 
     transform: translateY(-3px); box-shadow: 0 6px 12px rgba(0,0,0,0.15); } 
     
.category-btn .icon { 
     font-size: 32px; } 
     
     /* Responsive */ 
     @media (max-width: 768px) { 
.category-buttons { flex-direction: column; align-items: center; } 
.category-btn { width: 100%; max-width: 300px; } }

/*Ajout FAQ*/
.faq-category {
  margin-bottom: 40px;
}

.category-title {
  color: #e3aca8;
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 3px solid #e3aca8;
}

.faq-item {
  margin-bottom: 15px;
}

/* FAQ*/

.faq-item {
  border-bottom: 1px solid #ccc;
  margin-bottom: 10px;
}

.faq-category-menu {
  text-align: center;
  margin-bottom: 50px;
  padding: 30px;

  background: linear-gradient(135deg, #ffe5d9 0%, #fff6ea 100%); /* Dégradé rose-beige */
  border-radius: 15px;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.faq-question {
  background: none;
  border: none;
  font-size: 1.1em;
  font-weight: bold;
  cursor: pointer;
  width: 100%;
  text-align: left;
  padding: 10px 30px 10px 30px;
  position: relative;
  color: #243C69;
}

.faq-question::before {
  content: "+";
  position: absolute;
  left: 10px;
  font-size: 1.2em;
  transition: transform 0.3s ease;
}

.faq-item.active .faq-question::before {
  content: "−";
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  padding: 0 30px;
}

.faq-item.active .faq-answer {
  max-height: 300px;
  padding: 10px 30px;
}

/* Recompenses*/

body {
  background-color: #fff6ea;
}
.recompenses-section {
  background-color: #f8ccc3;
  border-left: 6px solid #243C69;
  padding: 2.5em;
  font-family: 'Montserrat', sans-serif;
  color: #243C69;
  max-width: 850px;
  margin: 3em auto;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(36, 60, 105, 0.1);
}

.recompenses-section h2 {
  font-size: 2em;
  color: #243C69;
  margin-bottom: 1em;
  text-align: center;
}

.recompenses-section h3 {
  font-size: 1.3em;
  color: #243C69;
  margin-top: 2em;
  margin-bottom: 0.5em;
}

.recompenses-section p {
  font-size: 1em;
  line-height: 1.6;
  margin-bottom: 1em;
}

.recompenses-section ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: 1em;
}

.recompenses-section li {
  margin-bottom: 0.75em;
  padding-left: 1.5em;
  position: relative;
}

.recompenses-section li::before {
  
  position: absolute;
  left: 0;
  color: #243C69;
  font-size: 1em;
}

/* Les classes*/
.course-link {
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.course-link:hover {
  transform: translateY(-5px);
  text-decoration: none;
}

.course-link:hover .our_yoga {
  box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

.course-link .our_yoga {
  transition: all 0.3s ease;
  cursor: pointer;
}


/* ===================================== */
/* PAGES DE COURS - Course Pages Styles */
/* ===================================== */


.gallery-image {
    border-radius: 15px; /* Plus arrondi */
}


.course-content {
    padding: 20px 0;
    background-color: #fff6ea;
}

.course-section {
    background: white;
    padding: 40px;
    margin-bottom: 30px;
    border-radius: 15px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.course-section h2 {
    color: #e3aca8;
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 20px;
    border-bottom: 3px solid #e3aca8;
    padding-bottom: 10px;
}

.course-section h3 {
    color: #243C69;
    font-size: 24px;
    font-weight: bold;
    margin-top: 25px;
    margin-bottom: 15px;
}

.course-section p {
    font-size: 16px;
    line-height: 1.8;
    color: #333;
}

.benefits-list {
    list-style: none;
    padding: 0;
}

.benefits-list li {
    padding: 12px 0;
    font-size: 16px;
    color: #243C69;
    border-bottom: 1px solid #f0f0f0;
}

.benefits-list li:before {
    content: "✓ ";
    color: #e3aca8;
    font-weight: bold;
    font-size: 20px;
    margin-right: 10px;
}



.cta-button {
    display: inline-block;
    background: #e3aca8;
    color: white;
    padding: 15px 40px;
    font-size: 18px;
    font-weight: bold;
    text-decoration: none;
    border-radius: 50px;
    transition: all 0.3s ease;
    margin: 20px 10px;
}

.cta-button:hover {
    background: #243C69;
    color: white;
    text-decoration: none;
    transform: translateY(-3px);
    box-shadow: 0 6px 12px rgba(0,0,0,0.2);
}

.cta-section {
    text-align: center;
    padding: 50px 0;
}

.course-image {
    width: 100%;
    border-radius: 15px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    margin: 20px 0;
}


/* Galerie cliquable - Catégories */
.course-gallery.gallery-clickable .gallery-link {
     display: block;
     transition: transform 0.3s ease;
}

.course-gallery.gallery-clickable .gallery-link:hover {
     transform: translateY(-5px);
}

.course-gallery.gallery-clickable .gallery-image {
     transition: all 0.3s ease;
}

.course-gallery.gallery-clickable .gallery-link:hover .gallery-image {
     box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

/* Responsive pour mobile */
@media (max-width: 768px) {
    .course-hero h1 {
        font-size: 36px;
    }
    
    .course-hero .subtitle {
        font-size: 18px;
    }
    
    .course-section {
        padding: 25px;
    }
    
    .course-section h2 {
        font-size: 26px;
    }
    
    .cta-button {
        display: block;
        margin: 10px auto;
        max-width: 300px;
    }
}

/* Espace entre la bannière et la galerie */
.course-gallery {
    padding: 30px 0 20px; /* 60px en haut, 40px en bas */
    background-color: #fff6ea;
}

/* Petit espace entre les colonnes quand elles se superposent */
.course-gallery .col-md-4 {
    padding-bottom: 20px;
}




/* ===== EVENT CATEGORIES SECTION ===== */

.event-categories-section {
    margin: 60px 0;
}

.categories-main-title {
    text-align: center;
    font-size: 36px;
    color: #243C69;
    font-weight: bold;
    margin-bottom: 50px;
    padding-bottom: 20px;
    border-bottom: 4px solid #e3aca8;
    display: inline-block;
    width: 100%;
}

.event-categories-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    margin: 40px 0;
}

.event-category-card {
    background: white;
    border-radius: 20px;
    padding: 40px;
    box-shadow: 0 8px 30px rgba(36, 60, 105, 0.15);
    transition: all 0.3s ease;
    border: 3px solid #f8ccc3;
    position: relative;
    overflow: hidden;
}

.event-category-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 6px;
    background: linear-gradient(90deg, #e3aca8 0%, #243C69 100%);
}

.event-category-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 12px 40px rgba(36, 60, 105, 0.25);
    border-color: #e3aca8;
}

.category-icon {
    font-size: 60px;
    text-align: center;
    margin-bottom: 20px;
}

.category-title {
    color: #243C69;
    font-size: 28px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 15px;
    padding: 0;
}

.category-price {
    font-size: 48px;
    font-weight: bold;
    color: #e3aca8;
    text-align: center;
    margin: 20px 0;
}

.category-capacity {
    text-align: center;
    font-size: 18px;
    color: #243C69;
    font-weight: 600;
    margin-bottom: 30px;
    padding-bottom: 20px;
    border-bottom: 2px dashed #f8ccc3;
}

.category-description {
    margin: 30px 0;
}

.category-description h4 {
    color: #243C69;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 15px;
    padding: 0;
}

.category-features {
    list-style: none;
    padding: 0;
    margin: 20px 0;
}

.category-features li {
    padding: 10px 0;
    font-size: 16px;
    color: #243C69;
    position: relative;
    padding-left: 30px;
}

.category-features li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #e3aca8;
    font-weight: bold;
    font-size: 20px;
}

.category-perfect-for {
    background: #fff6ea;
    padding: 20px;
    border-radius: 10px;
    margin-top: 25px;
}

.category-perfect-for strong {
    color: #e3aca8;
    font-size: 18px;
    display: block;
    margin-bottom: 10px;
}

.category-perfect-for p {
    color: #243C69;
    font-size: 15px;
    line-height: 24px;
    margin: 0;
}

.event-category-card .read_more {
    margin-top: 30px;
    width: 100%;
    max-width: 100%;
    padding: 15px 0;
    font-size: 18px;
}

/* Additional Options Section */
.additional-options {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
    margin-top: 25px;
}

.option-item {
    background: #fff6ea;
    padding: 20px;
    border-radius: 10px;
    border-left: 4px solid #e3aca8;
}

.option-item strong {
    color: #243C69;
    font-size: 17px;
    display: block;
    margin-bottom: 8px;
}

.option-item p {
    color: #243C69;
    font-size: 15px;
    line-height: 22px;
    margin: 0;
}

/* Responsive Design */
@media (max-width: 992px) {
    .event-categories-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .additional-options {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .event-category-card {
        padding: 25px;
    }
    
    .category-icon {
        font-size: 50px;
    }
    
    .category-title {
        font-size: 24px;
    }
    
    .category-price {
        font-size: 38px;
    }
    
    .categories-main-title {
        font-size: 28px;
    }
}

/* ===== STYLES POUR PAGE LOCATION COACHS ===== */

/* Pricing card pour coachs - centré */
.coach-pricing-section {
    margin: 60px 0;
}

.coach-pricing-card {
    background: white;
    border-radius: 20px;
    padding: 50px 40px;
    box-shadow: 0 8px 30px rgba(36, 60, 105, 0.15);
    border: 3px solid #f8ccc3;
    position: relative;
    overflow: hidden;
    max-width: 700px;
    margin: 40px auto;
    text-align: center;
}

.coach-pricing-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 6px;
    background: linear-gradient(90deg, #e3aca8 0%, #243C69 100%);
}

.coach-price-subtitle {
    font-size: 18px;
    color: #243C69;
    font-weight: 600;
    margin-top: -10px;
    margin-bottom: 30px;
}

/* Grille des horaires */
.coach-schedule-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 25px;
    margin: 30px 0;
}

.schedule-card {
    background: #fff6ea;
    padding: 25px;
    border-radius: 12px;
    border-left: 5px solid #e3aca8;
    transition: all 0.3s ease;
}

.schedule-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 6px 20px rgba(227, 172, 168, 0.3);
}

.schedule-card h4 {
    color: #243C69;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 15px;
    padding: 0;
    text-align: center;
}

.schedule-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.schedule-list li {
    color: #243C69;
    font-size: 16px;
    line-height: 28px;
    padding: 8px 0;
    border-bottom: 1px solid #f8ccc3;
}

.schedule-list li:last-child {
    border-bottom: none;
}

.schedule-list strong {
    color: #e3aca8;
    font-weight: 600;
}

/* Grille des activités */
.activities-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    justify-content: center;
    margin-top: 25px;
}

.activity-tag {
    background: linear-gradient(135deg, #e3aca8 0%, #f8ccc3 100%);
    color: white;
    padding: 12px 25px;
    border-radius: 25px;
    font-size: 15px;
    font-weight: 600;
    box-shadow: 0 3px 10px rgba(227, 172, 168, 0.3);
    transition: all 0.3s ease;
    cursor: default;
}

.activity-tag:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(227, 172, 168, 0.4);
}

/* Responsive pour page coachs */
@media (max-width: 768px) {
    .coach-pricing-card {
        padding: 30px 20px;
    }
    
    .coach-schedule-grid {
        grid-template-columns: 1fr;
    }
    
    .schedule-card {
        padding: 20px;
    }
    
    .activities-grid {
        gap: 10px;
    }
    
    .activity-tag {
        padding: 10px 20px;
        font-size: 14px;
    }
}

/* Style pour le séparateur du menu Prix */
.dropdown-divider {
   margin: 8px 0;
   border-top: 2px solid rgba(255, 255, 255, 0.4);
}

/* ===================================== */
/* BLOG SECTION STYLES */
/* ===================================== */

.blog-section {
   background-color: #fff6ea;
   padding: 60px 0 90px;
}

/* Categories Filter */
.blog-categories {
   display: flex;
   justify-content: center;
   flex-wrap: wrap;
   gap: 15px;
   margin: 40px 0 50px;
   padding: 0 20px;
}

.category-filter {
   background-color: white;
   color: #243C69;
   border: 2px solid #e3aca8;
   padding: 12px 30px;
   font-size: 16px;
   font-weight: 600;
   border-radius: 30px;
   cursor: pointer;
   transition: all 0.3s ease;
   text-transform: uppercase;
   letter-spacing: 0.5px;
}

.category-filter:hover {
   background-color: #f8ccc3;
   transform: translateY(-2px);
   box-shadow: 0 4px 12px rgba(227, 172, 168, 0.3);
}

.category-filter.active {
   background-color: #e3aca8;
   color: white;
   box-shadow: 0 4px 15px rgba(227, 172, 168, 0.4);
}

/* Blog Grid */
.blog-grid {
   display: grid;
   grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
   gap: 40px;
   margin: 40px 0;
}

/* Blog Card */
.blog-card {
   background: white;
   border-radius: 20px;
   overflow: hidden;
   box-shadow: 0 6px 25px rgba(36, 60, 105, 0.12);
   transition: all 0.4s ease;
   border: 2px solid transparent;
   display: flex;
   flex-direction: column;
}

.blog-card:hover {
   transform: translateY(-10px);
   box-shadow: 0 12px 35px rgba(36, 60, 105, 0.2);
   border-color: #e3aca8;
}

/* Blog Image */
.blog-image {
   position: relative;
   width: 100%;
   height: 250px;
   overflow: hidden;
}

.blog-image img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   transition: transform 0.4s ease;
}

.blog-card:hover .blog-image img {
   transform: scale(1.08);
}

.blog-category-badge {
   position: absolute;
   top: 20px;
   left: 20px;
   background: linear-gradient(135deg, #e3aca8 0%, #f8ccc3 100%);
   color: white;
   padding: 8px 20px;
   border-radius: 20px;
   font-size: 13px;
   font-weight: 700;
   text-transform: uppercase;
   letter-spacing: 0.5px;
   box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2);
}

/* Blog Content */
.blog-content {
   padding: 30px;
   display: flex;
   flex-direction: column;
   flex-grow: 1;
}

.blog-meta {
   display: flex;
   gap: 20px;
   margin-bottom: 15px;
   flex-wrap: wrap;
}

.blog-date,
.blog-author {
   color: #888;
   font-size: 14px;
   display: flex;
   align-items: center;
   gap: 6px;
}

.blog-date i,
.blog-author i {
   color: #e3aca8;
}

.blog-title {
   font-size: 22px;
   font-weight: bold;
   color: #243C69;
   margin-bottom: 15px;
   line-height: 1.4;
   padding: 0;
   transition: color 0.3s ease;
}

.blog-card:hover .blog-title {
   color: #e3aca8;
}

.blog-excerpt {
   color: #555;
   font-size: 15px;
   line-height: 1.7;
   margin-bottom: 20px;
   flex-grow: 1;
}

.blog-read-more {
   display: inline-flex;
   align-items: center;
   gap: 8px;
   color: #243C69;
   font-weight: 600;
   font-size: 15px;
   text-decoration: none;
   transition: all 0.3s ease;
   align-self: flex-start;
}

.blog-read-more:hover {
   color: #e3aca8;
   gap: 12px;
}

.blog-read-more i {
   transition: transform 0.3s ease;
}

.blog-read-more:hover i {
   transform: translateX(5px);
}

/* Newsletter Section */
.blog-newsletter {
   background: linear-gradient(135deg, #243C69 0%, #364A70 100%);
   border-radius: 20px;
   padding: 60px 40px;
   margin: 80px 0 40px;
   text-align: center;
   box-shadow: 0 8px 30px rgba(36, 60, 105, 0.2);
}

.newsletter-content h3 {
   color: #fff6ea;
   font-size: 36px;
   font-weight: bold;
   margin-bottom: 15px;
   padding: 0;
}

.newsletter-content p {
   color: #fff6ea;
   font-size: 18px;
   margin-bottom: 35px;
   max-width: 600px;
   margin-left: auto;
   margin-right: auto;
}

.newsletter-form {
   display: flex;
   max-width: 550px;
   margin: 0 auto;
   gap: 15px;
}

.newsletter-input {
   flex: 1;
   padding: 16px 25px;
   border: 2px solid rgba(255, 255, 255, 0.3);
   border-radius: 50px;
   font-size: 16px;
   background: rgba(255, 255, 255, 0.1);
   color: white;
   transition: all 0.3s ease;
}

.newsletter-input::placeholder {
   color: rgba(255, 255, 255, 0.7);
}

.newsletter-input:focus {
   outline: none;
   border-color: #e3aca8;
   background: rgba(255, 255, 255, 0.15);
}

.newsletter-btn {
   padding: 16px 40px;
   background-color: #e3aca8;
   color: white;
   border: none;
   border-radius: 50px;
   font-size: 16px;
   font-weight: 700;
   cursor: pointer;
   transition: all 0.3s ease;
   text-transform: uppercase;
   letter-spacing: 0.5px;
   white-space: nowrap;
}

.newsletter-btn:hover {
   background-color: #f8ccc3;
   transform: translateY(-2px);
   box-shadow: 0 6px 20px rgba(227, 172, 168, 0.4);
}

/* Responsive Design */
@media (max-width: 1200px) {
   .blog-grid {
      grid-template-columns: repeat(2, 1fr);
   }
}

@media (max-width: 768px) {
   .blog-section {
      padding: 40px 0 60px;
   }

   .blog-categories {
      margin: 30px 0;
   }

   .category-filter {
      padding: 10px 20px;
      font-size: 14px;
   }

   .blog-grid {
      grid-template-columns: 1fr;
      gap: 30px;
      padding: 0 15px;
   }

   .blog-image {
      height: 220px;
   }

   .blog-content {
      padding: 25px 20px;
   }

   .blog-title {
      font-size: 20px;
   }

   .blog-newsletter {
      padding: 40px 25px;
      margin: 50px 15px 30px;
   }

   .newsletter-content h3 {
      font-size: 28px;
   }

   .newsletter-content p {
      font-size: 16px;
   }

   .newsletter-form {
      flex-direction: column;
      gap: 12px;
   }

   .newsletter-btn {
      width: 100%;
   }
}

@media (max-width: 480px) {
   .blog-card {
      border-radius: 15px;
   }

   .blog-image {
      height: 200px;
   }

   .blog-title {
      font-size: 18px;
   }

   .blog-excerpt {
      font-size: 14px;
   }
}

/* ===================================== */
/* BLOG SECTION - PAGE LISTE */
/* ===================================== */

.blog-section {
   background-color: #fff6ea;
   padding: 60px 0 90px;
}

.blog-categories {
   display: flex;
   justify-content: center;
   flex-wrap: wrap;
   gap: 15px;
   margin: 40px 0 50px;
   padding: 0 20px;
}

.category-filter {
   background-color: white;
   color: #243C69;
   border: 2px solid #e3aca8;
   padding: 12px 30px;
   font-size: 16px;
   font-weight: 600;
   border-radius: 30px;
   cursor: pointer;
   transition: all 0.3s ease;
   text-transform: uppercase;
   letter-spacing: 0.5px;
}

.category-filter:hover {
   background-color: #f8ccc3;
   transform: translateY(-2px);
   box-shadow: 0 4px 12px rgba(227, 172, 168, 0.3);
}

.category-filter.active {
   background-color: #e3aca8;
   color: white;
   box-shadow: 0 4px 15px rgba(227, 172, 168, 0.4);
}

.blog-grid {
   display: grid;
   grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
   gap: 40px;
   margin: 40px 0;
}

.blog-card {
   background: white;
   border-radius: 20px;
   overflow: hidden;
   box-shadow: 0 6px 25px rgba(36, 60, 105, 0.12);
   transition: all 0.4s ease;
   border: 2px solid transparent;
   display: flex;
   flex-direction: column;
}

.blog-card:hover {
   transform: translateY(-10px);
   box-shadow: 0 12px 35px rgba(36, 60, 105, 0.2);
   border-color: #e3aca8;
}

.blog-image {
   position: relative;
   width: 100%;
   height: 250px;
   overflow: hidden;
}

.blog-image img {
   width: 100%;
   height: 100%;
   object-fit: cover;
   transition: transform 0.4s ease;
}

.blog-card:hover .blog-image img {
   transform: scale(1.08);
}

.blog-category-badge {
   position: absolute;
   top: 20px;
   left: 20px;
   background: linear-gradient(135deg, #e3aca8 0%, #f8ccc3 100%);
   color: white;
   padding: 8px 20px;
   border-radius: 20px;
   font-size: 13px;
   font-weight: 700;
   text-transform: uppercase;
   letter-spacing: 0.5px;
   box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2);
}

.blog-content {
   padding: 30px;
   display: flex;
   flex-direction: column;
   flex-grow: 1;
}

.blog-meta {
   display: flex;
   gap: 20px;
   margin-bottom: 15px;
   flex-wrap: wrap;
}

.blog-date, .blog-author {
   color: #888;
   font-size: 14px;
   display: flex;
   align-items: center;
   gap: 6px;
}

.blog-date i, .blog-author i {
   color: #e3aca8;
}

.blog-title {
   font-size: 22px;
   font-weight: bold;
   color: #243C69;
   margin-bottom: 15px;
   line-height: 1.4;
   padding: 0;
   transition: color 0.3s ease;
}

.blog-card:hover .blog-title {
   color: #e3aca8;
}

.blog-excerpt {
   color: #555;
   font-size: 15px;
   line-height: 1.7;
   margin-bottom: 20px;
   flex-grow: 1;
}

.blog-read-more {
   display: inline-flex;
   align-items: center;
   gap: 8px;
   color: #243C69;
   font-weight: 600;
   font-size: 15px;
   text-decoration: none;
   transition: all 0.3s ease;
   align-self: flex-start;
}

.blog-read-more:hover {
   color: #e3aca8;
   gap: 12px;
}

.blog-newsletter {
   background: linear-gradient(135deg, #243C69 0%, #364A70 100%);
   border-radius: 20px;
   padding: 60px 40px;
   margin: 80px 0 40px;
   text-align: center;
   box-shadow: 0 8px 30px rgba(36, 60, 105, 0.2);
}

.newsletter-content h3 {
   color: #fff6ea;
   font-size: 36px;
   font-weight: bold;
   margin-bottom: 15px;
   padding: 0;
}

.newsletter-content p {
   color: #fff6ea;
   font-size: 18px;
   margin-bottom: 35px;
   max-width: 600px;
   margin-left: auto;
   margin-right: auto;
}

.newsletter-form {
   display: flex;
   max-width: 550px;
   margin: 0 auto;
   gap: 15px;
}

.newsletter-input {
   flex: 1;
   padding: 16px 25px;
   border: 2px solid rgba(255, 255, 255, 0.3);
   border-radius: 50px;
   font-size: 16px;
   background: rgba(255, 255, 255, 0.1);
   color: white;
   transition: all 0.3s ease;
}

.newsletter-input::placeholder {
   color: rgba(255, 255, 255, 0.7);
}

.newsletter-input:focus {
   outline: none;
   border-color: #e3aca8;
   background: rgba(255, 255, 255, 0.15);
}

.newsletter-btn {
   padding: 16px 40px;
   background-color: #e3aca8;
   color: white;
   border: none;
   border-radius: 50px;
   font-size: 16px;
   font-weight: 700;
   cursor: pointer;
   transition: all 0.3s ease;
   text-transform: uppercase;
   letter-spacing: 0.5px;
   white-space: nowrap;
}

.newsletter-btn:hover {
   background-color: #f8ccc3;
   transform: translateY(-2px);
   box-shadow: 0 6px 20px rgba(227, 172, 168, 0.4);
}

/* ===================================== */
/* BLOG ARTICLE - PAGE INDIVIDUELLE */
/* ===================================== */

/* Hero avec image de fond */
.blog-article-hero {
   padding: 120px 0 80px;
   background-size: cover !important;
   background-position: center !important;
   position: relative;
   min-height: 500px;
   display: flex;
   align-items: center;
}

.blog-article-hero-content {
   text-align: center;
   color: white;
   position: relative;
   z-index: 2;
}

.article-category-badge-large {
   background: #e3aca8;
   color: white;
   padding: 10px 25px;
   border-radius: 25px;
   font-size: 14px;
   font-weight: 700;
   text-transform: uppercase;
   letter-spacing: 1px;
   display: inline-block;
   margin-bottom: 25px;
}

.blog-article-hero h1 {
   font-size: 42px;
   font-weight: bold;
   color: white;
   margin: 0 0 30px 0;
   line-height: 1.3;
   padding: 0;
   text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.article-meta-large {
   display: flex;
   justify-content: center;
   gap: 35px;
   flex-wrap: wrap;
   font-size: 16px;
   color: rgba(255, 255, 255, 0.95);
}

.article-meta-large span {
   display: flex;
   align-items: center;
   gap: 8px;
}

.article-meta-large i {
   color: #e3aca8;
   font-size: 18px;
}

/* Section de contenu */
.blog-article-section {
   background: #fff6ea;
   padding: 80px 0;
}

.blog-article-content {
   background: white;
   padding: 70px 80px;
   border-radius: 25px;
   box-shadow: 0 10px 40px rgba(36, 60, 105, 0.08);
}

.article-section {
   margin: 60px 0;
}

.article-section:first-child {
   margin-top: 0;
}

.article-intro-box {
   background: linear-gradient(135deg, #fff6ea 0%, #f8ccc3 50%);
   padding: 40px;
   border-radius: 20px;
   border-left: 6px solid #e3aca8;
   margin-bottom: 60px;
   box-shadow: 0 4px 15px rgba(227, 172, 168, 0.2);
}

.article-intro-box p {
   font-size: 18px;
   line-height: 1.8;
   color: #243C69;
   font-weight: 500;
   margin: 0;
}

.article-section h2 {
   color: #243C69;
   font-size: 32px;
   font-weight: bold;
   margin-bottom: 30px;
   padding-bottom: 20px;
   border-bottom: 4px solid #f8ccc3;
}

.article-section h3 {
   color: #e3aca8;
   font-size: 22px;
   font-weight: bold;
   margin: 40px 0 20px 0;
   padding: 0;
}

.article-section p {
   font-size: 17px;
   line-height: 1.8;
   color: #333;
   margin-bottom: 25px;
}

.article-section strong {
   color: #243C69;
   font-weight: 600;
}



/* Alert boxes */
.alert-box {
   display: flex;
   gap: 25px;
   padding: 35px;
   border-radius: 15px;
   margin: 40px 0;
   align-items: flex-start;
}

.alert-warning {
   background: #fff8e1;
   border-left: 6px solid #ffa726;
}

.alert-danger {
   background: #ffebee;
   border-left: 6px solid #ef5350;
}

.alert-icon {
   font-size: 42px;
   flex-shrink: 0;
   line-height: 1;
}

.alert-content h4 {
   color: #243C69;
   font-size: 22px;
   font-weight: bold;
   margin: 0 0 15px 0;
   padding: 0;
}

.alert-content ul {
   margin: 0;
   padding-left: 25px;
   list-style: disc;
}

.alert-content li {
   font-size: 17px;
   line-height: 1.8;
   margin-bottom: 10px;
   color: #333;
}

/* Steps cards */
.steps-container {
   margin: 50px 0;
}

.step-card {
   display: flex;
   gap: 30px;
   background: #fff6ea;
   padding: 40px;
   border-radius: 20px;
   margin-bottom: 30px;
   transition: all 0.3s ease;
   border: 2px solid transparent;
}

.step-card:hover {
   border-color: #e3aca8;
   transform: translateX(10px);
   box-shadow: 0 8px 25px rgba(227, 172, 168, 0.2);
}

.step-number {
   background: linear-gradient(135deg, #243C69 0%, #364A70 100%);
   color: white;
   width: 70px;
   height: 70px;
   border-radius: 50%;
   display: flex;
   align-items: center;
   justify-content: center;
   font-size: 32px;
   font-weight: bold;
   flex-shrink: 0;
   box-shadow: 0 4px 15px rgba(36, 60, 105, 0.3);
}

.step-content h3 {
   color: #243C69;
   font-size: 20px;
   font-weight: bold;
   margin: 0 0 15px 0;
}

.step-content p {
   margin-bottom: 12px;
   font-size: 16px;
   line-height: 1.7;
}

/* Timeline moderne */
.timeline-modern {
   position: relative;
   margin: 50px 0;
}

.timeline-card {
   background: white;
   padding: 35px;
   border-radius: 20px;
   margin-bottom: 30px;
   border-left: 6px solid #e3aca8;
   box-shadow: 0 6px 20px rgba(36, 60, 105, 0.1);
   transition: all 0.3s ease;
}

.timeline-card:hover {
   transform: translateY(-5px);
   box-shadow: 0 12px 30px rgba(36, 60, 105, 0.15);
}

.timeline-period {
   background: linear-gradient(135deg, #e3aca8 0%, #f8ccc3 100%);
   color: white;
   padding: 8px 20px;
   border-radius: 20px;
   font-size: 15px;
   font-weight: bold;
   display: inline-block;
   margin-bottom: 15px;
   text-transform: uppercase;
   letter-spacing: 0.5px;
}

.timeline-card h3 {
   color: #243C69;
   font-size: 20px;
   font-weight: bold;
   margin: 15px 0;
}

.timeline-card p {
   margin: 0;
   font-size: 16px;
   line-height: 1.7;
   color: #555;
}

/* Activities grid moderne */
.activities-modern-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
   gap: 30px;
   margin: 50px 0;
}

.activity-modern-card {
   background: white;
   padding: 40px 30px;
   border-radius: 20px;
   text-align: center;
   border: 3px solid #f8ccc3;
   transition: all 0.4s ease;
}

.activity-modern-card:hover {
   transform: translateY(-10px);
   border-color: #e3aca8;
   box-shadow: 0 15px 35px rgba(227, 172, 168, 0.25);
}

.activity-modern-icon {
   font-size: 64px;
   margin-bottom: 20px;
}

.activity-modern-card h3 {
   color: #243C69;
   font-size: 22px;
   font-weight: bold;
   margin: 20px 0 15px 0;
}

.activity-modern-card p {
   color: #555;
   font-size: 16px;
   line-height: 1.7;
   margin: 0;
}

/* Tips moderne */
.tips-modern-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
   gap: 25px;
   margin: 50px 0;
}

.tip-modern-card {
   background: white;
   padding: 35px;
   border-radius: 20px;
   border-top: 5px solid #e3aca8;
   box-shadow: 0 6px 20px rgba(36, 60, 105, 0.1);
   transition: all 0.3s ease;
}

.tip-modern-card:hover {
   transform: translateY(-8px);
   box-shadow: 0 12px 30px rgba(36, 60, 105, 0.15);
}

.tip-modern-number {
   background: linear-gradient(135deg, #243C69 0%, #364A70 100%);
   color: white;
   width: 50px;
   height: 50px;
   border-radius: 50%;
   display: flex;
   align-items: center;
   justify-content: center;
   font-size: 24px;
   font-weight: bold;
   margin-bottom: 20px;
}

.tip-modern-card h3 {
   color: #243C69;
   font-size: 20px;
   font-weight: bold;
   margin: 15px 0;
}

.tip-modern-card p {
   color: #555;
   font-size: 16px;
   line-height: 1.7;
   margin: 0;
}

/* CTA moderne */
.cta-modern-box {
   background: linear-gradient(135deg, #243C69 0%, #364A70 100%);
   padding: 70px 60px;
   border-radius: 25px;
   text-align: center;
   margin: 60px 0;
   box-shadow: 0 15px 40px rgba(36, 60, 105, 0.3);
}

.cta-modern-content h2 {
   color: #fff6ea;
   font-size: 34px;
   font-weight: bold;
   margin-bottom: 20px;
   padding: 0;
   border: none;
}

.cta-modern-content p {
   color: rgba(255, 255, 255, 0.95);
   font-size: 18px;
   margin-bottom: 40px;
   max-width: 700px;
   margin-left: auto;
   margin-right: auto;
   line-height: 1.8;
}

.cta-modern-button {
   background: #e3aca8;
   color: white;
   padding: 20px 60px;
   font-size: 20px;
   font-weight: bold;
   border-radius: 50px;
   text-decoration: none;
   display: inline-block;
   transition: all 0.3s ease;
   text-transform: uppercase;
   letter-spacing: 1px;
   box-shadow: 0 8px 25px rgba(227, 172, 168, 0.4);
}

.cta-modern-button:hover {
   background: #f8ccc3;
   transform: translateY(-5px);
   box-shadow: 0 12px 35px rgba(227, 172, 168, 0.5);
   color: white;
   text-decoration: none;
}

/* Author moderne */
.author-modern-box {
   display: flex;
   gap: 30px;
   background: #fff6ea;
   padding: 45px;
   border-radius: 20px;
   margin: 60px 0;
   border-left: 6px solid #e3aca8;
}

.author-modern-avatar {
   width: 120px;
   height: 120px;
   border-radius: 50%;
   background: linear-gradient(135deg, #e3aca8 0%, #f8ccc3 100%);
   display: flex;
   align-items: center;
   justify-content: center;
   font-size: 56px;
   font-weight: bold;
   color: white;
   flex-shrink: 0;
   box-shadow: 0 6px 20px rgba(227, 172, 168, 0.3);
}

.author-modern-info h3 {
   color: #243C69;
   font-size: 24px;
   font-weight: bold;
   margin: 0 0 15px 0;
}

.author-modern-info p {
   color: #555;
   font-size: 16px;
   line-height: 1.7;
   margin: 0;
}

/* Share moderne */
.share-modern-box {
   text-align: center;
   padding: 50px;
   background: #fff6ea;
   border-radius: 20px;
   margin: 60px 0;
}

.share-modern-box h3 {
   color: #243C69;
   font-size: 26px;
   font-weight: bold;
   margin-bottom: 30px;
   padding: 0;
}

.share-modern-buttons {
   display: flex;
   justify-content: center;
   gap: 20px;
   flex-wrap: wrap;
}

.share-modern-btn {
   padding: 15px 35px;
   border-radius: 50px;
   text-decoration: none;
   color: white;
   font-weight: 600;
   font-size: 16px;
   transition: all 0.3s ease;
   display: inline-flex;
   align-items: center;
   gap: 10px;
}

.share-modern-btn:hover {
   transform: translateY(-5px);
   box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
   text-decoration: none;
   color: white;
}

.share-facebook {
   background: #1877f2;
}

.share-instagram {
   background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}

.share-email {
   background: #243C69;
}

/* Related moderne */
.related-modern-section {
   margin-top: 80px;
   padding-top: 60px;
   border-top: 4px solid #f8ccc3;
}

.related-modern-section h2 {
   color: #243C69;
   font-size: 32px;
   font-weight: bold;
   text-align: center;
   margin-bottom: 50px;
   padding: 0;
   border: none;
}

.related-modern-grid {
   display: grid;
   grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
   gap: 35px;
}

.related-modern-card {
   background: white;
   border-radius: 20px;
   overflow: hidden;
   box-shadow: 0 6px 20px rgba(36, 60, 105, 0.1);
   transition: all 0.4s ease;
   text-decoration: none;
   display: block;
}

.related-modern-card:hover {
   transform: translateY(-12px);
   box-shadow: 0 15px 35px rgba(36, 60, 105, 0.2);
   text-decoration: none;
}

.related-modern-card img {
   width: 100%;
   height: 220px;
   object-fit: cover;
}

.related-modern-card h3 {
   color: #243C69;
   font-size: 20px;
   font-weight: 600;
   padding: 25px;
   margin: 0;
   line-height: 1.5;
}

.related-modern-card:hover h3 {
   color: #e3aca8;
}

/* Responsive */
@media (max-width: 992px) {
   .blog-article-hero {
      padding: 80px 0 60px;
      min-height: 400px;
   }

   .blog-article-hero h1 {
      font-size: 42px;
   }

   .blog-article-content {
      padding: 50px 40px;
   }

   .step-card {
      flex-direction: column;
      align-items: center;
      text-align: center;
   }

   .author-modern-box {
      flex-direction: column;
      align-items: center;
      text-align: center;
   }
}

@media (max-width: 768px) {
   .blog-grid {
      grid-template-columns: 1fr;
   }

   .blog-article-hero {
      padding: 60px 0 40px;
      min-height: 350px;
   }

   .blog-article-hero h1 {
      font-size: 32px;
   }

   .blog-article-content {
      padding: 40px 25px;
   }

   .article-intro-box {
      padding: 30px 25px;
   }

   .article-intro-box p {
      font-size: 18px;
   }

   .article-section h2 {
      font-size: 30px;
   }

   .article-section h3 {
      font-size: 22px;
   }

   .article-section p {
      font-size: 17px;
   }

   .cta-modern-box {
      padding: 50px 30px;
   }

   .cta-modern-content h2 {
      font-size: 32px;
   }

   .newsletter-form {
      flex-direction: column;
   }

   .share-modern-buttons {
      flex-direction: column;
   }

   .share-modern-btn {
      width: 100%;
      justify-content: center;
   }
}

/* ========================================= */
/* CSS COMPLET POUR .info-box */
/* Copiez TOUT ce code et remplacez TOUTES les définitions de .info-box dans style.css */
/* ========================================= */

/* ===== 1. INFO-BOX POUR PAGE LOCATION (pricing-location.html) ===== */

.pricing_main .info-box {
    background: white;
    padding: 40px;
    margin: 30px 0;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(36, 60, 105, 0.1);
}

.pricing_main .info-box h3 {
    color: #243C69;
    font-size: 28px;
    font-weight: bold;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 3px solid #e3aca8;
}

.pricing_main .info-box p {
    font-size: 16px;
    line-height: 28px;
    color: #243C69;
    margin-bottom: 15px;
    font-family: 'Open Sans', sans-serif;
}

.pricing_main .info-box strong {
    color: #243C69;
    font-weight: 700;
}

/* Features grid pour page location */
.pricing_main .features-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin: 30px 0;
}

.pricing_main .feature-card {
    background: #fff6ea;
    padding: 25px;
    border-radius: 8px;
    border-left: 4px solid #e3aca8;
    transition: all 0.3s ease;
}

.pricing_main .feature-card:hover {
    transform: translateX(5px);
    box-shadow: 0 4px 12px rgba(227, 172, 168, 0.3);
}

.pricing_main .feature-card h4 {
    color: #243C69;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 10px;
    padding: 0;
}

.pricing_main .feature-card p {
    color: #243C69;
    font-size: 15px;
    line-height: 24px;
}

/* Additional options pour page location */
.pricing_main .additional-options {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
    margin-top: 25px;
}

.pricing_main .option-item {
    background: #fff6ea;
    padding: 20px;
    border-radius: 10px;
    border-left: 4px solid #e3aca8;
}

.pricing_main .option-item strong {
    color: #243C69;
    font-size: 17px;
    display: block;
    margin-bottom: 8px;
}

.pricing_main .option-item p {
    color: #243C69;
    font-size: 15px;
    line-height: 22px;
    margin: 0;
}

/* CTA Section pour page location */
.pricing_main .cta-section {
    background: white;
    padding: 50px 40px;
    text-align: center;
    margin: 40px 0;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(36, 60, 105, 0.1);
}


/* ===== 2. INFO-BOX POUR PAGES DE COURS (cours-*.html) ===== */

.course-content .info-box,
.course-section .info-box {
    background: #fff6ea;
    padding: 25px 30px;
    border-left: 5px solid #e3aca8;
    border-radius: 10px;
    margin: 25px 0;
    box-shadow: 0 2px 8px rgba(36, 60, 105, 0.08);
}

.course-content .info-box strong,
.course-section .info-box strong {
    color: #243C69;
    font-weight: 700;
    display: inline-block;
    margin-right: 5px;
}

.course-content .info-box p,
.course-section .info-box p {
    margin: 10px 0;
    line-height: 1.8;
    color: #243C69;
    font-size: 16px;
}

.course-content .info-box br,
.course-section .info-box br {
    display: block;
    content: "";
    margin: 8px 0;
}


/* ===== 3. INFO-BOX POUR ARTICLES DE BLOG ===== */

.blog-article-content .info-box {
    display: flex;
    gap: 25px;
    padding: 35px;
    border-radius: 15px;
    margin: 40px 0;
    align-items: flex-start;
}

.blog-article-content .info-box-blue {
    background: linear-gradient(135deg, #e8f4f8 0%, #d1e7f0 100%);
    border-left: 6px solid #4A90A4;
}

.blog-article-content .info-box-icon {
    font-size: 42px;
    flex-shrink: 0;
    line-height: 1;
}

.blog-article-content .info-box-content h4 {
    color: #243C69;
    font-size: 20px;
    font-weight: bold;
    margin: 0 0 12px 0;
    padding: 0;
}

.blog-article-content .info-box-content p {
    margin: 0;
    font-size: 16px;
    line-height: 1.7;
    color: #333;
}


/* ===== 4. INFO-BOX INTRO POUR ARTICLES (style encadré rose) ===== */

.article-intro-box {
    background: linear-gradient(135deg, #fff6ea 0%, #f8ccc3 50%);
    padding: 40px;
    border-radius: 20px;
    border-left: 6px solid #e3aca8;
    margin-bottom: 60px;
    box-shadow: 0 4px 15px rgba(227, 172, 168, 0.2);
}

.article-intro-box p {
    font-size: 18px;
    line-height: 1.8;
    color: #243C69;
    font-weight: 500;
    margin: 0;
}


/* ===== 5. RESPONSIVE ===== */

@media (max-width: 768px) {
    .pricing_main .info-box {
        padding: 25px;
    }

    .pricing_main .features-grid {
        grid-template-columns: 1fr;
    }

    .pricing_main .additional-options {
        grid-template-columns: 1fr;
    }

    .pricing_main .cta-section {
        padding: 30px 20px;
    }
    
    .course-content .info-box,
    .course-section .info-box {
        padding: 20px;
    }
    
    .blog-article-content .info-box {
        flex-direction: column;
        padding: 25px;
    }
}

@media (max-width: 480px) {
    .pricing_main .info-box h3 {
        font-size: 24px;
    }
    
    .pricing_main .feature-card {
        padding: 20px;
    }
}

/* ===================================== */
/* STYLE POUR LIENS ACTIFS DU MENU */
/* ===================================== */

/* Lien dropdown parent actif (Prix, Pour qui?, etc.) */
.navigation.navbar-dark .navbar-nav .nav-item.dropdown.active > .nav-link {
     background: #243C69 !important;
     border-radius: 6px !important;
     color: #fff !important;
}

/* Lien simple actif (À propos, Horaires, etc.) */
.navigation.navbar-dark .navbar-nav .nav-item.active > .nav-link:not(.dropdown-toggle) {
     background: #243C69 !important;
     border-radius: 6px !important;
     color: #fff !important;
}

/* Item dropdown actif (dans le sous-menu) */
.dropdown-item.active {
     background-color: #243C69 !important;
     color: #fff !important;
     font-weight: bold !important;
}

/* ===================================== */
/* PAGE COURS - FEMMES SANS ENFANT       */
/* Ajouter à la fin de style.css         */
/* ===================================== */

/* Badge "No kid" dans le tableau horaires */
.badge-nokid {
   display: inline-block;
   background: #243C69;
   color: #fff;
   font-size: .68rem;
   font-weight: 700;
   padding: 2px 9px;
   border-radius: 20px;
   margin-left: 6px;
   vertical-align: middle;
   white-space: nowrap;
}

/* =====================================================
   pricing-redesign.css
   Styles spécifiques à la page pricing-avecgardienne
   ===================================================== */

/* ===== HERO ===== */

.pricing-hero {
  background: #243C69;
  padding: 50px 0 40px;
  text-align: center;
}

.pricing-hero h2 {
  color: #f8ccc3;
  font-size: 42px;
  font-weight: 800;
  letter-spacing: -0.5px;
  padding: 0;
  margin: 0;
}

/* ===== BANNIÈRE D'ESSAI ===== */

.pricing-intro-banner {
  background: linear-gradient(135deg, #f8ccc3 0%, #e3aca8 100%);
  padding: 40px 0;
  text-align: center;
}

.pricing-intro-banner .trial-cta {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  background: white;
  border-radius: 16px;
  padding: 22px 36px;
  box-shadow: 0 8px 30px rgba(36, 60, 105, 0.15);
  flex-wrap: wrap;
  justify-content: center;
}

.pricing-intro-banner .trial-label {
  font-size: 20px;
  font-weight: 700;
  color: #243C69;
}

.pricing-intro-banner .trial-label span {
  color: #e3aca8;
}

.btn-trial {
  background: #243C69;
  color: white;
  font-size: 16px;
  font-weight: 700;
  padding: 13px 32px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  white-space: nowrap;
  display: inline-block;
}

.btn-trial:hover {
  background: #e3aca8;
  color: white;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(227, 172, 168, 0.4);
}

/* ===== BANDE D'INFO ===== */

.pricing-info-row {
  background: #fff6ea;
  padding: 30px 0;
  border-bottom: 2px solid #f8ccc3;
}

.info-pill {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 0 20px;
}

.info-pill-icon {
  width: 42px;
  height: 42px;
  background: #e3aca8;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: white;
  font-size: 18px;
}

.info-pill-text h5 {
  font-size: 14px;
  font-weight: 700;
  color: #243C69;
  margin: 0 0 3px 0;
  padding: 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.info-pill-text p {
  font-size: 13px;
  color: #555;
  margin: 0;
  line-height: 1.5;
}

/* ===== WRAPPER PRINCIPAL ===== */

.pricing-page {
  background: #f5f0eb;
  padding: 60px 0 80px;
}

/* ===== TITRES DE SECTION ===== */

.section-label {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 32px;
}

.section-label h2 {
  font-size: 28px;
  font-weight: 800;
  color: #243C69;
  padding: 0;
  margin: 0;
}

.section-label::after {
  content: '';
  flex: 1;
  height: 2px;
  background: linear-gradient(to right, #e3aca8, transparent);
}

/* ===== CARTES À LA CARTE ===== */

.carte-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 60px;
}

.carte-card {
  background: white;
  border-radius: 20px;
  padding: 32px 24px;
  text-align: center;
  border: 2px solid #f0e8e0;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.carte-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, #e3aca8, #f8ccc3);
}

.carte-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(36, 60, 105, 0.12);
  border-color: #e3aca8;
}

.carte-card .nb-cours {
  font-size: 40px;
  font-weight: 800;
  color: #243C69;
  line-height: 1;
  margin-bottom: 4px;
}

.carte-card .nb-label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #999;
  font-weight: 600;
  margin-bottom: 20px;
}

.carte-card .prix-total {
  font-size: 35px;
  font-weight: 800;
  color: #e3aca8;
  line-height: 1;
}

.carte-card .prix-total sup {
  font-size: 22px;
  font-weight: 600;
  vertical-align: top;
  margin-top: 8px;
}

.carte-card .prix-unitaire {
  font-size: 20px;
  color: #888;
  margin: 8px 0 24px;
  font-weight: 500;
}

.btn-subscribe {
  display: inline-block;
  background: #243C69;
  color: white;
  font-size: 14px;
  font-weight: 600;
  padding: 11px 28px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  width: 100%;
}

.btn-subscribe:hover {
  background: #e3aca8;
  color: white;
  text-decoration: none;
  transform: translateY(-2px);
}

.carte-grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 991px) {
  .carte-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 576px) {
  .carte-grid-4 {
    grid-template-columns: 1fr;
  }
}

/* ===== BLOCS ABONNEMENTS ===== */

.abonnement-plans-4 {
  grid-template-columns: repeat(4, 1fr) !important;
}

@media (max-width: 991px) {
  .abonnement-plans-4 {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 576px) {
  .abonnement-plans-4 {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 991px) {
  .abonnement-plans-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 576px) {
  .abonnement-plans-4 {
    grid-template-columns: 1fr;
  }
}
.abonnement-block {
  background: white;
  border-radius: 24px;
  overflow: hidden;
  margin-bottom: 28px;
  box-shadow: 0 4px 20px rgba(36, 60, 105, 0.07);
  border: 2px solid #f0e8e0;
}

.abonnement-header {
  background: #243C69;
  padding: 18px 32px;
  display: flex;
  align-items: center;
  gap: 14px;
}

.abonnement-header h3 {
  color: white;
  font-size: 20px;
  font-weight: 700;
  margin: 0;
  padding: 0;
}

.abonnement-header .duree-badge {
  background: #e3aca8;
  color: white;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.abonnement-plans {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.plan-col {
  padding: 28px 24px;
  border-right: 1px solid #f0e8e0;
  text-align: center;
}

.plan-col:last-child {
  border-right: none;
}

.plan-col.featured {
  background: #fff6ea;
  position: relative;
}

.plan-col.featured::before {
  content: 'Populaire';
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: #e3aca8;
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 16px;
  border-radius: 0 0 12px 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.plan-frequency {
  font-size: 13px;
  font-weight: 700;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 16px;
}

.plan-price-monthly {
  font-size: 30px;
  font-weight: 800;
  color: #243C69;
  line-height: 1;
}

.plan-price-monthly sup {
  font-size: 18px;
  font-weight: 600;
  vertical-align: top;
  margin-top: 6px;
}

.plan-price-monthly .per-month {
  font-size: 14px;
  font-weight: 500;
  color: #999;
}

.plan-unit-cost {
  font-size: 30px;
  color: #888;
  margin: 8px 0 6px;
}

.plan-lump-sum {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #f0e8e0;
  border-radius: 20px;
  padding: 5px 14px;
  font-size: 13px;
  font-weight: 600;
  color: #243C69;
  margin: 8px 0 16px;
}

.plan-lump-sum .lump-price {
  color: #e3aca8;
  font-weight: 800;
}

.plan-buttons {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}

.btn-plan-once {
  display: inline-block;
  background: #e3aca8;
  color: white;
  font-size: 12px;
  font-weight: 600;
  padding: 10px 16px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  text-align: center;
}

.btn-plan-once:hover {
  background: #243C69;
  color: white;
  text-decoration: none;
}

.btn-plan-monthly {
  display: inline-block;
  background: transparent;
  color: #243C69;
  font-size: 12px;
  font-weight: 600;
  padding: 9px 16px;
  border-radius: 50px;
  border: 2px solid #243C69;
  text-decoration: none;
  transition: all 0.3s ease;
  text-align: center;
}

.btn-plan-monthly:hover {
  background: #243C69;
  color: white;
  text-decoration: none;
}

/* ===== CARTE CADEAU ===== */

.gift-card-section {
  background: linear-gradient(135deg, #243C69 0%, #364A70 100%);
  border-radius: 20px;
  padding: 36px 40px;
  display: flex;
  align-items: center;
  gap: 30px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.gift-icon {
  font-size: 52px;
  flex-shrink: 0;
}

.gift-text h3 {
  color: #f8ccc3;
  font-size: 22px;
  font-weight: 700;
  padding: 0;
  margin: 0 0 8px 0;
}

.gift-text p {
  color: rgba(255, 255, 255, 0.85);
  font-size: 14px;
  line-height: 1.7;
  margin: 0;
}

.btn-gift {
  margin-left: auto;
  background: #e3aca8;
  color: white;
  font-size: 15px;
  font-weight: 700;
  padding: 14px 32px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  white-space: nowrap;
  flex-shrink: 0;
}

.btn-gift:hover {
  background: #f8ccc3;
  color: #243C69;
  text-decoration: none;
  transform: translateY(-2px);
}

/* ===== NOTE TAXES ===== */

.tax-note {
  text-align: center;
  color: #999;
  font-size: 13px;
  font-style: italic;
  margin-top: 30px;
}

/* ===== RESPONSIVE ===== */

@media (max-width: 991px) {
  .abonnement-plans {
    grid-template-columns: 1fr;
  }

  .plan-col {
    border-right: none;
    border-bottom: 1px solid #f0e8e0;
  }

  .plan-col:last-child {
    border-bottom: none;
  }
}

@media (max-width: 768px) {
  .carte-grid {
    grid-template-columns: 1fr;
  }

  .pricing-hero h2 {
    font-size: 30px;
  }

  .gift-card-section {
    flex-direction: column;
    text-align: center;
    padding: 28px 24px;
  }

  .btn-gift {
    margin: 0 auto;
  }

  .info-pill {
    padding: 10px 15px;
  }
}

/* ===== RESPONSIVE RECOMPENSES ===== */

.img-float {
    float: right;
    max-width: 250px;
    margin-left: 20px;
    margin-bottom: 20px;
}
@media (max-width: 768px) {
    .img-float {
        float: right;
        max-width: 45%;
        margin-left: 15px;
        margin-bottom: 15px;
    }
}



      /* ===== QUICK NAV (style partagé avec pricing-prive) ===== */
      .quick-nav {
         background: #fff6ea;
         padding: 20px 0;
         border-bottom: 1px solid #e0e0e0;
      }
      .quick-nav .category-buttons {
         display: flex;
         justify-content: center;
         flex-wrap: wrap;
         gap: 12px;
      }
      .quick-nav .category-btn {
         padding: 11px 24px;
         font-size: 15px;
         min-width: auto;
      }
   