/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Feb 24 2026 | 15:50:31 */
#ast-scroll-top,
#ast-scroll-top::before {
	transition: all 0.3s linear;
}
#ast-scroll-top {
	width: 35px;
	height: 60px;
	background-color: var( --e-global-color-primary );
	border: 2px solid var( --e-global-color-secondary );
	border-radius: 8px;
	backdrop-filter: blur(5px);
}
#ast-scroll-top .ast-icon {
	display: none;
}
#ast-scroll-top::before {
	content: '';
	display: block;
	width: 30px;
	height: 30px;
	background-image: url('https://mw.dev-version.com/lotus-passage/wp-content/uploads/2026/02/arrow-up.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	/* 	filter: brightness(0) saturate(100%) invert(100%); */
	margin: auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
#ast-scroll-top:hover::before {
	transform: translate(-50%, calc(-50% - 5px));
}
input::placeholder, 
textarea::placeholder {
	opacity: 0.7 !important;
}
input:focus, 
textarea:focus {
	box-shadow: none !important;
	outline: none !important;
	border-style: solid !important;
	border-color: var( --e-global-color-secondary ) !important;
}
div p {
	margin-bottom: 10px !important;
}
div p:last-child {
	margin-bottom: 0 !important;
}
ol,
ul {
	margin-bottom: 10px;
	margin-left: 35px;
}
ol:last-child,
ul:last-child {
	margin-bottom: 0 !important;
}
ul li::marker {
	color: var( --e-global-color-primary );
}
.white-markers ul li::marker {
	color: #fff;
}
ul li {
	list-style: disc;
}
ul li > ul li {
	list-style: circle;
}
ul li > ul li > ul li {
	list-style: square;
}
a {
	text-decoration: none !important;
}
.overflow-x-hidden {
	overflow: clip;
	overflow-y: visible;
}
.overflow-y-hidden {
	overflow: clip;
	overflow-x: visible;
}
.w-fit-content {
	width: fit-content;
}
.h-100,
.loop-img-h-100 a {
	height: 100% !important;
}
.w-100,
.loop-img-w-100 a {
	width: 100% !important;
}
.position-static {
	position: static;
}
.color-primary {
	color: var(--e-global-color-primary);
}
.color-secondary {
	color: var(--e-global-color-secondary);
}
.color-accent {
	color: var(--e-global-color-accent);
}
.carousel .swiper {
	user-select: none;
	cursor: grab;
}
.blur-bg {
	backdrop-filter: blur(4px);
}
.white-img {
	filter: brightness(0) invert(1);
}
.truncate, 
.truncate h4, 
.truncate p{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}
.line-2,
.line-2 h4,
.line-2 p {
	-webkit-line-clamp: 2;
}
.line-3, 
.line-3 p {
	-webkit-line-clamp: 3;
}
.line-4, 
.line-4 p {
	-webkit-line-clamp: 4;
}
.line-5, 
.line-5 p {
	-webkit-line-clamp: 5;
}
.line-6, 
.line-6 p {
	-webkit-line-clamp: 6;
}
.line-7, 
.line-7 p {
	-webkit-line-clamp: 7;
}
.line-8, 
.line-8 p {
	-webkit-line-clamp: 8;
}
.position-relative,
.position-relative .e-con-inner {
	position: relative;
}
.elementor-nav-menu .current_page_item .elementor-item-active {
	font-weight: bold !important;
}
.elementor-menu-toggle {
	padding: 3px;
	border: 1px solid #fff !important;
	outline: 5px solid var( --e-global-color-primary );
	border-radius: 2px !important;
}
.custom-btn .elementor-button .elementor-button-content-wrapper {
	align-items: center;
	position: relative;
	z-index: 5;
}
.custom-btn .elementor-button .elementor-button-icon {
	font-size: 18px;
}
.custom-btn .elementor-button,
.custom-btn .elementor-button .elementor-button-icon {
	transition: all 0.4s linear;
}
.custom-btn .elementor-button::before {
	content: "";
	display: block;
	width: calc(100% - 60px);
	height: 2px;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%);
	transition: width 0.2s linear, height 0.2s linear 0.3s;
}
.custom-btn .elementor-button:hover::before {
	width: 100%;
	height: 100%;
}
.custom-btn.style1 .elementor-button .elementor-button-icon {
	color: var( --e-global-color-accent );
}
.custom-btn.style1 .elementor-button::before {
	background-color: var( --e-global-color-accent );
}
.custom-btn.style1 .elementor-button:hover,
.custom-btn.style1 .elementor-button:hover .elementor-button-icon {
	color: var( --e-global-color-secondary ) !important;
	fill: var( --e-global-color-secondary ) !important;
}
.btn-icon-box .elementor-icon, 
.btn-icon-box .elementor-icon-box-icon {
	transition: all 0.2s linear;
}
.btn-icon-box .elementor-icon-box-icon {
	padding: 6px;
	border-radius: 50%;
}
.btn-icon-box .elementor-icon {
	padding: 8px;
	border-radius: 50%;
}
.btn-icon-box.style1 .elementor-icon-box-icon {
	background-color: var( --e-global-color-accent );
}
.btn-icon-box.style1 .elementor-icon {
	border: 1px solid var( --e-global-color-primary );
}
.btn-icon-box.style1 .anchor {
	color: #fff;
}
.btn-icon-box.style1:hover .elementor-icon-box-icon {
	background-color: var( --e-global-color-secondary );
}
.btn-icon-box.style1:hover .elementor-icon {
	border-color: #fff;
}
.btn-icon-box.style1:hover .elementor-icon svg path {
	color: #fff !important;
	fill: #fff !important;
}
.btn-icon-box.style2 .elementor-icon-box-icon {
	background-color: var( --e-global-color-primary );
}
.btn-icon-box.style2 .elementor-icon {
	border: 1px solid #fff;
}
.btn-icon-box.style2 .elementor-icon svg path {
	color: #fff !important;
	fill: #fff !important;
}
.btn-icon-box.style2 .anchor {
	color: var( --e-global-color-text );
}
.btn-icon-box.style2:hover .elementor-icon-box-icon {
	background-color: var( --e-global-color-accent );
}
.btn-icon-box.style2:hover .elementor-icon {
	border-color: var( --e-global-color-primary ) !important;
}
.btn-icon-box.style2:hover .elementor-icon svg path {
	color: var( --e-global-color-primary ) !important;
	fill: var( --e-global-color-primary ) !important;
}
.icon-list-anchor {
	color: #fff;
	display: inline !important;
}
.icon-list-anchor:hover {
	color: var( --e-global-color-accent );
}
.steps::after {
	content: "";
	display: block;
	width: 1px;
	height: 100%;
	background: var( --e-global-color-accent );
	position: absolute;
	top: 50%;
	right: -20px;
	transform: translateY(-50%);
	transition: all 0.3s linear;
	z-index: -1;
}
.steps:hover::after {
	width: calc(100% + 40px);
}
.steps.step4::after {
	right: unset;
	left: -20px;
	transform: translateY(-50%) scaleX(0);
	transform-origin: left;
}
.steps.step4:hover::after {
	transform: translateY(-50%) scaleX(1);
}
.service-box,
.service-box h3, 
.service-box p,
.service-box .elementor-icon svg path {
	transition: all 0.2s linear !important;
}
.service-box:hover {
	background-color: var(--e-global-color-primary) !important;
}
.service-box:hover .elementor-icon svg path {
	color: var(--e-global-color-accent);
	fill: var(--e-global-color-accent);
}
.service-box:hover h3, 
.service-box:hover p {
	color: #fff !important;
}
.contact-icon-box .elementor-icon-box-icon, 
.contact-icon-box .elementor-icon-box-icon svg path,
.contact-icon-box .elementor-icon-box-icon svg circle {
	transition: all 0.2s linear;
}
.contact-icon-box .elementor-icon-box-icon {
	margin-top: -9px;
	border: 1px solid var( --e-global-color-primary );
	border-radius: 50%;
}
.contact-icon-box:hover .elementor-icon-box-icon svg circle {
	color: var( --e-global-color-accent ) !important; 
	fill: var( --e-global-color-accent ) !important; 
}
.contact-icon-box:hover .elementor-icon-box-icon svg path {
	color: var( --e-global-color-primary ) !important; 
	fill: var( --e-global-color-primary ) !important; 
}
.contact-icon-box .anchor {
	color: #000 !important;
}
@media screen and (max-width:1024px) {
	.btn-icon-box .elementor-icon-box-icon {
		padding: 5px;
	}
	.btn-icon-box .elementor-icon {
		padding: 7px;
	}
	.custom-btn .elementor-button .elementor-button-icon {
		font-size: 16px;
	}
	.custom-btn .elementor-button::before {
		width: calc(100% - 40px);
	}
	.steps.step2::after {
		right: unset;
		left: -20px;
		transform: translateY(-50%) scaleX(0);
		transform-origin: left;
	}
	.steps.step2:hover::after {
		transform: translateY(-50%) scaleX(1);
	}
	.step3::before,
	.step4::before {
		content: "";
		display: block;
		width: 100%;
		height: 1px;
		background: var( --e-global-color-accent );
		position: absolute;
		top: -20px;
		right: 0;
		z-index: -1;
	}
}
@media screen and (max-width:768px) {
	.step2::before {
		content: "";
		display: block;
		width: 100%;
		height: 1px;
		background: var( --e-global-color-accent );
		position: absolute;
		top: -20px;
		right: 0;
		z-index: -1;
	}
}
