/* General styles for all menus */
.cbp-spmenu {
	position: fixed;
}



/* Orientation-dependent styles for the content of the menu */

.cbp-spmenu-vertical {
	width: 240px;
	height: 100%;
	top: 0;
	z-index: 1000;
}

.cbp-spmenu-vertical a {
	padding: 1em;
}

.cbp-spmenu-horizontal {
	width: 100%;
	left: 0;
	z-index: 5;
	overflow: auto;
}

.link-sub {
    font-weight: 100;
    color: #a7a7a7;
    text-decoration: underline;
	font-size: 0.875rem;
	margin-top: 0.4rem;
	display: block;
}


/* Vertical menu that slides from the left or right */

.cbp-spmenu-left {
	left: -240px;
}

.cbp-spmenu-right {
	right: -240px;
}

.cbp-spmenu-left.cbp-spmenu-open {
	left: 0px;
}

.cbp-spmenu-right.cbp-spmenu-open {
	right: 0px;
}
img.logo-sub {
    width: 204px;
	height: auto;
	margin-bottom: 4rem;
}

/* Horizontal menu that slides from the top or bottom */

.cbp-spmenu-top {
	top: -1100px;
}

.cbp-spmenu-bottom {
	bottom: -150px;
}

.cbp-spmenu-top.cbp-spmenu-open {
	top: 3.4rem;
}

.cbp-spmenu-bottom.cbp-spmenu-open {
	bottom: 0px;
}

a.btn-sub {
    text-transform: uppercase;
    font-size: 0.875rem;
    letter-spacing: 0.05rem;
	font-weight: 300;
	margin-right:1rem;
}

.first-row{
	margin-bottom:0.7rem;
}

/* Push classes applied to the body */

.cbp-spmenu-push {
	overflow-x: hidden;
	position: relative;
	left: 0;
}

.cbp-spmenu-push-toright {
	left: 240px;
}

.cbp-spmenu-push-toleft {
	left: -240px;
}

#cbp-spmenu-s3 {
	background-color: white;
	border-bottom: 1px solid black;
	padding: 0 20px 10px 20px;
	box-sizing: border-box;
	overflow-x: hidden;
}

#cbp-spmenu-s3 p{
	font-size:1rem;
	line-height: 1.3rem;
	margin-top: 0.5rem;
	text-align:center;
}

#cbp-spmenu-s3 h3{
	margin:0;
	text-align:center;
}


#showTop {
    position: absolute;
    right: 0.45rem;
    top: 0;
    padding: 0.85rem;
    cursor: pointer;
	width: 40px;
	height: 20px;
	display:-webkit-flex;
	display:-moz-flex;
	display:flex;
	flex-direction: column;
	justify-content: space-between;
    text-align: center;
	margin: auto;
	-webkit-transform: translate3d(0, 0, 0);
}

.line{
	width:100%;
	height: 1px;
	background-color:black;
}

/* Transitions */

.cbp-spmenu,
.cbp-spmenu-push {
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	transition: all 0.5s ease;
}

/* Example media queries */

@media screen and (max-width: 55.1875em){

	.cbp-spmenu-top {
		top: -1015px;
	}

	.cbp-spmenu-bottom {
		bottom: -110px;
	}

}

@media screen and (max-height: 26.375em){

	.cbp-spmenu-vertical {
		font-size: 90%;
		width: 190px;
	}

	.cbp-spmenu-left,
	.cbp-spmenu-push-toleft {
		left: -190px;
	}

	.cbp-spmenu-right {
		right: -190px;
	}

	.cbp-spmenu-push-toright {
		left: 190px;
	}
}
@media only screen and (min-width: 48rem){
	.cbp-spmenu-horizontal {
		height: auto;
		overflow:hidden;
	}
	.first-row{
		margin-bottom:0.5rem;
	}
	a.btn-sub {
		font-size: 1rem;
	}
	.cbp-spmenu-top.cbp-spmenu-open {
		top: 3.4rem;
	}
}

@media only screen and (min-width: 76rem){
	#showTop {
		right: 1rem;
		width:auto;
		left:auto;
	}
	#showTop.active.close{
		right: 2.3rem;
		left:auto;
	}
	#cbp-spmenu-s3 p{
		text-align:left;
	}
	#cbp-spmenu-s3 h3{
		text-align:left;
	}
	.bottom-nav{
		display:none;
	}
}