/**
 * Contact form block — front-end styles
 * Mirrors design/index.html .contact-hero + .form-card--split + form fields.
 */

/* ── Contact hero (dark wrapper) ──────────────────────────── */

.contact-hero {
	background: var(--wp--preset--color--ink);
	color: var(--wp--preset--color--paper);
	position: relative;
	overflow: hidden;
}

.contact-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(1100px 600px at 85% -10%, rgba(224, 48, 30, 0.18), transparent 60%),
		radial-gradient(900px 500px at 5% 110%, rgba(224, 48, 30, 0.08), transparent 60%);
	pointer-events: none;
}

.contact-hero > .container {
	position: relative;
	z-index: 1;
}

.contact-hero__head {
	text-align: center;
	max-width: 980px;
	margin: 0 auto 56px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
}

.contact-hero__title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 400;
	font-size: clamp(40px, 5vw, 80px);
	line-height: 0.94;
	letter-spacing: -0.02em;
	margin: 0;
	text-transform: uppercase;
	color: var(--wp--preset--color--paper);
}

.contact-hero__title .red {
	color: var(--wp--preset--color--red);
}

/* ── Form card (split: pitch + form) ──────────────────────── */

.form-card--split {
	max-width: 1296px;
	margin: 0 auto;
	background: var(--wp--preset--color--paper);
	border: 1px solid var(--wp--preset--color--paper);
	border-radius: 8px;
	padding: 56px;
	display: grid;
	grid-template-columns: minmax(280px, 348px) 1fr;
	gap: 108px;
	align-items: stretch;
	box-shadow:
		0 1px 0 rgba(255, 255, 255, 0.04),
		0 40px 80px -20px rgba(0, 0, 0, 0.6),
		0 80px 160px -40px rgba(224, 48, 30, 0.18);
	position: relative;
}

.form-card__pitch {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 32px;
	min-height: 100%;
}

.form-card__pitch-title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 400;
	font-size: 48px;
	line-height: 1.05;
	letter-spacing: -0.5px;
	color: var(--wp--preset--color--ink);
	margin: 0;
	text-transform: uppercase;
}

.form-card__pitch-callout {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 700;
	font-size: 20px;
	line-height: 1.4;
	color: var(--wp--preset--color--red);
	margin: 12px 0 0;
}

.form-card__pitch-body {
	font-family: var(--wp--preset--font-family--body);
	font-size: 16px;
	line-height: 1.5;
	color: var(--tsuyo-ink-soft);
	margin: 24px 0 0;
}

.form-card__badges {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: flex-start;
	gap: 16px;
	flex-wrap: wrap;
}

.form-card__badges img {
	display: block;
	width: 100px;
	height: auto;
	object-fit: contain;
	flex: 0 0 auto;
}

.form-card__form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.form-card__missing-plugin {
	color: var(--wp--preset--color--amber);
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	margin: 0;
}

/* ── Gravity Forms overrides — make GF markup match our field styling ── */

.form-card__form .gform_wrapper {
	margin: 0;
}

.form-card__form .gform_wrapper form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.form-card__form .gform_fields {
	display: flex;
	flex-direction: column;
	gap: 20px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.form-card__form .gfield {
	display: flex;
	flex-direction: column;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.form-card__form .gfield_label {
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--ink);
	margin: 0;
	padding: 0;
}

.form-card__form .gfield_required {
	color: var(--wp--preset--color--ink);
	font-weight: 500;
	margin-left: 2px;
}

.form-card__form .ginput_container input[type="text"],
.form-card__form .ginput_container input[type="email"],
.form-card__form .ginput_container input[type="tel"],
.form-card__form .ginput_container select,
.form-card__form .ginput_container textarea,
.form-card__form .gform_wrapper input[type="text"],
.form-card__form .gform_wrapper input[type="email"],
.form-card__form .gform_wrapper input[type="tel"],
.form-card__form .gform_wrapper select,
.form-card__form .gform_wrapper textarea {
	width: 100%;
	height: 48px;
	background: var(--wp--preset--color--field-bg);
	border: 1px solid var(--wp--preset--color--field-border);
	padding: 12px 16px;
	font-family: var(--wp--preset--font-family--body);
	font-size: 16px;
	color: var(--wp--preset--color--ink);
	border-radius: 0;
	box-sizing: border-box;
}

.form-card__form .gform_wrapper textarea {
	height: calc(1.5em * 4 + 24px);
	min-height: 0;
	resize: vertical;
	line-height: 1.5;
}

.form-card__form .gform_wrapper select {
	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 d='M1 1l5 5 5-5' stroke='%230A0A0A' stroke-opacity='.65' stroke-width='1.5' fill='none'/></svg>");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 44px;
	appearance: none;
	-webkit-appearance: none;
}

.form-card__form .gform_wrapper input::placeholder,
.form-card__form .gform_wrapper textarea::placeholder {
	color: var(--tsuyo-ink-mute);
}

.form-card__form .gform_wrapper input:focus,
.form-card__form .gform_wrapper select:focus,
.form-card__form .gform_wrapper textarea:focus {
	outline: none;
	border: 2px solid var(--wp--preset--color--ink);
	padding: 11px 15px;
}

/* Submit button — match .btn.btn--primary.btn--block */
.form-card__form .gform_footer {
	margin: 8px 0 0;
	padding: 0;
}

.form-card__form .gform_footer input[type="submit"],
.form-card__form .gform_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 22px 28px;
	font-family: var(--wp--preset--font-family--display);
	font-weight: 400;
	font-size: 16px;
	letter-spacing: 0.125em;
	text-transform: uppercase;
	background: var(--wp--preset--color--red);
	color: var(--wp--preset--color--paper);
	border: 1px solid transparent;
	border-radius: 0;
	cursor: pointer;
	transition: background-color 200ms ease, scale 200ms ease;
	white-space: nowrap;
}

.form-card__form .gform_footer input[type="submit"]:hover,
.form-card__form .gform_button:hover {
	background: var(--wp--preset--color--red-dim);
}

.form-card__form .gform_footer input[type="submit"]:active,
.form-card__form .gform_button:active {
	scale: 0.995;
}

/* ── Field descriptions / helper text per field ───────────────── */
.form-card__form .gfield_description {
	font-family: var(--wp--preset--font-family--body);
	font-size: 13px;
	color: var(--tsuyo-ink-soft);
	line-height: 1.5;
	margin: 6px 0 0;
	padding: 0;
}

.form-card__form .gfield_description.gfield_description_above {
	margin: 0 0 6px;
}

/* ── Required asterisk ────────────────────────────────────────── */
.form-card__form .gfield_required {
	color: var(--wp--preset--color--ink);
	font-weight: 500;
	margin-left: 4px;
	opacity: 0.55;
}
.form-card__form .gfield_required_text,
.form-card__form .gfield_required .gfield_required_asterisk {
	font-family: var(--wp--preset--font-family--body);
	font-size: 12px;
}

/* ── Top-level "Required fields are marked..." legend ─────────── */
.form-card__form .gform_required_legend {
	font-family: var(--wp--preset--font-family--body);
	font-size: 12px;
	color: var(--tsuyo-ink-mute);
	margin: 0 0 12px;
}

/* ── Validation: per-field error messages ─────────────────────── */
.form-card__form .gfield_validation_message,
.form-card__form .validation_message {
	display: block;
	color: var(--wp--preset--color--amber);
	font-family: var(--wp--preset--font-family--body);
	font-size: 13px;
	font-weight: 500;
	margin: 6px 0 0;
	padding: 0;
	background: transparent;
	border: 0;
}

/* ── Validation: error-state field chrome ─────────────────────── */
.form-card__form .gfield_error input,
.form-card__form .gfield_error select,
.form-card__form .gfield_error textarea,
.form-card__form .gfield--has-error input,
.form-card__form .gfield--has-error select,
.form-card__form .gfield--has-error textarea {
	border-color: var(--wp--preset--color--amber);
	background: var(--wp--preset--color--field-bg);
}

.form-card__form .gfield_error .gfield_label,
.form-card__form .gfield--has-error .gfield_label {
	color: var(--wp--preset--color--ink);
}

/* ── Validation: top-level form error summary ─────────────────── */
.form-card__form .gform_validation_errors,
.form-card__form .validation_error {
	background: var(--wp--preset--color--bone);
	border: 1px solid var(--wp--preset--color--amber);
	color: var(--wp--preset--color--ink);
	padding: 14px 18px;
	margin: 0 0 20px;
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	line-height: 1.5;
	list-style: none;
}

.form-card__form .gform_validation_errors > h2,
.form-card__form .gform_submission_error {
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 600;
	color: var(--wp--preset--color--amber);
	margin: 0 0 6px;
	padding: 0;
}

.form-card__form .gform_validation_errors ol {
	list-style: disc;
	padding-left: 20px;
	margin: 8px 0 0;
}

.form-card__form .gform_validation_errors ol a {
	color: var(--wp--preset--color--ink);
	text-decoration: underline;
}

/* ── Confirmation (success) message ───────────────────────────── */
.form-card__form .gform_confirmation_wrapper,
.form-card__form .gform_confirmation_message {
	font-family: var(--wp--preset--font-family--body);
	font-size: 17px;
	line-height: 1.55;
	color: var(--wp--preset--color--ink);
	padding: 0;
	border: 0;
	background: transparent;
}

/* ── Thank-you panel (custom GF confirmation override) ─────── */

.tsuyo-thanks {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	padding: 8px 8px 16px;
	text-align: center;
}

/* Animated green check — SVG file with self-contained animations.
   Loaded via <img> so GF's HTML kses filter doesn't strip it. */
.tsuyo-thanks__check {
	width: 80px;
	height: 80px;
	margin-bottom: 6px;
}
.tsuyo-thanks__check img {
	display: block;
	width: 100%;
	height: 100%;
}

.tsuyo-thanks__heading {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 400;
	font-size: clamp(36px, 4.5vw, 56px);
	line-height: 1;
	letter-spacing: -0.02em;
	text-transform: uppercase;
	color: var(--wp--preset--color--ink);
	margin: 0;
	max-width: 18ch;
}

.tsuyo-thanks__id {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--tsuyo-ink-mute);
	margin: 0;
}

.tsuyo-thanks__id strong {
	color: var(--tsuyo-ink-soft);
	font-weight: 500;
}

.tsuyo-thanks__sub {
	font-family: var(--wp--preset--font-family--body);
	font-size: 17px;
	line-height: 1.5;
	color: var(--tsuyo-ink-soft);
	margin: 0;
	max-width: 36ch;
}

.tsuyo-thanks__sub strong {
	font-weight: 600;
	color: var(--wp--preset--color--ink);
}

/* Next steps */
.tsuyo-thanks__steps {
	width: 100%;
	max-width: 480px;
	margin-top: 12px;
	padding-top: 24px;
	border-top: 1px solid var(--tsuyo-line-light);
	text-align: left;
}

.tsuyo-thanks__steps-kicker {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--wp--preset--color--red);
	margin: 0 0 16px;
}

.tsuyo-thanks__steps-list {
	list-style: none;
	counter-reset: tsuyo-step;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.tsuyo-thanks__steps-list li {
	counter-increment: tsuyo-step;
	position: relative;
	padding-left: 36px;
	font-family: var(--wp--preset--font-family--body);
	font-size: 15px;
	line-height: 1.55;
	color: var(--wp--preset--color--ink);
}

.tsuyo-thanks__steps-list li::before {
	content: counter(tsuyo-step, decimal-leading-zero);
	position: absolute;
	left: 0;
	top: 0;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.14em;
	color: var(--tsuyo-ink-mute);
}

.tsuyo-thanks__steps-list strong {
	font-weight: 600;
}

/* Practitioner card — stacked & centered */
.tsuyo-thanks__owner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	width: 100%;
	max-width: 480px;
	margin-top: 8px;
	padding-top: 24px;
	border-top: 1px solid var(--tsuyo-line-light);
	text-align: center;
}

.tsuyo-thanks__avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	background: var(--wp--preset--color--bone);
}

.tsuyo-thanks__owner-meta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
}

.tsuyo-thanks__owner-name {
	font-family: var(--wp--preset--font-family--body);
	font-weight: 600;
	font-size: 16px;
	color: var(--wp--preset--color--ink);
	margin: 0;
}

.tsuyo-thanks__owner-role {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--tsuyo-ink-soft);
	margin: 0;
}

.tsuyo-thanks__footnote {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 12px;
	letter-spacing: 0.06em;
	color: var(--tsuyo-ink-mute);
	text-align: center;
	max-width: 32ch;
	margin: 12px auto 0;
}

@media (max-width: 480px) {
	.tsuyo-thanks__heading {
		font-size: clamp(32px, 8vw, 44px);
	}
	.tsuyo-thanks__owner {
		gap: 12px;
	}
	.tsuyo-thanks__avatar {
		width: 64px;
		height: 64px;
	}
}

/* ── AJAX loading spinner — hide GF's default image. */
.form-card__form .gform_ajax_spinner,
.form-card__form img.gform_ajax_spinner {
	display: none !important;
}

/* ── Submit button — loading state replaces label with spinner ─ */
.form-card__form .gform_footer {
	position: relative;
}

/* Trigger conditions: GF adds .gform_ajax_spinner during AJAX submit, OR
   it disables the button. Either path puts us in loading state. */
.form-card__form .gform_footer:has(.gform_ajax_spinner) input[type="submit"],
.form-card__form .gform_footer:has(.gform_ajax_spinner) .gform_button,
.form-card__form .gform_footer input[type="submit"]:disabled,
.form-card__form .gform_button:disabled,
.form-card__form .gform_button.is-loading,
.form-card__form input[type="submit"].is-loading {
	color: transparent !important;
	cursor: wait;
	pointer-events: none;
	background: var(--wp--preset--color--red) !important;
	opacity: 1 !important;
}

/* Spinner overlay — absolutely centered over the loading button. */
.form-card__form .gform_footer:has(.gform_ajax_spinner)::after,
.form-card__form .gform_footer:has(input[type="submit"]:disabled)::after,
.form-card__form .gform_footer:has(.gform_button:disabled)::after,
.form-card__form .gform_footer:has(.is-loading)::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 22px;
	height: 22px;
	margin: -11px 0 0 -11px;
	border: 2px solid rgba(255, 255, 255, 0.35);
	border-top-color: var(--wp--preset--color--paper);
	border-radius: 50%;
	pointer-events: none;
	z-index: 2;
	animation: tsuyo-btn-spin 700ms linear infinite;
}

@keyframes tsuyo-btn-spin {
	to { transform: rotate(360deg); }
}

/* ── Honeypot / hidden — keep hidden ──────────────────────────── */
.form-card__form .gform_validation_container,
.form-card__form .gfield_visibility_hidden {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

/* ── Inline character / instruction notes ─────────────────────── */
.form-card__form .charleft,
.form-card__form .ginput_counter {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	color: var(--tsuyo-ink-mute);
	margin-top: 4px;
}

/* ── GF wrapping anchor (hidden) ──────────────────────────────── */
.form-card__form .gform_anchor {
	display: block;
	height: 0;
	width: 0;
	overflow: hidden;
	position: absolute;
}

/* ── Reset GF fieldset chrome (Name, radio groups) ────────────── */

.form-card__form fieldset,
.form-card__form .gfield fieldset,
.form-card__form .ginput_complex {
	border: 0;
	padding: 0;
	margin: 0;
	min-width: 0;
}

.form-card__form legend {
	padding: 0;
	margin: 0 0 6px;
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--ink);
}

/* Hide the parent "Name" legend — keep only First / Last sublabels. */
.form-card__form .gfield--type-name > .gfield_label,
.form-card__form .gfield--type-name > legend.gfield_label {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Sub-labels (First Name, Last Name) — same size + weight as main labels. */
.form-card__form .ginput_complex label,
.form-card__form .gform-field-label--type-sub {
	display: block;
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--ink);
	margin: 0 0 6px;
}

/* Add (Required) marker to Name sublabels (parent legend is hidden). */
.form-card__form .gfield--type-name.gfield_contains_required .ginput_complex label::after {
	content: " (Required)";
	font-family: var(--wp--preset--font-family--body);
	font-size: 12px;
	font-weight: 500;
	color: var(--tsuyo-ink-mute);
	margin-left: 4px;
	letter-spacing: 0;
	text-transform: none;
}

/* Stack inputs inside complex fields (Name → first + last) */
.form-card__form .ginput_complex {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}
.form-card__form .ginput_complex .ginput_full,
.form-card__form .ginput_complex > span:only-child {
	grid-column: 1 / -1;
}
.form-card__form .ginput_complex > span {
	display: flex;
	flex-direction: column;
}

/* ── Radio fallback styling (used when Image Choices not active) ─ */

.form-card__form .gfield_radio {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.form-card__form .gfield_radio .gchoice {
	position: relative;
	background: var(--wp--preset--color--paper);
	border: 1px solid var(--wp--preset--color--field-border);
	padding: 14px 16px;
	list-style: none;
	margin: 0;
	transition: border-color 200ms ease, background 200ms ease;
}

.form-card__form .gfield_radio .gchoice:hover {
	border-color: var(--wp--preset--color--ink);
}

.form-card__form .gfield_radio .gchoice:has(input:checked) {
	border-color: var(--wp--preset--color--red);
	background: var(--wp--preset--color--bone);
}

.form-card__form .gfield_radio label {
	display: flex !important;
	align-items: center;
	gap: 12px;
	cursor: pointer;
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--ink);
	margin: 0;
}

.form-card__form .gfield_radio input[type="radio"] {
	width: 18px;
	height: 18px;
	margin: 0;
	flex-shrink: 0;
	accent-color: var(--wp--preset--color--ink);
}

@media (max-width: 480px) {
	.form-card__form .gfield_radio {
		grid-template-columns: 1fr;
	}
}

/* Phone-by-Wiz add-on — country selector + flag dropdown. */
.form-card__form .ginput_container_phone .iti {
	width: 100%;
}
.form-card__form .ginput_container_phone .iti__selected-flag {
	background: transparent;
	border-right: 1px solid var(--wp--preset--color--field-border);
}

/* ── Side-by-side Email + Phone (when GF columns are set to half) ── */
.form-card__form .gform_fields {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}
.form-card__form .gfield {
	grid-column: 1 / -1;
}
.form-card__form .gfield--width-half {
	grid-column: span 1;
}

@media (max-width: 600px) {
	.form-card__form .gform_fields {
		grid-template-columns: 1fr;
	}
	.form-card__form .gfield--width-half {
		grid-column: 1 / -1;
	}
}

/* ── Image Choices (native GF add-on) — 4-col card grid ────── */

.form-card__form .gfield--type-image_choice > .gfield_label,
.form-card__form .gfield--type-image_choice > legend.gfield_label {
	margin-bottom: 12px;
}

.form-card__form .gfield--type-image_choice .gfield_radio {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Card */
.form-card__form .gfield--type-image_choice .gchoice {
	position: relative;
	margin: 0;
	padding: 0;
	background: var(--wp--preset--color--paper);
	border: 1px solid var(--wp--preset--color--field-border);
	overflow: hidden;
	transition: border-color 200ms ease, background 200ms ease;
}

.form-card__form .gfield--type-image_choice .gchoice:hover {
	border-color: var(--wp--preset--color--ink);
}

.form-card__form .gfield--type-image_choice .gchoice:has(input:checked) {
	border-color: var(--wp--preset--color--red);
	background: var(--wp--preset--color--bone);
}

/* Outer wrapper unchains structure */
.form-card__form .gfield-image-choice-wrapper-outer {
	display: block;
	position: relative;
}

/* Image — full card width, square aspect, ignore GF inline width/height. */
.form-card__form .gfield-choice-image-wrapper {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--wp--preset--color--bone);
}

.form-card__form .gfield-choice-image {
	display: block;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover;
	margin: 0;
}

/* Inner wrapper holds input + label — text gets its own padding. */
.form-card__form .gfield-image-choice-wrapper-inner {
	display: block;
	padding: 12px 14px 14px;
}

/* Radio — absolute, top-left corner of card, on top of image. */
.form-card__form .gfield--type-image_choice .gfield-choice-input {
	position: absolute;
	top: 12px;
	left: 12px;
	right: auto;
	width: 18px;
	height: 18px;
	margin: 0;
	z-index: 3;
	accent-color: var(--wp--preset--color--ink);
	background: var(--wp--preset--color--paper);
	border-radius: 50%;
	cursor: pointer;
}

/* Label = just the choice text under the image. */
.form-card__form .gfield-image-choice-wrapper-inner label {
	display: block;
	margin: 0;
	padding: 0;
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--ink);
	text-align: left;
	line-height: 1.4;
	cursor: pointer;
}

/* Image-less choices — compact text-only tile, sits in same 4-col grid
   below the image cards. Useful as a "Something else" fallback. */
.form-card__form .gfield--type-image_choice .gchoice:has(.gfield-choice-image-no-image) .gfield-choice-image-wrapper {
	display: none;
}

.form-card__form .gfield--type-image_choice .gchoice:has(.gfield-choice-image-no-image) .gfield-image-choice-wrapper-inner {
	padding: 8px 16px;
	min-height: 44px;
	display: flex;
	align-items: center;
}

.form-card__form .gfield--type-image_choice .gchoice:has(.gfield-choice-image-no-image) {
	background: var(--wp--preset--color--bone);
	grid-column: 1 / -1;
}

.form-card__form .gfield--type-image_choice .gchoice:has(.gfield-choice-image-no-image) .gfield-choice-input {
	top: 50%;
	left: 14px;
	right: auto;
	transform: translateY(-50%);
}

.form-card__form .gfield--type-image_choice .gchoice:has(.gfield-choice-image-no-image) label {
	padding-left: 32px;
	padding-right: 0;
}

/* Mobile only — collapse to 2 cols. */
@media (max-width: 480px) {
	.form-card__form .gfield--type-image_choice .gfield_radio {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}
}

/* Hide the helper trio once the confirmation has rendered. */
.form-card__form:has(.gform_confirmation_wrapper) .form-helper,
.form-card__form:has(.tsuyo-thanks) .form-helper {
	display: none;
}

/* ── Helper trio (below submit) ─────────────────────────────────── */
.form-card__form .form-helper {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 24px;
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--tsuyo-line-light);
}

.form-card__form .form-helper span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--wp--preset--font-family--body);
	font-size: 13px;
	letter-spacing: 0;
	color: var(--tsuyo-ink-soft);
}

.form-card__form .form-helper svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	fill: var(--tsuyo-ink-mute);
}

/* ── Fields ───────────────────────────────────────────────── */

.field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.field label {
	font-family: var(--wp--preset--font-family--body);
	font-size: 14px;
	font-weight: 500;
	color: var(--wp--preset--color--ink);
}

.field input,
.field select,
.field textarea {
	width: 100%;
	height: 48px;
	background: var(--wp--preset--color--field-bg);
	border: 1px solid var(--wp--preset--color--field-border);
	padding: 12px 16px;
	font-family: var(--wp--preset--font-family--body);
	font-size: 16px;
	color: var(--wp--preset--color--ink);
	border-radius: 0;
}

.field textarea {
	height: auto;
	min-height: 120px;
	resize: vertical;
	line-height: 1.5;
}

.field select {
	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 d='M1 1l5 5 5-5' stroke='%230A0A0A' stroke-opacity='.65' stroke-width='1.5' fill='none'/></svg>");
	background-repeat: no-repeat;
	background-position: right 16px center;
	padding-right: 44px;
	appearance: none;
	-webkit-appearance: none;
}

.field input::placeholder,
.field textarea::placeholder {
	color: var(--tsuyo-ink-mute);
}

.field input:focus,
.field select:focus,
.field textarea:focus {
	outline: none;
	border: 2px solid var(--wp--preset--color--ink);
	padding: 11px 15px;
}

.field textarea:focus {
	padding: 11px 15px;
}

.field--row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.form-helper {
	color: var(--tsuyo-ink-soft);
	margin-top: 4px;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 13px;
	letter-spacing: 0.06em;
	text-transform: none;
}

/* ── Tablet ──────────────────────────────────────────────── */

@media (max-width: 1024px) {
	.form-card--split {
		gap: 56px;
		padding: 44px 40px;
	}
}

/* ── Mobile ──────────────────────────────────────────────── */

@media (max-width: 767px) {
	/* Section: kill horizontal section padding so the form-card spans
	   the full viewport width. Drop bottom margin + bottom corners. */
	.contact-hero {
		padding-left: 0;
		padding-right: 0;
		padding-bottom: 0;
		margin-bottom: 0;
	}
	.contact-hero > .container {
		padding-left: 0;
		padding-right: 0;
	}

	.contact-hero__head {
		margin-bottom: clamp(28px, 6vw, 44px);
		text-align: center;
		padding-left: var(--tsuyo-gutter);
		padding-right: var(--tsuyo-gutter);
	}

	.form-card--split {
		grid-template-columns: 1fr;
		gap: 16px;
		padding: clamp(20px, 5vw, 30px);
		max-width: none;
		width: 100%;
		margin: 0;
		border-radius: 8px 8px 0 0;
	}

	.form-card__pitch {
		gap: 16px;
		text-align: center;
	}

	.form-card__pitch-title {
		font-size: clamp(28px, 7vw, 40px);
		text-align: center;
	}

	/* Hide the supporting copy on mobile — heading + badges only. */
	.form-card__pitch-callout,
	.form-card__pitch-body {
		display: none;
	}

	.form-card__pitch-body {
		margin-top: 8px;
	}

	/* Badges row: 80px wide each, 16px gap, no wrap, normal justify, centered. */
	.form-card__badges {
		flex-wrap: nowrap;
		justify-content: center;
		gap: 16px;
	}
	.form-card__badges img {
		width: 80px;
	}

	.field--row {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	/* Submit button: 12px padding, 14px font on mobile. */
	.form-card__form .gform_button,
	.form-card__form .gform_footer input[type="submit"] {
		padding: 12px 16px;
		font-size: 14px;
	}
}
