/*****************************************************************************/
/***************************    FONTS    ***************************************/
/*****************************************************************************/

@font-face {
    font-family: 'DIN Cond';
    src: url('../fonts/DINPro-CondensedLight.woff2') format('woff2'),
        url('../fonts/DINPro-CondensedLight.woff') format('woff');
    font-weight: 300;
    font-style: normal;
}
@font-face {
    font-family: 'DIN Cond';
    src: url('../fonts/DINPro-CondensedRegular.woff2') format('woff2'),
        url('../fonts/DINPro-CondensedRegular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'DIN Cond';
    src: url('../fonts/DINPro-CondensedBlack.woff2') format('woff2'),
        url('../fonts/DINPro-CondensedBlack.woff') format('woff');
    font-weight: 900;
    font-style: normal;
}
@font-face {
    font-family: 'DIN Cond';
    src: url('../fonts/DINPro-CondensedBold.woff2') format('woff2'),
        url('../fonts/DINPro-CondensedBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}@font-face {
    font-family: 'DIN';
    src: url('../fonts/DINPro-Light.woff2') format('woff2'),
        url('../fonts/DINPro-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
}
@font-face {
    font-family: 'DIN';
    src: url('../fonts/DINPro-Black.woff2') format('woff2'),
        url('../fonts/DINPro-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
}
@font-face {
    font-family: 'DIN';
    src: url('../fonts/DINPro-Medium.woff2') format('woff2'),
        url('../fonts/DINPro-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
}
@font-face {
    font-family: 'DIN';
    src: url('../fonts/DINPro.woff2') format('woff2'),
        url('../fonts/DINPro.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'DIN';
    src: url('../fonts/DINPro-Bold.woff2') format('woff2'),
        url('../fonts/DINPro-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}
@font-face {
    font-family: 'DIN';
    src: url('../fonts/DINPro-Italic.woff2') format('woff2'),
        url('../fonts/DINPro-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
}
@font-face {
    font-family: 'philosopherregular';
    src: url('../fonts/Philosopher-Regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

/********************************/
/******** NAVBAR environnement ASSE *******/
/********************************/

:root {
  --vert-asse: #1d995b;
  --vert-hover-asse: #006648;
  --vert-digital: #54f6a0;
  --gris-asse: #151515;
  --gris-hover-asse: #8c8c8c;
  --color-facebook: #3b5999;
  --color-twitter: #55acee;
  --color-linkedin: #0077B5;
  --color-youtube: #cd201f;
  --color-instagram: #e4405f;
  --color-tiktok: #000;
  --color-twitch: #6441a5;
  --color-up2it: #000;
  --color-android: #a4c639;
  --color-apple: #7f7f7f;
}
a{
    text-decoration: none;
}
body {
    position: relative; 
    font-family: 'Roboto';
}
body .overlay {
    position: fixed;
    content: "";
    z-index: 10;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    -webkit-transition: .3s all ease-in-out;
    -o-transition: .3s all ease-in-out;
    transition: .3s all ease-in-out; 
}
body.show-sidebar {
    overflow: hidden; 
}
body.show-sidebar .overlay {
    opacity: 1;
    visibility: visible; 
}
aside, main {
    height: 100vh;
    min-height: 580px; 
}
aside {
    left: 0;
    z-index: 98;
    position: fixed;
    -webkit-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition: 1s -webkit-transform cubic-bezier(0.23, 1, 0.32, 1);
    transition: 1s -webkit-transform cubic-bezier(0.23, 1, 0.32, 1);
    -o-transition: 1s transform cubic-bezier(0.23, 1, 0.32, 1);
    transition: 1s transform cubic-bezier(0.23, 1, 0.32, 1);
    transition: 1s transform cubic-bezier(0.23, 1, 0.32, 1), 1s -webkit-transform cubic-bezier(0.23, 1, 0.32, 1); 
    background:#f2f2f2;
    border-top: 1px solid #E0E0E0;
    top: calc(120px);
    height: calc(100% - calc(120px));
    bottom: 0;
    left: 0;
    width: 320px;
    max-width: calc(100vw - 50px);
}
.mininav aside {
    height: calc(100% - calc(80px));
    top: calc(80px);
}
.show-sidebar aside {
    -webkit-transform: translateX(0%);
    -ms-transform: translateX(0%);
    transform: translateX(0%); 
}
#header{
    background: #fff;
    z-index: 9;
    /*position: fixed;*/
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10;
    transform: translate3d(0, -500px, 0);
    transition: transform 0.4s;
}
#header.sticky{
    position: fixed;
}
#header.isfixed{
    transform: translate3d(0, 0, 0);
}
#header .toggle button{
    display: block;
    -ms-flex: 0 0 25px;
    flex: 0 0 25px;
    width: 25px;
    background: none;
    border: none;
    border-radius: 0;
    box-shadow: none;
    cursor: pointer;
    position: relative;
    padding: 0;
    height: 16px;
    /*position: absolute;
    top: 0;
    left: 0;*/
}
#header .toggle button .bar{
    background: #1a2434;
    height: 2px;
    width: 100%;
    position: absolute;
    left: 0;
    transition: all 0.2s;
    transform-origin: center center;
}
#header .toggle_close{
    font-size: 14px;
    position: absolute;
    left: 25px;
    padding-left: 8px;
    top: -4px;
    display: none;
    opacity: .6;
    font-weight: 300;
}
#header .toggle button .bar:first-child{
    top: 0;
}
#header .toggle button .bar:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
}
#header .toggle button .bar:nth-child(3) {
    bottom: 0;
}
.show-sidebar #header .toggle button .bar:first-child{
    top: 50%;
    transform: rotate(45deg);
}
.show-sidebar #header .toggle button .bar:nth-child(2) {
    opacity: 0;
}
.show-sidebar #header .toggle button .bar:nth-child(3) {
    top: 50%;
    bottom: auto;
    transform: rotate(-45deg);
}
#header .logo img {
    display: block;
    margin:auto;
    padding-top: 5px;
    padding-bottom: 5px;
    transition: all .15s ease-in-out;
    height: 80px;
}
#header .icons{
    font-size: 20px;
    padding-left: 0;
}
#header .icons a{
    padding-left: 15px;
    color:var(--gris-asse);
    position: relative;
    transition: color .15s ease-in-out;
}
#header .icons a::after{
    content:"";
    position: absolute;
    background:#e8e8e8;
    height: 100%;
    width: 1px;
    right: -10px;
    top: 0px;
}
#header .icons a:last-child::after{
    content:none;
    display: none;
}
aside .side-inner {
    padding: 15px 0 0;
    height: calc(100vh - 70px);
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: none; 
}
aside .side-inner::-webkit-scrollbar {
    display: none; 
}
aside .dropdown-menu{
    position: relative !important;
    transform: none !important;
}
aside .dropdown-menu.show{
    transform: translate3d(0px, 0px, 0px) !important;
    background: none;
    border:none;
    padding-top: 0;
    padding-bottom: 0;
}
.dropdown-item:focus, 
.dropdown-item:hover {
    background-color: #e4e4e4;
}
.dropdown-item.active, 
.dropdown-item:active {
    background-color: none;
}
.navbar{
    padding:0;
}
.navbar-nav{
    width: 100%;
    padding:0;
}
.navbar .nav-item{
    border-top:solid 1px #dedede;
    padding:0;
}
.navbar .title_site{
    border-top:none;
}
.navbar .nav-item .nav-link,   
.navbar .nav-item .dropdown-item{    
    font-family: 'Titillium Web';
    font-size: 18px;
    color: var(--gris-asse);
    text-transform: uppercase;
    font-weight: bold;
    padding: 8px 15px;
}
.navbar .nav-item .dropdown-item{    
    font-size: 16px;
}
.navbar .nav-item:not(.title_site) .nav-link:hover,
#header .icons a:hover,  
#header .liens-rapides a:hover,    
#header .icons a:hover span{    
    color: var(--gris-hover-asse);
}
.navbar .nav-item .dropdown-item{    
    font-weight: normal;
    padding-left: 10px;
    padding-left: 20px;
    padding-top: 2px;
    padding-bottom: 2px;
}
.navbar .title_site .nav-link{
    font-size: 24px;
    color: var(--vert-asse);
    margin-bottom: 10px;
}
.navbar .dropdown-toggle::after{
    content: "";
    display: none;
}
.navbar .dropdown-toggle svg{
    float: right;
    margin-top: 7px;
}
.navbar .dropdown-toggle .bi-chevron-up,
.navbar .dropdown-toggle.show .bi-chevron-down{
    display: none;
}
.navbar .dropdown-toggle.show .bi-chevron-up{
    display: block;
}
aside .foot {
    background:var(--vert-asse);
    margin-top: 30px;
    padding-bottom: 30px;
    padding-top: 30px;
}
aside .foot.isfixed {
    position: absolute;
    width: 100%;
    bottom: 0;
}
aside .foot .social{
    margin-bottom: 10px;
}
aside .foot .social a{
    color:#fff;
    font-size: 14px;
    padding-left: 15px;
}
aside .foot .social a i{
    font-size: 18px;
}
aside .foot ul{
    padding-left: 0px;
    margin-bottom: 0;
}
aside .foot ul li {
    list-style: none;
    font-size: 20px;
    font-family: 'DIN Cond';
    text-transform: uppercase;
    font-weight: bold;
    padding: 0 0 0 15px;
}
aside .foot ul li.active,
aside .foot ul li:hover{
    border-left: solid 3px #2ed286;
    padding-left: 12px;
    background: #4da574;
}
aside .foot ul li a{
    color:#fff;
    padding-top: 3px;
    padding-bottom: 3px;
    display: inline-block;
    width: 100%;
}
.mininav main{
    margin-top: 55px;
}
main{
    /*margin-top: 55px;*/
}
.btn_cta{
    font-size: 14px;
    color: #fff !important;
    display: inline-block;
    background: var(--vert-asse);
    padding: 5px 25px !important;
    font-weight: 600;
    text-transform: uppercase;
    height: auto;
    -webkit-transition: all .1s ease-in-out;
    -moz-transition: all .1s ease-in-out;
    -o-transition: all .1s ease-in-out;
    transition: all .1s ease-in-out;
    margin: 15px;
}
.btn_cta:hover{
    color:#fff;
    background: var(--vert-hover-asse);
}

#preheader{
    background:#151515;
    font-family: 'DIN Cond';
    font-weight: bold;
    height: 40px;
    color:#fff;
    text-transform: uppercase;
    z-index: 98;
    /*position: fixed;*/
    position: relative;
    width: 100%;
    top: 0;
}
#preheader a{
    color:#fff;
    padding-left: 12px;
    padding-right: 2px;
    padding-top: 9px;
    padding-bottom: 8px;
}
#preheader .col-auto ul a {
    padding-left: 6px;
    padding-right: 6px;
}
#preheader ul{
    padding-left: 0px;
    margin-bottom: 0;
}
#preheader ul li{
    list-style: none;
    font-size: 15px;
    display: inline-flex;
    position: relative;
    font-family: 'apotek-cond';
    font-weight: 400;
}
#preheader ul li:before{
    display: block;
    position: absolute;
    content: '';
    border-top: solid 3px var(--vert-asse);
    transform: scaleX(0);
    width: 100%;
    transition: transform 100ms ease-in-out;
}
#preheader ul li.partenaire{
    height: 40px;
}
#preheader ul li.partenaire a{
    padding-top: 5px;
}
#preheader ul li.active:before,
#preheader ul li:hover:before{
    transform: scaleX(1);
}
#preheader ul li.active,
#preheader ul li:hover{
    background:#252525;
}
#preheader ul li a:hover{
    text-decoration: none;
}
#preheader ul li a img {
    height: 24px;
    margin-top: 2px;
}

@media (min-width: 992px) { 
    #preheader > .container-fluid,
    #header > .container-fluid{
        padding-left: 30px;
        padding-right: 30px;
    }
    #preheader a{
        padding-right: 12px;
    }
    #preheader ul li a img{
        height: 30px;
        margin-top: 0;
    }
    #header{
        transform: translate3d(0, 0px, 0);
    }
    #header.isfixed .logo img {
        padding-top: 15px;
        padding-bottom: 15px;
        height: 130px;
    }
    #header .icons a{
        padding-right: 15px;
        font-size: 24px;
    }
    #header .icons a::after {
        right: -5px;
    }
    #header .icons .reseaux {
        position: absolute;
        top: 9px;
        right: 45px;
        transform: translate3d(0, -300px, 0);
        transition: transform 100ms ease-in-out;
    }
    #header.isfixed .icons .reseaux {
        transform: translate3d(0, 0px, 0);
    }
    #header .icons .reseaux a.social {
        font-size: 16px;
        color: var(--vert-asse);
        padding: 7px;
        transition: opacity 100ms ease-in-out;
    }
    #header .icons .reseaux a.social svg{
        height: 16px;
        transition: opacity 100ms ease-in-out;
    }
    #header .icons .reseaux a.social svg path{
        fill: var(--vert-asse);
    }
    #header .icons .reseaux a.social:hover {
        /*opacity: 0.8;*/
    }
    #header .icons .reseaux a.social.fb:hover, #footer .liensociaux .social.fb:hover {color: var(--color-facebook);}
    #header .icons .reseaux a.social.tt:hover, #footer .liensociaux .social.tt:hover {color: var(--color-twitter);}
    #header .icons .reseaux a.social.in:hover, #footer .liensociaux .social.in:hover {color: var(--color-instagram);}
    #header .icons .reseaux a.social.yt:hover, #footer .liensociaux .social.yt:hover {color: var(--color-youtube);}
    #header .icons .reseaux a.social.tk:hover, #footer .liensociaux .social.tk:hover {color: var(--color-tiktok);}
    #header .icons .reseaux a.social.tw:hover, #footer .liensociaux .social.tw:hover {color: var(--color-twitch);}
    #header .icons .reseaux a.social.li:hover, #footer .liensociaux .social.li:hover {color: var(--color-linkedin);}
    #header .icons .reseaux a.social.up:hover svg path, #footer .liensociaux .social.up:hover svg path{fill: var(--color-up2it);}
    #footer .liensociaux .social.apple:hover {color: var(--color-apple);}
    #footer .liensociaux .social.android:hover {color: var(--color-android);}
    #header .icons .reseaux a.social::after {
        display: none;
    }
    aside {
        top: calc(170px);
        height: calc(100% - calc(170px));
        width: 380px;
        max-width: calc(100vw - 50px);
    }
    aside .side-inner {
        height: calc(100vh - 170px);
    }
    .mininav aside {
        top: calc(130px);
        height: calc(100% - calc(130px));
    }
    .mininav aside .side-inner {
        height: calc(100vh - 130px);
    }
    .mininav.petitnav aside {
        top: calc(80px);
        height: calc(100% - calc(80px));
    }
    .mininav.petitnav aside .side-inner {
        height: calc(100vh - 55px);
    }
    .mininav main{
        margin-top: 130px;
    }
    .navbar .nav-item .nav-link, 
    .navbar .nav-item .dropdown-item {
        padding: 12px 30px;
    }
    .btn_cta {
        margin: 15px 30px;
    }
    aside .foot ul li {
        padding: 0 0 0 30px;
    }
    aside .foot ul li.active, 
    aside .foot ul li:hover {
        padding-left: 27px;
    }
    aside .foot .social{
        padding-left: 15px;
    }
    .liens-rapides ul{
        margin-bottom: 0;
        padding-left: 0;
    }
    .liens-rapides ul li{
        list-style: none;
        display: inline-flex;
    }
    .liens-rapides ul li a,
    #header .icons a span{
        font-family: 'apotek-cond';
        font-weight: 400;
        text-transform: uppercase;
        transition: color .15s ease-in-out;
        color: #151515;
        font-size: 18px;
        padding-left: 7px;
        padding-right: 7px;
    }
    #header .linkright .zmdi{
        vertical-align: middle;
    }
    .navbar .nav-item .dropdown-item{
        padding-top: 4px;
        padding-bottom: 4px;
    }
}
@media (min-width: 1200px) { 
    .liens-rapides ul li a{
        font-size: 20px;
        padding-left: 15px;
        padding-right: 15px;
    }
}
@media (min-width: 1500px) { 
    #preheader > .container-fluid,
    #header > .container-fluid{
        padding-left: 60px;
        padding-right: 60px;
    }
    .navbar .nav-item .nav-link, 
    .navbar .nav-item .dropdown-item {
        padding: 12px 60px;
    }
    .btn_cta {
        margin: 15px 60px;
    }
    aside {
        width: 420px;
    }
    aside .foot ul li {
        padding: 0 0 0 60px;
    }
    aside .foot ul li.active, 
    aside .foot ul li:hover {
        padding-left: 57px;
    }
    aside .foot .social{
        padding-left: 40px;
    }
    aside .foot .social a {
        padding-left: 20px; 
    }
    .liens-rapides ul li a{
        padding-left: 30px;
        padding-right: 30px;
    }
    #preheader ul{
        padding-left: 20px;
    }
    #header .icons .reseaux {
        right: 70px;
    }
}

