/**
 * Gravity Forms plugin CSS is off (`gform_disable_css`). Keep spam/hidden fields visually hidden.
 *
 * @link https://docs.gravityforms.com/gform_disable_css/
 */
.gform_wrapper .gfield_visibility_hidden,
.gform_wrapper .gform_hidden,
.gform_wrapper .gform_validation_container {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}


.fx-gravity-form .gform_wrapper.gform-theme {
	--gf-color-primary: var(--color-primary);
	--gf-color-in-ctrl-primary: var(--color-red);
	--gf-ctrl-accent-color: var(--color-red);
	--gf-radius: 15px;
	--gf-ctrl-border-color: var(--color-secondary);
	--gf-ctrl-label-color-primary: #222;
	--gf-ctrl-label-color-secondary: #222;
}

.fx-gravity-form [id^='gform_wrapper_'].gform-theme {
	--gf-color-primary: var(--color-primary) !important;
	--gf-color-primary-rgb: 233, 29, 45 !important;
	--gf-ctrl-outline-width-focus: 4px !important;
}

.fx-gravity-form .gform_wrapper {
	width: 100%;
}

.fx-gravity-form .gform_wrapper .gform_body {
	width: 100%;
}


.fx-gravity-form .gform_heading .gform_title {
	text-align: center;
	color: var(--black);
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 25px;
	line-height: 1.2;
	margin-bottom: 20px;
}

@media (min-width: 768px) {
	.fx-gravity-form .gform_heading .gform_title {
		font-size: 32px;
		margin-bottom: 35px;
	}
}

@media (min-width: 1200px) {
	.fx-gravity-form .gform_heading .gform_title {
		font-size: 36px;
		margin-bottom: 32px;
	}
}

.fx-gravity-form .gform_heading .gform_description {
	display: none;
}

.fx-gravity-form .gform_heading .gform_required_legend {
	display: none;
}


.fx-gravity-form .gform_wrapper .gf_page_steps {
	display: flex;
	justify-content: center;
	gap: 30px;
	list-style: none;
	padding: 0;
	margin: 0 0 15px;
}

.fx-gravity-form .gform_wrapper .gf_step {
	display: flex;
	align-items: center;
	gap: 12px;
}

.fx-gravity-form .gform_wrapper .gf_step .gf_step_number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 33px;
	height: 33px;
	border-radius: 50%;
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 18px;
	line-height: 1.2;
	border: 1px solid var(--color-secondary);
	color: var(--color-secondary);
	background-color: transparent;
}

.fx-gravity-form .gform_wrapper .gf_step_active .gf_step_number {
	background-color: var(--color-secondary);
	border-color: var(--color-secondary);
	color: var(--color-white);
}

.fx-gravity-form .gform_wrapper .gf_step .gf_step_label {
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 24px;
	line-height: 1.2;
	color: var(--color-secondary);
}

.fx-gravity-form .gform_wrapper .gf_progressbar_wrapper {
	margin-bottom: 30px;
}

.fx-gravity-form .gform_wrapper .gf_progressbar {
	height: 3px;
	background-color: #e2e3ea;
	border-radius: 10px;
	overflow: hidden;
}

.fx-gravity-form .gform_wrapper .gf_progressbar .gf_progressbar_percentage {
	height: 3px;
	background-color: var(--color-red);
	border-radius: 10px;
	font-size: 0;
	line-height: 0;
}

.fx-gravity-form .gform_wrapper .gf_progressbar .gf_progressbar_percentage span {
	display: none;
}

.fx-gravity-form .gform_wrapper .gf_step_clear {
	display: none;
}


.fx-gravity-form .step-form__items {
	margin-bottom: 20px;
}

.fx-gravity-form .step-form__items ul,
.fx-gravity-form .gform_wrapper .step-form__items ul {
	--step-form-track-gap: 40px;
	--step-form-track-gray: #e2e3ea;
	display: flex;
	gap: var(--step-form-track-gap);
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	justify-content: stretch;
	width: 100%;
	padding-bottom: 20px !important;
	border-bottom: none;
	background-color: transparent;
	background-image: linear-gradient(
		to right,
		var(--color-red) 0,
		var(--color-red) calc(50% - var(--step-form-track-gap) / 2),
		var(--step-form-track-gray) calc(50% - var(--step-form-track-gap) / 2),
		var(--step-form-track-gray) 100%
	);
	background-size: 100% 3px;
	background-position: left bottom;
	background-repeat: no-repeat;
	position: relative;
}

.fx-gravity-form .step-form__items ul li,
.fx-gravity-form .gform_wrapper .step-form__items ul li {
	display: flex;
	flex: 1 1 0;
	min-width: 0;
	list-style: none !important;
	list-style-type: none !important;
	margin: 0;
	padding: 0;
}

.fx-gravity-form .step-form__items ul li:first-child,
.fx-gravity-form .gform_wrapper .step-form__items ul li:first-child {
	justify-content: flex-end;
}

.fx-gravity-form .step-form__items ul li:last-child,
.fx-gravity-form .gform_wrapper .step-form__items ul li:last-child {
	justify-content: flex-start;
}

.fx-gravity-form .step-form__items ul li:before,
.fx-gravity-form .gform_wrapper .step-form__items ul li:before {
	display: none;
}

.fx-gravity-form .step-form__items--progress-2 ul,
.fx-gravity-form .gform_wrapper .step-form__items--progress-2 ul {
	background-image: linear-gradient(
		to right,
		var(--color-red) 0%,
		var(--color-red) 100%
	);
}

.fx-gravity-form .step-form__items li a {
	display: flex;
	align-items: center;
	gap: 12px;
	box-sizing: border-box;
	min-width: var(--touch-target-min);
	min-height: var(--touch-target-min);
	text-decoration: none;
	color: var(--color-secondary);
}

.fx-gravity-form .step-form__items li.active a {
	color: var(--color-secondary);
}

.fx-gravity-form .step-form__items li a i {
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: 33px;
	height: 33px;
	min-width: 33px;
	min-height: 33px;
	flex-shrink: 0;
	border-radius: 50%;
	border: 1px solid var(--color-secondary);
	font-style: normal;
	font-weight: 700;
	font-size: 18px;
	line-height: 1;
	color: var(--color-secondary);
	background-color: transparent;
}

.fx-gravity-form .step-form__items li.active a i {
	background-color: var(--color-secondary);
	border-color: var(--color-secondary);
	color: var(--color-white);
}

.fx-gravity-form .step-form__items li a span {
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 24px;
	line-height: 1.2;
	min-width: 0;
	text-align: left;
}

@media (max-width: 767px) {
	.fx-gravity-form .step-form__items ul,
	.fx-gravity-form .gform_wrapper .step-form__items ul {
		--step-form-track-gap: 118px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
		gap: var(--step-form-track-gap) !important;
		margin: 0 0 20px !important;
		padding: 0 !important;
		padding-bottom: 0 !important;
		background-image: none !important;
		background-color: transparent !important;
		border-bottom: none !important;
	}

	.fx-gravity-form .step-form__items--progress-2 ul,
	.fx-gravity-form .gform_wrapper .step-form__items--progress-2 ul {
		background-image: none !important;
	}

	.fx-gravity-form .step-form__items ul li,
	.fx-gravity-form .gform_wrapper .step-form__items ul li {
		position: relative;
		flex: 0 0 auto;
		display: block;
		justify-content: unset;
		margin: 0 !important;
		padding: 0 !important;
	}

	.fx-gravity-form .step-form__items ul li.active:not(:last-child)::after {
		content: '';
		position: absolute;
		left: calc(100% + 10px);
		top: 50%;
		transform: translate(0, -50%);
		width: 98px;
		height: 1px;
		background: var(--primary-color);
	}

	.fx-gravity-form .step-form__items ul li:last-child.active::after {
		display: none !important;
	}

	.fx-gravity-form .step-form__items--progress-2 ul li:first-child::after,
	.fx-gravity-form .gform_wrapper .step-form__items--progress-2 ul li:first-child::after {
		content: '';
		position: absolute;
		left: calc(100% + 10px);
		top: 50%;
		transform: translate(0, -50%);
		width: 98px;
		height: 1px;
		background: var(--primary-color);
	}

	.fx-gravity-form .step-form__items li a {
		text-decoration: none;
		font-size: 20px;
		line-height: 1.2em;
		color: var(--secondary-color);
		font-family: var(--secondary-font);
		font-weight: 500;
	}

	.fx-gravity-form .step-form__items li a span {
		display: none !important;
	}

	.fx-gravity-form .step-form__items li a i {
		font-size: 18px;
		font-weight: 700;
		color: #d1d5db;
		line-height: 1em;
		width: 33px;
		height: 33px;
		min-width: 33px;
		min-height: 33px;
		border-radius: 50%;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: center;
		border: 1px solid #d1d5db;
		font-style: inherit;
		background-color: transparent;
	}

	.fx-gravity-form .step-form__items li.active a i {
		color: var(--white);
		border-color: var(--primary-color);
		background: var(--primary-color);
	}
}


.fx-gravity-form .step-form__wrap .form-col {
	margin-bottom: 20px;
}

.fx-gravity-form .step-form__wrap label {
	display: block;
	font-weight: var(--font-weight-bold);
	margin-bottom: 8px;
	color: var(--color-text-primary);
}

.fx-gravity-form .step-form__wrap label sup {
	color: var(--color-primary);
}

.fx-gravity-form .step-form__wrap input[type="text"],
.fx-gravity-form .step-form__wrap input[type="email"],
.fx-gravity-form .step-form__wrap input[type="tel"],
.fx-gravity-form .step-form__wrap textarea {
	width: 100%;
	border: 1px solid var(--color-border);
	border-radius: 10px;
	padding: 12px 16px;
	font-size: 16px;
	font-family: var(--font-body);
	color: var(--color-text-primary);
	appearance: none;
	background-color: var(--color-white);
}

.fx-gravity-form .step-form__wrap select {
	width: 100%;
	border: 1px solid var(--color-border);
	border-radius: 10px;
	padding: 12px 16px;
	padding-right: 40px;
	font-size: 16px;
	font-family: var(--font-body);
	color: var(--color-text-secondary);
	appearance: none;
	background-color: var(--color-white);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A3141F' stroke-width='2' fill='none'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 16px center;
}

.fx-gravity-form .step-form__wrap textarea {
	min-height: 120px;
	resize: vertical;
}

.fx-gravity-form .radio-box {
	display: flex;
	gap: 20px;
}

.fx-gravity-form .radio-box__col {
	display: flex;
	align-items: center;
	gap: 8px;
}

.fx-gravity-form .radio-box__col input[type="radio"] {
	width: 24px;
	height: 24px;
	accent-color: var(--color-red);
}

.fx-gravity-form .step-form__wrap .btn {
	width: 100%;
}

.fx-gravity-form .step-form__wrap .form-col .btn-primary {
	width: 100%;
	cursor: pointer;
	padding: 20px;
}

.fx-gravity-form .step-form__wrap .form-col .btn-primary::after {
	display: none;
}


.fx-gravity-form .gform_wrapper .gform_fields {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	column-gap: 20px;
	row-gap: 0;
}

.fx-gravity-form .gform_wrapper .gfield {
	flex: 0 0 100%;
	margin-bottom: 20px;
}

.fx-gravity-form .gform_wrapper .gfield--width-half {
	flex: 1 1 calc(50% - 10px);
	min-width: 0;
}

/* Three-column row (e.g. City / State / Zip); column-gap on .gform_fields is 20px → 2 gaps for 3 cols */
.fx-gravity-form .gform_wrapper .gfield--width-third {
	flex: 0 0 100%;
	min-width: 0;
}

@media (min-width: 768px) {
	.fx-gravity-form .gform_wrapper .gfield--width-third {
		flex: 1 1 calc((100% - 40px) / 3);
	}
}

/* Address: street full width; city / state / ZIP one row (override GF grid / ginput_left-right). */
.fx-gravity-form .gform_wrapper .ginput_container_address.ginput_complex,
.fx-gravity-form .gform_wrapper .ginput_container_address.gform-grid-row {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 20px;
	width: 100%;
}

.fx-gravity-form .gform_wrapper .ginput_container_address .ginput_full {
	flex: 1 1 100%;
	min-width: 0;
}

.fx-gravity-form .gform_wrapper .ginput_container_address .ginput_address_city,
.fx-gravity-form .gform_wrapper .ginput_container_address .ginput_address_state,
.fx-gravity-form .gform_wrapper .ginput_container_address .ginput_address_zip {
	float: none;
	width: auto;
	max-width: none;
	padding-right: 0;
	margin-right: 0;
	flex: 1 1 0;
	min-width: 0;
}

.fx-gravity-form .gform_wrapper .ginput_container_address .ginput_address_zip {
	flex: 0 1 140px;
}

.fx-gravity-form .gform_wrapper .ginput_container_address .ginput_address_state .choices {
	width: 100%;
}

.fx-gravity-form .gform_wrapper .ginput_container_address .gf_clear_complex {
	display: none;
}

/*
 * Name field: First + Last in two columns (plugin `gform-grid-*` CSS is disabled).
 * Scoped to `.gform_wrapper` so it applies whether or not the form uses `.fx-gravity-form`.
 */
.gform_wrapper .ginput_container_name.gform-grid-row.gf_name_has_2,
.gform_wrapper .ginput_container--name.gform-grid-row.gf_name_has_2 {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
	width: 100%;
	align-items: start;
}

@media (max-width: 599px) {
	.gform_wrapper .ginput_container_name.gform-grid-row.gf_name_has_2,
	.gform_wrapper .ginput_container--name.gform-grid-row.gf_name_has_2 {
		grid-template-columns: 1fr;
	}
}

.gform_wrapper .ginput_container_name .gform-grid-col,
.gform_wrapper .ginput_container--name .gform-grid-col {
	min-width: 0;
}

.gform_wrapper .ginput_container_name .gform-grid-col input[type="text"],
.gform_wrapper .ginput_container--name .gform-grid-col input[type="text"] {
	width: 100%;
	box-sizing: border-box;
}

.fx-gravity-form .gform_wrapper .gfield--type-html {
	margin-bottom: 0;
}

/* Image choice: horizontal row of cards (GF theme grid CSS is off). */
.gform_wrapper .ginput_container_image_choice .gfield_checkbox,
.gform_wrapper .ginput_container_image_choice .gfield_radio {
	display: flex;
	flex-flow: row wrap;
	gap: 20px;
	align-items: stretch;
	width: 100%;
}

.gform_wrapper .gfield--type-image_choice .gchoice {
	flex: 1 1 160px;
	max-width: 100%;
	min-width: 0;
}

.gform_wrapper .gfield--type-image_choice .gfield-image-choice-wrapper-outer {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	box-sizing: border-box;
	border: 1.5px solid var(--color-secondary);
	border-radius: 15px;
	padding: 12px;
	background-color: var(--color-white);
}

.gform_wrapper .gfield--type-image_choice .gfield-choice-image-wrapper {
	width: 100%;
	text-align: center;
}

.gform_wrapper .gfield--type-image_choice .gfield-choice-image-wrapper img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
	border-radius: 8px;
}

.gform_wrapper .gfield--type-image_choice .gfield-image-choice-wrapper-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	width: 100%;
	margin-top: 10px;
}

.gform_wrapper .gfield--type-image_choice .gfield-choice-input:focus {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.fx-gravity-form .gform_wrapper .gfield_label,
.fx-gravity-form .gform_wrapper .gfield_label.gform-field-label {
	display: block;
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 20px;
	line-height: 1.2;
	margin-bottom: 10px;
	color: #222;
}

.fx-gravity-form .gform_wrapper .gfield_required .gfield_required_asterisk {
	color: var(--color-primary);
	position: relative;
	left: 2px;
	top: 2px;
	font-size: 120%;
	font-weight: 700;
}

/* Complex fields (address, name, etc.): sublabels match main field label typography. */
.fx-gravity-form .gform_wrapper .ginput_complex .gform-field-label--type-sub {
	display: block;
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 20px;
	line-height: 1.2;
	margin-bottom: 10px;
	color: #222;
}


.fx-gravity-form .gform_wrapper input[type="text"],
.fx-gravity-form .gform_wrapper input[type="email"],
.fx-gravity-form .gform_wrapper input[type="tel"],
.fx-gravity-form .gform_wrapper input[type="url"],
.fx-gravity-form .gform_wrapper input[type="number"],
.fx-gravity-form .gform_wrapper select {
	width: 100%;
	border: 1.5px solid var(--color-secondary);
	border-radius: 15px;
	padding: 15px;
	font-size: 18px;
	font-family: var(--font-body);
	color: var(--color-text-secondary);
	background-color: var(--color-white);
	appearance: none;
	height: 60px;
}

.fx-gravity-form .gform_wrapper input[type="text"]::placeholder,
.fx-gravity-form .gform_wrapper input[type="email"]::placeholder,
.fx-gravity-form .gform_wrapper input[type="tel"]::placeholder,
.fx-gravity-form .gform_wrapper input[type="url"]::placeholder,
.fx-gravity-form .gform_wrapper input[type="number"]::placeholder,
.fx-gravity-form .gform_wrapper textarea::placeholder {
	color: #adb5bd;
	opacity: 1;
}

.fx-gravity-form .gform_wrapper .ginput_address_state select {
	height: auto;
	line-height: normal;
	box-sizing: border-box;
}

.fx-gravity-form .gform_wrapper textarea {
	width: 100%;
	border: 1px solid var(--color-secondary);
	border-radius: 15px;
	padding: 15px;
	font-size: 18px;
	font-family: var(--font-body);
	color: var(--color-black);
	background-color: var(--color-white);
	min-height: 134px;
	resize: vertical;
}

/*
 * Focus ring: `global.css` sets `input:focus, textarea:focus, select:focus { outline: none }`,
 * which removes the universal `*:focus-visible` treatment for these controls.
 */
.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="password"]:focus,
.gform_wrapper input[type="search"]:focus,
.gform_wrapper input[type="date"]:focus,
.gform_wrapper input[type="time"]:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}


.fx-gravity-form .gform_wrapper .choices {
	position: relative;
	overflow: hidden;
	margin-bottom: 0;
	cursor: pointer;
	/* Outline sits on this node (:focus-within); radius so ring matches pill (mouse :focus is not :focus-visible). */
	border-radius: 15px;
}

.fx-gravity-form .gform_wrapper .choices.is-open {
	overflow: initial;
	border-radius: 15px 15px 0 0;
}

.fx-gravity-form .gform_wrapper .choices .choices__inner {
	border: 1.5px solid var(--color-secondary);
	border-radius: 15px !important;
	padding: 15px 50px 15px 15px;
	min-height: auto;
	font-size: 18px;
	font-family: var(--font-body);
	background-color: var(--color-white);
	display: flex;
	align-items: center;
}

.fx-gravity-form .gform_wrapper .choices.is-open .choices__inner {
	border-radius: 15px 15px 0 0 !important;
}

/* Gravity Forms Choices: focus ring — primary, offset matches global. */
.fx-gravity-form .gform_wrapper .choices:focus-within {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--single {
	display: inline-block;
	padding: 0;
	width: 100%;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--single .choices__item {
	color: var(--color-text-secondary);
	font-size: 18px;
	line-height: 1.5;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--single .choices__item.choices__placeholder {
	color: #9ca3af;
}

.fx-gravity-form .gform_wrapper .choices[data-type*='select-one']::after {
	content: "\e902";
	font-family: 'wayne-alarm-icomoon' !important;
	width: auto;
	height: auto;
	border: none;
	margin: 0;
	top: 50%;
	transform: translateY(-50%);
	color: var(--color-red);
	right: 15px;
	position: absolute;
	font-size: 16px;
	pointer-events: none;
}

.fx-gravity-form .gform_wrapper .choices[data-type*='select-one'].is-open::after {
	transform: translateY(-50%) rotate(180deg);
}

.fx-gravity-form .gform_wrapper .choices[data-type*='select-one']::before {
	content: "";
	position: absolute;
	right: 46px;
	height: 100%;
	width: 1px;
	background: var(--color-secondary);
	z-index: 1;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown {
	visibility: hidden;
	position: absolute;
	width: 100%;
	top: 100%;
	z-index: 10;
	background-color: var(--color-white);
	border: 1.5px solid var(--color-secondary);
	border-top: none;
	border-radius: 0 0 15px 15px !important;
	overflow: hidden;
	margin-top: -1px;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown.is-active,
.fx-gravity-form .gform_wrapper .choices.is-open .choices__list--dropdown,
.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown[aria-expanded="true"] {
	visibility: visible;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown .choices__list {
	max-height: 300px;
	overflow: auto;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown .choices__item {
	padding: 10px 15px;
	font-size: 18px;
	font-family: var(--font-body);
	color: var(--color-text-secondary);
	cursor: pointer;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown .choices__item.is-highlighted,
.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown .choices__item:hover {
	background-color: var(--color-red);
	color: var(--color-white);
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown .choices__item--selectable::after {
	display: none;
}

.fx-gravity-form .gform_wrapper .choices .choices__list--dropdown .choices__input--cloned {
	display: none;
}


.fx-gravity-form .gform_wrapper .gfield_radio {
	display: flex;
	gap: 20px;
	flex-direction: row;
	flex-wrap: wrap;
}

.fx-gravity-form .gform_wrapper .gfield_radio .gchoice {
	display: flex;
	align-items: center;
	gap: 8px;
}

.fx-gravity-form .gform_wrapper .gfield_radio .gfield-choice-input[type="radio"] {
	appearance: none;
	-webkit-appearance: none;
	width: 22px;
	height: 22px;
	border: 2px solid #ccc;
	border-radius: 50%;
	background-color: #fff;
	flex-shrink: 0;
	cursor: pointer;
	position: relative;
	transition: border-color 0.2s ease;
}

.fx-gravity-form .gform_wrapper .gfield_radio .gfield-choice-input[type="radio"]:checked {
	border-color: var(--color-red);
	background-color: #fff;
}

.fx-gravity-form .gform_wrapper .gfield_radio .gfield-choice-input[type="radio"]:checked::after {
	content: '';
	display: block;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: var(--color-red);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.fx-gravity-form .gform_wrapper .gfield_radio .gfield-choice-input[type="radio"]:focus {
	outline: none !important;
	box-shadow: none !important;
}

.fx-gravity-form .gform_wrapper .gfield_radio .gfield-choice-input[type="radio"]:focus-visible {
	outline: 2px solid var(--color-red) !important;
	outline-offset: 2px;
	box-shadow: none !important;
}

.fx-gravity-form .gform_wrapper .gfield_radio .gform-field-label--type-inline {
	font-family: var(--font-body);
	font-weight: var(--font-weight-regular);
	font-size: 18px;
	line-height: 1.5;
	color: var(--color-black);
	margin-bottom: 0;
	margin-left: 0;
}

/* Checkbox lists — same red treatment as `.gfield_radio` (custom control, not native). */
.gform_wrapper .gfield_checkbox {
	display: flex;
	gap: 20px;
	flex-direction: row;
	flex-wrap: wrap;
}

.gform_wrapper .gfield_checkbox .gchoice {
	display: flex;
	align-items: center;
	gap: 8px;
}

.gform_wrapper .gfield_checkbox .gfield-choice-input[type="checkbox"],
.gform_wrapper .ginput_container_consent .gfield-choice-input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	width: 22px;
	height: 22px;
	margin: 0;
	border: 2px solid #ccc;
	border-radius: 4px;
	background-color: #fff;
	flex-shrink: 0;
	cursor: pointer;
	position: relative;
	transition: border-color 0.2s ease, background-color 0.2s ease;
}

.gform_wrapper .ginput_container_consent {
	display: flex;
	align-items: flex-start;
	gap: 8px;
}

.gform_wrapper .gfield_checkbox .gfield-choice-input[type="checkbox"]:checked,
.gform_wrapper .ginput_container_consent .gfield-choice-input[type="checkbox"]:checked {
	border-color: var(--color-red);
	background-color: var(--color-red);
}

.gform_wrapper .gfield_checkbox .gfield-choice-input[type="checkbox"]:checked::after,
.gform_wrapper .ginput_container_consent .gfield-choice-input[type="checkbox"]:checked::after {
	content: '';
	position: absolute;
	left: 6px;
	top: 2px;
	width: 5px;
	height: 10px;
	border: solid var(--color-white);
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.gform_wrapper .gfield_checkbox .gfield-choice-input[type="checkbox"]:focus,
.gform_wrapper .ginput_container_consent .gfield-choice-input[type="checkbox"]:focus {
	outline: none !important;
	box-shadow: none !important;
}

.gform_wrapper .gfield_checkbox .gfield-choice-input[type="checkbox"]:focus-visible,
.gform_wrapper .ginput_container_consent .gfield-choice-input[type="checkbox"]:focus-visible {
	outline: 2px solid var(--color-red) !important;
	outline-offset: 2px;
	box-shadow: none !important;
}

.gform_wrapper .gfield_checkbox .gform-field-label--type-inline {
	font-family: var(--font-body);
	font-weight: var(--font-weight-regular);
	font-size: 18px;
	line-height: 1.5;
	color: var(--color-black);
	margin-bottom: 0;
	margin-left: 0;
}


.fx-gravity-form .gform_wrapper .gform_page_footer {
	padding: 0;
	margin: 0;
	border: none;
}

.fx-gravity-form .gform_wrapper .gform_footer input[type="submit"],
.fx-gravity-form .gform_wrapper .gform_page_footer input[type="button"],
.fx-gravity-form .gform_wrapper .gform_page_footer input[type="submit"],
.fx-gravity-form .gform_wrapper .gform-theme-button:not(.gform_delete_file),
.fx-gravity-form .gform_wrapper .gform_next_button,
.fx-gravity-form .gform_wrapper .gform_button {
	width: 100% !important;
	display: block !important;
	background: var(--color-primary) !important;
	color: var(--color-white) !important;
	border: none !important;
	border-radius: 8px !important;
	padding: 0 25px !important;
	height: 57px !important;
	font-size: 18px !important;
	font-weight: 500 !important;
	font-family: var(--font-heading) !important;
	text-transform: uppercase !important;
	letter-spacing: 0 !important;
	cursor: pointer;
	transition: background var(--transition-medium) var(--transition-ease);
	line-height: 57px !important;
	text-align: center;
	box-shadow: none !important;
}

/* File preview: filename + delete on top row; progress bar below (GF DOM order: name, progress, button). */
.fx-gravity-form .gform_wrapper .ginput_preview {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px 12px;
	align-items: start;
	margin-top: 10px;
}

.fx-gravity-form .gform_wrapper .ginput_preview .gfield_fileupload_filename {
	grid-column: 1;
	grid-row: 1;
	min-width: 0;
}

.fx-gravity-form .gform_wrapper .ginput_preview .gfield_fileupload_progress {
	grid-column: 1 / -1;
	grid-row: 2;
}

/* File preview delete — GF reuses gform-theme-button--simple; trash via inline SVG (no fonts). */
.fx-gravity-form .gform_wrapper .ginput_preview .gform_delete_file.gform-theme-button.gform-theme-button--simple {
	grid-column: 2;
	grid-row: 1;
	align-self: start;
	justify-self: end;
	position: relative;
	overflow: visible;
	width: 44px !important;
	min-width: 44px !important;
	height: 44px !important;
	min-height: 44px !important;
	line-height: 1 !important;
	padding: 0 !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	background: var(--color-white) !important;
	color: var(--color-primary) !important;
	border: 2px solid var(--color-primary) !important;
	border-radius: 8px !important;
	text-transform: none !important;
	font-size: 0 !important;
	letter-spacing: normal !important;
}

.fx-gravity-form .gform_wrapper .ginput_preview .gform_delete_file.gform-theme-button.gform-theme-button--simple::before {
	content: "" !important;
	display: block !important;
	width: 20px !important;
	height: 20px !important;
	flex-shrink: 0;
	background-color: transparent !important;
	/* Fill matches custom-properties.css --color-primary default; override if brand red changes. */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23E91D2D' d='M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z'/%3E%3C/svg%3E") !important;
	background-size: 20px 20px !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
}

.fx-gravity-form .gform_wrapper .gform_delete_file .dashicons {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.fx-gravity-form .gform_wrapper .gform_page_footer .gform_previous_button {
	background: var(--color-gray);
	margin-bottom: 10px;
}

.fx-gravity-form .gform_wrapper .gform-submit-arrow {
	margin-left: 8px;
	font-family: 'wayne-alarm-icomoon' !important;
	font-size: 16px;
	font-style: normal;
	font-weight: normal;
	vertical-align: middle;
	position: relative;
	top: -2px;
}

.fx-gravity-form .gform_wrapper .gform-next-btn .gform-next-arrow {
	margin-left: 8px;
	font-family: 'wayne-alarm-icomoon' !important;
	font-size: 16px;
	font-style: normal;
	font-weight: normal;
	vertical-align: middle;
	position: relative;
	top: -2px;
}

.fx-gravity-form .gform_wrapper .gform-prev-btn .gform-prev-arrow {
	display: inline-block;
	margin-right: 8px;
	font-family: 'wayne-alarm-icomoon' !important;
	font-size: 16px;
	font-style: normal;
	font-weight: normal;
	vertical-align: middle;
	position: relative;
	top: -2px;
	transform: scaleX(-1);
}


.fx-gravity-form .gform_wrapper .gform_validation_errors {
	display: none;
}

.fx-gravity-form .gform_wrapper .gfield_error input[type="text"],
.fx-gravity-form .gform_wrapper .gfield_error input[type="email"],
.fx-gravity-form .gform_wrapper .gfield_error input[type="tel"],
.fx-gravity-form .gform_wrapper .gfield_error input[type="url"],
.fx-gravity-form .gform_wrapper .gfield_error input[type="number"],
.fx-gravity-form .gform_wrapper .gfield_error textarea {
	border-color: var(--color-primary);
	padding-right: 48px !important;
	background-image: url(../../img/error.svg) !important;
	background-repeat: no-repeat !important;
	background-position: right 15px center !important;
	background-size: 16px 15px !important;
}

.fx-gravity-form .gform_wrapper .gfield_error select,
.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__inner {
	border-color: var(--color-primary);
}

.fx-gravity-form .gform_wrapper .gfield_error .choices {
	position: relative;
	overflow: hidden;
	margin-bottom: 0;
	cursor: pointer;
	/* Rounds :focus-within outline (outline follows this box; top-only when list is open). */
	border-radius: 15px;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices.is-open {
	overflow: initial;
	border-radius: 15px 15px 0 0;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__inner {
	border: 1.5px solid var(--color-primary);
	border-radius: 15px !important;
	padding: 15px 50px 15px 15px;
	min-height: auto;
	font-size: 18px;
	font-family: var(--font-body);
	background-color: var(--color-white);
	display: flex;
	align-items: center;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices.is-open .choices__inner {
	border-radius: 15px 15px 0 0 !important;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--single {
	display: inline-block;
	padding: 0;
	width: 100%;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--single .choices__item {
	color: var(--color-text-secondary);
	font-size: 18px;
	line-height: 1.5;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices[data-type*='select-one']::after {
	content: "\e902";
	font-family: 'wayne-alarm-icomoon' !important;
	width: auto;
	height: auto;
	border: none;
	margin: 0;
	top: 50%;
	transform: translateY(-50%);
	color: var(--color-red);
	right: 15px;
	position: absolute;
	font-size: 16px;
	pointer-events: none;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices[data-type*='select-one']::before {
	content: "";
	position: absolute;
	right: 46px;
	height: 100%;
	width: 1px;
	background: var(--color-secondary);
	z-index: 1;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown {
	visibility: hidden;
	position: absolute;
	width: 100%;
	top: 100%;
	z-index: 100;
	background-color: var(--color-white);
	border: 1.5px solid var(--color-primary);
	border-top: none;
	border-radius: 0 0 15px 15px !important;
	overflow: hidden;
	margin-top: -1px;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown.is-active,
.fx-gravity-form .gform_wrapper .gfield_error .choices.is-open .choices__list--dropdown,
.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown[aria-expanded="true"] {
	visibility: visible;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown .choices__list {
	max-height: 300px;
	overflow: auto;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown .choices__item {
	padding: 10px 15px;
	font-size: 18px;
	font-family: var(--font-body);
	color: var(--color-text-secondary);
	cursor: pointer;
	pointer-events: auto;
}

.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown .choices__item.is-highlighted,
.fx-gravity-form .gform_wrapper .gfield_error .choices .choices__list--dropdown .choices__item:hover {
	background-color: var(--color-red);
	color: var(--color-white);
}

.fx-gravity-form .gform_wrapper .gfield_error .validation_message,
.fx-gravity-form .gform_wrapper .gfield_error .gfield_validation_message {
	font-family: var(--font-heading);
	font-weight: var(--font-weight-medium);
	font-size: 18px;
	line-height: 1;
	color: var(--color-primary);
	text-transform: uppercase;
	padding: 0;
	margin-top: 12px;
	background: transparent;
	border: none;
}


@media (min-width: 1200px) {
	.fx-gravity-form .gform_wrapper .gform_page_footer input[type="button"]:hover,
	.fx-gravity-form .gform_wrapper .gform_page_footer input[type="submit"]:hover,
	.fx-gravity-form .gform_wrapper .gform_footer input[type="submit"]:hover,
	.fx-gravity-form .gform_wrapper .gform-theme-button:not(.gform_delete_file):hover,
	.fx-gravity-form .gform_wrapper .gform_next_button:hover,
	.fx-gravity-form .gform_wrapper .gform_button:hover {
		background: var(--color-red-darkest) !important;
	}

	.fx-gravity-form .gform_wrapper .gform_delete_file.gform-theme-button.gform-theme-button--simple:hover {
		background: var(--color-primary) !important;
		color: var(--color-white) !important;
		border-color: var(--color-primary) !important;
	}

	.fx-gravity-form .gform_wrapper .gform_delete_file.gform-theme-button.gform-theme-button--simple:hover::before {
		filter: brightness(0) invert(1);
	}

	.fx-gravity-form .gform_wrapper .gform_page_footer .gform_previous_button:hover {
		background: var(--color-gray-dark) !important;
	}
}

/* -----------------------------------------------------------------------------
 * jQuery UI datepicker popup (`#ui-datepicker-div`) — GF loads script; theme CSS
 * replaces disabled Gravity Forms / jQuery UI theme stylesheets.
 * ----------------------------------------------------------------------------- */

#ui-datepicker-div {
	box-sizing: border-box;
	background-color: var(--color-white);
	border: 1.5px solid var(--color-secondary);
	border-radius: 15px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
	padding: 12px;
	font-family: var(--font-body);
	font-size: 15px;
	color: var(--color-text-secondary);
	z-index: 10010 !important;
	width: auto;
	min-width: 260px;
}

#ui-datepicker-div .ui-datepicker-header {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin-bottom: 10px;
	padding-bottom: 8px;
	border-bottom: 1px solid var(--color-secondary);
}

#ui-datepicker-div .ui-datepicker-title {
	flex: 1 1 auto;
	font-weight: 600;
	font-family: var(--font-heading);
	color: var(--color-black);
	text-align: center;
}

#ui-datepicker-div select.ui-datepicker-month,
#ui-datepicker-div select.ui-datepicker-year {
	margin: 0 4px;
	padding: 4px 8px;
	border-radius: 8px;
	border: 1px solid var(--color-secondary);
	font-family: var(--font-body);
	font-size: 14px;
	background-color: var(--color-white);
	color: var(--color-text-secondary);
}

#ui-datepicker-div select.ui-datepicker-month:focus,
#ui-datepicker-div select.ui-datepicker-year:focus {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

#ui-datepicker-div .ui-datepicker-prev,
#ui-datepicker-div .ui-datepicker-next {
	cursor: pointer;
	padding: 6px 10px;
	border-radius: 8px;
	border: none;
	background: transparent;
	font-size: 14px;
	line-height: 1.2;
	color: var(--color-primary);
}

#ui-datepicker-div .ui-datepicker-prev:hover,
#ui-datepicker-div .ui-datepicker-next:hover,
#ui-datepicker-div .ui-datepicker-prev:focus,
#ui-datepicker-div .ui-datepicker-next:focus {
	background-color: var(--color-bg-gray, #f2f2f2);
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

#ui-datepicker-div .ui-datepicker-calendar {
	width: 100%;
	border-collapse: collapse;
	margin: 0;
}

#ui-datepicker-div .ui-datepicker-calendar th {
	padding: 6px 4px;
	font-weight: 600;
	font-size: 13px;
	color: #222;
	text-align: center;
}

#ui-datepicker-div .ui-datepicker-calendar td {
	padding: 2px;
	text-align: center;
	vertical-align: middle;
}

#ui-datepicker-div .ui-datepicker-calendar td a,
#ui-datepicker-div .ui-datepicker-calendar td span {
	display: block;
	padding: 8px 4px;
	border-radius: 8px;
	text-decoration: none;
	color: inherit;
	border: 1px solid transparent;
	box-sizing: border-box;
}

#ui-datepicker-div .ui-datepicker-calendar td a:hover {
	background-color: var(--color-bg-gray, #f2f2f2);
	color: var(--color-black);
}

#ui-datepicker-div .ui-datepicker-calendar td .ui-state-active,
#ui-datepicker-div .ui-datepicker-calendar td .ui-state-highlight {
	background-color: var(--color-primary);
	color: var(--color-white);
}

#ui-datepicker-div .ui-datepicker-calendar .ui-datepicker-unselectable span {
	opacity: 0.35;
	cursor: default;
}

#ui-datepicker-div .ui-datepicker-buttonpane {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 8px;
	margin-top: 12px;
	padding-top: 10px;
	border-top: 1px solid var(--color-secondary);
}

#ui-datepicker-div .ui-datepicker-buttonpane button {
	cursor: pointer;
	padding: 8px 14px;
	border-radius: 8px;
	border: 1.5px solid var(--color-secondary);
	background: var(--color-white);
	font-family: var(--font-body);
	font-size: 14px;
	color: var(--color-text-secondary);
}

#ui-datepicker-div .ui-datepicker-buttonpane button:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}
