/*!
 * Ufiny AI Homepage — stylesheet
 * Design system: "UFINY.OS" — cyberpunk minimalism, future operating system.
 * Tokens: void black / graphite / electric blue / neon purple / AI cyan / soft white.
 */

/* ---------------------------------------------------------------------------
 * 1. Tokens + scoped reset
 * ------------------------------------------------------------------------ */
.ufx {
	--ufx-void: #050507;
	--ufx-graphite: #0e0e15;
	--ufx-panel: rgba(255, 255, 255, 0.035);
	--ufx-line: rgba(255, 255, 255, 0.08);
	--ufx-blue: #3d7bff;
	--ufx-purple: #8c5bff;
	--ufx-cyan: #2bd9ff;
	--ufx-white: #edf1f7;
	--ufx-muted: #8a90a2;
	--ufx-grad: linear-gradient(110deg, var(--ufx-blue), var(--ufx-purple) 50%, var(--ufx-cyan));
	--ufx-font-display: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
	--ufx-font-body: "Inter", ui-sans-serif, system-ui, sans-serif;
	--ufx-font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;
	--ufx-radius: 18px;
	--ufx-ease: cubic-bezier(0.22, 1, 0.36, 1);

	position: relative;
	background: var(--ufx-void);
	color: var(--ufx-white);
	font-family: var(--ufx-font-body);
	font-size: 17px;
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
	isolation: isolate;
}

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

.ufx img,
.ufx svg {
	max-width: 100%;
	display: block;
}

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

.ufx ul,
.ufx ol {
	list-style: none;
}

.ufx button {
	font: inherit;
	color: inherit;
	background: none;
	border: 0;
	cursor: pointer;
}

.ufx :focus-visible {
	outline: 2px solid var(--ufx-cyan);
	outline-offset: 3px;
	border-radius: 4px;
}

/* Neutralise common theme chrome on dedicated pages */
body.ufiny-ai-page {
	background: #050507;
}

.ufx-container {
	width: min(1180px, 92vw);
	margin-inline: auto;
}

/* Film-grain noise overlay */
.ufx-noise {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 60;
	opacity: 0.05;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	mix-blend-mode: overlay;
}

/* Scroll progress rail */
.ufx-progress {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	z-index: 70;
	background: rgba(255, 255, 255, 0.05);
}

.ufx-progress__bar {
	display: block;
	height: 100%;
	width: 100%;
	transform-origin: 0 50%;
	transform: scaleX(0);
	background: var(--ufx-grad);
	box-shadow: 0 0 12px rgba(43, 217, 255, 0.6);
}

/* Custom cursor (desktop pointer devices only) */
.ufx-cursor {
	position: fixed;
	top: 0;
	left: 0;
	width: 10px;
	height: 10px;
	margin: -5px 0 0 -5px;
	border-radius: 50%;
	background: var(--ufx-cyan);
	pointer-events: none;
	z-index: 80;
	mix-blend-mode: screen;
}

.ufx-cursor__ring {
	position: fixed;
	top: 0;
	left: 0;
	width: 38px;
	height: 38px;
	margin: -19px 0 0 -19px;
	border-radius: 50%;
	border: 1px solid rgba(43, 217, 255, 0.5);
	pointer-events: none;
	z-index: 79;
	transition: width 0.25s var(--ufx-ease), height 0.25s var(--ufx-ease), margin 0.25s var(--ufx-ease), border-color 0.25s;
}

.ufx-cursor-active .ufx-cursor__ring {
	width: 64px;
	height: 64px;
	margin: -32px 0 0 -32px;
	border-color: rgba(140, 91, 255, 0.8);
}

@media (hover: none), (pointer: coarse) {
	.ufx-cursor,
	.ufx-cursor__ring {
		display: none;
	}
}

/* ---------------------------------------------------------------------------
 * 2. Shared primitives — eyebrow, headings, cards, buttons
 * ------------------------------------------------------------------------ */
.ufx-section {
	position: relative;
	padding: clamp(96px, 12vw, 168px) 0;
}

.ufx-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: var(--ufx-font-mono);
	font-size: 12px;
	letter-spacing: 0.22em;
	color: var(--ufx-cyan);
	text-transform: uppercase;
	border: 1px solid rgba(43, 217, 255, 0.25);
	border-radius: 999px;
	padding: 7px 16px;
	margin-bottom: 26px;
	background: rgba(43, 217, 255, 0.05);
}

.ufx-eyebrow__dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--ufx-cyan);
	box-shadow: 0 0 10px var(--ufx-cyan);
	animation: ufx-pulse 2.2s infinite;
}

.ufx-h2 {
	font-family: var(--ufx-font-display);
	font-weight: 600;
	font-size: clamp(2rem, 4.6vw, 3.4rem);
	line-height: 1.08;
	letter-spacing: -0.02em;
	max-width: 18ch;
	margin-bottom: 22px;
}

.ufx-grad {
	background: var(--ufx-grad);
	background-size: 220% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	animation: ufx-grad-pan 7s ease-in-out infinite alternate;
}

.ufx-lede {
	color: var(--ufx-muted);
	max-width: 56ch;
	font-size: clamp(1rem, 1.4vw, 1.15rem);
	margin-bottom: clamp(40px, 5vw, 64px);
}

.ufx-card {
	position: relative;
	background: var(--ufx-panel);
	border: 1px solid var(--ufx-line);
	border-radius: var(--ufx-radius);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	overflow: hidden;
	transition: border-color 0.35s, transform 0.35s var(--ufx-ease), box-shadow 0.35s;
	transform-style: preserve-3d;
	will-change: transform;
}

.ufx-card:hover {
	border-color: rgba(43, 217, 255, 0.35);
	box-shadow: 0 24px 60px -30px rgba(61, 123, 255, 0.45);
}

.ufx-card__sheen {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(420px circle at var(--ufx-mx, 50%) var(--ufx-my, 50%), rgba(140, 91, 255, 0.14), transparent 60%);
	opacity: 0;
	transition: opacity 0.35s;
}

.ufx-card:hover .ufx-card__sheen {
	opacity: 1;
}

/* Buttons */
.ufx-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	font-family: var(--ufx-font-display);
	font-weight: 600;
	font-size: 0.95rem;
	letter-spacing: 0.01em;
	padding: 16px 30px;
	border-radius: 999px;
	transition: transform 0.3s var(--ufx-ease), box-shadow 0.3s, border-color 0.3s, background 0.3s;
	will-change: transform;
}

.ufx-btn--primary {
	color: #04050a;
	background: linear-gradient(110deg, var(--ufx-cyan), var(--ufx-blue));
	box-shadow: 0 8px 32px -8px rgba(43, 217, 255, 0.55);
}

.ufx-btn--primary:hover {
	box-shadow: 0 14px 44px -8px rgba(43, 217, 255, 0.75);
}

.ufx-btn__glow {
	position: absolute;
	inset: -2px;
	border-radius: inherit;
	background: var(--ufx-grad);
	filter: blur(18px);
	opacity: 0.35;
	z-index: -1;
	animation: ufx-grad-pan 5s linear infinite alternate;
}

.ufx-btn--ghost {
	color: var(--ufx-white);
	border: 1px solid var(--ufx-line);
	background: rgba(255, 255, 255, 0.02);
}

.ufx-btn--ghost:hover {
	border-color: rgba(43, 217, 255, 0.5);
	background: rgba(43, 217, 255, 0.06);
}

.ufx-btn--xl {
	padding: 20px 42px;
	font-size: 1.05rem;
}

/* Reveal defaults (JS removes via GSAP; CSS fallback keeps content visible) */
.ufx-js [data-reveal],
.ufx-js [data-stagger],
.ufx-js [data-hero-fade] {
	opacity: 0;
	transform: translateY(28px);
}

.ufx-js .ufx-split-word {
	display: inline-block;
	overflow: hidden;
	vertical-align: top;
}

.ufx-js .ufx-split-word > span {
	display: inline-block;
	transform: translateY(110%);
}

/* ---------------------------------------------------------------------------
 * 3. Hero
 * ------------------------------------------------------------------------ */
.ufx-hero {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	display: flex;
	align-items: center;
	overflow: hidden;
	padding: 120px 0 80px;
}

.ufx-hero__canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}

.ufx-hero__grid {
	position: absolute;
	inset: 0;
	z-index: 1;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
	background-size: 72px 72px;
	mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, #000 30%, transparent 75%);
	-webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, #000 30%, transparent 75%);
}

.ufx-hero__beams {
	position: absolute;
	inset: 0;
	z-index: 1;
	overflow: hidden;
}

.ufx-beam {
	position: absolute;
	width: 55vmax;
	height: 55vmax;
	border-radius: 50%;
	filter: blur(110px);
	opacity: 0.16;
	will-change: transform;
}

.ufx-beam--1 {
	background: var(--ufx-blue);
	top: -22vmax;
	left: -12vmax;
	animation: ufx-drift 22s ease-in-out infinite alternate;
}

.ufx-beam--2 {
	background: var(--ufx-purple);
	bottom: -26vmax;
	right: -14vmax;
	animation: ufx-drift 28s ease-in-out infinite alternate-reverse;
}

.ufx-beam--3 {
	background: var(--ufx-cyan);
	top: 30%;
	left: 55%;
	width: 30vmax;
	height: 30vmax;
	opacity: 0.1;
	animation: ufx-drift 18s ease-in-out infinite alternate;
}

.ufx-hero__hud {
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
}

.ufx-hud {
	position: absolute;
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	color: rgba(237, 241, 247, 0.45);
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.ufx-hud em {
	font-style: normal;
	color: var(--ufx-cyan);
}

.ufx-hud--tl { top: 28px; left: 32px; }
.ufx-hud--tr { top: 28px; right: 32px; }
.ufx-hud--bl { bottom: 28px; left: 32px; }
.ufx-hud--br { bottom: 28px; right: 32px; }

.ufx-hud__pulse {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #43ffa6;
	box-shadow: 0 0 10px #43ffa6;
	display: inline-block;
	animation: ufx-pulse 1.6s infinite;
}

.ufx-hero__inner {
	position: relative;
	z-index: 3;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.ufx-hero__kicker {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 12px;
	font-family: var(--ufx-font-mono);
	font-size: 12.5px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ufx-muted);
	margin-bottom: 32px;
}

.ufx-hero__kicker-chip {
	color: var(--ufx-white);
	border: 1px solid var(--ufx-line);
	border-radius: 999px;
	padding: 6px 14px;
	background: rgba(255, 255, 255, 0.03);
}

.ufx-hero__title {
	font-family: var(--ufx-font-display);
	font-weight: 700;
	font-size: clamp(2.6rem, 7.4vw, 6rem);
	line-height: 1.02;
	letter-spacing: -0.03em;
	max-width: 14ch;
	margin-bottom: 28px;
	text-wrap: balance;
}

.ufx-hero__title-grad {
	background: var(--ufx-grad);
	background-size: 220% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	animation: ufx-grad-pan 6s ease-in-out infinite alternate;
}

.ufx-hero__sub {
	color: var(--ufx-muted);
	font-size: clamp(1.02rem, 1.6vw, 1.25rem);
	max-width: 52ch;
	margin-bottom: 44px;
}

.ufx-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: center;
	margin-bottom: 56px;
}

.ufx-hero__stream {
	font-family: var(--ufx-font-mono);
	font-size: 12.5px;
	color: rgba(43, 217, 255, 0.7);
	letter-spacing: 0.06em;
	min-height: 1.4em;
}

.ufx-stream__line::after {
	content: "▌";
	animation: ufx-blink 1s steps(1) infinite;
	margin-left: 2px;
}

.ufx-hero__scrollcue {
	position: absolute;
	z-index: 3;
	bottom: 64px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	color: var(--ufx-muted);
	font-family: var(--ufx-font-mono);
	font-size: 10px;
	letter-spacing: 0.3em;
	text-transform: uppercase;
}

.ufx-scrollcue__track {
	width: 22px;
	height: 38px;
	border: 1px solid var(--ufx-line);
	border-radius: 12px;
	display: flex;
	justify-content: center;
	padding-top: 7px;
}

.ufx-scrollcue__dot {
	width: 4px;
	height: 8px;
	border-radius: 4px;
	background: var(--ufx-cyan);
	animation: ufx-scrollcue 1.8s var(--ufx-ease) infinite;
}

/* ---------------------------------------------------------------------------
 * 4. Transformation
 * ------------------------------------------------------------------------ */
.ufx-transform__panel {
	border: 1px solid var(--ufx-line);
	border-radius: var(--ufx-radius);
	background: var(--ufx-panel);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	overflow: hidden;
}

.ufx-transform__head {
	display: grid;
	grid-template-columns: 1fr 80px 1fr;
	padding: 18px 32px;
	border-bottom: 1px solid var(--ufx-line);
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.24em;
	color: var(--ufx-muted);
}

.ufx-transform__col--after {
	grid-column: 3;
	color: var(--ufx-cyan);
	text-align: right;
}

.ufx-transform__row {
	display: grid;
	grid-template-columns: 1fr 80px 1fr;
	align-items: center;
	gap: 12px;
	padding: 22px 32px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
	font-family: var(--ufx-font-display);
	font-size: clamp(1rem, 1.8vw, 1.3rem);
}

.ufx-transform__row:last-child {
	border-bottom: 0;
}

.ufx-transform__old {
	color: var(--ufx-muted);
	text-decoration: line-through;
	text-decoration-color: rgba(138, 144, 162, 0.5);
	text-decoration-thickness: 1px;
}

.ufx-transform__arrow {
	color: var(--ufx-cyan);
	display: flex;
	justify-content: center;
}

.ufx-transform__arrow svg {
	width: 48px;
	height: 12px;
}

.ufx-js .ufx-transform__path {
	stroke-dasharray: 60;
	stroke-dashoffset: 60;
}

.ufx-transform__new {
	text-align: right;
	font-weight: 600;
	background: var(--ufx-grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

/* ---------------------------------------------------------------------------
 * 5. Services
 * ------------------------------------------------------------------------ */
.ufx-services__tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 38px;
}

.ufx-tab {
	font-family: var(--ufx-font-mono);
	font-size: 12.5px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ufx-muted);
	border: 1px solid var(--ufx-line);
	border-radius: 999px;
	padding: 10px 20px;
	transition: color 0.3s, border-color 0.3s, background 0.3s, box-shadow 0.3s;
}

.ufx-tab:hover {
	color: var(--ufx-white);
	border-color: rgba(43, 217, 255, 0.4);
}

.ufx-tab.is-active {
	color: #04050a;
	background: linear-gradient(110deg, var(--ufx-cyan), var(--ufx-blue));
	border-color: transparent;
	box-shadow: 0 6px 24px -8px rgba(43, 217, 255, 0.6);
}

.ufx-services__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 18px;
}

.ufx-svc {
	padding: 28px 26px 30px;
	min-height: 190px;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.ufx-svc__index {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	color: rgba(43, 217, 255, 0.65);
}

.ufx-svc__title {
	font-family: var(--ufx-font-display);
	font-size: 1.18rem;
	font-weight: 600;
	letter-spacing: -0.01em;
}

.ufx-svc__desc {
	color: var(--ufx-muted);
	font-size: 0.93rem;
	line-height: 1.6;
}

/* ---------------------------------------------------------------------------
 * 6. Agents — pinned horizontal rail
 * ------------------------------------------------------------------------ */
.ufx-agents__head {
	margin-bottom: clamp(20px, 4vw, 48px);
}

.ufx-agents__pin {
	overflow: hidden;
}

.ufx-agents__rail {
	display: flex;
	gap: 22px;
	padding: 8px max(4vw, calc((100vw - 1180px) / 2)) 48px;
	will-change: transform;
	width: -moz-max-content;
	width: max-content;
}

.ufx-agent {
	position: relative;
	flex: 0 0 320px;
	padding: 26px 26px 30px;
	background: var(--ufx-panel);
	border: 1px solid var(--ufx-line);
	border-radius: var(--ufx-radius);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	transition: border-color 0.35s, box-shadow 0.35s, transform 0.35s var(--ufx-ease);
	transform-style: preserve-3d;
}

.ufx-agent:hover {
	border-color: rgba(140, 91, 255, 0.55);
	box-shadow: 0 0 0 1px rgba(140, 91, 255, 0.25), 0 26px 70px -28px rgba(140, 91, 255, 0.55);
}

.ufx-agent__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 22px;
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
}

.ufx-agent__id { color: var(--ufx-muted); }

.ufx-agent__status {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: #43ffa6;
}

.ufx-agent__core {
	position: relative;
	width: 88px;
	height: 88px;
	margin: 0 auto 22px;
}

.ufx-agent__ring {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 1px solid rgba(43, 217, 255, 0.4);
	border-top-color: transparent;
	animation: ufx-spin 6s linear infinite;
}

.ufx-agent__ring--2 {
	inset: 12px;
	border-color: rgba(140, 91, 255, 0.45);
	border-bottom-color: transparent;
	animation: ufx-spin 4s linear infinite reverse;
}

.ufx-agent__nucleus {
	position: absolute;
	inset: 30px;
	border-radius: 50%;
	background: radial-gradient(circle at 35% 35%, var(--ufx-cyan), var(--ufx-purple));
	box-shadow: 0 0 26px rgba(43, 217, 255, 0.6);
	animation: ufx-pulse 2.4s ease-in-out infinite;
}

.ufx-agent__title {
	font-family: var(--ufx-font-display);
	font-size: 1.25rem;
	font-weight: 600;
	text-align: center;
	margin-bottom: 16px;
}

.ufx-agent__caps {
	display: grid;
	gap: 8px;
	margin-bottom: 20px;
}

.ufx-agent__caps li {
	position: relative;
	padding-left: 18px;
	color: var(--ufx-muted);
	font-size: 0.9rem;
}

.ufx-agent__caps li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 7px;
	height: 7px;
	border-radius: 2px;
	background: var(--ufx-grad);
}

.ufx-agent__thinking {
	font-family: var(--ufx-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: rgba(43, 217, 255, 0.7);
	display: flex;
	align-items: center;
	gap: 4px;
}

.ufx-agent__thinking span {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--ufx-cyan);
	animation: ufx-think 1.2s ease-in-out infinite;
}

.ufx-agent__thinking span:nth-child(2) { animation-delay: 0.18s; }
.ufx-agent__thinking span:nth-child(3) { animation-delay: 0.36s; margin-right: 6px; }

/* ---------------------------------------------------------------------------
 * 7. Process timeline
 * ------------------------------------------------------------------------ */
.ufx-process__timeline {
	position: relative;
	padding-left: 38px;
}

.ufx-process__line {
	position: absolute;
	left: 11px;
	top: 8px;
	bottom: 8px;
	width: 2px;
	background: rgba(255, 255, 255, 0.07);
	border-radius: 2px;
	overflow: hidden;
}

.ufx-process__line-fill {
	display: block;
	width: 100%;
	height: 100%;
	background: var(--ufx-grad);
	transform-origin: top;
	transform: scaleY(0);
	box-shadow: 0 0 14px rgba(43, 217, 255, 0.7);
}

.ufx-process__list {
	display: grid;
	gap: 26px;
}

.ufx-process__step {
	position: relative;
}

.ufx-process__node {
	position: absolute;
	left: -38px;
	top: 26px;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	border: 1px solid rgba(43, 217, 255, 0.4);
	display: grid;
	place-items: center;
	background: var(--ufx-void);
}

.ufx-process__node-core {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--ufx-cyan);
	box-shadow: 0 0 12px var(--ufx-cyan);
	transform: scale(0.4);
	opacity: 0.4;
	transition: transform 0.5s var(--ufx-ease), opacity 0.5s;
}

.ufx-process__step.is-active .ufx-process__node-core {
	transform: scale(1);
	opacity: 1;
}

.ufx-process__body {
	padding: 26px 30px 30px;
}

.ufx-process__count {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.24em;
	color: rgba(43, 217, 255, 0.7);
}

.ufx-process__title {
	font-family: var(--ufx-font-display);
	font-size: 1.45rem;
	font-weight: 600;
	margin: 8px 0 8px;
}

.ufx-process__desc {
	color: var(--ufx-muted);
	max-width: 62ch;
}

/* ---------------------------------------------------------------------------
 * 8. Portfolio
 * ------------------------------------------------------------------------ */
.ufx-portfolio__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 20px;
}

.ufx-case {
	padding: 28px 28px 32px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.ufx-case__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ufx-case__industry {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ufx-muted);
}

.ufx-case__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--ufx-grad);
	box-shadow: 0 0 12px rgba(140, 91, 255, 0.8);
}

.ufx-case__metric {
	display: flex;
	flex-direction: column;
}

.ufx-case__value {
	font-family: var(--ufx-font-display);
	font-size: clamp(2rem, 3.4vw, 2.8rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	background: var(--ufx-grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	line-height: 1.05;
}

.ufx-case__label {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ufx-muted);
	margin-top: 6px;
}

.ufx-case__title {
	font-family: var(--ufx-font-display);
	font-size: 1.2rem;
	font-weight: 600;
}

.ufx-case__desc {
	color: var(--ufx-muted);
	font-size: 0.93rem;
	flex-grow: 1;
}

.ufx-case__bar {
	height: 3px;
	border-radius: 3px;
	background: rgba(255, 255, 255, 0.06);
	overflow: hidden;
}

.ufx-case__bar-fill {
	display: block;
	height: 100%;
	width: 100%;
	background: var(--ufx-grad);
	transform-origin: left;
	transform: scaleX(0);
}

/* ---------------------------------------------------------------------------
 * 9. Operations console (interactive demo)
 * ------------------------------------------------------------------------ */
.ufx-console {
	padding: 0;
	overflow: hidden;
}

.ufx-console__bar {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 14px 22px;
	border-bottom: 1px solid var(--ufx-line);
	background: rgba(255, 255, 255, 0.02);
}

.ufx-console__dots {
	display: inline-flex;
	gap: 6px;
}

.ufx-console__dots i {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
}

.ufx-console__title {
	font-family: var(--ufx-font-mono);
	font-size: 11.5px;
	letter-spacing: 0.16em;
	color: var(--ufx-muted);
	flex-grow: 1;
	text-align: center;
}

.ufx-console__live {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	color: #43ffa6;
	display: inline-flex;
	align-items: center;
	gap: 7px;
}

.ufx-console__kpis {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
	border-bottom: 1px solid var(--ufx-line);
}

.ufx-kpi {
	display: flex;
	flex-direction: column;
	gap: 6px;
	align-items: flex-start;
	text-align: left;
	padding: 22px 24px;
	border-right: 1px solid var(--ufx-line);
	transition: background 0.3s;
}

.ufx-kpi:last-child {
	border-right: 0;
}

.ufx-kpi:hover,
.ufx-kpi.is-active {
	background: rgba(43, 217, 255, 0.05);
}

.ufx-kpi__label {
	font-family: var(--ufx-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ufx-muted);
}

.ufx-kpi__value {
	font-family: var(--ufx-font-display);
	font-size: 1.7rem;
	font-weight: 700;
	letter-spacing: -0.02em;
}

.ufx-kpi__delta {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.08em;
}

.ufx-kpi__delta.is-up { color: #43ffa6; }

.ufx-console__main {
	display: grid;
	grid-template-columns: 1.7fr 1fr;
}

.ufx-console__chartwrap {
	padding: 24px;
	border-right: 1px solid var(--ufx-line);
}

.ufx-console__chart-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
	gap: 12px;
	flex-wrap: wrap;
}

.ufx-console__chart-title {
	font-family: var(--ufx-font-display);
	font-weight: 600;
	font-size: 1rem;
}

.ufx-console__ranges {
	display: inline-flex;
	gap: 6px;
}

.ufx-range {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	color: var(--ufx-muted);
	border: 1px solid var(--ufx-line);
	border-radius: 8px;
	padding: 6px 12px;
	transition: all 0.25s;
}

.ufx-range:hover { color: var(--ufx-white); }

.ufx-range.is-active {
	color: #04050a;
	background: var(--ufx-cyan);
	border-color: transparent;
}

.ufx-console__chart {
	width: 100%;
	height: 220px;
}

.ufx-console__gridlines line {
	stroke: rgba(255, 255, 255, 0.06);
	stroke-width: 1;
}

.ufx-console__lineplot {
	stroke: var(--ufx-cyan);
	stroke-width: 2.5;
	filter: drop-shadow(0 0 8px rgba(43, 217, 255, 0.6));
}

.ufx-console__cursor {
	fill: var(--ufx-white);
	stroke: var(--ufx-cyan);
	stroke-width: 2;
	opacity: 0;
}

.ufx-console__feed {
	padding: 24px;
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.ufx-console__feed-title {
	font-family: var(--ufx-font-display);
	font-weight: 600;
	font-size: 1rem;
	margin-bottom: 14px;
}

.ufx-console__events {
	display: grid;
	gap: 10px;
	align-content: start;
	max-height: 260px;
	overflow: hidden;
}

.ufx-console__events li {
	display: flex;
	gap: 10px;
	align-items: baseline;
	font-size: 0.85rem;
	color: var(--ufx-muted);
	border-left: 2px solid rgba(43, 217, 255, 0.4);
	padding-left: 12px;
}

.ufx-console__events li strong {
	color: var(--ufx-white);
	font-weight: 600;
	font-family: var(--ufx-font-mono);
	font-size: 0.74rem;
	letter-spacing: 0.08em;
	white-space: nowrap;
}

/* ---------------------------------------------------------------------------
 * 10. Trust
 * ------------------------------------------------------------------------ */
.ufx-trust__counters {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 18px;
	margin-bottom: clamp(48px, 6vw, 80px);
}

.ufx-counter {
	border: 1px solid var(--ufx-line);
	border-radius: var(--ufx-radius);
	background: var(--ufx-panel);
	padding: 30px 26px;
	text-align: center;
}

.ufx-counter__value {
	display: block;
	font-family: var(--ufx-font-display);
	font-size: clamp(2.2rem, 4vw, 3.2rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	background: var(--ufx-grad);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.ufx-counter__label {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ufx-muted);
}

.ufx-trust__quotes {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 18px;
	margin-bottom: clamp(48px, 6vw, 72px);
}

.ufx-quote {
	padding: 30px 28px;
}

.ufx-quote__text {
	font-family: var(--ufx-font-display);
	font-size: 1.08rem;
	line-height: 1.5;
	margin-bottom: 18px;
}

.ufx-quote__text::before { content: "“"; color: var(--ufx-cyan); }
.ufx-quote__text::after { content: "”"; color: var(--ufx-cyan); }

.ufx-quote__who {
	font-family: var(--ufx-font-mono);
	font-size: 11.5px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ufx-muted);
}

.ufx-trust__marquee {
	overflow: hidden;
	mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}

.ufx-trust__marquee-track {
	display: flex;
	gap: 14px;
	width: -moz-max-content;
	width: max-content;
	animation: ufx-marquee 32s linear infinite;
}

.ufx-trust__marquee:hover .ufx-trust__marquee-track {
	animation-play-state: paused;
}

.ufx-trust__chip {
	font-family: var(--ufx-font-mono);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ufx-muted);
	border: 1px solid var(--ufx-line);
	border-radius: 999px;
	padding: 10px 22px;
	white-space: nowrap;
}

/* ---------------------------------------------------------------------------
 * 11. Why Ufiny
 * ------------------------------------------------------------------------ */
.ufx-why__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 18px;
}

.ufx-pillar {
	padding: 28px 26px;
}

.ufx-pillar__title {
	font-family: var(--ufx-font-display);
	font-size: 1.12rem;
	font-weight: 600;
	margin-bottom: 10px;
	padding-left: 16px;
	position: relative;
}

.ufx-pillar__title::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.2em;
	bottom: 0.2em;
	width: 3px;
	border-radius: 3px;
	background: var(--ufx-grad);
}

.ufx-pillar__desc {
	color: var(--ufx-muted);
	font-size: 0.93rem;
}

/* ---------------------------------------------------------------------------
 * 12. Contact
 * ------------------------------------------------------------------------ */
.ufx-contact {
	text-align: center;
	overflow: hidden;
}

.ufx-contact__glow {
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	width: 70vmax;
	height: 40vmax;
	background: radial-gradient(ellipse at center, rgba(140, 91, 255, 0.16), transparent 60%);
	pointer-events: none;
}

.ufx-contact .ufx-eyebrow { margin-inline: auto; }
.ufx-contact .ufx-h2,
.ufx-contact .ufx-lede { margin-inline: auto; }

.ufx-contact__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	justify-content: center;
	margin-bottom: clamp(48px, 6vw, 72px);
}

.ufx-contact__details {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 18px;
	max-width: 880px;
	margin-inline: auto;
	text-align: left;
}

.ufx-contact__item {
	border: 1px solid var(--ufx-line);
	border-radius: var(--ufx-radius);
	background: var(--ufx-panel);
	padding: 24px 26px;
}

.ufx-contact__key {
	display: block;
	font-family: var(--ufx-font-mono);
	font-size: 10.5px;
	letter-spacing: 0.26em;
	color: var(--ufx-cyan);
	margin-bottom: 10px;
}

.ufx-contact__val {
	font-family: var(--ufx-font-display);
	font-size: 1.02rem;
	font-style: normal;
	line-height: 1.55;
	color: var(--ufx-white);
}

a.ufx-contact__val:hover {
	color: var(--ufx-cyan);
}

/* ---------------------------------------------------------------------------
 * 13. Footer
 * ------------------------------------------------------------------------ */
.ufx-footer {
	position: relative;
	border-top: 1px solid var(--ufx-line);
	padding: clamp(64px, 8vw, 110px) 0 40px;
	overflow: hidden;
}

.ufx-footer__bg {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(60% 90% at 10% 110%, rgba(61, 123, 255, 0.12), transparent 60%),
		radial-gradient(50% 80% at 90% 120%, rgba(140, 91, 255, 0.12), transparent 60%);
	animation: ufx-footer-breathe 9s ease-in-out infinite alternate;
	pointer-events: none;
}

.ufx-footer__inner {
	position: relative;
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr;
	gap: 36px;
	margin-bottom: 56px;
}

.ufx-footer__logo {
	font-family: var(--ufx-font-display);
	font-size: 1.7rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-bottom: 14px;
}

.ufx-footer__tag {
	color: var(--ufx-muted);
	max-width: 32ch;
	margin-bottom: 18px;
}

.ufx-footer__sys {
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	color: rgba(67, 255, 166, 0.7);
}

.ufx-footer__head {
	display: block;
	font-family: var(--ufx-font-mono);
	font-size: 11px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--ufx-muted);
	margin-bottom: 16px;
}

.ufx-footer__col ul {
	display: grid;
	gap: 10px;
}

.ufx-footer__col a {
	color: rgba(237, 241, 247, 0.78);
	font-size: 0.94rem;
	transition: color 0.25s;
}

.ufx-footer__col a:hover { color: var(--ufx-cyan); }

.ufx-footer__base {
	position: relative;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	padding-top: 26px;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	font-size: 0.82rem;
	color: var(--ufx-muted);
}

.ufx-footer__made {
	font-family: var(--ufx-font-mono);
	font-size: 0.74rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

/* ---------------------------------------------------------------------------
 * 14. Keyframes
 * ------------------------------------------------------------------------ */
@keyframes ufx-grad-pan {
	from { background-position: 0% 50%; }
	to { background-position: 100% 50%; }
}

@keyframes ufx-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: 0.45; transform: scale(0.82); }
}

@keyframes ufx-drift {
	from { transform: translate3d(0, 0, 0) scale(1); }
	to { transform: translate3d(8vmax, -6vmax, 0) scale(1.15); }
}

@keyframes ufx-blink {
	50% { opacity: 0; }
}

@keyframes ufx-scrollcue {
	0% { transform: translateY(0); opacity: 1; }
	70% { transform: translateY(12px); opacity: 0; }
	100% { transform: translateY(0); opacity: 0; }
}

@keyframes ufx-spin {
	to { transform: rotate(360deg); }
}

@keyframes ufx-think {
	0%, 100% { transform: translateY(0); opacity: 0.4; }
	50% { transform: translateY(-4px); opacity: 1; }
}

@keyframes ufx-marquee {
	to { transform: translateX(-50%); }
}

@keyframes ufx-footer-breathe {
	from { opacity: 0.7; }
	to { opacity: 1; }
}

/* ---------------------------------------------------------------------------
 * 15. Responsive
 * ------------------------------------------------------------------------ */
@media (max-width: 1024px) {
	.ufx-footer__inner {
		grid-template-columns: 1fr 1fr;
	}
	.ufx-console__main {
		grid-template-columns: 1fr;
	}
	.ufx-console__chartwrap {
		border-right: 0;
		border-bottom: 1px solid var(--ufx-line);
	}
}

@media (max-width: 720px) {
	.ufx { font-size: 16px; }

	.ufx-hud--bl,
	.ufx-hud--br { display: none; }

	.ufx-hero { padding-top: 96px; }
	.ufx-hero__scrollcue { display: none; }

	.ufx-transform__head { display: none; }

	.ufx-transform__row {
		grid-template-columns: 1fr;
		gap: 6px;
		text-align: left;
		padding: 20px 22px;
	}

	.ufx-transform__arrow { justify-content: flex-start; }
	.ufx-transform__arrow svg { transform: rotate(90deg); width: 28px; }
	.ufx-transform__new { text-align: left; }

	.ufx-kpi { border-right: 0; border-bottom: 1px solid var(--ufx-line); }
	.ufx-kpi:last-child { border-bottom: 0; }

	.ufx-agents__rail { padding-bottom: 24px; }
	.ufx-agent { flex-basis: 280px; }

	.ufx-footer__inner { grid-template-columns: 1fr; gap: 28px; }
	.ufx-footer__base { flex-direction: column; }
}

/* Mobile: agents rail falls back to native swipe scrolling */
@media (max-width: 900px), (pointer: coarse) {
	.ufx-agents__pin {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}
	.ufx-agents__pin::-webkit-scrollbar { display: none; }
}

/* ---------------------------------------------------------------------------
 * 16. Reduced motion — disable all non-essential animation
 * ------------------------------------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
	.ufx *,
	.ufx *::before,
	.ufx *::after {
		animation-duration: 0.001s !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001s !important;
	}

	.ufx-js [data-reveal],
	.ufx-js [data-stagger],
	.ufx-js [data-hero-fade] {
		opacity: 1;
		transform: none;
	}

	.ufx-js .ufx-split-word > span {
		transform: none;
	}

	.ufx-cursor,
	.ufx-cursor__ring,
	.ufx-hero__canvas {
		display: none;
	}
}
