:root {
    --main-menu-height: 5rem;
}

#main-menu {
    height: var(--main-menu-height);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-right: 1rem;
    position: fixed;
    top: 0;
    width: 100vw;
    z-index: 10000;
    color: white;
    background: linear-gradient(0deg, transparent, rgb(0 0 0 / 0.5));
    transition: all 0.3s ease-in;
    opacity: 1;
}

#main-menu.scrolled {
    background: hsl(0deg 0% 100% / 90%);
    transition: all 0.3s ease-in;
    opacity: 1;
}


#main-menu.scrolled img.custom-logo {
    height: 5rem;
    margin-top: 0;
    filter: invert(0);
    transition: all 0.3s ease-in;
}

#main-menu.scrolled .logo-text-complement {
    margin-top: 0;
    font-size: 1.3rem;
    filter: invert(1);
    transition: all 0.3s ease-in;
}

.custom-logo, .custom-logo.lazyloaded {
    height: 6.5rem;
    padding: 1rem;
    filter: invert(1);
    margin-top: 1.7rem;
    transition: height 0.3s ease-in;
}

.logo {
    display: flex;
    align-items: center;
}
.logo > a {
    display: block;
    height: fit-content;
}

.logo-text-complement {
    color: white;
    text-decoration: none;
    padding: 0.4rem 0.9rem;
    margin-top: 1.6rem;
    /* margin-left: -7rem; */
    /*font-family: 'Whitney Bold';*/
    /* font-weight: 500; */
    font-family: 'Open Sans', sans-serif;  /* font similar to Whitney Bold that supports tcheque language accents */
    font-weight: 800;                      /* equivalent to 500 in Whitney Bol */

    font-size: 1.5rem;
    letter-spacing: 2px;
    border-left: 1px solid white;
    transition: all 0.3s ease-out;
}

#main-menu .logo a.header-logo img {
    height: 3rem;
}

#main-menu #titre-header {
    font-size: 0;
} 
#main-menu.scrolled #titre-header {
    font-size: 2rem;
} 
#main-menu.scrolled .logo a.header-logo img {
    height: 2rem;
}


#ccn-hamburger-menu {
    display: none;
    cursor: pointer;
    transition: all 0.2s ease-in;
}

#main-menu ul.menu,
#main-menu .menu > ul,
body > .mobile-menu-container ul.menu,
body > .mobile-menu-container .menu > ul {
    list-style: none;
    display: flex;
    margin: 0 0 0 0; /* si pas coach-careme, mettre 0 30px 0 */
    padding: 0;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

#main-menu ul.menu > li,
#main-menu .menu > ul > li {
    margin: 0 0.6rem;
    padding: 5px 10px;
    cursor: pointer;
    transition: all 0.15s ease-out;
}

@media only screen and (max-width: 1359px) {
    #main-menu ul.menu > li,
    #main-menu .menu > ul > li {
        margin: 0 0.4rem;
        padding: 5px 0px;
        font-size: 14px;
    }
}
@media only screen and (min-width: 1360px) {
    @media only screen and (max-width: 1679px) {
    #main-menu ul.menu > li,
    #main-menu .menu > ul > li {
        margin: 0 0.6rem;
        padding: 5px 0px;
        font-size: 16px;
    }
}
}
@media only screen and (min-width: 1680px) {
    #main-menu ul.menu > li,
    #main-menu .menu > ul > li {
        margin: 0 0.8rem;
        padding: 5px 0px;
        font-size: 20px;
    }
}

#main-menu .menu li:hover {
    background: #b3b3b3b5;
    /* backdrop-filter: blur(2px); */
    transition: all 0.3s ease-in;
}

#main-menu ul.menu > li > a,
#main-menu .menu > ul > li > a {
    color: white;
    text-decoration: none;
    display: inline-block;
}

#main-menu.scrolled ul.sub-menu,
#main-menu.scrolled ul.children{
    background: white;
}

#main-menu.scrolled ul.menu > li > a,
#main-menu.scrolled .menu > ul > li > a {
    color: #000000;
    text-decoration: none;
}

#main-menu.scrolled ul.sub-menu a,
#main-menu.scrolled ul.children a {
    color: black;
}


#main-menu ul.menu li ul.sub-menu,
#main-menu .menu > ul li ul.children,
body > .mobile-menu-container ul.menu li ul.sub-menu,
body > .mobile-menu-container .menu > ul li ul.children {
    list-style: none;
    display: none;
    padding-top: 0.2rem;
    padding-left: 1.4rem;
    justify-content: center;
    flex-wrap: wrap;
    text-align: left;
    background: #ffffff59;
    width: 100%;
    margin-left: -0.7rem;
    margin-top: 0.4rem;
}

#main-menu ul.menu > li > ul.sub-menu,
#main-menu .menu > ul > li > ul.children {
    margin-left: -0.7rem;
    margin-top: 5px;
    width: auto;
    text-align: left;
    padding-left: 0;
    padding-top: 0.8rem;
    min-width: min(100vw, 300px);
}

#main-menu ul.menu li:hover ul.sub-menu,
#main-menu .menu > ul li:hover ul.children {
    display: flex;
    flex-direction: column;
    font-weight: normal;
    position: absolute;
    background: #44444450;
}

#main-menu.scrolled ul.menu li:hover ul.sub-menu,
#main-menu.scrolled .menu > ul li:hover ul.children {
    display: flex;
    flex-direction: column;
    background: #ffffffa6;
    /* margin-top: 0.4rem; */
}

#main-menu ul.sub-menu > li,
#main-menu ul.children > li {
    padding: 0.4rem 0.7rem;
    transition: all 0.15s ease-out;
}

#main-menu ul.sub-menu li:hover,
#main-menu ul.children li:hover {
    background: #ffffff8c;
    transition: all 0.3s ease-in;
}

#main-menu ul.sub-menu > li > a,
#main-menu ul.children > li > a {
    color: white;
    text-decoration: none;
}

#main-menu.scrolled ul.sub-menu > li > a,
#main-menu.scrolled ul.children > li > a {
    text-decoration: none;
}

/*
.menu .current-menu-item {
    font-weight: bold;
    color: var(--primary-color);
    border: 1px solid white;
}

#main-menu.scrolled .menu .current-menu-item {
    font-weight: bold;
    color: var(--primary-color);
    border: 1px solid black;
}
*/
.fas.fa-times {cursor: pointer;}


.extended-menu {
    display: flex;
    align-items: center;
}


#main-menu.scrolled .ccn-header-coach-careme-white {
    display: none;
}
#main-menu .ccn-header-coach-careme-black {
    display: none;
}
#main-menu.scrolled .ccn-header-coach-careme-black {
    display: block;
}
#main-menu .ccn-header-coach-careme-white {
    display: block;
}
#main-menu .ccn-header-coach-careme-logo {
    display: none;
}


