:root {
	--bg: #050a16;
	--bg-2: #081120;
	--panel: rgba(13, 22, 38, .78);
	--panel-2: rgba(255, 255, 255, .055);
	--text: #f8fafc;
	--muted: #b8c0d0;
	--line: rgba(255, 255, 255, .13);
	--red: #ff454e;
	--red-2: #ff6b55;
	--blue: #35a7ff;
	--teal: #45e0c4;
	--shadow: 0 28px 90px rgba(0, 0, 0, .42);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	color: var(--text);
	background:
		radial-gradient(ellipse at 12% 8%, rgba(255, 69, 78, .24), transparent 34%),
		radial-gradient(ellipse at 62% 0%, rgba(69, 224, 196, .16), transparent 32%),
		radial-gradient(ellipse at 92% 28%, rgba(53, 167, 255, .16), transparent 34%),
		linear-gradient(180deg, #040816 0%, #09111f 46%, #06101d 72%, #050a16 100%);
}

body::before {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -2;
	background-image:
		linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, .035) 1px, transparent 1px),
		linear-gradient(120deg, transparent 0 44%, rgba(69, 224, 196, .08) 45%, transparent 47% 100%);
	background-size: 72px 72px, 72px 72px, 240px 240px;
	mask-image: linear-gradient(180deg, black, rgba(0,0,0,.68) 70%, transparent 100%);
}

body::after {
	content: "";
	position: fixed;
	inset: auto 0 0;
	z-index: -1;
	height: 42vh;
	background:
		radial-gradient(ellipse at 6% 100%, rgba(255, 69, 78, .2), transparent 45%),
		repeating-radial-gradient(ellipse at 0% 100%, rgba(255, 69, 78, .18) 0 1px, transparent 1px 11px);
	opacity: .58;
	pointer-events: none;
}

a { color: inherit; text-decoration: none; }
svg {
	width: 20px;
	height: 20px;
	fill: none;
	stroke: currentColor;
	stroke-width: 1.85;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.section {
	position: relative;
	overflow: hidden;
	padding: 0;
}
.section::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(circle at 14% 18%, rgba(255, 69, 78, .1), transparent 30%),
		radial-gradient(circle at 88% 72%, rgba(53, 167, 255, .08), transparent 32%),
		linear-gradient(115deg, transparent 0 30%, rgba(255,255,255,.035) 30.2%, transparent 32% 100%);
}
.section-inner {
	position: relative;
	z-index: 1;
	width: min(100% - 40px, 1400px);
	margin: 0 auto;
}

.topbar {
	position: fixed;
	inset: 16px 20px auto;
	z-index: 50;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	width: min(calc(100% - 40px), 1400px);
	margin: 0 auto;
	padding: 10px 12px 10px 16px;
	border: 1px solid rgba(255, 69, 78, .3);
	border-radius: 22px;
	background: rgba(5, 10, 22, .72);
	backdrop-filter: blur(22px);
	box-shadow: 0 18px 60px rgba(0, 0, 0, .35), inset 0 0 22px rgba(255, 69, 78, .05);
}
.brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 800;
}
.brand-logo-frame {
	position: relative;
	display: inline-flex;
	align-items: center;
	width: 172px;
	height: 54px;
	padding: 4px 10px;
	border: 1px solid rgba(69, 224, 196, .2);
	border-radius: 18px;
	background:
		radial-gradient(circle at 50% 2%, rgba(69, 224, 196, .2), transparent 58%),
		rgba(2, 10, 18, .46);
	box-shadow: 0 0 30px rgba(69, 224, 196, .08), inset 0 0 20px rgba(255, 69, 78, .04);
	overflow: hidden;
}
.brand-logo-frame::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(105deg, transparent 0 34%, rgba(255,255,255,.14) 48%, transparent 62% 100%);
	transform: translateX(-120%);
	animation: brandShine 7s ease-in-out infinite;
}
.brand-logo-frame img {
	position: relative;
	z-index: 1;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	filter: saturate(1.12) contrast(1.06) drop-shadow(0 10px 24px rgba(69, 224, 196, .14));
}
.brand-mark,
.icon-bubble {
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border: 1px solid rgba(255, 100, 108, .45);
	border-radius: 15px;
	color: #fff;
	background: radial-gradient(circle at 35% 22%, #ff7c71, var(--red) 52%, #941a28 100%);
	box-shadow: 0 0 28px rgba(255, 69, 78, .44), inset 0 -10px 18px rgba(74, 10, 18, .28);
}
.brand-mark svg { animation: mascotFloat 4s ease-in-out infinite; }
.nav-links {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px;
	border: 1px solid rgba(255, 255, 255, .08);
	border-radius: 999px;
	background: rgba(255, 255, 255, .045);
}
.nav-links a {
	padding: 10px 14px;
	border-radius: 999px;
	color: rgba(255, 255, 255, .78);
	font-size: 14px;
	font-weight: 700;
	transition: color .25s ease, background .25s ease, transform .25s ease;
}
.nav-links a:hover {
	color: white;
	background: rgba(255, 69, 78, .16);
	transform: translateY(-1px);
}

.btn {
	position: relative;
	isolation: isolate;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	min-height: 50px;
	padding: 0 22px;
	border: 0;
	border-radius: 16px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	white-space: nowrap;
	overflow: hidden;
	transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}
.btn::after {
	content: "";
	position: absolute;
	inset: -40% auto -40% -90%;
	z-index: -1;
	width: 60%;
	transform: rotate(18deg);
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.48), transparent);
	transition: left .65s ease;
}
.btn svg { transition: transform .28s ease; }
.btn:hover {
	transform: translateY(-3px);
}
.btn:hover svg { transform: translateX(2px) scale(1.06); }
.btn:hover::after { left: 132%; }
.btn-primary {
	color: white;
	background: linear-gradient(135deg, #ff3342 0%, #ff685d 58%, #ff8b5c 100%);
	box-shadow: 0 0 0 1px rgba(255,255,255,.14) inset, 0 20px 48px rgba(255, 69, 78, .34), 0 0 42px rgba(255, 69, 78, .18);
}
.btn-soft,
.btn-ghost {
	color: #fff;
	border: 1px solid rgba(255, 69, 78, .34);
	background: rgba(255, 255, 255, .06);
	box-shadow: inset 0 0 22px rgba(255, 69, 78, .05);
}

.hero {
	min-height: 100vh;
	padding-top: 0;
	background:
		radial-gradient(ellipse at 46% 8%, rgba(69, 224, 196, .2), transparent 32%),
		radial-gradient(ellipse at 18% 34%, rgba(255, 69, 78, .2), transparent 31%),
		radial-gradient(ellipse at 76% 58%, rgba(53, 167, 255, .13), transparent 34%),
		linear-gradient(180deg, #050a16 0%, #081020 64%, #081020 100%);
}
.hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(126deg, transparent 0 18%, rgba(255,255,255,.035) 18.2%, transparent 19.1% 100%),
		linear-gradient(52deg, transparent 0 38%, rgba(69,224,196,.045) 38.2%, transparent 39.3% 100%),
		radial-gradient(circle at 16% 25%, rgba(255,255,255,.72) 0 1px, transparent 2px),
		radial-gradient(circle at 88% 42%, rgba(69,224,196,.65) 0 1px, transparent 2px),
		linear-gradient(180deg, transparent 70%, #081020 100%);
	opacity: .24;
	pointer-events: none;
}
.bg-orbit {
	position: absolute;
	border-radius: 999px;
	filter: blur(18px);
	opacity: .74;
	animation: orbit 13s ease-in-out infinite;
}
.bg-orbit-one {
	top: 18%;
	right: 11%;
	width: 220px;
	height: 220px;
	background: rgba(255, 69, 78, .22);
}
.bg-orbit-two {
	left: 7%;
	bottom: 15%;
	width: 190px;
	height: 190px;
	background: rgba(53, 167, 255, .12);
	animation-delay: -5s;
}
.hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr);
	align-items: center;
	gap: clamp(40px, 6vw, 96px);
	min-height: 100vh;
	padding: 48px 0 84px;
}
.hot-badge,
.eyebrow,
.section-heading span,
.section-kicker {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: #ff747b;
	font-size: 13px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0;
}
.hot-badge {
	padding: 14px 18px;
	border: 1px solid rgba(255, 69, 78, .5);
	border-radius: 16px;
	background: rgba(255, 69, 78, .06);
	box-shadow: inset 0 0 22px rgba(255, 69, 78, .05), 0 0 24px rgba(255, 69, 78, .12);
}
.hot-badge svg { fill: rgba(255, 69, 78, .22); }
.openclaw-lockup {
	position: relative;
	display: inline-grid;
	justify-items: center;
	width: min(100%, 520px);
	margin: 36px 0 34px;
	padding: 4px 0 10px;
	border-radius: 0;
	background: none;
	box-shadow: none;
	overflow: visible;
	animation: logoFloat 7s ease-in-out infinite;
}
.openclaw-lockup::before {
	content: "";
	position: absolute;
	inset: 4% 4% 10%;
	z-index: -1;
	border-radius: inherit;
	background:
		radial-gradient(circle at 50% 20%, rgba(69, 224, 196, .24), transparent 46%),
		radial-gradient(circle at 26% 58%, rgba(255, 69, 78, .18), transparent 38%);
	filter: blur(22px);
	opacity: .9;
	pointer-events: none;
}
.openclaw-lockup::after {
	content: "";
	position: absolute;
	top: 18%;
	left: -34%;
	width: 34%;
	height: 72%;
	border-radius: 999px;
	background: linear-gradient(105deg, transparent 0 18%, rgba(255,255,255,.2) 48%, transparent 78% 100%);
	filter: blur(2px);
	opacity: .58;
	transform: skewX(-18deg) translateX(0);
	animation: logoShine 8.5s ease-in-out infinite;
	pointer-events: none;
}
.openclaw-lockup-mascot {
	display: block;
	width: clamp(96px, 12vw, 148px);
	height: auto;
	margin-bottom: -8px;
	object-fit: contain;
	filter: saturate(1.08) contrast(1.05) drop-shadow(0 20px 34px rgba(255, 69, 78, .34)) drop-shadow(0 0 28px rgba(69, 224, 196, .16));
}
.openclaw-wordmark {
	display: block;
	font-size: clamp(54px, 8vw, 92px);
	font-weight: 900;
	line-height: .86;
	letter-spacing: 0;
	background: linear-gradient(90deg, #ff4550 0%, #ff7a61 45%, #45e0c4 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: #ff6b55;
	text-shadow: 0 18px 44px rgba(0, 0, 0, .28);
}
.hero h1 {
	position: relative;
	display: inline-block;
	max-width: 940px;
	margin: 0;
	font-size: clamp(48px, 7vw, 96px);
	line-height: .98;
	letter-spacing: 0;
	text-transform: uppercase;
}
.typewriter::after,
.typing-live::after {
	content: "";
	display: inline-block;
	width: .08em;
	height: .82em;
	margin-left: .08em;
	vertical-align: -.08em;
	border-radius: 99px;
	background: linear-gradient(180deg, #fff, var(--teal));
	box-shadow: 0 0 14px rgba(69, 224, 196, .64);
	animation: cursorBlink .9s steps(1) infinite;
}
.hero-subtitle {
	margin: 18px 0 0;
	font-size: clamp(30px, 4vw, 58px);
	font-weight: 800;
	line-height: 1.05;
	color: transparent;
	background: linear-gradient(90deg, #ff404d 0%, #ff6b55 56%, #45e0c4 120%);
	-webkit-background-clip: text;
	background-clip: text;
}
.hero-lead {
	position: relative;
	max-width: 690px;
	margin: 30px 0 0;
	padding-bottom: 28px;
	color: rgba(255, 255, 255, .82);
	font-size: clamp(18px, 1.6vw, 24px);
	line-height: 1.55;
}
.hero-lead::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 118px;
	height: 4px;
	border-radius: 99px;
	background: linear-gradient(90deg, var(--red), var(--red-2));
	box-shadow: 0 0 20px rgba(255, 69, 78, .54);
}
.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 34px;
}
.trust-row {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	max-width: 650px;
	margin-top: 36px;
}
.trust-row div,
.outcome-card {
	padding: 18px;
	border: 1px solid var(--line);
	border-radius: 22px;
	background: rgba(255, 255, 255, .055);
	box-shadow: 0 18px 52px rgba(0, 0, 0, .22);
	backdrop-filter: blur(16px);
}
.trust-row strong,
.outcome-card strong {
	display: block;
	color: white;
	font-size: 34px;
	font-weight: 800;
}
.trust-row span,
.outcome-card span {
	color: var(--muted);
	font-size: 14px;
	font-weight: 600;
}

.hero-panel { position: relative; min-height: 590px; }
.mascot-orb {
	position: absolute;
	top: 18px;
	right: 82px;
	z-index: 3;
	display: grid;
	place-items: center;
	width: clamp(98px, 10vw, 126px);
	aspect-ratio: 1;
	border: 1px solid rgba(255, 69, 78, .32);
	border-radius: 50%;
	background:
		radial-gradient(circle at 48% 35%, rgba(255, 255, 255, .12), transparent 34%),
		radial-gradient(circle at 50% 50%, rgba(255, 69, 78, .18), transparent 58%),
		rgba(2, 8, 16, .42);
	box-shadow: 0 0 46px rgba(255, 69, 78, .24), 0 0 62px rgba(69, 224, 196, .09), inset 0 0 26px rgba(255, 255, 255, .05);
	animation: mascotFloat 4.8s ease-in-out infinite;
	pointer-events: none;
}
.mascot-orb::before,
.mascot-orb::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
}
.mascot-orb::before {
	inset: -14px;
	border: 1px solid rgba(255, 69, 78, .16);
	border-left-color: rgba(69, 224, 196, .24);
	animation: spinAura 15s linear infinite;
}
.mascot-orb::after {
	inset: 12%;
	background: radial-gradient(circle at 50% 88%, rgba(69, 224, 196, .22), transparent 54%);
	filter: blur(14px);
}
.mascot-orb img {
	position: relative;
	z-index: 1;
	display: block;
	width: 82%;
	height: auto;
	filter: saturate(1.08) contrast(1.05) drop-shadow(0 22px 34px rgba(255, 69, 78, .28));
}
.phone-card {
	position: relative;
	max-width: 560px;
	margin: 214px 0 0 auto;
	padding: 18px;
	border: 1px solid rgba(255, 255, 255, .14);
	border-radius: 34px;
	background: linear-gradient(180deg, rgba(15, 25, 42, .84), rgba(7, 13, 27, .72));
	box-shadow: var(--shadow), inset 0 0 40px rgba(255, 69, 78, .05);
	backdrop-filter: blur(24px);
	transform: perspective(1100px) rotateY(-8deg) rotateX(5deg);
}
.phone-card::before {
	content: "";
	position: absolute;
	inset: 44px 34px;
	border: 1px solid rgba(69, 224, 196, .09);
	border-radius: 36px;
	background:
		linear-gradient(90deg, transparent 0 49%, rgba(69,224,196,.08) 50%, transparent 51% 100%),
		linear-gradient(180deg, transparent 0 49%, rgba(255,69,78,.08) 50%, transparent 51% 100%);
	opacity: .7;
	pointer-events: none;
}
.phone-head {
	display: flex;
	align-items: center;
	gap: 7px;
	padding: 12px;
	color: rgba(255, 255, 255, .76);
}
.phone-head span {
	width: 11px;
	height: 11px;
	border-radius: 99px;
	background: #ff454e;
}
.phone-head span:nth-child(2) { background: #ff8359; }
.phone-head span:nth-child(3) { background: #35a7ff; margin-right: auto; }
.chat {
	max-width: 82%;
	margin: 16px 0;
	padding: 16px 18px;
	border: 1px solid rgba(255, 255, 255, .11);
	border-radius: 20px;
	color: rgba(255, 255, 255, .82);
	font-weight: 700;
	line-height: 1.45;
	background: rgba(255, 255, 255, .06);
	box-shadow: 0 14px 32px rgba(0, 0, 0, .22);
}
.chat-right {
	margin-left: auto;
	color: white;
	background: linear-gradient(135deg, rgba(255, 69, 78, .95), rgba(255, 104, 93, .86));
	box-shadow: 0 18px 40px rgba(255, 69, 78, .22);
}
.flow-map {
	position: relative;
	display: grid;
	grid-template-columns: 1fr 42px 1fr 42px 1fr;
	align-items: center;
	gap: 0;
	margin-top: 32px;
	padding: 8px 0;
}
.flow-map::before {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	top: 50%;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(69, 224, 196, .24), rgba(255, 69, 78, .34), rgba(69, 224, 196, .24), transparent);
	filter: drop-shadow(0 0 14px rgba(255, 69, 78, .3));
	pointer-events: none;
}
.flow-node {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	gap: 10px;
	min-height: 128px;
	border: 1px solid rgba(255, 255, 255, .13);
	border-radius: 28px;
	color: #fff;
	background:
		linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.035)),
		radial-gradient(circle at 50% 0%, rgba(69,224,196,.12), transparent 56%);
	box-shadow: inset 0 0 30px rgba(255, 255, 255, .035), 0 0 32px rgba(0, 0, 0, .22);
	transition: transform .32s ease, border-color .32s ease, box-shadow .32s ease;
}
.flow-node::after {
	content: "";
	position: absolute;
	inset: -1px;
	border-radius: inherit;
	border: 1px solid transparent;
	background: linear-gradient(135deg, rgba(255,69,78,.7), rgba(69,224,196,.28), transparent 70%) border-box;
	mask: linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
	mask-composite: exclude;
	opacity: .34;
	pointer-events: none;
}
.flow-node:hover {
	transform: translateY(-5px);
	border-color: rgba(255, 69, 78, .46);
	box-shadow: 0 20px 54px rgba(0, 0, 0, .28), 0 0 38px rgba(255, 69, 78, .18), inset 0 0 26px rgba(255, 69, 78, .08);
}
.flow-node:first-child {
	border-color: rgba(255, 69, 78, .62);
	box-shadow: 0 0 32px rgba(255, 69, 78, .24), inset 0 0 22px rgba(255, 69, 78, .09);
}
.flow-map svg {
	width: 36px;
	height: 36px;
	color: var(--red);
	animation: iconPulse 3s ease-in-out infinite;
}
.flow-map div:nth-child(5) svg { color: var(--blue); }
.flow-map .flow-openclaw {
	border-color: rgba(255, 69, 78, .52);
	background: radial-gradient(circle at 50% 26%, rgba(255, 69, 78, .16), rgba(255, 255, 255, .045));
	box-shadow: 0 0 38px rgba(255, 69, 78, .22), inset 0 0 24px rgba(255, 69, 78, .08);
}
.flow-openclaw img {
	width: 58px;
	height: 58px;
	object-fit: contain;
	filter: drop-shadow(0 10px 16px rgba(255, 69, 78, .34));
	animation: iconPulse 3s ease-in-out infinite;
}
.flow-map span {
	font-weight: 800;
	font-size: 13px;
}
.flow-link {
	position: relative;
	z-index: 2;
	display: block;
	height: 4px;
	border-radius: 99px;
	background:
		linear-gradient(90deg, rgba(255,69,78,.08), rgba(255,69,78,.9), rgba(69,224,196,.78), rgba(255,69,78,.08));
	background-size: 220% 100%;
	box-shadow: 0 0 18px rgba(255, 69, 78, .46), 0 0 24px rgba(69, 224, 196, .18);
	animation: signalFlow 2.4s linear infinite;
}
.flow-link::before {
	content: "";
	position: relative;
	display: block;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.92), transparent);
	transform: translateX(-80%);
	animation: signalBeam 1.8s ease-in-out infinite;
}
.flow-link::after {
	content: "";
	position: absolute;
	top: 50%;
	right: -3px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--red);
	box-shadow: 0 0 0 8px rgba(255, 69, 78, .14), 0 0 26px rgba(255, 69, 78, .7);
	transform: translateY(-50%);
	animation: dataDot 2.2s ease-in-out infinite;
}
.mini-metrics {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}
.mini-metrics span,
.float-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 14px;
	border: 1px solid rgba(255, 255, 255, .13);
	border-radius: 999px;
	color: white;
	font-size: 14px;
	font-weight: 800;
	background: rgba(255, 255, 255, .06);
	box-shadow: 0 16px 34px rgba(0, 0, 0, .22);
}
.system-frame {
	position: relative;
	display: grid;
	grid-template-columns: minmax(126px, .72fr) 1fr;
	gap: 14px;
	align-items: center;
	margin-top: 16px;
	padding: 16px;
	border: 1px solid rgba(69, 224, 196, .15);
	border-radius: 26px;
	background:
		linear-gradient(135deg, rgba(69,224,196,.07), transparent 42%),
		rgba(255, 255, 255, .045);
	box-shadow: inset 0 0 26px rgba(255,255,255,.035), 0 18px 44px rgba(0,0,0,.2);
	overflow: hidden;
}
.system-frame::before {
	content: "";
	position: absolute;
	inset: 50% 16px auto 16px;
	height: 1px;
	background: linear-gradient(90deg, rgba(255,69,78,.12), rgba(69,224,196,.54), rgba(255,69,78,.12));
	box-shadow: 0 0 16px rgba(69,224,196,.28);
	pointer-events: none;
}
.system-core {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	gap: 8px;
	min-height: 126px;
	border: 1px solid rgba(255, 69, 78, .24);
	border-radius: 22px;
	background: radial-gradient(circle at 50% 22%, rgba(255,69,78,.2), rgba(255,255,255,.04) 64%);
}
.system-core img {
	width: 56px;
	height: 56px;
	object-fit: contain;
	filter: drop-shadow(0 12px 18px rgba(255, 69, 78, .3));
}
.system-core strong {
	font-size: 13px;
	text-align: center;
}
.system-ring {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}
.system-ring span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 44px;
	padding: 10px 12px;
	border: 1px solid rgba(255,255,255,.1);
	border-radius: 16px;
	color: rgba(255,255,255,.82);
	font-size: 12px;
	font-weight: 800;
	background: rgba(255,255,255,.05);
}
.system-ring svg {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	color: var(--teal);
	filter: drop-shadow(0 0 10px rgba(69,224,196,.42));
}
.float-badge {
	position: absolute;
	animation: mascotFloat 4.5s ease-in-out infinite;
}
.badge-one { top: 42px; left: 0; }
.badge-two { right: 16px; bottom: -20px; animation-delay: -2s; }

.features,
.workflow,
.outcomes,
.pricing,
.consult {
	background:
		radial-gradient(ellipse at 12% 0%, rgba(255,69,78,.08), transparent 34%),
		radial-gradient(ellipse at 88% 100%, rgba(69,224,196,.07), transparent 35%),
		linear-gradient(180deg, #081020 0%, #050a16 100%);
}
.features .section-inner,
.workflow .section-inner,
.outcomes .section-inner,
.pricing .section-inner,
.consult .section-inner {
	padding: 90px 0;
}
.section-heading {
	max-width: 790px;
	margin-bottom: 34px;
}
.section-heading h2,
.consult-copy h2 {
	margin: 12px 0 0;
	font-size: clamp(30px, 3.2vw, 52px);
	line-height: 1.05;
	letter-spacing: 0;
}
.section-heading p,
.consult-copy p {
	color: var(--muted);
	font-size: 17px;
	line-height: 1.7;
}
.feature-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}
.feature-card {
	position: relative;
	display: flex;
	align-items: center;
	gap: 16px;
	min-height: 116px;
	padding: 22px;
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 22px;
	background: linear-gradient(180deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .035));
	box-shadow: 0 20px 54px rgba(0, 0, 0, .26);
	overflow: hidden;
	transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.feature-card::after {
	content: "";
	position: absolute;
	inset: auto -48px -68px auto;
	width: 160px;
	height: 160px;
	border-radius: 50%;
	background: rgba(255, 69, 78, .15);
	filter: blur(6px);
}
.feature-card:hover {
	transform: translateY(-9px);
	border-color: rgba(255, 69, 78, .38);
	box-shadow: 0 30px 80px rgba(0, 0, 0, .34), 0 0 34px rgba(255, 69, 78, .12);
}
.feature-card h3 {
	position: relative;
	z-index: 1;
	margin: 0;
	font-size: 18px;
	line-height: 1.28;
}
.icon-bubble {
	flex: 0 0 auto;
	position: relative;
	z-index: 1;
	width: 58px;
	height: 58px;
	border-radius: 18px;
	transition: transform .48s cubic-bezier(.2,.8,.2,1), box-shadow .3s ease;
}
.icon-bubble svg {
	width: 28px;
	height: 28px;
	transition: transform .48s cubic-bezier(.2,.8,.2,1);
}
.feature-card:hover .icon-bubble {
	transform: rotate(12deg) scale(1.05);
	box-shadow: 0 0 34px rgba(255, 69, 78, .54), inset 0 -10px 18px rgba(74, 10, 18, .28);
}
.feature-card:hover .icon-bubble svg {
	transform: rotate(360deg);
}

.workflow {
	background:
		radial-gradient(circle at 84% 18%, rgba(255, 69, 78, .13), transparent 30%),
		radial-gradient(ellipse at 8% 92%, rgba(69,224,196,.07), transparent 36%),
		linear-gradient(180deg, #050a16 0%, #071020 100%);
}
.split {
	display: grid;
	grid-template-columns: minmax(0, .88fr) minmax(420px, 1fr);
	gap: clamp(34px, 6vw, 88px);
	align-items: center;
}
.timeline {
	display: grid;
	gap: 12px;
}
.timeline div {
	position: relative;
	display: grid;
	grid-template-columns: 62px 1fr;
	gap: 18px;
	align-items: center;
	padding: 20px;
	border: 1px solid rgba(255,255,255,.13);
	border-radius: 24px;
	background: rgba(255,255,255,.055);
	box-shadow: 0 18px 46px rgba(0, 0, 0, .22);
	transition: transform .3s ease, border-color .3s ease;
}
.timeline div::after {
	content: "";
	position: absolute;
	right: 18px;
	width: 12px;
	height: 12px;
	border-right: 2px solid var(--teal);
	border-bottom: 2px solid var(--teal);
	transform: rotate(45deg) scale(.9);
	opacity: .76;
	filter: drop-shadow(0 0 10px rgba(69,224,196,.6));
	transition: transform .3s ease, opacity .3s ease;
}
.timeline div:hover {
	transform: translateX(8px);
	border-color: rgba(255, 69, 78, .38);
}
.timeline div:hover::after {
	transform: rotate(45deg) scale(1.12);
	opacity: 1;
}
.timeline b {
	display: grid;
	place-items: center;
	width: 54px;
	height: 54px;
	border-radius: 18px;
	color: white;
	background: linear-gradient(135deg, #ff3342, #ff6b55);
	box-shadow: 0 14px 30px rgba(255, 69, 78, .25);
}
.timeline strong { font-size: 18px; }
.workflow .section-heading .btn {
	margin-top: 26px;
}

.outcomes {
	background:
		radial-gradient(ellipse at 20% 0%, rgba(255,69,78,.08), transparent 34%),
		linear-gradient(180deg, #071020 0%, #050a16 100%);
	color: white;
}
.outcomes::before {
	background:
		radial-gradient(circle at 18% 22%, rgba(255,69,78,.24), transparent 26%),
		radial-gradient(circle at 78% 50%, rgba(53,167,255,.13), transparent 24%);
}
.outcome-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}
.outcome-card {
	color: white;
	background: rgba(255,255,255,.06);
	border-color: rgba(255,255,255,.13);
}
.outcome-card span { color: rgba(255,255,255,.72); }

.pricing {
	background:
		radial-gradient(ellipse at 15% 20%, rgba(255,69,78,.14), transparent 33%),
		radial-gradient(ellipse at 78% 72%, rgba(69,224,196,.09), transparent 34%),
		linear-gradient(180deg, #050a16 0%, #071020 58%, #050a16 100%);
}
.pricing::before {
	background:
		linear-gradient(115deg, transparent 0 28%, rgba(255,255,255,.035) 28.2%, transparent 29.4% 100%),
		radial-gradient(circle at 82% 18%, rgba(53,167,255,.11), transparent 25%);
}
.pricing-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	align-items: stretch;
}
.pricing-card {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 24px;
	border: 1px solid rgba(255,255,255,.13);
	border-radius: 28px;
	background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.038));
	box-shadow: 0 24px 70px rgba(0,0,0,.28);
	overflow: hidden;
	transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.pricing-card::after {
	content: "";
	position: absolute;
	inset: auto -74px -92px auto;
	width: 210px;
	height: 210px;
	border-radius: 50%;
	background: rgba(255,69,78,.14);
	filter: blur(4px);
	pointer-events: none;
}
.pricing-card:hover {
	transform: translateY(-8px);
	border-color: rgba(69,224,196,.28);
	box-shadow: 0 34px 86px rgba(0,0,0,.36), 0 0 36px rgba(69,224,196,.12);
}
.pricing-card.is-featured {
	border-color: rgba(255,69,78,.48);
	background:
		linear-gradient(180deg, rgba(255,69,78,.13), rgba(255,255,255,.05)),
		radial-gradient(circle at 50% 0%, rgba(255,69,78,.24), transparent 52%);
	box-shadow: 0 30px 88px rgba(0,0,0,.36), 0 0 40px rgba(255,69,78,.14);
}
.pricing-card-head {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 10px;
	padding-bottom: 18px;
	border-bottom: 1px solid rgba(255,255,255,.1);
}
.pricing-card-head span {
	justify-self: start;
	padding: 8px 10px;
	border: 1px solid rgba(69,224,196,.18);
	border-radius: 999px;
	color: var(--teal);
	font-size: 12px;
	font-weight: 800;
	background: rgba(69,224,196,.07);
}
.pricing-card-head h3 {
	margin: 0;
	font-size: 25px;
	line-height: 1.15;
}
.pricing-card-head strong {
	color: #fff;
	font-size: clamp(30px, 3vw, 42px);
	line-height: 1;
}
.pricing-card ul {
	position: relative;
	z-index: 1;
	display: grid;
	gap: 12px;
	margin: 20px 0 24px;
	padding: 0;
	list-style: none;
}
.pricing-card li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: rgba(255,255,255,.78);
	font-weight: 700;
	line-height: 1.45;
}
.pricing-card li svg {
	flex: 0 0 auto;
	width: 20px;
	height: 20px;
	margin-top: 1px;
	color: var(--teal);
	filter: drop-shadow(0 0 10px rgba(69,224,196,.42));
}
.pricing-cta {
	position: relative;
	z-index: 1;
	width: 100%;
	justify-content: center;
	margin-top: auto;
}

.consult {
	background:
		radial-gradient(ellipse at 12% 22%, rgba(255,69,78,.18), transparent 34%),
		radial-gradient(ellipse at 84% 78%, rgba(53,167,255,.14), transparent 34%),
		radial-gradient(ellipse at 54% 18%, rgba(69,224,196,.11), transparent 35%),
		linear-gradient(180deg, #050a16 0%, #071020 52%, #050a16 100%);
}
.consult::after {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		linear-gradient(120deg, transparent 0 26%, rgba(255,255,255,.05) 26.2%, transparent 27.4% 100%),
		linear-gradient(55deg, transparent 0 62%, rgba(69,224,196,.06) 62.2%, transparent 63.2% 100%);
	opacity: .75;
}
.consult-float {
	position: absolute;
	z-index: 0;
	display: grid;
	place-items: center;
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 26px;
	color: rgba(255,255,255,.86);
	background: rgba(255,255,255,.055);
	box-shadow: 0 20px 54px rgba(0,0,0,.24), 0 0 34px rgba(255,69,78,.12);
	backdrop-filter: blur(14px);
	animation: consultFloat 7s ease-in-out infinite;
}
.consult-float svg {
	width: 46%;
	height: 46%;
	color: var(--red);
	filter: drop-shadow(0 0 16px rgba(255,69,78,.45));
}
.consult-float-phone {
	left: max(20px, 5vw);
	top: 18%;
	width: 82px;
	height: 82px;
}
.consult-float-mail {
	right: max(22px, 7vw);
	top: 16%;
	width: 116px;
	height: 116px;
	animation-delay: -2.5s;
}
.consult-float-message {
	right: max(54px, 16vw);
	bottom: 12%;
	width: 70px;
	height: 70px;
	animation-delay: -4.2s;
}
.consult-float-phone-small {
	left: max(28px, 13vw);
	bottom: 14%;
	width: 56px;
	height: 56px;
	border-radius: 20px;
	opacity: .72;
	animation-duration: 8.8s;
	animation-delay: -1.4s;
}
.consult-float-mail-small {
	right: max(34px, 24vw);
	top: 45%;
	width: 64px;
	height: 64px;
	border-radius: 22px;
	opacity: .68;
	animation-duration: 9.4s;
	animation-delay: -5.2s;
}
.consult-float-phone-tiny {
	left: max(18px, 29vw);
	top: 8%;
	width: 44px;
	height: 44px;
	border-radius: 16px;
	opacity: .55;
	animation-duration: 10.2s;
	animation-delay: -6.4s;
}
.consult-float-mail-tiny {
	right: max(18px, 4vw);
	bottom: 34%;
	width: 48px;
	height: 48px;
	border-radius: 17px;
	opacity: .58;
	animation-duration: 8.4s;
	animation-delay: -3.8s;
}
.consult-grid {
	display: grid;
	grid-template-columns: minmax(0, .9fr) minmax(420px, .72fr);
	gap: clamp(34px, 6vw, 88px);
	align-items: center;
}
.check-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin-top: 24px;
}
.check-list span {
	position: relative;
	display: flex;
	align-items: center;
	gap: 10px;
	min-height: 52px;
	padding: 12px 14px;
	border: 1px solid rgba(255,255,255,.1);
	border-radius: 18px;
	color: rgba(255, 255, 255, .82);
	font-weight: 700;
	background: rgba(255,255,255,.045);
	overflow: hidden;
	transition: transform .3s ease, border-color .3s ease, background .3s ease;
}
.check-list span.is-typing-row {
	border-color: rgba(69,224,196,.34);
	background: rgba(69,224,196,.075);
	box-shadow: 0 16px 40px rgba(0,0,0,.18), inset 0 0 22px rgba(69,224,196,.05);
}
.check-list span.is-typed-row {
	border-color: rgba(255,255,255,.14);
}
.check-list span::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(100deg, transparent 0 38%, rgba(255,255,255,.11) 48%, transparent 58% 100%);
	transform: translateX(-120%);
	transition: transform .72s ease;
}
.check-list span:hover {
	transform: translateY(-3px);
	border-color: rgba(69,224,196,.26);
	background: rgba(255,255,255,.065);
}
.check-list span:hover::before { transform: translateX(120%); }
.check-list svg {
	position: relative;
	z-index: 1;
	flex: 0 0 auto;
	width: 24px;
	height: 24px;
	color: var(--teal);
	stroke-width: 2.2;
	filter: drop-shadow(0 0 10px rgba(69,224,196,.55));
	opacity: 0;
	transform: scale(.82);
	transition: opacity .22s ease, transform .36s ease;
}
.check-list svg path:first-child {
	stroke-dasharray: 24;
	stroke-dashoffset: 24;
}
.check-list span.is-typing-row svg,
.check-list span.is-typed-row svg {
	opacity: 1;
	transform: scale(1);
}
.check-list span.is-typing-row svg {
	animation: checkPopOnce 1.35s ease-out both;
}
.check-list span.is-typing-row svg path:first-child {
	animation: checkDrawOnce 1.35s ease-out forwards;
}
.check-list span.is-typed-row svg path:first-child {
	stroke-dashoffset: 0;
}
.check-list em {
	position: relative;
	z-index: 1;
	min-width: 0;
	font-style: normal;
	line-height: 1.35;
}
.lead-form {
	display: grid;
	gap: 14px;
	padding: 24px;
	border: 1px solid rgba(255, 255, 255, .13);
	border-radius: 30px;
	background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.045));
	box-shadow: var(--shadow);
	backdrop-filter: blur(18px);
}
.lead-form label {
	display: grid;
	gap: 8px;
	color: rgba(255, 255, 255, .82);
	font-size: 14px;
	font-weight: 800;
}
.lead-form input,
.lead-form select,
.lead-form textarea {
	width: 100%;
	border: 1px solid rgba(255,255,255,.13);
	border-radius: 16px;
	background: rgba(255,255,255,.07);
	padding: 15px 16px;
	color: #fff;
	font: inherit;
	outline: none;
	transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}
.lead-form select option { color: #111827; }
.lead-form input::placeholder,
.lead-form textarea::placeholder {
	color: rgba(255, 255, 255, .42);
}
.lead-form input:focus,
.lead-form select:focus,
.lead-form textarea:focus {
	border-color: rgba(255,69,78,.72);
	background: rgba(255,255,255,.09);
	box-shadow: 0 0 0 5px rgba(255,69,78,.13);
}
.form-submit { width: 100%; min-height: 56px; margin-top: 4px; }
.form-alert {
	padding: 14px 16px;
	border-radius: 16px;
	font-weight: 700;
}
.form-alert.success { color: #d1fadf; background: rgba(6, 118, 71, .22); }
.form-alert.error { color: #fecaca; background: rgba(180, 35, 24, .2); }

.site-footer {
	padding: 26px 0;
	color: rgba(255,255,255,.68);
	background: #050a16;
	border-top: 1px solid rgba(255,255,255,.08);
}
.footer-inner {
	display: flex;
	justify-content: space-between;
	gap: 16px;
}
.footer-inner strong { color: white; }

.reveal {
	opacity: 0;
	transform: translateY(30px) scale(.985);
	filter: blur(10px);
	transition: opacity .82s cubic-bezier(.2,.8,.2,1), transform .82s cubic-bezier(.2,.8,.2,1), filter .82s cubic-bezier(.2,.8,.2,1);
}
.reveal.is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
	filter: blur(0);
}

@keyframes mascotFloat {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-12px); }
}
@keyframes logoFloat {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-8px); }
}
@keyframes logoShine {
	0%, 62% { transform: skewX(-18deg) translateX(0); opacity: 0; }
	68% { opacity: .52; }
	84%, 100% { transform: skewX(-18deg) translateX(460%); opacity: 0; }
}
@keyframes brandShine {
	0%, 62% { transform: translateX(-120%); opacity: 0; }
	70% { opacity: .42; }
	88%, 100% { transform: translateX(120%); opacity: 0; }
}
@keyframes orbit {
	0%, 100% { transform: translate3d(0,0,0) scale(1); }
	50% { transform: translate3d(24px,-18px,0) scale(1.08); }
}
@keyframes spinAura {
	to { transform: rotate(360deg); }
}
@keyframes iconPulse {
	0%, 100% { transform: scale(1); filter: drop-shadow(0 0 0 rgba(255,69,78,0)); }
	50% { transform: scale(1.12); filter: drop-shadow(0 0 12px rgba(255,69,78,.45)); }
}
@keyframes dataDot {
	0%, 100% { transform: translate(-18px, -50%) scale(.75); opacity: .55; }
	50% { transform: translate(2px, -50%) scale(1); opacity: 1; }
}
@keyframes signalFlow {
	to { background-position: -220% 0; }
}
@keyframes signalBeam {
	0%, 100% { transform: translateX(-80%); opacity: .28; }
	50% { transform: translateX(80%); opacity: .9; }
}
@keyframes cursorBlink {
	0%, 48% { opacity: 1; }
	49%, 100% { opacity: .08; }
}
@keyframes checkPopOnce {
	0% { transform: scale(.82); }
	58% { transform: scale(1.12); }
	100% { transform: scale(1); }
}
@keyframes checkDrawOnce {
	0%, 18% { stroke-dashoffset: 24; }
	100% { stroke-dashoffset: 0; }
}
@keyframes consultFloat {
	0%, 100% { transform: translate3d(0,0,0) rotate(0deg); }
	50% { transform: translate3d(10px,-14px,0) rotate(4deg); }
}

@media (max-width: 1060px) {
	.nav-links { display: none; }
	.hero-grid,
	.split,
	.consult-grid {
		grid-template-columns: 1fr;
	}
	.hero-panel { min-height: auto; }
	.mascot-orb {
		position: relative;
		top: auto;
		right: auto;
		margin: 0 auto 24px;
		width: clamp(104px, 28vw, 132px);
	}
	.phone-card {
		margin: 0;
		max-width: none;
		transform: none;
	}
	.system-frame {
		grid-template-columns: 1fr;
	}
	.pricing-grid {
		grid-template-columns: 1fr;
	}
	.feature-grid,
	.check-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 700px) {
	.section-inner { width: min(100% - 28px, 1400px); }
	.topbar {
		inset: 10px 14px auto;
		width: calc(100% - 28px);
		border-radius: 18px;
	}
	.topbar .btn { display: none; }
	.hero { padding-top: 78px; }
	.hero-grid { padding: 26px 0 58px; }
	.openclaw-lockup {
		width: 100%;
		margin: 28px 0 26px;
		border-radius: 22px;
	}
	.hero h1 { font-size: 44px; }
	.hero-subtitle { font-size: 30px; }
	.hero-actions,
	.trust-row,
	.outcome-grid,
	.feature-grid {
		grid-template-columns: 1fr;
	}
	.hero-actions { display: grid; }
	.flow-map {
		grid-template-columns: 1fr;
		gap: 0;
	}
	.flow-map::before {
		left: 50%;
		right: auto;
		top: 8%;
		bottom: 8%;
		width: 1px;
		height: auto;
		background: linear-gradient(180deg, transparent, rgba(69, 224, 196, .24), rgba(255, 69, 78, .34), rgba(69, 224, 196, .24), transparent);
	}
	.flow-node {
		min-height: 132px;
		border-radius: 24px;
	}
	.flow-link {
		width: 4px;
		height: 56px;
		margin: 0 auto;
		background:
			linear-gradient(180deg, rgba(255,69,78,.08), rgba(255,69,78,.9), rgba(69,224,196,.78), rgba(255,69,78,.08));
		background-size: 100% 220%;
	}
	.flow-link::before {
		width: 100%;
		background: linear-gradient(180deg, transparent, rgba(255,255,255,.92), transparent);
		animation: signalBeamY 1.8s ease-in-out infinite;
	}
	.flow-link::after {
		top: auto;
		right: 50%;
		bottom: -3px;
		transform: translateX(50%);
		animation: dataDotY 2.2s ease-in-out infinite;
	}
	.float-badge { display: none; }
	.system-frame {
		padding: 14px;
	}
	.system-frame::before {
		display: none;
	}
	.system-core {
		min-height: 104px;
	}
	.system-ring {
		grid-template-columns: 1fr;
	}
	.features .section-inner,
	.workflow .section-inner,
	.outcomes .section-inner,
	.pricing .section-inner,
	.consult .section-inner {
		padding: 58px 0;
	}
	.feature-grid,
	.check-list {
		grid-template-columns: 1fr;
	}
	.feature-card {
		min-height: 94px;
		padding: 18px;
	}
	.pricing-card {
		padding: 20px;
		border-radius: 24px;
	}
	.pricing-card-head h3 {
		font-size: 23px;
	}
	.pricing-card-head strong {
		font-size: 34px;
	}
	.consult-float {
		opacity: .42;
	}
	.consult-float-phone {
		top: 5%;
		left: 8px;
		width: 58px;
		height: 58px;
	}
	.consult-float-mail {
		top: 3%;
		right: 10px;
		width: 74px;
		height: 74px;
	}
	.consult-float-message {
		right: 22px;
		bottom: 5%;
		width: 56px;
		height: 56px;
	}
	.consult-float-phone-small {
		left: 30%;
		bottom: 10%;
		width: 42px;
		height: 42px;
	}
	.consult-float-mail-small {
		right: 32%;
		top: 26%;
		width: 46px;
		height: 46px;
	}
	.consult-float-phone-tiny {
		left: 46%;
		top: 6%;
		width: 34px;
		height: 34px;
	}
	.consult-float-mail-tiny {
		right: 6px;
		bottom: 30%;
		width: 38px;
		height: 38px;
	}
	.footer-inner {
		flex-direction: column;
	}
}

@keyframes signalBeamY {
	0%, 100% { transform: translateY(-80%); opacity: .28; }
	50% { transform: translateY(80%); opacity: .9; }
}
@keyframes dataDotY {
	0%, 100% { transform: translate(50%, -18px) scale(.75); opacity: .55; }
	50% { transform: translate(50%, 2px) scale(1); opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation: none !important;
		scroll-behavior: auto !important;
		transition: none !important;
	}
	.reveal {
		opacity: 1;
		transform: none;
		filter: none;
	}
}
