﻿
#newpage-button-80 {
	display: none;
}
#cms_root {
	display: flex;
	flex-direction: column;
	justify-content: center;
	flex-grow: 1;
}
#cont-1299::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, var(--overlay-opacity, 60%));
}
#text-1302 {
	text-align: center;
}
#text-1302 p {
	align-content: center;
	grid-template-areas: "";
}
#bild-2658 img {
	margin: 0 auto;
	display: block;
}
#form-field-2680 {
	text-align: center;
	max-width: 100% !important;
}
#form-field-2680 label {
	display: none;
}
#form-field-2676 {
	flex-direction: row !important;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 12px;
}
#form-field-2676 label {
	text-align: start;
	margin: 0 !important;
	vertical-align: middle;
	line-height: 1;
	font-weight: normal !important;
}
#form-field-2678 label {
	display: none;
}
#form-field-2651 label {
	display: none !important;
}
#text-2639 {
	--headline-padding-left: 20px;
	--headline-color: var(--hicolor);
	--headline-padding-right: 20px;
}
#text-2640 {
	--text-padding-left: 20px;
	--text-padding-right: 20px;
	--text-max-width: 800px;
	--text-margin-bottom: 62px;
}
#form-2637 {
	position: relative;
}
#form-2637 textarea {
	height: 100px;
	padding: 8px;
	box-sizing: border-box;
}
#form-2637 .content-cont {
	padding: 20px;
	gap: 20px;
}
#form-2637 .left-col {
	padding: 20px;
	background: var(--bgcolor2);
	border-radius: 16px;
	box-sizing: border-box;
}
#form-2637 .left-col .form-field:not(:has(input[type='hidden'])) {
	margin-bottom: 15px;
}
#form-2637 .form-field label {
	width: 100%;
	display: block;
	margin-bottom: 5px;
	font-weight: bold;
}
#form-2637 .form-field input , #form-2637 .form-field select {
	width: 100%;
	padding: 8px;
	border: 1px solid #ddd;
	border-radius: 4px;
	background: var(--bgcolor) !important;
	width: 100% !important;
	box-sizing: border-box;
}
#form-2637 .img-col {
	background: var(--bgcolor2);
	border-radius: 20px;
}
#form-2637 .img-col img {
	filter: drop-shadow(10px 14px 7px rgba(0, 0, 0, 0.3));
}
#form-2637 .check-info {
	background-color: var(--hicolor);
	color: white;
	padding: 12px;
	text-align: center;
	border-radius: 5px;
	margin: 10px 0;
	cursor: pointer;
	pointer-events: auto;
	padding-inline: 75px;
}
#form-2637 .checkInfo {
	align-self: center;
}
#form-2637 .review-cont {
	display: none;
	background: var(--bgcolor);
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 999;
	padding-block: 100px;
	flex-wrap: wrap;
	top: 0;
	left: 0;
	box-sizing: border-box;
	overflow-y: auto;
}
#form-2637 .cols-cont {
	background: var(--bgcolor2);
	gap: 12px;
	width: 100%;
	max-width: var(--content-width, 1200px);
	margin-inline: auto;
	flex-wrap: wrap;
	padding: 20px;
	box-sizing: border-box;
	border-radius: 20px;
}
#form-2637 .review-left-col {
	flex-basis: 50%;
	padding: 12px;
	padding-inline-end: 10%;
	box-sizing: border-box;
}
#form-2637 .selected-info .info {
	font-weight: bold;
}
#form-2637 .restaurant-info {
	padding: 20px;
	background-color: #f9f9f9;
	border-radius: 8px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	text-align: center;
	margin: 20px 0 10px 0;
}
#form-2637 .restaurant-info .restaurant-name {
	font-size: 1.5rem;
	font-weight: bold;
	color: #333;
	margin-bottom: 10px;
}
#form-2637 .restaurant-info .restaurant-address {
	font-size: 1rem;
	color: #555;
	line-height: 1.5;
}
#form-2637 .review-right-col {
	gap: 8px;
}
#form-2637 .review-right-col input , #form-2637 .review-right-col .textarea {
	width: 100% !important;
	border-radius: 4px;
}
#form-2637 .review-cont .form-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
#form-2637 .review-cont .form-field .small {
	font-size: 0.9rem;
	opacity: 0.8;
	font-weight: normal;
}
#form-2637 .review-bottom-col {
	flex-flow: row;
	flex-wrap: wrap;
	justify-content: center;
	column-gap: 20px;
	padding: 16px;
	box-shadow: 0px 0px 19px 0px color-mix(in lab, var(--color) 10%, var(--hicolor) 10%);
	box-sizing: border-box;
	border-radius: 12px;
}
#form-2637 .review-bottom-col .datenschutz {
	width: 100%;
}
#form-2637 .review-bottom-col .close-review-cont {
	flex: 1;
	max-width: 300px !important;
}
#form-2637 .review-bottom-col .close-review-cont label {
	display: none;
}
#form-2637 .review-bottom-col .close-review-cont .close-window {
	background-color: var(--bgcolor);
	color: var(--color);
	padding: 12px;
	text-align: center;
	border-radius: 5px;
	margin: 10px 0;
	cursor: pointer;
	pointer-events: auto;
	padding-inline: 75px;
	border: none;
	font-weight: bold;
}
#form-2637 .review-bottom-col .Senden {
	flex: 1;
	max-width: 300px !important;
}
#form-2637 .review-bottom-col .Senden label {
	display: none;
}
#form-2637 .review-bottom-col .Senden button {
	background-color: var(--hicolor);
	color: var(--bgcolor);
	padding: 12px;
	text-align: center;
	border-radius: 5px;
	margin: 10px 0;
	cursor: pointer;
	pointer-events: auto;
	padding-inline: 75px;
	border: none;
	font-weight: bold;
	white-space: nowrap;
}
#form-2637 .error-message {
	padding: 8px;
	border: 1px solid var(--hicolor);
	margin-block-start: 12px;
	border-radius: 12px;
	background: var(--bgcolor);
	background: color-mix(in lab, var(--hicolor) 10%, transparent);
	font-size: 0.9rem;
}
#form-2637 .booking-wrapper {
	margin: 0;
	padding: 20px;
}
#form-2637 .booking-card {
	background: var(--bgcolor);
	border-radius: 12px;
	text-align: center;
	margin: 20px auto;
}
#form-2637 .booking-status-icon {
	width: 64px;
	height: 64px;
	margin-bottom: 24px;
	fill: #4CAF50;
}
#form-2637 .booking-title {
	color: var(--color);
	margin-bottom: 16px;
	font-size: 1.6rem;
}
#form-2637 .booking-title.status {
	color: yellow !important;
	margin-block-start: 0;
	margin-block-end: 12px;
	background: black;
	display: inline-block;
	padding: 4px;
	border-radius: 4px;
	font-size: 1rem !important;
}
#form-2637 .booking-text {
	color: var(--color);
	opacity: 0.7;
	line-height: 1.6;
	margin-bottom: 24px;
}
#form-2637 .booking-button {
	display: inline-block;
	padding: 12px 24px;
	border-radius: 6px;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.3s ease;
	margin: 8px;
}
#form-2637 .booking-button--primary {
	background: var(--hicolor);
	color: var(--bgcolor) !important;
	border: none;
}
#form-2637 .booking-button--primary:hover {
	background: color-mix(in lab, var(--hicolor) 100%, black 20%);
}
#form-2637 .booking-button--secondary {
	background: var(--bgcolor);
	color: var(--hicolor) !important;
	outline: 2px solid var(--hicolor);
	outline-offset: -2px;
	box-sizing: border-box;
}
#form-2637 .booking-button--secondary:hover {
	color: color-mix(in lab, var(--hicolor) 100%, black 20%) !important;
	outline-color: color-mix(in lab, var(--hicolor) 100%, black 20%);
}
#form-2637 .booking-details {
	background: var(--bgcolor2);
	border-radius: 8px;
	padding: 16px;
	margin: 24px 0;
	text-align: left;
}
#form-2637 .booking-details__item {
	margin: 8px 0;
}
#form-2637 .booking-action-group {
	margin-top: 24px;
}
#form-2637 .open-close-info {
	background-color: var(--bgcolor);
	border-radius: 8px;
	padding: 12px;
	box-shadow: 0 2px 8px var(--bgcolor);
}
#form-2637 .open-close-info p {
	color: var(--color);
	font-size: 16px;
	font-weight: 600;
	border-bottom: 2px solid var(--bgcolor2);
	padding-bottom: 10px;
}
#form-2637 .open-close-info ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
#form-2637 .open-close-info ul li {
	padding: 8px 0;
	color: var(--color);
	font-size: 14px;
	border-bottom: 1px solid var(--bgcolor2);
	display: flex;
	flex-wrap: wrap;
}
#form-2637 .open-close-info ul li:last-child {
	border-bottom: none;
}
#form-2637 .open-close-info ul li:contains('Ruhetag') {
	color: var(--color);
	font-weight: 500;
}
#col-2688 {
	z-index: 1;
}
#cont-2685 {
	align-items: var(--col-align-items,inherit);
	padding-top: var(--section-padding-top);
	padding-bottom: var(--section-padding-bottom);
	--section-padding-top: 50px;
	--section-padding-bottom: 50px;
}
#shop-warenkorb-1310 {
	position: sticky;
	bottom: 5%;
	z-index: 10;
	margin: 50px 10px auto;
	display: flex;
	justify-content: center;
}
#shop-warenkorb-1310 a {
	text-decoration: none;
	color: inherit;
	white-space: nowrap;
}
#shop-warenkorb-1310 .wkheadernew {
	visibility: hidden;
	position: sticky;
	top: 10%;
	background-color: var(--hicolor);
	color: var(--bgcolor);
	font-size: var(--wkheader-font-size, 20px);
	text-align: center;
	padding: 10px 20px;
	border: none;
	cursor: pointer;
	display: inline-block;
	text-decoration: none;
	border-radius: 5px;
}
#shop-warenkorb-1310 .wkheadernew i.fa-solid {
	margin-left: 8px;
}
#shop-warenkorb-1310 .wkheadernew.visible {
	visibility: visible;
}
#shop30-artikel-2691 {
	font-family: 'Times New Roman', serif;
}
#shop30-artikel-2691 h2 {
	font-family: 'Times New Roman', serif;
}
#shop30-artikel-2691 h3 {
	margin-bottom: 0;
}
#shop30-artikel-2691 .title-select {
	display: flex;
	margin-block: 20px;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
#shop30-artikel-2691 .title-select h2 {
	margin: 0;
	flex: 1 0 50%;
	font-size: 3rem;
	font-weight: bold;
}
#shop30-artikel-2691 .menu-container {
	display: flex;
	flex-direction: column;
	gap: 30px;
}
#shop30-artikel-2691 .category-group {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	gap: 16px;
}
#shop30-artikel-2691 .category-group h2 {
	width: 100% !important;
	font-size: 28px;
	color: var(--color);
	border-bottom: 1px solid var(--color);
	padding-bottom: 8px;
	margin-bottom: 20px;
	font-weight: bold;
	font-family: 'Times New Roman', serif;
}
#shop30-artikel-2691 .card {
	background: var(--bgcolor);
	padding: 15px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	flex: 1 0 100%;
	box-sizing: border-box;
	gap: 12px;
	border-bottom: 1px dotted var(--locolor);
}
#shop30-artikel-2691 .img {
	height: 100px;
	aspect-ratio: 1 / 1;
}
#shop30-artikel-2691 .img img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: 4px;
	filter: drop-shadow(var(--locolor) 11px 9px 13px);
}
#shop30-artikel-2691 .card-content {
	display: flex;
	flex-direction: column;
	flex: 1 1 0%;
	gap: 8px;
}
#shop30-artikel-2691 .produkt-title {
	font-weight: bold;
}
#shop30-artikel-2691 .allergy {
	font-size: 0.9rem;
	opacity: 0.6;
}
#shop30-artikel-2691 .short-text {
	font-size: 0.9rem;
	opacity: 0.6;
}
#shop30-artikel-2691 .price-eingabe {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-end;
}
#shop30-artikel-2691 .price {
	font-size: 1rem;
	font-weight: bold;
	color: var(--color);
}
#shop30-artikel-2691 .normal-price {
	color: var(--color);
}
#shop30-artikel-2691 span.old-price {
	display: block;
	font-size: 0.8rem;
	text-align: start;
	text-decoration: line-through;
	opacity: 0.6;
}
#shop30-artikel-2691 span[style*='position: relative'] {
	display: inline-block;
	position: relative;
}
#shop30-artikel-2691 input[type='checkbox'][name='__anzahl'] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 38px;
	aspect-ratio: 1 / 1;
	height: auto;
	border-radius: 50%;
	border: 1px solid var(--hicolor);
	background: transparent;
	cursor: pointer;
	position: relative;
	outline: none;
}
#shop30-artikel-2691 input[type='checkbox'][name='__anzahl']::before {
	content: "+";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	color: var(--color);
}
#shop30-artikel-2691 input[type='checkbox'][name='__anzahl']:checked {
	background-color: var(--hicolor);
}
#shop30-artikel-2691 .no-results {
	display: none !important;
}
#shop30-artikel-2691 .eingabe {
	position: relative;
	display: flex;
	align-items: center;
	border: 1px solid var(--bgcolor2);
	border-radius: 20px;
	overflow: hidden;
	background: var(--bgcolor);
	height: 24px;
	box-shadow: 0 1px 3px var(--bgcolor2);
	width: fit-content;
}
#shop30-artikel-2691 .plusminus {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	cursor: pointer;
	user-select: none;
	font-size: 18px;
	font-weight: 500;
	color: var(--color);
	transition: background-color 0.2s;
}
#shop30-artikel-2691 .plusminus:hover {
	background-color: var(--hicolor);
}
#shop30-artikel-2691 .plusminus.minus {
	border-right: 1px solid var(--bgcolor2);
}
#shop30-artikel-2691 .plusminus.plus {
	border-left: 1px solid var(--bgcolor2);
}
#shop30-artikel-2691 .input {
	position: relative;
	display: flex;
	align-items: center;
	height: 100%;
}
#shop30-artikel-2691 .input input[type='number'] {
	width: 40px;
	height: 100%;
	border: none;
	text-align: center;
	font-size: 14px;
	font-weight: 500;
	color: var(--color);
	padding: 0 2px;
	background: transparent;
}
#shop30-artikel-2691 .input input[type='number']::-webkit-outer-spin-button , #shop30-artikel-2691 .input input[type='number']::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
#shop30-artikel-2691 .wk-add-msg {
	position: absolute;
	top: 100%;
	left: 0;
	font-size: 12px;
	color: var(--color);
	opacity: 0.6;
	text-align: center;
	margin-top: 4px;
	width: 150px !important;
	transform: translateX(-50%);
}
@media (max-width:800px) /* responsive */ {
	#form-2637 .content-cont {
		flex-direction: column-reverse;
	}
	#shop30-artikel-2691 .cat-btns {
		display: none;
	}
	#shop30-artikel-2691 .cat-dropdown {
		display: block;
	}
	#shop30-artikel-2691 .plusminus {
		width: 30px;
	}
	#shop30-artikel-2691 .input input[type='number'] {
		width: 25px;
	}
}

@media (max-width:450px) {
	#shop30-artikel-2691 .price-eingabe {
		flex-direction: row;
		align-items: center;
		width: 100%;
	}
}
