/* VARIABLES DE COULEURS */
:root {
    --primary: #4f9fc2;
    --secondary: #effaff;
    --tertiary: #cdd3e4;
    --quaternary: #f1e954;

    --text-dark: #010101;
    --card-blue: #040267;
    --white: #ffffff;
    --green: #02505b;
}

/* TYPOGRAPHIE & BALISES DE BASE*/
body,
html,
.body {
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    font-size: 17px !important;
    background-color: var(--white) !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    letter-spacing: initial;
    color: var(--text-dark);
}

h1 {
    font-size: 3.4em;
    line-height: 1em;
}

h2 {
    font-size: 2.5em;
    font-weight: 600;
}

p,
li,
figcaption {
    color: var(--text-dark);
}

.lead {
    line-height: 1.2em !important;
    font-size: 1.7em !important;
    letter-spacing: -.02em !important;
}

.typoscript {
    font-weight: 700;
    font-style: normal;
    text-transform: none;
}

/*  STRUCTURE & CONTAINERS (MEDIA QUERIES) */
@media (min-width: 1440px) {
    .container-xl-custom {
        max-width: 1440px !important;
    }

    .container-xxl-custom {
        max-width: 1630px;
    }
}

/*  HEADER & NAVIGATION (NORMAL ET STICKY) */

/* --- Base & Animations du Header --- */
#header .header-body {
    transition: background-color 0.35s ease, padding 0.35s ease, box-shadow 0.35s ease, height 0.35s ease;
}

#header .header-nav nav>ul>li>a {
    transition: color 0.25s ease;
}

@keyframes headerFadeIn {
    from {
        opacity: 0.95;
    }

    to {
        opacity: 1;
    }
}

/* On met le fond de la boîte globale du sous-menu en blanc */
#header .header-nav-main nav ul.dropdown-menu {
    background-color: var(--white) !important;
}

/* État par défaut des liens du sous-menu : fond blanc, texte noir */
#header .header-nav-main nav ul.dropdown-menu li a.dropdown-item {
    background-color: var(--white) !important;
    color: var(--text-dark) !important;
    transition: background-color 0.2s ease, color 0.2s ease;
}

/* Au survol du sous-menu : fond noir, texte blanc */
#header .header-nav-main nav ul.dropdown-menu li a.dropdown-item:hover {
    background-color: var(--text-dark) !important;
    color: var(--white) !important;
}

/* État actif global */
#header .header-nav nav>ul>li>a.active {
    color: var(--text-dark) !important;
}

/* --- Header : Apparence sur Desktop --- */
@media (min-width: 992px) {
    #header .header-nav-main nav>ul>li>a {
        color: var(--primary);
        font-size: 17px;
    }

    #header .header-nav.header-nav-links.header-nav-light-text nav>ul>li>a,
    #header .header-nav.header-nav-line.header-nav-light-text nav>ul>li>a {
        color: var(--primary);

    }

    #header .header-nav.header-nav-light-text nav>ul>li>a {
        color: var(--primary);
    }

    #header .header-nav.header-nav-light-text nav>ul>li>a:hover {
        color: var(--text-dark);
    }

    #header .header-nav.header-nav-dropdowns-dark nav>ul>li.dropdown .dropdown-menu>li>a {
        color: var(--text-dark);
    }
}

/* --- Header : État STICKY --- */
html.sticky-header-active #header .header-body,
body.sticky-header-active #header .header-body {
    animation: headerFadeIn 0.3s ease forwards;
}

@media (min-width: 992px) {
    html.sticky-header-active #header .header-nav-main nav>ul>li>a {
        color: var(--secondary) !important;
    }

    html.sticky-header-active #header .header-nav-main nav>ul>li>a.active {
        color: var(--text-dark) !important;
    }


    html.sticky-header-active #header .header-nav-main nav>ul>li>a:hover,
    html.sticky-header-active #header .header-nav-main nav>ul>li.dropdown:hover>a.nav-link {
        color: var(--text-dark) !important;
    }
}

/* --- Header : Apparence sur Mobile / Tablette (Responsive) --- */
@media (max-width: 992px) {

    /* On force tout le conteneur du menu mobile en blanc */
    #header .header-nav-main nav,
    #header .header-nav-main nav>ul,
    #header .header-nav-main nav>ul>li {
        background-color: var(--white) !important;
        border-color: #f0f0f0 !important;
    }

    /* Les liens principaux en couleur primary sur fond blanc */
    #header .header-nav-main nav>ul>li>a {
        color: var(--primary) !important;
        background-color: var(--white) !important;
    }

    /* Le lien actif (ou parent ouvert) en couleur text-dark */
    #header .header-nav-main nav>ul>li>a.active,
    #header .header-nav-main nav>ul>li.dropdown>a.active {
        color: var(--text-dark) !important;
        background-color: var(--white) !important;
    }

    /* On s'assure que les liens des sous-menus touchent bien les bords sur mobile */
    #header .header-nav-main nav ul.dropdown-menu {
        padding: 0 !important;
        border: none !important;
    }

    #header .header-nav-main nav ul.dropdown-menu li a.dropdown-item {
        padding: 10px 20px !important;
        border-bottom: 1px solid #f0f0f0 !important;
    }
}

/* Logo */
#header .header-logo .logo-sticky {
    display: none !important;
}

html.sticky-header-active #header .header-logo .logo-normal,
body.sticky-header-active #header .header-logo .logo-normal {
    display: none !important;
}

html.sticky-header-active #header .header-logo .logo-sticky,
body.sticky-header-active #header .header-logo .logo-sticky {
    display: block !important;
}

/* COMPOSANTS */
.btn-rounded {
    border-radius: 35px !important;
}

.card {
    border-radius: 1.5rem;
    border: none !important;
}

.card-img,
.card-img-top {
    border-top-left-radius: calc(1.5rem - 1px);
    border-top-right-radius: calc(1.5rem - 1px);
}

.border-radius-custom {
    border: 8px solid white !important;
    border-radius: 30px;
}

.cascading-images-wrapper {
    display: inline-block;
    padding: 12% 10%;
}

.cascading-images-wrapper .cascading-images {
    transform: translate3d(0, -35%, 0);
}

/*   SECTIONS SPÉCIFIQUES & PAGES */

/* --- Page : Nos Centres --- */
.row.carte-row {
    display: flex;
    flex-wrap: wrap;
}

.row.carte-row>.col-md-4 {
    display: flex;
}

.carte {
    background: #ffffff;
    border-radius: 16px;
    padding: 0px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
    transition: 0.3s ease;
    display: flex;
    flex-direction: column;
    width: 100%;
}

.carte h3 {
    font-size: 18px;
    font-weight: 600;
    color: #ffffff;
    margin: 0;
    padding: 16px 20px;
    background-color: var(--card-blue);
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
    position: relative;
}

.carte .carte-body {
    flex-grow: 1;
    padding: 20px;
}

.carte .info-line {
    font-size: 14px;
    margin-bottom: 8px;
    color: #555;
}

.carte .doctor-name {
    font-weight: 600;
    color: var(--card-blue);
}

.carte .carte-footer {
    margin-top: auto;
    font-size: 14px;
    color: var(--text-dark);
    padding: 0 20px 5px 20px;
}

.carte .carte-footer i {
    color: var(--card-blue);
    margin-right: 6px;
}

.carte .carte-footer a {
    color: var(--card-blue);
    text-decoration: none;
}

.carte .carte-footer a:hover {
    color: var(--card-blue);
}

/* --- Footer --- */
#footer {
    margin-top: 0px;
    background-color: var(--green);
}

.footer-custom-forme {
    background-image: url("../../img/demos/digital-agency-2/bg/bg-2.png");
    background-repeat: no-repeat;
    background-size: cover;
    position: relative;
}

.footer-custom-forme .custom-circle-1 {
    top: 20%;
    right: 10%;
}

.footer-custom-forme .custom-circle-2 {
    top: 70%;
    right: 5%;
}

@media (max-width: 1199px) {
    .footer-custom-forme {
        padding: 90px 0;
    }
}

@media (min-width: 1200px) {
    .footer-custom-forme:after {
        content: '';
        display: block;
        width: 120%;
        height: 127px;
        position: absolute;
        bottom: -95px;
        left: -5%;
        transform: rotate(2deg);
    }
}

/* --- Page : Bannière --- */
.page-banniere {
    padding-top: 200px;
    padding-bottom: 40px;
}

.page-banniere h1 {
    color: var(--primary);
}

/* --- Mélanome (Bénin / Malin) --- */
.benin img,
.malin img {
    text-align: center;
    border: 5px solid;
}

.benin img {
    border-color: green;
    color: green;
}

.malin img {
    border-color: crimson;
    color: crimson;
}

.malin::after,
.benin::after {
    content: "";
    display: inline-block;
    position: absolute;
    right: 10px;
    width: 45px;
    height: 45px;
    background-repeat: no-repeat;
    background-size: cover;
}

.malin::after {
    background-image: url(/img/icons/icon-warning.png);
}

.benin::after {
    background-image: url(/img/icons/icon-check.png);
}

/* --- Owl-carousel  --- */
.custom-carousel-nav .owl-nav button {
    background: #000000 !important;
    color: #ffffff !important;
    width: 40px;
    height: 40px;
    border-radius: 0px !important;
    margin: 5px;
    font-size: 24px !important;
    opacity: 0.8;
    transition: opacity 0.3s ease;
}

.custom-carousel-nav .owl-nav button:hover {
    opacity: 1 !important;
    background: #000000 !important;
}

.custom-carousel-nav {
    position: relative;
}

.custom-carousel-nav .owl-nav {
    position: absolute;
    top: 50%;
    width: 100%;
    transform: translateY(-50%);
    display: flex;
    justify-content: space-between;
    pointer-events: none;
    z-index: 10;
}

.custom-carousel-nav .owl-nav button {
    pointer-events: all;
}

/* Bouton fixe */
.custom-fixed-badge {
    position: fixed;
    bottom: 18px;
    right: 70px;
    z-index: 99;
    width: 200px;
    background-color: transparent;
    padding: 5px;

    /* État initial caché */
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s ease-in-out;
}

@media (max-width: 992px) {
    .custom-fixed-badge {
        width: 110px;
    }
}

.custom-fixed-badge.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.custom-fixed-badge img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 50%;
    border: 2px solid var(--quaternary);
}

.custom-fixed-badge.is-visible:hover {
    transform: translateY(-5px);
}

a.anchor {
    display: block;
    position: relative;
    top: -140px;
    visibility: hidden;
}

/* Post */
.mfp-vertical-video .mfp-content {
    max-width: 420px;
    margin: 0 auto;
}

.mfp-vertical-video .mfp-iframe-scaler {
    padding-top: 177.77%;
    background: transparent !important;
}

.mfp-vertical-video .mfp-iframe {
    background: transparent !important;
    box-shadow: none !important;
}