* {
	box-sizing:border-box;
	margin:0;
	padding:0;
	font-family: 'Open Sans', sans-serif;
	list-style-type: none;
	text-decoration: none;
}

body,html {

	height:100%;
	line-height: 1.8em;
	color:#07170c;
}

html {
	scroll-behavior:smooth;
}


.header-wrap {
	width: 100%;
	background: hsla(240,17%,99%,0.97);
	border-bottom: 0.0625em solid #fff;
	position: fixed;
	z-index: 10;
}

.wrapper {
	position: relative;
	width:100%;
	margin: 0 auto;
}

nav, nav ul {
	width: 100%;
	height: 4em;
	display: inline-block;
	position: relative;
}

#logo h2, .container h2 {
	color: #07170c;
	letter-spacing: .065em;

}

#logo a {
	display: block;
}

a.effect-shine:hover {
	-webkit-mask-image: linear-gradient(-75deg, rgba(0,0,0,.6) 30%, #000 50%, rgba(0,0,0,.6) 70%);
	-webkit-mask-size: 200%;
	animation: shine 2s infinite;
}

@-webkit-keyframes shine {
	from {
		-webkit-mask-position: 150%;
	}

	to {
		-webkit-mask-position: -50%;
	}
}


nav ul li {
	width: 30%;
	height: auto;
	margin: 0 2% 0 0;
	padding: 0;
	text-indent: 0;
	float: left;
	background: hsla(221,43%,98%,0.1);
	transition-property: background;
	transition-duration: .4s;
	transition-timing-function: ease-out;
}

nav ul li:nth-of-type(3) {
	margin: 0;
}

nav ul li:hover {
	background: hsla(210, 48%, 48%, 0.19);

	transition-property: background;
	
	transition-duration: .2s;
	
	transition-timing-function: ease-in;
}


nav ul li a {
	width: 100%;
	height: 3em;
	margin: 0.0625em 0 0;
	text-align: center;
	text-transform: uppercase;
	line-height: 3em;
	line-height: 2em;
	font-weight: 600;
	display: inline-block;
	color: #484e5b;
	background: transparent;
	border: 0;
	letter-spacing: .04em;

	transition-property: color,background,border,box-shadow;
	
	transition-duration: .2s;
	
	transition-timing-function: ease-out;
}


nav ul li a:hover {
	border-bottom: 0.5em solid hsla(119, 100%, 21%, 0.7);
}

nav ul li:hover a {

	color: #0b4325;;
}

.main_image {

	position: relative;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	background-attachment: fixed;
	background-image:url(./img/leaves.jpg);
	min-height: 100%;
}





section {

	text-align: center;
	padding:50px 10px;
	height:100vh;
	display: -webkit-box;  /* OLD - iOS 6-, Safari 3.1-6, BB7 */
	display: -ms-flexbox;  /* TWEENER - IE 10 */
	display: -webkit-flex; /* NEW - Safari 6.1+. iOS 7.1+, BB10 */
	display: flex;         /* NEW, Spec - Firefox, Chrome, Opera */
	justify-content:center;
	align-items:center;
	position: relative;
}

section:nth-child(odd) {
	background-color: #f0f3f6;

	
}

section:nth-child(even) {
	background-color:#07170c;
	color:#ddd;


}

.about {

	flex-direction: column;
	align-items: center;
	height: auto;
	padding-top:178px;
}

.about-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.about p {
	padding: 50px;
	text-align: justify;

	font-size: 22px;
	width:100%;
}

.slices {
	flex-direction: column;
	height: auto;
	justify-content: start;
	padding: 215px 35px 50px 35px;
}

.javascript ul {
	display: flex;
	justify-content: space-around;
	width: 100%;
}

.javascript a {
	background: #fff;
	border: 0px solid transparent;
	border-radius: 50%;
	height: 139px;
	width:139px;
	align-items: center;
	justify-content: center;
	display: flex;
	position: relative;
	transition: all 0.2s ease-out;
	color: #07170c;
	font-size: 19px;
	font-weight: 700;
	text-transform: uppercase;
}

.javascript a:hover {
	background: #0f6371;
	box-shadow: 0 0 0 14px #1bb2cb;
	color:#fff;
}

.javascript:before, .contact::before {
	top: 12.5%;
}

.contact ul {
	display: flex;
	justify-content: space-around;
	width: 100%;
}

.contact ul a { 
	display: block;
	position: relative;

}

.contact ul a:hover {
	-webkit-animation: pop 0.3s linear 1;
	animation: pop 0.3s linear 1;

}

@keyframes pop {
	50%  {
		-webkit-transform: scale(1.2);
		-ms-transform: scale(1.2);
		transform: scale(1.2);

	}
}



.contact ul img {
	max-width: 100px;
}

.contact p {

	position: absolute;
	bottom: 9px;
	font-size: 12px;
	left:0;
	right:0;
}




section:before {

	content: attr(data-text);
	letter-spacing: .095em;
	font-size:2em;
	text-transform: uppercase;
	font-weight: 600;
	position: absolute;
	top: 12%;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	text-shadow: -1px -1px 1px #f0f3f6, 2px 2px 1px #5c5c5c;
	color: #f0f3f6;

}

.slices:before {
	top: 3.5%;
}

.about:before {
	top: 9%;
}

section:nth-child(even):before {

	text-shadow: -1px -1px 1px #07170c, 2px 2px 1px #27412f;
	color: #07170c;
}


.about li {
	line-height: 33px;
	letter-spacing: .043em;

}
img.alex {
	height: 300px;
	display: block;
	max-width: 100%;
	box-shadow: 0px 10px 13px -7px #07170c;
}

.project {
	margin-bottom: 44px;
	position: relative;

}

.project1 {
    margin-top: 5rem;
}


.project img {

	height: auto;
	max-width: 100%;
	max-height: 200px;
	box-shadow: 0px 10px 13px -7px #07170c;

}



.project a {
	display: block;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-moz-osx-font-smoothing: grayscale;
	position: relative;
	color:#07170c;


}

.project a:hover {
	color:hsla(119, 100%, 21%, 1);
}

.project a:before {
	content: "";
	position: absolute;
	z-index: -1;
	left: 50%;
	right: 50%;
	bottom: -6px;
	background: hsla(119, 100%, 21%, 0.7);
	height: 7px;
	-webkit-transition-property: left right;
	transition-property: left right;
	-webkit-transition-duration: 0.3s;
	transition-duration: 0.3s;
	-webkit-transition-timing-function: ease-out;
	transition-timing-function: ease-out;
}

.project a:hover:before {

	left: 0;
	right: 0;
}




.ptext {
	position: absolute;
	top:50%;
	width:100%;
	text-align: center;
	color:#000;
	font-size:27px;
	letter-spacing: 8px;
	text-transform: uppercase;
}


.ptext .border {

	color:#fff;
	padding:20px;
	font-size: 44px;
	line-height: 44px;
}


.border:first-child {
	font-size: 56px;
	font-weight: bold;
}




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

	.about p {

		width: 80%; 

	}

}









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


	body {
		font-size: 112.5%;
	}

	.header-wrap{
		height: 5em;
	}

	.header-wrap #logo {
		width: 30%;
		width:100%;
		text-align: center;
		margin: 0 0 0 -10.285714%;
		margin:0;
		line-height: 2em;
		display: block;
		position: absolute;
		position: relative;
		text-transform: uppercase;
		z-index: 1;
	}

	.wrapper {

		width:100%;
		
	}

	nav, nav ul {

		float: right;

	}

	nav ul li {
		width: 22.428571%;
		width:25%;
		margin: 0;
	}

	nav ul li a {
		width: 100%;

	}

	.no-touch nav ul li a:hover {
		border-bottom: 0.375em solid hsla(3,90%,71%,0.7);
	}

}



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

	body {
		font-size: 131.25%;
	}

	.header-wrap {
		height: auto;
	}

	.header-wrap #logo {
		width: 30%;
		line-height: 3em;
		position: absolute;

	}


	.wrapper {
		width: 92.10526315789474%;
		max-width: 1020px;
		margin-left: auto;
		margin-right: auto;
	}

	nav, nav ul {
		width: 78.857143%;
		height: 3em;


	}

	nav ul li {
		width: 22.428571%;

	}

	nav ul li a {
		height: 3em;
		line-height: 3em;

	}



	section {
		padding: 50px 80px;
	}



}

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


	.header-wrap #logo {

		margin: 0 0 0 -10.285714%; 

	}



}




@media(max-width: 600px) {

	.main_image{
		background-attachment: scroll;
	}

	.header-wrap #logo {
		width: 100%;
		margin:0;

		text-align: center;
	}

	nav ul li {
		width:25%;
		margin:0;
	}



	nav, nav ul {
		display: flex;
		height:3em;
	}


	.border:first-child {
		font-size: 41px;

	}

	.ptext .border {

		padding: 0;

	}

	p.border:last-child {
		font-size: 30px;
	}

	.javascript a {
		height:110px;
		width:110px;
		font-size: 14px;
	}


	.about {
		padding-left: 0;
		padding-right: 0;
	}

	.contact, .javascript {

		padding:0 20px 0 20px;
	}

	.project1 {
		margin-top: 3rem;
	}


	.contact ul img {
		max-width: 67px;
	}


	.about:before {
		top: 7.5%;
	}

	.slices:before {
		top: 4.5%;
	}

	.javascript:before, .contact:before {
		top: 13.5%;
	}

}

@media(max-width: 458px) {

.javascript a {
    height: 77px;
    width: 77px;
    font-size: 12px;
    line-height: 13px;
}


.javascript a:hover {
   
    box-shadow: 0 0 0 3px #1bb2cb;
   
}

.ptext {
    top: 44%;
    letter-spacing: 1px;
   
}

.ptext .border {
   
    line-height: 34px;
}

.border:first-child {
    font-size: 33px;
}

p.border:last-child {
    font-size: 24px;
}

nav ul li a {
	font-size: 12px;
	height: 2.6em;
	line-height: 1em;
}

nav, nav ul {

   
    height: 2.5em;

}

.about p {

    padding: 32px;
    width:100%;
    font-size: 14px;

}

img.alex {

	height: 221px;
}

.contact ul img {

    max-width: 52px;

}

.project {
	width:100%;
}

}






