:root {
	--ink: #111820;
	--muted: #56616d;
	--subtle: #7b8792;
	--line: #d9e2e8;
	--paper: #f7faf8;
	--paper-warm: #fff8eb;
	--white: #ffffff;
	--deep: #08212a;
	--deep-2: #103947;
	--mint: #dff4eb;
	--sky: #dcecff;
	--accent: #0f8a65;
	--accent-dark: #0b614a;
	--hot: #111820;
	--hot-dark: #2f3a43;
	--warm: #f0b72f;
	--shadow-soft: 0 28px 80px rgba(17, 32, 44, .10);
	--shadow-tight: 0 14px 34px rgba(17, 32, 44, .08);
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--white);
	color: var(--ink);
	font-family: "Inter", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 16px;
	line-height: 1.7;
	text-rendering: optimizeLegibility;
}

a {
	color: inherit;
}

img,
video {
	display: block;
	max-width: 100%;
}

.site-header,
.site-footer,
.hero,
.section,
.trust-strip {
	padding-inline: max(28px, calc((100vw - 1180px) / 2));
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 22px;
	min-height: 74px;
	border-bottom: 1px solid rgba(217, 226, 232, .9);
	background: rgba(255, 255, 255, .94);
	backdrop-filter: blur(16px);
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--ink);
	font-weight: 900;
	text-decoration: none;
	white-space: nowrap;
}

.brand-icon {
	display: inline-block;
	width: 28px;
	height: 28px;
	flex: 0 0 auto;
	object-fit: contain;
	border-radius: 0;
}

nav,
.primary-nav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 14px;
	font-size: 13px;
}

nav a {
	color: var(--muted);
	text-decoration: none;
}

nav a:hover,
nav a:focus {
	color: var(--ink);
}

.nav-cta {
	min-height: 38px;
	padding: 6px 14px;
	border-radius: 7px;
	background: var(--hot);
	color: var(--white);
	font-weight: 800;
}

.nav-cta:hover,
.nav-cta:focus {
	background: var(--hot-dark);
	color: var(--white);
}

.hero {
	position: relative;
	overflow: hidden;
	min-height: calc(100svh - 74px);
	padding-block: clamp(84px, 10vh, 132px) clamp(64px, 8vh, 104px);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, .98) 0%, rgba(247, 250, 248, .98) 100%);
}

.hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	align-items: start;
	gap: clamp(54px, 7vh, 86px);
}

.hero-copy {
	display: grid;
	justify-items: center;
	max-width: 880px;
	margin-inline: auto;
	text-align: center;
}

.eyebrow {
	margin: 0 0 14px;
	color: var(--accent);
	font-size: 13px;
	font-weight: 900;
	letter-spacing: 0;
	text-transform: none;
}

h1,
h2,
h3 {
	margin: 0;
	color: var(--ink);
	line-height: 1.08;
	letter-spacing: 0;
}

h1 {
	max-width: 940px;
	font-size: clamp(46px, 5vw, 78px);
}

.hero h1 {
	word-break: keep-all;
}

.hero h1 span {
	display: block;
}

h2 {
	font-size: 44px;
}

h3 {
	font-size: 28px;
}

.lead {
	max-width: 710px;
	margin: 24px 0 0;
	color: var(--muted);
	font-size: 19px;
}

.measure {
	max-width: 720px;
	margin: 20px 0 0;
	color: var(--muted);
	font-size: 18px;
}

.actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px;
	margin-top: 32px;
}

.hero-badges {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0;
	margin: 22px 0 0;
	padding: 0;
	color: var(--subtle);
	font-size: 14px;
	list-style: none;
}

.hero-badges li {
	display: inline-flex;
	align-items: center;
	min-height: 24px;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: inherit;
	font-size: 13px;
	font-weight: 760;
}

.hero-badges li + li::before {
	padding-inline: 10px;
	color: #b5c0c8;
	content: "/";
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	padding: 0 22px;
	border: 1px solid var(--line);
	border-radius: 7px;
	background: var(--white);
	color: var(--ink);
	text-decoration: none;
	font-weight: 850;
}

.button.primary {
	border-color: var(--hot);
	background: var(--hot);
	color: var(--white);
	box-shadow: 0 14px 30px rgba(17, 24, 32, .14);
}

.button.primary:hover,
.button.primary:focus {
	background: var(--hot-dark);
	color: var(--white);
}

.button.subtle:hover,
.button.subtle:focus {
	border-color: var(--ink);
}

.button.full {
	width: 100%;
}

.hero-product {
	position: relative;
	width: min(940px, 100%);
	margin-inline: auto;
	min-width: 0;
}

.browser-frame {
	overflow: hidden;
	margin: 0;
	border: 1px solid rgba(17, 32, 44, .10);
	border-radius: 8px;
	background: var(--white);
	box-shadow: var(--shadow-soft);
}

.browser-bar {
	display: flex;
	align-items: center;
	gap: 7px;
	height: 31px;
	padding-left: 14px;
	border-bottom: 1px solid var(--line);
	background: #f6f9fb;
}

.browser-bar span {
	display: block;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: #b8c6d0;
}

.browser-bar span:first-child {
	background: #ef6960;
}

.browser-bar span:nth-child(2) {
	background: #f0bf45;
}

.browser-bar span:nth-child(3) {
	background: #60bf76;
}

.hero-preview {
	transform: none;
}

.hero-preview-motion {
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
}

.hero-preview img,
.hero-preview video {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: contain;
	object-position: center;
	background: transparent;
}

.tour-frame img,
.detail-visual img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	object-position: top center;
}

.hero-motion-video {
	display: block;
	border: 0;
	border-radius: 0;
	background: transparent;
}

.hero-note {
	position: absolute;
	display: inline-flex;
	align-items: center;
	min-height: 42px;
	padding: 8px 14px;
	border: 1px solid rgba(8, 33, 42, .12);
	border-radius: 999px;
	background: rgba(255, 255, 255, .92);
	color: var(--deep);
	font-size: 14px;
	font-weight: 850;
	box-shadow: var(--shadow-tight);
}

.hero-note.one {
	top: -18px;
	left: 28px;
}

.hero-note.two {
	right: 22px;
	bottom: -22px;
	background: var(--deep);
	color: var(--white);
}

.trust-strip {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 48px;
	padding-block: 66px;
	border-block: 0;
	background: var(--white);
}

.trust-strip > div {
	display: grid;
	gap: 6px;
	min-height: 0;
	padding: 0;
	border-left: 0;
}

.trust-strip strong {
	color: var(--ink);
	font-size: 18px;
}

.trust-strip span {
	color: var(--muted);
}

.section {
	padding-block: 106px;
}

.section-heading {
	max-width: 720px;
}

.section-heading.center {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-inline: auto;
	text-align: center;
}

.section-heading.narrow {
	max-width: 800px;
}

.workflow-band {
	display: grid;
	grid-template-columns: minmax(0, .75fr) minmax(0, 1fr);
	gap: 72px;
	background: #fbfdfb;
}

.flow-lines {
	display: grid;
	border-top: 1px solid var(--line);
}

.flow-line {
	display: grid;
	grid-template-columns: 70px minmax(0, 1fr);
	gap: 24px;
	padding: 25px 0;
	border-bottom: 1px solid var(--line);
}

.flow-line > span {
	color: var(--accent);
	font-size: 15px;
	font-weight: 900;
}

.flow-line strong {
	display: block;
	color: var(--ink);
	font-size: 22px;
	line-height: 1.25;
}

.flow-line p {
	max-width: 560px;
	margin: 8px 0 0;
	color: var(--muted);
}

.screen-lab {
	background: var(--white);
}

.tour-grid {
	display: grid;
	grid-template-columns: 310px minmax(0, 1fr);
	align-items: start;
	gap: 34px;
	margin-top: 46px;
}

.tour-menu {
	display: grid;
	gap: 10px;
}

.tour-menu-item {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	gap: 14px;
	width: 100%;
	padding: 18px 16px;
	border: 1px solid transparent;
	border-radius: 8px;
	background: transparent;
	color: inherit;
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.tour-menu-item > span {
	color: var(--subtle);
	font-size: 13px;
	font-weight: 900;
}

.tour-menu-item strong {
	display: block;
	color: var(--ink);
	font-weight: 900;
}

.feature-badge {
	display: inline-flex;
	align-items: center;
	margin-left: 8px;
	padding: 2px 7px;
	border: 1px solid var(--accent);
	border-radius: 999px;
	color: var(--accent-dark);
	font-size: 11px;
	font-weight: 900;
	line-height: 1.35;
	vertical-align: 2px;
	white-space: nowrap;
}

.tour-menu-item p {
	margin: 4px 0 0;
	color: var(--muted);
	font-size: 14px;
	line-height: 1.5;
}

.tour-menu-item.active,
.tour-menu-item:hover,
.tour-menu-item:focus {
	border-color: var(--line);
	background: var(--white);
	box-shadow: 0 10px 24px rgba(17, 32, 44, .06);
}

.tour-frame img {
	transition: opacity .18s ease, transform .18s ease;
}

.tour-frame img.is-changing {
	opacity: .55;
	transform: translateY(4px);
}

figcaption {
	padding: 16px 18px 18px;
	border-top: 1px solid var(--line);
	color: var(--muted);
	font-size: 14px;
}

.split {
	display: grid;
	grid-template-columns: minmax(0, .9fr) minmax(0, 1fr);
	align-items: start;
	gap: 72px;
}

.steps {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: step;
	border-top: 1px solid rgba(255, 255, 255, .18);
}

.steps li {
	position: relative;
	padding: 24px 0 24px 68px;
	border-bottom: 1px solid rgba(255, 255, 255, .18);
	counter-increment: step;
	font-size: 18px;
}

.steps li::before {
	position: absolute;
	top: 22px;
	left: 0;
	width: 42px;
	height: 42px;
	border: 1px solid rgba(255, 255, 255, .32);
	border-radius: 50%;
	color: var(--warm);
	content: counter(step);
	display: grid;
	place-items: center;
	font-size: 14px;
	font-weight: 900;
}

.detail-stack {
	display: grid;
	gap: 54px;
	background: var(--white);
}

.detail-row {
	display: grid;
	grid-template-columns: minmax(0, .75fr) minmax(0, 1fr);
	align-items: center;
	gap: 56px;
}

.detail-row:nth-of-type(2n + 1) .detail-copy {
	order: 2;
}

.detail-row:nth-of-type(2n + 1) .detail-visual {
	order: 1;
}

.detail-copy {
	max-width: 530px;
}

.detail-number {
	display: inline-flex;
	margin-bottom: 16px;
	color: var(--accent);
	font-size: 14px;
	font-weight: 900;
}

.detail-copy p,
.price-panel p,
details p,
.legal p {
	color: var(--muted);
}

.detail-copy p {
	margin: 16px 0 0;
	font-size: 18px;
}

.check-list {
	display: grid;
	gap: 10px;
	margin: 22px 0 0;
	padding: 0;
	list-style: none;
}

.check-list li {
	position: relative;
	padding-left: 24px;
	color: var(--muted);
}

.check-list li::before {
	position: absolute;
	top: .72em;
	left: 0;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--accent);
	content: "";
}

.comparison-section {
	background: #fbf7ef;
}

.comparison-wrap {
	overflow: hidden;
	margin-top: 42px;
	border: 1px solid rgba(17, 32, 44, .12);
	border-radius: 8px;
	background: var(--white);
	box-shadow: var(--shadow-tight);
}

table {
	width: 100%;
	border-collapse: collapse;
}

th,
td {
	padding: 18px 20px;
	border-bottom: 1px solid var(--line);
	text-align: left;
	vertical-align: top;
}

thead th {
	background: #f7faf8;
	color: var(--ink);
	font-size: 14px;
}

tbody th {
	width: 36%;
	color: var(--ink);
	font-weight: 850;
}

td {
	color: var(--muted);
}

tr:last-child th,
tr:last-child td {
	border-bottom: 0;
}

.visual-section {
	background: var(--white);
}

.demo-video {
	display: grid;
	grid-template-columns: minmax(0, .7fr) minmax(0, 1fr);
	align-items: center;
	gap: 54px;
}

.demo-video p {
	max-width: 620px;
	color: var(--muted);
}

.demo-video video {
	width: 100%;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #000;
	box-shadow: var(--shadow-tight);
}

.pricing-section {
	display: grid;
	grid-template-columns: minmax(0, .9fr) minmax(360px, .55fr);
	gap: 70px;
	background: linear-gradient(135deg, rgba(8, 33, 42, .98), rgba(16, 57, 71, .96));
}

.pricing-section h2,
.pricing-section .price-panel strong {
	color: var(--white);
}

.pricing-section .measure,
.pricing-section .price-panel p,
.pricing-section .check-list li {
	color: #c6d4d9;
}

.pricing-section .eyebrow {
	color: var(--warm);
}

.price-panel {
	padding: 34px;
	border: 1px solid rgba(255, 255, 255, .16);
	border-radius: 8px;
	background: rgba(255, 255, 255, .08);
	box-shadow: 0 24px 70px rgba(0, 0, 0, .22);
}

.price-panel > span {
	display: block;
	color: #c6d4d9;
	font-size: 14px;
	font-weight: 850;
}

.price-panel strong {
	display: block;
	margin-top: 8px;
	font-size: 72px;
	line-height: 1;
}

.price-panel .button {
	margin-top: 28px;
}

.faq {
	display: grid;
	grid-template-columns: minmax(0, .55fr) minmax(0, 1fr);
	gap: 70px;
	background: var(--paper);
}

.faq-list {
	display: grid;
	gap: 12px;
}

details {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: var(--white);
}

summary {
	padding: 18px 20px;
	color: var(--ink);
	font-weight: 850;
	cursor: pointer;
}

details p {
	margin: 0;
	padding: 0 20px 20px;
}

.legal {
	min-height: 60vh;
	max-width: none;
	background: var(--white);
}

.legal h1 {
	max-width: 900px;
	font-size: 52px;
}

.legal h1,
.legal-meta,
.legal-lead,
.legal-section {
	max-width: 900px;
	margin-inline: auto;
}

.legal-meta {
	margin: 18px auto 0;
	color: var(--accent);
	font-size: 14px;
	font-weight: 900;
}

.legal-lead {
	max-width: 820px;
	margin: 24px auto 48px;
	color: var(--muted);
	font-size: 19px;
}

.legal-section {
	padding: 34px 0;
	border-top: 1px solid var(--line);
}

.legal-section h2 {
	font-size: 25px;
	line-height: 1.25;
}

.legal-section p,
.legal-section li {
	color: var(--muted);
}

.legal-section p {
	max-width: none;
	margin: 14px 0 0;
}

.legal-section ul {
	display: grid;
	gap: 10px;
	max-width: none;
	margin: 18px 0 0;
	padding-left: 1.25rem;
}

.legal-section li::marker {
	color: var(--accent);
}

.legal-definition-list {
	display: grid;
	grid-template-columns: minmax(180px, .32fr) 1fr;
	margin: 20px 0 0;
	border-top: 1px solid var(--line);
}

.legal-definition-list dt,
.legal-definition-list dd {
	padding: 16px 0;
	border-bottom: 1px solid var(--line);
}

.legal-definition-list dt {
	color: var(--ink);
	font-weight: 850;
}

.legal-definition-list dd {
	margin: 0;
	color: var(--muted);
}

.legal-definition-list dd p {
	margin: 0;
}

.legal-definition-list dd p + p {
	margin-top: 8px;
}

.agency-page {
	min-height: 60vh;
	background: var(--white);
}

.agency-intro,
.agency-form,
.agency-notice {
	max-width: 760px;
	margin-inline: auto;
}

.agency-intro h1 {
	max-width: 760px;
	font-size: 48px;
}

.agency-notice {
	margin-top: 28px;
	padding: 16px 0;
	border-top: 1px solid #e7b2b2;
	border-bottom: 1px solid #e7b2b2;
	color: #9a2323;
	font-weight: 800;
}

.agency-form {
	display: grid;
	gap: 22px;
	margin-top: 34px;
	padding-top: 34px;
	border-top: 1px solid var(--line);
}

.agency-form label {
	display: grid;
	gap: 8px;
	color: var(--ink);
	font-weight: 850;
}

.agency-form input {
	min-height: 48px;
	width: 100%;
	border: 1px solid var(--line);
	border-radius: 7px;
	padding: 0 14px;
	background: var(--white);
	color: var(--ink);
	font: inherit;
}

.agency-form input:focus {
	border-color: var(--accent);
	outline: 3px solid rgba(15, 138, 101, .16);
}

.agency-form input[aria-invalid="true"] {
	border-color: #bd3434;
}

.agency-form-actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px 18px;
	padding-top: 8px;
	color: var(--muted);
}

.agency-form-actions span {
	font-size: 14px;
}

.agency-terms {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 16px;
	max-width: 760px;
	margin: 28px auto 0;
	padding-top: 22px;
	border-top: 1px solid var(--line);
	color: var(--muted);
	font-size: 13px;
	line-height: 1.6;
}

.agency-terms span {
	flex-basis: 100%;
	color: var(--ink);
	font-weight: 750;
}

.agency-terms a {
	color: var(--accent-dark);
	font-weight: 750;
}

.site-footer {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 32px;
	min-height: 148px;
	padding-block: 38px;
	border-top: 1px solid var(--line);
	background: var(--white);
	color: var(--muted);
	font-size: 14px;
}

.site-footer > div {
	display: grid;
	gap: 4px;
}

.site-footer strong {
	color: var(--ink);
}

@media (max-width: 1040px) {
	.hero-grid,
	.workflow-band,
	.split,
	.detail-row,
	.demo-video,
	.pricing-section,
	.faq {
		grid-template-columns: 1fr;
	}

	.hero-grid {
		gap: 42px;
	}

	.hero-copy {
		max-width: 820px;
	}

	.hero-product {
		max-width: 820px;
	}

	.detail-row:nth-of-type(2n + 1) .detail-copy,
	.detail-row:nth-of-type(2n + 1) .detail-visual {
		order: initial;
	}

	.tour-grid {
		grid-template-columns: 1fr;
	}

	.tour-menu {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 760px) {
	.site-header,
	.site-footer {
		display: grid;
		gap: 14px;
		padding-block: 18px;
	}

	.primary-nav {
		gap: 12px 14px;
	}

	.hero,
	.section {
		padding-block: 72px;
	}

	h1 {
		font-size: 36px;
		line-height: 1.14;
	}

	h2 {
		font-size: 34px;
	}

	h3 {
		font-size: 24px;
	}

	.lead,
	.measure,
	.detail-copy p {
		font-size: 17px;
	}

	.hero-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.actions {
		display: grid;
		width: 100%;
		max-width: 320px;
	}

	.button {
		width: 100%;
	}

	.hero-badges {
		display: grid;
		gap: 4px;
	}

	.hero-badges li {
		justify-content: center;
	}

	.hero-badges li + li::before {
		content: none;
	}

	.hero-note {
		position: static;
		margin-top: 12px;
	}

	.hero-preview {
		transform: none;
	}

	.trust-strip {
		grid-template-columns: 1fr;
	}

	.trust-strip > div {
		min-height: 0;
		border-left: 0;
		border-top: 0;
	}

	.trust-strip > div:first-child {
		border-top: 0;
	}

	.flow-line {
		grid-template-columns: 44px minmax(0, 1fr);
		gap: 14px;
	}

	.tour-menu {
		grid-template-columns: 1fr;
	}

	.price-panel {
		padding: 28px 22px;
	}

	.price-panel strong {
		font-size: 58px;
	}

	.comparison-wrap {
		overflow: visible;
		border: 0;
		background: transparent;
		box-shadow: none;
	}

	table,
	thead,
	tbody,
	tr,
	th,
	td {
		display: block;
	}

	thead {
		display: none;
	}

	tr {
		margin-bottom: 12px;
		border: 1px solid var(--line);
		border-radius: 8px;
		background: var(--white);
		overflow: hidden;
	}

	tbody th,
	td {
		width: auto;
		padding: 14px 16px;
		border-bottom: 1px solid var(--line);
	}

	td::before {
		display: block;
		margin-bottom: 4px;
		color: var(--accent);
		content: attr(data-label);
		font-size: 12px;
		font-weight: 900;
	}

	.legal h1 {
		font-size: 38px;
	}

	.legal h1,
	.legal-meta,
	.legal-lead,
	.legal-section {
		margin-inline: 0;
	}

	.legal-definition-list {
		grid-template-columns: 1fr;
	}

	.legal-definition-list dt {
		padding-bottom: 4px;
		border-bottom: 0;
	}

	.legal-definition-list dd {
		padding-top: 0;
	}
}

/* Minimal vertical storefront refresh. */
:root {
	--ink: #101418;
	--muted: #59636d;
	--subtle: #808a93;
	--line: #e7edf1;
	--paper: #fafbfb;
	--paper-warm: #fbf7ef;
	--white: #ffffff;
	--accent: #0f7a5f;
	--accent-dark: #0b5e49;
	--hot: #101418;
	--hot-dark: #2f353b;
	--warm: #b58113;
	--shadow-soft: 0 26px 70px rgba(16, 20, 24, .08);
	--shadow-tight: 0 16px 40px rgba(16, 20, 24, .06);
}

body {
	background: var(--white);
	color: var(--ink);
}

.site-header,
.site-footer,
.hero,
.section,
.trust-strip {
	padding-inline: max(32px, calc((100vw - 1120px) / 2));
}

.site-header {
	min-height: 72px;
	border-bottom-color: rgba(231, 237, 241, .92);
	background: rgba(255, 255, 255, .92);
}

.brand {
	font-weight: 850;
}

.footer-brand {
	display: inline-flex;
	align-items: center;
	gap: 9px;
}

.footer-brand .brand-icon {
	width: 24px;
	height: 24px;
	border-radius: 0;
}

.nav-cta,
.button,
.browser-frame,
.tour-menu-item,
.comparison-wrap,
.price-panel,
details {
	border-radius: 6px;
}

.hero {
	min-height: 0;
	padding-block: clamp(46px, 6vh, 72px) clamp(28px, 4vh, 48px);
	background: var(--white);
}

.hero-grid {
	gap: clamp(24px, 3.4vh, 38px);
}

.hero-copy {
	max-width: 790px;
}

.eyebrow {
	margin-bottom: 18px;
	color: var(--accent);
	font-size: 12px;
	font-weight: 850;
}

.hero h1 {
	font-size: clamp(42px, 4.6vw, 64px);
}

h1 {
	max-width: 860px;
	font-size: clamp(44px, 5vw, 72px);
	line-height: 1.09;
}

h2 {
	font-size: clamp(34px, 3.4vw, 54px);
	line-height: 1.12;
}

h3 {
	font-size: clamp(24px, 2.2vw, 32px);
}

.lead {
	max-width: 650px;
	margin-top: 28px;
	color: #47515b;
	font-size: 18px;
	line-height: 1.9;
}

.hero .lead {
	margin-top: 22px;
	line-height: 1.75;
}

.measure {
	max-width: 650px;
	color: var(--muted);
	font-size: 17px;
	line-height: 1.9;
}

.hero-badges {
	margin-top: 22px;
	color: var(--subtle);
}

.hero-badges li {
	font-size: 13px;
	font-weight: 700;
}

.actions {
	margin-top: 28px;
	gap: 12px;
}

.button {
	min-height: 48px;
	padding-inline: 22px;
	box-shadow: none;
}

.button.primary {
	box-shadow: none;
}

.hero-product {
	display: block;
	width: min(840px, 100%);
}

.browser-frame {
	border-color: rgba(16, 20, 24, .10);
	box-shadow: none;
}

.hero-preview-motion {
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	box-shadow: none;
}

.hero-motion-video {
	border: 0;
	border-radius: 0;
	background: transparent;
}

.hero-preview img,
.hero-preview video {
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: contain;
	object-position: center;
}

.trust-strip {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	max-width: 980px;
	margin-inline: auto;
	padding-block: 52px;
	background: var(--white);
}

.trust-strip > div {
	grid-template-columns: minmax(190px, .35fr) minmax(0, 1fr);
	align-items: baseline;
	gap: 28px;
	padding: 28px 0;
	border-top: 1px solid var(--line);
}

.trust-strip > div:last-child {
	border-bottom: 1px solid var(--line);
}

.trust-strip strong {
	font-size: 18px;
	line-height: 1.35;
}

.trust-strip span {
	max-width: 650px;
	line-height: 1.85;
}

.section {
	padding-block: clamp(112px, 13vw, 168px);
}

.section-heading,
.section-heading.narrow {
	max-width: 760px;
	margin-inline: auto;
	text-align: center;
}

.workflow-band {
	display: block;
	background: var(--paper);
}

.flow-lines {
	max-width: 920px;
	margin: 58px auto 0;
	background: transparent;
}

.flow-line {
	grid-template-columns: 76px minmax(0, 1fr);
	gap: 30px;
	padding: 32px 0;
}

.flow-line > span {
	color: var(--subtle);
	font-size: 13px;
}

.flow-line strong {
	font-size: 24px;
}

.flow-line p {
	max-width: 660px;
	line-height: 1.85;
}

.screen-lab {
	background: var(--white);
}

.tour-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 42px;
	max-width: 1040px;
	margin: 64px auto 0;
}

.tour-menu {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	max-width: 760px;
	margin-inline: auto;
	border-top: 1px solid var(--line);
}

.tour-menu-item {
	grid-template-columns: 54px minmax(0, 1fr);
	padding: 22px 0;
	border: 0;
	border-bottom: 1px solid var(--line);
	background: transparent;
	box-shadow: none;
}

.tour-menu-item.active,
.tour-menu-item:hover,
.tour-menu-item:focus {
	border-color: var(--line);
	background: transparent;
	box-shadow: none;
}

.tour-menu-item.active strong,
.tour-menu-item:hover strong,
.tour-menu-item:focus strong {
	color: var(--accent-dark);
}

.tour-menu-item p {
	max-width: 540px;
}

.tour-frame {
	max-width: 1040px;
	margin-inline: auto;
	box-shadow: var(--shadow-soft);
}

figcaption {
	padding: 18px 22px 22px;
	font-size: 14px;
	line-height: 1.7;
}

.comparison-section {
	background: var(--paper);
}

.comparison-wrap {
	max-width: 980px;
	margin: 60px auto 0;
	border: 0;
	border-top: 1px solid var(--line);
	background: transparent;
	box-shadow: none;
}

th,
td {
	padding: 22px 4px;
	border-bottom-color: var(--line);
}

thead th {
	background: transparent;
	color: var(--subtle);
	font-size: 13px;
}

tbody th {
	width: 38%;
	font-weight: 800;
}

.pricing-section {
	display: grid;
	grid-template-columns: 1fr;
	justify-items: center;
	gap: 54px;
	background: var(--white);
	text-align: center;
}

.pricing-copy {
	max-width: 720px;
}

.pricing-section h2,
.pricing-section .price-panel strong {
	color: var(--ink);
}

.pricing-section .measure,
.pricing-section .price-panel p,
.pricing-section .check-list li {
	color: var(--muted);
}

.pricing-section .eyebrow {
	color: var(--accent);
}

.price-panel {
	width: min(560px, 100%);
	padding: 0;
	border: 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	background: transparent;
	box-shadow: none;
	text-align: left;
}

.price-panel > span {
	padding-top: 34px;
	color: var(--subtle);
}

.price-panel strong {
	margin-top: 10px;
	font-size: clamp(64px, 8vw, 92px);
	letter-spacing: 0;
}

.price-panel .button {
	margin-bottom: 34px;
}

.faq {
	display: grid;
	grid-template-columns: 1fr;
	gap: 48px;
	background: var(--paper);
}

.faq-list {
	width: min(900px, 100%);
	margin-inline: auto;
	border-top: 1px solid var(--line);
}

details {
	border: 0;
	border-bottom: 1px solid var(--line);
	background: transparent;
}

summary {
	padding: 24px 0;
}

details p {
	padding: 0 0 24px;
	line-height: 1.85;
}

.site-footer {
	min-height: 132px;
	padding-block: 42px;
}

@media (max-width: 1040px) {
	.tour-menu {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 760px) {
	.site-header,
	.site-footer,
	.hero,
	.section,
	.trust-strip {
		padding-inline: 22px;
	}

	.site-header {
		flex-wrap: wrap;
		gap: 10px 14px;
	}

	.brand {
		min-width: 0;
		max-width: 100%;
	}

	.brand span {
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.primary-nav {
		max-width: 100%;
	}

	.hero {
		padding-block: 48px 36px;
	}

	.hero-grid {
		gap: 28px;
	}

	.hero h1,
	h1 {
		font-size: 36px;
	}

	.hero-preview img,
	.hero-preview video {
		height: auto;
	}

	h2 {
		font-size: 31px;
	}

	.lead,
	.measure {
		font-size: 16px;
		line-height: 1.85;
	}

	.trust-strip {
		padding-block: 74px;
	}

	.trust-strip > div {
		grid-template-columns: 1fr;
		gap: 8px;
		padding: 24px 0;
	}

	.section {
		padding-block: 86px;
	}

	.flow-lines,
	.tour-grid,
	.comparison-wrap {
		margin-top: 42px;
	}

	.flow-line {
		grid-template-columns: 42px minmax(0, 1fr);
		gap: 16px;
		padding: 26px 0;
	}

	.flow-line strong {
		font-size: 20px;
	}

	.tour-menu-item {
		grid-template-columns: 40px minmax(0, 1fr);
		padding: 20px 0;
	}

	.price-panel {
		width: 100%;
	}

	.price-panel strong {
		font-size: 64px;
	}

	.comparison-wrap tr {
		margin: 0;
		border: 0;
		border-bottom: 1px solid var(--line);
		border-radius: 0;
		background: transparent;
		overflow: visible;
	}

	.comparison-wrap tbody th,
	.comparison-wrap td {
		padding: 12px 0;
		border-bottom: 0;
	}

	.comparison-wrap tbody th {
		padding-top: 20px;
	}

	.comparison-wrap td:last-child {
		padding-bottom: 20px;
	}

	.comparison-wrap td::before {
		margin-bottom: 2px;
		color: var(--subtle);
		font-size: 11px;
	}
}

/* Final layout corrections after the minimal storefront refresh. */
.trust-strip {
	width: min(1120px, calc(100% - 64px));
	max-width: none;
	padding-inline: 0;
}

.trust-strip > div {
	grid-template-columns: minmax(240px, .28fr) minmax(0, 1fr);
	gap: 42px;
}

.trust-strip span {
	max-width: none;
}

.tour-menu {
	max-width: 1040px;
}

@media (min-width: 761px) {
	.tour-grid {
		grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
		align-items: start;
		max-width: 1120px;
		gap: 52px;
	}

	.tour-menu {
		grid-template-columns: 1fr;
		max-width: none;
		border-top: 1px solid var(--line);
		border-bottom: 1px solid var(--line);
	}

	.tour-menu-item {
		grid-template-columns: 54px minmax(0, 1fr);
		align-content: start;
		gap: 18px;
		padding: 22px 0;
		border-right: 0;
		border-bottom: 1px solid var(--line);
	}

	.tour-menu-item:last-child {
		border-bottom: 0;
	}

	.tour-menu-item p {
		max-width: none;
	}

	.tour-frame {
		max-width: none;
		margin-inline: 0;
	}
}

@media (max-width: 760px) {
	.trust-strip {
		width: auto;
		padding-inline: 22px;
	}

	.trust-strip > div {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.tour-menu {
		grid-template-columns: 1fr;
		border-bottom: 0;
	}

	.tour-menu-item {
		grid-template-columns: 40px minmax(0, 1fr);
		padding: 20px 0;
		border-right: 0;
		border-bottom: 1px solid var(--line);
	}
}

.visual-section {
	background: var(--white);
}

.demo-video {
	display: block;
	width: min(1040px, 100%);
	margin: 58px auto 0;
}

.demo-video video {
	width: 100%;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
}

@media (max-width: 760px) {
	.demo-video {
		margin-top: 38px;
	}
}

/* Difference management section. */
.difference-section {
	background: var(--white);
}

.difference-layout {
	display: grid;
	grid-template-columns: minmax(0, .82fr) minmax(0, 1fr);
	gap: 72px;
	width: min(1120px, 100%);
	margin-inline: auto;
}

.difference-rules {
	border-top: 1px solid var(--line);
}

.difference-rule {
	display: grid;
	grid-template-columns: 56px minmax(0, 1fr);
	gap: 24px;
	padding: 24px 0;
	border-bottom: 1px solid var(--line);
}

.difference-rule > span {
	color: var(--accent);
	font-size: 13px;
	font-weight: 900;
	letter-spacing: .12em;
}

.difference-rule strong {
	display: block;
	margin-bottom: 8px;
	color: var(--ink);
	font-size: 20px;
	line-height: 1.35;
}

.difference-rule p {
	margin: 0;
	color: var(--muted);
	line-height: 1.85;
}

.difference-flow {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	width: min(1120px, 100%);
	margin: 62px auto 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.difference-flow-item {
	min-height: 132px;
	padding: 24px 28px;
	border-right: 1px solid var(--line);
}

.difference-flow-item:last-child {
	border-right: 0;
}

.difference-flow-item strong,
.difference-flow-item span {
	display: block;
}

.difference-flow-item strong {
	margin-bottom: 10px;
	color: var(--ink);
	font-size: 18px;
	line-height: 1.35;
}

.difference-flow-item span {
	color: var(--muted);
	line-height: 1.75;
}

.metric-strip {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	width: min(1120px, calc(100% - 64px));
	margin: 0 auto;
	padding-block: 34px;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	background: var(--white);
}

.metric-strip > div {
	display: grid;
	gap: 6px;
	padding-inline: 28px;
	border-right: 1px solid var(--line);
}

.metric-strip > div:last-child {
	border-right: 0;
}

.metric-strip strong {
	color: var(--ink);
	font-size: clamp(28px, 3.2vw, 46px);
	line-height: 1;
}

.metric-strip span {
	color: var(--muted);
	font-size: 14px;
	line-height: 1.55;
}

.marketing-hero {
	padding: clamp(92px, 11vh, 132px) max(28px, calc((100vw - 1040px) / 2)) clamp(68px, 9vh, 108px);
	background: linear-gradient(180deg, #f7fbfa 0%, var(--white) 100%);
	text-align: center;
}

.marketing-hero h1 {
	max-width: 840px;
	margin-inline: auto;
}

.marketing-hero .lead {
	margin-inline: auto;
}

.product-summary {
	background: var(--white);
	padding-top: clamp(48px, 6vw, 76px);
}

.product-summary-grid {
	display: grid;
	grid-template-columns: minmax(0, .72fr) minmax(0, 1fr);
	gap: 64px;
	align-items: start;
	width: min(1120px, 100%);
	margin-inline: auto;
}

.product-summary-grid .section-heading {
	margin-inline: 0;
	text-align: left;
}

.product-summary-grid .measure {
	margin-inline: 0;
}

.product-visual img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	object-position: top center;
}

.feature-ledger {
	width: min(1040px, 100%);
	margin: 62px auto 0;
	border-top: 1px solid var(--line);
}

.feature-ledger-row {
	display: grid;
	grid-template-columns: 72px minmax(210px, .5fr) minmax(0, 1fr);
	gap: 30px;
	align-items: start;
	padding: 28px 0;
	border-bottom: 1px solid var(--line);
}

.feature-ledger-row > span:first-child {
	color: var(--accent);
	font-size: 13px;
	font-weight: 900;
	letter-spacing: .12em;
}

.feature-ledger-row strong {
	color: var(--ink);
	font-size: 22px;
	line-height: 1.35;
}

.feature-ledger-row > span:last-child {
	color: var(--muted);
	line-height: 1.8;
}

.product-process {
	background: var(--paper);
}

.process-list {
	display: grid;
	gap: 0;
	width: min(860px, 100%);
	margin: 54px auto 0;
	padding: 0;
	list-style: none;
	counter-reset: process;
	border-top: 1px solid var(--line);
}

.process-list li {
	position: relative;
	padding: 24px 0 24px 76px;
	border-bottom: 1px solid var(--line);
	color: var(--ink);
	counter-increment: process;
	font-size: 18px;
	line-height: 1.7;
}

.process-list li::before {
	position: absolute;
	top: 24px;
	left: 0;
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border: 1px solid var(--line);
	border-radius: 50%;
	color: var(--accent);
	content: counter(process);
	font-size: 13px;
	font-weight: 900;
}

.module-index,
.product-usecases {
	background: var(--paper);
}

.module-links {
	width: min(1060px, 100%);
	margin: 58px auto 0;
	border-top: 1px solid var(--line);
}

.module-link {
	display: grid;
	grid-template-columns: 72px minmax(190px, .42fr) minmax(0, 1fr);
	gap: 28px;
	align-items: start;
	padding: 26px 0;
	border-bottom: 1px solid var(--line);
	color: inherit;
	text-decoration: none;
}

.module-link > span,
.why-ledger > div > span {
	color: var(--accent);
	font-size: 13px;
	font-weight: 900;
	letter-spacing: .12em;
}

.module-link strong,
.why-ledger strong,
.usecase-ledger strong {
	color: var(--ink);
	line-height: 1.35;
}

.module-link strong {
	font-size: 22px;
}

.module-link em {
	color: var(--muted);
	font-style: normal;
	line-height: 1.75;
}

.module-link:hover strong,
.module-link:focus-visible strong,
.related-links a:hover,
.related-links a:focus-visible {
	color: var(--accent);
}

.usecase-section {
	background: var(--white);
}

.usecase-ledger {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	width: min(1040px, 100%);
	margin: 54px auto 0;
	border-top: 1px solid var(--line);
}

.usecase-ledger > div {
	display: grid;
	gap: 10px;
	min-height: 152px;
	padding: 26px 30px;
	border-bottom: 1px solid var(--line);
}

.usecase-ledger > div:nth-child(2n + 1) {
	border-right: 1px solid var(--line);
}

.usecase-ledger strong {
	font-size: 20px;
}

.usecase-ledger span {
	color: var(--muted);
	line-height: 1.75;
}

.why-ledger {
	width: min(1060px, 100%);
	margin: 58px auto 0;
	border-top: 1px solid var(--line);
}

.why-ledger > div {
	display: grid;
	grid-template-columns: 72px minmax(210px, .46fr) minmax(0, 1fr);
	gap: 28px;
	align-items: start;
	padding: 28px 0;
	border-bottom: 1px solid var(--line);
}

.why-ledger strong {
	font-size: 22px;
}

.why-ledger p {
	margin: 0;
	color: var(--muted);
	line-height: 1.8;
}

.product-page-faq {
	background: var(--white);
}

.product-page-faq .faq-list {
	width: min(920px, 100%);
}

.related-section {
	background: var(--paper);
}

.related-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px 28px;
	width: min(880px, 100%);
	margin: 40px auto 0;
	padding-block: 22px;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.related-links a {
	color: var(--ink);
	font-weight: 800;
	line-height: 1.4;
	text-decoration: none;
}

.compact-cta {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 42px;
	align-items: center;
	background: var(--deep);
}

.compact-cta h2 {
	color: var(--white);
}

.compact-cta .eyebrow {
	color: var(--warm);
}

.compact-cta .measure {
	color: #c6d4d9;
}

.risk-section {
	background: var(--paper);
}

.risk-layout {
	display: grid;
	grid-template-columns: minmax(0, .78fr) minmax(0, 1fr);
	gap: 72px;
	width: min(1120px, 100%);
	margin-inline: auto;
}

.risk-layout .section-heading {
	margin-inline: 0;
	text-align: left;
}

.risk-layout .measure {
	margin-inline: 0;
}

.risk-checks {
	border-top: 1px solid var(--line);
}

.risk-check {
	display: grid;
	grid-template-columns: 52px minmax(0, .55fr) minmax(0, 1fr);
	gap: 22px;
	align-items: start;
	padding: 24px 0;
	border-bottom: 1px solid var(--line);
}

.risk-check > span:first-child {
	color: var(--accent);
	font-size: 13px;
	font-weight: 900;
	letter-spacing: .12em;
}

.risk-check strong {
	color: var(--ink);
	font-size: 19px;
	line-height: 1.35;
}

.risk-check > span:last-child {
	color: var(--muted);
	line-height: 1.75;
}

.risk-note {
	width: min(1120px, 100%);
	margin: 44px auto 0;
	padding-top: 22px;
	border-top: 1px solid var(--line);
	color: var(--subtle);
	font-size: 14px;
	line-height: 1.75;
}

#screenshots,
#demo,
#pricing,
#faq {
	scroll-margin-top: 104px;
}

@media (max-width: 900px) {
	.difference-layout,
	.difference-flow,
	.risk-layout {
		grid-template-columns: 1fr;
	}

	.difference-layout,
	.risk-layout {
		gap: 42px;
	}

	.risk-check {
		grid-template-columns: 48px minmax(0, 1fr);
		gap: 8px 20px;
	}

	.risk-check > span:last-child {
		grid-column: 2;
	}

	.difference-flow-item {
		min-height: 0;
		border-right: 0;
		border-bottom: 1px solid var(--line);
	}

	.difference-flow-item:last-child {
		border-bottom: 0;
	}
}

@media (max-width: 760px) {
	.difference-rule {
		grid-template-columns: 42px minmax(0, 1fr);
		gap: 16px;
		padding: 22px 0;
	}

	.difference-rule strong {
		font-size: 19px;
	}

	.difference-flow {
		margin-top: 42px;
	}

	.difference-flow-item {
		padding: 22px 0;
	}

	.risk-check {
		grid-template-columns: 42px minmax(0, 1fr);
		gap: 6px 16px;
		padding: 22px 0;
	}

	.risk-check strong {
		font-size: 18px;
	}

	.risk-note {
		margin-top: 34px;
	}

	.metric-strip,
	.product-summary-grid,
	.feature-ledger-row,
	.module-link,
	.usecase-ledger,
	.why-ledger > div,
	.compact-cta {
		grid-template-columns: 1fr;
	}

	.metric-strip {
		width: auto;
		margin-inline: 22px;
		padding-block: 0;
	}

	.metric-strip > div {
		padding: 22px 0;
		border-right: 0;
		border-bottom: 1px solid var(--line);
	}

	.metric-strip > div:last-child {
		border-bottom: 0;
	}

	.marketing-hero {
		padding: 86px 22px 74px;
	}

	.feature-ledger {
		margin-top: 42px;
	}

	.product-summary-grid {
		gap: 36px;
	}

	.feature-ledger-row {
		gap: 8px;
		padding: 24px 0;
	}

	.feature-ledger-row strong,
	.feature-ledger-row > span:last-child {
		grid-column: 1;
	}

	.module-links,
	.usecase-ledger,
	.why-ledger {
		margin-top: 42px;
	}

	.module-link {
		gap: 8px;
		padding: 24px 0;
	}

	.module-link strong,
	.why-ledger strong {
		font-size: 20px;
	}

	.usecase-ledger > div {
		min-height: 0;
		padding: 24px 0;
		border-right: 0;
	}

	.usecase-ledger > div:nth-child(2n + 1) {
		border-right: 0;
	}

	.why-ledger > div {
		gap: 8px;
		padding: 24px 0;
	}

	.related-links {
		justify-content: flex-start;
		gap: 14px 22px;
	}

	.process-list {
		margin-top: 38px;
	}

	.process-list li {
		padding: 22px 0 22px 58px;
		font-size: 16px;
	}

	.process-list li::before {
		width: 36px;
		height: 36px;
	}

	.compact-cta {
		gap: 28px;
	}

	#screenshots,
	#demo,
	#pricing,
	#faq {
		scroll-margin-top: 190px;
	}
}

/* Headline scale and Japanese line-break refinement. */
.hero-copy {
	max-width: 1120px;
}

h1 {
	max-width: 820px;
	font-size: 54px;
	line-height: 1.12;
	line-break: strict;
	word-break: normal;
}

.hero h1 {
	max-width: 1120px;
	font-size: 50px;
	line-height: 1.12;
	line-break: strict;
	word-break: normal;
}

.hero h1 span,
.marketing-hero h1 span {
	display: block;
}

.mobile-break {
	display: none;
}

h2 {
	font-size: 40px;
	line-height: 1.15;
}

h3 {
	font-size: 24px;
}

.marketing-hero h1 {
	max-width: 760px;
	font-size: 46px;
	line-height: 1.16;
}

.metric-strip strong {
	font-size: 34px;
}

.price-panel strong {
	font-size: 68px;
}

.legal h1 {
	font-size: 42px;
}

.legal-section h2 {
	font-size: 22px;
}

@media (max-width: 760px) {
	h1,
	.hero h1,
	.marketing-hero h1 {
		font-size: 28px;
		line-height: 1.18;
	}

	.mobile-break {
		display: block;
	}

	h2 {
		font-size: 25px;
		line-height: 1.2;
	}

	h3 {
		font-size: 20px;
	}

	.metric-strip strong {
		font-size: 28px;
	}

	.price-panel strong {
		font-size: 48px;
	}

	.legal h1 {
		font-size: 31px;
	}

	.agency-intro h1 {
		font-size: 31px;
	}

	.legal-section h2 {
		font-size: 20px;
	}
}
