/****************************/
/* CONTACT FORM */
/****************************/

.contact_cc17 {
	margin: 0;
	padding: 80px 10%;
	background: linear-gradient(to bottom right, #ffffff, #e6f0fa);
	min-height: 80vh;
	color: var(--text-main);
}

.contact_cc17 h1 {
	color: var(--cc17-blue);
	font-size: 3.5rem;
	text-align: center;
	margin-bottom: 45px;
	font-weight: 800;
}

.layout_contact {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: 40px;
	max-width: 1280px;
	margin: 0 auto;
}

.titre_contact_cc17 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 15px;
	margin-bottom: 25px;
}

.titre_contact_cc17 > div {
	padding: 25px 20px;
	background: white;
	border-radius: 15px;
	border-top: 4px solid var(--cc17-blue);
	color: var(--text-main);
	box-shadow: 0 10px 30px rgba(0,0,0,0.05);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.titre_contact_cc17 > div:hover {
	transform: translateY(-5px);
	box-shadow: 0 15px 35px rgba(0, 61, 133, 0.15);
}

.titre_contact_cc17 h4 {
	color: var(--cc17-blue);
	font-size: 1.1rem;
	margin-bottom: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.titre_contact_cc17 p {
	color: #555555;
	margin: 3px 0;
	font-size: 0.95rem;
	line-height: 1.45;
}

.grille_contact_cc17 {
	display: flex;
	flex-direction: column;
	gap: 25px;
	background: white;
	padding: 40px;
	border-radius: 20px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}

.cellule_contact_cc17 {
	display: flex;
	flex-direction: column;
}

.ligne_nom_prenom {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}

.label_cellule_contact_cc17 label {
	font-weight: 600;
	margin-bottom: 8px;
	color: #00275A;
	display: block;
}

.input_cellule_contact_cc17 input,
.input_cellule_contact_cc17 textarea {
	width: 100%;
	padding: 15px 20px;
	border: 1px solid #e2e8f0;
	border-radius: 10px;
	font-family: inherit;
	font-size: 1rem;
	background: #f8fafc;
	transition: all 0.3s ease;
	box-sizing: border-box;
}

.input_cellule_contact_cc17 input:focus,
.input_cellule_contact_cc17 textarea:focus {
	outline: none;
	border-color: var(--cc17-blue);
	background: white;
	box-shadow: 0 0 0 3px rgba(0, 61, 133, 0.1);
}

.input_cellule_contact_cc17 textarea {
	min-height: 150px;
	resize: vertical;
}

.recaptcha_contact_cc17 {
	display: flex;
	justify-content: center;
	margin: 20px 0;
}

.bouton_message {
	text-align: center;
	margin-top: 20px;
}

.bouton_message input[type="submit"] {
	background-color: #00275A;
	color: white;
	padding: 15px 45px;
	border: none;
	border-radius: 8px;
	font-size: 1.15rem;
	font-weight: bold;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: 0 8px 20px rgba(0, 39, 90, 0.15);
	letter-spacing: 0.5px;
}

.bouton_message input[type="submit"]:hover {
	background-color: var(--cc17-blue);
	transform: translateY(-2px);
	box-shadow: 0 12px 25px rgba(0, 61, 133, 0.25);
}

.message_retour {
	text-align: center;
	padding: 40px;
	font-size: 1.2rem;
	background: #f8fafc;
	border-radius: 15px;
	color: var(--cc17-blue);
	border-left: 5px solid var(--cc17-orange);
}

@media all and (max-width: 1000px) {
	.layout_contact {
		grid-template-columns: 1fr;
		gap: 30px;
	}
	.titre_contact_cc17 {
		grid-template-columns: 1fr;
	}
	.contact_cc17 {
		padding: 40px 5%;
	}
	.contact_cc17 h1 {
		font-size: 2.5rem;
	}
	.grille_contact_cc17 {
		padding: 30px 20px;
	}
	.ligne_nom_prenom {
		grid-template-columns: 1fr;
	}
}