/**
 * AION Theme - Contact Page Styles
 *
 * Two-column layout with form on left and contact info sidebar on right.
 * Includes Gravity Forms style overrides and fallback form styling.
 *
 * @package aion-theme
 * @since   1.0.0
 */

/* =========================================================================
   Contact Grid (two-column layout)
   ========================================================================= */

.contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
}

@media (min-width: 1024px) {
	.contact-grid {
		grid-template-columns: 1.6fr 1fr;
		gap: var(--space-12);
		align-items: start;
	}
}

/* =========================================================================
   Form Column
   ========================================================================= */

.contact-form__heading {
	font-size: var(--text-2xl);
	font-weight: var(--weight-bold);
	color: var(--color-dark-text);
	margin-bottom: var(--space-8);
}

/* =========================================================================
   Gravity Forms Overrides (Contact Page Specific)
   ========================================================================= */

.contact-form-column .gform_wrapper {
	margin: 0 !important;
	padding: 0 !important;
}

.contact-form-column .gform_wrapper .gform_body {
	margin-bottom: var(--space-6);
}

.contact-form-column .gform_wrapper .gfield {
	margin-bottom: var(--space-5);
}

.contact-form-column .gform_wrapper .gfield_label {
	font-size: var(--text-sm) !important;
	font-weight: var(--weight-medium) !important;
	color: var(--color-dark-text) !important;
	margin-bottom: var(--space-2) !important;
}

.contact-form-column .gform_wrapper input[type="text"],
.contact-form-column .gform_wrapper input[type="email"],
.contact-form-column .gform_wrapper input[type="tel"],
.contact-form-column .gform_wrapper input[type="url"],
.contact-form-column .gform_wrapper select,
.contact-form-column .gform_wrapper textarea {
	width: 100% !important;
	padding: var(--space-3) var(--space-4) !important;
	font-family: var(--font-primary) !important;
	font-size: var(--text-base) !important;
	color: var(--color-dark-text) !important;
	background-color: var(--color-white) !important;
	border: 1px solid var(--color-border) !important;
	border-radius: var(--radius-md) !important;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
}

.contact-form-column .gform_wrapper input:focus,
.contact-form-column .gform_wrapper select:focus,
.contact-form-column .gform_wrapper textarea:focus {
	outline: none !important;
	border-color: var(--color-accent) !important;
	box-shadow: 0 0 0 3px rgba(0, 180, 216, 0.15) !important;
}

.contact-form-column .gform_wrapper textarea {
	min-height: 7rem !important;
	resize: vertical !important;
}

.contact-form-column .gform_wrapper select {
	appearance: none !important;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234A4A68' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important;
	background-position: right var(--space-3) center !important;
	padding-right: var(--space-10) !important;
}

/* Gravity Forms validation */
.contact-form-column .gform_wrapper .gfield_error input,
.contact-form-column .gform_wrapper .gfield_error select,
.contact-form-column .gform_wrapper .gfield_error textarea {
	border-color: var(--color-error) !important;
}

.contact-form-column .gform_wrapper .gfield_error input:focus,
.contact-form-column .gform_wrapper .gfield_error select:focus,
.contact-form-column .gform_wrapper .gfield_error textarea:focus {
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

.contact-form-column .gform_wrapper .validation_message {
	font-size: var(--text-sm) !important;
	color: var(--color-error) !important;
	margin-top: var(--space-1) !important;
}

.contact-form-column .gform_wrapper .validation_error {
	padding: var(--space-4) !important;
	margin-bottom: var(--space-6) !important;
	border: 1px solid var(--color-error) !important;
	border-radius: var(--radius-md) !important;
	background-color: rgba(239, 68, 68, 0.05) !important;
	color: var(--color-error) !important;
	font-size: var(--text-sm) !important;
}

/* Gravity Forms submit button — uses btn classes from plugin-compat.php */
.contact-form-column .gform_wrapper .gform_footer {
	margin-top: var(--space-6) !important;
	padding: 0 !important;
}

/* Gravity Forms confirmation message */
.contact-form-column .gform_confirmation_message {
	padding: var(--space-6);
	background-color: rgba(16, 185, 129, 0.08);
	border: 1px solid var(--color-success);
	border-radius: var(--radius-md);
	color: var(--color-success);
	font-weight: var(--weight-medium);
	font-size: var(--text-lg);
	text-align: center;
	animation: contact-fade-in 0.4s ease;
}

/* Gravity Forms AJAX spinner */
.contact-form-column .gform_ajax_spinner {
	margin-left: var(--space-3);
	vertical-align: middle;
}

/* =========================================================================
   Fallback Form
   ========================================================================= */

.contact-fallback-form .form-group {
	margin-bottom: var(--space-5);
}

/* Honeypot — visually hidden */
.contact-hp {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	padding: 0 !important;
	margin: -1px !important;
	overflow: hidden !important;
	clip: rect(0, 0, 0, 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/* Consent checkbox */
.contact-consent__label {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	cursor: pointer;
	font-size: var(--text-sm);
	color: var(--color-body-text);
	line-height: var(--leading-relaxed);
}

.contact-consent__checkbox {
	flex-shrink: 0;
	width: 1.25rem;
	height: 1.25rem;
	margin-top: 0.15rem;
	accent-color: var(--color-accent);
	cursor: pointer;
}

.contact-consent__text a {
	color: var(--color-accent);
	text-decoration: underline;
}

.contact-consent__text a:hover {
	color: var(--color-accent-dark);
}

/* Submit button area */
.contact-submit {
	margin-top: var(--space-6);
}

.contact-submit__btn {
	position: relative;
}

.contact-submit__btn[disabled] {
	opacity: 0.7;
	cursor: not-allowed;
	transform: none;
}

.contact-submit__spinner {
	width: 1rem;
	height: 1rem;
	margin-left: var(--space-2);
}

/* Messages area */
.contact-form__messages {
	margin-top: var(--space-5);
}

.contact-form__messages:empty {
	display: none;
}

.contact-form__messages .form-success {
	animation: contact-fade-in 0.4s ease;
}

.contact-form__messages .form-error {
	padding: var(--space-4);
	background-color: rgba(239, 68, 68, 0.05);
	border: 1px solid var(--color-error);
	border-radius: var(--radius-md);
	animation: contact-fade-in 0.4s ease;
}

/* Client-side validation error state */
.contact-fallback-form .form-input--error,
.contact-fallback-form .form-select--error,
.contact-fallback-form .form-textarea--error {
	border-color: var(--color-error);
}

.contact-fallback-form .field-error {
	font-size: var(--text-sm);
	color: var(--color-error);
	margin-top: var(--space-1);
}

/* =========================================================================
   Info Column / Sidebar
   ========================================================================= */

.contact-info-column {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
}

@media (min-width: 1024px) {
	.contact-info-column {
		position: sticky;
		top: calc(var(--space-20) + var(--space-4));
	}
}

.contact-info-card {
	padding: var(--space-6);
}

.contact-info-card:hover {
	transform: none;
	box-shadow: var(--shadow-sm);
}

.contact-info-card__title {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-lg);
	font-weight: var(--weight-semibold);
	color: var(--color-dark-text);
	margin-bottom: var(--space-5);
}

.contact-info-card__icon {
	color: var(--color-accent);
}

/* Contact info list */
.contact-info-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
}

.contact-info-list__item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
}

.contact-info-list__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.25rem;
	height: 2.25rem;
	background-color: var(--color-accent-light);
	border-radius: var(--radius-md);
	color: var(--color-accent);
	flex-shrink: 0;
}

.contact-info-list__label {
	display: block;
	font-size: var(--text-xs);
	font-weight: var(--weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-body-text);
	margin-bottom: var(--space-1);
}

.contact-info-list__value {
	display: block;
	font-size: var(--text-base);
	color: var(--color-dark-text);
	line-height: var(--leading-normal);
}

a.contact-info-list__value {
	text-decoration: none;
	color: var(--color-accent);
	transition: color var(--transition-fast);
}

a.contact-info-list__value:hover {
	color: var(--color-accent-dark);
	text-decoration: underline;
}

/* Office hours */
.contact-hours {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.contact-hours__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--color-medium-gray);
}

.contact-hours__row:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.contact-hours__row dt {
	font-size: var(--text-sm);
	font-weight: var(--weight-medium);
	color: var(--color-dark-text);
}

.contact-hours__row dd {
	font-size: var(--text-sm);
	color: var(--color-body-text);
	margin: 0;
}

.contact-hours__note {
	margin-top: var(--space-4);
	font-size: var(--text-sm);
	color: var(--color-body-text);
	font-style: italic;
	margin-bottom: 0;
}

/* Social links */
.contact-social {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}

.contact-social__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: var(--space-2) var(--space-4);
	font-size: var(--text-sm);
	font-weight: var(--weight-medium);
	color: var(--color-dark-text);
	background-color: var(--color-light-bg);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.contact-social__link:hover {
	background-color: var(--color-accent);
	color: var(--color-white);
	text-decoration: none;
}

.contact-social__link:hover i[data-lucide] {
	color: var(--color-white);
}

.contact-social__link i[data-lucide] {
	color: var(--color-accent);
	transition: color var(--transition-fast);
}

/* =========================================================================
   Animations
   ========================================================================= */

@keyframes contact-fade-in {
	from {
		opacity: 0;
		transform: translateY(8px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.contact-form__messages .form-success,
	.contact-form__messages .form-error,
	.contact-form-column .gform_confirmation_message {
		animation: none;
	}
}
