/**
 * CAROUSEL
 */
.swiper-container {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    z-index: 1;
}
.swiper-container .swiper-pagination.swiper-pagination-bullets {
	bottom: 0;
	position: relative;
	margin-top: 20px;
}
.swiper-container .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 1.5px !important;
	background: var(--color-primary);
	opacity: 0.5;
}
.swiper-container .swiper-pagination-bullet-active {
    width: 20px;
	border-radius: 30px;
	opacity: 1;
}

.swiper-button-next, 
.swiper-button-prev {
	color: var(--color-white) !important;
	font-size: 20px;
}
.swiper-button-next:after, 
.swiper-button-prev:after {
	font-size: inherit !important;
}

.swiper-nav {
    display: flex;
    justify-content: end;
    align-items: center;
    gap: 15px;
}
.swiper-nav .swiper-button-next, 
.swiper-nav .swiper-button-prev {
    position: relative;
    margin: 0;
    color: var(--color-white);
    right: 0;
    left: 0;
    width: auto;
    height: auto;
}
.swiper-nav .swiper-button-next {
	order: 1;
}

@media (min-width:991px) {
	.swiper-button-next, 
	.swiper-button-prev {
		font-size: 30px;
	}	
}



/**
 * Top Header
 */
.top-header {
    padding: 4px 15px;
    font-size: 0.625rem;
    font-weight: var(--font-weight-medium);
    background: var(--color-accent);
}
.top-header .container {
    justify-content: space-between;
    flex-wrap: nowrap;
}
.top-header .element-wrap {
    align-content: center;
    align-items: center;
}
.top-header .element-widget {
	display: inline-block;
	width: auto;
}
.top-header .element-widget i {
	margin-right: 4px;
}
.top-header .element-column:last-child .element-widget:not(:last-child) {
    border-right: 1px solid var(--border-gray-dark);
    padding-right: 10px;
}

.glanguage .notranslate { 
	translate: none; 
}
.glanguage .dropdown {
	position: relative;
	display: inline-flex;
	cursor: pointer;
	user-select: none;
	gap: 3px;
}
.glanguage .dropdown .options {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    border: 1px solid #e6e6e6;
    background: var(--color-white);
    width: 90px;
    max-height: 185px;
    overflow-y: auto;
    z-index: 99999;
    margin-top: 8px;
    border-radius: 5px;
    padding: 10px;
}
.glanguage .dropdown .options div {
    padding: 2px 5px;
    cursor: pointer;
    transition: 1s;
}
.glanguage .dropdown .options div:hover { 
	color: var(--color-primary); 
}

/* Default Google widget offscreen but alive */
.translated-ltr body,
.translated-rtl body {
	top: 0 !important
}
.skiptranslate { 
	display: none !important; 
}
#google_translate_element {
	position: absolute;
	left: -9999px;
	top: 0;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

@media (min-width: 767px) {
	.top-header {
        padding: 6px 15px;
        font-size: var(--font-size-xs);
    }	
	.top-header .call {
		border-right: 1px solid var(--border-gray-dark);
		padding-right: 20px;
	}
	.top-header .element-column:last-child .element-widget:not(:last-child) {
    	padding-right: 20px;
	}
	.top-header .tp-social a:not(:last-child) {
		margin-right: 10px;
	}
}
@media (min-width: 991px) {
	.top-header {
		padding: 8px 0;
	}
}
@media (max-width: 991px) {
	.top-header .call span,
	.top-header .iso {
	    display: none;
	}
}
@media (max-width: 768px) {
	.top-header .element-column {
		width: auto;
	}
	.top-header .element-wrap {
		gap: 10px;
	}
	.top-header .email {
	    display: none;
	}
}



/**
 * Header
 */
.main-header {
	padding: 10px 15px;
	z-index: 9999;
	transition: top 0.3s ease, box-shadow 0.3s ease;
}
.main-header.sticky {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: #fff;
    box-shadow: 0 0 8px 0 rgba(0,0,0,0.2);
}
.main-header .container {
    justify-content: space-between;
    flex-wrap: nowrap;
}
.main-header .element-wrap {
    align-content: center;
    align-items: center;
} 
.main-header .element-widget {
    display: inline-block;
    position: relative;
    width: auto;
}
.main-header .logo-link {
    display: block;
}
.main-header .logo {
    display: block;
    width: 140px;
    transition: width 0.3s ease;
}

/* site navigation */
.site-navigation,
.site-navigation ul.menu,
.site-navigation ul.menu li {
    position: relative;
    display: block;
} 
.site-navigation ul.menu > li {
	padding: 10px 0;
}
.site-navigation ul.menu > li a {
	font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
    line-height: var(--line-height-tight);
    white-space: nowrap;
}
.site-navigation ul.menu > li a .chevron {
    font-size: var(--font-size-base);
    margin-left: 5px;
    vertical-align: middle;
    display: inline-block;
}
.site-navigation ul.menu li:hover > a, 
.site-navigation ul.menu li.active > a {
	color: var(--color-primary);
}
.site-navigation ul.menu li ul.sub-menu li a {
	font-size: var(--font-size-base);
}
.site-navigation ul.menu li ul.sub-menu li:not(:last-child) {
	margin-bottom: 3px;
}

/* responsive */
@media (min-width: 991px) {
	.main-header {
		padding: 20px 0;
	}	
	.main-header.sticky {
		padding: 10px 0;
	}
	.main-header .logo {
		width: 230px;
	}
	.main-header.sticky .logo {
		width: 160px;
	}

	.site-navigation-toggle-holder {
		display: none;
	}

	.site-navigation ul.menu > li {
		display: inline-block;
	}
	.site-navigation ul.menu > li:not(:last-child) {
		margin-right: 25px;
	}

	/* submenu */
	.site-navigation ul.menu li > ul.sub-menu {
		position: absolute;
		top: 100%;
		left: 0;
		z-index: 7;
		padding: 20px 0;
		background-color: #fff;		
		border-radius: 5px;
		opacity: 0;
		visibility: hidden;
		box-shadow: 0 4px 30px 0 rgba(0, 0, 0, 0.15);
		transform: translateY(10px);
    	transition: transform 0.5s ease;
	}
	.site-navigation ul.menu li > ul.sub-menu li > ul.sub-menu {
		top: 0;
		left: 100%;
		margin-left: 1px;
	}
	.site-navigation ul.menu li:hover > ul.sub-menu {
	    opacity: 1;
	    visibility: visible;
	    transform: translateY(0);
	}
	.site-navigation ul.menu li ul.sub-menu li {
		padding-left: 30px;
		padding-right: 30px;
	}
	.site-navigation ul.menu li ul.sub-menu li a .chevron {
    	transform: rotate(-90deg);
    	transition: transform 0.3s ease;
	}
	.site-navigation ul.menu li ul.sub-menu li a:hover .chevron {
    	transform: rotate(90deg);
	}
}
@media (max-width: 991px) {
	.main-header .element-column {
		width: auto;
	}
	
	/* toggle holder */
	.site-navigation-toggle-holder {
		margin-left: 15px;
	}
	.site-navigation-toggle-holder.active::after {
    	content: '';
    	position: fixed;
    	inset: 0;
    	background-color: rgba(0, 0, 0, 0.6);
    	z-index: 1;
    	transition: background-color 0.3s ease-in-out;
    	pointer-events: none;
	}
	.site-navigation-toggle-holder .site-navigation-toggle {
        color: var(--color-primary);
        font-size: var(--font-size-2xl);
        cursor: pointer;
        position: relative;
        z-index: 5;
        padding: 0;
    }
	.site-navigation-toggle-holder .site-navigation-toggle[aria-expanded="true"] .bi-list:before {
		content: "\F659";
	}

	/* site navigation */
	.site-navigation {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		width: 230px;
		padding: 80px 0 0 50px;
		background-color: var(--color-white);
		transform: translateX(100%);
		transition: transform 0.3s ease-in-out;
		overflow-y: auto;
		z-index: 5;
	}
	.site-navigation.dropdown {
		transform: translateX(0);
		box-shadow: -8px 0 15px rgba(0, 0, 0, 0.2);
	}	
	.site-navigation ul.menu li ul.sub-menu {
		padding: 10px 0 0 15px;
	}
}

/* header utility
.htop-right {
    display: flex !important;
    gap: 0;
    line-height: 0;
}
@media (min-width: 991px) {
}
*/



/**
 * Archive Header
 */
.archive-header {
	position: relative;
    background: var(--color-primary);
    padding: 30px;
    text-align: center;    
}
.archive-header h1 {
    position: relative;
    font-size: 2rem;
	font-weight: var(--font-weight-medium);
    color: var(--color-white);
    text-transform: capitalize;
}
@media (min-width: 767px) {
	.archive-header {
		padding: 50px 0;
	}
	.archive-header h1 {
        font-size: 3rem;
    }
}
@media (min-width: 991px) {
	.archive-header {
		padding: 60px 0;
	}	
	.archive-header h1 {
        font-size: 4rem;
    }    
}



/**
 * Slider
 */
.element-slides {
	position: relative;
}
.element-slides .swiper-container {
	width: 100%;
	height: 200px;
}
.element-slides .slide-bg {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	min-width: 100%;
	min-height: 100%;
	background-color: var(--color-primary);
}
.element-slides .slide-inner {
	position: absolute;
	inset: 0;
	margin: auto;
	color: var(--color-white);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 70%;	

	align-items: center;
	justify-content: center;  /* flex-start - center - flex-end */
	text-align: center;
}
.element-slides .slide-content {
    position: relative;
    z-index: 1;
    width: 100%;
}
.element-slides .slide-content .slide-heading {
    font-size: 1rem;
    line-height: 1;
    font-weight: 400;    
}
.element-slides .slide-content .slide-description {
    font-size: 2rem;
    line-height: 1;
    font-weight: 700;
    margin-top: 10px;
    
}
.element-slides .slide-content .animation {
    display: none;
}
.element-slides .slide-content .animation.curr_swiper {
    display: block;
}
.element-slides .swiper-pagination.swiper-pagination-bullets {
	position: absolute;
	bottom: 30px;
	margin: 0;
	display: none;
}
@media (min-width:767px) {
	.element-slides .swiper-container {
		height: 450px;
	}
	.element-slides .slide-inner {
		width: 60%;
	}
	.element-slides .slide-content .slide-heading {
		font-size: 2.5rem;
	}
	.element-slides .slide-content .slide-description {
    	font-size: 4rem;
   		margin-top: 15px;
	}
}
@media (min-width:991px) {
	.element-slides .swiper-container {
		height: 750px;
	}
	.element-slides .slide-content .slide-heading {
		font-size: 2.5rem;
	}
	.element-slides .slide-content .slide-description {
    	font-size: 6rem;
		margin-top: 30px;
	}

	.element-slides .swiper-button-prev,
	.element-slides .swiper-button-next {
		font-size: 25px;
	}
	.element-slides .swiper-button-prev {
		left: 20px !important;
	}
	.element-slides .swiper-button-next {
		right: 20px !important;
	}
}


/**
 * Home
 */
.link-more {
    text-align: center;
    margin-top: 10px;
}
.link-more a {
    display: inline-flex;
    color: var(--color-gray);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    text-transform: uppercase;
    border: 1px solid var(--border-gray-dark);
    padding: 3px 10px;
    border-radius: 50px;
    transition: all 0.3s ease;
}
.link-more a:hover {
	background: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}
@media (min-width:991px) {
	.link-more {
    	margin-top: 20px;
	}
	.link-more a {
    	padding: 5px 15px;
	}
}

/*--about--*/
.hm-about .element-icon-box:not(:last-child) {
    padding-bottom: 20px;
    margin-bottom: 20px;
}
.hm-about .element-icon-box:not(:last-child):before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    left: 65px;
    border-bottom: 1px solid var(--border-gray);
}
@media (min-width: 991px) {
	.hm-about .e-flex {
	 	margin-bottom: 20px;
	 }
    .hm-about .element-icon-box:not(:last-child) {
        padding-bottom: 40px;
        margin-bottom: 40px;
    }
    .hm-about .element-icon-box:not(:last-child):before {
        left: 100px;
    }
}

/*--services--*/
.services .swiper-wrapper {
	padding: 6px 0 10px;
}
.services .content-wrap {
	border: 1px solid var(--border-gray);
	padding: 30px;
	border-radius: 20px;
	text-align: center;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.services .content-wrap:hover {
	transform: translateY(-6px);
	box-shadow: 0 12px 25px rgba(0, 0, 0, 0.1);
}
.services .content-wrap .icon {
	margin-bottom: 20px;
	transition: transform 0.3s ease;
}
.services .content-wrap:hover .icon {
	transform: scale(1.1);
}
.services .content-wrap h3 {
	margin-bottom: 15px;
}
.services.swiper-container .swiper-pagination.swiper-pagination-bullets {
	margin-top: 10px;
}
@media (min-width: 991px) {
	.services .content-wrap {
		padding: 50px 30px;
	}
	.services .content-wrap .icon {
		margin-bottom: 30px;
	}
	.services .content-wrap h3 {
        margin-bottom: 20px;
    }
    .services .content-wrap p {
        font-size: var(--font-size-base);
        line-height: var(--line-height-comfort);
    }
}

/*--industry--*/
.hm-industry {
	background: var(--color-primary);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	color: var(--color-white);
	padding: 40px 15px;
}
.hm-industry:before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.75);
}
.hm-industry .content-wrap .icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 90px;
    height: 90px;
    background: var(--color-primary);
    border-radius: 50%;
    margin-bottom: 20px;
}
.hm-industry .content-wrap .icon img {
	width: 50px;
    object-fit: contain;
    filter: brightness(0) invert(1);
}
.hm-industry .content-wrap h3 {
	margin-bottom: 15px;
	position: relative;
}
@media (min-width: 767px) {
	.hm-industry {
		padding: 80px 15px 0;
	}
	.hm-industry .pb-heading {
		padding-right: 100px;
	}
	.hm-industry .content-wrap {
		padding: 30px 0 50px;
	}
	.hm-industry .swiper-slide:before {
		content: "";
		position: absolute;
		top: 0;
		bottom: -60px;
		right: -15px;
		border-right: 1px solid var(--border-light);
	}
	.hm-industry .swiper-nav {
		position: absolute;
		top: 50px;
		right: 15px;
	}
}
@media (min-width: 991px) {
	.hm-industry {
		padding: 150px 0 0 0;
	}
	.hm-industry .pb-heading {
		padding-right: 300px;
	}
	.hm-industry .swiper-slide:before {
		right: -30px;
	}
	.hm-industry .content-wrap {
		padding: 50px 0;
	}
	.hm-industry .content-wrap .icon {
		margin-bottom: 30px;
	}
	.hm-industry .content-wrap h3 {
        margin-bottom: 20px;
    }
    .hm-industry .content-wrap p {
        font-size: var(--font-size-base);
        line-height: var(--line-height-comfort);
    }


    /*--hover--*/
    .hm-industry .content-wrap {
		transition: transform 0.3s ease;
	}
	.hm-industry .content-wrap:hover {
		transform: translateY(-30px);
	}
	.hm-industry .content-wrap .icon {
		transition: transform 0.3s ease;
	}
	.hm-industry .content-wrap:hover .icon {
		transform: rotate(45deg);
	}
	.hm-industry .content-wrap h3::after {
		content: '';
		position: absolute;
		left: 0;
		bottom: -12px;
		width: 0;
		height: 1px;
		background-color: var(--color-primary);
		transition: width 0.3s ease;
	}
	.hm-industry .content-wrap:hover h3::after {
		width: 100%;
	}



}
@media (max-width: 767px) {
	.hm-industry {
		text-align: center;
	}
	.hm-industry .content-wrap {
		background: rgba(255,255,255,0.1);
		padding: 30px;
		border-radius: 20px;
	}
	.hm-industry .swiper-nav {
		justify-content: center;
   		margin-top: 15px;
	}
}

/*--promotion--*/
.prom-block {
	background: var(--color-primary);
	color: var(--color-white);
}
.prom-block:before {
    content: "";
    position: absolute;
    inset: 0;
    background: url(../images/bg-pattarn.webp);
    background-position: center center;
    opacity: 0.1;
    background-size: contain;
}
.prom-block .left {
	text-align: center;
}
.prom-block .left h2 {
	position: relative;
	font-size: 2.5rem;
	padding-bottom: 20px;
	margin-bottom: 7px;
}
.prom-block .left h2:before {
    content: "";
    position: absolute;
    right: 25%;
    bottom: 0;
    height: 2px;
    width: 50%;
    background: var(--color-secondary);
}
.prom-block .right {
	text-align: center;
}
.prom-block .right img {
    display: inline-block;
    width: 200px;
}
@media (min-width: 767px) {
	.prom-block .left {
		text-align: right;
	}
	.prom-block .left h2 {
    	font-size: 3.75rem;
    	line-height: 1;
    	padding-bottom: 40px;
    	margin-bottom: 10px;
 	}
	.prom-block .left h2:before {
		right: 0;
	}
	.prom-block .right img {
		width: auto;
	}
}
@media (min-width: 991px) {
	.prom-block {
		padding: 150px 0;
	}
	.prom-block .left {
		padding-left: 100px;
	}
	.prom-block .left h2 {
    	font-size: 5.625rem;
	}
}



/*--GlobalPresence--*/
.global-presence .container {
	gap: 30px;
}
.global-presence .col-70 strong.strong.border {
	padding-bottom: 20px;
}

.global-presence .r-quote .element-widget {
	background: var(--color-primary);
	padding: 30px;
	border-radius: 20px;
	color: var(--color-white);
}
.global-presence .r-quote strong {
	font-weight: var(--font-weight-medium);
    margin-bottom: -5px;
}
.global-presence .r-quote h2 {
	padding-bottom: 12px;
	border-bottom: 1px solid var(--border-light);
}
.global-presence .r-quote p {
	margin-bottom: 5px;
}

@media (min-width: 767px) {
	.global-presence .col-70 strong.strong.border {
		padding-bottom: 35px;
		margin-bottom: 15px;
	}
	.global-presence .col-70 .map {
		display: flex;
		gap: 20px;
	}
	.global-presence .col-70 .map .content {
		width: 45%;
	}
	.global-presence .col-70 .map .img {
		width: 55%;
	}

	.global-presence .r-quote .element-widget {
		padding: 50px;
		border-radius: 30px;
	}
	.global-presence .r-quote strong {
    	font-size: var(--font-size-lgx);
    	margin-bottom: -10px;
	}
	.global-presence .r-quote h2 {
		padding-bottom: 20px;
	}
	.global-presence .r-quote p {
		margin-bottom: 10px;
	}
}
@media (min-width: 991px) {
	.global-presence .col-70 {
    	width: 65%;
	}
	.global-presence .col-70 h2 {
		margin-bottom: 10px;
	}
	.global-presence .r-quote {
		width: 35%;
	}
}
@media (max-width: 991px) {
	.global-presence .container {
		flex-wrap: wrap;
	}
	.global-presence .element-column {
		width: 100%;
	}
}
@media (max-width: 767px) {
	.global-presence .col-70 .map .img {
		margin-top: 30px;
	}
}


/*--Clients--*/
.clients {
	padding: 0 15px 40px 15px;	
}
@media (min-width: 767px) {
	.clients {
		padding: 0 15px 60px 15px;	
	}	
}
@media (min-width: 991px) {
	.clients {
		padding: 0 0 80px 0;	
	}
	.clients .element-widget {
		padding-top: 80px;
		border-top: 1px dashed var(--border-gray);
	}
}




/**
 * About Us
 */
.about .container:first-child {
	margin-bottom: 30px;
}
@media (min-width: 991px) {
	.about .container:first-child {
		margin-bottom: 50px;
	}
}

.abt-points  {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    text-align: center;
}
.abt-points .inner {
	padding: 0px;
	transition: all 0.3s ease;
}
.abt-points .inner .icon {
    display: inline-flex;
	margin-bottom: 15px;
	transition: transform 0.3s ease;
}
.abt-points .inner .icon img {
    width: 50px;
}
/* Hover Effects */
.abt-points .inner:hover {
	transform: translateY(-8px);
}
.abt-points .inner:hover .icon {
	transform: scale(1.15);
}
@media (min-width: 767px) {
	.abt-points  {
		grid-template-columns: repeat(4, 1fr);
    	gap: 0;
	}
	.abt-points .inner:not(:last-child) {
		border-right: 1px solid var(--border-gray);
	}
}
@media (min-width: 991px) {
	.abt-points .inner {
		padding: 30px 50px;
	}
	.abt-points .inner .icon {
    	margin-bottom: 30px;
	}
	.abt-points .inner .icon img {
    	width: 70px;
	}
}

/* Vision */
.vision {
	background: var(--color-primary);
}
.vision .left h2 {
	color: var(--color-white);
}
.vision .left .element-icon-box {
	transition: all 0.3s ease;
}
.vision .left .element-icon-box:hover {
	transform: translateX(10px);
}
.vision .left .element-icon-box:not(:last-child) {
    padding-bottom: 20px;
    margin-bottom: 20px;
}
.vision .left .element-icon-box:not(:last-child):before {
	content: "";
	position: absolute;
	bottom: 0;
	right: 0;
	left: 65px;
	border-bottom: 1px solid var(--border-light);
}
.vision .left .content h3,
.vision .left .content p {
	color: var(--color-white);
}
.vision .aim {
    background: var(--color-white);
    padding: 20px;
	border-radius: 20px;
}
.vision .aim h3 {
	color: var(--color-primary);
}
@media (min-width: 991px) {
	.vision .left {
		padding-right: 50px;
	}		
	.vision .left .element-icon-box:not(:last-child) {
    	padding-bottom: 40px;
    	margin-bottom: 40px;
	}
	.vision .left .element-icon-box:not(:last-child):before {
		left: 100px;
	}
	.vision .aim {
		padding: 50px;
	}	
	.vision .aim h3 {
		font-size: var(--font-size-2xl);
    }
}

/* Trusted */
.trusted ul li {
	list-style: none;
	padding-left: 15px;
    font-size: var(--font-size-md);
}
.trusted ul li:after {
    content: "\F3E5";
    font-family: bootstrap-icons !important;
    position: absolute;
    left: 0;
    top: 7px;
    font-size: 0.625rem;
}
@media (min-width: 991px) {
	.trusted ul li {
		padding-left: 20px;
		font-size: var(--font-size-lgx);
	}
	.trusted ul li:after {
		top: 10px;
		font-size: var(--font-size-xs);
	}
}



/**
 * Products
 */
.product-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
}
.product-grid .product-card {
	position: relative;
	padding: 15px 15px 0 15px;
    text-align: center;
}
.product-grid .product-card:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: var(--color-accent);
    border-radius: 10px 10px 40px 10px;
}
.product-grid .product-card .thumb {
	position: relative;
	display: block;
	margin-bottom: 15px;
}
.product-grid .product-card .thumb img {
    display: block;
}
.product-grid .product-card h3 {
	font-size: var(--font-size-base);
}
.product-grid .product-card .btn-link {
    display: inline-flex;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: var(--color-primary);
    margin-top: 5px;
}
.product-grid .product-card .btn-link:hover {
	color: var(--color-text);
}
@media (min-width: 767px) {
	.product-grid {
    	grid-template-columns: repeat(3, 1fr);
    	gap: 20px;
	}
	.product-grid .product-card {
    	padding: 40px 30px 0 30px;
	}
	.product-grid .product-card:before {
   		border-radius: 10px 10px 40px 10px;
	}
	.product-grid .product-card .thumb {
		margin-bottom: 30px;
	}
	.product-grid .product-card h3 {
		font-size: var(--font-size-lg);
	}
	.product-grid .product-card .btn-link {
    	font-size: var(--font-size-sm);
    	margin-top: 10px;
	}
}
@media (min-width: 991px) {
	.product-grid {
    	grid-template-columns: repeat(4, 1fr);
    	gap: 30px;
    }
    .product-grid .product-card h3 {
		padding: 0 30px;
	}

	/* hover animation */
	.product-grid .product-card {
    	transition: transform 0.3s ease;
  	}
  	.product-grid .product-card:hover {
    	transform: translateY(-10px);
    }
  	.product-grid .product-card:before {
    	transition: transform 0.3s ease, height 0.3s ease, background 0.3s ease;
    	transform-origin: top;
  	}
	.product-grid .product-card:hover:before {
        transform: scaleY(1.1);
        height: 55%;
        background: var(--border-gray);
    }
}



/**
 * Single Product
 */

/* product image & intro */
.sp-img-sec {
	background: var(--color-primary);
	color: #fff;
}
.sp-img-sec .element-column img {
	display: inline-flex;
}
.sp-img-sec .e-flex h1 {
	font-size: var(--font-size-2xl);
}
.sp-img-sec .e-flex .code,
.sp-img-sec .e-flex .category {
	color: var(--color-secondary);
}
.sp-img-sec .e-flex strong {
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-md);
}
@media (min-width: 767px) {
	.sp-img-sec .container {
		align-items: center;
	}
	.sp-img-sec .element-column:last-child {
    	border-left: 1px solid var(--border-light);
    	padding-left: 30px;
	}
}
@media (min-width: 991px) {
	.sp-img-sec .element-column:first-child {
		text-align: right;
		padding-right: 60px;
	}
	.sp-img-sec .element-column:last-child {
    	padding-left: 100px;
    	padding-right: 30px;
	}
	.sp-img-sec .e-flex h1 {
		font-size: var(--font-size-5xl);
	}
	.sp-img-sec .e-flex strong {
	    font-size: var(--font-size-lg);
	}
	.sp-img-sec .e-flex .element-button {
    	margin-top: 15px;
	}
}
@media (max-width: 767px) {
	.sp-img-sec {
        text-align: center;
        padding-bottom: 0;
    }
	.sp-img-sec .element-column:first-child {
        order: 1;
        margin-top: 40px;
        margin-bottom: -90px;
    }
	.sp-img-sec .e-flex .element-button {
		align-self: center;
		margin-top: 10px;
	}
}


/* operating limits */
.operating-limits {
    padding: 140px 15px 0;
}
.operating-limits .element-widget {
    border: 1px solid var(--border-gray);
    border-radius: 20px;
    padding: 0 0 30px;
    text-align: center;
}
.operating-limits h3 {
	display: inline-flex;
	position: relative;
    background: var(--color-white);
	color: var(--color-primary);
    margin-bottom: 15px;
    top: -15px;
    padding: 0 10px;
}
.operating-limits ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 0;
}
.operating-limits ul li {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.operating-limits ul li strong {
    font-weight: var(--font-weight-medium);
}
@media (min-width: 767px) {
	.operating-limits {
    	padding: 80px 15px 0;
	}
	.operating-limits ul {
    	grid-template-columns: repeat(4, 1fr);
    	gap: 0;
	}
	.operating-limits ul li {
    	gap: 5px;
	}
	.operating-limits ul li strong {
    	font-size: 1.25rem;
	}
}
@media (min-width: 991px) {
	.operating-limits {
    	padding: 120px 0 0;
	}
	.operating-limits .element-widget {
    	padding: 0 50px 70px;
	}
	.operating-limits h3 {
        font-size: var(--font-size-xlx);
        margin-bottom: 50px;
        top: -20px;
        padding: 0 20px;
    }
	.operating-limits ul li span {
    	font-size: var(--font-size-md);
	}
	.operating-limits ul li strong {
    	font-size: 1.75rem;
	}
}

/* content */
.sp-content {
    padding: 30px 15px 0;
}
.sp-content h3 {
    margin-bottom: 10px;
}
.sp-content .left .element-widget {
    border: 1px solid var(--border-gray);
    padding: 20px 30px;
    border-radius: 10px;
}
.sp-content .left .element-widget p {
    font-size: var(--font-size-base);
}
.sp-content .right .inner {
    border: 1px solid var(--border-gray);
    border-radius: 20px;
    padding: 30px;
}
.sp-content .right .element-widget:first-child {
    border-bottom: 1px solid var(--border-gray);
    padding-bottom: 20px;
    margin-bottom: 20px;
}
.sp-content .sf ul {
	padding-left: 20px;
}
@media (min-width: 991px) {
	.sp-content {
    	padding: 50px 0 0;
	}
	.sp-content h3 {
		font-size: var(--font-size-xlx);
    	margin-bottom: 15px;
	}
	.sp-content .container {
    	gap: 20px;
	}
	.sp-content .left .element-widget {
    	padding: 30px 50px;
	}	
	.sp-content .left .element-widget p {
    	font-size: var(--font-size-lgx);
    	line-height: 1.2;
	}
	.sp-content .right .inner {
    	padding: 50px;
	}
	.sp-content .right .element-widget:first-child {
    	padding-bottom: 30px;
    	margin-bottom: 30px;
	}
}
@media (max-width: 991px) {
	.sp-content .element-wrap {
		gap: 10px;
	}
}
@media (max-width: 767px) {
	.sp-content .right {
		margin-top: 30px;
	}
}

/* sp cta */
.sp-cta .element-widget {
	display: flex;
	flex-direction: column;
	gap: 20px;
	background: var(--color-primary);
    padding: 30px;
    border-radius: 20px;
    text-align: center;
}
.sp-cta .left strong {
    font-size: var(--font-size-xl);
    line-height: var(--line-height-heading);
    font-weight: var(--font-weight-medium);
    color: var(--color-white);
}
.sp-cta .right {
    display: flex;
    gap: 5px;
    justify-content: center;
}
@media (min-width: 767px) {
	.sp-cta .element-widget {
    	flex-direction: row;
    	gap: 0;
    	justify-content: space-between;
    	align-items: center;
    	text-align: left;
	}
	.sp-cta .right {
		width: 50%;
	}
}
@media (min-width: 991px) {
	.sp-cta .element-widget {
		padding: 50px 120px;
	}
	.sp-cta .left strong {
    	font-size: var(--font-size-2xl);
	}
	.sp-cta .right {
    	gap: 20px;
    	width: auto;
	}
}


/* related */
@media (max-width: 991px) {
	.related-products .product-grid .product-card:last-child {
		display: none;
	}
}
@media (max-width: 767px) {
	.related-products .product-grid .product-card:nth-last-child(2) {
		display: none;
	}
}




/**
 * Industries
 */
.industry-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
}
.industry-card {
    border: 1px solid var(--border-gray);
    border-radius: 20px;
    padding: 30px;
    text-align: center;
    transition: all 0.3s ease;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}
.industry-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 8px 22px rgba(0,0,0,0.12);
}
.industry-card .icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
    justify-content: center;
    width: 90px;
    height: 90px;
    background: var(--color-primary);
    border-radius: 50%;
    margin-bottom: 20px;
    transition: all 0.3s ease-out;
}
.industry-card:hover .icon {
	background: var(--color-accent);
	transform: scale(1.1) rotate(12deg);
}
.industry-card .icon img {
    width: 50px;
    object-fit: contain;
    filter: brightness(0) invert(1);
    transition: all 0.5s ease-out;
}
.industry-card:hover .icon img {
    filter: none;
}
.industry-card h3 {
    margin-bottom: 15px;
    transition: all 0.5s ease-out;
}
.industry-card:hover h3 {
    color: var(--color-primary);
}
@media (min-width: 767px) {
	.industry-grid {
    	grid-template-columns: repeat(2, 1fr);
    	gap: 30px;
	}
	.industry-card .icon {
		margin-bottom: 30px;
	}
}
@media (min-width: 991px) {
	.industry-grid {
    	grid-template-columns: repeat(3, 1fr);
    }
    .industry-card {
    	padding: 50px;
	}
	.industry-card p {
    	font-size: var(--font-size-base);
    	line-height: var(--line-height-comfort);
	}
}



/**
 * Quality
 */

/* quality */
@media (min-width: 991px) {
	.quality .col-50:first-child {
		order: 1;
	}
}

/* quality assuracne */
.q-assurance .points {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.q-assurance .inner {
    text-align: center;
    background: var(--color-accent);
    padding: 20px;
    border-radius: 20px;
    transition: transform 0.4s ease, box-shadow 0.4s ease, background 0.4s ease;
}
.q-assurance .inner:hover {
    transform: translateY(-8px) scale(1.05);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.2);
    background: var(--color-primary);
}
.q-assurance .inner .icon {
    margin-bottom: 15px;
    transition: transform 0.4s ease;
}
.q-assurance .inner:hover .icon {
    transform: rotate(10deg) scale(1.05);
}
.q-assurance .inner .icon img {
	width: 50px;
	transition: filter 0.4s ease;
}
.q-assurance .inner:hover .icon img {
    filter: brightness(0) invert(1);
}
.q-assurance .inner h3 {
	transition: color 0.4s ease;
}
.q-assurance .inner:hover h3 {
    color: var(--color-white);
}
@media (min-width: 767px) {
	.q-assurance .points {
		grid-template-columns: repeat(4, 1fr);
	}
}
@media (min-width: 991px) {
	.q-assurance .points {
		gap: 30px;
	}
	.q-assurance .inner {
		padding: 50px 30px;
	}
	.q-assurance .inner .icon {
		margin-bottom: 30px;
	}
	.q-assurance .inner .icon img {
		width: 70px;
	}
}

/* Infrastructure */
.infrastructure {
	background-color: var(--color-primary);
	background-image: url('../images/infrastructure-banner.webp');
	background-position: center center;
  	background-repeat: no-repeat;
  	background-size: cover;
	color: var(--color-white);
}
.infrastructure:before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.65);
}
.infrastructure strong.border:before {
	border-color: var(--border-light);
}
.infrastructure .points .element-widget {
	background: rgba(0, 0, 0, 0.3);
    padding: 15px;
    border-radius: 20px;
}
.infrastructure .points h3 {
	color: var(--color-secondary);
}
@media (min-width: 991px) {	
	.infrastructure .points .element-widget {
    	padding: 40px;
   		transition: transform 0.3s ease;
   	}
	.infrastructure .points .element-widget:hover {
    	transform: translateX(-10px);
   	}
}
@media (max-width: 767px) {
	.infrastructure .points .element-wrap {
		gap: 5px;
	}
}

/* Sealcare */
.sealcare .swiper-wrapper {
	padding: 6px 0;
}
.sealcare .swiper-slide {
    border: 2px solid var(--border-gray);
    border-radius: 20px;
    padding: 30px;
    text-align: center;
    transition: all 0.4s ease;
}
.sealcare .swiper-slide:hover {
	border-color: var(--color-primary);
  	transform: translateY(-6px);
  	box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}
.sealcare .thumb {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto 20px;
    border: 2px solid var(--border-gray);
    padding: 3px;
    transition: all 0.5s ease;
}
.sealcare .swiper-slide:hover .thumb {
	border-color: var(--color-primary);
}
.sealcare .thumb img {
    width: 100%;
    transition: transform 0.5s ease;
    border-radius: 50%;
}
.sealcare .swiper-slide:hover .thumb img {
	transform: scale(1.15);
}
.sealcare .content h3 {
	margin-bottom: 15px;
	transition: color 0.3s ease;
}
.sealcare .swiper-slide:hover .content h3 {
	color: var(--color-primary);
}
@media (min-width: 991px) {
	.sealcare .thumb {
    	margin: 0 auto 30px;
	}
	.sealcare .content h3 {
		margin-bottom: 20px;
	}
	.sealcare .content p {
    	font-size: var(--font-size-base);
    	line-height: var(--line-height-comfort);
	}
}



/**
 * Contact
 */
.contact .element-widget {
	border: 1px solid var(--border-gray);
	padding: 20px;
	border-radius: 20px;
}
.contact .element-icon-box:not(:last-child) {
    padding-bottom: 15px;
    margin-bottom: 15px;
}
.contact .element-icon-box:not(:last-child):before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    left: 50px;
    border-bottom: 1px solid var(--border-gray);
}
.contact .element-icon-box .icon {
	width: 35px;
}
.google-map .map {
	width: 100%; 
	height: 230px; 
	border-radius: 20px; 
	overflow: hidden;
}

@media (min-width: 991px) {
	.contact {
		padding-right: 30px;
	}
	.contact .element-widget {
		padding: 50px;
	}
	.contact .element-icon-box:not(:last-child) {
    	padding-bottom: 30px;
    	margin-bottom: 30px;
	}
	.contact .element-icon-box:not(:last-child):before {
    	left: 80px;
	}
	.contact .element-icon-box .icon {
        width: 50px;
    }
}
@media (max-width: 767px) {
	.google-map {
		margin-top: 30px;
		margin-bottom: 10px;
	}
	.google-map .map {
		height: 120px; 
	}
}



/**
 * FOOTER
 */
.main-footer {
    padding: 40px 15px 20px;
    background-color: var(--color-accent);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-comfort);
}
.main-footer .element-wrap h3 {
    margin-bottom: 10px;
    font-size: var(--font-size-base);
}
.main-footer .element-wrap p {
	font-size: inherit;
	line-height: inherit;
}
.main-footer .ftrintro img {
	width: 200px;
}
.main-footer .ftsocial a {
	display: inline-block;
	transition: all 1s ease;
    margin-right: 10px;
    color: var(--color-primary);
}
.main-footer .ftsocial a:hover {
	 color: var(--color-secondary);
}
.main-footer .ftrlinks {
	padding-left: 50px;
}
.main-footer .ftrlinks ul li {
	list-style: none;
	padding-left: 13px;
}
.main-footer .ftrlinks ul li:not(:last-child) {
	margin-bottom: 8px;
}
.main-footer .ftrlinks ul li:before {
    content: "";
    position: absolute;
    top: 12px;
    left: 0;
    width: 4px;
    height: 4px;
    background: var(--color-secondary);
    border-radius: 50%;
}
.main-footer .copyright .element-widget {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid var(--border-gray-dark);
    font-size: var(--font-size-xs);
    text-align: center;
}
.whatsapp-icon {
    position: fixed;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    bottom: 10px;
    right: 10px;
    background-color: #25D366;
    color: var(--color-white);
    width: 30px;
    height: 30px;
    font-size: var(--font-size-sm);
    border-radius: 50%;
    transition: background-color 0.3s ease;
}
.whatsapp-icon:hover {
	background-color: #119d45;
	color: var(--color-white);
}

@media (min-width: 991px) {
	.main-footer {
        padding: 120px 0 60px;
        font-size: var(--font-size-base);
        line-height: var(--line-height-base);
    }
    .main-footer > .container .element-wrap {
    	gap: 30px;
    }
	.main-footer .element-wrap h3 {
        font-size: var(--font-size-md);
        margin-bottom: 15px;
    }
	
	.main-footer .ftrintro {
        padding-right: 40px;
    }
    .main-footer .ftrintro img {
		width: 230px;
	}
	.main-footer .ftraddress {
        padding: 0 60px 0 25px;
    }
	.main-footer .ftrcontact {
		padding-right: 40px;
	}

	.main-footer .copyright .element-widget {
        margin-top: 60px;
        padding-top: 60px;
        font-size: var(--font-size-sm);
    }
	.whatsapp-icon {
		bottom: 15px;
	    right: 15px;
		width: 45px;
	    height: 45px;
	    font-size: var(--font-size-xl);
	}
}
@media (max-width: 991px) {
	.main-footer .ftrintro,
	.main-footer .ftraddress {
	    width: 35%;
	}
	.main-footer .ftrcontact {
	    width: 30%;
	}
	.main-footer .ftrlinks {
		display: none;
	}
}
@media (max-width: 767px) {
	.main-footer .ftrintro {
	    width: 100%;
		margin-bottom: 30px;
	}
	.main-footer .ftraddress,
	.main-footer .ftrcontact {
		width: 50%;
	}
	.main-footer .ftraddress .element-wrap {
		padding-right: 0;
	}
}