body {
	color: #444;
	font-family: Open Sans;
    font-size: 1em;
    line-height: 200%;
    padding:0;
    margin:0;
}

/* Footer text */
.footerText {
    color: rgb(200, 200, 200);
    justify-content: center;
    font-size: 0.8em;
    line-height: 1.5em;
}

/* Footer line */
.line{
    height: 3em;
    border-bottom: 1px solid rgb(200, 200, 200);
    margin-bottom: 1em;
}

/* Gallery viewer */
.viewer {
    display: none;
    width: 100%;
    min-height: 100vh;
    justify-content: center; 
    align-items: center; 
    flex-direction: column;

    background: rgba(0, 0, 0, 0.8);
    text-align:center;
}
  
.bigImage {
    max-width: 85%;
    max-height: 85vh;
    display: none;
}

.caption {
    display: inline-block;
    color: #fff;
    z-index: 2;
    max-width: 80%;
}

.galRight, .galLeft, .cancelButton {
    display: inline-block;
    color: #fff;
    border: none;
    padding: 10px;
    cursor: pointer;
    transition: background-color 0.3s;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.galRight{
    right: 10px;
    float: right;
}

.galLeft{
    left: 10px;
    float: left;
}

	.menu, .menuContact, .logo, .menuIcon{
		margin: 1em;
		font-weight: bold;
		cursor: pointer;
	}
	
/* Holder for image and text on project page */
.story{
    display: inline-block;
    box-shadow: 0px 0px 10px rgb(220,220,220);
    padding: 0px;
    margin: 10px;
    width: calc(50% - 21px);
    //height: 50vw;
    vertical-align: top;
    font-size: medium;
    text-align: center;
}

.story:hover { 
    box-shadow: 0px 0px 10px rgb(110,110,110);
}

/* Image holder for project page */
.galItem2{
    width: 100%;
    padding-top: 75%; /*1 3:4 Aspect Ratio */
    display: inline-block;
    margin: 0px;
    overflow: hidden;
    position: relative; /* If you want text inside of it */
}


	.menu, .menuContact, .menuIcon{
		float: right;
        display: inline-block;
	}
    
    .menu:hover{
        color: rgb(0,0,200);
    }
    
    .menuContact:hover, .button:hover{
        box-shadow: 0px 0px 5px rgb(110,110,110);
    }
    
    .menuList{
		float: right;
		display: none;
		position: relative;
		clear: both;
        width: 100%;
        z-index: 2;
        text-align:center;
        padding-bottom: 2em;
	}
	
	.menu, .menuListItem{
		color: #444;
        font-weight: bold;
		cursor: pointer;
	}
    
    .menuListItem{
		color: #444;
	}
		
	.logo{
        display: inline-block;
        float: left;
		color: rgb(0, 0, 200);
		font-weight: bold;
	}
	
	.menuContact, .button{
		border-radius: 50vh;
		padding-left: 1em;
		padding-right: 1em;
		background-color: rgb(0, 0, 200);
		color: white;
	}
	
	.button{
		width: 60%;
		display: inline-block;
        padding: 0;
        margin: 0;
	}
    
    .desktop{
        display: none;
    }
    
    .mobile{
        display: inline-block;
    }
	
	.space{
		height: 1em;
		clear: both;
	}

/* Remove decoration for hyperlinks */  
a{
    text-decoration:none;
}

/* Page tite */
h1{
    display: inline-block;
    font-size: 2em;
    color: rgb(0, 0, 200);
    font-weight: bold;
    line-height: 150%;
    padding: 0.2em;
    margin: 0;
    background: linear-gradient(rgb(0, 0, 200) 0 0) bottom/ 80% 0.07em no-repeat;
}

/* Page subtitle */
h2{
    display: inline-block;
    font-size: 0.9em;//0.7em;
    color: rgb(0, 0, 200);
    font-weight: bold;
    clear:both;
    margin: 0;
    padding: 0.4em;
}

/* Project title */
h3{
    font-size: .9em;
    line-height: 1.5em;
    max-height: 3em;        // twice line height
    overflow: hidden;       // cut off thrid line
    font-weight: bold;
    color: rgb(0, 0, 200);
    padding: 0;
    margin: 0;
    padding-top: 1em;
}

/* Poject date */
h4{
    font-size: 0.72em;
    font-weight: bold;
    color: rgb(0, 0, 200);
    line-height: 1.8em;
    padding: 0;
    margin: 0;
    padding-bottom: 1em;
}

/* Page text block title */
h5{
    font-size: 1.3em;
    font-weight: bold;
    color: rgb(0, 0, 200);
    line-height: 1.8em;
    padding: 0;
    margin: 0;
}

/* Feedback title */
h6{
    font-size: 1em;
    font-weight: bold;
    color: rgb(0, 0, 200);
    line-height: 1.5em;
    padding: 0;
    margin: 0;
}
	
    
/* Email format for contact page */
.email{
    color: rgb(0, 0, 200);
    font-weight: bold;
}
	
/* Generaic centering container */
.centerContainer{
    display: inline-block;
    width: 100%;
    text-align:center;
}

.leftContainer{
    display: inline-block;
    width: 100%;
    text-align:left;
}



/* Project page introduction block */
.pageIntro{
    padding: 2em;
    display: inline-block;
}

/* Page text in a half screen block */
.textHalf, .intro{
    display: inline-block;
    padding: 20px;       // 0px for clientHeight() method
    margin: 0 0 0 0;
}
	
/* Gallery for project highlights and project pages */
.gal{
    line-height: 0%;
    font-size: 0;       //stops spaces between inline-block elements
}

/* Square items within project page gallery */
.galItem {
    width: 29%;
    padding-top: 29%; /* 1:1 Aspect Ratio */
    display: inline-block;
    margin: 6px; 
    overflow: hidden;
    position: relative; /* If you want text inside of it */
    box-shadow: 0px 0px 8px rgb(220,220,220);
}


.galItem:hover { 
    box-shadow: 0px 0px 10px rgb(110,110,110);
}

/* Image containers within square .galItem within project page gallery*/
.imageCover, .imageContain, .videoCover, .videoCover{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    object-position: 50% 50%;
}

.imageContain, .videoContain{
    object-fit: contain;
}

.imageCover, .videoCover{
    object-fit: cover;
}

/* Comment under pictures in project heighlight gallery */
.picComment{
    clear: both;
    line-height: 1.6em;
    font-size:0.875em;
    color: #444;
    padding: 10px;
    margin: 0;
    display: none;
}

/* Clear fix for header */
.header:after{
    content: "";
    clear: both;
    display: table;
}
	
/* Grid style */
.grid {
	padding: 0 10px;
}

/* Page container  */
.container{
    width:100%;
    display:table;
    min-height: 90vh;
}

/* Feedback title */
.quote{
    /*font-style: italic;*/
    line-height: 1.5em;
}

.quoteName{
    text-align: right;
    font-size: 0.8em;
    /*font-weight: bold;*/
    color: rgb(50, 50, 50);
    line-height: 1.5em;
    padding: 0;
    margin: 0;
    padding-bottom: 0em;
}

.quoteDate{
    text-align: right;
    font-size: 0.8em;
    /*font-weight: bold;*/
    color: rgb(50, 50, 50);
    line-height: 1.5em;
    padding: 0;
    margin: 0;
    padding-bottom: 0em;
}

/* Quote block */
.quoteBlock{
    display: block;
    padding: 20px;       // 0px for clientHeight() method
    margin: 0 0 0 0;
}

