/* ============================================================
   FICHIER DE STYLE PRINCIPAL (FRONT-END)
   Projet : Soins Alternatifs
   Description : Surcharge Bootstrap, Couleurs Charte, 
                 Composants spécifiques (Menu, Tabs, Footer).
   Mise à jour documentaire : 15/03/2026
   ============================================================ */

/* --- 1. VARIABLES GLOBALES & UTILITAIRES --- */
:root {
  --main-blue-color: #02a6c0; /* Bleu Charte (Titres, Liens, Btn1) */
  --main-green-color: #27c414; /* Vert Action (Validation, Hover) */
}

/* Classes utilitaires de couleur */
vert {
    color: var(--main-green-color);
}
bleu {
    color: var(--main-blue-color);
}

rouge {
    color:#F00;
}

/*=== Header area start ===*/

/* --- 2. TYPOGRAPHIE & BASE --- */
body {  
    font-family: 'Arial', sans-serif;
    font-size: 16px;
    font-weight: 400;    
    background: #fff;
    color: #333333; 
}

h2,h3,h4,h5 {   
    color:  #02a6c0;    
    font-weight: 600;    
}

/* --- 3. RESPONSIVE TYPOGRAPHY --- */

/* Mobile (< 576px) */
@media all and (max-width: 576px) { 
body {  
    font-size: 14px;
}
 h1 {
    font-size: 18px;
}
 h2 {
    font-size: 16px;
}
 h3 {
    font-size: 15px;
}
 h4 {
    font-size: 14px;
}
}

/* Tablettes (576px - 768px) */
@media all and (min-width: 576px) and (max-width: 767.98px) {
body {  
    font-size: 16px;
}
 h1 {
    font-size: 20px;
}
 h2 {
    font-size: 18px;
}
 h3 {
    font-size: 17px;
}
 h4 {
    font-size: 16px;
}
}

/* Tablettes Paysage (768px - 992px) */
@media all and (min-width: 768px) and (max-width: 991.98px) {
body {  
    font-size: 17px;
}
  h1 {
    font-size: 30px;
}
 h2 {
    font-size: 20px;
}
 h3 {
    font-size: 19px;
}
 h4 {
    font-size: 18px;
}
}

/* Écrans Desktop (992px - 1200px) */
@media all and (min-width: 992px) and (max-width: 1199.98px) {
body {  
    font-size: 18px;
}
 h1 {
    font-size: 40px;
}
 h2 {
    font-size: 20px;
}
 h3 {
    font-size: 19px;
}
 h4 {
    font-size: 18px;
}
}

/* Très grands écrans (> 1200px) */
@media all and (min-width: 1200px) {
body {  
    font-size: 19px;
}
  h1 {
    font-size: 40px;
}
 h2 {
    font-size: 20px;
}
 h3 {
    font-size: 19px;
}
 h4 {
    font-size: 18px;
}
}

/* --- 4. COMPORTEMENT DES LIENS & LISTES --- */
a {
    text-decoration: none;
    color: #02A6C0;
}

a:hover {
    text-decoration: none;
    color: #27c414;
}

/* Reset de liste global */
ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

/* CORRECTIF : Restauration des puces pour le contenu CKEditor dans .recherch_area */
.recherch_area ul {
    list-style-type: disc !important;
    margin-left: 40px !important;
    margin-top: 10px;
    margin-bottom: 20px;
}

.recherch_area ul li {
    display: list-item !important;
    list-style: disc !important;
    margin-bottom: 8px;
}

/* Images fluides */
img {
    max-width: 100%;
}

/* Suppression outline focus */
input:focus,
textarea:focus,
button:focus {
    outline: none;
}

/* Couleur de sélection de texte */
::selection {
    color: white; 
    background: #ff7675;
}

::-webkit-selection {
    color: white; 
    background: #ff7675;
}

::-moz-selection {
    color: white; 
    background: #ff7675;
}

/* --- 5. BOUTON "SCROLL TO TOP" --- */
.scrolltotop {
    width: 40px;
    height: 40px;
    border-radius: 20px 20px 0 0;
    background: rgba(0,0,0,.5);   
    text-align: center;
    padding-top: 8px;
    font-size: 22px;
    color: #ffffff;
    position: fixed;
    right: 5px;
    bottom: 5px;
    display: none; 
    transition: 0.2s all ease;
    -webkit-transition: 0.2s all ease;
    -moz-transition: 0.2s all ease;
}

.scrolltotop:hover {   
    background: #000;
    color: #fff;
    box-shadow: 0px 0px 5px rgba(0,0,0,.5);
    -webkit-box-shadow: 0px 0px 5px rgba(0,0,0,.5);
    -moz-box-shadow: 0px 0px 5px rgba(0,0,0,.5);   
}

.header-item {
    display: flex;
    align-items: center;
}

.header-item div:nth-of-type(2) {
    margin: 0 auto;
}

.header-item img {
    max-width: 100%;
}

.header-item div:nth-of-type(1) img {
    max-width: 120px;
}


/*=== menu 3 ===*/
/* --- 6. BARRE DE NAVIGATION (NAVBAR) --- */
.navbar {
    padding: 0;
    background-color:#02a6c0;
    border:thick;
    border-color:black;
}

.navbar-nav .nav-link {
    color: #fff;
    font-weight: 700;
    text-transform: uppercase;
    padding: 20px 15px!important;
    font-size: 17px;
    display: block;
    margin-left: 20px;
    text-shadow: 2px 1px 0px rgb(0 0 0 / 50%);
    transition: 0.2s all ease;
    -webkit-transition: 0.2s all ease;
    -moz-transition: 0.2s all ease;
}

.navbar-nav .nav-link i {
    font-size: 18px;
    margin-left: 10px;
}

.navbar-nav .nav-link:hover {
    opacity: .8;
}

/* Dropdown Menu - Desktop */
@media all and (min-width: 992px) {
    .dropdown-menu {
        border: 0;
        padding: 0;
        background-color:#02a6c0;
    }
    
    .dropdown-menu li a {
        line-height: 2.5;
        font-size: 18px;
        border-bottom: 2px solid white;
        white-space: nowrap;
    }
    
    .dropdown-menu li a {
        background-color:#02a6c0;
        color: #fff;
    }
    .dropdown-menu li a:hover {
        color: #02a6c0;
        background-color:white;
    }
}   

/* Dropdown Menu - Mobile/Tablette */
@media all and (max-width: 991px){
    .navbar-nav .nav-link {
        border-top: 2px solid white;
    }
    
    .dropdown-menu {
        border: 0;
        padding: 0;
        text-align: left;
        top: auto;
        left: 5%;
    }
    .dropdown-menu li {
        line-height: 2.5;
        font-size: 18px;
        border-bottom: 2px solid white;
    }
    .dropdown-menu li a {
        color: #02a6c0;
        background-color:white;
    }
    .dropdown-menu li a:hover {
        color: #fff;
        background-color:#02a6c0;
    }
}

/* Styles spécifiques iPhone */
@media all and (max-device-width: 480px) {
    .navbar {
        padding: 0;
        background-color:#02a6c0;
        border:thick;
        border-color:black;
    }
    .navbar-nav .nav-link {
        border-top: 2px solid white;
    }
    
    .dropdown-menu {
        border: 0;
        padding: 0;
        text-align: left;
        top: auto;
        left: 5%;
    }
    .dropdown-menu li {
        line-height: 2.5;
        font-size: 18px;
        border-bottom: 2px solid white;
    }
    .dropdown-menu li a {
        color: #02a6c0;
        background-color:white;
    }
    .dropdown-menu li a:hover {
        color: #fff;
        background-color:#02a6c0;
    }
 }

.navbar-toggler,
.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler-icon:focus {
    outline: none;
    box-shadow: none;
}

.modal-content {
    background: transparent;
    border: none;
}

.btnsaisie{
    color:#fff;
    background-color: #02a6c0;
    border-radius: 12px;
    justify-content: center;
    align-items: center;
    border:none;
    margin-left: 8px !important;
    padding: 0 15px;
    transition: 0.2s all ease;
}
.btnsaisie:hover{
    color:#27c414;
}

/* --- 7. MENU LATÉRAL / SIDE MENU --- */
.side-menu-item {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    width: 100%;
    z-index: 99999999999;
    padding: 0 15px;
    display: none;
}

.side-menu-item ul li a {
    font-size: 17px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 10px;
    border-bottom: 1px solid #fff;
    background: #02a6c0;
    transition: 0.2s all ease;
    -webkit-transition: 0.2s all ease;
    -moz-transition: 0.2s all ease;
}

.side-menu-item ul li:last-of-type a {
    border-bottom: none;
}

.side-menu-item ul li a i:nth-of-type(2) {
    display: none;
}

.side-menu-item ul li a:hover {
    background: #fff;
    color: #02a6c0;
}

.side-menu-item ul li ul {
    display: none;
}

.side-menu-item ul li ul li a {
    font-size: 16px;
    text-transform: capitalize;
    padding-left: 30px;
    transition: 0.6s all ease;
    -webkit-transition: 0.6s all ease;
    -moz-transition: 0.6s all ease;
}

.side-menu-item ul li ul li a:hover {
    padding-left: 20px;
}

.fondmenu {
    color: #fff;
    background-color: #02a6c0;
    font-size: 18px;
}

/* --- 8. ANIMATION MENU HAMBURGER --- */
.hamburger {
    padding: 0px 0px;
    display: inline-block;
    cursor: pointer;
    transition-property: opacity, filter;
    transition-duration: 0.15s;
    transition-timing-function: linear;
    font: inherit;
    color: inherit;
    text-transform: none;
    background-color: transparent;
    border: 0;
    margin: 0;
    overflow: visible;
}
.hamburger:hover { opacity: 1; }
.hamburger.is-active:hover { opacity: 1; }
.hamburger.is-active .hamburger-inner,
.hamburger.is-active .hamburger-inner::before,
.hamburger.is-active .hamburger-inner::after {
    background-color: #fff;
}

.hamburger-box {
    width: 30px;
    height: 20px;
    display: inline-block;
    position: relative;
}

.hamburger-inner {
    display: block;
    top: 50%;
    margin-top: -2px;
}
.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after {
    width: 35px;
    height: 4px;
    background-color: #fff;
    border-radius: 4px;
    position: absolute;
    transition-property: transform;
    transition-duration: 0.15s;
    transition-timing-function: ease;
}
.hamburger-inner::before,
.hamburger-inner::after {
    content: "";
    display: block;
}
.hamburger-inner::before { top: -10px; }
.hamburger-inner::after { bottom: -10px; }

.hamburger--spring .hamburger-inner {
    top: 2px;
    transition: background-color 0s 0.13s linear;
}
.hamburger--spring .hamburger-inner::before {
    top: 10px;
    transition: top 0.1s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1),
                transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}
.hamburger--spring .hamburger-inner::after {
    top: 20px;
    transition: top 0.2s 0.2s cubic-bezier(0.33333, 0.66667, 0.66667, 1),
                transform 0.13s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.hamburger--spring.is-active .hamburger-inner {
    transition-delay: 0.22s;
    background-color: transparent !important;
}
.hamburger--spring.is-active .hamburger-inner::before {
    top: 0;
    transition: top 0.1s 0.15s cubic-bezier(0.33333, 0, 0.66667, 0.33333),
                transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 10px, 0) rotate(45deg);
}
.hamburger--spring.is-active .hamburger-inner::after {
    top: 0;
    transition: top 0.2s cubic-bezier(0.33333, 0, 0.66667, 0.33333),
                transform 0.13s 0.22s cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translate3d(0, 10px, 0) rotate(-45deg);
}

/* --- 9. SLIDER D'IMAGES (Owl Carousel) --- */
.carousel-area { padding: 70px 0; }
.carousel-area-inner { max-width: 900px; margin: 0 auto; }
.content-item { position: relative; }
.content-item-inner {
    position: absolute;
    width: 100%;
    left: 0px;
    bottom: 0;
    padding: 30px;
}
.content-item-inner p {
    font-size: 16px;
    font-weight: 400;
    color: #fff;
    margin: 0;
}
.owl-carousel .owl-nav button.owl-next, .owl-carousel .owl-nav button.owl-prev {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #0bc990;
    font-size: 25px;
    color: #fff;
    position: absolute;
    display: flex;
    text-align: center;
    justify-content: center;
    line-height: 35px;
    top: 50%;
    transform: translateY(-50%);
    transition: 0.2s all ease;
}

/* --- 10. ZONE "DEVISE" / OFFRES / CARTES --- */
.devise-area { padding: 60px 0 80px; overflow: hidden; }
.devise-item h2 {
    font-size: 30px;
    font-weight: 700;
    color: #02a6c0;
    text-align: center;
    margin: 0 0 70px;
}

.devise-item2 {
    box-shadow: 0 5px 10px #cccccc;
    margin-bottom: 25px;
    min-height: 740px;
}

.devise-item2-inner2 a {
    font-size: 16px;
    font-weight: 400;
    padding: 10px 25px;
    color: #FFFFFF;
    display: inline-block;
    border-radius: 12px;
    background-color: #02A6C0;
    transition: 0.2s all ease;
}

.devise-item2-inner2 a:hover {
    background-color: #27c414;
}

/* --- 11. ZONE "SQUARE" --- */
.square-area { padding: 50px 0; }
.square-item h3 {
    font-size: 30px;
    font-weight: 700;
    color: #000;
    margin: 0 0 15px;
}

/* --- 12. ONGLETS --- */
.tab-area { padding: 10px 0 60px; }
#tabs ul li a {
    font-size: 16px;
    font-weight: 400;
    color: #006600;
    background-color: #0bc990;
    padding: 8px 16px;
    display: inline-block;
    border: 1px solid transparent;
    border-radius: 4px 4px 0 0;
    margin-bottom: -1px;
    transition: 0.2s all ease;
}
#tabs ul li a:hover { background-color: #1dacbe; }
#tabs ul li.ui-state-active a {
    background: #fff;
    border-color: #006600;
    border-bottom-color: #fff;
}

/* --- 13. PIED DE PAGE (FOOTER) --- */
.footer-area {
    background: #02a6c0;
    padding: 40px 0 20px;
}
.footer-item-inner {
    padding: 25px;
    background: rgba(255, 255, 255, 0.1); /* Effet Glassmorphism */
    border-radius: 12px;
    text-align: center;
    color: #ffffff;
    transition: 0.3s all ease;
}
.footer-item-inner p {
    color: #ffffff;
    font-size: 15px;
    margin-bottom: 15px;
}
.footer-item-inner a {
    font-size: 16px;
    padding: 10px 25px;
    color: #FFFFFF;
    display: inline-block;
    border-radius: 12px;
    background-color: #27c414;
    transition: 0.2s all ease;
    text-decoration: none;
}
.footer-item-inner a:hover {
    background-color: #02A6C0;
    color: #FFFFFF;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}
.footer-item-inner input[type="search"] {
    border-radius: 12px;
    border: none;
    padding: 10px 15px;
}

.footer-item2 ul li a {
    font-size: 16px;
    color: #fff;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    background-color: #27c414;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.2s all ease;
}

/* --- 14. PAGE & FORMULAIRES DE CONTACT --- */
.titre h1 {
    font-size: 40px;
    font-weight: 700;
    color: #02a6c0;
    text-align: center;
    margin: 0 0 10px;
}

.contact-item form {
    max-width: 500px;
    margin: 0 auto;
    padding: 30px 15px;
    background: #02a6c0;
    border-radius: 12px; /* Ajout sécurité design */
}

.contact-item2-inner4 a {
    font-size: 16px;
    padding: 10px 25px;
    color: #FFFFFF;
    display: inline-block;
    border-radius: 12px;
    background-color: #02A6C0;
    transition: 0.2s all ease;
}

/* --- 15. BOUTONS PROTOCOLAIRES (BTN1 / BTN2) --- */
.buttons {
    display:flex;
    padding-top:10px;
    padding-bottom:10px;
    justify-content:center;
    align-items:center;
    color : white;
}

.btn1, .btn2 {
    display:compact;
    justify-content:center;
    align-items:center;
    white-space: nowrap;
    text-decoration: none;
    cursor: pointer;
    border-radius: 12px;
    padding: 10px 25px;
    border:none;
    overflow: hidden;
    text-overflow: ellipsis;
} 

/* Bouton "Retour" (Bleu) */
.btn1 { 
    color: #FFFFFF; 
    background-color: #02A6C0;
    border-color: #02A6C0; 
} 
.btn1:hover { 
  color: #FFFFFF; /* FORCE LE BLANC AU SURVOL */
  background-color: #27c414; 
  border-color: #27c414;
} 

/* Bouton "Enregistrer" (Vert) */
.btn2 { 
    color: #FFFFFF; 
    background-color: #27c414;
    border-color: #27c414;
    font-size: 1.2rem;
} 
.btn2:hover { 
  color: #FFFFFF; /* FORCE LE BLANC AU SURVOL */
  background-color: #02A6C0;
  border-color: #02A6C0;
}

/* --- 16. VALIDATION FORMULAIRE --- */
input:required {
  border: 1px dashed red;
  background-color:#98FB98;
}

/* --- 17. COMPOSANTS DIVERS --- */
.nav-tabs {
    border-bottom: 1px solid #006600;
}
.nav-tabs .nav-link.active {
    border: 1px solid #000;
    border-bottom-color: #FFF;
    background-color: #FFF;
}
