/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */
/* Document ========================================================================== */ /** * 1. Correct the line height in all browsers. * 2. Prevent adjustments of font size after orientation changes in * IE on Windows Phone and in iOS. */ html { line-height: 1.15; /* 1 */ -ms-text-size-adjust: 100%; /* 2 */ -webkit-text-size-adjust: 100%; /* 2 */ } /* Sections ========================================================================== */ /** * Remove the margin in all browsers (opinionated). */ body { margin: 0; } /** * Add the correct display in IE 9-. */ article, aside, footer, header, nav, section { display: block; } /** * Correct the font size and margin on `h1` elements within `section` and * `article` contexts in Chrome, Firefox, and Safari. */ h1 { font-size: 2em; margin: 0.67em 0; } /* Grouping content ========================================================================== */ /** * Add the correct display in IE 9-. * 1. Add the correct display in IE. */ figcaption, figure, main { /* 1 */ display: block; } /** * Add the correct margin in IE 8. */ figure { margin: 1em 40px; } /** * 1. Add the correct box sizing in Firefox. * 2. Show the overflow in Edge and IE. */ hr { box-sizing: content-box; /* 1 */ height: 0; /* 1 */ overflow: visible; /* 2 */ } /** * 1. Correct the inheritance and scaling of font size in all browsers. * 2. Correct the odd `em` font sizing in all browsers. */ pre { font-family: monospace, monospace; /* 1 */ font-size: 1em; /* 2 */ } /* Text-level semantics ========================================================================== */ /** * 1. Remove the gray background on active links in IE 10. * 2. Remove gaps in links underline in iOS 8+ and Safari 8+. */ a { background-color: transparent; /* 1 */ -webkit-text-decoration-skip: objects; /* 2 */ } /** * 1. Remove the bottom border in Chrome 57- and Firefox 39-. * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. */ abbr[title] { border-bottom: none; /* 1 */ text-decoration: underline; /* 2 */ text-decoration: underline dotted; /* 2 */ } /** * Prevent the duplicate application of `bolder` by the next rule in Safari 6. */ b, strong { font-weight: inherit; } /** * Add the correct font weight in Chrome, Edge, and Safari. */ b, strong { font-weight: bolder; } /** * 1. Correct the inheritance and scaling of font size in all browsers. * 2. Correct the odd `em` font sizing in all browsers. */ code, kbd, samp { font-family: monospace, monospace; /* 1 */ font-size: 1em; /* 2 */ } /** * Add the correct font style in Android 4.3-. */ dfn { font-style: italic; } /** * Add the correct background and color in IE 9-. */ mark { background-color: #ff0; color: #000; } /** * Add the correct font size in all browsers. */ small { font-size: 80%; } /** * Prevent `sub` and `sup` elements from affecting the line height in * all browsers. */ sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } sub { bottom: -0.25em; } sup { top: -0.5em; } /* Embedded content ========================================================================== */ /** * Add the correct display in IE 9-. */ audio, video { display: inline-block; } /** * Add the correct display in iOS 4-7. */ audio:not([controls]) { display: none; height: 0; } /** * Remove the border on images inside links in IE 10-. */ img { border-style: none; } /** * Hide the overflow in IE. */ svg:not(:root) { overflow: hidden; } /* Forms ========================================================================== */ /** * 1. Change the font styles in all browsers (opinionated). * 2. Remove the margin in Firefox and Safari. */ button, input, optgroup, select, textarea { font-family: sans-serif; /* 1 */ font-size: 100%; /* 1 */ line-height: 1.15; /* 1 */ margin: 0; /* 2 */ } /** * Show the overflow in IE. * 1. Show the overflow in Edge. */ button, input { /* 1 */ overflow: visible; } /** * Remove the inheritance of text transform in Edge, Firefox, and IE. * 1. Remove the inheritance of text transform in Firefox. */ button, select { /* 1 */ text-transform: none; } /** * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video` * controls in Android 4. * 2. Correct the inability to style clickable types in iOS and Safari. */ button, html [type="button"], /* 1 */ [type="reset"], [type="submit"] { -webkit-appearance: button; /* 2 */ } /** * Remove the inner border and padding in Firefox. */ button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner { border-style: none; padding: 0; } /** * Restore the focus styles unset by the previous rule. */ button:-moz-focusring, [type="button"]:-moz-focusring, [type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring { outline: 1px dotted ButtonText; } /** * Correct the padding in Firefox. */ fieldset { padding: 0.35em 0.75em 0.625em; } /** * 1. Correct the text wrapping in Edge and IE. * 2. Correct the color inheritance from `fieldset` elements in IE. * 3. Remove the padding so developers are not caught out when they zero out * `fieldset` elements in all browsers. */ legend { box-sizing: border-box; /* 1 */ color: inherit; /* 2 */ display: table; /* 1 */ max-width: 100%; /* 1 */ padding: 0; /* 3 */ white-space: normal; /* 1 */ } /** * 1. Add the correct display in IE 9-. * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera. */ progress { display: inline-block; /* 1 */ vertical-align: baseline; /* 2 */ } /** * Remove the default vertical scrollbar in IE. */ textarea { overflow: auto; } /** * 1. Add the correct box sizing in IE 10-. * 2. Remove the padding in IE 10-. */ [type="checkbox"], [type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ } /** * Correct the cursor style of increment and decrement buttons in Chrome. */ [type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; } /** * 1. Correct the odd appearance in Chrome and Safari. * 2. Correct the outline style in Safari. */ [type="search"] { -webkit-appearance: textfield; /* 1 */ outline-offset: -2px; /* 2 */ } /** * Remove the inner padding and cancel buttons in Chrome and Safari on macOS. */ [type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration { -webkit-appearance: none; } /** * 1. Correct the inability to style clickable types in iOS and Safari. * 2. Change font properties to `inherit` in Safari. */ ::-webkit-file-upload-button { -webkit-appearance: button; /* 1 */ font: inherit; /* 2 */ } /* Interactive ========================================================================== */ /* * Add the correct display in IE 9-. * 1. Add the correct display in Edge, IE, and Firefox. */ details, /* 1 */ menu { display: block; } /* * Add the correct display in all browsers. */ summary { display: list-item; } /* Scripting ========================================================================== */ /** * Add the correct display in IE 9-. */ canvas { display: inline-block; } /** * Add the correct display in IE. */ template { display: none; } /* Hidden ========================================================================== */ /** * Add the correct display in IE 10-. */ [hidden] { display: none; }
@media all {
/*****************************************************************************/

@font-face {
	font-family: 'Flama-Basic-A';
	src: url('../_fonts/Flama-Basic-A.eot'); /* IE9 Compat Modes */
	src: url('../_fonts/Flama-Basic-A.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
		 url('../_fonts/Flama-Basic-A.woff') format('woff'), /* Modern Browsers */
		 url('../_fonts/Flama-Basic-A.ttf') format('truetype'), /* Safari, Android, iOS */
		 url('../_fonts/Flama-Basic-A.svg#svgFontName') format('svg'); /* Legacy iOS */
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Flama-Book-A';
	src: url('../_fonts/Flama-Book-A.eot');
	src: url('../_fonts/Flama-Book-A.eot?#iefix') format('embedded-opentype'),
		 url('../_fonts/Flama-Book-A.woff') format('woff'),
		 url('../_fonts/Flama-Book-A.ttf') format('truetype'),
		 url('../_fonts/Flama-Book-A.svg#svgFontName') format('svg');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Flama-Medium-A';
	src: url('../_fonts/Flama-Medium-A.eot');
	src: url('../_fonts/Flama-Medium-A.eot?#iefix') format('embedded-opentype'),
		 url('../_fonts/Flama-Medium-A.woff') format('woff'),
		 url('../_fonts/Flama-Medium-A.ttf') format('truetype'),
		 url('../_fonts/Flama-Medium-A.svg#svgFontName') format('svg');
	font-weight: normal;
	font-style: normal;
}

/*****************************************************************************/
}

@media only screen {
/*****************************************************************************/

/*
COLORS:
_ gold: #9c8a70

FONTS:
font-family: 'Flama-Book-A', sans-serif;
font-family: 'Flama-Basic-A', sans-serif;
font-family: 'Flama-Medium-A', sans-serif;
font-weight: 400;
*/

/*
FLUID FONT SIZES (https://css-tricks.com/snippets/css/fluid-typography/)
font-size: calc(14px + (26 - 14) * ((100vw - 300px) / (1600 - 300)));
font-size: calc([minimum size] + ([maximum size] - [minimum size]) * ((100vw - [minimum viewport width]) / ([maximum viewport width] - [minimum viewport width])));
... min font size @  300px viewport width: 14px
... max font size @ 1600px viewport width: 26px
*/

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

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

html, body {
	position: absolute;
	min-width: 100%;
	max-width: 100%;
	min-height: 100%;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	overflow-x: hidden;
	z-index: 1;
}

body {
	background-color: #fff;
	font-family: 'Flama-Book-A', sans-serif;
	font-weight: 400;
	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;
	-webkit-font-feature-settings: "salt";
	   -moz-font-feature-settings: "salt";
	    -ms-font-feature-settings: "salt“;
	     -o-font-feature-settings: "salt";
	        font-feature-settings: "salt";
	text-align: center;
}

* {
	-webkit-box-sizing: inherit;
	   -moz-box-sizing: inherit;
	        box-sizing: inherit;
	padding: 0;
	margin: 0;
}

::selection { color: #9c8a70; background-color: #000; }

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

/* HEADER */

header {
	position: relative;
	width: 100%;
	height: auto;
	margin: auto;
	text-align: left;
	z-index: 31;
}

header > div#logoLayer {
	position: relative;
	display: block;
	left: calc(50% - (100% - 300px) / 2 - 103px);
	width: 220px;
	height: 32px;
	margin-top: -3px;
	z-index: 31;
}

header > div#logoLayer img {
	width: 100%;
	height: 100%;
}

header > div#addressLayer {
	position: relative;
	display: none;
	width: auto;
	height: auto;
	font-family: 'Flama-Medium-A', sans-serif;
	font-weight: 400;
	font-size: 17px;
	line-height: 1.5em;
	word-spacing: -0.03em;
	letter-spacing: 0.02em;
	z-index: 31;
}

header > nav#button {
	position: relative;
	display: none;
	left: calc(48px + 103px - 14px);
	top: 0;
	width: auto;
	height: auto;
	z-index: 35;
}

header > nav#main {
	position: relative;
	left: calc(50% - (100% - 300px) / 2 - 14px);
	width: auto;
	max-width: calc(100% - 300px / 2 + 14px);
	height: auto;
	text-align: left;
	z-index: 33;
}

/* MAIN */

main {
	position: relative;
	width: 100%;
	height: auto;
	z-index: 21;
}

main > section {
	position: relative;
	width: auto;
	/*padding-top: 64px;*/
	padding-top: 34px;
	text-align: center;
	z-index: 21;
}

main > section.gallery {
	margin-bottom: 34px;
	margin-bottom: 50px;
	z-index: 22;
}

main > section.projectsList:hover { z-index: 22; }

/*main > section:nth-child(1) { padding-top: 44px; }*/

main > section > div.content {
	position: relative;
	width: calc(100% - 300px);
	max-width: 1600px;
	margin: auto;
	/*font-size: calc(14px + (17 - 14) * ((100vw - 300px) / (1600 - 300)));*/
	font-size: 17px;
	line-height: 1.5em;
	text-align: left;
	word-spacing: -0.03em;
	letter-spacing: 0.02em;
}

main > section > div.content .fontSizeBig,
main > section > div.content .intro {
	font-family: 'Flama-Basic-A', sans-serif;
	/*font-size: calc(20px + (26 - 20) * ((100vw - 300px) / (1600 - 300)));*/
	font-size: 25px;
	line-height: 1.44em;
	letter-spacing: 0.02em;
}

main > section > div.content .intro { margin-bottom: 1em; }

/* FOOTER */

footer {
	position: relative;
	width: calc(100% - 40px);
	height: auto;
	margin: auto;
	border-top: 1px solid #9c8a70;
	margin-top: 64px;
	padding: 20px 0 40px 0;
	z-index: 11;
}

footer > div#infoWrapper {
	position: relative;
	width: calc(100% - 300px + 40px);
	max-width: 1600px;
	height: auto;
	margin: auto;
	font-family: 'Flama-Book-A', sans-serif;
	font-size: 14px;
	line-height: 1.35714em;
	text-align: left;
}

footer > div#infoWrapper > div.subcolumns > div:nth-child(2) { color: #9c8a70; }
footer > div#infoWrapper > div.subcolumns > div:nth-child(4) { text-align: right; }

footer > div#infoWrapper img[src$='.svg'] { width: 100%; max-width: 120px; }

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

/* GALLERY */

div.galleryWrapper {
	position: relative;
	width: 100%;
	height: auto;
	font-size: 0;
	line-height: 0;
	z-index: 21;
}

div.galleryWrapper.descriptionOK { margin-top: 64px; }

div.galleryWrapper > div.itemsWrapper {
	position: relative;
	width: 100%;
	/*width: calc(100% - 150px * 2);*/
	height: auto;
	z-index: 21;
}

div.galleryWrapper > div.itemsWrapper > div {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	text-align: center;
	z-index: 21;
}

div.galleryWrapper > div.itemsWrapper > div:nth-child(1) { position: relative; }
div.galleryWrapper > div.itemsWrapper > div.act { z-index: 22; opacity: 1; }

div.galleryWrapper > div.itemsWrapper > div > div.pict {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	/*width: calc(100% - 150px * 2);*/
	height: 100%;
	margin: auto;
	background: transparent url() scroll no-repeat center center;
	background-size: contain;
}

div.galleryWrapper > div.itemsWrapper > div:nth-child(1) > div.pict {
	position: relative;
	height: auto;
}

div.galleryWrapper > div.itemsWrapper > div:nth-child(1) > div.pict > img {
	/*width: 100%;*/
	width: calc(100% - 150px * 2);
	height: auto;
}

div.galleryWrapper > div.itemsWrapper > div > div.text {
	position: absolute;
	left: 0;
	/* bottom: 100%; */
	top: -64px;
	width: 100%;
	height: auto;
	margin: auto;
	margin-top: -3px;
	padding-bottom: 0;
	font-size: 17px;
	line-height: 1.333em;
	color: #000;
	text-align: center;
}

div.galleryWrapper > div.arrow {
	position: absolute;
	top: 0;
	width: 50%;
	height: 100%;
	z-index: 22;
}

div.galleryWrapper > div.arrowLeft.over {
	cursor: pointer;
	cursor: url('../images/main/gallery-arrow-left.png') 25 12, w-resize;
	cursor: -webkit-image-set(url('../images/main/gallery-arrow-left.png') 1x, url('../images/main/gallery-arrow-left_2x.png') 2x) 25 12, w-resize;
}
div.galleryWrapper > div.arrowRight.over {
	cursor: pointer;
	cursor: url('../images/main/gallery-arrow-right.png') 25 12, e-resize;
	cursor: -webkit-image-set(url('../images/main/gallery-arrow-right.png') 1x, url('../images/main/gallery-arrow-right_2x.png') 2x) 25 12, e-resize;
}

div.galleryWrapper > div.arrow.arrowLeft { left: 0; }
div.galleryWrapper > div.arrow.arrowRight { right: 0; }

div.galleryWrapper > div.dotsWrapper {
	position: absolute;
	left: 0;
	top: 100%;
	width: 100%;
	height: 0;
	text-align: center;
	z-index: 23;
}

div.galleryWrapper > div.dotsWrapper > div {
	position: relative;
	display: inline-block;
	padding: 27px 10px;
	font-size: 15px;
	line-height: 1;
	color: #000;
	transition-duration: 1s;
	transition-property: color;
}

div.galleryWrapper > div.dotsWrapper > div.over,
div.galleryWrapper > div.dotsWrapper > div.act {
	color: #9c8a70;
}

div.galleryWrapper > div.dotsWrapper > div.over { cursor: pointer; }

/* PROJECTS TILES */

div.projectsTilesWrapper {
	position: relative;
	left: 20px;
	width: calc(100% - 20px);
	height: auto;
	text-align: left;
	z-index: 21;
}

div.projectsTilesWrapper > div {
	position: relative;
	display: inline-block;
	width: calc(25% - 20px);
	height: auto;
	margin: 0 20px 20px 0;
	font-size: 0;
	line-height: 0;
	overflow: hidden;
	z-index: 21;
}

div.projectsTilesWrapper > div > div.pict {
	position: relative;
	width: 100%;
	height: auto;
	transform-origin: 50% 50%;
	transform: scale(1.025);
	transition-duration: 0.25s;
	transition-property: transform;
	z-index: 21;
}

div.projectsTilesWrapper > div:hover > div.pict {
	transform: scale(1);
}

div.projectsTilesWrapper > div > div.link {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 22;
}

div.projectsTilesWrapper > div > div.link img {
	width: 100%;
	height: 100%;
}

/* PROJECTS LIST */

ul.projects {
	position: relative;
	display: inline-block;
	width: calc(100% - 40px);
	margin: auto;
	z-index: 21;
}

main > section.gallery > ul.projects { top: 3px; }

ul.projects > li {
	position: relative;
	padding: 7px 0;
	border-bottom: 1px solid #b3b3b3;
	text-align: left;
	z-index: 21;
}

section.gallery > ul.projects > li { padding: 0 0; }

ul.projects > li.over {
	border-bottom-color: #000;
	z-index: 22;
}

ul.projects > li.head,
ul.projects > li:last-child {
	border-bottom: 0;
}

ul.projects > li.pictNO { opacity: 0.5; }

/*section.gallery > ul.projects > li:last-child { border-bottom: 1px solid #b3b3b3 !important; }*/

ul.projects > li > span {
	display: inline-block;
	vertical-align: top;
	text-align: left;
	font-family: 'Flama-Book-A', sans-serif !important;
	font-weight: 400;
	font-size: 17px;
	line-height: 1.1em;
	line-height: 1.333em;
	letter-spacing: 0.04em;
	color: #9c8a70;
}

ul.projects > li.head > span {
	font-family: 'Flama-Medium-A', sans-serif !important;
	font-weight: 400;
	letter-spacing: 0.025em;
}

ul.projects > li > span:nth-child(1) { width: calc(150px - 20px); }
ul.projects > li > span:nth-child(2) { width: calc((100% - 150px - 20px) * 0.275); padding-right: 20px; }
ul.projects > li > span:nth-child(3) { width: calc((100% - 150px - 20px) * 0.275); padding-right: 20px; }
ul.projects > li > span:nth-child(4) { width: calc((100% - 150px - 20px) * 0.275); padding-right: 20px; }
ul.projects > li > span:nth-child(5) { width: calc((100% - 150px - 20px) * 0.175); }

ul.projects > li.over > span,
ul.projects > li.head > span {
	color: #000;
}

ul.projects > li > div.pict {
	position: absolute;
	right: 0;
	width: calc((100% - 150px - 20px) * (0.275 + 0.175) + 40px);
	height: auto;
}

section.projectsList:nth-child(1) > ul.projects > li > div.pict,
section.projectsList:nth-child(2) > ul.projects > li > div.pict { top: calc(100% + 1px); }
section.projectsList:nth-child(3) > ul.projects > li > div.pict,
section.projectsList:nth-child(4) > ul.projects > li > div.pict { bottom: calc(100% + 1px); }

ul.projects.mouseRightOK > li > div.pict {
	right: auto;
	left: 0;
}

ul.projects > li > div.pict > img {
	width: 100%;
	height: auto;
}

/* FIRE and TEAM */

div.fireWrapper,
div.teamWrapper {
	position: relative;
	left: -20px;
	width: calc(100% + 20px);
	margin: 1.5em 0;
}

div.teamWrapper > div,
div.fireWrapper > div {
	position: relative;
	display: inline-block;
	vertical-align: top;
	margin-left: 20px;
	width: calc(20% - 20px);
}

div.fireWrapper > div > p > img {
	width: 100%;
	height: auto;
	margin-bottom: 10px;
}

/* SITEMAP */

nav#sitemap {
	position: relative;
	width: 100%;
}

/* GOOGLE MAPS */

.mapWrapper {
	position: relative;
	width: 100%;
	height: 0;
	padding-bottom: 56.25%; /* 16:9 */
	overflow: hidden;
}

.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-bottom: 56.25%; /* 16:9 */
	padding-top: 0;
	margin-bottom: 1.5em;
	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;
}

.videoWrapper > div.overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	/*background-color: rgba(0, 0, 0, 0.25);*/
	background-color: #9c8a70;
	color: white;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding: 20px;
}

.videoWrapper > div.overlay > p {
	max-width: 60ch;
	margin: 0 auto;
	margin-bottom: 20px;
}

.videoWrapper > div.overlay > p > button {
	margin: 0 5px;
	border: 2px solid #fff;
	padding: 5px 20px;
	color: #fff;
	background-color: #9c8a70;
	font-family: 'Flama-Medium-A', sans-serif;
	font-weight: 400;
}

.videoWrapper > div.overlay > p > button:hover {
	color: #9c8a70;
	background-color: #fff;
	cursor: pointer;
}

.videoWrapper > div.overlay > p a,
.videoWrapper > div.overlay > p a:link,
.videoWrapper > div.overlay > p a:visited {
	color: #fff !important;
}

/* ETC */

.fontColorBlack { color: #000 !important; }
.fontColorGold {
	color: #9c8a70 !important;
	letter-spacing: 0.02em;
}

.jsOK img.grayscale {
	-webkit-filter: grayscale(100%);
	        filter: grayscale(100%);
}

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

h1, h2 {
	font-family: 'Flama-Medium-A', sans-serif;
	font-weight: 400;
	font-size: 34px;
	line-height: 1em;
	margin: 0 0 0.5em 0;
	text-align: left;
	letter-spacing: 0.025em;
}

h2 {
	/*font-family: 'Flama-Basic-A', sans-serif;*/
	/*font-family: 'Flama-Book-A', sans-serif;*/
	font-size: 17px;
	line-height: 1.5em;
	letter-spacing: 0.02em;
	margin-bottom: 1em;
}

h2 > span.fontColorGold {
	font-family: 'Flama-Book-A', sans-serif !important;
	letter-spacing: 0.04em;
}

/*
h1 + h2, p + h2, ul + h2, ol + h2, p + h1, ul + h1, ol + h1 { margin-top: 40px !important; }
h1.displayNO + h2 { margin-top: 0 !important; }
*/

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

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

header > div#addressLayer a,
header > div#addressLayer a:link,
header > div#addressLayer a:visited { color: #000; }

footer a,
footer a:link,
footer a:visited {
	color: #000;
	text-decoration: none;
}
footer a:hover,
footer a:active,
footer a:visited:hover,
footer a:visited:active { color: #9c8a70; text-decoration: none; }

footer > div#infoWrapper > div.subcolumns > div:nth-child(2) > a,
footer > div#infoWrapper > div.subcolumns > div:nth-child(2) > a:link,
footer > div#infoWrapper > div.subcolumns > div:nth-child(2) > a:visited { color: #9c8a70; }

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

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

ul {
	list-style-type: square;
	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; }

/* NO BULLETS */

ul.projects,
ul.bulletsNO,
ul.dotsNO {
	list-style-type: none;
	list-style-position: inside;
	margin-left: 0;
}

ul.projects > li,
ul.bulletsNO > li,
ul.dotsNO > li {
	padding-left: 0 !important;
	background: none !important;
}

/* ==========================================================================
   NAVIGATION
   ========================================================================== */

/* LIST NAVIGATION VERTICAL */

nav#sitemap > ul {
	width: 100%;
	display: inline-block;
	list-style-type: none;
	list-style-position: outside;
	margin: 0;
}

/* LIST NAVIGATION HORIZONTAL */

nav#main > ul {
	width: auto;
	display: inline-block;
	list-style-type: none;
	list-style-position: outside;
	margin: 0;
}

nav#main > ul > li {
	display: inline-block;
	width: auto;
}

nav#button > a,
nav#button > a:link,
nav#button > a:visited,
nav#main > ul > li > a,
nav#main > ul > li > a:link,
nav#main > ul > li > a:visited {
	display: inline-block;
	width: auto;
	font-family: 'Flama-Medium-A', sans-serif;
	font-weight: 400;
	/*font-size: calc(14px + (17 - 14) * ((100vw - 300px) / (1600 - 300)));*/
	font-size: 17px;
	line-height: 1em;
	color: #000;
	letter-spacing: 0.025em;
	text-decoration: none !important;
	text-transform: none;
	padding: 24px 14px;
}
nav#button > a:hover,
nav#button > a:active,
nav#button > a:visited:hover,
nav#button > a:visited:active,
nav#main > ul > li > a:hover,
nav#main > ul > li > a:active,
nav#main > ul > li > a:visited:hover,
nav#main > ul > li > a:visited:active,
nav#main > ul > li.act > a,
nav#main > ul > li.act > a:link,
nav#main > ul > li.act > a:visited,
nav#main > ul > li.act > a:hover,
nav#main > ul > li.act > a:active,
nav#main > ul > li.act > a:visited:hover,
nav#main > ul > li.act > a:visited:active { color: #9c8a70 !important; }

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

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

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

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

main > hr {
	width: 100%;
	height: 0;
	margin: 0 auto;
	border: 0;
	border-top: 1px solid #9c8a70;
	opacity: 0.5;
}

div.distance,
div.space {
	position: relative;
	width: 100%;
	height: 25px;
	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: 600; 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 0.75em 0; }
p.pict { font-size: 0; line-height: 0; margin: 0; padding: 0; }

p:last-child,
ul:last-child,
ol:last-child {
	margin-bottom: 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; }*/

figure, figcaption { display: block; width: 100%; margin: 0; font-size: 0; line-height: 0; }
img { border: 0; height: auto; max-width: 100%; }

strong, b { font-family: 'Flama-Medium-A', sans-serif; font-weight: 400; }
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 {
	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; }

/* ==========================================================================
   SUBCOLUMNS
   ========================================================================== */

div.subcolumns {
	position: relative;
	left: -30px;
	width: calc(100% + 30px);
	height: auto;
	margin-bottom: 1.5em;
	margin-bottom: 0;
}

div.subcolumns > div.col {
	position: relative;
	padding-left: 30px;
}

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

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

div.subcolumns > div.col.marginLeft1 { margin-left: 8.33333%; }
div.subcolumns > div.col.marginLeft2 { margin-left: 16.66667%; }
div.subcolumns > div.col.marginLeft3 { margin-left: 25%; }
div.subcolumns > div.col.marginLeft4 { margin-left: 33.33333%; }
div.subcolumns > div.col.marginLeft5 { margin-left: 41.66667%; }
div.subcolumns > div.col.marginLeft6 { margin-left: 50%; }
div.subcolumns > div.col.marginLeft7 { margin-left: 58.33333%; }
div.subcolumns > div.col.marginLeft8 { margin-left: 66.66667%; }
div.subcolumns > div.col.marginLeft9 { margin-left: 75%; }
div.subcolumns > div.col.marginLeft10 { margin-left: 83.33333%; }
div.subcolumns > div.col.marginLeft11 { margin-left: 91.66667%; }
div.subcolumns > div.col.marginLeft12 { margin-left: 100%; }

div.subcolumns > div.col.marginRight1 { margin-right: 8.33333%; }
div.subcolumns > div.col.marginRight2 { margin-right: 16.66667%; }
div.subcolumns > div.col.marginRight3 { margin-right: 25%; }
div.subcolumns > div.col.marginRight4 { margin-right: 33.33333%; }
div.subcolumns > div.col.marginRight5 { margin-right: 41.66667%; }
div.subcolumns > div.col.marginRight6 { margin-right: 50%; }
div.subcolumns > div.col.marginRight7 { margin-right: 58.33333%; }
div.subcolumns > div.col.marginRight8 { margin-right: 66.66667%; }
div.subcolumns > div.col.marginRight9 { margin-right: 75%; }
div.subcolumns > div.col.marginRight10 { margin-right: 83.33333%; }
div.subcolumns > div.col.marginRight11 { margin-right: 91.66667%; }
div.subcolumns > div.col.marginRight12 { margin-right: 100%; }

div.subcolumns > div.col.paddingLeft1 { padding-left: 8.33333%; }
div.subcolumns > div.col.paddingLeft2 { padding-left: 16.66667%; }
div.subcolumns > div.col.paddingLeft3 { padding-left: 25%; }
div.subcolumns > div.col.paddingLeft4 { padding-left: 33.33333%; }
div.subcolumns > div.col.paddingLeft5 { padding-left: 41.66667%; }
div.subcolumns > div.col.paddingLeft6 { padding-left: 50%; }
div.subcolumns > div.col.paddingLeft7 { padding-left: 58.33333%; }
div.subcolumns > div.col.paddingLeft8 { padding-left: 66.66667%; }
div.subcolumns > div.col.paddingLeft9 { padding-left: 75%; }
div.subcolumns > div.col.paddingLeft10 { padding-left: 83.33333%; }
div.subcolumns > div.col.paddingLeft11 { padding-left: 91.66667%; }
div.subcolumns > div.col.paddingLeft12 { padding-left: 100%; }

div.subcolumns > div.col.paddingRight1 { padding-right: 8.33333%; }
div.subcolumns > div.col.paddingRight2 { padding-right: 16.66667%; }
div.subcolumns > div.col.paddingRight3 { padding-right: 25%; }
div.subcolumns > div.col.paddingRight4 { padding-right: 33.33333%; }
div.subcolumns > div.col.paddingRight5 { padding-right: 41.66667%; }
div.subcolumns > div.col.paddingRight6 { padding-right: 50%; }
div.subcolumns > div.col.paddingRight7 { padding-right: 58.33333%; }
div.subcolumns > div.col.paddingRight8 { padding-right: 66.66667%; }
div.subcolumns > div.col.paddingRight9 { padding-right: 75%; }
div.subcolumns > div.col.paddingRight10 { padding-right: 83.33333%; }
div.subcolumns > div.col.paddingRight11 { padding-right: 91.66667%; }
div.subcolumns > div.col.paddingRight12 { padding-right: 100%; }

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

/*****************************************************************************/
}

@media only screen and (min-width: 1395px) { div.projectsTilesWrapper > div { width: calc(20.00000% - 20px); } }
@media only screen and (min-width: 1670px) { div.projectsTilesWrapper > div { width: calc(16.66667% - 20px); } }
@media only screen and (min-width: 1945px) { div.projectsTilesWrapper > div { width: calc(14.28571% - 20px); } }
@media only screen and (min-width: 2220px) { div.projectsTilesWrapper > div { width: calc(12.50000% - 20px); } }
@media only screen and (min-width: 2495px) { div.projectsTilesWrapper > div { width: calc(11.11111% - 20px); } }
@media only screen and (min-width: 2770px) { div.projectsTilesWrapper > div { width: calc(10.00000% - 20px); } }

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

body { padding: 0 calc((100% - 1896px) / 2); }


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

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

/* MAIN */
main > section { text-align: left; }
main > section > div.content {
	left: 150px;
	width: calc(100% - 150px - 48px);
	margin: 0;
}

/* GALLERY */
div.galleryWrapper > div.itemsWrapper > div > div.pict { margin: 0; background-position: 150px center; }
div.galleryWrapper > div.itemsWrapper > div:nth-child(1) > div.pict > img { width: calc(100% - 150px - 48px); }

/* PROJECTS LIST */
ul.projects {
	left: 20px;
	width: calc(100% - 20px * 2);
}
div.galleryWrapper ul.projects { left: 0; }

/* SUBCOLUMNS */
/*footer div.subcolumns > div.col.c3 { width: 50%; margin-bottom: 2em; }*/
footer > div#infoWrapper > div.subcolumns > div.col.c3 { width: 100%; }
footer > div#infoWrapper > div.subcolumns > div:nth-child(4) { text-align: left; }
footer div.subcolumns > div.col:nth-last-of-type(-n+2) { margin-bottom: 0 !important; }

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

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

/* HEADER */
header > div#addressLayer {
	display: inline-block;
	display: none;
	left: 150px;
	padding-top: 34px;
}
header > nav#button { display: inline-block; }
header > nav#main {
	position: absolute;
	display: none;
	left: 150px;
	top: calc(100% + 44px - 20px);
	/*width: calc(100% - 150px - 48px);*/
	width: calc(100% - 150px - 20px);
	max-width: none;
	padding-bottom: 28px;
}
nav#main > ul,
nav#main > ul > li {
	display: block;
	width: 100%;
}
nav#main > ul > li > a,
nav#main > ul > li > a:link,
nav#main > ul > li > a:visited {
	display: inline-block;
	width: 100%;
	padding: 14px 0;
	border-bottom: 1px solid #b3b3b3;
}
nav#main > ul > li:last-child > a,
nav#main > ul > li:last-child > a:link,
nav#main > ul > li:last-child > a:visited {
	border-bottom: 0;
}

/* FOOTER */
footer { padding-bottom: 20px; }

/* GALLERY */
/*div.galleryWrapper.descriptionOK { margin-top: 128px; }*/
/*div.galleryWrapper > div.itemsWrapper > div > div.text > div:nth-child(2) { display: none; }*/

/* PROJECTS TILES */
div.projectsTilesWrapper > div { width: calc(33.33333% - 20px); }

/* PROJECTS LIST */
ul.projects > li { text-align: right; }
ul.projects > li > span:nth-child(1) { width: calc(150px - 20px); }
ul.projects > li > span:nth-child(2) { width: calc((100% - 130px) * 0.5); }
ul.projects > li > span:nth-child(3) { width: calc((100% - 130px) * 0.5); }
ul.projects > li > span:nth-child(4) { width: calc((100% - 130px) * 0.5); }
ul.projects > li > span:nth-child(5) { width: calc((100% - 130px) * 0.5); }

/* FIRE and TEAM */
div.teamWrapper > div,
div.fireWrapper > div {
	width: calc(33.33333% - 20px);
	margin-bottom: 1.667em;
}

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

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

/* GALLERY */
div.galleryWrapper { padding: 0 0; }

/* SUBCOLUMNS */
div.subcolumns > div.col { width: 100% !important; margin-bottom: 2em; }
div.subcolumns > div.col:last-child { margin-bottom: 0 !important; }

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

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

/* PROJECTS TILES */
div.projectsTilesWrapper > div { width: calc(50% - 20px); }

/* FIRE and TEAM */
div.teamWrapper > div,
div.fireWrapper > div {
	width: calc(50% - 20px);
}

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

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

/* HEADER */
header > div#logoLayer { left: 28px; }
header > div#addressLayer { display: block; left: calc(28px + 103px); }
header > nav#button { left: calc(28px - 14px + 103px); }
header > nav#main {
	left: calc(28px + 103px);
	/*width: calc(100% - 28px - 103px - 28px);*/
	width: calc(100% - 28px - 103px - 20px);
}

/* MAIN */
main > section { text-align: center; }
main > section > div.content {
	left: 0;
	width: calc(100% - 28px * 2);
	margin: auto;
}

/* FOOTER */
footer { width: calc(100% - 28px * 2); }
footer > div#infoWrapper {
	position: relative;
	width: 100%;
}
footer > div#infoWrapper { font-size: 12px; line-height: 1.35714em; }

/* GALLERY */
div.galleryWrapper.descriptionOK { margin-top: 96px; }
div.galleryWrapper > div.itemsWrapper {
	left: 28px;
	width: calc(100% - 28px * 2);
}
div.galleryWrapper > div.itemsWrapper > div > div.pict { background-position: center center; }
div.galleryWrapper > div.itemsWrapper > div:nth-child(1) > div.pict > img { width: 100%; }
div.galleryWrapper > div.itemsWrapper > div > div.text {
	left: 0;
	top: -96px;
	width: 100%;
}
div.galleryWrapper > div.itemsWrapper > div > div.text > div { padding-right: 28px; }
div.galleryWrapper > div.itemsWrapper > div > div.text > div:nth-child(2) { display: none; }

/* PROJECTS LIST */
ul.projects {
	left: 0;
	width: calc(100% - 28px * 2);
}
div.galleryWrapper ul.projects { width: 100%; }
ul.projects > li > span { width: 100% !important; }
ul.projects > li > span:nth-child(1)::before { content: '# '; }
ul.projects > li:nth-child(1) > span:nth-child(1)::before { content: ''; }
ul.projects > li:nth-child(1) > span:nth-child(1) { display: none; }

/* FONT SIZES */
main > section > div.content { font-size: 14px; line-height: 1.5em; }
main > section > div.content .fontSizeBig,
main > section > div.content .intro {
	font-size: 21px;
	line-height: 1.44em;
}
h1 { font-size: 28px; line-height: 1em; }
h2 { font-size: 14px; line-height: 1.5em; }
ul.projects > li > span { font-size: 14px; line-height: 1.333em; }
div.galleryWrapper > div.itemsWrapper > div > div.text { font-size: 14px; line-height: 1.333em; }
div.galleryWrapper > div.dotsWrapper > div { font-size: 12px; line-height: 1; padding: 10px 5px }

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

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

/* FIRE and TEAM */
div.teamWrapper > div,
div.fireWrapper > div {
	width: calc(100% - 20px);
}

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

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

/* HEADER */
header > nav#button { left: calc(28px - 14px); }
header > nav#main {
	left: 28px;
	width: calc(100% - 28px - 28px);
}
header > div#addressLayer { left: 28px; }

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

footer > div#addressLayer a[href^='tel']:hover,
footer > div#addressLayer a[href^='tel']:active,
footer > div#addressLayer a[href^='tel']:visited:hover,
footer > div#addressLayer a[href^='tel']:visited:active {
	cursor: default;
	color: #80a0b0;
}

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

body > * { display: none; }

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