* { box-sizing: border-box; margin: 0; padding: 0; }

html,body { font-size: 16px; font-family: "Poppins", sans-serif; background: #fff; color: #29484f; line-height: 1.4em; }

a { text-decoration: none; color: unset; }
ul { list-style: none; }
img { vertical-align: middle; }

p { font-size: 15px; }

h1,h2,h3,h4,h5,h6 { color: #000; line-height: 1.2; }
section { overflow: hidden; }
 
.container { max-width: 1140px; margin: auto; }
.widget-section { display: block; padding: 60px 16px; position: relative; }

button { border: 0; outline: 0; font-family: var(--ff); letter-spacing: 1px; }


:root {

	--c1 : #ffea00;
	--c2 : #1cc44f;
	--c3 : #ea1622;

	--bs: 0 3px 15px 0 #0000001a;
	--bs2 : 0 3.4px 2.7px -30px #0000000f, 0 8.2px 8.9px -30px #00000012, 0 25px 40px -30px #00000033;
	--ts : all 0.5s ease-in-out;
	--ff : "Font Awesome 6 Pro";
	--fs : 40px;

	--rg: radial-gradient(#dc1707, #551303);
}




/* ========== ========== ===== Header Section ===== ========== ========== */


/* ---------- Top Bar ---------- */
.topbar { width: 100%; display: block; position: relative; border-bottom: 1px solid #f2f2f2; background: var(--c1); color: #000; }
.topbar_row { display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 1; }
.topbar_row a i { display: block; width: 36px; height: 36px; line-height: 36px; text-align: center; transition: var(--ts); }

.topbar_info { display: flex; align-items: center; gap: 16px; }
.topbar_info a { display: flex; align-items: center; }
.topbar_info a i { color: var(--c3); }

.topbar_social { display: flex; justify-content: space-around; padding: 6px 0; }
.topbar_social a:hover i { background: var(--c1); }
.topbar_social a+a { border-left: 1px solid #00000080; }

@media all and (max-width:480px) {
	.topbar:before { width: 60%; }
	.topbar_info a p { display: none; }
}


/* ---------- NAV BAR ---------- */
.nav_btn { margin-left: 24px; }

.header { display: block; width: 100%; position: sticky; top: 0; background: #fff; box-shadow: var(--bs); z-index: 999; }
.nav-container { display: flex; justify-content: space-between; align-items: center;
	padding: 4px 0px; max-width: 1140px; margin: auto; position: relative; }

.logo { width: 116px; }
.logo img { width: 100%; height: auto; }

.navbar { display: block; }
.nav_area { display: flex; align-items: center; }

.nav_links { display: flex; }
.nav_links li { position: relative; }
.nav_links li a,
.nav_links li label { display: block; padding: 8px 12px; transition: var(--ts); font-weight: 600; }


.sub_link input { display: none; }
.sub_link:hover .sub_menu { display: block; }

.sub_menu { width: 260px; display: none; position: absolute; top: 100%; left: 0;
	background: #fff; box-shadow: var(--bs); transition: var(--ts); border-radius: 6px; z-index: 99; overflow: hidden; }
.sub_menu li a { display: block; padding: 12px 16px; font-weight: 500; }
.sub_menu li a:hover { background: #f2f2f2; }

.btn_OC { display: none; }
.btn_OC button { display: block; width: 40px; height: 40px; line-height: 40px; text-align: center; font-size: 26px; border: 0; outline: 0; background: var(--c1); color: #000; }

/* Request */
.btn_nav { display: block; width: 160px; height: 50px; background: var(--c1); color: #000; position: relative; border-radius: 4px; }
.btn_nav:before { content:"Request Quote"; position: absolute; top: 0; display: block; width: 100%; height: 50px; line-height: 50px; text-align: center; transition: var(--ts); }
.btn_nav:hover:before { letter-spacing: 0.3px; }

@media all and (max-width:480px) {
	.btn_OC { display: flex; padding: 16px; justify-content: flex-end; }

	.logo { padding-left: 16px; }

	.navbar { position: fixed; top: 0; left: -100%; width: 100%; height: 100%; background: #00000080; transition: var(--ts); }
	.nav_area { display: block; width: 80%; height: 100%; background: #fff; }
	.nav_links { display: block; }
	.nav_links li a, .nav_links li label { padding: 16px 32px; }
	.nav_links li+li { border-top: 1px solid #3333331a;}

	.sub_link:hover .sub_menu { display: none; }
	#dropdown:checked ~ ul { width: 100%; display: block; position: relative; padding: 0; background: #fff0; box-shadow: unset; }
}



/* ---------- ----- POPUP MODEL ----- ---------- */
.modal { display: none; position: fixed; z-index: 9999; padding-top: 100px; left: 0; top: 0;
  width: 100%; height: 100%; overflow: auto; background: #00000080; }

.modal-content { background: #fefefe; margin: auto; border: 1px solid #888; width: 360px; }

.modal-head { display: flex; justify-content: space-between; align-items: center; padding: 16px; background: var(--c1); }
.modal-head { font-size: 24px; }

.close { color: #aaaaaa; font-size: 28px; font-weight: bold; }
.close:hover,
.close:focus { color: #000; text-decoration: none; cursor: pointer; }

.modal-body { display: block; width: 100%; }
.modal-body iframe { width: 100%; height: 380px; border: 0; }





/* ========== ========== ===== Pages Section ===== ========== ========== */


/* ----- Title ----- */
.section-title { display: block; max-width: 750px; text-align: center; margin: auto auto 60px auto; }
.section-title h2 { display: inline-block; font-size: 32px; font-weight: 700; position: relative; text-transform: capitalize; }
.section-title h4 { font-size: 20px; font-weight: 500; margin-bottom: 12px; text-transform: uppercase; color: var(--c1); }
.section-title .style { display: block; }
.section-title .style span { display: inline-block; width: 60px; height: 3px; background: #333; }
.section-title .style span:last-child { background: var(--c1); }






/* ---------- ----- About Us ----- ---------- */
.aboutus_row { display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 24px; }
.aboutus_col { width: 100%; display: block; position: relative; }
.aboutus_txt { display: block; }
.aboutus_txt h2 { font-size: 42px; line-height: 1.2; }
.aboutus_txt h3 { font-size: 18px; font-weight: 100; margin-top: 12px; }
.aboutus_txt p  { margin-top: 12px; text-align: justify; }
.aboutus_txt a { display: inline-block; padding: 12px 32px; background: var(--c1); color: #000;
	transition: var(--ts); margin-top: 16px; border-radius: 50px; }
.aboutus_txt a:hover { background: var(--rg); color: #fff; }

.aboutus_txt ul { font-size: 15px; margin-top: 16px; list-style-type: disc; padding-left: 16px; }
.aboutus_txt ul li+li { margin-top: 12px; }

.aboutus_img { display: block; width: 100%; }
.aboutus_img img { width: 100%; height: auto; }


@media all and (max-width:480px) {

	.aboutus_row { grid-template-columns: repeat(1, 1fr); }
}


/* ---------- ----- Services ----- ---------- */
.service_row { display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 24px; }
.service_col { width: 100%; display: block; position: relative; box-shadow: var(--bs); background: #fff; border-radius: 8px; overflow: hidden; }
.service_img { display: block; width: 100%; }
.service_img img { width: 100%; height: auto; }
.service_txt { display: block; padding: 24px; }
.service_txt h3 { font-size: 24px; }
.service_txt p  { margin-top: 12px; text-align: justify; }
.service_txt a { display: inline-block; padding: 12px 32px; background: var(--c1); color: #000;
	transition: var(--ts); margin-top: 16px; border-radius: 50px; }
.service_txt a:hover { background: var(--rg); color: #fff; }

@media all and (max-width:480px) {

	.service_row { grid-template-columns: repeat(1, 1fr); }
}



/* ---------- ----- Why Choose ----- ---------- */
.why_row { display: grid; grid-template-columns: repeat(3, 1fr); grid-gap: 16px; }
.why_col { display: block; width: 100%; position: relative;
	padding: 24px; text-align: center; background: #fff; transition: var(--ts); box-shadow: var(--bs); z-index: 1; }

.why_col::before, .why_col::after { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; transition: var(--ts); }
.why_col::before { width: 92%; height: 90%; border: 1.5px dashed #333; margin: auto; z-index: 0; }
.why_col::after { width: 100%; height: 100%; background: var(--rg); opacity: 0; z-index: -1; }

.why_col_icon { font-size: 60px; color: var(--rg); }
.why_col_text { margin-top: 16px; }
.why_col_text h3 {  }
.why_col_text p  { margin-top: 12px; text-align: justify; }

.why_col:hover { color: #fff; }
.why_col:hover h3 { color: var(--c1); }
.why_col:hover:before { border: 1.5px dashed #fff;  }
.why_col:hover:after { opacity: 1; }


@media all and (max-width:480px) {

	.why_row { grid-template-columns: repeat(1, 1fr); }
}



/* ---------- ----- Reviews ----- ---------- */
.reviews { background: #f2f2f2; }
.review_carousel { display: block; }
.review_slider { width: 33.33%; display: inline-block; overflow: hidden; padding: 20px;  }

.review { display: block; box-shadow: var(--bs); position: relative; z-index: 1; }
.review:before { content: ""; position: absolute; top: -20px; left: -20px;
	display: block; width: 100%; height: 100%;  border: 1px solid #ddd; z-index: -1; }

.review_box { display: block; background-color: #fff; height: 260px; padding: 16px; position: relative; z-index: 3; }

.reviewer_area { display: flex; align-items: center; gap: 16px; position: relative; }
.reviewer_area:after { content: ""; position: absolute; right: 0;
	display: block; width: 28px; height: 28px; background: url("assets/images/google-icon.png") no-repeat center / cover; }

.reviewer_thumb { width: 62px; height: 62px; display: block;  }
.reviewer_thumb img { width: 100%; height: auto; }

.reviewer_Info h3 { font-size: 18px; }
.reviewer_Info span { display: block; font-size: 20px; font-weight: bold; color: #FFDF00; margin-top: 8px; }

.reviewer_text { margin-top: 16px; }

@media all and (max-width: 480px) {

	.review_slider { width: 100%; padding: 24px 16px 24px 24px; }
	.review:before { top: -16px; left: -16px; }
	.review_box { padding: 30px 16px; }
}



/* ========== ========== ===== Pages CSS Section ===== ========== ========== */


/* ========== Page Banner ========== */
.banner_page { display: block; width: 100%; position: relative; background: url("assets/images/page-banner.jpg") no-repeat center / cover; }
.banner_page:before { content: ""; background: url("assets/images/shape-3.png") no-repeat;
	position: absolute; left: 0; bottom: 0; width: 100%; height: 100%; }

.page_content { display: block; max-width: 1140px; margin: auto; padding: 150px 16px; position: relative; }
.page_content h1 { font-weight: 700; color: #000; font-size: 3rem; }

.breadcrumb { display: inline-block; margin: 32px 0px 0px 8px; }
.breadcrumb li { display: inline-block; position: relative; font-weight: 800; color: #000; text-transform: uppercase; font-size: 14px; }
.breadcrumb li i { margin-right: 4px; }
.breadcrumb li.pactive { color: var(--c3); }

.shapes { padding: 8px 4px; margin: 0 8px; }
.shapes::before,
.shapes::after { content: ""; font-weight: 600; display: inline-block; position: absolute; top: 6px; width: 5px; height: 5px; color: #ddd; border: 2px solid #333; border-radius: 50%; }
.shapes::before { left: 0; }
.shapes::after {right: 0;}

@media all and (max-width: 480px) {
	.banner_page { padding-bottom: 0px;  }
	.page_content { padding: 120px 16px; }
}

@media (min-width: 500px) and (max-width: 1200px) {
	.page_content { padding: 120px 16px; }
}




.calculator { display: block; background: #fff; box-shadow: var(--bs); border-radius: 8px; overflow: hidden; margin-bottom: 16px; }

/* Title */
.calc_title { display: block; padding: 24px 16px; text-align: center; background: yellow; }
.calc_title h2 { font-size: 32px; }
.calc_title p { margin-top: 8px; font-size: 18px; }

/* Form */
.calc_form { display: block; width: 100%; padding: 24px; }

.input_group { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.input_group+.input_group { margin-top: 20px; }

.input_ { display: block; width: 100%; }
.input_ label { display: block; position: relative; font-size: 15px; font-weight: 500; color: #000; margin-bottom: 8px; }
.input_ input,
.input_ select { width: 100%; padding: 12px 16px; background: #f5f5f5; border: 1px solid #e1e1e1; border-radius: 6px; outline: 0; }
.input_ button { padding: 14px 32px; border: 0; outline: 0; font-size: 16px; font-family: var(--Poppins);
	border-radius: 50px; background: yellow; color: #000; }

/* Results */
.results { max-width: 400px; margin: auto auto 24px auto; }
.results table { font-family: arial, sans-serif; border-collapse: collapse; width: 100%; }
.results th { border: 1px solid #dddddd; text-align: center; padding: 12px 8px; background-color: #dddddd; font-size: 24px; }
.results td { border: 1px solid #dddddd; text-align: left; padding: 4px 2px; font-size: 14px; }

@media all and (max-width:480px) {
	.calc_title { padding: 18px 16px; }
	.calc_title h2 { font-size: 24px; }
	.calc_title p { margin-top: 6px; font-size: 14px; }

	.calc_form { padding: 18px 16px; }
	.input_group { flex-direction: column; gap: 8px; }
	.input_group+.input_group { margin-top: 8px; }

	.input_ label { font-size: 14px; font-weight: 500; margin-bottom: 6px; }
	.input_ input, .input_ select { padding: 9px 16px; }
	.input_ button { margin-top: 8px; }
}

@media (min-width: 500px) and (max-width: 992px) {
	.input_group:nth-child(2) { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
}








/* ========== ===== ===== Service Page ===== ===== ========== */

.service_row_ { display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 24px; }
.service_col_ { display: block; width: 100%; }
.service_col_:nth-child(3) { grid-column: 1/ span 2; }

.service_col_ h2 { font-size: 24px; line-height: 1.4em; }
.service_col_ h2 span { display: block; color: var(--c2); font-size: 28px; }
.service_col_ p { margin-top: 16px; text-align: justify; }
.service_col_ ul { margin: 16px 0px 0px 16px; list-style-type: disc; }
.service_col_ ul li+li { margin-top: 12px; }
.service_col_ img { width: 100%; height: auto; }

@media all and (max-width:480px) {
    .service_row_ { grid-template-columns: repeat(1, 1fr); }
    .service_col_:nth-child(3) { grid-column: unset; }
}

/* ----- HOW IT WORKS ----- */
.how_it_works { background: var(--c1); }
.work_row_ { display: grid; grid-template-columns: repeat(3, 1fr); grid-gap: 24px; }
.work_row__ { display: grid; grid-template-columns: repeat(4, 1fr); grid-gap: 24px; }
.work_col_ { display: block; width: 100%; position: relative; padding: 24px 16px; background: #fff; box-shadow: var(--bs); border-radius: 8px; }
.work_col_img { display: block; width: 82px; margin: auto; }
.work_col_img img { width: 100%; height: auto; }
.work_col_txt { display: block; margin-top: 24px; }
.work_col_txt h3 { font-size: 20px; text-align: center; }
.work_col_txt p { margin-top: 16px; text-align: justify; }

@media all and (max-width: 480px) {
	.work_row_, .work_row__ { grid-template-columns: repeat(1, 1fr); grid-gap: 16px; }
}

@media (min-width: 500px) and (max-width: 992px) {
	.work_row_ { grid-gap: 16px; }
	.work_row__ { grid-template-columns: repeat(2, 1fr); grid-gap: 16px; }
}

/* ----- DOCUMENTS REQUIRED ----- */
.doc_row_ { display: grid; grid-template-columns: repeat(5, 1fr); grid-gap: 24px; }
.doc_row__ { display: grid; grid-template-columns: repeat(4, 1fr); grid-gap: 24px; }
.doc_col_ { display: block; width: 100%; position: relative; padding: 24px 16px; background: var(--c1); box-shadow: var(--bs); border-radius: 8px; }
.doc_col_img { display: block; width: 82px; margin: auto; }
.doc_col_img img { width: 100%; height: auto; }
.doc_col_txt { display: block; margin-top: 24px; }
.doc_col_txt h3 { font-size: 16px; text-align: center; }
.doc_col_txt p { margin-top: 16px; text-align: justify; }

@media all and (max-width: 480px) {
	.doc_row_, .doc_row__ { grid-template-columns: repeat(2, 1fr); grid-gap: 16px; }
}

@media (min-width: 500px) and (max-width: 992px) {
	.doc_row_, .doc_row__ { grid-gap: 16px; }
}



/* ========== ===== ===== Contact Page ===== ===== ========== */

.section-contact { display: block; padding: 100px 16px; }
.contact_row { display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 24px; }
.contact_col { display: block; width: 100%; }

.contact_text { display: block; }
.contact_text h2 { font-size: 32px; margin-top: 12px; }
.contact_text p { margin-top: 16px; }
.contact_text p+p { margin-top: 6px; }
.contact_box { display: block; margin-top: 24px; }
.contact_box ul { display: flex; align-items: center; gap: 24px; }
.contact_box ul li i { font-size: 42px; color: #1cc34f; }
.contact_box ul li h3 { font-size: 18px; }
.contact_box ul li p { font-size: 15px; margin-top: 8px; }

.contact_form { display: block; padding: 32px; background: #fff; border-radius: 6px; box-shadow: 0px 7px 24px 0px #0000001f; }
.contact_form h2 { font-size: 32px; }
.contact_form p { margin-top: 16px; }
.contact_form form { display: block; }
.form_group { display: flex; gap: 16px; margin-top: 16px; }
.form_group input,
.form_group select,
.form_group textarea { width: 100%; padding: 16px; background: #f3f5fd; border: 1px solid #f3f5fd; outline: 0; }
.form_group button { padding: 16px 48px; border: 0; outline: 0; border-radius: 4px; background: var(--c1); color: #000; }

@media all and (max-width: 480px) {
	.contact_row { grid-template-columns: repeat(1, 1fr); }
	.form_group { flex-direction: column; }
}

@media (min-width: 500px) and (max-width: 992px) {
	.contact_row { grid-template-columns: repeat(1, 1fr); }
}




/* ========== ========== ===== Footer Section ===== ========== ========== */
.footer {  }

.upper_section { width: 100%; display: block; background: #000; position: relative; padding: 60px 16px; }
.footer_row { width: 100%; display: grid; grid-template-columns: 45% 25% 30%; }
.footer_col { width: 100%; display: block; color: #fff; }
.footer_col h3 { font-size: 22px; color: var(--c1); margin-bottom: 24px; }

.footer_col:first-child { padding-right: 60px; }

.footer_social { display: inline-flex; gap: 8px; margin-top: 24px; }
.footer_social a { display: block; width: 38px; height: 38px; line-height: 38px; text-align: center;
	background: #1e282f; color: #fff; border-radius: 6px; transition: var(--ts); }
.footer_social a:hover { background: var(--c1); color: #000; }

.quick_links { display: block; }
.quick_links li+li { margin-top: 12px; }
.quick_links li { transition: var(--ts); }
.quick_links li a { display: block; position: relative;  }
.quick_links li a:before { content: "\f061"; font-family: "Font Awesome 6 Pro";
	font-weight: 900; font-size: 13px; margin-right: 8px; color: var(--c1); }
.quick_links li:hover { margin-left: 16px; color: #fff; }

.footer_anch+.footer_anch { margin-top: 16px; }
.footer_anch { display: block; }
.footer_anch ul { display: flex; align-items: center; }
.footer_anch ul li { display: block; margin-top: 0; }
.footer_anch ul li:first-child { width: 34px; }
.footer_anch ul li:last-child  { width: 80%; }
.footer_anch ul li i { font-size: 18px; padding-top: 5px; color: var(--c1); }
.footer_anch ul li p  {  margin-top: 0px; }
.footer_anch ul li a { display: block; margin-top: 8px; }
.footer_anch:last-child ul { align-items: flex-start; }


.lower_section { width: 100%; display: block; background: var(--c1); position: relative; text-align: center; }
.lower_section .row { display: flex; justify-content: center; align-items: center;  gap: 12px; max-width: 1140px; margin: auto; padding: 26px 16px; }
.lower_section .row p {  }
.lower_section .row p a { display: inline-block; color: var(--c1); font-weight: 500; }
.lower_section .row .lower_section_img { display: inline-block; width: 140px; }
.lower_section .row .lower_section_img img { width: 100%; height: auto; }

@media all and (max-width: 480px) {
	.footer_row { grid-template-columns: repeat(1, 1fr); grid-gap: 32px; }
	.footer_col:first-child { padding-right: 0px; }

	.lower_section .row { flex-direction: column; padding: 16px; }
}