﻿:root {
	--fontcol: #333333;
	--menucol: #116C5B;
	--backcol: #DDDDDD;
	font-family: "Segoe UI",Trebuchet MS, Arial, sans-serif;
	font-size: 1em;
}

body {
	padding-top: 5rem;
	padding-left: 5%;
	color: var(--fontcol);
	background-color: var(--backcol);
	overflow: auto;
	-webkit-hyphens: auto;
	hyphens: auto;
}

h1 {font-size: 1.95rem;text-align: left;}
h2 {font-size: 1.56rem;text-align: left;}
h3 {font-size: 1.25rem;text-align: left;}
h4 {font-size: 1.20rem;text-align: left;}

#impressum p {font-size: 1em;}
#impressum h1 {font-size: 1.5em;}
#impressum h2 {font-size: 1.25em;}
#impressum h3 {font-size: 1.10em;}

#agb h1 {font-size: 1.5em;}
#agb li {
	text-align: left;
	font-weight: bold;
}

#datenschutz ul {
	list-style-type: square;
	border: none;
	padding: 0 0 0 1.2rem;
}
#datenschutz li {
	text-align: left;
}


@media only screen and ( min-width: 1300px ) {
/* breites Browserfenster */
	body {font-size: 1.15em;}
}

@media only screen and ( max-width: 440px ) {
	/* mobile Geräte */
	body {padding-left: 0;}
}


header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 2.25rem;
	background-color: var(--backcol);
	padding: .5rem 0;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	vertical-align: middle;
}

footer {
	margin: 0 auto;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 10px;
	background-color: var(--backcol);
	font-size: 0.8rem;
	text-align: right;
	-webkit-hyphens: none;
	hyphens: none;
}

a {
	  text-decoration: none;
}

nav {
	position: fixed;
	top: 2.75rem;
	left: 0;
	right: 0;
	text-align: center;
 	display: inline-block;
	background-color: var(--backcol);
	-webkit-hyphens: none;
	hyphens: none;
}

ul {
  list-style-type: none;
	border-top: 1px solid black;
	border-bottom: 1px solid black;
	padding: 0.5rem 0;
}

nav ul li {
	display: inline;
	border-right: 1px solid #bbb;
}

nav ul li a {
  color: var(--fontcol);
  padding: 12px 15px;
}

ul li a:hover:not(.active) {
	color: var(--menucol);
	text-decoration: underline;
}

ul li a.active {
	color: var(--menucol);
	font-weight: bold;
	cursor: default;
}

nav ul li:last-child {
  border-right: none;
}

article {
	text-align: center;
	max-width: 85%;
	margin: 0 auto;
	padding-bottom: 30px;
}

article p {
	text-align: left;
}

table, th, td {
	border: 4px solid red;
	border-collapse: collapse;
	padding: .2rem 1rem;
}

th, td {
	 text-align: left;
}

#preis {
	text-align: right;
}

#bemerkung {
	font-size: 0.95rem;
}

.tab {
	text-align: left;
	display: grid;
	grid-template-columns: repeat(3,min-content);
	gap: 0.2rem 1rem;
	-webkit-hyphens: none;
	hyphens: none;
}


.raster {
	display: grid;
	grid-template-columns: min-content 30rem;
	gap: 2px 1.0rem;
	-webkit-hyphens: none;
	hyphens: none;
}

form {
	padding: 0.7rem;
}

input, label, select, textarea, button {
	text-align: left;
	float: left;
}

select {
	background-color: white;
}

textarea {
	resize: none;
}


button {
	margin-top: 1.5em;
	border: 1px solid black;
	border-radius: 4px;
	padding: 0.4em 0;
	width: 11em;
	text-align: center;
	-webkit-hyphens: none;
	hyphens: none;
}

.button2 {
	background-color: #BDF5BD;
	border: 1px solid black;
	border-radius: 4px;
	/*color: white;*/
	padding: 4px 10px;
	text-align: center;
	text-decoration: none;
	display: inline-block;
	font-size: 1rem;
	margin: 4px 0;
	cursor: pointer;
	-webkit-hyphens: none;
	hyphens: none;
}

#error {
	position: absolute; top: 95px; left:10%; right: 10%;
	padding:15%;
	font-size: 120%; font-weight: bold; color: #FF0000;
	line-height: 2;
	}

#error a {text-decoration: underline; color: #FF0000;}

/*input:invalid { background: #FFE5EB; }
input:valid   { background: #99FF66; }*/
