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

/***-------------------------------------------*** Header ***-------------------------------------------***/
header { position: fixed; z-index: 1000; left: 0; top: 0; right: 0; height: 130px; background: var(--white); box-shadow: var(--box-shadow-header); }
header .cms_container_header { --headerPadding: calc(calc(calc(100% - 1630px) / 2) + 30px); position: relative; width: 100%; height: 130px; padding: 0 max(30px,var(--headerPadding)) 0 30px; }

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

/***-------------------------------------------*** Close ***-------------------------------------------***/
header #hClose { cursor: pointer; position: absolute; z-index: 1; top: 30px; right: 30px; display: none; width: 39px; height: 39px; }
header #hClose > span { position: absolute; z-index: 1; top: 50%; left: 50%; transform: translate(-50%,-50%) rotate(45deg); background: var(--white); }
header #hClose > span:first-of-type { width: 100%; height: 2px; }
header #hClose > span:last-of-type { width: 2px; height: 100%; }

/***-------------------------------------------*** Logo ***-------------------------------------------***/
body #logo_container { position: absolute; z-index: 1; top: 52px; left: 50px; width: 150px; height: 150px; }
body #logo_container > a { position: absolute; z-index: 2; inset: 0; background: center left / contain no-repeat url("/pages/img/logo.svg"); }

/***-------------------------------------------*** Hide above Smartphone ***-------------------------------------------***/
@media screen and (min-width: 960px) { #hFooterContent { display: none; } }

/***-------------------------------------------*** Desktop ***-------------------------------------------***/
@media screen and (min-width: 1201px) {
	/* Start: First-Level */
	header #hNavigation > ul { display: flex; justify-content: flex-end; align-items: center; gap: 100px; width: 100%; padding: 54px 0 0 210px; }
	header #hNavigation > ul > li { position: relative; display: flex; align-items: center; gap: 8px; padding: 0 0 54px 0; }
	header #hNavigation > ul > li > a { display: block; font-weight: 700; font-size: 18px; line-height: 22px; letter-spacing: 2.7px; text-transform: uppercase; color: var(--black); transition: var(--transition); }
	header #hNavigation > ul > li > a:not([href]) { cursor: auto; }
	header #hNavigation > ul > li.current > a,
	header #hNavigation > ul > li:hover > a { color: var(--primary); }
	/* End: First-Level */

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

	/* Start: Second-Level */
	header #hNavigation > ul > li > ul { display: none; flex-direction: column; position: absolute; top: 76px; left: 0; min-width: 100%; background: var(--white); border-top: 5px solid var(--primary); box-shadow: var(--box-shadow-header); }
	header #hNavigation > ul > li:hover > ul { display: flex; }
	header #hNavigation > ul > li > ul > li { display: block; border-bottom: 1px solid var(--secondary); }
	header #hNavigation > ul > li > ul > li:last-of-type { border: none; }
	header #hNavigation > ul > li > ul > li > a { display: block; font-weight: 600; font-size: 20px; line-height: 24px; color: var(--black); padding: 15px 25px 20px 25px; transition: var(--transition); }
	header #hNavigation > ul > li > ul > li.current > a,
	header #hNavigation > ul > li > ul > li:hover > a { color: var(--primary); }
	header #hNavigation > ul > li > ul > li > a > div { display: flex; align-items: center; gap: 17px; transition: var(--transition); will-change: transform; }
	header #hNavigation > ul > li > ul > li.current > a > div,
	header #hNavigation > ul > li > ul > li:hover > a > div { transform: translateX(13px); }
	header #hNavigation > ul > li > ul > li > a > div > svg { display: flex; flex-shrink: 0; width: 7px; height: 14px; }
	header #hNavigation > ul > li > ul > li > a > div > svg > path { stroke: var(--black); transition: var(--transition); }
	header #hNavigation > ul > li > ul > li.current > a > div > svg > path,
	header #hNavigation > ul > li > ul > li:hover > a > div > svg > path { stroke: var(--primary); }
	header #hNavigation > ul > li > ul > li > a > div > span { flex: 1; }
	/* End: Second-Level */

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

	body.scrolled header { height: 100px; }
	body.scrolled header .cms_container_header { height: 100px; }
	body.scrolled #logo_container { top: 16px; left: 50px; width: 68px; height: 68px; }
	body.scrolled header #hNavigation > ul { gap: 70px; padding: 40px 0 0 128px; }
	body.scrolled header #hNavigation > ul > li { padding: 0 0 38px 0; }
	body.scrolled header #hNavigation > ul > li > ul { top: 60px; }
	/* End: Scrolled */
}

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

	/* Start: Hamburger */
	header #hHamburger { top: 50%; transform: translateY(-50%); display: block; }
	/* End: Hamburger */

	/* Start: First-Level */
	header #hNavigation > ul { display: flex; flex-direction: column; width: 100%; padding: 15px 30px; box-shadow: var(--box-shadow-header); }
	header #hNavigation > ul > li { position: relative; display: block; border-bottom: 1px solid var(--white); }
	header #hNavigation > ul > li:last-of-type { border: none; }
	header #hNavigation > ul > li > a { display: block; font-weight: 600; font-size: 24px; line-height: 29px; color: var(--white); padding: 15px 29px 15px 0; transition: var(--transition); }
	header #hNavigation > ul > li.current > a,
	header #hNavigation > ul > li:hover > a { opacity: 0.5; }
	/* End: First-Level */

	/* Start: Toggler */
	header #hNavigation > ul > li > div.toggler { cursor: pointer; position: absolute; z-index: 1; top: 25px; right: 0; width: 14px; height: 9px; }
	header #hNavigation > ul > li > div.toggler > svg { display: flex; width: 14px; height: 9px; will-change: transform; }
	header #hNavigation > ul > li.open > div.toggler > svg { transform: rotate(180deg); }
	header #hNavigation > ul > li > div.toggler > svg > path { stroke: var(--white); transition: var(--transition); }
	header #hNavigation > ul > li.open > div.toggler > svg > path,
	header #hNavigation > ul > li:hover > div.toggler > svg > path { opacity: 0.5; }
	/* End: Toggler */

	/* Start: Second-Level */
	header #hNavigation > ul > li > ul { position: relative; display: none; flex-direction: column; gap: 20px; padding: 20px 0; }
	header #hNavigation > ul > li.open > ul { display: flex; }
	header #hNavigation > ul > li > ul:before { content: ""; position: absolute; z-index: 1; top: 0; left: 0; width: 100%; height: 1px; background: var(--white); }
	header #hNavigation > ul > li > ul > li { display: block; }
	header #hNavigation > ul > li > ul > li > a { display: block; font-weight: 600; font-size: 18px; line-height: 22px; color: var(--white); transition: var(--transition); }
	header #hNavigation > ul > li > ul > li.current > a,
	header #hNavigation > ul > li > ul > li:hover > a { opacity: 0.5; }
	header #hNavigation > ul > li > ul > li > a > div { display: block; }
	header #hNavigation > ul > li > ul > li > a > div > svg { display: none; }
	header #hNavigation > ul > li > ul > li > a > div > span { display: block; }
	/* End: Second-Level */

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

	body.scrolled header { height: 100px; }
	body.scrolled header .cms_container_header { height: 100px; }
	body.scrolled #logo_container { top: 16px; left: 50px; width: 68px; height: 68px; }
	body.scrolled header #hNavigation { top: 100px; }
	/* End: Scrolled */
}

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

	/* Start: Header */
	#cmsgrid > div:first-of-type { padding-top: 80px; }
	header { height: 80px; }
	header .cms_container_header { height: 80px; }
	header #hHamburger { top: 50%; transform: translateY(-50%); display: block; }
	header #hClose { display: block; }
	body #logo_container { top: 15px; left: 30px; width: 50px; height: 50px; }
	/* End: Header */

	/* Start: First-Level */
	header #hNavigation > ul { display: flex; flex-direction: column; flex: 1; width: 100%; padding: 141px 30px 15px 30px; }
	header #hNavigation > ul > li { position: relative; display: block; border-bottom: 1px solid var(--white); }
	header #hNavigation > ul > li:last-of-type { border: none; }
	header #hNavigation > ul > li > a { display: block; font-weight: 600; font-size: 24px; line-height: 29px; color: var(--white); padding: 15px 29px 15px 0; transition: var(--transition); }
	header #hNavigation > ul > li.current > a,
	header #hNavigation > ul > li:hover > a { opacity: 0.5; }
	/* End: First-Level */

	/* Start: Toggler */
	header #hNavigation > ul > li > div.toggler { cursor: pointer; position: absolute; z-index: 1; top: 25px; right: 0; width: 14px; height: 9px; }
	header #hNavigation > ul > li > div.toggler > svg { display: flex; width: 14px; height: 9px; will-change: transform; }
	header #hNavigation > ul > li.open > div.toggler > svg { transform: rotate(180deg); }
	header #hNavigation > ul > li > div.toggler > svg > path { stroke: var(--white); transition: var(--transition); }
	header #hNavigation > ul > li.open > div.toggler > svg > path,
	header #hNavigation > ul > li:hover > div.toggler > svg > path { opacity: 0.5; }
	/* End: Toggler */

	/* Start: Second-Level */
	header #hNavigation > ul > li > ul { position: relative; display: none; flex-direction: column; gap: 20px; padding: 20px 0; }
	header #hNavigation > ul > li.open > ul { display: flex; }
	header #hNavigation > ul > li > ul:before { content: ""; position: absolute; z-index: 1; top: 0; left: 0; width: 100%; height: 1px; background: var(--white); }
	header #hNavigation > ul > li > ul > li { display: block; }
	header #hNavigation > ul > li > ul > li > a { display: block; font-weight: 600; font-size: 18px; line-height: 22px; color: var(--white); transition: var(--transition); }
	header #hNavigation > ul > li > ul > li.current > a,
	header #hNavigation > ul > li > ul > li:hover > a { opacity: 0.5; }
	header #hNavigation > ul > li > ul > li > a > div { display: block; }
	header #hNavigation > ul > li > ul > li > a > div > svg { display: none; }
	header #hNavigation > ul > li > ul > li > a > div > span { display: block; }
	/* End: Second-Level */

	/* Start: Footer Content */
	#hFooterContent { display: flex; justify-content: flex-end; width: 100%; padding: 15px 30px 30px 30px; }
	#hFooterContent .small-text { display: flex; flex-wrap: wrap; align-items: center; gap: 10px 38px; color: var(--white); }
	#hFooterContent a:hover { text-decoration: underline; }
	/* End: Footer Content */
}