/*
	colours
	base: 	rgba(220, 40, 60, 1.0); 	220-40-60
	dark: 	rgba(180, 0, 40, 1.0);		180-0-40
	links: 	rgba(0, 120, 200, 1.0);		0-120-200
	hover:	rgba(0, 90, 160, 1.0);		0-90-160
*/

body {
	font-family: 'Helvetica Neue','Helvetica','Open Sans',Roboto,Oxygen,Ubuntu,Cantarell,'Arial',sans-serif;
	/* system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif */
}
h1 {
	margin: 72px 0;
	font-size: 72px;
	line-height: 72px;
	font-weight: 900;
	color: rgba(220, 40, 60, 1.0);
}
h2 {
	margin: 60px 0;
	font-size: 60px;
	line-height: 60px;
	font-weight: 800;
	color: rgba(220, 40, 60, 1.0);
}
h3 {
	margin: 48px 0;
	font-size: 48px;
	line-height: 48px;
	font-weight: 700;
	color: rgba(220, 40, 60, 1.0);
}
h4 {
	margin: 32px 0;
	font-size: 32px;
	line-height: 32px;
	font-weight: 600;
	color: rgba(220, 40, 60, 1.0);
}
h5 {
	margin: 24px 0;
	font-size: 24px;
	line-height: 24px;
	font-weight: 500;
	color: rgba(220, 40, 60, 1.0);
}
h6 {
	margin: 21px 0;
	font-size: 21px;
	line-height: 21px;
	font-weight: 400;
	color: rgba(220, 40, 60, 1.0);
}
p {
	font-size: 24px;
	color: rgba(220, 40, 60, 1.0);
}
a, a:focus, a:active, a:visited {
	font-weight: 600;
	color: rgba(0, 120, 200, 1.0);
	text-decoration: none;
	/* text-decoration: underline; */
	transition: all 0.2s ease-in-out;
}
a:hover {
	color: rgba(0, 90, 160, 1.0);
	text-decoration: underline;
}
ul {
	margin: 0 0 0 30px;
	padding: 0;
}
ul li {
	font-weight: 300;
}
ul.flush {
	margin: 0;
	padding: 0;
}
ul.flush li {
	margin: 0;
	padding: 16px 0 0;
	list-style-type: none;
}
h1, h2, h3, h4, h5, h6, p, a {
	word-wrap: break-word;
	/* word-break: break-all; */
}
svg {
	margin: -4 0 0 0;
	padding: 0;
}

.scroll {
	overflow-y: scroll;
}
.noscroll {
	overflow: hidden;
}
.hidden {
	display: none !important;
}
.opener:before {
	background: rgba(220, 40, 60, 0.3);
	content: "\020";
	display: block;
	height: 2px;
	margin: 0 0 60px 0;
	width: 60px;
}
.closer:after {
	background: rgba(220, 40, 60, 0.3);
	content: "\020";
	display: block;
	height: 2px;
	margin: 60px 0 0 0;
	width: 60px;
}

/* main container */
/* #main {} */

.container-fluid {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* main menu */
#main-menu {
	position: fixed;
	float: right;
	top: 80px;
	right: 10px;
	width: auto;
	padding: 0;
	border-radius: 12px 0 0 12px;
	background-color: rgba(255, 255, 255, 0.0);
	transition: all 0.2s ease-in-out;
	z-index: 12;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
}
#main-menu:hover {
	background-color: rgba(255, 255, 255, 0.0);
}
#main-menu a {
	display: block;
	height: 38px;
	padding: 4px 8px;
	color: rgba(0, 120, 200, 1.0);
	text-align: right;
	text-decoration: none;
	border-radius: 8px;
}
#main-menu a .header-menu-label {
	display: none;
	visibility: hidden;
}
#main-menu a svg {
	height: 33px;
	/* margin-top: 2; */
}
#main-menu:hover a {
	color: rgba(0, 120, 200, 1.0);
}
#main-menu:hover a .header-menu-label {
	display: inline;
	visibility: visible;
}
#main-menu a:hover .header-menu-label {
	display: inline;
	visibility: visible;
}
#main-menu a:hover {
	color: rgba(255, 255, 255, 1.0);
	border-radius: 8px;
	background-color: rgba(0, 120, 200, 1.0);
}

/* header */
#header {
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	text-shadow: 0 0px 4px rgba(0, 0, 0, 0.35);
}

#header .header-featured-image {
	overflow: hidden;
	position: relative;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	min-height: 80vh;
}
#header .header-featured-image:before {
	background-color: rgba(220, 40, 60, 1.0);
	mix-blend-mode: screen;
	opacity: 0.1;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	content: "\020";
	width: 100%;
	height: 100%;
}
#header .header-featured-image:after {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	content: "\020";
	width: 100%;
	height: 100%;
	background-color: rgba(220, 40, 60, 1.0);
	opacity: 1;
	z-index: 3;
	mix-blend-mode: multiply;
}
#header .header-featured-image .post-thumbnail {
	margin: 0;
	overflow: hidden;
}
#header .header-featured-image .post-thumbnail img {
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	max-width: 1000%;
	min-height: 100%;
	min-width: 100vw;
	object-fit: cover;
    filter: grayscale(100%);
	border-style: none;
	position: absolute;
	transform: none;
	opacity: 0.85;
	z-index: 1;
}

#header .header-large {
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 45%;
	z-index: 4;
}
#header .header-large .site-title {
	margin: 0;
	color: rgba(255, 255, 255, 1.0);
}
#header .header-large .site-subtitle {
	margin: 20px 0 0;
	font-size: 36px;
	line-height: 36px;
	font-weight: 300;
	color: rgba(255, 255, 255, 1.0);
}
#header .header-large .site-description {
	margin: 20px 0 0;
	font-size: 21px;
	line-height: 24px;
	font-weight: 200;
	color: rgba(255, 255, 255, 1.0);
}
#header .header-large .site-caption {
	position: absolute;
	bottom: 40px;
	font-size: 18px;
	color: rgba(255, 255, 255, 1.0);
}

/* sections */
.section {
	padding-top: 15px;
	padding-bottom: 45px;
}
.section .section-title {
	font-size: 32px;
	line-height: 32px;
	margin: 30px 0 10px;
	color: rgba(220, 40, 60, 1.0);
}

h3.all-projects-link {
	margin: 120px 0;
}

/* featured projects */
.project {
	position: relative;
	margin: 60px 0 0;
	padding: 0;
}
.project.fullsize {
	margin-top: 0;
}
.project .project-header {
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
	text-shadow: 0 0px 4px rgba(11, 44, 77, 0.35);
}
.project .project-title {
	margin: 40px 0 10px;
	font-size: 48px;
	line-height: 48px;
	color: #fff;
}
.project .project-subtitle {
	margin: 10px 0;
	font-weight: 300;
}
.project .project-details {
	color: rgba(220, 40, 60, 1.0);
}
.project .project-header .project-site-header {
	display: none;
	position: absolute;
	float: left;
	top: 80px;
	width: 100%;
	margin: 0;
	background-color: rgba(255, 255, 255, 0.0);
	z-index: 10;
}
.project .project-header .project-site-header .site-title {
	margin: 0;
	padding: 0;
	color: #fff;
	opacity: 0.9;
}
.project .project-header .project-site-header .site-subtitle {
	color: #fff;
	opacity: 0.6;
}
.project .project-header .project-title-header {
	position: absolute;
	float: left;
	bottom: 80px;
	width: 100%;
	margin: 0;
	background-color: rgba(255, 255, 255, 0.0);
	z-index: 10;
}
.project .project-header .project-title-header .project-title {
	position: relative;
	margin: 40px 0 20px;
}
.project .project-header .project-title-header .project-subtitle {
	color: #fff;
	margin-top: 0;
	padding: 0;
}
.project .project-header .project-title-header .project-details {
	margin: 20px 0 0;
}
.project .project-header .project-featured-image {
	overflow: hidden;
	position: relative;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	min-height: 80vh;
}
.project .project-header .project-featured-image:before {
	background: rgba(220, 40, 60, 1.0);
	mix-blend-mode: screen;
	opacity: 0.1;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	content: "\020";
	width: 100%;
	height: 100%;
}
.project .project-header .project-featured-image:after {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	content: "\020";
	width: 100%;
	height: 100%;
	background: rgba(220, 40, 60, 1.0);
	opacity: 1;
	z-index: 3;
	mix-blend-mode: multiply;
}
.project .project-header .project-featured-image .post-thumbnail {
	margin: 0;
	overflow: hidden;
}
.project .project-header .project-featured-image .post-thumbnail::selection {
	background: rgba(255, 255, 255, 0.17);
}
.project .project-header .project-featured-image .post-thumbnail img {
	height: 100%;
	left: 0;
	object-fit: cover;
	top: 0;
	transform: none;
	width: 100%;
    filter: grayscale(100%);
	max-width: 1000%;
	min-height: 100%;
	min-width: 100vw;
	position: absolute;
	z-index: 1;
	border-style: none;
}
.project .project-desc {
	position: relative;
	padding-top: 10px;
	font-size: 24px;
	font-weight: 500;
	color: rgba(220, 40, 60, 1.0);
}
.project .project-desc h3 {
	font-size: 24px;
}
.project .project-desc p {
	padding-top: 4px;
	font-size: 21px;
	line-height: 28px;
	font-weight: 300;
	color: rgba(220, 40, 60, 1.0);
}
.project .project-desc .gallery {
	margin: 60px 0 30px;
}
.project .project-desc .gallery:before {
	background: rgba(220, 40, 60, 0.5);
	content: "\020";
	display: block;
	height: 2px;
	margin: 0 0 60px 0;
	width: 60px;
}
.project .project-desc .gallery .gallery-col p {
	margin: 0;
	padding: 0;
}
.project .project-desc .gallery .gallery-col img.gallery-image {
	display: inline-block;
	width: 100%;
	margin: 20px 20px 40px 0;
	padding: 0;
	/* border: 1px solid #ddd; */
	border: 0px solid #fff;
	transform: scale(1.0);
	transition: all 0.2s ease-in-out;
}
.project .project-desc .gallery.image-shadow .gallery-col img.gallery-image {
	border: 0px solid #fff;
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}
.project .project-desc .gallery .gallery-col img.gallery-image:hover {
	/* border: 1px solid #ff4a14; */
	transform: scale(1.05);
}
.project .project-desc .gallery .gallery-col * {
	text-decoration: none !important;
}
.project .project-cover {
	width: 100%;
}
.project .project-image-link {
	position: relative;
	/* float: left; */
	width: 100%;
	height: 600px;
	/* border: 1px solid red; */
}
.project .project-content {
	display: block;
}
.project .project-categories {
	padding-top: 10px;
	font-size: 24px;
	line-height: 28px;
	color: rgba(220, 40, 60, 0.4);
	font-weight: 300;
}
.download-image {
	/* float: right; */
	margin-top: 20px;
	width: 180px;
	height: auto;
	transition: all 0.2s ease-in-out;
	transform: scale(1.0);
}
.download-image:hover {
	transform: scale(1.05);
}
.download-app-button {
	margin-top: 40px;
}

/* testimonials */
/* .testimonials {} */

.testimonial {
	margin: 60px 0 30px;
	padding: 0;
}
.testimonial:after {
	background: rgba(220, 40, 60, 0.4);
	content: "\020";
	display: block;
	height: 2px;
	margin: 60px 0 0 0;
	width: 60px;
}
.testimonial .testimonial-quote {
	padding-left: 46px;
	font-size: 21px;
	font-weight: 300;
	color: rgba(220, 40, 60, 0.5);
	background-image: url(../../images/smart-quotes-open.svg);
	background-size: 36px 24px;
	background-position: 0px 6px;
	background-repeat: no-repeat;
}
.testimonial .testimonial-name {
	padding-left: 46px;

}
.testimonial .testimonial-role {
	padding-left: 46px;
	display: none;
}
.testimonial .testimonial-relation {
	padding-left: 46px;
	color: rgba(220, 40, 60, 0.8);
}

/* thoughts featured */
.thought {
	margin: 60px 0 30px;
	padding: 0;
}
.thought.fullsize {
	margin-top: 0;
}
.thought .thought-id {
	margin: 0;
	padding: 0;
}
.thought .thought-title {
	margin: 10px 0;
	padding: 0;
}
.thought .thought-header {
	margin: 0 0 120px 0;
	padding: 0;
	height: 640px;
	background-color: rgba(220, 40, 60, 1.0);

	position: relative;
	overflow: hidden;
	text-shadow: 0 0px 4px rgba(0, 0, 0, 0.35);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}
.thought .thought-header .thought-featured-image {
	width: 100%;
	height: 100%;
}
.thought .thought-header .thought-featured-image:before {
	background: rgba(220, 40, 60, 1.0);
	mix-blend-mode: screen;
	opacity: 0.1;
}
.thought .thought-header .thought-featured-image:after {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	content: "\020";
	width: 100%;
	height: 1000%;
	opacity: 1;
	background: rgba(220, 40, 60, 1.0);
	z-index: 3;
	mix-blend-mode: multiply;
}
.thought .thought-header .thought-featured-image .post-thumbnail::selection {
	background: rgba(255, 255, 255, 0.17);
}
.thought .thought-header .thought-featured-image .post-thumbnail img {
	height: 100%;
	left: 0;
	object-fit: cover;
	top: 0;
	transform: none;
	width: 100%;
	-webkit-filter: grayscale(100%);
    filter: grayscale(100%);
}

.thought .thought-header .thought-site-header {
	display: block;
	position: absolute;
	float: left;
	top: 80px;
	width: 100%;
	margin: 0;
	background-color: rgba(255, 255, 255, 0.0);
	z-index: 10;
}

.thought .thought-header .thought-site-header .thought-id {
	margin: 40px 0 0;
	color: #fff;
	opacity: 0.3;
}
.thought .thought-header .thought-site-header .thought-title {
	margin: 240px 0 60px;
	padding: 0;
	font-size: 90px;
	color: #fff;
	opacity: 1.0;
}
.thought .thought-content-short {
	font-size: 21px;
}
.thought .thought-content {
	margin: 40px 0 120px;
	padding: 0;
	line-height: 40px;
}
.thought .thought-content h1,
.thought .thought-content h2,
.thought .thought-content h3 {
	margin: 60px 0 30px;
}
.thought .thought-content h4,
.thought .thought-content h5,
.thought .thought-content h6 {
	margin: 40px 0 20px;
}
.thought .thought-content p,
.thought .thought-content ul,
.thought .thought-content ol {
	margin: 30px 0 20px;
	font-size: 32px;
	line-height: 40px;
	font-weight: 300;
}
.thought .thought-end {
	font-size: 32px;
	color: rgba(220, 40, 60, 0.4);
	text-align: center;
	margin: 0 0 120px;
}

.info .info-container {
	margin: 40px 0;
	padding: 0;
	line-height: 40px;
}
.info .info-container h1,
.info .info-container h2,
.info .info-container h3 {
	margin: 60px 0 30px;
}
.info .info-container h4,
.info .info-container h5,
.info .info-container h6 {
	margin: 40px 0 20px;
}
.info .info-container p,
.info .info-container ul,
.info .info-container ol {
	margin: 30px 0 20px;
	font-size: 32px;
	line-height: 40px;
	font-weight: 300;
}

ul.contact-list {
	margin: 0;
}
ul.contact-list li a {
	font-size: 32px;
}

/* article overlay */
#article_overlay {
	position: fixed;
	display: block;
	top: 0;
	left: 100%;
	right: -100%;
	bottom: 0;
	background-color: #fff;
	overflow-y: scroll;
	transition: all 0.5s ease-in-out;
	z-index: 10;
}
#article_overlay .article-topbar {
	position: fixed;
	visibility: hidden;
	top: 0;
	left: 0;
	right: 0;
	margin: 0;
	padding: 30px 0;
	z-index: 15;
	background-color: rgba(255, 255, 255, 0.0);
}
#article_overlay .article-topbar .container {
	width: 100%;
}
#article_overlay .article-topbar .article-back {
	margin: 0;
	padding: 8px 12px;
	background-color: rgba(0, 120, 200, 1.0);
	border-radius: 12px;
	color: #fff;
}
#article_overlay .article-topbar .article-back:hover {
	background-color: rgba(0, 90, 160, 1.0);
	color: #fff;
}
#article_overlay .article-content {
	position: relative;
	/* margin-top: 120px; */
	overflow-y: scroll;
}

/* #image overlay */
#image_overlay {
	position: fixed;
	display: block;
	top: 0;
	left: 100%;
	right: -100%;
	bottom: 0;
	background-color: #fff;
	overflow-y: scroll;
	transition: all 0.5s ease-in-out;
	z-index: 10;
	background-color: rgba(255, 255, 255, 1.0);
}
#image_overlay .image-topbar {
	position: fixed;
	visibility: hidden;
	top: 0;
	left: 0;
	right: 0;
	margin: 0;
	padding: 30px 0;
	z-index: 15;
	background-color: rgba(255, 255, 255, 0.0);
}
#image_overlay .image-topbar .container {
	width: 100%;
}
#image_overlay .image-topbar .image-back {
	margin: 0;
	padding: 0;
}
#image_overlay .image-content {
	position: relative;
	margin: 80px 20px 0;
	height: 92%;
	overflow-y: scroll;
	text-align: center;
	/* outline: 1px solid red; */
}
#image_overlay .image-content img {
	max-width: 100%;
	height: auto;
	padding: 10px;
	transform-origin: 0 0;
	/* border: 1px solid #eee; */
	/* border: 0px solid #fff; */
	/* box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px; */
}

.bg-block {
	background-color: rgba(220, 40, 60, 1.0) !important;
}
.bg-ultradark {
	background-color: rgba(220, 40, 60, 0.9) !important;
}
.bg-superdark {
	background-color: rgba(220, 40, 60, 0.8) !important;
}
.bg-dark {
	background-color: rgba(220, 40, 60, 0.7) !important;
}
.bg-medium-dark {
	background-color: rgba(220, 40, 60, 0.6) !important;
}
.bg-medium {
	background-color: rgba(220, 40, 60, 0.5) !important;
}
.bg-medium-light {
	background-color: rgba(220, 40, 60, 0.4) !important;
}
.bg-light {
	background-color: rgba(220, 40, 60, 0.3) !important;
}
.bg-superlight {
	background-color: rgba(220, 40, 60, 0.2) !important;
}
.bg-ultralight {
	background-color: rgba(220, 40, 60, 0.1) !important;
}
.bg-hyperlight {
	background-color: rgba(220, 40, 60, 0.05) !important;
}

/* footer */
#footer {
	display: block;
	padding: 60px 0 120px;
	background-color: rgba(220, 40, 60, 1.0);
}
#footer * {
	color: #fff !important;
}
#footer a {
	text-decoration: underline !important;
}
.footer-info {
	margin: 20px 0;
	padding: 0;
}
.footer-info p {
	margin: 10px 0;
}
.footer-info p a {
	margin: 0 10px;
	display: inline-block;
}
.footer-copyright {
	margin: 0;
	padding: 0;
}

/* MEDIA QUERIES */

/* mobile wide */
@media (min-width: 768px) {
	.section {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	.project {
		margin: 90px 0;
	}
}

/* tablet */
@media (min-width: 1024px) {
	.project {
		margin: 120px 0;
	}
	.section .section-title {
		font-size: 52px;
		margin: 30px 0 10px;
	}
	.project .project-title {
		margin: 40px 0 10px;
		font-size: 72px;
		line-height: 72px;
	}
	ul.contact-list {
		margin: 40px 0;
	}
	ul.contact-list li a {
		font-size: 48px;
	}
}

/* desktop */
@media (min-width: 1280px) {
	h1 {
		margin: 90px 0;
		font-size: 90px;
		line-height: 90px;
		font-weight: 900;
	}
	.project {
		margin: 120px 0;
	}
	.section .section-title {
		font-size: 52px;
		margin: 30px 0 10px;
	}
	.project .project-title {
		margin: 40px 0 10px;
		font-size: 72px;
		line-height: 72px;
	}
}

/* large desktop */
@media (min-width: 1600px) {
	
}
