.app-page {
	background: #f4f7fb;
	color: #142033;
	overflow: hidden;
}

.app-page * {
	box-sizing: border-box;
}

.app-page p {
	color: #64738a;
	font-size: .23rem;
	line-height: .38rem;
}

.app-hero {
	position: relative;
	min-height: 6.2rem;
	padding: .68rem .26rem .5rem;
	color: #fff;
	background: linear-gradient(145deg, #071322 0%, #16364c 58%, #15786f 100%);
	overflow: hidden;
}

.sender-mobile .app-hero {
	background: linear-gradient(145deg, #071322 0%, #27425a 55%, #9a5d28 100%);
}

.app-hero:before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px);
	background-size: .56rem .56rem;
	opacity: .32;
}

.app-hero-content,
.app-hero-device {
	position: relative;
	z-index: 1;
}

.app-kicker,
.app-section-head span,
.app-qrcode-panel span,
.app-final-cta span {
	display: inline-block;
	color: #ffb76b;
	font-size: .18rem;
	line-height: .26rem;
	font-weight: 700;
	letter-spacing: 0;
}

.app-hero h1 {
	margin: .18rem 0 0;
	color: #fff;
	font-size: .48rem;
	line-height: .62rem;
	font-weight: 700;
}

.app-hero p {
	margin-top: .2rem;
	color: rgba(237, 248, 255, .9);
}

.app-tags {
	display: flex;
	flex-wrap: wrap;
	gap: .12rem;
	margin-top: .28rem;
}

.app-tags span {
	padding: .1rem .14rem;
	border: 1px solid rgba(255,255,255,.24);
	border-radius: .08rem;
	color: rgba(237, 248, 255, .9);
	font-size: .19rem;
	line-height: .26rem;
	background: rgba(255,255,255,.08);
}

.app-actions,
.app-final-actions {
	display: flex;
	gap: .16rem;
	margin-top: .34rem;
}

.app-actions a,
.app-final-actions a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.78rem;
	height: .72rem;
	border-radius: .08rem;
	font-size: .23rem;
	font-weight: 700;
}

.app-primary,
.app-final-actions a:first-child {
	color: #071322;
	background: #7df0d4;
}

.app-secondary,
.app-final-actions a:last-child {
	color: #fff;
	border: 1px solid rgba(255,255,255,.42);
	background: rgba(255,255,255,.08);
}

.app-hero-device {
	width: 3.05rem;
	margin: .36rem auto 0;
	padding: .12rem;
	border: 1px solid rgba(255,255,255,.18);
	border-radius: .08rem;
	background: rgba(255,255,255,.08);
}

.app-hero-device img {
	width: 100%;
	max-height: 3.5rem;
	object-fit: contain;
}

.download-hero {
	min-height: 5.6rem;
	padding-bottom: .46rem;
}

.download-hero-visual {
	position: relative;
	z-index: 1;
	margin: .34rem .08rem 0;
	padding: .16rem;
	border: 1px solid rgba(255,255,255,.16);
	border-radius: .08rem;
	background: rgba(255,255,255,.08);
}

.download-hero-visual img {
	width: 100%;
	max-height: 2.65rem;
	object-fit: contain;
}

.app-qrcode-panel {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 1.72rem;
	gap: .22rem;
	align-items: center;
	margin: -.3rem .26rem .22rem;
	padding: .28rem;
	border: 1px solid #dfe8f1;
	border-radius: .08rem;
	background: #fff;
	box-shadow: 0 .16rem .38rem rgba(22, 47, 82, .1);
	position: relative;
	z-index: 2;
}

.app-qrcode-panel h2 {
	margin: .08rem 0 .1rem;
	color: #132033;
	font-size: .31rem;
	line-height: .42rem;
	font-weight: 700;
}

.app-qrcode-panel p {
	font-size: .21rem;
	line-height: .34rem;
}

.app-qrcode-panel img {
	width: 1.72rem;
	height: 1.72rem;
	padding: .08rem;
	border: 1px solid #dbe6f0;
	border-radius: .08rem;
	background: #f8fbff;
}

.app-section {
	padding: .58rem .26rem;
	background: #fff;
	border-bottom: .12rem solid #f0f4f8;
}

.app-section-muted {
	background: #f8fbff;
}

.app-section-head {
	margin-bottom: .28rem;
}

.app-section-head h2,
.app-final-cta h2 {
	margin-top: .1rem;
	color: #132033;
	font-size: .34rem;
	line-height: .46rem;
	font-weight: 700;
}

.app-section-head p {
	margin-top: .14rem;
}

.download-grid {
	display: grid;
	gap: .18rem;
}

.download-card {
	display: grid;
	grid-template-columns: 1.08rem minmax(0, 1fr);
	gap: .22rem;
	align-items: start;
	padding: .26rem;
	border: 1px solid #dfe8f1;
	border-radius: .08rem;
	background: linear-gradient(180deg, #fff, #f8fbff);
	box-shadow: 0 .12rem .3rem rgba(22, 47, 82, .06);
}

.download-card-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.08rem;
	height: 1.08rem;
	border: 1px solid #e0eaf3;
	border-radius: .08rem;
	background: #fff;
}

.download-card-icon img {
	width: .72rem;
	height: .72rem;
	object-fit: contain;
}

.download-card-copy h3 {
	margin: 0;
	color: #132033;
	font-size: .27rem;
	line-height: .38rem;
	font-weight: 700;
}

.download-card-copy p {
	margin-top: .08rem;
	font-size: .21rem;
	line-height: .34rem;
}

.download-card-copy a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.72rem;
	height: .58rem;
	margin-top: .18rem;
	padding: 0 .22rem;
	border-radius: .08rem;
	color: #071322;
	background: #7df0d4;
	font-size: .21rem;
	font-weight: 700;
}

.app-metric-grid,
.app-flow-grid,
.app-scene-grid,
.app-faq-list {
	display: grid;
	gap: .16rem;
}

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

.app-metric-grid article,
.app-flow-grid article,
.app-faq-list article,
.app-feature,
.app-scene-grid article {
	border: 1px solid #dfe8f1;
	border-radius: .08rem;
	background: #fff;
	box-shadow: 0 .12rem .3rem rgba(22, 47, 82, .05);
}

.app-metric-grid article {
	padding: .26rem .18rem;
	text-align: center;
}

.app-metric-grid strong {
	display: block;
	color: #0d9288;
	font-size: .34rem;
	line-height: .42rem;
	font-weight: 700;
}

.app-metric-grid span {
	display: block;
	margin-top: .08rem;
	color: #607087;
	font-size: .2rem;
	line-height: .3rem;
}

.app-feature-list {
	display: grid;
	gap: .22rem;
}

.app-feature {
	overflow: hidden;
}

.app-feature-copy {
	padding: .28rem .26rem .08rem;
}

.app-feature-copy em {
	color: #0d9288;
	font-size: .2rem;
	font-weight: 700;
}

.app-feature-copy h3,
.app-flow-grid h3,
.app-scene-grid h3,
.app-faq-list h3 {
	margin-top: .08rem;
	color: #132033;
	font-size: .27rem;
	line-height: .38rem;
	font-weight: 700;
}

.app-feature-copy p,
.app-flow-grid p,
.app-scene-grid p,
.app-faq-list p {
	margin-top: .1rem;
	font-size: .21rem;
	line-height: .34rem;
}

.app-feature-copy ul {
	display: grid;
	gap: .08rem;
	margin-top: .18rem;
}

.app-feature-copy li {
	position: relative;
	padding-left: .24rem;
	color: #4f6178;
	font-size: .2rem;
	line-height: .32rem;
}

.app-feature-copy li:before {
	content: "";
	position: absolute;
	left: 0;
	top: .13rem;
	width: .1rem;
	height: .1rem;
	border-radius: 50%;
	background: #ff9f43;
}

.app-feature > img {
	width: 100%;
	max-height: 3.4rem;
	object-fit: contain;
	padding: .1rem .16rem .22rem;
	background: linear-gradient(180deg, #fff, #f6fbff);
}

.app-flow-grid article,
.app-faq-list article {
	padding: .26rem;
}

.app-flow-grid span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: .48rem;
	height: .48rem;
	border-radius: .08rem;
	color: #071322;
	background: #7df0d4;
	font-size: .24rem;
	font-weight: 700;
}

.app-section-dark {
	color: #fff;
	background: linear-gradient(145deg, #0d1828, #21444a);
	border-bottom: 0;
}

.sender-mobile .app-section-dark {
	background: linear-gradient(145deg, #0d1828, #56402c);
}

.app-section-dark .app-section-head h2,
.app-section-dark .app-scene-grid h3 {
	color: #fff;
}

.app-section-dark .app-section-head p,
.app-section-dark .app-scene-grid p {
	color: rgba(238, 248, 255, .78);
}

.app-scene-grid article {
	padding: .24rem;
	border-color: rgba(255,255,255,.16);
	background: rgba(255,255,255,.08);
	box-shadow: none;
}

.app-faq {
	background: #fff;
}

.app-final-cta {
	padding: .58rem .26rem .7rem;
	color: #fff;
	background: linear-gradient(145deg, #102033, #1c5159);
}

.sender-mobile .app-final-cta {
	background: linear-gradient(145deg, #102033, #6b4b2c);
}

.app-final-cta h2 {
	color: #fff;
}

.app-final-cta p {
	margin-top: .14rem;
	color: rgba(238, 248, 255, .82);
}

@media (max-width: 340px) {
	.app-hero h1 {
		font-size: .42rem;
		line-height: .56rem;
	}

	.app-qrcode-panel {
		grid-template-columns: 1fr;
	}

	.app-qrcode-panel img {
		margin: 0 auto;
	}

	.app-actions,
	.app-final-actions {
		flex-direction: column;
	}

	.app-actions a,
	.app-final-actions a {
		width: 100%;
	}
}
