.radio {
	display: block;
	position: relative;
	padding-left: 2.5rem;
	margin-bottom: 12px;
	cursor: pointer;
	font-size: inherit;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	line-height: 1;
}

.radio input {
	position: absolute;
	opacity: 0;
	cursor: pointer;
}

.radio .check-indicator {
	position: absolute;
	top: 0;
	left: 0;
	height: 18px;
	width: 18px;
	background-color: #fff;
	border: 2px solid #ced4da;
	border-radius: 50%;
}

.radio .check-indicator::after {
	content: "";
	position: absolute;
	display: none;
	top: 3px;
	left: 3px;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--brand-color);
}

.radio input:checked ~ .check-indicator {
	background-color: var(--surface-light);
	border: 2px solid var(--brand-color);
}

.radio input:checked ~ .check-indicator::after {
	display: block;
}
