/*
 Theme Name:   Dr. Uphoff
 Description:  Dr. Uphoff WordPress Theme (2025)
 Author:	   Splendid
 Author URI:   https://splendid.claims
 Version:      1.0.0
 Text Domain:  uphoff

*/
/**	____________________________________________________________
 *
 *	INHALTE
 *
 *
 *	01 — BASICS
 *	02 — TYPO
 *	03 — GRID
 *	04 — HEADER, FOOTER & MENÜS
 *	05 — UX ELEMENTE
 *	06 — SEITEN
 *	07 — BLÖCKE
 *	08 — RESPONSIVE
 *
 *	____________________________________________________________
*/


/* SWIPER */


/* For Parallax */

.swiper-slide {
	overflow: hidden;
}

/* SWIPER NAV */

.swiper-nav {
	display: flex;
}
.swiper-nav-element {
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--3em);
	height: var(--3em);
	border: 1px solid var(--cl-weiss);
	border-radius: 50%;
	cursor: pointer;
	pointer-events: all;
}

/* Style 00 (Std.) */

.swiper-nav.st-0 .swiper-nav-element:not(:last-child) {
	margin-right: var(--0-5em);
}

/* Style 1 (Spaced) */

.swiper-nav.st-1 {
	position: absolute;
	bottom: 50%;
	left: var(--1em);
	transform: tanslateY(50%);
	z-index: 4;
	display: flex;
	justify-content: space-between;
	width: calc(100% - var(--2em));
	pointer-events: none;
}

.swiper-prev,
.swiper-next {
	opacity: 1;
	transition: opacity 0.4s;
}
.swiper.no-loop.reached-start .swiper-prev,
.swiper.no-loop.reached-end .swiper-next {
	opacity: 0.25;
	cursor: default;
}

/* Style 02 (Cornered) */

.swiper-nav.st-02 {
  bottom: var(--2em);
  right: var(--2em);
  overflow: hidden;
  border-radius: var(--3em);
}


/* Header */

.akk-header {
	margin-bottom: var(--1em);
}

/* Akk (Std.) */

.akk-1-wrapper .row + .row {
	margin-top: var(--3em);
}

/* Style 01 - Std. */

.akk.st-01 {
	border-top: 1px solid var(--cl-schwarz);
}
.akk.st-01:last-child {
	border-bottom: 1px solid var(--cl-schwarz);
}
.akk.st-01 .akk-trigger {
	display: flex;
	justify-content: space-between;
	padding: var(--1em) 0px var(--0-5em) 0px;
	overflow: hidden;
}
.akk.st-01 .akk-trigger .col {
	display: flex;
	justify-content: space-between;
}
.akk.st-01 .akk-trigger-text {
	padding-right: var(--1em);
}
.akk.st-01 .akk-content {
	padding: var(--1-5em) 0px;
}
.akk.st-01 .akk-hint {
	opacity: 0;
	transform: translateY(50%);
	transition: transform 0.2s, opacity 0.2s;
}
.akk.st-01 .akk-trigger:hover .akk-hint {
	opacity: 1;
	transform: translateY(0%);
}
.akk.st-01 .akk-trigger.active .akk-hint {
	transform: rotate(180deg);
}

/* Abschnitte */

.akk-abschnitt {
	display: flex;
	border-top: 2px solid var(--cl-weiss);
}
.akk-abschnitt .akk.st-01:first-child {
	border-top: none;
}
.akk-abschnitt-titel,
.akk-abschnitt-content {
	flex: 0 0 50%;
}
.akk-abschnitt-titel {
	padding: var(--0-5em) 0px;
}

h1 + h3 {
	margin-top: 3em;
}
p + h3 {
	margin-top: 2em;
}


.logo {
	display: flex;
	align-items: center;
}
.logo img {
	width: 30px;
	height: 30px;
}
.logo span {
	margin-left: var(--0-5em);
	font-weight: 300;
}

p + h2 {
	margin-top: 2em;
}



/**
 *	01 — BASICS
 *	Basiselemente
 *	____________________________________________________________
*/

*, :before, :after {
    box-sizing: border-box;
}
html {
    font-family: sans-serif;
    line-height: 1;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
	scroll-snap-type: y mandatory;
	scroll-behavior: smooth;
}
body {
    position: relative;
    margin: 0;
    line-height: 1;
    -webkit-text-size-adjust: 100%;
	overflow-x: hidden;
	color: var(--cl-schwarz);
	background-color: var(--cl-weiss);
}
a {
    color: inherit;
    text-decoration: none;
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
}
a, a:active, a:hover {
    text-decoration: none;
    outline: 0;
    outline-width: 0;
}
:focus {
    outline: none;
}
svg {
    transform: translate(0,0);
    line-height: 1em;
}
img,svg,video {
    display: block;
    border: 0 none;
    max-width: 100%;
	height: auto;
}
/* Safari Fix */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
	_::-webkit-full-page-media, _:future, :root, img {
		align-self: center;
	}
}
::-moz-selection {
    color: var(--cl-weiss);
    background: var(--cl-schwarz);
}
::selection {
    color: var(--cl-weiss);
    background: var(--cl-schwarz);
}



/**
 *	02 — TYPO, COLORS & ICONS
 *	Schrift- und Farbsettings
 *	____________________________________________________________
*/


/*--- FARBEN ---*/

/* CD Farben */

:root {
	--cl-schwarz: rgb(0,0,0);
	--cl-weiss: rgb(255,255,255);
	--cl-beige: rgb(223,228,228);
	--cl-beige-2: rgb(210,205,200);
	--cl-grau: rgb(233,236,235);
}

/* Box Farben */

.opt-bg-cl-1 {
	background-color: var(--cl-weiss);
}
.opt-bg-cl-2 {
	background-color: var(--cl-beige);
}
.opt-bg-cl-3 {
	background-color: var(--cl-grau);
}

/* Text Farben */

.f-cl-schwarz {
	color: var(--cl-schwarz);
}
.f-cl-weiss {
	color: var(--cl-weiss);
}
.f-cl-beige {
	color: var(--cl-beige);
}


/*  SVG */

/* SVG Farben */

.fill {
	fill: var(--cl-weiss);
}

.fill.opt-color-weiss {
	fill: var(--cl-weiss);
}
.fill.opt-color-schwarz {
	fill: var(--cl-schwarz);
}

.stroke.opt-color-weiss {
	stroke: var(--cl-weiss);
}
.stroke.opt-color-schwarz {
	stroke: var(--cl-schwarz);
}

/* SVG Formen */

.stroke {
	fill: none;
	stroke-miterlimit: 0;
	stroke-width: 1px;
}
.stroke.thick {
	stroke-width: 2px;
}


/* SCHRIFT */

@font-face {
  font-family: 'neue-montreal';
  font-style: normal;
  font-weight: 350;
  src: url('fonts/pp-neue-montreal-book.woff2') format('woff2');
}
@font-face {
  font-family: 'neue-montreal';
  font-style: normal;
  font-weight: 500;
  src: url('fonts/pp-neue-montreal-medium.woff2') format('woff2');
}
@font-face {
  font-family: 'neue-montreal';
  font-style: normal;
  font-weight: 100 1000;
  src: url('fonts/pp-neue-montreal-var.woff2') format('woff2');
}

body {
    font-family: 'neue-montreal';
	font-weight: 375;
	line-height: 1.5em;
}

/* Size Settings */

:root {

	--body-l:	16;	/* px */
	--body-s:	12;

	--h1-l:		3.75;	/* em */
	--h1-s:		2;

	--h1:		3.75;
	--h2:		2.5;
	--h3:		1.5;
	--h4:		1.25;
	--h5:		1.125;

	--rate:		calc( (var(--h1-l) - 1) / (var(--h1-s) - 1) );	/* Vorgegeben durch H1-Verhältnis: Desktop (H1l) 6em, Mobile (H1s) 3em -> Bei H1l wird der Bodytext um 5em vergrößert, Mobile um 2em -> Daraus Verhältnis 5/2 */

}

:root {
	--v-bd: calc(1px * var(--body-s) + (var(--body-l) - var(--body-s)) * ((100vw - 320px) / 1120));
	--v-h1: calc(((1 + ((var(--h1) - 1) / var(--rate))) * var(--body-s) * 1px) + (var(--h1) * var(--body-l) - ((1 + ((var(--h1) - 1) / var(--rate))) * var(--body-s))) * ((100vw - 320px) / 1120));
	--v-h2: calc(((1 + ((var(--h2) - 1) / var(--rate))) * var(--body-s) * 1px) + (var(--h2) * var(--body-l) - ((1 + ((var(--h2) - 1) / var(--rate))) * var(--body-s))) * ((100vw - 320px) / 1120));
	--v-h3: calc(((1 + ((var(--h3) - 1) / var(--rate))) * var(--body-s) * 1px) + (var(--h3) * var(--body-l) - ((1 + ((var(--h3) - 1) / var(--rate))) * var(--body-s))) * ((100vw - 320px) / 1120));
	--v-h4: calc(((1 + ((var(--h4) - 1) / var(--rate))) * var(--body-s) * 1px) + (var(--h4) * var(--body-l) - ((1 + ((var(--h4) - 1) / var(--rate))) * var(--body-s))) * ((100vw - 320px) / 1120));
	--v-h5: calc(((1 + ((var(--h5) - 1) / var(--rate))) * var(--body-s) * 1px) + (var(--h5) * var(--body-l) - ((1 + ((var(--h5) - 1) / var(--rate))) * var(--body-s))) * ((100vw - 320px) / 1120));
}
body {
	font-size: var(--v-bd);
}

@media screen and (min-width: 1440px) {

:root {
	--v-bd: calc(var(--body-l) * 1px);
	--v-h1: calc(var(--h1) * 1em);
	--v-h2: calc(var(--h2) * 1em);
	--v-h3: calc(var(--h3) * 1em);
	--v-h4: calc(var(--h4) * 1em);
	--v-h5: calc(var(--h5) * 1em);
}

}

h1, .f-h1 { font-size: var(--v-h1); }
h2, .f-h2 { font-size: var(--v-h2); }
h3, .f-h3 { font-size: var(--v-h3); }
h4, .f-h4 { font-size: var(--v-h4); }
h5, .f-h5 { font-size: var(--v-h5); }

/* Heading Settings */

h1, h2, h3, h4, h5,
.f-h0, .f-h1, .f-h2, .f-h3, .f-h4, .f-h5 {
	margin: 0.5em 0em 1.5em 0em;
	line-height: 1em;
}
h1:first-child, h2:first-child, h3:first-child, h4:first-child,
.f-h0:first-child, .f-h1:first-child, .f-h2:first-child, .f-h3:first-child, .f-h4:first-child {
    margin-top: 0;
}
h1:last-child, h2:last-child, h3:last-child, h4:last-child,
.f-h0:first-child, .f-h1:last-child, .f-h2:last-child, .f-h3:last-child, .f-h4:last-child {
    margin-bottom: 0;
}

/* Individual Settings */

h1, .f-h1 {
	font-weight: 375;
	line-height: 1.067em;
	transform: translateX(-0.05em);
}
h1 span, .f-h1 span {
	font-size: 0.5em;
	line-height: 1em;
	font-weight: 250;
}
h2, .f-h2,
h3, .f-h3,
h4, .f-h4 {
	font-weight: 520;
	line-height: 1.2em;
}

/* Paragraphs */

p {
	max-width: 720px;
    margin: 0 0 1.5em;
}
.ul {
	text-decoration: underline;
}
.kicker {
	margin-bottom: 1em;
}

/* Styles */

.f-s1 {
	font-size: 1em;
	line-height: 1.5em;
}
.f-s2 {
	font-size: 1em;
	line-height: 1.5em;
	text-transform: uppercase;
}
.f-s3 {
	font-size: 0.875em;
	line-height: 1.5em;
}
p.small-gap,
.smapp-gap p {
	margin-bottom: 0.5em;
}

.f-link-std {
	font-weight: 500;
	text-decoration: underline;
}

.hl.opt-hl-centered {
	display: block;
	text-align: center;
}
.hl.opt-hl-half span,
.hl.opt-hl-full span {
	display: inline-flex;
	width: 50%;
}
.hl.opt-hl-half h3,
.hl.opt-hl-full h3 {
	display: inline;
}
.hl.opt-hl-half {
	width: 50%;
}
.hl h2,
.hl h3 {
	margin: 0;
}
.hl.opt-hl-full h2:not(span + h2),
.hl.opt-hl-full h3:not(span + h3) {
	display: block;
	text-indent: 50%;
}
.hl.opt-hl-spaced {
	display: flex;
	align-items: first baseline;
}
.hl.opt-hl-spaced span {
	width: calc(50% - calc(var(--6em) * 2));
}
.hl.opt-hl-spaced h3 {
	width: calc(50% + calc(var(--6em) * 2));
	text-indent: calc(var(--6em) * 2);
}

/* Sonstiges */

p:last-child,
ul:last-child,
li:last-child,
ol:last-child {
    margin-bottom: 0;
}

b, strong {
    font-weight: 500;
}
ul, ol {
    margin: 0 0 2.1em;
    padding: 0;
    list-style: none;
}
ul:not(.list-clear):not(.list):not(.menu) li {
    position: relative;
    padding: 0px 0px 10px 15px;
}
ul:not(.list-clear):not(.list):not(.menu) li:after {
	content: '•';
    position: absolute;
	left: 0px;
	top: 0px;
	font-weight: 390;
}

h1+h1,
h2+h2 {
	margin-top: calc(0.75em * -1);
}


/* BUTTONS & LINKS */

/*-- Browser Fix --*/

a, .button:focus, button:focus, input[type="button"]:focus, input[type="reset"]:focus, input[type="submit"]:focus {
    outline: none;
}
button {
	font-family: "raleway";
	font-size: inherit;
	font-weight: 400;
	background-color: transparent;
	border: none;
	cursor: pointer;
}
button::-moz-focus-inner {
    border: 0;
    outline: none;
}

/*-- Std. --*/

.btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 400;
	font-size: 1em;
	line-height: 1.125em;
	text-transform: uppercase;
	transition: color 0.2s, background-color 0.2s;
	cursor: pointer;
	overflow: hidden;
}
.btn.pointer {
	cursor: pointer;
}
.btn:not(:first-child):not(.btn-wrapper .btn):not(.btn-wrapper-box .btn) {
	margin-top: var(--3em);
}

/*-- Colors --*/

.btn.btn-fill.btn-cl-weiss {
	background-color: var(--cl-weiss);
	color: var(--cl-schwarz);
}
.btn.btn-fill.btn-cl-schwarz {
	background-color: var(--cl-schwarz);
	color: var(--cl-weiss);
}

.btn.btn-outline.btn-cl-weiss {
	border: 1px solid var(--cl-weiss);
	color: var(--cl-weiss);
}
.btn.btn-outline.btn-cl-schwarz {
	border: 1px solid var(--cl-schwarz);
	color: var(--cl-schwarz);
}

/*-- Hover --*/

.btn.btn-outline.btn-cl-weiss.btn-effect-1:hover {
	background-color: var(--cl-weiss);
	color: var(--cl-schwarz);
}
.btn.btn-outline.btn-cl-weiss.btn-effect-1:hover svg.fill {
	fill: var(--cl-schwarz) !important;
}
.btn.btn-outline.btn-cl-schwarz.btn-effect-1:hover {
	background-color: var(--cl-schwarz);
	color: var(--cl-weiss);
}
.btn.btn-outline.btn-cl-schwarz.btn-effect-1:hover svg.fill {
	fill: var(--cl-weiss) !important;
}

.btn.btn-outline.btn-effect-2:after {
	content: '';
	position: absolute;
	top: -1px;
	left: -1px;
	width: calc(100% + 2px);
	height: calc(100% + 2px);
	transform: scaleY(0%);
	transform-origin: bottom;
	z-index: -1;
	transition: transform 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.btn.btn-outline.btn-effect-2:hover:after {
	transform: scaleY(100%);
}

.btn.btn-outline.btn-cl-weiss.btn-effect-2:after {
	background-color: var(--cl-weiss);
}
.btn.btn-outline.btn-cl-weiss.btn-effect-2:hover {
	color: var(--cl-schwarz);
}
.btn.btn-outline.btn-cl-weiss.btn-effect-2:hover svg.fill {
	fill: var(--cl-schwarz) !important;
}
.btn.btn-outline.btn-cl-schwarz.btn-effect-2:after {
	background-color: var(--cl-schwarz);
}
.btn.btn-outline.btn-cl-schwarz.btn-effect-2:hover {
	color: var(--cl-weiss);
}
.btn.btn-outline.btn-cl-schwarz.btn-effect-2:hover svg.fill {
	fill: var(--cl-weiss) !important;
}

/*-- Size & Shape --*/

.btn.btn-size-small {
	height: var(--2em);
}
.btn.btn-size-medium {
	height: calc(var(--1em) * 2.5);
}
.btn.btn-size-large {
	height: var(--3em);
}

.btn-form-std {
	padding: var(--0-5em) var(--2em);
}
.btn-form-round {
	border-radius: 50%;
	padding: var(--0-5em);
}
.btn.btn-size-small.btn-form-round,
.btn.btn-size-small.btn-form-square {
	width: var(--2em);
}
.btn.btn-size-medium.btn-form-round,
.btn.btn-size-medium.btn-form-square {
	width: calc(var(--1em) * 2.5);
}
.btn.btn-size-large.btn-form-round,
.btn.btn-size-large.btn-form-square {
	width: calc(var(--1em) * 3);
}

/*-- Width --*/

.btn.btn-width-std {
	width: 100%;
	max-width: calc(var(--1em) * 24);
}
.btn.btn-width-wide {
	width: 100%;
	max-width: calc(var(--1em) * 32);
}
.btn.btn-width-widest {
	width: 100%;
}
.btn.btn-width-half {
	width: 50%;
}

/*-- Position --*/

.btn.btn-pos-center {
	margin-left: auto;
	margin-right: auto;
}
.btn.btn-pos-right {
	margin-left: auto;
}

/*-- Grid --*/

.btn-wrapper {
	display: flex;
	align-items: center;
}
.btn-wrapper.opt-align-center {
	justify-content: center;
}
.btn-wrapper .btn:not(:last-child) {
	margin-right: var(--0-5em);
}

/*-- Toggle --*/

.btn.btn-toggle .toggle-el-1,
.btn.btn-toggle.active .toggle-el-2 {
	display: block;
}
.btn.btn-toggle .toggle-el-2,
.btn.btn-toggle.active .toggle-el-1 {
	display: none;
}

/*-- Icon Links --*/

.icon-link {
	display: flex;
	align-items: center;
}
.icon-link .btn + span,
.icon-link span + .btn {
	margin-left: var(--1em);
}

/*-- Arrow Links --*/

.arrow-link {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.arrow-link.wide {
	width: 100%;
	justify-content: space-between;
}
.arrow-link span:last-child {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-left: var(--1em);
	font-weight: 200;
	width: calc(var(--1em) * 2.5);
	transform: translateX(27.5%);
	transition: color 0.2s, transform 0.2s;
}
.arrow-link span:last-child:after {
	content: '';
	position: absolute;
	transform: scale(0);
	transform-origin: center center;
	z-index: -1;
	width: calc(var(--1em) * 2.5);
	height: calc(var(--1em) * 2.5);
	border-radius: 50%;
	background-color: var(--cl-schwarz);
	transition: transform 0.2s;
}
.arrow-hov-trigger:hover .arrow-link span:last-child {
	color: var(--cl-weiss);
	transform: translateX(0%);
}
.arrow-hov-trigger:hover .arrow-link span:last-child:after {
	transform: scale(1);
	transform-origin: center center;
}

/*.arrow-link {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.arrow-link.wide {
	width: 100%;
	justify-content: space-between;
}
.arrow-link span:last-child {
	position: relative;
	z-index: 1;
	margin-left: var(--1em);
	font-weight: 200;
	transform: translateX(0px);
	transition: color 0.2s, transform 0.2s;
}
.arrow-link span:last-child:after {
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateX(-50%) translateY(-50%) scale(0);
	transform-origin: center center;
	z-index: -1;
	width: var(--2em);
	height: var(--2em);
	border-radius: 50%;
	background-color: var(--cl-schwarz);
	transition: transform 0.2s;
}
.arrow-hov-trigger:hover .arrow-link span:last-child {
	color: var(--cl-weiss);
	transform: translateX(-10px);
}
.arrow-hov-trigger:hover .arrow-link span:last-child:after {
	transform: translateX(-50%) translateY(-50%) scale(1);
	transform-origin: center center;
}*/

/* ICONS */

.icon-burger,
.icon-plus,
.icon-x {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: var(--2em);
	height: var(--2em);
}
.icon-burger div,
.icon-plus div,
.icon-x div {
	position: absolute;
	width: 100%;
	height: 0%;
}
.icon-burger.opt-cl-schwarz div,
.icon-plus.opt-cl-schwarz div,
.icon-x.opt-cl-schwarz div {
	border-top: 1px solid var(--cl-schwarz);
}
.icon-burger.opt-cl-weiss div,
.icon-plus.opt-cl-weiss div,
.icon-x.opt-cl-weiss div {
	border-top: 1px solid var(--cl-weiss);
}
.icon-burger div:nth-child(1) {
	transform: translateY(-3px);
}
.icon-burger div:nth-child(2) {
	transform: translateY(3px);
}
.icon-plus div:nth-child(2),
.icon-x div:nth-child(2) {
	transform: rotate(90deg);
}
.icon-x {
	transform: rotate(45deg);
}



/**
 *	03 — GRID
 *	Flexbox, Abstände
 *	____________________________________________________________
*/

/*-- Units --*/

:root {
	/* Std. Einheit */
	--1em: 10px;
	--0-25em: calc(var(--1em) * 0.25);
	--0-5em: calc(var(--1em) * 0.5);
	--1-5em: calc(var(--1em) * 1.5);
	--2em: calc(var(--1em) * 2);
	--3em: calc(var(--1em) * 3);
	--4em: calc(var(--1em) * 4);
	--5em: calc(var(--1em) * 5);
	--6em: calc(var(--1em) * 6);
	--8em: calc(var(--1em) * 8);
	--9em: calc(var(--1em) * 9);
	--12em: calc(var(--1em) * 12);
	--18em: calc(var(--1em) * 18);
}

@media screen and (min-width: 1024px) {
	:root {
		/* Std. Einheit */
		--1em: 0.977vw;
	}
}
@media screen and (min-width: 2048px) {
	:root {
		/* Std. Einheit */
		--1em: 20px;
	}
}

/*-- Boxes --*/

.boxed {
	padding: var(--6em) var(--2em);
}

/*-- Overlapping --*/

.overlap-container {
	position: relative;
}
.overlap-container.opt-height-100 {
	padding-bottom: 100vh;
}
.overlap-container.opt-height-80 {
	padding-bottom: 80vh;
}
.overlap-container.opt-height-50 {
	padding-bottom: 50vh;
}

.overlap-container.opt-height-100.opt-fitted .overlap-wrapper {
	max-height: 100vh;
}
.overlap-container.opt-height-80.opt-fitted .overlap-wrapper {
	max-height: 80vh;
}
.overlap-container.opt-height-50.opt-fitted .overlap-wrapper {
	max-height: 50vh;
}

.overlap-wrapper {
	display: flex;
	flex-direction: column;
}
.overlap-container.opt-align-top .overlap-wrapper {
	justify-content: flex-start;
}
.overlap-container.opt-align-center .overlap-wrapper {
	justify-content: center;
}
.overlap-container.opt-align-bottom .overlap-wrapper {
	justify-content: flex-end;
}

.overlap-clipper {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	clip: rect(0, auto, auto, 0);
	clip-path: inset(0 0 0 0);
}
.overlap-wrapper {
	position: fixed;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100vh;
}
.overlap-media {
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: 0;
	width: 100%;
	height: 100%;
}
.overlap-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.overlap-content {
	z-index: 1;
	padding: 0px var(--sidegaps);
}
.overlap-overlay {
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: 1;
	width: 100%;
	height: 100%;
	pointer-events: none;
	background: linear-gradient(0deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,0) 83.333%, rgba(0,0,0,0.25) 100%);
}
/* TMP Fix */
.block-bild-banner-1 .overlap-wrapper {
	position: relative;
	top: unset;
	left: unset;
	width: 100%;
	height: 100vh;
}
.block-bild-banner-1 .overlap-overlay {
	background: linear-gradient(20deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0) 50%);
}

/*-- Gaps --*/

body {
	padding-top: var(--4em);
}

:root {
	--sidegaps: var(--6em);
}

.main-header,
.main-content,
.main-footer {
	padding: 0px var(--sidegaps);
}

.main-content {
}
.main-footer {
	position: relative;
}

.opt-gap-top-0 {
	padding-top: 0px;
}
.opt-gap-top-1 {
	padding-top: var(--3em);
}
.opt-gap-top-2 {
	padding-top: var(--6em);
}
.opt-gap-top-3 {
	padding-top: var(--9em);
}
.opt-gap-bottom-0 {
	padding-bottom: 0px;
}
.opt-gap-bottom-1 {
	padding-bottom: var(--3em);
}
.opt-gap-bottom-2 {
	padding-bottom: var(--6em);
}
.opt-gap-bottom-3 {
	padding-bottom: var(--9em);
}

.block-fw,
.block-fw-gap {
	width: calc(100% + calc(var(--sidegaps) * 2));
	margin-left: calc(var(--sidegaps) * -1);
}
.block-fw-gap {
	padding-left: var(--sidegaps);
	padding-right: var(--sidegaps);
}

/* Columns */

:root {
	--col-half: 0 0 calc(50% - calc(var(--sidegaps) / 4));
	--col-third: 0 0 calc(33.333% - calc(var(--sidegaps) / 3));
	--col-fourth: 0 0 calc(25% - calc(var(--sidegaps) / 2.667));
}
.col-half {
	flex: var(--col-half);
}
.col-third {
	flex: var(--col-third);
}
.col-fourth {
	flex: var(--col-fourth);
}
.col-wrapper {
	display: flex;
	justify-content: space-between;
}
.col-wrap {
	flex-wrap: wrap;
}

/* Wrapper */

.wrapper {
	width: 100%;
	margin: 0 auto;
}

.wrapper-2048 { max-width: 2048px; }
.wrapper-1024 { max-width: 1024px; }

.wrapper-p50 { max-width: 50%; }

/* Width */

.opt-width-1 { max-width: 100%; }
.opt-width-2 { max-width: 50%; }
.opt-width-3 { max-width: 25%; }

/* Position */

.opt-pos-a { display: flex; width: 100%;}

.opt-pos-a.opt-pos-1 { justify-content: flex-start; }
.opt-pos-a.opt-pos-2 { justify-content: center; }
.opt-pos-a.opt-pos-3 { justify-content: flex-end; }

.opt-pos-b.opt-pos-1 { margin-right: auto;}
.opt-pos-b.opt-pos-2 { margin-left: auto; margin-right: auto; }
.opt-pos-b.opt-pos-3 { margin-left: auto; }

/* Image Crop */

.crop-el .video-js,
.crop-el video,
.crop-el img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
.crop-el.crop-top img {
	object-position: top;
}
.crop-2-3	{ aspect-ratio: 2  / 3; }
.crop-3-4	{ aspect-ratio: 3  / 4; }
.crop-4-5	{ aspect-ratio: 4  / 5; }
.crop-1-1	{ aspect-ratio: 1  / 1; }
.crop-3-2	{ aspect-ratio: 3  / 2; }
.crop-16-9	{ aspect-ratio: 16 / 9; }
.crop-2-1	{ aspect-ratio: 2  / 1; }
.crop-3-1	{ aspect-ratio: 3  / 1; }

/* Image Hov Zoom */

.img-hov-e {
	overflow: hidden;
}
.img-hov-e img	{
	transform: scale(1);
	transform-origin: center;
	transition: transform 0.3s;
}
.img-hov:hover .img-hov-e img	{
	transform: scale(1.025);
}

/* Cols */

.col-wrapper {
	display: flex;
}
.col-wrapper.opt-align-1 {
	justify-content: flex-start;
}
.col-wrapper.opt-align-2 {
	justify-content: center;
}
.col-wrapper.opt-align-3 {
	justify-content: flex-end;
}
.col-wrapper.opt-cols {
	flex-wrap: wrap;
	width: calc(100% + var(--3em));
	margin-left: calc(var(--1-5em) * -1);
}
.col-wrapper.opt-cols .col {
	margin-left: var(--1-5em);
	margin-right: var(--1-5em);
}
.col-wrapper.opt-cols-2 .col {
	flex: 0 0 calc(50% - var(--3em));
}
.col-wrapper.opt-cols-3 .col {
	flex: 0 0 calc(33.333% - var(--3em));
}
.col-wrapper.opt-cols-4 .col {
	flex: 0 0 calc(25% - var(--3em));
}

/* Max Width */

.mw-480{
	max-width: 480px;
}
.mw-720{
	max-width: 720px;
}
.mw-960{
	max-width: 960px;
}




/**
 *	04 — HEADER, FOOTER & NAVI
 *	Header, Footer, Layer, Meüs, etc.
 *	____________________________________________________________
*/


/* HEADER */

.main-header {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 3;
	width: 100%;
	transform: translateY(0%);
	transition: background-color 0.3s 0.3s, color 0.3s 0.3s, transform 0.3s;
}
.main-bar {
	position: relative;
	z-index: 3;
	display: flex;
	align-items: center;
	width: 100%;
	min-height: var(--4em);
	padding: var(--0-5em) 0px;
}

.main-header.nav-up {
	transform: translateY(-100%);
}
.home .main-header {
	color: var(--cl-weiss);
	background-color: transparent;
}
.main-header,
.main-header.solid {
	color: var(--cl-schwarz);
	background-color: var(--cl-weiss);
}

.main-bar .slot-1 {
	flex: 0 0 50%;
	justify-content: flex-start;
	margin-right: var(--1-5em);
}
.main-bar .slot-2 {
	margin-right: auto;
}
.main-bar .slot-2,
.main-bar .slot-3,
.main-bar .slot-4 {
	flex: 1 1 auto;
	justify-content: center;
	margin-left: var(--1-5em);
}
.main-bar .slot-3,
.main-bar .slot-4 {
	text-align: right;
}
.main-bar .slot-4 {
	display: none;
}

.menu-wrapper-1 {
	display: flex;
}
.menu-wrapper-1 .menu-item:not(:last-child) {
	margin-right: var(--1em);
}
.opener,
.closer {
	cursor: pointer;
}


/* LAYER */

.moving-layer {
	position: fixed;
	top: 0px;
	right: 0px;
	z-index: 4;
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 480px;
	background-color: var(--cl-weiss);
	transform: translateY(-100%);
	transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.ml-section {
	padding-left: var(--sidegaps);
	padding-right: var(--sidegaps);
}
.moving-layer.active {
	transform: translateY(0%);
}
.moving-layer-wrapper {
	position: relative;
	display: flex;
	flex-direction: column;
	flex: 1 1 100%;
	width: 100%;
}
.moving-layer-header,
.moving-layer-footer {
	display: flex;
	min-height: var(--4em);
}
.moving-layer-content {
	flex: 1 1 100%;
	padding-top: var(--6em);
	padding-bottom: var(--6em);
}
.moving-layer-header {
	padding-top: var(--0-5em);
	padding-bottom: var(--0-5em);
}
.moving-layer-header .slot {
	flex: 1 1 33.333%;
	display: flex;
	align-items: center;
}
.moving-layer-header .slot-1 {
	justify-content: flex-start;
}
.moving-layer-header .slot-2 {
	justify-content: center;
}
.moving-layer-header .slot-3 {
	justify-content: flex-end;
}
.moving-layer-footer {
	margin-top: auto;
	padding-top: var(--1-5em);
	padding-bottom: var(--1-5em);
	border-top: 1px solid rgba(0,0,0,0.25)
}

.moving-layer-overlay {
	position: fixed;
	top: 0px;
	right: 0px;
	z-index: 3;
	width: 100%;
	height: 100vh;
	background-color: rgba(0,0,0,0.5);
	pointer-events: none;
	opacity: 0;
	transition: opacity 1s cubic-bezier(0.165, 0.84, 0.44, 1);
}
body.layer-active .moving-layer-overlay {
	opacity: 1;
	pointer-events: auto;
}

/* Contact */

.moving-layer-contact .moving-layer-content a {
	white-space: nowrap;
}

/* FOOTER */

.main-footer {
}

.footer-wrapper .row-1,
.footer-wrapper .row-2 {
	display: flex;
	padding: var(--3em) 0px var(--6em) 0px;
}
.footer-wrapper .row-1 {
	justify-content: space-between;
}
.footer-wrapper .row-3 {
	display: flex;
	align-items: center;
	min-height: var(--6em);
	padding: var(--1em) 0px;
}
.footer-wrapper .row-2,
.footer-wrapper .row-3 {
	border-top: 1px solid var(--cl-schwarz);
}

.footer-wrapper .col-1 {
	margin-right: var(--3em);
}
.footer-wrapper .row-2 .col-1,
.footer-wrapper .row-3 .col-1 {
	flex: 1 1 50%;
}
.footer-wrapper .row-2 .col-2,
.footer-wrapper .row-2 .col-3,
.footer-wrapper .row-3 .col-2,
.footer-wrapper .row-3 .col-3 {
	flex: 1 1 25%;
}

/* NAVI */

/* Breadcrumb */

.breadcrumb {
	display: flex;
}
.breadcrumb-item:not(:last-child)::after {
	content: '›';
	margin: 0px var(--0-5em);
}




/**
 *	05 — UX ELEMENTE
 *	Layer, Popups und weitere UX Elemente
 *	____________________________________________________________
*/

/*-- LINKBOX --*/

.linkbox {
	display: block;
	padding: var(--1-5em) 0px var(--1em) 0px;
	border-bottom: 1px solid var(--cl-schwarz);
}
.linkbox-wrapper .linkbox:first-child {
	border-top: 1px solid var(--cl-schwarz);
}
.linkbox-wrapper.col-wrap .linkbox:nth-child(-n+2) {
	border-top: 1px solid var(--cl-schwarz);
}

/* WHITEBOX */

.whitebox {
	padding: var(--1-5em);
	background-color: var(--cl-weiss);
	aspect-ratio: 2/1;
}
.whitebox-wrapper {
	display: flex;
	flex-direction: column;
	height: 100%;
	max-width: 480px;
}
.whitebox .kicker {
	margin-bottom: auto;
}

/* LIST */

/* Style 01: Std. */

.list.st-01 li {
	display: flex;
	align-items: center;
	min-height: var(--3em);
	padding: var(--0-5em) 0px;
	border-top: 2px solid var(--cl-weiss);
}
.list.st-01 li:last-child {
	border-bottom: 2px solid var(--cl-weiss);
}
.list.st-01 li > span:first-child {
	text-align: left;
	margin-right: auto;
}
.list.st-01 li > span:last-child {
	text-align: right;
}

/* Style 02: Erweitert (2 Spalten) */

.list.st-02 li {
	display: flex;
	padding: var(--0-25em) 0px;
	border-top: 2px solid var(--cl-weiss);
}
.list.st-02 li span {
	flex: 0 0 50%;
}
.list.st-02 li span:nth-child(2) {
	flex: 0 0 50%;
}

/* Style 03: Linkliste (2 Spalten) */

.list.st-3 a {
	display: flex;
	padding: var(--0-25em) 0px;
	border-top: 2px solid var(--cl-weiss);
}
.list.st-3 a span:nth-child(1) {
	flex: 0 0 50%;
}
.list.st-3 a span:nth-child(2) {
	flex: 1 1 100%;
}
.list.st-3 a span:nth-child(3) {
	margin-left: auto;
}


/* LINKLIST */

/* Std. */

.linklist:not(:first-child) {
	margin-top: var(--3em);
}
.linklist-entry {
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-height: var(--4em);
	border-bottom: 2px solid var(--cl-weiss);
}
.linklist-entry:first-child {
	border-top: 2px solid var(--cl-weiss);
}
.linklist.opt-col-count-2 {
	columns: 2;
	column-gap: var(--1em);
}

/* Overlay */

.linklist-overlay-wrapper.active .linklist-overlay-entry {
	color: var(--cl-weiss);
	border-color: rgba(255,255,255,0.25);
}
.linklist-overlay-wrapper.active .linklist-overlay-entry span {
	opacity: 0.25;
}
.linklist-overlay-wrapper.active .linklist-overlay-entry:hover span {
	opacity: 1;
}
.linklist-overlay-entry {
	position: relative;
	z-index: 4;
	display: flex;
	justify-content: flex-start;
	align-items: baseline;
	border-bottom: none;
}
/*.linklist-overlay-entry span:nth-child(2) {
	margin-left: var(--1em);
}*/
.linklist-overlay {
	position: fixed;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100vh;
	z-index: 3;
	opacity: 0;
	transition: opacity 0.2s;
	pointer-events: none;
}
.linklist-overlay.active {
	opacity: 1;
}
.linklist-overlay .video-js,
.linklist-overlay video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}



/**
 *	06 — SECTIONS & SEITEN
 *	Startseite, Unterseiten, Blog, Singles
 *	____________________________________________________________
*/

/* BLOG */

.intro-meta-wrapper {
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-height: var(--4em);
	padding: var(--0-5em) 0px;
}

/* PRELOADER */

.preloader {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 10;
	width: 100%;
	height: 100vh;
	display: flex;
	align-items: center;
	padding: var(--1em) var(--sidegaps);
	background-color: var(--cl-beige);
}
.preloader-wrapper {
	width: 100%;
}
.preloader .name,
.preloader .number {
	flex: 0 0 auto;
	overflow: hidden;
}
.preloader .name span,
.preloader .number span {
	display: block;
	transform: translateY(0%);
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.preloader .track {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
}
.preloader .train {
	flex: 1 0 auto;
	display: flex;
	align-items: center;
	padding: var(--1em);
	transform-origin: right;
	transform: scaleX(1);
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.preloader .trainline {
	width: 100%;
	height: 0px;
	border-bottom: 1px solid var(--cl-schwarz);
	transform-origin: left;
	transform: scaleX(0);
}
.preloader .elements {
	position: fixed;
	top: 0px;
	left: 0px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100vh;
}
.preloader .elements span {
	display: none;
	background-color: var(--cl-black);
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	transition: clip-path 1s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.preloader {
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	transition: clip-path 1s 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.preloader.c-up {
	clip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);
}
.preloader.c-up .name span,
.preloader.c-up .number span {
	transform: translateY(100%);
}
.preloader.c-up .train {
	transform: scaleX(0);
}

/*.intro-1-wrapper .row-1 .text {
	overflow: hidden;
}
.intro-1-wrapper .row-1 .text h1 {
	transform: translateY(100%);
}
.intro-1-wrapper .row-1 .text h1 {
	display: block;
	transition: opacity 0.4s, transform 0.4s;
}
.intro-1-wrapper.c-up .row-1 .text h1 {
	transform: translateY(0%);
}*/


.intro-1-wrapper .overlap-wrapper {
	overflow: hidden;
}
.block-intro-1 .overlap-media {
	transform: translateY(20%);
	transition: transform 1.5s;
}
.block-intro-1.c-up .overlap-media {
	transform: translateY(0%);
}


/**
 *	07 — BLÖCKE
 *	Module, bzw. WordPress Blöcke
 *	____________________________________________________________
*/


/* ALLG. */

/* Block Wrapper */

.block {
	position: relative;
	min-width: 100%;
}

.opt-border-top {
	border-top: 2px solid var(--cl-weiss);
	padding-top: var(--1em);
}
.opt-border-bottom {
	border-bottom: 2px solid var(--cl-weiss);
	padding-bottom: var(--1em);
}

.bl-header {
	margin-bottom: var(--3em);
}
.bl-header.opt-border-bottom {
	margin-bottom: var(--1em);
	padding-bottom: var(--1em);
	border-bottom: 2px solid var(--cl-weiss);
}
.bl-header-std {
}
.bl-header-big span:last-child {
}

/* Divider */

.opt-divider {
	padding-top: var(--1em);
	border-top: 1px solid var(--cl-schwarz);
}

/* INTRO */

/* Main */

.block-intro-1 {
	margin-top: calc(var(--4em) * -1);
}
.intro-1-wrapper-1 {
	padding-bottom: var(--3em);
	margin-bottom: var(--1em);
	border-bottom: 1px solid var(--cl-weiss);
}
.intro-1-wrapper-1 .row-1 {
	display: flex;
	align-items: last baseline;
	margin-bottom: var(--2em);
}
.intro-1-wrapper-1 .row-1 .col-1 {
	flex: 0 0 50%;
}
.intro-1-wrapper-1 .row-1 .col-2 {
	position: relative;
	flex: 0 0 25%;
	margin-left: auto;
}
.intro-1-wrapper-1 .row-1 .col-2:after {
	content: '„';
	font-size: 3em;
	position: absolute;
}

.intro-1-wrapper-2 {
	margin-top: var(--1em);
}
.intro-1-wrapper-2 .row-2 {
	margin-top: var(--3em);
}

/* Small */

.intro-small-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	margin: var(--6em) auto var(--3em);
}
.intro-small-wrapper p {
	max-width: 1024px;
}

/* Full (Bild) */

.block-intro-3 {
	margin-top: calc(var(--4em) * -1);
}


/* TEXT (STD.) */

.text-1-wrapper .row-2,
.text-1-wrapper .row-3 {
	margin-top: var(--3em);
}

/* LINKBOX */

.linkbox-1-wrapper .row-2,
.linkbox-2-wrapper .row-2 {
	margin-top: var(--12em);
}
.linkbox-1-wrapper.small-gap .row-2,
.linkbox-2-wrapper.small-gap .row-2 {
	margin-top: var(--6em);
}

/* ICONBOX */

/* Std. */

.iconbox-wrapper {
	margin-bottom: calc(var(--3em) * -1);
}
.iconbox {
	display: flex;
	margin-bottom: var(--3em);
}
.iconbox-icon {
	margin-right: var(--1em);
	padding-right: var(--1em);
	border-right: 1px solid var(--cl-schwarz);
}
.iconbox-content {
	display: flex;
	flex-direction: column;
}
.iconbox-bottom {
	margin-top: auto;
}
.iconbox-icon.long .btn {
	height: 100%;
}

/* Large */

.iconbox-wrapper.opt-size-large .iconbox-icon,
.iconbox-wrapper.opt-size-large .iconbox-content {
	flex: 1 1 50%;
}
.iconbox-icon .icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	aspect-ratio: 1/1;
	padding: var(--1em);
	border: 1px solid var(--cl-schwarz);
}
.iconbox-icon .icon img {
	max-width: calc(var(--1em) * 10);
}

/* QUOTEBOX */

/* Std. */

.quotebox-wrapper {
}
.quotebox {
	display: flex;
	flex-direction: column;
	margin-bottom: var(--3em);
	padding-top: var(--1em);
	border-top: 1px solid var(--cl-schwarz);
}
.quotebox-icon {
	margin-bottom: var(--3em);
}
.quotebox-content {
	padding-bottom: var(--1em);
}
.quotebox-bottom {
	margin-top: auto;
	padding-top: var(--1em);
}


.akk.st-02 .akk-trigger {
	display: flex;
	justify-content: center;
	width: 100%;
	padding: var(--1em);
	border-top: 1px solid var(--cl-schwarz);
}

/* BILD 01 (FULL) */

.bild-1-wrapper {
}

/* BILDBANNER */

.block-intro-2 {
	margin-top: var(--6em);
	border-bottom: 1px solid rgba(0,0,0,0.5);
}
.breadcrumb-std {
	display: flex;
	align-items: center;
	min-height: var(--3em);
	padding: var(--0-5em) 0px;
}

.bild-banner-1-wrapper {
	position: absolute;
	z-index: 2;
	top: 0px;
	left: 0px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	height: 100%;
	padding: var(--3em) 0px;
}

.bt-2-entry a {
	border-top: 1px solid rgba(255,255,255,0.5);
	width: 100%;
	display: flex;
	align-items: center;
	padding: var(--0-5em) 0px;
}
.bt-2-entry a:last-child {
	border-bottom: 1px solid rgba(255,255,255,0.5);
}

/* BILD & TEXT 1 (STD.) */

.bt-1-wrapper .row-2 {
	display: flex;
}
.bt-1-wrapper .row-2 .col {
	flex: 0 0 50%;
}
.bt-1-wrapper .row-2 .col-1 {
	padding-right: var(--3em);
}
/*.bt-1-wrapper .linklist {
	position: sticky;
	top: var(--8em);
}*/

/* Order */

.bt-1-wrapper.opt-order-2 .row-2 {
	flex-direction: row-reverse;
}
.bt-1-wrapper.opt-order-2 .row-2 .col-1 {
	padding-right: 0px;
}
.bt-1-wrapper.opt-order-2 .row-2 .col-2 {
	padding-right: var(--3em);
}

/* BILD & TEXT 2 (...) */

.bt-2-wrapper .row-1 {
	margin-bottom: var(--3em);
}
.bt-2-wrapper .row-2 {
	display: flex;
}
.bt-2-wrapper .row-2 .col {
	flex: 1 1 50%;
}
.bt-2-wrapper .row-2 .col-1 {
	margin-right: var(--3em);
}
.bt-2-entry .text,
.bt-2-entry .link {
	margin-top: var(--3em);
}

/* Order */

.bt-2-wrapper.opt-order-2 .row-2 {
	flex-direction: row-reverse;
}
.bt-2-wrapper.opt-order-2 .row-2 .col-1 {
	padding-right: 0px;
}
.bt-2-wrapper.opt-order-2 .row-2 .col-2 {
	padding-right: var(--3em);
}

/* BILD & TEXT 3 (...) */

.bt-3-wrapper .row-2 {
	display: flex;
}
.bt-3-wrapper .row-2 .col {
	flex: 0 0 50%;
}
.bt-3-wrapper .row-2 .col-1 {
	padding-right: var(--1em);
}
.bt-3-wrapper .row-3 {
	margin-top: var(--1em);
}

/* BILD & TEXT 4 (...) */

.bt-4-wrapper .row-2 {
	display: flex;
	align-items: flex-end;
}
.bt-4-wrapper .row-2 .col {
	flex: 0 0 50%;
}
.bt-4-wrapper .row-2 .col-1 {
	padding-right: var(--12em);
}
.bt-4-wrapper .row-3 {
	margin-top: var(--3em);
}
.bt-4-wrapper .row-4 {
	margin-top: var(--1em);
}

/* BILD & TEXT 5 (...) */

.bt-5-wrapper .row-3 {
	margin-top: var(--2em);
}
.bt-5-wrapper .row-3.opt-box-align-h-2 {
	text-align: center;
}

/* BILD 1 */

.bilder-1-wrapper .row-1 {
	display: flex;
	justify-content: center;
}
.bilder-1-wrapper .row-1 .col {
	flex: 0 0 calc(33.333% - var(--3em));
}
.bilder-1-wrapper .row-1 .col-1 {
	margin-right: var(--1em);
}
.bilder-1-wrapper .row-2 {
	margin-top: var(--1em);
}

/* BILD 2 */

.bilder-2-wrapper .row-1 {
	display: flex;
	justify-content: center;
}
.bilder-2-wrapper .row-1 .col {
	flex: 1 1 33.333%;
}
.bilder-2-wrapper .row-1 .col:not(:last-child) {
	margin-right: var(--1em);
}
.bilder-2-wrapper .row-2 {
	margin-top: var(--1em);
}


/* KLAPPTEXTE */

/* Allgemein */

.akk-trigger {
	cursor: pointer;
}

/* Style 01 - Trenner */

.akk-1-wrapper .row-3 {
	margin-top: var(--3em);
}


/* FILM TEASER */

.ft-header {
	margin-bottom: var(--3em);
}
.ft-1-entry-wrapper .ft-player {
	display: block;
	width: 100%;
	aspect-ratio: 6.4/3;
}
.ft-1-entry-wrapper .ft-player video-js {
	width: 100%;
	height: 100%;
}
.ft-1-entry-wrapper .ft-player video-js video {
	object-fit: cover;
}
.ft-titel-text {
	display: block;
	max-width: calc(var(--6em) * 3);
}
.ft-1-wrapper .ft-titel-text span {
	display: block;
}

/* Style 1 */

.ft-1-wrapper.opt-st-1 .ft-1-entry-wrapper {
	display: block;
}
.ft-1-wrapper.opt-st-1 .ft-1-entry-wrapper:not(:last-child) {
	margin-bottom: var(--3em);
}
.ft-1-wrapper.opt-st-1 .ft-media {
	margin-bottom: var(--1em);
}
.ft-1-wrapper.opt-st-1 .ft-player {
	max-width: 66.667%;
	margin: 0 auto;
}
.ft-1-wrapper.opt-st-1 .ft-titel {
	display: flex;
}
.ft-1-wrapper.opt-st-1 .ft-titel .col-1,
.ft-1-wrapper.opt-st-1 .ft-titel .col-3 {
	flex: 1 1 16.667%;
}
.ft-1-wrapper.opt-st-1 .ft-titel .col-2 {
	flex: 1 1 66.667%;
}
.ft-1-wrapper.opt-st-1 .ft-titel .col-3 {
	display: flex;
	justify-content: flex-end;
	text-align: right;
}

/* Style 2 & 3 */

.ft-1-wrapper.opt-st-2 .ft-1-entry-wrapper,
.ft-1-wrapper.opt-st-3 .ft-1-entry-wrapper {
	display: flex;
}
.ft-1-wrapper.opt-st-2 .ft-1-entry-wrapper:not(:last-child),
.ft-1-wrapper.opt-st-3 .ft-1-entry-wrapper:not(:last-child){
	margin-bottom: var(--1em);
}
.ft-1-wrapper.opt-st-2 .ft-media,
.ft-1-wrapper.opt-st-3 .ft-media {
	flex: 1 1 auto;
}
.ft-1-wrapper.opt-st-2 .ft-titel,
.ft-1-wrapper.opt-st-3 .ft-titel {
	flex: 0 0 33.333%;
	display: flex;
	justify-content: space-between;
}
.ft-1-wrapper.opt-st-2 .ft-titel .col-1,
.ft-1-wrapper.opt-st-3 .ft-titel .col-1 {
	display: none;
}

.ft-1-wrapper.opt-st-2 .ft-media {
	margin-right: var(--1em);
}

.ft-1-wrapper.opt-st-3 .ft-1-entry-wrapper {
	flex-flow: row-reverse;
}
.ft-1-wrapper.opt-st-3 .ft-media {
	margin-left: var(--1em);
}
.ft-1-wrapper.opt-st-3 .ft-titel {
	flex: 0 0 50%;
}


/* VIDEO PLAYER */

/* Video JS Fixes */

/*.video-js .vjs-play-progress {
	background-color: var(--cl-beige);
}
.vjs-poster {
	background-size: cover;
}
.video-js .vjs-big-play-button {
	display: none;
}
.video-js .vjs-control-bar {
	background-color: transparent;
}
.video-js .vjs-slider {
	background: rgba(255,255,255,0.5);
}
.video-js .vjs-load-progress div {
	background: var(--cl-weiss);
}*/

/* Video Player 2 */

/*.video-player-2-wrapper .row-1 {
	position: relative;
	margin-bottom: var(--1-5em);
}
.video-player-2-filme .video-player-2-poster {
	position: absolute;
	z-index: 2;
	width: 100%;
}
.video-player-2-wrapper .row-2 {
	display: flex;
	margin-bottom: var(--1-5em);
}
.video-player-2-wrapper .row-2.spaced {
	margin-bottom: var(--3em);
}
.video-player-2-wrapper .row-2 .col-1,
.video-player-2-wrapper .row-2 .col-3 {
	flex: 1 1 16.667%;
}
.video-player-2-wrapper .row-2 .col-2 {
	flex: 1 1 66.667%;
	display: flex;
	justify-content: center;
	text-align: center;
}
.video-player-2-titel {
	display: block;
	max-width: calc(var(--6em) * 4);
}
.video-player-2-titel span {
	display: block;
}
.video-player-2-wrapper .row-2 .col-3 {
	display: flex;
	justify-content: flex-end;
	text-align: right;
}
.video-player-2-play-button {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
}*/

/* Remote Framework */

/*.remote-play-poster {
	opacity: 1;
	transition: opacity 0.2s;
}
.remote-play-wrapper.rp-active .remote-play-poster {
	opacity: 0;
	pointer-events: none;
}
.remote-play-wrapper.rp-active .remote-play-trigger-inside {
	display: none;
}*/


/* BLOG */

.blog-teaser-1-wrapper {
	display: flex;
}
.blog-teaser-1-entry-wrapper:nth-child(2n-1) {
	flex: 0 0 50%;
}
.blog-teaser-1-entry-wrapper:nth-child(2n) {
	flex: 0 0 30%;
	margin-left: auto;
}
.blog-teaser-1-wrapper .row-2 {
	margin-top: var(--1em);
	display: flex;
	justify-content: space-between;
}
.blog-teaser-1-wrapper .row-2 .col-1 {
	margin-right: var(--3em);
}
.blog-teaser-1-wrapper .row-2 .col-2 {
	white-space: nowrap;
}



/**
 *	08 — RESPONSIVE
 *	Anpassung des Layouts für mobile Geräte
 *	____________________________________________________________
*/

@media screen and (min-width: 2048px) {

}

@media screen and (max-width: 1440px) {

}

@media screen and (max-width: 1024px) {

/* Grid */
	
:root {

--sidegaps: var(--1em);
--col-half: 1 1 100%;
--col-third: 1 1 100%;
--col-fourth: 1 1 50%;

}

.intro-1-wrapper-1 .row-1 {
	display: block;
}
.intro-1-wrapper-1 .row-1 .col-1 {
	margin-bottom: var(--2em);
}
.intro-1-wrapper-1 {
	border-bottom: none;
}
.intro-1-wrapper-1 .row-1 .col-2 p:before {
	content: '„';
}
.intro-1-wrapper-1 .row-1 .col-2 p:after {
	content: '“';
}
.intro-1-wrapper-1 .row-1 .col-2:after {
	display: none;
}
.block-intro-1 .overlap-media img {
	width: 200%;
	height: 100%;
	object-fit: cover;
	transform: translateX(-40%);
	max-width: unset;
}

.text-1-wrapper .row-1 .col-2,
.text-1-wrapper .row-2 .col-1,
.text-1-wrapper .row-3 .col-1 {
	display: none;
}

.bild-banner-1-wrapper {
	position: relative;
	width: calc(100% + var(--2em));
	padding:  0px;
	margin-left: calc(var(--1em) * -1);
}
.block-bild-banner-1 .overlap-content,
.block-intro-2 .overlap-content {
	padding: 0px;
}
.block-bild-banner-1 .overlap-container,
.block-intro-2 .overlap-container {
	padding-bottom: 0px !important;
}
.block-bild-banner-1 .overlap-clipper,
.block-intro-2 .overlap-clipper {
  position: relative;
  clip: unset;
  clip-path: unset;
}
.block-bild-banner-1 .overlap-wrapper,
.block-intro-2 .overlap-wrapper {
	position: relative;
	height: unset;
}
.block-bild-banner-1 .overlap-media,
.block-intro-2 .overlap-media {
	position: relative;
	height: unset;
}
.bild-banner-1-wrapper .row-2 .col-1,
.block-intro-2 .row-2 .col-1 {
	display: none;
}

.bild-banner-1-wrapper .whitebox {
	background-color: var(--cl-grau);
	aspect-ratio: unset;
}
	
.akk-1-wrapper .row-2 .col:first-child {
	display: none;
}

.bt-1-wrapper .row-1 {
	flex-direction: column-reverse;
}
.bt-1-wrapper .row-1 .col {
	flex: 1 1 auto;
}
.bt-1-wrapper .row-1 .col-1 {
	padding: var(--3em) 0px;
}

.linkbox-1-wrapper .row-2,
.linkbox-2-wrapper .row-2 {
	margin-top: var(--6em);
}
.linkbox-1-wrapper .row-1 .col-2,
.linkbox-2-wrapper .row-1 .col-2 {
	display: none;
}

/* Type */

.f-s1-a {
	font-size: 2em;
	line-height: 1.0667em;
}

.hl.opt-hl-spaced {
	display: block;
}
.hl.opt-hl-spaced span {
	display: inline-flex;
	width: 50%;
}
.hl.opt-hl-spaced h3 {
	display: inline;
	width: 100%;
	text-indent: 0%;
}
.hl.opt-hl-half,
.hl.opt-hl-full h3:not(span + h3) {
	width: 100%;
	text-indent: 0%;
}

/* Framework */

.main-bar .slot-1 {
	flex: 1 1 auto;
}
.main-bar .slot-2,
.main-bar .slot-3 {
	display: none;
}
.main-bar .slot-4 {
	display: block;
}
.btn {
	width: 100%;
}

.opt-width-3 {
	max-width: 50%;
}

/* Modul: Intro (Main) */

.intro-main-wrapper {
	display: block;
	height: unset;
}
.intro-main-media {
	width: 100%;
}
.intro-main-media .video-js .vjs-tech {
	position: relative;
}
.intro-main-media .video-js {
	width: 100%;
	height: auto;
}
.intro-main-media video {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
}
.intro-main-wrapper .row-2 {
	display: block;
	height: auto;
	margin-top: var(--1em);
}
.intro-wrapper .row-2 .col-2 {
	margin-top: var(--1em);
}

/* Modul: Film & Text 1 */

.ft-1-wrapper.opt-st-2 .ft-titel {
	flex: 0 0 50%;
}

/* Modul: Bild & Text */

.bt-1-wrapper .row-2 {
	display: block;
}
.bt-1-wrapper .row-2 .col-1,
.bt-2-wrapper .row-2 .col-1 {
	margin-right: 0px;
	margin-bottom: var(--6em);
}

.bt-2-wrapper .row-2 {
	display: block;
}
.box-align.opt-box-align-h-1 .box-align-item, .box-align.opt-box-align-h-2 .box-align-item, .box-align.opt-box-align-h-3 .box-align-item {
	width: 100%;
}

/* Modul: Blog Teaser */

.blog-teaser-1-entry-wrapper {
	flex: 0 0 calc(50% - var(--0-5em)) !important;
}
.blog-teaser-1-entry-wrapper:nth-child(2n) {
	margin-left: var(--1em);
}
.blog-teaser-1-wrapper .row-2 {
	display: block;
}
.blog-teaser-1-wrapper .row-2 .col-1 {
	margin-right: 0px;
}

.bild-banner-wrapper {
      padding: var(--3em) var(--1em);
}



	
.hero-slider-content .row .col-1 {
	display: none;
}
.hero-slider-content {
	padding: 0px var(--1em) var(--3em);
}
.text-1-wrapper {
	padding: 0px;
}
.footer-wrapper .row-2 .col-1 {
	display: none;
}


}

@media screen and (max-width: 480px) {
	
.hero-wrapper {
	flex-direction: column;
}

.opt-width-3 {
	max-width: 100%;
}
.text-1-wrapper .text {
	width: 100%;
}

.akk-abschnitt {
	display: block;
	border-top: none;
}
.akk-abschnitt:not(:last-child) {
	margin-bottom: var(--3em);
}
.akk-abschnitt-titel {
	margin-bottom: var(--1em);
}
.akk-abschnitt .akk.st-01:first-child {
	border-top: 2px solid var(--cl-weiss);
}
.akk.st-01 .akk-trigger {
	padding: calc(var(--1em) * 0.75) 0px;
}
.akk.st-01 .akk-trigger .akk-hint {
	opacity: 1;
}
.akk.single.st-01 .akk-trigger,
.akk.single.st-01 .akk-content {
	padding-left: 0%;
}

.btn.btn-width-half {
	width: 100%;
}

.hl.opt-hl-full h2:not(span + h2), .hl.opt-hl-full h3:not(span + h3) {
	text-indent: 0%;
}
.hl.opt-hl-half span, .hl.opt-hl-full span {
	display: block;
	width: unset;
	margin-bottom: 0.5em;
}

.bild-banner-wrapper .row-2 {
	display: block;
}
.bild-banner-wrapper .row-2 .col-2 {
	margin-top: var(--3em);
}

.bt-3-wrapper .row-2 {
	display: block;
}

.bt-3-wrapper .row-2 .col-1 {
	padding-right: 0px;
	margin-bottom: var(--1em);
}
.bt-4-wrapper .row-2 .col-1 {
	padding-right: var(--3em);
}

.crop-2-1 {
	aspect-ratio: 1 / 1;
}
.crop-3-1 {
	aspect-ratio: 2 / 1;
}

}

/** IE FIXES **/
@media screen\0, @media screen\9 {
    h1, h2, h3, p {
        width: 100%;
    }
    img {
        flex-shrink: 0;
    }
}