.cssmenu > ul {
	margin: 0;
}

/** setup tree like behaviour */
.cssmenu li {
    cursor: default;
    list-style: none;
	position: relative;
}

.cssmenu li > input {
	margin: 0;
	padding: 0;
}

.cssmenu li > input ~ ul {
    display: none;
}
 
.cssmenu li > input:checked ~ ul {
    display: block;
}

.cssmenu li > input, .cssmenu li > .blank {
	display: none;
	cursor: pointer;
}

.cssmenu li.submenu > input, .cssmenu li.submenu > .blank {
	display: block;
	position: absolute;
	right: 10px;
	width: 20px;
	height: 20px;
	top: 10px;
}

/** style checkboxes with pic in next span */
.cssmenu li > input {
    opacity: 0; 
    z-index: 1;
}

.cssmenu li.submenu > input + span {
	background: url('../pics/plus_icon.png');
	background-position: center;
	background-repeat: no-repeat;
	background-size: 15px 15px;
}

.cssmenu li.submenu > input:checked + span {
	background: url('../pics/minus_icon.png');
	background-position: center;
    background-repeat: no-repeat;
	background-size: 15px 15px;
}

/** style */
.cssmenu {
    padding-top: 0px;
    padding-bottom: 0px;
	position: relative;
}

.cssmenu ul {
	-webkit-padding-start: 0;
	-moz-padding-start: 0;
	padding-left: 0;
}

.cssmenu li {
	padding-top: 0px;
	padding-bottom: 0px;
}

.cssmenu li > a {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 16px;
    text-decoration: none;
	color: black;
	display: inline-block;
}

.cssmenu li > a:first-child {
	line-height: 30px;
}

.cssmenu li > a[href]:first-child:hover {
	color: #0080D0;
}

.cssmenu li.selected > a {
    color: #000000;
}

.cssmenu,
.cssmenu ul,
.cssmenu ul li,
.cssmenu span
{
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cssmenu .Wt-separator 
{
    height: 5px;
}

.cssmenu .menu-button {
    border-radius: 3px;
    border: solid 2px #52A7CA;
    background-color: #52A7CA;
    color: white;
    font-size: 12px;
    padding: 0 2px;
	margin-left: 20px;
}

.cssmenu .menu-group > * {
	vertical-align: middle;
}

.cssmenu .menu-group > a:first-child {
	font-weight: bold;
	line-height: 40px;
}

.cssmenu .menu-group > a:first-child > .Wt-icon {
	background-size: 20px;
	vertical-align: middle;
	display: inline-block;
	margin-left: 5px;
	margin-right: 8px;
	height: 20px;
	width: 20px;
	padding: 0px;
	margin-top: -3px;
}

.cssmenu .menu-button:hover {
    color: white;
    text-decoration: underline;
}

.cssmenu li.root > input {
	display: none;
}

.cssmenu li.selected.root > a span::after {
	width: 30%;
}

.cssmenu li.submenu {
	background-color: #e2e4e2;
	border-bottom: 1px solid whitesmoke;
}

.cssmenu li.submenu:last-child {
	border-bottom: none;
}

.cssmenu li.submenu > ul {
	background-color: #f8f9f8;
}

.cssmenu li.submenu > ul > li:hover,
.cssmenu li.submenu > ul > li.selected {
	background-color: whitesmoke;
}

.cssmenu li.submenu > ul > li {
	padding-left: 26px;
	border-left: 7px solid transparent;
}

.cssmenu li.submenu > ul > li.selected {
	border-left: 7px solid #454ca9;
}
