@import url(https://fonts.googleapis.com/css?family=Raleway:400,200);
/*
#cssmenu,
#cssmenu ul,
#cssmenu ul li,
#cssmenu ul li a {
	margin: 0;
	padding: 0;
	border: 0;
	list-style: none;
	line-height: 1;
	display: block;
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
*/


/*--- scrolling menu design --- */
.scrollbar {
	float: left;
	height: 510px;
	width: 280px;
	background: rgba(54, 54, 54, 0.95);
	overflow-y: scroll;
	margin-bottom: 25px;
	display: none;
	position: fixed;
    z-index: 99;
    top: 50px;
}

.force_overflow {
	min-height: 510px;
}

/* --- button overflow to x --- */

.js-menu_activated {
	overflow: hidden;
}

.js-menu_activated .menu {
	height: 100%;
	transform: translate3d(0, 0, 0);
	opacity: 1;
}

.js-menu_activated .hamburger:before {
	width: 100vh;
	height: 100vh;
	transform: translate3d(-50vh, -50vh, 0) scale(5);
}

.js-menu_activated .menu_list {
	display: block;
}

.js-menu_activated .hamburger_button:before {
	transform: translate3d(0, -50%, 0) rotate(45deg);
	top: 50%;
}

.js-menu_activated .hamburger_button:after {
	transform: translate3d(0, -50%, 0) rotate(135deg);
	top: 50%;
}

.js-menu_activated .hamburger_label {
	transform: rotate(-45deg) translate3d(-5.71429px,-6px,0);
	opacity: 0;
}

#style_1::-webkit-scrollbar-track {
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);
	border-radius: 10px;
	background-color: #F5F5F5;
}

#style_1::-webkit-scrollbar {
	width: 12px;
	background-color: #F5F5F5;
}

#style_1::-webkit-scrollbar-thumb {
	border-radius: 10px;
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);
	background-color: #555;
}

/*
.menu {
	box-sizing: border-box;
	width: 100%;
	padding-bottom: 55px;

	height: 0;
	transform: translate3d(0, -100%, 0);
	opacity: 0;

	display: flex;
	align-items: flex-end;

	position: fixed;
	top: 0;
	left: 0;
}

.menu_list {
	box-sizing: border-box;
	width: 100%;
	max-height: 100%;
	display: none;

	padding-top: 30px;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.menu_group {
	padding: .5rem 3rem; 
	font-size: 3.2rem;
	font-weight: 700;
	text-transform: uppercase;
}

.menu_group_active{
	//background-color: var(--colorWhite);
	//color: var(--colorBlack);
}

.menu_item{
	padding: 8px 25px;
	display: block;
}
*/
/* hamburger */

.hamburger {
	width: 40px;
    float: left;
}

.hamburger:before {
	content :"";
	//width: 100px;
	//height: 100px;
	//border-radius: 50%;

	position: absolute;
	bottom: -55px;
	left: -35px;
}

.hamburger_button {
	width: 40px;
	height: 30px;
	font-size: 20px;
	cursor: pointer;
	position: relative;
	text-indent: -9999px;
	z-index: 2;
	opacity: 0.7;
}

.hamburger_button:before, .hamburger_button:after, .hamburger_label {
	width: 100%;
	height: 15%;
	border-radius: 5px;
	background-color: #22264b;

	position: absolute;
	left: 0;
}

.hamburger_button:before, .hamburger_button:after {
	content:"";
}

.hamburger_button:before {
	top: 0;
}

.hamburger_button:after {
	bottom: 0;
}

.hamburger_button:focus {
	outline: none;
}

.hamburger_label {
	margin-top: -.1em;
	top: 50%;
}

/* --- responsive menu --- */
#cssmenu,
#cssmenu ul {
	margin: 0;
	padding: 0;
	border: 0;
	list-style: none;
	line-height: 1;
	display: block;
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

ul.responsive_menu_ul {
	display: none;
    width: 100%;
    padding: 0;
    margin: 0;
    position: static;
    float: left;
	//overflow-y: scroll;
    //height: 400px;
}

.responsive_menu_ul li {
    width: 100%;
    padding: 10px 5px 0 7px;
    display: table;
    position: relative;
    z-index: 9;
    border-bottom: 1px solid #fff;
    padding-bottom: 10px;
}

.responsive_menu_ul li ul li {
    padding-top: 20px;
    display: table;
    background: unset;
}

.responsive_menu_ul li a {
    font-weight: bold;
}

#cssmenu {
	width: 280px;
	color: #fff;
}

#cssmenu > ul {
	top: 50px;
}

#cssmenu > ul > li {
	float: left;
	width: 100%;
}

#cssmenu ul ul {
	display: none;
	float: left;
	width: 100%;
}

#cssmenu > ul > li.active > ul {
	display: block;
}

.align-right {
	float: right;
}

#cssmenu > ul > li > a {
	/*padding: 16px 22px;
	cursor: pointer;
	z-index: 2;
	font-size: 16px;
	text-decoration: none;
	color: #fff;
	background: #22264b;*/
	-webkit-transition: color .2s ease;
	-o-transition: color .2s ease;
	transition: color .2s ease;
}

.rotate_block {
	position: relative;
    width: 30px;
    height: 30px;
    float: right;
	background: rgba(0, 0, 0, 0.4);
    border-radius: 3px;
    border: 1px solid white;
}

#cssmenu > ul > li > .rotate_block:hover {
	color: #d8f3f0;
}

#cssmenu ul > li.has_sub > .rotate_block:after {
	position: absolute;
	right: 13px;
    top: 8px;
	z-index: 5;
	display: block;
	height: 10px;
	width: 2px;
	background: #fff;
	content: "";
	-webkit-transition: all 0.1s ease-out;
	-moz-transition: all 0.1s ease-out;
	-ms-transition: all 0.1s ease-out;
	-o-transition: all 0.1s ease-out;
	transition: all 0.1s ease-out;
}

#cssmenu ul > li.has_sub > .rotate_block:before {
	position: absolute;
	right: 9px;
    top: 12px;
	display: block;
	width: 10px;
	height: 2px;
	background: #fff;
	content: "";
	-webkit-transition: all 0.1s ease-out;
	-moz-transition: all 0.1s ease-out;
	-ms-transition: all 0.1s ease-out;
	-o-transition: all 0.1s ease-out;
	transition: all 0.1s ease-out;
}

#cssmenu ul > li.has_sub.open > .rotate_block:after,
#cssmenu ul > li.has_sub.open > .rotate_block:before {
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
}

#cssmenu ul ul li {
	/*padding: 14px 22px;
	cursor: pointer;
	z-index: 2;
	font-size: 14px;
	text-decoration: none;
	color: #fff;
	background: #22264b;*/
	-webkit-transition: color .2s ease;
	-o-transition: color .2s ease;
	transition: color .2s ease;
}
/*
#cssmenu ul ul li a {
	padding: 14px 22px;
	cursor: pointer;
	z-index: 2;
	font-size: 14px;
	text-decoration: none;
	color: #fff;
	background: #22264b;
	-webkit-transition: color .2s ease;
	-o-transition: color .2s ease;
	transition: color .2s ease;
}
*/
#cssmenu ul ul ul li a {
	//padding-left: 32px;
}

#cssmenu ul ul li a:hover {
	color: #fff;
}

#cssmenu ul ul > li.has_sub > .rotate_block:after {
	top: 10px;
    right: 13px;
	background: #fff;
}

#cssmenu ul ul > li.has_sub > .rotate_block:before {
	top: 14px;
	background: #fff;
}
/*
.label_cs {
	display: block;
	background: #22264b;
	width: 40px;
	height: 40px;
	cursor: pointer;
	float: left;
	position: fixed;
    z-index: 99;
}
		  
.label_cs:after {
	content:'';
	display: block;
	width: 30px;
	height: 5px;
	background: #ECEFF1;
	margin: 7px 5px;
	box-shadow: 0px 10px 0px #ECEFF1, 0px 20px 0px #ECEFF1;
}
*/
.has_sub {
	z-index: 9;
	width: 100%;
}
/*
.has_sub:hover a {
	transform: scale(0.95);
	transition: all .2s ease-in-out;
}

.has_sub:hover a:before {
	top: 10px !important;
}

.has_sub:hover a:after {
	top: 6px !important;
}
*/
.has_sub > a {
	width: 80%;
    float: left;
}

a:empty {
	display: none;
}

.responsive_menu_ul li:last-child {
	padding-bottom: 20px;
}

@media all and (max-width: 600px) {
	
	/* --- responsive menu scrollbar --- */
	
	.scrollbar {
		height: 320px;
	}
}
	

/* --- iPhone 6, 8 --- */

@media only screen and (min-device-width: 375px) and (max-device-height: 667px) and (orientation: landscape) and (-webkit-device-pixel-ratio: 2) {
	
	/* --- responsive menu scrollbar --- */
	
	.scrollbar {
		height: 320px;
	}
}	

/* --- iPhone 6, 8 --- */

@media only screen and (min-device-width: 414px) and (max-device-height: 736px) and (orientation: landscape) and (-webkit-device-pixel-ratio: 3) {
	
	/* --- responsive menu scrollbar --- */
	
	.scrollbar {
		height: 320px;
	}

}


	




