@CHARSET "UTF-8";
/**
 * Menüs
 */ 

@media screen, projection {
	#dp-navigation <<* { text-align: center; }
		li { display: inline; }
		a{ display: inline-block; margin: .25rem .5rem; font-size: .75rem; }
		a:hover{ opacity: .666; }
		li.active > a{ text-decoration: underline; }
	>>
	
	#dp-mobilemenubtn <<* {
		display: inline-block; width: 30px; height: 25px; position: relative;
		-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
		-moz-tap-highlight-color: rgba(0, 0, 0, 0);
	}
		span, span:before, span:after{ display: block; width: 100%; position: absolute; height: 2px; left: 0; background: #fff; border-radius: 1px; transition: all .25s; }
		span{ top: 50%; margin-top: -1px; }
		span:before, span:after{ content: ""; }
		span:before{ bottom: 7px; }
		span:after{ top: 7px; }
		&:hover <<* {}
			span:before{ bottom: 10px; }
			span:after{ top: 10px; }
		>>
	>>

	#dp-mainmenu, #dp-mmenu <<* { display: none; width: 100%; background: #fff; margin: 1rem 0 0; }
		li{ position: relative; }
		a, .append-submenu, .menu-item-static{ display: block; padding: var(--smallspacing) 1rem; }
		.append-submenu <<* { display: none; position: absolute; top: 0; right: 0; width: 3rem; text-align: center; border-left: 1px solid rgba(0,0,0,.15); }
			svg{ vertical-align: middle; height: 1em; transform: rotate(0); transition: all .25s; display: inline-block; color: inherit; }
		>>
		li.has-submenu <<* {  }
			> .append-submenu{ display: block; }
		>>
		li.dropdownOpen <<* {  }
			> .append-submenu svg{ transform: rotate(180deg); }
			> ul{ display: block!important; }
		>>
		> ul <<* { border-bottom: 1px solid rgba(0,0,0,.15); margin: 0 -1rem; background: #fff; }
			> li <<* { border-top: 1px solid rgba(0,0,0,.15); }
				> a, > .menu-item-static{ text-transform: uppercase; font-weight: var(--fontweightbold); color: var(--linkcolor); }
				> a + .append-submenu > svg{ color: var(--linkcolor); }
				> .menu-item-static + .append-submenu > svg{ color: var(--linkcolor); }
			>>
			> li.active > a, > li > a:active,
			> li.active > .menu-item-static, > li > .menu-item-static:active <<* {
				color: #fff; background: var(--linkcolor);
			}
				& + .append-submenu > svg{ color: #fff; }
			>>
		>>
		ul.submenu <<* { display: none; background: rgba(0,0,0,0.05); }
			li <<* { border-top: 1px solid rgba(0,0,0,.1); font-size: .925em; }
				> a{ color: var(--linkcolor); }
				> a + .append-submenu > svg{ color: var(--linkcolor); }
			>>
			> li.active > a, > li > a:active <<* {
				color:var(--linkcolor); background: rgba(0,0,0,.075);
			}
				& + .append-submenu > svg{ color: var(--linkcolor); }
			>>
			ul.submenu{ background: rgba(0,0,0,.05); }
		>>
	>>

	body.mobilemenu-active <<* {}
		#dp-mobilemenubtn <<* {}
			span{ background: transparent; }
			span:before{ bottom: 0; transform: rotate(-45deg); transform-origin: 50% 50%; }
			span:after{ top: 0; transform: rotate(45deg); transform-origin: 50% 50%; }
		>>
		#dp-mmenu { display: block!important; }
		.dp-topnav.is-clone{ display: block; }
	>>
	
	#dp-mainsubmenu{ display: none; }
}

@media all and (min-width: var(--breakpoint-s)){
}

@media all and (min-width: var(--breakpoint-m)){
}

@media all and (min-width: var(--breakpoint-l)){
	#dp-mobilemenubtn, #dp-mmenu, body.mobilemenu-active #dp-mmenu{ display: none !important; }
	
	#dp-mainmenu <<* { display: block!important; width: auto; background: none; margin: 0; border: none; }
		/* Mobile menu resets */
		ul, li{ border: none!important; }
		.append-submenu{ display: none!important; }
	
		/* Alle Menüebenen */
		ul.menu <<* { }
			li <<* { position: relative; }
				a, .menu-item-static{ display: block; }
			>>
			li.active > .menu-item-static, li:hover > .menu-item-static,
			li.active > a, li:hover > a{ text-decoration: none; }
		>>
	
		/* Alle Unterebenen */
		ul.submenu <<* {
			display: none !important; width: 280px; background: #fff; box-shadow: 0 0 3px 0 rgba(0,0,0,.05);
			opacity: 0; visibility: hidden; transition: opacity .25s, transform .25s; position: absolute; top: -100vh; left: -100vw; z-index: 5;
		}
			li <<* { }
				> a { color: var(--linkcolor); line-height: 1.25em; font-size: 1rem; padding: .75rem 1.25rem; }
			>>
			> li.active, > li:hover, > li.dropdownOpen <<*  {}
				> a { color: #fff; background: var(--linkhover); }
			>>
		>>
		
		/* Oberste Ebene */
		ul.menu <<* { margin: 0; }
			> li <<* { float: left; position: relative; }
				> a, > .menu-item-static { color: var(--fontcolor); line-height: 1rem; display: inline-flex; flex-direction: column; font-size: 1rem; padding: 1.75rem 1rem 1rem; }
				> a::after, .menu-item-static::after{ content: ""; width: 100%; height: .25rem; background: #fff; margin-top: .5rem; opacity: 0; transform: translate(0,.5rem); transition: all .5s; }
			>>
			> li.active, > li:hover, > li.dropdownOpen, > li.current-megamenu <<*  {}
				> a,> .menu-item-static { color: var(--fontcolor); background: none; }
				> a::after, > .menu-item-static::after{ opacity: 1; transform: translate(0,0); }
			>>
			> li.has-submenu <<* {}
			>>
		>>
		
		/* 1. Unterebene */
		ul.menuDepth1 <<* { }
			> li <<* { }
				> a { }
			>>
			> li.active > a, > li:hover > a{  }
		>>
		
		/* 2. Unterebene */
		ul.menuDepth2 <<* { }
			> li <<* { }
				> a { }
			>>
			> li.active > a, > li:hover > a{  }
		>>
		
		/* Allgemeiner Hover */
		li:hover, li.dropdownOpen <<* { position: relative; }
			/*
			> ul{ opacity: 1; visibility: visible; }
			ul.submenu <<* { top: 100%; left: 0; }
				ul.submenu{ top: 0; left: 100%; }
			>>
			*/
		>>
	>>
	
	#dp-secondlevelmenu{ background: var(--brandprimarydark); padding: 2em 0; }
	#dp-mainsubmenu <<* { display: block; }
		.menu-title{ font-size: 1.5rem; padding-bottom: .1rem; color: #fff; border-bottom: 2px solid #fff; white-space: nowrap; }
		li.active > .menu-title{ color: var(--brandsecondary); border-bottom-color: var(--brandsecondary); }
		a{ color: #fff; display: block; padding: .1rem 0; }
		li.active > a, a:hover{ color: var(--brandsecondary); }
		> ul <<* { }
			> li <<* { width: 250px; padding-right: var(--defaultspacing); }
			>>
		>>
		> ul.single-level <<* { max-width: 690px; }
			> li <<* { width: 33.333%; }
			>>
		>>
	>>
}

@media all and (min-width: var(--breakpoint-xl)){
	#dp-mainmenu <<* {  }
		ul.menu <<* {  }
			> li <<* { margin-left: 1.5rem; }
				> a, .menu-item-static{ font-size: 1.25rem; padding: 1.75rem 1.25rem 1rem; }
			>>
		>>
	>>
	
	#dp-header #dp-secondlevelmenu .close-secondlevelmenu{ right: .5rem!important; }
	#dp-mainsubmenu <<* {  }
		.menu-title{ font-size: 1.75rem; }
		> ul <<* { }
			> li <<* { width: 270px; padding-right: 20px; }
			>>
		>>
	>>
}

@media all and (min-width: var(--breakpoint-xxl)){
	#dp-mainsubmenu <<* {}
		> ul <<* { }
			> li <<* { width: 300px; padding-right: 30px; }
			>>
		>>
	>>
}

@media all and (min-width: 1660px){
	#dp-header #dp-secondlevelmenu .close-secondlevelmenu{ right: 1.5rem!important; }
}