@import url("https://use.typekit.net/cdv2nwv.css");

@font-face {
  font-family: curlyFont;
  src: url('/assets/fonts/braisetto-regular.otf');
}


body, html {
	margin:0;
	padding:0;
	font-family: "futura-pt", sans-serif;
	color:#354759;
	font-size:16px;
	font-weight: 400;
	line-height: 1.6em;
	scroll-behavior: smooth;
}

.standardText {
	font-family: "futura-pt", sans-serif;
}

h1 {
	font-family: curlyFont;
	font-weight: 100;
	font-size: 55px;
	margin: 35px;
	line-height: 40px;
	margin-left: 0;
    margin-right: 0;
	color: #163c48;
}

.curlyFont {
	font-family: curlyFont;
	font-weight: 100;
}

intro {
	font-family: curlyFont;
	font-size: 34px;
    font-weight: 100;
}

h1.large {
	font-size: 60px;
	line-height: initial;
	margin: 60px;
}

h1.small {
	font-size: 24px;
    margin: 45px;
    line-height: 30px;
    font-weight: 400;
    letter-spacing: 5px;
	word-spacing: 2px;
}

a {
	color:inherit;
	text-decoration:none;
	cursor:pointer;
}

content a {
	color: blue;
}

img {
	display: block;
	height: auto;
	border:0;
	max-width: 100%;
}

container {
	display: block;
	width: 1180px;
	margin: 0 auto;
	position: relative;
	max-width:100%;
}

banner {
	display: block;
	margin-bottom: 50px;
}

content {
	display: block;
	width: 1130px;
	margin: 0 auto;
	position: relative;
	max-width:100%;
}

smallContent, smallContentMenu {
	display: block;
	width: 880px;
	margin: 0 auto;
	position: relative;
	max-width:100%;
}

.desktopOnly {
	display: block;
}

.mobileOnly {
	display: none;
}

.center {
	display:block;
	margin:0 auto;
}

.flex {
	display:flex;
	flex-wrap: wrap;
}

.half {
	width: 50%;
	height: auto;
}

.third {
	width: 33.333%;
	height: auto;
}

.quarter {
	width: 25%;
	height: auto;
}

.fifth {
	width: 20%;
	height: auto;
}

.sixth {
	width: 16.666%;
	height: auto;
}

header {
	padding-top:55px;
}

header logo {
	display: block;
	margin-bottom: 55px;
	max-width: 480px;
	margin: 25px auto 55px auto;
	text-align: center;
}

header logo primaryLogoText {
	margin-left: -15px;
	font-family: curlyFont;
	font-weight: 100;
	font-size: 56px;
	line-height: 55px;
	color: #163c48;
}

header logo secondaryLogoText {
	display: block;
	font-family: "futura-pt", sans-serif;
	color: #b4ccb2;
	font-size: 20px;
	margin-top: -10px;
	letter-spacing: 10px;
	word-spacing: 6px;
}

header nav {
	background-color: #163c48;
	text-transform: uppercase;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 9px;
	padding: 5px;
}

.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
	padding: 0;
	margin: 0;
}

.menu a {
    color: white;
    text-decoration: none;
    padding: 0;
    display: block;
}

.left-menu, .right-menu {
    display: flex;
	width: 100%;
	justify-content: space-between;
}

.center-menu {
    flex-grow: 1;
    display: flex;
    justify-content: center;
	width: 80%;
}

header nav ul li a {
	width: 100%;
	text-align: center;
}

header nav ul li.selected, header nav ul li:hover  {
	font-family: futura-pt-condensed;
	color: #b4ccb2;
	letter-spacing: 14px;
}

.welcomeTitle {
	max-width: 375px;
	margin-top:32px
}

.homeImages {
	margin-top: 45px;
	justify-content: center;
	gap:4px;
}

.homeImages img {
	height: 160px;
	width: auto;
}

gallery h1 {
	margin-top: 65px;
	margin-bottom: 65px;
	text-align: center;
}

gallery images {
	display: flex;
    align-items: center;
    flex-direction: column;
}

gallery imagesContainer images:first-child {
	display: flex;
}

gallery imagesContainer images:nth-child(n+2) {
	display: none;
}

gallery images a {
	display: block;
	width: 75%;
	color: #b4ccb2;
	text-align: center;
    font-size: 17px;
    letter-spacing: 4px;
    margin: 40px;
	line-height: 32px;
}

gallery images a.small {
	width: 55%;
}

gallery images a.large {
	width: 120%;
}

gallery images a:first-child {
	margin-top: 0;
}

gallery images a span:first-of-type {
	margin-top:25px;
	display: block;
}
gallery images a span:nth-child(3) {
	display: block;
	letter-spacing: initial;
}

gallery images img {
	width: 100%;
	height: auto;
}

gallery a.loadMore {
	display: block;
	width: 100%;
	text-align: center;
	margin-top: 0;
	color: #000;
	font-size: 20px;
}

main-image {
	display: block;
	margin-bottom: 10px
}

.painting-info {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.painting-info.vertical main-image {
	width: 63%;
}

.painting-info.vertical .images {
	margin-right: 0%;
	width: 35%;
	align-self: flex-start;
}

.painting-info.vertical .description {
    width: 80%;
    margin-left: auto;
	margin-right: auto;
	align-self: center;
}

.painting-info.square main-image {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	align-self: center;
}

.painting-info.panorama {
	margin-top: 40px;
}

.painting-info.panorama .images img {
	width: 100%;
	margin: 0 0 10px 0;
}

.painting-info.panorama .images img:nth-child(3) {
	margin-bottom: 0;
}

.painting-info .details {
	width: 100%;
}

.painting-info .contact {
	padding: 5px;
	margin: 10px 0;
	width: 100%;
	background-color: #153c48;
	color: #dbe3da;
	text-align: center;
	font-weight: 100;
	font-size: 16px;
	box-sizing: border-box;
}

.painting-info .contact a {
	color: #dbe3da;
	font-weight: 500;
}

.painting-info .images {
	display:flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 42%;
	margin-right: 4%;
	align-self: flex-start;
}

.painting-info .images img {
	width: calc(33% - 6px);
	height: auto;
	cursor: pointer;
	border: 2px inset #ffffff00;
}

.painting-info iframe {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}

.painting-info .images .details img {
	width: 100%;
	height: auto;
}


.painting-info .images img:hover {
	border: 2px inset #8a9f89;
}

.painting-info .images img.active {
	border: 2px inset #6d856c;
}

.painting-info .description {
	margin-top: 18px;
	width: 50%;
	margin-right: 4%;
	font-size: 20px;
	line-height: 36px;
	color: #153c48;
	font-weight: 100;
}

.painting-info .info p {
	font-weight: 500;
	margin: 10px 0;
}

videos iframe {
	width: 100%;
	height: 480px;
	margin-bottom: 75px;

}

.contactTitles {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 670px;
	font-weight: 500;
}

.contactTitle {
	font-weight: 300;
	font-size: 32px;
	text-align: center;
	line-height: 14px;
}

.contactTileImage {
	display: block;
	margin: 0 auto;
	max-width: 550px;
	padding-bottom: 150px;
}

.contactBike {
	width: 200px;
    max-width: 50%;
    margin: 0 auto;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -160px;
    z-index: -1;
}

.mainContactImage {
	max-width: 90%;
	margin-left: auto;
	margin-right: auto;
	margin-bottom:160px;
	margin-top: -70px;
}

footer {
	background-color: #c2d3c1;
	padding: 10px 0 20px;
	margin-top: 70px;
    width: 100%;
    box-sizing: border-box;
}

footer.bottom {
	position: absolute;
	bottom: 0;

}

footer container {
	display: flex;
	justify-content: center;
	align-items: center;
}

footer container img {
	max-height: 28px;
	margin: 5px 5px 0 5px;
}

@media screen and (max-width: 980px) {

	body {
		font-size: 16px;
	}

	h1 {
		font-size: 40px;
		line-height: 35px;
	}

	content {
		max-width: calc(100% - 20px);
		margin-left: 10px;
		margin-right: 10px;
	}

	smallContent {
		max-width: calc(100% - 60px);
		margin-left: 30px;
		margin-right: 30px;
	}

	.desktopOnly {
		display: none;
	}

	.mobileOnly {
		display: block;
	}

	.hidden {
		display: none;
	}

	header {
		padding-top:35px;
	}

	header logo {
		margin-bottom:35px;
	}

	header nav {
		font-size:18px;
	}

	header nav ul {
		display: none !important;
		flex-wrap: wrap;
		width: 100%;
		max-width: none;
	}

	header nav.active ul {
		display: flex !important;
		flex-direction: column;
		display: flex;
		position: absolute;
		top: 5px;
		background-color: #163c48;
		z-index: 5;
		width: 100%;
		padding-bottom: 20px;
	}

	.left-menu, .right-menu, .center-menu {
		flex-direction: column;
		align-items: center;
		width: 100%;
	}

	header nav.active a {
		margin: 8px;
	}

	header nav ul li {
		width: 100% !important;
		text-align: center;
		padding: 20px 0;
	}

	.mobileMenuButton {
		display: flex;
		justify-content: flex-end;
		padding: 5px 10px;
	}

	.portfolioCategoryImage {
		width: 90%;
		margin: 0 auto 75px auto;
		height: auto;
	}

	.subsectionBanner.fullWidth {
		margin-bottom: -45px;
	}

	.aboutFreshAndFun {
		width: 170px;
		margin-left: auto;
		margin-right: 14%;
		margin-top: -8px;
	}

	.aboutCards {
		width: 100%;
		margin-top: -60px;
		z-index: -1;
		position: relative;
	}

	.contactImage {
		width: 60%;
		margin: 0 auto 60px auto;
	}

	.contactBike {
		bottom: -158px;
	}

	.portfolioExamples {
		margin: 35px auto 35px auto;
		width: 90%;
		max-width: 90%;
	}

	.portfolioImages {
		width: calc(100% - 40px);
		margin: 0 auto 75px auto;
		height: auto;
	}

	.portfolioImage {
		width: calc(50% - 10px);
		margin: 0 5px 20px 5px;
	}

	.portfolioSubsectionImage {
		width: 100%;
		margin: 0 2.5% 20% 2.5%;
		height: auto;
	}

	.contactTitles {
		max-width: 100%;
		justify-content: center;
		margin-bottom: 20px;
	}

	.contactTitle {
		margin-bottom: 10px;
		width: 100%;
	}

	.mainContactImage {
		margin-top: -20px;
		max-width: 100%;
	}

	footer {
		margin-top: 45px;
	}

}

@media screen and (max-width: 680px) {

	.homeImages {
		gap: 8px;
	}

	.homeImages img.middle {
		order: -1;
		height: auto;
    	width: calc(100% - 2px);
	}

	.homeImages img {
		height: auto;
    	width: calc(50% - 4px);
	}

	.painting-info main-image, .painting-info.vertical main-image {
		width: 100%;
	}

	.painting-info .images, .painting-info.vertical .images {
		width: 100%;
	}


	.painting-info.panorama .images img {
		width: calc(33% - 6px);
		margin-bottom:0;
	}

	.painting-info .description {
		width: 80%;
		margin-left: auto;
		margin-right: auto;
		align-self: center;
	}
}
