/* Standardize inputs */
input,
textarea,
select {
	font: inherit;
	padding: var(--space-xxsmall) var(--space-xsmall);
	border: 1px solid var(--color-neutral-200);
	border-radius: var(--border-radius, 4px); /* NOTE: This matches select2 fields. */
	width: 100%;
	
	/* Not sure about these... Maybe should be tied to button styles? */
	font-family: var(--body-small-font-desktop);
	font-size: var(--body-small-size-rem-desktop);
	font-weight: var(--body-small-weight-desktop);
	line-height: var(--body-small-line-height-rem-desktop);
}

@media (min-width: 64em) {

	form.post-password-form {
		margin: 5em auto 15em;
	}
}

/* Special case field types */
input[type="submit"],
input[type="number"],
input[type="radio"],
input[type="checkbox"] {
	width: auto;	
}

input[type="radio"],
input[type="checkbox"] {
	padding: inherit;
}

/* Gravity forms specific */
.gform_wrapper {
	clear: both;	
}

.gform_fields,
.gfield_radio,
.gfield_checkbox {
	list-style: none;
	margin: 0;
	padding: 0;	
}

.gform_fields > li {
	margin: 1em 0;	
}

.gform_fields > li.gform_hidden {
	margin: 0;
}

.gfield > label {
	display: block;
	font-family: var(--label-large-font-desktop);
	font-size: var(--label-large-size-rem-desktop);
	font-weight: var(--label-large-weight-desktop);
	line-height: var(--label-large-line-height-rem-desktop);
}

.gfield_radio input {
	margin-right: 0.25em;	
}

.gfield_description {
	font-family: var(--label-medium-font-desktop);
	font-size: var(--label-medium-size-rem-desktop);
	font-weight: var(--body-small-weight-desktop);
	line-height: var(--label-medium-line-height-rem-desktop);
}

.validation_message {
	color: var(--color-form-error);
}

.gform_footer {
	margin-top: 1em;	
}

.gform_button.button {
	border: 1px solid transparent;	
}

/* Gravity Forms theme markup bridge */
.gform_wrapper.gravity-theme {
	clear: both;
}

.gform_wrapper.gravity-theme :where(.gform_fields, .gfield_radio, .gfield_checkbox) {
	list-style: none;
	margin: 0;
	padding: 0;
}

.gform_wrapper.gravity-theme .gfield {
	margin: 1em 0;
}

.gform_wrapper.gravity-theme :where(.gfield_label, .gform-field-label, .gform_required_legend) {
	display: block;
	font-family: var(--label-large-font-desktop);
	font-size: var(--label-large-size-rem-desktop);
	font-weight: var(--label-large-weight-desktop);
	line-height: var(--label-large-line-height-rem-desktop);
}

.gform_wrapper.gravity-theme :where(.gfield_description, .gform_description, .gfield_consent_description) {
	font-family: var(--label-medium-font-desktop);
	font-size: var(--label-medium-size-rem-desktop);
	font-weight: var(--body-small-weight-desktop);
	line-height: var(--label-medium-line-height-rem-desktop);
}

.gform_wrapper.gravity-theme :where(.gfield_required, .gfield_validation_message, .validation_message) {
	color: var(--color-form-error);
}

.gform_wrapper.gravity-theme :where(.gform_validation_errors, .gform_confirmation_message) {
	border: 1px solid var(--color-neutral-200);
	border-radius: var(--border-radius);
	padding: var(--space-small) var(--space-medium);
	background-color: var(--color-form-surface);
}

.gform_wrapper.gravity-theme .gform_validation_errors {
	border-color: var(--color-form-error);
	color: var(--color-form-error);
}

.gform_wrapper.gravity-theme .gform_confirmation_message {
	border-color: var(--color-form-success);
}

.gform_wrapper.gravity-theme :where(.gform_footer, .gform_page_footer) {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-small);
	margin-top: 1em;
}

.gform_wrapper.gravity-theme :where(.gform_button, .gform_next_button, .gform_previous_button) {
	width: auto;
}

/* Honeypot fields */
.gform_validation_container {
	position: absolute;
	left: -9999em;
	top: -9999em;
}

/* Date Select Fields */
.ui-datepicker {
	padding: 0.5em;
	background-color: var(--color-form-surface);
	border: 1px solid var(--gray-light);
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);	
}

.ui-datepicker-header {
	display: flex;
	align-items: center;
}

.ui-datepicker-prev {
	order: 1;	
}

.ui-datepicker-next {
	order: 3;	
}

.ui-datepicker-title {
	order: 2;
	padding: 0 0.5em;	
}

.ui-datepicker-title select {
	max-width: 50%;	
}

.ui-datepicker-calendar {
	margin-bottom: 0;
	border-collapse: collapse;	
}

.ui-datepicker-calendar td {
	border: 1px solid var(--gray-light);
	text-align: center;
}

.ui-datepicker-calendar .ui-datepicker-today {
	background-color: var(--gray-xlight);
}

.ui-datepicker-calendar td a {
	display: block;
	text-decoration: none;
	width: 2em;
	line-height: 2;
}

/* Put the hide-labels class on the form to hide all labels */
.hide-labels label {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	white-space: nowrap;	
}

/* Required field has no value */
.invalid > input,
input[aria-invalid="true"],
.gfield_error input {
	box-shadow: inset 2px 0 0 var(--color-form-error);
}

/* Required field has value */
.valid > input {
	box-shadow: inset 2px 0 0 var(--color-form-success);
}

/* Select2 Fields need lots of overrides */
.select2.select2-container {
	display: block;
	font-family: var(--body-small-font-desktop);
	font-size: var(--body-small-size-rem-desktop);
	font-weight: var(--body-small-weight-desktop);
	line-height: var(--body-small-line-height-rem-desktop);
}

.select2.select2-container .select2-selection--single {
	height: auto;
	margin: 0;
	border-color: var(--color-neutral-200);
	border-radius: var(--border-radius);
}

.select2.select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: inherit;
	color: inherit;
	padding-top: var(--space-xxsmall);
	padding-bottom: var(--space-xxsmall);
}

.select2.select2-container--default .select2-selection--single .select2-selection__placeholder {
	display: block;
	min-height: 1.5em;
}

.select2.select2-container--default .select2-selection--single .select2-selection__arrow {
	height: auto;
	bottom: 1px;
}

.select2-container .select2-results {
	font-family: var(--body-small-font-desktop);
	font-size: var(--body-small-size-rem-desktop);
	font-weight: var(--body-small-weight-desktop);
	line-height: var(--body-small-line-height-rem-desktop);
}

/* Password Protected Login Page */
form.post-password-form {
	margin: 5em auto;
	max-width: 650px;
}

form.post-password-form > p:first-of-type::before {
	content: "Please Enter Password";
	display: block;
	font-family: var(--heading-small-font-desktop);
	font-size: var(--heading-small-size-rem-desktop);
	font-weight: var(--label-large-weight-desktop);
	line-height: var(--heading-small-line-height-rem-desktop);
	text-transform: uppercase;
}

form.post-password-form > p:last-of-type {
	align-items: flex-end;
	display: flex;
	justify-content: space-between;
}

form.post-password-form > p:last-of-type label {
	margin-right: var(--space-large);
	width: 100%;
}

form.post-password-form > p:last-of-type > input {
	background-color: var(--color-primary-500);
	border: none;
	border-radius: 1.5em;
	color: var(--color-white);
	font-family: var(--body-small-font-desktop);
	font-size: var(--body-small-size-rem-desktop);
	font-weight: var(--label-large-weight-desktop);
	height: fit-content;
	line-height: var(--body-small-line-height-rem-desktop);
	padding: var(--space-xxsmall) var(--space-normal);
}

button.display-password,
button.show-password-input {
    display: none;
}

