/* //////////////////////////////////// ALLGEMEIN //////////////////////////////////// */
html {
	box-sizing: border-box;
}
*, *:before, *:after {
	box-sizing: inherit;
}
body{
	font-family: "mr-eaves-modern", sans-serif;
	color: #000;
	margin: 0px;
	line-height: 1.4;
	font-size: 25px;
	font-weight: 200;
	scroll-behavior: smooth;
	width: 100%;
  	overflow-x: hidden; /* Verhindert horizontales Scrollen */
  	background: #fff;
	position: relative;
}
h1, h2, h3, h4, h5, h6 {
	font-family: "mr-eaves-modern", sans-serif;
	/*font-family: "palomino-script", sans-serif;*/
	font-size: 2.5rem;
	color: #C32727;
	margin-bottom: 40px;	
	line-height: 1;
	text-align: left;
	font-weight: 400;
}
.container-wrapper h2, h2 {
	line-height: 0.8;
}
.highlighted {
	font-family: "mr-eaves-modern", sans-serif;
    /*font-family: "palomino-script", sans-serif;*/
	font-size: 50px;
	font-weight: 600;
}
.remaining {
    font-family: "mr-eaves-modern", sans-serif;
	font-size: 36px;
	font-weight: 500;
    margin-left: 80px;
	color:#000;
    display: inline-block; /* Damit margin-left funktioniert */
}
div p{
	margin: 0px 0px 15px 0px;
}
div p:last-child, p:last-child{
	margin: 0 auto;
}
img, svg, video{
	max-width: 100%;
	height:auto;
}
a{
	color: #C32727;
	text-decoration: none;
}
a:active, a:hover {
	color: #666;
}
ul{
	padding-left: 20px;
	margin: 0 auto 15px;
}
.no_scroll{
	height: 100vh;
	overflow: hidden;
}
.textcenter{
	text-align: center;
}
/* //////////////////////////////////// CONTENT //////////////////////////////////// */
.w1280{
	max-width: 1280px;
	margin: 0 auto;
	position:relative;
	padding: 0px 40px;
}
.w1024{
	max-width:1024px;
	margin:0 auto;
	position:relative;
}
.w960{
	max-width:960px;
	margin:0 auto;
	position:relative;
}
.w800{
	max-width:800px;
	margin:0 auto;
	position:relative;
}
.w700{
	max-width:700px;
	margin:0 auto;
	position:relative;
}
.margin_oben{
	margin-top: 100px;
}
.margin_unten{
	margin-bottom: 100px;
}
.margin_unten_half{
	margin-bottom: 50px;
}
.fullwidth{
	width:100%;
	background-repeat:no-repeat;
	background-size:cover;
	background-position: center;
	position: relative;
}
.bg_padding{
	padding: 100px 0;
}
.textblock{
	margin-left:60px;
}

/* //////////////////////////////////// Header //////////////////////////////////// */
.header{
	position: absolute;
	z-index: 9;
	top: 0;
	left: 0;
	width: auto;
	text-align: center;
}
.header_logo{
	position: absolute;
	z-index: 8;
	bottom: 20px;
	left: calc(5vw + 40px);
	margin-top: 40px;
	display: inline-block;
}
.header_logo svg{
	width: 300px;
	height: auto;
}
/*.header_logo svg {
    filter: drop-shadow(0 0 30px rgba(255, 255, 255, 1));
}*/

.open_menu{
	position:fixed;
	top: 0;
	left: 60px;
	z-index: 10;
	display: block;
}
.open_menu svg{
	width: 40px;
	height: auto;
}
.close_menu{
	position:absolute;
	top: 40px;
	left: 40px;
	z-index: 10;
	display: block;
}
.close_menu{
	cursor: pointer;
}
.menu {
    display: none;
    width: 400px;
    max-width: calc(100% - 60px);
    border-right: 6px solid #C32727;
    background-color: #fff;
    position: fixed;
    z-index: 11;
    height: 100vh;
    padding: 0 40px 0;
    left: -400px; /* Startposition außerhalb des Bildschirms */
	top: 0;
}
.svp{
	position:absolute;
	right: -40px;
	top: 40px;
}
.svp svg{
	width:80px;
	height: auto;
}
.menu-menu-de-container, .menu-menu-it-container{
	display:table;
	height: 100%;
	text-align: right;
	width: 100%;
}
.nav-menu{
	list-style: none;
	padding: 0;
	margin: 0;
	display: table-cell;
	vertical-align: middle;
}
.nav-menu li{
	cursor: pointer;
	margin-bottom: 20px;
}
.nav-menu li:last-child{
	margin: 0;
}
.nav-menu li a{
	display: block;
	line-height: 1;
	color: #000;
	font-size: 30px;
	text-transform: uppercase;
}
.nav-menu li a:hover{
	color:#C32727;
}
.socials{
	position:absolute;
	bottom: 80px;
	right: 40px;
	z-index: 12;
}
.socials a{
	display: inline-block;
}
.socials a:last-child{
	margin-left: 10px;
}
.socials svg{
	width: auto;
	height: 25px;
}

#languages{
	position: absolute;
	left: 40px;
	bottom: 80px;
}
#languages a{
	text-transform: lowercase;
}


#languages.outer_lang {
  left: auto;
  bottom: auto;
  right: 40px;
  top: 20px;
  z-index: 9;
}
#languages.outer_lang a{
	color: #ffffff;
	border-bottom: 1px solid #FFFFFF;
	line-height: 1;
}
#languages.outer_lang a:hover{
	color: #C32727;
	border-bottom: 1px solid #C32727;
}
/* //////////////////////////////////// Button //////////////////////////////////// */
.button{
	display: inline-block;
	width: auto;
	position: relative;
	cursor: pointer;
	padding: 2px 20px;
	font-size: 20px;
	color:#000;
	font-weight: 500;
	border: 1px solid #000;
}
.button:hover{
	color:#C32727;
}


/* //////////////////////////////////// Inhalt //////////////////////////////////// */
.container1,
.container2,
.container3,
.container4,
.container5,
.container6,
.container7,
.container8,
.container9,
.container10 {
	width: 110vw; /* Noch breiter, um Keile sicher zu entfernen */
	position: relative;
	left: -5vw; /* Zentriert die Überbreite */
	overflow: hidden;
}
.container1,
.container3,
.container4,
.container7,
.container10{
	transform: rotate(-2deg);
}
.container5,
.container6{
	transform: rotate(2deg);
}
.container3 .contentright,
.container4 .contentright,
.container7 .contentright,
footer .w1280{
	transform: rotate(2.2deg); /* Entgegenwirken der Container-Drehung */
}
.container6 .contentright{
	transform: rotate(-2.2deg); /* Entgegenwirken der Container-Drehung */
}
.container1 {
	height: 80vh;
	top: -80px; /* Weiter hochgeschoben, um Keile zu verhindern */
}
.container1 img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
}
.lorenz{
	position:absolute;
	bottom: 0;
	right: 20%;
	height: 50vh;
	width: auto;
	z-index: 8;
}
.container3 {
	height: auto;
	max-height:750px;
}
.container4 {
	height: auto;
}
.container4 .contentleft,
.container7 .contentleft{
	max-height:550px;
}
.container6 .contentleft{
	max-height:690px;
}
.container4 .contentright,
.container7 .contentright{
	margin-bottom:170px;
}
.container5{
	height: 80vh;
	min-height: 800px;
	top: -90px;
}
.container5 img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.container6 {
	height: auto;
	max-height:750px;
	top:-90px;
}
.container-wrapper {
	max-width: 1280px;
	width: 100%;
	display: flex;
	flex-direction: row;
	justify-content: start;
}
.container4 .container-wrapper,
.container7 .container-wrapper{
	flex-direction: row-reverse;
}
.container-wrapper h2{
	margin-top:80px;
}
.contentleft {
	width: 46%;
	height: auto;
	position: relative;
	overflow: hidden;
	line-height: 0;
}
.contentleft img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
}
/* Schräge am unteren Rand von .contentleft */
.contentleft::after {
	content: "";
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 100%;
	height: 100px;
	background: inherit;
	transform: skewY(-2deg);
	transform-origin: bottom left;
}
.contentright {
	width: 54%;
	padding: 0 80px 40px;
    transform-origin: left center; /* Damit es sich nicht verschiebt */
	/* Anti-Aliasing verbessern */
    backface-visibility: hidden;
    will-change: transform;
}
.termin{
	border-left:1px solid #C32727;
	padding-left: 30px;
	position: relative;
	padding-bottom: 30px;
}
.termin p{
	margin:0;
}
.termindot{
	position:absolute;
	top: -10px;
	left:-10px;
	z-index: 8;
}
.termindot svg{
	width:20px;
	height: 20px;
}
.werdegang {
	display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(255, 255, 255, 0.9);
	z-index: 10;
	overflow: scroll;
	padding: 100px 0 0;
}
.flex_box_werdegang{
	display: flex;
	align-items: center;
    justify-content: top;
    flex-direction: column;
}
.close_mir {
    cursor: pointer;
    position: absolute;
    right: 20px;
	top: 40px;
	z-index: 10;
	display: block;
}
.close_mir svg{
	height: auto;
}

.werdegang ul {
	--col-gap: 2rem;
	--row-gap: 2rem;
	--line-w: 0.25rem;
	display: grid;
	grid-template-columns: var(--line-w) 1fr;
	grid-auto-columns: max-content;
	column-gap: var(--col-gap);
	list-style: none;
	width: min(60rem, 90%);
	margin-inline: auto;
	padding: 50px 0 0;
	margin: 0;
}
/* line */
.werdegang ul::before {
	content: "";
	grid-column: 1;
	grid-row: 1 / span 20;
	background: rgb(225, 225, 225);
	border-radius: calc(var(--line-w) / 2);
}
/* row gaps */
.werdegang ul li:not(:last-child) {
	margin-bottom: var(--row-gap);
}
/* card */
.werdegang ul li {
	grid-column: 2;
	--inlineP: 1.5rem;
	margin-inline: var(--inlineP);
	grid-row: span 2;
	display: grid;
	grid-template-rows: min-content min-content min-content;
}
/* date */
.werdegang ul li .date {
	margin-inline: calc(var(--inlineP) * -1);
	text-align: center;
	background-color: #C32727;
	display: grid;
	place-content: center;
	position: relative;
	border-radius: 10px;
	line-height: 1;
	padding: 8px 0 5px;
	color:#fff;
}
/* circle */
.werdegang ul li .date::after {
	content: "";
	position: absolute;
	width: 2rem;
	aspect-ratio: 1;
	background: #fff;
	border: 0.3rem solid #C32727;
	border-radius: 50%;
	top: 50%;
	transform: translate(50%, -50%);
	right: calc(100% + var(--col-gap) + var(--line-w) / 2);
}
/* title descr */
.werdegang ul li .descr {
	background: var(--bgColor);
	position: relative;
	padding: 20px 0;
	color:#000;
}
.werdegang ul li .descr {
	padding-block-end: 1.5rem;
}
.werdegang ul li .descr::before {
	z-index: -1;
	bottom: 0.25rem;
}
@media (min-width: 40rem) {
	.werdegang ul {
		grid-template-columns: 1fr var(--line-w) 1fr;
	}
	.werdegang ul::before {
		grid-column: 2;
	}
	.werdegang ul li:nth-child(odd) {
		grid-column: 1;
	}
	.werdegang ul li:nth-child(even) {
		grid-column: 3;
	}
	/* start second card */
	.werdegang ul li:nth-child(2) {
		grid-row: 2/4;
	}
	.werdegang ul li:nth-child(odd) .date::before {
		clip-path: polygon(0 0, 100% 0, 100% 100%);
		left: 0;
	}
	.werdegang ul li:nth-child(odd) .date::after {
		transform: translate(-50%, -50%);
		left: calc(100% + var(--col-gap) + var(--line-w) / 2);
	}
}




.beige{
	background-color: #EDDEE1;
}
.grey{
	background-color: #F2F2F2;
}

/* //////////////////////////////////// Swiper //////////////////////////////////// */
.swiper {
	margin-left: auto;
	margin-right: auto;
	position: relative;
	overflow: hidden;
	list-style: none;
	padding: 0;
	z-index: 1;
	display: block;
}
.swiper-vertical > .swiper-wrapper {
	flex-direction: column;
}
.swiper-wrapper {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: 1;
	display: flex;
}
.swiper-slide {
	flex-shrink: 0;
	width: 100%;
	height: 100%;
	position: relative;
	display: block;
}
.swiper_nav{
	width: 100%;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 50px;
}
.swiper_arrows{
	width: 10px;
	line-height: 0;
	cursor: pointer;
}
.swiper-pagination{
	margin: 0 20px;
	line-height: 0;
}
.swiper-pagination-bullet{
	width: 12px;
	height: 12px;
	border-radius: 15px;
	background-color: #000;
	display: inline-block;
	vertical-align: middle;
	margin: 0 10px;
	cursor: pointer;
}
.swiper-pagination-bullet:hover, .swiper-pagination-bullet-active, .swiper-button-disabled{
	opacity: 0.5;
}





/* //////////////////////////////////// Footer //////////////////////////////////// */
footer{
	line-height: 1.2;
}
footer a:hover{
	color:#000;
}
.footer_logo{
	margin-bottom: 30px;
}
.footer_logo svg{
	width:200px;
	height: auto;
	margin-bottom: 30px;
}
.adresse{

}
.impressum{
	display: inline-block;
}
.impressum a, .impressum span{
	display: inline-block;
	vertical-align: middle;
	font-size:18px;
}
.impressum span{
	margin: 0 5px;
}
.footerbar{
	position:absolute;
	bottom: -105px;
	height: 150px;
	background-color: #F2F2F2;
	z-index: -1;
	width: 100%;
}

#wpadminbar{
	display:none!important;
}




/* //////////////////////////////////// Anliegen Formular //////////////////////////////////// */
.custom-form {
  margin: auto;
}
.custom-form a:hover{
	color:#666;
}
.form-group {
  margin-bottom: 20px;
}
label {
  
}
textarea, input{
	width:100%;
	font-family: "mr-eaves-modern", sans-serif;
	color: #000;
	line-height: 1.4;
	font-size: 25px;
	font-weight: 200; 
}
.short-field, .long-field {
  padding: 8px;
  border: 1px solid #ccc;
  background: #fff;
}
.short-field {
  width: 200px;
}
.long-field {
  width: 100%;
}

:root {
  --radio-color: #C32727;
}
.custom-form input[type="radio"] {
  appearance: none;
  width: 20px;
  height: 20px;
  outline: 2px solid var(--radio-color);
  outline-offset: 2px;
  border-radius: 2px;
  transition:all 0.5s ease-in-out;
  border-radius:50%;
}
.custom-form input[type="radio"]:checked {
  background: var(--radio-color);
  transform:rotateZ(180deg);
  border-radius:50%;
}
.custom-form input[type="radio"]#m {
  --radio-color: #C32727;
}
.custom-form input[type="radio"]#w {
  --radio-color: #C32727;
}
.custom-form input[type="radio"]#keine_angabe {
  --radio-color: #C32727;
}
.wpcf7-list-item{
	margin:0 25px 0 0;
}
.wpcf7-list-item-label{
	position:relative;
	top:-3px;
	left: 5px;
}
.check_anfrage{
	float:left;
	width: 40px;
}
.check_anfrage_text{
	float:left;
	width:calc(100% - 40px);
	position:relative;
	top:-3px;
	left: 5px;
}
.custom-form input[type="checkbox"] {
  appearance: none;
  width: 20px;
  height: 20px;
  outline: 2px solid var(--radio-color);
  outline-offset: 2px;
  border-radius: 2px;
  transition:all 0.5s ease-in-out
}
.custom-form input[type="checkbox"]:checked {
  background: var(--radio-color);
  transform:rotateZ(180deg);
}
.anfragen_btn2{
	margin-top:40px;
}
.wpcf7-not-valid-tip {
  color: #C32727;
  font-size: 1em;
  font-weight: normal;
  display: block;
}
input:focus, 
textarea:focus {
    outline: none;
    border: 1px solid #C32727; /* Graue Umrandung statt blauem Rand */
}

.anliegenlink{
	position: absolute;
	left: 40px;
	bottom: 40px;
	width: calc(100% - 80px);
}
.anliegenlink a{
	display:block;
	background-color: #C32727;
	border: 1px solid #C32727;
	line-height: 1;
	width: 100%;
	padding: 2px 20px;
	font-size: 20px;
	color:#fff;
	font-weight: 500;
	position: relative;
	cursor: pointer;
	text-align: center;
}
.anliegenlinkseite{
	position: relative;
}
.anliegenlinkseite a{
	display:inline-block;
	background-color: #C32727;
	border: 1px solid #C32727;
	line-height: 1;
	padding: 10px 40px;
	font-size: 20px;
	color:#fff;
	font-weight: 500;
	position: relative;
	cursor: pointer;
	text-align: center;
}
.anliegenlinkseite a:hover{
	display:inline-block;
	background-color: #fff;
	border: 1px solid #C32727;
	line-height: 1;
	padding: 10px 40px;
	font-size: 20px;
	color:#C32727;
	font-weight: 500;
	position: relative;
	cursor: pointer;
	text-align: center;
}
.button:hover{
	color:#C32727;
	background-color: #fff;
}

/* //////////////////////////////////// CLEARFIX do not group these rules //////////////////////////////////// */
.clearfix:before,
.clearfix:after {
	content:"";
	display:table;
}
.clearfix:after {
	clear:both;
}
.clearfix {
	zoom:1; /* For IE 6/7 (trigger hasLayout) */
}