.service-demo-page .unlock-shell {
	padding-bottom: 36px;
	background: linear-gradient(180deg, #fff 0%, #fbfcff 100%);
}

.service-demo-page .unlock-summary h1 {
	margin-top: 18px;
	line-height: 1.35;
}

.service-demo-page .service-result-card {
	border-color: rgba(37, 170, 131, 0.18);
	background: linear-gradient(135deg, #fff, #f5fffb);
}

.service-flow-card,
.recommendation-card,
.service-compliance-card,
.service-ops-card {
	margin: 12px 0;
	padding: 18px;
	border: 1px solid rgba(63, 70, 93, 0.06);
	border-radius: 16px;
	background: #fff;
	box-shadow: 0 8px 22px rgba(70, 78, 110, 0.1);
}

.service-flow-card h2,
.recommendation-card h2,
.service-compliance-card h2,
.service-ops-card h2 {
	margin: 0 0 8px;
	color: #2f333b;
	font-size: 20px;
	font-weight: 900;
	line-height: 1.32;
}

.service-flow-intro,
.recommendation-head p,
.primary-service p,
.secondary-grid p,
.service-compliance-card li,
.ops-grid span {
	color: #676d78;
	font-size: 13px;
	line-height: 1.65;
}

.service-flow-intro {
	margin: 0 0 18px;
}

.question-block {
	padding: 14px 0;
	border-top: 1px solid #edf0f6;
}

.question-block:first-of-type {
	border-top: 0;
	padding-top: 0;
}

.question-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 10px;
}

.question-title strong {
	color: #323741;
	font-size: 15px;
	font-weight: 900;
}

.question-title span {
	flex: 0 0 auto;
	padding: 3px 8px;
	border-radius: 999px;
	background: #f3f5fb;
	color: #7c8290;
	font-size: 11px;
	font-weight: 800;
}

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

.option-grid--three {
	grid-template-columns: 1fr;
}

.option-chip {
	min-height: 42px;
	padding: 8px 10px;
	border: 1px solid #e5e8f1;
	border-radius: 10px;
	background: #f8f9fd;
	color: #4c5260;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.25;
	text-align: center;
}

.option-chip.is-active {
	border-color: rgba(140, 97, 166, 0.38);
	background: linear-gradient(180deg, #fff, #f7f0fb);
	color: #8c61a6;
	box-shadow: 0 8px 18px rgba(140, 97, 166, 0.12);
}

.recommendation-card {
	border-color: rgba(140, 97, 166, 0.12);
	background: linear-gradient(180deg, #fff, #fbf8ff);
}

.recommendation-head {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 12px;
	align-items: start;
	margin-bottom: 14px;
}

.recommendation-head p {
	margin: 0;
}

.recommendation-head strong {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 76px;
	height: 32px;
	padding: 0 10px;
	border-radius: 999px;
	background: #102638;
	color: #fff;
	font-size: 12px;
	font-weight: 900;
	white-space: nowrap;
}

.primary-service {
	position: relative;
	padding: 18px;
	border: 1px solid rgba(240, 38, 134, 0.12);
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 10px 24px rgba(220, 58, 103, 0.1);
}

.service-badge {
	display: inline-flex;
	margin-bottom: 10px;
	padding: 4px 9px;
	border-radius: 999px;
	background: #fff0f5;
	color: #f02686;
	font-size: 11px;
	font-weight: 900;
}

.primary-service h3 {
	margin: 0 0 8px;
	color: #262b34;
	font-size: 19px;
	font-weight: 900;
}

.primary-service p {
	margin: 0 0 12px;
}

.service-meta {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	margin-bottom: 14px;
}

.service-meta span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 34px;
	padding: 7px;
	border-radius: 9px;
	background: #f7f8ff;
	color: #545b67;
	font-size: 12px;
	font-weight: 800;
	text-align: center;
}

.service-cta,
.secondary-grid button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	border: 0;
	border-radius: 999px;
	font-weight: 900;
}

.service-cta {
	height: 46px;
	background: linear-gradient(90deg, #ff7b42, #f02686);
	color: #fff;
	font-size: 16px;
}

.secondary-grid {
	display: grid;
	gap: 10px;
	margin-top: 10px;
}

.secondary-grid article {
	padding: 14px;
	border-radius: 12px;
	background: #fff;
	border: 1px solid rgba(63, 70, 93, 0.06);
}

.secondary-grid b {
	display: block;
	margin-bottom: 6px;
	color: #303640;
	font-size: 15px;
	font-weight: 900;
}

.secondary-grid p {
	min-height: 42px;
	margin: 0 0 10px;
}

.secondary-grid button {
	height: 38px;
	background: #eef1ff;
	color: #6574d8;
	font-size: 13px;
}

.demo-toast {
	margin: 12px 0 0;
	padding: 10px 12px;
	border-radius: 10px;
	background: #edf8f3;
	color: #16795f;
	font-size: 12px;
	font-weight: 800;
	text-align: center;
}

.service-compliance-card {
	background: #fffdf8;
	border-color: rgba(228, 174, 58, 0.18);
}

.service-compliance-card ul {
	margin: 8px 0 0;
	padding-left: 18px;
}

.service-compliance-card li {
	margin-bottom: 8px;
}

.service-compliance-card li:last-child {
	margin-bottom: 0;
}

.ops-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 8px;
	margin-top: 12px;
}

.ops-grid article {
	padding: 12px;
	border-radius: 12px;
	background: #f7f8ff;
}

.ops-grid b {
	display: block;
	margin-bottom: 5px;
	color: #8c61a6;
	font-size: 13px;
	font-weight: 900;
}

.ops-grid span {
	display: block;
}

@media (min-width: 430px) {
	.option-grid--three {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 360px) {
	.service-demo-page .unlock-shell {
		padding-left: 10px;
		padding-right: 10px;
	}

	.option-grid,
	.ops-grid,
	.service-meta,
	.recommendation-head {
		grid-template-columns: 1fr;
	}

	.recommendation-head strong {
		width: fit-content;
	}
}
