/* Contact form — success, error, loading, message field */

.contact-form-col-inner {
	width: 100%;
}

.contact-form-placeholder .form-field textarea {
	width: 100%;
	min-height: 7rem;
	padding: 0.5rem 0;
	border: 0;
	border-bottom: 1px solid var(--color-outline-variant);
	font-family: var(--font-body);
	font-size: var(--font-size-body-md);
	line-height: var(--line-height-body);
	color: var(--color-charcoal);
	background: transparent;
	resize: vertical;
	transition: border-color 250ms ease;
}

.contact-form-placeholder .form-field textarea:focus {
	outline: none;
	border-bottom-color: var(--color-sand);
}

.contact-form-error {
	margin: 0 0 0.5rem;
	padding: 0.75rem 1rem;
	border-radius: var(--radius-btn);
	font-family: var(--font-body);
	font-size: var(--font-size-body-md);
	line-height: var(--line-height-body);
	color: var(--color-on-error-container);
	background: var(--color-error-container);
}

.contact-form-error[hidden] {
	display: none !important;
}

.form-field-error {
	margin: 0.35rem 0 0;
	font-family: var(--font-body);
	font-size: var(--font-size-body-sm, 0.875rem);
	color: var(--color-error);
}

.form-field-error[hidden] {
	display: none !important;
}

.form-field--invalid input,
.form-field--invalid textarea {
	border-bottom-color: var(--color-error) !important;
}

.btn-inquiry[disabled] {
	opacity: 0.6;
	cursor: not-allowed;
}

.btn-inquiry--loading {
	pointer-events: none;
}

.contact-form-success {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	min-height: 12rem;
	padding: 2rem;
	text-align: center;
	border: 1px solid var(--color-soft-gray);
	border-radius: var(--radius-card);
	background: rgba(255, 255, 255, 0.85);
	box-shadow: var(--shadow-xl);
	backdrop-filter: blur(8px);
}

.contact-form-success[hidden] {
	display: none !important;
}

.contact-form-success__icon {
	color: var(--color-charcoal);
}

.contact-form-success__title {
	margin: 0;
	font-family: var(--font-display, var(--font-headline));
	font-size: var(--font-size-headline-sm, 1.5rem);
	font-weight: var(--font-weight-headline);
	color: var(--color-charcoal);
}

.contact-form-success__body {
	margin: 0;
	max-width: 28rem;
	font-family: var(--font-body);
	font-size: var(--font-size-body-md);
	line-height: var(--line-height-body);
	color: var(--color-on-surface-variant);
}

/* Standalone shortcode on inner pages (outside homepage grid) */
.page .entry-content .contact-form-col-inner .contact-form-placeholder,
.page .entry-content .contact-form-col-inner .contact-form-success {
	max-width: 36rem;
}
