/* Reset default styles */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	font-size: inherit;
	color: inherit;
	vertical-align: baseline;
	text-decoration: none;
	list-style-type: none;
	margin: 0;
	padding: 0;
	border: 0;
}

button, input, optgroup, select, textarea, html input[type="button"], input[type="reset"], input[type="submit"], button[disabled], html input[disabled], button::-moz-focus-inner, input::-moz-focus-inner, input[type="checkbox"], input[type="radio"], input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button, input[type="search"], input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
	font-family: 'Inter UI';
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
	background-image: none;
	background-color: transparent;
	appearance: none;
	-webkit-box-shadow: none;
		 -moz-box-shadow: none;
					box-shadow: none;
	-webkit-box-sizing: border-box;
		 -moz-box-sizing: border-box;
			-ms-box-sizing: border-box;
					box-sizing: border-box;
}
fieldset {
	font-size: 0;
}

input, label, select, button, textarea {
	margin: 0;
	border: 0;
	padding: 0;
	vertical-align: middle;
	white-space: normal;
	background: none;
	line-height: 1;
	-webkit-appearance: none;
		 -moz-appearance: none;
					appearance: none;
	-webkit-box-sizing: border-box;
		 -moz-box-sizing: border-box;
	 		-ms-box-sizing: border-box;
					box-sizing: border-box;
}

input[type='number'] {
	-webkit-appearance: textfield;
		 -moz-appearance: textfield;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
	-webkit-appearance: none;
		 -moz-appearance: none;
}
/* End reset */





/* --------
 Global
 -------- */
body {
	font-family: 'Roboto', sans-serif;
	text-align: center;
	padding: 0;
	margin: 0;
	color: #292929;
}

section {
	padding: 70px 0;
}

img {
	object-fit: cover;
}

@media only screen and (max-width: 720px) {
	section {
		padding: 44px 0;
	}
}





/* --------
 Layout
 -------- */
.container {
	max-width: 900px;
	margin: auto;
	padding: 0 30px;
	position: relative;
	text-align: left;
}

@media only screen and (max-width: 560px) {
	.container {
		padding: 0 16px;
	}
}





/* --------
 Typography
 -------- */
h1 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 62px;
	font-weight: bold;
	font-style: normal;
	text-transform: uppercase;
	font-stretch: normal;
	line-height: 1.1;
	letter-spacing: -0.5px;
	margin-bottom: 24px;
}

h1 span, i {
	color: #326dec;
}

h2 {
	font-family: 'Rajdhani', sans-serif;
	font-size: 48px;
	font-weight: bold;
	font-style: normal;
	font-stretch: normal;
	line-height: 52px;
	letter-spacing: -0.5px;
	text-transform: uppercase;
	margin: 32px 0;
	padding: 0;
}

h3, .header-3 {
	display: block;
	font-family: 'Rajdhani', sans-serif;
	font-size: 26px;
	font-weight: bold;
	font-style: normal;
	font-stretch: normal;
	line-height: 1.2;
	letter-spacing: -0.2px;
	text-transform: uppercase;
	margin-top: 0;
	margin-bottom: 8px;
}

@media only screen and (max-width: 720px) {
	h1 {
		font-size: 48px;
		margin-bottom: 16px;
	}
	h2 {
		font-size: 38px;
	}
	h3, .header-3 {
		font-size: 22px;
	}
}





/* --------
 Logo
 -------- */
.logo  {
	width: 100%;
	margin: 40px auto auto auto;
}
.logo img {
	height: 100px;
}





/* --------
 Welcome Block
 -------- */
#welcome p {
	font-size: 28px;
	line-height: 1.6;
	font-family: 'Roboto', sans-serif;				
}
#welcome p:nth-of-type(1) {
	margin-bottom: 24px;
}

@media only screen and (max-width: 720px) {
	#welcome p {
		font-size: 22px;
	}
}
#welcome a {
	color: #326dec;
}




/* --------
 Projects Block
 -------- */
#projects .block {
	margin-bottom: 44px;
}

#projects a {
	display: inline-flex;
	flex-flow: row wrap;
	height: auto;
	width: calc(49% - 40px);
	margin-right: 40px;
}

#projects a:hover h4 {
	border-color: #CCCCCC;
}

#projects ul li {
	position: relative;
	padding: 6px 0 12px 56px;
	margin-bottom: 4px;

}

#projects h4 {
	width: max-content;
	font-size: 17px;
	font-weight: 500;
	line-height: 19px;
	letter-spacing: -.1;
	border-bottom: 2px solid transparent;
	transition: 140ms;
	margin-bottom: 2px;
}

#projects p {
	font-size: 14px;
	opacity: .7;
	letter-spacing: -.1;
	line-height: 1.4;
}

#projects .border {
	display: block;
	z-index: 2;
	box-shadow: inset 0 0 0 1px rgba(0,0,0,.1);
}

#projects ul li img, #projects .border {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: 6px;
}

@media only screen and (max-width: 720px) {
	#projects a {
		width: 100%;
		margin-right: 0;
	}
}





/* --------
 Customers Block
 -------- */
#customers .block {
	max-width: 80%;
	position: relative;
	padding-left: 56px;
	margin-bottom: 40px;
}

#customers i {
	font-size: 40px;
	position: absolute;
	left: 0;
	top: 0;
}

#customers h3 {
	padding-top: 6px;
}

#customers p {
	font-size: 17px;
	line-height: 1.6;
}

#customers li {
	padding: 0 0 4px 0;
}

#customers li:first-child {
	padding: 4px 0 4px 0;
}

#customers li:before {
	content: "\02015 ";
}





/* --------
 Team Block
 -------- */
#team .grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-column-gap: 40px;
	grid-row-gap: 60px;
}

#team .border {
	display: block;
	z-index: 2;
	box-shadow: inset 0 0 0 1px rgba(0,0,0,.1);
	position: absolute;
}

#team img, #team .border  {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	border: solid 1px #eee;
	margin-bottom: 24px;
}

#team p {
	font-size: 17px;
	line-height: 1.6;
}

@media only screen and (max-width: 840px) {
	#team .grid {
		grid-template-columns: repeat(2, 1fr);
		grid-row-gap: 44px;
	}
}

@media only screen and (max-width: 560px) {
	#team .grid {
		grid-template-columns: repeat(1, 1fr);
		grid-row-gap: 32px;
	}

	#team .grid div {
		display: flex;
		flex-flow: row wrap;
	}

	#team .border {
		left: -64px;
	}

	#team img, #team .border {
		width: 60px;
		height: 60px;
		position: absolute;
	}

	#team span, #team p  {
		width: calc(100% - 80px);
		margin-left: 80px;
	}
}





/* --------
 Partners Block
 -------- */
#partners .grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-column-gap: 40px;
	grid-row-gap: 60px;
}

#partners .grid div {
	display: block;
	position: relative;
}

#partners .border {
	display: block;
	max-height: 100px;
	height: 100%;
	width: 100%;
	box-shadow: inset 0 0 0 1px rgba(0,0,0,.1);
	z-index: 2;
	position: absolute;
	top: 0;
	left: 0;
}

#partners img {
	display: block;
	max-height: 100px;
	width: 100%;
	object-fit: contain;
	margin: auto auto 24px auto;
}

@media only screen and (max-width: 840px) {
	#partners .grid {
		display: grid;
		grid-template-columns: repeat(2, calc(50% - 20px));
		grid-row-gap: 44px;
	}
}

@media only screen and (max-width: 560px) {
	#partners .grid {
		grid-template-columns: repeat(1, 1fr);
		grid-row-gap: 32px;
	}

	#partners img {
		margin: auto auto 16px auto;
	}
}





/* --------
 Roadmap Block
 -------- */
#roadmap .block {
	margin-bottom: 32px;
}

#roadmap .block:last-child {
	margin-bottom: 0;
}

#roadmap span.date {
	display: block;
	font-size: 22px;
	opacity: .6;
	font-family: 'Rajdhani', sans-serif;
	text-transform: uppercase;
	margin-bottom: 2px;
}

#roadmap p {
	font-size: 17px;
	line-height: 1.6;
}





/* --------
 Contacts Block
 -------- */
#contacts .grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-column-gap: 40px;
	grid-row-gap: 60px;
}

#contacts .header-3 {
	width: max-content;
	margin-bottom: 4px;
	border-bottom: 2px solid transparent;
	transition: 140ms;
	font-size: 23px;
}

#contacts a:hover .header-3 {
	border-color: #CCCCCC;
}

#contacts .caption {
	font-size: 13px;
	opacity: .6;
}

@media only screen and (max-width: 720px) {
	#contacts .grid {
		grid-template-columns: repeat(1, 1fr);
		grid-row-gap: 32px;
	}
}





/* --------
 Footer
 -------- */
#footer {
	max-width: 900px;
	margin: 0 auto;
	font-size: 13px;
	font-family: 'Roboto', sans-serif;
	opacity: .6;
	text-align: left;
	padding-bottom: 30px;
}

#footer .flex {
	display: inline-flex;
}

#footer p {
	line-height: 16px;
	margin-bottom: 6px;
}

#footer i {
	color: #eb5757;
	font-size: 16px;
	margin: 0 3px 0 3px;
}
