@import 'https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.8.1/slick.min.css';
@import 'https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.8.1/slick-theme.min.css';

/* Global */
.general-title{
	line-height: 0.6;
	color: #d8f40a;
	text-align: center;
	text-transform: uppercase;
	font-size: clamp(2.8em, 5vw, 5em);
}

.intro-section p{
	max-width: 1200px;
	margin: 50px auto 0;
}

.general-btn{
	width: 175px;
	display: block;
	margin: 15px 0;
	color: #1d2021;
	font-size: 20px;
	padding: 11px 5px;
	text-align: center;
	border-radius: 7px;
	background-color: #daf04f;
	/* border: 1px solid white; */
}

.general-btn:hover{
	color: #daf04f;
	border: 1px solid white;
	background-color: #1d2021;
}

p{font-size: clamp(0.8em, 2vw, 1.2em);}
/* End */

.banner{
	height: 100vh;
	padding-top: 60px;
	background-size: cover;
	background-repeat: no-repeat;
}

.banner-info{
	width: 80%;
	height: 90%;
	display: flex;
	margin: 0 auto;
	flex-direction: column;
	justify-content: center;
}

.banner-info h3, .banner-info h2, .banner-info h1{text-align: left;}

.banner-info h3{
	line-height: 0.7;
	color: #B2BCB0;
	max-width: 650px;
	letter-spacing: -0.7px;
	font-size: clamp(2em, 5vw, 3.7em);
}

.banner-info h2{
	color: #d8f40a;
	line-height: 0.65;
	max-width: 500px;
	margin: 30px 0 15px;
	letter-spacing: -1.67px;
	font-size: clamp(3.8em, 5vw, 5.3em);
}

.banner-info h1{
	line-height: 1;
	font-size: 23px;
	font-weight: 400;
	max-width: 520px;
	margin-bottom: 20px;
}

main{
	margin: 0 auto;
	max-width: 1523px;
}

/* Section About */
.about{padding: 90px 10px 50px;}

.about-cards{
	margin: 0 auto;
	max-width: 100%;
}

.card{
	height: 420px;
	padding: 1vw 4vw;
	margin: 60px 40px;
	flex-direction: column;
	justify-content: center;
	display: flex !important;
	outline: none !important;
	border: 1px solid #D5F10A;
	border-radius: 0px 30px 0px 0px;
	box-shadow: -19px 20px 20px 0px #000000a0;
}

.title-line{
	width: 15%;
	height: 5px;
	transition: .5s;
	position: relative;
	margin: 0 auto 20px;
	background-color: #d8f40a;
}

.card .general-title {line-height: 1.2;font-size: clamp(3.8em, 5vw, 5em);}

.card p{
	line-height: 1;
	text-align: center;
	font-size: clamp(1em, 2vw, 1.5em);
}

.about-cards .general-btn{margin: 60px auto;}

/* Section Service */
.services {padding: 50px 10px;}

.intro-side-content {
  gap: 150px;
  display: flex;
  max-width: 90%;
  margin: 70px auto 0;
  flex-direction: column;
}

.intro-side {
  gap: 60px;
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: center;
}

.intro-side h2{
  line-height: .6;
  text-align: left;
  color: #d8f40a;
  max-width: 100%;
  letter-spacing: -0.4px;
  font-size: clamp(3.4em, 5vw, 4.5em);
}

.intro-side p{
  line-height: 1;
  margin: 20px 0;
  max-width: 81%;
  font-weight: 300;
  font-family: 'Poppins', sans-serif;
}

.intro-side:nth-child(1) .iintro-side h2{max-width: 70%;}
.intro-side:nth-child(2) {flex-direction: row-reverse;}
.intro-side:nth-child(2) .iintro-side{text-align: right;}
.intro-side:nth-child(2) .iintro-side:last-child{width: 40%;}
.intro-side:nth-child(2) .iintro-side:first-child{width: 60%;}
.intro-side:nth-child(2) .iintro-side h2{float: right;text-align: right;max-width: 91%;}
.intro-side:nth-child(2) .iintro-side p, .intro-side:nth-child(2) .iintro-side .general-btn{float: right;max-width: 90%;}
.intro-side:nth-child(3) .iintro-side h2{max-width: 66%;}
.iintro-side {width: 50%;}

.iintro-side img{
	width: 100%;
	cursor: pointer;
}

/* Gallery Section*/
.our-jobs{padding: 50px 0;}

.job-gallery{
  display: grid;
  grid-gap: 30px 10px;
  margin: 60px auto;
  max-width: 80%;
  justify-items: center;
  grid-template-rows: repeat(3, auto);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 20rem), 1fr));
}

.job-gallery img{
	width: 370px;
	height: 370px;
}

.our-jobs .general-btn{margin: 0 auto 60px;}
.flexslider{display: none;}
.general-btn.carousel-btn{display: none;}

/* Contact Section */

.tell-side-container{
	gap: 3vw;
	display: flex;
	max-width: 90%;
	flex-direction: row;
	margin: 50px auto 0;
}

.tell-side{width: 50%;}

/* Form */
label{
	color: #d8f40a;
	font-size: 22px;
	font-weight: bold;
}

input[type="text"], input[type="phone"], input[type="email"] {
	color: white;
	outline: none;
	width: 100%;
	border: none;
	height: 30px;
	font-size: 16px;
	margin: 0 0 10px;
	padding: 15px 10px;
	background: transparent;
	border-bottom: 1px solid white;
}

input[type="radio"]{
	outline: none;
	vertical-align: middle;
}

.wpcf7-list-item-label {font-size: 14px;}
input[type="submit"]{font-family: 'Genos', sans-serif;}

.wpcf7-not-valid-tip {
  display: block;
  color: #dc3232;
  position: absolute;
  margin-top: -12px;
  font-weight: normal;
  font-size: .8em !important;
}

form .general-btn{margin: 50px auto;}
/* End */

iframe {
	width: 100%;
	height: 91%;
}

/* Responsive */
@media (max-width: 1500px) {
	.job-gallery {
		max-width: 90%;
		grid-gap: 20px 60px;
	}
}

@media (max-width: 1400px) {
  .banner-info {width: 90%;}
  .job-gallery, .tell-side-container {max-width: 89%;}
}

@media (max-width: 1330px) {
  .intro-section{
    margin: 0 auto;
    max-width: 90%;
  }
}

@media (max-width: 1220px) {
	.intro-side:nth-child(2) .iintro-side p, .intro-side:nth-child(2) .iintro-side .general-btn {max-width: 100%;}

	.job-gallery {
    grid-gap: 20px;
    max-width: 90%;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 26vw), 1fr));
}

	.job-gallery img{
		width: 100%;
		height: 100%;
	}
}

@media (max-width: 1050px) {
	.intro-section p{text-align: center;}
	.intro-side {gap: 40px;}
	.intro-side p {max-width: 100%;}
	.intro-side:nth-child(2) .iintro-side:first-child {width: 50%;}
	.intro-side:nth-child(2) .iintro-side:last-child {width: 50%;}

	.card {
		height: 380px;
		padding: 1vw 1.5vw;
		margin: 60px 20px;
	}

	.intro-side-content {gap: 70px;}
}

@media (max-width: 1024px) {
	.intro-side:nth-child(3) .iintro-side h2, .intro-side:nth-child(1) .iintro-side h2 {max-width: 100%;}
}

@media (max-width: 600px) {
	.general-btn{margin: auto;}

	.banner {
    height: 70vh;
    padding-top: 100px;
 }

	.banner-info h3, .banner-info h2 {
    color: #d8f40a;
    text-align: center;
	}

	.banner-info h2{line-height: .8;}

	.banner-info h1{
		margin: 0 auto;
		font-size: 15px;
		max-width: 90%;
		text-align: center;
	}

	.slick-dots li.slick-active button:before {color: #d8f40a;}

	.slick-dots li button:before {
		width: 12px;
		height: 12px;
		font-size: 10px;
		line-height: 13px;
		border-radius: 100%;
		border: 1px solid #d8f40a;
	}

	.about-cards .general-btn {margin: 60px auto 0;}
	.services {padding: 10px;}

	.intro-side{flex-direction: column;}
	.intro-side:nth-child(2) {flex-direction: column;}
	.iintro-side, .intro-side:nth-child(2) .iintro-side:first-child, .intro-side:nth-child(2) .iintro-side:last-child {width: 100%;}

	.intro-side p, .intro-side:nth-child(2) .iintro-side h2 {
		float: none;
		max-width: 100%;
		text-align: center;
	}

	.intro-side h2{text-align: center;}

	.intro-side p{
		font-size: 11px;
		line-height: 1.5;
	}

	.intro-side:nth-child(2) .iintro-side p, .intro-side:nth-child(2) .iintro-side .general-btn{float: none;}

	.tell-side-container{flex-direction: column;}
	.tell-side {width: 100%;}
	.tell-side-container {max-width: 100%;}

	form.wpcf7-form.init {
    margin: 0 auto;
    max-width: 84%;
	}

	.wpcf7-list-item {margin: 0 !important;}
	.wpcf7-list-item-label {font-size: 3vw;}
	label {font-size: 19px;}
	form .general-btn {margin: 50px auto 0;}
}

@media (max-width: 500px) {
	.banner-info {height: 100%;}
	.job-gallery, .grid-gallery-btn{display: none;}
	.flexslider{display: block;}

	.general-btn.carousel-btn{
		display: block;
		margin: 90px auto 60px;
	}

	.slides{margin: 60px auto;}
	.slick-list{padding: 0px 33px 0 30px !important;}
	.slides img {width: 295px;width: 75vw;}
	.slides .slick-dots {bottom: -60px;}
}

@media (max-width: 370px) {
  .banner-info h2 {font-size: clamp(14.8vw, 5vw, 5.3em);}
  .intro-side h2 {font-size: clamp(14vw, 5vw, 4.5em);}
  .card {height: 300px;}
}

@media (max-width: 330px) {
  .banner {height: 83vh;}
}