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

:root {
	--green: #00A884;
	--green-lt: #22c78d;
	--green-dk: #128a5e;
	--teal-dark: #0d2d2a;
	--navy: #0b1c1a;
	--dark: #111827;
	--mid: #374151;
	--muted: #6B7280;
	--light: #F4FAF8;
	--border: #E5E7EB;
	--white: #ffffff;
}

* html {
	overflow-x: hidden;
}

html,
body {
	scroll-behavior: smooth;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	padding: 0;
	margin: 0;
}

a {
	-webkit-transition: var(--transition);
	transition: var(--transition);
	color: var(--blackColor);
	text-decoration: none;
	outline: 0 !important;
}

a:hover {
	color: var(--mainColor);
	text-decoration: none;
}

:focus {
	outline: 0 !important;
	-webkit-box-shadow: none !important;
	box-shadow: none !important;
}

ul,
ol,
li {
	list-style: none;
	margin: 0;
	padding: 0;
}

.no-padding {
	padding: 0px;
}

img {
	max-width: 100%;
	height: auto;
}

p:last-child {
	margin-bottom: 0;
}

img {
	max-width: 100%;
}

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

body {
	margin: 0px;
	padding: 0px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	font-family: "Montserrat", sans-serif;
	overflow-x: hidden;
}

.custom-container {
	max-width: 1800px;
	margin: 0px auto;
	padding: 0px 15px;
}

.cmn-gap {
	padding: 100px 0px;
	margin: 0px;
}

.cmn-butn {
	font-family: Montserrat;
	font-weight: 600;

	font-size: 16px;

	line-height: 100%;
	letter-spacing: 0%;
	text-align: center;

	border-radius: 10px;
	padding: 16px 30px;
	transition: all 0.3s ease-in-out;
}

.grn-butn {
	background: #00A884;
	border: 1px solid #00A884;
	color: #fdfdfd;
	transition: all 0.25s;
}

.grn-butn:hover {
	background: #ffff;
	border: 1px solid #00A884;
	color: #00A884;
	transform: translateY(-2px);
}

.white-butn {
	background: #fff;
	border: 1px solid #fff;
	color: #020202;
	transition: all 0.25s;
}

.white-butn:hover {
	background: transparent;
	border: 1px solid #fff;
	color: #fff;
	transform: translateY(-2px);
}

.cmn-butn.white-butn span {
	margin-left: 10px;
}


h6 {
	font-weight: 500;
	font-style: Medium;
	font-size: 26px;
	line-height: 37px;
	letter-spacing: 0%;
	color: #004D3D;
	padding: 0px;
	margin: 0px 0px 10px 0px;
}

h2 {
	font-weight: 500;
	font-style: Medium;
	font-size: 45px;
	line-height: 55px;
	letter-spacing: 0%;
	color: #1A2B2B;
	margin: 0px 0px 20px 0px;
	padding: 0px;
}


h2 span {
	color: #004D3D;
}


h3 {
	font-family: Montserrat;
	font-weight: 600;
	font-size: 32px;
	line-height: 45px;
	letter-spacing: 0%;
	margin: 0px 0px 20px 0px;
}

p {
	font-family: Montserrat;
	font-weight: 400;
	font-size: 18px;
	line-height: 28px;
	letter-spacing: 0%;

	color: #666666;
	margin: 0px 0px 20px 0px;
	padding: 0px;
}

/* =================================== */
/* =============my-css-start===========*/
/* =================================== */

/* =================================== */
/* ============header-section===========*/
/* =================================== */

/* ========NAVBAR===========*/


header {
	padding: 20px;
	border-radius: 30px;
	overflow: hidden;
}


.main-nav {
	margin: 0px 20px;
	padding: 10px 0px;
	width: 96%;
	height: auto;
	background: #ffffff29;
	transition: all 0.1s ease 0s;
	z-index: 9;
	position: absolute;
	top: 50px;
	border: 1px solid #d3eeb469;
	border-radius: 14px;
}

.main-nav.scroll {
	background: #052D25;
	height: auto;
	padding: 0px;
	transition: background-color 0.5s ease 0s;
	top: 0;
	position: fixed;
	transition: all 0.3s ease 0s;
	box-shadow: 0 0 15px 1px rgba(0, 0, 0, 0.07);
	width: 100%;
	left: 0px;
	right: 0px;
	margin: 0px;
	border-radius: 0px;
}

.site-nav {
	padding: 0px;
	margin: 0px;
	transition:
		box-shadow 0.3s,
		padding 0.3s;
	background: transparent;
}

.logo {
	width: 290px;
	height: auto;
	margin: 0px;
	padding: 0px;
	position: relative;
}

.logo img {
	width: 100%;
}

.main-nav.scroll .logo {
	width: 50%;
	margin: 10px 0px;
}

.stellarnav.mobile.right>ul {
	z-index: 99;
	background: #f0d04d;
}

.stellarnav {
	position: relative;
	width: 100%;
	line-height: normal;
	display: flex;
	justify-content: end;
	align-items: center;
	height: 100%;
}

.stellarnav ul {
	margin: 0px 0px;
	padding: 0px 0px 0px 0px;
	position: relative;
	width: 100%;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: end;
	gap: 60px;
}

.stellarnav>ul>li>a {

	font-weight: 400;
	font-size: 18px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #FFFFFF;
	padding: 0px;
	margin: 0px;
}

.stellarnav>ul>li>a:hover {
	color: var(--green);
	text-decoration: none;
}

.stellarnav>ul>li>a.active {
	color: var(--green) !important;
	text-decoration: none;
	font-weight: 600;
	background-repeat: unset;
	background-image: unset;
	background-size: unset;
	background-position: unset;
	text-decoration-line: underline;
	text-decoration-style: solid;
	text-decoration-color: inherit;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.4em;
	text-decoration-skip: auto;
	text-decoration-skip-ink: auto;
}

.main-nav-socialicon {
	margin: 20px 0px 0px 0px;
	padding: 0px 0px;
	position: relative;
	text-align: right;
}

.main-nav .stellarnav ul ul {
	width: 263px;
	padding: 8px 0px;
	top: 45px;
}

.main-nav .stellarnav li li {
	margin: 0px 0px;
	width: 100% !important;
	border-bottom: #ccccccb8 1px solid;
}

.main-nav .stellarnav li li a {
	font-size: 15px;
	padding: 8px 12px;
	color: #2c2c2c;
	font-weight: 400;
}

.stellarnav li.has-sub a {
	padding-right: 0px !important;
}

.main-nav .stellarnav li li a:hover {
	background: #f9f9f9;
	color: #00a884;
}

.main-nav .stellarnav li li a.active {
	background: #f9f9f9;
	color: #a4b4e8;
}

.stellarnav li.has-sub>a::after {
	content: "\f107";
	margin-left: 7px !important;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #267ec3;
	display: inline-block;
	border: none !important;
	font: normal normal normal 16px/1 FontAwesome;
}

.rightlink {
	display: flex;
	align-items: center;
	gap: 12px;
	justify-content: end;
	height: 100%;
}

.btn-request-quote {
	border: 1px solid var(--white);
	color: var(--white);
	background: transparent;
	padding: 12px 30px;
	border-radius: 6px;
	font-family: Poppins;
	font-weight: 600;
	font-style: SemiBold;
	font-size: 20px;
	line-height: 100%;
	letter-spacing: 0%;
	text-align: center;
	vertical-align: middle;
	text-transform: uppercase;
	text-transform: uppercase;
	text-decoration: none;
	transition: all 0.25s;
}

.btn-request-quote:hover {
	background: var(--white);
	color: var(--navy-dark);
	transform: translateY(-2px);
}

/* ========NAVBAR===========*/

/* =======banner-section===========*/

.banner-section {
	margin: 0px 0px;
	padding: 0px;
	width: 100%;
	height: 940px;
	max-height: 100%;
	position: relative;
	border-radius: 20px;
	overflow: hidden;
}

.banner-section img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.banner-section #overlay {
	position: absolute;
	width: 100%;
	left: 0;
	right: 0;
	top: 0px;
	background: linear-gradient(90deg,
			rgba(0, 0, 0, 0.52) 50.52%,
			rgba(0, 0, 0, 0.13) 100%);
}

.hero-content {
	position: absolute;
	color: #ffffff;
	display: flex;
	justify-content: start;
	align-items: start;
	flex-direction: column;
	top: 350px;
	width: 100%;
}

.hero-content h6 {
	font-weight: 400;
	font-size: 24px;
	line-height: 24px;
	letter-spacing: 0%;
	text-align: left;
	margin: 0px 0px 20px 0px;
	padding: 0px;
	color: #fff;
}

.hero-content h6 span {
	margin-right: 10px;
}

.hero-content h6 span img {
	width: 30px;
	height: 30px;
}

.hero-content h1 {
	font-weight: 700;
	font-size: 75px;
	line-height: 85px;
	letter-spacing: 0%;
	color: #fff;
	margin: 0px 0px 30px 0px;
	padding: 0px;
	text-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
	position: relative;
}


.hero-content h1 span {
	color: #00A884;
	position: relative;
}

.hero-content h1 span::after {
	content: "";
	position: absolute;
	bottom: -15px;
	right: 60px;
	background: url(../images/span-bg.png) bottom left no-repeat;
	width: 250px;
	height: 25px;
}


.hero-content p {
	font-weight: 400;
	font-size: 30px;
	line-height: 40px;
	letter-spacing: 0%;
	color: #DCDCDC;
	margin: 0px 0px 40px 0px;
	padding: 0px;
	max-width: 90%;
}

.hero-btns {
	display: flex;
	justify-content: start;
	align-items: center;
	gap: 20px;
	width: 100%;
}

.hero-card {
	background: rgba(255, 255, 255, 0.07);
	backdrop-filter: blur(16px);
	border-radius: 25px;
	padding: 30px;
	animation: slideInRight 0.8s ease 0.4s both;
}

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(60px);
	}

	to {
		opacity: 1;
		transform: translateX(0);
	}
}

.hero-card h4 {
	font-weight: 600;

	font-size: 32px;

	line-height: 40px;
	letter-spacing: 0%;
	margin: 0px 0px 10px 0px;
	padding: 0px;
	color: #ffff;
}

.hero-card p {
	font-family: Montserrat;
	font-weight: 400;

	font-size: 16px;
	line-height: 26px;
	letter-spacing: 0%;
	margin: 0px 0px 30px 0px;
	padding: 0px;
	color: #ffff;
	max-width: 100%;
}

.hero-card-img {
	width: 100%;
	border-radius: 14px;
	object-fit: cover;
	height: 275px;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.hero-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.6s ease;
}

.hero-card-img:hover img {
	transform: scale(1.04);
}


/* floating cards */


.hero-float-section {
	position: relative;
	height: 100%;
}

.hero-float-card {
	background: rgba(255, 255, 255, .95);
	backdrop-filter: blur(10px);
	border-radius: 20px;
	padding: 20px 10px;
	display: flex;
	align-items: center;
	gap: 12px;
	box-shadow: 0px 4px 55.9px -13px #1E1E1E;
	width: 260px;
	height: 100px;
	animation: floatCard 4s ease-in-out infinite alternate;
}

.hero-float-card1 {
	top: 30px;
	left: 100px;
	position: absolute;
}


.hero-float-card2 {
	bottom: 30px;
	right: 0px;
	position: absolute;
}


.hero-float-card:nth-child(2) {
	animation-delay: 2s;
}

@keyframes floatCard {
	from {
		transform: translateY(0)
	}

	to {
		transform: translateY(-8px)
	}
}

.hero-float-icon {
	width: 60px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.hero-float-icon img {
	width: 60px;
	height: 60px;
	object-fit: contain;
}


.hero-float-label {
	font-weight: 500;

	font-size: 20px;

	line-height: 100%;
	letter-spacing: 0%;
	color: #1A2B2B;
	margin: 0px 0px 10px 0px;
	padding: 0px;
}


.hero-float-val {
	font-weight: 400;
	font-size: 16px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #00A884;
	margin: 0px;
	padding: 0px;
}


/* =======banner-section===========*/

/* =================================== */
/* ===========logo-tag-section========*/
/* =================================== */

.logo-tag-section {
	background: #fff;
	padding: 30px 0px;
	position: relative;
	overflow: hidden;
}

.logo-item {
	transition: opacity 0.3s;
	filter: none;
	display: flex;
	justify-content: center;
	align-items: center;
	width: auto;
	height: 130px;

}

.logo-item img {
	width: auto !important;
	height: auto !important;
}

.logo-item:hover {
	opacity: 0.9;

	filter: grayscale(100%);
}

.logo-bar .owl-dots {
	display: none;
}

/* =================================== */
/* ===========logo-tag-section========*/
/* =================================== */

/* =================================== */
/* ===========about-section=======*/
/* =================================== */


.about-section {
	background: #F0F7F4;
	margin: 0px 20px;
	border-radius: 20px;
	overflow: hidden;
}

.about-text-wrap {
	padding: 0px 100px 0px 0px;
	margin: 0px;
	text-align: left;
}

.about-text-wrap p {
	max-width: 95%;
}


.about-img-wrap {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
}

.about-img-wrap img {
	width: 100%;
	height: 625px;
	object-fit: cover;
	display: block;
	transition: transform .7s ease;
}

.about-img-wrap:hover img {
	transform: scale(1.04);
}


/* green shape accent */
.stat-trio {
	display: flex;
	gap: 25px;
	flex-wrap: wrap;
	margin-top: 50px;
	border: 1px solid #E7E9EF;
	max-width: 85%;
	justify-content: space-evenly;
	align-items: center;
	border-radius: 20px;
}

.stat-box {
	text-align: center;
	padding: 30px 20px;
	width: fit-content;
}

.stat-box .stat-icon {

	margin-bottom: 20px;
}

.stat-box .stat-icon img {
	width: 38px;
	height: 38px;
}


.stat-box .stat-num {

	font-weight: 500;

	font-size: 36px;

	line-height: 100%;
	letter-spacing: 0%;
	text-align: center;
	color: #079455;
	padding: 0px;
	margin: 0px 0px 10px 0px;

}

.stat-box .stat-lbl {
	font-weight: 400;

	font-size: 20px;

	line-height: 30px;
	letter-spacing: 0%;
	text-align: center;
	color: #505650;
	padding: 0px;
	margin: 0px 0px 10px 0px;
}


.stat-divider {
	width: 1px;
	background: #E7E9EF;
	align-self: stretch;
}


/* =================================== */
/* ===========about-section=======*/
/* =================================== */


/* =================================== */
/* ===========services-section=======*/
/* =================================== */


.services-section {
	background: #fff;
}

.services-section-header {
	margin: 0px 0px 80px 0px;
	padding: 0px;
	text-align: center;
}


.service-card {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	cursor: pointer;
	height: 360px;
	transition: transform .38s, box-shadow .38s;
	box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
	margin: 0px 0px 30px 0px;
}

.service-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 50px rgba(0, 0, 0, .18);
}


.service-card-bg {
	position: absolute;
	inset: 0;
}


.service-card-bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .5s;
	display: block;
}


.service-card:hover .service-card-bg img {
	transform: scale(1.07);
}


.service-card-overlay {
	position: absolute;
	inset: 0;
	background: #1A2B2B05;
	transition: background .35s;
}


.service-card:hover .service-card-overlay {
	background: linear-gradient(180deg, rgba(26, 171, 120, .35) 0%, rgba(10, 35, 30, .92) 100%);
}


.service-card-body {
	position: absolute;
	inset: 0;
	padding: 26px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}


.service-icon {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: #9BEDBD6B;
	backdrop-filter: blur(6px);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 10px;
	transition: background .3s;
}

.service-card:hover .service-icon {
	background: rgba(26, 171, 120, .4);
}


.service-icon img {
	width: 35px;
	height: 35px;
	object-fit: contain;
}


.service-card h4 {
	font-weight: 500;
	font-size: 35px;
	line-height: 45px;
	letter-spacing: 0%;
	color: #fff;
	margin: 20px 0px 10px 0px;
	padding: 0px;
}

.service-card p {
	font-weight: 500;
	font-size: 20px;
	line-height: 30px;
	letter-spacing: 0%;
	color: #fff;
	margin: 0px 0px 20px 0px;
	padding: 0px;
}


.service-learn {

	font-weight: 500;

	font-size: 20px;

	line-height: 30px;
	letter-spacing: 0%;

	margin-top: 10px;
	transition: gap .25s;
	color: #9BEDBD;
}

.service-card:hover .service-learn {
	gap: 10px;
}


/* =================================== */
/* ==========services-section=======*/
/* =================================== */


/* =================================== */
/* ==========platforms-section=======*/
/* =================================== */


.platforms-section {
	background: #fff;
	overflow: hidden;
	padding: 0px 0px 100px 0px;
}


.platforms-section-header {
	margin: 0px 0px 60px 0px;
	text-align: center;
}

.platforms-section-header h2 span {
	color: #079455;
}


.plt-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px;
	margin-top: 40px;
}

.plt-icon {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background: #F5F5F5;
	display: flex;
	align-items: center;
	justify-content: center;

	transition: all .3s;
	cursor: pointer;
}

.plt-icon img {
	width: 40px;
	height: auto;
	object-fit: contain;
}

.plt-icon:hover {
	transform: translateY(-6px) scale(1.08);
	box-shadow: 0 14px 36px rgba(26, 171, 120, .2);
	background: #9BEDBD;
}


/* =================================== */
/* ==========platforms-section=======*/
/* =================================== */


/* =================================== */
/* ==========case-section=======*/
/* =================================== */


.case-section {
	background: #fff;
	overflow: hidden;
}

.case-section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 100px;
	margin: 0px 0px 60px 0px;
}


.case-section-header-right .grn-arrow {
	color: #079455;
	font-weight: 500;

	font-size: 20px;

	line-height: 30px;
	letter-spacing: 0%;
}

.case-section-header-right .grn-arrow:hover {
	color: #000;
}


.case-card {
	border-radius: 20px;
	overflow: hidden;
	background: #fff;
	transition: all .35s;
	cursor: pointer;
	box-shadow: 0 2px 12px rgba(0, 0, 0, .05);
}

.case-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 22px 55px rgba(0, 0, 0, .12);
	border-color: var(--green);
}


.case-img-wrap {
	height: 270px;
	border-radius: 20px;
	overflow: hidden;
}


.case-img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .5s;
	
}


.case-card:hover .case-img-wrap img {
	transform: scale(1.06);
}


.case-body {
	padding: 22px;
}


.case-tag {
	display: inline-block;
	border-radius: 20px;
	padding: 10px 30px;
	margin: 15px 0px;
	background: #F0F7F4;
	color: #079455;
	font-weight: 500;
	font-size: 18px;
	line-height: 18px;
	letter-spacing: 0%;
}

.case-body h4 {
	font-weight: 500;
	font-size: 30px;
	line-height: 30px;
	letter-spacing: 0%;
	color: #1A2B2B;
	margin: 0px 0px 10px 0px;
	padding: 0px;
}


.case-card:hover .case-body h4 {
	color: #079455;
}


.case-body p {
	font-weight: 400;
	font-size: 20px;
	line-height: 30px;
	letter-spacing: 0%;
	color: #505650;
	margin: 0px 0px 15px 0px;
	padding: 0px;
}


.case-body h3 {
	font-weight: 500;
	font-size: 32px;
	line-height: 42px;
	letter-spacing: 0%;
	color: #004D3D;
	padding: 0px;
	margin: 0px;
}


.case-learn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	justify-content: space-between;

	font-weight: 400;

	font-size: 16px;

	line-height: 100%;
	letter-spacing: 0%;
	color: #079455;

	transition: all .25s;
}


.case-card:hover .case-learn {
	color: var(--green);
	gap: 10px;
}

.case-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 12px;
	border-top: 1px solid #f0f7f4;
	padding: 20px 0px;
}


/* =================================== */
/* ==========case-section=======*/
/* =================================== */


/* =================================== */
/* ==========testi-section=======*/
/* =================================== */


.testi-section {
	overflow: hidden;
	background: url(../images/test-bg.png) top left no-repeat;
	background-size: 100% 100%;
	border-radius: 20px;
	margin: 0px 20px;
}

.testi-section-header {
	text-align: center;
	padding: 0px 0px 80px 0px;
}

.testi-left {
	border-radius: 20px;
	overflow: hidden;
	position: relative;
	min-height: 490px;
}


.testi-left img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}


.testi-owl-wrap {
	padding-left: 28px;
}


.testi-card {
	background: #fff;
	border-radius: 20px;
	padding: 30px;
	box-shadow: 0 4px 24px rgba(0, 0, 0, .07);
	margin-bottom: 20px;
	border: 1px solid #E7E9EF;
	transition: border-color .3s, box-shadow .3s;
}


.testi-card:hover {
	border-color: var(--green);
	box-shadow: 0 12px 40px rgba(26, 171, 120, .12);
}

.testi-card p {
	font-weight: 400;
	font-size: 20px;
	line-height: 30px;
	letter-spacing: 0%;
	color: #505650;
	margin: 0px 0px 40px 0px;
	padding: 0px;
}


.testi-card p::before {
	content: '\201C';
	color: var(--green);
	font-size: 2rem;
	line-height: 0;
	vertical-align: -.4em;
	margin-right: 4px;
}


.testi-card-info {
	display: flex;
	justify-content: start;
	align-items: center;
	gap: 20px;
}


.testi-avatar {
	width: 42px !important;
	height: 42px;
	object-fit: cover;

}


.testi-name {
	font-weight: 400;

	font-size: 16px;

	line-height: 100%;
	letter-spacing: 0%;
	color: #000000;
	margin: 0px 0px 10px 0px;
	padding: 0px;
}

.testi-role {
	font-weight: 400;

	font-size: 12px;

	line-height: 100%;
	letter-spacing: 0%;
	color: #6D717F;
	margin: 0px 0px 10px 0px;
	padding: 0px;
}

/* Owl dots */


.testiCarousel .owl-dots {
	display: flex;
	gap: 6px;
	justify-content: flex-start;
	margin-top: 20px;
}

.testiCarousel .owl-dot span {
	width: 10px;
	height: 10px;
	background: var(--border);
	border-radius: 50%;
	display: block;
	transition: all .3s;
}


.testiCarousel .owl-dot.active span {
	background: var(--green);
	width: 30px;
	border-radius: 10px;
}


/* =================================== */
/* ==========testi-section=======*/
/* =================================== */


/* =================================== */
/* ==========faq-section=======*/
/* =================================== */


.faq-section {
	background: #fff;
	overflow: hidden;
}

.faq-section-left p {
	margin-bottom: 50px;
}


.accordion {
	border-left: 1px solid #ccc;
	padding-left: 60px;
}


.accordion-item {
	border: 1.5px solid var(--border) !important;
	border-radius: 12px !important;
	margin-bottom: 10px;
	overflow: hidden;
	transition: border-color .3s;
}


.accordion-item:hover {
	border-color: var(--green) !important;
}


.accordion-button {
	font-weight: 500;
	font-size: 22px;
	line-height: 35px;
	letter-spacing: 0%;
	color: #1A2B2B !important;
	background: #fff !important;
	padding: 10px 15px;
	box-shadow: none !important;
}


.accordion-button:not(.collapsed) {
	color: var(--green) !important;
	background: rgba(26, 171, 120, .04) !important;
}

.accordion-button::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%231AAB78' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E") !important;
}

.accordion-button:not(.collapsed)::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%231AAB78' viewBox='0 0 16 16'%3E%3Cpath fill-rule='evenodd' d='M7.646 4.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1-.708.708L8 5.707l-5.646 5.647a.5.5 0 0 1-.708-.708l6-6z'/%3E%3C/svg%3E") !important;
}

.accordion-body {
	font-weight: 400;
	font-size: 18px;
	line-height: 28px;
	letter-spacing: 0%;
	color: #505650;
	padding: 0 15px 10px;
	background: rgba(26, 171, 120, .02);
}

/* =================================== */
/* ==========faq-section=======*/
/* =================================== */


/* =================================== */
/* ==========cta-section=======*/
/* =================================== */


.cta-section {
	position: relative;
	padding: 100px 0;
	text-align: center;
	overflow: hidden;
	margin: 0px 20px;
	border-radius: 20px;
	overflow: hidden;
}

.cta-bg {
	position: absolute;
	inset: 0;
	background: url('../images/tag-banner.png') center center / cover no-repeat;
}

.cta-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(10, 35, 30, 0) 0%, rgba(10, 35, 30, 0.58) 100%);
}

/* green blob in CTA */
.cta-blob {
	position: absolute;
	right: -80px;
	bottom: -80px;
	width: 380px;
	height: 380px;
	border-radius: 50%;
	pointer-events: none;
}

.cta-content {
	position: relative;
	z-index: 2;
	text-align: center;
}


.cta-content h2 {
	font-weight: 700;
	font-size: 70px;
	line-height: 80px;
	letter-spacing: 0%;
	text-align: center;
	color: #fff;
	margin-bottom: 20px;
	padding: 0px;
}


.cta-content h2 span {
	font-style: normal;
	color: #00A884;
}

.cta-content p {
	color: #DCDCDC;
	font-weight: 400;
	font-size: 24px;
	line-height: 40px;
	letter-spacing: 0%;
	text-align: center;
	max-width: 60%;
	margin: 0px auto;
}


.cta-section-butn {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	margin: 50px 0px 0px;
}


/* =================================== */
/* ==========cta-section=======*/
/* =================================== */


.footer {
	background: #051E26;
	padding: 80px 0 0px;
	margin: 100px 20px 20px;
	border-radius: 20px;
	overflow: hidden;
}

.footer-logo img {
	height: 250px;
	width: 200px;
	object-fit: cover;
}

.footer h6 {
	font-weight: 600;
	font-size: 28px;
	line-height: 38px;
	color: #FDFDFD;
	margin: 0px 0px 20px 0px;
	padding: 0px;
	letter-spacing: 0px;
}


.footer-links {
	list-style: none;
	padding: 0;
}


.footer-links li {
	margin-bottom: 12px;
}


.footer-links a {

	font-weight: 600;
	font-size: 20px;
	line-height: 30px;
	letter-spacing: 0px;
	color: #FDFDFD;
	transition: all .25s;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}


.footer-links a:hover {
	color: var(--green);
	padding-left: 5px;
}


.footer-contact-item {
	margin-bottom: 15px;
}

.footer-contact-item p {
	font-weight: 400;
	font-size: 14px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #9D9D9D;
	margin: 0px;
	padding: 0px 0px 10px 0px;
}


.footer-contact-item h4 {
	font-weight: 500;
	font-size: 14px;
	line-height: 100%;
	letter-spacing: 0%;
	color: #FDFDFD;
	margin: 0px;
	padding: 0px;
}

.footer-contact-item h4 a {
	color: #FDFDFD;
}

.footer-contact-item h4 a:hover {
	color: var(--green);
}

.footer-social {
	display: flex;
	gap: 8px;
}

.footer-social a {
	width: 45px;
	height: 45px;
	border-radius: 50%;
	background: #0B3948;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;

	transition: all .3s;
}

.footer-social a:hover {
	background: var(--green);
	color: #fff;
	border-color: var(--green);
	transform: translateY(-2px);
}


.footer-bottom {
	border-top: 1px solid #FCFEFF;
	margin-top: 20px;
	padding: 20px 0px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 14px;
}

.footer-bottom span {
	font-size: .78rem;
	color: rgba(255, 255, 255, .35);
}


.footer-bottom p {
	font-weight: 500;
	font-size: 16px;

	line-height: 100%;
	letter-spacing: 0px;
	color: #FDFDFD;
	padding: 0px;
	margin: 0px;
}

.footer-bottom p a {
	color: #FDFDFD;
}

.footer-bottom p a:hover {
	color: var(--green);
}


/* =================================== */
/* ==========footer========*/
/* =================================== */

/*================================================
Go Top CSS
=================================================*/
.go-top {
	position: fixed;
	cursor: pointer;
	bottom: 100px;
	right: 20px;
	border-radius: 50%;
	background-color: #00A884;
	color: #ffffff;
	z-index: 999;
	width: 50px;
	text-align: center;
	height: 50px;
	opacity: 0;
	visibility: hidden;
	font-size: 25px;
	-webkit-transition: var(--transition);
	-webkit-transition: 0.5s;
	transition: 0.5s;
	-webkit-box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.1);
	box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.1);
}

.go-top i {
	position: absolute;
	right: 0;
	left: 0;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.go-top:hover {
	color: #ffffff;
	-webkit-transition: all 0.5s linear;
	transition: all 0.5s linear;
	background-color: #000;
	border: 1px solid #000;
}

.go-top.active {
	opacity: 1;
	visibility: visible;
	bottom: 25px;
	-webkit-animation: top-bottom 5s infinite linear;
	animation: top-bottom 5s infinite linear;
}

/*================================================
Go Top CSS
=================================================*/

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(28px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

@keyframes fadeInLeft {
	from {
		opacity: 0;
		transform: translateX(-28px)
	}

	to {
		opacity: 1;
		transform: translateX(0)
	}
}

@keyframes fadeInRight {
	from {
		opacity: 0;
		transform: translateX(28px)
	}

	to {
		opacity: 1;
		transform: translateX(0)
	}
}

.h-a1 {
	animation: fadeInUp .75s ease .05s both;
}

.h-a2 {
	animation: fadeInUp .75s ease .2s both;
}

.h-a3 {
	animation: fadeInLeft .8s ease .05s both;
}

.h-a4 {
	animation: fadeInUp .75s ease .35s both;
}

.h-a5 {
	animation: fadeInUp .75s ease .5s both;
}

.h-a6 {
	animation: fadeInRight .8s ease .2s both;
}


/* ==================================================================*/
/* end M.B css*/
/* ==================================================================*/


/*--inner page --*/

.inner-banner-section {
	padding: 0px;
	margin: 0px;
	position: relative;
	overflow: hidden;
}

.inner-banner-section img {
	width: 100%;
	height: auto;
	object-fit: cover;
}

.inner-banner-text {
	position: absolute;
	top: 70%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	padding: 0px;
	width: 100%;
}

.inner-banner-text h1 {
	font-weight: 600;
	font-size: 50px;
	line-height: 60px;
	text-transform: capitalize;
	color: #fff;
	padding: 0px;
	margin: 0px;
}

.inner-banner-text p {
	font-family: Poppins;
	font-weight: 400;
	font-size: 35px;
	line-height: 35px;
	letter-spacing: 0%;
	color: #fff;
	padding: 0px;
	margin: 0px;
}

.inner-banner-section .banner-right-info {
	width: 23%;
}


.service-content .content p {
	text-align: justify;
}

section.aboutuspage-section {
	padding: 67px 0px;
}


/*--inner page --*/


/*-- Case Study single--*/

.single-case-study-page {
	padding: 100px 0;
	background: #fff;
}

.case-study-single-image img {
	border-radius: 20px;
	height: 100%;
	object-fit: cover;
}

.case-study-category {
	display: inline-block;
	background: #f5f5f5;
	padding: 8px 20px;
	border-radius: 30px;
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 20px;
}

.case-study-title {
	font-weight: 700;
	margin-bottom: 25px;
	line-height: 1.2;
}

.case-study-result {
	background: #111;
	color: #fff;
	padding: 25px 30px;
	border-radius: 20px;
	margin-bottom: 30px;
}

.case-study-result h3 {
	margin: 0;
	font-size: 36px;
	font-weight: 700;
}

.case-study-content {
	font-size: 18px;
	line-height: 1.9;
}

/*-- case study single --*/

/*--- service Single Page --*/

.single-service-page {
	padding: 100px 0;
	background: #fff;
}

.service-single-image img {
	border-radius: 20px;
	height: 100%;
	object-fit: cover;
}

.service-subtitle {
	display: inline-block;
	background: #f5f5f5;
	padding: 8px 20px;
	border-radius: 30px;
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 20px;
}

.service-title {
	font-size: 40px;
	font-weight: 700;
	margin-bottom: 20px;
	line-height: 1.2;
}

.service-content {
	font-size: 18px;
	line-height: 1.9;
}


/*---service single Page ---*/


/* Contact detail cards */
.contact-cards {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 2rem;
}

.contact-card {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	background: #ffffff;
	border: 1px solid #c6d0d5;
	border-radius: 8px;
	padding: 1.1rem 1.25rem;
	text-decoration: none;
	color: inherit;
	transition: border-color 0.2s, box-shadow 0.2s;
}

.contact-card:hover {
	border-color: #004D3D;
	box-shadow: 0 4px 20px rgba(201, 147, 90, 0.12);
	color: inherit;
}

.card-icon {
	flex-shrink: 0;
	width: 42px;
	height: 42px;
	border-radius: 8px;
	background: #d9e3eb;
	display: flex;
	align-items: center;
	justify-content: center;
}

.card-icon svg {
	width: 20px;
	height: 20px;
	stroke: #004D3D;
	fill: none;
	stroke-width: 1.6;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.card-label {
	font-size: 0.68rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #aaa49d;
	font-weight: 500;
	margin-bottom: 0.2rem;
}

.card-value {
	font-size: 0.92rem;
	font-weight: 500;
	color: #004D3D;
}


/* ── Right Form Panel ── */
.form-panel {
	background: #ffffff;
	border: 1px solid #c6d0d5;
	border-radius: 12px;
	padding: 40px;
	margin-left: 80px;
}

.form-panel .form-title {
	font-size: 1.65rem;
	font-weight: 600;
	color: #004D3D;
	margin-bottom: 0.25rem;
}

.form-panel .form-sub {
	font-size: 0.875rem;
	color: #aaa49d;
	margin-bottom: 2rem;
}

/* Form controls */
.form-panel label {
	font-size: 0.72rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 500;
	color: #6b6560;
	margin-bottom: 0.45rem;
	display: block;
}

.form-panel input,
.form-panel select,
.form-panel textarea {
	width: 100%;
	/* background: #d9e3eb; */
	border: 1px solid #d9e3eb;
	border-radius: 6px;
	padding: 0.75rem 1rem;
	font-size: 0.9rem;

	outline: none;
	transition: border-color 0.2s, box-shadow 0.2s;
	appearance: none;
}

.form-panel textarea {
	resize: vertical;
	min-height: 130px;
}

/* Select arrow */
.select-wrap {
	position: relative;
}

.select-wrap::after {
	content: '';
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	border: 5px solid transparent;
	border-top-color: #aaa49d;
	pointer-events: none;
}

.select-wrap select {
	padding-right: 2.5rem;
	cursor: pointer;
}

/* Radio / checkbox group */
.radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem;
}

.radio-chip input {
	display: none;
}

.radio-chip label {
	display: inline-block;
	padding: 0.45rem 1rem;
	border: 1px solid #d9e3eb;
	border-radius: 100px;
	font-size: 0.78rem;
	letter-spacing: 0.05em;
	text-transform: none;
	color: #6b6560;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s, color 0.2s;
	font-weight: 400;
}

.radio-chip input:checked+label {
	border-color: #004D3D;
	background: #004D3D;
	color: #ffffff;
}

.radio-chip label:hover {
	border-color: #004D3D;
	color: #004D3D;
}

/* Submit */
.btn-submit {
	width: 100%;
	background: #004D3D;
	color: #ffffff !important;
	border: 2px solid #004D3D;
	border-radius: 6px;
	padding: 0.9rem;
	font-size: 0.78rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.22s, color 0.22s;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.6rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}


.form-note {
	text-align: center;
	font-size: 0.75rem;
	color: #aaa49d;
	margin-top: 1rem;
}

/*-- Contact end--*/
.page-id-260 .accordion {
	border-left: none;

}

.page-id-105 .about-section {
	background: none;

}


button.sub-menu-toggle {
	display: none;
}


.stellarnav .icon-close::after { border-bottom: solid 3px #fff; }

.stellarnav .icon-close::before { border-bottom: solid 3px #fff; }


.stellarnav a.dd-toggle .icon-plus::after { border-bottom: solid 3px #fff; }
.stellarnav a.dd-toggle .icon-plus::before { border-bottom: solid 3px #fff; }



/* ===== Single Service Page ===== */

.single-service-page {
    padding: 60px 0;
    background: #ffffff;
    font-family: 'DM Sans', sans-serif;
}

.single-service-page .custom-container {
    
    margin: 0 auto;
    padding: 0 20px;
}

/* ===== Image Side ===== */

.single-service-page .service-single-image {
    position: relative;
    padding: 18px 0 14px 18px;
}

.single-service-page .service-single-image::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 65px;
    height: 65px;
    border: 2.5px solid #1D9E75;
    border-radius: 4px;
    z-index: 0;
}

.single-service-page .service-single-image::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 40px;
    height: 40px;
    background: #E1F5EE;
    border-radius: 50%;
    z-index: 0;
}

.single-service-page .service-single-image img {
    position: relative;
    z-index: 1;
    border-radius: 12px;
    /*border: 1px solid #e8e8e8;*/
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* ===== Content Side ===== */

.single-service-page .service-title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
    color: #111111;
    letter-spacing: -0.02em;
    margin: 0 0 20px;
    position: relative;
    padding-bottom: 18px;
}

.single-service-page .service-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 36px;
    height: 2px;
    background: #1D9E75;
    border-radius: 2px;
}

/* ===== Service Content ===== */

.single-service-page .service-content p {
    font-size: 14.5px;
    line-height: 1.8;
    font-weight: 300;
    margin: 0 0 14px;
}

.single-service-page .service-content p strong {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    display: block;
    margin-bottom: 12px;
}

.single-service-page .service-content ul {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.single-service-page .service-content ul li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13.5px;
    color: #222222;
    line-height: 1.5;
}

.single-service-page .service-content ul li::before {
    content: '';
    width: 20px;
    height: 20px;
    min-width: 20px;
    border-radius: 50%;
    background: #E1F5EE url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpolyline points='2,6 5,9 10,3' fill='none' stroke='%230F6E56' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/11px no-repeat;
    margin-top: 1px;
}

.single-service-page .service-content p span {
    font-size: 16px;
    color: #1d9e75;
    font-style: italic;
    padding: 10px 14px;
    border-left: 2px solid #1d9e75;
    background: #f7faf9;
    border-radius: 0 6px 6px 0;
    margin-bottom: 0;
    font-weight: 500;
}

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

@media (max-width: 991px) {
    .single-service-page .service-title {
        font-size: 1.6rem;
    }
}

@media (max-width: 767px) {
    .single-service-page {
        padding: 40px 0;
    }
    .single-service-page .service-title {
        font-size: 1.4rem;
    }
}



/* ===== SECTION ===== */
.tech-stack-section {
  padding: 90px 0 80px;
  background: #f6f6f3;
  overflow: hidden;
  position: relative;
}

.tech-stack-section::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -80px;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: #E1F5EE;
  opacity: 0.45;
  pointer-events: none;
}

/* ===== SECTION HEADER ===== */
.ts-section-header {
  margin-bottom: 64px;
}

.ts-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #0F6E56;
  margin-bottom: 16px;
}

.ts-eyebrow::before {
  content: '';
  display: block;
  width: 28px;
  height: 2px;
  background: #1D9E75;
  border-radius: 2px;
}

.ts-section-header h2 {
  font-weight: 800;
  color: #111111;
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin-bottom: 16px;
}

.ts-section-header h2 span {
  color: #1D9E75;
}

.ts-section-desc {
  font-size: 15px;
  line-height: 1.8;
  color: #666666;
  font-weight: 300;
  max-width: 620px;
}

/* ===== BLOCK ===== */
.ts-block {
  margin-bottom: 72px;
}

.ts-block-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}

.ts-block-header::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #dddddd;
}

.ts-block-title {
  font-family: 'Syne', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: #111111;
  white-space: nowrap;
}

.ts-block-title span {
  color: #1D9E75;
  margin-right: 6px;
}

/* ===== PARTNER CARDS ===== */
.ts-partner-card {
  background: #ffffff;
  border: 1px solid #e8e8e4;
  border-radius: 16px;
  padding: 32px 28px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.25s ease, transform 0.25s ease;
}

.ts-partner-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #1D9E75;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}

.ts-partner-card:hover {
  border-color: #9FE1CB;
  transform: translateY(-3px);
}

.ts-partner-card:hover::after {
  transform: scaleX(1);
}

.ts-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ts-badge {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #0F6E56;
  background: #E1F5EE;
  padding: 4px 10px;
  border-radius: 100px;
  border: 1px solid #9FE1CB;
}

.ts-partner-logo {
  width: 100px;
  height: 100px;
  border-radius: 14px;
  border: 1px solid #eeeeee;
  overflow: hidden;
  background: #fafafa;
  flex-shrink: 0;
}

.ts-partner-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 8px;
  display: block;
}

.ts-partner-name {
  
  font-size: 1.25rem;
  font-weight: 700;
  color: #111111;
}

.ts-partner-desc {
  font-size: 13.5px;
  line-height: 1.7;
  color: #777777;
  font-weight: 300;
  flex: 1;
}

.ts-card-number {
  position: absolute;
  top: 20px;
  right: 24px;
  
  font-size: 3rem;
  font-weight: 800;
  color: #f0faf6;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}

/* ===== PARTNER NOTE ===== */
.ts-partner-note {
  font-size: 14px;
  line-height: 1.85;
  color: #555555;
  font-weight: 300;
  padding: 20px 24px;
  border-left: 3px solid #1D9E75;
  background: #ffffff;
  border-radius: 0 10px 10px 0;
  margin-top: 24px;
  border-top: 1px solid #eef8f4;
  border-right: 1px solid #eef8f4;
  border-bottom: 1px solid #eef8f4;
}

.ts-partner-note a {
  color: #1D9E75;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid #9FE1CB;
  transition: color 0.2s;
}

.ts-partner-note a:hover {
  color: #0F6E56;
}

/* ===== TOOL CARDS ===== */
.ts-tool-card {
  background: #ffffff;
  border: 1px solid #e8e8e4;
  border-radius: 16px;
  padding: 28px 24px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
  transition: border-color 0.25s ease, transform 0.25s ease;
}

.ts-tool-card:hover {
  border-color: #9FE1CB;
  transform: translateY(-3px);
}

.ts-tool-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #1D9E75;
  opacity: 0;
  transition: opacity 0.25s ease;
}

.ts-tool-card:hover::before {
  opacity: 1;
}

.ts-tool-icon {
  width: 80px;
  height: 80px;
  border-radius: 12px;
  border: 1px solid #eeeeee;
  overflow: hidden;
  background: #fafafa;
  flex-shrink: 0;
}

.ts-tool-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 8px;
  display: block;
}

.ts-tool-name {
  
  font-size: 1rem;
  font-weight: 700;
  color: #111111;
}

.ts-tool-desc {
  font-size: 13px;
  line-height: 1.7;
  color: #777777;
  font-weight: 300;
  flex: 1;
}

.ts-tool-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #888888;
  background: #f4f4f1;
  padding: 3px 8px;
  border-radius: 100px;
  margin-top: 4px;
  align-self: flex-start;
}

/* ===== STATS STRIP ===== */
.ts-stats-strip {
  background: #111111;
  border-radius: 16px;
  padding: 32px 36px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 24px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.ts-stat {
  text-align: center;
}

.ts-stat-num {
  
  font-size: 1.8rem;
  font-weight: 800;
  color: #1D9E75;
  display: block;
  line-height: 1;
  margin-bottom: 6px;
}

.ts-stat-label {
  font-size: 12px;
  color: #888888;
  font-weight: 300;
  letter-spacing: 0.04em;
}

.ts-stat-divider {
  width: 1px;
  height: 40px;
  background: #333333;
}

@media (max-width: 576px) {
  .ts-stat-divider { display: none; }
  .ts-stats-strip { gap: 20px; }
}


.about-bottom-section h3 {
    font-weight: 500;
    font-style: Medium;
    font-size: 30px;
    line-height: 55px;
    letter-spacing: 0%;
    color: #1A2B2B;
    margin: 0px 0px 30px 0px;
    padding: 0px;
}
.about-bottom-section ul {
    margin-left: 40px;
}

.about-bottom-section ul li {
    font-family: Montserrat;
    font-weight: 400;
    font-size: 18px;
    line-height: 28px;
    letter-spacing: 0%;
    color: #666666;
    margin: 0px 0px 8px 0px;
    padding: 0px;
    list-style-type: disclosure-closed;
}

.cms-page h2 {
    font-size: 22px;
    font-weight: 600;
}

.cms-page h3 {
    font-size: 20px;
    font-weight: 600;
}


.cms-page ul {
    margin-left: 40px;
}

.cms-page ul li {
    font-family: Montserrat;
    font-weight: 400;
    font-size: 16px;
    line-height: 28px;
    letter-spacing: 0%;
    color: #666666;
    margin: 0px 0px 8px 0px;
    padding: 0px;
    list-style-type: disclosure-closed;
}
