/*
 Theme Name:   vonHand 2022 Theme
 Description:  vonHand WordPress Theme - 2022
 Author:	   Stappen & Kryska
 Author URI:   https://stappenundkryska.de
 Version:      1.0.0
 Text Domain:  vonhand

*/
/**	____________________________________________________________
 *
 *	INHALTE
 *
 *
 *	01 — BASICS
 *	02 — TYPO
 *	03 — GRID
 *	04 — HEADER, FOOTER & MENÜS
 *	05 — BLÖCKE & UX ELEMENTE
 *	06 — PAGES & SECTIONS
 *	07 — RESPONSIVE
 *
 *	____________________________________________________________
*/



.kontakt-cta {
	position: fixed;
	right: 40px;
	bottom: 0px;
	z-index: 1;
	display: flex;
	align-items: center;
	height: 60px;
	padding: 0px 40px;
	color: rgb(255,255,255);
	font-size: 1.111em;
	font-weight: 700;
	font-family: 'Akrobat', sans-serif;
	letter-spacing: 0em;
	text-transform: uppercase;
	background: var(--cd-blue-1);
	border-radius: 15px 15px 0px 0px;
	transform: translateY(calc(100% - 10px));
	transition: transform 0.2s;
}

.pulsating-circle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 6px;
	height: 6px;
	margin-right: 17px;
	margin-left: -5px;
	border-radius: 50%;
	background-color: rgb(255,255,255);
	animation: pulse 3s linear infinite;
	transition: width 0.2s, height 0.2s;
}

@keyframes pulse {
	0% {
		box-shadow: 0px 0px 0px 0px rgba(255,255,255,0.7), 0px 0px 0px 0px rgba(255,255,255,0.7);
	}
	40% {
		box-shadow: 0px 0px 0px 30px rgba(255,255,255,0), 0px 0px 0px 0px rgba(255,255,255,0.7);
	}
	80% {
		box-shadow: 0px 0px 0px 30px rgba(255,255,255,0), 0px 0px 0px 15px rgba(255,255,255,0);
	}
	100% {
		box-shadow: 0px 0px 0px 0px rgba(255,255,255,0), 0px 0px 0px 15px rgba(255,255,255,0);
	}
}

.kontakt-cta.active {
	transform: translateY(0%);
}



/**
 *	01 — BASICS
 *	Basissettings
 *	____________________________________________________________
*/

*, :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-behavior: smooth;
	overflow-x: hidden;
}
body {
	position: relative;
	margin: 0;
	line-height: 1;
	-webkit-text-size-adjust: 100%;
}
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 {
	display: block;
	border: 0 none;
	height: auto;
	max-width: 100%;
}
/* Safari Fix */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
	_::-webkit-full-page-media, _:future, :root, img {
		align-self: center;
	}
}
::-moz-selection {
	color: rgb(255, 255, 255);
	background: rgb(0, 0, 0);
}
::selection {
	color: rgb(255, 255, 255);
	background: rgb(0, 0, 0);
}



/**
 *	02 — TYPO, COLORS & ICONS
 *	Schrift- und Farbsettings
 *	____________________________________________________________
*/

/*--- FARBEN ---*/

/* CD Farben */

:root {
	--cd-blue-0: rgb(5,84,242);
	--cd-blue-1: rgb(5,108,242);
	--cd-blue-2: rgb(5,131,242);
	--cd-blue-3: rgb(5,151,242);
	--cd-blue-4: rgb(5,175,242);
}

/*--- SVG ---*/

/* SVG Farben */

.fill.white {
	fill: rgb(255,255,255);
}
.fill.black {
	fill: rgb(0,0,0);
}
.stroke.white {
	stroke: rgb(255,255,255);
}
.stroke.black {
	stroke: rgb(0,0,0);
}

/* SVG Framework */

.stroke {
	fill: none;
	stroke-miterlimit: 0;
}
.stroke.thin {
	stroke-width: 1px;
}
.stroke.normal {
	stroke-width: 2px;
}
.stroke.thick {
	stroke-width: 3px;
}

/*--- SCHRIFT ---*/

@font-face {
	font-family: 'Inter';
	src:
		url('fonts/inter-v8-latin-300.woff2') format('woff2'),
		url('fonts/inter-v8-latin-300.woff') format('woff');
	font-weight: 300;
	font-style: normal;
}
@font-face {
	font-family: 'Inter';
	src:
		url('fonts/inter-v8-latin-400.woff2') format('woff2'),
		url('fonts/inter-v8-latin-400.woff') format('woff');
	font-weight: 400;
	font-style: normal;
}
@font-face {
	font-family: 'Inter';
	src:
		url('fonts/inter-v8-latin-500.woff2') format('woff2'),
		url('fonts/inter-v8-latin-500.woff') format('woff');
	font-weight: 500;
	font-style: normal;
}
@font-face {
	font-family: 'Akrobat';
	src:
		url('fonts/akrobat-regular.woff2') format('woff2'),
		url('fonts/akrobat-regular.woff') format('woff');
	font-weight: 400;
	font-style: normal;
}
@font-face {
	font-family: 'Akrobat';
	src:
		url('fonts/akrobat-semibold.woff2') format('woff2'),
		url('fonts/akrobat-semibold.woff') format('woff');
	font-weight: 600;
	font-style: normal;
}
@font-face {
	font-family: 'Akrobat';
	src:
		url('fonts/akrobat-bold.woff2') format('woff2'),
		url('fonts/akrobat-bold.woff') format('woff');
	font-weight: 700;
	font-style: normal;
}
body {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	font-weight: 300;
	line-height: 1.4em;
	letter-spacing: 0.025em;
	background-color: rgb(255,255,255);
}

:root {
	color-scheme: only light;
}
@media (prefers-color-scheme: dark) {
	body {
		background-color: rgb(255,255,255);
	}
}

/* Headings */

h1, h2, h3, h4, .h1, .h2, .h3, .h4 {
	margin: 1em 0em;
	line-height: 1em;
}
h1:first-child, h2:first-child, h3:first-child, h4:first-child, .h1:first-child, .h2:first-child, .h3:first-child, .h4:first-child {
	margin-top: 0;
}
h1:last-child, h2:last-child, h3:last-child, h4:last-child, .h1:last-child, .h2:last-child, .h3:last-child, .h4:last-child {
	margin-bottom: 0;
}
h1, h2, h3, h4, .h1, .h2, .h3, .h4 {
	font-weight: 600;
	font-family: 'Akrobat', sans-serif;
	letter-spacing: 0em;
}
.h3, .h4 {
	letter-spacing: 0.05em;
}
h1, .h1 {
	font-weight: 400;
}
h1, .h1,
h2.big, .h2.big {
	font-size: 3em;
	line-height: 1em;
	text-transform: uppercase;
}
h2.big, .h2.big {
	font-weight: 600;
}
h2, .h2 {
	font-size: 2em;
	font-weight: 400;
	line-height: 1.125em;
}
h3, .h3 {
	font-size: 1.5em;
	line-height: 1.125em;
}
h4, .h4 {
	font-size: 1em;
	line-height: 1.3em;
	max-width: 270px;
	letter-spacing:  0.05em;
}

/* Type Elements */

.sec-big-type {
	margin-bottom: -30px;
}
.sec-big-type span {
	font-weight: 600;
	font-family: 'Akrobat', sans-serif;
	font-size: 16.5vw;
	line-height: 1em;
	text-transform: uppercase;
}
.sec-title h2 {
	text-align: center;
	padding: 0.5em 0em;
	max-width: 11em;
	margin: 0em auto 0.25em;
}
.sec-title p {
	text-align: center;
}
.sec-title.right {
	width: 50%;
	margin-left: auto;
	text-align: left;
}
.sec-title.right h2 {
	text-align: left;
	margin: 0;
}
.sec-title.has-copy h2 {
	margin-bottom: 0.5em;
}
.title-copy {
	margin-bottom: 60px;
}
.title-copy p {
	margin: 0px auto;
}
.kicker {
	display: flex;
	margin-bottom: 1.667em;
	border-top: 1px solid rgb(0,0,0);
	padding-top: 1.667em;
	line-height: 1.667em;
	text-transform: uppercase;
}
.kicker span {
	display: block;
	flex: 1;
}
.kicker span:nth-child(1) {
	margin-right: auto;
	padding-right: 20px;
}
.kicker span:nth-child(2) {
	text-align: center;
}
.kicker span:nth-child(3) {
	margin-left: auto;
	text-align: right;
}
.kicker.left span:nth-child(1),
.kicker.left span:nth-child(3) {
	flex: 1 1 0%;
}
.kicker.left span:nth-child(2) {
	flex: 0 1 1440px;
	text-align: left;
}
.kicker.right span:nth-child(1) {
	flex: 0 0 50%;
}
.kicker.right span:nth-child(2) {
	flex: 1 1 50%;
	text-align: left;
}
.kicker.right span:nth-child(3) {
	flex: 1 1 auto;
}
p {
	max-width: 960px;
	margin: 0 0 1.5em;
}
p.big {
	font-size: 2em;
	line-height: 1.2em;
	margin: 0 0 1.2em;
}
p:last-child, ul:last-child, li:last-child, ol:last-child {
	margin-bottom: 0;
}
b, strong {
	font-weight: 700;
}
ul, ol {
	margin: 0 0 1.45em;
	padding: 0;
	list-style: none;
	break-inside: avoid;
}
li:not(.menu-item) {
	position: relative;
	margin-bottom: 10px;
	padding-left: 10px;
}
li:not(.menu-item):after {
	content: '_';
	position: absolute;
	left: 0px;
	top: 0px;
}

/* BUTTONS & LINKS */

/* Browser Fixes */

a, .button:focus, button:focus, input[type="button"]:focus, input[type="reset"]:focus, input[type="submit"]:focus {
	outline: none;
}
button {
	border: none;
	font-size: inherit;
	font-family: 'Akrobat', sans-serif;
	font-size: 1em;
	font-weight: 600;
	cursor: pointer;
}
button::-moz-focus-inner {
	border: 0;
	outline: none;
}

/* Std */

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 60px;
	padding: 10px 45px;
	font-family: 'Akrobat', sans-serif;
	font-size: 1.5em;
	font-weight: 600;
	line-height: 1em;
	letter-spacing: 0em;
	text-transform: uppercase;
	border-radius: 30px;
}
.button.small {
	min-height: 45px;
	font-size: 1.111em;
}

/* Styles */

.button.icon {
	justify-content: space-between;
}
.button.icon svg {
	margin-left: 20px;
}
.button.outline {
	border: 1px solid rgb(0,0,0);
	border-radius: 5px;
	font-size: 1.25em;
}

/* Color */

.button.full.blue {
	color: rgb(255,255,255);
	background-color: var(--cd-blue-1);
}
.button.full.gray {
	color: rgb(255,255,255);
	background-color: rgba(0,0,0,0.2);
}

.button:hover {
	opacity: 0.9;
}

/* Grid */

.button-wrapper {
	display: flex;
}
.button + .button,
.button + .opener {
	margin-left: 10px;
}

/* Arrow Link */

.arrow-link {
	display: flex;
	align-items: center;
	font-size: 1.5em;
	font-weight: 500;
	line-height: 1em;
}
.arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	margin-left: 15px;
	border: 2px solid rgb(255,255,255);
	border-radius: 50%;
}
.arrow-link h3 {
	margin: 0;
	font-size: 1.5rem;
	font-weight: 400;
}

/* Arrow Hov */

.arrow-hov {
	position: relative;
}
.arrow-hov-icon {
	position: absolute;
	top: 30px;
	right: 30px;
	width: 20px;
	height: 20px;
	opacity: 0;
	transform: translate3D(10px,-10px,0px);
	transition: opacity 0.2s, transform 0.2s;
}
.arrow-hov:hover .arrow-hov-icon {
	opacity: 1;
	transform: translate3D(0px,0px,0px);
}


/**
 *	03 — GRID
 *	Flexbox, Abstände
 *	____________________________________________________________
*/

.main-header, .main-content, .main-footer {
	padding: 0px 40px;
}
.main-content {
	position: relative;
	min-height: 100vh;
	padding-top: 120px;
}
.sec {
	position: relative;
	padding: 90px 0px;
}
.pt-0 {
	padding-top: 0px;
}
.pt-1 {
	padding-top: 20px;
}
.pt-2 {
	padding-top: 60px;
}
.pt-3 {
	padding-top: 90px;
}
.pb-0 {
	padding-bottom: 0px;
}
.pb-1 {
	padding-bottom: 20px;
}
.pb-2 {
	padding-bottom: 60px;
}
.pb-3 {
	padding-bottom: 90px;
}
.npt {
	padding-top: 0px;
}
.npb {
	padding-bottom: 0px;
}
.rel {
	position: relative;
}

/* Flex */

.row {
	display: flex;
	flex-direction: row;
}
.row.wrap {
	width: 100%;
	flex-wrap: wrap;
}
.col {
	display: flex;
	flex-direction: column;
	flex: 1;
}
.boxed {
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Wrapper */

.wrapper {
	width: 100%;
	margin: 0 auto;
}
.wrapper-full {
	width: calc(100% + 80px);
	margin-left: -40px;
}
.wrapper-1920 {
	max-width: 1920px;
}
.wrapper-1680 {
	max-width: 1680px;
}
.wrapper-1560 {
	max-width: 1560px;
}
.wrapper-1440 {
	max-width: 1440px;
}
.wrapper-1320 {
	max-width: 1320px;
}
.wrapper-1200 {
	max-width: 1200px;
}
.wrapper-1080 {
	max-width: 1080px;
}
.wrapper-960 {
	max-width: 960px;
}
.wrapper-4-5 {
	max-width: 75%;
}
.wrapper-2-3 {
	max-width: 66.667%;
}
.wrapper-1-2 {
	max-width: 50%;
}
.wrapper-1-3 {
	max-width: 33.333%;
}
.wrapper-box {
	display: flex;
	flex-wrap: wrap;
}
.wrapper-left {
	margin-left: 0;
}
.wrapper-right {
	margin-right: 0;
}

/* Edges */

.re {
	overflow: hidden;
	border-radius: 30px;
}
.re-small {
	overflow: hidden;
	border-radius: 15px;
}

/* Cols */

.content-cols {
	display: flex;
	width: calc(100% + 40px);
	margin: -20px;
}
.content-col {
	padding: 0px 20px;
}
.col-1-2 {
	flex: 0 0 50%;
}
.col-1-3 {
	flex: 0 0 33.33%;
}
.col-2-3 {
	flex: 0 0 66.66%;
}
.css-col {
	column-count: 2;
	column-gap: 40px;
}



/**
 *	04 — HEADER, FOOTER & MENÜS
 *	Header, Footer, Beitragsbilder etc.
 *	____________________________________________________________
*/


/* HEADER */

/* Main Bar */

.main-header {
	position: fixed;
	z-index: 3;
	top: 0px;
	left: 0px;
	width: 100%;
	background-color: rgba(255,255,255,0.9);
}
.main-bar {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	height: 120px;
	transition: height 0.3s;
}
.main-bar-logo {
	padding-right: 30px;
	font-size: 1.5em;
}
.logo {
	font-family: 'Akrobat', sans-serif;
	font-weight: 400;
	letter-spacing: 0em;
	font-size: 1.5em;
	line-height: 0.8em;
}
.logo span {
	display: block;
}
.logo span:last-child {
	font-size: 0.45em;
	text-transform: uppercase;
}
.menu-controls {
	display: flex;
}
.menu-controls .button {
	margin-right: 10px;
}

.main-header.nav-up .main-bar {
	height: 75px;
}


/* FOOTER */

.main-footer {
	margin-top: 60px;
}
.footer-bottom {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 90px;
	padding: 30px 0px;
	border-top: 1px solid rgb(0,0,0);
}
.footer-kontakt {
	background-color: rgb(240,240,240);
	padding: 60px 20px;
	display: flex;
	justify-content: center;
}


/* MENU / NAVIGATION */

/* Menü Button */

.mobile-controls {
	display: none;
}
.main-opener {
	width: 60px;
	height: 60px;
	border: 1px solid rgb(0,0,0);
	border-radius: 5px;
}
.opener {
	cursor: pointer;
}
.opener-icon {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
}
.opener-icon .line {
	width: 20px;
	height: 2px;
	background-color: rgb(0,0,0);
	margin: 0px 2px;
}
.opener-icon .line:not(:last-child) {
	margin-bottom: 3px;
}
.opener-icon, .closer-icon {
	position: absolute;
	transition: opacity .2s;
}
.opener:not(.active) .closer-icon, .opener.active .opener-icon {
	opacity: 0;
}

/* Hauptmenü */

.full-menu-wrapper {
	display: flex;
	flex-direction: column;
	min-height: 100%;
	align-self: stretch;
}
.main-items-wrapper {
	margin-bottom: 60px;
}
.main-item {
	display: flex;
	justify-content: space-between;
	padding-top: 0.5vw;
	border-top: 1px solid rgb(0,0,0);
	overflow: hidden;
}
.main-item:hover {
	color: var(--cd-blue-1);
}
.main-item span:first-child {
	font-weight: 600;
	font-family: 'Akrobat', sans-serif;
	letter-spacing: -0.025em;
	font-size: 8vw;
	line-height: 0.9em;
	text-transform: uppercase;
	transform: translateY(100%);
	transition: transform 0.3s 0.5s;
}
.moving-layer.active .main-item span:first-child {
	transform: translateY(0%);
}
.sub-items {
	padding: 25px 0px 40px 60px;
}
.sub-item {
	display: block;
	font-size: 1.25em;
	line-height: 1.25em;
	font-weight: 400;
	letter-spacing: 0em;
}
.sub-item:hover {
	color: var(--cd-blue-1);
}
.footer-items-wrapper {
	display: flex;
	margin-top: auto;
}
.footer-items-group-02 {
	margin-left: auto;
}
.footer-item {
	display: inline-flex;
	align-items: center;
	margin: 0px;
}
.footer-item img {
	margin-right: 5px;
}
.footer-item:not(:last-child) {
	margin: 0px 20px 0px 0px;
}

.menu {
	position: relative;
	display: flex;
}
.footer-bottom .menu-item {
	margin-right: 0px;
	margin-left: 30px;
	white-space: nowrap;
}
.menu-item:hover {
	color: var(--cd-blue-1);
}
.current-menu-item {
}
#main-nav {
	flex-direction: column;
}
#main-nav .menu-item {
	font-family: 'Akrobat', sans-serif;
	font-size: 2em;
	line-height: 1.25em;
	text-align: center;
}

/* Hauptmenü Layer */

.moving-layer {
	position: fixed;
	top: 0px;
	right: 0px;
	z-index: 2;
	transform: translateY(-100%);
	width: 100%;
	padding-top: 120px;
	background-color: rgb(255, 255, 255);
	transition: transform 0.5s;
}
.moving-layer.active {
	transform: translateY(0%);
	opacity: 1;
}
.ml-content {
	display: flex;
	padding: 30px 40px;
}
.overlay {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 1;
	width: 100%;
	height: 100vh;
	background-color: rgba(0, 0, 0, 0.3);
	opacity: 0;
	transition: opacity 0.5s;
	pointer-events: none;
}
.overlay.active {
	opacity: 1;
	pointer-events: auto;
}
.single-closer {
	position: relative;
	margin-bottom: 30px;
	cursor: pointer;
}

/* Languages */

.lang-switcher {
	display: flex;
}
.lang:not(:last-child) {
	margin-right: 10px;
}
.lang {
	font-size: 1.111em;
	font-weight: 700;
	font-family: 'Akrobat', sans-serif;
	letter-spacing: 0em;
	text-transform: uppercase;
}



/**
 *	05 — BLÖCKE & UX ELEMENTE
 *	WordPress Block Elemente & UX Elemente
 *	____________________________________________________________
*/


/* TRENNLINIE */


.divider.std {
	width: 100%;
	border-top: 1px solid rgb(0,0,0);
}


/* BLOCK: INTRO MAIN */

.intro-main-wrapper {
	padding-top: 60px;
}
.intro-text {
	margin: 0px auto 60px;
	text-align: center;
	max-width: 960px;
}
.intro-subline {
	background-color: var(--cd-blue-1);
	max-width: 960px;
	color: rgb(255,255,255);
	padding: 30px;
	text-align: center;
	margin: 0px auto;
}


/* BLOCK: BIG TEXT */

.big-text p {
	max-width: 100%;
	font-size: 1.25em;
	line-height: 1.5em;
}


/* BLOCK: KONTAKT */

.kontakt-content {
	position: relative;
	text-align: center;
}
.kontakt-intro {
	margin-bottom: 60px;
}
.kontakt-link {
}
.kontakt-link:hover {
	color: var(--cd-blue-1);
}

.kontakt-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 60px;
	background-color: rgb(240,240,240);
}
.kontakt-buttons {
	margin-top: 30px;
}
.block-text .wrapper p {
	margin: 0 auto;
}


/* BULLET */

.bullet-group {
	display: flex;
	flex-wrap: wrap;
}

/* St. 01 */

.bullet-group.st-01 .bullet {
	flex: 0 0 calc(50% - 10px);
	padding: 20px 30px;
	color: rgb(255,255,255);
	background-color: var(--cd-blue-1);
	border-radius: 10px;
	margin-bottom: 20px;
}
.bullet-group.st-01 .bullet:nth-child(2n) {
	margin-left: 20px;
}
.bullet-group.st-01 h3 {
	margin-bottom: 0.5em;
}



/* AKKORDEON */

.akkordeon-trigger {
	cursor: pointer;
}

/* St. 01 */

.akkordeon-group.st-01 {
	border: 1px solid rgb(0,0,0);
	border-radius: 15px;
}
.akkordeon-group.st-01 .akkordeon:not(:last-child) {
	border-bottom: 1px solid rgb(0,0,0);
}
.akkordeon-group.st-01 .akkordeon-trigger {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 75px;
	padding: 15px 30px;
}
.akkordeon-group.st-01 .akkordeon-trigger h3 {
	text-align: center;
	margin: 0px auto;
	line-height: 1em;
}
.akkordeon-group.st-01 .akkordeon-content {
	padding: 0.75em 20px 1.5em 20px;
	max-width: 720px;
	margin: 0px auto;
	text-align: center;
}
.akkordeon-group.st-01 .akkordeon-trigger .acc-opener {
	position: absolute;
	transform: rotate(0deg);
	transition: transform 0.2s;
}
.akkordeon-group.st-01 .akkordeon-trigger.active .acc-opener {
	transform: rotate(45deg);
}

/* St. 02 */

.akkordeon-group.st-2.opt-align-2 {
	display: flex;
	justify-content: center;
	text-align: center;
}
.akkordeon-group.st-2 .akkordeon-trigger {
	margin: 30px 0px;
}

/* St. 03 */

.akkordeon-group.st-03 {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.akkordeon-group.st-03 .akkordeon {
	flex: 0 0 calc(50% - 5px);
	border-radius: 10px;
	border: 1px solid rgb(0,0,0);
	margin-bottom: 10px;
}
.akkordeon-group.st-03 .akkordeon:nth-child(2n) {
	margin-left: 10px;
}
.akkordeon-group.st-03 .akkordeon-trigger {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 75px;
	padding: 15px 30px;
}
.akkordeon-group.st-03 .akkordeon-trigger h3 {
	margin: 0px 0px 0px 40px;
	line-height: 1em;
}
.akkordeon-group.st-03 .akkordeon-content {
	padding: 0.75em 20px 1.5em 20px;
}
.akkordeon-group.st-03 .akkordeon-trigger .acc-opener {
	position: absolute;
	transform: rotate(0deg);
	transition: transform 0.2s;
}
.akkordeon-group.st-03 .akkordeon-trigger.active .acc-opener {
	transform: rotate(45deg);
}


/* BLOCK: PARALLAX BANNER */


.parallax-banner-wrapper {
	position: relative;
	width: 100%;
	padding-bottom: 33.33%;
}
.parallax-banner-inner {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	clip: rect(0, auto, auto, 0);
	clip-path: inset(0 0 0 0);
}
.parallax-banner-media {
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0;
	left: 0;
}
.parallax-banner-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.parallax-banner-media video, .parallax-banner-media video-js {
	width: 100%;
	height: 100%;
}
.parallax-banner-media video {
	object-fit: cover;
}


/* BLOCK: PROJEKT PREVIEW */

.projekt-pre-wrapper {
	position: relative;
	width: 100%;
}
.projekt-pre-entry {
	position: relative;
	display: block;
}
.projekt-pre-entry {
	margin-bottom: 240px;
}
.projekt-pre-media {
	position: relative;
	padding-bottom: 60%;
}
.projekt-pre-video,
.projekt-pre-bild {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0px;
	top: 0px;
}
.projekt-pre-video video,
.projekt-pre-video video-js {
	width: 100%;
	height: 100%;
}
.projekt-pre-video video {
	object-fit: cover;
}
.projekt-pre-bild img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.projekt-pre-info {
	position: absolute;
	bottom: 0px;
	right: 0px;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	min-height: 120px;
	padding: 0px 40px;
	color: rgb(255,255,255);
	font-family: 'Akrobat', sans-serif;
	letter-spacing: 0em;
	font-size: 1.5em;
	font-weight: 400;
}
.kategorien {
	display: flex;
	font-size: 1.5rem !important;
}
.kategorien span {
	margin-right: 15px;
}
.projekt-pre-ticker-wrapper {
	position: fixed;
	top: 0px;
	left: 0px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	width: 100%;
	height: 100vh;
	z-index: -1;
	overflow: hidden;
	overflow-x: clip;
}
.projekt-pre-ticker {
	display: block;
	width: 100%;
	margin-left: 100%;
	white-space: nowrap;
}
.projekt-pre-ticker span {
	display: inline-block;
	width: 100%;
	font-weight: 600;
	font-family: 'Akrobat', sans-serif;
	font-size: 26vw;
	line-height: 1em;
	text-align: center;
	text-transform: uppercase;
	white-space: nowrap;
}
.projekt-pre-overlay {
	position: absolute;
	bottom: 0px;
	left: 0px;
	z-index: 0;
	width: 100%;
	height: 50%;
	background: linear-gradient(180deg, rgba(0,0,0,0) 50%, rgb(0, 0, 0) 100%);
}


.img-hov {
	overflow: hidden;
}
.img-hov img {
	transform: scale(1);
	transition: transform 0.2s;
}
.img-hov:hover img {
	transform: scale(1.05);
}


/* BLOCK: BILD & TEXT */


.bild-text-wrapper {
	display: flex;
}
.bild-text-wrapper.r-2 {
	flex-flow: row-reverse;
}
.bild-text-wrapper .bild,
.bild-text-wrapper .text {
	flex: 1 1 50%;
}
.bild-text-wrapper .text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	margin-left: 60px;
}
.bild-text-wrapper.r-2 .text {
	margin-left: 0px;
	margin-right: 60px;
}


/* BLOCK: VIDEO */


/* Popup */

.video-wrapper {
	position: relative;
}
.video-wrapper .play-button,
.video-text-wrapper .play-button {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateX(-50%) translateY(-50%);
}
.video-wrapper .play-button-circle,
.video-text-wrapper .play-button-circle {
	border: 1px solid rgb(255,255,255);
}
.video-wrapper .video-overlay,
.video-text-wrapper .video-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	background-color: rgb(0,0,0);
	pointer-events: none;
}


/* BLOCK: VIDEO & TEXT */


.video-text-wrapper {
	display: flex;
	width: 100%;
}
.video-text-wrapper .video {
	position: relative;
	flex: 0 0 calc(66.66% - 30px);
	margin-right: 60px;
}
.video-text-wrapper .text {
	flex: 1 1 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
}
.video-text-wrapper.r-2 {
	flex-flow: row-reverse;
}
.video-text-wrapper.r-2 .video {
	margin-right: 0px;
	margin-left: 60px;
}


/* Frame */

.video-poster {
	position: absolute;
	z-index: 1;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	opacity: 1;
	transition: opacity 0.3s;
}
.video-poster.hidden {
	opacity: 0;
	pointer-events: none;
}
.video-poster img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.video-player {
	width: 100%;
}


/* BLOCK: GALERIE GRID */

.galerie-grid {
	display: flex;
	flex-wrap: wrap;
	width: calc(100% + 20px);
	margin: -10px;
}
.galerie-item {
	padding: 10px;
}
.galerie-grid.gr-1 .galerie-item {
	flex: 0 0 100%;
}
.galerie-grid.gr-2 .galerie-item {
	flex: 0 0 50%;
}
.galerie-grid.gr-3 .galerie-item {
	flex: 0 0 33.33%;
}
.galerie-grid.gr-4 .galerie-item {
	flex: 0 0 25%;
}
.framed .galerie-item img {
	border: 1px solid rgba(0,0,0,0.33);
}

.popup-galerie-wrapper {
	display: flex;
	height: 100vh;
}
.popup-galerie-img {
	flex: 0 0 calc(100% - 360px);
	padding: 15px;
	border-right: 1px solid rgba(255,255,255,0.5);
}
.popup-galerie-img img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.popup-galerie-txt {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 90px 15px;
	color: rgb(255,255,255);
}


/* CTA FORMULAR */

.cta-formular-wrapper {
	padding: 60px;
	background-color: rgb(240,240,240);
}


/* SWIPER */

/* Std. */

.popup .swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
	pointer-events: none;
}
.popup.active .swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
	pointer-events: auto;
}
.swiper-horizontal > .swiper-scrollbar {
	left: 0px;
	bottom: 0px;
	height: 0px;
	width: 100%;
	margin-bottom: 2px;
	border-radius: 0px;
	background: transparent;
	border-top: 1px solid rgb(0,0,0);
}
.swiper-scrollbar-drag {
	background: rgb(0,0,0);
	border-radius: 0px;
	height: 2px;
}
.swiper-nav {
	display: flex;
}
.swiper-prev,
.swiper-next {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 50px;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	border: 2px solid rgb(255,255,255);
	cursor: pointer;
}
.swiper-prev {
	margin-right: 10px;
}
.swiper .bild.square {
	position: relative;
	padding-bottom: 100%;
}
.swiper .bild.square img {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.swiper .bild.flat {
	position: relative;
	padding-bottom: 66.667%;
}
.swiper .bild.flat img {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.swiper .text h3 {
	margin-bottom: 0px;
}

/* St. 01 - Bild Slider */

.swiper-st-01 .swiper-wrapper {
	padding-bottom: 30px;
}
.swiper-st-01 .swiper-nav {
	position: absolute;
	right: 20px;
	bottom: 50px;
	z-index: 1;
}
.swiper-st-01 .swiper-nav.black .swiper-prev,
.swiper-st-01 .swiper-nav.black .swiper-next {
	border: 2px solid rgb(0,0,0);
}
.swiper-st-01 .swiper-nav.black .stroke.white {
	stroke: rgb(0,0,0);
}

/* St. 02 - Bild & Text Slider */

.swiper-st-02 .swiper-nav {
	position: absolute;
	right: 15px;
	bottom: 15px;
	z-index: 1;
}
.swiper-st-02 .swiper-prev,
.swiper-st-02 .swiper-next {
	border: 1px solid rgb(255,255,255);
}


/* VIDEO TEASER 01 */

.vt-01 .teaser-images {
	display: flex;
	align-items: flex-end;
}
.vt-01 .teaser-main-image {
	position: relative;
	flex: 0 0 calc(50% - 10px);
	margin-right: 20px;
}
.vt-01 .teaser-main-image .play-button {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translateX(-50%) translateY(-50%);
}
.vt-01 .teaser-main-image .play-button-circle {
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: -1;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	background-color: rgb(255,255,255);
	border: none;
	transform: scale(1);
	transition: transform 0.2s;
}
.vt-01 .teaser-side-images {
	display: flex;
	flex-direction: column;
	align-self: stretch;
	flex: 1 1 100%;
}
.vt-01 .teaser-side-images .row-01 {
	display: flex;
	margin-bottom: 20px;
}
.vt-01 .teaser-caption,
.vt-01 .teaser-img-02 {
	flex: 0 0 50%;
}
.vt-01 .teaser-img-02 {
	padding-left: 20px;
}
.vt-01 .teaser-img-02 img {
	width: 100%;
}
.vt-01 .teaser-caption {
	display: flex;
	align-items: flex-end;
	padding-right: 20px;
}
.vt-01 .teaser-caption p {
	max-width: 320px;
}
.vt-01 .teaser-play {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50%;
	margin-right: auto;
	flex: 1 1 100%;
	border: 1px solid rgb(0,0,0);
}
.vt-01 .teaser-img-03 {
	width: 50%;
	margin-right: auto;
}
.vt-01 .teaser-text {
	width: 50%;
	margin: 30px 0px 120px auto;
}
.img-shadow-layer {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.25);
}
.img-mask {
	position: relative;
}
.img-mask-layer {
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 100%;
	background-color: rgb(255,255,255);
	transform: scaleX(1);
	transform-origin: left;
	transition: transform 0.75s;
}
.img-mask-group.active .img-mask-layer {
	transform: scaleX(0);
}

.block-agentur .video-js {
	width: 100%;
	height: 100%;
}

.play-button {
	position: relative;
	z-index: 1;
	width: 120px;
	height: 120px;
	cursor: pointer;
}
.play-button-inner {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}
.play-button-circle {
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: -1;
	width: 100%;
	height: 100%;
	border-radius: 50%;
	border: 1px solid rgb(0,0,0);
	transform: scale(1);
	transition: transform 0.2s;
}
.play-button:hover .play-button-circle {
	transform: scale(1.1);
}


/* POPUP */

.popup {
	position: fixed;
	left: 0px;
	top: 0px;
	z-index: 3;
	width: 100%;
	height: 100vh;
	opacity: 0;
	pointer-events: none;
	transition: transform 0.3s, opacity 0.3s;
}
.popup.active {
	transform: translateX(0px);
	opacity: 1;
	pointer-events: all;
}
.popup-trigger {
	cursor: pointer;
}
.popup-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
}
.popup-content-scroller {
	display: block;
	width: 100%;
	height: 100%;
	overflow-y: scroll;
}
.popup-content {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 600px;
	padding: 105px 95px;
}
.closer {
	position: fixed;
	top: 15px;
	right: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	border: 1px solid rgb(255,255,255);
	cursor: pointer;
	z-index: 1;
}



/* VIDEO */

/* Std. Setting */

.vjs-poster {
	background-size: cover;
}
.vjs-has-started.vjs-user-inactive.vjs-playing .vjs-control-bar {
	opacity: 1;
}
/*.vjs-play-control.vjs-control.vjs-button.vjs-playing,
.vjs-volume-panel.vjs-control.vjs-volume-panel-horizontal,
.vjs-remaining-time.vjs-time-control.vjs-control,
.vjs-fullscreen-control.vjs-control.vjs-button,
.video-js .vjs-play-progress::before {
	display: none;
}*/
.player-intro .vjs-play-control.vjs-control.vjs-button.vjs-playing,
.player-intro .vjs-volume-panel.vjs-control.vjs-volume-panel-horizontal,
.player-intro .vjs-remaining-time.vjs-time-control.vjs-control,
.player-intro .vjs-fullscreen-control.vjs-control.vjs-button,
.video-js.player-intro .vjs-play-progress::before {
	display: none;
}
.video-js .vjs-control-bar,
.video-js .vjs-load-progress,
.video-js .vjs-slider,
.video-js .vjs-progress-holder .vjs-load-progress,
.video-js .vjs-progress-holder .vjs-load-progress div {
	background-color: transparent !important;
	background: transparent !important;
}
.video-js .vjs-progress-control .vjs-progress-holder {
	margin: 0px !important;
	width: 100% !important;
}
.video-js .vjs-control-bar {
	max-width: 1940px;
	left: 50%;
	transform: translateX(-50%);
	bottom: 15px;
	padding: 0px 10px;
}
.video-js.player-intro .vjs-control-bar {
	max-width: 2000px;
	bottom: 56px;
	height: 5px;
	padding: 0px 40px;
}
.video-js .vjs-big-play-button {
    top: calc(50% - 45px);
    left: calc(50% - 45px);
    height: 90px;
    width: 90px;
	color: rgb(255,255,255);
    border: none;
    background-color: rgb(35,35,35);
    border-radius: 50%;
}
.video-js .vjs-big-play-button .vjs-icon-placeholder:before {
 	line-height: 90px;
}

/* Video & Text */

.video-text {
	display: flex;
}
.video-text .video {
	flex: 0 0 50%;
}
.video-text .text {
	display: flex;
	align-items: center;
	padding-left: 60px;
	flex: 0 0 50%;
}

/* Video Teaser */

.video-teaser {
	display: flex;
}
.video-teaser .video {
	flex: 0 0 calc(50% + 280px);
	margin-left: -40px;
}
.video-teaser .text {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex: 0 0 calc(50% - 240px);
	pointer-events: none;
}
.video-teaser .text-wrapper {
	width: calc(100% + 240px);
	margin-left: -240px;
	font-weight: 300;
}


/* ANIMATIONEN */

/* Loader */

.circle {
	width: 120px;
	height: 120px;
	position: relative;
	margin: auto;
	background: transparent;
	margin-bottom: 30px;
}
.inner-circle {
	width: 116px;
	height: 116px;
	background: rgb(255,255,255);
	border-radius: 50%;
	margin: 2px;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}
.spinner {
	height: 120px;
	width: 120px;
	border-radius: 50%;
	border-right: 1px solid rgb(0, 0, 0);
	border-top: 1px solid transparent;
	border-left: 1px solid transparent;
	border-bottom: 1px solid transparent;
	animation: rotate 1.5s infinite linear;
	position: absolute;
}
@keyframes 'rotate' {
	from {
		transform: rotate(0);
	}
	to {
		transform: rotate(360deg);
	}
}


.footer-page-select {
	display: flex;
	border-top: 1px solid rgb(0,0,0);
}
.page-selector {
	flex: 0 0 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 90px 0px;
}
.page-selector:first-child {
	border-right: 1px solid rgb(0,0,0);
}
.page-selector .arrow {
	border: 1px solid rgb(0,0,0);
}
.page-selector .arrow-link h3 {
	font-size: 1em;
}
.arrow-link.left {
	flex-flow: row-reverse;
}
.page-selector .arrow-link .arrow {
	margin-left: 30px;
}
.page-selector .arrow-link.left .arrow {
	transform: rotate(180deg);
	margin-right: 30px;
	margin-left: 0px;
}
.block-banner-bild {
	position: relative;
	width: 100%;
	margin: 30px 0px;
	padding-bottom: 33.33%;
	background-repeat: no-repeat;
	background-attachment: fixed;
	background-position: center center;
	background-size: cover;
}
.sec-projekt-intro,
.sec-page-intro {
	padding-top: 180px;
}
.sec-projekt-intro h1,
.sec-page-intro h1 {
	margin: 0;
}
.page-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin-bottom: 60px;
}


/* FORM */

/* Std Settings & Browser Fixes */

::placeholder {
	color: var(--cd-black);
	opacity: 1;
}
input[type="text"],
input[type="email"],
textarea {
	width: 100%;
	margin: 0px;
	padding: 0px;
	border: none;
	font-family: 'Inter', sans-serif;
	font-size: 1em;
	font-weight: 300;
	line-height: 1.5em;
	letter-spacing: 0.05em;
	color: rgb(0,0,0);
	background-color: transparent;
}
input[type="submit"] {
    border: none;
    border-radius: 0px;
}
textarea {
	min-height: 120px;
}

/* Booking Form */

.booking-form {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.booking-form-field {
	flex: 0 0 100%;
}
.in-field {
	position: relative;
	border-bottom: 1px solid rgb(0,0,0);
}
.in-field.error {
	border-bottom: 1px solid var(--cd-blue-1);
}
.in-field.error label {opener
	color: var(--cd-blue-1);
	opacity: 1;
}
.in-field input {
	width: 100%;
}
.in-field input[type="text"],
.in-field input[type="email"] {
	min-height: 90px;
	padding: 37px 0px 25px;
}
.in-button {
	border-bottom: none;
}
.in-field .button {
	display: flex;
	width: 50%;
	margin: 45px auto 0px;
}
.form-alert {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 60px 0px;
}
.form-alert svg {
	margin-bottom: 30px;
}
.form-alert.error {
	color: var(--cd-blue-1);
}
.form-alert.success {
	color: rgb(0,165,17);
}

/* Label */

.in-field label {
	position: absolute;
	top: 30px;
	left: 0px;
	display: flex;
	align-items: center;
	height: 30px;
	line-height: 30px;
	font-family: 'Akrobat', sans-serif;
	font-weight: 600;
	font-size: 1em;
	transform: translateY(0px);
	transition: transform 0.2s;
}
.in-field:not(.check) label {
	pointer-events: none;
}
.in-field.has-input label {
	transform: translateY(-20px);
}

/* Select Layer */

.select-layer-trigger {
	position: absolute;
	left: 0px;
	top: 0px;
	z-index: 1;
	display: flex;
	justify-content: flex-end;
	width: 100%;
	height: 100%;
	cursor: pointer;
}
.side-layer {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 4;
	width: 50%;
	height: 100vh;
	background-color: rgb(255,255,255);
	transform: translateX(-100%);
	transition: transform 0.5s;
}
.side-layer.active {
	transform: translateX(0%);
}
.layer-wrapper {
	position: relative;
	width: 100%;
	min-height: 100%;
	overflow-y: auto;
	padding: 80px 20px 20px;
}
.date-selection-header,
.date-selection {
	width: 100%;
}
.date-selection-header {
	display: flex;
	margin: 60px 0px 20px;
}
.date-selection-header h4 {
	flex: 0 0 50%;
	max-width: unset;
	margin: 0;
}
.date-entry {
	position: relative;
	display: flex;
	justify-content: space-between;
	padding: 15px 0px;
	border-top: 1px solid rgb(0,0,0);
	cursor: pointer;
}
.date-entry:last-child {
	border-bottom: 1px solid rgb(0,0,0);
}
.date-entry span {
	flex: 0 0 50%;
	font-size: 0.875em;
}
.date-entry .date-arrow {
	position: absolute;
	right: 0px;
	top: calc(50% - 10px);
	transform: translateX(-10px);
	opacity: 0;
	transition: transform 0.2s, opacity 0.2s;
}
.date-entry:hover .date-arrow {
	transform: translateX(0px);
	opacity: 1;
}
.side-layer-overlay {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 1;
	height: 100%;
	width: 100%;
	background: rgba(0,0,0,0.5);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.5s;
}
.side-layer-overlay.active {
	opacity: 1;
	pointer-events: auto;
}



/**
 *	06 — PAGES & SECTIONS
 *	Seitenspezifische Einstellungen
 *	____________________________________________________________
*/

/*.sec-agentur .sec-title,
.sec-agentur .kicker.right span:nth-child(2),
.sec-agentur .teaser-text,
.sec-agentur .akkordeon.st-01 .akkordeon-trigger h3,
.sec-agentur .akkordeon.st-01 .akkordeon-content {
	padding-left: 10px;
}*/
.agentur-infos {
	margin-top: 170px;
}
.booking-form-text p {
	max-width: 100%;
}
.home .sec-about {
	text-align: center;
}
#gdpr-cookie-message {
	position: fixed;
	right: 40px;
	bottom: 0px;
	background-color: var(--cd-blue-1);
	z-index: 3;
	color: rgb(255,255,255);
	padding: 40px;
	max-width: 480px;
	border-radius: 15px 15px 0px 0px;
}
#gdpr-cookie-types ul {
	margin: 10px 0px 30px;
}
#gdpr-cookie-types li {
	position: relative;
	margin: 0;
	margin-bottom: 10px;
	padding: 0;
}
#gdpr-cookie-types li:after {
	content: '';
	display: none;
}
#gdpr-cookie-message button {
	min-height: 50px;
	margin-right: 10px;
	padding: 10px 20px;
	border-radius: 10px;
}
#gdpr-cookie-message button + button {
	background-color: var(--cd-blue-2);
	color: rgb(255,255,255);
}
[type="checkbox"] {
	position: relative;
	z-index: 0;
	-webkit-appearance: none;
	appearance: none;
	display: block;
	margin: 0;
	padding: 0;
}
[type="checkbox"] + label {
	position: relative;
	display: block;
	padding-left: 45px;
	cursor: pointer;
	line-height: 16px;
}
[type="checkbox"] + label:before {
	content: "";
	position: absolute;
	left: 0px;
	z-index: 5;
	width: 40px;
	height: 16px;
	border-radius: 8px;
	margin-right: 15px;
	background-color: rgba(255,255,255,0.25);
	transition: background-color 0.5s linear;
}
[type="checkbox"] + label:after {
	content: "";
	position: absolute;
	left: 0px;
	top: 0px;
	z-index: 10;
	width: 16px;
	height: 16px;
	border-radius: 10px;
	background-color: #fff;
	box-shadow: 0px 0px 5px #aaa;
	transition: margin 0.1s linear;
}
[type="checkbox"]:checked + label:before {
	background-color: rgba(255,255,255,0.75);
}
[type="checkbox"]:checked + label:after {
	margin: 0 0 0 24px;
}



/**
 *	07 — RESPONSIVE
 *	Anpassung des Layouts für mobile und spezifische Geräte
 *	____________________________________________________________
*/

/* VERTIKAL */

@media screen and (max-height: 840px) {

.intro-home-logo svg {
	width: 100px;
}
.intro-home-curtain {
	padding-bottom: 60px;
}
.scroller-container {
	width: 120px;
	height: 120px;
}

}

/* HORIZONTAL */

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

}

/*@media screen and (max-width: 1920px) {


.sec-title {
	margin-bottom: 4.688vw;
}
.kicker {
	font-size: 0.938vw;
}
.intro-home-logo svg {
  width: 6.250vw;
}
.claim {
	max-width: 34.375vw;
}
.intro-home-curtain {
	padding-bottom: 4.688vw;
}
.scroller {
	bottom: -1.563vw;
}
.scroller-container {
	width: 7.813vw;
	height: 7.813vw;
}
.projekt-pre-entry:not(:last-child) {
	margin-bottom: 12.5vw;
}

}

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

body {
	font-size: 1.111vw;
}

}*/




@media screen and (min-width: 320px) {

body {
	font-size: calc(14px + 2 * ((100vw - 320px) / 1600));
}
h1, .h1 {
	font-size: calc(32px + 64 * ((100vw - 320px) / 1600));
}
gg, .h2.big {
	font-size: calc(32px + 16 * ((100vw - 320px) / 1600));
}
.big-text p {
	font-size: calc(16px + 4 * ((100vw - 320px) / 1600));
}

}


@media screen and (min-width: 1920px) {

body {
	font-size: 16px;
}
h1, .h1 {
	font-size: 96px;
}
h2.big, .h2.big {
	font-size: 48px;
}
.big-text p {
	font-size: 1.25em;
}

}






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

.projekt-pre-entry {
	margin-bottom: 12vw;
}
.clients-wrapper {
	width: calc(100% + 6vw);
	margin-left: -3vw;
}
.client {
	padding: 0vw 3vw;
}

}


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

.video-js.player-intro .vjs-control-bar {
	padding: 0px 20px;
}
.wrapper-2-3 {
	max-width: 80%;
}
.wrapper-1-3 {
	max-width: 50%;
}

}

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

.projekt-pre-info {
	justify-content: flex-end;
}
.projekt-pre-entry .kategorien {
	display: none;
}
.projekt-pre-info {
	min-height: 90px;
	padding: 0px 30px;
}
.wrapper-4-5,
.wrapper-2-3 {
	max-width: 90%;
}
.wrapper-1-3 {
	max-width: 66.66%;
}

.vt-01 .teaser-images {
	display: block;
}
.vt-01 .teaser-main-image {
	margin-right: 0px;
	margin-bottom: 20px;
}
.side-layer {
	width: 100%;
}
.popup-galerie-wrapper {
	flex-direction: column;
	overflow: hidden;
}
.popup-galerie-img {
	flex: 0 1 auto;
	padding: 15px;
	border-right: none;
	border-bottom: 1px solid rgba(255,255,255,0.5);
	overflow: hidden;
}
.popup-galerie-txt {
	flex: 0 1 auto;
	padding: 15px 15px 75px 15px;
}
.page-selector {
	padding: 30px 0px;
}
.page-selector .arrow-link .arrow {
	margin-left: 10px;
}
.page-selector .arrow-link.left .arrow {
	margin-right: 10px;
}
.page-selector-next {
	justify-content: flex-start;
}
.page-selector-prev {
	justify-content: flex-end;
}
.kontakt-content .kicker {
	overflow: hidden;
	height: 0px;
}
.kontakt-link {
	margin-bottom: 2em;
}
.popup .closer {
	top: unset;
	right: unset;
	bottom: 15px;
	left: 15px;
}
.parallax-banner-media {
	position: relative;
	height: 100%;
}
.parallax-banner-wrapper {
	padding-bottom: 56.25%;
}

.cta-formular-wrapper,
.kontakt-wrapper {
	padding: 60px 20px;
}
.video-text-wrapper,
.bild-text-wrapper {
	display: block;
	width: 100%;
}
.bild-text-wrapper .text {
	margin-top: 30px;
	margin-left: 0px;
}
.bild-text-wrapper.r-2 .text {
	margin-top: 30px;
	margin-right: 0px;
}
.video-text-wrapper .video {
	flex: 1 1 100%;
	margin-right: 0px;
	margin-bottom: 30px;
}
.play-button {
	width: 60px;
	height: 60px;
}
.vt-01 .teaser-img-02 {
	padding-left: 0px;
}

.akkordeon-group.st-03 {
	display: block;
}
.akkordeon-group.st-03 .akkordeon:nth-child(2n) {
	margin-left: 0px;
}

}

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

.main-header, .main-content, .main-footer {
	padding: 0px 20px;
}
.main-content {
	padding-top: 90px;
}
.wrapper-full {
	width: calc(100% + 40px);
	margin-left: -20px;
}
.wrapper-4-5,
.wrapper-2-3,
.wrapper-1-3 {
	max-width: 100%;
}
.sec:not(.sec-intro-home), .sec-about {
	padding: 45px 0px;
}
.sec-projekt-intro, .sec-page-intro {
	padding-top: 120px !important;
}
.page-header {
	display: block;
	margin-bottom: 30px;
}
.breadcrumb {
	margin-top: 10px;
}
.pt-1 {
	padding-top: 10px;
}
.pt-2 {
	padding-top: 30px;
}
.pt-3 {
	padding-top: 45px;
}
.pb-1 {
	padding-bottom: 10px;
}
.pb-2 {
	padding-bottom: 30px;
}
.pb-3 {
	padding-bottom: 45px;
}

.video-js .vjs-control-bar {
	padding: 0px 20px;
}
.main-header {
}
.in-field .button {
	width: 100%;
}
.projekt-pre-ticker-wrapper {
	display: none;
}
.in-field .button {
	min-height: 60px;
}
.in-field input[type="text"],
.in-field input[type="email"] {
	min-height: 60px;
	padding: 20px 0px 0px;
}
.in-field.has-input label {
	transform: translateY(-25px);
}
.button {
	padding: 10px 20px;
}
.menu-controls .button {
	display: none;
}
.ml-content {
	padding: 90px 20px 30px;
}
.sub-items {
	display: block !important;
	padding: 10px 0px 20px !important;
	height: unset !important;
}
.main-item {
	padding-top: 10px;
}
.sub-item {
	font-size: 1.125em;
}
.agentur-infos {
	margin-top: 110px;
}
.main-footer {
	margin-top: 60px;
}
.kontakt-cta {
	right: 20px;
}
.button-wrapper {
	display: block;
}
.button-wrapper .button {
	width: 100%;
}
.button-wrapper .button + .button, .button-wrapper .button + .opener {
	margin-top: 10px;
	margin-left: 0px;
}

#gdpr-cookie-message {
	right: 20px;
}

}

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

.projekt-pre-info {
	min-height: 60px;
	padding: 0px 20px;
}
.closer,
.arrow,
.swiper-prev,
.swiper-next {
	width: 40px;
	height: 40px;
}
.swiper-prev,
.swiper-next {
	flex: 0 0 40px;
}.swiper-prev {
  margin-right: 5px;
}
.swiper-st-01 .swiper-nav {
	right: 10px;
	bottom: 40px;
}
.page-selector .arrow-link h3 {
	font-size: 0.75em;
}
.kontakt-link {
	font-size: 1.125em;
	margin-bottom: 2.75em;
}

}

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

.big-text p {
  font-size: 1.125em;
}
.footer-bottom {
	flex-direction: column;
}
.footer-nav {
	margin-top: 15px;
}
.footer-nav .menu {
	display: block;
}
.footer-nav .menu-item {
	margin-left: 0px;
	text-align: center;
}
.footer-bottom .menu-item:first-child {
	margin-left: 0px;
}
.akkordeon-group.st-03 .akkordeon {
	flex: 0 0 100%;
}
.client {
	flex: 0 0 33.33%;
}
.footer-item img {
	display: none;
}
.galerie-grid.gr-2 .galerie-item {
	flex: 0 0 100%;
}
.galerie-grid.gr-3 .galerie-item {
	flex: 0 0 100%;
}
.galerie-grid.gr-4 .galerie-item {
	flex: 0 0 50%;
}
.agentur-infos {
	margin-top: 50px;
}
.akkordeon-group.st-03 .akkordeon-trigger-wrapper {
	padding: 10px 0px;
}
.akkordeon-group.st-03 .akkordeon-trigger .acc-opener {
	margin-top: 10px;
}
.akkordeon-group.st-01 .akkordeon-trigger .acc-opener {
	width: 15px;
	left: 15px;
}
.bullet-group {
	display: block;
}
.bullet-group.st-01 .bullet:nth-child(2n) {
	margin-left: 0px;
}
.sec-title h2 {
	text-align: left;
	margin-left: 0;
}
.sec-title p {
	text-align: left !important;
}
.kicker span {
	flex: 0 1 auto;
}
.kicker span:nth-child(1) {
	margin-right: 0px;
}
.kontakt-cta {
	width: calc(100% - 40px);
}
.home .sec-about {
	text-align: left;
}
#gdpr-cookie-message {
	padding: 30px 20px 20px;
	max-width: calc(100% - 40px);
}
#gdpr-cookie-message button {
	min-height: 40px;
	margin-right: 5px;
	padding: 10px 15px;
}
#gdpr-cookie-message p {
	font-size: 12px;
	line-height: 1.5em;
}
#gdpr-cookie-message p a {
	text-decoration: underline;
}

}

/** IE FIXES **/

@media screen\0, @media screen\9 {
	h1, h2, h3, p {
		width: 100%;
	}
	img {
		flex-shrink: 0;
	}
}