/* =========================================================
   Astuces Emploi — thème éditorial recherche d'emploi
   Fichier : /css4/aejobs.css
   Scope principal : .aejob
   FAQ hors wrapper : .aejob-faq
   Bloc CMS natif intouchable : not-to-miss-content / not-to-miss / ntm
   ========================================================= */

/* =========================================================
   Base scoped
   ========================================================= */

html body .aejob,
html body .aejob *:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob-faq,
html body .aejob-faq * {
	box-sizing: border-box !important;
}

html body .aejob {
	--ae-bg: #f6f8fc;
	--ae-bg-soft: #ffffff;
	--ae-bg-deep: #071b3a;
	--ae-text: #102033;
	--ae-muted: #617088;
	--ae-border: rgba(25, 55, 95, 0.12);
	--ae-border-strong: rgba(25, 55, 95, 0.2);
	--ae-primary: #1769ff;
	--ae-primary-deep: #0c3fba;
	--ae-accent: #22c7a9;
	--ae-accent-soft: rgba(34, 199, 169, 0.13);
	--ae-warning: #ffb84d;
	--ae-danger: #ff5c7a;
	--ae-radius: 22px;
	--ae-radius-sm: 14px;
	--ae-shadow: 0 22px 60px rgba(12, 35, 70, 0.12);
	--ae-shadow-soft: 0 12px 35px rgba(12, 35, 70, 0.08);
	--ae-max: 1180px;

	position: relative !important;
	width: min(var(--ae-max), calc(100% - 24px)) !important;
	max-width: var(--ae-max) !important;
	margin: 0 auto !important;
	padding: clamp(18px, 3vw, 34px) !important;
	color: var(--ae-text) !important;
	font-family: inherit !important;
	line-height: 1.65 !important;
	isolation: isolate !important;
}

html body .aejob::before {
	content: "" !important;
	position: absolute !important;
	inset: 0 auto auto 50% !important;
	width: min(900px, 94vw) !important;
	height: 420px !important;
	transform: translateX(-50%) !important;
	background:
		radial-gradient(circle at 20% 20%, rgba(23, 105, 255, 0.14), transparent 34%),
		radial-gradient(circle at 76% 18%, rgba(34, 199, 169, 0.16), transparent 32%),
		radial-gradient(circle at 48% 80%, rgba(255, 184, 77, 0.11), transparent 35%) !important;
	filter: blur(4px) !important;
	z-index: -2 !important;
	pointer-events: none !important;
	animation: aejob-ambient 12s ease-in-out infinite alternate !important;
}

html body .aejob::after {
	content: "" !important;
	position: absolute !important;
	inset: 14px !important;
	border-radius: 34px !important;
	background:
		linear-gradient(135deg, rgba(255,255,255,0.82), rgba(246,248,252,0.62)),
		linear-gradient(90deg, rgba(23,105,255,0.07), rgba(34,199,169,0.05)) !important;
	z-index: -3 !important;
	pointer-events: none !important;
}

/* =========================================================
   Typographie article — not-to-miss exclu
   ========================================================= */

html body .aejob p:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	margin: 0 0 1.05em !important;
	color: var(--ae-text) !important;
	font-size: clamp(16px, 1.15vw, 18px) !important;
	line-height: 1.65 !important;
}

html body .aejob strong:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	color: #071b3a !important;
	font-weight: 800 !important;
}

html body .aejob em:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	color: var(--ae-primary-deep) !important;
	font-style: normal !important;
	font-weight: 700 !important;
}

html body .aejob h2:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob h3:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob h4:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	color: #071b3a !important;
	font-family: inherit !important;
	font-weight: 850 !important;
	line-height: 1.12 !important;
	letter-spacing: -0.025em !important;
	margin: 0 0 16px !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	text-transform: none !important;
}

html body .aejob h2:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	font-size: clamp(27px, 3.1vw, 42px) !important;
}

html body .aejob h3:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	font-size: clamp(20px, 2vw, 27px) !important;
}

html body .aejob h4:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	font-size: clamp(18px, 1.5vw, 22px) !important;
}

html body .aejob a:not(.aejob-btn):not(.aejob-card-cta):not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)) {
	color: var(--ae-primary-deep) !important;
	font-weight: 800 !important;
	text-decoration: underline !important;
	text-decoration-thickness: 0.12em !important;
	text-underline-offset: 0.18em !important;
}

html body .aejob a:not(.aejob-btn):not(.aejob-card-cta):not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)):hover {
	color: var(--ae-primary) !important;
}

/* =========================================================
   Hero HP / Article
   ========================================================= */

html body .aejob .aejob-hero {
	position: relative !important;
	overflow: hidden !important;
	margin: 0 0 clamp(22px, 3vw, 38px) !important;
	padding: clamp(28px, 5vw, 62px) !important;
	border-radius: 32px !important;
	background:
		linear-gradient(135deg, rgba(7, 27, 58, 0.96), rgba(18, 62, 124, 0.94)),
		radial-gradient(circle at top right, rgba(34, 199, 169, 0.36), transparent 38%) !important;
	color: #fff !important;
	box-shadow: var(--ae-shadow) !important;
	border: 1px solid rgba(255,255,255,0.16) !important;
}

html body .aejob .aejob-hero::before {
	content: "" !important;
	position: absolute !important;
	inset: -90px -80px auto auto !important;
	width: 330px !important;
	height: 330px !important;
	border-radius: 999px !important;
	background: radial-gradient(circle, rgba(34,199,169,0.34), transparent 68%) !important;
	animation: aejob-float 9s ease-in-out infinite !important;
	pointer-events: none !important;
}

html body .aejob .aejob-hero::after {
	content: "" !important;
	position: absolute !important;
	right: clamp(18px, 4vw, 52px) !important;
	bottom: clamp(18px, 4vw, 46px) !important;
	width: 170px !important;
	height: 170px !important;
	border-radius: 36px !important;
	background:
		linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0.04)),
		repeating-linear-gradient(135deg, rgba(255,255,255,0.18) 0 1px, transparent 1px 12px) !important;
	transform: rotate(8deg) !important;
	opacity: 0.55 !important;
	pointer-events: none !important;
}

html body .aejob .aejob-kicker,
html body .aejob .aejob-eyebrow {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	width: auto !important;
	max-width: max-content !important;
	margin: 0 0 14px !important;
	padding: 8px 13px !important;
	border-radius: 999px !important;
	background: rgba(34, 199, 169, 0.14) !important;
	color: #075f56 !important;
	border: 1px solid rgba(34, 199, 169, 0.34) !important;
	font-size: 13px !important;
	font-weight: 900 !important;
	line-height: 1 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
}

html body .aejob .aejob-hero .aejob-kicker {
	color: #eafffb !important;
	background: rgba(34, 199, 169, 0.18) !important;
	border-color: rgba(34, 199, 169, 0.42) !important;
}

html body .aejob .aejob-section--focus .aejob-eyebrow {
	color: #eafffb !important;
	background: rgba(34, 199, 169, 0.18) !important;
	border-color: rgba(34, 199, 169, 0.42) !important;
}

html body .aejob .aejob-kicker::before,
html body .aejob .aejob-eyebrow::before {
	content: "●" !important;
	color: var(--ae-accent) !important;
	font-size: 10px !important;
	line-height: 1 !important;
	animation: aejob-pulse 1.8s ease-in-out infinite !important;
}

html body .aejob .aejob-title {
	position: relative !important;
	z-index: 1 !important;
	max-width: 860px !important;
	margin: 0 0 18px !important;
	color: #fff !important;
	font-size: clamp(34px, 5.2vw, 68px) !important;
	font-weight: 950 !important;
	line-height: 0.98 !important;
	letter-spacing: -0.06em !important;
}

html body .aejob .aejob-lead {
	position: relative !important;
	z-index: 1 !important;
	max-width: 780px !important;
	margin: 0 !important;
	color: rgba(255,255,255,0.88) !important;
	font-size: clamp(17px, 1.55vw, 22px) !important;
	line-height: 1.55 !important;
}

html body .aejob .aejob-actions {
	position: relative !important;
	z-index: 1 !important;
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 12px !important;
	margin: 28px 0 0 !important;
	padding: 0 !important;
}

/* =========================================================
   Boutons / CTA
   ========================================================= */

html body .aejob .aejob-btn,
html body .aejob .aejob-card-cta {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 9px !important;
	min-height: 46px !important;
	padding: 12px 18px !important;
	border-radius: 999px !important;
	font-size: 15px !important;
	font-weight: 900 !important;
	line-height: 1.1 !important;
	text-decoration: none !important;
	cursor: pointer !important;
	transition: transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease !important;
	border: 1px solid transparent !important;
	white-space: normal !important;
}

html body .aejob .aejob-btn--primary,
html body .aejob .aejob-card-cta {
	color: #ffffff !important;
	background: linear-gradient(135deg, var(--ae-primary), var(--ae-primary-deep)) !important;
	box-shadow: 0 14px 30px rgba(23, 105, 255, 0.28) !important;
}

html body .aejob .aejob-btn--primary:hover,
html body .aejob .aejob-card-cta:hover {
	transform: translateY(-2px) !important;
	box-shadow: 0 18px 42px rgba(23, 105, 255, 0.34) !important;
	color: #ffffff !important;
}

html body .aejob .aejob-btn--ghost {
	color: #ffffff !important;
	background: rgba(255,255,255,0.12) !important;
	border-color: rgba(255,255,255,0.22) !important;
	backdrop-filter: blur(10px) !important;
}

html body .aejob .aejob-btn--ghost:hover {
	transform: translateY(-2px) !important;
	background: rgba(255,255,255,0.18) !important;
	color: #ffffff !important;
}

/* =========================================================
   Sections
   ========================================================= */

html body .aejob .aejob-section {
	position: relative !important;
	margin: clamp(18px, 3vw, 34px) 0 !important;
	padding: clamp(22px, 3.4vw, 38px) !important;
	border-radius: var(--ae-radius) !important;
	background: var(--ae-bg-soft) !important;
	border: 1px solid var(--ae-border) !important;
	box-shadow: var(--ae-shadow-soft) !important;
	overflow: hidden !important;
}

html body .aejob .aejob-section:has(:where(.not-to-miss-content, .not-to-miss, .ntm)) {
	overflow: visible !important;
}

html body .aejob .aejob-section--soft {
	background:
		linear-gradient(135deg, rgba(255,255,255,0.96), rgba(246,248,252,0.94)),
		radial-gradient(circle at top right, rgba(23,105,255,0.08), transparent 36%) !important;
}

html body .aejob .aejob-section--focus {
	background:
		linear-gradient(135deg, rgba(7, 27, 58, 0.96), rgba(11, 45, 95, 0.94)) !important;
	color: #ffffff !important;
}

html body .aejob .aejob-section--focus h2,
html body .aejob .aejob-section--focus h3,
html body .aejob .aejob-section--focus p,
html body .aejob .aejob-section--focus li,
html body .aejob .aejob-section--focus strong {
	color: #ffffff !important;
}

html body .aejob .aejob-section--warning {
	background:
		linear-gradient(135deg, rgba(255, 248, 235, 0.96), rgba(255,255,255,0.95)) !important;
	border-color: rgba(255, 184, 77, 0.34) !important;
}

html body .aejob .aejob-section > :last-child:not(:where(.not-to-miss-content, .not-to-miss, .ntm)) {
	margin-bottom: 0 !important;
}

/* =========================================================
   Grids / cards
   ========================================================= */

html body .aejob .aejob-grid {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 16px !important;
	margin: 22px 0 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

html body .aejob .aejob-grid--2 {
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

html body .aejob .aejob-card {
	position: relative !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	gap: 10px !important;
	min-width: 0 !important;
	padding: 20px !important;
	border-radius: 20px !important;
	background:
		linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,255,0.94)) !important;
	border: 1px solid var(--ae-border) !important;
	box-shadow: 0 10px 28px rgba(12, 35, 70, 0.07) !important;
	transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease !important;
	overflow: hidden !important;
	text-align: center !important;
}

html body .aejob .aejob-card::before {
	content: "" !important;
	position: absolute !important;
	inset: 0 0 auto 0 !important;
	height: 4px !important;
	background: linear-gradient(90deg, var(--ae-primary), var(--ae-accent)) !important;
	opacity: 0.82 !important;
}

html body .aejob .aejob-card:hover {
	transform: translateY(-4px) !important;
	border-color: rgba(23,105,255,0.24) !important;
	box-shadow: 0 18px 42px rgba(12, 35, 70, 0.12) !important;
}

html body .aejob .aejob-card-icon {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 44px !important;
	height: 44px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	border-radius: 15px !important;
	background: linear-gradient(135deg, rgba(23,105,255,0.12), rgba(34,199,169,0.16)) !important;
	color: var(--ae-primary-deep) !important;
	font-size: 22px !important;
	line-height: 1 !important;
	flex: 0 0 auto !important;
}

html body .aejob .aejob-card h2,
html body .aejob .aejob-card h3,
html body .aejob .aejob-card h4 {
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	margin-bottom: 6px !important;
	font-size: clamp(19px, 1.6vw, 24px) !important;
	text-align: center !important;
}

html body .aejob .aejob-card p {
	margin: 0 !important;
	color: var(--ae-muted) !important;
	font-size: 16px !important;
	text-align: center !important;
}

html body .aejob .aejob-card-cta {
	align-self: center !important;
	margin-top: auto !important;
	padding: 10px 15px !important;
	min-height: 40px !important;
	font-size: 14px !important;
}

/* =========================================================
   Bloc réponse rapide / réassurance
   ========================================================= */

html body .aejob .aejob-answer {
	position: relative !important;
	display: grid !important;
	grid-template-columns: 64px minmax(0, 1fr) !important;
	gap: 18px !important;
	align-items: start !important;
	margin: 22px 0 !important;
	padding: 22px !important;
	border-radius: 22px !important;
	background:
		linear-gradient(135deg, rgba(23,105,255,0.08), rgba(34,199,169,0.09)),
		#ffffff !important;
	border: 1px solid rgba(23,105,255,0.16) !important;
	box-shadow: var(--ae-shadow-soft) !important;
}

html body .aejob .aejob-answer::before {
	content: "✓" !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 58px !important;
	height: 58px !important;
	border-radius: 18px !important;
	background: linear-gradient(135deg, var(--ae-accent), #48e6c6) !important;
	color: #062d2a !important;
	font-size: 28px !important;
	font-weight: 950 !important;
	box-shadow: 0 14px 30px rgba(34,199,169,0.25) !important;
}

html body .aejob .aejob-answer p {
	margin: 0 !important;
	color: #203247 !important;
}

/* =========================================================
   Listes custom
   ========================================================= */

html body .aejob ul.aejob-list,
html body .aejob ul.aejob-checklist,
html body .aejob ol.aejob-steps,
html body .aejob .aejob-badges,
html body .aejob .aejob-quicknav {
	margin: 18px 0 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

html body .aejob .aejob-list li,
html body .aejob .aejob-checklist li,
html body .aejob .aejob-steps li {
	position: relative !important;
	margin: 0 0 12px !important;
	padding: 14px 16px 14px 46px !important;
	border-radius: 16px !important;
	background: rgba(255,255,255,0.76) !important;
	border: 1px solid var(--ae-border) !important;
	color: var(--ae-text) !important;
	font-size: 16px !important;
	list-style: none !important;
}

html body .aejob .aejob-checklist li::before,
html body .aejob .aejob-list li::before {
	content: "✓" !important;
	position: absolute !important;
	left: 15px !important;
	top: 14px !important;
	width: 22px !important;
	height: 22px !important;
	border-radius: 999px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: var(--ae-accent-soft) !important;
	color: #087b6f !important;
	font-size: 13px !important;
	font-weight: 950 !important;
}

html body .aejob .aejob-steps {
	counter-reset: aejob-step !important;
}

html body .aejob .aejob-steps li {
	counter-increment: aejob-step !important;
}

html body .aejob .aejob-steps li::before {
	content: counter(aejob-step) !important;
	position: absolute !important;
	left: 14px !important;
	top: 13px !important;
	width: 24px !important;
	height: 24px !important;
	border-radius: 9px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: linear-gradient(135deg, var(--ae-primary), var(--ae-primary-deep)) !important;
	color: #fff !important;
	font-size: 13px !important;
	font-weight: 950 !important;
}

/* =========================================================
   Badges / KPIs
   ========================================================= */

html body .aejob .aejob-badges {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 10px !important;
	margin: 20px 0 0 !important;
}

html body .aejob .aejob-badge {
	display: inline-flex !important;
	align-items: center !important;
	gap: 8px !important;
	padding: 9px 12px !important;
	border-radius: 999px !important;
	background: #ffffff !important;
	border: 1px solid var(--ae-border) !important;
	color: #263a53 !important;
	font-size: 14px !important;
	font-weight: 850 !important;
	box-shadow: 0 8px 20px rgba(12, 35, 70, 0.06) !important;
	list-style: none !important;
}

html body .aejob .aejob-kpis {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 14px !important;
	margin: 22px 0 0 !important;
}

html body .aejob .aejob-kpi {
	padding: 18px !important;
	border-radius: 18px !important;
	background: #ffffff !important;
	border: 1px solid var(--ae-border) !important;
	box-shadow: 0 10px 24px rgba(12, 35, 70, 0.06) !important;
}

html body .aejob .aejob-kpi strong {
	display: block !important;
	margin: 0 0 4px !important;
	font-size: clamp(24px, 3vw, 38px) !important;
	line-height: 1 !important;
	letter-spacing: -0.05em !important;
	color: var(--ae-primary-deep) !important;
}

html body .aejob .aejob-kpi span {
	display: block !important;
	color: var(--ae-muted) !important;
	font-size: 14px !important;
	font-weight: 750 !important;
}

/* =========================================================
   Tableaux responsive sans double scroll forcé
   ========================================================= */

html body .aejob .aejob-table-wrap {
	width: 100% !important;
	margin: 22px 0 !important;
	border-radius: 20px !important;
	border: 1px solid var(--ae-border) !important;
	background: #ffffff !important;
	box-shadow: var(--ae-shadow-soft) !important;
	overflow: hidden !important;
	container-type: inline-size !important;
}

html body .aejob table.aejob-table,
html body .aejob .aejob-table-wrap table {
	width: 100% !important;
	border-collapse: separate !important;
	border-spacing: 0 !important;
	margin: 0 !important;
	background: #ffffff !important;
}

html body .aejob table.aejob-table th,
html body .aejob table.aejob-table td,
html body .aejob .aejob-table-wrap th,
html body .aejob .aejob-table-wrap td {
	padding: 15px 16px !important;
	border: 0 !important;
	border-bottom: 1px solid var(--ae-border) !important;
	text-align: left !important;
	vertical-align: top !important;
	color: var(--ae-text) !important;
	font-size: 15px !important;
}

html body .aejob table.aejob-table th,
html body .aejob .aejob-table-wrap th {
	background: linear-gradient(135deg, #071b3a, #103d7a) !important;
	color: #ffffff !important;
	font-weight: 900 !important;
}

html body .aejob table.aejob-table th strong,
html body .aejob .aejob-table-wrap th strong {
	color: #ffffff !important;
}

html body .aejob table.aejob-table tr:last-child td,
html body .aejob .aejob-table-wrap tr:last-child td {
	border-bottom: 0 !important;
}

html body .aejob table.aejob-table tbody tr:hover,
html body .aejob .aejob-table-wrap tbody tr:hover {
	background: rgba(23,105,255,0.04) !important;
}

/* =========================================================
   Encarts
   ========================================================= */

html body .aejob .aejob-note,
html body .aejob .aejob-tip,
html body .aejob .aejob-alert {
	position: relative !important;
	margin: 20px 0 !important;
	padding: 18px 18px 18px 58px !important;
	border-radius: 18px !important;
	border: 1px solid var(--ae-border) !important;
	background: #ffffff !important;
	box-shadow: 0 10px 25px rgba(12, 35, 70, 0.07) !important;
}

html body .aejob .aejob-note::before,
html body .aejob .aejob-tip::before,
html body .aejob .aejob-alert::before {
	position: absolute !important;
	left: 18px !important;
	top: 18px !important;
	width: 28px !important;
	height: 28px !important;
	border-radius: 11px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 15px !important;
	font-weight: 950 !important;
}

html body .aejob .aejob-note::before {
	content: "i" !important;
	background: rgba(23,105,255,0.12) !important;
	color: var(--ae-primary-deep) !important;
}

html body .aejob .aejob-tip::before {
	content: "✓" !important;
	background: var(--ae-accent-soft) !important;
	color: #087b6f !important;
}

html body .aejob .aejob-alert::before {
	content: "!" !important;
	background: rgba(255,92,122,0.13) !important;
	color: #b62443 !important;
}

/* =========================================================
   Sommaire / navigation interne
   ========================================================= */

html body .aejob .aejob-quicknav {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 10px !important;
	margin: 22px 0 !important;
	padding: 14px !important;
	border-radius: 20px !important;
	background: rgba(255,255,255,0.82) !important;
	border: 1px solid var(--ae-border) !important;
	box-shadow: var(--ae-shadow-soft) !important;
}

html body .aejob .aejob-quicknav li {
	list-style: none !important;
}

html body .aejob .aejob-quicknav a {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 9px 12px !important;
	border-radius: 999px !important;
	background: #ffffff !important;
	border: 1px solid var(--ae-border) !important;
	color: var(--ae-primary-deep) !important;
	font-size: 14px !important;
	font-weight: 850 !important;
	text-decoration: none !important;
	transition: transform .2s ease, border-color .2s ease, background .2s ease !important;
}

html body .aejob .aejob-quicknav a:hover {
	transform: translateY(-2px) !important;
	background: rgba(23,105,255,0.07) !important;
	border-color: rgba(23,105,255,0.24) !important;
}

/* =========================================================
   Images / sécurité anti-débordement
   ========================================================= */

html body .aejob img:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob-faq img {
	max-width: 100% !important;
	height: auto !important;
}

html body .aejob iframe,
html body .aejob embed,
html body .aejob object {
	max-width: 100% !important;
}

html body .aejob .aejob-section,
html body .aejob .aejob-card,
html body .aejob .aejob-answer,
html body .aejob .aejob-table-wrap,
html body .aejob-faq {
	max-width: 100% !important;
}

html body .aejob .aejob-title,
html body .aejob h2:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob h3:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob p:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob li:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob td:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob th:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
html body .aejob-faq h2,
html body .aejob-faq h3,
html body .aejob-faq p {
	overflow-wrap: anywhere !important;
	word-break: normal !important;
}

/* =========================================================
   Animation article — not-to-miss non ciblé
   ========================================================= */

html body .aejob .aejob-hero,
html body .aejob .aejob-section,
html body .aejob .aejob-card,
html body .aejob .aejob-answer,
html body .aejob .aejob-table-wrap {
	animation: aejob-rise .58s ease both !important;
}

html body .aejob .aejob-section:nth-of-type(2) { animation-delay: .04s !important; }
html body .aejob .aejob-section:nth-of-type(3) { animation-delay: .08s !important; }
html body .aejob .aejob-section:nth-of-type(4) { animation-delay: .12s !important; }
html body .aejob .aejob-section:nth-of-type(5) { animation-delay: .16s !important; }

/* =========================================================
   FAQ hors wrapper principal
   ========================================================= */

html body .aejob-faq {
	--ae-bg: #f6f8fc;
	--ae-bg-soft: #ffffff;
	--ae-text: #102033;
	--ae-muted: #617088;
	--ae-border: rgba(25, 55, 95, 0.12);
	--ae-primary: #1769ff;
	--ae-primary-deep: #0c3fba;
	--ae-accent: #22c7a9;
	--ae-accent-soft: rgba(34, 199, 169, 0.13);
	--ae-radius: 22px;
	--ae-shadow-soft: 0 12px 35px rgba(12, 35, 70, 0.08);

	position: relative !important;
	width: min(1180px, calc(100% - 24px)) !important;
	max-width: 1180px !important;
	margin: clamp(18px, 3vw, 34px) auto !important;
	padding: clamp(22px, 3.4vw, 38px) !important;
	border-radius: var(--ae-radius) !important;
	background:
		linear-gradient(135deg, rgba(255,255,255,0.96), rgba(246,248,252,0.94)),
		radial-gradient(circle at top right, rgba(23,105,255,0.08), transparent 36%) !important;
	border: 1px solid var(--ae-border) !important;
	box-shadow: var(--ae-shadow-soft) !important;
	color: var(--ae-text) !important;
	overflow: hidden !important;
}

html body .aejob-faq h2,
html body .aejob-faq h3 {
	color: #071b3a !important;
	font-family: inherit !important;
	font-weight: 850 !important;
	line-height: 1.12 !important;
	letter-spacing: -0.025em !important;
	margin: 0 0 16px !important;
	padding: 0 !important;
	background: transparent !important;
	border: 0 !important;
	text-transform: none !important;
}

html body .aejob-faq h2 {
	font-size: clamp(27px, 3.1vw, 42px) !important;
}

html body .aejob-faq h3 {
	font-size: clamp(20px, 2vw, 27px) !important;
}

html body .aejob-faq p {
	margin: 0 0 1.05em !important;
	color: var(--ae-text) !important;
	font-size: clamp(16px, 1.15vw, 18px) !important;
	line-height: 1.65 !important;
}

html body .aejob-faq strong {
	color: #071b3a !important;
	font-weight: 800 !important;
}

html body .aejob-faq .aejob-eyebrow,
html body section.aejob-faq .aejob-eyebrow,
html body section.aejob-section#faq .aejob-eyebrow {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px !important;
	width: auto !important;
	max-width: max-content !important;
	margin: 0 0 16px !important;
	padding: 9px 14px !important;
	border-radius: 999px !important;
	background: rgba(34, 199, 169, 0.14) !important;
	color: #075f56 !important;
	border: 1px solid rgba(34, 199, 169, 0.32) !important;
	font-size: 13px !important;
	font-weight: 900 !important;
	line-height: 1 !important;
	letter-spacing: 0.05em !important;
	text-transform: uppercase !important;
	box-shadow: 0 10px 24px rgba(12, 35, 70, 0.06) !important;
}

html body .aejob-faq .aejob-eyebrow::before,
html body section.aejob-faq .aejob-eyebrow::before,
html body section.aejob-section#faq .aejob-eyebrow::before {
	content: "●" !important;
	color: #22c7a9 !important;
	font-size: 10px !important;
	line-height: 1 !important;
}

html body .aejob-faq .aejob-qa-grid {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	gap: 16px !important;
	margin: 22px 0 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

html body .aejob-faq .aejob-qa-card {
	padding: 20px !important;
	border-radius: 20px !important;
	background: #ffffff !important;
	border: 1px solid var(--ae-border) !important;
	box-shadow: 0 10px 24px rgba(12, 35, 70, 0.06) !important;
}

html body .aejob-faq .aejob-qa-card h3 {
	margin: 0 0 8px !important;
	font-size: 20px !important;
}

html body .aejob-faq .aejob-qa-card p {
	margin: 0 !important;
	color: var(--ae-muted) !important;
	font-size: 16px !important;
}

/* =========================================================
   Responsive
   ========================================================= */

@container (max-width: 720px) {
	html body .aejob .aejob-table-wrap {
		border: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
		overflow: visible !important;
	}

	html body .aejob .aejob-table-wrap table,
	html body .aejob .aejob-table-wrap thead,
	html body .aejob .aejob-table-wrap tbody,
	html body .aejob .aejob-table-wrap tr,
	html body .aejob .aejob-table-wrap th,
	html body .aejob .aejob-table-wrap td {
		display: block !important;
		width: 100% !important;
	}

	html body .aejob .aejob-table-wrap thead {
		display: none !important;
	}

	html body .aejob .aejob-table-wrap tr {
		margin: 0 0 14px !important;
		padding: 14px !important;
		border-radius: 18px !important;
		background: #ffffff !important;
		border: 1px solid rgba(25, 55, 95, 0.12) !important;
		box-shadow: 0 10px 24px rgba(12,35,70,0.07) !important;
	}

	html body .aejob .aejob-table-wrap td {
		position: relative !important;
		padding: 10px 0 !important;
		border: 0 !important;
		border-bottom: 1px solid rgba(25, 55, 95, 0.12) !important;
		font-size: 15px !important;
		line-height: 1.45 !important;
	}

	html body .aejob .aejob-table-wrap td:last-child {
		border-bottom: 0 !important;
	}

	html body .aejob .aejob-table-wrap td::before {
		content: attr(data-label) !important;
		display: block !important;
		margin: 0 0 4px !important;
		color: #617088 !important;
		font-size: 12px !important;
		font-weight: 900 !important;
		text-transform: uppercase !important;
		letter-spacing: 0.04em !important;
	}
}

@media (max-width: 980px) {
	html body .aejob {
		padding: 18px !important;
	}

	html body .aejob .aejob-grid,
	html body .aejob .aejob-grid--2,
	html body .aejob .aejob-kpis,
	html body .aejob .aejob-qa-grid,
	html body .aejob-faq .aejob-qa-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	html body .aejob .aejob-hero {
		padding: 34px !important;
	}
}

@media (max-width: 720px) {
	html body .aejob,
	html body .aejob-faq {
		width: min(100%, calc(100% - 16px)) !important;
		padding-left: 14px !important;
		padding-right: 14px !important;
	}

	html body .aejob {
		padding-top: 14px !important;
		padding-bottom: 14px !important;
	}

	html body .aejob::after {
		inset: 6px !important;
		border-radius: 24px !important;
	}

	html body .aejob .aejob-hero {
		padding: 26px 18px !important;
		border-radius: 22px !important;
	}

	html body .aejob .aejob-hero::after {
		display: none !important;
	}

	html body .aejob .aejob-title {
		font-size: clamp(31px, 10vw, 44px) !important;
		line-height: 1.02 !important;
		letter-spacing: -0.045em !important;
	}

	html body .aejob .aejob-lead {
		font-size: 16px !important;
		line-height: 1.52 !important;
	}

	html body .aejob .aejob-actions {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 10px !important;
	}

	html body .aejob .aejob-btn,
	html body .aejob .aejob-card-cta {
		width: 100% !important;
		min-height: 44px !important;
		padding: 11px 14px !important;
	}

	html body .aejob .aejob-grid,
	html body .aejob .aejob-grid--2,
	html body .aejob .aejob-kpis,
	html body .aejob .aejob-qa-grid,
	html body .aejob-faq .aejob-qa-grid {
		grid-template-columns: 1fr !important;
	}

	html body .aejob .aejob-card {
		text-align: center !important;
		align-items: center !important;
	}

	html body .aejob .aejob-card-icon {
		margin-left: auto !important;
		margin-right: auto !important;
	}

	html body .aejob .aejob-card-cta {
		align-self: stretch !important;
	}

	html body .aejob .aejob-answer {
		grid-template-columns: 1fr !important;
		text-align: left !important;
		padding: 18px !important;
	}

	html body .aejob .aejob-answer::before {
		margin: 0 !important;
	}

	html body .aejob .aejob-section,
	html body .aejob-faq {
		padding: 20px 14px !important;
		border-radius: 20px !important;
	}

	html body .aejob .aejob-table-wrap {
		border: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
		overflow: visible !important;
	}

	html body .aejob .aejob-table-wrap table,
	html body .aejob .aejob-table-wrap thead,
	html body .aejob .aejob-table-wrap tbody,
	html body .aejob .aejob-table-wrap tr,
	html body .aejob .aejob-table-wrap th,
	html body .aejob .aejob-table-wrap td {
		display: block !important;
		width: 100% !important;
	}

	html body .aejob .aejob-table-wrap thead {
		display: none !important;
	}

	html body .aejob .aejob-table-wrap tr {
		margin: 0 0 14px !important;
		padding: 14px !important;
		border-radius: 18px !important;
		background: #ffffff !important;
		border: 1px solid rgba(25, 55, 95, 0.12) !important;
		box-shadow: 0 10px 24px rgba(12,35,70,0.07) !important;
	}

	html body .aejob .aejob-table-wrap td {
		position: relative !important;
		padding: 10px 0 !important;
		border: 0 !important;
		border-bottom: 1px solid rgba(25, 55, 95, 0.12) !important;
		font-size: 15px !important;
		line-height: 1.45 !important;
	}

	html body .aejob .aejob-table-wrap td:last-child {
		border-bottom: 0 !important;
	}

	html body .aejob .aejob-table-wrap td::before {
		content: attr(data-label) !important;
		display: block !important;
		margin: 0 0 4px !important;
		color: #617088 !important;
		font-size: 12px !important;
		font-weight: 900 !important;
		text-transform: uppercase !important;
		letter-spacing: 0.04em !important;
	}
}

@media (max-width: 460px) {
	html body .aejob,
	html body .aejob-faq {
		width: min(100%, calc(100% - 10px)) !important;
		padding-left: 10px !important;
		padding-right: 10px !important;
	}

	html body .aejob .aejob-title {
		font-size: 32px !important;
	}

	html body .aejob h2:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
	html body .aejob-faq h2 {
		font-size: 25px !important;
	}

	html body .aejob h3:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
	html body .aejob-faq h3 {
		font-size: 20px !important;
	}

	html body .aejob p:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
	html body .aejob li:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
	html body .aejob-faq p {
		font-size: 15.5px !important;
	}
}

/* =========================================================
   Accessibilité animations
   ========================================================= */

@media (prefers-reduced-motion: reduce) {
	html body .aejob,
	html body .aejob *:not(:where(.not-to-miss-content, .not-to-miss-content *, .not-to-miss, .not-to-miss *, .ntm, .ntm *)),
	html body .aejob::before,
	html body .aejob::after,
	html body .aejob-faq,
	html body .aejob-faq * {
		animation: none !important;
		transition: none !important;
		scroll-behavior: auto !important;
	}
}

/* =========================================================
   Keyframes
   ========================================================= */

@keyframes aejob-rise {
	from {
		opacity: 0;
		transform: translateY(16px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes aejob-float {
	0% {
		transform: translate3d(0, 0, 0) scale(1);
		opacity: .78;
	}
	50% {
		transform: translate3d(-18px, 18px, 0) scale(1.06);
		opacity: .95;
	}
	100% {
		transform: translate3d(8px, -10px, 0) scale(.98);
		opacity: .72;
	}
}

@keyframes aejob-pulse {
	0%, 100% {
		transform: scale(1);
		opacity: .75;
	}
	50% {
		transform: scale(1.45);
		opacity: 1;
	}
}

@keyframes aejob-ambient {
	0% {
		transform: translateX(-50%) translateY(0) scale(1);
	}
	100% {
		transform: translateX(-50%) translateY(18px) scale(1.04);
	}
}

/* =========================================================
   PATCH — tableaux mobile sans débordement horizontal
   ========================================================= */

html body .aejob {
	overflow-x: clip !important;
}

html body .aejob .aejob-table-wrap,
html body .aejob .aejob-table-wrap *,
html body .aejob table.aejob-table,
html body .aejob table.aejob-table * {
	max-width: 100% !important;
	box-sizing: border-box !important;
}

@media (max-width: 720px) {
	html body .aejob .aejob-table-wrap {
		width: 100% !important;
		max-width: 100% !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
		border: 0 !important;
		background: transparent !important;
		box-shadow: none !important;
		overflow: visible !important;
	}

	html body .aejob .aejob-table-wrap table,
	html body .aejob table.aejob-table {
		display: block !important;
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
		table-layout: fixed !important;
		border-collapse: separate !important;
		border-spacing: 0 !important;
		overflow: visible !important;
	}

	html body .aejob .aejob-table-wrap thead,
	html body .aejob table.aejob-table thead {
		display: none !important;
	}

	html body .aejob .aejob-table-wrap tbody,
	html body .aejob .aejob-table-wrap tr,
	html body .aejob .aejob-table-wrap td,
	html body .aejob table.aejob-table tbody,
	html body .aejob table.aejob-table tr,
	html body .aejob table.aejob-table td {
		display: block !important;
		width: 100% !important;
		max-width: 100% !important;
		min-width: 0 !important;
	}

	html body .aejob .aejob-table-wrap tr,
	html body .aejob table.aejob-table tr {
		margin: 0 0 14px !important;
		padding: 14px !important;
		border-radius: 18px !important;
		background: #ffffff !important;
		border: 1px solid rgba(25, 55, 95, 0.12) !important;
		box-shadow: 0 10px 24px rgba(12, 35, 70, 0.07) !important;
		overflow: hidden !important;
	}

	html body .aejob .aejob-table-wrap td,
	html body .aejob table.aejob-table td {
		position: relative !important;
		padding: 10px 0 !important;
		border: 0 !important;
		border-bottom: 1px solid rgba(25, 55, 95, 0.12) !important;
		color: #102033 !important;
		font-size: 15px !important;
		line-height: 1.45 !important;
		white-space: normal !important;
		overflow-wrap: anywhere !important;
		word-break: normal !important;
	}

	html body .aejob .aejob-table-wrap td:last-child,
	html body .aejob table.aejob-table td:last-child {
		border-bottom: 0 !important;
	}

	html body .aejob .aejob-table-wrap td::before,
	html body .aejob table.aejob-table td::before {
		content: attr(data-label) !important;
		display: block !important;
		margin: 0 0 4px !important;
		color: #617088 !important;
		font-size: 12px !important;
		font-weight: 900 !important;
		line-height: 1.25 !important;
		text-transform: uppercase !important;
		letter-spacing: 0.04em !important;
		white-space: normal !important;
	}
}