/* =================================================================
   Page Contact — layout + formulaire
   ================================================================= */

.gf-contact-layout {
	display: grid;
	grid-template-columns: minmax(240px, 0.85fr) minmax(0, 1.15fr);
	gap: var(--gf-space-6);
	align-items: start;
}

.gf-contact-aside {
	display: flex;
	flex-direction: column;
	gap: var(--gf-space-4);
}

.gf-contact-card {
	background: var(--gf-surface);
	border: 1px solid var(--gf-line);
	border-radius: var(--gf-r-lg);
	padding: var(--gf-space-5);
	box-shadow: var(--gf-shadow-sm);
}

.gf-contact-card--muted {
	background: var(--gf-bg-tint);
}

.gf-contact-card__kicker {
	display: block;
	margin-bottom: var(--gf-space-2);
	font-family: var(--gf-font-mono);
	font-size: var(--gf-fs-xs);
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gf-muted);
}

.gf-contact-card__text {
	margin: 0;
	font-size: var(--gf-fs-sm);
	line-height: 1.55;
	color: var(--gf-ink);
	max-width: none;
}

.gf-contact-card__text a {
	font-weight: 600;
	text-decoration: none;
	word-break: break-all;
}

.gf-contact-card__text a:hover {
	text-decoration: underline;
}

.gf-contact-card__list {
	margin: 0;
	padding-left: 1.1em;
	font-size: var(--gf-fs-sm);
	line-height: 1.55;
	color: var(--gf-ink);
}

.gf-contact-card__list li {
	margin-bottom: var(--gf-space-2);
}

.gf-contact-card__list li:last-child {
	margin-bottom: 0;
}

.gf-contact-form-wrap {
	background: var(--gf-surface);
	border: 1px solid var(--gf-line);
	border-radius: var(--gf-r-lg);
	padding: var(--gf-space-6);
	box-shadow: var(--gf-shadow-md);
}

.gf-contact-notice {
	margin-bottom: var(--gf-space-5);
	padding: var(--gf-space-4) var(--gf-space-5);
	border-radius: var(--gf-r-md);
	font-size: var(--gf-fs-sm);
	line-height: 1.5;
}

.gf-contact-notice--success {
	background: var(--gf-accent-soft);
	border: 1px solid color-mix(in srgb, var(--gf-accent) 30%, transparent);
	color: var(--gf-accent-ink);
}

.gf-contact-notice--error {
	background: var(--gf-warn-soft);
	border: 1px solid color-mix(in srgb, var(--gf-warn) 30%, transparent);
	color: var(--gf-warn-ink);
}

.gf-contact-form {
	display: flex;
	flex-direction: column;
	gap: var(--gf-space-4);
}

.gf-contact-form__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--gf-space-4);
}

.gf-contact-form__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.gf-contact-field {
	display: flex;
	flex-direction: column;
	gap: var(--gf-space-2);
}

.gf-contact-field__label {
	font-family: var(--gf-font-mono);
	font-size: var(--gf-fs-xs);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--gf-muted);
}

.gf-contact-field__input {
	width: 100%;
	font-family: var(--gf-font-text);
	font-size: var(--gf-fs-base);
	line-height: 1.4;
	color: var(--gf-ink);
	background: var(--gf-bg);
	border: 1px solid var(--gf-line-strong);
	border-radius: var(--gf-r-md);
	padding: 0.75em 0.9em;
	transition:
		border-color var(--gf-dur) var(--gf-ease),
		box-shadow var(--gf-dur) var(--gf-ease);
}

.gf-contact-field__input:focus {
	outline: none;
	border-color: var(--gf-brand);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--gf-brand) 18%, transparent);
}

.gf-contact-field__input--error {
	border-color: var(--gf-warn);
}

.gf-contact-field__input--area {
	min-height: 9rem;
	resize: vertical;
}

.gf-contact-field__error {
	font-size: var(--gf-fs-xs);
	color: var(--gf-warn-ink);
}

.gf-contact-field--checkbox {
	margin-top: var(--gf-space-1);
}

.gf-contact-checkbox {
	display: flex;
	align-items: flex-start;
	gap: var(--gf-space-3);
	font-size: var(--gf-fs-sm);
	line-height: 1.5;
	color: var(--gf-muted);
	cursor: pointer;
}

.gf-contact-checkbox input {
	margin-top: 0.2rem;
	flex: 0 0 auto;
	accent-color: var(--gf-brand);
}

.gf-contact-checkbox a {
	color: var(--gf-brand);
	font-weight: 600;
}

.gf-contact-form__submit {
	margin: var(--gf-space-2) 0 0;
}

@media (max-width: 860px) {
	.gf-contact-layout {
		grid-template-columns: 1fr;
	}

	.gf-contact-form__grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 520px) {
	.gf-contact-form-wrap {
		padding: var(--gf-space-5);
	}
}
