
.T2820 {
	--footer-gap: 1.5rem;
	margin-bottom: 0px !important;
}


footer .wrapper {
	padding-top: 10px;
	background-position: top;
	z-index: 5;	
}

footer:not(.S9072) .wrapper { margin: 0; }

footer .wrapper .boxes {
	display: flex;
	flex-wrap: wrap;
	gap: var(--footer-gap);
	margin-bottom: var(--footer-gap);
}


footer .box {
	position: relative;
	width: 100%;
}

footer .box.empty { padding-bottom: 0;  }



footer .box > .inner {
	margin: 1.5rem 0 0 0;
}

footer .footer_img {
	float: left;
	margin: 0px 5px 8px 0px;
}

footer .box > .inner .headline {
	text-transform: uppercase;
	margin-top: 0px;
	margin-bottom: 7px !important;
}

footer .box > .inner h4 {
	margin-top: 10px;
	margin-bottom: 5px !important;
}

footer .box > .inner p {
	margin-bottom: 0.4em;
}

footer .box > .inner ul {
	padding-left: 25px;
}

footer .box > .inner ul.list {
	padding: 0;
	margin: 0.5em 0 0 0;
	list-style-type: none;
}

footer .box > .inner ul.list li {
	padding: 0;
	margin: 0 0 0.2em 0;
}

footer .box > .inner ul.list li a {
	display: flex;
	text-decoration: none;
}
footer .box > .inner ul.list li a .icon {
	width: 1.3em;
	height: auto;
	margin-right: 0.6rem;
}

footer .box > .inner ul.list li a .icon img {
	width: 100%;
	height: auto;
}


/* Adresse */

.Mandant_800 footer .adresse .firma { font-weight: bold; }


/* Öffnungszeiten */
.T2820 .oeffnungszeiten { font-size: 0.9rem; }
.T2820 .oeffnungszeiten .tage { width: 34%; margin-right: 1%; flex-grow: 0; flex-shrink: 0; font-weight: bold;  }
.T2820 .oeffnungszeiten .tag { 
	display: flex; 
	flex-wrap:wrap; 
	border-bottom: 1px solid var(--footer_border_color,rgba(0,0,0,0.05));
	padding-bottom: 0.2rem; 
	margin-bottom: 0.2rem; 
}
.T2820 .oeffnungszeiten .tag:last-child { border-width: 0; padding-bottom: 0; margin-bottom: 0; }
.T2820 .oeffnungszeiten .rightside { width: 65%; hyphens: auto; }
.T2820 .oeffnungszeiten .rightside .nachmittag { display: block; }

footer .staticmap {
	display: inline-block;
	background-color: #fff;
	border: 1px solid rgba(0,0,0,0.1);
	padding: 4px;	
}

footer .staticmap img {
	width: 100%;
	height: auto;
}

#totop {
	position: fixed;
	bottom: 50px;
	right: 50px;
	width: 65px;
	height: 65px;
	z-index: 2001;
	display: none;
	cursor: pointer;
	background-color: #FFF;
	background-color: rgba(255,255,255,0.5);
}

#totop i {
	position: absolute;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%, -50%);
	    transform: translate(-50%, -50%);
	font-size: 50px;
}

footer .box .social {
	display: flex;
	flex-direction: column;
}

footer .box .social a {
	display: flex;
	font-size:  1.15rem;
	text-decoration: none;
	align-items:  center;
	margin-bottom: 0.2rem;
}

footer .box .social a i {
	margin-right: 0.5rem;
	font-size:  1.3em;
}


/* Fix Mittelberg */

.Mandant_800 footer {
	padding: 0 1em;
	margin: 0 auto !important;
	max-width: 1800px;
}



.Mandant_800 footer :is(.copyright,.boxes,.badges) {
	width: auto;
	padding: 0;
	margin-left: 0.5rem;
	margin-right: 0.5rem;
}


.Mandant_800 .T2820.S9073 .wrapper {
	border-radius: 1em 1em 0 0; /* sollte einstellbar sein irgendwie */
}

@media (min-width: 420px) {
	footer .box {
		width: auto;
		width: calc( 50% - var(--footer-gap) );
	}
}
@media (min-width: 567px) {

}

@media (min-width: 768px) {

	footer .box {
		width: calc( 25% - var(--footer-gap) );
	}

	.Mandant_800 footer {
		padding: 0 2em;
	}

	.Mandant_800 footer :is(.copyright,.boxes,.badges) {
		width: auto;
		padding: 0 2em;
	}
}

@media (min-width: 1024px) {

}

@media (min-width: 1280px) {

}


/* -- Copyright -- */

footer .badges { text-align: right; }
footer .badges.align-left { text-align: left; }
footer .badges.align-center { text-align: center; }

footer .badges a {
	display: inline-block;
	text-decoration: none;
	margin: 0px 0px 15px 15px;
}

footer .copyright {
	display: flex;
	flex-wrap:  wrap;
	justify-content:  space-between;
	padding-bottom: 15px !important;
	
}

footer .copyright .links { opacity: 0.6; }
footer .copyright .tc { opacity: 0.4; }

footer .copyright a { text-decoration: none; color: inherit;  }
footer .copyright .social a {  margin: 0px 15px 15px 0px; display: flex; align-items: center; }
footer .copyright i { font-size: 20px; line-height: 16px;  padding-right: 5px;}

footer .copyright ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
}

footer .copyright ul:after {
	display: block;
	content: "";
	clear: left;
}


footer .copyright ul li {
	float: left;
	margin: 0 10px 0 0;
}

footer .copyright .social {
	float: none;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	margin: 0 10px 0 0;
}

@media (max-width: 567px) {
	footer .copyright .social {
		order: 1;
		width:  100%;
		flex-grow: 0;
		flex-shrink: 0;
	}
	footer .copyright .links { order: 2; }
	footer .copyright .tc { order: 3; }
}


/* -- Weisser Hintergrund -- [disabled] */

#body .T2820.S5702 .wrapper { background-color: #fff; }



/* -- Hintergrund Hintergrund 5% Schwarz (1) [disabled]  -- */

#body .T2820.S5703 .wrapper { background-color: rgba(0,0,0,0.05); }



/* -- Hintergrund Dunkler Hintergrund (6) [disabled]  -- */

.S7756 .background {
	color: #fff !important;
}




/* -- Hintergrund Grauer Hintergrund [disabled] -- */

footer.S8854, footer .S8854 {
    background: #555;	
}

footer.S8854 section.box.box4, footer .S8854 section.box.box4 {
    width: 100%;
}

footer.S8854 section.box.box4 .inner.clearfix.text, footer .S8854 section.box.box4 .inner.clearfix.text {
	margin-right: 0;
}

@supports (container-type: inline-size) {
	footer .search_wrapper {
		container-type: inline-size;
		container-name: footer_search;
		width: 100%;
	}

	footer .search {
		display: flex;
	}
	footer .search input[type=text] {
		flex-grow: 1;
		flex-shrink: 1;
	}


	@container footer_search (max-width: 279px) {
		footer .search {
			flex-wrap: wrap;
			flex-direction: column;
		}
		footer .search input[type=text] {
			min-height: 2rem;
			width: 100%;
			margin-bottom: 0.5em;
		}
		footer .search button {
			width: 100%;
		}
	}
}

@supports not (container-type: inline-size) {
	footer .search {
		display: flex;
	}
	footer .search input[type=text] {
		flex-grow: 1;
		flex-shrink: 1;
		width: 124px;
	}

	
	@media (min-width: 768px) and (max-width: 1023px)  {

		footer .search {
			flex-direction: column;
		}
		footer .search input[type=text] {
			width: 100%;
		}
		footer .search button {
			width: 100%;
		}
	}
	

	
}


/* -- Responsive  -- */


@media all and (min-width: 768px) and (max-width:1023px) {

	.T2820 .oeffnungszeiten .tag { margin-bottom: 5px; }
	.T2820 .oeffnungszeiten .tage { width: 100%; }
	.T2820 .oeffnungszeiten .rightside { float: left; width: 100%; }
	.T2820 .oeffnungszeiten .rightside .nachmittag { display: block; }

	#totop {
		bottom: 45px;
		right: 45px;
		width: 60px;
		height: 60px;
	}

	#totop i {
		font-size: 45px;
	}

}

@media all and (min-width: 568px) and (max-width: 767px) {

	.T2820 .oeffnungszeiten .tag { margin-bottom: 5px; }
	.T2820 .oeffnungszeiten .tage { width: 100%; font-weight: bold; }
	.T2820 .oeffnungszeiten .rightside { float: left; width: 100%; }
	.T2820 .oeffnungszeiten .rightside .nachmittag { display: block; }

	#totop {
		bottom: 40px;
		right: 40px;
		width: 50px;
		height: 50px;
	}

	#totop i {
		font-size: 40px;
	}

	
}

@media all and (max-width: 567px) {
	
	footer .wrapper {
	 	padding-top: 15px;
		background-size: cover !important;	
	}
	
	
	footer .box > .inner {
		margin: 0px;
	}
	

	#totop {
		bottom: 30px;
		right: 30px;
		width: 40px;
		height: 40px;
	}

	#totop i {
		font-size: 30px;
	}
	
	footer .box iframe { width: 100%; height: auto; }
	footer .box iframe.noresponsive { width: auto; height: auto; }


	footer .copyright .social {
		padding-top: 0.8rem;
   		padding-bottom: 0.8rem;
		border-top: 1px solid var(--footer_border_color,rgba(0,0,0,0.05));
		border-bottom: 1px solid var(--footer_border_color,rgba(0,0,0,0.05));
		margin-bottom: 0.8rem;
	}
	footer .copyright .social a {
		margin-bottom: 0.5rem;
	}

}

/* -- CSS (für Browser) #9072: Breite Nur Maximalbreite (1) [optional]  -- */

.T2820.S9072 .wrapper { padding-left: 2rem; padding-right: 2rem; }


/* -- CSS (für Browser) #9073: Rundung Abgerundete Ecken oben (1) [optional] -- */

.T2820.S9073 .wrapper { border-radius: 2rem 2rem 0 0; }

