* {
	margin:0;
	padding:0;
	list-style-type: none;
	box-sizing: border-box;
}

*:focus{
	 outline-color: white;
}


html {
	font-family: "Helvetica Neue", Helvetica;
	font-weight: bold;
	font-size: 28px;
	line-height: 1;
	color: white;

}

h1{
	font-size: 72px;
}

	@media (max-width: 700px){
		h1{
			font-size: 50px;
		}
		p{
			font-size: 21px;
		}
	}

h1.outline{
	color: transparent;
	-webkit-text-stroke: 2px white;
	text-stroke: 2px white;
}



@media (min-width:700px) and (max-width:1400px){

	
	#mce-EMAIL{
		font-size: 28px!important;
	}
	
	#logo{
		width: 235px!important;
	}
	
}

body {
	background: #16161d
}

.bg{
	position: absolute;
	top:0;left:0;
	width:100%;
	z-index:-1;
	background-size:auto 100%!important;
	transition:background-size 20s ease-in-out;
}
	
	.bg.a{
		background-size:auto 0.5%!important;backface-visibility: hidden;
	}


/*

::selection{
	color: white;
	background: #16161d;
}
*/

p{
	line-height: 1.3;
}

	h3{
		font-size: 21px;
		line-height: 1.2;
	}

	h4 {
		font-size: 16px;
		line-height: 1.2;
		max-width: 955px;
		margin-bottom: 20px;
	}
	
	h4 a {color:inherit}

	h5 {
		font-size:10px;
/* 		margin: 14px 35px; */
		font-weight: normal;
	}

	a {
		color: white;
		text-decoration: none;
	}
	
	p {
		max-width: 955px;
	}
	
	h3 a,h4 a,h5 a,p a {
		text-decoration: underline;
	}

/*


	GRID


*/

.grid {
	position: relative;
	float:left;
}

	.full {
		width: 100%;
	}

/*


	GLOBAL


*/

.margin--top {
	margin-top: 35px;
}

.margin--bottom {
	margin-bottom: 70px;
}

.show {
	cursor: pointer;
}

.hide {
	display: none;
}

.small {
	font-size: 50%;
}

@media screen and (max-width:700px){

	.small {
		font-size: 60%;
	}

}


#logo{
	width: 310px;
	fill: white;
	margin: 50px 0px 50px 0px;
}


main{
	height: 100%;
	padding: 0px 21px;
	margin: 0 auto;
	overflow-y: hidden;
	clear: both;
}

.header{
	cursor: pointer;
}

	@media screen and (max-width: 700px){
	
		#logo{
			width: 165px;
			margin-top: 40px!important;
		}
		
		main{
			padding: 0px 14px;
		}
	}

.table{
	position: relative;
	float:left;
	width: 100%;
	margin: 0px;
}

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

	.table{
		margin-top: 25px!important;
	}

}
*/

.rows{
	margin:0 auto;
	width: 100%;
	max-width: 900px;
}

.row{
	position: relative;
	float:left;
	clear: both;
	padding-bottom: 50px;
	width: 100%;
	max-width: 900px;
	margin-bottom: 14px;
	padding:14px;
/* 	padding-left:21px; */
	padding-left: 0;
	padding-right:28px;
}

	.glossary .row{
		margin-bottom: 20px;
	}
	
	
	.glossary .row a{
/* 		border-bottom: 1px solid white; */
	}
	
	.glossary .row ul li{
		list-style-type: circle;
	}
	
	#glossary h2, #glossary h3, #glossary h4{
		max-width: 800px;
	}
	
	
	.glossary p{
		font-weight: normal;
		font-size: 18px;
		margin-bottom: 20px;
	}
	
	
	.left{
		text-align: left;
		display: block;
	}
	
	
	.center{
		text-align: center;
		display: block;
	}
	
	.right{
		text-align: right;
		display: block;
	}
	
	
	
	
.row.center{
	text-align: center;
}

.row.right{
	text-align: right;
}

	@media screen and (max-width: 700px){
	
		.row{
			padding-right: 0;
			width: 100%;
		}
		
		.row.header{
			padding:0;
			padding-bottom: 27px;
		}
	
	}

	center{
/* 		float:left; */
		margin: 14px 0px;
	}


.cell{
	position: relative;
	float:left;
}

	.cell:nth-child(1){
		width: 100%;
		cursor: pointer;
	}
	
	
	
	.cell.locked:after{
		content: " 🔒";
		color: white;
	}
	
		.glossary .cell:nth-child(1){
			-webkit-text-stroke: 1px white;
			color:transparent;
		}
		
		.glossary .cell:nth-child(1) p{
			font-weight: bold;
			font-size:35px;
		}
	
	.cell.a{
		color: white;
	}
	
	.cell:nth-child(1):hover{
		color: white;
	}
	
		.glossary .cell:nth-child(1):hover{
			color: white;
		}

	.cell:nth-child(2){
		width: 100%;
		float:left;
		clear:both;
		display: none;
	}
	
	

.projects{
	position: relative;
	float:left;
	width: 100%;
}

	.project{
		width: 33.33%;
		height: 350px;
		background-repeat: none!important;
		margin: 35px 0px ;
		transition: 300ms;
	}

	.projects img{
		height: 300px;
		margin: 0px 14px 14px 0px;
	}

	.project:hover{
		transform: scale(1.05);
	}

	@media screen and (max-width: 700px){

		.project{
			/*padding: 14px;*/
			margin: 10px;
			width: 40%;
			height: 45vw;
		}
		
	}
	
.logout{
	position: absolute;
	top:0; right: 0;
	margin: 30px;
	font-size: 12px;
	text-transform: uppercase;
}

.accessibility{
	position: fixed;
	z-index: 9;
	bottom:35px;right:0;
	width:35px;height:35px;
	background: #16161d url(../access-icon2.png) center/70% no-repeat;
	cursor: pointer;
}

	@media screen and (max-width: 700px){	
	
		.accessibility{
			top: 43px;
			bottom: auto;
		}
	
	}
	
.littleLogo{
	position: absolute;
	top: 0;left: 0;
	z-index:9;
	width:35px;
	margin: 35px;
}

	@media screen and (max-width: 700px){
	
		.littleLogo{
			margin: 21px;
		}
	}

nav{
	position: relative;
	float:left;
	margin-top: 50px
}

nav li{
	position: relative;
	float:left;
	margin-right: 35px;
	font-size: 16px;
	line-height: 1.5;
}


@media screen and (max-width: 700px){

	nav li{
		font-size: 21px;
		clear: both;
	}

}

	.swiper-slide,.image{
		height: 100vh;
	}
	
.controls{
	position: absolute;
	bottom: 0;left: 0;
	margin:35px;
	z-index:99;
}


.next,.prev{
	cursor: pointer;
}

.swiper-pagination-fraction{
	position: relative;
	float: left;
	text-align: left;
	bottom: 0;
	
}
/*

.swiper-button-next, .swiper-button-prev{
	width:14px!important;
	height: 14px!important;
}

.swiper-button-next:after, .swiper-button-prev:after{
	font-size: 12px!important;
}
*/

.credits{
/* 	background: black; */
	padding: 50px 35px;
}

.credits p {
	max-width: 100%;
	margin-bottom: 50px;
}




@media screen and (max-width: 700px){

	.controls{
		margin: 21px;
	}
	.credits{
		padding: 50px 21px;
	}
}

.about *{
	text-transform: none;
}
/*

blockquote{
	padding:35px;
}
*/

footer{
	margin: 35px 0px;
}


#mce-EMAIL{
	position: relative;
	float: left;
	font-size: 100%;
    background: none;
    border: none;
    font-weight: bold;
    border-bottom: 3px solid white;
    color:white;
    border-radius: 0;
}

#mc-embedded-subscribe{
	font-size: 42px;
    background: none;
    border: 0;
    color: white;
    font-weight: bold;
	
}

::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: white;
  opacity: 0.5; /* Firefox */
}

:-ms-input-placeholder { /* Internet Explorer 10-11 */
  color: white;
}

::-ms-input-placeholder { /* Microsoft Edge */
  color: white;
}

#mc_embed_signup div.mce_inline_error{
	background-color:transparent!important;
	padding: 0;
}

#mce-EMAIL {
	outline: 0;
}

.button{
	cursor: pointer;
}


@media screen and (max-width:700px){
	
	#mce-EMAIL,#mc-embedded-subscribe {
		font-size: 28px;
	}
	
}

/*  Disc */


  
.disc-container {
    position: fixed;
    top:0;right:70px;
    margin: 50px;
    height: 125px;
/*     margin-top: -125px; */
    display: flex;
    justify-content: center;
    cursor: pointer;
    z-index:99;
}

	@media (max-width:700px){
	
		.disc-container {
			right:40px;
			margin: 40px;
	    }
	}

.disc {
    position: absolute;
    /* right: 50px; */
    width: 125px;
    height: 125px;
    transform-style: preserve-3d;
    perspective: 750px;
    
    animation: disc-spin 8s infinite linear;
}







.disc-front, .disc-back {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 125px;
    height: 125px;
    border-radius: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: radial-gradient(#c6bcd0 30%,#c6bcd0 100%);
    color: white;
    backface-visibility: hidden;
    font-size: 18px;
}

.disc-front{
	transform:translateZ(1px)
}

.disc-front img, .disc-back img{
	width: 100%;
	width: 60px;
}

.disc-back {
    transform: rotateY(180deg);
    text-shadow: none;
}


@keyframes disc-spin{

	0%{transform:rotateY(0deg)}
	100%{transform:rotateY(360deg)}

}

  svg{fill:white}
  
  
  .disc-back,.disc-front{
  	background: black;
  }
  
  
 @media (max-width:700px){
	 .disc{
		 margin-top: 250px;
	 }
 }



.subnav{
	margin: 50px 0px;
}

	.subnav a:hover{
		text-decoration: underline;
	}

article h1{
/* 	color: black; */
	margin-top: 50px;
}

article p{
	width: 100%;
	max-width:700px;
	margin: 7px auto;
	padding: 14px;
	margin-bottom: 10px;
}

article img{
/* 	max-width:80%; */
	margin: 0 auto;
	display: block;
	width: 700px;
	max-width: 100%;
}

article .swiper-slide,article  .image{
	height: auto;
}

article figcaption p {
	margin-bottom: 0px;
}

/* GLOSSARY */

.title{
	font-size: 42px;
	margin: 20px;
}

	.title img{
		width: 25px;
		margin-right: 5px;
	}

