/* ################################################## */
/* FONTS */

/* Chewy – Überschriften */
@font-face {
  font-family: 'chewy';
  src: url("../media/fonts/Chewy-Regular.ttf");
  font-display: swap;
}

/* Mukta Malar – Fließtext */
@font-face {
  font-family: 'mukta-regular';
  src: url("../media/fonts/MuktaMalar-Regular.ttf");
  font-display: swap;
}
@font-face {
  font-family: 'mukta-bold';
  src: url("../media/fonts/MuktaMalar-Bold.ttf");
  font-display: swap;
}
@font-face {
  font-family: 'mukta-semibold';
  src: url("../media/fonts/MuktaMalar-SemiBold.ttf");
  font-display: swap;
}
@font-face {
  font-family: 'mukta-light';
  src: url("../media/fonts/MuktaMalar-Light.ttf");
  font-display: swap;
}

/* ################################################## */
/* ROOT VARIABLEN */
:root {
	/* Farben */
	--c1: rgb(15,15,15);
	--c2: rgb(45,45,45);
	--c3: rgb(120,10,10);
	--c4: rgb(170,10,10);
	
	--rot: #E31E24;
	--rot: rgb(255,100,100);
	--gruen: #3FAB3C;
	
	--ca: rgb(255,0,0);
	--ctxt: rgb(250,250,250);
	
	--c-error: 	 rgb(255,0,0);
	--c-success: rgb(0,255,0);
	
	/* Größen */
	--d1: 8px;
	--d2: 16px;
	--d3: 32px;
	--d4: 64px;
	
	--dh: 100vh;
	
	--br: 10px;
	
	/* Transitions */
	--t1: 0.2s;
	--t2: 0.4s;
	--t3: 0.8s;
	
	/* Schatten */
	--bshad: 0 0 15px rgb(0,0,0);
	--tshad: 0 0 15px rgb(0,0,0);
	
	/* Navigation */
	--nav-max-height: 200px;
	--nav-min-height: 45px;
}

/* ################################################## */
/* GRUNDLEGENDES MARKUP */
body {
	margin: 0; padding: 0;
	background-color: var(--c1);
	background: url('../media/imgs/schiefer-bg.jpg');
}
*, *:before, *:after {
	-webkit-box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-ms-box-sizing: border-box !important;
	box-sizing: border-box !important;
	
	margin: 0; padding: 0;
	color: var(--ctxt);
	font-family: 'mukta-regular';
	font-style: normal; font-weight: normal;
	font-size: 12pt;
	line-height: 1.4em;
	font-variant-ligatures: none;
	hyphens: auto;
}

html, html * {
	scrollbar-width: thin;
	scrollbar-color: var(--ca) var(--c1);
}
::-webkit-scrollbar {
	background-color: var(--blk1);
	width: 20px; height: 20px;
}
::-webkit-scrollbar-thumb {
	box-shadow: inset 0 0 10px 10px var(--ca);
    border: solid 7px transparent;
	border-radius: 10px;
}
::-webkit-scrollbar-track { background-color: var(--blk1); }
::-webkit-scrollbar-corner { background: var(--blk1); }

h1 { font-size: 2.5em;  font-family: 'chewy'; color: var(--rot); }
h2 { font-size: 2.0em; 	font-family: 'mukta-bold'; }
h3 { font-size: 2.0em; 	font-family: 'chewy'; text-transform: uppercase; letter-spacing: 1px; }
h4 { font-size: 1.2em; 	font-family: 'mukta-semibold'; }
h5 { font-size: 1.0em; 	font-family: 'mukta-semibold'; }
h6 { font-size: 1.0em; 	font-family: 'mukta-semibold'; }

c, c * { color: var(--ca); }
b, b * { font-family: 'mukta-bold'; }

img { display: block; }

input, textarea, button {
	outline: none;
	border: 0;
	padding: var(--d2);
	background-color: var(--c2);
	accent-color: var(--ca);
}
input:focus, textarea:focus {
	outline: none;
	border-color: var(--ca);
}

button, input[type='submit'] { 
	cursor: pointer; 
	background-color: var(--c2);
}
input[type = 'checkbox'] {
	background-color: var(--c1);
}
input[type = 'checkbox'] + label { user-select: none; }

table {
	border-collapse: collapse;
	border-radius: var(--br);
	overflow: hidden;
}
th,td {
	text-align: left;
	padding: var(--d1); 
}
th { 
	font-family: 'mukta-bold';
	background-color: var(--c4);
}
tr { background-color: var(--c3); }
tr:nth-child(odd) { background-color: var(--c2); }

ul { padding-left: 2em; }
li { list-style: none; }
li:before { content: '»\00a0\00a0'; margin-left: -1.4em; }

/* ################################################## */
/* Z-INDEX */
#nav 			{ z-index: 10;	}
#query-msg-cont { z-index: 10; 	}
#contact 		{ z-index: 9; 	}
#shopping-cart 	{ z-index: 9; 	}
.conf-win [name = 'win'] { z-index: 8; }
.cart-item-popup { z-index: 8; }

/* ################################################## */
/* HAUPTSTRUKTUREN */

/* Navigationsleiste */
#nav {
	position: fixed; top: 0;
	width: 100%; height: var(--nav-max-height);
	padding: var(--d2); 
	
	background-color: var(--c1);
	box-shadow: var(--bshad);
}
#nav > * { position: relative; }
#nav-top {}
#nav-bottom {}

#nav-logo { 
	display: block;
	position: relative;
	width: 100%; height: 100px; 
	margin-left: auto;
}
#nav-logo img {
	height: 100%;
	top: 0; left: 0;
	position: absolute;
	transform-origin: center center;
}
#nav-title {
	position: absolute;
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	
	padding: inherit;
	top: 0; right: 0;
	width: 100%; height: 100px;
	opacity: 1;
	pointer-events: none;
}
#nav .hr-it { 
	margin: var(--d2) 0 var(--d2) auto; 
}

#nav-links {
	display: flex; gap: var(--d1);
	align-items: center; justify-content: center;
	height: var(--nav-min-height); 
}
#nav a {
	font-family: 'mukta-semibold';
	text-decoration: none;
	text-transform: uppercase;
}

/* Navigation bei Scroll */
#nav.min {
	height: var(--nav-min-height);
	padding: 0;
}
#nav.min #nav-logo {
	width: 0; height: 0;
}
#nav.min #nav-logo [name = 'logo'] { 
	opacity: 0;
}
#nav.min #nav-logo [name = 'schneider'] {
	transform: rotate(30deg) translate(-10%, 40%);
	opacity: 0;
}
#nav.min #nav-title {
	opacity: 0;
}
#nav.min .hr-it {
	width: 0; height: 0;
	opacity: 0;
	margin: 0 0 0 auto;
}

:root { --navtime: 0.15s; /* Zeit, an der sich alles orientiert. */ }
#nav.min 		{ transition: var(--navtime) calc(var(--navtime) * 3); }
#nav:not(.min) 	{ transition: var(--navtime) 0s; }
#nav.min #nav-logo { 
	transition: 
		width calc(var(--navtime) * 2) var(--navtime), 
		height var(--navtime) calc(var(--navtime) * 3); 
}
#nav:not(.min) #nav-logo { 
	transition: 
		width 	calc(var(--navtime) * 2) var(--navtime), 
		height 	var(--navtime) 0s;
}
#nav.min 		#nav-logo [name = 'logo'] { transition: opacity var(--navtime) 0s; 	}
#nav:not(.min) 	#nav-logo [name = 'logo'] { transition: opacity var(--navtime) calc(var(--navtime) * 3); 	}
#nav.min #nav-logo [name = 'schneider'] { 
	transition: 
		opacity 	var(--navtime) calc(var(--navtime) * 2), 
		transform 	var(--navtime) 0s; 
}
#nav:not(.min) #nav-logo [name = 'schneider'] { 
	transition: 
		opacity 	var(--navtime) var(--navtime), 
		transform 	var(--navtime) calc(var(--navtime) * 3); 
}
#nav.min 		#nav-title { transition: var(--navtime); }
#nav:not(.min) 	#nav-title { transition: var(--navtime) calc(var(--navtime) * 3); }
#nav.min .hr-it {
	transition: 
		width 	calc(var(--navtime) * 2) var(--navtime), 
		opacity var(--navtime) calc(var(--navtime) * 2), 
		margin 	var(--navtime) calc(var(--navtime) * 3), 
		height 	var(--navtime) calc(var(--navtime) * 3);
}
#nav:not(.min) .hr-it { 
	transition: 
		width 	calc(var(--navtime) * 2) var(--navtime), 
		opacity var(--navtime) var(--navtime), 
		margin 	var(--navtime) 0s,  
		height 	var(--navtime) 0s;  	
}
#nav.min 		#nav-links { transition: var(--navtime) calc(var(--navtime) * 3); }
#nav:not(.min) 	#nav-links { transition: var(--navtime) 0s; }

/* Navigations Button */
#nav-btn {
	position: absolute;
	top: 8px; right: 8px;
	width: 35px; height: 30px;
	cursor: pointer;
	
	display: none;
}
#nav-btn > * { 
	position: absolute; 
}
.navbtn-bar {
	position: absolute;
	width: 100%; height: 4px;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	background-color: var(--ctxt);
	
	transition: 0.2s;
}
.navbtn-bar.bar1 { 
	top: 2px;
	transition: transform 0.4s 0.2s, top 0.2s 0.4s;
}
.navbtn-bar.bar1::after { /* Kreis */
	content: ''; position: absolute;
	right: -10%; top: 50%;
	transform: translateY(-50%);
	
	width: 0; height: 0;
	border-radius: 50%;
	background-color: var(--ctxt);
	transition: 0.2s;
}
.navbtn-bar.bar2 {
	transition: 0.2s 0.4s;
}
.navbtn-bar.bar3 { 
	top: calc(100% - 2px);
	transition: 0.2s, transform 0.4s 0.2s, top 0.2s 0.4s;
}

#nav-btn.active {}
#nav-btn.active .navbtn-bar.bar1 {
	top: 50%;
	transform: translate(-50%, -50%) rotate(225deg);
	transition: 0.2s, transform 0.4s 0.2s;
}
#nav-btn.active .navbtn-bar.bar1::after { /* Kreis */
	width: 18px; height: 18px;
	transition: 0.2s 0.4s;
}
#nav-btn.active .navbtn-bar.bar2 { opacity: 0; }
#nav-btn.active .navbtn-bar.bar3 {
	top: 50%; width: 50%;
	transform: translate(-50%, -50%) rotate(135deg);
	transition: 0.2s, transform 0.4s 0.2s, width 0.2s 0.6s;
}

#main {
	width: 100%; 
	margin-top: var(--nav-max-height);
}
#page {
	display: flex; flex-direction: column;
	gap: var(--d2);
}
#page-header {}
#page-content {
	padding: var(--d3);
	display: flex; gap: var(--d2);
}
#page-left {
	flex: 1 0 0;
	display: flex; flex-direction: column;
	align-items: center; gap: var(--d2);
}
#page-right {
	flex: 1 0 0;
	display: flex; flex-direction: column;
	/* align-items: center;  */
	gap: var(--d2);
}

#footer {
	display: flex; flex-direction: column;
	align-items: center;
	gap: var(--d1);
	
	padding: var(--d2);
	margin-bottom: 120px; /* Shopping-Cart */
}

/* ################################################## */
/* SPEZIELLE ELEMENTE */

/* Formen für Nutzer Interaktion */
/* Allgemeines Layout für Nutzerdaten-Formen */
.userdata-form {
	min-width: 300px;
	padding: var(--d1);
	
	display: flex; flex-direction: column;
	gap: var(--d1);
	
	background-color: var(--c4);
	border-radius: var(--br);
}
.userdata-form input {
	background-color: var(--c3);
	border-radius: var(--br);
}
#login-form {}
#register-form {}
#logout-form {}
#change-password-form {}

/* Kontaktdaten Anzeige */
#contact {
	position: fixed;
	right: 0; bottom: calc(120px + var(--d1));
	transform: translateX(calc(100% - 60px));
	
	display: flex; gap: 10px;
	align-items: center;
	
	padding: 10px;
	
	box-shadow: var(--bshad);
	border-radius: var(--br) 0 0 var(--br);
	background-color: var(--c4);
	transition: var(--t1);
	cursor: pointer;
}
#contact img { width: 40px; }
#contact a { text-decoration: none; }
#contact.active {
	transform: translateX(0);
}

/* Registrations-Form */
#register-form {
	display: flex; flex-direction: row;
	flex-wrap: wrap; gap: var(--d1);
}
#register-form input { width: 100%; }
#register-form [name = 'street'] 		{ width: calc(50% - var(--d1) / 2); }
#register-form [name = 'street_extra'] 	{ width: calc(50% - var(--d1) / 2); }
#register-form [name = 'plz'] 			{ width: calc(50% - var(--d1) / 2); }
#register-form [name = 'town'] 			{ width: calc(50% - var(--d1) / 2); }

/* Form mit allen Nutzerdaten (Bestell-Checkout & Datenänderung auf Profil) */
#user-data-form {
	flex-direction: row; flex-wrap: wrap;
}
#user-data-form input { width: 100%; }
#user-data-form [name = 'email'] 		{ width: calc(50% - var(--d1) / 2 ); }
#user-data-form [name = 'phone'] 		{ width: calc(50% - var(--d1) / 2 ); }
#user-data-form [name = 'street'] 		{ width: calc(50% - var(--d1) / 2 ); }
#user-data-form [name = 'street_extra'] { width: calc(50% - var(--d1) / 2 ); }
#user-data-form [name = 'plz'] 			{ width: calc(50% - var(--d1) / 2 ); }
#user-data-form [name = 'town'] 		{ width: calc(50% - var(--d1) / 2 ); }

/* Kontaktformular */
#contact-form {
	padding: var(--d1);
	border-radius: var(--br);	
	text-align: center;
	
	background-color: var(--c4);
}
#contact-form form {
	display: flex; flex-direction: column;
	gap: var(--d1);
}
#contact-form input, 
#contact-form textarea {
	border-radius: var(--br);
	background-color: var(--c3);
}
#contact-form label { font-size: 0.8em; }

/* Bestellform */
#order-form {
	width: 100%;
	align-items: stretch;
}
#order-form .block-body {
	flex: auto;
	gap: var(--d3);
	
	/* max-height: 800px; */
	/* overflow-y: scroll; */
}

#order-form .tab-window-block {
	border-color: var(--c2);
	background-color: var(--c2);
}
#order-form .tab-window-btns p {
	background-color: var(--c4);
}
#order-form .tab-window-btns p.active {
	background-color: var(--c2);
}
#order-form .win-head {
	background-color: var(--c2);
}
#order-form .win-body {
	flex: auto;
	display: flex;
	gap: 2px;
	padding: 0; 
	background-color: var(--c2);
	border-radius: var(--br);
	overflow: hidden;
}

.order-item {
	width: 100%; height: auto;
}

.order-item-btn { /* Bild & Titel */
	position: relative;
	height: 90px;
	padding: var(--d1);
	overflow: hidden;
	
	background-color: var(--c1);
	
	z-index: 0;
	cursor: pointer;
	overflow: hidden;
}
.order-item-btn [name = 'image'] {
	position: absolute;
	right: 0; top: 50%;
	transform: translateY(-50%);
	width: 50%; height: auto;
	
	z-index: -1;
}
.order-item-btn [name = 'image']::after {
	content: ''; position: absolute;
	width: 80%; height: 100%;
	top: 0; left: 0;
	background: linear-gradient(to right, var(--c1), transparent);
}
.order-item-btn [name = 'image'] img {
	width: 100%; height: 100%;
	object-fit: cover;
	padding: 0;
}
.order-item-btn [name = 'title'] { 
	grid-area: name;
}
.order-item-btn [name = 'ingr'] {
	grid-area: ingr;
	margin-bottom: var(--d1);
	max-width: 80%;
}

.order-item-btn .lowest-price {
	position: absolute;
	right: 0; top: 60%;
	transform: translate(0,-50%);
	
	display: flex; flex-direction: column;
	
	padding: inherit;
	font-size: 45px;
	line-height: 180%;
	text-shadow: var(--tshad);
}
.order-item-btn .lowest-price::before {
	content: 'Schon ab'; position: absolute;
	top: 0; right: 0;
	padding: inherit;
	
	font-size: 14pt;
}

.order-item .arrow {
	position: absolute;
	bottom: var(--d1); left: 50%;
	transform: translate(0,-50%) rotate(45deg);
	
	width: 0.65em; height: 0.65em;
	border: solid var(--ca);
	border-width: 0 4px 4px 0;
	transition: var(--t1);
}
.order-item.active .arrow {
	transform: translate(0,-50%) rotate(225deg);
}

.order-item.active + .order-item .order-item-btn {
	border-radius: var(--br) var(--br) 0 0;
}

.order-item-cont { /* Preise & Extras */
	height: 0;
	display: flex; flex-direction: column;
	gap: var(--d1);
	
	background-color: var(--c4);
	border-radius: 0 0 var(--br) var(--br);
	
	transition: var(--t1);
	visibility: hidden; opacity: 0;
}
.order-item-cont.active {
	visibility: visible; opacity: 1;
	padding: var(--d1);
	margin-bottom: var(--d1);
}
.order-item-cont [name = 'prices'] {
	display: flex; gap: var(--d1);
	width: 100%;
}
.order-item-cont [name = 'prices'] input { display: none; }
.order-item-cont [name = 'prices'] label {
	flex: 1 0 0;
	position: relative;
	background-color: var(--c1);
	padding: var(--d1);
	border-radius: var(--br);
	cursor: pointer;	
}
.order-item-cont [name = 'prices'] label [name = 'size-name'] {
	opacity: 0.7;
	font-size: 10pt;
}
.order-item-cont [name = 'prices'] label [name = 'value'] { font-size: 14pt; }
.order-item-cont [name = 'prices'] input:checked + label {
	background-color: var(--c3);	
}

.order-item-cont [name = 'checkmark'] {
	display: none; /* Nur in input:checked + label */
	
	position: absolute;
	top: 50%; right: var(--d1);
	transform: translate(0,-50%);
	
	width: 20px; height: 20px;
	background-color: var(--c1);
	border: 2px solid var(--ctxt);
	border-radius: 50%;
}
.order-item-cont [name = 'checkmark']::after {
	content: ''; position: absolute; 
	width: 40%; height: 60%;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%) rotate(45deg);
	
	border: solid var(--ctxt);
	border-width: 0 3px 3px 0;
}
.order-item-cont [name = 'prices'] input:checked + label [name = 'checkmark'] {
	display: block;
}

.order-item-cont [name = "extras"] .search-box-list {
	display: flex; flex-wrap: wrap;
	gap: var(--d1);
	padding: var(--d1);
	background-color: var(--c1);
	overflow-y: hidden;
}
.order-item-cont .item-extra-btn {
	padding: var(--d1);
	background-color: var(--c2);
	border-radius: var(--br);
	cursor: pointer;
}
.order-item-cont .item-extra-btn::before { content: '+ '; }
.order-item-cont input:checked + .item-extra-btn::before { content: '- '; }
.order-item-cont [name = "extras"] .search-box-list input { display: none; }
.order-item-cont [name = "extras"] .search-box-list input:checked + .item-extra-btn {
	background-color: var(--c3);
}
.order-item-cont [name = 'extra-prices'] p { 
	display: none;
	opacity: 0.7;
}

.order-item .checkout-btn {
	border-radius: var(--br);
}

/* Warenkorb */
#shopping-cart {
	position: fixed; 
	left: 0; bottom: 0;
	width: 100%; height: 0;
	
	background-color: var(--c3);
	box-shadow: var(--bshad);
	
	display: flex; gap: var(--d1);
	align-items: center;
	
	transition: var(--t1);
	overflow: hidden;
}
#shopping-cart.active {
	height: 120px;
	padding: var(--d1);
	border-top: var(--c4) var(--d1) solid;
}
#cart-checkout-link {
	margin-left: auto;
	height: 100%; width: 100px;
	padding: var(--d1);
	
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	
	background-color: var(--c4);
	border-radius: var(--br);
	text-decoration: none;
	hyphens: none;
}
#cart-checkout-link img {
	min-height: 0;
	max-width: 80%;
}
#cart-checkout-link p { hyphens: none; }

.cart-item {
	position: relative;
	width: 100px; height: 100%;
	
	display: flex; flex-direction: column;
	align-items: center; justify-content: center;
	text-align: center;
	
	border-radius: var(--br);
	z-index: 0;
	
	cursor: pointer;
}
.cart-item * { 
	hyphens: none;
	user-select: none;
}
.cart-item [name = "name"] {}
.cart-item [name = "size"] { 
	opacity: 0.7;
	font-size: 10pt;
}
.cart-item img {
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	border-radius: var(--br);
	opacity: 0.4;
	z-index: -1;
}
.cart-item .delete {
	position: absolute;
	top: 0; right: 0;
	transform: translate(20%,-20%);
	
	width: 24px; height: 24px;
	background-color: var(--c1);
	border: 2px solid var(--ctxt);
	border-radius: 50%;
	cursor: pointer;
}
.cart-item .delete::after {
	content: '✕'; position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	font-weight: 1600;
	font-size: 9pt;
	
	display: flex; align-items: center;
	justify-content: center;
}
.cart-item [name = "number"] {
	display: none;
	
	position: absolute;
	bottom: 2px; right: 2px;
	
	padding: 1px 6px;
	background-color: var(--c3);
	border: 2px solid var(--c4);
	box-shadow: 0 0 2px var(--c4);
	border-radius: var(--br);
	
	z-index: 1;
}
.cart-item [name = "number"].active { display: block; }
.cart-item [name = "number"]::after {
	content: 'x';
}
.cart-item [name = "extra-indicator"] { 
	opacity: 0.7;
	font-size: 10pt; 
}

.cart-item-popup {
	position: absolute;
	bottom: calc(100% + var(--d1) * 3);
	left: 0;
	
	padding: var(--d1);
	border-radius: var(--br);
	background-color: var(--c2);
	border: 2px var(--c4) solid;
	
	/* opacity: 0; visibility: hidden; */
	/* transition: var(--t1); */
}
.cart-item-popup.active {
	/* opacity: 1; visibility: visible; */
}

.cart-item.highlight {
	animation: cart-item-fade 3s;
}
@keyframes cart-item-fade {
	from { box-shadow: 0 0 15px var(--ctxt); }
	to { box-shadow: 0; }
}

/* Checkout */
#checkout-form {
	display: flex; flex-direction: column;
	gap: var(--d2);
}
#checkout-delivery-area {
	width: 100%;
	display: flex; flex-wrap: wrap;
	gap: var(--d1);
}
#checkout-remark {
	resize: none;
	width: 100%;
	border-radius: var(--br);
}

#checkout-item-cont {
	display: flex; flex-direction: column;
	gap: var(--d1);
}
.checkout-item {
	position: relative;
	width: 100%;
	padding: var(--d1);
	background-color: var(--c2);
	border-radius: var(--br);
	
	display: grid; gap: var(--d1);
	grid-template-rows: auto 1fr auto auto auto;
	grid-template-columns: repeat(3, 1fr);
	grid-template-areas:
		'title title del'
		'img num num'
		'img price price'
		'img extra extra'
		'img total total'
}
.checkout-item [name = 'title'] { 
	grid-area: title;
	display: flex; gap: var(--d2);
	align-items: center;
}
.checkout-item [name = 'title'] [name = 'size'] { opacity: 0.8; }
.checkout-item [name = 'delete'] { 
	grid-area: del;
	display: flex; justify-content: end;
}
.checkout-item [name = 'delete'] p {
	grid-area: del;
	color: red;
	cursor: pointer;
}
.checkout-item [name = 'image'] {
	grid-area: img;
	min-height: 200px;
	position: relative;
	border: 2px solid var(--c4);
}
.checkout-item [name = 'image'] img {
	position: absolute;
	width: 100%; height: 100%;
	object-fit: cover;
}
.checkout-item [name = 'num-edit'] {
	grid-area: num;
	display: flex; align-items: center;
	gap: var(--d1);
}
.checkout-item [name = 'num-edit'] [name = 'number']::before { content: 'Anzahl: '; }
.checkout-item [name = 'num-edit'] .minus, 
.checkout-item [name = 'num-edit'] .plus {
	position: relative;
	width: 30px; height: 30px;
	background-color: var(--c4);
	border: var(--c3) solid 2px;
	cursor: pointer;
}
.checkout-item [name = 'num-edit'] .minus::before, 
.checkout-item [name = 'num-edit'] .plus::before {
	position: absolute; top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	font-size: 25px;
}
.checkout-item [name = 'num-edit'] .minus::before { content: '-'; }
.checkout-item [name = 'num-edit'] .plus::before  { content: '+'; }

.checkout-item > [name = 'price'] { 
	grid-area: price;
	font-size: 16pt;
}
.checkout-item > [name = 'price']::before { content: 'Basispreis: '; }
.checkout-item [name = 'extras'] {
	grid-area: extra;
	padding-left: var(--d1);
}
.checkout-item .extra-item {
	display: flex; gap: var(--d1);
}
.checkout-item .extra-item::before { content: '+'; }
.checkout-item .extra-item [name = 'price'] { opacity: 0.7; }
.checkout-item [name = 'total'] { 
	grid-area: total;
	padding-top: var(--d1);
	border-top: 1px var(--ctxt) solid;
	text-align: right;
	font-size: 16pt;
}
.checkout-item [name = 'total']::before { content: 'Preis mit ausgewählten Extras: '; }
#checkout-form > [type = 'submit'],
#checkout-form .conf-win [name = 'label'] {
	border-radius: var(--br);
	background-color: var(--c4);
	padding: var(--d2);
	font-size: 14pt;
}

#checkout-total-price {
	position: relative;
	width: 100%;
	padding: var(--d1) var(--d4);
	background-color: var(--c2);
	border-radius: var(--br);
}
#checkout-total-price * { text-align: right; font-size: 16pt; }
#checkout-total-price [name = 'full-price'] 	{}
#checkout-total-price [name = 'discount'] 		{ color: var(--c-error); }
#checkout-total-price [name = 'final-price'] 	{}

#order-status-cont {
	display: flex; flex-direction: column;
	gap: var(--d1);
	
	padding: var(--d1);
	background-color: var(--c3);
	border-radius: var(--br);
}

/* Öffnungszeiten & Liefergebiete */
#business-hours {
	width: 100%; height: 100%;
	display: flex; flex-direction: column;
	gap: var(--d1);
	justify-content: center;
	align-items: center; 
}
#delivery-areas {
	display: flex;
}
#delivery-areas > * { flex: 1 0 0; }

.business-hours-warning {
	display: flex; flex-direction: column;
	align-items: center;
	border: var(--d1) 
}
.business-hours-warning h3 {
	animation: 1s color-anim-1 infinite;
}
@keyframes color-anim-1 {
	0%,100% { color: var(--ca); }
	50% { color: var(--c3); }
}

/* ################################################## */
/* UNIVERSELLES STYLING */

/* Diashow */
.diashow {
	position: relative; 
	width: 100%; height: 500px;
	margin: var(--d2) 0;
	
	display: flex; flex-direction: column;
	justify-content: center; align-items: center;
	
	overflow: hidden;
}
.with-autoskip {} .with-buttons {} .with-icons {} .fullscreen {}
.diashow:not(.fullscreen) .dia img {
	width: auto; height: auto;
	max-width: 100%; max-height: 100%;
	border: 2px solid var(--ca);
	padding: var(--d1);
}
.diashow.fullscreen { 
	height: 100%; width: 100%; 
	margin: 0;
}
.diashow.fullscreen img {
	height: 100%; width: 100%;
	object-fit: cover;
}
.dia {
	position: absolute; 
	height: 100%; width: 100%;
	
	display: flex; flex-direction: column;
	justify-content: center; align-items: center;
	gap: var(--d1);
	
	transition: visibility 3s, opacity 3s;
	visibility: hidden; opacity: 0; 
}
.dia.active {
	position: relative;
	visibility: visible; opacity: 1;
	transition-delay: 0;
}
.dia > * { 
	width: 100%; overflow: hidden;
	display: flex; 
	justify-content: center; align-items: center;
}
.dia-cont { }
.dia-desc { padding: 10px; }

.dia-btn-left, .dia-btn-right {
	position: absolute; 
	height: 30px; width: 30px;
	top: 50%; transform: translateY(-50%);

	background-color: rgba(0,0,0,0.7);
	color: white;
	
	cursor: pointer;
	z-index: 1;
}
.dia-btn-left 	{ left: 0; }
.dia-btn-right 	{ right: 0; }
.dia-btn-left::after, .dia-btn-right::after {
	content: ''; position: absolute;
	width: 40%; height: 40%;
	top: 50%; left: 50%;
	
	transform-origin: center, center;
	transform: translate(-35%, -50%) rotate(135deg);
	
	border: solid white; border-width: 0 3px 3px 0;
}
.dia-btn-right::after {
	transform: translate(-65%, -50%) rotate(-45deg);
}

.dia-icon-cont {
	/* Diashow Elemente werden in JS.diashow_setup geklont */
	width: 100%;
	display: flex; gap: 2px;
	justify-content: center;
	
	overflow: hidden;
}
.dia-icon-cont > div {
	width: 40px; height: 40px;
	filter: grayscale(1);
	overflow: hidden;
	cursor: pointer;
}
.dia-icon-cont > div > img {
	width: 100%; height: 100%;
	object-fit: cover;
}

/* Akkordeon */
.accordion {}
.acc-btn {
	cursor: pointer;
}
.acc-cont {
	height: 0;
	transition: var(--t1);
	visibility: hidden; opacity: 0;
}
.acc-cont.active {
	visibility: visible; opacity: 1;
}

/* Dropdown Input */
.dropdown-input {
	width: 100%;
	display: flex; flex-direction: column;
	border-radius: var(--br);
	overflow: hidden;
}
.dropdown-btn {
	cursor: pointer;
	background-color: var(--c3);
	padding: var(--d2);
}
.dropdown-cont {
	display: flex; flex-direction: column;
	overflow: hidden;
}
.dropdown-cont input { display: none; }
.dropdown-cont input:checked + label {
	background-color: var(--c1);
	color: var(--ca);
}
.dropdown-cont label {
	height: 0;
	padding: 0;
	opacity: 0;
	background-color: var(--c2);
	transition: var(--t1);
	cursor: pointer;
}
.dropdown-input.active .dropdown-cont label { 
	height: 35px; 
	padding: var(--d1); 
	opacity: 1; 
}

/* Radio Switch */
.radio-switch {
	display: flex;
	background-color: var(--c2);
	border-radius: var(--br);
	padding: 5px;
}
.radio-switch label {
	flex: 1 0 0;
	display: block;
	background-color: var(--c2);
	border-radius: var(--br);
	padding: var(--d2);
	
	display: flex; flex-direction: column;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}
.radio-switch label [name = 'sub'] { 
	opacity: 0.7; font-size: 0.9em;
	text-align: center;
}
.radio-switch input { display: none; }
.radio-switch input:checked + label {
	background-color: var(--c4);
	box-shadow: var(--bshad);
	z-index: 1;
}

/* Tab Windows */
.tab-window {
	width: 100%;
	
	display: flex; flex-direction: column;
	gap: var(--d1);
}
.tab-window-btns { 
	width: 100%;
	display: flex; gap: var(--d1);
	flex-wrap: wrap;
}
.tab-window-btns p {
	display: block;
	padding: var(--d2);
	
	border-radius: var(--br);
	background-color: var(--c4);
	hyphens: none;
	cursor: pointer;
}
.tab-window-btns p.active {
	background-color: var(--c3);
}
.tab-window-conts > div {
	width: 100%;
	
}
.tab-window-conts > div:not(.active) { display: none; }

.tab-window-block {
	width: 100%;
	display: flex; flex-direction: column;
	border: var(--d1) solid var(--c3);
	border-radius: var(--br);
	background-color: var(--c3);
}
.tab-window-block > * { padding: var(--d1); }
.win-head { background-color: var(--c3); }
.win-body {
	display: flex; flex-direction: column;
	align-items: center; gap: var(--d2);
	background-color: var(--c3);
}

/* Search Checkbox (Checkboxliste mit Suchfunktion) */
.search-box {
	border-radius: var(--br);
	overflow: hidden;
}
.search-box-input {
	/* Die Suchzeile */
	width: 100%; height: 35px;
	border: 0; 
	border-bottom: 1px solid var(--ctxt);
	font-size: 12pt;
}
.search-box-input:focus {
	background-color: var(--c1);
	border-bottom: 1px solid var(--ca);
}
.search-box-list {
	height: calc(100% - 25px); /* - Input & Bechriftung */
	padding: var(--d2) 0;
	overflow-y: scroll;
}
.search-box-list label {
	/* Checkbox befindet sich IM jeweiligen Label-Tag */
	display: flex; 
	gap: var(--d1);
}

/* Input Arrays */
.input-array {
	display: flex; gap: var(--d1);
	padding: var(--d1);
}
.inp-arr-item {
	position: relative;
	width: 150px;
}
.inp-arr-item .delete {
	position: absolute;
	top: 0; right: 5px;
	cursor: pointer;
}
.inp-arr-item .delete::after {
	content: '✕';
}
.inp-arr-item input {
	width: 100%;
}
.inp-arr-add {
	position: relative;
	height: 50px; width: 50px;
	background-color: var(--c3);
	border-radius: 10%;
	cursor: pointer;
}
.inp-arr-add::after {
	content: '+'; position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	font-size: 32px;
}

/* Confirmation Window */
.conf-win {
	position: relative;
	/* padding: var(--d1); */
	
	display: flex; flex-direction: column;
	gap: var(--d1);
}
.conf-win.off { opacity: 0.3; }
.conf-win [name = 'label'] {
	display: flex; align-items: center;
	justify-content: center;
	
	width: 100%; height: 100%;
	background-color: var(--c3);
	
	cursor: pointer;
}
.conf-win.off [name = 'label'] { cursor: auto; }
.conf-win [name = 'win'] {
	width: 100%;
	padding: var(--d1);
	background-color: var(--c1);
	border: 1px solid var(--ctxt);
	box-shadow: var(--bshad);
	
	display: none;
	flex-direction: column;
	gap: var(--d1);
}
.conf-win [name = 'win'].active { 
	display: flex; 
}
.conf-win div * { hyphens: none; }
.conf-win [name = 'close'],
.conf-win input {
	font-size: 11pt;
	padding: var(--d1);
	background-color: var(--c4);
	border: 0;
	border-radius: var(--br);
	cursor: pointer;
	
	display: flex; align-items: center;
	justify-content: center;
}

/* Blöcke */
.block {
	width: 100%; max-width: 900px;
	min-width: 300px;
	display: flex; flex-direction: column;
	
	border-radius: var(--br);
	box-shadow: var(--bshad);
	overflow: hidden;
}
.block > * { padding: var(--d2); }
.block-head { background-color: var(--c4); }
.block-body {
	flex: 1 0 0;
	display: flex; flex-direction: column;
	gap: var(--d2);
	
	background-color: var(--c1);
}
.block-body > img {
	max-width: 100%; max-height: 450px;
	border: 2px solid var(--gruen-1);
	background-color: var(--c1);
	padding: var(--d2);
}
.block-txt { column-count: 2; }
.block-txt > img { margin: var(--d1) auto; }
.block-txt > p { display: block; margin-bottom: var(--ab); }
.block-txt > p::first-letter { margin-left: var(--el); }
.block-foot {
	display: flex;
	align-items: center; gap: var(--d2);
	
	background-color: var(--c2);
}

/* Italienflagge Trennstrich */
.hr-it {
	position: relative;
	display: block;
	width: 100%; height: 4px;
	
	background-color: var(--ctxt);
	border: 0;
}
.hr-it::before, .hr-it::after {
	content: '';
	position: absolute; top: 0;
	height: 100%; width: 33%;
}
.hr-it::before { background-color: var(--gruen); left: 0;  }
.hr-it::after  { background-color: var(--rot);	 right: 0; }

/* Rows & Columns */
.row, .column { display: flex; gap: var(--d2); }
.column { flex-direction: column; }
.row.center,
.column.center { align-items: center; justify-content: center; }
.row.space-evenly > *,
.column.space-evenly > * { flex: 1 0 0; }
.row:not(.no-wrap) { flex-wrap: wrap; }

/* Pfeile */
.arrow {
	display: inline-block;
	width: 0.65em; height: 0.65em;
	border: solid var(--ca);
	border-width: 0 4px 4px 0;
}
.arrow.up    { transform: rotate(-135deg); -webkit-transform: rotate(-135deg); }
.arrow.left  { transform: rotate(135deg);  -webkit-transform: rotate(135deg);  }
.arrow.down  { transform: rotate(45deg);   -webkit-transform: rotate(45deg);   }
.arrow.right { transform: rotate(-45deg);  -webkit-transform: rotate(-45deg);  }

/* Error- oder Success-Meldungen von Query Parametern */
#query-msg-cont {
	position: fixed;
	bottom: 0; right: 0;
	
	display: flex; align-items: end;
	width: 300px; height: 100px;
	padding: var(--d1);
	
	pointer-events: none;
}
.msg {
	display: block;
	width: 100%;
	padding: var(--d1);
	
	background-color: var(--c1);
	border: 2px solid;
	
	opacity: 1;
	transition: 2s;
	hyphens: none;
}
.msg.error 		{ color: var(--c-error); 	border-color: var(--c-error); 	}
.msg.success 	{ color: var(--c-success); 	border-color: var(--c-success); }

/* Animationen */
.bounce {
	position: absolute;
	bottom: 0;
	animation: bounce 1.2s infinite;
}
@keyframes bounce {
	0%, 100%  { bottom: 1em; }
	60%, 80%  { bottom: 2em; }
}

/* ################################################## */
/* MEDIA QUERIES */
@media (hover: hover) and (pointer: fine) {
	button:hover, 
	input[type='submit']:hover { background-color: var(--c1); }
	
	.inp-arr-add:hover { background-color: var(--c2); }
	
	.conf-win [name = 'close']:hover,
	.conf-win input:hover { background-color: var(--c3); }
	
	#checkout-form [type = 'submit']:hover,
	#checkout-form .conf-win [name = 'label']:hover {
		background-color: var(--c3);
	}
	
	#contact a:hover { text-decoration: underline; }
	
	.dropdown-cont label:hover { background-color: var(--c1); }
}
@media only screen and (max-width: 1000px) {
	:root {
		--d1: 7px;
		--d2: 14px;
		--d3: 28px;
		--d4: 56px;
	}
	
	#page-content { flex-direction: column-reverse; }
}
@media only screen and (max-width: 700px) {
	*, *::before, *::after { font-size: 10pt; }
	
	:root {
		--d1: 6px;
		--d2: 12px;
		--d3: 24px;
		--d4: 48px;
		
		--nav-max-height: 180px;
	}
	
	#nav { padding: var(--d1) 0 0 0; }
	#nav #nav-title { display: none; }
	#nav #nav-logo [name = 'schneider'] { display: none; }
	#nav #nav-logo [name = 'logo'] { left: 50%; transform: translateX(-50%); }
	
	#page-content { padding: var(--d1); }
	
	.order-item-cont [name = 'prices'] { gap: 2px; }
	.order-item-cont [name = 'prices'] * { font-size: 9pt; }
	
	.order-item-btn .lowest-price { font-size: 24pt; }
	.order-item-btn .lowest-price::before { font-size: 10pt; }

	#shopping-cart * { font-size: 9pt; }
	#shopping-cart.active { height: 100px; }
	#cart-checkout-link { width: 80px; }
	.cart-item { width: 90px; }
	
	#contact { bottom: calc(100px + var(--d1)); }
	
	#query-msg-cont { width: 100%; }
	.msg { padding: var(--d2); font-size: 16px; }
}
@media only screen and (max-width: 500px) {
	:root {
		--d1: 5px;
		--d2: 10px;
		--d3: 20px;
		--d4: 40px;
	}
	
	#nav-btn { display: block; }
	
	#nav-links {
		height: auto;
		background-color: var(--c4);
		display: block;
	}
	#nav-links.active { box-shadow: var(--bshad); }
	#nav-links span { display: none; }
	#nav-links a { 
		display: block; 
		width: 100%; height: var(--nav-min-height); 
		
		display: flex; align-items: center;
		justify-content: center;
		
		background-color: var(--c4);
		transition: height 0.2s;
	}
	#nav-links a:not(.active) {
		background-color: var(--c3);
		border-top: var(--c1) 1px solid;
	}
	#nav-links:not(.active) a:not(.active) {
		height: 0;
		overflow: hidden;
		border: 0;
	}
}