:root {
	--spc-ink: #061D41;
	--spc-accent: #E0F0BF;
	--spc-accent-strong: #88BC23;
	--spc-soft: #f1f3f6;
	--spc-line: #061D41;
	--spc-danger: #b42318;
}

.spc-page-template {
	background: #e9ecef;
	padding: 56px 0 96px;
}

.spc-wrapper {
	max-width: 1080px;
	margin: 0 auto;
	padding: 0 20px;
    font-family: "Acumin Pro", sans-serif !important;
}

body.spc-page-loading {
	overflow: hidden;
}

.spc-loading-overlay {
	position: fixed;
	inset: 0;
	background: rgba(6, 29, 65, 0.5);
	backdrop-filter: blur(4px);
	display: none;
	align-items: center;
	justify-content: center;
	padding: 24px;
	z-index: 9999;
}

.spc-page-loading .spc-loading-overlay {
	display: flex;
}

.spc-loading-panel {
	min-width: 280px;
	max-width: 360px;
	text-align: center;
	padding: 24px 20px;
	border-radius: 16px;
	background: #ffffff;
	box-shadow: 0 16px 40px rgba(6, 29, 65, 0.25);
	border: 1px solid rgba(136, 188, 35, 0.25);
}

.spc-loading-spinner {
	display: inline-block;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	border: 4px solid rgba(6, 29, 65, 0.12);
	border-top-color: var(--spc-accent-strong);
	border-right-color: #061D41;
	animation: spc-spin 0.9s linear infinite;
	margin-bottom: 14px;
}

.spc-loading-title {
	margin: 0;
	color: var(--spc-ink);
	font: normal normal bold 20px/28px Acumin Pro;
}

.spc-loading-copy {
	margin: 8px 0 0;
	color: #3b4a67;
	font: normal normal normal 14px/22px Acumin Pro;
}

@keyframes spc-spin {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}

.spc-shell {
	padding: 0;
}
.site-main section.service-plan-form {
    margin: 0;
}
.spc-grid {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.spc-card {
	border: 1px solid transparent;
	background: var(--spc-accent);
    border-radius: 30px;
    box-shadow: 0px 3px 6px rgba(6, 29, 65, 0.0509803922);
    padding: 35px 20px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.spc-card.is-selected {
	border-color: var(--spc-accent);
	box-shadow: 0 0 0 1px rgba(134, 188, 31, 0.25);
}

.spc-card-main {
	display: block;
	padding: 0;
	cursor: pointer;
}

.spc-product-radio {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.spc-card-head {
	display: flex;
	gap: 18px;
	align-items: center;
	flex-direction: column;
}

.spc-card-head img {
	max-width: 220px;
	max-height: 170px;
	width: auto;
	height: auto;
	object-fit: contain;
}

.spc-card-title-wrap {
	display: flex;
	align-items: center;
	gap: 8px;
	justify-content: flex-start;
	width: 100%;
}

.spc-card-title {
	font-weight: 700;
	color: var(--spc-ink);
	line-height: 1.1;
    font: normal normal bold 23px/42px Acumin Pro;
    letter-spacing: -0.38px;
    opacity: 1;
}

.spc-tooltip-trigger {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	border: 2px solid var(--spc-accent);
	background: transparent;
	color: var(--spc-accent);
	font-size: 0.8rem;
	font-weight: 700;
	cursor: pointer;
	line-height: 1;
}

.spc-card-desc {
	margin: 10px 0 0;
	color: var(--spc-ink);
	font: normal normal normal 15px/21px Acumin Pro;
	line-height: 1.5;
}

.spc-frequency-wrap {
	margin-top: 20px;
}

.spc-frequency-label {
	margin: 0 0 20px;
	color: var(--spc-ink);
	text-align: left;
    font: normal normal bold 18px/21px Acumin Pro;
    letter-spacing: -0.3px;
}

.spc-frequency-group {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.spc-frequency-option {
	border: 1px solid var(--spc-line);
	padding: 0 12px;
	background: #FFFFFF;
	color: var(--spc-ink);
	cursor: pointer;
	transition: all 0.2s ease;
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-height: 48px;
    border-radius: 8px;
}

.spc-frequency-option input {
	position: absolute;
	opacity: 0;
}

.spc-frequency-option span {
	text-align: left;
    font: normal normal bold 14px/21px Acumin Pro;
}

.spc-frequency-option::after {
	content: '';
	width: 26px;
	height: 26px;
	border-radius: 7px;
	border: 1px solid var(--spc-line);
	background: transparent;
	flex-shrink: 0;
}

.spc-frequency-option.is-selected {
	border-color: var(--spc-accent-strong);
	background: var(--spc-accent-strong);
	color: var(--spc-ink);
}
.spc-frequency-option input {
    display: none;
}
.spc-frequency-option.is-selected::after {
	content: '';
	border: 0;
	background: url('../icons/check_mark.svg') center/contain no-repeat;
    background-color: var(--spc-line);
    background-size: 18px;
    border-radius: 30px;
}

.spc-bottom {
	margin: 48px auto 0;
	max-width: 560px;
	display: block;
}
.spc-bottom h4{
    font: normal normal bold 26px/42px Acumin Pro;
    margin-bottom: 15px;
}
.spc-center{
	text-align: center;
}

.spc-field-group label {
	display: inline-block;
	margin-bottom: 15px;
	color: var(--spc-ink);
	font: normal normal bold 18px/21px Acumin Pro;
	/* text-align: center; */
}
.spc-field-group small {
	font-size: 12px;
}

.spc-field-group {
	margin-bottom: 20px;
}

.spc-consent-group {
	margin-top: -10px;
}

.spc-consent-group h6 {
	margin: 0 0 8px;
	color: var(--spc-ink);
	font: normal normal bold 18px/24px Acumin Pro;
}

.spc-consent-group > p {
	margin: 0 0 10px;
	color: var(--spc-ink);
	font: normal normal normal 14px/21px Acumin Pro;
}

.spc-consent-group .spc-consent-option {
	display: flex;
	align-items: flex-start;
	text-align: left;
	gap: 10px;
	margin-bottom: 0;
	cursor: pointer;
	font: normal normal normal 14px/21px Acumin Pro;
	text-transform: none;
	margin-bottom: 10px;
}
.spc-consent-group .spc-consent-option input[type="checkbox"] {
	width: 18px !important;
	min-height: 18px !important;
	height: 18px !important;
	margin: 2px 0 0;
	padding: 0 !important;
	border: 1px solid #061D4167 !important;
	border-radius: 3px !important;
	flex-shrink: 0;
	appearance: none !important;
	-webkit-appearance: checkbox;
	background: #ffffff !important;
}

.spc-consent-group .spc-consent-option span {
	font: normal normal normal 14px/21px Acumin Pro;
	color: var(--spc-ink);
}

.spc-consent-group .spc-consent-option p {
	margin: 0;
	font: normal normal normal 14px/21px Acumin Pro;
	color: var(--spc-ink);
}

.spc-field-group input,
.spc-field-group select {
	width: 100%;
    background: #FFFFFF 0% 0% no-repeat padding-box !important;
    border: 1px solid #061D4167 !important;
    border-radius: 8px !important;
	min-height: 44px !important;
	padding: 0 16px !important;
	font: 14px/21px Acumin Pro !important;
    font-family: "Acumin Pro", sans-serif !important;
    
	color: var(--spc-ink) !important;
}
.spc-postcode-row,
.spc-promo-row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 10px;
}

.spc-btn-secondary,
.spc-btn-primary {
	border: 0;
	border-radius: 999px;
	min-height: 44px;
	padding: 0 20px;
	font-weight: 700;
	cursor: pointer;
	font: normal normal bold 15px/28px Acumin Pro;
    font-family: "Acumin Pro", sans-serif !important;
}

.spc-btn-secondary {
	background: var(--spc-accent-strong) !important;
	color: var(--spc-ink) !important;
	min-width: 89px !important;
}
.spc-btn-primary:hover{
    background: var(--spc-accent-strong);
}
.spc-btn-primary {
	background: var(--spc-accent);
	color: #001638;
}

.spc-btn-primary[disabled] {
	opacity: 0.45;
	cursor: not-allowed;
}

.spc-btn-primary.is-disabled {
	opacity: 0.45;
	cursor: not-allowed;
}
#spc-postcode-message a{
	color: var(--spc-accent-strong);
}
.spc-message {
	margin-top: 8px;
	font: normal normal normal 14px/21px Acumin Pro;
	min-height: 1.2em;
    display: none;
}

.spc-message.is-success {
	/* color: var(--spc-accent-strong); */
    display: block;
	font: normal normal bold 14px/21px Acumin Pro;
}

.spc-message.is-error {
	/* color: var(--spc-danger); */
    display: block;
}

.spc-message.is-muted {
	color: #577371;
}

.spc-price-wrap {
	grid-column: 1 / -1;
	padding: 0;
	border-radius: 0;
	background: transparent;
	color: var(--spc-ink);
	font: 18px/42px Acumin Pro;
    font-family: "Acumin Pro", sans-serif !important;
	margin-bottom: 18px;
	text-align: center;
}

#spc-proceed {
	grid-column: 1 / -1;
	width: 100%;
}
.spc_service_day{
    text-align: center;
}
#spc_service_day {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--spc-accent-strong) 50%), linear-gradient(135deg, var(--spc-accent-strong) 50%, transparent 50%) !important;
	background-position: calc(100% - 24px) 50%, calc(100% - 16px) 50% !important;
	background-size: 8px 8px, 8px 8px !important;
	background-repeat: no-repeat !important;
	padding-right: 40px !important;
}

#spc-final-price {
	font: normal normal bold 26px/42px Acumin Pro;
}

@media (max-width: 960px) {
	.spc-grid {
		grid-template-columns: 1fr;
	}

	.spc-shell {
		padding: 0;
	}

	.spc-card {
		padding: 16px;
		border-radius: 18px;
	}

	.spc-card-title,
	.spc-card-desc,
	.spc-frequency-label,
	.spc-field-group label,
	.spc-price-wrap {
		font-size: 1.2rem;
	}

	.spc-frequency-option span,
	.spc-field-group input,
	.spc-field-group select,
	.spc-btn-primary,
	.spc-btn-secondary,
	.spc-message {
		font-size: 1rem;
	}

	#spc-final-price {
		font-size: 2rem;
	}
}
