/* --------------------------------------------------------
Style Sheet for karenmdesigns.com

author: Karen McCullough
website: http://karenmdesigns.com
----------------------------------------------------------*/
/*
	1: Base Rules - include base reset of elements and single element selectors.
	2: Layout Rules - include sections of pages and hold modules together.
	3: Modules - reusable parts of the design, including sidebars, callouts, etc.
	4: Helper Classes
	5: State Rules - mostly css rules for javascript and states such as hidden, visible, expanded, etc.
	6: Media Queries
	7: Print Styles
	
	
	Main Colors:
	#325158 - Dark Grey/Text Gray
	#30cbe8 - Peacock Blue
	#4a62a7 - Accent Purple
	#ecf4f5 - Light Gray
	#888888 - Medium Gray
	
*/


/*==============================================/  
	
	1: Base
	
==============================================*/

*, *::after, *::before,
figure {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 62.5%;
}

body,
main {
	background: #fff;
    color: #325158;
    font: 300 1.8rem/1.5 'Roboto', Helvetica, Arial, sans-serif;
}
header { padding: 2rem; }
hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ecf4f5;
    margin: 1em 0;
    padding: 0;
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

figure {
	text-align: center;
}

figcaption {
	color: #888;
	font-size: 1.2rem;
	font-weight: 300;
	margin-bottom: 1rem;
	text-align: left;
}

fieldset { border: 0; }

textarea { resize: vertical; }


a { 
	color: #4a62a7;
	text-decoration: none;
	transition: all .6s; 
}

a:hover,
a:focus { color: #30cbe8; }

footer {
  font-size: 1.4rem
  background: #ecf4f5;
}

input, 
select, 
textarea {
    font-size:1.5rem;
    width:98%;
    border: 1px solid #ecf4f5;
    margin-bottom:2rem;
    padding:2% 0 2% 2%;
}

input:focus, 
select:focus, 
textarea:focus {
    border: 1px solid #AFCDD8;
    background-color: #F8FBFF;
} 

textarea {
    height:150px;
    resize: none;
} 

label { display:block; }
sup { font-size: 50%; }


/*** FONTS ***/

/* roboto-300 - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/roboto-v20-latin-300.eot'); /* IE9 Compat Modes */
  src: local('Roboto Light'), local('Roboto-Light'),
       url('../fonts/roboto-v20-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/roboto-v20-latin-300.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/roboto-v20-latin-300.woff') format('woff'), /* Modern Browsers */
       url('../fonts/roboto-v20-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../fonts/roboto-v20-latin-300.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-regular - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/roboto-v20-latin-regular.eot'); /* IE9 Compat Modes */
  src: local('Roboto'), local('Roboto-Regular'),
       url('../fonts/roboto-v20-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/roboto-v20-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/roboto-v20-latin-regular.woff') format('woff'), /* Modern Browsers */
       url('../fonts/roboto-v20-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../fonts/roboto-v20-latin-regular.svg#Roboto') format('svg'); /* Legacy iOS */
}
/* roboto-700 - latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/roboto-v20-latin-700.eot'); /* IE9 Compat Modes */
  src: local('Roboto Bold'), local('Roboto-Bold'),
       url('../fonts/roboto-v20-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../fonts/roboto-v20-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/roboto-v20-latin-700.woff') format('woff'), /* Modern Browsers */
       url('../fonts/roboto-v20-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../fonts/roboto-v20-latin-700.svg#Roboto') format('svg'); /* Legacy iOS */
}


/*** TYPOGRAPHY ***/

h1, h2, h3, h4, h5, h6 {
	font-weight: 300;
	margin: 1rem 0;
}

h1 { 
	font-size: 3.6rem;
	line-height: .8;
	margin-top: 0;
}
h3 {
	font-size: 2rem;
}
h4 {
	font-size: 1.8rem;
	font-weight: 700;
}
p:not(.button__container-ghost), li { max-width: 75ch; }
p + h4,
p + p {
	margin-top: 2rem;
}
h5 {
	font-size: 1.6rem;
}
h4 {
	font-size: 1.4rem;
}
ul {
	margin: 2rem 0 2rem 2rem;
}
li { padding-bottom: 1rem; }

.pipe { margin: 0 1rem; }


/*** LINKS/BUTTONS ***/

a[rel="external"]:after,
.link--external:after,
.icon:after,
#pull:before,
.plus:after,
.minus:after {
  	font-family: "Font Awesome 5 Pro", "Font Awesome 5 Free";
  	font-weight: 900;
	margin-left: .5rem;
}
a[rel="external"]:after,
.link--external:after {
	content: '\f35d';
}
#pull:before {
	content: '\f0c9'; /* hamburger menu icon */
}
#pull.js-open:before {
	content: '\f00d'; /* close icon */
}
#pull:before {
	margin-right: 1rem;
}
.no-icon[rel="external"]:after { content: ''; }

.button {
	background: #4a62a7;
	border: 1px solid #4a62a7;
	border-radius: 3px;
	color: #fff; 
	display: inline-block;
	margin-top: 2rem;
	padding: 1.5rem 2rem;
}
.button:hover,
.button:focus {
	background: #30cbe8;
	border-color: #30cbe8;
	color: #fff;
}


.button__container-ghost {
	background: #fff;
	margin-bottom: 4rem;
	text-align: center;
}
.button--ghost {
	background: #fff;
	border: 2px solid #4a62a7;
	color: #4a62a7;
	margin: 
}

.current {
	color: #325158;
	font-weight: 400;
	padding: 0;
}



/**** FOOTER ****/

footer {
	background: #325158;
	color: #fff;
	padding: 0 0 6rem 0;
	text-align: center;
}
.copyright {	
	font-size: 1.2rem;
}

#site-subtitle { 
	color: #4a62a7;
	display: block;
	font-size: 2rem;
	line-height: 1.5; 
}

#hp-intro,
.page__intro,
.page__about { 
	color: #fff;
	background: #30cbe8;
	padding: 2rem 0 0 0;
	position: relative;
}


#hp-intro,
.page__about,
.page__intro {
	background-color: #325158;
	background-image: url("data:image/svg+xml,%3Csvg width='32' height='26' viewBox='0 0 			32 26' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 0v3.994C14 7.864 10.858 11 7 11c-3.866 0-7-3.138-7-7.006V0h2v4.005C2 6.765 4.24 9 7 9c2.756 0 5-2.236 5-4.995V0h2zm0 26v-5.994C14 16.138 10.866 13 7 13c-3.858 0-7 3.137-7 7.006V26h2v-6.005C2 17.235 4.244 15 7 15c2.76 0 5 2.236 5 4.995V26h2zm2-18.994C16 3.136 19.142 0 23 0c3.866 0 7 3.138 7 7.006v9.988C30 20.864 26.858 24 23 24c-3.866 0-7-3.138-7-7.006V7.006zm2-.01C18 4.235 20.244 2 23 2c2.76 0 5 2.236 5 4.995v10.01C28 19.765 25.756 22 23 22c-2.76 0-5-2.236-5-4.995V6.995z' fill='%2329abc2' fill-opacity='0.14' fill-rule='evenodd'/%3E%3C/svg%3E");
}

svg {
  padding: 0;
  position: absolute;
  top: 0;
  width: 100%;
  height: 3vw;
  /* set height to pixels if you want angle to change with screen width */
}

/*** HOMEPAGE ***/
#hp-intro {
	background-color: #325158;
	padding-bottom: 4rem;
}
#hp-intro p,
#hp-intro-heading {
	padding: 0 2rem;
}
#hp-intro-heading {
	font-weight: 400;
	margin-bottom: 2rem;
	padding-top: 2rem;
}
#hp-intro p {
	font-weight: 300;
}

#hp-portfolio-btn {
	background: #4a62a7;
	border: 3px solid transparent;
	border-radius: 3px 3px 0 0;
	color: #fff;
	display: inline-block;
	font-size: 1.6rem;
	margin: 4rem 0 0 0;
	padding: 1.5rem;
	transition: all .6s;
}
#hp-portfolio-btn:hover,
#hp-portfolio-btn:focus {
	background: #3453ba;
}

.project__hp {
	border-bottom: 1px solid #ecf4f5;
	padding: 4rem 2rem;
}
.project__type {
	display: block;
	font-size: 1.4rem;
}
.project__title {
	margin: 0 0 1.5rem 0;
}
.project__title a {
	color: #325158;
}
.project__title a:hover,
.project__title a:focus {
	color: #30cbe8;
}

.project__container {
	background: #ecf4f5;
	margin-bottom: 4rem;
	padding-bottom: 4rem;
}
.project__image-hp,
.project__image {
	width: 100%;
	height: auto;
}
.project__button {
	
}
.image__wrap-mobile {
	display: flex;
	justify-content: space-around;
}
.image__wrap-mobile .project__image {
	max-width: 202px;
}
.project__image-hp {
	max-width: 425px;
	transition: opacity .6s;
}
.project__image-hp:hover,
.project__image-hp:focus {
	opacity: .8;
}
.project__image-main {
	padding: 0 2rem;
}
.project__heading-main {
	margin-bottom: 2rem;
}
.project__heading-main:before {
	content: '';
	border-top: 5px solid #4a62a7;
	display: block;
	margin-bottom: .5rem;
	width: 45px;
}
.image__preview-link { display: block; }
.image__preview-link:hover,
.image__preview-link:focus {
	box-shadow: 1px 1px 10px 5px rgba(0,0,0,0.2);
}
.image__external-link {
	margin-top: 1rem;
}

.project__thoughts {
	font-size: 2.5rem;
	margin-top: 5.25rem;
	opacity: .4;
}


/** Animated Down Arrow **/

#hp-projects {
	position: relative;
}
.arrow__down {
	position: absolute;
	top: 0;
	left: 48.2%;
	text-align: center;
}
.bounce {
	-moz-animation: bounce 3.5s infinite;
	-webkit-animation: bounce 3.5s infinite;
	animation: bounce 3.5s infinite;
}
@-webkit-keyframes bounce {
  0% {
    -webkit-transform: translate(0, 0);
  }
  20% {
    -webkit-transform: translate(0, 10px);
  }
  40% {
    -webkit-transform: translate(0, 0);
  }
}
@keyframes bounce {
  0% {
    transform: translate(0, 0);
  }
  20% {
    transform: translate(0, 10px);
  }
  40% {
    transform: translate(0, 0);
  }
}



/**** CTA ****/

.button__container {
    margin: 2rem 0 0 0;
    text-align: center;
    transition: all .6s;
}
#contact-cta {
	background: #325158;
	color: #fff;
	text-align: center;
}
.cta__wrapper {
	border-top: 5px solid #30cbe8;
	display: flex;
    align-items: center;
    justify-content: center;
    padding: 4rem 0;	
}
.cta__heading {
	font-size: 1.8rem;
	font-weight: normal;
	margin-right: 2rem;
}
.cta__link {
	color: #fff;
	padding: 2rem 0;
}
.cta__link:hover,
.cta__link:focus {
	color: #fff;
	text-decoration: underline;
}
.cta__li[rel="external"]:after {
	content: '\f08c';
	font-family: "Font Awesome 5 Brands";
}

/*==============================================/  
	
	2: Layout Rules
	
==============================================*/

/*** Subpages ***/

.intro--shadow {
    	box-shadow: inset 0 -100px 0px 0px #ecf4f5;
	}

.page__title,
.project__highlights,
.project__thoughts {
	padding: 2rem 0;
}
.project__heading-secondary {
	border-bottom: 1px solid #30cbe8;
	font-size: 1.8rem;
	font-weight: 300;
	margin: 4rem 0;
	padding-bottom: .75rem;
}
.project__overview .project__heading-main:nth-of-type(2) {
	margin-top: 4rem;
}

.image--shadow {
	box-shadow: 1px 1px 5px 0px rgba(0,0,0,0.2);
}
.image--paper {
	background: #fff;
}

.about__blurb {
	padding-bottom: 2rem;
}
.about__flex,
.flex__container {
	display: flex;
	justify-content: space-between;
}
.about__flex {
	align-items: flex-start;
}
.about__flex-image {
	flex: 0 1;
	margin-left: 6rem;
}
.about__flex-text {
	flex: 1 0;
}


.portfolio-nav {
	background: #ecf4f5;
}

#qai-sitemap {
	align-self: flex-start;
}





/*==============================================/  
	
	3: Modules
	
==============================================*/

/*** NAVIGATION ***/

#logo-menu,
#mobile-menu-button {
	display: flex;
}

#mobile-menu-button { 
	align-self: flex-start;
	justify-content: flex-end; 
	margin-bottom: 2rem; 
	visibility: hidden;
}

#logo-link {
	color: #325158;
}
#logo-link:hover,
#logo-link:focus {
	color: #30cbe8;
}

#pull {
	margin-right: 2rem;
	text-align: center;
}



.menu,
.menu__sub { list-style: none; }
.menu {
	display: flex;
	justify-items: center;
}
.menu__item:not(.last) {
	margin-right: 2rem;
}
.menu__link, .current {
	display: block;
	padding: 1rem 2rem 0 2rem;
}

#portfolio-nav {
	background: #ecf4f5;
}
#portfolio-nav-heading {
	padding-left: 1.5rem;
}
.portfolio__item {
	font-size: 1.4rem;
	padding: 1rem;
}
 .menu__item:not(.last) {
	margin: .5rem;
}

/** For Dropdown Menus **/
nav ul ul { display: none; }


/*==============================================/  
	
	4: Helper Classes
	
==============================================*/

.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}
.clearfix:after {
    clear: both;
}
.clearfix {
    *zoom: 1;
}

.u-push--top {
	margin-top: 4rem;
}
.u-push--bottom {
	margin-bottom: 4rem;
}

.text--center {
	text-align: center;
}

.padding--1-all {
	padding: 1rem;
}

/*==============================================/  
	
	5: State Rules
	
==============================================*/



/*==============================================/  
	
	6: Media Queries
	
==============================================*/

/**** Larger Than ****/

@media only screen and (min-width: 768px) {

	h3 {
		font-size: 2.4rem;
	}
	
	.project__section--centered  {
		margin: 0 auto;
		max-width: 50%;
	}

	header .container {
		display: flex;
		justify-content: space-between;
	}
	
	#pull { display: none; }

	.container {
		margin: 0 auto;
		padding: 2rem;
	}
	#hp-intro {
		padding: 6rem 0 4rem 0;
	}
	#hp-intro-heading {
		font-size: 3.6rem;
	}
	#hp-intro p,
	#hp-intro-heading {
		padding: 0
	}
	#hp-intro p {
		font-size: 2.4rem;
		max-width: 75ch;
	}
	
	#hp-projects {
		display: flex;
		flex-wrap: wrap;
		align-content: space-around;
		margin: 0 auto;
		padding: 4rem 0;
		width: 75%;
	}
	.project__hp {
	 	border: 1px solid #eee;
	    box-shadow: 1px 1px 5px #eee;
		display: flex;
		flex-direction: column;
		flex: 1 0 350px;
		margin: 2rem;
	}
	.project__hp > * {
		flex: 0 1 50%;
	}
	.project__hp figure {
		margin-bottom: 2rem;
		order: 1;
	}
	.project__hp .project__text {
		order: 2;
	}
	.project__button {
		background: transparent;
		border: none;
		color: #4a62a7;
		padding: 0;
	}
	.project__button:after {
		content: '\f105';
	}
	.project__button:hover,
	.project__button:focus {
		background: transparent;
		color: #30cbe8;
	}

	
	#research-pages-project .project__text,
	#cfs-project .project__text,
	#nz-project .project__text {
		order: 2;
	}
	
	#matrix {
		max-width: 750px;
	}

	
	#student-portal-project .project__text { min-width: 100%; }
	
	/**** Navigation ****/
	
	#portfolio-item:after {
		content: '\f0d7';
	}
	
	.current:before {
		border-top: 5px solid #30cbe8;
		content: '';
		display: block;
		margin-bottom: .5rem;
		width: 30px;
	}
	
	/* Submenus */
	
	
	
	nav .menu__parent {
		padding: 1rem 2rem 1rem 2rem;
    	position: relative;
	}
	nav .menu__parent:hover,
	nav .menu__parent:focus {
		background: #ecf4f5;
    	border-top: 5px solid #30cbe8;
    	padding-top: .5rem;
    }
    nav .menu__parent:hover:before,
	nav .menu__parent:focus:before {
		border-top-color: transparent;
	}
	nav .menu__parent:hover > ul, 
	nav .menu__parent:focus > ul { 
		display: block; 
	}

	.menu__sub {
		background: #ecf4f5;
    	box-shadow: 3px 3px 5px 0px rgba(102,102,102,.2);
    	float: none;
    	height: auto;
    	list-style: none;
    	margin: 0;
    	position: absolute;
    	top: 47px;
    	left: 0;
    	width: 300px;
    	z-index: 2000;
    }
    .menu__sub li {
    	padding: .5rem 0;
    }
    .menu__sub li:last-of-type {
    	padding-bottom: 1rem;
    }
    .menu__sub li:hover,
    .menu__sub li:focus {
    	background: #30cbe8;
    }
    .menu__sub a,
    .current__title {
    	padding: 0 2rem;
    }
    .current__page {
    	background: #30cbe8;
    	color: #fff;
    }
    .menu__sub a,
    .current__title {
    	color: #325158;
    	display: block;
    	font-size: 1.4rem;
    }
    .menu__sub li:hover a,
    .menu__sub li:focus a,
    .menu__sub li:active a {
    	color: #fff;
    }
	
	#top-button {
  		background-color: #4a62a7;
  		border-radius: 50%;
		display: inline-block;
  		height: 50px;
  		margin: 3rem;
  		position: fixed;
  			bottom: 20.5rem;
  			right: 3rem;
  		text-align: center;
  		transition: background-color .3s, 
    	opacity .5s, visibility .5s;
  		opacity: 0;
  		visibility: hidden;
  		width: 50px;
  		z-index: 1000;
	}
	#top-button:hover,
	#top-button:focus {
		background-color: #333;
	}
	#top-button:active {
		background-color: #555;
	}
	#top-button:after {
  		content: "\f077";
  		font-family: "Font Awesome 5 Pro", "Font Awesome 5 Free";
  		font-weight: 900;
  		font-size: 1em;
  		line-height: 50px;
  		color: #fff;
	}
	#top-button.show {
  		opacity: .8;
  		visibility: visible;
	}
	
	
	/*** Subpages ***/
	.intro--shadow {
    	box-shadow: inset 0 -250px 0px 0px #ecf4f5;
	}
	
	.project__flex {
		display: flex;
		justify-content: space-between;
	}
	.project__overview {
		flex: 0 1 100%;
	}
	.project__highlights,
	.project__thoughts {
		flex: 0 0 35%;
		margin-left: 4rem;
	}
	.flex--children-max2,
	.flex--children-max3 {
		flex-wrap: wrap;
		max-width: 900px;
	}
	.flex--children-max2 figure,
	.image__wrap-mobile,
	.project__flex-textbox {
		flex: 0 0 48%;
	}
	.flex--children-max3 figure {
		flex: 0 0 32%;
	}
	.flex--children-max4 figure {
		flex: 0 0 195px;
	}
	.flex--children-max2 .image--full-width {
		flex: 0 0 100%;
	}
	.max--65 {
		max-width: 65%;
	}
	
	
	
	
	
}

@media only screen and (min-width: 769px) {

	.menu__link:before {
		border-top: 5px solid transparent;
		content: '';
		display: block;
		margin-bottom: .5rem;
		width: 55%;
	}
	.current:before {
		border-top-color: #30cbe8;
	}
	.column--single {
		margin: 0 auto;
		max-width: 50%;
	}
	.content--columns {
		column-count: 2;
	}
	.content--columns + .content--columns {
		margin-top: 2rem;
	}
	.flex--children-max2 figure {
		margin-bottom: 4rem;
	}
	
	#portfolio-nav {
    	margin-top: 8rem;
	}

}


@media only screen and (min-width: 900px) {

	.container {
		margin: 0 auto;
		max-width: 1200px;
		width: 75%;
	}
	
	.intro--shadow {
    	box-shadow: inset 0 -300px 0px 0px #ecf4f5;
	}

}



/**** Smaller Than ****/


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

	h1 {
		line-height: 1;
	}

	#logo-menu > * { flex: 1 1 50%; }

	#mobile-menu-button { 
		flex: 0 1 30%;
		visibility: visible; 
	}
	#pull {
		display: inline-block;
		margin: 0;
	}
	#main-menu { display: none; }
	#main-menu.js-open {
		display: flex;
		justify-content: center;
	}
	
	#main-menu .menu {
		flex-direction: column;
		width: 100%;
	}
	
	.menu__item {
		border: 1px solid #4a62a7;
		margin: 0;
		min-height: 54px;
		text-decoration: none;
	}
	.menu__item:hover,
	.menu__item:focus,
	.menu__subitem:hover,
	.menu__subitem:focus {
		background: #30cbe8;
		border-color: #30cbe8;
		color: #fff;
	}
	.menu__item:not(.last) {
    	margin: .5rem 0;
	}
	#main-menu .menu__link:not(#portfolio-item), 
	.menu__sub li a,
	.current__title { 
		padding: 1.5rem 1rem; 
	}
	.menu__sub li { 
    	background: #888;
	}
	.menu__sub li:not(:last-of-type) { 
    	border-bottom: 1px solid #fff;
	}
	.menu__sub li:first-of-type { 
    	border-top: 1px solid #fff;
	}
	.menu__sub li a,
	.current__title { 
		color: #fff;
		display: block; 
		min-height: 54px;
	}
	.current__title {
		background: #325158;
	}
	#main-menu li:hover a,
	#main-menu li:focus a,
	#portfolio-nav .menu__link a:hover,
	#portfolio-nav .menu__link a:focus
	.menu__subitem a { 
		color: #fff;
	}
	
	.current:hover:not(#portfolio-item),
	.current:focus:not(#portfolio-item) {
		background: #fff;
		border-color: #30cbe8;
		color: #325158;
	}
	.current {
		border-top: 1px solid #325158;
    	padding: 1rem;
    	border-right: 1px solid #325158;
    	border-left: 1px solid #325158;
    	border-bottom: 1px solid #325158;
    	border-top: 5px solid #30cbe8;
    	margin: 0;
	} 
	#portfolio-item:after {
		display: none;
	}
	.js-dropdown--expanded .menu__parent {
		padding: 0;
	}
	.js-dropdown--expanded .menu__parent-link {
		display: block;
		padding: 1.5rem 1rem;
	}
	.plus:after,
	.minus:after {
		content: '\f067';
		font-size: 1.2rem;
		position: absolute:
		right: 20px;
	}
	.minus:after {
		content: '\f068';
	}


	
	#site-name {
		font-size: 2.4rem;
		margin: 0;
	}
	#site-subtitle {
		font-size: 1.6rem; 
	}
	
	.arrow__down {
		left: 46%;
	}
	
	.project__image-hp,
	.image__wrap-mobile {
		margin: 4rem 0 2rem 0;
	}
	
	.image__wrap-mobile figure {
		flex-basis: 50%;
	}
	.image__wrap-mobile figure:last-of-type {
		margin-left: 2rem;
	}
	
	.page__title {
		text-align: center;
	}
	.project__container--highlight {
		background: #ecf4f5;
		margin-bottom: 2rem;
	}
	.project__section {
		padding: 2rem;
	}
	.project__section:not(:last-of-type) {
		margin-bottom: 2rem;
	}
	.project__overview { 
		margin-bottom: 2rem;
	}
	.project__heading-secondary {
		margin: 0 2rem;
	}
	.project__heading-blurb {
		margin: 4rem 0 2rem 0;
	}
	.project__flex-textbox + .project__flex-textbox {
		margin-top: 4rem;
	}
	.flex--single {
		flex: 1 0 50%;
	}
	
	figure {
		margin-top: 2rem;
	}
	.page__about .container {
		padding: 2rem;
	}
	.about__flex {
		align-items: flex-start;
		flex-direction: column;
	}
	.about__flex-text {
		order: 2;
		padding: 0 2rem 2rem 2rem;
	}
	.about__flex-image {
		order: 1;
		margin: 0 auto;
		padding: 2rem;
	}

	.cta__wrapper,
	.portfolio__menu {
		flex-direction: column;
	}
	#portfolio-nav {
		padding: 2rem;
	}
	#portfolio-nav-heading {
		padding-left: .5rem;
	}
	#portfolio-nav .menu__link {
		padding: 0;
	}
	#portfolio-nav .menu__link a {
		display: block;
		padding: 1.75rem 1rem;
	}
}



/*==============================================/  
	
	7: Print Styles
	
============================================= */


@media print {
  
  
  body {
      background: #fff !important;
      color: #000;
      font: 13pt Georgia, "Times New Roman", Times, serif;
      letter-spacing: normal;
      line-height: 1.3;
    }
	
   h1, h2, h3, h4, h5, h6 {
     color: #000;
     font-weight: bold;
     margin: 20px 0;
   } 
  
   ul li {
     margin: 0;
   }
	
   * {
	  float: none;
	  font-size: 10pt;
	  letter-spacing: normal;
	  line-height: 20pt;
	}
    
  img {
    border: none;
    max-width: 100% !important;
  }

  
  
  
  /* Displaying link color and link behavior */
	a:link, a:visited, a,
	.button {
	  background: transparent;
	  border: none;
	  box-shadow: none;
	  color: #005596;
	  text-align: left;
	  font-weight: bold;
	}
	
	h1 a:link { text-decoration: none; }
	
	a[href^="http"]:after,
	a.button:after
	{
	  content: " (" attr(href) ") ";
	  font-size: 90%;
	}
	
	a[href^="#"]:after {
	 content: "";
   }
   
/* Defining all page breaks */
  a, img, blockquote,
	 h1, h2, h3, h4, h5, h6, form, .button {
   page-break-inside: avoid;
	}
  
  h1, h2, h3, h4, h5, h6,
  img {
	   page-break-after:avoid;
	}
	
	table, pre { page-break-inside:avoid }
	ul, ol, dl  { page-break-before:avoid }
	
	
	/*** hiding unecessary elements for print ***/
	nav,
	svg,
	footer,
 	.callout {
	  display: none;
	}

	.container::after, .row::after {
	  display: block;
	}
	.container {
	  padding: 0;
	}
	
	main {
	  margin: 25px 0;
	  padding: 0;
	}
	

  
  /*** form print styles ***/
  
	input[type="email"],
	input[type="number"],
	input[type="search"],
	input[type="text"],
	input[type="tel"],
	input[type="url"],
	input[type="password"],
	textarea,
	select {
	  border-bottom: 1px solid #d1d1d1;
	  border-top: none;
	  border-left: none;
	  border-right: none;
	  color: #000;
	  height: auto;
	  padding: 0;
	  width: 90%;
	}
	
	
	

 
/** Setting margins */       
@page { margin: 2cm }
	
	
	
}












