/* @override
	http://eleav5.local:8080/css/contact.css */

:root {
	--contact-bordeaux: #8a3441;
	--contact-bordeaux-dark: #6f2633;
	--contact-text: #2f2f32;
	--contact-muted: #68665d;
	--contact-line: #e8e3df;
	--contact-soft: #f8ecef;
	--contact-blue: #147ea8;
}

#page.contact #center.full {
	padding: 0 40px 0;
}

.contact_page {
	color: var(--contact-text);
	margin: 0 auto;
	max-width: 1360px;
	padding: 30px 0 0;
}

#page.contact main h1.titre_page {
	border-bottom: 0;
	color: #241f21;
	font-size: 34px;
	line-height: 1.15em;
	margin: 0 0 14px;
	padding: 0;
}

.contact_intro {
	margin-bottom: 26px;
}

.contact_breadcrumb {
	color: var(--contact-muted);
	font-size: 14px;
	line-height: 1.4em;
	margin: 0 0 24px;
}

.contact_breadcrumb a {
	color: var(--contact-muted);
	text-decoration: none;
}

.contact_breadcrumb a:hover {
	color: var(--contact-bordeaux);
	text-decoration: none;
}

.contact_breadcrumb span {
	display: inline-block;
	margin: 0 8px;
}

.contact_intro > p:not(.contact_breadcrumb) {
	color: var(--contact-muted);
	font-size: 15px;
	line-height: 1.5em;
	margin: 0;
}

.contact_infos {
	background: #fff;
	border: 1px solid var(--contact-line);
	border-radius: 8px;
	box-shadow: 0 12px 34px rgba(58, 41, 31, .06);
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-bottom: 24px;
	overflow: hidden;
}

.contact_card {
	display: grid;
	gap: 20px;
	grid-template-columns: 68px minmax(0, 1fr);
	min-height: 168px;
	padding: 36px 44px;
	position: relative;
}

.contact_card + .contact_card:before {
	background: var(--contact-line);
	bottom: 34px;
	content: "";
	left: 0;
	position: absolute;
	top: 34px;
	width: 1px;
}

.contact_card_icon {
	align-items: center;
	background: var(--contact-soft);
	border-radius: 50%;
	color: var(--contact-bordeaux);
	display: flex;
	font-size: 32px;
	height: 64px;
	justify-content: center;
	width: 64px;
}

.contact_card h2 {
	color: var(--contact-bordeaux);
	font-family: var(--fonte-2);
	font-size: 22px;
	font-weight: 600;
	line-height: 1.15em;
	margin: 0 0 10px;
}

.contact_card p {
	color: #403d3d;
	font-size: 15px;
	line-height: 1.55em;
	margin: 0;
}

.contact_card p + p {
	margin-top: 12px;
}

.contact_card p strong {
	font-weight: 600;
}

.contact_card_actions a,
.contact_phone {
	color: var(--contact-bordeaux);
	font-weight: 600;
	text-decoration: none;
}

.contact_card_actions a:hover,
.contact_phone:hover {
	color: var(--contact-bordeaux-dark);
	text-decoration: none;
}

.contact_phone {
	display: inline-block;
	font-size: 22px;
	line-height: 1.2em;
	margin-bottom: 4px;
}

.contact_callout {
	align-items: center;
	background: linear-gradient(90deg, #fff7f8 0%, #f9e8eb 100%);
	border-radius: 8px;
	color: #423f3f;
	display: flex;
	font-size: 15px;
	gap: 16px;
	justify-content: center;
	line-height: 1.45em;
	margin: 0 0 24px;
	padding: 15px 22px;
	text-align: center;
}

.contact_callout i.fa {
	color: var(--contact-bordeaux);
	font-size: 28px;
}

.contact_callout strong,
.contact_callout a {
	color: var(--contact-bordeaux);
	font-weight: 700;
	text-decoration: none;
}

.contact_form_panel {
	background: #fff;
	border: 1px solid var(--contact-line);
	border-radius: 8px;
	box-shadow: 0 12px 34px rgba(58, 41, 31, .06);
	margin-bottom: 28px;
	padding: 36px 44px 32px;
}

.contact_connect_prompt {
	background: #f7f4f2;
	border-radius: 6px;
	color: var(--contact-muted);
	font-size: 14px;
	margin: 0 0 20px;
	padding: 12px 14px;
}

.contact_connect_prompt i.fa {
	color: var(--contact-bordeaux);
	margin-right: 6px;
}

.contact_form form {
	display: grid;
	gap: 0;
	grid-template-columns: minmax(300px, .85fr) minmax(360px, 1.15fr);
	margin: 0;
}

.contact_form form > table {
	border: 0;
	border-collapse: collapse;
	box-sizing: border-box;
	display: block;
	float: none;
	margin: 0;
	width: 100%;
}

.contact_form form > table:first-of-type {
	padding-right: 56px;
}

.contact_form form > table:nth-of-type(2) {
	border-left: 1px solid var(--contact-line);
	padding-left: 56px;
}

.contact_form table tbody,
.contact_form table tr,
.contact_form table td {
	display: block;
}

.contact_form table tr {
	display: grid;
	gap: 0 12px;
	grid-template-columns: 96px minmax(0, 1fr);
	margin-bottom: 16px;
}

.contact_form table tr:first-child {
	align-items: center;
	grid-template-columns: 72px minmax(0, 1fr);
	margin-bottom: 22px;
}

.contact_form table tr:has(input[type="hidden"]),
.contact_form table tr:has(.vh) {
	display: none;
}

.contact_form table td {
	background: transparent;
	border: 0;
	margin: 0;
	padding: 0;
}

.contact_form table td.label {
	padding-top: 10px;
	text-align: right;
}

.contact_form table tr:first-child td.label {
	align-items: center;
	background: var(--contact-soft);
	border-radius: 50%;
	color: var(--contact-bordeaux);
	display: flex;
	font-family: FontAwesome;
	font-size: 30px;
	height: 64px;
	justify-content: center;
	padding: 0;
	text-align: center;
	width: 64px;
}

.contact_form table:first-of-type tr:first-child td.label:before {
	content: "\f007";
}

.contact_form table:nth-of-type(2) tr:first-child td.label:before {
	content: "\f040";
}

.contact_form table h4 {
	color: var(--contact-bordeaux);
	font-family: var(--fonte-2);
	font-size: 24px;
	font-weight: 600;
	line-height: 1.15em;
	margin: 0;
	padding-top: 16px;
}

.contact_form table td label {
	color: var(--contact-muted);
	display: block;
	font-size: 14px;
	line-height: 1.3em;
	margin: 0;
	position: static;
	text-align: right;
	top: 0;
}

.contact_form table td label strong,
.contact_form .asterisque strong {
	color: #df7a18;
}

.contact_form input.input,
.contact_form textarea {
	background: #fff;
	border: 1px solid #d8d4d0;
	border-radius: 6px;
	box-sizing: border-box;
	color: var(--contact-text);
	font-size: 15px;
	line-height: 1.35em;
	margin: 0;
	padding: 11px 13px;
	width: 100%;
}

.contact_form textarea {
	min-height: 162px;
	resize: vertical;
}

.contact_form textarea::placeholder {
	color: #9b9792;
}

.contact_form input.input:focus,
.contact_form textarea:focus {
	border-color: var(--contact-bordeaux);
	box-shadow: 0 0 0 3px rgba(138, 52, 65, .12);
	outline: 0;
}

.contact_form .erreur {
	background: #fbe4e4;
	border-radius: 6px;
	color: #9d2020;
	display: none;
	font-size: 14px;
	margin: 0;
	padding: 10px 12px;
}

.contact_form table:nth-of-type(2) tr:has(.erreur) {
	margin-bottom: 12px;
}

.contact_form table:nth-of-type(2) tr:has(.submit_bt) {
	margin-bottom: 14px;
}

.contact_form table td.submit_bt {
	text-align: left;
}

.contact_form .bouton {
	background: linear-gradient(180deg, #1a8db7 0%, #0d668f 100%);
	border: 0;
	border-radius: 6px;
	box-shadow: 0 10px 20px rgba(28, 72, 92, .22);
	color: #fff;
	display: inline-flex;
	float: none;
	font-size: 19px;
	font-weight: 400;
	gap: 8px;
	line-height: 1.1em;
	margin: 0;
	padding: 13px 17px;
	position: relative;
	text-align: center;
	text-decoration: none;
}

.contact_form .bouton:hover,
.contact_form .bouton:focus {
	background: linear-gradient(180deg, #147da5 0%, #0a5577 100%);
	box-shadow: 0 10px 20px rgba(28, 72, 92, .3);
	color: #fff;
	text-decoration: none;
}

.contact_form .loader {
	display: none;
	position: static;
}

.contact_form .asterisque {
	color: #4f78b8;
	font-size: 14px;
	font-style: italic;
}

.contact_form .asterisque em {
	color: #4f78b8;
	font-size: 14px;
}

.form_retour .form_ok {
	display: none;
}

.contact_reassurance {
	background: #fff;
	border-top: 1px solid var(--contact-line);
	display: grid;
	gap: 1px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 0 -40px;
	padding: 28px 40px;
}

.contact_reassurance div {
	display: grid;
	gap: 4px 18px;
	grid-template-columns: 48px minmax(0, 1fr);
	padding: 0 28px;
	position: relative;
}

.contact_reassurance div + div:before {
	background: var(--contact-line);
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	top: 0;
	width: 1px;
}

.contact_reassurance i.fa {
	color: var(--contact-bordeaux);
	font-size: 34px;
	grid-row: 1 / span 2;
	text-align: center;
}

.contact_reassurance strong {
	color: var(--contact-text);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.2em;
}

.contact_reassurance span {
	color: var(--contact-muted);
	font-size: 13px;
	line-height: 1.35em;
}

@media (max-width: 1120px) {
	.contact_infos {
		grid-template-columns: 1fr;
	}

	.contact_card {
		min-height: 0;
	}

	.contact_card + .contact_card:before {
		bottom: auto;
		height: 1px;
		left: 34px;
		right: 34px;
		top: 0;
		width: auto;
	}

	.contact_form form {
		grid-template-columns: 1fr;
	}

	.contact_form form > table:first-of-type {
		padding: 0 0 24px;
	}

	.contact_form form > table:nth-of-type(2) {
		border-left: 0;
		border-top: 1px solid var(--contact-line);
		padding: 26px 0 0;
	}

	.contact_reassurance {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		row-gap: 24px;
	}

	.contact_reassurance div:nth-child(3):before {
		display: none;
	}
}

@media (max-width: 768px) {
	#page.contact #center.full {
		padding: 0 25px 0;
	}

	.contact_page {
		padding-top: 18px;
	}

	#page.contact main h1.titre_page {
		font-size: 30px;
	}

	.contact_card {
		grid-template-columns: 54px minmax(0, 1fr);
		padding: 24px 22px;
	}

	.contact_card_icon,
	.contact_form table tr:first-child td.label {
		font-size: 24px;
		height: 50px;
		width: 50px;
	}

	.contact_callout {
		align-items: flex-start;
		text-align: left;
	}

	.contact_form_panel {
		padding: 24px 20px;
	}

	.contact_form table tr {
		display: block;
		margin-bottom: 15px;
	}

	.contact_form table tr:first-child {
		display: grid;
		grid-template-columns: 58px minmax(0, 1fr);
	}

	.contact_form table td.label,
	.contact_form table td label {
		padding: 0 0 6px;
		text-align: left;
	}

	.contact_form table h4 {
		font-size: 22px;
		padding-top: 12px;
	}

	.contact_reassurance {
		grid-template-columns: 1fr;
		margin: 0 -25px;
		padding: 24px 25px;
		row-gap: 0;
	}

	.contact_reassurance div {
		padding: 16px 0;
	}

	.contact_reassurance div:before {
		display: none;
	}

	.contact_reassurance div + div {
		border-top: 1px solid var(--contact-line);
	}
}
