
-------------------------------- */
.cd-img-replace {
  /* replace text with a background-image */
  display: inline-block;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
}

.overflow-hidden {
  overflow: hidden;
}

/* -------------------------------- 

Main components 

-------------------------------- */
.cd-main-content {
  /* set a min-height and a z-index to be sure that the main element completely covers the lateral menu */
  min-height: 100%;
  position: relative;
  z-index: 2;
  padding-top: 50px;
  /* Force Hardware Acceleration in WebKit */
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  -webkit-transition-property: -webkit-transform;
  -moz-transition-property: -moz-transform;
  transition-property: transform;
  -webkit-transition-duration: 0.4s;
  -moz-transition-duration: 0.4s;
  transition-duration: 0.4s;
}
.cd-main-content.lateral-menu-is-open {
  /* translate to show the lateral menu - all content needs to be put in the .cd-main-content to translate*/
  /*-webkit-transform: translateX(100%);
  -moz-transform: translateX(100%);
  -ms-transform: translateX(100%);
  -o-transform: translateX(100%);
  transform: translateX(100%);*/
}
@media only screen and (min-width: 768px) {
  .cd-main-content {
    padding-top: 70px;
  }
}

header {
  position: fixed;
  top: 0;
  left: 0;
  min-height: 50px;
  width: 100%;
  z-index: 3;
  /* Force Hardware Acceleration in WebKit */
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  -webkit-transition-property: -webkit-transform;
  -moz-transition-property: -moz-transform;
  transition-property: transform;
  -webkit-transition-duration: 0.4s;
  -moz-transition-duration: 0.4s;
  transition-duration: 0.4s;
}
header.lateral-menu-is-open {
  /* translate to show the lateral menu */
  /*-webkit-transform: translateX(100%);
  -moz-transform: translateX(100%);
  -ms-transform: translateX(100%);
  -o-transform: translateX(100%);
  transform: translateX(100%);*/
}
.is-clicked {
    right: 0px !important;
    /*display: none;*/
}
header.is-fixed {
  position: fixed;
}
@media only screen and (min-width: 768px) {
  header {
    height: 70px;
  }
}

#cd-logo {
  display: block;
  float: left;
  margin: 12px 0 0 20px;
}
#cd-logo img {
  display: block;
}
@media only screen and (min-width: 768px) {
  #cd-logo {
    margin: 22px 0 0 30px;
  }
}

#cd-top-nav {
  position: absolute;
  top: 0;
  right: 120px;
  height: 100%;
  display: none;
}
#cd-top-nav ul {
  height: 100%;
  padding-top: 18px;
}
#cd-top-nav li {
  display: inline-block;
  margin-right: 1em;
}
#cd-top-nav a {
  display: inline-block;
  padding: .5em;
  color: #FFF;
  text-transform: uppercase;
  font-weight: 600;
}
#cd-top-nav a.current {
  background-color: #242e30;
}
.no-touch #cd-top-nav a:hover {
  color: rgba(255, 255, 255, 0.7);
}
@media only screen and (min-width: 768px) {
  #cd-top-nav {
    display: block;
  }
}

#cd-menu-trigger {
  position: absolute;
  right: 0;
  top: 0px;
  height: 50px;
  width: 50px;
  z-index:99;
}
#cd-menu-trigger .cd-menu-text {
  height: 100%;
  text-transform: uppercase;
  color: #FFF;
  font-weight: 600;
  display: none;
}
    #cd-menu-trigger .cd-menu-icon {
        /* this span is the central line in the menu menu */
        display: inline-block;
        position: absolute;
        left: 50%;
        top: 58%;
        bottom: auto;
        right: auto;
        -webkit-transform: translateX(-50%) translateY(-50%);
        -moz-transform: translateX(-50%) translateY(-50%);
        -ms-transform: translateX(-50%) translateY(-50%);
        -o-transform: translateX(-50%) translateY(-50%);
        transform: translateX(-50%) translateY(-50%);
        width: 18px;
        height: 2px;
        background-color: #fae58c;
        /* these are the upper and lower lines in the menu menu */
        -webkit-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        -o-transition: .5s ease-in-out;
        transition: .5s ease-in-out;
    }
#cd-menu-trigger .cd-menu-icon::before, #cd-menu-trigger .cd-menu-icon:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background-color: inherit;
  left: 0;
}
#cd-menu-trigger .cd-menu-icon::before {
  bottom: 5px;
}
#cd-menu-trigger .cd-menu-icon::after {
  top: 5px;
}
#cd-menu-trigger.is-clicked .cd-menu-icon {
  background-color: rgba(255, 255, 255, 0);
}
#cd-menu-trigger.is-clicked .cd-menu-icon::before, #cd-menu-trigger.is-clicked .cd-menu-icon::after {
  background-color: white;
}
#cd-menu-trigger.is-clicked .cd-menu-icon::before {
  bottom: 0;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}
#cd-menu-trigger.is-clicked .cd-menu-icon::after {
  top: 0;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
@media only screen and (min-width: 768px) {
  #cd-menu-trigger {
    width: 110px;
    padding-left: 1.25em;
  }
  #cd-menu-trigger .cd-menu-text {
    display: inline-block;
    line-height: 60px;
  }
  #cd-menu-trigger .cd-menu-icon {
    left: auto;
    right: 1.25em;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
  }
   #cd-lateral-nav {
       width: 360px !important;
   }
}

/*@media only screen and (min-width: 380px) and (max-width: 414px) {
    .is-clicked {
        left: 285px !important;
    }
}

@media only screen and (max-width: 360px) {
    .is-clicked {
        left: 242px !important;
    }
}

@media only screen and (max-width: 320px) {
    .is-clicked {
        left: 212px !important;
    }
}*/



#cd-lateral-nav {
    position: fixed;
    height: 100%;
    right: 0;
    top: 0;
    visibility: hidden;
    /* the secondary navigation is covered by the main element */
    z-index: 2;
    width: 70%;
    background-color: #070707;
    overflow-y: auto;
    /* Force Hardware Acceleration in WebKit */
    -webkit-transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    -webkit-transition: -webkit-transform .4s 0s, visibility 0s .4s;
    -moz-transition: -moz-transform .4s 0s, visibility 0s .4s;
    transition: transform .4s 0s, visibility 0s .4s;
    /* this creates the subtle slide in animation of the navigation */
    -webkit-transform: translateX(360px);
    -moz-transform: translateX(360px);
    -ms-transform: translateX(360px);
    -o-transform: translateX(360px);
    transform: translateX(360px);
}

#cd-lateral-nav .cd-navigation {
    margin: 56px 0 16px;
}

#cd-lateral-nav .sub-menu {
    padding: 0px 0px 0px 0px;
    display: none;
}

#cd-lateral-nav a {
    display: block;
    line-height: 2em;
    padding: 0 16px 0 18px;
    color: #fff;
    font-size: 16px;
    background: #131313;
    border-bottom: 2px solid #070707;
}
    /*#cd-lateral-nav img{padding-right: 8px;width: 50px;}*/

    #cd-lateral-nav img {
        padding: 13px 8px 15px 0px;
        width: 24px;
    }

    #cd-lateral-nav a.current {
        background-color: #3a4a4d;
        color: #FFF;
    }

.no-touch #cd-lateral-nav a:hover {
    color: #FFF;
}

@media only screen and (min-width: 768px) {
    #cd-lateral-nav .cd-navigation {
        margin: 20px 0;
    }
}

#cd-lateral-nav .item-has-children.box1 > a {
    background: #0a0a0a;
    padding: 10px 10px 10px 95px;
}

    ul.sub-menu.box2 a {
        background: #06122c;
        padding: 10px 10px 10px 100px;
    }

ul.sub-menu.box2 li a {
    background: #070707 !important;
    padding: 10px 10px 10px 120px !important;
    border-bottom: 2px solid #090909 !important;
}

    ul.sub-menu.box3 li a {
        background: #06122c;
        padding: 10px 10px 10px 100px !important;
    }



    #cd-lateral-nav.lateral-menu-is-open {
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        -o-transform: translateX(0);
        transform: translateX(0);
        visibility: visible;
        -webkit-transition: -webkit-transform .4s 0s, visibility 0s 0s;
        -moz-transition: -moz-transform .4s 0s, visibility 0s 0s;
        transition: transform .4s 0s, visibility 0s 0s;
        /* smooth the scrolling on touch devices - webkit browsers */
        -webkit-overflow-scrolling: touch;
    }

    /* style menu items which have a submenu  */
    #cd-lateral-nav .item-has-children > a {
        position: relative;
        /* this is the right arrow to show that the item has a submenu  */
    }

        #cd-lateral-nav .item-has-children > a::after {
            content: '';
            display: block;
            height: 11px;
            width: 8px;
            position: absolute;
            top: 50%;
            bottom: auto;
            -webkit-transform: translateY(-50%);
            -moz-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
            -o-transform: translateY(-50%);
            transform: translateY(-50%);
            right: 1em;
            background: url("/Resources/images/mobile/cd-arrow.svg") no-repeat center center;
            background-size: 8px 11px;
            -webkit-transition-property: -webkit-transform;
            -moz-transition-property: -moz-transform;
            transition-property: transform;
            -webkit-transition-duration: 0.2s;
            -moz-transition-duration: 0.2s;
            transition-duration: 0.2s;
        }

        #cd-lateral-nav .item-has-children > a.submenu-open::after {
            -webkit-transform: translateY(-50%) rotate(90deg);
            -moz-transform: translateY(-50%) rotate(90deg);
            -ms-transform: translateY(-50%) rotate(90deg);
            -o-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
        }

    #cd-lateral-nav .socials {
        padding: 0 32px;
    }

        #cd-lateral-nav .socials:after {
            content: "";
            display: table;
            clear: both;
        }

        #cd-lateral-nav .socials a {
            height: 32px;
            width: 32px;
            float: left;
            padding: 0;
            background-image: url("../img/cd-socials.svg");
            background-repeat: no-repeat;
            background-size: 128px 64px;
            background-color: #FFF;
            margin-right: .5em;
            border-radius: 0.25em;
        }

            #cd-lateral-nav .socials a.cd-twitter {
                background-position: 0 0;
            }

            #cd-lateral-nav .socials a.cd-github {
                background-position: -32px 0;
            }

            #cd-lateral-nav .socials a.cd-facebook {
                background-position: -64px 0;
            }

            #cd-lateral-nav .socials a.cd-google {
                background-position: -96px 0;
            }

    .no-touch #cd-lateral-nav .socials a:hover {
        background-color: #4e6361;
    }

        .no-touch #cd-lateral-nav .socials a:hover.cd-twitter {
            background-position: 0 -32px;
        }

        .no-touch #cd-lateral-nav .socials a:hover.cd-github {
            background-position: -32px -32px;
        }

        .no-touch #cd-lateral-nav .socials a:hover.cd-facebook {
            background-position: -64px -32px;
        }

        .no-touch #cd-lateral-nav .socials a:hover.cd-google {
            background-position: -96px -32px;
        }
