@import url('https://fonts.googleapis.com/css?family=Rajdhani:300,400,700&subset=latin-ext');


/*RESET*/
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 {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* ANIMATIONS */
@-moz-keyframes spin { 100% { -moz-transform: rotate(360deg); } }
@-webkit-keyframes spin { 100% { -webkit-transform: rotate(360deg); } }
@keyframes spin { 100% { -webkit-transform: rotate(360deg); transform:rotate(360deg); } }

/*MAIN RULES*/
body, html { margin: 0; padding: 0; width: 100%; position: relative; float: left; }

body, input, textarea, button { font-size: 18px; font-family: "Rajdhani"; line-height: 1.5em; }

a, div, input, textarea { box-sizing: border-box;}

h1, h2, .font_big { font-size: 45px; line-height: 1.2em; }
h3, h4, .font_big { font-size: 36px; line-height: 1.2em; margin-top: 30px; }

strong { font-weight: 700; }

a, button { transition: .2s all; text-decoration: none; }

.col { position: relative; width: 100%; float: left;}
.col2 { position: relative; width: 50%; float: left; }
.col3 { position: relative; width: 33.3333333%; float: left; }
.col_contact1 { position: relative; width: 40%; float: left; }
.col_contact2 { position: relative; width: 60%; float: left; }
.col3_features { cursor: default; position: relative; width: 350px; display: inline-block; padding: 100px 0 100px 0; transition: 0.5s all;  background-size: 0.5px; background-image: url(../img/feature_active.png); background-position: center; background-repeat: no-repeat; }
.col3_features:hover { background-size: 80%; }

.col4 { position: relative; width: 25%; float: left;}
.col4_features { transition: 0.5s all; position: relative; width: 180px; display: inline-block; background-position: center 10px; background-repeat: no-repeat; height: 85px; padding-top: 150px; }
.col4_features:hover { background-position: center 0;}

.bg_dark_blue { background-color: #19192d; }
.bg_dark_blue2 { background-color: #1e1e38; }
.color_dark_blue { color: #19192d; }
.color_white, .color_white a { color: white; }
.color_green { color: #4df4bc; }
.color_white_darkened { color: #606bac; }
.bg_green { background-color: #4df4bc; }
.bg_triangles { background-image: url(../img/background_triangles.png); }

.align_center { text-align: center; }
.margin_top { margin-top: 120px; }
.margin_bottom { margin-bottom: 120px; }
.padding_top { padding-top: 120px; }
.padding_bottom { padding-bottom: 120px; }

.margin_top80 { margin-top: 80px; }
.margin_bottom80 { margin-bottom: 80px; }

.wrap { width: 100%; float: left; position: relative; }
.wrap_center { max-width: 1720px; margin-left: auto; margin-right: auto; position: relative; perspective: 1000px; -webkit-perspective:1000px; -moz-perspective:1000px; }

/*HEADER*/
header .logo { display: inline-block; float: left; margin: 37px 0 37px 0; }
header .logo img { float: left; max-height: 50px; transition: 1s all ease; }
header .logo:hover img { transform: scale(1.1, 1.1); }
header nav { display: block; float: right; margin-top: 57px; }
header nav a { font-weight: 700; display: inline-block; color: white; transition: 0.5s all ease; }
header nav a:hover, header nav a.active { color: #4df4bc; }
header nav a.color_white_darkened { color: #606bac; }
header nav ul { display: block; float: right; }
header nav ul li { display: inline-block; float: left; margin: 0 12px 0 12px; }
header nav ul li.gap { border-left: 1px dotted #606bac; height: 11px; margin-top: 8px; }

.menuburger { float: right; margin: 20px; display: none; }
.menuburger i { font-size: 22px; line-height: 30px; }

/*SLIDER*/
.main_slider { position: relative; width: 100%; float: left; background-color: black; }
#ytplayer {width: 100%; height: 100%; float: left; }
.video_overlay { position: absolute; top: 0; left: 0; }
.bg_image { background-position: center; background-size: cover; }

/*FEATURES*/
.number_triangle { display: inline-block; line-height: 36px; width: 42px; background-image: url(../img/green_triangle.png); background-repeat: no-repeat; background-position: center; background-size: contain; padding-top: 10px; font-weight: 700; margin-bottom: 10px; }
img.logo { display: inline-block; margin: 50px; max-height: 70px; max-width: 150px; line-height: 100px; vertical-align: middle; }
.borders_light { border-top: 3px solid #1c1c35; border-bottom: 3px solid #1c1c35; }

/*PROJECTS*/
.projects {}
.projects .item { height: 400px; background-position: center; background-size: cover; background-repeat: no-repeat; font-size: 24px; transition: .5s all ease; overflow: hidden; float: left; z-index: 0; position: relative; }
.projects .item.psize1, .projects .item.psize4 { width: 66.6666%; }
.projects .item.psize2, .projects .item.psize3 { width: 33.3333%; }
.projects .item:hover { transform: scale(1.02, 1.02) translateZ( 5px ); z-index: 999; box-shadow: 0 0 20px black; }
.projects .item .desc { padding-top: 40%; transition: .5s all ease; width: 100%; position: relative; float: left; }
.projects .item:hover .desc { padding-top: 0px; }
.projects .item .overlay { position: relative; width: 100%; height: 100%; float: left; background: rgba(25,25,45,.8); opacity: 0; transition: .5s all; }
.projects .item:hover .overlay { opacity: 1; }
.projects .item .overlay .item_logo { display: block; clear: both; margin: 30px auto; float: none; position: relative; max-width: 120px; max-height: 80px; }
.projects .item .overlay .line { display: block; width: 100px; border-top: 2px solid #4df4bc; margin: 30px auto; }
a.button_green { display: inline-block; background: #4df4bc; line-height: 60px; padding: 0 50px; color: #19192d; font-weight: 700; font-size: 18px; margin: 30px auto; }
a.button_green:hover { background: white; }

.news_short { height: 250px; position: relative; margin: 20px; background-position: center; background-size: cover; display: block; transition: 0.5s ease all; }
.news_short:hover { transform: translateY( -20px ) rotateX(10deg); }
.news_short:hover .desc { background: #4df4bc; color: black; }
.news_short .desc { min-height: 90px; position: absolute; width: 100%; bottom: 0; z-index: 999; font-weight: 700; padding: 30px 10px 20px 10px; background: rgba(0,0,0,0.5); font-size: 22px; transition: 0.5s all;}
.news_short .desc .date { display: inline-block; position: absolute; top: 0; left: 0; width: 100%; text-align: center; font-size: 14px; color: black; line-height: 20px; }
.news_short .desc .date p { background: #4df4bc; display: inline-block; width: auto; padding: 0 10px; line-height: 20px; }

.item a.button_green { margin-top: 100px; margin-bottom: 0; transition: .8s all; }
.item:hover a.button_green { margin-top: 30px; margin-bottom: -120px; }

/*MAP*/

.map { width: 100%; height: 500px; float: left; }

/*CONTACT*/

.contact { padding-bottom: 60px; }
.contact .wrap_center { margin-top: -100px; max-width: 1200px; }
.contact .bg_dark_blue2 { padding: 50px 60px; float: left; height: 100%; width: 100%; }

.contact .col_contact2 .bg_dark_blue2 { margin-left: 10px; text-align: justify; }
.line_light { display: block; width: 100%; border-top: 1px solid #2b2b4d; margin: 30px auto; float: left; }

.contact form { float: left; width: 100%; }
.contact form input, .contact form textarea { display: block; float: left; width: 100%; background: transparent; border: none; border-bottom: 1px solid #2b2b4d; padding: 10px 0; outline: none; line-height: 1em; margin: 10px 0; color: white; }
.submit { cursor: pointer; float: right; display: inline-block; background: transparent; border: 3px solid #4df4bc; line-height: 60px; padding: 0 50px; color: white; font-weight: 700; font-size: 18px; margin: 30px auto;  margin-bottom: 0; }
.submit:hover { background: #4df4bc; color: #19192d!important; }

span.wpcf7-not-valid-tip { display: none!important; }
.wpcf7-not-valid { border-bottom: 1px solid red; color: red; }
div.wpcf7-response-output { border: none!important; display: block!important; border: none!important; margin: 0!important; padding: 0!important; position: absolute!important; bottom: 15px!important;}
div.wpcf7-validation-errors { color: red; }
.wpcf7-not-valid { border-bottom: 1px solid red!important; color: red!important; }

/*PROJECT*/

.project_image { height: 500px; background-position: center; background-size: cover; }
.project_gap { display: inline-block; width: 2px; height: 28px; border-left: 1px solid #4df4bc; margin: 0 30px; vertical-align: middle; }
.wrap_center.news img.client_logo { display: inline-block; max-height: 28px; vertical-align: middle; margin: 0 20px; }
.wrap_center.news p.project_details { margin: 40px 0; }
.gal { height: 400px; background-position: center; background-size: cover; }
.gal:hover { transform: scale(1.05,1.05); z-index: 9999; box-shadow: 0 0 15px rgba(0,0,0,.8); }
.yt_player { width: 100%; margin-top: 40px; }

/* NEWS */
.wrap_center.news { padding: 100px 0; font-size: 24px; max-width: 960px; }
.wrap_center.news h1 { max-width: 800px; }
.wrap_center.news img { margin: 40px 0; max-width: 100%; }
.wrap_center.news p { line-height: 38px; margin: 20px 0;}
.wrap_center.news p.post_date { display: inline-block; float: right; color: black; background: #4df4bc; padding: 0 10px; font-size: 14px; font-weight: 700; line-height: 20px; position: absolute; top: 90px; right: 0; }

.color_white .news a { color: #4df4bc; }
.news ul { list-style: square; padding-left: 30px; }

/*NOT FULLHD*/
@media (max-width: 1780px ) {
	.wrap_center { max-width: 1200px; }
}

/*NOT FULLHD*/
@media (max-width: 1200px ) {
	.wrap_center { max-width: 1000px; }
}

/*NOT FULLHD*/
@media (max-width: 1030px ) {
	.wrap_center { max-width: 900px; }
	.video_overlay { display: none; }
	.wrap_center.news h1 { max-width: 700px; }
	.wrap_center.news { width: 100%; padding: 100px 20px; }
}



/* MOBILE */
@media (max-width: 800px ) {

	.menuburger { display: block; }
	.wrap_center {  }
	.margin_top { margin-top: 50px; }
	.margin_bottom { margin-bottom: 50px; }
	h1, h2, .font_big { font-size: 28px; }

	.col_contact1, .col_contact2 { width: 100%; }
	.col3 { width: 50%; }
	.projects .item.psize1, .projects .item.psize2, .projects .item.psize3, .projects .item.psize4 { width: 100%; }
	.contact .col_contact2 .bg_dark_blue2 { margin-left: 0; text-align: center; }
	.projects .item { height: 500px; }
	.projects .item:hover { transform: none; }
	.projects .item .overlay { opacity: 1; }
	.projects .item .desc { padding-top: 0; padding-left: 40px; padding-right: 40px; }
	img.logo { margin: 15px; max-height: 20px; }
	.item a.button_green { margin-top: 20px; }
	.projects .item .overlay .item_logo { margin-top: 10px; }

	.contact form input, .contact form textarea { margin-bottom: 20px; }
	.contact form textarea { height: 100px; }
	.submit { float: none; display: block; clear: both; }
	div.wpcf7-response-output { left: 0; width: 100%; text-align: center; }

	.col3_features { width: 100%; padding: 50px 0; }
	.col4_features { margin-top: 20px; }

	.project_image { height: 300px; }
	.gal { height: 200px; }
	.wrap_center.news { padding: 50px 20px; }
	.wrap_center.news img.client_logo { max-height: 16px; }
	.project_gap { display: block; clear: right; height: 0; margin-top: 20px; }

	.wrap_center.news p.project_details span.text { width: 100%; display: block; }
	.wrap_center.news p { font-size: 20px; line-height: 1.5em; }
	.wrap_center.news img { max-width: 100%; margin: 20px 0; }
	.wrap_center.news p.post_date { top: 0; }

	header .logo { margin: 20px; }
	header .logo img { max-height: 30px; }

	header nav { display: block; margin-top: 0; border-top: 1px solid #606bac; display: none; }
	header nav ul li { width: 100%; font-size: 22px; border-bottom: 1px solid #606bac; margin: 0; box-sizing: border-box; }
	header nav ul li a { width: 100%; padding: 20px; box-sizing: border-box; margin: 0; text-align: center; }
	header nav ul li.gap { display: none; }

	.slick-next { right: 0px!important;  }
	.slick-prev { left: 0px!important; }
}

@media (max-width: 600px ) {
	.col2, .col3 { width: 100%; }


}
