/*╔════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╗*/
/*║ HEADER I                                                                                                                                                                                                                                              ║*/
/*╚════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╝*/
/***-------------------------------------------*** Space for Header ***-------------------------------------------***/
#cmsgrid > div:first-of-type { padding-top: 216px; }

/***-------------------------------------------*** Header ***-------------------------------------------***/
header { position: fixed; z-index: 1000; left: 0; top: 0; right: 0; height: 216px; background: var(--white); transition: var(--transition); }
body.scrolled header { box-shadow: 0 0 100px 0 rgba(0,0,0,0.1); }
header:before { content: ""; position: absolute; z-index: -1; bottom: 0; left: 0; width: 100%; height: 6px; background: var(--primary); }
header .cms_container_wide { position: relative; height: 216px; padding: 0 30px; }

/***-------------------------------------------*** Hamburger ***-------------------------------------------***/
header #hHamburger { position: absolute; right: 30px; display: none; width: 39px; height: 20px; transition: var(--transition); }
#nav-icon4 { cursor: pointer; position: relative; display: inline-block; width: 39px; height: 20px; transform: rotate(0deg); transition: var(--transition); }
#nav-icon4 span { position: absolute; left: 0; display: block; width: 100%; height: 2px; opacity: 1; background: var(--primary); transform: rotate(0deg); transition: var(--transition); }
#nav-icon4 span:nth-child(1),
#nav-icon4 span:nth-child(2),
#nav-icon4 span:nth-child(3) { transform-origin: left center; }
#nav-icon4 span:nth-child(1) { top: 0px; }
#nav-icon4 span:nth-child(2) { top: 9px; }
#nav-icon4 span:nth-child(3) { top: 18px; }
body.navi header #hHamburger { height: 30px; }
body.navi #nav-icon4 { height: 30px; }
body.navi #nav-icon4 span:nth-child(1) { top: 0; left: 4.5px; transform: rotate(45deg); }
body.navi #nav-icon4 span:nth-child(2) { width: 0%; opacity: 0; }
body.navi #nav-icon4 span:nth-child(3) { top: 28px; left: 4.5px; transform: rotate(-45deg); }

/***-------------------------------------------*** Close ***-------------------------------------------***/
#hClose { cursor: pointer; position: absolute; top: 30px; right: 30px; display: none; width: 28px; height: 28px; transition: var(--transition); will-change: transform; }
#hClose:hover { transform: scale(1.1); }
#hClose > span { position: absolute; z-index: 1; top: 50%; left: 50%; transform: translate(-50%,-50%) rotate(45deg); background: var(--white); }
#hClose > span:first-child { width: 100%; height: 2px; }
#hClose > span:last-child { width: 2px; height: 100%; }

/***-------------------------------------------*** Logo ***-------------------------------------------***/
body #logo_container { position: absolute; z-index: 1; top: 17px; left: 30px; width: 163px; height: 174px; }
body #logo_container > a { position: absolute; z-index: 1; inset: 0; background: center left / contain no-repeat url("/pages/img/logo.svg"); transition: var(--transition); }
body.scrolled #logo_container > a { background: center left / contain no-repeat url("/pages/img/logo_small.svg"); }

/***-------------------------------------------*** Service Navigation ***-------------------------------------------***/
header #hService { position: absolute; z-index: 3; top: 0; right: 30px; }
header #hService > ul { display: flex; align-items: center; gap: 48px; }
header #hService > ul > li { display: block; }
header #hService > ul > li > a { display: block; font-weight: 600; padding: 9.5px 22px; color: var(--white); background: var(--primary); border: 2px solid var(--primary); box-shadow: 1px 3px 11px 0 rgba(0,0,0,0.25); transition: var(--transition); }
header #hService > ul > li.current > a,
header #hService > ul > li:hover > a { color: var(--primary); background: var(--white); }

/***-------------------------------------------*** Hide Except Mobile ***-------------------------------------------***/
header #hServiceMobile,
header #hFooterArt { display: none; }

/***-------------------------------------------*** Desktop ***-------------------------------------------***/
@media screen and (min-width: 1201px) {
	/* Start: First-Level */
	header #hNavigation { position: relative; z-index: 2; width: calc(100% - 193px); padding: 91px 0 0 0; margin: 0 0 0 auto; }
	header #hNavigation > ul { display: flex; justify-content: flex-end; align-items: baseline; width: 100%; }
	header #hNavigation > ul > li { position: relative; display: block; }
	header #hNavigation > ul > li > a:not([href]) { cursor: auto; }
	header #hNavigation > ul > li:not(.hCustom) > a { position: relative; z-index: 1; display: flex; align-items: center; gap: 11px; font-weight: 500; font-size: 24px; line-height: 29px; padding: 18.5px 35px; background: transparent; transition: var(--transition); }
	header #hNavigation > ul > li:not(.hCustom).current > a,
	header #hNavigation > ul > li:not(.hCustom):hover > a { color: var(--primary); background: var(--white); }
	header #hNavigation > ul > li.hCustom > a { display: block; font-weight: 600; padding: 9.5px 22px; color: var(--white); background: var(--primary); border: 2px solid var(--primary); box-shadow: 1px 3px 11px 0 rgba(0,0,0,0.25); transition: var(--transition); }
	header #hNavigation > ul > li.hCustom.current > a,
	header #hNavigation > ul > li.hCustom:hover > a { color: var(--primary); background: var(--white); }
	/* End: First-Level */

	/* Start: Toggler */
	header #hNavigation > ul > li > a > div.toggler { width: 13px; height: 7px; }
	header #hNavigation > ul > li > a > div.toggler > svg { display: flex; width: 13px; height: 7px; will-change: transform; }
	header #hNavigation > ul > li:hover > a > div.toggler > svg { transform: rotate(180deg); }
	header #hNavigation > ul > li > a > div.toggler > svg > path { stroke: var(--primary); }
	/* End: Toggler */

	/* Start: Second-Level */
	header #hNavigation > ul > li > div { display: none; align-items: flex-start; gap: 52px; position: absolute; top: 66px; right: 0; max-width: 1040px; width: calc(100dvw - 60px); padding: 50px; background: var(--white); box-shadow: 0 0 100px 0 rgba(0,0,0,0.2); }
	header #hNavigation > ul > li:hover > div { display: flex; }
	header .cms_nav_imgContainer { position: relative; display: flex; width: 52.554%; aspect-ratio: 494 / 292; }
	header .cms_nav_imgBox { display: flex; width: 100%; }
	header .cms_nav_imgBox > picture { display: block; width: 100%; }
	header .cms_nav_imgBox > picture > img { position: absolute; z-index: 1; inset: 0; width: 100%; height: 100%; object-position: center; object-fit: cover; }
	header #hNavigation > ul > li > div > ul { display: flex; flex-direction: column; gap: 26px; flex: 1; }
	header #hNavigation > ul > li > div > ul > li { position: relative; display: block; }
	header #hNavigation > ul > li > div > ul > li:before,
	header #hNavigation > ul > li > div > ul > li:after { content: ""; position: absolute; z-index: 1; left: 0; width: 100%; height: 1px; background: var(--primary); }
	header #hNavigation > ul > li > div > ul > li:before { bottom: -7px; }
	header #hNavigation > ul > li > div > ul > li:after { bottom: -13px; transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > div > ul > li.current:after,
	header #hNavigation > ul > li > div > ul > li:hover:after { transform: translateY(-5px); }
	header #hNavigation > ul > li > div > ul > li > a { display: block; font-size: 28px; line-height: 34px; transition: var(--transition); }
	header #hNavigation > ul > li > div > ul > li.current > a,
	header #hNavigation > ul > li > div > ul > li:hover > a { color: var(--primary); }
	/* End: Second-Level */

	/* Start: Scrolled */
	header,
	header .cms_container_wide,
	body #logo_container,
	header #hService,
	header #hNavigation,
	header #hNavigation > ul > li.hCustom { transition: var(--transition); }

	header #hService { will-change: transform; }

	body.scrolled header { height: 100px; }
	body.scrolled header .cms_container_wide { height: 100px; }
	body.scrolled #logo_container { top: 12px; width: 68px; height: 70px; }
	body.scrolled header #hService { transform: translateY(-60px); }
	body.scrolled header #hNavigation { width: calc(100% - 98px); padding: 14px 0 0 0; }
	header #hNavigation > ul > li.hCustom { margin: 0 -181.16px 0 0; opacity: 0; visibility: hidden; }
	body.scrolled header #hNavigation > ul > li.hCustom { margin: 0; opacity: 1; visibility: visible; }
	/* End: Scrolled */
}
@media screen and (min-width: 1201px) and (max-width: 1750px) {
	header #hNavigation > ul > li > div { transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > div { position: fixed; top: 157px; right: auto; left: 50%; transform: translateX(-50%); max-width: 1170px; }
	body.scrolled header #hNavigation > ul > li > div { top: 80px; }
}

/***-------------------------------------------*** Tablet ***-------------------------------------------***/
@media screen and (min-width: 960px) and (max-width: 1200px) {
	/* Start: Allgemein */
	header #hNavigation { position: fixed; top: 172px; right: -100%; bottom: 0; overflow-y: auto; transition: var(--transition); }
	body.navi header #hNavigation { right: 0; }
	/* End: Allgemein */

	/* Start: Header */
	#cmsgrid > div:first-of-type { padding-top: 172px; }
	header { height: 172px; }
	header .cms_container_wide { height: 172px; }
	header #hHamburger { display: block; top: 98px; transform: none; }
	body #logo_container { top: 17px; width: 124px; height: 132px; }
	/* End: Header */

	/* Start: First-Level */
	header #hNavigation > ul { display: flex; flex-direction: column; gap: 12px; width: 100%; padding: 30px; background: var(--primary); }
	header #hNavigation > ul > li { display: block; }
	header #hNavigation > ul > li.hCustom { display: none; }
	header #hNavigation > ul > li > a { display: flex; align-items: center; gap: 10px; font-weight: 500; font-size: 36px; line-height: 43px; color: var(--white); transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > a:not([href]) { cursor: auto; }
	header #hNavigation > ul > li.current > a,
	header #hNavigation > ul > li:hover > a { transform: translateX(15px); }
	/* End: First-Level */

	/* Start: Toggler */
	header #hNavigation > ul > li > a > div.toggler { width: 29px; height: 17px; }
	header #hNavigation > ul > li > a > div.toggler > svg { display: flex; width: 29px; height: 17px; will-change: transform; }
	header #hNavigation > ul > li.open > a > div.toggler > svg { transform: rotate(180deg); }
	header #hNavigation > ul > li > a > div.toggler > svg > path { stroke: var(--white); }
	/* End: Toggler */

	/* Start: Second-Level */
	header #hNavigation > ul > li > div { display: none; margin: 12px 0 0 0; }
	header #hNavigation > ul > li.open > div { display: block; }
	header .cms_nav_imgContainer { display: none; }
	header #hNavigation > ul > li > div > ul { display: flex; flex-direction: column; gap: 24px; padding: 20px; background: var(--white); }
	header #hNavigation > ul > li > div > ul > li { position: relative; display: block; }
	header #hNavigation > ul > li > div > ul > li:before,
	header #hNavigation > ul > li > div > ul > li:after { content: ""; position: absolute; z-index: 1; left: 0; width: 100%; height: 1px; background: var(--primary); }
	header #hNavigation > ul > li > div > ul > li:before { bottom: -5px; }
	header #hNavigation > ul > li > div > ul > li:after { bottom: -9px; transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > div > ul > li.current:after,
	header #hNavigation > ul > li > div > ul > li:hover:after { transform: translateY(-3px); }
	header #hNavigation > ul > li > div > ul > li > a { display: block; font-size: 24px; line-height: 36px; transition: var(--transition); }
	header #hNavigation > ul > li > div > ul > li.current > a,
	header #hNavigation > ul > li > div > ul > li:hover > a { color: var(--primary); }
	/* End: Second-Level */

	/* Start: Scrolled */
	header,
	header .cms_container_wide,
	header #hHamburger,
	body #logo_container,
	header #hService,
	header #hNavigation { transition: var(--transition); }

	body.scrolled header { height: 80px; }
	body.scrolled header .cms_container_wide { height: 80px; }
	body.scrolled header #hHamburger { top: 27px; }
	body.scrolled #logo_container { top: 12px; width: 58px; height: 59px; }
	body.scrolled header #hService { top: -60px; }
	body.scrolled header #hNavigation { top: 80px; }
	/* End: Scrolled */
}

/***-------------------------------------------*** Smartphone ***-------------------------------------------***/
@media screen and (max-width: 959px) {
	/* Start: Allgemein */
	header #hNavigation { position: fixed; z-index: 2; top: 0; right: -100vW; bottom: 0; display: flex; flex-direction: column; gap: 50px; width: 100vW; background: var(--primary); overflow-y: auto; transition: var(--transition); }
	body.navi header #hNavigation { right: 0; }
	/* End: Allgemein */

	/* Start: Header */
	#cmsgrid > div:first-of-type { padding-top: 172px; }
	header { height: 172px; }
	header .cms_container_wide { height: 172px; }
	header #hHamburger { display: block; top: 83px; transform: none; }
	#hClose { display: block; }
	body #logo_container { top: 17px; width: 124px; height: 132px; }
	header #hService { display: none; }
	/* End: Header */

	/* Start: First-Level */
	header #hNavigation > ul { display: flex; flex-direction: column; gap: 12px; width: 100%; padding: 88px 30px 0 30px; }
	header #hNavigation > ul > li { display: block; }
	header #hNavigation > ul > li.hCustom { display: none; }
	header #hNavigation > ul > li > a { display: flex; align-items: center; gap: 10px; font-weight: 500; font-size: 36px; line-height: 43px; color: var(--white); transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > a:not([href]) { cursor: auto; }
	header #hNavigation > ul > li.current > a,
	header #hNavigation > ul > li:hover > a { transform: translateX(15px); }
	/* End: First-Level */

	/* Start: Toggler */
	header #hNavigation > ul > li > a > div.toggler { width: 29px; height: 17px; }
	header #hNavigation > ul > li > a > div.toggler > svg { display: flex; width: 29px; height: 17px; will-change: transform; }
	header #hNavigation > ul > li.open > a > div.toggler > svg { transform: rotate(180deg); }
	header #hNavigation > ul > li > a > div.toggler > svg > path { stroke: var(--white); }
	/* End: Toggler */

	/* Start: Second-Level */
	header #hNavigation > ul > li > div { display: none; margin: 12px 0 0 0; }
	header #hNavigation > ul > li.open > div { display: block; }
	header .cms_nav_imgContainer { display: none; }
	header #hNavigation > ul > li > div > ul { display: flex; flex-direction: column; gap: 24px; padding: 20px; background: var(--white); }
	header #hNavigation > ul > li > div > ul > li { position: relative; display: block; }
	header #hNavigation > ul > li > div > ul > li:before,
	header #hNavigation > ul > li > div > ul > li:after { content: ""; position: absolute; z-index: 1; left: 0; width: 100%; height: 1px; background: var(--primary); }
	header #hNavigation > ul > li > div > ul > li:before { bottom: -5px; }
	header #hNavigation > ul > li > div > ul > li:after { bottom: -9px; transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > div > ul > li.current:after,
	header #hNavigation > ul > li > div > ul > li:hover:after { transform: translateY(-3px); }
	header #hNavigation > ul > li > div > ul > li > a { display: block; font-size: 24px; line-height: 36px; transition: var(--transition); }
	header #hNavigation > ul > li > div > ul > li.current > a,
	header #hNavigation > ul > li > div > ul > li:hover > a { color: var(--primary); }
	/* End: Second-Level */

	/* Start: Scrolled */
	header,
	header .cms_container_wide,
	header #hHamburger,
	body #logo_container { transition: var(--transition); }

	body.scrolled header { height: 80px; }
	body.scrolled header .cms_container_wide { height: 80px; }
	body.scrolled header #hHamburger { top: 27px; }
	body.scrolled #logo_container { top: 12px; width: 58px; height: 59px; }
	/* End: Scrolled */

	/* Start: Service Mobile */
	header #hServiceMobile { display: block; padding: 0 30px; }
	header #hServiceMobile > ul { display: flex; flex-wrap: wrap; align-items: center; gap: 30px; width: 100%; }
	header #hServiceMobile > ul > li { display: block; }
	header #hServiceMobile > ul > li > a { font-weight: 600; font-size: 15px; line-height: 23px; color: var(--primary); padding: 4px 12px; background: var(--white); border: 2px solid var(--white); box-shadow: 1px 3px 11px 0 rgba(0,0,0,0.25); transition: var(--transition); }
	header #hServiceMobile > ul > li.current > a,
	header #hServiceMobile > ul > li:hover > a { background: var(--secondary); border: 2px solid var(--secondary); }
	/* End: Service Mobile */

	/* Start: Footer Article */
	header #hFooterArt { display: block; padding: 0 30px 30px 30px; margin: auto 0 0 0; }
	header #hFooterArt .small-text { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 15px 45px; }
	header #hFooterArt a { color: var(--white); transition: var(--transition); }
	header #hFooterArt a:hover { color: var(--secondary); }
	/* End: Footer Article */
}