*, *:before, *:after { box-sizing: border-box; }
img { border: none; height: auto; width: 100%; display: block; }
::selection { background:#E0D7C3; color: #111;} 
html { -webkit-text-size-adjust: 100%;  scroll-behavior: smooth; } 
strong { font-weight: 700;}

/*  F A R B E N
	text	#333
	sand	#BEB49D
	grau	#666
========================= */

@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400;
  src: local('Open Sans Regular'),
       url('open-sans-v17-latin-regular.woff2') format('woff2'), 
       url('open-sans-v17-latin-regular.woff') format('woff');
    font-display: swap; 
}
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 400;
  src: local('Open Sans Italic'),
       url('open-sans-v17-latin-italic.woff2') format('woff2'), 
       url('open-sans-v17-latin-italic.woff') format('woff');
    font-display: swap; 
}
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 700;
  src: local('Open Sans Bold'),
       url('open-sans-v17-latin-700.woff2') format('woff2'),
       url('open-sans-v17-latin-700.woff') format('woff');
    font-display: swap; 
}

body {
	background: #fff;
	font: normal 62.5%/1.8 'Open Sans', Arial, sans-serif; 
	color: #333;
	margin: 0;
	padding: 0;
	}	
.wrp {
	max-width: 1040px;
	margin: 0 auto;
	padding: 0 20px;
	}
.wrp:after { 
	content: " "; 
	display: table; 
	clear: both;
	}
.wrp_s {
	max-width: 740px;
	margin: 0 auto;
	padding: 0 20px;
	}
header 	{ 
	width: 100%;
	height: auto;
	overflow: hidden;
    margin: 0 auto; 
    padding: 0;
	position: fixed;
	top: 0;
	left: 0;
	background: rgba(255, 255, 255, 0.8);
	z-index: 10;
	backdrop-filter: blur(16px);
	}
.logo {
	font-size: 2.3rem;
	line-height: 1.1;
	color: #666;
	float: left;
	margin: 30px 0;
	}
.logo strong {
	color: #BEB49D;
	}
.hero {
	width: 100%;
	height: 420px;
	background: #eee;
	background: linear-gradient(to right,  #FFFDF7 1%,#f2f2f2 64%,#fcfcfc 100%);
	overflow: hidden;
	z-index: 1;
	position: fixed;
	top: 100px;
	}
.hero img {
	max-width: 327px;
	float: right;
	}
.hero p {
	font-size: 1.1rem;
	max-width: 500px;
	line-height: 1.5;
	margin-bottom: 0;
	}

main { 
	width: 100%;
	height: auto;
	overflow: hidden;
    margin: 500px 0 0 0; 
    padding: 0px;
    font-size: 1rem;
    background: #fff;
    z-index: 5;
    position: relative;
	}
#datenschutz main {
    margin: 0px 0 0 0; 	
	}
.col-1 {
	width: 45%;
	margin-right: 10%;
	float: left;
	}	
.col-2 {
	width: 45%;
	margin-right: 0%;
	float: left;
	}	
.zitat {
	width: 100%;
	height: 450px;
	overflow: hidden;
	position: relative;
	margin: 80px 0;
	background: url('../img/back-zitat.jpg') no-repeat center center #ddd;
	background-size: cover;
	}
.zitat p {
	margin: 0 auto;
	text-align: center;
	color: #666;
	font-size: 2.6rem;
	line-height: 1.2;
	max-width: 640px;
	padding: 130px 20px;
	}

.kunden {
	width: 100%;
	height: 850px;
	overflow: hidden;
	position: relative;
	margin: 80px 0;
	background: url('../img/back-kunden.jpg') no-repeat center center #ddd;
	background-size: cover;
	}
.an {
	font-family: Times, serif;
	font-size: 180px;
	color: #BEB49D;
	margin: 20px 0 25px 0;
	line-height: 1;
	}
.text {
	font-size: 1.2rem;
	font-weight: bold;
	color: #333;
	}
.autor {
	font-style: italic;
	color: #666;
	font-size: 1rem;
	}
.kontakt {
	width: 100%;
	height: 450px;
	overflow: hidden;
	position: relative;
	margin: 80px 0 0 0;
	background: url('../img/back-kontakt.jpg') no-repeat center center #ddd;
	background-size: cover;
	}	
	
	
	
h1 {
	font-size: 2.5rem;
	line-height: 1.2;
	color: #BEB49D;
	margin: 0 0 35px 0;
	padding-top: 120px;
	}	
h2 {
	font-size: 2rem;
	line-height: 1.3;
	max-width: 400px;
	color: #BEB49D;
	margin: 60px 0 35px 0;
	padding: 0 0 0 15px;
	border-left: 5px solid #BEB49D;
	}	
p {
	font-size: 1rem;
	}
	

a {
	color: #000;
	text-decoration: none;
	}
a:hover {
	color: #CBB78A;
	text-decoration: underline;
	text-underline-offset: 3px;
	}
		
nav ul {
	list-style-type: none;
	margin: 41px 0 0 0;
	padding: 0;
	overflow: hidden;
	float: right;
	font-size: 0.9rem;
	}
nav li {
	float: left; 
	margin-right: 0px;
	margin-left: 20px;
	}
nav a {
	color: #333;
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 1px;
	}	
nav a:hover, nav a.off {
	color: #BEB49D;
	text-decoration: none;
	border-bottom: 2px solid #BEB49D;
	}	
.anker { height: 50px; }
.hamburger {
	cursor: pointer;
	position: relative;
	float: right;
	background: rgba(0,0,0,0.0);
	padding: 10px 15px;
	display: none;
	margin: 0;
	}
.bar1, .bar2, .bar3 {
	width: 30px;
	height: 3px;
	background-color: #333;
	margin: 6px 0;
	transition: 0.4s;
	}
.change .bar1 { transform: rotate(-45deg) translate(-5px, 6px); }
.change .bar2 { opacity: 0; }
.change .bar3 {	transform: rotate(45deg) translate(-7px, -8px); }
	
	
	
/* --- RESPONSIVE ---------------------------------------------- */

@media screen and (max-width: 960px) {

nav ul {
	list-style-type: none;
	width: 100%;
	margin: 0px;
	padding: 10px 0 20px 0px;
	overflow: hidden;
	font-size: 1.2rem;
	position: relative;
	display: none;
	z-index: 8;
	}
nav li {
	float: none; 
	margin-left: 0px;
	text-align: left;
	line-height: 3;
	}
.hamburger {
	display: block;
	position: absolute;
	top: 26px;
	right: 20px;
	background: none;
	}
/*  per JS an ul.hauptnavi  */
.mobList { 
	display: block; 
	opacity: 1; 
	}
.desk { display: none; }
h1 {
	padding-top: 20px;
	}	

}

@media screen and (max-width: 700px) {
	
h1 {
	font-size: 2rem;
	line-height: 1.2;
	margin: 20px 0 30px 0;
	padding: 0;
	}	
h2 {
	font-size: 1.8rem;
	line-height: 1.3;
	}	
.hero {
	width: 100%;
	height: auto;
	position: relative;
	padding-bottom: 30px;
	}
.hero img {
	width: 100%;
	float: none;
	}
main { 
    margin: 50px 0 0 0; /* liegt sonst über dem hero */
	}

.col-1 {
	width: 100%;
	margin-right: 0%;
	float: none;
	}	
.col-2 {
	width: 100%;
	margin-right: 0%;
	float: none;
	}	
.zitat {
	width: 100%;
	height: auto;
	padding: 20px 0;
	}
.kunden {
	width: 100%;
	height: auto;
	padding: 0 0 30px 0;
	}
.an {
	margin: -20px 0 25px 0;
	}
.text {
	font-size: 1.1rem;
	}

 }

@media screen and (max-width: 450px) {
.logo {
	font-size: 1.9rem;
	line-height: 1.2;
	color: #666;
	float: left;
	margin: 10px 0 15px 0;
	background: none;
	z-index: 20;
	}
.hamburger {
	display: block;
	position: absolute;
	top: 2px;
	right: 10px;
	}
.hero {
	margin-top: 0px;
	top: 60px;
	}
}

@media screen and (max-width: 380px) {
.logo {
	font-size: 1.5rem;
	margin: 13px 0;
	}

}