/* -------------------------------------------------------------- Euclid Circular B */

@font-face{
	font-family: euclid;
	src: url("fonts/EuclidCircularB-Light-WebS.eot?#iefix");
	src: url("fonts/EuclidCircularB-Light-WebS.eot?#iefix") format("eot"),
		 url("fonts/EuclidCircularB-Light-WebS.woff2") format("woff2"),
		 url("fonts/EuclidCircularB-Light-WebS.woff") format("woff"),
		 url("fonts/EuclidCircularB-Light-WebS.ttf") format("truetype");
	font-weight: 300;
	font-style: normal;
}

@font-face{
	font-family: euclid;
	src: url("fonts/EuclidCircularB-Regular-WebS.eot?#iefix");
	src: url("fonts/EuclidCircularB-Regular-WebS.eot?#iefix") format("eot"),
		 url("fonts/EuclidCircularB-Regular-WebS.woff2") format("woff2"),
		 url("fonts/EuclidCircularB-Regular-WebS.woff") format("woff"),
		 url("fonts/EuclidCircularB-Regular-WebS.ttf") format("truetype");
	font-weight: 400;
	font-style: normal;
}

@font-face{
	font-family: euclid;
	src: url("fonts/EuclidCircularB-Medium-WebS.eot?#iefix");
	src: url("fonts/EuclidCircularB-Medium-WebS.eot?#iefix") format("eot"),
		 url("fonts/EuclidCircularB-Medium-WebS.woff2") format("woff2"),
		 url("fonts/EuclidCircularB-Medium-WebS.woff") format("woff"),
		 url("fonts/EuclidCircularB-Medium-WebS.ttf") format("truetype");
	font-weight: 500;
	font-style: normal;
}

@font-face{
	font-family: euclid;
	src: url("fonts/EuclidCircularB-Semibold-WebS.eot?#iefix");
	src: url("fonts/EuclidCircularB-Semibold-WebS.eot?#iefix") format("eot"),
		 url("fonts/EuclidCircularB-Semibold-WebS.woff2") format("woff2"),
		 url("fonts/EuclidCircularB-Semibold-WebS.woff") format("woff"),
		 url("fonts/EuclidCircularB-Semibold-WebS.ttf") format("truetype");
	font-weight: 600;
	font-style: normal;
}

@font-face{
	font-family: euclid;
	src: url("fonts/EuclidCircularB-Bold-WebS.eot?#iefix");
	src: url("fonts/EuclidCircularB-Bold-WebS.eot?#iefix") format("eot"),
		 url("fonts/EuclidCircularB-Bold-WebS.woff2") format("woff2"),
		 url("fonts/EuclidCircularB-Bold-WebS.woff") format("woff"),
		 url("fonts/EuclidCircularB-Bold-WebS.ttf") format("truetype");
	font-weight: 700;
	font-style: normal;
}

/* -------------------------------------------------------------- CSS Reset */

html, body, div, span, h1, h2, h3, h4, h5, h6, h7, p, a, img, strong, b, form, label {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

ul,li {
	list-style: none;
}

body {
	line-height: 1;
}

* {
	margin: 0;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center center;-webkit-tap-highlight-color: rgba(0,0,0,0);
}

html, *, *:before, *:after {
	   -webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

* :focus {outline: none;}

*, * :active {
	-webkit-tap-highlight-color: rgba(0,0,0,0.05);
}

/* -------------------------------------------------------------- Body */

html, body {
	height: 100%;
}

html {
	  overflow-y: scroll; 
}

body {
	-webkit-text-size-adjust: none;
	font-family: euclid, Helvetica, sans-serif;
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 1.7em;
	width: 100%;
	color: #171619;
	background-color: #fff;
	text-rendering: optimizeLegibility;
	font-variant-ligatures: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

@media (max-width: 480px) {
	body {
		height: auto;
		min-height: auto;
	}
}

/* -------------------------------------------------------------- Fonts */

h1,h2,h3,h4,h5 {
	float: left;
	clear: both;
	width: 100%;
	max-width: 820px;
	color: #000;
}

h1 {
	margin: 0 0 80px 0;
	font-weight: 600;
	font-style: normal;
	font-size: 3.2em;
	line-height: 1em;
	letter-spacing: -.02em;
}

h2 {
	margin: 0 0 40px 0;
	font-weight: 600;
	font-style: normal;
	font-size: 3em;
	line-height: 1.1em;
	letter-spacing: -.02em;
}

h3 {
	margin: 0 0 50px 0;
	font-weight: 600;
	font-style: normal;
	font-size: 2.4em;
	line-height: 1.2em;
	letter-spacing: -.02em;
}

h4 {
	margin: 0 0 40px 0;
	font-weight: 600;
	font-style: normal;
	font-size: 1.7em;
	line-height: 1.4em;
	letter-spacing: -.01em;
}

h5 {
	margin: 0 0 10px 0;
	font-weight: 600;
	font-style: normal;
	font-size: 1.25em;
	line-height: 1.2em;
	letter-spacing: -.01em;
}

b,strong {
	font-weight: 600;
}

p {
	position: relative;
	float: left;
	width: 100%;
	max-width: 700px;
	margin: 0 0 30px 0;
	font-size: 1.25em;
	line-height: 1.55em;
	letter-spacing: -.01em;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

del {
	text-decoration: line-through;
}

a,a:active,a:visited {
	text-decoration: none;
	color: #ff9000;
	-webkit-transition: all .3s;
	transition: all .3s;
}

a:hover {
	color: #ff9915;
}

@media (max-width: 1024px) and (min-width: 480px) {
	h1,h2,h3,h4,h5 {
		padding: 0 40px 0 0;
	}
	
	h1 {
		margin: 0 0 60px 0;
		font-size: 2.8em;
	}
	
	h2 {
		font-size: 2.6em;
	}
	
	h3 {
		font-size: 2em;
	}
		
	h4 {
		margin: 0 0 30px 0;
		font-size: 1.6em;
	}
	
	h5 {
		font-size: 1.2em;
	}
	
	p {
		font-size: 1.1em;
	}
}

@media (max-width: 480px) {
	h1,h2,h3,h4,h5 {
		padding: 0 20px 0 0;
	}
	
	h1 {
		margin: 0 0 50px 0;
		font-size: 2em;
	}
	
	h2 {
		font-size: 1.8em;
	}
	
	h3 {
		font-size: 1.6em;
	}
		
	h4 {
		margin: 0 0 30px 0;
		font-size: 1.5em;
	}
	
	h5 {
		font-size: 1.1em;
	}
	
	p {
		font-size: 1em;
	}
}

/* -------------------------------------------------------------- Holder */

.holder {
	margin: 0 auto;
	width: 100%;
	max-width: 1140px;
	padding: 0 60px 0 60px;
}

@media (max-width: 768px) and (min-width: 480px) {
	.holder {
		padding: 0 40px 0 40px;
	}
}

@media (max-width: 480px) {
	.holder {
		max-width: 100%;
		padding: 0 24px 0 24px;
	}
}

/* -------------------------------------------------------------- Header */

header {
	position: relative;
	float: left;
	width: 100%;
	padding: 40px 0 40px 0;
}

@media (max-width: 1024px) and (min-width: 480px) {
	header {
		padding: 30px 0 30px 0;
	}	
}

@media (max-width: 480px) {
	header {
		padding: 20px 0 20px 0;
	}
}

/* -------------------------------------------------------------- Logo */

.logo a, .logo a:active, .logo a:visited {
	float: left;
	font-weight: 600;
	font-size: 2.8em;
	line-height: 60px;
	letter-spacing: -.04em;
	color: #000;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.logo a, .logo a:active, .logo a:visited {
		font-size: 2em;
		line-height: 50px;
	}
}

@media (max-width: 480px) {
	.logo a, .logo a:active, .logo a:visited {
		font-size: 1.4em;
		line-height: 40px;
	}
}

/* -------------------------------------------------------------- Start */

.start a, .start a:active, .start a:visited {
	float: right;
	padding: 0 20px 0 20px;
	font-weight: 600;
	font-size: 1.1em;
	line-height: 60px;
	letter-spacing: -.02em;
	color: #000;
	background-color: #ff9000;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
}

.start a:hover {
	background-color: #ff9915;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.start a, .start a:active, .start a:visited {
		padding: 0 15px 0 15px;
		font-size: 1em;
		line-height: 50px;
	}
}

@media (max-width: 480px) {
	.start a, .start a:active, .start a:visited {
		padding: 0 10px 0 10px;
		font-size: .95em;
		line-height: 40px;
	}
}

/* -------------------------------------------------------------- Get */

.projects {
	float: left;
	display: flex;
	flex-wrap: wrap;
	width: calc(100% + 40px);
	margin: 0 0 0 -20px;
}

.projects a, .projects a:active, .projects a:visited {
	width: calc(50% - 40px);
	margin: 20px;
	padding: 40px;
	font-weight: 600;
	font-style: normal;
	font-size: 2.4em;
	line-height: 1.2em;
	letter-spacing: -.02em;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
}

.projects a:nth-child(1), .projects a:nth-child(1):active, .projects a:nth-child(1):visited {
	color: #fff;
	background-color: #360677;
}

.projects a:nth-child(2), .projects a:nth-child(2):active, .projects a:nth-child(2):visited {
	color: #fff;
	background-color: #00b07c;
}

.projects a:nth-child(1):hover,
.projects a:nth-child(2):hover {
	color: #000;
	background-color: #ff9915;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.projects {
		width: 100%;
		margin: 0;
	}
	
	.projects a, .projects a:active, .projects a:visited {
		width: 100%;
		margin: 20px 0 0 0;
		padding: 24px;
		font-size: 2em;
	}
}

@media (max-width: 480px) {
	.projects {
		width: 100%;
		margin: 0;
	}
	
	.projects a, .projects a:active, .projects a:visited {
		width: 100%;
		margin: 20px 0 0 0;
		padding: 24px;
		font-size: 1.6em;
	}
}

/* -------------------------------------------------------------- Section */

.section {
	position: relative;
	float: left;
	width: 100%;
	padding: 100px 0 100px 0;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.section {
		padding: 80px 0 80px 0;
	}
}

@media (max-width: 480px) {
	.section {
		padding: 60px 0 60px 0;
	}
}

/* -------------------------------------------------------------- Cover */

.cover {
	background-color: #f5f5f7;
	margin: 0 0 40px 0;
	padding: 100px 0 0 0;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.cover {
		margin: 0 0 30px 0;
		padding: 80px 0 0 0;
	}
}

@media (max-width: 480px) {
	.cover {
		margin: 0 0 20px 0;
		padding: 60px 0 0 0;
	}
}

/* -------------------------------------------------------------- About */

.about {
	padding: 100px 0 40px 0;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.about {
		padding: 80px 0 30px 0;
	}		
}

@media (max-width: 480px) {
	.about {
		padding: 60px 0 20px 0;
	}
}

/* -------------------------------------------------------------- Spots */

.spots {
	float: left;
	width: calc(100% + 8px);
	margin: 0 0 -4px -4px;
}

.spot-box {
	position: relative;
	float: left;
	width: 33.33%;
	padding: 4px;
}

.spot-content {
	position: relative;
	float: left;
	width: 100%;
	padding-bottom: 100%;
	overflow: hidden;
}

.spot-image {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	width: 100%;
	padding-bottom: 100%;
	background-color: #fff;
}

.spot-image img {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.spot-box:nth-child(4) .spot-content {
	padding-bottom: 50%;
}

.spot-box:nth-child(5) .spot-content {
	padding-bottom: 50%;
}

.spot-box:nth-child(6) .spot-content {
	padding-bottom: 50%;
}

@media (max-width: 768px) and (min-width: 480px) {
	.spots {
		margin: 0 0 36px -4px;
	}
	
	.spot-box:nth-child(4) .spot-content {
		padding-bottom: 100%;
	}
	
	.spot-box:nth-child(5) .spot-content {
		padding-bottom: 100%;
	}
	
	.spot-box:nth-child(6) .spot-content {
		padding-bottom: 100%;
	}
}

@media (max-width: 480px) {
	.spots {
		width: calc(100% + 4px);
		margin: 0 0 22px -2px;
	}
	
	.spot-box {
		padding: 2px;
	}
	
	.spot-box:nth-child(4) .spot-content {
		padding-bottom: 100%;
	}
	
	.spot-box:nth-child(5) .spot-content {
		padding-bottom: 100%;
	}
	
	.spot-box:nth-child(6) .spot-content {
		padding-bottom: 100%;
	}
}

/* -------------------------------------------------------------- Benefits */

.benefits {
	float: left;
	display: flex;
	flex-wrap: wrap;
	width: calc(100% + 40px);
	margin: 20px 0 0 -20px;
}

.benefit {
	width: calc(50% - 40px);
	margin: 20px;
	padding: 40px;
	font-weight: 600;
	font-size: 1.4em;
	line-height: 1.2em;
	background-color: #f5f5f7;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.benefits {
		width: 100%;
		margin: 0;
	}
	
	.benefit {
		width: 100%;
		margin: 20px 0 0 0;
	}
}

@media (max-width: 480px) {
	.benefits {
		width: 100%;
		margin: 0;
	}
	
	.benefit {
		width: 100%;
		margin: 20px 0 0 0;
		padding: 24px;
		font-size: 1.25em;
	}
}

/* -------------------------------------------------------------- Footer */

.footer {
	margin: 100px 0 0 0;
	background-color: #171619;
}

.footer h3 {
	width: auto;
	margin: 0;
	font-size: 2.2em;
	line-height: 1em;
	letter-spacing: -.03em;
	color: #fff;
}

@media (max-width: 1024px) and (min-width: 480px) {
	.footer {
		margin: 80px 0 0 0;
	}
}

@media (max-width: 480px) {
	.footer {
		margin: 60px 0 0 0;
	}
	
	.footer h3 {
		font-size: 1.8em;
	}	
}

/* -------------------------------------------------------------- Copyright */

.copyright {
	float: left;
	width: 100%;
	font-weight: 400;
	font-size: .8em;
	color: #666;
}

/* -------------------------------------------------------------- Social */

.social {
	float: right;
	margin: 0 -12px 0 0;
}

.social a,.social a:active,.social a:visited {
	display: inline-block;
	padding: 0 12px 0 12px;
	font-weight: 600;
	font-size: 1.6em;
	color: #f5f5f7;
}

.social a:hover {
	color: #ff9915;
}

@media (max-width: 480px) {
	.social a,.social a:active,.social a:visited {
	}
}