/* ── CR Emplois — Frontend Styles ─────────────────────── */

/* Force black text — high specificity for The7 / Elementor */
#content .cr-emplois-grille,
#content .cr-emplois-grille *,
#content .cr-emploi-carte,
#content .cr-emploi-carte *,
body .cr-emploi-single-header,
body .cr-emploi-single-header *,
body .cr-emploi-single-fiche,
body .cr-emploi-single-fiche *,
body .cr-emploi-breadcrumb,
body .cr-emploi-breadcrumb *,
body .cr-emploi-formulaire,
body .cr-emploi-formulaire p,
body .cr-emploi-formulaire label,
body .cr-emploi-formulaire h3,
.cr-emploi-single-fiche__label,
.cr-emploi-single-fiche__value,
.cr-emploi-carte__info dt,
.cr-emploi-carte__info dd,
.cr-emploi-carte__titre,
.cr-emploi-single-header__titre {
	color: #000 !important;
}

/* Exceptions : garder les couleurs spécifiques */
#content .cr-emploi-carte__badge,
body .cr-emploi-carte__badge {
	color: #8a7210 !important;
}

#content .cr-emploi-carte__lien,
body .cr-emploi-carte__lien {
	color: #c8a415 !important;
}

#content .cr-emploi-carte:hover .cr-emploi-carte__lien,
body .cr-emploi-carte:hover .cr-emploi-carte__lien {
	color: #8a7210 !important;
}

#content .cr-emploi-carte:hover .cr-emploi-carte__titre,
body .cr-emploi-carte:hover .cr-emploi-carte__titre {
	color: #c8a415 !important;
}

body .cr-emploi-breadcrumb a,
#content .cr-emploi-breadcrumb a {
	color: #c8a415 !important;
}

body .cr-emploi-breadcrumb__sep {
	color: #ccc !important;
}

body .cr-emploi-champ .requis {
	color: #d32f2f !important;
}

body .cr-emploi-btn,
body .cr-emploi-btn--postuler,
body .cr-emploi-btn--submit {
	color: #fff !important;
}

/* Grille des emplois — 2 colonnes */
.cr-emplois-grille {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	margin: 2rem 0;
}

/* ── Card ─────────────────────────────────────────────── */
#content .cr-emploi-carte,
body .cr-emploi-carte {
	display: flex;
	flex-direction: column;
	position: relative;
	padding: 0;
	border: 1px solid #ddd;
	border-left: 4px solid #c8a415;
	border-radius: 4px;
	background: #fff;
	text-decoration: none !important;
	color: inherit;
	overflow: hidden;
	transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

.cr-emploi-carte:hover {
	border-color: #ddd;
	border-left-color: #a8880e;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
}

.cr-emploi-carte:visited,
.cr-emploi-carte:focus {
	color: inherit;
	text-decoration: none !important;
}

/* Header : titre + badge */
.cr-emploi-carte__header {
	padding: 1.25rem 1.5rem 0.75rem;
	border-bottom: 1px solid #f0f0f0;
}

.cr-emploi-carte__titre {
	margin: 0 0 0.625rem 0 !important;
	padding: 0 !important;
	font-size: 1.125rem !important;
	font-weight: 700 !important;
	line-height: 1.35 !important;
	color: #1a1a1a !important;
}

.cr-emploi-carte:hover .cr-emploi-carte__titre {
	color: #c8a415 !important;
}

.cr-emploi-carte__badge {
	display: inline-block;
	padding: 0.2rem 0.625rem;
	margin-bottom: 0.25rem;
	background: #f5f0dc;
	color: #8a7210;
	border-radius: 3px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	line-height: 1.5;
}

/* Infos : label / valeur */
.cr-emploi-carte__infos {
	margin: 0;
	padding: 1rem 1.5rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	flex-grow: 1;
}

.cr-emploi-carte__info {
	display: flex;
	gap: 0.5rem;
	font-size: 0.8125rem;
	line-height: 1.5;
}

.cr-emploi-carte__info dt {
	font-weight: 700;
	color: #333;
	white-space: nowrap;
	min-width: 0;
}

.cr-emploi-carte__info dt::after {
	content: " :";
}

.cr-emploi-carte__info dd {
	margin: 0;
	padding: 0;
	color: #1a1a1a;
}

/* Lien "Voir l'offre" */
.cr-emploi-carte__lien {
	display: block;
	padding: 0.75rem 1.5rem;
	background: #fafafa;
	border-top: 1px solid #f0f0f0;
	font-size: 0.8125rem;
	font-weight: 600;
	color: #c8a415;
	text-align: right;
	transition: background 0.2s ease, color 0.2s ease;
}

.cr-emploi-carte:hover .cr-emploi-carte__lien {
	background: #f5f0dc;
	color: #8a7210;
}

/* ── Containement single (align with Elementor container) ── */
.cr-emploi-breadcrumb,
.cr-emploi-single-header,
#cr-formulaire-emploi,
.cr-emploi-formulaire {
	max-width: 1140px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 15px;
	padding-right: 15px;
	box-sizing: border-box;
}

.cr-emploi-breadcrumb {
	margin-top: 25px;
}

body .cr-emploi-formulaire,
#content .cr-emploi-formulaire {
	margin-bottom: 25px;
}

/* ── Breadcrumb ───────────────────────────────────────── */
.cr-emploi-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
	font-size: 0.875rem;
	color: #888;
}

.cr-emploi-breadcrumb a {
	color: #c8a415;
	text-decoration: none;
	transition: color 0.2s ease;
}

.cr-emploi-breadcrumb a:hover {
	color: #8a7210;
	text-decoration: underline;
}

.cr-emploi-breadcrumb__sep {
	color: #ccc;
}

.cr-emploi-breadcrumb__current {
	color: #1a1a1a;
	font-weight: 600;
}

/* ── Single header ────────────────────────────────────── */
.cr-emploi-single-header {
	margin-bottom: 2.5rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid #e0e0e0;
}

.cr-emploi-single-header__titre {
	margin: 0 0 1.5rem !important;
	font-size: 1.75rem !important;
	line-height: 1.25 !important;
	color: #1a1a1a !important;
}

/* Fiche infos label:valeur */
body .cr-emploi-single-fiche,
#content .cr-emploi-single-fiche {
	background: #f9f9f9;
	border: 1px solid #eee;
	border-left: 4px solid #c8a415;
	border-radius: 4px;
	padding: 1.25rem 1.5rem;
	margin-bottom: 1.5rem;
}

.cr-emploi-single-fiche__row {
	display: flex;
	padding: 0.4rem 0;
	font-size: 0.9375rem;
	line-height: 1.5;
}

.cr-emploi-single-fiche__row + .cr-emploi-single-fiche__row {
	border-top: 1px solid #eee;
}

.cr-emploi-single-fiche__label {
	font-weight: 700;
	color: #333;
	min-width: 180px;
	flex-shrink: 0;
}

.cr-emploi-single-fiche__label::after {
	content: " :";
}

.cr-emploi-single-fiche__value {
	color: #1a1a1a;
}

/* Bouton Postuler */
.cr-emploi-btn--postuler {
	padding: 0.75rem 2.5rem;
	font-size: 1rem;
	letter-spacing: 0.02em;
}

/* ── Boutons ──────────────────────────────────────────── */
.cr-emploi-btn {
	display: inline-block;
	padding: 0.625rem 1.25rem;
	background: #c8a415;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	font-weight: 600;
	font-size: 0.875rem;
	border: none;
	cursor: pointer;
	transition: background 0.2s ease;
}

.cr-emploi-btn:hover {
	background: #a8880e;
	color: #fff;
}

.cr-emploi-btn--submit {
	padding: 0.75rem 2rem;
	font-size: 1rem;
}

/* ── Formulaire ───────────────────────────────────────── */
body .cr-emploi-formulaire,
#content .cr-emploi-formulaire {
	margin-top: 3rem;
	padding: 2rem 15px;
	border: 1px solid #e0e0e0;
	border-left: 4px solid #c8a415;
	border-radius: 4px;
	background: #fafafa;
	max-width: 1140px;
	margin-left: auto;
	margin-right: auto;
}

.cr-emploi-formulaire h3 {
	margin: 0 0 1.5rem;
	font-size: 1.375rem;
}

.cr-emploi-champ-group {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	margin-bottom: 1rem;
}

.cr-emploi-champ {
	margin-bottom: 1rem;
}

.cr-emploi-champ label {
	display: block;
	margin-bottom: 0.375rem;
	font-weight: 600;
	font-size: 0.9375rem;
}

.cr-emploi-champ .requis {
	color: #d32f2f;
}

.cr-emploi-champ input[type="text"],
.cr-emploi-champ input[type="email"],
.cr-emploi-champ input[type="tel"],
.cr-emploi-champ textarea {
	width: 100%;
	padding: 0.625rem 0.75rem;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 1rem;
	font-family: inherit;
	transition: border-color 0.2s ease;
}

.cr-emploi-champ input:focus,
.cr-emploi-champ textarea:focus {
	border-color: #c8a415;
	outline: none;
	box-shadow: 0 0 0 2px rgba(200, 164, 21, 0.15);
}

.cr-emploi-champ input[type="file"] {
	font-size: 0.9375rem;
}

/* ── Messages ─────────────────────────────────────────── */
.cr-emploi-succes {
	margin-top: 3rem;
	padding: 1.5rem 2rem;
	background: #e8f5e9;
	border: 1px solid #a5d6a7;
	border-radius: 4px;
}

.cr-emploi-succes h3 {
	margin: 0 0 0.5rem;
	color: #2e7d32;
}

.cr-emploi-erreurs {
	margin-bottom: 1.5rem;
	padding: 1rem 1.25rem;
	background: #fce4ec;
	border: 1px solid #ef9a9a;
	border-radius: 4px;
}

.cr-emploi-erreurs ul {
	margin: 0;
	padding: 0 0 0 1.25rem;
}

.cr-emploi-erreurs li {
	color: #c62828;
}

.cr-emplois-vide {
	padding: 2rem;
	text-align: center;
	color: #999;
	font-style: italic;
}

/* ── Responsive ───────────────────────────────────────── */
@media (max-width: 768px) {
	.cr-emplois-grille {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 600px) {
	.cr-emploi-champ-group {
		grid-template-columns: 1fr;
	}

	.cr-emploi-formulaire {
		padding: 1.25rem;
	}

	.cr-emploi-carte__info {
		flex-direction: column;
		gap: 0;
	}

	.cr-emploi-single-fiche__row {
		flex-direction: column;
		gap: 0;
	}

	.cr-emploi-single-fiche__label {
		min-width: 0;
	}
}
