@font-face {
	font-display: swap;
	font-family: "Anek Bangla Local";
	font-style: normal;
	font-weight: 400;
	src: url("../fonts/Anek_Bangla/AnekBangla-Regular.ttf") format("truetype");
}

@font-face {
	font-display: swap;
	font-family: "Anek Bangla Local";
	font-style: normal;
	font-weight: 600;
	src: url("../fonts/Anek_Bangla/AnekBangla-SemiBold.ttf") format("truetype");
}

@font-face {
	font-display: swap;
	font-family: "Anek Bangla Local";
	font-style: normal;
	font-weight: 800;
	src: url("../fonts/Anek_Bangla/AnekBangla-Bold.ttf") format("truetype");
}

@font-face {
	font-display: swap;
	font-family: "Hind Siliguri Local";
	font-style: normal;
	font-weight: 400;
	src: url("../fonts/Hind_Siliguri/HindSiliguri-Regular.ttf") format("truetype");
}

@font-face {
	font-display: swap;
	font-family: "Hind Siliguri Local";
	font-style: normal;
	font-weight: 600;
	src: url("../fonts/Hind_Siliguri/HindSiliguri-SemiBold.ttf") format("truetype");
}

@font-face {
	font-display: swap;
	font-family: "Hind Siliguri Local";
	font-style: normal;
	font-weight: 800;
	src: url("../fonts/Hind_Siliguri/HindSiliguri-Bold.ttf") format("truetype");
}

:root {
	--ec-bg: #070b16;
	--ec-panel: rgba(15, 23, 42, 0.78);
	--ec-panel-strong: rgba(15, 23, 42, 0.94);
	--ec-text: #f8fafc;
	--ec-muted: #94a3b8;
	--ec-line: rgba(148, 163, 184, 0.18);
	--ec-teal: #14b8a6;
	--ec-cyan: #22d3ee;
	--ec-indigo: #6366f1;
	--ec-green: #16a34a;
	--ec-red: #b91c1c;
}

* {
	box-sizing: border-box;
}

html {
	scroll-padding-top: 112px;
}

body {
	background:
		linear-gradient(120deg, rgba(20,184,166,.14), transparent 30%),
		linear-gradient(240deg, rgba(99,102,241,.13), transparent 34%),
		linear-gradient(135deg, rgba(20, 184, 166, 0.14), transparent 28%),
		linear-gradient(225deg, rgba(99, 102, 241, 0.14), transparent 30%),
		var(--ec-bg);
	background-attachment: fixed;
	color: var(--ec-text);
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	margin: 0;
	min-height: 100vh;
	position: relative;
}

html[data-ec-lang="bn"] body {
	font-family: "Hind Siliguri Local", "Anek Bangla Local", ui-sans-serif, system-ui, sans-serif;
}

html[data-ec-lang="bn"] h1,
html[data-ec-lang="bn"] h2,
html[data-ec-lang="bn"] h3,
html[data-ec-lang="bn"] strong,
html[data-ec-lang="bn"] .ec-button,
html[data-ec-lang="bn"] .ec-kicker,
html[data-ec-lang="bn"] .ec-nav,
html[data-ec-lang="bn"] .ec-price-cards a,
html[data-ec-lang="bn"] .ec-faq-list summary {
	font-family: "Anek Bangla Local", "Hind Siliguri Local", ui-sans-serif, system-ui, sans-serif;
}

body:before {
	animation: ecColorShift 12s ease-in-out infinite alternate;
	background:
		linear-gradient(115deg, rgba(20,184,166,.14), rgba(99,102,241,.16), rgba(34,211,238,.12), rgba(16,185,129,.12)),
		repeating-linear-gradient(90deg, transparent 0 80px, rgba(255,255,255,.025) 80px 81px);
	background-size: 300% 300%;
	content: "";
	inset: 0;
	pointer-events: none;
	position: fixed;
	z-index: 0;
}

body:after {
	background:
		radial-gradient(circle at var(--ec-mouse-x, 50%) var(--ec-mouse-y, 24%), rgba(45, 212, 191, 0.34), transparent 21%),
		radial-gradient(circle at calc(var(--ec-mouse-x, 50%) + 14%) calc(var(--ec-mouse-y, 24%) + 10%), rgba(99, 102, 241, 0.22), transparent 28%);
	content: "";
	filter: blur(8px);
	inset: 0;
	mix-blend-mode: screen;
	pointer-events: none;
	position: fixed;
	z-index: 1;
}

.ec-site-header,
.ec-site-main,
.ec-footer {
	position: relative;
	z-index: 2;
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
select,
textarea {
	font: inherit;
}

.ec-site-header {
	align-items: center;
	backdrop-filter: blur(18px);
	background: rgba(7, 11, 22, 0.76);
	border-bottom: 1px solid var(--ec-line);
	display: flex;
	gap: 24px;
	justify-content: space-between;
	left: 0;
	padding: 18px clamp(18px, 4vw, 56px);
	position: sticky;
	right: 0;
	top: 0;
	z-index: 50;
}

.ec-brand,
.ec-header-actions,
.ec-nav,
.ec-hero-actions {
	align-items: center;
	display: flex;
	gap: 12px;
}

.ec-brand {
	font-size: 19px;
	font-weight: 900;
	letter-spacing: 0;
	min-width: 0;
}

.ec-brand-mark {
	align-items: center;
	animation: ecColorShift 5s ease-in-out infinite alternate;
	background:
		radial-gradient(circle at var(--ec-logo-x, 35%) var(--ec-logo-y, 28%), rgba(255,255,255,.28), transparent 34%),
		linear-gradient(135deg, var(--ec-teal), var(--ec-indigo), var(--ec-cyan));
	background-size: 220% 220%;
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 14px;
	box-shadow: 0 16px 36px rgba(20,184,166,.22), inset 0 0 0 1px rgba(255,255,255,.12);
	display: inline-flex;
	height: 38px;
	justify-content: center;
	overflow: hidden;
	position: relative;
	width: 38px;
}

.ec-brand-mark:before,
.ec-brand-mark:after {
	background: rgba(255,255,255,.2);
	content: "";
	height: 1px;
	left: 8px;
	position: absolute;
	right: 8px;
	top: 50%;
	transform: rotate(45deg);
}

.ec-brand-mark:after {
	transform: rotate(-45deg);
}

.ec-logo-core {
	animation: ecLogoPulse 2.8s ease-in-out infinite;
	background: rgba(7, 11, 22, .5);
	border: 2px solid rgba(255,255,255,.9);
	border-radius: 10px;
	box-shadow: 0 0 20px rgba(94,234,212,.36);
	height: 14px;
	position: relative;
	transform: rotate(45deg);
	width: 14px;
	z-index: 2;
}

.ec-logo-node {
	background: #e0f2fe;
	border-radius: 999px;
	box-shadow: 0 0 14px rgba(255,255,255,.68);
	height: 5px;
	position: absolute;
	width: 5px;
	z-index: 3;
}

.ec-logo-node-one {
	animation: ecNodeOne 3.2s ease-in-out infinite;
	left: 9px;
	top: 9px;
}

.ec-logo-node-two {
	animation: ecNodeTwo 3.2s ease-in-out infinite;
	right: 9px;
	top: 9px;
}

.ec-logo-node-three {
	animation: ecNodeThree 3.2s ease-in-out infinite;
	bottom: 9px;
	left: 9px;
}

.ec-logo-node-four {
	animation: ecNodeFour 3.2s ease-in-out infinite;
	bottom: 9px;
	right: 9px;
}

.ec-nav {
	color: #cbd5e1;
	font-size: 14px;
}

.ec-nav a {
	align-items: center;
	border-radius: 999px;
	display: inline-flex;
	gap: 7px;
	padding: 9px 12px;
}

.ec-nav a:hover {
	background: rgba(255,255,255,0.08);
}

.ec-button {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 999px;
	cursor: pointer;
	display: inline-flex;
	font-weight: 800;
	gap: 8px;
	justify-content: center;
	padding: 12px 18px;
}

.ec-button .bx,
.ec-nav .bx,
.ec-footer .bx,
.ec-price-cards .bx {
	font-size: 1.15em;
}

.ec-button-primary {
	animation: ecColorShift 6s ease-in-out infinite alternate;
	background: linear-gradient(135deg, var(--ec-teal), var(--ec-indigo), var(--ec-cyan));
	background-size: 240% 240%;
	box-shadow: 0 14px 34px rgba(20, 184, 166, 0.22);
	color: #fff;
}

.ec-button-ghost {
	background: rgba(15, 23, 42, 0.7);
	border-color: var(--ec-line);
	color: #e2e8f0;
}

.ec-lang-switch {
	align-items: center;
	background: rgba(15, 23, 42, 0.72);
	border: 1px solid rgba(94, 234, 212, .24);
	border-radius: 999px;
	color: #e2e8f0;
	cursor: pointer;
	display: inline-flex;
	font-weight: 900;
	gap: 7px;
	min-height: 44px;
	padding: 10px 13px;
	transition: background .2s ease, border-color .2s ease, transform .2s ease;
}

.ec-lang-switch:hover {
	background: rgba(20, 184, 166, .14);
	border-color: rgba(94, 234, 212, .58);
	transform: translateY(-1px);
}

.ec-lang-switch .bx {
	color: #67e8f9;
	font-size: 18px;
}

html[data-ec-lang="bn"] .ec-lang-switch {
	background: linear-gradient(135deg, rgba(20,184,166,.24), rgba(99,102,241,.2));
	border-color: rgba(94, 234, 212, .52);
}

.ec-site-main {
	min-height: calc(100vh - 160px);
}

.ec-hero {
	display: grid;
	gap: clamp(34px, 5vw, 76px);
	grid-template-columns: minmax(0, 0.96fr) minmax(430px, 0.84fr);
	margin: 0 auto;
	max-width: 1220px;
	min-height: calc(100vh - 86px);
	overflow: visible;
	padding: clamp(56px, 8vw, 110px) clamp(18px, 4vw, 40px) 64px;
	position: relative;
}

.ec-hero:after {
	content: "";
	filter: blur(10px);
	pointer-events: none;
	position: absolute;
	z-index: 0;
}

.ec-hero:after {
	background:
		linear-gradient(135deg, rgba(16,185,129,.06), transparent 58%);
	bottom: 8%;
	height: 68%;
	right: -5%;
	width: 56%;
}

.ec-hero-copy {
	align-self: center;
	min-width: 0;
	position: relative;
	z-index: 2;
}

.ec-kicker {
	color: #5eead4;
	font-size: 13px;
	font-weight: 900;
	letter-spacing: 0.14em;
	margin: 0 0 16px;
	text-transform: uppercase;
}

.ec-hero h1 {
	background: linear-gradient(115deg, #fff, #99f6e4, #bfdbfe, #c4b5fd);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	font-size: clamp(58px, 7.2vw, 106px);
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0 0 18px;
	max-width: 100%;
	overflow: visible;
}

.ec-hero-lede {
	color: #cbd5e1;
	font-size: clamp(18px, 2vw, 23px);
	line-height: 1.65;
	margin: 0 0 34px;
	max-width: 690px;
}

.ec-typewriter {
	align-items: center;
	background: rgba(15, 23, 42, .56);
	border: 1px solid rgba(94, 234, 212, .18);
	border-radius: 999px;
	display: inline-flex;
	gap: 10px;
	margin: -4px 0 22px;
	max-width: 100%;
	padding: 10px 14px;
}

.ec-typewriter span {
	color: #67e8f9;
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}

.ec-typewriter strong {
	color: #f8fafc;
	display: inline-block;
	font-size: clamp(15px, 1.5vw, 18px);
	min-height: 1.35em;
	white-space: nowrap;
}

.ec-typewriter strong:after {
	animation: ecCaret 0.8s steps(1) infinite;
	color: #5eead4;
	content: "|";
	margin-left: 3px;
}

.ec-hero-feature-stream {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 28px;
	max-width: 660px;
}

.ec-hero-feature-stream span {
	align-items: center;
	background: linear-gradient(135deg, rgba(15,23,42,.72), rgba(30,41,59,.48));
	border: 1px solid rgba(148, 163, 184, .2);
	border-radius: 999px;
	color: #dbeafe;
	display: inline-flex;
	font-size: 13px;
	font-weight: 800;
	gap: 7px;
	padding: 10px 12px;
}

.ec-hero-feature-stream .bx {
	color: #67e8f9;
	font-size: 16px;
}

.ec-hero-system {
	align-self: center;
	background:
		linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px),
		linear-gradient(135deg, rgba(20, 184, 166, 0.22), rgba(99, 102, 241, 0.16));
	background-size: 30px 30px, 30px 30px, auto;
	border: 1px solid var(--ec-line);
	border-radius: 30px;
	min-height: 520px;
	padding: 28px;
	position: relative;
	transform: perspective(1000px) rotateX(calc(var(--ec-tilt-y, 0) * -0.8deg)) rotateY(calc(var(--ec-tilt-x, 0) * 0.8deg));
	transition: transform 0.18s ease-out;
	z-index: 2;
}

.ec-hero-system:after {
	background: radial-gradient(circle at var(--ec-local-x, 50%) var(--ec-local-y, 50%), rgba(94, 234, 212, 0.28), transparent 34%);
	border-radius: inherit;
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.ec-price-cards span {
	color: var(--ec-muted);
	display: block;
	font-size: 13px;
	margin-bottom: 8px;
}

.ec-icon-dashboard {
	align-items: center;
	background:
		radial-gradient(circle at 50% 50%, rgba(94, 234, 212, .16), transparent 56%),
		linear-gradient(145deg, rgba(2, 6, 23, .52), rgba(15, 23, 42, .18));
	border: 1px solid rgba(148, 163, 184, .18);
	border-radius: 28px;
	box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 28px 80px rgba(2,6,23,.28);
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	left: 50%;
	padding: 28px;
	position: absolute;
	top: 50%;
	transform: translate(calc(-50% + (var(--ec-float-x, 0) * 10px)), calc(-50% + (var(--ec-float-y, 0) * 10px)));
	width: min(430px, calc(100% - 62px));
	z-index: 2;
}

.ec-icon-dashboard:before,
.ec-icon-dashboard:after {
	border: 1px solid rgba(94, 234, 212, .14);
	border-radius: 999px;
	content: "";
	inset: 44px;
	pointer-events: none;
	position: absolute;
}

.ec-icon-dashboard:after {
	border-color: rgba(129, 140, 248, .16);
	inset: 84px;
}

.ec-feature-orb {
	align-items: center;
	aspect-ratio: 1;
	background:
		linear-gradient(145deg, rgba(15, 23, 42, .86), rgba(30, 41, 59, .62)),
		radial-gradient(circle at 30% 22%, rgba(94,234,212,.28), transparent 45%);
	border: 1px solid rgba(125, 211, 252, .2);
	border-radius: 20px;
	box-shadow: 0 18px 48px rgba(2, 6, 23, .28), inset 0 0 0 1px rgba(255,255,255,.05);
	color: #67e8f9;
	display: inline-flex;
	font-size: 28px;
	justify-content: center;
	position: relative;
	transform: translate(calc(var(--ec-float-x, 0) * var(--ec-depth-x, 5px)), calc(var(--ec-float-y, 0) * var(--ec-depth-y, 5px)));
	transition: border-color .2s ease, box-shadow .2s ease, color .2s ease, z-index .2s ease;
	z-index: 2;
}

.ec-feature-orb .bx {
	animation: ecIconGlyphFloat 4.8s ease-in-out infinite;
	animation-delay: calc(var(--ec-delay, 0) * -0.18s);
}

.ec-feature-orb:before {
	background: radial-gradient(circle, rgba(94, 234, 212, .24), transparent 62%);
	border-radius: inherit;
	content: "";
	inset: -10px;
	opacity: .58;
	position: absolute;
	z-index: -1;
}

.ec-orb-title {
	background: rgba(2, 6, 23, .9);
	border: 1px solid rgba(94, 234, 212, .3);
	border-radius: 999px;
	box-shadow: 0 16px 40px rgba(2, 6, 23, .34);
	color: #f8fafc;
	font-size: 12px;
	font-weight: 900;
	left: 50%;
	letter-spacing: 0;
	line-height: 1.2;
	max-width: 220px;
	opacity: 0;
	padding: 9px 12px;
	pointer-events: none;
	position: absolute;
	text-align: center;
	top: -14px;
	transform: translate(-50%, -86%) scale(.92);
	transition: opacity .18s ease, transform .18s ease;
	white-space: nowrap;
	z-index: 10;
}

.ec-feature-orb:hover {
	border-color: rgba(94, 234, 212, .48);
	box-shadow: 0 24px 58px rgba(20, 184, 166, .18), 0 18px 42px rgba(99, 102, 241, .16);
	color: #fff;
	z-index: 8;
}

.ec-feature-orb:hover .ec-orb-title,
.ec-feature-orb.is-typing .ec-orb-title {
	animation: ecTitleReveal .24s ease both;
	opacity: 1;
	transform: translate(-50%, -104%) scale(1);
}

.ec-orb-primary {
	background:
		linear-gradient(135deg, rgba(20, 184, 166, .84), rgba(99, 102, 241, .82)),
		radial-gradient(circle at 30% 20%, rgba(255,255,255,.32), transparent 45%);
	color: #fff;
	grid-column: span 2;
	grid-row: span 2;
	font-size: 58px;
}

.ec-feature-orb:nth-child(2) { --ec-depth-x: -8px; --ec-depth-y: 5px; --ec-delay: 1; }
.ec-feature-orb:nth-child(3) { --ec-depth-x: 7px; --ec-depth-y: -6px; --ec-delay: 2; }
.ec-feature-orb:nth-child(4) { --ec-depth-x: -5px; --ec-depth-y: -8px; --ec-delay: 3; }
.ec-feature-orb:nth-child(5) { --ec-depth-x: 9px; --ec-depth-y: 7px; --ec-delay: 4; }
.ec-feature-orb:nth-child(6) { --ec-depth-x: -10px; --ec-depth-y: 4px; --ec-delay: 5; }
.ec-feature-orb:nth-child(7) { --ec-depth-x: 6px; --ec-depth-y: 9px; --ec-delay: 6; }
.ec-feature-orb:nth-child(8) { --ec-depth-x: -6px; --ec-depth-y: -5px; --ec-delay: 7; }
.ec-feature-orb:nth-child(9) { --ec-depth-x: 8px; --ec-depth-y: -7px; --ec-delay: 8; }
.ec-feature-orb:nth-child(10) { --ec-depth-x: -7px; --ec-depth-y: 8px; --ec-delay: 9; }
.ec-feature-orb:nth-child(11) { --ec-depth-x: 9px; --ec-depth-y: -4px; --ec-delay: 10; }
.ec-feature-orb:nth-child(12) { --ec-depth-x: -8px; --ec-depth-y: -7px; --ec-delay: 11; }

.ec-band,
.ec-pricing,
.ec-download,
.ec-page-shell {
	margin: 0 auto;
	max-width: 1180px;
	padding: 72px clamp(18px, 4vw, 40px);
}

.ec-section-heading {
	max-width: 680px;
}

.ec-section-heading h2,
.ec-pricing h2,
.ec-download h2,
.ec-page-card h1 {
	font-size: clamp(34px, 5vw, 58px);
	line-height: 1.04;
	margin: 0 0 18px;
}

.ec-feature-band {
	position: relative;
	scroll-margin-top: 112px;
}

.ec-feature-band:before {
	background:
		linear-gradient(90deg, rgba(94,234,212,.08) 1px, transparent 1px),
		linear-gradient(rgba(129,140,248,.08) 1px, transparent 1px);
	background-size: 44px 44px;
	content: "";
	inset: 28px 0 auto;
	height: calc(100% - 56px);
	mask-image: linear-gradient(to bottom, transparent, black 15%, black 84%, transparent);
	pointer-events: none;
	position: absolute;
	z-index: -1;
}

.ec-feature-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(4, 1fr);
	margin-top: 34px;
}

.ec-feature-grid article,
.ec-seo-grid article,
.ec-faq-list details,
.ec-price-cards div,
.ec-download,
.ec-page-card,
.rounded-lg.bg-white,
.rounded.bg-white {
	background: var(--ec-panel);
	border: 1px solid var(--ec-line);
	border-radius: 22px;
	box-shadow: 0 24px 60px rgba(2, 6, 23, 0.18);
}

.ec-feature-grid article {
	background:
		linear-gradient(145deg, rgba(15, 23, 42, 0.84), rgba(2, 6, 23, 0.72)),
		radial-gradient(circle at var(--ec-card-x, 50%) var(--ec-card-y, 0%), rgba(45, 212, 191, 0.24), transparent 46%);
	min-height: 245px;
	overflow: hidden;
	padding: 24px;
	position: relative;
	transform: translateY(0);
	transition: border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}

.ec-seo-grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 34px;
}

.ec-seo-grid article {
	background:
		linear-gradient(145deg, rgba(15, 23, 42, .82), rgba(2, 6, 23, .72)),
		radial-gradient(circle at 18% 0%, rgba(94,234,212,.18), transparent 46%);
	padding: 26px;
}

.ec-seo-grid h3,
.ec-faq-list summary {
	color: #f8fafc;
	font-size: 20px;
	line-height: 1.25;
	margin: 0 0 12px;
}

.ec-seo-grid p,
.ec-faq-list p {
	color: #cbd5e1;
	line-height: 1.7;
	margin: 0;
}

.ec-faq-list {
	display: grid;
	gap: 14px;
	margin-top: 30px;
}

.ec-faq-list details {
	background:
		linear-gradient(145deg, rgba(15, 23, 42, .78), rgba(2, 6, 23, .66)),
		radial-gradient(circle at 100% 0%, rgba(99,102,241,.16), transparent 42%);
	cursor: pointer;
	padding: 22px 24px;
	transition: border-color .32s ease, box-shadow .32s ease, background .32s ease, transform .32s ease;
}

.ec-faq-list details:hover {
	border-color: rgba(94, 234, 212, .3);
	transform: translateY(-1px);
}

.ec-faq-list summary {
	cursor: pointer;
	font-weight: 900;
	list-style: none;
	margin: 0;
}

.ec-faq-list summary::-webkit-details-marker {
	display: none;
}

.ec-faq-list summary:after {
	color: #67e8f9;
	content: "+";
	float: right;
	font-size: 22px;
	line-height: 1;
}

.ec-faq-list details.is-open summary:after,
.ec-faq-list details[open] summary:after {
	content: "-";
}

.ec-faq-list p {
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transform: translateY(-4px);
	transition: max-height .58s cubic-bezier(.2,.75,.2,1), opacity .42s ease, transform .5s ease, margin-top .5s ease;
}

.ec-faq-list details.is-open {
	border-color: rgba(94, 234, 212, .32);
	box-shadow: 0 26px 70px rgba(20,184,166,.11);
}

.ec-faq-list details.is-open p,
.ec-faq-list details[open] p {
	max-height: 220px;
	margin-top: 12px;
	opacity: 1;
	transform: translateY(0);
}

.ec-feature-grid article:before {
	background: linear-gradient(135deg, rgba(45,212,191,.8), rgba(99,102,241,.7), rgba(34,211,238,.65));
	content: "";
	height: 3px;
	left: 18px;
	position: absolute;
	right: 18px;
	top: 0;
	transform: scaleX(.34);
	transform-origin: left;
	transition: transform .22s ease;
}

.ec-feature-grid article:after {
	background: radial-gradient(circle, rgba(255,255,255,.16), transparent 62%);
	content: "";
	height: 110px;
	position: absolute;
	right: -44px;
	top: -48px;
	width: 110px;
}

.ec-feature-grid article:hover {
	border-color: rgba(94, 234, 212, .42);
	box-shadow: 0 30px 80px rgba(20,184,166,.16), 0 18px 50px rgba(99,102,241,.12);
	transform: translateY(-7px);
}

.ec-feature-grid article:hover:before {
	transform: scaleX(1);
}

.ec-feature-grid span {
	align-items: center;
	background: rgba(34, 211, 238, .1);
	border: 1px solid rgba(103, 232, 249, .22);
	border-radius: 999px;
	color: #67e8f9;
	display: inline-flex;
	font-size: 22px;
	font-weight: 900;
	height: 34px;
	justify-content: center;
	width: 42px;
}

.ec-feature-grid h3 {
	font-size: 19px;
	line-height: 1.2;
	margin: 24px 0 10px;
	min-height: 46px;
}

.ec-feature-grid p,
.ec-pricing p,
.ec-download p,
.ec-footer,
.ec-entry-content {
	color: #cbd5e1;
	line-height: 1.7;
}

.ec-pricing {
	align-items: end;
	display: grid;
	gap: 24px;
	grid-template-columns: 0.9fr 1.1fr;
}

.ec-price-cards {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(2, 1fr);
}

.ec-price-cards div {
	padding: 24px;
}

.ec-price-cards span {
	align-items: center;
	display: inline-flex;
	gap: 7px;
}

.ec-price-cards strong {
	display: block;
	font-size: 34px;
	margin-bottom: 18px;
}

.ec-price-cards a {
	align-items: center;
	color: #5eead4;
	display: inline-flex;
	font-weight: 900;
	gap: 7px;
}

.ec-download {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 72px;
}

.ec-page-card {
	padding: clamp(22px, 5vw, 44px);
}

.ec-footer {
	align-items: center;
	border-top: 1px solid var(--ec-line);
	display: flex;
	justify-content: space-between;
	padding: 28px clamp(18px, 4vw, 56px);
}

.ec-footer strong,
.ec-footer span {
	display: block;
}

.ec-footer strong,
.ec-footer a {
	align-items: center;
	display: inline-flex;
	gap: 8px;
}

.ec-js .ec-reveal {
	opacity: 0;
	pointer-events: none;
	transform: translate3d(0, 34px, 0) scale(.98);
	transition: opacity .52s ease, transform .58s cubic-bezier(.2,.75,.2,1), filter .52s ease;
	transition-delay: calc(var(--ec-reveal-delay, 0) * 70ms);
	filter: blur(10px);
	will-change: opacity, transform, filter;
}

.ec-js .ec-reveal[data-ec-reveal="left"] {
	transform: translate3d(-42px, 18px, 0) scale(.98);
}

.ec-js .ec-reveal[data-ec-reveal="right"] {
	transform: translate3d(42px, 18px, 0) scale(.98);
}

.ec-js .ec-reveal[data-ec-reveal="zoom"] {
	transform: translate3d(0, 22px, 0) scale(.92);
}

.ec-js .ec-reveal.is-visible {
	opacity: 1;
	pointer-events: auto;
	transform: translate3d(0, 0, 0) scale(1);
	filter: blur(0);
}

.ec-js .ec-feature-grid article.ec-reveal.is-visible:hover {
	transform: translateY(-7px);
}

@keyframes ecColorShift {
	0% { background-position: 0% 45%; }
	100% { background-position: 100% 55%; }
}

@keyframes ecCaret {
	0%, 45% { opacity: 1; }
	46%, 100% { opacity: 0; }
}

@keyframes ecIconGlyphFloat {
	0%, 100% { transform: translateY(0) scale(1); }
	50% { transform: translateY(-5px) scale(1.06); }
}

@keyframes ecLogoPulse {
	0%, 100% { transform: rotate(45deg) scale(1); }
	50% { transform: rotate(45deg) scale(1.12); }
}

@keyframes ecNodeOne {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(2px, 2px); }
}

@keyframes ecNodeTwo {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(-2px, 2px); }
}

@keyframes ecNodeThree {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(2px, -2px); }
}

@keyframes ecNodeFour {
	0%, 100% { transform: translate(0, 0); }
	50% { transform: translate(-2px, -2px); }
}

@keyframes ecTitleReveal {
	0% {
		filter: blur(6px);
		letter-spacing: .02em;
	}
	100% {
		filter: blur(0);
		letter-spacing: 0;
	}
}

/* Portal utility subset used by the plugin shortcodes. */
.min-h-screen { min-height: 100vh; }
.mx-auto { margin-left: auto; margin-right: auto; }
.mt-1 { margin-top: .25rem; }
.mt-2 { margin-top: .5rem; }
.mt-4 { margin-top: 1rem; }
.mt-5 { margin-top: 1.25rem; }
.mb-1 { margin-bottom: .25rem; }
.mb-2 { margin-bottom: .5rem; }
.mb-3 { margin-bottom: .75rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-5 { margin-bottom: 1.25rem; }
.mb-6 { margin-bottom: 1.5rem; }
.ml-2 { margin-left: .5rem; }
.block { display: block; }
.inline { display: inline; }
.inline-flex { display: inline-flex; }
.flex { display: flex; }
.grid { display: grid; }
.hidden { display: none !important; }
.flex-1 { flex: 1 1 0%; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.self-end { align-self: flex-end; }
.gap-2 { gap: .5rem; }
.gap-3 { gap: .75rem; }
.gap-4 { gap: 1rem; }
.gap-5 { gap: 1.25rem; }
.flex-wrap { flex-wrap: wrap; }
.w-full { width: 100%; }
.h-full { height: 100%; }
.min-w-full { min-width: 100%; }
.max-w-5xl { max-width: 64rem; }
.max-w-7xl { max-width: 80rem; }
.max-w-md { max-width: 28rem; }
.max-w-full { max-width: 100%; }
.max-h-full { max-height: 100%; }
.max-h-56 { max-height: 14rem; }
.h-10 { height: 2.5rem; }
.w-20 { width: 5rem; }
.overflow-x-auto { overflow-x: auto; }
.overflow-auto { overflow: auto; }
.overflow-hidden { overflow: hidden; }
.aspect-\[7\/4\] { aspect-ratio: 7 / 4; }
.rounded { border-radius: 12px; }
.rounded-lg { border-radius: 18px; }
.rounded border,
.border { border: 1px solid var(--ec-line); }
.border-2 { border-width: 2px; border-style: solid; }
.border-transparent { border-color: transparent; }
.border-teal-200 { border-color: rgba(94, 234, 212, .28); }
.border-teal-300 { border-color: rgba(94, 234, 212, .38); }
.border-teal-600 { border-color: rgba(13, 148, 136, .72); }
.hover\:border-teal-300:hover { border-color: rgba(94, 234, 212, .48); }
.hover\:border-teal-600:hover { border-color: rgba(13, 148, 136, .72); }
.border-t { border-top: 1px solid var(--ec-line); }
.p-2 { padding: .5rem; }
.p-3 { padding: .75rem; }
.p-4 { padding: 1rem; }
.p-5 { padding: 1.25rem; }
.p-6 { padding: 1.5rem; }
.px-2 { padding-left: .5rem; padding-right: .5rem; }
.px-3 { padding-left: .75rem; padding-right: .75rem; }
.px-4 { padding-left: 1rem; padding-right: 1rem; }
.px-5 { padding-left: 1.25rem; padding-right: 1.25rem; }
.py-1 { padding-bottom: .25rem; padding-top: .25rem; }
.py-2 { padding-bottom: .5rem; padding-top: .5rem; }
.py-3 { padding-bottom: .75rem; padding-top: .75rem; }
.py-4 { padding-bottom: 1rem; padding-top: 1rem; }
.py-10 { padding-bottom: 2.5rem; padding-top: 2.5rem; }
.text-left { text-align: left; }
.text-center { text-align: center; }
.tracking-wide { letter-spacing: .025em; }
.text-xs { font-size: .75rem; }
.text-sm { font-size: .875rem; }
.text-base { font-size: 1rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.text-2xl { font-size: 1.5rem; }
.text-3xl { font-size: 1.875rem; }
.font-medium { font-weight: 600; }
.font-semibold { font-weight: 700; }
.font-bold { font-weight: 800; }
.font-mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.uppercase { text-transform: uppercase; }
.leading-none { line-height: 1; }
.whitespace-pre-line { white-space: pre-line; }
.text-white { color: #fff; }
.text-slate-400 { color: #94a3b8; }
.text-slate-500 { color: #94a3b8; }
.text-slate-600 { color: #cbd5e1; }
.text-slate-700,
.text-slate-800,
.text-slate-900 { color: #f8fafc; }
.text-teal-700 { color: #5eead4; }
.text-blue-800 { color: #bfdbfe; }
.bg-white { background: var(--ec-panel); }
.bg-slate-50,
.bg-slate-100 { background: rgba(15, 23, 42, .72); }
.bg-slate-800,
.bg-slate-900 { background: #0f172a; }
.bg-teal-50 { background: rgba(20, 184, 166, .1); }
.hover\:bg-teal-50:hover { background: rgba(20, 184, 166, .1); }
.hover\:bg-teal-100:hover { background: rgba(20, 184, 166, .16); }
.bg-blue-50 { background: rgba(37, 99, 235, .14); }
.bg-teal-700 { background: var(--ec-teal); }
.bg-teal-800 { background: #0f766e; }
.bg-slate-700 { background: #334155; }
.bg-green-700 { background: var(--ec-green); }
.bg-red-700 { background: var(--ec-red); }
.bg-amber-700 { background: #b45309; }
.bg-indigo-700 { background: #4338ca; }
.shadow { box-shadow: 0 18px 45px rgba(2,6,23,.24); }
.transition { transition: all .2s ease; }
.cursor-pointer { cursor: pointer; }
.object-contain { object-fit: contain; }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.sr-only {
	clip: rect(0,0,0,0);
	border: 0;
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

.ec-entry-content input,
.ec-entry-content select,
.ec-entry-content textarea,
.ec-entry-content .rounded input,
.ec-entry-content .rounded select,
.ec-entry-content .rounded textarea,
.ec-page-card input,
.ec-page-card select,
.ec-page-card textarea {
	background: rgba(2, 6, 23, .45);
	border: 1px solid var(--ec-line);
	border-radius: 12px;
	color: #fff;
	padding: .75rem .9rem;
}

.ec-entry-content button,
.ec-page-card button,
.ec-entry-content .rounded a {
	border: 0;
	cursor: pointer;
}

.ec-entry-content table,
.ec-page-card table {
	border-collapse: collapse;
	width: 100%;
}

.ec-entry-content th,
.ec-entry-content td,
.ec-page-card th,
.ec-page-card td {
	border-color: var(--ec-line);
}

.ecs-plan-toggle {
	background: rgba(2, 6, 23, .42);
	border: 1px solid var(--ec-line);
	border-radius: 18px;
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	padding: 8px;
}

.ecs-plan-option {
	cursor: pointer;
	display: block;
	min-width: 0;
	position: relative;
}

.ecs-plan-option input {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.ecs-plan-option span {
	align-items: center;
	background: rgba(15, 23, 42, .62);
	border: 1px solid rgba(148, 163, 184, .18);
	border-radius: 14px;
	display: flex;
	gap: 12px;
	justify-content: space-between;
	min-height: 62px;
	padding: 13px 15px;
	transition: border-color .2s ease, box-shadow .2s ease, background .2s ease, transform .2s ease;
}

.ecs-plan-option span:before {
	align-items: center;
	border: 1px solid rgba(103, 232, 249, .42);
	border-radius: 999px;
	color: #67e8f9;
	content: "";
	display: inline-flex;
	height: 16px;
	justify-content: center;
	width: 16px;
}

.ecs-plan-option strong {
	color: #f8fafc;
	font-size: 16px;
	margin-right: auto;
}

.ecs-plan-option small {
	color: #cbd5e1;
	font-size: 13px;
	font-weight: 800;
	white-space: nowrap;
}

.ecs-plan-option input:checked + span {
	background:
		radial-gradient(circle at 12% 10%, rgba(94,234,212,.2), transparent 42%),
		linear-gradient(135deg, rgba(20,184,166,.2), rgba(99,102,241,.18));
	border-color: rgba(94, 234, 212, .58);
	box-shadow: 0 18px 44px rgba(20,184,166,.12), inset 0 0 0 1px rgba(255,255,255,.08);
	transform: translateY(-1px);
}

.ecs-plan-option input:checked + span:before {
	background: linear-gradient(135deg, var(--ec-teal), var(--ec-indigo));
	box-shadow: 0 0 18px rgba(94,234,212,.38);
	content: "";
}

.ecs-payment-tab {
	align-items: center;
	background: transparent;
	border: 0;
	color: #cbd5e1;
	display: inline-flex;
	font-weight: 800;
	justify-content: center;
	min-height: 44px;
	text-transform: capitalize;
	transition: background .2s ease, color .2s ease;
}

.ecs-payment-tab.bg-teal-700 {
	background: linear-gradient(135deg, var(--ec-teal), var(--ec-indigo));
	color: #fff;
}

.ecs-payment-panel {
	align-items: stretch;
	background:
		linear-gradient(145deg, rgba(15, 23, 42, .7), rgba(2, 6, 23, .52)) !important;
}

.ecs-payment-card {
	display: grid;
	gap: 10px;
	min-width: 0;
}

.ecs-payment-logo-box {
	background: rgba(2, 6, 23, .48) !important;
	border-color: rgba(148, 163, 184, .18) !important;
	filter: grayscale(1) saturate(.25) opacity(.64);
	min-height: 96px;
	overflow: hidden;
	padding: 0;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease, background .2s ease, filter .2s ease;
}

.ecs-payment-logo-box img {
	display: block;
	height: 100%;
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
	width: 100%;
}

.ecs-payment-logo-box:hover {
	background: rgba(20, 184, 166, .1) !important;
	border-color: rgba(94, 234, 212, .74) !important;
	filter: grayscale(.35) saturate(.85) opacity(.86);
	box-shadow: 0 18px 42px rgba(20, 184, 166, .12);
	transform: translateY(-1px);
}

.ecs-payment-logo-box.\!border-teal-700,
.ecs-payment-card input[type="radio"]:checked + .ecs-payment-logo-box {
	background: rgba(20, 184, 166, .12) !important;
	border-color: #5eead4 !important;
	filter: none;
	box-shadow:
		inset 0 0 0 3px #020617,
		0 0 0 2px rgba(94, 234, 212, .9),
		0 0 0 6px rgba(94, 234, 212, .14),
		0 20px 48px rgba(20, 184, 166, .18);
}

.ecs-payment-card > span {
	color: #f8fafc !important;
	font-size: 13px;
	line-height: 1.25;
	overflow-wrap: anywhere;
}

.ecs-payment-details img {
	max-height: 42px;
	max-width: 96px;
	object-fit: contain;
}

.ecs-proof-upload {
	align-items: center !important;
	background:
		linear-gradient(145deg, rgba(15, 23, 42, .72), rgba(2, 6, 23, .54)),
		radial-gradient(circle at 50% 0%, rgba(20,184,166,.2), transparent 48%) !important;
	border-color: rgba(94, 234, 212, .32) !important;
	border-radius: 18px !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	min-height: 230px;
	position: relative;
	text-align: center;
}

.ecs-proof-upload:hover {
	border-color: rgba(94, 234, 212, .7) !important;
	box-shadow: 0 24px 58px rgba(20,184,166,.12);
}

.ecs-proof-icon {
	align-items: center;
	background: rgba(34, 211, 238, .12);
	border: 1px solid rgba(103, 232, 249, .28);
	border-radius: 18px;
	color: #67e8f9;
	display: inline-flex;
	font-size: 30px;
	height: 58px;
	justify-content: center;
	margin-bottom: 14px;
	width: 58px;
}

.ecs-proof-upload [data-ecs-proof-name] {
	color: #94a3b8;
	font-size: 13px;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.ecs-proof-upload [data-ecs-proof-preview] {
	background: rgba(2, 6, 23, .58);
	border-color: rgba(148, 163, 184, .22);
}

.ecs-checkout-submit {
	align-items: flex-start;
	display: inline-flex;
	flex-direction: column;
	gap: 12px;
	margin-top: 24px;
}

.ecs-submit-price {
	background:
		linear-gradient(135deg, rgba(20,184,166,.18), rgba(99,102,241,.16)),
		rgba(2, 6, 23, .58);
	border: 1px solid rgba(94, 234, 212, .32);
	border-radius: 16px;
	color: #cbd5e1;
	font-size: 14px;
	font-weight: 800;
	padding: 13px 16px;
}

.ecs-submit-price strong {
	color: #f8fafc;
	font-size: 20px;
	margin-left: 8px;
}

.ecs-checkout-submit .mt-5 {
	margin-top: 0;
}

@media (min-width: 768px) {
	.md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
	.md\:col-span-2 { grid-column: span 2 / span 2; }
	.md\:grid-cols-\[1fr_auto\] { grid-template-columns: 1fr auto; }
}

@media (max-width: 860px) {
	html {
		scroll-padding-top: 168px;
	}

	.ec-site-header {
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
		gap: 14px;
		padding: 16px 18px;
	}

	.ec-brand {
		flex: 1 1 auto;
		order: 1;
	}

	.ec-brand > span:last-child {
		display: none;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
	}

	.ec-header-actions {
		flex: 0 0 auto;
		margin-left: auto;
		order: 2;
	}

	.ec-nav {
		flex: 1 0 100%;
		flex-wrap: wrap;
		order: 3;
	}

	.ec-feature-band {
		scroll-margin-top: 168px;
	}

	.ec-header-actions .ec-button {
		padding: 11px 14px;
	}

	.ec-hero,
	.ec-pricing {
		grid-template-columns: 1fr;
	}

	.ec-hero {
		min-height: auto;
	}

	.ec-hero-system {
		min-height: 430px;
	}

	.ec-hero:after {
		display: none;
	}

	.ec-typewriter {
		border-radius: 18px;
		align-items: flex-start;
		flex-direction: column;
	}

	.ec-typewriter strong {
		white-space: normal;
	}

	.ec-feature-grid,
	.ec-seo-grid,
	.ec-price-cards,
	.ecs-plan-toggle {
		grid-template-columns: 1fr;
	}

	.ec-download,
	.ec-footer {
		align-items: flex-start;
		flex-direction: column;
		gap: 18px;
	}
}

@media (min-width: 861px) and (max-width: 1180px) {
	.ec-feature-grid,
	.ec-seo-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*:before,
	*:after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		scroll-behavior: auto !important;
		transition-duration: .01ms !important;
	}
}
