@charset "utf-8";
/* CSS Document */

body {
	font-family: 'Open Sans', sans-serif;
	font-weight: 400;
	margin: 0px;
	padding: 0px;
}

ul,
li,
h1,
h2,
h3,
h4,
h5,
h6,
p {
	margin: 0px;
	padding: 0px;
}

/*---HEADER---*/

header {
	border-bottom: 5px solid #029795;
}

.logo {
	margin-top: 55px;
	margin-bottom: 40px;
	width: 207px;
}

/*---NAVIGATIONEN---*/

.navigation-container {
	float: right;
	text-align: right;
}

/*---Metanavigation---*/

.metanavigation {
	text-align: right;
	list-style: none;
	margin: 15px 0 0 0;
	padding: 0px;
	
}

.metanavigation li {
	list-style: none;
	display: inline-block;
	
}

.metanavigation li:after {
	content: "|";
	margin: 0 1px 0 3px;
}

.metanavigation li:last-of-type:after {
	content: "";
	margin: 0px;
}

.metanavigation li a {
	font-size: 14px;
	font-weight: 400;
	color: #383838;
	text-transform: uppercase;
	transition: ease 0.5s;
	text-decoration: none;
	border-bottom: 1px solid #ffffff;
}

.metanavigation li a:hover,
.metanavigation li.current-menu-item a {
	border-bottom: 1px solid #383838;
}

/*---Hauptnavigation---*/

.hauptnavigation {
	text-align: right;
	float: right;
	list-style: none;
	margin: 53px 0 0 0;
	padding: 0px;
}

.hauptnavigation > li {
	list-style: none;
	display: inline-block;
	margin-left: 15px;
}

.hauptnavigation > li > a {
	font-size: 18px;
	color: #029795;
	text-transform: uppercase;
	transition: ease 0.5s;
	-webkit-transition: ease 0.5s;
}

.hauptnavigation > li > a:hover,
.hauptnavigation > li.current-menu-item > a,
.hauptnavigation > li.current-menu-ancestor > a {
	color: #383838;
	text-decoration: none;
}

/*---Subnavigation---*/

.sub-menu {
	display: none;	
	position: absolute;
	z-index: 9999;
	background-color: #029795;
	
	padding: 25px 30px 10px 15px;
}

.hauptnavigation li:hover .sub-menu {
	display: block;
}

.sub-menu li {
	list-style: none;
	margin: 0px;
	padding: 0px;
	text-align: left;
	margin-bottom: 15px;
}

.sub-menu li a {
	color: #ffffff;
	font-size: 16px;
}

.sub-menu li a:hover,
.sub-menu li.current-menu-item a {
	text-decoration: underline;
}

.sub-menu li a:after {
	content: " ";
	background-image: url(../img/link-arrow_white.png);
	background-size: cover;
	width: 7px;
	height: 13px;
	position: absolute;
	margin-top: 5px;
	margin-left: 10px;
	
}

/*---RESPONSIVE NAVIGATION---*/

.responsive-navigation-container {
	display: none;
	
}

.responsive-navigation-button {
	float: right;
	margin-top: 80px;l
}

.responsive-navigation-button .glyphicon-menu-hamburger {
	font-size: 22px;
	color: #029795;
}

.responsive-navigation-container {
	
}

.responsive-hauptnavigation,
.responsive-metanavigation {
	list-style: none;
	margin-bottom: 30px;
}

.responsive-metanavigation li a {
	font-size: 14px;
	font-weight: 400;
	color: #383838;
	text-transform: uppercase;
	transition: ease 0.5s;
	text-decoration: none;
	border-bottom: 1px solid #ffffff;
}

.responsive-hauptnavigation > li {
	padding: 5px 0;
}

.responsive-hauptnavigation > li > a {
	font-size: 18px;
	color: #029795;
	text-transform: uppercase;
}

.responsive-hauptnavigation > li.current-menu-item > a {
	text-decoration: underline;
	
}

.responsive-hauptnavigation li .sub-menu {
	position: relative;
}

.responsive-metanavigation li {
	padding: 5px 0;
}

.responsive-metanavigation li.current-menu-item a {
	text-decoration: underline;
}

/*---IMMOBILIENANGEBOTE---*/

.details a {
	color: #029795;
	font-size: 16px;
	transition: ease 0.5s;
	-webkit-transition: ease 0.5s;
	display: inline-block;
}

.details a:after {
	content: " ";
	background-image: url(../img/link-arrow_green.png);
	background-size: cover;
	width: 7px;
	height: 13px;
	position: absolute;
	margin-top: 5px;
	margin-left: 5px;
}

.details a:hover:after {
	background-image: url(../img/link-arrow_grey.png);
}

.details a:hover {
	color: #383838;
	text-decoration: none;
}

.details a:last-of-type {
	margin-bottom: 30px;
}

.immobilienangebot img {
	margin-bottom: 30px;
}



/*---FORMULAR---*/

form input[type=text],
form select,
form textarea {
	width: 100%;
	background-color: #ececec;
	height: 40px;
	border: 0px;
	margin-bottom: 15px;
}

form select {
	padding: 0 5px;
}

form input[type=text] {
	padding: 0 10px;
}

textarea {
	padding: 10px;
}

form textarea {
	height: 130px;
	resize: none;
}

form label {
	color: #383838;
	font-size: 16px;
	font-weight: 400;
	padding: 0 0 5px 0;
}

form input[type=submit] {
	width: 100%;
	background-color: #029795;
	height: 40px;
	text-transform: uppercase;
	border: 0px;
	color: #ffffff;
	font-weight: 700;
	font-size: 18px;
	-webkit-transition: ease 2s;
	-moz-transition: ease 2s;
	transition: ease 0.5s;
}

form input[type=submit]:hover {
	background-color: #383838;
}

form input[type=submit]:disabled {
	cursor: not-allowed;
	background-color: #ebebeb;
}

span.wpcf7-list-item {
	margin: 0;
}

/*---FORMULAR VALIDIERUNG---*/

.wpcf7-not-valid-tip {
	display: none !important;
}

.wpcf7-not-valid {
	border: 5px solid #029795 !important;
}

.wpcf7-response-output.wpcf7-validation-errors {
	background-color: #029795;
	color: #ffffff;
	font-weight: 700;
	margin: 0px !important;
	padding: 15px !important;	
}

.wpcf7-response-output {
	font-size: 16px;
	border: 0px !important;
}

.wpcf7-response-output.wpcf7-mail-sent-ok {	
	color: #383838;
	font-weight: 700;
	margin: 0px !important;
	padding: 0px !important;
}


/*---GOOGLE MAPS---*/

iframe {
	margin-bottom: 30px;
}



/*---TYPOGRAFIE---*/

h1 {
	color: #383838;
	font-size: 22px;
	padding-bottom: 20px;
	margin-top: 50px;
}

h2 {
	color: #383838;
	font-size: 18px;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 15px;
}

p {
	color: #383838;
	font-size: 16px;
	padding-bottom: 20px;
}

p a {
	color: #029795;
	text-decoration: none;
}

p a:hover {
	color: #383838;
	text-decoration: none;
}

.content ul {
	color: #383838;
	font-size: 16px;
	padding-bottom: 20px;
}

.content ul li {
	list-style: none;
	background-image: url(../img/list-style.png);
	background-repeat: no-repeat;
	background-position: 0 10px;
	padding-left: 15px;
	
}

/*.content ul li:before {
	content: "-";
	margin-right: 5px;
}*/


/*---GREEN TEASER---*/

.green-teaser {
	background-color: #029795;
	padding: 25px 15px 5px 15px;
	margin-bottom: 30px;
	margin-top: 50px;
}

.green-teaser p {
	color: #ffffff;
	font-size: 16px;
	line-height: 22px;
	font-weight: 300;
}

.green-teaser p a {
	color: #ffffff;
	
	text-decoration: underline;
}

.green-teaser p a:hover {
	text-decoration: none;
}

.green-teaser h2 {
	color: #ffffff;
	margin-bottom: 15px;
}

.green-teaser ul {
	
	
}

.content .green-teaser li {
	list-style: none;
	margin-bottom: 10px;
	padding-left: 0px;
	background: none;
}

.green-teaser li a {
	color: #ffffff;
	font-size: 16px;
}

.green-teaser li a:after {
	content: " ";
	background-image: url(../img/link-arrow_white.png);
	background-size: cover;
	width: 7px;
	height: 13px;
	position: absolute;
	margin-top: 5px;
	margin-left: 10px;
}



/*---TEASER---*/

.teaser {
	margin-top: 5px;
	border-top: 5px solid #029795;
	margin-bottom: 30px;
}

.teaser img {
	margin-bottom: 15px;
}

.teaser a {
	color: #029795;
	font-size: 16px;
	transition: ease 0.5s;
	-webkit-transition: ease 0.5s;
	
}

.teaser a:after {
	content: " ";
	background-image: url(../img/link-arrow_green.png);
	background-size: cover;
	width: 7px;
	height: 13px;
	position: absolute;
	margin-top: 5px;
	margin-left: 5px;
}

.teaser a:hover:after {
	background-image: url(../img/link-arrow_grey.png);
}

.teaser a:hover {
	color: #383838;
	text-decoration: none;
}

/*---TEAM---*/

.name {
	display: block;
	font-weight: 700;
	color: #383838;
	font-size: 16px;
	padding-bottom: 0px;
}

.email {
	color: #383838;	
	font-size: 16px;
	padding-bottom: 20px;
	display: block;
}

.email a {
	color: #029795;
	text-decoration: none;
}

.email a:hover {
	color: #383838;
	text-decoration: none;
}

img.portrait {
	margin-bottom: 30px;
	width: 100%;
}


/*---FOOTER---*/

footer {
	margin-top: 40px;
	border-top: 5px solid #029795;
	padding: 10px 0;
	font-size: 14px;
	font-weight: 400;
}

footer a {
	color: #383838;
}

footer a:hover {
	color: #383838;
	text-decoration: underline;
}

footer .copyright {
	text-align: left;
}

footer .webdesign {
	text-align: right;
}












