/*
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/




/* ========================================== product page css ================================================== */

*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.container{
    width: 100%;
    max-width: 1230px;
    padding: 0 15px;
    margin: 0 auto;
}

.d-flex{
    display: flex;
}

/* -------------------------------------------------------- */

.hero-sec{
    height: 565px;
    width: 100%;
    padding: 40px 50px ;
}

.hero-sec .hero-bg{
    background-image: linear-gradient(rgba(0, 0, 0, 0.041),#17479e),url(./assets/images/header.jpg);
    background-position: top center;
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    height: 100%;
    width: 100%;
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    
}

.hero-sec .hero-bg p{
    font-size: 57px;
    line-height: 3.5rem;
    text-align: center;
    font-weight: 600;
    color: #fff;
}

.product-section-wrapper{
    background-color: #fff;
    padding: 50px 0;
}

.product-section .section-head {
    text-align: center;
    font-weight: 500;
    font-size: 35px;
    text-shadow: 0 0;
    color: #000;
    text-shadow: 0px 1px 1px #000;
}

.product-section .section-subhead{
    text-align: center;
}

.product-section .product-type{
    margin-top: 40px;
}

.product-section .product-type h4{
    font-size: 30px;
}

.product-section .product-wrapper{
    margin: 40px 0;
    flex-wrap: wrap;
    justify-content: space-between;
}

.product-section .product-card{
    background-color: #C9DCFF;
    height: 230px;
    width: 100%;
    position: relative;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}

.product-section .product-card h6 {
    font-size: 28px;
    color: #17479E;
    text-align: center;
    font-weight: 500;
    text-shadow: 0 0;
    line-height: 42px;
}
.product-overlay::before{
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    top: 0;
    right: 0;
    height: 100%;
    width: 100%;
    z-index: -1;
    background-color: #17469ee0;
    transform: translateY(120%);
    transition: 0.6s;
}

.product-overlay{
    text-align: center;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 15px;
    padding: 15px;
    transform: translateY(-20%);
    transform-origin: bottom;
    transition: all 0.6s;
    opacity: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1;
    left: 0;
    bottom: 0;
}

.product-section .owl-nav button {
    width: 35px;
    height: 35px;
    font-size: 20px !important;
    position: absolute;
    display: inline-block;
    background: #17479E !important;
    border-radius: 5px !important;
    left: -19px;
    top: 44%;
    transform: translateY(-50%);
}
.product-section .owl-nav button.owl-next {
    right: -19px;
    left:auto;
   
}
.product-section .owl-nav button span{
    color:#ffffff;
    font-size:20px;
}

.product-section .product-card:hover .product-overlay{
    transform: translateY(0);
    opacity: 1;
}

.product-section .product-card:hover .product-overlay::before{
    transform: translateY(0);
}

.product-card-btn a{
    background-color: #00cea6;
    color: #17479E;
    padding: 6px 18px;
}

.category-icon svg{
    width: 18px;
    height: 18px;
    fill: #17479E;
}


/* ================================================ Responsive ============================================= */

@media only screen and (max-width: 1024px){

    .hero-sec{
        height: 320px;
    }

    .hero-sec .hero-bg p{
        font-size: 32px;
    }
    
}

@media only screen and (max-width: 991px){
 
}

@media only screen and (max-width: 767px){
 
}

@media only screen and (max-width: 575px){

    .hero-sec{
        height: 200px;
        padding: 15px ;
    }

    .hero-sec .hero-bg{
        padding: 0 20px;
    }

    .hero-sec .hero-bg p{
        font-size: 28px;
    }

    .product-section .product-type h4{
        font-size: 24px;
    }
    
}







.kg-promotion-tabs {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0 10px;
    border-bottom: 1px solid #6599e3;
}
.kg-promotion-tabs li a {
    padding: 10px 30px;
    display: inline-block;
    border-radius: 7px;
    background: #f4f4f4;
    color: #434343;
    font-size: 22px;
    font-weight: 500;
    line-height: 32px;
    margin: 0 9px 0px;
}
.kg-promotion-tabs li .kg-org-active {
    background: #D4E8FF;
    color: #4474B9;
    font-weight: 600;
}
.kg-promotion-tabs li a:hover, .kg-promotion-tabs li a:focus {
    background: #D4E8FF!important;
    color: #4474B9!important;
}

.kg_loader img.lazyload {
    width: 100px;
    margin:0 auto;
}
.kg_loader_loadmore {
    text-align: center;
    margin: 50px 0 0;
}
.kg_loader{
    text-align: center;
    margin: 45px 0 0;
    }
    
.product-section .product-item {
    background: #fff;
    border-radius: 10px;
    padding: 20px 20px;
    height: 100%;
    display: flex;
	position:relative;
	    overflow: hidden;

    flex-wrap: wrap;
    justify-content: space-between;
    flex-direction: column;
}

 .product-section .col-6 {
    width: 33.3%;
    padding: 0 15px 30px;
}
.product-section .kg_blog_list {
    display: flex;
    flex-wrap: wrap;
    padding: 60px 0 0;
}
.product-section h2.title {
    font-size: 22px;
    color: #181818;
    line-height: 33px;
    margin: 30px 0 10px;
    text-align: center;
}

.product-section h2.title a {
     color: #181818;
}
.img-section a {
    display: inline-block;
    text-align: center;
    margin: 0 auto;
}
.img-section  {
    text-align: center;
}
.kg_loader_loadmore {
    width: 100%;
}
form#searchform, .searchform {
    padding: 0px 0px 0px;
    position: relative;
    max-width: 504px;
    margin: 40px auto 0;
}

form#searchform input, .searchform input {
    max-width: 500px;
    border-radius: 50px;
}

#searchsubmit, .searchform button[type="submit"] {
    position: absolute;
    left: auto;
    right: 10px;
    top: 5px;
    padding: 14px 32px;
    background: #d5e9fd;
    border-color: transparent;
    font-weight: 500;
    font-size: 20px;
    text-shadow: 0 0;
    box-shadow: rgb(148 183 248) 0 0 2px;
}




ul#search-results {
    position: absolute;
    left: auto;
    right: auto;
    background: #fff;
    width: 100%;
    padding: 18px 8px 18px 18px;
    border-radius: 10px;
    margin: 8px 0 0;
    box-shadow: rgba(0 0 0 / 10%) 0 0 20px;
    height: 300px;
    overflow: hidden;
}
ul#search-results li a {
    color: #000;
    font-size: 16px;
    font-weight: 500;
    padding: 11px 0 11px;
    display: inline-block;
    border-bottom: 1px solid #ddd;
    width: 100%;
}
ul#search-results ul {
    overflow: auto;
    height: 100%;
}


ul#search-results ul {
    scrollbar-width: thin;
    scrollbar-color: #a1a1a1 #f0f0f0;
}


.search-area {
    width: 100%;
}
.entry-thumb {
    width: 100%;
}

.icon-custom span.elementor-icon {
    background: #e4ebff;
    padding: 8px;
    border-radius: 100px;
}

.hover-content {
    transition: all 0.5s;
    transform: scaleY(0);
    transform-origin: bottom;
}

.team-box:hover .hover-content {transform: scaleY(1);
 transition: all 0.5s;}

.home-pg-product .col-6 {
    width: 25%;
    padding: 0 15px 30px;
}

.home-pg-product  .product-item {
    box-shadow: rgba(0 0 0 / 8%) 0 0 19px;
}

.home-pg-product  .product-item  img{
       height: 180px;
object-fit:contain;
}

footer .menu-main-menu-container ul li a {
    color: #fff;
    font-size: 16px;
    margin: 0 0 14px;
    display: inline-block;
}
.btn-product {
    padding: 9px 20px;
    background: #01a883;
    border-color: #01a581;
    border-radius: 7px;
    color: #ffff!important;
    font-size: 16px;
}
.btn-product svg, .btn-product svg path{
	fill:#fff;
}

.overlay-product {
    position: absolute;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    background: #cccc;
	transition: all 0.5s;
    transform: scaleY(0);
    transform-origin: bottom;
}

.overlay-product {
    position: absolute;
    top: auto;
    bottom: 0;
    left: 0;
    right: 0;
    transition: all 0.5s;
    transform: scaleY(0);
    transform-origin: bottom;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: end;
    padding: 25px 20px;
    background: linear-gradient(180deg, rgba(23, 71, 158, 0.2) 0%, rgba(23, 71, 158, 0.6) 24%, rgba(23, 71, 158, 1) 100%);
}
.overlay-product  p{
	color:#fff;
}

.product-section .product-item:hover .overlay-product{
	 transition: all 0.5s;
    transform: scaleY(1);
}
.home-pg-product button.btn-product {
    padding: 9px 4px;
    font-size: 14px;
}


section.product-section.home-pg-product {
    padding: 0;
}

/* hero section */



.listing-content h3{
	margin:5px 0 5px!important;
	
}

.product-section .product-item img.img-fluid {
    width: 100%;
    height: 230px;
    object-fit: contain;
}

section.product-section {
    background: #ffff;
    padding: 60px 10px;
}

.category-block {
    background: #eef5fd;
    padding: 0;
    border-radius: 20px;
    margin: 0 0 40px;
    box-shadow: rgb(23 71 158 / 7%) 0 0 3px;
    overflow: hidden;
}

h2.category-title{
    font-size: 32px;
    text-align: center;
    position: relative;
    padding: 29px 30px 20px;
    /* background: #d2e2ff; */
    margin: 0;
    border-bottom: 1px solid #c0d4f8;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
h2.category-title span {
    color: #ff9700;
    font-size: 22px;
}

h2.category-title span b {
    font-weight: 500;
      color: #000000;
    font-size: 20px;
    margin: 0 12px 0 0;
}


.filter-search {
    width: 100%;
    max-width: 700px;
    display: flex;
    align-items: center;
    gap: 7px;
}
 .filter-select {
    width: 100%;
    max-width: 100%;
}
.product-section .searchform {
    margin: 0;
    width: 100%;
    max-width: 100%;
}
form#letter-filter-form {
    text-align: center;
}

.product-section .searchform input {
    width: calc(100% - 155px);
    border-radius: 100px !important;
    padding: 15px 25px 15px 25px !important;
    font-size: 18px !important;
    border: 0 !important;
    box-shadow: rgb(0 0 0 / 11%) 0 0 7px!important;
    font-style: italic;
}

.select-group {
    display: flex;
    align-items: center;
}

.filter-controls {
    justify-content: center;
    margin: 59px 0 50px;
    align-items: center;
    flex-wrap: wrap;
}

form#letter-filter-form {
    padding: 23px 0 0;
}
select#letter-select {
    max-width: 140px;
    height: 50px;
    background: transparent;
    color: #5A5A5A;
    border: 1px solid #17479E;
    padding: 0 20px;
    font-size: 18px;
    border-radius: 7px;
    	appearance: none;
}
.filter-select label, .filter-search label {
    margin: 0 18px 0 0;
    font-size: 18px;
    color: #000;
}


.filter-select  svg {
    right: 34px;
    position: relative;
}

.clear-button svg{
    width:50px;
    height:50px;
}

.tooltipText {
    background-color: #1c4b9f;
    position: absolute;
    bottom: 130%;
    padding: 4px 8px;
    border-radius: 5px;
    font-size: 12px;
    opacity: 0;
    transition: all .5s;
    color: #ffffff;
    width: 81px;
}

.clear-button {
    padding: 13px 33px;
    position: relative;
    border: 1px solid #fabf87;
    border-radius: 50px;
	font-weight:500;
    color: #f16600 !important;
    background: #ffe6ce;
}
.tooltipText::after {
    content: '';
    border-width: 5px;
    border-style: solid;
    border-color: #1c4b9f transparent transparent transparent;
    position: absolute;
    top: 100%;
    left: 40%;
    margin-left: 5%;
}
.clear-button:hover .tooltipText {
    opacity: 1;
    transform: translateY(-17px);
}

.letter-filter-list .letter-link {
    padding: 5px 12px;
    border: 0;
    border-radius: 4px;
    text-decoration: none;
    color: #333;
    font-weight: 500;
    display: inline-block;
}


.letter-filter-list .hexagon:hover:after {
    background-color: #dbecff;
   
}


.letter-filter-list .hexagon:hover .letter-link{
	    background-color: #dbecff;
	 color: #007bff;
    border-color: #007bff;
}

.hexagon:after

.letter-filter-list .letter-link.active {
    background-color: #007bff;
    color: #fff;
    border-color: #007bff;
}
a.btn.btn-secondary.clear-button {
    width: 46px;
}
.filter-search {
        width: calc(100% - 66px);
}
.filter-controls {
    align-items: end;
}


.hexagon {
  width: 65px;
  height: 38px;
  position: relative;
  display:inline-block;
}

.hexagon, 
.hexagon:before, 
.hexagon:after {
  background: #ffffff;
  box-shadow: 0 0 11px rgb(0 0 0 / 16%);
}

.hexagon:before,
.hexagon:after {
  content: "";
  position: absolute;
  left: 15px;
  width: 35px;
  height: 36px;
  transform: rotate(145deg) skew(22.5deg);
}

.hexagon:before {
  top: -29px;
	display:none;
}

.hexagon:after {
  top: 21px;
}

.hexagon a {
  position: absolute;
  top: 0;
  left: 0;
  width: 65px;
  height: 38px;
  background: #ffffff;
  z-index: 1;
}

@media only screen and (min-width: 767px){
.product-wrapper .owl-carousel.owl-few-items .owl-stage-outer {
     display: flex;
    align-items: center;
    justify-content: center;
	gap:20px;
}
.product-wrapper .owl-carousel.owl-few-items .owl-stage-outer .owl-stage {
        gap: 20px;
        display: flex;
    }
}
/* ================================================ Responsive ============================================= */
@media only screen and (max-width: 1399px){

.counter-box {
    width: 97%;
    margin-left: auto;
    margin-right: auto;
}

}
@media only screen and (max-width: 1299px){
.hero-section .content-banner-box {
        max-width: 84%;
    }
	
.listing-content h3{

	line-height:28px!important;
}

}

@media only screen and (max-width: 1024px){

   .hero-sec {
        height: 320px;
        padding: 0 15px 50px;
    }
    .hero-sec .hero-bg h1{
        font-size: 32px;
    }
	
	.product-section .section-head {
        font-size: 28px;
    }

    .product-section .product-type h4{
        font-size: 24px;
    }
	.product-section h2.title {
    font-size: 20px;
    line-height: 30px;
    word-break: break-word;
}
    
}

@media only screen and (max-width: 991px){
 .kg-promotion-tabs li a {
    padding: 10px 22px;
    font-size: 16px;
    line-height: 25px;
    margin: 0 6px 0px;
}
	.product-section .col-6 {
    width: 33.3%;
    padding: 0 8px 18px;
}
	.kg_loader_loadmore {
    margin:0;
}
	
	section.product-section {
    padding: 0 0 50px;
}
	.hero-section  .content-banner-box {
        width: 100%;
    }

}

@media only screen and (max-width: 767px){
 .product-section h2.title {
    font-size: 18px;
    line-height: 26px;
}
.kg-promotion-tabs li a {
        padding: 10px 8px;
        font-size: 13px;
        margin: 0 4px 0px;
        font-weight: 600;
    }
	.listing-content .elementor-widget-icon-box {
    max-width: 47% !important;
}
	.team-cards .team-box {
    width: 47%;
}
.product-section .col-6 {
        width: 50%;
        padding: 0 25px 25px;
    }
    
	.kg-promotion-tabs {
    padding: 21px 0 13px;
}
	.product-section .product-item {
    padding: 11px 12px;
}
.product-section .kg_blog_list {
    margin: 0 -25px;
}
	ul.letter-filter-list{
		max-width:100%!important;
	}
	#searchsubmit, .searchform button[type="submit"], .clear-button {
       
        font-size: 16px;
        padding: 11px 24px;
		height:45px;
		line-height:normal;
    }
	.product-section .searchform input {
		width: calc(100% - 126px);
}
}

@media only screen and (max-width: 575px){

   .hero-sec {
        height: 250px;
        padding: 0 15px;
    }

    .hero-sec .hero-bg{
        padding: 0 20px;
    }

   .hero-sec .hero-bg h1 {
        font-size: 28px;
        line-height: 41px;
    }
	
	.product-section .section-head {
        font-size: 22px;
    }

    .product-section .product-type h4{
        font-size: 18px;
    }
	
	.home-pg-product .portfolio-nav {
        margin: 0;
    }
	
	.kg-promotion-tabs li a {
    padding: 7px 20px;
    font-size: 14px;
    line-height: 22px;
    margin: 3px 3px 0px;
}
	.kg-promotion-tabs {
    display: flex;
    flex-wrap: wrap;
}
	.product-section .col-6 {
    width: 100%;
    padding: 0 0px 30px;
}
	form#searchform input#s {
    padding: 10px 74px 10px 14px;
}
	#searchsubmit {
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
}
   .portfolio-nav {
    margin: 23px 0 0;
} 
	.product-section .kg_blog_list {
    padding: 31px 0 0;
}

	 .product-section h2.title {
    font-size: 20px;
    line-height: 30px;
}
	.kg-promotion-tabs li a {
        padding: 10px 18px;
        font-size: 16px;
        margin: 6px 8px 0px;
        font-weight: 500;
    }
	section.product-section {
    padding: 0 0 30px;
}
	.listing-content .elementor-widget-icon-box {
    max-width: 100% !important;
}
	.team-cards .team-box {
    width: 90%;
		margin:0 auto;
}
 ul.letter-filter-list {
    width: 100%;
    max-width: 100%!important;
}
.product-section .searchform input {
/*     width: 100% ; */
    padding: 12px 25px 12px 25px !important;
    font-size: 14px !important;
}
	.filter-search {
    width: 100%;
}
	
	
#searchsubmit, .searchform button[type="submit"] {
    position: absolute;
    left: auto;
    right: 10px;
    top: 30px;
    padding: 13px 29px;
}
	ul.letter-filter-list{
		   max-width:100%!important;
	}
	.letter-filter-list .letter-link {
    padding: 2px 8px;
		  font-size: 14px;
}
	#searchsubmit, .searchform button[type="submit"], .clear-button {
        right: 5px;
        top: 0;
        font-size: 15px;
        padding: 9px 24px;
    }
	.filter-select label, .filter-search label {
    margin: 0 0 10px;
}
	.filter-controls {
    margin: 30px 0 20px; 
}
	.product-section .product-type {
    margin-top: 14px;
}
	form#letter-filter-form {
    padding: 5px 0 0;
}
}

@media only screen and (max-width: 430px){
.product-section .searchform input {
        width: 100%;
    }
	#searchsubmit, .searchform button[type="submit"] {
        position: static;
        margin: 20px 0 0;
        display: block;
 
        padding: 6px 24px;
        height: 38px;
    }
.filter-search {
        max-width: 100%;
        flex-wrap: wrap;
        position: relative;
    }
	a.btn.btn-primary.clear-button {
    position: absolute;
    left: auto;
    right: 0;
    bottom: 0;
    top: auto;
    padding: 11px 24px;
    height: 38px;
}
}

.letter-filter-list .letter-link {
    text-decoration: none;
    border-radius: 0px;
    color: #17479e;
    font-weight: 600;
    line-height: 40px;
    font-size: 25px;
}
.letter-filter-list{
	max-width: 90% !important;
	gap: 33px 18px !important;
}
.letter-filter-list li{
	z-index: 0;
	position: relative;
}
.letter-filter-list .hexagon.disabled  .letter-link {
    background: #f6f9ff;
    pointer-events:none;
    color: #8fade4;
}
.hexagon.disabled::after {
    background: #f6f9ff;
    pointer-events:none;
}
.letter-filter-list .hexagon.disabled:hover:after {
    background-color: #f6f9ff;
}

.clear-button:hover .tooltipText {
    opacity: 1;
    transform: translateY(20px);
}


@media only screen and (max-width: 1199px){

	.hexagon {
    width: 50px;
    height: 30px;
    
}
	
.hexagon a, .letter-filter-list .letter-link {
    width: 50px;
    height: 33px;
	line-height: 33px;
    font-size: 21px;
}
	.hexagon:after {
    top: 20px;
}
	.hexagon:before, .hexagon:after {
    left: 12px;
    width: 27px;
    height: 27px;
}
	.letter-filter-list {
    max-width: 85% !important;
    gap: 26px 14px !important;
}
}