/**
 * Girdie 5K registration form — brand styling layered over the GravityForms
 * legacy markup. Scoped to .lgmd-girdie-form / #gform_wrapper_15 so it never
 * bleeds into the site's other forms.
 *
 * Design mirrors the reference prototype at lgmd5k.godooley.com (clean, modern,
 * LGMD-green): single elevated card, numbered section headers, generous inputs
 * with a green focus ring, card-style radio options, registrant cards.
 */

.lgmd-girdie-form_wrapper {
	--lgmd-green-900: #1b5e20;
	--lgmd-green-700: #2e7d32;
	--lgmd-green-600: #388e3c;
	--lgmd-green-500: #4caf50;
	--lgmd-green-50: #e8f5e9;
	--lgmd-ink: #1f2933;
	--lgmd-ink-soft: #4a5568;
	--lgmd-muted: #6b7280;
	--lgmd-line: #e5e7eb;
	--lgmd-line-strong: #d1d5db;
	--lgmd-surface: #ffffff;
	--lgmd-surface-alt: #f7f9f7;
	--lgmd-surface-sunken: #f3f4f6;
	--lgmd-danger: #b3261e;
	--lgmd-radius-sm: 6px;
	--lgmd-radius-md: 10px;
	--lgmd-radius-lg: 14px;
	--lgmd-shadow-sm: 0 1px 2px rgba(16, 24, 40, 0.04);
	--lgmd-shadow-md: 0 4px 12px rgba(16, 24, 40, 0.06);
	--lgmd-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* ---------- Container ---------- */
.lgmd-girdie-form_wrapper {
	max-width: 820px;
	margin: 2rem auto;
	font-family: var(--lgmd-font);
	color: var(--lgmd-ink);
	line-height: 1.55;
}

.lgmd-girdie-form_wrapper * {
	box-sizing: border-box;
}

/* The form itself becomes one elevated card. */
.lgmd-girdie-form {
	background: var(--lgmd-surface);
	border: 1px solid var(--lgmd-line);
	border-radius: var(--lgmd-radius-lg);
	box-shadow: var(--lgmd-shadow-md);
	padding: 2rem 2rem 1.75rem;
}

/* ---------- Field list reset ---------- */
.lgmd-girdie-form .gform_fields {
	display: block;
	margin: 0;
	padding: 0;
	list-style: none;
	counter-reset: lgmd-section;
}

.lgmd-girdie-form .gfield {
	list-style: none;
	margin: 0 0 1.25rem;
	padding: 0;
	overflow: visible;
}

.lgmd-girdie-form .gfield:last-child {
	margin-bottom: 0;
}

/* ---------- Labels ---------- */
.lgmd-girdie-form .gfield_label {
	display: block;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--lgmd-ink);
	margin: 0 0 0.4rem;
}

.lgmd-girdie-form .gfield_required_asterisk,
.lgmd-girdie-form .gfield_required {
	color: var(--lgmd-danger);
	font-weight: 700;
}

/* ---------- Inputs / selects / textarea ---------- */
.lgmd-girdie-form input[type="text"],
.lgmd-girdie-form input[type="email"],
.lgmd-girdie-form input[type="tel"],
.lgmd-girdie-form input[type="number"],
.lgmd-girdie-form select,
.lgmd-girdie-form textarea {
	width: 100%;
	font: inherit;
	color: var(--lgmd-ink);
	background: #fff;
	border: 1px solid var(--lgmd-line-strong);
	border-radius: var(--lgmd-radius-sm);
	padding: 0.7rem 0.85rem;
	margin: 0;
	box-shadow: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.lgmd-girdie-form input[type="text"]:focus,
.lgmd-girdie-form input[type="email"]:focus,
.lgmd-girdie-form input[type="tel"]:focus,
.lgmd-girdie-form input[type="number"]:focus,
.lgmd-girdie-form select:focus,
.lgmd-girdie-form textarea:focus {
	outline: none;
	border-color: var(--lgmd-green-600);
	box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.18);
}

.lgmd-girdie-form select {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%234a5568' d='M6 8L0 0h12z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 0.85rem center;
	padding-right: 2.25rem;
}

/* ---------- Field descriptions / sub-labels ---------- */
.lgmd-girdie-form .gfield_description,
.lgmd-girdie-form .gsection_description {
	font-size: 0.85rem;
	color: var(--lgmd-muted);
	margin-top: 0.4rem;
	padding: 0;
}

.lgmd-girdie-form .gfield_validation_message {
	font-size: 0.85rem;
	color: var(--lgmd-danger);
	margin-top: 0.4rem;
	padding: 0;
	background: none;
	border: 0;
}

.lgmd-girdie-form .gfield_error input,
.lgmd-girdie-form .gfield_error select,
.lgmd-girdie-form .gfield_error textarea {
	border-color: var(--lgmd-danger);
}

/* ---------- Section headers (numbered) ---------- */
.lgmd-girdie-form_wrapper .gsection {
	border: 0 !important;
	border-top: 1px solid var(--lgmd-line) !important;
	margin: 2rem 0 1.25rem !important;
	/* Avada overrides .gfield padding — force the gap below the divider line. */
	padding: 2.5rem 0 0 !important;
}

.lgmd-girdie-form_wrapper .gsection:first-child {
	border-top: 0 !important;
	margin-top: 0 !important;
	padding-top: 0 !important;
}

.lgmd-girdie-form_wrapper .gsection_title {
	counter-increment: lgmd-section;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	/* Avada applies its serif heading font to h2/h3 — force the form's sans. */
	font-family: var(--lgmd-font) !important;
	font-size: 1.2rem !important;
	font-weight: 700 !important;
	line-height: 1.3 !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
	color: var(--lgmd-ink) !important;
	margin: 0;
}

.lgmd-girdie-form .gsection_title::before {
	content: counter(lgmd-section);
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--lgmd-green-600);
	color: #fff;
	font-size: 0.95rem;
	font-weight: 600;
}

/* ---------- Address (GF complex grid) ---------- */
.lgmd-girdie-form .ginput_container_address {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem 1.25rem;
	margin-top: 0.25rem;
}

.lgmd-girdie-form .ginput_container_address > span {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: column-reverse; /* sub-label sits above its input */
	margin: 0;
}

.lgmd-girdie-form .ginput_container_address > .address_state,
.lgmd-girdie-form .ginput_container_address > .address_zip {
	grid-column: span 1;
}

.lgmd-girdie-form .ginput_container_address .gform-field-label--type-sub {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--lgmd-ink-soft);
	margin: 0 0 0.35rem;
}

@media (max-width: 600px) {
	.lgmd-girdie-form .ginput_container_address {
		grid-template-columns: 1fr;
	}
	.lgmd-girdie-form .ginput_container_address > span {
		grid-column: 1 / -1;
	}
}

/* ---------- Radio options as cards ---------- */
.lgmd-girdie-form .gfield_radio,
.lgmd-girdie-form .gfield_checkbox {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.lgmd-girdie-form_wrapper .lgmd-girdie-form .gfield_radio .gchoice {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0;
	/* Avada resets .gchoice padding to 0 with high specificity — force it. */
	padding: 1rem 1.1rem !important;
	border: 1px solid var(--lgmd-line-strong);
	border-radius: var(--lgmd-radius-md);
	background: #fff;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease;
}

.lgmd-girdie-form .gfield_radio .gchoice:hover {
	border-color: var(--lgmd-green-500);
	background: var(--lgmd-surface-alt);
}

.lgmd-girdie-form .gfield_radio .gchoice:has(input[type="radio"]:checked) {
	border-color: var(--lgmd-green-600);
	background: var(--lgmd-green-50);
}

.lgmd-girdie-form .gfield_radio input[type="radio"],
.lgmd-girdie-form .gfield_checkbox input[type="checkbox"] {
	margin: 0;
	accent-color: var(--lgmd-green-600);
	flex: 0 0 auto;
}

/* Consistent label weight (Avada bolds the checked option otherwise). */
.lgmd-girdie-form_wrapper .gchoice label {
	margin: 0 !important;
	font-weight: 500 !important;
	color: var(--lgmd-ink);
	cursor: pointer;
}

/* ---------- Checkbox options (lighter card) ---------- */
.lgmd-girdie-form_wrapper .lgmd-girdie-form .gfield_checkbox .gchoice {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	margin: 0;
	padding: 0.85rem 1rem !important;
	border: 1px solid var(--lgmd-line);
	border-radius: var(--lgmd-radius-md);
	background: var(--lgmd-surface-alt);
	cursor: pointer;
}

.lgmd-girdie-form .gfield_checkbox .gchoice label {
	font-weight: 500;
	color: var(--lgmd-ink-soft);
	font-size: 0.95rem;
}

/* ---------- Repeater: additional-registrant cards ---------- */
.lgmd-girdie-form .gfield_repeater,
.lgmd-girdie-form .gfield_repeater_container {
	border: 0;
	margin: 0;
	padding: 0;
}

.lgmd-girdie-form .gfield_repeater > legend {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--lgmd-ink);
	margin-bottom: 0.4rem;
	padding: 0;
}

.lgmd-girdie-form .gfield_repeater_item {
	background: var(--lgmd-surface-alt);
	border: 1px solid var(--lgmd-line);
	border-radius: var(--lgmd-radius-md);
	padding: 1.25rem 1.25rem 1rem;
	margin-bottom: 1rem;
}

.lgmd-girdie-form .gfield_repeater_cell {
	margin-bottom: 0.85rem;
}

.lgmd-girdie-form .gfield_repeater_cell:last-child {
	margin-bottom: 0;
}

.lgmd-girdie-form .gfield_repeater_cell > label {
	display: block;
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--lgmd-ink-soft);
	margin: 0 0 0.35rem;
}

/* Cells hidden by the same-as-primary toggle. */
.lgmd-girdie-form .lgmd-hidden-cell,
.lgmd-girdie-form .gfield_repeater_cell[hidden] {
	display: none !important;
}

/* Add / remove repeater buttons → on-brand pill buttons. */
.lgmd-girdie-form .gfield_repeater_buttons button,
.lgmd-girdie-form .add_repeater_item {
	font: inherit;
	font-weight: 600;
	font-size: 0.9rem;
	cursor: pointer;
	border-radius: var(--lgmd-radius-sm);
	padding: 0.5rem 1rem;
	background: #fff;
	color: var(--lgmd-green-700);
	border: 1px solid var(--lgmd-green-600);
	transition: background 0.15s ease;
}

.lgmd-girdie-form .gfield_repeater_buttons button:hover,
.lgmd-girdie-form .add_repeater_item:hover {
	background: var(--lgmd-green-50);
}

.lgmd-girdie-form .gfield_repeater_buttons .remove_repeater_item {
	color: var(--lgmd-ink-soft);
	border-color: var(--lgmd-line-strong);
}

.lgmd-girdie-form .gfield_repeater_buttons .remove_repeater_item:hover {
	color: var(--lgmd-danger);
	border-color: var(--lgmd-danger);
	background: #fff;
}

/* ---------- Donation amount ---------- */
/* No CSS "$" prefix here: GF renders this currency field as type=text and
   formats the value itself on blur ("$5.00"), so an overlay would collide
   with typed digits. A placeholder supplies the empty-state affordance. */

/* ---------- Date field (planned 5K date) ---------- */
.lgmd-girdie-form_wrapper .ginput_container_date {
	position: relative;
}

.lgmd-girdie-form_wrapper .ginput_container_date input.datepicker {
	padding-left: 2.5rem !important;
}

/* GF appends the calendar icon after the input — pin it inside, left. */
.lgmd-girdie-form_wrapper .ginput_container_date .ui-datepicker-trigger {
	position: absolute;
	left: 0.85rem;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: auto;
	margin: 0;
	cursor: pointer;
}

/* ---------- Stripe card field ---------- */
.lgmd-girdie-form_wrapper .ginput_stripe_creditcard {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 0.25rem;
}

.lgmd-girdie-form_wrapper .ginput_stripe_creditcard > .ginput_full {
	margin: 0;
	display: flex;
	flex-direction: column-reverse; /* sub-label sits above its field */
}

/* The Stripe Elements mount becomes a bordered input box (number/expiry/CVC/ZIP). */
.lgmd-girdie-form_wrapper .ginput_stripe_creditcard .StripeElement {
	width: 100%;
	min-height: 46px;
	border: 1px solid var(--lgmd-line-strong);
	border-radius: var(--lgmd-radius-sm);
	background: #fff;
	padding: 0.8rem 0.85rem;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.lgmd-girdie-form_wrapper .ginput_stripe_creditcard .StripeElement--focus {
	border-color: var(--lgmd-green-600);
	box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.18);
}

.lgmd-girdie-form_wrapper .ginput_stripe_creditcard .StripeElement--invalid {
	border-color: var(--lgmd-danger);
}

/* Hide the redundant "Card Details" sub-label (the field label already says it). */
.lgmd-girdie-form_wrapper .ginput_stripe_creditcard .ginput_full:has(.StripeElement) > label {
	display: none;
}

/* Cardholder-name sub-label → small label above its input. */
.lgmd-girdie-form_wrapper .ginput_stripe_creditcard .ginput_full:has(> input[type="text"]) > label {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--lgmd-ink-soft);
	margin: 0 0 0.35rem;
}

/* ---------- Submit footer ---------- */
.lgmd-girdie-form .gform_footer {
	text-align: center;
	margin: 2rem 0 0;
	padding: 1.75rem 0 0;
	border-top: 1px solid var(--lgmd-line);
}

.lgmd-girdie-form .gform_footer input[type="submit"],
.lgmd-girdie-form .gform_footer button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font: inherit;
	font-size: 1.05rem;
	font-weight: 600;
	min-width: 240px;
	padding: 0.85rem 2rem;
	border-radius: var(--lgmd-radius-sm);
	border: 1px solid var(--lgmd-green-600);
	background: var(--lgmd-green-600);
	color: #fff;
	cursor: pointer;
	transition: background 0.15s ease, border-color 0.15s ease, transform 0.05s ease;
}

.lgmd-girdie-form .gform_footer input[type="submit"]:hover,
.lgmd-girdie-form .gform_footer button:hover {
	background: var(--lgmd-green-700);
	border-color: var(--lgmd-green-700);
}

.lgmd-girdie-form .gform_footer input[type="submit"]:active,
.lgmd-girdie-form .gform_footer button:active {
	transform: translateY(1px);
}

/* ---------- Validation summary ---------- */
.lgmd-girdie-form .gform_validation_errors {
	border: 1px solid var(--lgmd-danger);
	background: #fdecea;
	border-radius: var(--lgmd-radius-md);
	box-shadow: none;
	color: var(--lgmd-danger);
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
}

.lgmd-girdie-form .gform_validation_errors .gform_submission_error {
	color: var(--lgmd-danger);
	font-weight: 700;
}

/* ---------- Live payment summary (built by form.js) ---------- */
.lgmd-girdie-payment-summary {
	margin-top: 0.5rem;
}
.lgmd-ps {
	background: var(--lgmd-surface-alt);
	border: 1px solid var(--lgmd-line);
	border-radius: var(--lgmd-radius-md);
	padding: 1rem 1.25rem;
}
.lgmd-ps__row {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 1rem;
	padding: 0.4rem 0;
}
.lgmd-ps__label {
	color: var(--lgmd-ink-soft);
}
.lgmd-ps__detail {
	color: var(--lgmd-muted);
	font-size: 0.85em;
}
.lgmd-ps__value {
	font-variant-numeric: tabular-nums;
	font-weight: 600;
	color: var(--lgmd-ink);
	white-space: nowrap;
}
.lgmd-ps__muted .lgmd-ps__value {
	color: var(--lgmd-muted);
	font-weight: 500;
}
.lgmd-ps__total {
	border-top: 1px solid var(--lgmd-line-strong);
	margin-top: 0.4rem;
	padding-top: 0.85rem;
	font-size: 1.1rem;
	font-weight: 700;
}
.lgmd-ps__total .lgmd-ps__label,
.lgmd-ps__total .lgmd-ps__value {
	color: var(--lgmd-ink);
}

/* ---------- Small screens ---------- */
@media (max-width: 600px) {
	.lgmd-girdie-form {
		padding: 1.5rem 1.1rem;
	}
	.lgmd-girdie-form .gform_footer input[type="submit"],
	.lgmd-girdie-form .gform_footer button {
		width: 100%;
		min-width: 0;
	}
}
