/* =====================================================
   Nom du fichier : style.css
   Auteur         : Arbadine Said
   Descripton.    : Styles principaux du site
   Dernière maj   : 09-10-2025
   Approche       : Mobile First (base=393px)
===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Raleway:wght@400;600&family=Roboto:wght@400;500;700&family=Montserrat:wght@400;600&display=swap');


/* Reset / Base */
*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}


/* Variables globales */
:root{
    /* Typographie */
    --font-principale: 'Roboto', sans serif;
    --font-titres: 'Raleway', sans serif;
    --font-alternative: 'Montserrat' sans serif;

    /* Couleurs principales */
    --couleur-principale: #FCFBFC;
    --couleur-secondaire: #AA8630;
    --couleur-tertiaire: #F6F3EC;
    
    /* Couleurs textes */
    --couleur-titre: #000000;
    --couleur-texte: #0F0F0F;
    --couleur-texte-inverse: #ffffff; 

    /* Couleurs de fond */
    --fond-principal : #ffffff;
    --fons-secondaire : #F6F3EC;
    --fond-sombre : #010101;

}

body{
    font-family: var(--font-principale);
    color: var(--couleur-texte);
    background-color: var(--couleur-principale);
    line-height: 1.6;
    overflow-y: auto;
    height: auto;
}

.wrapper{

    margin-inline: auto;
}

/* Taille des fonts */
h1,h2{ font-family: var(--font-titres); color: var(--couleur-titre); }
h1{ font-size: 32px; }
h2{ font-size: 24px; font-weight: 500; }
p{ font-family: var(--fond-principal); font-size: 15px; }
a{ color: var(--couleur-texte); }

button{
    font-family: var(--font-alternative);
    background-color: var(--couleur-secondaire);
}

@media (min-width: 768px) {
    h1{ font-size: 40px;}
    h2{ font-size: 28px;}
    p{ font-size: 16px;}
}

@media (min-width: 1200px) {
    h1{ font-size: 48px;}
    h2{ font-size: 32px;}
    p{ font-size: 18px; font-weight: 300; line-height: normal;}
}



/* ========== Navbar========== */

.navbar{
    position: sticky; top: 0; z-index: 1000;
    padding: 0px 0px;
}

.nav-container{
    margin: 0 auto;
    padding: 12px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: var(--couleur-secondaire);
}

.navbar .logo{
    font-family: "Sahitya", serif;
    text-decoration: none;
    line-height: 0.8;
    font-size: 20px;
    text-align: center;
    color: var(--couleur-principale);
}

.navbar .logo span{
    font-size: 15px;
    color: #D1C59B;
}

.nav-toggle{
    appearance: none;
    -webkit-appearance: none;
    border: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    -webkit-tap-highlight-color: transparent; 
    cursor: pointer;
    outline: none; /* on gère le focus ci-dessous */
}

.nav-menu{
    position: absolute;
    top: calc(56px + 1px);
    right: 0;
    left: 0;
    background: var(--couleur-principale);
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s ease;
    display: flex;
    height: 100vh;

}

.nav-menu.open{ max-height: 80vh; }

.nav-menu ul{
    list-style: none;
    margin: 0; 
    display: flex; flex-direction: column;
    gap: 30px;
    padding: 24px;
    padding-bottom: 100px;
}

.nav-menu a{
  text-decoration: none;
  color: var(--couleur-texte);
  font-weight: 100;
  font-size: 24px;
  transition: color .2s ease;
}

.nav-space{
    display: none;
}

/* ========== Ordinateur ========== */

@media (min-width: 1024px){

    .navbar{
        background: transparent;
    }

    .nav-container{ 
        padding-left: clamp(24px, 6vw, 100px);
        padding-right: clamp(24px, 6vw, 100px);
        margin: 0px 0px;
        background-color: transparent;
        transition: background-color 0.3s ease, box-shadow 0.3s ease;
    }

    .navbar.scrolled {
        background-color: var(--couleur-principale);
        box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    }

    .navbar .logo{
        font-size: 30px;
        color: #000000;
    }

    .navbar .logo span{
        font-size: 20px;
    }

    .nav-toggle{ display: none; }

    .nav-menu{
        background: transparent;
        height: 100%;
        position: static;
        max-height: none;
        overflow: visible;
        border-top: 0;
    }
    .nav-menu ul{
        flex-direction: row;
        gap: 40px;
        padding: 0;
    }
    .nav-menu a{ 
        padding: 6px 0; 
        font-size: 16px;
    }

    .nav-menu a:hover{ 
        color: var(--couleur-secondaire);
    }



    .nav-space{
        display: block;
        background-color: transparent;
    }

}




/* Base */
.nav-menu li { position: relative; }
.submenu-toggle{
    background: transparent; 
    border: 0; 
    cursor: pointer;
    color: var(--couleur-texte);
    display: inline-flex; 
    align-items: center; 
    gap: 6px;
    padding: 0;
    font-size: 24px;
}
.has-submenu ul{
    list-style: none; 
    margin: 0; 
    padding: 0;
    max-height: 0;          
    overflow: hidden;
    transition: max-height .3s ease;
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 0px 20px;
    margin: 10px 0px;
}


.submenu a{
    display: block;
    text-decoration: none;
        
    font-size: 20px;         
    color: var(--couleur-texte);
}

/* ---- Mobile (<1024px) ---- */


.has-submenu .chevron{ transform: translateY(1px); transition: transform .2s ease; }
.has-submenu.open .chevron{ transform: rotate(180deg) translateY(-1px); }
.has-submenu.open > .submenu{ max-height: 500px; }

@media (min-width: 1024px){
  .submenu-toggle{
    color: var(--couleur-texte);
    font-size: 16px;
  }


  .has-submenu ul{
    position: absolute;
    top: 100%; left: 0;
    background: var(--couleur-principale);
    padding: 20px;
    width: 150px;
    margin: 0px;
    max-height: none;
    overflow: visible;
    display: none;
    box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  }

  .submenu a{
    font-size: 16px;
    padding: 8px 6px;
    border-radius: 8px;
  }
  .submenu a:hover{ color: var(--couleur-secondaire); }


  .has-submenu:hover .submenu,
  .has-submenu:focus-within .submenu{
    display: block;
  }

}


/* ========== Section Hero ========== */

.hero{
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: top;
    padding: 0px 24px 40px 24px;
    overflow: hidden;
}

.hero-text{
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 40px 0px;

    opacity: 0;
    transform: translateY(28px);
    animation: heroIn 520ms ease-out forwards;
    animation-delay: 120ms; 
    will-change: transform, opacity;
}

.hero-texts > * {
  opacity: 0;
  animation: fadeOnly 400ms ease-out forwards;
}

.hero-texts > *:nth-child(1) { animation-delay: 180ms; }
.hero-texts > *:nth-child(2) { animation-delay: 260ms; }
.hero-texts > *:nth-child(3) { animation-delay: 340ms; }
.hero-texts > *:nth-child(4) { animation-delay: 420ms; }
.hero-texts > *:nth-child(5) { animation-delay: 500ms; }
.hero-texts > *:nth-child(6) { animation-delay: 580ms; }

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

@keyframes fadeOnly {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Accessibilité : réduire fortement si l’utilisateur n’aime pas les animations */
@media (prefers-reduced-motion: reduce) {
    .hero-texts, .hero-texts > * {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
    }
}

.hero-text h1{
    line-height: 1.3;
    font-family: "Sahitya", serif;
    font-weight: 100;
    margin-bottom: 1.25rem;

}

.hero-text h1 span {
    display: block;
    color: #D1C59B;
}

.hero-text p{
    font-size: 15px;
}

.hero-text .encadre{
    display: flex;
    width: fit-content;
    align-items: center;
    gap: 5px;
    background-color: var(--couleur-tertiaire);
    border-radius: 5px;
    padding: 6px 10px;
}

.hero-text .encadre p{
    font-size: 8px;
}

.hero-text .encadre .icone{
    width: 15px;
    height: 15px;
}

.hero-text a{
    font-size: 12px;
}

.hero-forfait{
    margin-top: 0.5rem;
    margin-bottom: 0.7rem;
}

.hero-text .btn{
    display: inline-flex;
    align-items: center;    
    width: fit-content;
    gap: 15px;

    padding: 6px 6px 6px 20px;
    background-color: var(--couleur-secondaire);
    text-decoration: none;
    color: var(--couleur-principale);

    transition: background-color 0.3s ease;
}

.hero-text .btn:hover { 
    background-color: var(--couleur-principale);
    color: var(--couleur-secondaire);
 }

.hero-text .btn .icone{
    width: 30px;
    height: 30px;

    background-color: var(--couleur-principale);
    padding: 5px;    
}

.hero-image{
    display: flex;
    justify-content: flex-end;
    width: 100%;
    margin-right: -48px;
    margin-top: -100px;
    position: relative;
    z-index: 0;

    opacity: 0;
    transform: translateX(30px);
    animation: imageIn 600ms ease-out forwards;
    animation-delay: 600ms; 
    will-change: transform, opacity;
}

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

.hero-image .voiture{
    width: 100%;
    height: auto;
    max-width: 900px;
}


/* ========== Tablet ========== */
@media (min-width: 700px) {
    .hero{
        flex-direction: row;
    }

    .hero-image{
        margin-top: 0px;
    }

}

/* ========== Ordinateur ========== */
@media (min-width: 1024px) {
    .start-space{
        height: 0px;
    }
    .hero{
        padding: 50px;
        padding-left: clamp(24px, 6vw, 100px);
        padding-right: clamp(24px, 6vw, 100px);
        overflow: visible;
    }
    
    .hero-text{
        padding: 40px 0px;
    }

    .hero-text h1{
        font-size: 60px;
        line-height: 1.3;
    }

    .hero-text .encadre{
        gap: 8px;
    }

    .hero-text .encadre p{
        font-size: 17px;
    }

    .hero-text .encadre .icone{
    width: 20px;
    height: 20px;
}

    .hero-text p{
        font-size: 17px;
    }

    .hero-text a{
        font-size: 17px;
    }

    .hero-text .btn {
        gap: 25px;  
        padding: 5px 5px 5px 35px;
    }

    .hero-text .btn .icone{
        width: 40px;
        height: 40px;

        background-color: var(--couleur-principale);
        padding: 8px;    
    }

    .hero-image{
        margin-top: -130px;
        margin-right: calc(clamp(24px, 6vw, 100px) * -1);
    }
    
}


/* ========== Section Populaire ========== */

.populaire{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    background-color: var(--couleur-tertiaire);
    gap: 50px;
}

.populaire h1{
    text-align: center;
    padding: 0% 15%;
}

.populaire-cards-container{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
}

.populaire-cards{
    display: flex;
    flex-wrap: wrap;
    gap: 36px;
    justify-content: center;
}

.populaire-cards > .card {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s ease-out, transform .6s ease-out;
}

.populaire-cards > .card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Accessibilité */
@media (prefers-reduced-motion: reduce) {
  .populaire-cards > .card {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

/* From Uiverse.io by Yaya12085 */ 
.card {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 320px;
    flex-direction: column;
    border-radius: 5px;
    background-color: var(--couleur-principale);
    padding: 20px 24px;
    gap : 20px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}



.card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0; 
  background-color: #AA8630; 
  transition: height 0.3s ease;
}

.card:hover::before {
  height: 5px; 
}

.card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.15);
}

.header {
  display: flex;
  flex-direction: row;
  justify-content: space-between;

}

.card-formation{
    color: var(--couleur-secondaire);
}

.price {
  color: var(--couleur-texte);
}

.desc {
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
  color: var(--couleur-texte)
}

.card-line{
    width: 100%;
    height: 1px;
    background-color: var(--couleur-texte);
}

.lists {
  margin-bottom: 30px;
  flex: 1 1 0%;
  gap: 20px;
  display: flex;
  flex-direction: column;
}

.lists .list {
  display: flex;
  margin-left: 0.5rem;
  gap: 10px;
  align-items: center;
}

.lists .list svg {
  height: 1.1rem;
  width: 1.1rem;
  flex-shrink: 0;
  margin-right: 0.5rem;
}

.action {
  border: none;
  outline: none;
  display: inline-block;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  width: 100%;
  text-decoration: none;
  
  background-color: var(--couleur-secondaire);
  text-align: center;
  color: var(--couleur-principale);
  transition: background-color 0.3s ease;
}

.action:hover { 
    background-color: var(--couleur-principale);
    color: var(--couleur-secondaire);
 }

.evaluation{
    text-decoration: underline;
    padding: 0% 15%;
    text-align: center;
    font-style: italic;
}

.financement{
    display : flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
    text-align: center;
}

.financement-images{
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 30px;
}

.financement-images img{
    width: 30%;
}

.financement p{
    max-width: 700px;
}

.financement span{
    font-weight: bold;
}

/* ========== Ordinateur ========== */
@media(min-width: 1024px) {
    .populaire{
        padding: 120px 100px;
        padding-left: clamp(24px, 6vw, 100px);
        padding-right: clamp(24px, 6vw, 100px);
        gap: 100px;
    }

    .populaire h1{
        text-align: left;
        padding: 0% 0%;
    }   

    .populaire-cards{
        gap: 0px;
        justify-content: space-between;
    }

    .card{
        width: 32%;
        gap: 30px;
        padding: 2.75rem 2rem;
    }

    .lists{
        gap: 30px;
        margin-bottom: 50px;
    }

    .card-button-container{
        display: flex;
        justify-content: center;

    }

    .action {
        width: auto;
        padding: 14px 36px;
    }
}




/* ========== Section Formations ========== */

.formations{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    background-color: var(--couleur-tertiaire);
    gap: 50px;
}

.formations h1{
    text-align: center;
    padding: 0% 10%;
}

.formations-container{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.formations-cards{
    display: flex;
    flex-wrap: wrap;
    gap: 36px;
    justify-content: center;
}

.formation{
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    width: 320px;
    flex-direction: column;
    background-color: var(--couleur-tertiaire);
    padding: 20px 24px;
    gap : 30px;
}

.formations-cards > .formation {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s ease-out, transform .6s ease-out;
}

.formations-cards > .formation.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Accessibilité */
@media (prefers-reduced-motion: reduce) {
  .formations-cards > .formation {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

.formation-image{
    display: flex;
    align-items: center;
    justify-content: center;
}

.formation-image img{
    width: 50px;
    height: 50px;
}

.formation-text{
    display: flex;
    flex-direction: column;
    text-align: center;
    gap: 8px;
}

.formations .action {
  border: none;
  outline: none;
  text-decoration: underline;
  display: inline-block;
  background-color: var(--couleur-tertiaire);
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  width: 100%;
  text-align: center;
  color: var(--couleur-secondaire);
}

.formations .action:hover{
    background-color: var(--couleur-secondaire);
    color: var(--couleur-texte-inverse);
    padding: 14px 36px;
}

.formations span{
    font-weight: bold;
}

/* ========== Ordinateur ========== */
@media(min-width: 1024px) {
    .formations{
        padding: 120px 100px;
        padding-left: clamp(24px, 6vw, 100px);
        padding-right: clamp(24px, 6vw, 100px);
        gap: 100px;
    }

    .formations h1{
        text-align: left;
        padding: 0% 0%;
    }   

    .formations-cards{
        gap: 0px;
        justify-content: space-between;
    }

    .formation{
        width: 30%;
        gap: 50px;
        padding-left: 0%;
        padding-right: 0%;
    }

    .formation h2{
        font-size: 26px;
    }

    .formation-image{
        justify-content: left;
    }

    .formation-text{
        text-align: left;
        gap: 20px;
    }

    .card-button-container{
        display: flex;
        justify-content: center;
    }

    .formation .action {
        width: auto;
        padding: 0;
    }
}



/* ========== Section À propos ========== */

.a-propos{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    background-color: var(--couleur-principale);
    gap: 60px;
    text-align: center;
    align-items: center;
}

.a-propos h1{
    padding: 0% 10%;
}

.a-propos-text{
    display: flex;
    flex-direction: column;
    justify-content: left;
    text-align: lef;
    gap: 100px;
}

.a-propos-text-description{
    display: flex;
    flex-direction: column;    
    gap: 20px;
}

.a-propos-image{
    display: flex;
    flex-direction: column;
    width: 100%;
}

.a-propos-avantages{
    display: flex;
    flex-direction: column;
    gap: 50px;
    width: 75%;
}

.acc { 
    border-top: 1px solid var(--couleur-texte); 
    padding: 40px 0px;
    display: flex;
    flex-direction: column;
    gap: 0px;
}

.acc:last-of-type { 
    border-bottom: 1px solid var(--couleur-texte); 
}

.acc summary {
    text-align: left;
    display: flex; 
    flex-direction: row;
    align-items: center; 
    gap: 5px;
    cursor: pointer; 
    font-weight: 500;
    font-size: 18px;
    outline: none;
    justify-content: space-between;
}

summary:focus {
  outline: none;
}

.acc summary::-webkit-details-marker { 
    display: none; 
} 

.toggle { 
    font-size: 12px;
    font-weight: 400; 
    color: #888; 
    text-decoration: underline;
}
.voir-moins { display: none; }
.acc[open] .voir-plus { display: none; }
.acc[open] .voir-moins { display: inline; }

.content { 
    overflow: hidden; 
    max-height: 0; 
    transition: max-height .3s ease; 
    justify-content: left;

}

.acc .content ul{
    display: flex;
    flex-direction: column;
    gap: 30px;
    text-align: left;
    justify-content: left;
}

.acc .content li{
    display: flex;
    gap: 8px;
    align-items: center;
}

.acc .content li img{
    width: 5px;
    height: 5px;
}


.acc[open] .content { max-height: 300px; }
.content > * { margin: 0 0 12px 0; }


@media(max-width: 1024px) {
    .acc summary {
        margin-bottom: 40px;
    }

    .a-propos-text{
        max-width: 700px;
    }

    .a-propos-text p {
        text-align: left;
    }

    .a-propos-image{
        max-width: 700px;
    }

    .a-propos-avantages{
        max-width: 700px;
    }


}

/* ========== Ordinateur ========== */
@media(min-width: 1024px) {
    .a-propos{
        flex-direction: row;
        align-items: start;
        text-align: left;
        padding: 120px 100px;
        padding-left: clamp(24px, 6vw, 100px);
        padding-right: clamp(24px, 6vw, 100px);
        align-items: stretch;
        gap: 50px;
    }

    .a-propos h1{
        padding: 0px;
    }

    .a-propos-text, .a-propos-image, .a-propos-avantages{
        width: 33%;
    }

    .a-propos-image{
        overflow: hidden;
    }

    .a-propos-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        display: block;
    }

    .a-propos-text{
        justify-content: space-between;
    }

    .a-propos-avantages{
        justify-content: space-between;
    }

    .acc{
        gap: 30px;
    }

    .acc summary{
        align-items: start;
        flex-direction: row;
        justify-content: space-between;
    }

    .acc .content li img{
        display: block;
    }
}





/* ========== Section Avis clients ========== */

.avis-clients{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    background-color: var(--couleur-principale);
    gap: 60px;
    text-align: center;
    align-items: center;
    justify-content: center;
}

.avis-container{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 36px;
}

/* From Uiverse.io by Yaya12085 */ 
.avis {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background-color: var(--couleur-principale);
  padding: 20px;
  max-width: 320px;
  gap: 20px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);

}

.avis-head{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}

.stars {
  display: flex;
  grid-gap: 0.125rem;
  gap: 0.125rem;
  color: rgb(238, 203, 8);
}

.star {
  height: 1.25rem;
  width: 1.25rem;
}

.description {
  color: rgba(107, 114, 128, 1);
  text-align: left;
}

.avis-clients a{
    margin-top: -30px;
}

.reussite{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 36px;
}

.reussite-logos{
    display: flex;
    flex-wrap: wrap;
    gap: 36px;
    align-items: center;
    justify-content: center;
}

.reussite-logo{
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center;
}

.reussite-logo img{
    width: 30px;
    height: 30px;
}

.reussite-texte{
    max-width: 700px;
}


/* ========== Ordinateur ========== */

@media (min-width: 1024px){

    .avis-clients{ 
        padding: 120px clamp(24px, 6vw, 100px);
        gap: 100px;
        align-items: start;
        overflow-x: hidden;
    }

    .avis-container{
        flex-wrap: nowrap;
        align-items: left;
        justify-content: left;
        gap: 30px;

        overflow-x: auto;   
        overflow-y: hidden; 
        padding: 1rem;
        scroll-behavior: smooth;
    }

    .avis{
        flex-shrink: 0;
    }

    .reussite{
        flex-direction: row;
        gap: 100px;
    }
    .reussite-logos{
        flex-wrap: nowrap;
    }

    .reussite-texte{
        text-align: left;
        max-width: 500px;
    }
}






/* ========== Section Nous trouver ========== */

.nous-trouver{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    gap: 50px;
    align-items: center;
    text-align: center;
    background-color: var(--couleur-tertiaire);
}

.nous-trouver-elements{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 50px;
    width: 100%;
}
.nous-trouver-text{
    display: flex;
    flex-direction: column;
    gap: 50px;
}

.nous-trouver-text span{
    font-weight: 600;
}

.nous-trouver-text-first{
    display: flex;
    flex-direction: column;
    gap: 36px
}

.nous-trouver-text-second{
    display: flex;
    flex-direction: column;
}

.nous-trouver-text-info{
    display: flex;
    flex-direction: column;
    gap: 0px;
}

.nous-trouver-maps{
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 700px;
    height: 300px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}


/* ========== Tablet ========== */
@media (min-width: 700px) {
    

    .nous-trouver h1{
        max-width: none;
    }

    .nous-trouver-text{
        flex-direction: row;
        gap: 150px;
        max-width: none;
        text-align: left;
    }

    .nous-trouver-elements{
        width: 100%;
        flex-direction: column;
        justify-content: space-between;
        gap: 50px;
    }

}

/* ========== Ordinateur ========== */

@media (min-width: 1024px){

    .nous-trouver{ 
        padding: 120px clamp(24px, 6vw, 100px);
        gap: 100px;
        align-items: start;

    }

    .nous-trouver-elements{
        flex-direction: row;
        gap: 0px;
        justify-content: space-around;
    }

    .nous-trouver-text span{
        font-size: 20px;
    }

    .nous-trouver-text{
        width: 66%;
        gap: 0px;
        justify-content: space-between;
    }

    .nous-trouver-text-first, .nous-trouver-text-second{
        width: 100%;
    }

    .nous-trouver-text-info{
        gap: 10px;
    }

    .nous-trouver-text-second{
        gap: 10px;
    }


    .nous-trouver-maps{
        width: 45%;
        height: 400px;
    }

    .nous-trouver-text-horaires{
        display: flex;
        flex-direction: column;
        gap: 10px;
    }

}


/* ========== animation section A propos, avis et nous trouver ========== */

.a-propos,
.avis-clients,
.nous-trouver {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.a-propos.is-visible,
.avis-clients.is-visible,
.nous-trouver.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* accessibilité */
@media (prefers-reduced-motion: reduce) {
  .a-propos,
  .avis-clients,
  .nous-trouver {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}



/* ========== Section FAQ ========== */

.faq{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    align-items: center;
    justify-content: center;
    gap: 50px;
    text-align: center;
}

.faq-titre h1{
    color: var(--couleur-secondaire);
}

.faq-texte{
    display: flex;
    flex-direction: column;
    gap: 50px;
}

.faq-texte-contenu{
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.faq-texte-contenu span{
    font-weight: 500;
}

.faq-texte p{
    max-width: 700px;
}

.faq-texte-contenu {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .6s ease-out, transform .6s ease-out;
}
.faq-texte-contenu.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ========== Ordinateur ========== */

@media (min-width: 1024px){

    .faq{ 
        flex-direction: row;
        padding: 120px clamp(24px, 6vw, 100px);
        gap: 70px;
        align-items: start;
        justify-content: space-between;
        text-align: left;
        gap: 200px;
    }

    .faq-texte p{
        max-width: none;
    }


    .faq-texte{
        width: 60%;
        gap: 100px;
    }
}



/* ========== Bulle flotante ========== */

.bulle-appel {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 50px;
  height: 50px;
  cursor: pointer;
  z-index: 1000;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.bulle-appel:hover {
  transform: scale(1.1);
}

.icone-telephone {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 6px 15px rgba(0,0,0,0.25));
}


@media (min-width: 1025px) {
  .bulle-appel {
    display: none;
  }
}



/* ========== Footer ========== */

footer{
    padding: 60px 24px;
    background-color: var(--couleur-texte);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 50px;
    color: var(--couleur-principale)
}

.foot-head{
    display: flex;
    flex-direction: column;
    gap: 36px;
}

footer h1{
    line-height: 1.3;
    font-family: "Sahitya", serif;
    font-weight: 100;
    color: var(--couleur-principale);
}

footer h1 span {
    display: block;
    color: #D1C59B;
    font-size: 20px;
}

footer h2{
    color: var(--couleur-principale);
    font-size: 20px;
}

.foot-info{
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.foot-link{
    display: flex;
    flex-direction: column;
    gap: 16px;
    text-transform: uppercase;
}

footer a{
    color: var(--couleur-principale);
    text-decoration: none;
}


/* ========== Ordinateur ========== */

@media (min-width: 1024px){

    footer{ 
        padding: 60px clamp(24px, 6vw, 100px);
        gap: 100px;    
        flex-direction: column;
        justify-content: space-between;
        width: 100%;    
    }

    footer h2{
        font-size: 26px;
    }

    .foot-head{
        flex-direction: row-reverse;
        gap: 36px;
        width: 100%;
        justify-content: space-between;
    }

    .foot-info{
        text-align: left;
    }

    .foot-link{
        width: 100%;
        text-align: left;
    }

    .foot-link p{
        font-weight: 500;
        margin-bottom: 20px;
    }
}


/* ========== Crédit ========== */

.credit{
    display: flex;
    flex-direction: column;
    background-color: var(--couleur-texte);
    align-items: center;
    color: var(--couleur-principale);
    padding-bottom: 10px;

}

.credit p {
    font-size: 12px;
}

.credit a{
    font-size: 12px;
    color: var(--couleur-principale);
}

/* ========== Ordinateur ========== */

@media (min-width: 1024px){

    .credit{
        flex-direction: row;
        gap: 36px;
        text-align: center;
        align-items: center;
        justify-content: center;
        width: 100%;
        padding: 0px clamp(24px, 6vw, 100px);
        padding-bottom: 10px;
    }
}



/* ============================== PAGE FORMATION ============================== */

/* ========== Section Hero ========== */

.formation-hero{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 24px;
    overflow: hidden;
    background-color: var(--couleur-tertiaire);
    text-align: center;
}

.formation-hero-text{
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 40px;
    padding: 40px 0px;
}

.formation-hero-text p{
    max-width: 600px;
}

.tarifs{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 30px;
}

.tarif p{
    font-weight: lighter;
    color: var(--couleur-texte);
    font-family:'Raleway', sans serif;
}

.tarif span{
    color: var(--couleur-secondaire);
}

.formation-hero-text h1 span {
    color: var(--couleur-secondaire)
}

.formation-hero-text a{
    font-size: 12px;
}

.formation-hero-text .btn{
    display: inline-flex;
    align-items: center;    
    width: fit-content;

    padding: 12px 24px;
    background-color: var(--couleur-secondaire);
    text-decoration: none;
    color: var(--couleur-tertiaire);

    transition: background-color 0.3s ease;
}

.formation-hero-text .btn:hover { 
    background-color: var(--couleur-principale);
    color: var(--couleur-secondaire);
}


.formation-hero-image{
    display: none;
}

/* ========== Tablet ========== */
@media (min-width: 700px) {
    .formation-hero{
        flex-direction: row;
    }

}

/* ========== Ordinateur ========== */
@media (min-width: 1024px) {
    .start-space{
        height: 0px;
    }
    .formation-hero{
        text-align: left;
        padding: 0px;
        padding-left: clamp(24px, 6vw, 100px);
        padding-right: clamp(24px, 6vw, 100px);
        overflow: hidden;
        justify-content: space-between;
    }

    .formation-hero-text{
        gap: 50px;
        align-items: start;
    }

    .tarifs{
        gap: clamp(10px, 4vw, 100px);
        flex-wrap: nowrap;
    }


    .formation-hero-text p{
        font-size: 20px;
    }

    .formation-hero-text a{
        font-size: 17px;
    }

    .formation-hero-text .btn {
        padding: 5px 35px 5px 35px;
    }

    .formation-hero-image{
        display: flex;
        height: 100%;
        padding: 0px;
        margin-right: calc(clamp(24px, 6vw, 100px) * -1); 
    }

    .formation-hero-image .image{
        height: 100%;
    }
    
}

@media (min-width: 1200px) {
    .tarifs{
        gap: 100px;
    }
}



/* ========== Section Infos ========== */

.formation-infos{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    gap: 50px;
    align-items: center;
    text-align: center;
    background-color: var(--couleur-principale);
}

.formation-infos-inclus, .formation-infos-documents{
    display: flex;
    flex-direction: column;
    gap: 36px;
}

.formation-infos .lists {
    width: 300px;
    align-items: start;
    margin-bottom: 30px;
    flex: 1 1 0%;
    gap: 20px;
    display: flex;
    flex-direction: column;
}

.formation-infos .lists .list {
    text-align: left;
  display: flex;
  margin-left: 0.5rem;
  gap: 10px;
  align-items: start;
}

.formation-infos .lists .list svg {
  height: 1.1rem;
  width: 1.1rem;
  flex-shrink: 0;
  margin-right: 0.5rem;
}


/* ========== Tablet ========== */
@media (min-width: 700px) {
    .formation-infos{
        align-items: start;
        justify-content: center;
        flex-direction: row;
    }

}

/* ========== Ordinateur ========== */
@media (min-width: 1024px) {
    .formation-infos{
        padding: 50px clamp(24px, 6vw, 100px);
        justify-content: start;
        gap: clamp(10px, 10vw, 100px);
    }

    .formation-infos-documents{
        text-align: left;
    }

    .formation-infos-documents .lists{
        display: grid;
        grid-template-columns: repeat(2, 1fr); 
        column-gap: clamp(10px, 4vw, 40px);
        width: auto;
    }

    .formation-infos-documents .list{
        max-width: 350px;
    }
}


/* ========== Section Description ========== */

.formation-description{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    gap: 50px;
    align-items: center;
    text-align: center;
    background-color: var(--couleur-principale);
}
.formation-description:last-of-type{
    margin-bottom: 50px;
}

.formation-description-titre{
    display: flex;
    flex-direction: column;
    gap: 0px;
}

.formation-description-titre p{
    color: var(--couleur-secondaire);
}



.formation-description-texte{
    text-align: left;
    max-width: 700px;
    display: flex;
    flex-direction: column;
    gap: 36px;
}

.formation-description:nth-last-child(1 of .formation-description) {
    padding-bottom: 250px;
}


/* ========== Ordinateur ========== */
@media (min-width: 1024px) {
    .formation-description{
        padding: 50px clamp(24px, 6vw, 100px);
        align-items: start;
    }

    .formation-description:last-of-type{
        padding-bottom: 100px;
    }

    .formation-description-titre{
        text-align: left;
    }

    .formation-description-texte{
        max-width: 80%;
    }

    .formation-description:nth-last-child(1 of .formation-description) {
        padding-bottom: 500px;
    }
}



/* ========== Animation formation ========== */


/* état initial */
.formation-hero .formation-hero-text {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .48s ease-out, transform .48s ease-out;
}

.formation-hero .tarifs .tarif {
  opacity: 0;                 /* stagger sur les 3 tarifs (opacité seule) */
  transition: opacity .4s ease-out;
}

.formation-hero .formation-hero-image {
  opacity: 0;
  transform: translateX(18px);
  transition: opacity .52s ease-out, transform .52s ease-out;
  transition-delay: .22s;     /* arrive après le texte */
}

/* quand le hero devient visible */
.formation-hero.is-visible .formation-hero-text {
  opacity: 1;
  transform: translateY(0);
}

.formation-hero.is-visible .tarifs .tarif:nth-child(1) { opacity: 1; transition-delay: .10s; }
.formation-hero.is-visible .tarifs .tarif:nth-child(2) { opacity: 1; transition-delay: .17s; }
.formation-hero.is-visible .tarifs .tarif:nth-child(3) { opacity: 1; transition-delay: .24s; }

.formation-hero.is-visible .formation-hero-image {
  opacity: 1;
  transform: translateX(0);
}

/* accessibilité */
@media (prefers-reduced-motion: reduce) {
  .formation-hero .formation-hero-text,
  .formation-hero .formation-hero-image,
  .formation-hero .tarifs .tarif {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}


/* état initial */
.formation-infos .list {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease-out, transform 0.5s ease-out;
}

/* une fois visible */
.formation-infos .list.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* accessibilité */
@media (prefers-reduced-motion: reduce) {
  .formation-infos .list {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

.formation-description {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.formation-description.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Accessibilité */
@media (prefers-reduced-motion: reduce) {
  .formation-description {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}




/* ========== Mentions Légales ========== */

.mentions-legales{
    display: flex;
    flex-direction: column;
    padding: 60px 24px;
    background-color: var(--couleur-tertiaire);
    gap: 50px;
}

.mentions-legales strong{
    font-weight: 600;
}


/* ========== Ordinateur ========== */
@media (min-width: 1024px) {
    .mentions-legales{
        padding: 50px clamp(24px, 6vw, 100px);
        align-items: start;
    }

    .mentions-legales p{
        max-width: 1000px;
    }
    
}