@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap");

/* Light 300
Regular 400
Medium 500
SemiBold 600
Bold 700 */
:root { --primary-color: #0f7897; --secondary-color: #00bfdf; --secondary-light-color: #6ecfe0; }
body { font-family: "Poppins", sans-serif; font-weight: 400; font-style: normal; }
li { list-style: none; }
ul { padding: 0; }
ul, p, h1, h2, h3, h4, h5, h6 { margin-bottom: 0; line-height: 1.4; }
p { font-size: 20px; line-height: 25px; }
a { outline: none; color: #fff; text-decoration: none; }
a:hover { text-decoration: none; transition: 0.3s all ease-in-out; color: var(--primary-color); }
.custom-container { padding: 0 120px; }
.custom-container-left { padding-left: 120px; }
.common-section { padding: 80px 0; }
.common-section-top { padding-top: 80px; }
.common-section-bottom { padding-bottom: 80px; }
.title-box { margin-bottom: 35px; }
.title-box.text-center { margin-bottom: 35px; text-align: center; }
.title-box * { color: #141417; }
.title-box p { font-size: 16px; text-transform: uppercase; margin: 0; font-weight: 500; }
.title-box h2 { font-size: 36px; text-transform: uppercase; margin: 0 0 10px; font-weight: 600; }
p { position: relative; color: #888888; font-size: 16px; line-height: 26px; margin: 0; font-weight: 400; }
.common-btn { color: #fff; border: 2px solid var(--primary-color); background: var(--primary-color); border-radius: 8px; font-size: 20px; padding: 16px 30px; position: relative; display: inline-block; transition: all 0.3s ease-in-out; overflow: hidden; }
.common-btn:hover { opacity: 0.8; color: #fff; }
.main-header .header-inner { display: flex; justify-content: space-between; align-items: center; padding: 15px 0; position: relative; }
.main-header .logo { width: 280px; display: block; }
.main-header .logo img { width: 100%; }
nav * { font-size: 15px; line-height: 30px; color: #141417; font-weight: 500; }
nav .inner-menu ul { display: flex; }
nav .inner-menu li { padding: 10px 20px; }
nav .inner-menu a:hover { color: var(--primary-color); }
.shrink.main-header { position: fixed; width: 100%; z-index: 99; background-color: #fff; top: 0; transition: all 0.6s linear; box-shadow: 0 0 20px #dfdfdf; }
.main-header { box-shadow: 0 0 20px #dfdfdf;  background-color : #fff;}

/* banner-section */
.banner-section .item { height: 450px; }
.banner-section .slider-one { background-image: url(../images/banner.jpg); text-align: center; background-repeat: no-repeat; background-size: cover; background-position: center; position: relative; position: relative; height: 100%; }
.banner-section .slider-one.two { background-image: url(../images/banner_1.jpg); }
.banner-section .slider-one.three { background-image: url(../images/banner_2.jpg); }
.banner-section .slider-one.four { background-image: url(../images/banner_3.jpg); }
.banner-section .slider-one.five { background-image: url(../images/banner_4.jpg); }
.banner-section .slider-one:after { content: ""; position: absolute; inset: 0; width: 100%; height: 100%; background-color: rgba(000, 000, 000, 0.5); }
.banner-section h2 { position: relative; z-index: 1; font-size: 2.6rem; font-weight: 500; color: #fff; margin: auto 15rem; text-align: center; justify-content: center; width: 100%; }
.banner-section .custom-container { height: 100%; display: flex; }
.banner-section .owl-dots .owl-dot { width: 10px; height: 10px; background-color: rgba(255, 255, 255, 0.6); border-radius: 8px; display: inline-block; margin: 0 5px; }
.banner-section .owl-dots .owl-dot.active { background-color: var(--primary-color); width: 30px; }
.banner-section .owl-dots { position: absolute; bottom: 30px; left: 0; right: 0; margin: 0 auto; width: 100%; text-align: center; }

/* about-us-section */
.about-us-section .point { margin-top: 40px; }
.about-us-section .split { display: flex; gap: 80px; justify-content: space-around; width: 100%; align-items: center; }
.about-us-section .split div { flex-basis: 100%; }
.about-us-section .point-details { display: flex; gap: 30px; }
.about-us-section .point-details:hover .point-img { margin-top: -10px; transition: all 0.3s linear; }
.about-us-section .point-details div { flex-basis: auto; margin-bottom: 30px; }
.about-us-section .point-img { width: 70px; height: 70px; background-color: var(--primary-color); padding: 12px; transition: all 0.3s linear; }
.about-us-section .point-img img { height: 100%; }
.about-us-section .point-details h5 { font-size: 24px; margin: 0; margin-bottom: 12px; color: #141417; }
.about-us-section .about-img { display: flex; gap: 30px; position: relative; padding: 60px 90px; z-index: 1; }
.about-us-section .about-img img { width: 100%; height: 500px; object-fit: cover; border-radius: 6px; }
.about-us-section .about-img:after { content: ""; position: absolute; background-image: url(../images/shape-66.png); width: 240px; height: 240px; right: 0; top: 0; z-index: -1; transition: all 0.3s linear; background-size: cover; }
.about-us-section .about-img:before { content: ""; position: absolute; background-image: url(../images/shape-66.png); width: 240px; height: 240px; left: 0; bottom: 0; z-index: -1; transition: all 0.3s linear; background-size: cover; }
.about-us-section .about-img:hover:after { right: 20px; top: 20px; }
.about-us-section .about-img:hover:before { bottom: 20px; }

/* services-section */
.services-section { background: linear-gradient(180deg, rgba(244, 244, 244, 1) 0%, rgba(255, 255, 255, 1) 35%); }
.services-section .services-title { display: flex; margin-bottom: 30px; }
.services-section .services-title div { flex-basis: 100%; }
.services-list { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; text-align: center; gap: 30px; }
.services-section a img { width: 20px; margin-left: 10px; transition: all 0.3s linear; }
.services-section a:hover img { margin-left: 20px; }
.services-section .icon { width: 60px; margin: 0 auto; margin-bottom: 35px; transition: all 0.3s linear; }
.services-section .services-name:hover .icon { transform: scale(1.1); transition: all 0.3s linear; }
.services-section .services-name { border: 1px solid #e5e5e5; padding: 40px 30px; transition: all 0.3s linear; display: flex; flex-direction: column; position: relative; overflow: hidden; }
.services-section .services-name:after { content: ""; position: absolute; bottom: -85px; left: -95px; width: 100px; height: 100px; background-color: var(--primary-color); transform: rotate(140deg); transition: all 0.3s linear; }
.services-section .services-name:hover:after { bottom: -45px; left: -55px; transition: all 0.3s linear; }
.services-section * { color: #141417; }
.services-section h5 { font-size: 22px;  /* margin-bottom: 25px; */ height: 100%; }
.services-section .services-name:hover { border-color: var(--primary-color); box-shadow: 0px 10px 50px 0px rgb(0 0 0 / 10%); }

/* Contact section */
.contact-section { background-image: url(../images/contact-bg.jpg); background-repeat: no-repeat; background-size: cover; background-position: center; text-align: center; position: relative; }
.contact-section h3 { font-size: 40px; color: #fff; margin: 0 20rem; }
.contact-section:after { content: ""; inset: 0; width: 100%; height: 100%; background-color: rgba(000, 000, 000, 0.6); position: absolute; }
.contact-section .custom-container { position: relative; z-index: 1; }

/* footer */
footer { background-color: var(--primary-color);  /* background-image: url(../images/footer-bg.svg); */ background-repeat: no-repeat; background-size: contain; background-position: bottom; position: relative; overflow: hidden; }
footer .custom-container { position: relative; z-index: 1; }
footer:after { content: ""; position: absolute; top: 250px; right: -300px; width: 500px; height: 500px; background-color: #fff; border-radius: 50%; opacity: 0.1; border: solid 20px var(--secondary-color); }
footer:before { content: ""; position: absolute; top: -250px; left: -350px; width: 500px; height: 500px; border-radius: 50%; background-color: #fff; opacity: 0.1; border: solid 20px var(--secondary-color); }
footer .box .logo { width: 300px; display: block; margin-bottom: 20px; }
footer .logo { width: 400px; margin: 0 auto; }
footer .logo img { width: 100%; }
footer * { color: #fff; }
footer .footer-inner { text-align: center; }
footer .box a { font-size: 18px; line-height: 35px; }
footer .box a:hover { color: rgba(255, 255, 255, 0.6); }
footer .box li:hover img { margin-top: -10px; transition: all 0.3s linear; }
footer .box ul li { position: relative; }
footer .box span { width: 50px; height: 50px; border-radius: 6px; text-align: center; padding: 8px 0; display: block; margin: 0 auto 10px; }
footer .box span img { width: 100%; height: 100%; }
footer .design-by { background-color: #1e1e1e; padding: 15px 0; position: relative; z-index: 1; }
footer .design-by .copy { display: flex; justify-content: center; }
footer .design-by * { color: rgba(255, 255, 255, 0.4); }
footer .design-by .copy a { margin-left: 5px; }
footer .design-by .copy a:hover { color: var(--primary-color); }
footer .box ul { display: flex; justify-content: space-around; gap: 10px; margin-top: 40px; border-top: solid 1px rgba(255, 255, 255, 0.4); padding-top: 40px; }
footer .box p { max-width: 60%; margin: 0 auto; }

/* back-to-top */
.back-to-top { cursor: pointer; height: 50px; width: 50px; background: var(--primary-color); text-align: center; padding: 7px; position: fixed; bottom: 30px; right: 30px; z-index: 9; border-radius: 6px; }
.back-to-top a { color: white; text-decoration: none; font-size: 20px; display: block; }
.back-to-top svg { height: 36px; width: auto; }
.back-to-top:hover { background-color: var(--secondary-color); }
.logo-and-menu .menu { position: absolute; right: 0; top: 0; bottom: 0; margin: auto; height: 20px; display: none; cursor: pointer; }
.logo-and-menu .menu span { width: 32px; height: 3px; background: #333; display: block; margin-bottom: 6px; }


.contact-section .form-box { width: 50%; margin: 0 auto; }
.contact-section .form-box .form-control {
  height: 50px;
  border: none;
  border-radius: 6px;
  padding: 0 20px;
}

.contact-section .form-box .form-group {
  margin-bottom: 25px;
}
.contact-section .form-box textarea.form-control {
  border-radius: 6px;
  height: 110px;
  padding: 10px 20px;
}

footer .box ul li { width: 33.33%; }
.contact-section .form-box .form-group:last-of-type { margin-bottom: 0; }
.about-us-section .about-img img { object-position: bottom; }
.about-us-section p { font-size: 20px; line-height: 30px; margin-bottom: 20px; }
.about-us-section p:last-of-type { margin-bottom: 0; }
.contact-section .title-box h2 { color: #fff; }
.about-us-section p { color: var(--primary-color); }
.about-us-section .content-box p { font-size: 17px; margin-bottom: 14px; color: #888888; line-height: 25px; }
.about-us-section .content-box li { position: relative; font-size: 17px; color: #888888; padding-left: 20px; padding-bottom: 15px; line-height: 1.5; }
.about-us-section .content-box li::before { content: ''; position: absolute; left: 0; height: 10px; width: 10px; background: var(--primary-color); border-radius: 50%; top: 7px; }
.about-us-section .content-box .left-box { width: 35%; display: inline-block; vertical-align: middle; overflow: hidden; border-radius: 6px; }
.about-us-section .content-box .right-box { width: 65%; display: inline-block; vertical-align: middle; padding-left: 80px; margin-left: -5px; }
.about-us-section .content-box { padding-top: 50px; }
.about-us-section .content-box p:last-of-type { margin-bottom: 0; }
.wpcf7-response-output {
    color: #fff;
}

/* virendra */
.contact-section .form-box .wpcf7-spinner { position:absolute;}