


* {
margin: 0;
}

html, body {
height: 100%;
}

.logo { 
	padding: 0.2em 0.5em;
	color: #000000;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 1.8em;
    font-weight: 200;
	letter-spacing: 0.03em;
	text-transform: none; 
}

#maincontent {
    margin: 3em auto 0;
    position: relative;
    min-height: 100%;
	height: auto !important;
	height: 100%;
	max-width: 1600px;
}

img { max-width: 100%; border:0; }

hr {
border: none;
border-top: 0.1em solid #666;
color: #FFFFFF;
margin: 0 0 0 0.5em; 
}

.text { 
	padding: 0;
	color: #000;
	text-transform: none; 
	text-align: center;
}

.text a {
	color:#000000;
    text-decoration:none;
}

.text a:hover {
    color:#ff9900;
}

.text h1 {
    margin: 0.8em auto;
    font-family: 'Lora', serif;
    font-size: 1.8em;
    font-weight: 400;
	letter-spacing: 0.02em;
}

.text p { 
	margin: 2em 3em 0;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 0.9em;
    font-weight: 200;
	letter-spacing: 0.03em;
	line-height: 1.4em;
}

.textlinks { 
	color: #333;
	letter-spacing: 0.03em;
	text-transform: none; 
	text-align: left;
	width: 100%;
}

.textlinks h2 {
    padding: 2.5em 0 3em 3em;
    font-family: 'Lora', serif;
    font-size: 2.0em;
    font-weight: 200;
	line-height: 1.4em;
}

.textlinks p {
    padding: 3.5em 5em 0 0;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 1.0em;
    font-weight: 200;
	line-height: 2.0em;
}

.textinfo {
	color: #333;
	letter-spacing: 0.03em;
	text-transform: none; 
	text-align: left;
	width: 100%;
}

.textinfo h1 {
    padding: 0em;
    font-family: 'Lora', serif;
    font-size: 1.4em;
    font-weight: 200;
	line-height: 1.4em;
}

.textinfo p {
    padding: 0em;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 1.0em;
    font-weight: 200;
	line-height: 2.0em;
}

.anzeige {
	transition: all 0.4s linear;
	-moz-transition: all 0.4s linear;
	-webkit-transition: all 0.4s linear;
	-o-transition: all 0.4s linear;
	opacity: 0;
	background-color: #fff;
	position: absolute;
	text-align: center;
	bottom: 0px;
	height: 100%; 
	width: 100%; 
}	
	
.anzeige:hover { opacity: 0.9; }

.anzeigentext {
	position: absolute;
	text-align: left;
	margin: 1.8em 1.5em 0;
}

.anzeigentext h2 { 
	color: #444;
	font-size: 1.4em;
    font-weight: 400;  
    font-family: 'Lora', serif;
    letter-spacing:0.02em;
}

.anzeigentext p {
    padding-top: 1.4em;
	color: #444;
	font-size: 0.8em;
    font-weight: 300;
    font-family: 'Source Sans Pro', sans-serif;
    line-height: 1.0em;
}

.aboutme {
	opacity: 0.95;
	background-color: #fff;
	position: absolute;
	text-align: center;
	bottom: 0px;
	height: 100%; 
	width: 100%; 
}

.aboutmetext {
	position: absolute;
	text-align: left;
	margin: 1.8em 2em 0 0;
}

.aboutmetext h2 { 
	color: #444444;
	font-size: 1.4em;
	font-weight: 400;
    font-family: 'Lora', serif;
    letter-spacing:0.02em;
}

.aboutmetext p {
    padding-top: 1.4em;
    color: #444;
	font-size: 1.0em;
	font-weight: 300;
    font-family: 'Source Sans Pro', sans-serif;
    line-height: 2.0em;
}

.texte { 
	color: #333;
	letter-spacing: 0.03em;
	text-transform: none; 
	text-align: left;
	width: 100%;
}

.texte h2 {
    padding: 2.5em 1em 0;
    font-family: 'Lora', serif;
    font-size: 2.0em;
    font-weight: 200;
	line-height: 1.4em;
}

.texte h3 {
    padding: 2.5em 1em 0;
    font-family: 'Lora', serif;
    font-size: 1.6em;
    font-weight: 200;
	line-height: 1.4em;
}

.texte h4 {
    padding: 2.5em 1em 0;
    font-family: 'Lora', serif;
    font-size: 1.2em;
    font-weight: 200;
	line-height: 1.4em;
}


.texte p {
    padding: 2em 2em 0;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 1.0em;
    font-weight: 200;
	line-height: 2.0em;
}

.shadow {
    -moz-box-shadow: 0px 1px 10px 6px #eee; 
    -webkit-box-shadow: 0px 1px 10px 6px #eee; 
    box-shadow: 0px 1px 10px 6px #eee;
}

/*  Aufteilung */

.columns { 
    		position: relative; 
   			overflow: hidden; 
   			text-align: center; 
   			line-height: 0;
   			float: left; 
    		display: inline; 
    		margin: 0.5%; 
}
	
.eine.columns	{ width: 24%; }
.zwei.columns	{ width: 32.33333%; }
.drei.columns	{ width: 49%; }
.vier.columns	{ width: 65.66666%; }
.sechs.columns	{ width: 99%; }

.abstand { 
    		position: relative; 
   			overflow: hidden; 
   			line-height: 0;
   			float: left; 
    		width: 100%; 
   			margin: 1em 0; 
}





/*----------------------------------------- 1) Allgemein --------------------------------------------------*/
a {
  color: #2f2f2f;
  text-decoration: none;
  transition: ease .6s;
  -webkit-transition: ease .6s;
  -moz-transition: ease .6s;
  -o-transition: ease .6s;
  -ms-transition: ease .6s;
}
a:hover {
  text-decoration: none;
  color: #818181;
}
a:focus {
  outline: none;
  color: #999999;
  text-decoration: none;
}
iframe {
  border: none;
  width: 100%;
}
img { max-width: 100%; }
*:focus {
  outline: none;
}

.glyphicon-menu-up:before{content:"\e260"}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}

/*----------------------------------------- 2) Preloader --------------------------------------------------*/
#preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #fff;
  z-index: 999999;
}
#status {
  width: 200px;
  height: 200px;
  position: absolute;
  left: 50%;
  top: 50%;
  background-image: url(../images/loader.gif);
  background-repeat: no-repeat;
  background-position: center center;
  text-align: center;
  margin: -40px 0 0 -100px;
}
#status img {
  text-align: center;
  margin-top: -80px;
}

/*----------------------------------------- 4) Header --------------------------------------------------*/
.header {
  width: 100%;
  z-index: 9999;
}
.for-sticky {
  position: fixed;
  z-index: -1;
  bottom: 0;
  width: 100%;
  height: 50px;
  opacity: 0.8;
  z-index: 1;
  top: 0;
  left: 0;
  border-bottom: 1px solid #f1f1f1;
  display: block;
  padding: 0px 15px 5px 15px;
  background: #ffffff;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
.logo-nav {
  padding: 6px 0 10px 0;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -ms-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  width: 45px;
  display: block;
}

/*----------- panel ----------*/
.content-wrap {
  -webkit-overflow-scrolling: touch;
  height: 100%;
  width: 100%;
}
.content {
  position: absolute;
  width: 100%;
  height: 100%;
}
.content::before {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  content: '';
  opacity: 0;
  -webkit-transform: translate3d(100%, 0, 0);
  transform: translate3d(100%, 0, 0);
  -webkit-transition: opacity 0.4s, -webkit-transform 0s 0.4s;
  transition: opacity 0.4s, transform 0s 0.4s;
  -webkit-transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
.wrap { 
overflow: hidden;
} /* nötig damit die Ankerpunkte und Höhe erkannt werden */


/* Menu Button */
.menu-button {
  width: 34px;
  height: 45px;
  position: fixed;
  right: 0;
  margin-top: 13px;
  margin-right: 35px;
  z-index: 1000;
  padding: 0;
  cursor: pointer;
  background: transparent;
  border: none;
}
.menu-button span {
  display: block;
  position: absolute;
  height: 1px;
  width: 100%;
  background: #2f2f2f;
  border-radius: 9px;
  opacity: 1;
  left: 0;
}
.menu-button span:nth-child(1) {top: 0px;}

.menu-button span:nth-child(2) {top: 9px;}

.menu-button span:nth-child(3) {top: 18px;}
.menu-button:hover {opacity: 0.6;}
/* Close Button */
.close-button {
  width: 1em;
  height: 1em;
  position: absolute;
  right: 1em;
  top: 1em;
  overflow: hidden;
  text-indent: 1em;
  font-size: 0.75em;
  border: none;
  background: transparent;
  color: transparent;
}
.close-button::before,
.close-button::after {
  content: '';
  position: absolute;
  width: 3px;
  height: 100%;
  top: 0;
  left: 50%;
  background: #bdc3c7;
}
.close-button::before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.close-button::after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
/* Menu */
.menu-wrap {
  position: fixed;
  z-index: 1001;
  width: 300px;
  height: 100%;
  right: 0;
  float: right;
  background: #2f2f2f;
  padding: 2.5em 1.5em 0;
  -webkit-transform: translate3d(300px, 0, 0);
  transform: translate3d(300px, 0, 0);
  -webkit-transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  -webkit-transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
.menu,
.menu-list {
  height: 100%;     
  overflow-x: auto;
}
.menu-list {
  -webkit-transform: translate3d(0, 100%, 0);
  transform: translate3d(0, 100%, 0);
}
.menu-list a {
  display: block;
  padding: 1.5em 0;
  -webkit-transform: translate3d(0, 500px, 0);
  transform: translate3d(0, 500px, 0);
  color: #a5a5a5;
  position: relative;
}
.menu-list a:hover, .menu-list a:active span {color: #ffffff;}
.menu-list,
.menu-list a {
  -webkit-transition: -webkit-transform 0s 0.4s;
  transition: transform 0s 0.4s;
  -webkit-transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
.menu a:nth-child(2) {
  -webkit-transform: translate3d(0, 1000px, 0);
  transform: translate3d(0, 1000px, 0);
}
.menu-list a:nth-child(3) {
  -webkit-transform: translate3d(0, 1500px, 0);
  transform: translate3d(0, 1500px, 0);
}
.menu-list a:nth-child(4) {
  -webkit-transform: translate3d(0, 2000px, 0);
  transform: translate3d(0, 2000px, 0);
}
.menu-list a:nth-child(5) {
  -webkit-transform: translate3d(0, 2500px, 0);
  transform: translate3d(0, 2500px, 0);
}
.menu-list a:nth-child(6) {
  -webkit-transform: translate3d(0, 3000px, 0);
  transform: translate3d(0, 3000px, 0);
}
.menu-list a span:nth-last-child(1){
  margin-bottom: 100px;
}
.menu-list a span {
    margin-left: 10px;
    font-weight: 400;
    letter-spacing: 5px;
    text-transform: uppercase;
    z-index: 2;
    position: absolute;
    margin-bottom: 20px;
    padding: 10px;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 1.2em;
}
.menu-list a span:before{
  content: '';
  display: block;
  width: 0;
  height: 2px;
  background: #ffffff;
  -webkit-transition: width .3s ease;
  transition: width .3s ease;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0,-50%);
  -ms-transform: translate(0,-50%);
  transform: translate(0,-50%);
  z-index: -1;
}
.menu-list a.active span{
  color: #ffffff !important;
}
.menu-list a.active span:before{
  width: 100%;
}

/* Shown menu */
.show-menu .menu-wrap {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -webkit-transition: -webkit-transform 0.8s;
  transition: transform 0.8s;
  -webkit-transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
.show-menu .menu-list,
.show-menu .menu-list a {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -webkit-transition: -webkit-transform 0.8s;
  transition: transform 0.8s;
  -webkit-transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
}
.show-menu .menu-list a {
  -webkit-transition-duration: 0.9s;
  transition-duration: 0.9s;
}
.show-menu .content::before {
  opacity: 1;
  -webkit-transition: opacity 0.8s;
  transition: opacity 0.8s;
  -webkit-transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  transition-timing-function: cubic-bezier(0.7, 0, 0.3, 1);
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

/*-------------- Start ------------------*/

#home {
  background: url('../images/photography.jpeg') no-repeat center center fixed;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  min-width: 100%;
  min-height: 100%;
  height: 100%;
  width: 100%;
  display: block;
}
.wrap-start-content{
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.start-content{
    position: absolute;
    text-align: center;
    left: 50%;
    top: 50%;
    padding: 65px;
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}

.start-content h1{
    font-family: 'Lato', sans-serif;
    font-weight: 100;
    color: #fff;
	font-size: 4.8em;
    letter-spacing:0.02em;
    text-shadow: 0.02em 0.01em 0.02em #555;
}

.start-icon {
  position: absolute;
  opacity: 0.8;
  height: 40px;
  width: 30px;
  color: #fff;
  margin: 0 auto;
  display: block;
  left: 0;
  right: 0;
  bottom: 30px;
  z-index: 100;
}


/*-------------- Footer ------------------*/
footer{
    width: 100%;
    background: #2f2f2f;
    padding: 60px 0 0;
    color: #636363;
    display: table;
    text-align: center;
}

footer p{
    font-family: 'Lato', sans-serif;
    font-weight: 300;
    color: #bbb;
    font-size: 0.7em;
    letter-spacing:0.04em;
    padding: 3em 0 2em;
}

footer p a{
    color: #bbb;
}

footer p a:hover{
    color: #eee;
}



/*  Screenweite */

@media screen and (min-device-width: 1025px) and (max-width : 1080px)  {
    .aboutmetext p { font-size: 0.9em; line-height: 1.6em; }
}

@media screen and (min-device-width: 720px) and (max-width : 1024px)  {
   #maincontent { width: 90%; }
    .columns { margin-bottom: 12px; }
    .eine.columns,
    .zwei.columns,
    .drei.columns,
	.vier.columns,
	.sechs.columns  { width: 100%; }
    .aboutmetext p { font-size: 0.9em; line-height: 1.6em; }
    .text p { margin: 2em 6em 0;}
    .textlinks h2 { padding: 0em; }
    .textlinks p { padding: 0em; }
}

@media screen and (min-device-width: 640px) and (max-width : 719px)  {
   #maincontent { width: 90%; }
    .columns { margin-bottom: 12px; }
    .eine.columns,
    .zwei.columns,
    .drei.columns,
	.vier.columns,
	.sechs.columns  { width:100%; }
    .aboutmetext h2 { font-size: 1.0em }
    .aboutmetext p { font-size: 0.8em; line-height: 1.2em; }
    .text p { margin: 2em 3em 0;}
    .textlinks h2 { padding: 0em; }
    .textlinks p { padding: 0em; }
}

@media screen and (min-device-width: 320px) and (max-width : 639px)  {
   #maincontent { width: 90%; }
    .columns { margin-bottom: 12px; }
    .eine.columns,
    .zwei.columns,
    .drei.columns,
	.vier.columns,
	.sechs.columns  { width:100%; }
    #aboutme { height: 100%; }
    .text p { margin: 2em 3em 0;}
    .textlinks h2 { padding: 0em; }
    .textlinks p { padding: 0em; }
    .start-content h1 {font-size: 3.0em;}
}

@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: landscape){
    #maincontent { width: 960px; }
    .columns { margin-bottom: 12px; }
    .eine.columns,
    .zwei.columns,
    .drei.columns,
	.vier.columns,
	.sechs.columns  { width: 940px; }
}

@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: portrait){
	#maincontent { width: 90%; }
    .columns { margin-bottom: 12px; }
    .eine.columns,
    .zwei.columns,
    .drei.columns,
	.vier.columns,
	.sechs.columns  { width: 100%; }
    .textlinks h2 { padding: 0em; }
    .textlinks p { padding: 0em; }
}
