@charset "utf-8";

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	font-family: 'Aptos', sans-serif;
}

img {
	max-width: 100%;
}

h2 {
	font-size: 2.5em;
}

.container {
	width: 90%;
	margin: auto;
}

header {
	background: #bb5722;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 99;
	box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.25);
	text-align: left;
}

header .container {
	display: fixed;
	flex-flow: row wrap;
	align-items: center;
	padding: 15px 0;
}

.logo {
	padding: 0 1em;
}

section {
	padding: 100px 0;
}

.hero-banner {
	background-size: cover;
	height: 100vh;
	display: flex;
	align-items: center;
	text-align: center;
	position: relative;
	z-index: 0;
}

.hero-banner:after {
	content: "";
	display: block;
	background: rgba(0, 0, 0, 0.2);
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
	position: absolute;
}

.hero-banner h2 {
	color: #fff;
	position: relative;
	z-index: 1;
}

.hell {
	text-align: center;
	line-height: 2;
}

.dunkel {
	text-align: center;
	line-height: 2;
	background: #f1f1f1;
	color: #333;
}

.dunkel a:link {
	color: darkorange;
	text-decoration: underline;
}

.dunkel a:visited {
	color: black;
	text-decoration: underline;
}

.hell a:link {
	color: orangered;
	text-decoration: underline;
}

.hell a:visited {
	color: darkorange;
	text-decoration: underline;
}


header.fixed {
	background: #fff;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	opacity: 0;
	visibility: hidden;
	box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.2);
	transform: translate(0, -200px);
}

header.fixed nav a, header.fixed .logo a {
	color: #333;
}


header.in-view {
	opacity: 1;
	visibility: visible;
	transition: all 0.3s ease;
	transform: translate(0, 0);
}

.white {
	color: white;
}

.Band {
	min-height: 420px;
	font-family: 'Aptos', sans-serif;
	color: white;
	background-color: #1b1b1b;
	font-size: 0.9em;
	vertical-align: text-top;
	text-align: center;
	width: 100%;
}

.Band th {
	text-align: center;
	width: 20%;
}

.Band td {
	border-left: 1px solid silver;
	border-bottom: 1px solid silver;
	padding: 1em 1em;
	vertical-align: text-top;
	width: 20%;	
	text-align: justify;
}

.Band td:first-child, th:first-child {
 border-left: none;
}

.PgFooter {
	margin-left: auto;
	margin-right: auto;
	font-family: 'Tahoma', sans-serif;
	font-size: .9em;
	vertical-align: middle;
	text-align: center;
	width: 800px;
}

.PgFooter a:link {
	color: orangered;
	text-decoration: underline;
}

.PgFooter a:visited {
	color: darkorange;
	text-decoration: underline;
}

.nonbtn {
	background: inherit;
	font-family: inherit;
	border: none;
	padding: auto 1rem;
	color: darkorange;
	text-decoration: underline; 
	text-align: center;
	display: inline-block;
	cursor: pointer;	
	font-size: 1rem;
}

.fett {
	font-weight: bold;
}

h3 {
	color: darkorange;
	font-size: 1.2rem;
}


.About {
	margin-left: auto;
	margin-right: auto;
	background-color: #1b1b1b;
	color: white; font-family : 'Tahoma', sans-serif;
	font-size: 1em;
	vertical-align: middle;
	text-align: center;
	width: 800px;
	font-family: 'Tahoma', sans-serif;
}

a:link {
	color: white;
	text-decoration: underline;
}

a:visited {
	color: silver;
	text-decoration: underline;
}

div.slideshow {
	margin-left: auto;
	margin-right: auto;
	margin-top: 16px;
	margin-bottom: 16px;
	vertical-align: middle;
}

.SetList {
	text-align: center;
	font-size: .9em;
}

.darktext {
	background-color: #1b1b1b;
	padding: 1mm;
}

.right {
	text-align: right;
	font-size: .9em;
	
}

.bk2btn {
 	position: absolute;
	right: 1rem;
}

.wide {
	width: 100%;
}

.centre {
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	width: 90%;
}

.videos {
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	width: 80%;
}

.vimeo {
	width: 560px;
}

.vimeoTD {
	width: 50%;
}

.vimeoDiv {
	padding: 60% 0 0 0;
	position: relative;
}


.boxML {
	border: 2px solid #ff4500;
  	outline: 2px double #ff4500;    
    background-color: PaleGoldenrod;
	font-weight: bold;
}

.klein {
	font-size: .8em;
}

.flex-container {
    display: flex;
    align-items: center;
    gap: 20px;
}

/* Navigation Bar*/

nav {
  	padding: 1.5rem 2rem;
  	background-color: #1b1b1b;
  	color: #fff;
	justify-content: flex-begin;
	display: flex;
	flex: 2 auto;
}

.checkbtn{
  color: white;
  cursor: pointer;
}

.lflag {
	vertical-align: middle;
	padding-right:8px;	
}

.ltext {
	vertical-align: middle;
}

.pagefont {
	font-family: 'Aptos', sans-serif;
}

#menu {
  display: none;
}

#menu:checked ~ .nav-mobile { display: block; }


#lang_menu {
  display: none;
}

#lang_menu:checked ~ .lang-mobile { 
	display: block; 
}

.nav-mobile {
  display: none;
  position: absolute;
  top: 4.5rem;
  left: 0;
  overflow: hidden;
  background: #1b1b1b;
  z-index: 1;
  width: 200px;
  font-variant: small-caps;
}

.nav-mobile a {
  color: #fff;
  padding: 1rem 1.5rem;
  display: block;
}


.lang-mobile {
  display: none;
  position: absolute;
  top: 4.5rem;
  left: 200px;
  overflow: hidden;
  background: #333333;
  z-index: 1;
  width: 200px;
  font-variant: small-caps;
}

.lang-mobile a {
  color: #fff;
  background: #333333;
  padding: 1rem 1rem;
  display: block;
}

.kontakt {
	text-align: left;
	vertical-align: top;
}

.kfta {
	padding: 8px;
}

.hideBtn {
  display: none;
}


.reqd {
	color: firebrick;
	font-size: 1rem;
}

hr {
  background-color: black;
  padding: 1px;
  border: none;
}

/* Media Query Breakpoints */

@media only screen and (max-width: 640px) {
	header.fixed {
		position: relative;
	}

  nav {
  	padding: 5rem 0;
  }
  
  .checkbtn {
  	display: block; 
  	position: absolute; 
  	top: 30px; 
  	left: 40px;
  }
  
  .nav-mobile { 
  	top:10rem; 
  	width: 100%;
  }
  
  .nav-mobile a { 
  	font-size: 1rem; 
  	padding: 1rem 2rem;
  }
}
