/* ---------- General ----------------- */
body {
  overflow-x: hidden;
  font-family: "Roboto Slab", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

p {
  line-height: 1.75;
}

a {
  color: #69b3a2;
}

a:hover {
  color: #251667;
}

.text-primary {
  color: #69b3a2 !important;
}

.c{
  color: #1a1a1a;
            margin-bottom: 30px;
            border-bottom: 3px solid #69b3a2;
            padding-bottom: 10px;
            font-size: 2em;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 695;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

section {
  padding: 100px 0;
}

section h2.section-heading {
  font-size: 40px;
  margin-top: 0;
  margin-bottom: 15px;
}

section h3.section-subheading {
  font-size: 16px;
  font-weight: 400;
  font-style: italic;
  margin-bottom: 45px;
  text-transform: none;
  font-family: "Droid Serif", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

@media (min-width: 768px) {
  section {
    padding: 150px 0;
  }
}

/* ---------- Button ----------------- */
.btn {
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
}

.btn-xl {
  font-size: 18px;
  padding: 20px 40px;
}

.btn-primary {
  background-color: transparent;
  border-color: #69b3a2;
  color: #69b3a2;
  border-width: medium;
  margin-top: 5px;
}

.btn-primary:active,
.btn-primary:focus,
.btn-primary:hover {
  background-color: #69b3a2 !important;
  border-color: #69b3a2 !important;
  color: white;
}

.btn-primary:active,
.btn-primary:focus {
  box-shadow: 0 0 0 0.2rem rgba(254, 209, 55, 0.5) !important;
}

.btn-secondary {
  background-color: transparent;
  border-color: #69b3a2;
  color: #69b3a2;
  border-width: small;
}

.btn-secondary:active,
.btn-secondary:focus,
.btn-secondary:hover {
  background-color: #69b3a2 !important;
  border-color: #69b3a2 !important;
  color: white;
}

.btn-secondary:active,
.btn-secondary:focus {
  background-color: #69b3a2 !important;
}

.btn-secondary:not(:disabled):not(.disabled).active {
  background-color: #69b3a2 !important;
  border-color: #69b3a2 !important;
  color: white;
}

::-moz-selection {
  background: #69b3a2;
  text-shadow: none;
}

::selection {
  background: #69b3a2;
  text-shadow: none;
}

img::selection {
  background: transparent;
}

img::-moz-selection {
  background: transparent;
}

#mainNav {
  background-color: white;
}

#mainNav .navbar-toggler {
  font-size: 12px;
  right: 0;
  padding: 13px;
  text-transform: uppercase;
  color: white;
  border: 0;
  background-color: #69b3a2;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}


#mainNav .navbar-brand {
  color: #69b3a2;
  font-family: "Kaushan Script", "Helvetica Neue", Helvetica, Arial, cursive;
}

#mainNav .navbar-brand.active,
#mainNav .navbar-brand:active,
#mainNav .navbar-brand:focus,
#mainNav .navbar-brand:hover {
  color: #251667;
}

/* Color of the TEXT of the menu top right*/
#mainNav .navbar-nav .nav-item .nav-link {
  font-size: 90%;
  font-weight: 400;
  padding: 0.75em 0;
  letter-spacing: 1px;
  color: black;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

#mainNav .navbar-nav .nav-item .nav-link.active,
#mainNav .navbar-nav .nav-item .nav-link:hover {
  color: #69b3a2;
  background-color: white;
  border-bottom: 5px solid #69b3a2;
}

@media (min-width: 992px) {
  #mainNav {
    padding-top: 25px;
    padding-bottom: 25px;
    -webkit-transition: padding-top 0.3s, padding-bottom 0.3s;
    -moz-transition: padding-top 0.3s, padding-bottom 0.3s;
    transition: padding-top 0.3s, padding-bottom 0.3s;
    background-color: transparent;
  }
  #mainNav .navbar-brand {
    font-size: 1.75em;
    -webkit-transition: all 0.3s;
    -moz-transition: all 0.3s;
    transition: all 0.3s;
  }
  #mainNav .navbar-nav .nav-item .nav-link {
    padding: 1.1em 1em !important;
  }
  #mainNav.navbar-shrink {
    padding-top: 0;
    padding-bottom: 0;
    background-color: white;
  }

  #mainNav.navbar-shrink .navbar-brand {
    font-size: 1.25em;
    padding: 12px 0;
  }
}

/* Fond blanc pour le menu quand il est déroulé (mode mobile) */
#navbarResponsive {
  background-color: white !important;
}

/* Liens en noir pour être lisibles sur le fond blanc */
#navbarResponsive .nav-link {
  color: black !important;
}

/* Optionnel : un peu d'espace dans le menu mobile */
@media (max-width: 991px) {
  #navbarResponsive {
    padding: 10px 0;
  }
}



.masthead {
  text-align: center;
  color: black;
  position: relative;
  overflow: hidden;
}


.btn-explore { /* J'utilise la classe '.btn-explore' de ma proposition précédente */
    display: inline-block;
    padding: 15px 35px;
    border: none;
    border-radius: 5px; /* Bords légèrement arrondis */
    text-decoration: none;
    
    /* Couleurs pour attirer l'œil */
    background-color: #69b3a2; /* Couleur vive (ex: bleu) */
    color: #ffffff; /* Texte blanc */
    font-size: 1.1rem;
    font-weight: bold;
    letter-spacing: 1px;
    
    /* Animation subtile pour l'interaction */
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.btn-explore:hover {
    background-color: #69b3a2; /* Un bleu plus sombre au survol */
    color: #ffffff;
    transform: translateY(-2px); /* Léger soulèvement au survol pour un effet de profondeur */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}


.parallax {
  /* The image used (faded with convert overview_RGG.png  -fill white -colorize 50%  overview_RGG_faded.png*/
  background-image: url("../img/arriere/arriere1.jpg");

  /* Set a specific height */
  min-height: 100px;

  /* Create the parallax scrolling effect */
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.parallaxstory {
  /* The image used (faded with convert overview_RGG.png  -fill white -colorize 50%  overview_RGG_faded.png*/
  background-color: white;

  /* Set a specific height */
  min-height: 500px;

  /* Create the parallax scrolling effect */
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.parallaxcontact {
  /* The image used (faded with convert overview_RGG.png  -fill white -colorize 50%  overview_RGG_faded.png*/
  background-image: url("../img/parallax/surf_fading.png");

  /* Set a specific height */
  min-height: 500px;

  /* Create the parallax scrolling effect */
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.parallaxposter {
  /* The image used (faded with convert overview_RGG.png  -fill white -colorize 50%  overview_RGG_faded.png*/
  background-image: url("../img/parallax/poster_zoom_fadded.png");

  /* Set a specific height */
  min-height: 500px;

  /* Create the parallax scrolling effect */
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

header.masthead .intro-text {
  padding-top: 150px;
  padding-bottom: 150px;
}

header.masthead .intro-text .intro-lead-in {
  font-size: 14px;
  font-style: italic;
  line-height: 22px;
  margin-bottom: 25px;
  font-family: "Droid Serif", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

header.masthead .intro-text .intro-heading {
  font-size: 50px;
  font-weight: 700;
  line-height: 50px;
  margin-bottom: 25px;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

@media (min-width: 768px) {
  header.masthead .intro-text {
    padding-top: 100px;
    padding-bottom: 200px;
  }
  header.masthead .intro-text .intro-lead-in {
    font-size: 16px;
    font-style: italic;
    color: grey;
    line-height: 40px;
    margin-bottom: 25px;
    margin-right: 20%;
    margin-left: 20%;
    font-family: "Droid Serif", "Helvetica Neue", Helvetica, Arial, sans-serif;
  }
  header.masthead .intro-text .intro-heading {
    font-size: 75px;
    font-weight: 700;
    line-height: 75px;
    margin-bottom: 50px;
    font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
  }
}

.service-heading {
  margin: 15px 0;
}

#portfolio .portfolio-item {
  right: 0;
  margin: 0 0 15px;
}

#portfolio .portfolio-item .portfolio-link {
  position: relative;
  display: block;
  max-width: 130px;
  margin: 0 auto;
  cursor: pointer;
}

#portfolio .portfolio-item .portfolio-link .portfolio-hover {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-transition: all ease 0.5s;
  -moz-transition: all ease 0.5s;
  transition: all ease 0.5s;
  opacity: 0;
  background: rgba(254, 209, 54, 0.9);
  border-radius: 100%;
  background-color: grey !important;
}

#portfolio .portfolio-item .portfolio-link .portfolio-hover:hover {
  opacity: 0.8;
}

#portfolio
  .portfolio-item
  .portfolio-link
  .portfolio-hover
  .portfolio-hover-content {
  font-size: 20px;
  position: absolute;
  top: 50%;
  width: 100%;
  height: 20px;
  margin-top: -12px;
  text-align: center;
  color: white;
}

#portfolio
  .portfolio-item
  .portfolio-link
  .portfolio-hover
  .portfolio-hover-content
  i {
  margin-top: -12px;
}

#portfolio
  .portfolio-item
  .portfolio-link
  .portfolio-hover
  .portfolio-hover-content
  h3,
#portfolio
  .portfolio-item
  .portfolio-link
  .portfolio-hover
  .portfolio-hover-content
  h4 {
  margin: 0;
}

#portfolio .portfolio-item .portfolio-caption {
  max-width: 400px;
  margin: 0 auto;
  padding: 25px;
  text-align: center;
  background-color: "none";
}

#portfolio .portfolio-item .portfolio-caption h4 {
  margin: 0;
  text-transform: none;
}

#portfolio .portfolio-item .portfolio-caption p {
  font-size: 16px;
  font-style: italic;
  margin: 0;
  font-family: "Droid Serif", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

#portfolio * {
  z-index: 2;
}

@media (min-width: 767px) {
  #portfolio .portfolio-item {
    margin: 0 0 30px;
  }
}

/* -------------------- MENU ------------------ */

.dropdown-submenu {
  position: relative;
}

.dropdown-submenu > .dropdown-menu {
  top: 0;
  left: 100%;
  margin-top: -6px;
  margin-left: -1px;
  -webkit-border-radius: 0 6px 6px 6px;
  -moz-border-radius: 0 6px 6px;
  border-radius: 0 6px 6px 6px;
}

.dropdown-submenu:hover > .dropdown-menu {
  display: block;
}

.dropdown-submenu > a:after {
  display: block;
  content: " ";
  float: right;
  width: 0;
  height: 0;
  border-color: transparent;
  border-style: solid;
  border-width: 5px 0 5px 5px;
  border-left-color: #ccc;
  margin-top: 5px;
  margin-right: -10px;
}

.dropdown-submenu:hover > a:after {
  border-left-color: #fff;
}

.dropdown-submenu.pull-left {
  float: none;
}

.dropdown-submenu.pull-left > .dropdown-menu {
  left: -100%;
  margin-left: 10px;
  -webkit-border-radius: 6px 0 6px 6px;
  -moz-border-radius: 6px 0 6px 6px;
  border-radius: 6px 0 6px 6px;
}

/* -------------------- TOOLTIP ------------------ */

.data-tooltip {
  color: black;
  background-color: white;
  background: white;
  align-content: "middle";
  margin-right: 10%;
  margin-left: 10%;
}

.tooltip.show {
  opacity: 1;
  background-color: white;
  border: green;
}

/* -------------------- MODAL ------------------ */

.portfolio-modal {
  padding-right: 0px !important;
}

/* width of modal: different following the device: small (100%), medium(50%), large(30%); */

.portfolio-modal .modal-dialog {
  margin: 3rem;
  max-width: 100vw;
  max-height: 95vh;
  overflow-y: auto;
  pointer-events: all;
}

@media (min-width: 1000px) {
  .portfolio-modal .modal-dialog {
    max-width: 50vw;
  }
}

@media (min-width: 1800px) {
  .portfolio-modal .modal-dialog {
    max-width: 30vw;
  }
}

.portfolio-modal .modal-content {
  padding: 10px 0;
  text-align: center;
}

.portfolio-modal .modal-content h2 {
  font-size: 2em;
  margin-bottom: 15px;
}

.portfolio-modal .modal-content p {
  margin-bottom: 30px;
}

.portfolio-modal .modal-content p.item-intro {
  font-size: 16px;
  font-style: italic;
  margin: 20px 0 30px;
  font-family: "Droid Serif", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.portfolio-modal .modal-content ul.list-inline {
  margin-top: 0;
  margin-bottom: 30px;
}

.portfolio-modal .modal-content img {
  margin-bottom: 30px;
}

.portfolio-modal .modal-content button {
  cursor: pointer;
}

/* -------------------- MODAL FULL SCREEN ------------------ */

.fullScreen {
  max-width: 100vw;
  max-height: 100vh;
}

.modal-dialog-full {
  max-width: 100vw;
  max-height: 100vh;
}

/* -------------------- CLOSING MODAL ------------------ */

.portfolio-modal .close-modal {
  position: absolute;
  top: 25px;
  right: 25px;
  width: 75px;
  height: 75px;
  cursor: pointer;
  background-color: transparent;
  z-index: 1;
}

.portfolio-modal .close-modal:hover {
  opacity: 0.3;
}

.portfolio-modal .close-modal .lr {
  /* Safari and Chrome */
  z-index: 1051;
  width: 1px;
  height: 75px;
  margin-left: 35px;
  /* IE 9 */
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  background-color: #212529;
}

.portfolio-modal .close-modal .lr .rl {
  /* Safari and Chrome */
  z-index: 1052;
  width: 1px;
  height: 75px;
  /* IE 9 */
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
  background-color: #212529;
}

.timeline {
  position: relative;
  padding: 0;
  list-style: none;
}

.timeline:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 40px;
  width: 2px;
  margin-left: -1.5px;
  content: "";
  background-color: #e9ecef;
}

.timeline > li {
  position: relative;
  min-height: 50px;
  margin-bottom: 50px;
}

.timeline > li:after,
.timeline > li:before {
  display: table;
  content: " ";
}

.timeline > li:after {
  clear: both;
}

.timeline > li .timeline-panel {
  position: relative;
  float: right;
  width: 100%;
  padding: 0 20px 0 100px;
  text-align: left;
}

.timeline > li .timeline-panel:before {
  right: auto;
  left: -15px;
  border-right-width: 15px;
  border-left-width: 0;
}

.timeline > li .timeline-panel:after {
  right: auto;
  left: -14px;
  border-right-width: 14px;
  border-left-width: 0;
}

.timeline > li .timeline-image {
  position: absolute;
  z-index: 100;
  left: 0;
  width: 80px;
  height: 80px;
  margin-left: 0;
  text-align: center;
  color: white;
  border: 7px solid #e9ecef;
  border-radius: 100%;
  background-color: #fed136;
}

.timeline > li .timeline-image h4 {
  font-size: 10px;
  line-height: 14px;
  margin-top: 12px;
}

.timeline > li.timeline-inverted > .timeline-panel {
  float: right;
  padding: 0 20px 0 100px;
  text-align: left;
}

.timeline > li.timeline-inverted > .timeline-panel:before {
  right: auto;
  left: -15px;
  border-right-width: 15px;
  border-left-width: 0;
}

.timeline > li.timeline-inverted > .timeline-panel:after {
  right: auto;
  left: -14px;
  border-right-width: 14px;
  border-left-width: 0;
}

.timeline > li:last-child {
  margin-bottom: 0;
}

.timeline .timeline-heading h4 {
  margin-top: 0;
  color: inherit;
}

.timeline .timeline-heading h4.subheading {
  text-transform: none;
}

.timeline .timeline-body > ul,
.timeline .timeline-body > p {
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .timeline:before {
    left: 50%;
  }
  .timeline > li {
    min-height: 100px;
    margin-bottom: 100px;
  }
  .timeline > li .timeline-panel {
    float: left;
    width: 41%;
    padding: 0 20px 20px 30px;
    text-align: right;
  }
  .timeline > li .timeline-image {
    left: 50%;
    width: 100px;
    height: 100px;
    margin-left: -50px;
  }
  .timeline > li .timeline-image h4 {
    font-size: 13px;
    line-height: 18px;
    margin-top: 16px;
  }
  .timeline > li.timeline-inverted > .timeline-panel {
    float: right;
    padding: 0 30px 20px 20px;
    text-align: left;
  }
}

@media (min-width: 992px) {
  .timeline > li {
    min-height: 150px;
  }
  .timeline > li .timeline-panel {
    padding: 0 20px 20px;
  }
  .timeline > li .timeline-image {
    width: 150px;
    height: 150px;
    margin-left: -75px;
  }
  .timeline > li .timeline-image h4 {
    font-size: 18px;
    line-height: 26px;
    margin-top: 30px;
  }
  .timeline > li.timeline-inverted > .timeline-panel {
    padding: 0 20px 20px;
  }
}

@media (min-width: 1200px) {
  .timeline > li {
    min-height: 170px;
  }
  .timeline > li .timeline-panel {
    padding: 0 20px 20px 100px;
  }
  .timeline > li .timeline-image {
    width: 170px;
    height: 170px;
    margin-left: -85px;
  }
  .timeline > li .timeline-image h4 {
    margin-top: 40px;
  }
  .timeline > li.timeline-inverted > .timeline-panel {
    padding: 0 100px 20px 20px;
  }
}

.team-member {
  margin-bottom: 50px;
  text-align: center;
}

.team-member img {
  width: 225px;
  height: 225px;
  border: 7px solid #fff;
}

.team-member h4 {
  margin-top: 25px;
  margin-bottom: 0;
  text-transform: none;
}

.team-member p {
  margin-top: 0;
}

footer {
  padding: 25px 0;
  text-align: center;
}

footer span.copyright {
  font-size: 90%;
  line-height: 40px;
  text-transform: none;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

footer ul.quicklinks {
  font-size: 90%;
  line-height: 40px;
  margin-bottom: 0;
  text-transform: none;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

ul.social-buttons {
  margin-bottom: 0;
}

ul.social-buttons li a {
  font-size: 20px;
  line-height: 40px;
  display: block;
  width: 40px;
  height: 40px;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  transition: all 0.3s;
  color: white;
  border-radius: 100%;
  outline: none;
  background-color: #212529;
}

ul.social-buttons li a:active,
ul.social-buttons li a:focus,
ul.social-buttons li a:hover {
  background-color: #fed136;
}

/* ------------------------------------------------------------------------------------------------------------------- */

/* CSS for the image caroussell (poster) */
/** {box-sizing: border-box}
    body {font-family: Verdana, sans-serif; margin:0}
    .mySlides {display: none}
    img {vertical-align: middle;}*/

/* Slideshow container */
.slideshow-container {
  max-width: 1000px;
  position: relative;
  margin: auto;
}

/* Next & previous buttons */
.prev,
.next {
  cursor: pointer;
  position: absolute;
  top: 50%;
  width: auto;
  padding: 16px;
  margin-top: -22px;
  color: white;
  font-weight: bold;
  font-size: 18px;
  transition: 0.6s ease;
  border-radius: 0 3px 3px 0;
}

/* Position the "next button" to the right */
.next {
  right: 0;
  border-radius: 3px 0 0 3px;
}

/* On hover, add a black background color with a little bit see-through */
.prev:hover,
.next:hover {
  background-color: rgba(0, 0, 0, 0.8);
}

/* Caption text */
.text {
  color: #f2f2f2;
  font-size: 15px;
  padding: 8px 12px;
  position: absolute;
  bottom: 8px;
  width: 100%;
  text-align: center;
}

/* The dots/bullets/indicators */
.dot {
  cursor: pointer;
  height: 15px;
  width: 15px;
  margin: 0 2px;
  background-color: #69b3a2;
  border-radius: 50%;
  display: inline-block;
  transition: background-color 0.6s ease;
}

.active,
.dot:hover {
  background-color: white;
}

/* ------------------------------------------------------------------------------------------------------------------- */

/* ------------------------------------------------------------------------------------------------------------------- */

/*Tree Style*/

.graphtypelogo:hover {
  opacity: 0.5;
}

.graphtypelogo {
  opacity: 1;
}

#NumCat {
  color: red;
}

.astext {
  background: none;
  border: none;
  font-weight: 900;
  font-family: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

.mystory {
  fill: #69b3a2;
  font-size: 16px;
  text-align: center;
}
/* ------------------------------------------------------------------------------------------------------------------- */

/* ------------------------------------------------------------------------------------------------------------------- */
/* Customize the gallery of the portfolio section
/* ------------------------------------------------------------------------------------------------------------------- */

.captionPortfolio {
  font-size: 12px;
  padding: 8px;
  margin: 0px;
  text-align: center;
}

/* Create three equal columns that floats next to each other */
.column {
  display: none; /* Hide all elements by default */
}

/* The "show" class is added to the filtered elements */
.show {
  display: block;
}
</style>

/* ------------------------------------------------------------------------------------------------------------------- */










/* ------------------------------------------------------------------------------------------------------------------- */
/* BUTTON TREE CHOICE
/* ------------------------------------------------------------------------------------------------------------------- */

.treeHead {
  border-style: solid;
  border-color: rgba(0, 0, 0, 1);
  border-radius: 25px;
}

.tree {
  opacity: 0;
}

/* ------------------------------------------------------------------------------------------------------------------- */
/* TOOLTIP WITH DATA EXAMPLE
/* ------------------------------------------------------------------------------------------------------------------- */

.tooltip {
  max-width: 510px;
  padding: 3px 8px;
  color: white;
  text-align: center;
  background-color: white;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
}

.tooltip-inner {
  max-width: 510px;
  color: black;
  background-color: white;
  border-style: solid;
  border-color: black;
  border-width: 1px;
}

/* ------------------------------------------------------------------------------------------------------------------- */
/* MISTAKE CAROUSSEL CUSTOM
/* ------------------------------------------------------------------------------------------------------------------- */

.carousel-control-next,
.carousel-control-prev {
  color: black;
}

.carousel-control-prev-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='black' viewBox='0 0 8 8'%3E%3Cpath d='M5.25 0l-4 4 4 4 1.5-1.5-2.5-2.5 2.5-2.5-1.5-1.5z'/%3E%3C/svg%3E");
}

.carousel-control-next-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='black' viewBox='0 0 8 8'%3E%3Cpath d='M2.75 0l-1.5 1.5 2.5 2.5-2.5 2.5 1.5 1.5 4-4-4-4z'/%3E%3C/svg%3E");
}

.carousel-control-prev {
  left: -121px;
}
.carousel-control-next {
  right: -121px;
}

.mytextrelated {
  text-transform: none;
  font-weight: normal !important;
  color: black;
}

.mytitlerelated {
  margin: 10px 0 10px;
  font-size: 14px;
}

.mybtnrelated {
  height: 380px;
  margin-top: 24px;
  padding-top: 24px;
}

/* ------------------------------------------------------------------------------------------------------------------- */
/* DROPDOWN BUTTON
/* ------------------------------------------------------------------------------------------------------------------- */

.dropdown-item {
  margin-left: 30px;
}

/* ------------------------------------------------------------------------------------------------------------------- */
/* PROMOTIONAL BANNER
/* ------------------------------------------------------------------------------------------------------------------- */

.promo-banner {
  position: fixed;
  bottom: 0;
  width: 100%;
  background: linear-gradient(
    90deg,
    #ff007f,
    #f01cf3
  ); /* Simulating bg-purple-100 gradient */
  color: rgba(255, 255, 255, 0.9);
  text-align: center;
  padding: 10px 0;
  font-size: 16px;
  z-index: 1000;
  font-weight: 300;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  letter-spacing: 1px;
  text-decoration: none !important;
}

.promo-banner:hover {
  color: rgba(255, 255, 255, 1);
  font-weight: 600;
}

.promo-banner-close-btn {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background-color: transparent;
  color: rgba(255, 255, 255, 0.8);
  font-size: 24px;
  cursor: pointer;
}

/* ------------------------------------------------------------------------------------------------------------------- */
/* LOST
/* ------------------------------------------------------------------------------------------------------------------- */

.cardtitle {
  color: orange;
  text-align: left;
}

/* ------------------------------------------------------------------------------------------------------------------- */
/* Concernant les animations sur les mots qui doivent défilés 
/* ------------------------------------------------------------------------------------------------------------------- */


#animated-buttons {
  position: relative;
  height: 70px;
  overflow: hidden;
}

.word-animation {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}

.visible {
  opacity: 1;
}


/* Conteneur des boutons sous la photo */
.profile-buttons {
  display: flex;
  justify-content: center;
  gap: 15px;
  flex-wrap: wrap;
}

/* Style générique des boutons */
.profile-buttons .btn {
  background: black;
  color: white;
  border-radius: 12px;
  padding: 10px 20px;
  font-weight: 600;
  font-size: 0.95rem;
  border: 2px solid black;
  transition: 0.2s ease;
}

.profile-buttons .btn:hover {
  background: #222;
  transform: translateY(-3px);
}

/* Bouton Contact (style clair) */
.btn-contact {
  background: transparent !important;
  color: #69b3a2 ;
  border-color: #69b3a2 ;
}

.btn-cv {
  background: transparent !important;
  color: #69b3a2 ;
  border-color: #69b3a2 ;
}

.btn-contact:hover {
  background: #e8f3ef !important;
}
.btn-cv:hover {
  background: #e8f3ef !important;
}


/* ------------------------------------------------------------------------------------------------------------------- */
/* Concernant le profil 
/* ------------------------------------------------------------------------------------------------------------------- */
/* Timeline mobile - s'affiche uniquement sur petits écrans */
    .mobile-timeline {
      display: none;
      padding: 20px;
    }

    .mobile-timeline-item {
      background: white;
      padding: 20px;
      margin-bottom: 20px;
      border-radius: 12px;
      border-left: 4px solid #69b3a2;
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    }

    .mobile-timeline-item h4 {
      color: #333;
      margin-bottom: 8px;
      font-size: 1.1rem;
      font-weight: 600;
    }

    .mobile-timeline-item .date {
      color: #69b3a2;
      font-weight: 600;
      margin-bottom: 8px;
      font-size: 0.9rem;
    }

    .mobile-timeline-item p {
      color: #666;
      font-style: italic;
      margin-bottom: 0;
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 0.95rem;
    }

    .mobile-timeline-item .flag {
      width: 16px;
      height: 12px;
    }

    /* Media query pour basculer entre les deux affichages */
    @media (max-width: 992px) {
      /* Cache la timeline SVG sur petits écrans */
      .hide-if-small-screen {
        display: none !important;
      }

      /* Affiche la timeline mobile */
      .mobile-timeline {
        display: block;
      }
    }

    /* Ajustements supplémentaires pour très petits écrans */
    @media (max-width: 768px) {
      .mobile-timeline {
        padding: 10px;
      }

      .mobile-timeline-item {
        padding: 15px;
      }

      .mobile-timeline-item h4 {
        font-size: 1rem;
      }
    }




/* ------------------------------------------------------------------------------------------------------------------- */
/* ANimation concernant les compétences
/* ------------------------------------------------------------------------------------------------------------------- */

/* === Animation de survol pour les cartes de la section compétences === */
.grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
      margin-bottom: 2rem;
    }
    
    @media (max-width: 768px) {
      .grid {
        grid-template-columns: 1fr;
      }
    }

    .card {
      border-radius: 1rem;
      padding: 1rem;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
      transition: transform 0.6s ease, box-shadow 0.6s ease;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
    }

    .card:hover {
      transform: scale(1.05);
      box-shadow: 0 8px 16px rgba(0, 100, 0, 0.25);
    }



    .card h4 {
      text-align: center;
      padding: 1rem;
      margin-bottom: 1rem;
      background-color: white;
      border-radius: 8px;
      box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
      color: #2d3748;
      font-size: 1.4rem;par
      font-weight: 600;
      transition: color 0.4s ease;
    }

    .card:hover h4 {
      color: #004d40;
    }

    .card p {
      color: #4a5568;
      line-height: 1.7;
      margin-bottom: 20px;
      font-size: 0.95rem;
      transition: color 0.4s ease;
    }

    .card:hover p {
      color: #004d40;
    }

    .badges {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .badge {
      background: transparent !important;
      color: #69b3a2 ;
      padding: 6px 14px;
      border-radius: 20px;
      font-size: 0.8rem;
      font-weight: 500;
      border: 3px solid #2e7d3230;
      transition: all 0.3s ease;
    }

    .badge:hover {
      background:  #2e7d32;
      background: #e8f3ef !important;
      transform: scale(1.05);
    }

    @media (max-width: 768px) {
      h2 {
        font-size: 2rem;
        margin-bottom: 40px;
      }

      .card {
        padding: 25px;
      }

      .card h4 {
        font-size: 1.2rem;
      }
    }


/* ------------------------------------------------------------------------------------------------------------------- */
/* Section Outils et Technologies
/* ------------------------------------------------------------------------------------------------------------------- */

/* ====== Section Outils et Technologies ====== */
/* === SECTION OUTILS === */
#outils {
  overflow: hidden;
  padding: 60px 0;
  text-align: center;
}

#outils h2 {
  font-weight: 700;
  color: #2b2b2b;
  margin-bottom: 30px;
}

.logos-container {
  display: flex;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
  width: 100%;
  margin: 0 auto;
}

.logos-slide {
  display: inline-flex;
  align-items: center;
  animation: scroll 45s linear infinite;
}

.logos-container:hover .logos-slide {
  animation-play-state: paused;
}

@keyframes scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-100%); }
}

.logo-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 35px;
  cursor: pointer;
}

.logo-item img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  transition: transform 0.3s ease, filter 0.3s ease;
}

.logo-item:hover img {
  transform: scale(1.15);
  filter: drop-shadow(0 0 10px #69b3a2);
}

.logo-item p {
  margin-top: 10px;
  font-size: 1rem;
  font-weight: 600;
  color: #333;
}

/* Zone d’affichage du texte */
.outil-description {
  margin-top: 40px;
  font-size: 1.1rem;
  color: #333;
  font-weight: 500;
  background: #e7f6f2;
  padding: 15px 20px;
  border-radius: 10px;
  display: inline-block;
  min-width: 300px;
  max-width: 80%;
}


/* ------------------------------------------------------------------------------------------------------------------- */
/* Section Experience professionnelle
/* ------------------------------------------------------------------------------------------------------------------- */

/* 🌙 Section globale */

/* 🌙 Section générale */
.experience-section {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  color: black;
  font-family: "Inter", sans-serif;
}

/* Conteneur */


/* 🔥 Titre principal */


.experience-title {
  background: black;
  text-align: center;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}



.experience-title {
  text-align: center;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* 🧱 Carte d'expérience — style similaire à #compétences .card */
.experience-card {
  border: 1px solid rgba(30, 58, 95, 0.5);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 4px 8px rgba(15, 33, 63, 0.25);
  transition: transform 0.5s ease, box-shadow 0.5s ease, border 0.5s ease;
  margin-bottom: 2rem;
}

/* 🌟 Effet au survol */
.experience-card:hover {
  transform: scale(1.04);
  box-shadow: 0 8px 16px rgba(0, 100, 0, 0.25);
  
}

/* 🔹 En-tête de la carte */
.experience-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  border-bottom: 1px solid rgba(30, 58, 95, 0.6);
  padding-bottom: 1rem;
  margin-bottom: 1.5rem;
}

.experience-role {
  color: black;
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
}

.experience-company {
  color: #69b3a2;
  font-weight: 600;
}

/* 📅 Infos à droite */
.experience-info p {
  margin: 4px 0;
  color: black;
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* 🧾 Liste des tâches */
.experience-tasks {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.experience-tasks li {
  margin-bottom: 12px;
  position: relative;
  padding-left: 22px;
  color: black;
  line-height: 1.6;
  transition: color 0.4s ease;
}

/* 🟣 Puce dégradée */
.experience-tasks li::before {
  content: "→";
    position: absolute;
    left: 0;
    color: #ff6b35;
    font-weight: bold;
}

/* ✨ Effet au survol des items */
.experience-card:hover .experience-tasks li {
  color: black; /* bleu clair au survol */
}

.experience-card:hover .experience-tasks li::before {
  transform: scale(1.3);
}

.experience-tech {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #e0e0e0;
}

.experience-context {
    background: #fff4e5;
    padding: 12px;
    border-radius: 6px;
    margin-bottom: 16px;
    font-size: 14px;
    line-height: 1.6;
    color: #444;
    border-left: 3px solid #ff6b35;
}


.tech-badge {
    background: #e8f4f8;
    color: #0077b6;
    padding: 6px 12px;
    border-radius: 16px;
    font-size: 13px;
    font-weight: 500;
}

.flex {
    display: flex;
}

.items-center {
    align-items: center;
}

.mr-2 {
    margin-right: 8px;
}

.text-orange {
    color: #ff6b35;
}

.github-link {
    display: flex;
    justify-content: flex-end;
    margin-top: 16px;
}

.containeer {
    display: inline-flex;
    justify-content: center;
    border-radius: 10%;
    color: #ff6b35;
    transition: all 0.3s ease;
    text-decoration: none;
    margin-left: auto;
}





/* ------------------------------------------------------------------------------------------------------------------- */
/* Section Projets
/* ------------------------------------------------------------------------------------------------------------------- */

/* Nouveau style pour les cartes de projets */
/* 🎯 Style de base */
.btn-project {
  background-color: transparent;
  border: 3px solid #69b3a2;
  border-radius: 1rem;
  color: #69b3a2;
  padding: 20px;
  transition: border-color 0.4s ease, box-shadow 0.4s ease;
  display: inline-block;
}

/* ✨ Effet uniquement sur les bordures et l’ombre */
.btn-project:hover {
  border-color: #69b3a2;
  box-shadow: 0 0 20px #69b3a2;
}

/* Icônes sociales */
.social-icons {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 10px;
}

.icon-container svg {
  transition: transform 0.3s ease;
}

.icon-container:hover svg {
  transform: scale(1.15);
}


/* ------------------------------------------------------------------------------------------------------------------- */
/* Section compétences conernant les outils
/* ------------------------------------------------------------------------------------------------------------------- */

.badge-custom {
    background-color: transparent !important;
    color: #69b3a2;
    border: 2px solid #69b3a2;
    padding: 0.5rem 1rem;
    margin: 0.25rem;
    border-radius: 0.25rem;
    display: inline-block;
  }


  /* ------------------------------------------------------------------------------------------------------------------- */
  /* Concernant les section du code projets.html
  /* ------------------------------------------------------------------------------------------------------------------- */

/* Conteneur des boutons de filtre */
#myBtnContainer {
  display: flex;
  justify-content: center;
  flex-wrap: wrap; /* Permet de passer à la ligne */
  gap: 10px;       /* Espace entre les boutons */
}

/* Style mobile */
@media (max-width: 768px) {
  #myBtnContainer .btn {
    width: 100%;          /* Chaque bouton prend toute la largeur */
    margin: 5px 0;        /* Espacement vertical */
    font-size: 15px;      /* Ajuste la taille du texte */
  }
}

/* --- Styles de profil et de texte --- */

/* Mettre en valeur le nom (anciennement inline style) */
.name-highlight {
  color: #69b3a2 !important; 
  font-size: 2em; 
  white-space: nowrap; 
  font-weight: bold;
  display: block; /* Peut être utile si vous voulez qu'il saute une ligne */
  margin-bottom: 0.5rem;
}

/* Mettre en valeur le BUT (anciennement inline style) */
.but-highlight {
  color: #69b3a2; 
  font-weight: bold; 
  font-size: 1.2em;
}

/* Styles pour l'image de profil */
.img-fluid {
  max-width: 100%;
  height: auto;
}

/* Assurez-vous que l'image de profil est bien mise en forme (cercle + espace) */
.col-lg-4 img {
    /* Si vous voulez une taille fixe sur desktop */
    max-width: 250px; 
    height: auto;
    /* rounded-circle est une classe Bootstrap qui donne un bord arrondi */
    border-radius: 50% !important; 
    /* Ajout d'une ombre discrète pour un effet "pop" */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); 
}

/* Conteneur des boutons (si vous n'utilisez pas Bootstrap 5 `gap-3`) */
.d-flex.justify-content-center.gap-3 {
    display: flex;
    justify-content: center;
    gap: 15px; /* Espacement entre les boutons */
    margin-top: 15px; /* Espace sous l'image */
}

/* --- Amélioration de la Timeline SVG (Desktop) --- */

/* Pour centrer horizontalement le SVG si la ligne est de 1000px */
.row.pt-5.hide-if-small-screen {
  text-align: center;
}
.row.pt-5.hide-if-small-screen svg {
    display: inline-block;
    max-width: 100%; /* S'adapte à la largeur du conteneur */
    height: auto;
}

/* Amélioration des styles du SVG pour un meilleur alignement */
/* Si vous utilisez cette méthode, assurez-vous que les coordonnées (cx, cy, x, y) sont dynamiques 
   ou que le SVG est contenu dans un bloc qui gère son redimensionnement. */


/* Style par défaut pour mobile */
/* --- Ajustement du Header pour Mobile et Desktop --- */

/* 1. Sur tous les écrans (Mobile par défaut) */
/* --- CONFIGURATION DU HEADER PLEIN ÉCRAN --- */
.masthead {
  height: 100vh; /* Prend 100% de la hauteur de l'écran */
  min-height: 500px;
  display: flex;
  align-items: center; /* Centre verticalement */
  justify-content: center; /* Centre horizontalement */
  text-align: center;
  background-color: #ffffff; /* Ou votre image de fond */
}

.masthead .intro-text {
  width: 100%;
  padding-top: 80px; /* Évite que le texte soit sous la navbar fixe */
}

/* Style du titre principal */
.intro-heading {
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 25px;
  color: #000;
}

/* Style du sous-titre */
.intro-lead-in {
  font-size: 1.2rem;
  margin-bottom: 40px;
  color: #555;
  font-style: italic;
}

/* --- RESPONSIVE (MOBILE) --- */
@media (max-width: 768px) {
  .intro-heading {
    font-size: 2rem; /* Plus petit sur téléphone pour éviter de déborder */
    padding: 0 10px;
  }
  
  .intro-lead-in {
    font-size: 1rem;
    padding: 0 20px;
  }
}
/* --- Cercle Pulsant --- */
.scroll-pulse-container {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}

.pulse-circle {
  width: 50px;
  height: 50px;
  background: #dee8e4; /* Ton vert */
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 0 0 0 rgba(100, 188, 156, 0.7);
  animation: pulse-wave 2s infinite;
}

@keyframes pulse-wave {
  0% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(100, 188, 156, 0.7);
  }
  70% {
    transform: scale(1);
    box-shadow: 0 0 0 15px rgba(100, 188, 156, 0);
  }
  100% {
    transform: scale(0.95);
    box-shadow: 0 0 0 0 rgba(100, 188, 156, 0);
  }
}

/* Ajustement pour mobile */
@media (max-width: 768px) {
  .pulse-circle {
    width: 40px;
    height: 40px;
    font-size: 16px;
  }
}

/*----*

/* --- EFFET FLOU SUR LE PORTFOLIO --- */
body.modal-open #page-top > *:not(.modal) {
    filter: blur(8px);
    transition: filter 0.3s ease-in-out;
}

/* --- STYLE DE LA MODAL PREMIUM LIGHT --- */
.custom-modal-premium-light {
    background: #ffffff !important;
    border: 1px solid #e0e0e0 !important; /* Bordure fine et discrète */
    border-radius: 20px !important;
    box-shadow: 0 15px 35px rgba(0,0,0,0.1) !important;
    padding: 15px;
}

.modal-header { border: none; position: relative; }
.project-category { color: #64bc9c; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; }
.modal-title { color: #1a1a1a; font-weight: 800; margin-top: 5px; }

.close-btn {
    position: absolute; right: 10px; top: 10px; background: none; border: none;
    color: #999; font-size: 28px; cursor: pointer; transition: 0.2s;
}
.close-btn:hover { color: #333; }

/* Typographie interne */
.section-title { color: #64bc9c; font-weight: 700; margin-bottom: 15px; font-size: 14px; }
.project-desc { color: #555; line-height: 1.6; font-size: 15px; }
.goals span { display: block; font-size: 13px; color: #777; margin-top: 8px; }
.goals i { color: #64bc9c; margin-right: 8px; }

/* Boutons stylisés */
.btn-primary-custom {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    background: #64bc9c; color: #fff !important; padding: 12px; border-radius: 12px;
    text-decoration: none !important; font-weight: 600; transition: 0.3s;
}
.btn-primary-custom:hover { background: #64bc9c; transform: translateY(-2px); }

.btn-secondary-custom {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    background: #f8f9fa; color: #1a1a1a; padding: 12px; border-radius: 12px;
    margin-top: 10px; text-decoration: none !important; border: 1px solid #eee; font-weight: 600;
}
.btn-secondary-custom:hover { background: #eee; color: #64bc9c;}

/* Badges Outils */
.side-info { border-left: 1px solid #eee; padding-left: 25px; }
.label { font-size: 11px; color: #aaa; font-weight: bold; margin: 25px 0 10px 0; text-transform: uppercase; }
.tags { display: flex; flex-wrap: wrap; gap: 8px; }
.tag { background: #f1f3f5; color: #64bc9c; padding: 5px 12px; border-radius: 8px; font-size: 12px; font-weight: 600; border: 1px solid #e9ecef; }

label span {
    color: #e74c3c; /* Un rouge un peu plus doux et moderne */
    font-weight: bold;
    margin-left: 2px;
}