/*
 * Contact page styles.
 * Loaded only on the page with slug "contact" (see inc/enqueue.php).
 * Adapted from the home-contact block; CF7 renders the form, so this file
 * styles the info card, the form card wrapper, and CF7's own markup.
 */

/* ---------- LAYOUT ---------- */
.contact-page__grid {
	display: grid;
	gap: var(--jai-space-xl);
}

@media (min-width: 1024px) {
	.contact-page__grid {
		grid-template-columns: 1fr 1.2fr;
		align-items: stretch;
	}
}

/* ---------- INFO CARD ---------- */
.contact-page__info {
	position: relative;
	overflow: hidden;
	padding: clamp(1.5rem, 3vw, 2.25rem);
	border-radius: var(--jai-radius-2xl);
	background: var(--jai-gradient-dark);
	color: rgba(241, 245, 249, 0.82);
	display: flex;
	flex-direction: column;
	gap: var(--jai-space-lg);
	box-shadow: var(--jai-shadow-soft);
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.contact-page__info::before {
	content: "";
	position: absolute;
	top: -6rem;
	right: -6rem;
	width: 18rem;
	height: 18rem;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(124, 58, 237, 0.35), transparent 65%);
	filter: blur(40px);
	pointer-events: none;
	z-index: 0;
}

.contact-page__info > * {
	position: relative;
	z-index: 1;
}

.contact-page__info-title {
	margin: 0;
	color: #f8fafc;
	font-size: 1.5rem;
}

.contact-page__info-lead {
	margin: 0;
	color: rgba(241, 245, 249, 0.74);
	font-size: 0.95rem;
	line-height: 1.6;
}

.contact-page__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: var(--jai-space-md);
}

.contact-page__item {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
}

.contact-page__icon {
	flex-shrink: 0;
	width: 2.5rem;
	height: 2.5rem;
	display: grid;
	place-items: center;
	border-radius: var(--jai-radius-lg);
	background: rgba(255, 255, 255, 0.1);
	color: #f8fafc;
	-webkit-backdrop-filter: blur(8px);
	        backdrop-filter: blur(8px);
	transition: background var(--jai-transition);
}

.contact-page__item:hover .contact-page__icon {
	background: var(--jai-gradient-brand);
}

.contact-page__item-body {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.contact-page__item-title {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(241, 245, 249, 0.55);
}

.contact-page__item-body a,
.contact-page__item-body p {
	margin: 0;
	color: #f8fafc;
	font-weight: 500;
	text-decoration: none;
	transition: color var(--jai-transition);
}

.contact-page__item-body a:hover {
	color: var(--jai-color-brand-300);
}

.contact-page__socials {
	margin-top: auto;
	padding-top: var(--jai-space-lg);
	display: flex;
	gap: 0.5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.contact-page__social {
	display: grid;
	place-items: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.12);
	color: #f8fafc;
	text-decoration: none;
	border: 1px solid rgba(255, 255, 255, 0.14);
	transition: background var(--jai-transition), color var(--jai-transition), border-color var(--jai-transition), transform var(--jai-transition);
}

.contact-page__social i {
	color: inherit;
	font-size: 1.05rem;
	line-height: 1;
}

.contact-page__social:hover,
.contact-page__social:focus-visible {
	background: var(--jai-gradient-brand);
	color: #ffffff;
	border-color: transparent;
	transform: translateY(-2px);
	outline: none;
	box-shadow: 0 8px 22px rgba(124, 58, 237, 0.4);
}

/* ---------- FORM CARD ---------- */
.contact-page__form {
	padding: clamp(1.5rem, 3vw, 2.25rem);
	border-radius: var(--jai-radius-2xl);
	background: var(--jai-color-bg);
	border: 1px solid var(--jai-color-border);
	box-shadow: var(--jai-shadow-soft);
	display: flex;
	flex-direction: column;
	gap: var(--jai-space-md);
}

html.dark .contact-page__form {
	background: var(--jai-color-surface);
}

/* ---------- FORM FIELDS ---------- */
/*
 * The shared CF7 form (id 22) emits home-contact__* field classes in its
 * markup. home.css is not loaded on this page, so the homepage field styling
 * is replicated here — including the 2-column name/email row that collapses
 * to a single column on mobile.
 */
.contact-page__form .home-contact__field-row {
	display: grid;
	gap: var(--jai-space-md);
}

@media (min-width: 640px) {
	.contact-page__form .home-contact__field-row {
		grid-template-columns: 1fr 1fr;
	}
}

.contact-page__form .home-contact__field {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.contact-page__form .home-contact__label {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--jai-color-text);
	letter-spacing: 0.02em;
}

.contact-page__form .home-contact__input {
	width: 100%;
	padding: 0.75rem 0.95rem;
	border: 1px solid var(--jai-color-border-strong);
	border-radius: var(--jai-radius-lg);
	background: var(--jai-color-bg);
	color: var(--jai-color-text);
	font: inherit;
	transition: border-color var(--jai-transition), box-shadow var(--jai-transition);
	min-height: 2.9rem;
}

.contact-page__form .home-contact__input:focus {
	outline: none;
	border-color: var(--jai-color-brand-500);
	box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.15);
}

.contact-page__form .home-contact__input--textarea {
	min-height: 9rem;
	resize: vertical;
}

html.dark .contact-page__form .home-contact__input {
	background: var(--jai-color-surface-strong);
}

.contact-page__form .home-contact__submit {
	width: max-content;
	align-self: flex-start;
	margin-top: var(--jai-space-xs);
}

.contact-page__form .home-contact__note {
	margin: 0;
	color: var(--jai-color-muted);
	font-size: 0.82rem;
}

/* ---------- Contact Form 7 integration ---------- */
/* CF7's .wpcf7 wrapper fills the grid cell so the form card stretches to full height. */
.contact-page__grid .wpcf7 {
	display: flex;
	flex-direction: column;
}

.contact-page__grid .wpcf7 > form.contact-page__form {
	flex: 1 1 auto;
}

/* CF7 wraps each field in an inline <span>; force block for full width. */
.contact-page__form .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
}

.contact-page .contact-page__form .wpcf7-not-valid-tip {
	margin-top: 0.35rem;
	font-size: 0.78rem;
}

.contact-page .contact-page__form .wpcf7-response-output {
	margin: var(--jai-space-sm) 0 0;
	padding: 0.75rem 0.95rem;
	border-width: 1px;
	border-radius: var(--jai-radius-lg);
	font-size: 0.85rem;
}

.contact-page__form .wpcf7-spinner {
	margin-left: 0.5rem;
}
