
/*Cookie Consent Begin*/
#cookieConsent {
    background-color: rgba(20,20,20,0.8);
    min-height: 26px;
    font-size: 14px;
    color: #ccc;
    line-height: 26px;
    padding: 8px 0 8px 30px;
    font-family: "Trebuchet MS",Helvetica,sans-serif;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    display: none;
    z-index: 9999;
}
#cookieConsent a {
    color: #4B8EE7;
    text-decoration: none;
}
#closeCookieConsent {
    float: right;
    display: inline-block;
    cursor: pointer;
    height: 20px;
    width: 20px;
    margin: -15px 0 0 0;
    font-weight: bold;
}
#closeCookieConsent:hover {
    color: #FFF;
}
#cookieConsent a.cookieConsentOK {
    background-color: #F1D600;
    color: #000;
    display: inline-block;
    border-radius: 5px;
    padding: 0 20px;
    cursor: pointer;
    float: right;
    margin: 0 60px 0 10px;
}
#cookieConsent a.cookieConsentOK:hover {
    background-color: #E0C91F;
}
/*Cookie Consent End*/

.gallery:hover{
  cursor: pointer;
}

.overlay-gallery{
  display: none;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba( 0, 0, 0, 0.6 );
  z-index: 5000;
  text-align: center;
}

.overlay-gallery ul{
  width: 800px;
  margin: auto;
  padding: 0;
  height: 100vh;
}

.overlay-gallery li{
  display: none;
  background: rgba( 0,0,0,0.8);
  padding: 50px;
  align-items: center;
  justify-content: center;
  height: 100vh;
}

.overlay-gallery li img{
  max-width: 420px;
  margin: auto;
  padding: 0;
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.overlay-gallery li:first-child{
  display: block;
}

.overlay-gallery .prev, .overlay-gallery .next{
  font-size: 4em;
  color: white;
  font-weight: 300;
}

.overlay-gallery .prev:hover, .overlay-gallery .next:hover{
  cursor: pointer;
}

body{
	margin: 0px;
  padding: 0px;
  width: 100%;
  height: 100%;
	font-family: "Montserrat";
}

.parallax-window{
	background-image: url("assets/images/graz_cover.jpg");
  display: flex;
  flex: 1 0 auto;
  position: relative;
  height: 100vh;
  transform: translateZ(-1px) scale(2);
  z-index: -1;
	background-size: cover;
}


.parallax-window-2{
	background-image: url("assets/images/graz02.jpg");
  display: flex;
  flex: 1 0 auto;
  position: relative;
  height: 100vh;
  transform: translateZ(-1px) scale(2);
  z-index: -1;
	background-size: cover;
	top: 100vh;
}


.top-banner{
	background-image: url("assets/images/graz_01.jpg");
	height: 20vh;
	text-align: center;
	background-position-y: -350px;
	background-size: cover;
	padding-top: 1%;
	position: relative;
}

.top-banner:hover{
	cursor: pointer;
}

.top-overlay{
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
	background: rgba(40,40,40,0.6);
	z-index: 10;
}

.top-banner img.logo{
	width: 50%;
	z-index: 20;
	position: relative;
}

.overlay-gradient{
	z-index: 5;
	position: absolute;
	height: 100vh;
	width: 100%;
	/*background-color: rgba(0, 0, 0, 0.56); */
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#eaeaea+0,b2b2b2+50,ededed+100&0.41+0,1+100 */
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#eaeaea+0,b2b2b2+50,ededed+100&0.41+0,1+100 */
	background: -moz-linear-gradient(top, rgba(234,234,234,0.10) 0%, rgba(78,78,78,0.71) 50%, rgba(237,237,237,0.1) 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(top, rgba(234,234,234,0.10) 0%,rgba(78,78,78,0.71) 50%,rgba(237,237,237,0.1) 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to bottom, rgba(234,234,234,0.10) 0%,rgba(78,78,78,0.71) 50%,rgba(237,237,237,0.1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#69eaeaea', endColorstr='#ededed',GradientType=0 ); /* IE6-9 */
}

.header-outer{
	width: 100%;
	height: 100vh;
	z-index: 6;
	position: absolute;
}

.header-inner{
	transform: translateY(-50%);
	top: 50%;
	color: white;
	position: relative;
	z-index: 9;
	text-align: center;
	font-size: 3em;
	display: inline-block;
	width: 100%;
}

.main-content{
  display: block;
  position: relative;
  background-color: white;
  z-index: 1;
	padding: 10% 0;
}

.main-65{
	height: 65vh;
}

.header-inner a{
	border: 1px solid white;
	padding: 15px 25px;
	margin: 0 10px;
	border-radius: 5px;
	font-size: .8em;
}

.main-wrapper {
  perspective: 1px;
  transform-style: preserve-3d;
  height: 100vh;
  overflow-x: hidden;
  overflow-y: scroll;
}

.immo-option{
	border: 10px solid #015F46;
	margin: 20px;
	text-align: center;
	padding: 50px 0;
	background-size: cover;
	position: relative;
}

.house{
	background-image: url("assets/images/haus-bg.jpg");
  background-position-x: -50px;
}

.flat{
	background-image: url("assets/images/wohnung-bg.jpg");
	background-size: cover;
  background-position-x: -50px;
	position: relative;
}

.contact{
	background-image: url("assets/images/contact.jpg");
}


.estate{
	background-image: url("assets/images/grund_bg.jpg");
}

.immo-option > img{
	z-index: 15;
	position: relative;
}

.immo-overlay{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background: rgba(255,255,255,0.65);
	z-index: 12;
}



* {
  @include box-sizing(border-box);
}

section {
  background: #eee;
  max-width: 600px;
  margin: 0 auto;
  padding: 20px;
  overflow: hidden;
}

.module {
  box-shadow: 0 1px 3px rgba(black, 0.2);
}

.come-in {
  transform: translateY(150px);
  animation: come-in 1.0s ease forwards;
}

.come-in-slow {
  transform: translateY(200px);
  animation: come-in 2.0s ease forwards;
}

.come-in-left{
  transform: translateX(-150px);
  animation: come-in 1.0s ease forwards;
}

.come-in-left-slow{
  transform: translateX(-200px);
  animation: come-in 2.0s ease forwards;
}

.come-in-right{
  transform: translateX(150px);
  animation: come-in 1.0s ease forwards;
}

/* .come-in:nth-child(odd) {
  animation-duration: 1.6s;
} */

.already-visible {
  transform: translateY(0);
  animation: none;
}

@keyframes come-in {
  to { transform: translateY(0); }
}

footer{
	background: rgba(60,60,60,1);
	/*position: fixed;*/
	bottom: 0;
	height: 15vh;
	width: 100%;
	color: white;
	min-height: 180px
}

footer a{
	color: white;
}

.footer-wrapper{
	max-width: 1140px;
	width: 100%;
	margin: auto;
	position: relative;
	height: 100%;
}

.footer-left{
	float: left;
}
.footer-right{
	float: right;
	text-align: right;
}

.footer-wrapper > div{
  height: 60%;
  overflow: auto;
  margin: auto;
  position: absolute;
  top: 0; left: 0; bottom: 0; right: 0;
	font-size: 1.3em;
}

.footer-wrapper a{
	line-height: 2em;
}

.less-padding{
	padding: 2% 0;
}

.immo-option{
	transition: all .3s ease-in-out;
}
.immo-option:hover{
	transform: scale(1.2);
	cursor: pointer;
}

.archive-pic{
	float: left;
	margin-right: 10px;
}

.archive-content{

}

.archive-content .price div > div{
	border-bottom: 1px dashed #AAA;
}

.archive-content .price div > div:last-child{
	border-bottom: none;
}

.archive-content .price div > div:nth-last-child(2){
	border-bottom: 1px solid #555;
}

.archive-content .price > div{
	width: 50%;
	display: inline-block;
	margin-top: 20px;
}

.archive-content .size{
	width: 50%;
	display: inline-block;
	margin-top: 20px;
}

.finance span:last-child, .price span:last-child{
	float: right;
}



#main-content{
	background: blue;
}

.archive-elem:hover{
	cursor: pointer;
}

.archive-elem{
	margin-bottom: 40px;
	font-weight: light;
	font-family: "Montserrat";
}

.archive-content{
	font-size: 1.4em;
}

.archive-elem img.default{
	width: 200px;
	border: 3px solid #015F46;
	padding: 40px 50px;
}

.archive-pic{
	margin-right: 100px;
}

.total{
	font-weight: bold;
}

.size{
	font-weight: bold;
	text-align: center;
	font-size: 1.8em;
	margin-top: 10px;
}

.main-content, .page-content{
	min-height: 55vh;
}

.page-content{
	margin: 8vh 0;
}

.no-archive{
	margin-top: 20vh;
	font-size: 1.8em;
	text-align: center;
}

.single-img{
	text-align: center;
}

.gallery{
	margin-top: 40px;
}

.gallery div{
	margin: 5px;
	display: inline-block;
}

.gallery img{
	width: 80px;
	height: 80px;
}

.page-content{

}

.description{
	text-align: justify;
}

.finance, .information{
	margin-bottom: 30px;
}

.finance{
	margin-top: 20px;
}
