/* =Reset default browser CSS. Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
}

body {
	text-rendering: optimizeLegibility;
	color:#222;
}	

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

html {
	overflow-y: scroll;
	font-size: 87.5%;
}

:focus {/* remember to define focus styles! */
	outline: 0;
}

ol, ul {
	list-style: none;
}

table {/* tables still need 'cellspacing="0"' in the markup */
	border-collapse: separate;
	border-spacing: 0;
}

caption, th, td {
	font-weight: normal;
	text-align: left;
}

a img {
	border: 0;
	-ms-interpolation-mode: bicubic;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

/* Global
-------------------------------------------------------------- */

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

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

body {
	font-family: 'NationalWeb-Regular', Times, Arial, sans-serif;
	font-weight:normal;
}

a, a:focus, a:active {
	color:#222;
	text-decoration:none;
}


strong {
	font-family: 'NationalWeb-Extrabold', Arial, sans-serif;
	display:block;
	letter-spacing:0.25px;
}

.indented {
	text-indent:2em;
	display:block;
}

.headline {
	font-family: 'NationalWeb-Extrabold', Arial, sans-serif;
	display:block;
	letter-spacing:0.25px;
}

/* Header
-------------------------------------------------------------- */

#branding {
	width:100%;
	overflow:hidden;
	font-family: 'NationalWeb-Extrabold', Arial, sans-serif;
}

#branding nav {
	margin:1em;
}

#branding #headline, #branding #subline {
	display:block;
}

#branding nav ul li a {
	text-decoration:none;
}


/* Articles
-------------------------------------------------------------- */

.article {
	width:100%;
	overflow:hidden;
	display:table;
}

.even-slide {
	background:none;
}

.article-content {
	display:table-cell;
	vertical-align:middle;
}

.article-content h3 span:first-of-type::before,
.article-content h3 span:last-of-type::after {
	content: '\00BB';
	display: block;
	text-indent:2em;
	display:block;
}

.article-content h3 span:last-of-type::after {
	content: '\00AB';
}

#claim-wrapper {
	font-family: 'NationalWeb-Extrabold', Arial, sans-serif;
	position:relative;
	border-bottom:1px solid #222;
  height: 100vh;
}

/*#claim-wrapper:hover {
	cursor:pointer;
}*/

.grey {
	color:#888;
}

#arrow-down {
	width:100%;
	height:60px;
	position:absolute;
	bottom:40px;
	left:0px;
	text-align:center;
}

#arrow-down a {
	width:120px;
	height:60px;
	overflow:hidden;
	display:block;
	text-indent:1000px;
	background:url('../img/arrow-down.png');
	margin:0 auto;
	cursor:default;
}

.invisible {
  visibility: hidden;
}

.gallery-wrapper {
	position:relative;	
	width:100%;
	display: flex;
	border-bottom:1px solid #222;
  height: 100vh;
}

.swiper-container-gallery-desktop, 
.swiper-container-publications-desktop ,
.swiper-container-art ,
.swiper-slide {
	overflow:hidden;
  margin-top: auto;
  margin-bottom: auto;
}

.swiper-slide {
   text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.swiper-slide img {
  max-height: 90vh;
  max-width: 100%;
}
.swiper-lazy-preloader {
	width: 60px;
	height: 60px;
}
.caption {
  text-align: center;
	margin-top:5px;
}

.arrow-left-gallery, .arrow-right-gallery,
.arrow-left-publications,
.arrow-right-publications, .arrow-left-art, .arrow-right-art {
	position:absolute;
	top:50%;
	z-index:99;
	width:90px;
	height:140px;
	margin-top:-70px;
}

.arrow-left-gallery, .arrow-left-publications , .arrow-left-art{
	left:20px;
	background:url('../img/larr.png');
	display:none;
}

.arrow-right-gallery, .arrow-right-publications , .arrow-right-art{
	right:20px;
	background:url('../img/rarr.png');
}

#profile-wrapper {
	font-family: 'NationalWeb-Extrabold', Arial, sans-serif;
	border-bottom:1px solid #222;
  min-height: 100vh;
}

#reference-wrapper {
	border-bottom:1px solid #222;
}

#contact-wrapper p {
	margin:0 auto;
	font-family: 'NationalWeb-Extrabold', Arial, sans-serif;
	display:inline-block;
	text-align:left;
}

@media screen and (max-width: 680px) {
	body {
		line-height:1.25em;
		overflow-x:hidden;
	}
	
	#branding {
		display:block !important;
	}
	
	#branding #headline, #branding #subline {
		font-size:1em;
		line-height:1.1em;
	}
	
	.even-slide {
		background:none;
	}

	#claim-wrapper {
		font-size:1em;
		line-height:1.25em;
	}
	
	#claim-wrapper .column-wrapper {
		margin:1.5em 1em;
	}
	
	#claim-wrapper .left-column, #claim-wrapper .right-column {
		margin:0em 0em;
	}
	
	#arrow-down {
		display:none !important;
	}
	
	.gallery-image {
		max-width:100%;
	}
	
	.caption {
		line-height:10px;
		font-size:9px;
	}
	
	#profile-wrapper {
		font-size:1em;
		line-height:1.25em;
	}
	
	#profile-wrapper .content-wrapper {
		margin:2.5em 1em;
	}
	
	#profile-wrapper img, .foto-credit {
    max-width: 100%
	}
	
	#profile-wrapper p {
		margin:1em 0;
		text-align:left;
	}
	
	#reference-wrapper {
		font-size:1em;
		padding:0 1em;
	}

	#reference-wrapper p {
		max-width:90%;
		margin:2.5em 0em;
	}
	
	#contact-wrapper {
		margin:1em;
	}
	
	#contact-wrapper .article-content {
		text-align:left;
	}
	
	#contact-wrapper p {
		font-size:1em;
		line-height:1.25em;
	}
	
	#footer {
		/* width:100%; */
		margin:0 1em 0.5em 1em;
		font-size:0.85em;
		text-align:left;
		display:block;
	}

	#footer p {
		margin-right: 1em;
	}

}

@media screen and (min-width: 681px) {
	#footer p {
		max-width: 320px;
		text-align: justify;
		margin: 0 auto;
	}
}

@media screen and (min-width: 681px) and (max-width: 1024px) {
	body {
		line-height:1.25em;
	}
	
	#branding {
		position:absolute;
		top:0;
		left:0;
		z-index:999;
	}
	
	#branding #headline, #branding #subline {
		font-size:1.25em;
		line-height:1.1em;
	}

	#claim-wrapper {
		font-size:1.25em;
		line-height:1.25em;
	}
	
	#claim-wrapper .column-wrapper {
		width:80%;
		margin:4em auto;
	}
	
	#claim-wrapper .left-column {
		float:left;
		width:45%;
		margin-right:1.5%;
		margin-top:4em;
		margin-bottom:4em;
	}
	
	#claim-wrapper .right-column {
		float:right;
		width:45%;
		margin-left:2.5%;
		margin-top:4em;
		margin-bottom:4em;	
	}
	
	
	#profile-wrapper {
		font-size:1.25em;
		line-height:1.25em;
	}
	
	#profile-wrapper .content-wrapper {
		width:70%;
		margin:0 auto;
	}
	
	#profile-wrapper .left-column {
		float:left;
		width:48%;
		margin-right:1%;
		height:auto;
	}
	
	#profile-wrapper img {
		max-width:100%;
		height:auto;
	}
	
	.foto-credit {
		font-size:0.65em;
		font-family: 'NationalWeb-Regular', Arial, sans-serif;
	}
	
	#profile-wrapper .right-column {
		float:right;
		width:48%;
		margin-left:1%;
	}
	
	#profile-wrapper, #profile-wrapper .left-column, #profile-wrapper .right-column {
		margin:4em 0;
	}

	#reference-wrapper p {
		column-count: 3; column-gap: 1em; column-rule: 0px solid #000000; 
		margin:8em 1em;	
	}
	
	#contact-wrapper .article-content {
		text-align:center;	
	}
	
	#contact-wrapper p {
		font-size:1.25em;
		line-height:1.25em;
	}
	
	#footer {
		width:100%;
		margin:0 0 0.5em 0;
		font-size:0.85em;
		text-align:center;
		display:block;
	}

}

@media screen and (min-width: 1025px) and (max-width: 1440px) {
	body {
		line-height:1.5em;
	}
	
	#branding {
		position:absolute;
		top:0;
		left:0;
		z-index:999;
	}
	
	#branding #headline, #branding #subline {
		font-size:1.5em;
		line-height:1.25em;
	}

	#claim-wrapper {
		font-size:1.5em;
		line-height:1.25em;
	}
	
	#claim-wrapper .column-wrapper {
		width:80%;
		margin:4em auto;
	}
	
	#claim-wrapper .left-column {
		float:left;
		width:45%;
		margin-right:2.5%;
		margin-top:4em;
		margin-bottom:4em;
	}
	
	#claim-wrapper .right-column {
		float:right;
		width:45%;
		margin-left:2.5%;
		margin-top:4em;
		margin-bottom:4em;	
	}
	
	#profile-wrapper {
		font-size:1.5em;
		line-height:1.25em;
	}
	
	#profile-wrapper .content-wrapper {
		width:65%;
		margin:0 auto;
	}
	
	#profile-wrapper .left-column {
		float:left;
		width:48%;
		margin-right:1%;
		height:auto;
	}
	
	#profile-wrapper img {
		max-width:100%;
		height:auto;
	}
	
	.foto-credit {
		font-size:0.65em;
		font-family: 'NationalWeb-Regular', Arial, sans-serif;
	}
	
	#profile-wrapper .right-column {
		float:right;
		width:48%;
		margin-left:1%;
	}

	#reference-wrapper p {
		column-count: 3; column-gap: 2em; column-rule: 0px solid #000000; 
		margin:8em 10%;	
	}
	
	#contact-wrapper .article-content {
		text-align:center;	
	}
	
	#contact-wrapper p {
		font-size:1.5em;
		line-height:1.25em;
	}
	
	#footer {
		width:100%;
		margin:0 0 0.5em 0;
		font-size:0.85em;
		text-align:center;
		display:block;
	}
}

@media screen and (min-width: 1441px) {
	body {
		line-height:1.5em;
	}
	
	#branding {
		position:absolute;
		top:0;
		left:0;
		z-index:999;
	}
	
	#branding #headline, #branding #subline {
		font-size:1.5em;
		line-height:1.25em;
	}

	#claim-wrapper {
		font-size:1.75em;
		line-height:1.25em;
	}
	
	#claim-wrapper .column-wrapper {
		width:70%;
		margin:0 auto;
	}
	
	#claim-wrapper .left-column {
		float:left;
		width:45%;
		margin-right:2.5%;
		margin-top:4em;
		margin-bottom:4em;
	}
	
	#claim-wrapper .right-column {
		float:right;
		width:45%;
		margin-left:2.5%;
		margin-top:4em;
		margin-bottom:4em;	
	}
	
	#profile-wrapper {
		font-size:1.5em;
		line-height:1.25em;
	}
	
	#profile-wrapper .content-wrapper {
		width:50%;
		margin:0 auto;
	}
	
	#profile-wrapper .left-column {
		float:left;
		width:48%;
		margin-right:1%;
		height:auto;
	}
	
	#profile-wrapper img {
		max-width:100%;
		height:auto;
	}
	
	.foto-credit {
		font-size:0.65em;
		font-family: 'NationalWeb-Regular', Arial, sans-serif;
	}
	
	#profile-wrapper .right-column {
		float:right;
		width:48%;
		margin-left:1%;
	}

	#reference-wrapper p {
		column-count: 3; column-gap: 2em; column-rule: 0px solid #000000; 
		margin:8em 25%;	
	}
	
	#contact-wrapper .article-content {
		text-align:center;	
	}
	
	#contact-wrapper p {
		font-size:1.5em;
		line-height:1.25em;
	}
	
	#footer {
		width:100%;
		margin:0 0 0.5em 0;
		font-size:0.85em;
		text-align:center;
		display:block;
	}
}



.admin header#branding {
	position: relative;
}

.admin .article-content {
	display: block;
}

.admin form {
	display: block;
	margin: 1em;
	font-size: 1em;
}

.admin select {
	display: block;
	margin-bottom: 1em;
	font-size: 1.2em;
	padding: 5px;
}

.admin textarea {
	display: block;
	min-width: 600px;
	min-height: 400px;
	margin: 0 1em 1em 0;
}

.admin button {
	display: block;
	font-size: 1em;
	margin-bottom: 1em;
}

.admin .fieldset {
	display: flex;
	flex-flow: row nowrap;
}

.admin .fieldset > div:first-child {
	margin: 0 1em 1em 0;
}

.admin dl {
	text-align: left;
}

.admin dl h3 {
	font-weight: bold;
	font-size: 1.2em;
}

.admin dl a:first-child {
	min-width: 20em;
	display: inline-block;
}

.admin dl a:hover,
.admin dl a:focus,
.admin dl a:active {
	color: #f00;
}

#tinymce p {
	margin-bottom: 10px;
}
