/*================================================================
                 CLICK MENU STYLES
================================================================*/

/*
    THESE STYLES will probably not be needed and are adjusted in your main styles
    - * for example is most efficient when not a child of a class
       -- hopefully you already are using the box sizing globally
    - you may not need text-decoration etc. depending on your global anchors
*/
.cm-menu a, .cm-menu a:visited { color:#252525; text-decoration:none; }
.cm-menu *, .cm-menu *:after, .cm-menu *:before {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
            box-sizing: border-box;
}

.cm-menu a:active, .cm-menu a:focus { outline:0; }

.outer-container {position:relative; right:0px;

    -webkit-transition: all .2s linear;
		-moz-transition: all .2s linear;
		-ms-transition: all .2s linear;
		-o-transition: all .2s linear;
		transition: all .2s linear;
}

@media (max-width:47.99em){
    .main-nav-active .outer-container {right:-83%;}
}


.main-nav-container {background:#fff;}
.main-nav-container > .container {position:static;}

.main-nav-fly-in {
	background: #2c1b5d none repeat scroll 0 0;  
	height: auto;
    left: -83%;
    position: absolute;
    top: 0;
    width: 83%;
    z-index: 100;
}

.cm-menu:focus { outline:3px solid blue;  }
.cm-menu, .cm-menu ul { margin:0; padding:0; list-style:none; background:#fff; }

.toggle-menu + .cm-menu, .cm-menu ul {
    max-height:0;
    opacity:0;
    overflow:hidden;
    -wekbit-transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out;
            transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out;
}

.cm-menu li a { display:block; padding:10px 25px; position:relative; background:#fff; }

.cm-menu li { border-top:1px solid #ccc; }
.cm-menu li:first-child { border-top:0; }
.cm-menu li { position:relative; }

.cm-menu .has-sub:after,
.cm-menu .expander-wrap .has-sub > span:after {
    content:"\2304";
	font-size:12px;
	font-weight:bold;
    display:inline-block;
    position:absolute; top:50%; right:10px;
    /* margin:2px 0 0 5px; */
	margin-top:-11px;
    vertical-align:middle;
    /* border:5px solid transparent; */
    /* Extra is for anti-aliasing issues in firefox and others */
    /* border:5px solid rgba(0,0,0,0);
    border-top-color:#fff; */
    -webkit-transform: scale(1.9,1);
        -ms-transform: scale(1.9,1);
            transform: scale(1.9,1);
}

.cm-menu .opened > .has-sub:after,
.cm-menu .opened > .expander-wrap .has-sub > span:after{
    content:"\2303";
	margin-top:-7px;
}

.cm-menu > .opened > a,
.cm-menu > li > a:hover,
.cm-menu > li > a:focus,
.cm-menu > li > div > a:hover,
.cm-menu > li > div > a:focus {}

.cm-menu .expander-wrap .has-sub:hover > span,
.cm-menu .expander-wrap .has-sub:focus > span { color:#333; background:#d4d4d4; }

.cm-menu ul li a:hover, 
.cm-menu ul li a:focus {background:#fff;}

.cm-menu ul .opened > .has-sub:after,
.cm-menu ul .opened > .expander-wrap .has-sub > span:after{
    border-top-color:#fff;
}

.cm-js-active .cm-menu { max-height:80em; opacity:1; }
.cm-menu .opened > ul { max-height:80em; opacity:1; }

/* ================= SEPARATE EXPANDERS OPTION IS ENABLED ================= */

.cm-menu .expander-wrap { display:table; width:100%; }
.cm-menu .expander-wrap a { display:table-cell; }
.cm-menu .expander-wrap .has-sub { position:relative; width:30px; }
.cm-menu .expander-wrap .has-sub:after { display:none; }
.cm-menu .expander-wrap .has-sub > span {
    display:block;
    position:absolute; top:0; right:0;
    width:100%; height:100%;
    background:#aaa;
}
.cm-menu .expander-wrap .has-sub > span:after {
    content:" ";
    display:inline-block;
    position:absolute; top:50%; right:50%;
    margin:2px 0 0 5px;
    vertical-align:middle;
    border:5px solid transparent;
    /* Extra is for anti-aliasing issues in firefox and others */
    border:5px solid rgba(0,0,0,0);
    border-top-color:#fff;
    -wekbit-transition: all 0.4s ease-in-out;
            transition: all 0.4s ease-in-out;
    -webkit-transform: scale(0.98) translate(50%, -50%);
        -ms-transform: scale(0.98) translate(50%, -50%);
            transform: scale(0.98) translate(50%, -50%);
}
.cm-menu .opened > .expander-wrap .has-sub > span:after {
    border-top-color:#333;
    -webkit-transform: scale(0.98) translate(50%, -75%) rotate(-180deg);
        -ms-transform: scale(0.98) translate(50%, -75%) rotate(-180deg);
            transform: scale(0.98) translate(50%, -75%) rotate(-180deg);
}

/* ================= HOVER FALLBACK IF JAVASCRIPT IS DISABLED ================= */

.no-js .toggle-menu + .cm-menu { opacity:1; max-height:80em; }
.no-js .cm-menu > li:hover > a { background:#333; }
.no-js .cm-menu ul ul li:hover > a { background:#444; }

.no-js .cm-menu li:hover > ul { display:block; max-height:80em; opacity:1; width:100%; }
.no-js .cm-menu ul { display:none; overflow:visible; }


/* ================= MENU OPEN FUNCTIONALITY ADDED ON SETUP ================= */

@media (min-width:80em){
    .toggle-menu + .cm-menu { max-height:80em; opacity:1; overflow:visible; }
    .cm-menu ul { top:100%; overflow:hidden; }
    .cm-menu .opened > ul { max-height:80em; opacity:1; }

    .cm-menu .animated > ul { overflow:visible; z-index:10; }
    .cm-menu .animating > ul { z-index:-1; }
	
	.main-nav-fly-in {background:#999; position:static; width:auto; min-height:0px !important;}
}


/*================================================================
                 CLICK MENU MENU TYPES
================================================================*/

/*  NAV BAR STYLE TYPE
    ================================================================*/

.nav-bar > ul > li > a > span {text-transform:uppercase; font-weight:bold; font-size:18px;}

@media (min-width:80em){
    .nav-bar li { border-top:0; }

    .nav-bar > ul { display:table; width:100%; /* table-layout:fixed; */ }
    .nav-bar > ul > li { display:table-cell; vertical-align:middle; padding:2px; }
    .nav-bar > ul > li > a { display:table; width:100%; padding:0; }
    .nav-bar > ul > li > a > span { display:table-cell; padding:0 25px; height:50px; vertical-align:middle; text-align:center; }
    .nav-bar > ul > li > ul { position:absolute; margin-top:19px;}

    .nav-bar .has-sub span:after { position:static; margin-top:10px; }
    .nav-bar ul ul .has-sub:after {right:25px; }

    .nav-bar ul li li:first-child {padding-top:30px;}
	.nav-bar ul li li:last-child {padding-bottom:30px;}
    .nav-bar ul li li li { margin-left:0; margin-right:0; }
    .nav-bar ul ul a,
	.nav-bar ul ul a:visited {background:#fff;}

    .nav-bar ul ul a:hover, 
	.nav-bar ul ul a:focus,
    .nav-bar ul ul .opened > a {background:#a3cb4d;}

    /* ================= HOVER FALLBACK IF JAVASCRIPT IS DISABLED ================= */

    .no-js .nav-bar ul ul li:hover > a { color:#2c1b5d; background:#f8fbff; }
	
	

}

/*  ACCORDION NAVIGATION
    ================================================================*/

/* ------------- CURRENTLY KEEPS SMALL SCREEN STYLES -------------- */


/*  DROP DOWN NAVIGATION
    ================================================================*/

@media (min-width:80em){
    [data-type="dropdown"] ul {
        display:block;
        position:absolute;
        z-index:-1;
        top:100%; left:0;
        width:100%; min-width:320px;
		border:1px solid #e3e3e3;
        -wekbit-transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out, left 0.4s ease-in-out, right 0.4s ease-in-out;
                transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out, left 0.4s ease-in-out, right 0.4s ease-in-out;
    }
	[data-type="dropdown"] ul li {}
	
    [data-type="dropdown"] ul ul { top:-1px;}
    [data-type="dropdown"] .opened > ul { left:100%; max-height:80em; opacity:1; }

    .nav-bar ul li[data-type="dropdown"] li li { /* margin-left:5px; margin-right:5px; */ }

    [data-type="dropdown"] a + .has-sub { width:0; min-height:0; height:100%; }
    [data-type="dropdown"] a + .has-sub > span { min-height:0; height:100%; }

    /* ================= HOVER FALLBACK IF JAVASCRIPT IS DISABLED ================= */

    .no-js .cm-menu [data-type="dropdown"] li:hover > ul { left:100%; }
    .no-js .cm-menu [data-type="dropdown"]:nth-last-child(-n+2) ul { left:auto; right:0; }
    .no-js .cm-menu [data-type="dropdown"]:nth-last-child(-n+2) li:hover > ul { left:auto; right:100%; }

}

/* @media only screen and (min-width:87.5em) {
    li[data-type="dropdown"]:nth-last-child(-n+6) ul { left:auto; right:0; }
    li[data-type="dropdown"]:nth-last-child(-n+6) .opened > ul { left:auto; right:100%; }	
} */	

/*  SLIDING MENU NAVIGATION ADJUSTMENTS
    ================================================================*/


[data-type="sliding"].opened .sub-menu,
[data-type="sliding"].opened .sub-menu ul { max-width:100%; }

.cm-menu [data-type="sliding"].opened .sub-menu > ul { max-height:80em; opacity:1; }
.cm-menu [data-type="sliding"].animated .sub-menu > ul { overflow:visible; z-index:10; }
.cm-menu [data-type="sliding"].animating .sub-menu { z-index:-1; }

@media (min-width:80em){

    [data-type="sliding"] .sub-menu {
        position:absolute;
        -wekbit-transition: all 0.4s ease-in-out;
                transition: all 0.4s ease-in-out;
    }
    [data-type="sliding"] .sub-menu > ul {
        display:block;
        position:absolute;
        z-index:-1;
        top:100%; left:0;
        width:180px;
        background:#333;
        -wekbit-transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out, left 0.4s ease-in-out, right 0.4s ease-in-out;
                transition: max-height 0.4s ease-in-out, opacity 0.4s ease-in-out, left 0.4s ease-in-out, right 0.4s ease-in-out;
    }

    [data-type="sliding"] .sub-menu > ul li { position:static; }
    [data-type="sliding"] .sub-menu > ul > li > ul { position:absolute; top:0; }

    [data-type="sliding"] .sub-menu > ul ul { position:absolute; top:0; }

    [data-type="sliding"] .sub-menu ul ul ul { position:static; margin:0; padding:0; max-height:80em; width:100%; overflow:hidden; background:transparent; opacity:1; }

    [data-type="sliding"] .sub-menu ul ul .has-sub { color:#fff; cursor:default; }
    [data-type="sliding"] .sub-menu ul ul .has-sub { background: none; border-bottom:1px solid #fff; }
    [data-type="sliding"] .sub-menu ul ul .has-sub:after,
    [data-type="sliding"] .sub-menu ul ul .expander-wrap .has-sub  { display:none; }

    [data-type="sliding"] .sub-menu > ul > li > ul > li { float:left; width:50%; padding:0 5px; }
    [data-type="sliding"] .sub-menu > ul > li > ul > li:nth-child(2n+1) { clear:left; }
    [data-type="sliding"] .sub-menu > ul > li > ul > .link-landing { margin-left:0; margin-right:0; width:100%; }
    [data-type="sliding"] .sub-menu > ul > li > ul > .link-landing ~ li:nth-child(2n+1) { clear:none; }
    [data-type="sliding"] .sub-menu > ul > li > ul > .link-landing ~ li:nth-child(2n+2) { clear:left; }

    /* ================= ESSENTIAL SLIDING FUNCTIONALITY ================= */

    [data-type="sliding"] .sub-menu.cm-js-inactive { position:relative; left:0 !important; width:100% !important; }
    [data-type="sliding"] .sub-menu.cm-js-inactive > ul { min-width:100%; }
    [data-type="sliding"] .sub-menu.cm-js-inactive > ul > li > ul { padding:0; max-width:0; }

    [data-type="sliding"] .sub-menu > ul ul { width:100%; margin-left:-5px; padding-left:180px; padding-right:5px; z-index:-1; opacity:0; }
    [data-type="sliding"] .sub-menu .animated ul { opacity:1; }

    [data-type="sliding"].opened .sub-menu, [data-type="sliding"].opened .sub-menu ul { max-width:none; }

    /* ================= HOVER FALLBACK IF JAVASCRIPT IS DISABLED ================= */

    .no-js .cm-menu [data-type="sliding"] li:hover > ul { left:100%; }
    .no-js .cm-menu [data-type="sliding"]:nth-last-child(-n+2) ul { left:auto; right:0; }
    .no-js .cm-menu [data-type="sliding"]:nth-last-child(-n+2) li:hover > ul { left:auto; right:100%; }

}

/*  MEGA MENU NAVIGATION ADJUSTMENTS
    ================================================================*/

@media (min-width:80em){

    .cm-menu [data-type="mega"] { position:static; }
    [data-type="mega"] > ul {
        position:absolute;
        top:100%; left:0;
        width:100%; max-height:0;
        background:#333;
        overflow:hidden;
        -wekbit-transition: all 0.5s ease-in-out;
                transition: all 0.5s ease-in-out;
    }

    [data-type="mega"] > ul ul { position:static; max-height:80em; width:100%; overflow:hidden; background:transparent; opacity:1; }
    [data-type="mega"] > ul .opened ul { margin-left:0; }
    [data-type="mega"] > ul > li { float:left; width:25%; }
    [data-type="mega"] > ul > li:nth-child(4n+1) { clear:left; }

    [data-type="mega"] > ul > .link-landing { margin:0; width:100%; }
    [data-type="mega"] > ul > .link-landing ~ li:nth-child(4n+1) { clear:none; }
    [data-type="mega"] > ul > .link-landing ~ li:nth-child(4n+2) { clear:left; }

    /* ================= OPENED FUNCTIONALITY ADDED ON SETUP ================= */

    [data-type="mega"] a + .has-sub { width:0; min-height:0; height:100%; }
    [data-type="mega"] a + .has-sub > span { min-height:0; height:100%; }
    [data-type="mega"] ul .has-sub:after { display:none; }
    [data-type="mega"].opened > ul { padding:20px; }

    /* ================= SEPARATE EXPANDERS OPTION IS ENABLED ================= */

    [data-type="mega"] ul a + .has-sub { display:none; }

    /* ================= HOVER FALLBACK IF JAVASCRIPT IS DISABLED ================= */

    .no-js .cm-menu [data-type="mega"] ul ul { display:block; }

}


/*================================================================
                 NAVIGATION TOGGLE STYLES
================================================================*/

.toggle-menu, .toggle-menu2 { display:block; position:absolute; top:13px;  right:15px;  width:50px; height:50px; background:none; }
.toggle-menu:before, .toggle-menu:after, .toggle-menu > span:before,
.toggle-menu2:before, .toggle-menu2:after, .toggle-menu2 > span:before  {
    content:" ";
    position:absolute;
    left:50%;
	margin-left:-16px;
    border-radius:3px;
    width:32px; height:4px;
    background:#2b1b5d;
}

.toggle-menu:before,
.toggle-menu2:before { top:14px; }
.toggle-menu:after,
.toggle-menu2:after  { top:24px; }
.toggle-menu > span:before,
.toggle-menu2 > span:before { top:34px; }

.toggle-menu:hover, .toggle-menu:focus, .js-menu-active .toggle-menu,
.toggle-menu2:hover, .toggle-menu2:focus, .js-menu-active .toggle-menu2 { background:#f9f9f9; }

@media screen and (max-width: 460px) {
    .toggle-menu, .toggle-menu2 {
        top: 18px;
    }

    .toggle-menu:before, .toggle-menu:after, .toggle-menu > span:before, .toggle-menu2:before, .toggle-menu2:after, .toggle-menu2 > span:before {
        width: 28px;
        margin-left: -5px;
    }

    .toggle-menu:before, .toggle-menu2:before {
        top: 10px;
    }

    .toggle-menu > span:before, .toggle-menu2 > span:before {
        top: 26px;
    }

    .toggle-menu:after, .toggle-menu2:after {
        top: 18px;
    }

    .site-header a.site-logo {
        Xwidth: 120px;
    }
}

@media (min-width:80em){
    .toggle-menu, .toggle-menu2 { display:none; }
}


/*================================================================
                 EXTRA OVERWRITE STYLES
================================================================*/

.main-nav { z-index:1000; }

[data-type="sliding"] .sub-menu .item-banner { width:100%; }
[data-type="sliding"] .sub-menu .item-banner a { text-align:center; background:none; }

[data-type="mega"] .custom-sub {
    max-height:0; opacity:0;
    overflow:hidden;
    -wekbit-transition: all 0.5s ease-in-out;
            transition: all 0.5s ease-in-out;
}
[data-type="mega"] .custom-sub ul { position:static; opacity:1; max-height:80em; }
[data-type="mega"] .custom-sub p { margin:10px; color:#fff; }

[data-type="mega"] .custom-sub .banner-wrap { width:100%; }
[data-type="mega"] .custom-sub .banner-wrap a { text-align:center; background:none; }

.cm-menu .opened > .custom-sub { max-height:80em; opacity:1; padding:20px; }
.cm-menu .animated > .custom-sub { overflow:visible; z-index:10; }
.cm-menu .animating > .custom-sub { z-index:-1; }

.section-nav .opened > ul { border-bottom:1px solid #d4d4d4; max-height:80em; opacity:1; }
.section-nav .opened > a,
.section-nav .opened > .expander-wrap a { border-bottom:1px solid #aaa; color:#333; background:#d4d4d4; }
.section-nav .opened .opened > .expander-wrap > a { background:#c4c4c4; }


.cm-menu { 
	position:absolute;
	top:92px;	
	left:0;
	width:100%;
    z-index:9;
}

.site-header .logos {
	Xdisplay:none;
	position:relative;
	padding:0 10px;
}

    .site-header .logos p {
        text-align: center;
        display: flex;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center;
        min-width: 280px;
    }

        .site-header .logos p a {
            margin: 5px 0px;
        }

.site-header .logos img {
	margin:0 20px;
}

.header-logo {
	margin:10px 10px 40px 25px;
}

.site-header .logos .pipe:after {
    content: "";
    width: 1px;
    height: 20px;
    background: #bfbfbf;
    position: relative;
    top: -10px;
    right: initial;
    display:block;
}

@media (min-width:80em) {
	.cm-menu { 
		position:relative;
		top:auto;	
		left:auto;
		width:auto;
	}
	
	.site-header .logos {
		display:block;
	}

	.header-logo {
		display:none;
	}
    .site-header a.site-logo {
        max-width: 300px;
        width: auto;
    }

    .toggle-menu + .cm-menu {
        display: flex;
        justify-content: flex-start;
        align-items: center;
    }
	
}

.cm-menu li:not(.opened) ul a {
    display:none;
}


@media (max-width:1279px) {
    .site-header {
        width:calc((100%) - (70px));
    }
    .site-header .logos {
        xorder: 4;
        Xright: -97px;  border:solid 0px #ff0000;
    }
    .site-header .siteLogo {
        flex-grow: 1;
        border: solid 0px #ff0000;
    }

    .toggle-menu, .toggle-menu2 {
        top:21px;
        Xright: -60px;
        
    }
    .cm-menu .header-logo {
        display:none;
    }
}

@media (max-width:710px) {
    .site-header {
        flex-wrap:wrap;
    }
    .site-header .logos {
        order: 4;
        width:100%;
        padding:0;
    }
    .toggle-menu, .toggle-menu2 {
        top: 11px;
    }
    .cm-menu {
        top: 142px;
    }
    .site-header .logos p {
        width: 100%;
        justify-content:flex-start;
    }
    .site-header .logos p .pipe {
        display:none;
    }
    .site-header a.site-logo {
        xmargin: 0px auto;
    }
    span.algolia-autocomplete .searchbox__input:focus {
        max-width: 115px !important;
    }
}

@media (max-width:460px) {
    .toggle-menu, .toggle-menu2 {
        top: 18px;
    }
    .site-header .search {
        width:auto;
    }
    span.algolia-autocomplete .searchbox__input:focus {
        max-width: initial !important;
    }
}