/*
 Theme Name:   Geschichten stärken
 Description:  Geschichten stärken WordPress Theme (2026)
 Author:	   splendid
 Author URI:   https://splendid.claims
 Version:      1.0.0
 Text Domain:  stiftung

*/
/**	____________________________________________________________
 *
 *	INHALTE
 *
 *
 *	01 — BASICS
 *	02 — TYPO
 *	03 — GRID
 *	04 — HEADER, FOOTER & MENÜS
 *	05 — UX ELEMENTE
 *	06 — SEITEN
 *	07 — BLÖCKE
 *	08 — RESPONSIVE
 *
 *	____________________________________________________________
*/



.scroll-slider-media img,
.scroll-slider-media-mobile img {
	width: 100%;
	height: 100vh;
	object-fit: cover;
}
.scroll-slider-media-mobile {
	display: none;
}
.block-sticky {
	position: sticky;
	top: 0;
	z-index: 0;
}
.scroll-slider-content {
	margin-top: -100vh;
}
.scroll-slider-entry {
	position: relative;
	width: 100%;
	height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	color: rgb(255,255,255);
}
.text-1-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.scroll-slider-entry p {
	text-align: justify;
}



/**
 *	01 — BASICS
 *	Basiselemente
 *	____________________________________________________________
*/

.icon-link {
	display: flex;
	align-items: center;
}
.icon-link .btn {
	margin-right: var(--0-5em);
}

*, :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-dunkelblau: rgb(32,37,49);
}

/* Box Farben */

.opt-bg-cl-1 {
	background-color: var(--cl-schwarz);
}
.opt-bg-cl-2 {
	background-color: var(--cl-weiss);
}

/* Text Farben */

.f-cl-schwarz {
	color: var(--cl-schwarz);
}
.f-cl-weiss {
	color: var(--cl-weiss);
}


/*  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');
}
@font-face {
  font-family: 'editorial';
  font-style: light;
  font-weight: 300;
  src: url('fonts/pp-editorial-ultralight.otf') format('opentype');
}

body {
    font-family: 'neue-montreal';
	font-weight: 375;
	line-height: 1.25em;
}

/* Size Settings */

:root {

	--body-l:	20;	/* px */
	--body-s:	15;
	--v-bd:		calc(1px * var(--body-s) + (var(--body-l) - var(--body-s)) * ((100vw - 320px) / 1120));
	--v-h1:		6em;
	--v-h2:		3em;
	--v-h3:		2em;
	--v-h4:		1.25em;
	--v-h5:		1.125em;

}

body {
	font-size: var(--v-bd);
}

@media screen and (min-width: 1440px) {

:root {
	--v-bd: calc(var(--body-l) * 1px);
}

}

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 {
    font-family: 'editorial';
	margin: 0.5em 0em 1em 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;
}
h2, .f-h2 {
	margin-bottom: 1em;
}
h2, .f-h2,
h3, .f-h3,
h4, .f-h4 {
	font-weight: 375;
	line-height: 1em;
}

/* Paragraphs */

p {
	max-width: 960px;
    margin: 0 0 1.25em;
}
.ul {
	text-decoration: underline;
}
.kicker {
	margin-bottom: 1em;
}

/* Styles */

.f-s1 {
	font-size: var(--v-bd);
	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;
}
.f-w-light {
	font-weight: 375;
}

.f-link-std {
	font-weight: 500;
	text-decoration: underline;
}

/* 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: "neue-montreal";
	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: 520;
	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-vert .btn):not(.btn-wrapper-box .btn) {
	margin-top: var(--1-5em);
}
.btn .dot {
	position: absolute;
	left: calc(var(--1em) * 1.25 - 4px);
	width: 8px;
	height: 8px;
	border-radius: 50%;
}

/*-- 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);
}
.btn.btn-fill.btn-cl-weiss .dot,
.btn.btn-outline.btn-cl-schwarz .dot {
	background-color: var(--cl-schwarz);
}
.btn.btn-fill.btn-cl-schwarz .dot,
.btn.btn-outline.btn-cl-weiss .dot {
	background-color: var(--cl-weiss);
}

/*-- Hover Effect 1 --*/

.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;
}

/*-- Hover Effect 2 --*/

.btn.btn-outline.btn-effect-2 {
	position: relative;
	z-index: 1;
}
.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-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-schwarz.btn-effect-2:after {
	background-color: var(--cl-schwarz);
}
.btn.btn-outline.btn-cl-weiss.btn-effect-2:hover {
	color: var(--cl-schwarz);
}
.btn.btn-outline.btn-cl-schwarz.btn-effect-2:hover {
	color: var(--cl-weiss);
}
.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: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(--3em);
	border-radius: 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);
}
.btn.btn-form-box {
	width: 100%;
	height: var(--6em);
}

/*-- 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 .btn:not(:last-child) {
	margin-right: var(--1em);
}
.btn-wrapper-vert .btn:not(:first-child) {
	margin-top: var(--1em);
}

/*-- 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;
}

/* 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;
	}
}

/*-- Gaps --*/

body {
}

:root {
	--sidegaps: var(--2em);
}

.main-header,
.main-content,
.main-footer {
	padding: 0px var(--sidegaps);
}

.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);
}

/* Wrapper */

.wrapper {
	width: 100%;
	margin: 0 auto;
}

.wrapper-2048 { max-width: 2048px; }
.wrapper-1440 { max-width: 1440px; }
.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%; }

/* 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);
}

/* Columns */

.col-wrapper {
	display: flex;
	justify-content: space-between;
}
.col-wrap {
	flex-wrap: wrap;
}
: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-half-right {
	width: calc(50% - var(--1-5em));
	margin-left: auto;
}

/* 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 */

.topbar {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	height: var(--2em);
	color: var(--cl-weiss);
	background-color: var(--cl-dunkelblau);
}
.toplogo {
	position: relative;
	z-index: 3;
	display: flex;
	justify-content: center;
	align-items: center;
	height: var(--6em);
	padding: var(--1em) 0px;
}
.toplogo svg {
	width: auto;
	height: var(--3em);
}
.main-header {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 4;
	width: 100%;
	/*transform: translateY(0%);
	transition: transform 0.2s, background-color 0.2s, color 0.2s;*/
	transition: background-color 0.2s, color 0.2s;
}
.main-bar {
	position: relative;
	z-index: 3;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	width: 100%;
	height: var(--3em);
	padding: var(--1em) 0px var(--0-5em);
	border-bottom: 1px solid var(--cl-weiss);
}

.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 {
	display: flex;
}
/*.main-bar .slot-1,
.main-bar .slot-3 {
	flex: 0 0 25%;
}
.main-bar .slot-2 {
	flex: 0 0 50%;
	justify-content: center;
}
.main-bar .slot-3 {
	justify-content: flex-end;
}
.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;
}
.menu-wrapper-1.hov-effect-1 .menu-item a {
	position: relative;
	display: block;
	padding: 0px var(--0-5em);
}
.menu-wrapper-1.hov-effect-1 .menu-item a:after {
	content: "";
	position: absolute;
	bottom: calc(var(--0-5em) * -1);
	right: 0px;
	transform-origin: center;
	width: 100%;
	height: 4px;
	background-color: var(--cl-weiss);
	transform: scaleX(0%);
	transition: transform 0.2s;
}
.menu-wrapper-1.hov-effect-1 .menu-item a:hover:after {
	transform: scaleX(100%);
}

/* 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 {
}

.footer-wrapper .row-1 {
	display: flex;
	justify-content: center;
	margin-top: var(--3em);
}
.footer-wrapper .row-2 {
	display: flex;
	margin-top: var(--3em);
	padding-top: var(--1em);
	border-top: 1px solid var(--cl-schwarz);
}
.footer-wrapper .row-2 .col-1 {
	flex: 0 0 50%;
}
.footer-wrapper .row-2 .col-2,
.footer-wrapper .row-2 .col-3 {
	flex: 0 0 25%;
}
.footer-wrapper .row-3 {
	display: flex;
	margin-top: var(--9em);
	padding-bottom: var(--1em);
}
.footer-wrapper .row-3 .col-1,
.footer-wrapper .row-3 .col-2,
.footer-wrapper .row-3 .col-3 {
	flex: 0 0 33.333%;
}
.footer-wrapper .col-2 {
	display: flex;
	justify-content: center;
}
.footer-wrapper .row-3 .col-3 {
	display: flex;
	justify-content: flex-end;
}

/* 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 {
}

/* LIST */

/* Style 1: Std. */

.list.st-1 li {
}

/* 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);
}



/**
 *	06 — SECTIONS & SEITEN
 *	Startseite, Unterseiten, Blog, Singles
 *	____________________________________________________________
*/

/* BLOG */

.intro-meta-wrapper {
}


/**
 *	07 — BLÖCKE
 *	Module, bzw. WordPress Blöcke
 *	____________________________________________________________
*/


/* ALLG. */

/* Block Wrapper */

.block {
	position: relative;
	min-width: 100%;
}
.block-media,
.block-overlay {
	position: absolute;
	top: 0px;
	left: 0px;
	height: 100%;
}
.block-media {
	z-index: 1;
}
.block-overlay {
	z-index: 2;
	min-width: 100%;
	background: linear-gradient(rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.2) 10%, rgba(255,255,255,1) 100%);
}
.block-content {
	position: relative;
	z-index: 3;
}
.bl-header {
	margin-bottom: var(--3em);
}
.block-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

/* INTRO */

/* Main */

.block-intro-1 {
	z-index: 0;
	min-height: calc(100vh - var(--2em));
	margin-top: calc(var(--1em) * -9);
	aspect-ratio: 1/1;
	max-width: 100%;
	min-height: 100vh;
	margin-bottom: -240px;
}
.intro-1-wrapper {
	display: flex;
	flex-direction: column;
	min-height: calc(100vh - var(--2em));
	padding-top: var(--12em);
	padding-bottom: var(--2em);
}
.intro-1-wrapper .row-2 {
	display: flex;
	align-items: last baseline;
	margin-top: var(--3em);
}
.intro-1-wrapper .row-2 .col-1 {
	flex: 1 1 50%;
}
.intro-1-wrapper .row-2 .col-2,
.intro-1-wrapper .row-2 .col-3 {
	flex: 1 1 25%;
}
.intro-1-wrapper .row-2 .col-3 {
	text-align: right;
}
.intro-1-wrapper .row-3 {
	display: flex;
	margin-top: auto;
}
.intro-1-wrapper .row-3 .col {
	flex: 0 0 50%;
}


/* TEXT (STD.) */

.text-1-wrapper {
}
.text-1-wrapper .row-1 h2 {
	max-width: calc(50% + 240px);
	margin-left: auto;
	text-indent: 240px;
}
.text-1-wrapper .row-2 {
	margin-top: var(--4em);
	padding-top: var(--1em);
	border-top: 1px solid var(--cl-schwarz);
}
.text-1-wrapper p {
	max-width: 600px;
}

.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 */

.bild-banner-1-wrapper {
	min-height: 75vh;
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--cl-weiss);
}

/* BILD & TEXT 1 (...) */

.bt-1-wrapper {
}
.bt-1-wrapper .col-1 h2 {
	max-width: 480px;
}
.bt-1-wrapper .col-1 p {
	max-width: 360px;
}
.bt-1-wrapper .col-1 {
	display: flex;
	flex-direction: column;
}
.bt-1-wrapper .col-1 .btn-wrapper {
	margin-top: auto;
}

/* BILD & TEXT 2 (...) */

.bt-2-wrapper {
}

/* BILD & TEXT 3 (...) */

.bt-3-wrapper .row-2 {
}

/* BILD & TEXT 4 (...) */

.bt-4-wrapper {
}

/* BILD & TEXT 5 (...) */

.bt-5-wrapper {
}

/* BILD 1 */

.bilder-1-wrapper .row-1 {
}

/* BILD 2 */

.bilder-2-wrapper .row-1 {
}


/* KLAPPTEXTE */

/* Allgemein */

.akk-trigger {
	cursor: pointer;
}

/* Header */

.akk-header {
	margin-bottom: var(--1em);
}

/* Style 01 - Trenner */

.akk-1-wrapper {
}

/* Akk (Std.) */

.akk-1-wrapper .row-1 {
	padding-top: var(--1em);
	border-top: 1px solid var(--cl-schwarz);
}
.akk-1-wrapper .row + .row {
	margin-top: var(--3em);
}
.akk-trigger.active .akk-trigger-text-a,
.akk-trigger .akk-trigger-text-b {
	display: none;
}
.akk-trigger .akk-trigger-text-a,
.akk-trigger.active .akk-trigger-text-b {
	display: block;
}

/* Style 01 - Std. */

.akk.st-1 {
	border-top: 1px solid var(--cl-schwarz);
}
.akk.st-1:last-child {
	border-bottom: 1px solid var(--cl-schwarz);
}
.akk.st-1 .akk-trigger {
	display: flex;
	justify-content: space-between;
	padding: var(--1em) 0px var(--0-5em) 0px;
	overflow: hidden;
}
.akk.st-1 .akk-trigger .col {
	display: flex;
	justify-content: space-between;
}
.akk.st-1 .akk-trigger-text {
	padding-right: var(--1em);
}
.akk.st-1 .akk-content {
	padding: var(--1-5em) 0px;
}
.akk.st-1 .akk-hint {
	opacity: 0;
	transform: translateY(50%);
	transition: transform 0.2s, opacity 0.2s;
}
.akk.st-1 .akk-trigger:hover .akk-hint {
	opacity: 1;
	transform: translateY(0%);
}
.akk.st-1 .akk-trigger.active .akk-hint {
	transform: rotate(180deg);
}

/* PRELOADER */

.preloader {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 10;
	width: 100%;
	height: 100vh;
	display: flex;
	align-items: center;
	padding: var(--1em) var(--3em);
	background-color: var(--cl-dunkelblau);
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	transition: clip-path 1s 0s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.preloader.hidden {
	display: none;
}
.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;
	flex-direction: column;
	align-items: center;
}
.preloader .train {
	flex: 1 0 auto;
	display: flex;
	align-items: center;
	height: 180px;
	padding: var(--1em);
	transform-origin: top;
	transform: scaleY(1);
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.preloader .trainline {
	width: 1px;
	height: 100%;
	background-color: var(--cl-weiss);
	transform-origin: bottom;
	transform: scaleY(0);
}

.preloader .name.c-up span,
.preloader .number.c-up span {
	transform: translateY(-100%);
}
.preloader .track.c-up {
	background-color: transparent;
}
.preloader .train.c-up {
	transform: scaleY(0);
}
.preloader.c-up {
	clip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);
}

.intro-1-wrapper:not(.no-pl) .row-1 .text {
	overflow: hidden;
}
.intro-1-wrapper:not(.no-pl) h1 {
	display: block;
	transform: translateY(100%);
	transition: opacity 0.4s, transform 0.4s;
}
.intro-1-wrapper:not(.no-pl).c-up h1 {
	transform: translateY(0%);
}

.intro-1-wrapper:not(.no-pl) .swiper-slide {
	overflow: hidden;
}
.intro-1-wrapper:not(.no-pl) .swiper-slide img {
	transform: translateY(20%);
	transition: transform 1.5s;
}
.intro-1-wrapper:not(.no-pl).c-up .swiper-slide img {
	transform: translateY(0%);
}



/**
 *	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%;

}
.opt-width-3 {
	max-width: 50%;
}

/* Type */

:root {
	--v-h1: 4em;
	--v-h2: 2em;
}

/* Framework */

.toplogo svg {
	height: var(--4em);
}
.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.btn-size-medium {
	height: calc(var(--1em) * 3);
}
.block-intro-1 {
	margin-bottom: -60px;
}
.footer-wrapper .row-2 .col-2,
.footer-wrapper .row-3 .col-2 {
	flex: 0 0 50%;
}
.footer-wrapper .row-2 .col-3,
.footer-wrapper .row-3 .col-3 {
	display: none;
}
/*.btn {
	width: 100%;
}*/

/* Modul: Text (Std.) */

.text-1-wrapper .row-1 h2 {
	text-indent: 50%;
}
.text-1-wrapper p {
	max-width: 100%;
}
.text-1-wrapper .row-2 {
	display: block;
}
.text-1-wrapper .row-2 .col-1 {
	margin-bottom: 1em;
}

/* Modul: Bild Text 1 */

.bt-1-wrapper .row-1 {
	display: block;
}
.bt-1-wrapper .row-1 .col-2 {
	margin-top: 1em;
}

/* Modul: Akkordeon */

.akk-1-wrapper .row-1,
.akk-1-wrapper .row-2 {
	display: block;
}

/* Modul: Intro (Main) */

.intro-1-wrapper .row-1 {
	padding-top: var(--1-5em);
}
.intro-1-wrapper .row-2 .col-1 {
	display: none;
}
.intro-1-wrapper .row-3 {
	display: none;
}

/* Modul: Scroll Slider */

.scroll-slider-media {
	display: none;
}
.scroll-slider-media-mobile {
	display: block;
}

/* Modul: Blog Teaser */


}

@media screen and (max-width: 480px) {

/* Grid */

.crop-2-1 {
	aspect-ratio: 1 / 1;
}
.crop-3-1 {
	aspect-ratio: 2 / 1;
}
.opt-width-3 {
	max-width: 100%;
}
.text-1-wrapper .text {
	width: 100%;
}

/* UX Elements */

.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%;
}

}

/** IE FIXES **/
@media screen\0, @media screen\9 {
    h1, h2, h3, p {
        width: 100%;
    }
    img {
        flex-shrink: 0;
    }
}