body {
	margin: 0;
	font-family: "SF Pro Display","SF Pro Icons","Helvetica Neue","Helvetica","Arial",sans-serif;
	color: #111318;
	background: #fff;
}

.container {
	max-width: 1060px;
}

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

nav a,
footer a {
	color: #26344A;
	font-size: 15px;
	font-weight: 600;
	opacity: 0.62;
}

nav a:hover,
footer a:hover {
	color: #26344A;
	opacity: 1;
	text-decoration: none;
}

.hero {
	min-height: 800px;
	padding-top: 56px;
	padding-bottom: 86px;
	display: grid;
	grid-template-columns: minmax(280px, 0.84fr) minmax(420px, 1.16fr);
	gap: 54px;
	align-items: center;
}

.app-icon {
	width: 96px;
	height: 96px;
	border-radius: 24px;
	box-shadow: 0 16px 34px rgba(38, 52, 74, 0.18);
	margin-bottom: 28px;
}

h1 {
	font-size: 88px;
	line-height: 0.95;
	letter-spacing: 0;
	font-weight: 700;
	margin: 0 0 24px;
}

.hero__intro {
	max-width: 390px;
	color: #4F5968;
	font-size: 30px;
	line-height: 1.24;
	font-weight: 400;
	margin-bottom: 36px;
}

.download-row {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
}

.app-store {
	display: inline-flex;
	width: 178px;
	height: 53px;
}

.app-store img {
	width: 178px;
	height: 53px;
	object-fit: contain;
}

.app-store--disabled {
	cursor: default;
	opacity: 0.42;
}

.download-note {
	color: #9AA3AE;
	font-size: 14px;
	line-height: 1.5;
	margin-top: 22px;
	margin-bottom: 0;
}

.hero__phones {
	position: relative;
	height: 650px;
}

.phone {
	position: absolute;
	border: 10px solid #101116;
	border-radius: 46px;
	background: #101116;
	box-shadow: 0 26px 70px rgba(38, 52, 74, 0.2);
	overflow: hidden;
}

.phone--main {
	width: 330px;
	height: 640px;
	left: 42px;
	top: 0;
}

.phone--side {
	width: 255px;
	height: 470px;
	right: 8px;
	top: 92px;
	border-radius: 40px;
}

.phone__screen {
	width: 100%;
	height: 100%;
	background: #fff;
	border-radius: 34px;
	overflow: hidden;
}

.phone__status {
	height: 34px;
	padding: 12px 24px 0;
	font-size: 12px;
	font-weight: 700;
	color: #111318;
}

.screen-title {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 18px 24px 14px;
}

.screen-title h2 {
	font-size: 26px;
	line-height: 1;
	font-weight: 700;
	margin: 0;
}

.screen-title span {
	width: 18px;
	height: 18px;
	border-radius: 6px;
	background: linear-gradient(180deg, #13C674, #0A84FF);
}

.screen-title--small {
	padding: 18px 18px 12px;
}

.screen-title--small h2 {
	font-size: 22px;
}

.screen-title--small span {
	color: #0A84FF;
	font-size: 24px;
	font-weight: 500;
	background: none;
	width: auto;
	height: auto;
}

.photo-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2px;
	padding: 0 14px;
}

.photo-grid div {
	aspect-ratio: 1;
	background:
		linear-gradient(140deg, rgba(255,255,255,0.12), rgba(0,0,0,0.08)),
		linear-gradient(135deg, #54A2E8, #F3B45C 48%, #23624E);
}

.photo-grid div:nth-child(3n) {
	background:
		linear-gradient(140deg, rgba(255,255,255,0.1), rgba(0,0,0,0.1)),
		linear-gradient(135deg, #0F6A50, #31C16B 55%, #D5F2E4);
}

.photo-grid div:nth-child(4n) {
	background:
		linear-gradient(140deg, rgba(255,255,255,0.08), rgba(0,0,0,0.14)),
		linear-gradient(135deg, #E36D45, #F7D169 45%, #266E8F);
}

.segmented {
	margin: 24px 18px 0;
	padding: 5px;
	border-radius: 18px;
	background: #F0F1F4;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	font-size: 11px;
	color: #7B8490;
	text-align: center;
}

.segmented span,
.segmented strong {
	padding: 7px 0;
}

.segmented strong {
	color: #111318;
	background: #fff;
	border-radius: 14px;
	font-weight: 700;
}

.tabbar {
	position: absolute;
	left: 10px;
	right: 10px;
	bottom: 10px;
	height: 66px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	align-items: center;
	text-align: center;
	border-top: 1px solid #ECEEF2;
	background: rgba(255, 255, 255, 0.94);
	font-size: 11px;
	color: #87909C;
}

.tabbar strong {
	color: #0A84FF;
	font-weight: 700;
}

.album-list {
	list-style: none;
	padding: 0 18px;
	margin: 0;
}

.album-list li {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	border-bottom: 1px solid #EEF0F3;
	padding: 13px 0;
	font-size: 13px;
	color: #1B2028;
}

.album-list b {
	font-weight: 500;
	color: #9AA3AE;
}

.features,
.privacy,
.faq {
	border-top: 1px solid #E6E9EE;
	padding-top: 72px;
	padding-bottom: 72px;
}

.features {
	display: grid;
	grid-template-columns: 0.86fr 1.14fr;
	gap: 64px;
}

.section-copy h2,
.privacy h2,
.faq h2 {
	font-size: 36px;
	line-height: 1.12;
	font-weight: 700;
	margin: 0 0 18px;
}

.section-copy p,
.privacy p {
	color: #5B6471;
	font-size: 18px;
	line-height: 1.55;
	margin: 0;
}

.feature-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 34px 42px;
}

.feature-grid article {
	position: relative;
	padding-left: 44px;
}

.feature-grid article::before {
	content: "";
	position: absolute;
	left: 0;
	top: 3px;
	width: 24px;
	height: 24px;
	border: 2px solid #16B86A;
	border-radius: 7px;
}

.feature-grid h3 {
	font-size: 19px;
	font-weight: 700;
	margin: 0 0 9px;
}

.feature-grid p {
	color: #5B6471;
	font-size: 15px;
	line-height: 1.5;
	margin: 0;
}

.privacy {
	display: grid;
	grid-template-columns: 0.95fr 1.05fr;
	gap: 64px;
	align-items: center;
}

.face-id {
	min-height: 240px;
	border-radius: 36px;
	background: linear-gradient(145deg, #F7FAFF, #F4FFF8);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 32px;
}

.face-id__mark {
	width: 64px;
	height: 64px;
	border: 3px solid #16B86A;
	border-radius: 22px;
	margin-bottom: 18px;
	box-shadow: inset 18px 18px 0 -15px #0A84FF, inset -18px -18px 0 -15px #0A84FF;
}

.face-id strong {
	font-size: 22px;
	color: #111318;
	margin-bottom: 8px;
}

.face-id span {
	max-width: 300px;
	color: #5B6471;
	font-size: 15px;
	line-height: 1.45;
}

.faq h2 {
	margin-bottom: 30px;
}

details {
	border-top: 1px solid #E6E9EE;
	padding: 20px 0;
}

details:last-child {
	border-bottom: 1px solid #E6E9EE;
}

summary {
	cursor: pointer;
	list-style: none;
	font-size: 17px;
	font-weight: 700;
	color: #111318;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

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

summary::after {
	content: "+";
	color: #0A84FF;
	font-size: 22px;
	font-weight: 500;
}

details[open] summary::after {
	content: "-";
}

details p {
	max-width: 700px;
	color: #5B6471;
	font-size: 16px;
	line-height: 1.55;
	margin: 16px 0 0;
}

footer {
	border-top: 1px solid #E6E9EE;
	padding: 34px 0 46px;
	display: flex;
	gap: 28px;
}

footer a:first-child {
	margin-right: auto;
}

.legal {
	max-width: 820px;
	padding-top: 64px;
	padding-bottom: 72px;
}

.legal__header {
	border-bottom: 1px solid #E6E9EE;
	padding-bottom: 42px;
	margin-bottom: 42px;
}

.legal__icon {
	width: 68px;
	height: 68px;
	border-radius: 17px;
	box-shadow: 0 12px 26px rgba(38, 52, 74, 0.14);
	margin-bottom: 22px;
}

.legal__header p {
	color: #0A66E8;
	font-size: 15px;
	font-weight: 700;
	margin: 0 0 14px;
}

.legal__header h1 {
	font-size: 56px;
	line-height: 1;
	margin-bottom: 18px;
}

.legal__header span {
	color: #8B95A3;
	font-size: 15px;
}

.legal__section {
	margin-bottom: 36px;
}

.legal__section h2 {
	font-size: 24px;
	line-height: 1.2;
	font-weight: 700;
	margin: 0 0 12px;
}

.legal__section p {
	color: #4F5968;
	font-size: 17px;
	line-height: 1.65;
	margin: 0 0 14px;
}

.legal__section a {
	color: #0A66E8;
	font-weight: 600;
}

@media (max-width: 960px) {
	.hero {
		grid-template-columns: 1fr;
		min-height: 0;
		padding-top: 42px;
		gap: 40px;
	}

	.hero__phones {
		height: 570px;
	}

	.phone--main {
		left: 8%;
	}

	.phone--side {
		right: 6%;
	}

	.features,
	.privacy {
		grid-template-columns: 1fr;
		gap: 38px;
	}
}

@media (max-width: 640px) {
	nav,
	footer {
		padding-left: 20px;
		padding-right: 20px;
	}

	.hero {
		min-height: 0;
		padding: 34px 20px 64px;
	}

	.app-icon {
		width: 78px;
		height: 78px;
		border-radius: 20px;
	}

	h1 {
		font-size: 64px;
	}

	.hero__intro {
		font-size: 24px;
	}

	.download-row {
		align-items: flex-start;
		flex-direction: column;
	}

	.hero__phones {
		height: 530px;
		overflow: hidden;
	}

	.phone--main {
		width: 270px;
		height: 524px;
		left: 0;
	}

	.phone--side {
		width: 200px;
		height: 370px;
		right: -52px;
		top: 78px;
	}

	.features,
	.privacy,
	.faq {
		padding: 54px 20px;
	}

	.legal {
		padding: 42px 20px 60px;
	}

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

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

	.section-copy h2,
	.privacy h2,
	.faq h2 {
		font-size: 30px;
	}

	footer {
		flex-wrap: wrap;
	}
}
