/* Google Fonts nachladen nicht DSGVO konform ohne Cookie Meldung...
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&display=swap');*/
:root{
	--base-color: #E21E25;
	--base-font-size: 20px;
	--headline-color: #4D6867;
}


body {
	margin: 0;
	padding: 0;
}

/*-----------------------hier wird die Schriftart �berschrieben, ansonsten wird es von Vaadin geladen----------------------*/
html {
	/*font-family: 'Open Sans', sans-serif !important;*/
	font-weight: 300 !important;
	color: #464646 !important;
	font-size: 20px!important;	
	line-height: 155% !important;
}

.maintheme.v-app, .maintheme.v-app-loading {
	font-size: var(--base-font-size) !important;
}


#top{
	-webkit-user-select: text;
	-moz-user-select: text;
	-ms-user-select: text;
	user-select: text;
}

h1, h2, h3, h4{
    color: #141414;
	line-height: 1.1!important;
}

h1, h2, h3{
    font-weight: 200!important;
}

h1{
	font-size: 2.4em!important;
    margin-top: 1.4em;
    margin-bottom: 1em;
    letter-spacing: -0.03em;
}


h2{
    display: block;
	font-size: 1.6em !important;
    margin-top: 1.6em;
    margin-bottom: 0.77em;
    letter-spacing: -0.02em!important;
}

h3{
    font-size: 1.2em!important;
    margin-top: 1.8em;
    margin-bottom: 0.77em;
    letter-spacing: 0; 
}

h4{
    font-weight: 400!important;
    font-size: 0.8em!important;
    text-transform: uppercase;
    letter-spacing: 0;
    margin-top: 2.4em;
    margin-bottom: 0.8em;

}

.menueleistentext{
	font-size: 23pt;
}

.fliesstext{
	font-size: 28pt;
}
/*---------------------------------AdminSection----------------------*/
.adminSection{
	background-color: #6f6f6f;
}

.logoutButton{
	background: transparent;
	color: white;
	border: none;
}

.logoutButton:hover {
    cursor: pointer;
    background: #5a5a5a;
}

/*---------------------------------Edit Icon----------------------*/
.edit_icon
{
	width: 25px;
	height: 25px;
	border: 0;	
	padding-left: 5px;
}

.tooltiptext{
	cursor: pointer;
}

.edit_icon:hover{
	cursor: pointer;
}

.editButtonLeft{
    left: 0;
}

.editButtonHeader{
	left: 0;
	
}

.editButtonLogo{
}

.menu1 .editButtonLeft {
	position: absolute;
	margin-bottom: 3%;
	margin-left: 11%;
}

.bannerImageWrapper .tooltip {
    position: absolute;
    top: -3%;
    z-index: 1;
}

.menuEditButton {
	position: absolute;
	width: 10rem;
}

.menuEditButton:hover{
	cursor: pointer;
}

.menuLevel1>li>.menuEditButton {
	top: -3.75rem;
}

/*---------------------------------Container----------------------*/
.container {
	min-height: 100vh;
	display: flex;
    flex-direction: column;
}

/*---------------------------------Header----------------------*/
.header {
	border-bottom: 2px solid var(--base-color);
    z-index: 1;
    background: white;
	display: flex;
    align-items: center;
}
	
.LogoImage {
	display: inline-block;
	margin: 20px 0;
}

.LogoImage img {
	width: 200px;
	vertical-align: middle;
}

input#hamburg {
	display:none
}

.menu1 {
	display: flex;
	justify-content: flex-start;
	align-items: flex-end;
	margin: 0 8rem;
}

.menu1 ul{
	list-style-type: none;
}

.menuLevel1 {
	list-style: none;
	z-index: 10;
}

.menuLevel3 {
	min-width: 100%;
    margin-top: -1px;
}

/**** menulevel 1 ****/
.menuLevel1>li{
	display: inline-block;
	position: relative;
	margin-left: 10px;
}

.menuLevel1>li>button,
.menuLevel2>li>button,
.menuLevel3>li>button {
	background: none;
	border: none;
	float: inherit;
	width: 100%;
	text-align: left;
}

.menuLevel1>li>button,
.menuLevel2>li>button {
	display: flex;
	justify-content: space-around;
}

.menuLevel1>li:hover > ul,
.menuLevel2>li:hover > ul{
	visibility: visible;
	opacity: 1;
	transition-delay: 0s;
}

.menuLevel1>li.editButton_menu{
	position: absolute;
	left: -20px;
}

.menuLevel1>li.editButton_menu >button>a{
	border-left: 0px;
	padding: 0px;
}

.menuLevel1 li a {
	color: #2a3032;
	display: block;
}

.menuLevel1>li>button>a {
	margin: 10px 0px;
	font-size: 1.2rem;
    font-weight: 400;
	font-family: 'Open Sans', sans-serif !important;
    box-sizing: border-box;
    width: 100%;
}

.menuLevel1>li>button>a::after {
	content: " |";
	margin-left: 10px;
	color: black;
}

.menuLevel1>li:last-child a::after {
	content: none;
}

.menuLevel1>li:first-of-type>button>a {
	border-left: none;
}

.menuLevel1>li>button>a:LINK {
	text-decoration: none;
}

/* einblenden Linie bei selectierte Menu */
.menuLevel1>li.selected>button>a, .menuLevel1>li.hasSelectedDescendant>button>a {
	color: var(--base-color);
}

.menuLevel1>li>button>a:hover{
	color: var(--base-color);
}

.menuLevel1>li>button>a:hover:before,
.menuLevel1>li .current a:before {
  	opacity: 1;
  	width: 100%;
}
.menuLevel1>li>button>a:hover:after,
.menuLevel1>li .current a:after {
  	max-width: 100%;
}

/**** submenu level 1 ****/
.menuLevel2{
	visibility: hidden;
	position: absolute;
	float: left;
	min-width: 100%;
    white-space: nowrap;
    padding: 0px;
    box-sizing: border-box;
    margin-top: 2px;
}

.menuLevel2>li {
	float: left;
	clear: left;
	width: 100%;
    box-sizing: border-box;
}

.menuLevel2>li>button>a {
	float: left;
	clear: left;
	box-sizing: border-box;
	font-family: 'Open Sans', sans-serif !important;
	width: 100%;
	font-size: 1.4rem;
    font-weight: 400;
    position: relative;
}

.menuLevel2>li>button>a:LINK {
	text-decoration: none;
}

.menuLevel2>li>button>a:HOVER {
	background-color: var(--base-color);
	color: white;
	border-color: var(--base-color);
}

.menuLevel2>li:HOVER {
    border-color: var(--base-color);
}

#container li.editButton_menu > a::after{
	display: none;
}

.menuLevel2>li>button>a,
.menuLevel3>li>button>a {
	padding: 8px 15px;
	color: var(--base-color);
	background-color: white;
}

.menuLevel2, 
.menuLevel3{
	opacity: 0;
	transition-delay: 0s;
	transition: visibility 0s 0.2s, opacity 0.2s linear;
}

.submenu_level_3 {
	display: none;
}

/*sub-nav-level-2*/
.menuLevel3 {
	display: block;
	visibility: hidden;
	position: absolute;
	float: left;
	left: 100%;
	white-space: nowrap;
	
}

.editButtonLi{
	background: white;
}

.menuLevel2>li:last-Child, 
.menuLevel3>li:last-Child {
	margin-bottom: 0px;
	}

.menuLevel3>li>button>a {
	float: left;
    clear: left;
    box-sizing: border-box;
    width: 100%;
    font-size: 1.2rem;
    font-weight: 400;
	font-family: 'Open Sans', sans-serif !important;
    position: relative;
}

.menuLevel3>li {
	float: left;
	clear: left;
	width: 100%;
    box-sizing: border-box;
    background-color: #ffffff;
    margin-left: 2px;
    margin-bottom: 2px;
    border: 1px solid;
    border-color: #969696;
}

.menuLevel3>li>button>a:LINK {
	text-decoration: none;
}

.menuLevel3>li:hover{
	background-color: var(--base-color);
}

.menuLevel3>li>button>a:hover{
	color: white;
	border-color: var(--base-color);
}

.menuWrapper {
	z-index: 2;
	white-space: nowrap;
    display: inline-flex;
	margin-left: 0.2rem;
    margin-top: 0.05rem;
    margin-bottom: 0.15rem;
}

.stukkateurMenu{
	background-color: #a38b4b;
    color: white !important;
    padding-left: 10px;
	padding-right: 10px;
	padding-bottom: 1px;
    text-decoration: none !important;
    font-weight: 400;
	line-height: 1.55!important;
    position: relative;
    left: 1.6rem;
    font-size: 1.2rem;
    top: 1.25rem;
    height: min-content;
}

.stukkateurMenu::before {
	display:none;
}

/*------Content-------*/
.content{
	flex:1;
}

.bannerImageWrapper{
    margin-bottom: 2.5rem;
    position: relative;
}

.bannerImage{
    display: flex;
	overflow: hidden;
    justify-content: center;
    object-fit: Fill;
    width: 100%;
    min-width: 100%;
}

#mainimage{
	max-width: 100%;
}

.bannerTextWrapper{
    position: absolute;
    background: #8e7023a8;
}

.bannerTextWrapperWithoutImage {
    background: var(--base-color);
}

.bannerText{
	color: white;
	font-size: 3rem;
	font-weight: 400;
	display: inline;
    margin-right: 2rem;
    margin-left: 10rem;
}

.breadcrumb{
	background-color: var(--base-color);
	color: white;
}

.breadcrumbText{
	margin-left: 10rem;
}

.breadcrumbText a{
	color: white;
}

.inner_content{
	margin: 0 8rem;
	margin-bottom: 2.5rem;
}

/*------Home-------*/

.imageTable {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-around;
	margin: 30px 20% 20px 20%;
}

.box-01, .box-02, .box-03 {
	max-width: 350px;
}

.box-01>img, .box-02>img, .box-03>img {
	width: 100%;
}

.box-01>p, .box-02>p, .box-03>p {
	font-size: 1.7em;
	text-align: center;
}

.mySlides {
	width: 100%;
	height: auto;
	display: none;
}

/*------HomeArticle-------*/

.artikelHomeProdomizil {
    list-style-type: none;
    display: flex;
    justify-content: space-around;
    padding-left: 0px;
	flex-wrap: wrap;
}

.artikelHomeProdomizil li p {
	font-size: 1.2em;
	font-weight: 100;
}

/*------Article-------*/

.articleModul{
	display: flex;
	flex-wrap: wrap;
	margin-top: 20px;
}

.articelTextWrapper {
    flex: 1;
    min-width: 300px;
    margin-right: 100px;
    max-width: 790px;
}

.articelImageWrapper{
	align-self: center;
}

.articelImage{
	width: 450px;
    height: 400px;
    text-align: center;
}

.articelImageStartseite{
	max-width: 400px;
	max-height: 450px;
	margin: 0 10px;
	text-align: center;
}

.artikelThumbbar {
    list-style-type: none;
    display: flex;
    padding-left: 0px;
	max-width: 450px;
    overflow-x: auto;
	overflow-y: hidden;
}

.artikelThumbbarImage {
    height: 60px;
    margin: 2px;
}

#article_text {
	max-width: 90ch;
}

/*------Produktmodul-------*/
.productArticleBackButton {
	background-color: var(--base-color);
    width: 100px;
    display: flex;
    justify-content: center;
    margin-top: auto;
	margin-bottom: 0.75em;
    color: white !important;
    font-weight: 400;
	box-shadow: none;
	border-radius: 0px;
    text-decoration: none;
}

.productlist_div {
	display: flex;
	flex-direction: column;
}

.productlist_entry{
	display: flex;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

.productlist_text {
	box-sizing: border-box;
	display: flex;
    flex-direction: column;
    flex: 1;
	max-width: 100ch;
}


.productlist_textRight{
	margin-left:100px;
}

.productlist_text > .editButton_productlist_div {
    top: 0px;
    left: -20px;
}

.productlist_title {
	font-weight: 400 !important;
    font-size: 1.6rem;
	line-height: 1.1!important;
	margin-bottom: 0.3rem;
    color: var(--headline-color);
	margin-top: 0.2em;
}

.productlist_description{
    font-size: 1rem;
	margin-right: 50px;
}

.productlist_description > h2{
	 margin-top: 0 !important;
}

.productlist_more a {
    color: var(--base-color);
    font-weight: 400;
    text-decoration: none;
	border:1px solid var(--base-color);
    width: 90px;
    display: flex;
    justify-content: center;
    margin-top: auto;
    font-weight: 400;
}

.productlist_more:hover {
    opacity: 0.7;
    cursor: pointer;
}

.productlist_image_div {
	max-width : 450px;
	max-height: 450px !important;
}

.productlist_image{
	width: 100%;
}

.productToogle_description{
}

.productToogle_image_div {
	max-width : 800px;
	max-height: 550px;
}


.product_back_outer a {
    font-size: 1.3rem;
    color: #008ecf;
    text-decoration: underline;
}

.produkt_text{
	background: #e3e3e3;
	padding: 8px 0px;
	margin-bottom: 2.5em;
	
}

.produkt_text p{
	color: var(--headline-color) !important;
	font-size: 1.6rem !important;
	line-height: 155% !important;
	font-weight: 400 !important;
}

.produkt_text *{
	margin: 0 8rem;
}

.produkt_text  img.edit_icon{
	margin: 0 0 0 0;
}

/*------abwechselnd Produktmodul-------*/


.productToogle_entry{
	display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 40px;
}

.productToogle_text {
	box-sizing: border-box;
	display: flex;
    flex-direction: column;
    flex: 1;
}

/*-------Contact-------*/

.contacts_map {
    margin: 0 auto;
    border-bottom: 8px solid var(--base-color);
    display: flex;
}

.contacts_div{
	margin-top: 25px;
}

.contact_data {
	width: 100%;
}

.contact_data p{
	margin-block-start: 0em;
	margin-block-end: 0em;
	margin-top: 0em !important;
}

.contact_data > p:first-of-type{
    font-size: 1.5rem;
    font-weight: 500;
	margin-top: 1rem !important;
}

.contact_data p a:any-link{
	text-decoration: underline;
	color: var(--base-color);
	font-weight: 400;
}

.contact_image_div{
    max-width: 200px;
}	

.contact_separator {
	width: 100%;
    border-top: 2px solid var(--base-color);
    margin: 3rem 0;
}

.contact_separator:last-Child {
	width: 0%;
}

.contact_text p {
    margin-block-start: 0em;
    margin-block-end: 0em;
	font-weight: 100;
}

/*------Gallerie-------*/

.gallerieWrapper{
	display: flex;
    flex-direction: column;
    align-items: center;
}

.gallerie_mainimage{
	
}

.thumbbarWrapper{
	
}

.thumbbar{
	list-style-type: none;
    display: flex;
    justify-content: center;
}

.thumbbarImage{
	height: 120px;
}

#thumbnailimage{
	height: 100%;
}

/*------Buchmodul-------*/

.bildLayout {
	max-width: 100%;	
}

.coverimage {
	max-width: 7em;
}

.cellautor {
	width: 13em;
}

/*-------Footer-------*/

.footer {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
	flex-wrap: wrap;
	font-size: 1.2em;
	line-height:190% !important;
	background-color: var(--base-color);
}

.footerLogo {
	margin-left: 10rem;
}

.footerText {
	margin-bottom: 50px;
	color: white;
	text-align: center;
}

.footerLogo>img {
	width: 100%;
	max-width: 308px;
}

.footerText>h2 {
	margin-bottom: 0 !important;
    line-height: 1.4em !important;
	font-size: 1.91rem !important;
	font-stretch: 0%!important;
	letter-spacing: -0.02em;
    font-weight: 100 !important;
    color: white !important;
}

.flexText>p {
	font-size: 1.1em;
	margin-block-start: 0em;
	letter-spacing: 0.4px;
	margin-block-end: 0.2em;
}

.flexText{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.copyright_div{
    margin-top: 0.2rem;
	display: flex;
	justify-content: center;
	font-size: 0.95rem;
	color: white !important;
}

.copyright_div a{
	text-decoration: none;
	color: white !important;
	font-stretch: 155%;
	line-height: 1.1!important;
}


/******************************/
/* Responsive*/
/******************************/
@MEDIA only screen and (max-width: 1280px){
	
	.LogoImage{
	    margin: 10px 2rem 0px 2rem;
	}

	.inner_content {
    	margin: 0 2rem;
	}
	
	.produkt_text * {
		margin: 0 2rem;
	}
	
	label.hamburg { 
	   display: block; 
	   width: 75px; 
	   height: 50px; 
	   position: relative; 
	   margin-left: auto; 
	   margin-right: 2rem;
	   border-radius: 4px; 
	}

	.line { 
	   position: absolute; 
	   left:10px;
	   height: 4px; width: 55px; 
	   background: var(--base-color); border-radius: 2px;
	   display: block; 
	   transition: 0.5s; 
	   transform-origin: center; 
	}

	.line:nth-child(1) { top: 12px; }
	.line:nth-child(2) { top: 24px; }
	.line:nth-child(3) { top: 36px; }

	#hamburg:checked + .hamburg .line:nth-child(1){
	   transform: translateY(12px) rotate(-45deg);
	}

	#hamburg:checked + .hamburg .line:nth-child(2){
	   opacity:0;
	}

	#hamburg:checked + .hamburg .line:nth-child(3){
	   transform: translateY(-12px) rotate(45deg);
	}
	
	#hamburg:checked ~ .menuWrapper .menuLevel1 {
	   display: flex;
	}
	
	.stukkateurMenu{
		display: none !important;
	}
	
	.menu1 {
	    align-items: flex-end;
	    margin: 0;
	    flex-wrap: wrap;
	    justify-content: space-around;
	}
	
	.menuWrapper {
		width: 100%;		
	}
	
	.menuLevel1 {
		display: none;
	    flex-direction: column;
	    position: relative;
	    align-items: center;
	    background: #e4e4e4;
	    padding-inline-start: 0px;
	    width: 100%;
	}
	
	.menuLevel1>li {
     	margin-left: 0px;
    	width: 100%;
    	text-align: center;
    	border-bottom: 1px solid #d4d4d4;
	}
	
	.menuLevel1>li >button>a::after {
		display: none;
	}
	
	.menuLevel1>li:last-child {
    	border-bottom: none;
	}
	
	.menuLevel1>li.selected>button>a::after, .menuLevel1>li.hasSelectedDescendant>button>a::after {
    	display: none;
	}

	.menuLevel1>li>button>a,
	.menuLevel2>li>button>a{
		width: fit-content;
	}
	
	.menuLevel1>li>button,
	.menuLevel2>li>button {
		display: flex;
		justify-content: space-around;
	}
	
	.menuLevel1>li>button>a::before {
	  	display:none;
	}
	
	.menuLevel1>li:focus-within .menuLevel2{
		position: inherit;
		visibility: visible;
		opacity: 1;
		transition: none;
		text-align: center;
	}
	
	.menuLevel2 > li{
	    margin-bottom: 0px;
	    border-color: #e4e4e4;
	}
	
	.flexText {
		margin: 0 2rem;
	}
}

@MEDIA only screen and (max-width: 850px){
	.articelTextWrapper {
		margin-right: 50px;
	}
	
	.articelImageWrapper {
		width: 100%;
	}
	
	.articelImage {
		width: auto;
		height: auto;
	}
	
	.footerLogo {
		margin-left: 0px;
	}
	
	.footerLogo>img {
		max-width: 150px;
	}
	
	.produkt_text h1 {
		font-size: 2rem !important;
	}
	
	.productToogle_entry {
		display: grid;
		grid-template-areas: "image text";
	}
	
	.productToogle_text {
		grid-area: 2;
	}
	
	.productToogle_image_div {
		grid-area: 1;
	}
	
	.productToogle_description {
		width: 100%;
	}
	
	.productlist_entry {
		display: grid;
		grid-template-areas: "image text";
	}
	
	.productlist_text {
		grid-area: 2;
	}
	
	.productlist_image_div {
		grid-area: 1;
	}
	
	.productlist_textRight {
		margin-left: 0px;
	}
	
	.productToogle_description>p {
		font-size: 1.3rem;
	}

	.productlist_more {
		margin-bottom: 20px;
	}

}
