:root {
	--bg: #05060a;
	--bg2: #070812;
	--panel: rgba(255, 255, 255, .06);
	--panel2: rgba(255, 255, 255, .085);
	--stroke: rgba(255, 255, 255, .12);
	--text: rgba(255, 255, 255, .94);
	--muted: rgba(255, 255, 255, .68);
	--faint: rgba(255, 255, 255, .48);
	--shadow: 0 24px 80px rgba(0, 0, 0, .58);
	--shadow2: 0 14px 42px rgba(0, 0, 0, .45);
	--r: 28px;
	--r2: 18px;
	--max: 1180px;
	--ease: cubic-bezier(.2, .8, .2, 1);
	--blue: 0 140 255;
	--green: 106 255 179;
	--amber: 255 214 102;
	--danger: 255 123 123;
	--focus: 0 0 0 4px rgba(0, 140, 255, .28);
	--success-bg: rgba(106, 255, 179, .12);
	--success-border: 1px solid rgba(106, 255, 179, .24);
	--success-text: rgba(255, 255, 255, .9);
	--error-bg: rgba(255, 123, 123, .12);
	--error-border: 1px solid rgba(255, 123, 123, .28);
	--error-text: rgb(var(--danger));
}

* {
	box-sizing: border-box
}

html {
	scroll-behavior: smooth;
	background: var(--bg)
}

body {
	margin: 0;
	font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
	color: var(--text);
	background:
		radial-gradient(1200px 800px at 15% 8%, rgba(255, 255, 255, .10), transparent 55%),
		radial-gradient(900px 700px at 85% 18%, rgba(0, 140, 255, .10), transparent 55%),
		radial-gradient(900px 900px at 55% 88%, rgba(255, 255, 255, .06), transparent 60%),
		linear-gradient(180deg, var(--bg), var(--bg2));
	overflow-x: hidden;
}

.hidden {
	display: none !important
}

a {
	color: inherit
}

.wrap {
	max-width: var(--max);
	margin: 0 auto;
	padding: 0 24px
}

.wrap.wide {
	max-width: 1320px
}

.skip {
	position: absolute;
	left: -9999px;
	top: 12px;
	background: #fff;
	color: #000;
	padding: 10px 12px;
	border-radius: 12px;
	z-index: 9999
}

.skip:focus {
	left: 24px
}

:focus-visible {
	outline: none;
	box-shadow: var(--focus);
	border-radius: 12px
}

.bg {
	position: fixed;
	inset: -40px;
	pointer-events: none;
	background:
		linear-gradient(to right, rgba(255, 255, 255, .05) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255, 255, 255, .04) 1px, transparent 1px);
	background-size: 86px 86px;
	mask-image: radial-gradient(circle at 40% 12%, #000 0, rgba(0, 0, 0, .35) 55%, transparent 75%);
	opacity: .22;
	transform: translateZ(0);
}

.siteHeader {
	position: sticky;
	top: 0;
	z-index: 70;
	backdrop-filter: blur(20px) saturate(160%);
	-webkit-backdrop-filter: blur(20px) saturate(160%);
	background: rgba(5, 6, 10, .68);
	border-bottom: 1px solid rgba(255, 255, 255, .10)
}

.nav {
	height: 64px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px
}

.brand {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	font-weight: 760;
	letter-spacing: -.02em
}

.logo,
.logo img {
	width: 34px;
	height: 34px;
	border-radius: 10px;
	display: block
}

.menu {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: var(--muted);
	white-space: nowrap
}

.menu a {
	text-decoration: none;
	padding: 9px 11px;
	border-radius: 999px;
	transition: background .25s var(--ease), color .25s var(--ease)
}

.menu a:hover {
	background: rgba(255, 255, 255, .07);
	color: var(--text)
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 12px 17px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .14);
	background: rgba(255, 255, 255, .08);
	color: var(--text);
	text-decoration: none;
	font-size: 13px;
	font-weight: 780;
	transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
	will-change: transform;
	cursor: pointer
}

.btn.small {
	padding: 9px 13px;
	font-size: 12px
}

.btn:hover {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, .12);
	border-color: rgba(255, 255, 255, .22);
	box-shadow: 0 16px 38px rgba(0, 0, 0, .38)
}

.btn.primary {
	background: linear-gradient(180deg, rgba(0, 140, 255, .34), rgba(0, 96, 255, .20));
	border-color: rgba(0, 140, 255, .42)
}

.btn.ghost {
	background: rgba(255, 255, 255, .055)
}

.dot {
	width: 9px;
	height: 9px;
	border-radius: 999px;
	background: rgb(var(--green));
	box-shadow: 0 0 0 6px rgba(106, 255, 179, .12)
}

main {
	padding-bottom: 40px
}

.hero {
	min-height: calc(100svh - 64px);
	display: grid;
	align-items: center;
	padding: 76px 0 52px;
	position: relative
}

.heroIntro {
	text-align: center;
	max-width: 980px;
	margin: 0 auto;
	position: relative;
	z-index: 2
}

.eyebrow,
.sectionLabel {
	margin: 0 0 14px;
	color: rgba(255, 255, 255, .58);
	font-size: 13px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .13em
}

.hero h1 {
	margin: 0 auto;
	font-size: clamp(48px, 8vw, 118px);
	line-height: .92;
	letter-spacing: -.075em;
	max-width: 1120px
}

.heroLead {
	margin: 26px auto 0;
	color: var(--muted);
	font-size: clamp(18px, 2vw, 26px);
	line-height: 1.35;
	letter-spacing: -.02em;
	max-width: 780px
}

.ctaRow {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	align-items: center
}

.ctaRow.center {
	justify-content: center;
	margin-top: 30px
}

.productStage {
	position: relative;
	height: 520px;
	margin: 34px auto 0;
	max-width: 1080px;
	perspective: 1200px
}

.stageGlow {
	position: absolute;
	inset: 70px 4% 0;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(0, 140, 255, .28), rgba(255, 255, 255, .06) 38%, transparent 70%);
	filter: blur(26px)
}

.browserMock {
	position: absolute;
	border-radius: 34px;
	border: 1px solid rgba(255, 255, 255, .16);
	background: linear-gradient(180deg, rgba(255, 255, 255, .11), rgba(255, 255, 255, .045));
	box-shadow: var(--shadow);
	overflow: hidden;
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px)
}

.mainMock {
	left: 50%;
	top: 18px;
	width: min(860px, 92vw);
	height: 440px;
	transform: translateX(-50%) rotateX(8deg);
	transform-origin: center bottom
}

.mockTop {
	height: 46px;
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 0 20px;
	border-bottom: 1px solid rgba(255, 255, 255, .10);
	background: rgba(0, 0, 0, .22)
}

.mockTop span {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .22)
}

.mockHero {
	margin: 34px auto 24px;
	width: 68%;
	height: 116px;
	border-radius: 28px;
	background: linear-gradient(135deg, rgba(255, 255, 255, .26), rgba(0, 140, 255, .16), rgba(255, 255, 255, .06));
	box-shadow: 0 24px 70px rgba(0, 140, 255, .18)
}

.mockLines {
	display: grid;
	gap: 13px;
	place-items: center
}

.mockLines i {
	display: block;
	height: 14px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .14)
}

.mockLines i:nth-child(1) {
	width: 62%
}

.mockLines i:nth-child(2) {
	width: 47%
}

.mockLines i:nth-child(3) {
	width: 35%
}

.mockCards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	padding: 34px
}

.mockCards b {
	height: 96px;
	border-radius: 22px;
	background: rgba(0, 0, 0, .22);
	border: 1px solid rgba(255, 255, 255, .10)
}

.floatingMetric {
	position: absolute;
	border-radius: 20px;
	border: 1px solid rgba(255, 255, 255, .14);
	background: rgba(255, 255, 255, .075);
	box-shadow: var(--shadow2);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	padding: 14px 16px;
	z-index: 4
}

.floatingMetric strong {
	display: block;
	font-size: 16px;
	letter-spacing: -.02em
}

.floatingMetric span {
	display: block;
	margin-top: 4px;
	color: var(--muted);
	font-size: 12px
}

.metricOne {
	left: 6%;
	top: 88px
}

.metricTwo {
	right: 8%;
	top: 150px
}

.metricThree {
	left: 18%;
	bottom: 46px
}

section {
	padding: 72px 0
}

.cinema {
	padding-top: 100px
}

.giant {
	margin: 0 0 28px;
	font-size: clamp(42px, 7vw, 96px);
	line-height: .96;
	letter-spacing: -.06em;
	max-width: 940px
}

.sectionHead {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 22px;
	flex-wrap: wrap;
	margin-bottom: 22px
}

.sectionHead h2 {
	margin: 0;
	font-size: clamp(34px, 5vw, 68px);
	line-height: .98;
	letter-spacing: -.055em
}

.sectionHead p {
	margin: 0;
	color: var(--muted);
	max-width: 560px;
	line-height: 1.55;
	font-size: 17px
}

.highlightGrid {
	display: grid;
	grid-template-columns: 1.25fr .75fr;
	gap: 16px
}

.highlightGrid .large {
	grid-row: span 2;
	min-height: 430px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end
}

.grid3 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px
}

.grid2 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px
}

.card,
.panel {
	border-radius: var(--r);
	border: 1px solid rgba(255, 255, 255, .11);
	background: linear-gradient(180deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .035));
	box-shadow: 0 16px 44px rgba(0, 0, 0, .35);
	position: relative;
	overflow: hidden
}

.card {
	padding: 24px;
	transition: transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease)
}

.card:before {
	content: "";
	position: absolute;
	inset: -1px;
	background: radial-gradient(420px 220px at 20% 0%, rgba(255, 255, 255, .11), transparent 70%);
	opacity: .75;
	pointer-events: none
}

.card>* {
	position: relative
}

.card:hover {
	transform: translateY(-3px);
	border-color: rgba(255, 255, 255, .18);
	background: linear-gradient(180deg, rgba(255, 255, 255, .085), rgba(255, 255, 255, .045))
}

.featureCard h3 {
	margin: 0 0 12px;
	font-size: clamp(28px, 4vw, 58px);
	line-height: 1;
	letter-spacing: -.055em
}

.featureCard:not(.large) h3 {
	font-size: clamp(24px, 3vw, 38px)
}

.featureCard p,
.card p {
	margin: 0;
	color: var(--muted);
	line-height: 1.58;
	font-size: 15px
}

.k {
	font-size: 12px;
	color: var(--faint);
	letter-spacing: .08em;
	text-transform: uppercase;
	font-weight: 850;
	margin-bottom: 12px
}

.serviceCard {
	min-height: 360px
}

.serviceCard h3 {
	margin: 10px 0 10px;
	font-size: 22px;
	line-height: 1.12;
	letter-spacing: -.03em
}

.iconOrb {
	width: 48px;
	height: 48px;
	border-radius: 16px;
	display: grid;
	place-items: center;
	margin-bottom: 28px;
	border: 1px solid rgba(0, 140, 255, .25);
	background: rgba(0, 140, 255, .12);
	font-weight: 900;
	color: rgba(255, 255, 255, .82)
}

.list {
	margin: 16px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 9px;
	color: var(--muted);
	font-size: 14px
}

.list li {
	display: flex;
	gap: 10px;
	align-items: flex-start
}

.check {
	width: 20px;
	height: 20px;
	border-radius: 999px;
	display: grid;
	place-items: center;
	background: rgba(106, 255, 179, .12);
	border: 1px solid rgba(106, 255, 179, .24);
	flex: 0 0 auto;
	margin-top: 1px;
	color: rgba(255, 255, 255, .9)
}

.splitFeature {
	border-top: 1px solid rgba(255, 255, 255, .10);
	border-bottom: 1px solid rgba(255, 255, 255, .10);
	background: rgba(0, 0, 0, .12);
	padding: 98px 0
}

.splitWrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	align-items: center
}

.copyBlock h2 {
	margin: 0;
	font-size: clamp(38px, 5vw, 76px);
	line-height: .97;
	letter-spacing: -.06em
}

.copyBlock p {
	color: var(--muted);
	font-size: 18px;
	line-height: 1.55;
	max-width: 620px
}

.specList {
	display: grid;
	gap: 12px;
	margin-top: 24px
}

.specList div {
	border-radius: 18px;
	border: 1px solid rgba(255, 255, 255, .10);
	background: rgba(255, 255, 255, .04);
	padding: 16px
}

.specList strong {
	display: block
}

.specList span {
	display: block;
	color: var(--muted);
	font-size: 14px;
	margin-top: 5px;
	line-height: 1.45
}

.performanceVisual,
.kiirusVisual {
	min-height: 520px;
	border-radius: var(--r);
	/*
    border: 1px solid rgba(255,255,255,.12);
    background: radial-gradient(circle at 50% 35%,rgba(0,140,255,.24),transparent 45%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
    box-shadow: var(--shadow);
  */
	display: grid;
	place-items: center;
	position: relative;
	overflow: hidden
}

.scoreRing {
	width: 250px;
	height: 250px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	align-content: center;
	border: 1px solid rgba(255, 255, 255, .18);
	background: conic-gradient(rgba(0, 140, 255, .85), rgba(106, 255, 179, .75), rgba(255, 255, 255, .13), rgba(0, 140, 255, .85));
	box-shadow: 0 0 80px rgba(0, 140, 255, .20)
}

.scoreRing:before {
	content: "";
	position: absolute;
	width: 210px;
	height: 210px;
	border-radius: 50%;
	background: rgba(5, 6, 10, .86);
	border: 1px solid rgba(255, 255, 255, .10)
}

.scoreRing span,
.scoreRing small {
	position: relative
}

.scoreRing span {
	font-size: 56px;
	font-weight: 950;
	letter-spacing: -.06em
}

.scoreRing small {
	color: var(--muted);
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: .14em
}

/* iOS fix: keep score ring layers locked together */
.scoreRing {
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
  isolation: isolate;
}

.scoreRing::before {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

/* optional: less huge empty space on mobile */
@media (max-width: 560px) {
  .performanceVisual,
  .kiirusVisual {
    min-height: 300px;
  }
}

.perfBars {
	position: absolute;
	left: 34px;
	right: 34px;
	bottom: 34px;
	display: grid;
	gap: 10px
}

.perfBars i {
	display: block;
	width: var(--w);
	height: 12px;
	border-radius: 999px;
	background: linear-gradient(90deg, rgba(0, 140, 255, .82), rgba(106, 255, 179, .58))
}

.showcase {
	background: rgba(0, 0, 0, .10)
}

.showGrid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	align-items: start
}

.sticky {
	position: sticky;
	top: 92px;
	border-radius: var(--r);
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, .12);
	background: rgba(0, 0, 0, .22);
	box-shadow: var(--shadow2);
	min-height: 520px
}

.stickyInner {
	min-height: 520px;
	display: grid;
	place-items: center;
	padding: 28px
}

.deviceStack {
	position: relative;
	width: min(430px, 90%);
	height: 390px
}

.device {
	position: absolute;
	border-radius: 34px;
	border: 1px solid rgba(255, 255, 255, .14);
	background: linear-gradient(180deg, rgba(255, 255, 255, .10), rgba(255, 255, 255, .04));
	box-shadow: var(--shadow2)
}

.deviceBack {
	inset: 40px 10px 0 80px;
	transform: rotate(8deg);
	opacity: .55
}

.deviceFront {
	inset: 0 70px 30px 0;
	transform: rotate(-5deg);
	padding: 18px
}

.deviceHeader {
	height: 24px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .13);
	margin-bottom: 20px
}

.deviceHero {
	height: 130px;
	border-radius: 24px;
	background: radial-gradient(circle at 30% 20%, rgba(255, 255, 255, .24), transparent 48%), rgba(0, 140, 255, .16);
	margin-bottom: 18px
}

.deviceRows {
	display: grid;
	gap: 10px
}

.deviceRows i {
	height: 12px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .13)
}

.deviceRows i:nth-child(2) {
	width: 80%
}

.deviceRows i:nth-child(3) {
	width: 60%
}

.steps {
	display: grid;
	gap: 14px;
	padding-bottom: 40px
}

.step {
	padding: 24px;
	border-radius: 22px;
	border: 1px solid rgba(255, 255, 255, .12);
	background: rgba(255, 255, 255, .04);
	transition: transform .35s var(--ease), border-color .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease)
}

.step strong {
	display: block;
	font-size: 22px;
	letter-spacing: -.03em
}

.step span {
	display: block;
	margin-top: 8px;
	color: var(--muted);
	line-height: 1.58;
	font-size: 15px
}

.step.is-active {
	border-color: rgba(0, 140, 255, .38);
	box-shadow: 0 22px 50px rgba(0, 140, 255, .13);
	transform: translateY(-2px);
	background: rgba(0, 140, 255, .085)
}

.priceGrid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px
}

.priceCard {
	min-height: 300px
}

.priceCard h3 {
	margin: 0 0 14px;
	font-size: 24px;
	letter-spacing: -.03em
}

.priceCard h3 span {
	font-size: clamp(54px, 7vw, 92px);
	letter-spacing: -.07em
}

.priceLine {
	margin-top: 20px;
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	align-items: center;
	color: var(--muted);
	font-size: 14px
}

.tag {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 11px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .12);
	background: rgba(255, 255, 255, .04);
	color: var(--text);
	font-weight: 850;
	font-size: 12.5px;
	white-space: nowrap
}

.contactPanel {
	padding: 28px
}

.contactIntro {
	text-align: center;
	max-width: 680px;
	margin: 0 auto 24px
}

.contactIntro h2 {
	margin: 0;
	font-size: clamp(34px, 5vw, 64px);
	line-height: 1;
	letter-spacing: -.055em
}

.contactIntro p {
	margin: 14px 0 0;
	color: var(--muted);
	line-height: 1.55
}

form {
	display: grid;
	gap: 12px
}

.row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px
}

.hp {
	position: absolute;
	left: -9999px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden
}

label {
	display: block;
	font-size: 12.5px;
	color: var(--faint);
	margin: 0 0 6px
}

input,
textarea,
select {
	width: 100%;
	padding: 13px 13px;
	border-radius: 15px;
	border: 1px solid rgba(255, 255, 255, .12);
	background: rgba(0, 0, 0, .26);
	color: var(--text);
	outline: none;
	transition: border-color .2s var(--ease), background .2s var(--ease)
}

input:focus,
textarea:focus,
select:focus {
	border-color: rgba(0, 140, 255, .45);
}

textarea {
	min-height: 124px;
	resize: vertical
}

.hint {
	font-size: 12.5px;
	color: var(--faint);
	line-height: 1.45
}

.link {
	font-size: 13px;
	color: rgba(120, 190, 255, .96);
	text-decoration: none;
	font-weight: 800
}

.link:hover {
	text-decoration: underline
}

.notice {
	font-size: 12.5px;
	line-height: 1.45;
	padding: 10px 12px;
	border-radius: 13px;
	border: 1px solid rgba(255, 255, 255, .10);
	background: rgba(255, 255, 255, .04)
}

.notice.success {
	background-color: var(--success-bg);
	border: var(--success-border);
	color: var(--success-text)
}

.notice.error {
	background-color: var(--error-bg) !important;
	border: var(--error-border) !important;
	color: var(--error-text) !important
}

.submitRow {
	display: flex;
	gap: 12px;
	align-items: center;
	flex-wrap: wrap;
	margin-top: 4px
}

details {
	border-radius: var(--r);
	border: 1px solid rgba(255, 255, 255, .10);
	background: rgba(255, 255, 255, .035);
	padding: 17px 18px
}

details+details {
	margin-top: 10px
}

summary {
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	font-weight: 850;
	font-size: 15px
}

summary::-webkit-details-marker {
	display: none
}

summary:after {
	content: "+";
	color: var(--faint);
	font-size: 18px;
	line-height: 18px;
}

details[open] summary:after {
	content: "–"
}

details p {
	margin: 12px 0 0;
	color: var(--muted);
	line-height: 1.7;
	font-size: 14px
}

footer {
	padding: 36px 0 60px;
	border-top: 1px solid rgba(255, 255, 255, .10);
	color: var(--faint)
}

.foot {
	display: flex;
	justify-content: space-between;
	gap: 18px;
	flex-wrap: wrap;
	align-items: center;
	font-size: 13px
}

.footMeta {
	display: flex;
	gap: 14px;
	flex-wrap: wrap
}

.reveal {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity .8s var(--ease), transform .8s var(--ease)
}

.reveal.in {
	opacity: 1;
	transform: translateY(0)
}

@media (max-width:980px) {
	.menu {
		display: none
	}

  .navActions .btn.small {
		display: none
	}

	.hero {
		min-height: auto;
		padding: 64px 0 28px
	}

	.hero h1 {
		font-size: clamp(44px, 14vw, 82px)
	}

	.productStage {
		height: 430px
	}

	.mainMock {
		height: 360px
	}

	.floatingMetric {
		display: none
	}

	.highlightGrid,
	.grid3,
	.grid2,
	.splitWrap,
	.showGrid,
	.priceGrid {
		grid-template-columns: 1fr
	}

	.highlightGrid .large {
		min-height: 340px
	}

	.sticky {
		position: relative;
		top: auto;
		min-height: 420px
	}

	.stickyInner {
		min-height: 420px
	}

	.performanceVisual,
  .kiirusVisual {
		min-height: 420px
	}

	.row {
		grid-template-columns: 1fr
	}

	.sectionHead h2,
	.copyBlock h2,
	.giant {
		letter-spacing: -.045em
	}
}

@media (max-width:560px) {
	.wrap {
		padding: 0 16px
	}

	.nav {
		height: 60px
	}

	.brand span:last-child {
		display: none
	}

	.btn.small {
		padding: 9px 11px
	}

	.heroLead {
		font-size: 17px
	}

	.ctaRow.center {
		align-items: stretch
	}

	.ctaRow.center .btn {
		width: 100%
	}

	.productStage {
		height: 330px;
		margin-top: 20px
	}

	.mainMock {
		height: 290px;
		border-radius: 24px
	}

	.mockHero {
		height: 76px
	}

	.mockCards {
		padding: 20px;
		gap: 9px
	}

	.mockCards b {
		height: 62px;
		border-radius: 16px
	}

	section {
		padding: 52px 0
	}

	.card {
		padding: 20px
	}

	.featureCard h3,
	.featureCard:not(.large) h3 {
		font-size: 30px
	}

	.serviceCard {
		min-height: auto
	}

	.priceCard h3 span {
		font-size: 58px
	}

	.scoreRing {
		width: 210px;
		height: 210px
	}

	.scoreRing:before {
		width: 174px;
		height: 174px
	}

	.scoreRing span {
		font-size: 46px
	}

	.footMeta {
		gap: 8px;
		display: grid
	}
}

@media (prefers-reduced-motion:reduce) {
	html {
		scroll-behavior: auto
	}

	.bg {
		display: none
	}

	.reveal {
		opacity: 1;
		transform: none;
		transition: none
	}

	.card,
	.btn,
	.step {
		transition: none
	}

	.mainMock {
		transform: translateX(-50%)
	}
}

/* Fixes: language toggle, select arrow, cleaner checks, smooth FAQ, equal card heights */
.navActions {
	display: flex;
	align-items: center;
	gap: 10px;
	flex: 0 0 auto;
}

.langSwitch {
	display: inline-flex;
	align-items: center;
	gap: 3px;
	padding: 3px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .12);
	background: rgba(255, 255, 255, .055);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
}

.langSwitch a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	min-height: 30px;
	padding: 0 10px;
	border-radius: 999px;
	color: var(--muted);
	text-decoration: none;
	font-size: 11px;
	font-weight: 850;
	letter-spacing: .04em;
	transition: background .22s var(--ease), color .22s var(--ease), box-shadow .22s var(--ease);
}

.langSwitch a:hover {
	color: var(--text);
	background: rgba(255, 255, 255, .07);
}

.langSwitch a.is-active {
	color: #fff;
	background: rgba(255, 255, 255, .14);
	box-shadow: 0 8px 22px rgba(0, 0, 0, .24);
}

/* Equal heights for cards next to each other */
.grid3,
.grid2,
.priceGrid,
.highlightGrid {
	align-items: stretch;
}

.grid3>.card,
.grid2>.card,
.priceGrid>.card,
.highlightGrid>.card {
	height: 100%;
}

.serviceCard,
.priceCard,
.featureCard {
	display: flex;
	flex-direction: column;
}

.serviceCard .list,
.priceCard .priceLine {
	margin-top: auto;
	padding-top: 18px;
}

/* Better select arrow spacing */
select {
	appearance: none;
	-webkit-appearance: none;
	padding-right: 46px;
	background-image:
		linear-gradient(45deg, transparent 50%, rgba(255, 255, 255, .72) 50%),
		linear-gradient(135deg, rgba(255, 255, 255, .72) 50%, transparent 50%);
	background-position:
		calc(100% - 23px) 52%,
		calc(100% - 17px) 52%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
}

select::-ms-expand {
	display: none;
}

/* Cleaner check icons */
.check {
	width: 22px;
	height: 22px;
	font-size: 0;
	color: transparent;
	background: linear-gradient(180deg, rgba(106, 255, 179, .22), rgba(106, 255, 179, .08));
	border: 1px solid rgba(106, 255, 179, .36);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .16), 0 8px 20px rgba(106, 255, 179, .08);
}

.check::before {
	content: "";
	margin-left: 1px;
	margin-top: 3px;
	width: 9px;
	height: 5px;
	border-left: 2px solid rgba(255, 255, 255, .92);
	border-bottom: 2px solid rgba(255, 255, 255, .92);
	transform: rotate(-45deg) translateY(-1px);
}

/* Smooth FAQ accordion */
details {
	overflow: hidden;
	transition: border-color .22s var(--ease), background .22s var(--ease);
}

details[open] {
	border-color: rgba(255, 255, 255, .16);
	background: rgba(255, 255, 255, .048);
}

summary:after {
	width: 28px;
	height: 28px;
	display: grid;
	place-items: center;
	border-radius: 999px;
	background: rgba(255, 255, 255, .06);
	transition: transform .26s var(--ease), background .26s var(--ease), color .26s var(--ease);
}

details[open] summary:after {
	transform: rotate(180deg);
	background: rgba(0, 140, 255, .14);
	color: rgba(255, 255, 255, .9);
}

.faqContent {
	height: 0;
	overflow: hidden;
	opacity: 0;
	transition: height .34s var(--ease), opacity .22s var(--ease);
}

details[open] .faqContent {
	opacity: 1;
}

.faqContent p {
	margin: 12px 0 0;
}

@media (max-width:980px) {
	.navActions {
		gap: 8px
	}

	.langSwitch a {
		min-width: 38px;
		min-height: 28px;
		padding: 0 8px
	}
}

/* Mobile menu only */
.mobileMenuToggle {
	display: none;
	width: 42px;
	height: 42px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .14);
	background: rgba(255, 255, 255, .07);
	color: var(--text);
	cursor: pointer;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 5px;
	padding: 0;
	transition: background .22s var(--ease), border-color .22s var(--ease), transform .22s var(--ease);
}

.mobileMenuToggle:hover {
	background: rgba(255, 255, 255, .11);
	border-color: rgba(255, 255, 255, .22);
}

.mobileMenuToggle span {
	width: 17px;
	height: 2px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .9);
	transition: transform .28s var(--ease), opacity .22s var(--ease);
}

.mobileMenuToggle.is-open span:first-child {
	transform: translateY(3.5px) rotate(45deg);
}

.mobileMenuToggle.is-open span:last-child {
	transform: translateY(-3.5px) rotate(-45deg);
}

.mobileMenu {
	position: absolute;
	top: calc(100% + 10px);
	left: 24px;
	right: 24px;
	z-index: 80;
	opacity: 0;
	transform: translateY(-10px) scale(.985);
	transform-origin: top center;
	pointer-events: none;
	transition: opacity .28s var(--ease), transform .28s var(--ease);
}

.mobileMenu.is-open {
	opacity: 1;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

.mobileMenuInner {
	display: grid;
	gap: 6px;
	padding: 10px;
	border-radius: 24px;
	border: 1px solid rgba(255, 255, 255, .12);
	background: rgba(8, 9, 15, .92);
	box-shadow: 0 24px 70px rgba(0, 0, 0, .58);
	backdrop-filter: blur(22px) saturate(160%);
	-webkit-backdrop-filter: blur(22px) saturate(160%);
}

.mobileMenuInner>a:not(.btn) {
	display: flex;
	align-items: center;
	min-height: 46px;
	padding: 0 14px;
	border-radius: 16px;
	color: var(--text);
	text-decoration: none;
	font-size: 15px;
	font-weight: 780;
	letter-spacing: -.02em;
	transition: background .22s var(--ease), transform .22s var(--ease);
}

.mobileMenuInner>a:not(.btn):hover {
	background: rgba(255, 255, 255, .075);
	transform: translateX(2px);
}

.mobileMenuDivider {
	height: 1px;
	margin: 6px 4px;
	background: rgba(255, 255, 255, .10);
}

.mobileMenuLang {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
}

.mobileMenuLang a {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, .10);
	background: rgba(255, 255, 255, .045);
	color: var(--muted);
	text-decoration: none;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: .05em;
}

.mobileMenuLang a.is-active {
	color: #fff;
	background: rgba(255, 255, 255, .14);
}

.mobileMenuCta {
	width: 100%;
	margin-top: 4px;
}

@media (max-width:980px) {
	.siteHeader .wrap.wide {
		position: relative;
	}

	.mobileMenuToggle {
		display: inline-flex;
		flex: 0 0 auto;
	}

	.navActions {
		margin-left: auto;
	}
}

@media (max-width:640px) {
	.mobileMenu {
		left: 16px;
		right: 16px;
	}
}

@media (min-width:981px) {
	.mobileMenu {
		display: none !important;
	}
}