
:root
{
	--text-color: #020202;
	--fancybox-content-color:var(--text-color);
	--theme-color: #3A4B5B;
	--hover-color: lightgreen;
	--odd-color: lightgrey;
	--swiper-navigation-size: 3em;
	--swiper-theme-color: white;
	--header-height: 0px;
	--content-width-small:944px;
	--content-width: 1600px;
	--content-padding-vertical:clamp(2rem, 3vw, 3rem);
	--content-padding-horizontal: clamp(1.2em, 3vw, 3rem);
}

body
{
	color:var(--text-color);
	font-family: "sofia-pro",sans-serif;
	margin:0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	min-height: 100dvh;
	background: #EBE8E8;
	font-weight: 300;
}


.logo
{
	display: block;
	position:absolute;
	z-index:100;
	width:clamp(5rem,22vw,22rem);
	position: absolute;
	top:0;
	left:var(--content-padding-horizontal);
}

.logo img
{
	width: 100%;
}

.content-box 
{
	background-color: var(--box-bg-color);
}

.content-box .group  .element
{
	padding-inline: 0px;
}

h1
{
	font-size: clamp(1.87em,4.5vw,4.5em);
	line-height: 1.1em;
	text-align: center;
	margin-bottom: .4em;
	font-weight: 700;
}

.fancybox__content h1
{
	font-size: clamp( 1.65em,4.5vw,3.37em);
}

.fancybox__content h2
{
	font-size: clamp( 1.4em,2.3vw,1.75em);
}

h2
{
	font-size: clamp( 1.65em,4.5vw,3.37em);
	font-weight: 700;
	line-height: 1.1em;
	text-align: center;

}

h4
{
	font-size: clamp( 1.1em,2.3vw,1.75em);
	line-height: 1.28em;
}

h3
{
	font-size: clamp( 1em,2.3vw,1.75em);
	line-height: 1.28em;

	letter-spacing: 0.012em;
	font-weight: 400;
}

h4{

	font-weight: 400;
	text-decoration: underline;
	text-decoration-thickness:.11em;
	text-underline-offset: .2em;
	letter-spacing: .02em;
	font-size: clamp( 1em,2vw,1.25em);
}

a
{
	color:inherit;
	text-decoration: none;
}

.selectables a
{
	text-decoration: underline;
}

.links .items
{
	display:flex;
	gap: .5em;
	flex-wrap:wrap;
}


.linklist .wrapper
{
	display: grid;
	grid-template-columns: 1fr 1fr;
	justify-content: center;
	gap: 3em;
	flex-wrap: wrap;
	margin: 3em 0;
	
}

.linklist .wrapper a
{
	display: block;
	background-size: 100%;
}

.linklist .wrapper img
{
	width: 100%;
	display: block;
}

.linklist .wrapper a:hover img:first-child,
.linklist .wrapper a img:last-child
{
	display: none;
}

.linklist .wrapper a:hover img:last-child
{
	display: block
}



strong
{
	font-weight: bold;
}

.owner
{
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 3.5em;
}

.owner img
{
	height: 90px;
	margin: 1em 0;
}

main
{
	flex-grow:1;
}

main .group
{
	--content-padding-vertical: clamp(2.8em, 8.8vw, 6.6em);
	--content-padding-horizontal: clamp(.5em, 3vw, 6.6em);;
}

main .group > .wrapper
{
	max-width:var(--content-width);
	margin:auto;
}

.group > .wrapper
{
	padding:var(--content-padding-vertical) var(--content-padding-horizontal);
}

.group > .wrapper > :first-child,
.group > .wrapper > .title:first-child > .wrapper > h1,
.group > .wrapper > .subtitle:first-child > .wrapper > h2
{
	margin-top:0;
}

.group > .wrapper > :last-child,
.group > .wrapper > .title:last-child > .wrapper > h1,
.group > .wrapper > .subtitle:last-child > .wrapper > h2
{
	margin-bottom:0;
}

.group .element
{
	margin:calc(var(--content-padding-vertical) * .5)  0;
}

.title h1,.subtitle h2
{
	margin-bottom: 0;
	margin-top: calc(var(--content-padding-vertical) * .5) ;
}

main section
{
	margin-bottom: calc(var(--content-padding-vertical) * 1.2) ;
}

main .title + .element
{
	margin-top: calc(0px - calc(var(--content-padding-vertical) * .25)) ;
}

main .subtitle + .text
{

	margin-top: calc(0px - calc(var(--content-padding-vertical) * .35)) ;
}

.timeline .subtitle h2
{
	margin-top: 0px;
}

.text + .timeline
{
	margin-top: var(--content-padding-vertical);
}

.timeline
{
	background:#FFFFFF;
}

.timeline .container
{
	position: relative;
}



.timeline ul
{
	list-style: none;
	padding: 0;
}

.timeline .typo
{
	margin:0px;
	color:#6e6e6e;
	font-weight: normal;
	margin: .2em 0 .3em 0;
}

.timeline ul > li
{
	position: relative;

	display: flex;
	flex-direction: column;
}

.timeline .item
{
	padding-left:3%;
	padding-right:3%;
	
	margin-bottom: calc(var(--content-padding-vertical) / 100 * 25) ;
}

.timeline .border
{
	width: 100%;
	margin-bottom: calc(var(--content-padding-vertical) / 100 * 30) ;
	
}

.timeline .border img
{
	width: 100%;

}

.timeline ul > li:last-child .border
{
	display: none;
}

.timeline h3
{
	margin:0px;
}




.timeline ul > li:last-child
{
	border: 0px;
    padding-bottom: 0;
}

.timeline .wrapper
{
	margin-top: calc(var(--content-padding-vertical) * .4);
}

.timeline.element
{
	overflow: auto;
	padding-bottom: 5em;
	padding: 0 calc(var(--content-padding-horizontal) * .7);
}

.content-box.element 
{
	overflow: auto;
	padding: 0 calc(var(--content-padding-horizontal) * .7);
	margin-top:var(--content-padding-vertical);
}

.content-box.element > .wrapper
{
	margin-top: calc(var(--content-padding-vertical) * .5);
	margin-bottom: calc(var(--content-padding-vertical) * .6);
}

.content-box .group > .wrapper
{
	padding-top: 0;
	padding-bottom: 0;
}
 
.timeline a.homerun,.text .mailto
{
	text-decoration: none;
	display: inline-block;
	position: relative;
	
}

.text .mailto
{
	color:#6e6e6e;
}

.timeline a.homerun:after,.text .mailto::after
{
	display: inline-block;
	content:"";
	width: .5em;
	height: 1em;
	background-image: url('../images/pfeil_grau.svg');
	background-size: contain;
	background-position-y: 0.23em;
	background-repeat: no-repeat;
}


.timeline a.homerun:hover:after,.text .mailto:hover::after
{
	background-image: url('../images/pfeil_orange.svg');
}

.timeline a.homerun:before,.text .mailto::before
{
	content:"";
	position:absolute;
	left: 0px;
	right: 0px;
	bottom: .05em;
	height: 1px;
	border-bottom: 2px solid #6e6e6e;
}

.timeline a.homerun:hover:before,.text .mailto:hover::before
{
	border-color: #ff6502
}


.toggle-button::after
{
	content:"";
	position:absolute;
	left:0;
	top:0;
	width:calc(1em - 4px);
	height:calc(1em - 4px);
	margin:2px;
	background:white;
	border-radius:.4em;
}


.downloads .items
{
	display: flex;
	grid-template-columns:repeat(auto-fit,minmax(auto,410px));
	justify-content: center;
	gap: clamp(2em,6vw,6em);
	flex-wrap: wrap;	
}


.fancybox__content .downloads .items
{
	gap: 2em;
}


.downloads .items .item
{
	width:100%;
	max-width: clamp(150px,20vw,243px);
	display: flex;
	gap: clamp(.5em,1vw,1em);	
	text-align: center;
	justify-content: start;
	justify-items: center;
	flex-direction: column;
	transition: all .2s;
}

.downloads a:hover
{	
	color:  #ff6502;
}

.downloads h4
{
	margin:0px;
	font-weight: bold;
}

.downloads .items img
{
	display: block;
	width: 100%;
	border:1px solid #707070;
}
main .text .typo
{
	text-align: center;
}

main .typo,
.timeline .wrapper
{
	max-width: var(--content-width-small);
	margin-left:auto;
	margin-right: auto;
}

/* elements */
.typo,
.consent-settings .consent-links a,
.consent-message
{
	font-size: clamp( 1em,2.3vw,1.5em);
	line-height: 1.4em;
	letter-spacing: 0.02em;
}

.typo a
{
	text-decoration: underline;
}

.consent-message
{
	font-size: clamp( .8em,2.3vw,1.2em);
}


.images img
{
	display:block;
	width:100%;
}

.intro.images img
{
	object-fit: cover;
	object-position: top center;
	height: 100vh;
}

input,
select
{
	margin:0;
}

input[type=text],
input[type=email],
input[type=tel],
textarea,
button,
select
{
	box-sizing:border-box;
	font:inherit;
	color:inherit;
}

input[type=text],
input[type=email],
input[type=tel],
textarea,
select
{
	display:block;
	width:100%;
	border:1px solid var(--theme-color);
	padding:.5em;
	border-radius: 0;
}

.button,
button
{
	background:var(--theme-color);
	border:none;
	color:white;
	cursor:pointer;
	padding:.5em 1em;
	white-space: nowrap;
	display: inline-block;
	font-weight:normal;
}

.button.primary,
button.primary
{
	font-weight:bold;
}

.button.secondary,
button.secondary
{
	color:var(--theme-color);
	border:1px solid var(--theme-color);
	background:none;
}

select
{
	appearance:none;
	background:none;
}

.contact .form-group
{
	margin-bottom:1.2em;
}

.contact .form-split-1-3
{
	display:grid;
	gap:1em;
	grid-template-columns:1fr 3fr;
}

.contact .form-label
{
	display: block;
	padding-bottom: 0.1em;
}

.contact .form-warning
{
	color:red;
	margin-bottom: .5em;
	margin-top:.25em;
	display:block;
	width:100%;
}

.contact .form-invalid
{
	border-color:red;
}

.contact .form-interest-selection
{
	display:grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 1em;
}

.contact .form-interest-selection [data-interest-type=radio]
{
	grid-column: 1 / span 2;
}

.contact .selectables
{
	display:flex;
	flex-wrap:wrap;
	gap: 0 1em;
}

.contact .selectables > label
{
	display:flex;
	align-items: center;
	gap:.5em;
}

.contact input[name=Email_Address]{display:none;}

.contact .items
{
	display:grid;
	grid-template-columns:2fr 1fr;
	gap:4em;
	margin:0;
}

.contact .ajax-loading,
.contact .ajax-error,
.contact .mail.success,
.contact .mail.error
{
	
	background: green;
	padding:3em 1em;
	text-align:center;
	color:white;
}

.contact .ajax-error,
.contact .mail.error
{
	background:red;
}

.contact .ajax-form .ajax-loading,
.contact .ajax-form .ajax-result,
.contact .ajax-form .ajax-error,
.contact .ajax-form.ajax-state-loading form,
.contact .ajax-form.ajax-state-success form
{
	display:none;
}

.contact .ajax-form.ajax-state-loading .ajax-loading,
.contact .ajax-form.ajax-state-success .ajax-result,
.contact .ajax-form.ajax-state-error .ajax-error
{
	display:block;
}


.contact .info 
{
	display: flex;
	flex-direction: column;
	gap: 1em;
}

.responsive
{
	position: relative;
	overflow: hidden;
	border: 0px;
	background: #EBE8E8;
	margin-bottom: 3.5em;
	aspect-ratio: 1.28;
	max-height: 95dvmin;
	margin: 0 auto;
}

.fancybox__content .group .flipbook.element
{
	margin-top: -1em;
}


.responsive iframe,
.responsive > .consent-content
{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border:0;
}

.video video
{
	display:block;
	width:100%;
	object-fit: cover;
	max-height: 100dvh;
	min-height: 35dvh;
	object-position: center;
}


.text-left
{
	text-align: left;
}

.text-center
{
	text-align: center;
}

.text-right
{
	text-align: right;
}

.fancybox__container
{
	--fancybox-bg: rgba(24, 24, 27, 0.92);
}


.fancybox__content
{
	padding:0;
	width: 60em;
	max-width:100%;
}

.big .fancybox__content
{
	width: 87em;
}


.fancybox__slide.has-image .fancybox__content
{
	width: 100%;
}


.icon::after,
.icon::before
{
	text-align: center;
	font: var(--fa-font-regular);
}

.consent-cover
{
	position:absolute;
	width:100%;
	height:100%;
	background:rgba(0,0,0,.2);
	display:flex;
	justify-content: center;
	align-items:center;
}

.consent-cover .consent-message
{
	text-align:center;
}

.consent-cover-info
{
	display:flex;
	flex-direction:column;
	align-items: center;
	gap:.5em;
	padding:2em;
}

.consent-dialog
{
	position:sticky;
	bottom:0;
	background:white;
	z-index:100;
	box-shadow: 3px 3px 10px 0px rgb(50 50 50);
}

.consent-dialog .wrapper
{
	display:flex;
	flex-direction:column;
	gap:.5em;
	margin:auto;
	max-width:var(--content-width);
	padding: calc(var(--content-padding-vertical) / 2) var(--content-padding-horizontal);
}

.toggle-button
{
	font-size:1.4em;
	position:relative;
	width:2em;
	height:1em;
	background:gray;
	box-sizing:border-box;
	border-radius:.5em;
	transition:background .5s;
	cursor:pointer;
}

.toggle-button::after
{
	content:"";
	position:absolute;
	left:0;
	top:0;
	width:calc(1em - 4px);
	height:calc(1em - 4px);
	margin:2px;
	background:white;
	border-radius:.4em;
}

.toggle-button.active
{
	background:green;
}

.toggle-button.active::after
{
	right:0;
	left:auto;
}

a[consent-settings]
{
	cursor: pointer;
}

.consent-settings .tab
{
	border-top:1px solid black;
}

.consent-settings .consent-preferences
{
	border-bottom: 1px solid black;
}

.consent-settings .tab .header
{
	display:flex;
	justify-content: space-between;
	align-items:center;
	gap:.5em;
}

.consent-links
{
	gap:.5em;
	display:inline-flex;
	text-decoration: underline;
	flex-wrap: wrap;
}

.consent-settings .tab [data-toggle]
{
	cursor:pointer;
}

.consent-settings .tab [data-toggle] h2
{
	display: flex;
	gap:.5em;
	align-items: center;
}

.consent-settings .tab [data-toggle] h2:before
{
	display: grid;
	width:1em;
	height:1em;
	place-items:center;
	font: var(--fa-font-regular);
	content:"\f054"
}

.consent-settings .tab [data-toggle].active h2:before
{
	content:"\f078";
}

.consent-settings .tab .body
{
	padding-bottom: 1em;
}

.tab .body.toggled
{
	display:block;
}

footer
{
	background: #3A4B5B;
	color:white;
	font-weight: normal;
	line-height: 1.3em;
	letter-spacing: .05em;
}

footer > .wrapper
{
	margin:auto;
	max-width:var(--content-width-small);
	padding:var(--content-padding-vertical) var(--content-padding-horizontal);
	font-size:clamp(.85em,1.5vw,1em);
}

footer nav
{
	display:flex;
	gap: 1em;
	margin:2em 0 1em 0;
	flex-wrap: wrap;
}

footer nav a
{
	text-transform: uppercase;
	font-weight: 700;
}

.hidden
{
	display:none;
}

@media screen and (max-width: 1060px) 
{

	
	.intro.images img
	{
		object-fit: contain;
		height: auto;
	}
	
	.typo,
	.consent-settings .consent-links a,
	.consent-message
	{
		line-height: 1.3em;
	}
	.timeline .item{
		padding-left: 0px;
		padding-right: 0px;
	}

}

@media(max-width:520px)
{
	.flipbook.element{
		margin-left:calc(0px - var(--content-padding-horizontal));
		margin-right:calc(0px - var(--content-padding-horizontal));
	}
	
	.responsive
	{
		aspect-ratio: 1.05;
	}
	
	.fancybox__content .group .flipbook.element
	{
		margin-top: -.5em;
	}

	
	.group .element {
		padding-left: 1em;
		padding-right: 1em;
	}
	
	.group .element.flipbook
	{
		padding-left: 0em;
		padding-right: 0em;
	}
	
	.group .timeline.element
	{
		padding-left: 0.7em;
		padding-right: 0.7em;
	}
	
	.linklist .wrapper
	{
		grid-template-columns: 1fr;
	}
	
	footer nav
	{
		flex-direction: column;
		gap: .4em;
		margin-bottom: 1.4em;
	}
	
	

	
}