@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Open+Sans');/*font-family: 'Open Sans', sans-serif;*/
@import url('https://fonts.googleapis.com/css?family=Open+Sans+Condensed:300');/*font-family: 'Open Sans Condensed', sans-serif;*/
/*Font bouton custom*/
@import url("https://fonts.googleapis.com/css?family=Roboto:900");

@import url('https://fonts.googleapis.com/css2?family=Fjalla+One&display=swap');/* font-family: "Fjalla One", sans-serif;*/

.banner-image {
background-image: url('../charte/banner-img-1-1920.webp');
background-size: cover
}



.banner-slider2 {
background-image: url('../charte/banner-img-2-1920.webp');
background-size: cover
}

.banner-slider3 {
background-image: url('../charte/banner-img-3-1920.webp');
background-size: cover
}

.banner-slider4 {
background-image: url('../charte/banner-img-4-1920.webp');
background-size: cover
}

.banner-slider5 {
    background-image: url('../charte/banner-img-5-1920.webp');
    background-size: cover
}

@media (max-width:960px) {
.banner-image {
background-image: url('../charte/banner-img-1-960.webp');
background-size: cover
}
.banner-slider2 {
background-image: url('../charte/banner-img-2-960.webp');
background-size: cover
}
.banner-slider3 {
background-image: url('../charte/banner-img-3-960.webp');
background-size: cover
}
.banner-slider4 {
background-image: url('../charte/banner-img-4-960.webp');
background-size: cover
}
.banner-slider4 {
 background-image: url('../charte/banner-img-5-960.webp');
 background-size: cover }
}


@media (max-width:720px) {
.banner-image {
background-image: url('../charte/banner-img-1-720.webp');
background-size: 100%;
background-repeat: no-repeat; margin-top:113px
}
.banner-slider2 {
background-image: url('../charte/banner-img-2-720.webp');
background-size: 100%;
background-repeat: no-repeat; margin-top:176px
}
.banner-slider3 {
background-image: url('../charte/banner-img-3-720.webp');
background-size: 100%;
background-repeat: no-repeat; margin-top:176px
}
.banner-slider4 {
background-image: url('../charte/banner-img-4-720.webp');
background-size: 100%;
background-repeat: no-repeat; margin-top:176px
}
.banner-slider5 {
background-image: url('../charte/banner-img-5-720.webp');
background-size: 100%;
background-repeat: no-repeat; margin-top:176px
}
.vh-100 {
    height: 33vh !important;
}

.carousel-control-prev {
    height: 70vh !important;
}

.carousel-control-next {
    height: 70vh !important;
}

}

.carousel-item  p {
    color:#fff; font-family: "Fjalla One", sans-serif; font-size:20px; text-shadow:0px 0px 20px rgba(133,208,240,0.4);
}
.carousel-item  p a {
color:#fff; font-weight: bold; font-family: "Fjalla One", sans-serif;
}



.banner-image2 {
        background-image: url('../charte/bandeau-header.webp');
        background-size: cover
      }

.heighter {
    height: 40vh !important;
}


/* HEADER */
#header {   background: #fff; width: 100%; height: 400px; background-size:100%;}
#logo {text-align:left; margin-top:40px}
#slogan p {font-size:24px; font-family: "Fjalla One", sans-serif; text-align:right; margin-top:40px; font-weight: bold; color:#000; line-height: 1.2em}
#slogan p a {color:#000}
#slogan p a:hover {text-decoration: none}
#slogan .icone {text-align: right; padding:5px 0px}
#slogan .icone a {color:#fff}
#slogan .icone a:hover {text-decoration: none; color:#000}
#slogan .langue p  {text-align: right; font-size: 14px; margin-top: 10px}


@media (max-width: 992px) {
#header { background:#fff; width: 100%; height: auto}
#logo {text-align:center}
#slogan p {font-size:20px;text-align:center; margin-top:10px}
#slogan p a{}
#slogan .icone {text-align: center; padding-top: 15px}
#slogan .langue p  {text-align: center; font-size: 14px; margin-top: 10px}
}
/*HEADER*/



/*MENU*/
.bg-light {
background-color: #000 !important;
}

.navbar-light {background: rgba(133,208,240,0.8)}
.bg-dark {background:#85d0f0!important}


.nav a  {color:#000}
.nav a:hover  {color:#000}

.navbar-nav { margin: 0 auto}

@media (max-width:992px) {
.navbar-nav {margin: 20px 0px;}
.bg-light {background-color: #000 !important;}
.navbar {background: #85d0f0;}
}

.navbar-nav.active { display: block}
.navbar-light .navbar-nav .active > .nav-link, .navbar-light .navbar-nav .nav-link.active, .navbar-light .navbar-nav .nav-link.show, .navbar-light .navbar-nav .show > .nav-link {
color: #000;
background-color:  #fff;
}


.navbar-light .navbar-nav .nav-link {
    color: #fff;
    font-family: "Fjalla One", sans-serif; font-size:18px;  text-align: center;
}


.navbar-light .navbar-nav .nav-link:hover {
color: #000;
background-color:  #fff;
}

.navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 1rem;
    padding-left: 1rem;
}


.navbar-light .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}


/*Custom ouverture menu mobile*/
@media (max-width: 992px) {
.navbar-collapse {
        position: absolute;
        top: 110px;
        left: 0;
        padding-left: 15px;
        padding-right: 15px;
        padding-bottom: 15px;
        width: 100%;
    }
.navbar-collapse.collapsing {
        height: auto;
        -webkit-transition: left 0.3s ease;
        -o-transition: left 0.3s ease;
        -moz-transition: left 0.3s ease;
        transition: left 0.3s ease;
        left: -100%;
    }
.navbar-collapse.show {
        left: 0;
        -webkit-transition: left 0.3s ease-in;
        -o-transition: left 0.3s ease-in;
        -moz-transition: left 0.3s ease-in;
        transition: left 0.3s ease-in;
		background-color:#85d0f0 ;height: 900px;
		text-align: center;
    }
 }


/*MENU*/



/*INTEGRATION*/
a, a:hover {color:#000; text-decoration: none}

#section1 {background: none}
#section1 h1 {color:#333333; line-height: 1.4em}
#section1 h2, h3, h4, h5 {color:#333333; line-height: 1.4em}
#section1 p {color:#000;}

#section2 {background:#c7eeff}
#section2 h1 {color:#fff; line-height: 1.4em}
#section2 h2{color:#009de0; line-height: 1.4em}
#section2 h3 {color:#fff; line-height: 1.4em}
#section2 h4 {color:#fff; line-height: 1.4em}
#section2 h5 {color:#fff; line-height: 1.4em}
#section2 p {color:#fff;}

#section3 {background: none}
#section3 h1 {color:#333333; line-height: 1.4em}
#section3 h2, h3, h4 {color:#333333; line-height: 1.4em}
#section3 h5 {color:#333333 !important; line-height: 1.4em}
#section3 p {color:#000;}

#section4 {background: none}
#section4 h1 {color:#333333; line-height: 1.4em}
#section4 h2, h3, h4, h5 {color:#333333; line-height: 1.4em}
#section4 p {color:#000;}

#section5 {background: #041015}
#section5 h1 {color:#fff; line-height: 1.4em}
#section5 h2 {color:#fff; line-height: 1.4em}
#section5 h3 {color:#fff !important; line-height: 1.4em}
#section5 h4 {color:#fff !important; line-height: 1.4em}
#section5 h5 {color:#fff !important; line-height: 1.4em}
#section5 p {color:#fff;}

#section-parallax img {padding-top:200px;}
#section-parallax h2 { color:#000; text-align: center }

@media (max-width: 992px) {
    #section-parallax h2 {padding-top:50px}
    #section-parallax img {padding-top:70px;}
}

.parallax {
    /* The image used */
    background-image: url("../../../assets/theme5/charte/img-parallax.webp");
    /* Set a specific height */
    height:600px;
    /* Create the parallax scrolling effect */
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
@media only screen and (max-device-width: 1366px) {
    .parallax {
        background-attachment: scroll;
        height:300px;
    }
}

/*boutons custom bootstrap*/
.btn-custom {
	color: #fff;
    background-color: #85d0f0;
    border-color: #85d0f0;
}
.btn-custom:hover, .btn-custom:focus, .btn-custom:active, .btn-custom.active, .open>.dropdown-toggle.btn-custom {
    color: #fff;
    background-color: #85d0f0;
    border-color: #85d0f0; /*set the color you want here*/
}
/*fin boutons custom bootstrap*/


/*boutons custom bootstrap*/
.button {
  flex: 1 1 auto;
  margin: 10px;
  padding: 20px;
  border: 2px solid #fff;
  text-align: center;
  text-transform: uppercase;
  position: relative;
  overflow: hidden;
  transition: 0.3s; color:#fff; background:none
}
.button:after {
  position: absolute;
  transition: 0.3s;
  content: "";
  width: 0;
  left: 50%;
  bottom: 0;
  height: 3px;
  background: #000;
}
.button:hover:nth-of-type(1) {
  border-radius: 30px;
}
.button:hover:nth-of-type(1):after {
  width: 0%;
}
.button:hover {
  cursor: pointer;
}
.button:hover:after {
  width: 100%;
  left: 0;
}


.button2 {
  flex: 1 1 auto;
  margin: 10px;
  padding: 20px;
  border: 2px solid #009de0;
  text-align: center;
  text-transform: uppercase;
  position: relative;
  overflow: hidden;
  transition: 0.3s; color:#009de0; background:none
}
.button2:after {
  position: absolute;
  transition: 0.3s;
  content: "";
  width: 0;
  left: 50%;
  bottom: 0;
  height: 3px;
  background: #000;
}
.button2:hover:nth-of-type(1) {
  border-radius: 30px;
}
.button2:hover:nth-of-type(1):after {
  width: 0%;
}
.button2:hover {
  cursor: pointer;
}
.button2:hover:after {
  width: 100%;
  left: 0;
}
/*Fin Boutons*/





/*FOOTER*/
footer {
background: #85d0f0;
padding: 20px;
min-height: 100px;
}
footer h2 {color: #fff; font-size:18px}
footer p {color: #fff; font-size:14px}
footer p a {color: #fff; }
footer p a:hover {color:#fff; text-decoration: none}
footer p a:visited {color:#fff; text-decoration: none}
footer hr {border-color:#fff;    margin: 0rem 0 !important;}
footer ul.list-unstyled li a {color: #fff}
footer .rubrique { color: #fff}
footer .fab {color:#fff}
/*FOOTER*/

.encart { background-color: #9e9e9e;border: 1px solid #eee; padding:20px; border-radius: 10px}
.rounded-5 {
    border-radius: 3rem; /* ajuste la valeur comme tu veux */
}


/* Styles de base : s'appliquent sur TOUS les écrans */
.info-bull {
    width: 160px;
    height: 160px;
    background: #9ed5ed;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: transform 0.4s;
}

.info-bull.rotate1 {
    transform: rotate(-18deg);
    background: #6BBDE3;
    color: white;
}
.info-bull.rotate1:hover { transform: rotate(0deg); }

.info-bull.rotate2 {
    transform: rotate(18deg);
    background: #9ED4EC;
    color: white;
}
.info-bull.rotate2:hover { transform: rotate(0deg); }

.info-bull.rotate3 {
    transform: rotate(-18deg);
    background: #9ED4EC;
    color: white;
}
.info-bull.rotate3:hover { transform: rotate(0deg); }

.info-bull.rotate4 {
    transform: rotate(18deg);
    background: #6BBDE3;
    color: white;
}
.info-bull.rotate4:hover { transform: rotate(0deg); }

/* Adaptation mobile/tablette : bulles plus petites pour rentrer dans col-3 */
@media only screen and (max-width: 1023px) {
    .info-bull {
        width: 90px;
        height: 90px;
    }
    .info-bull .number-bull {
        font-size: 1.2rem;
    }
    .info-bull .item-bull {
        font-size: 0.75rem;
    }
}

@media (min-width: 768px) {
    .position-md-sticky { position: sticky; top: 20px; z-index: 1020; }
}

.bd-bubble {
    /* --- Desktop : en absolute --- */
    /* position: absolute;
    top: 50px;
    right: 10px;
    z-index: 10;*/
    position: relative;
    max-width: 100%;
    background: #e8f6fd;
    color: #003b5c;
    border: 3px solid #009de0;
    border-radius: 30px;
    padding: 25px 30px;
    font-size: 1rem;
    line-height: 1.5;
    text-align: center;
    box-shadow: 4px 4px 0 #009de0;
}

.bd-bubble p {
    margin: 0;
}

/* Queue de la bulle (contour bleu) */
.bd-bubble::before {
    content: "";
    position: absolute;
    bottom: -28px;
    left: 40px;
    width: 0;
    height: 0;
    border-top: 28px solid #009de0;
    border-right: 25px solid transparent;
}

/* Queue de la bulle (intérieur bleu clair pour masquer le trait) */
.bd-bubble::after {
    content: "";
    position: absolute;
    bottom: -20px;
    left: 45px;
    width: 0;
    height: 0;
    border-top: 22px solid #e8f6fd;
    border-right: 18px solid transparent;
}

/* --- Tablette et mobile : passage en relative --- */
@media only screen and (max-width: 1023px) {
    .bd-bubble {
        position: relative;
        top: auto;
        right: auto;
        margin: 30px auto;     /* centrée horizontalement, avec un peu d'air */
        max-width: 90%;
    }
}


.kit-card {
    background: #ffffff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 157, 224, 0.12);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
    border: 1px solid rgba(0, 157, 224, 0.1);
}

.kit-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(0, 157, 224, 0.25);
}

/* ====== HEADER ====== */
.kit-card-header {
    background: linear-gradient(135deg, #009de0 0%, #6BBDE3 100%);
    color: #fff;
    padding: 28px 24px;
    text-align: center;
    position: relative;
}

.kit-card-header::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 20px;
    background: #fff;
    border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}

.kit-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    margin-bottom: 12px;
    backdrop-filter: blur(4px);
}

.kit-card-title {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
    letter-spacing: 0.5px;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* ====== BODY ====== */
.kit-card-body {
    padding: 24px 28px 28px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.kit-list {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
}

.kit-list li {
    position: relative;
    padding: 8px 0 8px 28px;
    color: #333;
    font-size: 0.95rem;
    line-height: 1.5;
    border-bottom: 1px dashed rgba(0, 157, 224, 0.15);
    transition: padding-left 0.2s ease, color 0.2s ease;
}

.kit-list li:last-child {
    border-bottom: none;
}

.kit-list li::before {
    content: "";
    position: absolute;
    left: 4px;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    background: #009de0;
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(0, 157, 224, 0.18);
}

.kit-list li:hover {
    padding-left: 32px;
    color: #009de0;
}

/* ====== NOTE EN BAS ====== */
.kit-card-note {
    background: #f3faff;
    border-left: 4px solid #009de0;
    border-radius: 8px;
    padding: 16px 18px;
    margin-top: 0;
}

.kit-card-note p {
    margin: 0;
    font-size: 0.9rem;
    color: #2c3e50;
    line-height: 1.55;
}

.kit-card-note em {
    color: #009de0;
    font-style: italic;
}







.reviews-section {
    padding: 60px 20px;
}

.section-title {
    font-size: 2rem;
    font-weight: 700;
    color: #2c2c2c;
    margin-bottom: 10px;
}

.section-subtitle {
    color: #888;
    font-size: 1rem;
    margin-bottom: 40px;
}

.review-card {
    background: #fff;
    border-radius: 16px;
    padding: 40px 36px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.07);
    max-width: 720px;
    margin: 0 auto;
    min-height: 240px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.review-stars {
    color: #f5a623;
    font-size: 1.3rem;
    margin-bottom: 18px;
}

.review-text {
    font-size: 1.05rem;
    color: #444;
    line-height: 1.75;
    font-style: italic;
    flex-grow: 1;
}

.review-author {
    margin-top: 24px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.review-author .avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #d4a84b;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.1rem;
    font-weight: bold;
    flex-shrink: 0;
}

.review-author .name {
    font-size: 0.9rem;
    font-weight: 600;
    color: #333;
}

.review-author .source {
    font-size: 0.78rem;
    color: #aaa;
}


.carousel-indicators [data-bs-target] {
    background-color: #d4a84b;
    border-radius: 50%;
    width: 10px;
    height: 10px;
    border: none;
    opacity: 0.35;
}

.carousel-indicators .active {
    opacity: 1;
}

.carousel-indicators {
    bottom: -38px;
}

.carousel-wrapper {
    position: relative;
    padding-bottom: 50px;
}

.btn-all-reviews {
    background-color: #d4a84b;
    color: #fff;
    border: none;
    padding: 12px 30px;
    border-radius: 30px;
    font-size: 0.95rem;
    font-weight: 600;
    text-decoration: none;
    display: inline-block;
    transition: background 0.2s ease, transform 0.15s ease;
}

.btn-all-reviews:hover {
    background-color: #b88c38;
    color: #fff;
    transform: translateY(-2px);
}

.google-logo {
    width: 18px;
    height: 18px;
    vertical-align: middle;
    margin-right: 6px;
}

.carousel-arrows-custom .carousel-control-prev-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23d4a84b'%3E%3Cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3E%3C/svg%3E");
}

.carousel-arrows-custom .carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23d4a84b'%3E%3Cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");
}