/*! 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; }
@media only screen {
/*****************************************************************************/

/*
COLORS:
_ red: 			#c40c1f
_ blue: 			#155792
_ black (80%): #333
_ black (30%): #b2
*/

/* ==========================================================================
   basics
   ========================================================================== */

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

html, body {
	position: absolute;
	min-width: 100%;
	min-height: 100%;
}

body {
	background-color: #fff;
	font-size: 0;
	line-height: 0;
	color: #333;
	-moz-font-feature-settings: "liga=0";
	-moz-font-feature-settings: "liga" 0;
	-webkit-font-variant-ligatures: no-common-ligatures;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

* {
	font-family: Geneva, Verdana, sans-serif;
	font-size: 100%;
	padding: 0;
	margin: 0;
}

div, ul, ul li, ul li a, ol, ol li, ol li a, figure, figure figcaption, iframe, form, label, select, input, textarea {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

/* ==========================================================================
   layers
   ========================================================================== */

/* PAGE AND LAYOUT WRAPPING */

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

div#linkTopLayer {
	position: fixed;
	display: none;
	right: 0;
	bottom: 8px;
	width: 63px;
	height: 63px;
	background: transparent url('../images/main/link-arrow-top-red.png') scroll no-repeat center center;
	background-size: 23px 23px;
	z-index: 141;
}

/* HEADER */

div#headerWrapper {
	position: fixed;
	left: 50%;
	margin-left: -440px;
	top: 0;
	width: 880px;
	height: 137px;
	border-bottom: 1px solid #333;
	background: transparent url('../images/main/bg-white-90p.png') scroll repeat left top;
	z-index: 31;
}

div#logoLayer {
	position: absolute;
	right: -52px;
	bottom: 13px;
	width: 208px;
	height: 82px;
	z-index: 31;
}

div#logoLayer img {
	width: 208px;
	height: 82px;
}

div#jubileeLayer {
	position: absolute;
	left: 0;
	bottom: 16px;
	width: 150px;
	z-index: 31;
}

div#navigationLayer {
	position: absolute;
	left: 50%;
	margin-left: -450px;
	top: 60px;
	width: auto;
	height: auto;
	z-index: 31;
}

div#navigationBackgroundLayer { display: none; }

div#navigationLayer div.line {
	position: absolute;
	display: none;
	left: 11px;
	bottom: 2px;
	width: calc(100% - 20px);
	height: 0;
	border-top: 1px solid #155792;
	z-index: 31;
}
div#navigationLayer li.act div.line { display: block; }

div#navigationLayer div.sub {
	position: absolute;
	display: none;
	left: 9px;
	top: 24px;
	width: auto;
	height: auto;
	padding: 0 5px 0 7px;
	background: transparent url('') scroll no-repeat left top;
	background-size: 5px 21px;
	z-index: 31;
}
div#navigationLayer div.sub.reversed {
	left: auto;
	right: 7px;
	padding: 0 7px 0 5px;
	background-position: right top;
}

.jsOK div#navigationLayer li.act div.sub {
	background-image: url('../images/main/nav-dot.png');
	display: block;
}

div#navigationButtonLayer { display: none; }
div#navigationButtonBackgroundLayer { display: none; }

div#navigationLanguageLayer {
	position: absolute;
	left: 50%;
	margin-left: 288px;
	top: 0;
	width: auto;
	height: auto;
	z-index: 31;
}

/* CONTENT */

div#contentWrapper {
	position: relative;
	width: 100%;
	height: auto;
	text-align: center;
	padding-top: 137px; /* height of headerWrapper */
	z-index: 21;
}

div#contentWrapper div#contentLayer {
	position: relative;
	width: 100%;
	max-width: 880px;
	height: auto;
	margin: auto;
	font-size: 13px;
	line-height: 1.333em;
	text-align: left;
	padding: 0 0 50px 0;
	z-index: 21;
}

div#contentWrapper div#contentLayer p:last-child { margin-bottom: 0; }

div#contentWrapper div#contentLayer div.section {
	position: relative;
	width: 100%;
	height: auto;
	padding: 40px 0 40px 0;
	border-top: 1px solid #155792;
	z-index: 21;
}

div#contentWrapper div#contentLayer div.section:first-child { border: 0; }

div#contentWrapper div#contentLayer div.section div.anchor {
	position: absolute;
	left: 0;
	top: -137px;
	width: 0;
	height: 0;
}

/* FOOTER */

div#footerWrapper {
	position: relative;
	width: 100%;
	height: auto;
	min-height: 150px;
	background: #15558e url('../images/main/bg-footer-shadow.png') scroll repeat-x left top;
	background-size: 1px 10px;
	z-index: 11;
}

div#navigationExtraWrapper {
	position: relative;
	left: 50%;
	margin-left: -440px;
	width: 710px;
	height: auto;
	padding: 30px 0 10px 0;
	z-index: 12;
}

div#navigationExtraWrapper div.item {
	position: relative;
	float: left;
	width: 20%;
	height: auto;
	padding-right: 10px;
}

div#socialmediaLayer {
	position: absolute;
	left: 50%;
	margin-left: 250px;
	bottom: 43px;
	width: auto;
	height: auto;
	z-index: 13;
}

div#sectorsLayer {
	position: absolute;
	right: 50%;
	margin-right: -490px;
	top: 30px;
	width: 209px;
	height: 105px;
	background: transparent url('../images/main/business-sectors_1.png') scroll no-repeat center center;
	background-size: cover;
	z-index: 11;
}

body[data-lngID='2'] div#sectorsLayer { background-image: url('../images/main/business-sectors_2.png'); }

div#curveLayer {
	position: absolute;
	right: 0;
	bottom: 100%;
	margin-bottom: -10px;
	width: 50%;
	height: 344px;
	background: transparent url('../images/main/bg-footer-curve.png') scroll no-repeat 315px top;
	background-size: 500px 344px;
	z-index: 11;
}

div#searchLayer {
	position: absolute;
	left: 0;
	top: 0;
	width: auto;
	height: auto;
	z-index: 13;
	border: 3px solid red;
}

/* HOME */

div#homeButtonsWrapper {
	position: relative;
	width: 896px;
	left: -8px;
	padding: 32px 0 32px 0;
}

div#homeButtonsWrapper div.item {
	position: relative;
	float: left;
	border: 8px solid #fff;
	background-color: #155792;
	overflow: hidden;
}

div#homeButtonsWrapper div.button25 { width: 25.00000%; padding-bottom: 6%; }
.jsOK div#homeButtonsWrapper div.button25:hover { background-color: #c40c1f; }
div#homeButtonsWrapper div.button33 { width: 33.33333%; padding-bottom: 32.5%; }
.jsOK div#homeButtonsWrapper div.button33:hover div.pict img { opacity: 0.25; }
div#homeButtonsWrapper div.button33-2 { width: 33.33333%; padding-bottom: 10%; }
.jsOK div#homeButtonsWrapper div.button33-2:hover div.pict img { opacity: 0.25; }
div#homeButtonsWrapper div.button33-3 { width: 33.33333%; padding-bottom: 15.5%; }
.jsOK div#homeButtonsWrapper div.button33-3:hover div.pict img { opacity: 0.25; }
div#homeButtonsWrapper div.button50 { width: 50.00000%; padding-bottom: 16%; }
.jsOK div#homeButtonsWrapper div.button50:hover div.pict img { opacity: 0.25; }

div#homeButtonsWrapper div.item.news {
	width: 66.66666%;
	background-color: transparent;
}

div#homeButtonsWrapper div.item.news span {
	display: block;
	margin-bottom: 5px;
}

div#homeButtonsWrapper div.item div {
	position: absolute;
	left: 0;
	width: 100%;
}

div#homeButtonsWrapper div.item div.pict {
	top: 0;
	height: 100%;
	background-color: #333;
	overflow: hidden;
}

div#homeButtonsWrapper div.item div.pict img {
	width: 100%;
	height: 100%;
}

div#homeButtonsWrapper div.item div.text {
	bottom: 0;
	height: auto;
	padding: 10px;
	font-size: 16px;
	line-height: 1em;
	text-align: center;
	text-transform: uppercase;
	color: #155792;
	background: transparent url('../images/main/bg-white-70p.png') scroll repeat left top;
}

div#homeButtonsWrapper div.button25 div.text { color: #fff; background-image: none; }
div#homeButtonsWrapper div.button33 div.text,
div#homeButtonsWrapper div.button50 div.text { font-size: 21px; line-height: 1em; }
div#homeButtonsWrapper div.button33-3 div.text { padding: 6px 10px; }

/* TEXT-PICT */

div.pixtWrapper {
	position: relative;
	width: 100%;
}

div.pixtWrapper div.pict {
	position: relative;
	float: left;
	width: 432px;
}
div.pixtWrapper div.pict img { width: 100%; height: auto; }
div.pixtWrapper.type2 div.pict { width: 656px; }
div.pixtWrapper.reversed div.pict { float: right; }

div.pixtWrapper div.text {
	position: relative;
	float: right;
	width: 432px;
}
div.pixtWrapper.type2 div.text { width: 208px; }
div.pixtWrapper.reversed div.text { float: left; }

/* INFOGALLERY */

div.infogalleryWrapper {
	position: relative;
	width: 100%;
}

div.infogalleryWrapper div.pictsWrapper {
	position: relative;
	float: left;
	width: 448px;
}
div.infogalleryWrapper.reversed div.pictsWrapper { float: right; }

div.infogalleryWrapper div.pictsWrapper div {
	font-size: 0;
	line-height: 0;
}

div.infogalleryWrapper div.pictsWrapper div.pict {
	position: relative;
	width: 100%;
	padding: 0 16px 16px 0;
}
div.infogalleryWrapper.reversed div.pictsWrapper div.pict { padding: 0 0 16px 16px; }

div.infogalleryWrapper div.pictsWrapper div.pict img {
	width: 100%;
	height: auto;
}

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper {
	position: relative;
	width: 100%;
}

.jsNO div.infogalleryWrapper div.pictsWrapper div.previewsWrapper { display: none; }

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper div.item {
	position: relative;
	float: left;
	width: 25%;
	/*padding: 0 16px 16px 0;*/
	border: 16px solid #fff;
	border-width: 0 16px 16px 0;
	background-color: #333;
}
div.infogalleryWrapper.reversed div.pictsWrapper div.previewsWrapper div.item { border-width: 0 0 16px 16px; }

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper div.item img {
	width: 100%;
	height: auto;
	opacity: 0.25;
}
div.infogalleryWrapper div.pictsWrapper div.previewsWrapper div.item img:hover { opacity: 0.5; }

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper div.item.act img { opacity: 1; }

div.infogalleryWrapper div.textWrapper {
	position: relative;
	float: right;
	width: 432px;
}
div.infogalleryWrapper.reversed div.textWrapper { float: left; }

div.infogalleryWrapper div.textWrapper div.infoWrapper,
div.infogalleryWrapper div.textWrapper div.infoWrapper div.item,
div.infogalleryWrapper div.textWrapper div.infoWrapper div.item div.content {
	position: relative;
	width: 100%;
}

div.infogalleryWrapper div.textWrapper div.infoWrapper div.item { margin-top: 0.667em; }
div.infogalleryWrapper div.textWrapper div.infoWrapper div.item:first-child { margin-top: 0; }

div.infogalleryWrapper div.textWrapper div.infoWrapper div.item h2 {
	display: inline-block;
	padding: 3px 20px 3px 0;
	margin-bottom: 0;
}
div.infogalleryWrapper div.textWrapper div.infoWrapper div.item.open h2 { color: #c40c1f !important; }
.jsOK div.infogalleryWrapper div.textWrapper div.infoWrapper div.item h2 {
	color: #333;
	background: transparent url('../images/main/link-arrow-down-red.png') scroll no-repeat right center;
	background-size: 14px 7px;
}
.jsOK div.infogalleryWrapper div.textWrapper div.infoWrapper div.item.open h2 {
	background-image: url('../images/main/link-arrow-up-red.png');
}

div.infogalleryWrapper div.textWrapper div.infoWrapper div.item h2 span.dot { color: #155792; }
div.infogalleryWrapper div.textWrapper div.infoWrapper div.item.open h2 span.dot { color: #c40c1f; }

div.infogalleryWrapper div.textWrapper div.infoWrapper div.item div.content {
	padding-bottom: 2.5em;
	padding-left: 13px;
}

.jsOK div.infogalleryWrapper div.textWrapper div.infoWrapper div.item div.content { display: none; }
.jsOK div.infogalleryWrapper div.textWrapper div.infoWrapper div.item.open div.content { display: block; }

/* COLLAPSABLE LIST */

ul.collapsable li { padding-top: 0.667em; }
ul.collapsable li:first-child { padding-top: 0; }

ul.collapsable ul {
	list-style-type: none;
	list-style-position: inside;
	margin-left: 0;
}

ul.collapsable ul li {
	padding-top: 0;
	padding-left: 12px !important;
	background: transparent url('../images/main/list-dot.png') scroll no-repeat left 7px !important;
	background-size: 5px 5px !important;
}

ul.collapsable li h2 {
	display: inline-block;
	padding: 3px 20px 3px 0;
	margin-bottom: 0;
}
ul.collapsable.downloads li h2,
ul.collapsable.news li h2 { margin-bottom: 5px; }
/*ul.collapsable.downloads li h2 { color: #155792 !important; }*/
ul.collapsable li.open h2 { color: #c40c1f !important; }
.jsOK ul.collapsable li h2 {
	color: #333;
	background: transparent url('../images/main/link-arrow-down-red.png') scroll no-repeat right center;
	background-size: 14px 7px;
}
.jsOK ul.collapsable li.open h2 {
	background-image: url('../images/main/link-arrow-up-red.png');
}

ul.collapsable li h2 span.dot { color: #155792; }
ul.collapsable li.open h2 span.dot { color: #c40c1f; }

ul.collapsable li div.content { padding-bottom: 2.5em; }
ul.collapsable li:last-child div.content { padding-bottom: 0; }

ul.collapsable.indent li div.content { padding-left: 13px; }
ul.collapsable.downloads li div.content,
ul.collapsable.people li div.content {
	padding-top: 1.333em;
	padding-bottom: 1.333em;
}
ul.collapsable.downloads li div.content { padding-bottom: 0; }
.jsOK ul.collapsable li div.content { display: none; }
.jsOK ul.collapsable li.open div.content { display: block; }

ul.collapsable.people li div.content div.personWrapper {
	position: relative;
	width: 100%;
	margin-bottom: 16px;
}

ul.collapsable.people li div.content div.personWrapper div {
	position: relative;
	display: inline-block;
	vertical-align: bottom;
}

ul.collapsable.people li div.content div.personWrapper div.personPict { width: 51.852%; padding-right: 16px; font-size: 0; line-height: 0; }
ul.collapsable.people li div.content div.personWrapper div.personText { width: 48.148%; padding-bottom: 16px; }

ul.collapsable.downloads li div.content div,
ul.collapsable.news li div.content div {
	position: relative;
}

ul.collapsable.news li div.content div.pict {
	position: relative;
	float: left;
	width: 208px;
	padding-top: 3px;
}

ul.collapsable.news li div.content div.pict img {
	width: 100%;
	height: auto;
}

ul.collapsable.news li div.content div.text {
	float: right;
	width: 656px;
}

ul.collapsable.downloads li div.content {
	width: calc(100% + 16px);
	min-width: 100%;
}

ul.collapsable.downloads li div.content div.item {
	float: left;
	width: 25%;
	padding-right: 16px;
	margin-bottom: 24px;
}

ul.collapsable.downloads li div.content div.item div.pict { border: 1px solid #ccc; }
ul.collapsable.downloads li div.content div.item:hover div.pict img { opacity: 0.25; }
ul.collapsable.downloads li div.content div.item:hover div.text { color: #c40c1f; }

ul.collapsable.downloads li div.content div.item div.pict {
	width: 100%;
	height: 0;
	padding-bottom: 70.192%;
	background-color: #333;
	margin-bottom: 5px;
}

ul.collapsable.downloads li.portrait div.content div.item div.pict {
	width: 70.192%;
	padding-bottom: 100%;
}

ul.collapsable.downloads li div.content div.item div.text {
	position: relative;
	width: 100%;
	height: 40px;
}

ul.collapsable.downloads li div.content div.item div.button {
	position: absolute;
	left: 0;
	top: 0;
	width: calc(100% - 16px);
	height: 100%;
}

ul.collapsable.downloads li div.content div.item div.button img {
	width: 100%;
	height: 100%;
}

/* NEWS ARCHIVE */

div.newsArchiveWrapper,
div.newsArchiveWrapper > div.item {
	position: relative;
	width: 100%;
}

.jsNO div.newsArchiveWrapper { display: none; }

div.newsArchiveWrapper > div.item > h1 {
	display: inline-block;
	padding-right: 20px;
	background: transparent url('../images/main/link-arrow-down-red.png') scroll no-repeat right center;
	background-size: 14px 7px;
}

div.newsArchiveWrapper > div.item.open > h1 {
	background-image: url('../images/main/link-arrow-up-red.png');
}

div.newsArchiveWrapper > div.item > ul { display: none; }
div.newsArchiveWrapper > div.item.open > ul { display: block; }

/* PROJECTS */

div.projectsSelection {
	position: relative;
	width: 100%;
	height: auto;
	display: none;
}
.jsOK div.projectsSelection { display: block; }

div.projectsSelection div {
	position: relative;
	float: left;
	white-space: nowrap;
	width: 37.27273%;
	font-size: 16px;
	line-height: 1.333em;
	color: #155792;
	text-transform: uppercase;
}

div.projectsSelection div.title { width: 25.45455%; }

div.projectsSelection div.caption {
	font-size: 13px;
	line-height: 1.333em;
	text-align: right;
}
.jsOK div.projectsSelection div.caption { display: none; }

div.projectsSelection div.caption span {
	margin-left: 20px;
	padding-left: 14px;
	background: transparent url('../images/main/project-dot-1.png') scroll no-repeat left center;
	background-size: 9px 9px;
}
div.projectsSelection div.caption span.dot2 { background-image: url('../images/main/project-dot-2.png'); }

div.projectsSelection form { display: inline-block; }
div.projectsSelection form select { width: 220px; }

/* TABLE PROJECTS and JOBS */

table.presse,
table.messen,
table.jobs,
table.jobs2,
table.projects {
	width: 100%;
	margin-top: 30px;
}
table.presse,
table.messen,
table.jobs,
table.jobs2 { margin-top: 1.333em; }

.jsOK table.projects tbody tr { display: none; }

table.presse thead tr th,
table.messen thead tr th,
table.jobs thead tr th,
table.jobs2 thead tr th,
table.projects thead tr th {
	color: #155792;
	font-weight: normal;
	text-transform: uppercase;
	text-align: left;
	border: 0 !important;
}
table.presse thead tr th.col1 { width: 24.09091%; }
table.presse thead tr th.col2 { width: 24.09091%; }
table.presse thead tr th.col3 { width: 41,81818%; }
table.presse thead tr th.col4 { width: 10%; text-align: center; }
table.presse tbody tr td.col4 { text-align: center; }
table.messen thead tr th.col1 { width: 24.09091%; }
table.messen thead tr th.col2 { width: 24.09091%; }
table.messen thead tr th.col3 { width: 41,81818%; }
table.messen thead tr th.col4 { width: 10%; text-align: center; }
table.messen tbody tr td.col4 { text-align: center; }
table.jobs thead tr th.col1 { width: 24.09091%; }
table.jobs thead tr th.col2 { width: 24.09091%; }
table.jobs thead tr th.col3 { width: 24.09091%; }
table.jobs thead tr th.col4 { width: 17.72727%; }
table.jobs thead tr th.col5 { width: 10%; text-align: center; }
table.jobs tbody tr td.col1,
table.jobs tbody tr td.col2,
table.jobs tbody tr td.col3 { padding-right: 16px; }
table.jobs tbody tr td.col5 { text-align: center; }
table.jobs2 thead tr th.col1 { width: 24.09091%; }
table.jobs2 thead tr th.col2 { width: 65.90909%; }
table.jobs2 thead tr th.col3 { width: 10%; text-align: center; }
table.jobs2 tbody tr td.col2 { padding-right: 16px; }
table.jobs2 tbody tr td.col3 { text-align: center; }
table.projects thead tr th.col1 { width: 25.45455%; }
table.projects thead tr th.col2 { width: 25.45455%; }
table.projects thead tr th.col3 { width: 41.13636%; }
table.projects thead tr th.col4 { width: 4.54545%; }
table.projects thead tr th.col5 { width: 3.40909%; }

table.presse tr th,
table.presse tr td,
table.messen tr th,
table.messen tr td,
table.jobs tr th,
table.jobs tr td,
table.jobs2 tr th,
table.jobs2 tr td,
table.projects tr th,
table.projects tr td {
	vertical-align: top;
	padding: 20px 0;
	border-top: 1px solid #b2b2b2;
}
table.projects tr td.col1 { padding-right: 16px; }
table.projects tr td.col2 { padding-right: 16px; }
table.projects tr td.col3 { padding-right: 16px; }

table tr td.download img,
table tr td.upload img {
	width: 15px;
	height: 12px;
}

/*
table.jobs tr td.download img,
table.jobs2 tr td.download img {
	width: 15px;
	height: 12px;
}
*/

table.projects tr td.dot {
	background: transparent url('../images/main/project-dot-1.png') scroll no-repeat center 26px;
	background-size: 9px 9px;
}
table.projects tr td.dot2 { background-image: url('../images/main/project-dot-2.png'); }

/* PROJECTS PHOTOSWIPE GALLERY */

.pswpGallery {
	position: relative;
	left: 0;
	top: 0;
	width: 30px;
	height: 20px;
	/*overflow: hidden;*/
}

.pswpGallery figure {
	position: absolute;
	display: block;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	font-size: 0;
	line-height: 0;
	z-index: 21;
}
.pswpGallery figure.first { z-index: 22; }
.pswpGallery figure a {
	display: block;
	width: 100%;
	height: 100%;
	background: transparent url('../images/main/project-pict.png') scroll no-repeat center center;
	background-size: 30px 20px;
}
.pswpGallery figure a img {
	width: 100%;
	height: 100%;
	opacity: 0.01;
}
.pswpGallery figure figcaption { display: none; }

.pswpGallery.news {
	width: 100%;
	height: auto;
}
.pswpGallery.news figure.first { position: relative; }
.pswpGallery.news figure a { background: none !important; }
.pswpGallery.news figure a img { opacity: 1; }

/* ETC */

div.tableWrapper {
	position: relative;
	width: auto;
	height: auto;
	overflow-x: auto;
}

.textColorRed,
.textColorRed a,
.textColorRed a:link { color: #c40c1f !important; }
.textColorBlue,
.textColorBlue a,
.textColorBlue a:link { color: #155792 !important; }
.textColorBlack,
.textColorBlack a,
.textColorBlack a:link { color: #000 !important; }

/* GALLERY (30 years) */

ul.galleryCols2 {
	position: relative;
	width: calc(100% + 20px);
	left: -20px;
	height: auto;
	list-style-type: none !important;
	list-style-position: outside !important;
	margin-left: 0 !important;
}

ul.galleryCols2 > li {
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: calc(100% / 2 - 20px);
	margin-left: 20px;
	margin-top: 20px;
}

ul.galleryCols2 > li img {
	width: 100%;
}

/* ==========================================================================
   headlines
   ========================================================================== */

h1, h2, h3 {
	font-size: 16px;
	font-weight: normal;
	line-height: 1.1em;
	color: #155792;
	margin: 0 0 1em 0;
	text-transform: uppercase;
}

h2 {
	font-size: 13px;
	line-height: 1em;
	/*color: #c40c1f;*/
}

/* ==========================================================================
   links
   ========================================================================== */

a, a:link, a:visited { color: #155792; text-decoration: none; }
a:hover, a:active, a:visited:hover, a:visited:active { color: #c40c1f; }

a.download {
	padding-left: 22px;
	background: transparent url('../images/main/link-download-blue.png') scroll no-repeat left center;
	background-size: 15px 12px;
}
a.download:hover { background-image: url('../images/main/link-download-red.png'); }

div#homeButtonsWrapper a, div#homeButtonsWrapper a:link, div#homeButtonsWrapper a:visited { color: #155792; text-decoration: none; }
div#homeButtonsWrapper a:hover, div#homeButtonsWrapper a:active, div#homeButtonsWrapper a:visited:hover, div#homeButtonsWrapper a:visited:active { color: #c40c1f; }

div#navigationLayer a,
div#navigationLayer a:link,
div#navigationLayer a:visited {
	display: block;
	float: left;
	width: auto;
	height: 27px;
	font-size: 16px;
	font-weight: normal;
	color: #155792;
	line-height: 1em;
	letter-spacing: 0;
	text-decoration: none !important;
	text-transform: uppercase;
	padding: 5px 10px;
}
div#navigationLayer a:hover,
div#navigationLayer a:active,
div#navigationLayer a:visited:hover,
div#navigationLayer a:visited:active { color: #c40c1f !important; }
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: #c40c1f !important; }

div#navigationLayer div.sub a,
div#navigationLayer div.sub a:link,
div#navigationLayer div.sub a:visited {
	height: auto;
	font-size: 13px;
	color: #333 !important;
	line-height: 1em;
	text-transform: none;
	padding: 12px 5px;
}
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 { color: #c40c1f !important; }
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 { color: #c40c1f !important; }

div#navigationLanguageLayer a,
div#navigationLanguageLayer a:link,
div#navigationLanguageLayer a:visited {
	display: block;
	float: left;
	width: auto;
	font-size: 12px;
	font-weight: normal;
	color: #155792;
	line-height: 1em;
	letter-spacing: 0;
	text-decoration: none !important;
	text-transform: uppercase;
	padding: 5px 3px;
}
div#navigationLanguageLayer a:hover,
div#navigationLanguageLayer a:active,
div#navigationLanguageLayer a:visited:hover,
div#navigationLanguageLayer a:visited:active { color: #c40c1f !important; }
div#navigationLanguageLayer li.act a,
div#navigationLanguageLayer li.act a:link,
div#navigationLanguageLayer li.act a:visited,
div#navigationLanguageLayer li.act a:hover,
div#navigationLanguageLayer li.act a:active,
div#navigationLanguageLayer li.act a:visited:hover,
div#navigationLanguageLayer li.act a:visited:active { color: #c40c1f !important; }

div#navigationExtraWrapper a,
div#navigationExtraWrapper a:link,
div#navigationExtraWrapper a:visited {
	display: inline-block;
	width: auto;
	font-size: 13px;
	font-weight: normal;
	color: #fff;
	line-height: 1.333em;
	letter-spacing: 0;
	text-decoration: none !important;
	text-transform: none;
}
div#navigationExtraWrapper a:hover,
div#navigationExtraWrapper a:active,
div#navigationExtraWrapper a:visited:hover,
div#navigationExtraWrapper a:visited:active { color: #c40c1f !important; }

div#navigationExtraWrapper ul li.title a,
div#navigationExtraWrapper ul li.title a:link,
div#navigationExtraWrapper ul li.title a:visited { text-transform: uppercase; }

/* ==========================================================================
   lists
   ========================================================================== */

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

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

div#contentLayer ul {
	list-style-type: none;
	list-style-position: inside;
	margin-left: 0;
}

div#contentLayer ul li {
	padding-left: 12px;
	background: transparent url('../images/main/list-dot.png') scroll no-repeat left 7px;
	background-size: 5px 5px;
	padding-bottom: 0;
}

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

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

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

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

/* LIST NAVIGATION HORIZONTAL */

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

div#navigationLayer ul { z-index: 31; }

div#socialmediaLayer ul li,
div#navigationLanguageLayer ul li,
div#navigationLayer ul li {
	position: relative;
	float: left;
	display: inline-block;
}

div#socialmediaLayer ul li { padding: 0 5px; }
div#socialmediaLayer ul li img { width: 25px; height: 25px; }

/* LIST NAVIGATION VERTICAL */

div#navigationExtraWrapper ul {
	width: 100%;
	list-style-type: none;
	list-style-position: outside;
	margin: 0;
	margin-bottom: 20px;
}

div#navigationExtraWrapper ul li {
	width: 100%;
	margin: 0;
}

div#navigationExtraWrapper ul li.title { padding-bottom: 5px; }

/* WRAPPING VIDEO */

.videoWrapper {
	position: relative;
	width: 100%;
	/*
	height: 0;
	padding-bottom: 56.25%;
	margin-bottom: 0;
	overflow: hidden;
	*/
	font-size: 0;
	line-height: 0;
}

/*.jsNO .videoWrapper {
	display: none;
}*/

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

.videoWrapper > div.pict {
	position: relative;
	width: 100%;
	z-index: 1;
}

.videoWrapper > div.pict figure,
.videoWrapper > div.pict picture,
.videoWrapper > div.pict img {
	width: 100%;
	margin: 0;
	padding: 0;
}

.videoWrapper > div.button {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: fit-content;
	z-index: 2;
}

.videoWrapper > div.button a {
	position: relative;
	display: block;
	width: fit-content;
	z-index: 3;
}

.videoWrapper > div.button img {
	width: 80px;
}

.videoWrapper > div.button::after {
	content: '';
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 40px;
	height: 40px;
	background-color: #fff;
	z-index: -1;
}

/* ==========================================================================
   basic configuration
   ========================================================================== */

.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; }
.noWrap { white-space: nowrap; }
.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: 2.5em;
	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: bold; 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 { margin: 0 0 1.333em 0; }
.p { margin: 0 0 1.333em 0; }
.first { margin-top: 0em; }
p.listTitle { font-weight: normal; margin-bottom: 5px; }
p.pict, p.pict img { font-size: 0; line-height: 0; margin: 0; padding: 0; }

table {
	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-weight: bold; }
em, i { font-style: italic; }

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 {
	position: relative;
	height: 0;
	font-size: 75%;
	line-height: 1;
	vertical-align: baseline;
}
sup { bottom: 1ex; }
sub { top: .5ex; }

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

/* ==========================================================================
   (sub)columns
   ========================================================================== */

.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;
}

.subcolumns {
	width: 100%;
	overflow: hidden;
	margin-top: 0;
	margin-bottom: 0;
}

.subcolumns,
.subcolumns div,
.subcolumns div div,
.subcolumns div div div,
.subcolumns div div div div { position: relative; }

.subcolumns div p:last-child,
.subcolumns div div p:last-child { margin-bottom: 0; }
.subcolumns .left { float: left; }
.subcolumns .center { float: left; }
.subcolumns .right { float: right; }

.subcolumns .c20 { width: 19.999%; }
.subcolumns .c25 { width: 24.999%; }
.subcolumns .c30 { width: 29.999%; }
.subcolumns .c33 { width: 33.333%; }
.subcolumns .c35 { width: 34.999%; }
.subcolumns .c38 { width: 37.999%; }
.subcolumns .c40 { width: 39.999%; }
.subcolumns .c45 { width: 44.999%; }
.subcolumns .c50 { width: 49.999%; }
.subcolumns .c55 { width: 54.999%; }
.subcolumns .c60 { width: 59.999%; }
.subcolumns .c62 { width: 61.999%; }
.subcolumns .c65 { width: 64.999%; }
.subcolumns .c66 { width: 66.666%; }
.subcolumns .c70 { width: 69.999%; }
.subcolumns .c75 { width: 74.999%; }
.subcolumns .c80 { width: 79.999%; }

.subcolumns .left .sub { padding: 0 20px 0 0; }
.subcolumns .center .sub { padding: 0 10px; }
.subcolumns .right .sub { padding: 0 0 0 20px; }

.subcolumns img {
	width: 100%;
	height: auto;
	/*margin-top: 5px;*/
}

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

div#jubileeLayer {
	left: 50%;
	margin-left: -440px;
	bottom: auto;
	top: 5px;
	width: 80px;
}

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

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

div#jubileeLayer {
	left: 60px;
	margin-left: 0;
}

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

@media only screen and (min-width: 1630px) {
/*****************************************************************************/

div#curveLayer { background-position: right top; }

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

@media only screen and (min-width: 1500px) {
/*****************************************************************************/

/* HEADER */

div#headerWrapper {
	margin-left: -670px;
	width: 1340px;
}

div#navigationLanguageLayer {
	left: 100%;
	margin-left: -153px;
}

/* FOOTER */

div#sectorsLayer { margin-right: -720px; }

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

@media only screen and (min-width: 1040px) and (max-width: 1499px) {
/*****************************************************************************/

/* HEADER */

div#headerWrapper {
	margin-left: calc(-50% + 80px);
	width: calc(100% - 160px);
}

div#navigationLanguageLayer {
	left: 100%;
	margin-left: -153px;
}

/* FOOTER */

div#sectorsLayer { margin-right: calc(-50% + 30px); }

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

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

/* FOOTER */
div#socialmediaLayer {
	left: auto;
	right: 5px;
	margin-left: 0;
	bottom: auto;
	top: 0;
}

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

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

/* HEADER */

div#headerWrapper {
	position: relative;
	left: 0;
	margin-left: 0;
	width: 100%;
	height: auto;
	background: none;
	background-color: #fff;
}

div#logoLayer {
	position: relative;
	right: auto;
	left: 0;
	bottom: auto;
	top: 0;
	width: 100%;
	height: auto;
	padding: 13px 20px 13px 0;
	text-align: right;
}

div#navigationLayer {
	position: relative;
	left: 0;
	margin-left: 0;
	top: 0;
	width: 100%;
	padding: 20px 10px;
	background-color: #ededed;
	border-top: 1px solid #333;
}

.jsOK div#navigationLayer {
	position: fixed;
	display: none;
	width: auto;
	height: auto;
	min-height: 100%;
	padding: 72px 10px 20px 10px;
	/*background: transparent url('../images/main/bg-white-90p.png') scroll repeat left top;*/
	background-color: transparent;
	border-top: 0;
}

div#navigationBackgroundLayer {
	position: absolute;
	display: block;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: #fff;
	opacity: 0.7;
	z-index: 30;
}

div#navigationLayer div.line { display: none !important; }

div#navigationLayer div.sub {
	position: relative;
	left: 0;
	top: 0;
	padding: 4px 0 16px 0;
	background: none !important;
}

div#navigationLayer div.sub.reversed {
	right: auto;
	left: 0;
	padding: 4px 0 16px 0;
}

div#navigationLayer ul li {
	float: none;
	display: block;
}

div#navigationLayer a,
div#navigationLayer a:link,
div#navigationLayer a:visited {
	float: none;
	width: 100%;
	height: auto;
	line-height: 1em;
	padding: 4px 7px;
}

div#navigationLayer div.sub a,
div#navigationLayer div.sub a:link,
div#navigationLayer div.sub a:visited {
	padding: 6px 7px;
}

div#navigationButtonLayer {
	position: fixed;
	display: block;
	left: -2px;
	top: 15px;
	width: 60px;
	height: 60px;
	background: transparent url('../images/main/nav-button-open-red.png') scroll no-repeat center center;
	background-size: 23px 23px;
	z-index: 33;
}
/*div#navigationButtonLayer:hover { background-image: url('../images/main/nav-button-open-red.png'); }*/
div#navigationButtonLayer.open { background-image: url('../images/main/nav-button-close-red.png'); }
/*div#navigationButtonLayer.open:hover { background-image: url('../images/main/nav-button-close-red.png'); }*/

div#navigationButtonBackgroundLayer {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 80px;
	background-color: #fff;
	opacity: 0.7;
	z-index: 30;
}

/* CONTENT */

div#contentWrapper { padding-top: 0; }

div#contentWrapper div#contentLayer div.section.paddingMobile { padding-left: 16px; padding-right: 16px; }

div#contentWrapper div#contentLayer div.section div.anchor { top: -81px; }
div#contentWrapper div#contentLayer div.section:first-child div.anchor { top: -500px; }

div#navigationLanguageLayer {
	left: 11px;
	margin-left: 0;
}

/* FOOTER */

div#socialmediaLayer { top: 10px; }

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

div#curveLayer {
	display: none;
	background-image: none;
}

/* HOME */

div#homeButtonsWrapper {
	width: 100%;
	left: 0;
	padding: 32px 8px;
}

/* TEXT-PICT */

div.pixtWrapper div.pict { width: 50%; padding-right: 8px;  }
div.pixtWrapper.reversed div.pict { padding-right: 0; padding-left: 8px; }
div.pixtWrapper.type2 div.pict { width: 66.667%; }

div.pixtWrapper div.text { width: 50%; padding-left: 8px; padding-right: 8px; }
div.pixtWrapper.reversed div.text { padding-left: 16px; }
div.pixtWrapper.type2 div.text { width: 33.333%; }

/* INFOGALLERY */

div.infogalleryWrapper div.pictsWrapper { width: 50%; padding-right: 8px; }
div.infogalleryWrapper.reversed div.pictsWrapper { padding-right: 0; padding-left: 8px; }

div.infogalleryWrapper div.pictsWrapper div.pict { padding: 0 0 8px 0; }
div.infogalleryWrapper.reversed div.pictsWrapper div.pict { padding: 0 0 8px 0; }

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper {
	width: 100%;
	width: calc(100% + 8px);
}
div.infogalleryWrapper.reversed div.pictsWrapper div.previewsWrapper { margin-left: -8px; }

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper div.item { border-width: 0 8px 8px 0; }
div.infogalleryWrapper.reversed div.pictsWrapper div.previewsWrapper div.item { border-width: 0 0 8px 8px; }

div.infogalleryWrapper div.textWrapper { width: 50%; padding-left: 8px; padding-right: 8px; }
div.infogalleryWrapper.reversed div.textWrapper { padding-left: 16px; padding-right: 8px; }

/* COLLAPSABLE LIST */

ul.collapsable.news li div.content div.pict { width: 33.333%; }
ul.collapsable.news li div.content div.text { width: 66.667%; padding-left: 16px; }

ul.collapsable.downloads li div.content div.item { width: 33.333%; }

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

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

/* FOOTER */

div#navigationExtraWrapper { display: none; }
div#socialmediaLayer {
	right: auto;
	left: 15px;
	top: 15px;
}

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


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

/* HOME */

div#homeButtonsWrapper div.item.button25 div.text,
div#homeButtonsWrapper div.item.button33-3 div.text { font-size: 12px; line-height: 1em; }

/* PROJECTS */

div.projectsSelection div.caption span {
	padding-left: 0;
	padding-right: 14px;
	margin-left: 0;
	display: block;
	background-position: right center;
}

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

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

/* INFOGALLERY */

div.infogalleryWrapper div.pictsWrapper div.previewsWrapper { display: none; }

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

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

/* HOME */

div#homeButtonsWrapper div.item div.text { font-size: 14px !important; line-height: 1em; }
div#homeButtonsWrapper div.button25 { width: 50%; padding-bottom: 12%; }
div#homeButtonsWrapper div.button33-2 { width: 100%; padding-bottom: 30%; }
div#homeButtonsWrapper div.button33-3 div.text { font-size: 10px !important; line-height: 1em; }
div#homeButtonsWrapper div.item.news { width: 100%; }

/* TEXT-PICT */

div.pixtWrapper div.pict { width: 100%; float: none; padding: 0 16px !important; margin-bottom: 32px; }
div.pixtWrapper.type2 div.pict { width: 100%; }

div.pixtWrapper div.text { width: 100%; float: none; padding: 0 16px !important; }
div.pixtWrapper.type2 div.text { width: 100%; }

/* INFOGALLERY */

div.infogalleryWrapper div.pictsWrapper { width: 100%; float: none; padding: 0 16px !important; margin-bottom: 32px; }
div.infogalleryWrapper div.textWrapper { width: 100%; float: none; padding: 0 16px !important; }

/* COLLAPSABLE LIST */

ul.collapsable.downloads li div.content div.item { width: 50%; }

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

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

/* PROJECTS */

div.projectsSelection div {
	float: none;
	width: 100% !important;
	margin-bottom: 5px;
}

div.projectsSelection div.caption {
	text-align: left;
}

div.projectsSelection div.caption span {
	display: none;
	padding-left: 14px;
	padding-right: 0;
	background-position: left center;
}

/* TABLE PROJECTS and JOBS */

table.messen thead tr,
table.jobs thead tr,
table.jobs2 thead tr,
table.projects thead tr { display: none; }
table.messen td,
table.jobs td,
table.jobs2 td,
table.projects td {
	width: 100% !important;
	padding-right: 0 !important;
	display: block !important;
	padding: 3px 0 !important;
	border: 0 !important;
	text-align: left !important;
}

table.messen td.col1,
table.jobs td.col1,
table.jobs2 td.col1,
table.projects td.col1 {
	text-transform: uppercase;
	color: #c40c1f;
}

table.messen td.col2,
table.jobs td.col2,
table.jobs2 td.col2,
table.projects td.col2 {
	color: #000;
}

table.messen td.col4,
table.jobs td.col5,
table.jobs2 td.col3,
table.projects td.col5 {
	padding-bottom: 24px !important;
}

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

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

/* COLLAPSABLE LIST */

ul.collapsable.news li div.content div.pict { float: none; width: 50%; margin-bottom: 5px; }
ul.collapsable.news li div.content div.text { float: none; width: 100%; padding-left: 0; }

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

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

/* HOME */

div#homeButtonsWrapper div.button25 { width: 100%; padding-bottom: 24%; }
div#homeButtonsWrapper div.button33 { width: 100%; padding-bottom: 100%; }
div#homeButtonsWrapper div.button33-3 { width: 100%; padding-bottom: 46.5%; }
div#homeButtonsWrapper div.button50 { width: 100%; padding-bottom: 34.72222%; }

div#homeButtonsWrapper div.item div.text,
div#homeButtonsWrapper div.button33-3 div.text { font-size: 16px !important; line-height: 1em; }

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

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

/* GENERAL SETTINGS */

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

.w10, .w15, .w20, .w25, .w30, .w33, .w35, .w38, .w40, .w45, .w50, .w55, .w60, .w65, .w66, .w70, .w75, .w80, .w85, .w90 { width: 100% !important; }

.subcolumns .left, .subcolumns .center, .subcolumns .right { float: none; }
.subcolumns div { width: 100% !important; }
.subcolumns .sub { margin: 0 !important; padding: 0 !important; }
.subcolumns .center, .subcolumns .right { padding-top: 0; }

/*****************************************************************************/
}

@media print {
/*****************************************************************************/

/* ==========================================================================
   basics
   ========================================================================== */

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

html, body {
	position: relative;
	min-width: 0;
	min-height: 0;
}

body {
	background-color: #fff;
	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;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

* {
	font-family: Geneva, Verdana, sans-serif;
	font-size: 100%;
	padding: 0;
	margin: 0;
}

div, ul, ul li, ul li a, ol, ol li, ol li a, figure, figure figcaption, iframe, form, label, select, input, textarea {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

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

table {
	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; }

a, a:link, a:visited { color: #000; text-decoration: none; }
a:after, a:link:after, a:visited:after { content:" [" attr(href) "] "; }

table a:after, table a:link:after, table a:visited:after { content:"" !important; }

/* ==========================================================================
   layers
   ========================================================================== */

/* PAGE AND LAYOUT WRAPPING */

div#layoutWrapper {
	position: absolute;
	width: 100%;
	height: auto;
	padding: 30px;
	z-index: 1;
}

div#linkTopLayer { display: none; }

/* HEADER */

div#headerWrapper {
	position: relative;
	width: 100%;
	height: auto;
	border-bottom: 1px solid #333;
}

div#logoLayer {
	position: relative;
	width: 100%;
	height: auto;
	text-align: right;
	padding: 20px 0;
}

div#logoLayer img {
	width: 208px;
	height: 82px;
}

div#navigationLayer { display: none; }
div#navigationBackgroundLayer { display: none; }
div#navigationButtonLayer { display: none; }
div#navigationButtonBackgroundLayer { display: none; }

/* CONTENT */

div#contentWrapper {
	position: relative;
	width: 100%;
	height: auto;
}

div#contentWrapper div#contentLayer {
	position: relative;
	width: 100%;
	height: auto;
	margin: auto;
	font-size: 13px;
	line-height: 1.333em;
	text-align: left;
	padding: 0 0 50px 0;
	z-index: 21;
}

div#contentWrapper div#contentLayer div.section {
	position: relative;
	width: 100%;
	height: auto;
	padding: 40px 0 40px 0;
	border-top: 1px solid #155792;
}

div#contentWrapper div#contentLayer div.section:first-child { border: 0; }

div#navigationLanguageLayer { display: none; }

/* FOOTER */

div#footerWrapper { display: none; }

/* ETC */

div.projectsSelection { display: none; }

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