/*! normalize.css v3.0.2 | MIT License | git.io/normalize */ /** * 1. Set default font family to sans-serif. * 2. Prevent iOS text size adjust after orientation change, without disabling * user zoom. */ html { font-family: sans-serif; /* 1 */ -ms-text-size-adjust: 100%; /* 2 */ -webkit-text-size-adjust: 100%; /* 2 */ } /** * Remove default margin. */ body { margin: 0; } /* HTML5 display definitions ========================================================================== */ /** * Correct `block` display not defined for any HTML5 element in IE 8/9. * Correct `block` display not defined for `details` or `summary` in IE 10/11 * and Firefox. * Correct `block` display not defined for `main` in IE 11. */ article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary { display: block; } /** * 1. Correct `inline-block` display not defined in IE 8/9. * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. */ audio, canvas, progress, video { display: inline-block; /* 1 */ vertical-align: baseline; /* 2 */ } /** * Prevent modern browsers from displaying `audio` without controls. * Remove excess height in iOS 5 devices. */ audio:not([controls]) { display: none; height: 0; } /** * Address `[hidden]` styling not present in IE 8/9/10. * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22. */ [hidden], template { display: none; } /* Links ========================================================================== */ /** * Remove the gray background color from active links in IE 10. */ a { background-color: transparent; } /** * Improve readability when focused and also mouse hovered in all browsers. */ a:active, a:hover { outline: 0; } /* Text-level semantics ========================================================================== */ /** * Address styling not present in IE 8/9/10/11, Safari, and Chrome. */ abbr[title] { border-bottom: 1px dotted; } /** * Address style set to `bolder` in Firefox 4+, Safari, and Chrome. */ b, strong { font-weight: bold; } /** * Address styling not present in Safari and Chrome. */ dfn { font-style: italic; } /** * Address variable `h1` font-size and margin within `section` and `article` * contexts in Firefox 4+, Safari, and Chrome. */ h1 { font-size: 2em; margin: 0.67em 0; } /** * Address styling not present in IE 8/9. */ mark { background: #ff0; color: #000; } /** * Address inconsistent and variable font size in all browsers. */ small { font-size: 80%; } /** * Prevent `sub` and `sup` affecting `line-height` in all browsers. */ sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } sup { top: -0.5em; } sub { bottom: -0.25em; } /* Embedded content ========================================================================== */ /** * Remove border when inside `a` element in IE 8/9/10. */ img { border: 0; } /** * Correct overflow not hidden in IE 9/10/11. */ svg:not(:root) { overflow: hidden; } /* Grouping content ========================================================================== */ /** * Address margin not present in IE 8/9 and Safari. */ figure { margin: 1em 40px; } /** * Address differences between Firefox and other browsers. */ hr { -moz-box-sizing: content-box; box-sizing: content-box; height: 0; } /** * Contain overflow in all browsers. */ pre { overflow: auto; } /** * Address odd `em`-unit font size rendering in all browsers. */ code, kbd, pre, samp { font-family: monospace, monospace; font-size: 1em; } /* Forms ========================================================================== */ /** * Known limitation: by default, Chrome and Safari on OS X allow very limited * styling of `select`, unless a `border` property is set. */ /** * 1. Correct color not being inherited. * Known issue: affects color of disabled elements. * 2. Correct font properties not being inherited. * 3. Address margins set differently in Firefox 4+, Safari, and Chrome. */ button, input, optgroup, select, textarea { color: inherit; /* 1 */ font: inherit; /* 2 */ margin: 0; /* 3 */ } /** * Address `overflow` set to `hidden` in IE 8/9/10/11. */ button { overflow: visible; } /** * Address inconsistent `text-transform` inheritance for `button` and `select`. * All other form control elements do not inherit `text-transform` values. * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. * Correct `select` style inheritance in Firefox. */ button, select { text-transform: none; } /** * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` * and `video` controls. * 2. Correct inability to style clickable `input` types in iOS. * 3. Improve usability and consistency of cursor style between image-type * `input` and others. */ button, html input[type="button"], /* 1 */ input[type="reset"], input[type="submit"] { -webkit-appearance: button; /* 2 */ cursor: pointer; /* 3 */ } /** * Re-set default cursor for disabled elements. */ button[disabled], html input[disabled] { cursor: default; } /** * Remove inner padding and border in Firefox 4+. */ button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; } /** * Address Firefox 4+ setting `line-height` on `input` using `!important` in * the UA stylesheet. */ input { line-height: normal; } /** * It's recommended that you don't attempt to style these elements. * Firefox's implementation doesn't respect box-sizing, padding, or width. * * 1. Address box sizing set to `content-box` in IE 8/9/10. * 2. Remove excess padding in IE 8/9/10. */ input[type="checkbox"], input[type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ } /** * Fix the cursor style for Chrome's increment/decrement buttons. For certain * `font-size` values of the `input`, it causes the cursor style of the * decrement button to change from `default` to `text`. */ input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button { height: auto; } /** * 1. Address `appearance` set to `searchfield` in Safari and Chrome. * 2. Address `box-sizing` set to `border-box` in Safari and Chrome * (include `-moz` to future-proof). */ input[type="search"] { -webkit-appearance: textfield; /* 1 */ -moz-box-sizing: content-box; -webkit-box-sizing: content-box; /* 2 */ box-sizing: content-box; } /** * Remove inner padding and search cancel button in Safari and Chrome on OS X. * Safari (but not Chrome) clips the cancel button when the search input has * padding (and `textfield` appearance). */ input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; } /** * Define consistent border, margin, and padding. */ fieldset { border: 1px solid #c0c0c0; margin: 0 2px; padding: 0.35em 0.625em 0.75em; } /** * 1. Correct `color` not being inherited in IE 8/9/10/11. * 2. Remove padding so people aren't caught out if they zero out fieldsets. */ legend { border: 0; /* 1 */ padding: 0; /* 2 */ } /** * Remove default vertical scrollbar in IE 8/9/10/11. */ textarea { overflow: auto; } /** * Don't inherit the `font-weight` (applied by a rule above). * NOTE: the default cannot safely be changed in Chrome and Safari on OS X. */ optgroup { font-weight: bold; } /* Tables ========================================================================== */ /** * Remove most spacing between table cells. */ table { border-collapse: collapse; border-spacing: 0; } td, th { padding: 0; }
/**
 * @license
 * MyFonts Webfont Build ID 3360107, 2017-03-15T10:08:09-0400
 *
 * The fonts listed in this notice are subject to the End User License
 * Agreement(s) entered into by the website owner. All other parties are
 * explicitly restricted from using the Licensed Webfonts(s).
 *
 * You may obtain a valid license at the URLs below.
 *
 * Webfont: FF Meta Web Light by FontFont
 * URL: http://www.myfonts.com/fonts/fontfont/ff-meta/ot-light/
 *
 * Webfont: FF Meta Web Bold by FontFont
 * URL: http://www.myfonts.com/fonts/fontfont/ff-meta/ot-bold/
 *
 *
 * License: http://www.myfonts.com/viewlicense?type=web&buildid=3360107
 * Licensed pageviews: 50,000
 * Webfonts copyright: 2009 Erik Spiekermann published by FSI FontShop International GmbH
 *
 * © 2017 MyFonts Inc
*/
/* @import must be at top of file, otherwise CSS will not work */
@import url("//hello.myfonts.net/count/33456b");
@font-face {font-family: 'FFMetaWebLight';src: url('../_fonts/33456B_0_0.eot');src: url('../_fonts/33456B_0_0.eot?#iefix') format('embedded-opentype'),url('../_fonts/33456B_0_0.woff2') format('woff2'),url('../_fonts/33456B_0_0.woff') format('woff'),url('../_fonts/33456B_0_0.ttf') format('truetype');}
@font-face {font-family: 'FFMetaWebBold';src: url('../_fonts/33456B_1_0.eot');src: url('../_fonts/33456B_1_0.eot?#iefix') format('embedded-opentype'),url('../_fonts/33456B_1_0.woff2') format('woff2'),url('../_fonts/33456B_1_0.woff') format('woff'),url('../_fonts/33456B_1_0.ttf') format('truetype');}

@media only screen {
/*****************************************************************************/

/*
COLORS:
_ gray dark: 	#231f20
_ gray bright:	#f7f7f9 (#e8e8e9)
_ green:		#88b800
_ red:			#872112

FONTS:
font-family: 'FFMetaWebLight', sans-serif;
font-weight: 400;
font-family: 'FFMetaWebBold', sans-serif;
font-weight: 400;

FONTS (GOOGLE):
font-family: 'Signika', sans-serif;
font-weight: 300/400/600/700
*/

/* ==========================================================================
   BASICS
   ========================================================================== */

* html body * { overflow: visible; }
* html iframe, * html frame { overflow: auto; }

html, body {
	position: absolute;
	min-width: 100%;
	min-height: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

body {
	background: #f7f7f9 url() fixed no-repeat center center;
	background-size: cover;
	font-family: 'FFMetaWebLight', sans-serif;
	font-size: 0;
	line-height: 0;
	color: #000;
	-moz-font-feature-settings: "liga=0";
	-moz-font-feature-settings: "liga" 0;
	-webkit-font-variant-ligatures: no-common-ligatures;
	        font-variant-ligatures: no-common-ligatures;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	/*text-align: center;*/
}

* {
	-webkit-box-sizing: inherit;
	-moz-box-sizing: inherit;
	box-sizing: inherit;
	padding: 0;
	margin: 0;
	font-size: 100%;
}

/* ==========================================================================
   LAYOUT
   ========================================================================== */

/* PAGE AND LAYOUT WRAPPING */

div#layoutWrapper {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: auto;
	min-height: 100%;
	z-index: 1;
}

/* HEADER */

div#headerWrapper {
	position: fixed;
	width: 100%;
	height: 115px;
	background-color: #231f20;
	border-bottom: 30px solid #fff;
	-webkit-box-shadow: 0px 2px 4px rgba(51,51,51,0.1);
	   -moz-box-shadow: 0px 2px 4px rgba(51,51,51,0.1);
	        box-shadow: 0px 2px 4px rgba(51,51,51,0.1);
	z-index: 21;
}

div#headerWrapper.open {
	-webkit-box-shadow: 0px 5px 10px rgba(51,51,51,0.5);
	   -moz-box-shadow: 0px 5px 10px rgba(51,51,51,0.5);
	        box-shadow: 0px 5px 10px rgba(51,51,51,0.5);
}

/*div#headerWrapper:hover { height: 230px; }*/

.pageHomeOK div#headerWrapper { opacity: 0.95; }

div#logoLayer {
	position: absolute;
	right: 50%;
	margin-right: -590px;
	bottom: -33px;
	width: 120px;
	height: 118px;
	z-index: 21;
}

div#logoLayer img {
	width: 120px;
	height: 118px;
}

div#navigationLayer {
	position: absolute;
	left: 50%;
	margin-left: -610px;
	/*bottom: 0;*/
	top: 30px;
	width: auto;
	height: auto;
	z-index: 23;
}

div#navigationLayer div.sub {
	position: absolute;
	display: none;
	left: -20px;
	top: 100%;
	margin-top: -2px;
	width: auto;
	height: auto;
	background-color: #231f20;
	padding-bottom: 10px;
	z-index: 24;
}

.jsOK div#navigationLayer div.sub {
	padding-bottom: 0;
	background-color: transparent;
}

div#navigationLayer li:hover div.sub { display: block; }

div#navigation2Layer {
	position: absolute;
	bottom: -30px;
	left: 50%;
	margin-left: -600px;
	height: 30px;
	overflow: hidden;
	z-index: 21;
}

/* CONTENT */

div#mainWrapper {
	position: relative;
	width: 100%;
	height: auto;
	margin: auto;
	padding-top: 115px;
	text-align: center;
	z-index: 11;
}

.pageHomeOK div#mainWrapper { padding-bottom: 80px; }

div#mainWrapper > div.section,
div#mainWrapper > div.section > div.content {
	position: relative;
	width: 100%;
	margin: auto;
	text-align: left;
}

div#mainWrapper > div.section {}

div#mainWrapper > div.section > div.content {
	max-width: 1180px;
	padding: 40px 0;
	font-size: 18px;
	line-height: 1.667em;
	color: #231f20;
}

div#mainWrapper > div.section:last-child > div.content { padding-bottom: 80px; }

div#mainWrapper > div.section > div.content > p:last-child,
div#mainWrapper > div.section > div.content > ul:last-child { margin-bottom: 0; }

.pageHomeOK div#mainWrapper > div.section { padding: 50px 0 90px 0; }

div#mainWrapper > div.section.bgWhite { background-color: #fff; }
div#mainWrapper > div.section.bgGray { background-color: #d3d1d2; }

div#mainWrapper > div.section.bgPict {
	background: #fff url() scroll no-repeat center center;
	background-size: cover;
}

/* FOOTER */

div#footerWrapper {
	position: relative;
	width: 100%;
	height: 80px;
	font-size: 14px;
	line-height: 1.333em;
	color: #fff;
	background-color: #231f20;
	z-index: 21;
}

.pageHomeOK div#footerWrapper { opacity: 0.95; }

.pageHomeOK div#footerWrapper,
div#footerWrapper.fixed {
	position: fixed;
	left: 0;
	bottom: 0;
}

div#addressLayer {
	position: absolute;
	left: 50%;
	margin-left: -590px;
	top: 20px;
	width: auto;
	height: auto;
	z-index: 21;
}

div#addressLayer > div {
	position: relative;
	float: left;
	margin-right: 40px;
}

div#addressLayer > div.socialmedia {
	font-size: 0;
	line-height: 0;
	top: -3px;
}

div#addressLayer div img {
	width: 40px;
	height: 40px;
	margin-right: 10px;
	opacity: 0.2;
}

div#addressLayer div img:hover { opacity: 1; }

div#imprintLayer {
	position: absolute;
	right: 50%;
	margin-right: -590px;
	top: 20px;
	width: auto;
	height: auto;
	z-index: 21;
}

/* ==========================================================================
   CONTENT
   ========================================================================== */

/* HOME */

div#homeBoxWrapper { padding: 10px 0 !important; }

div#homeBoxWrapper div.item {
	position: relative;
	display: inline-block;
	width: calc(100% - 20px);
	max-width: 480px;
	height: auto;
	margin: 10px;
	text-align: left;
	z-index: 11;
}

div#homeTickerWrapper {
	position: relative;
	width: 100%;
	height: auto;
	padding: 0 !important;
	margin: 0 !important;
	/*background-color: #88b800;*/
	/*opacity: 0.95;*/
	background-color: #fab600;
	text-align: center;

}

div#homeTickerWrapper > div {
	position: relative;
	width: 100% !important;
	max-width: none !important;
	/*max-width: 980px !important;*/
	height: auto !important;
	min-height: 120px !important;
	margin: auto;
	margin-bottom: 100px;
	/*padding: 20px 0 !important;*/
	padding: 20px !important;
	/*
	background: transparent url('../images/graphics/icons/gray/coffee-hot.png') scroll no-repeat left center;
	background-size: 100px 100px;
	*/
	/*
	background: transparent url('../images/graphics/icons/gray/corona@3x.png') scroll no-repeat left center;
	background-size: 120px 120px;
	*/
	/*
	font-size: 32px !important;
	line-height: 1.2em !important;
	*/
	font-size: 0 !important;
	line-height: 0 !important;
	text-align: center !important;
	/*color: #a6594a !important;*/
	color: #fff !important;

}

div#homeTickerWrapper > div > strong {
	position: relative;
	display: inline-block;
	padding-bottom: 10px;
	text-transform: uppercase;
	letter-spacing: 2px;
}

div#homeTickerWrapper > div > strong::before {
	content: '';
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 5px;
	width: 50px;
	height: 3px;
	background-color: #fff;
	font-size: 0;
	line-height: 0;
	z-index: 2;
}

/* OBJECTS OVERVIEW */

div.objectsWrapper {
	display: relative;
	margin-left: -20px;
	width: calc(100% + 20px);
	height: auto;
}

div.objectsWrapper div.item {
	float: left;
	width: 33.333%;
	max-width: 570px;
	border: 20px solid #f7f7f9;
	border-width: 0 0 20px 20px;
}

div.objectsWrapper div.item div.pict {
	position: relative;
	width: 100%;
	height: auto;
	font-size: 0;
	line-height: 0;
}

div.objectsWrapper div.item div.pict img {
	-webkit-border-top-left-radius: 8px;
	-webkit-border-top-right-radius: 8px;
	   -moz-border-radius-topleft: 8px;
	   -moz-border-radius-topright: 8px;
	        border-top-left-radius: 8px;
	        border-top-right-radius: 8px;
}

div.objectsWrapper div.item div.text {
	position: relative;
	width: 100%;
	height: 80px;
	padding: 20px 20px;
	-webkit-border-bottom-right-radius: 8px;
	-webkit-border-bottom-left-radius: 8px;
	   -moz-border-radius-bottomright: 8px;
	   -moz-border-radius-bottomleft: 8px;
	        border-bottom-right-radius: 8px;
	        border-bottom-left-radius: 8px;
	background-color: #fff;
	z-index: 11;
}

/*div.objectsWrapper div.item div.text div.link {
	position: absolute;
	right: 0;
	top: 0;
	width: 60px;
	height: 100%;
	background: transparent url('../images/graphics/icons/green/arrow-right.png') scroll no-repeat center center;
	background-size: 30px 30px;
	z-index: 12;
}*/

div.objectsWrapper div.item div.text div.link {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 40px;
	height: 40px;
	background: transparent url('../images/graphics/icons/green/arrow-right.png') scroll no-repeat center center;
	background-size: 20px 20px;
	z-index: 12;
}

div.objectsWrapper.red div.item div.text div.link { background-image: url('../images/graphics/icons/red/arrow-right.png'); }

div.objectsWrapper div.item div.text div.link img {
	width: 100%;
	height: 100%;
}

div.objectsWrapper div.item div.text h2 {
	font-size: 21px;
	line-height: 1em;
	color: #88b800;
}

div.objectsWrapper div.item div.text h2 span {
	font-family: 'FFMetaWebLight', sans-serif;
	font-size: 18px;
	line-height: 1em;
	/*color: #7b7979;*/
	color: #231f20;
}

/* OBJECTS DETAIL */

/*h1.objectDetailTitle { margin-bottom: 20px; }*/

/* COLLAPSIBLE */

div.collapsible {
	position: relative;
	width: 100%;
	height: auto;
}

div.collapsible > div { position: relative; }

.jsOK div.collapsible div.title h2 {
	color: #88b800;
	background: transparent url('../images/graphics/icons/green/arrow-right.png') scroll no-repeat left top;
	background-size: 30px 30px;
	padding: 5px 0 2px 40px;
}
.jsOK div.collapsible.red div.title h2 { background-image: url('../images/graphics/icons/red/arrow-right.png'); }

.jsOK div.collapsible.open div.title h2 { background-image: url('../images/graphics/icons/green/arrow-down.png'); }
.jsOK div.collapsible.red.open div.title h2 { background-image: url('../images/graphics/icons/red/arrow-down.png'); }

.jsOK div.collapsible div.content {
	padding-left: 80px;
	display: none;
}

.jsOK div.collapsible:last-child div.content ul:last-child { margin-bottom: 0; }

/* COLLAPSIBLE REFERENCES */

div.collapsible.references div.content { padding-right: 40px; }

div.collapsible.references div.content div.portrait {
	position: absolute;
	right: -100px;
	top: 0;
	width: 120px;
	height: auto;
	margin-bottom: 20px;
	text-align: center;
	color: #b1b3b6;
}

div.collapsible.references div.content div.portrait img {
	width: 120px;
	height: 120px;
	-webkit-border-radius: 60px;
	   -moz-border-radius: 60px;
	        border-radius: 60px;
}

/* RENTAL QUESTIONS */

div#rentalQuestionsWrapper {
	position: relative;
	display: none;
	width: calc(100% + 20px);
	left: -20px;
	margin: 40px 0;
}

.jsOK div#rentalQuestionsWrapper { display: block; }

div#rentalQuestionsWrapper div.item {
	position: relative;
	float: left;
	width: 33.33333%;
	padding-left: 20px;
}

div#rentalQuestionsWrapper div.item div.question {
	padding: 10px 0;
	border-top: 2px solid #231f20;
	border-bottom: 1px solid #e8e8e9;
}

div#rentalQuestionsWrapper div.item div.answer {
	height: auto;
	padding: 10px 0;
	border-bottom: 2px solid #231f20;
}

div#rentalQuestionsWrapper div.result {
	position: relative;
	display: none;
	width: calc(100% - 20px);
	left: 20px;
	padding: 10px 0;
	border-bottom: 2px solid #231f20;
}

/* PEOPLE */

div.vCardsWrapper {
	position: relative;
	width: 100%;
	height: auto;
}

div.vCardsWrapper.tiles {
	position: relative;
	left: -20px;
	width: calc(100% + 20px);
	height: auto;
}

div.contactPeopleWrapper {
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: 100%;
	max-width: 480px;
	height: auto;
	padding: 20px 40px;
	margin: 10px;
	background-color: #fff;
	-webkit-border-radius: 8px;
	   -moz-border-radius: 8px;
	        border-radius: 8px;
	text-align: left;
}

div.contactPeopleWrapper h2 { margin-bottom: 20px; }

div.vCardsWrapper > div.item,
div.contactPeopleWrapper > div.item {
	position: relative;
	width: 100%;
	height: auto;
	margin: 20px 0 0 0;
	line-height: 1.2em;
}

div.vCardsWrapper > div.item:first-child,
div.contactPeopleWrapper > div.item:first-child { margin-top: 0; }
div.vCardsWrapper.tiles > div.item:first-child { margin-top: 20px; }

/*div.vCardsWrapper.tiles > div.item { margin-bottom: 0; }*/

div.vCardsWrapper.tiles > div.item {
	width: calc(33.33333% - 20px);
	max-width: 570px;
	margin-left: 20px;
	float: left;
}

div.vCardsWrapper > div.item > div.subcolumnsWrapper > div.left,
div.contactPeopleWrapper > div.item > div.subcolumnsWrapper > div.left {
	width: calc(100% - 130px);
	padding-top: 20px;
}

div.vCardsWrapper > div.item > div.subcolumnsWrapper > div.right,
div.contactPeopleWrapper > div.item > div.subcolumnsWrapper > div.right {
	width: 130px;
	text-align: right;
	font-size: 0;
	line-height: 0;
	padding: 0;
}

div.vCardsWrapper > div.item > div.subcolumnsWrapper > div.right > img,
div.contactPeopleWrapper > div.item > div.subcolumnsWrapper > div.right > img {
	width: 120px;
	height: 120px;
	-webkit-border-radius: 60px;
	   -moz-border-radius: 60px;
	        border-radius: 60px;
}

/* PHOTOSWIPE GALLERY */

.pswpGallery {
	position: relative;
	left: -10px;
	width: calc(100% + 10px);
	min-width: 100%;
	height: auto;
	margin-top: 10px;
}

.pswpGallery figure {
	position: relative;
	/*float: left;*/
	display: inline-block;
	width: calc(10% - 10px);
	height: auto;
	margin: 0 0 10px 10px;
	padding: 0;
	font-size: 0;
	line-height: 0;
	/*
	border: 20px solid #f7f7f9;
	border-width: 0 0 20px 20px;
	*/
	background: transparent url('') scroll no-repeat center center;
	background-size: cover;
	-webkit-border-radius: 8px;
	   -moz-border-radius: 8px;
	        border-radius: 8px;
	overflow: hidden;
	z-index: 11;
}

.pswpGallery figure a {
	display: block;
	width: 100%;
	height: auto;
	overflow: hidden;
}

.pswpGallery figure img {
	width: 100%;
	height: auto;
}

.pswpGallery figure figcaption { display: none; }

/* CALCULATOR */

div#calcWrapper {
	position: relative;
	display: inline-block;
	width: 100%;
	max-width: 800px;
	height: 340px;
	background-color: #fff;
	-webkit-border-radius: 8px;
	   -moz-border-radius: 8px;
	        border-radius: 8px;
	overflow: hidden;
	z-index: 11;
}

.jsNO div#calcWrapper { display: none; }

div#calcWrapper > div#calcTitleLayer {
	position: absolute;
	left: 0;
	top: 0;
	width: 40%;
	height: 100%;
	padding: 40px 20px 40px 40px;
	text-align: left;
	z-index: 13;
}

div#calcWrapper > div#calcTitleLayer > h1 {
	background-image: none;
	margin-bottom: 0;
}

div#calcWrapper > div#calcQuestionsWrapper {
	position: absolute;
	left: 40%;
	top: 0;
	width: 60%;
	height: 100%;
	z-index: 13;
}

div#calcWrapper > div#calcQuestionsWrapper > div.section {
	position: relative;
	display: none;
	width: 100%;
	height: 100%;
	text-align: left;
	padding: 40px 40px 40px 20px;
	z-index: 11;
}

div#calcWrapper > div#calcQuestionsWrapper > div.section:nth-child(1) { display: block; }

div#calcWrapper > div#calcQuestionsWrapper > div.section > div.text {
	position: relative;
	width: 100%;
	margin-bottom: 20px;
}

div#calcWrapper div#calcQuestionsWrapper div.section form.sent {
	width: 1px;
	height: 1px;
	overflow: hidden;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.input {
	position: relative;
	width: 100%;
	font-size: 18px;
	line-height: 1em;
	color: #231f20;
	margin-bottom: 3px;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.input label {
	display: inline-block;
	width: 140px;
	padding-bottom: 5px;
	font-family: 'FFMetaWebLight', sans-serif;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.input input {
	padding: 7px 10px 5px 10px;
	margin: 0;
	margin-right: 10px;
	text-align: right;
}

div#calcWrapper div#calcQuestionsWrapper div.section.calcResult div.input input { text-align: left; }

div#calcWrapper div#calcQuestionsWrapper div.section div.input input,
div#calcWrapper div#calcQuestionsWrapper div.section div.input select {
	width: calc(100% - 170px);
	max-width: 200px;
}

/*div#calcWrapper div#calcQuestionsWrapper div.section div.input submit { border: 3px solid red; }*/

div#calcWrapper div#calcQuestionsWrapper div.section div.button,
div#calcWrapper div#calcQuestionsWrapper div.section div.buttonBack {
	position: absolute;
	right: 10px;
	bottom: 10px;
	width: 40px;
	height: 40px;
	font-size: 0;
	line-height: 0;
	background: transparent url('../images/graphics/icons/green/arrow-right.png') scroll no-repeat center center;
	background-size: 30px 30px;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.buttonBack {
	right: 50px;
	background-image: url('../images/graphics/icons/green/arrow-left.png');
}

div#calcWrapper div#calcQuestionsWrapper div.section div.buttons {
	position: relative;
	width: 100%;
	font-size: 0;
	line-height: 0;
	text-align: center;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.buttons img {
	width: 80px;
	height: 80px;
	margin: 0 10px;
}

div#calcWrapper > div#calcValuesLayer { display: none; padding: 20px 0; }
div#calcWrapper > div#calcValuesLayer p { margin: 0; }

div#calcIndicatorWrapper {
	position: relative;
	display: inline-block;
	left: -2px;
	top: -16px;
	width: auto;
	height: 12px;
}

div#calcIndicatorWrapper > div.item {
	position: relative;
	float: left;
	width: 12px;
	height: 12px;
	background: transparent url('../images/graphics/calculator/dot_off.png') scroll no-repeat center center;
	background-size: 10px 10px;
	z-index: 12;
}

div#calcIndicatorWrapper > div.item.on { background-image: url('../images/graphics/calculator/dot_on.png'); }

div#calcIndicatorWrapper > div.line {
	position: absolute;
	left: 5px;
	top: 5px;
	width: calc(100% - 10px);
	min-width: 120px;
	height: 2px;
	background-color: #000;
	overflow: hidden;
	z-index: 11;
}

/* GOOGLE MAPS */

.mapWrapper {
	position: relative;
	width: 100%;
	height: 0;
	padding-bottom: 50%;
	overflow: hidden;
}

.c4 .mapWrapper {
	-webkit-border-radius: 8px;
	   -moz-border-radius: 8px;
	        border-radius: 8px;
}

.jsNO .mapWrapper { display: none; }

.mapWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	border: 0;
	pointer-events: none;
}

/* VIDEO 16:9 */

.videoWrapper {
	position: relative;
	width: 100%;
	height: 0;
	padding: 0 !important;
	padding-bottom: 56.25% !important; /* 16:9 */
	background-color: #fff;
	overflow: hidden;
}

.jsNO .videoWrapper { display: none; }

.videoWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	border: 0;
}

/* THETA360 */

.theta360Wrapper {
	text-align: center;
	padding: 20px 0;
}

.jsNO .theta360Wrapper { display: none; }

.theta360Wrapper > div.ricoh-theta-spherical-image {
	position: relative !important;
	display: inline-block !important;
	left: 50%;
	margin-left: -250px !important;
	width: 500px;
	height: 375px;
}

/* ETC */

.indent { padding-left: 80px; }

div.roundedCorners {
	-webkit-border-radius: 8px;
	   -moz-border-radius: 8px;
	        border-radius: 8px;
	background-color: #fff;
	padding: 40px 30px 40px 20px;
}

.c9 div.roundedCorners { padding-right: 120px; }
.c9 p.paddingRight { padding-right: 160px; }
/*.c9 div.roundedCorners.references { padding-right: 30px; }*/

.pageHomeOK div.roundedCorners { padding: 40px; }

img.roundedCorners {
	-webkit-border-radius: 8px;
	   -moz-border-radius: 8px;
	        border-radius: 8px;
}

p.logos img {
	margin: 0 22px;
	max-width: calc(100% - 20px);
	height: auto;
}

.fontSupersize {
	font-size: 40px;
	line-height: 1em;
}

/* ==========================================================================
   HEADLINES
   ========================================================================== */

h1, h2, h3 {
	font-family: 'FFMetaWebBold', sans-serif;
	font-weight: 400;
	font-size: 40px;
	line-height: 1em;
	/*color: #88b800;*/
	color: #000;
	margin: 0 0 24px 0;
}

h1, .h1 {
	background: transparent url('../images/main/bg-headline.gif') scroll no-repeat left bottom;
	background-size: 120px 3px;
	padding-bottom: 22px;
}

.h1 {
	font-size: 40px !important;
	line-height: 1em !important;
	margin-bottom: 24px !important;
}

h2, h3 {
	font-size: 24px;
	line-height: 1em;
	color: #231f20;
	margin-bottom: 5px;
}

h2.small, h3 {
	font-size: 18px;
	line-height: 1.667em;
}

.red h1, h1.red,
.red h2, h2.red,
.red h3, h3.red { color: #872112 !important; }

.green h1, h1.green,
.green h2, h2.green,
.green h3, h3.green { color: #88b800 !important; }

/* ==========================================================================
   LINKS
   ========================================================================== */

a, a:link, a:visited { color: #88b800; text-decoration: none; }
a:hover, a:active, a:visited:hover, a:visited:active { text-decoration: underline; }

.red a, .red a:link, .red a:visited,
a.red, a.red:link, a.red:visited { color: #872112 !important; }

a.icon,
a.icon:link,
a.icon:visited,
p.vCard a,
p.vCard a:link,
p.vCard a:visited {
	background: transparent url('../images/graphics/icons/green/arrow-right.png') scroll no-repeat left center;
	background-size: 15px 15px;
	padding: 2px 0 0 25px;
}

a.icon.red,
a.icon.red:link,
a.icon.red:visited,
p.vCard.red a,
p.vCard.red a:link,
p.vCard.red a:visited {
	background-image: url('../images/graphics/icons/red/arrow-right.png');
}

a.iconBig,
a.iconBig:link,
a.iconBig:visited,
div#homeBoxWrapper ul li a,
div#homeBoxWrapper ul li a:link,
div#homeBoxWrapper ul li a:visited,
ul.downloads li a,
ul.downloads li a:link,
ul.downloads li a:visited,
ul.linksPartner li a,
ul.linksPartner li a:link,
ul.linksPartner li a:visited {
	display: inline-block;
	font-family: 'FFMetaWebBold', sans-serif;
	font-weight: 400;
	font-size: 24px;
	line-height: 1em;
	color: #88b800;
	text-decoration: none;
	background: transparent url('../images/graphics/icons/green/arrow-right.png') scroll no-repeat left 0;
	background-size: 30px 30px;
	padding: 5px 0 2px 40px;
}

a.iconBig.red,
a.iconBig.red:link,
a.iconBig.red:visited,
div#homeBoxWrapper div.red ul li a,
div#homeBoxWrapper div.red ul li a:link,
div#homeBoxWrapper div.red ul li a:visited,
ul.downloads.red li a,
ul.downloads.red li a:link,
ul.downloads.red li a:visited {
	color: #872112;
	background-image: url('../images/graphics/icons/red/arrow-right.png') !important;
}

div#homeBoxWrapper ul li a,
div#homeBoxWrapper ul li a:link,
div#homeBoxWrapper ul li a:visited {
	background-size: 40px 40px;
	padding: 11px 0 8px 50px;
}

div#homeBox1Layer.red > ul > li:nth-child(1) a,
div#homeBox1Layer.red > ul > li:nth-child(1) a:link,
div#homeBox1Layer.red > ul > li:nth-child(1) a:visited { background-image: url('../images/graphics/icons/red/apartment.png') !important; }
div#homeBox1Layer.red > ul > li:nth-child(2) a,
div#homeBox1Layer.red > ul > li:nth-child(2) a:link,
div#homeBox1Layer.red > ul > li:nth-child(2) a:visited { background-image: url('../images/graphics/icons/red/bubbles.png') !important; }
div#homeBox1Layer.red > ul > li:nth-child(3) a,
div#homeBox1Layer.red > ul > li:nth-child(3) a:link,
div#homeBox1Layer.red > ul > li:nth-child(3) a:visited { background-image: url('../images/graphics/icons/red/book.png') !important; }

div#homeBox2Layer > ul > li:nth-child(1) a,
div#homeBox2Layer > ul > li:nth-child(1) a:link,
div#homeBox2Layer > ul > li:nth-child(1) a:visited { background-image: url('../images/graphics/icons/green/house.png'); }
div#homeBox2Layer > ul > li:nth-child(2) a,
div#homeBox2Layer > ul > li:nth-child(2) a:link,
div#homeBox2Layer > ul > li:nth-child(2) a:visited { background-image: url('../images/graphics/icons/green/price.png'); }
div#homeBox2Layer > ul > li:nth-child(3) a,
div#homeBox2Layer > ul > li:nth-child(3) a:link,
div#homeBox2Layer > ul > li:nth-child(3) a:visited { background-image: url('../images/graphics/icons/green/key.png'); }

div#footerWrapper a, div#footerWrapper a:link, div#footerWrapper a:visited { color: #fff; text-decoration: none; }
div#footerWrapper a:hover, div#footerWrapper a:active, div#footerWrapper a:visited:hover, div#footerWrapper a:visited:active { color: #88b800; }

div#navigationLayer a,
div#navigationLayer a:link,
div#navigationLayer a:visited {
	display: block;
	width: auto;
	font-family: 'FFMetaWebBold', sans-serif;
	font-weight: 400;
	font-size: 32px;
	line-height: 1em;
	color: #fff;
	letter-spacing: 0;
	text-decoration: none !important;
	text-transform: lowercase;
	padding: 12px 20px;
	opacity: 0.2;
}
.pageHomeOK div#navigationLayer a,
.pageHomeOK div#navigationLayer a:link,
.pageHomeOK div#navigationLayer a:visited {
	opacity: 1;
}
div#navigationLayer li:hover a,
div#navigationLayer li:active a { opacity: 1; }
.pageHomeOK div#navigationLayer li:hover a,
.pageHomeOK div#navigationLayer li:active a { opacity: 0.75; }
div#navigationLayer li.act a,
div#navigationLayer li.act a:link,
div#navigationLayer li.act a:visited,
div#navigationLayer li.act a:hover,
div#navigationLayer li.act a:active,
div#navigationLayer li.act a:visited:hover,
div#navigationLayer li.act a:visited:active { /*color: #88b800 !important;*/ opacity: 1; }
div#navigationLayer div.sub a,
div#navigationLayer div.sub a:link,
div#navigationLayer div.sub a:visited {
	width: 100%;
	height: auto;
	font-size: 26px;
	line-height: 1.1em;
	color: #fff !important;
	text-transform: uppercase;
	white-space: nowrap;
	padding: 1px 40px;
	background: transparent url() scroll no-repeat 16px 2px;
	background-size: 8px 22px;
}
div#navigationLayer div.sub a:hover,
div#navigationLayer div.sub a:active,
div#navigationLayer div.sub a:visited:hover,
div#navigationLayer div.sub a:visited:active { background-image: url('../images/main/nav-arrow.png'); }
div#navigationLayer div.sub li.act a,
div#navigationLayer div.sub li.act a:link,
div#navigationLayer div.sub li.act a:visited,
div#navigationLayer div.sub li.act a:hover,
div#navigationLayer div.sub li.act a:active,
div#navigationLayer div.sub li.act a:visited:hover,
div#navigationLayer div.sub li.act a:visited:active { background-image: url('../images/main/nav-arrow.png'); }

div#navigation2Layer a,
div#navigation2Layer a:link,
div#navigation2Layer a:visited {
	display: block;
	width: auto;
	font-family: 'FFMetaWebBold', sans-serif;
	font-weight: 400;
	font-size: 15px;
	color: #7b7979;
	line-height: 1em;
	letter-spacing: 1px;
	text-decoration: none !important;
	text-transform: lowercase;
	padding: 9px 10px;
}
div#navigation2Layer li:hover a,
div#navigation2Layer li:active a { color: #88b800 !important; }
div#navigation2Layer li.act a,
div#navigation2Layer li.act a:link,
div#navigation2Layer li.act a:visited,
div#navigation2Layer li.act a:hover,
div#navigation2Layer li.act a:active,
div#navigation2Layer li.act a:visited:hover,
div#navigation2Layer li.act a:visited:active { color: #88b800 !important; }

/* ==========================================================================
   LISTS
   ========================================================================== */

ul, ol, dl {
	position: relative;
	margin: 0 0 1.5em 0;
}

ul {
	list-style-type: disc;
	list-style-position: outside;
	margin-left: 20px;
}

ol {
	list-style-type: decimal;
	list-style-position: outside;
	margin-left: 20px;
}

ul ul, ul ol, ol ol, ol ul { margin-bottom: 0; }

div#homeBoxWrapper ul,
ul.noBullets {
	list-style-type: none;
	list-style-position: inside;
	margin-left: 0;
}

div#homeBoxWrapper ul li,
ul.noBullets li {
	padding-left: 0 !important;
	background: none !important;
}

div.section ul {
	position: relative;
	left: 0;
	list-style-type: none;
	list-style-position: outside;
	margin-left: 0;
}

div.section ul li {
	padding-left: 25px;
	background: transparent url('../images/main/list-item-check.png') scroll no-repeat 0 8px;
	background-size: 15px 15px;
}

div.section ul.downloads {
	list-style-type: none;
	list-style-position: outside;
	margin-left: 0;
}

div.section ul.downloads li {
	padding-left: 0 !important;
	background: none !important;
}

ul.linksPartner {
	list-style-type: none;
	list-style-position: outside;
	display: inline-block;
	margin: 0;
	width: calc(100% + 20px);
	left: -20px !important;
}

ul.linksPartner li {
	position: relative;
	display: inline-block;
	/*
	float: left;
	width: 33.33333%;
	*/
	float: none;
	width: 100%;
	padding-left: 20px;
	background: none !important;
}

/* LIST NAVIGATION HORIZONTAL */

div#navigationLayer ul,
div#navigation2Layer ul {
	list-style-type: none;
	list-style-position: outside;
	display: inline-block;
	margin: 0;
	width: auto;
}

div#navigationLayer ul li,
div#navigation2Layer ul li {
	position: relative;
	float: left;
	display: inline-block;
	height: auto;
	overflow: visible;
}

/* LIST NAVIGATION VERTICAL */

div#navigationLayer div.sub ul {
	width: 100%;
	list-style-type: none;
	list-style-position: outside;
	margin: 0;
}

div#navigationLayer div.sub ul li {
	float: none;
	display: block;
	width: 100%;
	height: auto;
	margin: 0;
}

/* ==========================================================================
   GENERAL
   ========================================================================== */

.viewMobileOnly { display: none; }
.viewDesktopOnly { display: block; }

.jsNO .jsNO { display: block; }
.jsOK .jsNO { display: none; }

.jsNO .jsOK { display: none; }
.jsOK .jsOK { display: block; }

.borderbox {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	/*values: content-box|border-box|inherit*/
}

.clear { clear: both; display: block; height: 0; width: 0; overflow: hidden; }
.ghost { display: none !important; }
.noWrap { white-space: nowrap; }
.noFont { font-size: 0; line-height: 0; }
.hyphen { hyphens: auto; word-wrap: break-word; }

hr {
	width: 100%;
	border: 0; /* Firefox und Opera */
	border-top: 1px solid #ccc;
	border-bottom: transparent;
	margin: 2.5em 0 2.5em 0;
}

.subcolumns hr { width: 80%; }
hr.invisible { background: none; }

div.distance,
div.space {
	position: relative;
	width: 100%;
	height: 20px;
	overflow: hidden;
	background-color: transparent;
}
div.space5 { height: 5px; }
div.space10 { height: 10px; }
div.space15 { height: 15px; }
div.space20 { height: 20px; }
div.space25 { height: 25px; }
div.space30 { height: 30px; }
div.space35 { height: 35px; }
div.space40 { height: 40px; }
div.space45 { height: 45px; }
div.space50 { height: 50px; }

.textAlignLeft { text-align: left !important; }
.textAlignCenter { text-align: center !important; }
.textAlignRight { text-align: right !important; }
.textAlignBlock { text-align: justify !important; }

.textCaseUpper { text-transform: uppercase !important; }
.textCaseLower { text-transform: lowercase !important; }

.alert { font-weight: 700; color: #c00; }

.paddingTopZero { padding-top: 0 !important; }
.paddingBottomZero { padding-bottom: 0 !important; }

.marginTopZero { margin-top: 0 !important; }
.marginTopSingle { margin-top: 1.5em !important; }
.marginTopDouble { margin-top: 3.0em !important; }
.marginBottomZero { margin-bottom: 0 !important; }
.marginBottomSingle { margin-bottom: 1.5em !important; }
.marginBottomDouble { margin-bottom: 3.0em !important; }

.w10 { width: 9.999% !important; }
.w15 { width: 14.999% !important; }
.w20 { width: 19.999% !important; }
.w25 { width: 24.999% !important; }
.w30 { width: 29.999% !important; }
.w33 { width: 33.333% !important; }
.w35 { width: 34.999% !important; }
.w38 { width: 37.999% !important; }
.w40 { width: 39.999% !important; }
.w45 { width: 44.999% !important; }
.w50 { width: 49.999% !important; }
.w55 { width: 54.999% !important; }
.w60 { width: 59.999% !important; }
.w65 { width: 55.999% !important; }
.w66 { width: 66.666% !important; }
.w70 { width: 69.999% !important; }
.w75 { width: 74.999% !important; }
.w80 { width: 79.999% !important; }
.w85 { width: 84.999% !important; }
.w90 { width: 89.999% !important; }

p, .p { margin: 0 0 1.5em 0; }
p.pict { font-size: 0; line-height: 0; margin: 0; padding: 0; }

table {
	position: relative;
	width: 100%;
	border-width: 0;
	margin: 0 0 1.333em 0;
	border-collapse: collapse;
	empty-cells: hide;
}
th, td { background-color: transparent; vertical-align: top; }
/*table p, table ul, table ol { margin-bottom: 0; }*/

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

figure, figcaption { display: block; }

strong, b { font-family: 'FFMetaWebBold', sans-serif; font-weight: 400; }
em, i { font-style: normal; }

pre, code { font-family: "Courier New", Courier, monospace; }
address { font-style: normal; margin: 0 0 1.5em 0; }
acronym, abbr { letter-spacing: 0.07em; border-bottom: 1px dashed #000; cursor: help; }
blockquote, cite { margin: 0 0 1.5em 1.5em; width: auto; }

sup, sub {
	font-size: 75%;
	position: relative;
	height: 0;
	line-height: 1;
	vertical-align: baseline;
}
sup { bottom: 1ex; }
sub { top: .5ex; }

iframe { margin-bottom: 1.5em; border: 0; }

/* ==========================================================================
   COLUMNS
   ========================================================================== */

div.subcolumnsWrapper {
	position: relative;
	left: -20px;
	width: calc(100% + 20px);
	height: auto;
}

div.subcolumnsWrapper > div.col {
	position: relative;
	padding-left: 20px;
}

div.subcolumnsWrapper > div.col > p:last-child,
div.subcolumnsWrapper > div.col > ul:last-child {
	margin-bottom: 0;
}

div.subcolumnsWrapper > div.col.left { float: left; }
div.subcolumnsWrapper > div.col.right { float: right; }

div.subcolumnsWrapper > div.col.c1 { width: 8.33333%; }
div.subcolumnsWrapper > div.col.c2 { width: 16.66667%; }
div.subcolumnsWrapper > div.col.c3 { width: 25%; }
div.subcolumnsWrapper > div.col.c4 { width: 33.33333%; }
div.subcolumnsWrapper > div.col.c5 { width: 41.66667%; }
div.subcolumnsWrapper > div.col.c6 { width: 50%; }
div.subcolumnsWrapper > div.col.c7 { width: 58.33333%; }
div.subcolumnsWrapper > div.col.c8 { width: 66.66667%; }
div.subcolumnsWrapper > div.col.c9 { width: 75%; }
div.subcolumnsWrapper > div.col.c10 { width: 83.33333%; }
div.subcolumnsWrapper > div.col.c11 { width: 91.66667%; }
div.subcolumnsWrapper > div.col.c12 { width: 100%; }

div.subcolumnsWrapper > div.col.paddingExtraRight { padding-right: 10px; }
div.subcolumnsWrapper > div.col.c8.paddingExtraRight,
div.subcolumnsWrapper > div.col.c9.paddingExtraRight { padding-right: 8.33333%; }

.columns-2 {
	-webkit-column-count: 2;
	   -moz-column-count: 2;
	        column-count: 2;
	-webkit-column-gap: 20px;
	   -moz-column-gap: 20px;
	        column-gap: 20px;
}

.columns-3 {
	-webkit-column-count: 3;
	   -moz-column-count: 3;
	        column-count: 3;
	-webkit-column-gap: 20px;
	   -moz-column-gap: 20px;
	        column-gap: 20px;
}

/* ==========================================================================
   FORMS
   ========================================================================== */

/* FORM GENERAL SETTINGS */

div.formWrapper { position: relative; width: 100%; text-align: left; }
form { position: relative; overflow: hidden; width: 100%; /*max-width: 400px;*/ /*margin: auto;*/ }
fieldset { border: 0; }
div.formInputset { position: relative; margin: 0 0 1.333em 0; display: block; clear: both; }
/*div.calcResult div.formInputset { margin-bottom: 5px; text-align: left; }*/
/*div.calcResult div.formInputset.indent { padding-left: 84px; }*/

/* LABEL */

label {
	display: block;
	width: 100%;
	height: auto;
	margin-bottom: 3px;
	font-family: 'FFMetaWebBold', sans-serif;
	font-weight: 400;
}

/*div.calcResult label {
	display: inline-block;
	width: 80px;
	margin-bottom: 0;
	overflow: hidden;
}*/

/* INPUT TEXT and TEXTAREA */

input[type=text],
input[type=password] {
	width: 100%;
	padding: 10px 10px;
	border: 1px solid #b1b3b6;
	background-color: #fff;
	color: #231f20;
	text-align: left;
}

/*
div.calcResult input[type=text],
div.calcResult input[type=password] {
	display: inline-block;
	width: 240px;
}
*/

textarea {
	width: 100%;
	height: 100px;
	padding: 10px 10px;
	border: 1px solid #b1b3b6;
	background-color: #fff;
	color: #231f20;
	text-align: left;
}

input[type=text]:focus, input[type=text]:active,
input[type=password]:focus, input[type=password]:active,
textarea:focus, textarea:active {
	border-color: #231f20;
	background-color: #fff;
	color: #231f20;
}

/* INPUT SELECT, RADIO and CHECKBOX */

select { width: 50%; }
select.wAuto { width: auto; }
select option { padding: 0 5px; }

input[type=radio],
input[type=checkbox] {
	margin-right: 5px;
}
input[type=radio] { margin-left: 2px; }

/* INPUT BUTTONS */

input[type=button],
input[type=submit],
input[type=reset] {
	width: 100%;
	width: auto;
	max-width: 400px;
	padding: 6px 12px;
	background-color: #88b800;
	border: 1px solid #88b800;
	color: #fff;
	font-family: 'FFMetaWebBold', sans-serif;
	font-weight: 400;
	text-align: center;
}

input[type=button]:hover,
input[type=submit]:hover,
input[type=reset]:hover {
	border-color: #231f20;
	background-color: #231f20;
	color: #fff;
	cursor: pointer;
}

/*****************************************************************************/
}

@media only screen and (min-width: 1000px) and (min-height: 700px) {
/*****************************************************************************/

.pageHomeOK div#mainWrapper { padding-bottom: 0; }

div#homeBoxWrapper {
	position: fixed !important;
	left: 0 !important;
	top: 50% !important;
	margin-top: -220px !important;
	padding: 0 !important;
}

div#homeTickerWrapper {
	position: fixed !important;
	left: 0;
	bottom: 80px;
	margin-bottom: 0;
}

/*****************************************************************************/
}



@media only screen and (max-width: 999px) {
/*****************************************************************************/

/*
.pageHomeOK div#mainWrapper { border: 1px solid red; }
.pageHomeOK div#mainWrapper { padding-bottom: 0; }
*/

/*****************************************************************************/
}



@media only screen and (max-width: 1219px) {
/*****************************************************************************/

/* HEADER */

div#logoLayer {
	right: 20px;
	margin-right: 0;
}

div#navigationLayer {
	left: 0;
	margin-left: 0;
}

div#navigation2Layer {
	left: 10px;
	margin-left: 0;
}

/* CONTENT */

div#mainWrapper > div.section > div.content { width: calc(100% - 40px); }

/* FOOTER */

div#addressLayer {
	left: 20px;
	margin-left: 0;
}

div#imprintLayer {
	right: 20px;
	margin-right: 0;
}

/* CONTENT: COLLAPSIBLE */

.jsOK div.collapsible div.content { padding-left: 40px; }

div.collapsible.references div.content { padding-right: 120px; }
div.collapsible.references div.content div.portrait { right: -20px; }

/* CONTENT: OBJECTS OVERVIEW */

div.objectsWrapper div.item { width: 50%; }

/* CONTENT: PEOPLE */

div.vCardsWrapper.tiles > div.item { width: calc(50% - 20px); }

/* ETC */

.indent { padding-left: 0; }

.c9 div.roundedCorners { padding-right: 40px; }
.c9 p.paddingRight { padding-right: 0; }

/* LINKS */

div#navigationLayer > ul > li:nth-child(1) div.sub a,
div#navigationLayer > ul > li:nth-child(1) div.sub a:link,
div#navigationLayer > ul > li:nth-child(1) div.sub a:visited {
	background-position: 26px center;
}

/*****************************************************************************/
}

@media only screen and (max-width: 1023px) {
/*****************************************************************************/

/* COLUMNS*/

div.subcolumnsWrapper {
	left: 0;
	width: 100%;
}

div.subcolumnsWrapper > div.col {
	padding-left: 0;
	padding-bottom: 20px;
}

div.subcolumnsWrapper > div.col:nth-child(2) { padding-bottom: 0; }

div.subcolumnsWrapper > div.col.left { float: none; }
div.subcolumnsWrapper > div.col.right { float: none; }

div.vCardsWrapper.tiles div.subcolumnsWrapper > div.col.left,
div.vCardsWrapper.list div.subcolumnsWrapper > div.col.left,
div.contactPeopleWrapper div.subcolumnsWrapper > div.col.left { float: left; }
div.vCardsWrapper.tiles div.subcolumnsWrapper > div.col.right,
div.vCardsWrapper.list div.subcolumnsWrapper > div.col.right,
div.contactPeopleWrapper div.subcolumnsWrapper > div.col.right { float: right; }

div.subcolumnsWrapper > div.col.c1,
div.subcolumnsWrapper > div.col.c2,
div.subcolumnsWrapper > div.col.c3,
div.subcolumnsWrapper > div.col.c4,
div.subcolumnsWrapper > div.col.c5,
div.subcolumnsWrapper > div.col.c6,
div.subcolumnsWrapper > div.col.c7,
div.subcolumnsWrapper > div.col.c8,
div.subcolumnsWrapper > div.col.c9,
div.subcolumnsWrapper > div.col.c10,
div.subcolumnsWrapper > div.col.c11,
div.subcolumnsWrapper > div.col.c12 { width: 100%; }

div.subcolumnsWrapper > div.col.paddingExtraRight { padding-right: 0 !important; }

/*****************************************************************************/
}

@media only screen and (max-width: 919px) {
/*****************************************************************************/

p.logos a {
	display: block;
	text-align: center;
	margin-bottom: 20px;
}

p.logos a:last-child { margin-bottom: 0; }

/*****************************************************************************/
}

@media only screen and (max-width: 919px) {
/*****************************************************************************/

/* CONTENT: OBJECTS OVERVIEW */

div.objectsWrapper div.item { width: 100%; }

/* CONTENT: PEOPLE */

div.vCardsWrapper.tiles > div.item { width: calc(100% - 20px); }

/*****************************************************************************/
}

@media only screen and (max-width: 839px) {
/*****************************************************************************/

/* CALCULATOR */

div#calcWrapper { height: auto; }

div#calcWrapper > div#calcTitleLayer {
	position: relative;
	width: 100%;
	height: auto;
	padding: 40px 20px 0 20px;
}

div#calcWrapper > div#calcQuestionsWrapper {
	position: relative;
	left: 0;
	width: 100%;
	height: 300px;
}

div#calcWrapper > div#calcQuestionsWrapper > div.section {
	padding: 0 20px;
}

/*****************************************************************************/
}

@media only screen and (max-width: 779px) {
/*****************************************************************************/

/* HEADER */

div#headerWrapper {
	/*position: relative;*/
	/*height: auto !important;*/
	height: auto;
	border-bottom: 0;
}

div#logoLayer {
	position: relative;
	right: auto;
	left: 0;
	margin-right: 0;
	bottom: auto;
	top: 0;
	width: 100%;
	border-bottom: 32px solid #fff;
	margin-bottom: 4px;
	text-align: center;
}

div#navigationLayer {
	position: relative;
	left: 0;
	margin-left: 0;
	top: 0;
	width: 100%;
	text-align: center;
	border: 1px solid #231f20;
}

div#navigationLayer div.sub {
	position: fixed;
	left: 0;
	top: 180px;
	width: 100%;
	height: auto;
	padding-bottom: 20px !important;
	background-color: #231f20 !important;
	-webkit-box-shadow: 0px 5px 10px rgba(51,51,51,0.5);
	   -moz-box-shadow: 0px 5px 10px rgba(51,51,51,0.5);
	        box-shadow: 0px 5px 10px rgba(51,51,51,0.5);
}

/*div#navigationLayer li:hover div.sub { display: none; }*/

div#navigation2Layer {
	position: absolute;
	bottom: auto;
	top: 10px;
	left: 10px;
	margin-left: 0;
	height: auto;
}

div#navigationLayer div.sub a,
div#navigationLayer div.sub a:link,
div#navigationLayer div.sub a:visited { background-image: none !important; }

/* CONTENT */

/*div#mainWrapper { padding-top: 0; }*/
div#mainWrapper { padding-top: 180px; }

/* FOOTER */

.pageHomeOK div#footerWrapper,
div#footerWrapper.fixed {
	position: relative;
	left: 0;
	bottom: auto;
	top: 0;
}

/* HOME */

div#homeTickerWrapper > div {
	font-size: 24px !important;
	line-height: 1.333em !important;
}

/*****************************************************************************/
}

@media only screen and (max-width: 719px) {
/*****************************************************************************/

/* FOOTER */

div#footerWrapper {
	height: auto;
}

div#addressLayer {
	position: relative;
	left: 0;
	margin-left: 0;
	top: 0;
	padding-top: 20px;
}

div#addressLayer > div {
	width: 100%;
	float: none;
	text-align: center;
}

div#addressLayer > div:last-child { padding: 20px 0; }

div#addressLayer div img { margin: 0 5px; }

div#imprintLayer {
	position: relative;
	right: auto;
	margin-right: 0;
	left: 0;
	top: 0;
	width: 100%;
	text-align: center;
	padding-bottom: 20px;
}

/* CONTENT: RENTAL QUESTIONS */

div#rentalQuestionsWrapper {
	width: 100%;
	left: 0;
	border-top: 2px solid #231f20;
}

div#rentalQuestionsWrapper div.item {
	float: none;
	width: 100%;
	padding-left: 0;
}

div#rentalQuestionsWrapper div.item div.question {
	padding: 10px 0;
	border-top-width: 1px;
}

div#rentalQuestionsWrapper div.result {
	width: 100%;
	left: 0;
	border-top: 1px solid #231f20;
}

/*****************************************************************************/
}

@media only screen and (max-width: 679px) {
/*****************************************************************************/

/* HEADER */

div#navigationLayer div.sub { top: 172px; }

div#navigationLayer a,
div#navigationLayer a:link,
div#navigationLayer a:visited {
	font-size: 24px;
	line-height: 1em;
	padding: 12px 6px;
}

/* CONTENT */

div#mainWrapper { padding-top: 170px; }

/* CONTENT: COLLAPSIBLE */

div.collapsible.references div.content { padding-right: 20px; }
div.collapsible.references div.content div.portrait {
	position: relative;
	right: auto;
	left: 0;
}

/*****************************************************************************/
}

@media only screen and (max-width: 479px) {
/*****************************************************************************/

/* CALCULATOR */

div#calcWrapper div#calcQuestionsWrapper div.section div.input input,
div#calcWrapper div#calcQuestionsWrapper div.section div.input select {
	max-width: 140px;
}

/*****************************************************************************/
}

@media only screen and (max-width: 413px) {
/*****************************************************************************/

/* HEADER */

div#navigationLayer div.sub { top: 164px; }

div#navigationLayer a,
div#navigationLayer a:link,
div#navigationLayer a:visited {
	font-size: 18px;
	line-height: 1em;
}

/* PEOPLE */

div.vCardsWrapper > div.item > div.subcolumnsWrapper > div.left,
div.contactPeopleWrapper > div.item > div.subcolumnsWrapper > div.left {
	width: calc(100% - 90px);
	padding-top: 5px;
}

div.vCardsWrapper > div.item > div.subcolumnsWrapper > div.right,
div.contactPeopleWrapper > div.item > div.subcolumnsWrapper > div.right {
	width: 90px;
}

div.vCardsWrapper > div.item > div.subcolumnsWrapper > div.right > img,
div.contactPeopleWrapper > div.item > div.subcolumnsWrapper > div.right > img {
	width: 80px;
	height: 80px;
	-webkit-border-radius: 40px;
	   -moz-border-radius: 40px;
	        border-radius: 40px;
}

/* CALCULATOR */

div#calcWrapper > div#calcQuestionsWrapper {
	height: auto;
	padding-bottom: 40px;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.button,
div#calcWrapper div#calcQuestionsWrapper div.section div.buttonBack {
	bottom: -30px;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.input {
	margin-bottom: 20px;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.input label {
	display: block;
	width: 100%;
}

div#calcWrapper div#calcQuestionsWrapper div.section div.input input,
div#calcWrapper div#calcQuestionsWrapper div.section div.input select {
	display: inline-block;
	float: none;
	width: 80%;
	max-width: none;
}

/*****************************************************************************/
}

