@layer main-theme {
	.textblock.schmal {
		--content-width: var(--narrow-content-width);
	}
	.textblock.breit {
		--content-width: var(--wide-content-width);
	}
	.textblock.randlos {
		/* Fallback für Browser, die mit 'var()' in 'calc()' noch nicht klarkommen */
		padding-left: 0;
		padding-right: 0;
	}


	/* BREADCRUMB */
	body div.breadcrumb {
		font-size: 0.8em;
		font-weight: 500;
		padding-top: .5rem;
		text-align: left;
	}
	.breadcrumb a {
		color: currentcolor;
		margin-right: .3em;
		text-decoration: none;
	}
	.breadcrumb a:not(:first-child)::before {
		content: '\276f';
		color: var(--textcolor);
		display: inline-block;
		padding-right: .3em;
		vertical-align: middle;
	}
	.breadcrumb a:last-child {
		color: var(--linkcolor);
	}

	/* CONTENT */
	body > main {
		padding-top: 3em;
		position: relative;
		z-index: 1;
	}
	body main > * {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}
	body main > *[class*=" hg-"] {
		margin: 3em 0;
	}
	main > h1 {
		margin: 0;
		padding-top: 1em;
		padding-bottom: 0;
	}

	body > main .textblock {
		--rand-links: max(var(--page-margin-left), 50vw - var(--content-width) / 2);
		--rand-rechts: max(var(--page-margin-right), 50vw - var(--content-width) / 2);
		--inhaltsbereich: min(var(--content-width), 100vw - var(--page-margin-left) - var(--page-margin-right));
		--spaltenbreite: calc((var(--inhaltsbereich) + 2 * var(--grid-gap)) / 12);
	}
	body > main .textblock[class*="hg-"] {
		font-weight: 400;
	}
	main a[name] {
		position: relative;
		top: -80px;
	}
	body main > a[name] {
		padding: 0;
	}

	.textblock > h2:first-child {
		margin-top: 0;
	}
	.textblock p:last-child {
		margin-bottom: 0;
	}
	/*.textblock p > a:only-child {
		display: inline-block;
		font-weight: 500;
		padding-top: .2em;
		padding-left: 2em;
		position: relative;
		text-decoration: none;
		text-transform: uppercase;
	}
	.textblock p > a:only-child::before {
		content: "\276f";
		background: var(--highlight-color);
		border-radius: 50%;
		color: #fff;
		font-family: icomoon;
		font-size: 1.12em;
		line-height: 1.43;
		padding: 0 0 0 .28em;
		position: absolute;
			top: 0;
			left: 0;
		width: 1.43em;
		height: 1.43em;
	}*/

	.textblock.hg-bild {
		background: var(--hgbild) no-repeat top / cover;
	}
	.textblock .txt-img-wrap > * {
		position: relative;
	}
	.textblock .txt-img-wrap a {
		color: currentcolor;
		display: block;
		text-decoration: none;
	}
	.textblock .txt-img-wrap .caption {
		font-size: 1.5em;
		font-weight: 400;
	}
	.oeffnungszeiten span:first-child {
		display: inline-block;
		width: 8em;
		max-width: 50%;
	}
	
	.row.downloads > div:only-child {
		flex-grow: 1;
	}
	.downloads a.dl {
		display: inline-flex;
			align-items: center;
		padding: 0.9em 1.5em 0.6em;
	}
	.downloads a.dl:hover {
		background: var(--highlight-color);
		color: #fff;
	}
	.downloads a.dl .icon {
		font-family: icomoon;
		margin: -0.3em 0 0 1em;
		position: relative;
	}
	.downloads a.dl .icon-document {
		font-size: 2.2em;
	}
	.downloads a.dl .icon-dl-arr-down {
		font-size: 0.8em;
		position: absolute;
			bottom: 0.9rem;
			left: 0.5rem;
		transition: .3s ease-out;
	}
	.downloads a.dl:hover .icon-dl-arr-down {
		bottom: .3rem;
	}

	.js main > * > * {
		opacity: 0;
	}
	.js main > * > *.in-view {
		animation: .8s ease-in-out 0s 1 slideInFromBottom;
		opacity: 1;
	}


	/* FOOTER */
	.seo-texte {
		max-height: 2px;
		margin: 0;
		overflow: hidden;
		padding: 0;
	}
	
	@media (min-width: 800px) {
		.banner .slide img {
			width: 100%;
			max-height: 21vw;
		}
		
		/* Text-Bild / Bild-Text: allgemein */
		.textblock.bild_text img,
		.textblock.text_bild img {
			width: 100%;
			height: 100%;
			object-fit: contain;
		}
		
		.bild_text .grid {
			display: grid;
			grid-template-columns: 1fr 1fr;
			grid-gap: 0 var(--grid-gap);
			justify-content: center;
		}
		.grid.r4x8 { grid-template-columns: 4fr 8fr; }
		.bild_text .grid > :first-child {
			align-self: end;
			margin: 0;
		}
		.bild_text .grid > .img {
			grid-row: span 2;
			order: -1;
		}
	}

	@media (min-width: 1200px) {
		.textblock.columns-2 {
			columns: 2;
			column-gap: calc(3 * var(--grid-gap));
			text-align: left;
		}
		.textblock.columns-2 > h1,
		.textblock.columns-2 > h2,
		.textblock.columns-2 > .txt-img-wrap {
			column-span: all;
			text-align: center;
		}
		.textblock.columns-2 > p {
			margin-top: 0;
		}
	}
	
	@media (max-width: 799px) {
		.bild_text .row > * {
			margin-bottom: 0;
		}
		.bild_text .grid > :first-child {
			grid-column: span 2;
		}
		
		.overflowing {
			max-height: 620px;
			overflow: hidden;
			position: relative;
		}
		.showMore {
			display: none;
		}
		.overflowing > .showMore {
			background: linear-gradient(to bottom, transparent, #fff9 10%, #fff);
			display: flex;
				align-items: center;
				justify-content: center;
			height: 3.5em;
			position: absolute;
				bottom: 0;
				left: 0;
			width: 100%;
		}
	}
}
		
.btnFav i {
	--bg-color: transparent;
	background: radial-gradient(var(--bg-color) 45%, transparent 45%);
	border-radius: 50%;
	display: inline-block;
	outline: 1px solid var(--bg);
	outline-offset: -1px;
}
.btnFav.aktiv i {
	--bg-color: var(--secondary-color);
	outline: .4em solid transparent;
	outline-offset: 1em;
	transition: .25s ease-out;
}
button.btnFav i[class*="icon-"]:last-child::before {
	margin: -1px;
}

/* Startseite */
.startseite .textblock.hg-gruen .row > * {
	padding: 0 var(--spaltenbreite);
	position: relative;
}
.startseite .textblock.hg-gruen .row h3 {
	margin: -.2em 0 .4em;
}
.startseite .textblock.hg-gruen .row h3::after {
	content: '•••';
	display: block;
	margin: 0.5em 0 0;
	letter-spacing: .1em;
}
.startseite .textblock.hg-gruen .row p {
	margin-top: 0;
}
.startseite .textblock.hg-gruen .row .button {
	background: transparent;
	border: 2px solid currentcolor;
	border-radius: 1.5em;
	box-shadow: 0 3px 6px #00000080, inset 0 0 0 var(--linkcolor);
	color: inherit;
	font-weight: 500;
	padding: 0.4em 2em 0.5em;
	transition-property: box-shadow, color;
}
.startseite .textblock.hg-gruen .row .button:hover,
.startseite .textblock.hg-gruen .row .button:focus {
	box-shadow: 0 3px 6px #00000080, inset 0 0 0 1.1em var(--linkcolor);
	color: var(--bg-color);
}
@media (min-width: 800px) {
	.startseite .textblock.hg-gruen .row {
		border: solid;
		border-width: 0 3px;
	}
	.startseite .textblock.hg-gruen .row > *:not(:last-child)::after {
		content: '';
		border: solid;
		border-width: 0 1px 0 2px;
		position: absolute;
			top: 0;
			right: calc(var(--grid-gap) * -1);
			bottom: 0;
	}
}
.startseite .gruende {
	position: relative;
	z-index: 2;
}
.startseite .iconbox {
	font-size: 1.3em;
	font-weight: 500;
	hyphens: none;
	padding-block: 0;
}
.startseite .iconbox [class^="icon-"] {
	font-size: 2.2em;
	line-height: 1;
	margin-top: 1rem;
}
.startseite .iconbox p {
	hyphens: none;
	line-height: 1.2;
	margin: 0.15em 0 0.85em;
	padding: 0 .3em;
}
.startseite .merkmale .produkte {
	border-radius: 1.5em;
	margin-top: -6em;
	padding-top: 8.5em;
	position: relative;
}
.startseite .merkmale .produkte::before {
	content: '';
	background: var(--hellgrau);
	border-radius: 1.5em;
	position: absolute;
		top: 0;
		right: max(-2.4em, 50% - 50vw);
		bottom: 0;
		left: max(-2.4em, 50% - 50vw);
	z-index: -1;
}
.startseite .merkmale .produkte .row .txt {
	text-align: left;
	padding-bottom: 1em;
}
.startseite .merkmale .produkte .row .txt h2 {
	margin-top: 0;
}
.startseite .merkmale .produkte ul li {
	margin-bottom: 1em;
}
.startseite .merkmale .produkte .row .img {
	text-align: center;
}
.startseite .merkmale .produkte .row .img img {
	margin-bottom: 1.6em;
	max-height: 24.5em;
	width: auto;
}
.startseite .liste-warum ul {
	columns: 3 15em;
}
@media (min-width: 1024px) {
	.startseite .merkmale .produkte .row .txt {
		padding-left: 7%;
	}
}


/* Suche */
.suche .searchform {
	position: relative;
}
.suche .searchform input {
	padding: 0 .6em;
	width: 100%;
	height: 3em;
}
.suche .searchform button {
	--bg-color: var(--hellgrau);
	border: 0;
	border-radius: 0;
	padding: .55em .5em .4em;
	position: absolute;
		top: 1px;
		right: 1px;
	width: 3rem;
	height: calc(3rem - 2px);
}
.suche .searchform button i {
	font-size: 0;
}
.suche .searchform button i::before {
	font-size: 1.5rem;
	line-height: 1;
	margin: 0;
	vertical-align: baseline;
}
.suche h1 {
	margin-top: 1.2em;
}

.livesuche .liste {
	columns: 8em;
}
.livesuche .liste > * {
	break-inside: avoid;
	display: block;
}


/* Produkte */
.produktliste {
	padding-top: 1.8em;
}
.breadcrumb + main .produktliste {
	padding-top: 0;
}
.produktliste .subnav {
	align-self: flex-start;
	font-weight: 500;
	margin-top: 4em;
	max-height: calc(100vh - 4em);
	min-width: 13em;
	overflow: auto;
	position: sticky;
		top: 1em;
	text-align: left;
}
.produktliste .subnav > ul > li {
	margin-bottom: 1rem;
}
.produktliste .subnav ul a {
	color: var(--grau);
	text-decoration: none;
}
.produktliste .subnav > ul > li > a {
	font-weight: 700;
}
.produktliste .subnav ul .active a,
.produktliste .subnav ul a:hover,
.produktliste .subnav ul a:focus {
	color: #000;
}
.produktliste .subnav ul ul {
	font-size: .8em;
}
.produktliste .subnav ul ul li {
	display: inline-block;
	margin-right: .5em;
}
.produktliste .subnav ul ul a {
	color: var(--grau);
	font-weight: 400;
	text-decoration: none;
}
.produktliste .subnav ul ul a:hover,
.produktliste .subnav ul ul a:focus {
	text-decoration: underline;
}
.produktliste .subnav ul .active ul a {
	color: var(--highlight-color);
}
.produktliste .subnav ul .active ul .active a {
	color: #000;
	text-decoration: underline;
}
.produktliste .subnav ul .active ul li:not(.active) a:hover,
.produktliste .subnav ul .active ul li:not(.active) a:focus {
	color: var(--secondary-color);
}
.produktliste .liste {
	container-type: inline-size;
	flex-grow: 1;
}
.produktliste .products {
	gap: 2.5em calc(2 * var(--grid-gap));
	padding-top: 1em;
}
.produktliste .products h2 {
	font-size: 1.2em;
	margin: 0;
}
.produktliste .products .col-4 {
	margin: auto;
	max-width: 17em;
}
@media (500px < width < 1000px) {
	.produktliste .products .col-4 {
		--colspan: 6;
	}
}
@media (500px < width) {
	.produktliste .products .col-4 {
		max-width: none;
		margin: 0;
	}
}
.produktliste .liste .row.navigation > * {
	width: 100%;
}
.produktliste nav.pagination {
	margin-bottom: 1rem;
	text-align: center;
}
.produktliste .pagination li {
	display: inline-block;
	text-align: center;
}
.produktliste .pagination li:not(:last-child) {
	margin-right: .85em;
}
.produktliste .pagination li a {
	color: var(--grau);
	line-height: .9;
	font-size: 1.6em;
	text-decoration: none;
	vertical-align: bottom;
}
.produktliste .pagination li a.nr::first-letter {
	margin: 0 -1px;
}
.produktliste .pagination li a:hover,
.produktliste .pagination li a:focus {
	color: var(--secondary-color);
}
.produktliste .pagination li a.disabled {
	opacity: .5;
	pointer-events: none;
}
.produktliste .pagination li a.nr {
	background: var(--hellgrau);
	border-radius: 50%;
	display: inline-block;
	font-size: .82em;
	font-weight: 400;
	width: 1.5em;
	height: 1.5em;
	line-height: 1.3;
}
.produktliste .pagination li a.nr:hover,
.produktliste .pagination li a.nr:focus,
.produktliste .pagination li a.aktiv {
	background: var(--highlight-color);
	color: #fff;
}
.produktliste .sort {
	margin-bottom: 1rem;
}
@container (min-width: 25em) {
	.produktliste .liste > .row.navigation {
		justify-content: space-between;
	}
	.produktliste .liste .row.navigation > * {
		flex-grow: 0;
		min-width: auto;
	}
	.produktliste .liste .row.navigation nav.pagination {
		width: auto;
	}
	.produktliste .liste .row.navigation .sort {
		order: 2;
		min-width: 9em;
		width: calc(33.333% - 1 * var(--grid-gap))
	}
}
.produktliste .sort select {
	border-color: currentcolor;
	color: var(--grau);
	font-size: .82em;
	height: 2.666em;
}

.textblock.produkte > h2 {
	background: var(--highlight-color);
	border-radius: 1em;
	color: #fff;
	display: inline-block;
	margin: 0 0 .8em;
	padding: 0.2em min(5%, 1em) 0.25em;
	position: relative;
	z-index: 1;
}
.textblock.produkte > h2::before {
	content: '';
	border: 1px solid var(--highlight-color);
	position: absolute;
		top: 50%;
		left: 50%;
	margin-left: calc(var(--inhaltsbereich) / -2);
	width: var(--inhaltsbereich);
	z-index: -1;
}
.textblock.produkte .immer_scrollbar {
	margin-right: -5px;
}
.textblock.produkte .scrollbox {
	margin-left: -5px;
	padding: 1em 10px 5px 0;
}
.products .item {
	height: 100%;
	position: relative;
}
.textblock.produkte .item {
	left: 5px;
	max-width: 20em;
	margin: auto;
}
.textblock.produkte .scrollbox + .dots {
	padding-right: 5px;
}
.products .item > button {
	background: transparent;
	border: 0 none;
	border-radius: 50%;
	color: var(--highlight-color);
	font-size: 1.33em;
	padding: 0;
	position: absolute;
		top: .35em;
		right: .35em;
	width: auto;
	height: auto;
	z-index: 1;
}
@media (hover: hover) and (pointer: fine) {
	.products .item > button:hover,
	.products .item > button:focus {
		box-shadow: 0 0 10px var(--secondary-color);
	}
	.products .item > button i {
		margin: -1px;
	}
}
.products .item > button:not(.aktiv) i {
	--bg-color: #fff;
}
.products .item > button i::before {
	line-height: 1;
	margin: 0;
}
.products .item > a {
	border: 2px solid transparent;
	box-shadow: 0 0 6px #00000029;
	color: currentcolor;
	display: flex;
		flex-direction: column;
	height: 100%;
	overflow: hidden;
	padding: 0 0 .5em;
	text-decoration: none;
}
.products .item:hover > a,
.products .item > a:focus {
	box-shadow: none;
	border-color: var(--secondary-color);
}
.products .item a .img {
	padding-bottom: 100%;
	position: relative;
}
.products .item a .img img {
	position: absolute;
		top: 50%;
		left: 50%;
	translate: -50% -50%;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}
.item .title {
	flex-grow: 1;
}
.item .title > * {
	display: block;
	margin: .5em 0;
}
.item .title small {
	font-size: 0.82em;
}
.item .title strong {
	font-weight: 500;
	line-height: 1;
	/*margin: 0.1em 0 -0.2em;*/
}
.item .price {
	font-size: 1.6em;
	color: var(--highlight-color);
}
.products .item > a:hover .price {
	color: var(--secondary-color);
}
.item .price strong {
	font-weight: 500;
}
.products .item .icon-info {
	position: absolute;
		bottom: .4em;
		left: .5em;
}
.products .item .icon-info::before {
	color: #fff;
}

.textblock.produkt {
	font-size: .85em;
	padding-top: 0;
	padding-bottom: 0;
	text-align: left;
}
.textblock.produkt .daten {
	gap: 2em calc(2 * var(--grid-gap));
	margin-bottom: 5em;
}
.textblock.produkt .title {
	color: var(--textcolor);
	font-size: 1rem;
	font-weight: 700;
	margin-bottom: calc(1em * var(--line-height));
}
.textblock.produkt strong {
	font-weight: 500;
}
.textblock.produkt .row.daten > div {
	flex-grow: 1;
}
.textblock.produkt .bild {
	width: 12.2em;
}
.textblock.produkt .bild .dots {
	display: none;
}
.textblock.produkt .img-wrap,
.textblock.produkt .bild .preview a {
	padding: 5px;
}
.textblock.produkt .bild img {
	box-shadow: 0 0 6px #00000029;
}
.js .textblock.produkt .img-wrap img {
	cursor: pointer;
}
.textblock.produkt .bild .row.preview {
	--grid-gap: 0;
}
.textblock.produkt .bild .row.preview img {
	cursor: pointer;
}
.textblock.produkt .text {
	width: 100%;
}
.textblock.produkt .details {
	width: 18.5em;
}
.textblock.produkt table.preise {
	margin-bottom: .5em;
	table-layout: fixed;
	width: 100%;
}
.textblock.produkt table.preise tr > * {
	padding: .3em 1.5em;
}
.textblock.produkt table.preise th {
	background: var(--highlight-color);
	color: #fff;
}
.textblock.produkt table.preise tr > td {
	border-bottom: 1px solid var(--highlight-color);
}
.textblock.produkt .details p {
	margin-left: 1.5em;
}
.textblock.produkt .action {
	container-type: inline-size;
}
.textblock.produkt .action > * {
	vertical-align: middle;
}
.textblock.produkt #btnCart {
	display: inline-flex;
		align-items: center;
		gap: min(0.75em, 30cqw - 6.3em);
	height: 2.3em;
	padding: 0 .5em 0 min(1.5em, 40cqw - 7em);
}
.textblock.produkt .action > #btnCart i {
	position: relative;
}
.textblock.produkt .action > #btnCart::before,
.textblock.produkt .action > #btnCart i::before {
	float: right;
	font-size: 1.5rem;
	line-height: 0.55;
	order: 2;
}
.textblock.produkt .action > #btnCart i .item-amount {
	background-color: var(--bg-color);
	border-color: var(--bg);
	color: var(--bg);
	font-size: .7em;
	font-style: normal;
	top: -1.5em;
	right: -0.7em;
}
.textblock.produkt .action > #btnCart i .item-amount:empty {
	display: none;
}
.textblock.produkt .action > #btnCart:hover i .item-amount,
.textblock.produkt .action > #btnCart:focus i .item-amount {
	background-color: var(--bg);
	border-color: var(--bg-color);
	color: var(--bg-color);
}
.textblock.produkt > .tabs {
	margin-bottom: 3em;
}

.textblock.tabs dl.tabs dl.dropdown {
	padding: 0 calc(var(--spaltenbreite) - 1.5em);
}
@container (max-width: 23.5em) {
	.textblock.produkt .action > #btnCart > span {
		overflow: hidden;
		text-indent: -3.7em;
	}
}
@media (min-width: 800px) {
	.textblock.tabs dl.tabs dl.dropdown dd {
		padding-right: 3.5em;
	}
}
@media (min-width: 800px) and (max-width: 1000px) {
	.textblock.produkte .immer_scrollbar .col-3 {
		--colspan: 4;
	}
}
@media (min-width: 1100px) {
	.textblock.produkt .text {
		width: 25em;
	}
	.textblock.produkt .details {
		order: 2;
	}
}

/* Dienstleistungen */
.dienstleistungen .text_bild .img {
	text-align: center;
}
.dienstleistungen .text_bild img {
	object-position: 50% 75%;
}
.dienstleistungen .beispiele .row {
	align-items: end;
}
.dienstleistungen .beispiele .row > div {
	position: relative;
}
.dienstleistungen .beispiele p {
	color: var(--highlight-color);
	font-size: 1.3em;
	font-weight: 500;
	margin: 0;
	padding-bottom: 55%;
	position: absolute;
		bottom: -1.5em;
		left: 1.3em;
	z-index: 1;
}
.dienstleistungen .beispiele .row img {
	border: 1px solid #000;
	border-radius: 2em;
	width: 100%;
}
.dienstleistungen .pakete .paket {
	background: var(--hellgrau);
	border-radius: 1rem;
	container-type: inline-size;
	overflow: hidden;
}
.dienstleistungen .pakete h3 {
	background: var(--highlight-color);
	border-radius: 1rem;
	color: #fff;
	font-size: 11cqw;
	line-height: 1.2;
	margin: 0;
	padding: .33em 0;
}
.dienstleistungen .pakete h3 small {
	font-size: .6em;
}
.dienstleistungen .pakete .paket > div {
	border-bottom: 1px solid #000;
	font-size: 5.15cqw;
	margin: 5.15cqw 10.3cqw;
	padding: 0 0 2.57cqw;
}
.dienstleistungen .pakete .paket div[class^="icon-"]::before {
	display: block;
	font-size: 3em;
	margin-bottom: .5rem;
}
.dienstleistungen .pakete .paket .preis {
	color: var(--highlight-color);
	font-size: 15.6cqw;
	font-weight: 500;
	line-height: .9;
}
.dienstleistungen .pakete .paket .preis small {
	display: block;
	font-size: .25em;
}
.dienstleistungen .pakete .paket .beispielbilder {
	border: 0;
}
.dienstleistungen .pakete .paket .beispielbilder h4 {
	--factor-min: 2.15;
	--factor-max: 1.5;
}
.dienstleistungen .pakete .beispielbilder .row > div {
	--colspan: 6;
	background: #fff;
	border-radius: .5em;
	position: relative;
}
.dienstleistungen .pakete .beispielbilder .row > div::before {
	content: '';
	display: block;
	padding-bottom: 100%;
}
.dienstleistungen .pakete .beispielbilder .row img {
	object-fit: contain;
	padding: .75em;
	position: absolute;
		top: 0;
		left: 50%;
	transform: translateX(-50%);
	width: 100%;
	max-width: 45vw;
	height: 100%;
}
.dienstleistungen .textblock.schmal {
	text-align: center;
}
.dienstleistungen .textblock.schmal h2 {
	--factor-min: 2;
	--factor-max: 3;
}
.dienstleistungen .textblock.schmal big {
	font-weight: 300;
	max-width: 924px;
	margin: auto;
}


/* Über uns */
.ueber-uns .textblock > ul {
	columns: 12em;
}


/* Konto */
body.konto .row.heading {
	align-items: center;
	justify-content: center;
}
body.konto .row.heading div * {
	margin-bottom: 1rem;
}
body.konto .row.heading .btn-wrap {
	width: 10em;
	text-align: right;
}
.textblock form[name="form_login"] p > a:only-child {
	text-transform: none;
}
#pw_vergessen h3 {
	font-size: 1em;
}
.konto .button i.icon-logout::before {
	vertical-align: top;
}
.konto #tbl_konto tr {
	transition: 0.5s;
}
#tbl_konto .bnr { width: 8em; }
#tbl_konto .bdatum { width: 11em; }
#tbl_konto .bstatus { width: 10.5em; }
#tbl_konto td.bbetrag { text-align: right; width: 5.5em; }
.konto #tbl_konto tr.order.active td {
	background-color: #ddd;
}
.konto #tbl_konto tr.order:not(.active):hover td {
	background-color: #f0f0f0;
}
.konto #tbl_konto .order td {
	cursor: pointer;
	padding: 10px 5px;
}
.konto #bestellungen .details {
	display: none;
	border-bottom: 5px solid #fff;
}
.konto #bestellungen .details.active {
	display: table-row;
}
.konto #bestellungen .details th {
	background-color: #ddd;
}
.konto #bestellungen .details > td > div {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 3em 1em;
}
.konto #bestellungen .details h2 {
	width: 100%;
}
.konto #bestellungen .details table.left {
	flex-grow: 1;
}
.konto #bestellungen .details .trenner hr {
	margin: 5px 0;
}
.konto #bestellungen .details .boxen {
	flex-grow: 1;
	width: 20em;
}
.konto #bestellungen .details .box {
	background-color: #f6f6f6;
	border: 1px solid #ccc;
	margin-right: 5px;
	margin-bottom: 20px;
}
.konto #bestellungen .details .box div {
	padding: 7px 10px;
}
.konto #bestellungen .details .box .title {
	background-color: #ddd;
	font-weight: bold;
}
.konto #bestellungen .product {
	background-color: #eee;
	border-top: 1px solid #fafafa;
	cursor: pointer;
}
.konto #bestellungen .options {
	background-color: #f6f6f6;
	font-size: 0.9rem;
	line-height: 1.2em;
	border-bottom: 4px solid #fafafa;
	display: none;
}
.konto #bestellungen .options.active {
	display: table-row;
}
.konto #warenkoerbe table td:last-child {
	text-align: center;
}
.konto .content.adressbuch .col-4 {
	margin: 0;
}
.konto .vcard {
	background: #f9f9f9;
	font-size: .8em;
	padding: 0.1em 1em 1em;
}

.vcard {
	font-size: 0.93rem;
	position: relative;
	min-height: 100%;
}
.area .content.adressbuch > div {
	overflow: hidden;
}
.vcard.aktiv {
	box-shadow: inset 0 0 0 5px var(--highlight-color);
}
.vcard.aktiv .btnDefault {
	display: none;
}
.vcard h3 {
	margin-bottom: 1em;
}
.vcard .del {
	position: absolute;
		top: 5px;
		right: 5px;
}
.vcard.new a,
a.vcard.new {
	display: flex;
		align-items: center;
		justify-content: center;
	font-size: 13em;
	line-height: .66;
	overflow: hidden;
	padding: .2em 0 0;
	text-decoration: none;
}

form .form_bottom {
	display: flex;
		align-items: center;
		flex-wrap: wrap;
		gap: 1em;
		justify-content: space-between;
}
form .form_bottom .hinweis {
	width: 15em;
	flex: 1 1 auto;
}

.konto #reklamation textarea {
	--lines: 6;
}
#reklamation .filedrag.img_div:empty::before {
	content: 'Um Ihre Reklamation schnellstmöglich zu bearbeiten, benötigen wir Ihre Mithilfe. Bitte laden Sie hier die relevanten Dateien hoch, die uns bei der Analyse des Problems unterstützen.';
}
.no-js .konto #reklamation_produkt {
	display: none;
}
.konto form.form_newsletter label.lbl-chk,
.konto #konto-loeschen label.lbl-chk {
	background: var(--hellgrau);
	box-shadow: 0 -.2em 0 var(--hellgrau);
	font-size: 1em;
	left: 0;
	padding-left: .7em;
}


/* Warenkorb Table-Layout - deprecated */
.cart-list td.menge {
	min-width: 10rem;
}
.cart-list td.menge input {
	margin-bottom: 1em;
}
.cart-list td.menge button,
.cart-list td.menge .button {
	border: 0;
	display: inline-flex;
		align-items: center;
		justify-content: center;
	padding: 0;
	vertical-align: top;
	width: 1.75em;
	height: 1.75em;
}
@media (max-width: 800px) {
	table.cart-list {
		display: block;
		overflow: auto;
		width: 100%;
	}
}

/* Warenkorb Flex-Layout */
.cart-list div.produkt {
	box-shadow: 0 0 5px #ccc;
	background: #f1f1f1;
	margin-bottom: 1rem;
	text-align: left;
}
.cart-list div.produkt.upload-missing {
	box-shadow: 0 0 10px var(--highlight-color);
}
.cart-list .produkt .header {
	background: var(--highlight-color);
	color: #fff;
	display: flex;
	justify-content: space-between;
}
.cart-list .produkt .header .titel {
	line-height: 1.4;
	padding: 0.1rem 0 .2rem 1rem;
}
.cart-list .header .buttons {
	flex-shrink: 0;
	text-align: right;
	width: 4em;
}
.cart-list .header .buttons > * {
	--bg: var(--secondary-color);
	border-radius: 0;
	display: inline-flex;
		/*align-items: center;*/
		justify-content: center;
	padding: .2em;
	vertical-align: top;
	width: 1.7em;
	height: 1.7em;
}
.cart-list .produkt .content {
	display: flex;
		/*align-items: center;*/
		gap: 1.5em;
	padding: .3rem .8em;
}
.cart-list .produkt .upload {
	max-width: 20%;
}
.cart-list .produkt dl {
	flex: 0 0 auto;
	font-size: .75em;
	hyphens: none;
	line-height: 1.3;
	width: 36em;
	max-width: 100%;
}
.cart-list .produkt dl > * {
	display: inline-block;
	max-width: 100%;
	vertical-align: top;
}
.cart-list .produkt dt {
	width: 13.5em;
}
.cart-list .produkt dd {
	margin-bottom: .4em;
	width: 22em;
}
.cart-list .produkt .desc {
	width: 11em;
}
.cart-list .produkt .preise {
	display: flex;
		/*align-items: center;*/
		flex-wrap: wrap;
		gap: 0.5em 2em;
		justify-content: end;
	flex: 1 1 10em;
	padding-top: .3em;
	text-align: right;
}
.cart-list .produkt .preise > * {
	break-inside: avoid;
}
.cart-list .produkt .preise span {
	display: inline-block;
	min-width: 5em;
}
@media (max-width: 1000px) {
	.cart-list .produkt .content {
		flex-wrap: wrap;
	}
}

.cart-list .subprodukt {
	font-size: .8em;
	margin-top: -.5rem;
	margin-left: 2%;
}

.warenkorb-liste {
	font-size: .82em;
	font-weight: 500;
}
.warenkorb-liste > .col-8 {
	flex-grow: 1;
}
.warenkorb-liste > .col-grow {
	min-width: 300px;
}
.warenkorb-liste .gesamtkosten {
	border-collapse: separate;
	border-spacing: 0 5px;
	color: var(--grau);
	line-height: 1.25;
	margin-top: -5px;
	text-align: left;
	width: 100%;
}
.warenkorb-liste .gesamtkosten th {
	background: var(--highlight-color);
	color: #fff;
}
.warenkorb-liste .gesamtkosten tr > * {
	padding: .3em 0 .3em 1.5em;
}
.warenkorb-liste .gesamtkosten td:nth-child(2) {
	padding: .3em 1.5em .3em 0;
	text-align: right;
}
.warenkorb-liste .gesamtkosten tr.hrb td {
	border-bottom: 1px solid var(--highlight-color);
}
.warenkorb-liste .gesamtkosten tr.hrt td {
	border-top: 1px solid var(--highlight-color);
}
.warenkorb-liste .gesamtkosten tr.strong td {
	color: #000;
	padding-top: .6em;
}
.warenkorb-liste .gesamtkosten tr .button-wrap {
	padding-inline: 0;
}
.warenkorb-liste .gesamtkosten tr .button-wrap .button.submit {
	text-align: center;
	width: 100%;
}
.warenkorb .modal-infoblatt {
	margin-bottom: -.5em;
}
.warenkorb .modal-infoblatt .button {
	--bg: var(--highlight-color);
	margin-top: .5em;
	width: 13.2em;
}
@media (min-width: 1000px) {
	.warenkorb-liste > .col-8 {
		flex-grow: 0;
	}
}

.icon-bag-clone {
	background: var(--highlight-color);
	border-radius: 50%;
	box-shadow: 0 0 0 .3em var(--highlight-color);
	color: #fff;
	display: flex;
		align-items: center;
		justify-content: center;
	font-size: 1em;
	line-height: 1;
	margin: -.3em 0 0 -.1em;
	position: fixed;
	width: 1.2em;
	height: 1.2em;
	z-index: 22;
}

/* Kasse */
.kasse h1 {
	overflow: hidden;
}
.kasse h1 small {
	display: inline-block;
	font-size: .8em;
	margin-left: -.5em;
}
.kasse form div {
	text-align: inherit;
}
.kasse form.area:not(.bestaetigung) label {
	cursor: pointer;
}
.kasse .area .gruppe:not(:first-child) {
	border-top: 1px dashed #ccc;
	margin-top: .75em;
	padding-top: .75em;
}
.kasse .area .gruppe .vcard {
	hyphens: none;
	margin-bottom: 1.5em;
}
.kasse .area .row input[type="radio"] {
	display: none;
}
.kasse .area .row input[type="radio"] + label {
	margin-bottom: 1em;
}
.kasse .area .row input[type="radio"] + label > div {
	background: var(--hellgrau);
	height: 100%;
	padding: .7em .5em .4em;
	position: relative;
}	
.kasse .area .row input[type="radio"]:checked + label > div {
	box-shadow: inset 0 0 0 5px var(--highlight-color);
}

.kasse .area.versand .row input[type="radio"] + label > div {
	line-height: 1;
	padding: .7em .5em .4em 5em;
}
.kasse .area.versand img {
	max-width: 4.1em;
	position: absolute;
		top: .7em;
		left: .4em;
}
.kasse .modal .vcards-overview .col-4 > div {
	background: #fff;
	border-radius: 1em;
	display: flex;
		flex-direction: column;
	padding: .75em;
}
.kasse .modal .vcards-overview .col-4 > div > div:last-of-type {
	flex-grow: 1;
}
.kasse .lsDiv {
	margin: 0;
	min-height: 7.5em;
	position: relative;
}
.kasse .lsDiv:empty::before {
	content: 'Bitte laden Sie hier Ihren Lieferschein hoch.';
}
.kasse .lsDiv a {
	display: inline-block;
}
.vcard.lschein .filedrag + .uploadButtonsContainer {
	margin: 0;
	text-align: left;
	top: 0;
}

.kasse .area .row small {
	font-size: .6em;
}
.kasse .area .zahlungsarten label div {
	text-align: center;
}
.kasse .area .rechnungsadresse > input[type="radio"] {
	position: absolute;
	opacity: 0;
}

.kasse .area .rechnungsadresse > .row {
	max-height: 0;
	overflow: hidden;
	transition: max-height .8s cubic-bezier(0, 1, 0, 1) -.3s;
}
.kasse .area .rechnungsadresse > input[name="rechnungsadresse_abweichend"][value="1"]:checked ~ .row {
	max-height: 9999px;
	transition: max-height .8s cubic-bezier(0.5, 0, 1, 0) 0s;
}

.kasse .bestaetigung .lbl {
	display: block;
}
.kasse .bestaetigung input[type="text"],
.kasse .bestaetigung textarea {
	padding-block: 0;
	width: 100%;
}
.kasse .bestaetigung .gutschein .inpt_gutschein {
	margin-right: -2.4rem;
}
.kasse .bestaetigung .gutschein button {
	--bg-color: var(--hellgrau);
	border: 0;
	border-radius: 0 .5em .5em 0;
	padding: 0;
	vertical-align: middle;
	width: 2.4rem;
	height: 2.2rem;
}
.kasse .bestaetigung .gutschein button span {
	display: none;
}
@media (min-width: 650px) {
	.kasse .bestaetigung .lbl {
		display: inline-block;
		width: 8em;
	}
	.kasse .bestaetigung input[type="text"],
	.kasse .bestaetigung textarea {
		width: min(30em, 100% - 8.5em);
	}
}
.kasse .bestaetigung input[type="text"] {
	height: 2.2em;
	vertical-align: top;
}
.kasse .bestaetigung textarea {
	height: 5em;
}
.kasse .bestaetigung .anmerkungen div + div {
	margin-top: .5em;
}
.kasse .bestaetigung .action {
	background: var(--hellgrau);
	padding: .5em;
}
.kasse .action label.agb {
	margin-bottom: 0;
}
.kasse .action label.agb span.label {
	padding-top: 1px;
}
.kasse .bestaetigung .warenkorb-liste ~ * {
	line-height: 1.25;
	text-align: right;
}
.kasse .bestaetigung .gesamtkosten {
	margin-top: 1em;
}
.kasse .bestaetigung .gesamtkosten span {
	display: inline-block;
	hyphens: auto;
	max-width: calc(100% - 5.5em);
	vertical-align: top;
}
.kasse .bestaetigung .gesamtkosten span span {
	max-width: none;
}
.kasse .bestaetigung .gesamtkosten span.price {
	display: inline-block;
	width: 5em;
}
.kasse .bestaetigung p.red {
	color: red;
	font-weight: 500;
}
.kasse .datenuebergabe button,
.kasse .datenuebergabe a.button {
	--bg: var(--highlight-color);
	margin-bottom: .5em;
	text-align: center;
	width: 17em;
}

/* Overlay Adressbuch */
.has-3d {
	perspective: 2000px;
}
.has-3d .vcard.new {
	height: 13em;
	transform-style: preserve-3d;
	overflow: visible;
}
.vcards-overview .vcard.new > * {
	position: absolute;
	top: 0;
	left: 0;
	width: 250px;
	height: 200px;
	padding: 10px 20px;
}
.has-3d .vcard.new > * {
	backface-visibility: hidden;
	transform-style: preserve-3d;
	transition: transform 1s ease 0s;
	width: 100%;
	height: 100%;
}
.vcards-overview .vcard.new > form {
	--input-height: 2.3em;
	display: flex;
		flex-wrap: wrap;
		gap: .5em;
	padding-bottom: 15px;
}
.vcards-overview form.vcards-form {
	padding-left: 20px;
	clear: both;
	font-size: 0.87rem;
	line-height: 18px;
	text-align: left;
}
.has-3d form.vcards-form {
	transform: rotateY(180deg);
}
.vcards-overview.no-3d form.vcards-form {
	left: 100%;
	transition: left .3s ease 0s;
}
.has-3d .flipped > a {
	transform: rotateY(-180deg);
}
.has-3d .flipped form {
	transform: rotateY(0deg);
}
.vcards-overview.no-3d .flipped form {
	left: 0;
}
form.vcards-form label {
	flex: 1 0 45%;
	margin-bottom: 0;
}
form.vcards-form input:not([type="checkbox"]):not([type="radio"]),
form.vcards-form select {
	font-size: .8em;
	margin: 0;
	padding: .3em .3em 1px;
}
form.vcards-form select {
	margin: 0;
}
.kasse .vcard.new form button {
	position: static;
	margin-top: 5px;
}
.kasse .vcard.new form button::after {
	display: none;
}


/* Kontakt */
.textblock.formular .columns {
	columns: 2 500px;
	column-gap: calc(2 * var(--grid-gap));
	font-size: .8em;
}
.textblock.formular.hg-hellgrau input,
.textblock.formular.hg-hellgrau select,
.textblock.formular.hg-hellgrau textarea {
	border-color: var(--hellgrau);
}
form.columns label {
	margin-bottom: 1em;
}
form.columns label.lbl-chk {
	align-items: end;
	margin-bottom: 1.333em;
	min-height: calc(var(--input-height) / .75);
	left: 0;
}
form.columns label.lbl-chk .label {
	min-height: 1.6em;
}
form.columns label.lbl-chk .icon {
	align-self: end;
}
.textblock ~ .kontaktform-wrap {
	padding-top: 0;
}
.kontakt .pflichtinfo {
	display: block;
	font-size: 0.8rem;
	font-weight: 400;
	padding: 0.6em 0;
}
form div.send {
	align-self: end;
	text-align: right;
}
.kontakt .textblock.gmap-wrap {
	padding-bottom: 0;
}
.kontakt .google_map {
	margin-top: 3em;
}


/* CallBack */
.callback form.columns textarea {
	--lines: 8;
}


/* Downloads */
.download h2 {
	--factor-max: 2;
	--factor-min: 1.2;
	font-weight: 300;
	margin: 1em 0 .3em;
}
.download .file {
	margin: 0;
}
.download .file .button {
	--bg: var(--hellgrau);
	--bg-color: #000;
	display: flex;
		align-items: center;
	font-weight: 500;
	gap: .5em;
	padding: .5em;
	width: 100%;
	height: 100%;
}
.download .file .button .icon {
	flex-shrink: 0;
}


/* Aktuelles */
.aktuelles .news.row h2 {
	font-size: 1.33em;
	margin: 0;
}
.aktuelles .news.row p {
	margin: .6em 0;
}
.aktuelles .images {
	float: right;
	margin-left: 1.5em;
	width: 250px;
}


/* Referenzen */
body.referenzen main .row {
	align-items: end;
}
body.referenzen main .row > a {
	color: inherit;
	display: block;
	font-size: .9em;
	text-decoration: none;
}
body.referenzen main .row.details a {
	margin: 0;
}
