/* ---- About page modern & dynamic ---- */
:root {
	--about-green: #0a7d3b;
	--about-orange: #ff6a00;
	--about-bg: #f7fafc;
	--about-card: #fff;
	--about-dark: #181818;
}

body {
	background: var(--about-bg);
}

.home-hero.contact-hero {
	background: linear-gradient(90deg, var(--about-dark) 0%, #1a1a1a 55%, #f7ede4 100%);
	color: #fff;
	padding: 2.5rem 0 1.5rem 0;
	margin-bottom: 1.5rem;
	border-radius: 0 0 38px 38px;
	box-shadow: 0 8px 32px rgba(11,11,11,0.08);
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.home-hero .container, .contact-hero .container {
	max-width: 98vw;
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 18px;
	padding-left: 2.5rem;
	padding-right: 2.5rem;
}
@media (max-width: 1300px) {
	.home-hero.contact-hero {
		max-width: 99vw;
		border-radius: 0 0 24px 24px;
	}
	.home-hero .container, .contact-hero .container {
		padding-left: 1.2rem;
		padding-right: 1.2rem;
	}
}
.home-hero h1 {
	font-size: 2.1rem;
	font-weight: 800;
	margin: 0 0 .4rem;
	letter-spacing: -1px;
}
.home-hero .lead {
	color: #ffe;
	font-size: 1.1rem;
	margin-bottom: .7rem;
}
.hero-cta .btn {
	margin-right: .7rem;
	margin-bottom: .5rem;
	font-weight: 700;
	box-shadow: 0 4px 18px rgba(255,106,0,0.10);
	transition: transform .18s, box-shadow .18s;
}
.hero-cta .btn:hover {
	transform: translateY(-2px) scale(1.04);
	box-shadow: 0 8px 32px rgba(255,106,0,0.18);
}

.stats {
	padding: 1.2rem 0;
}
.stats-grid {
	display: grid;
	grid-template-columns: repeat(4,1fr);
	gap: 1.2rem;
	margin-top: .8rem;
}
.stat {
	background: linear-gradient(180deg, #fff 0%, #fbfbfb 100%);
	padding: 1.1rem;
	border-radius: 12px;
	box-shadow: 0 6px 18px rgba(11,11,11,0.06);
	text-align: center;
	border: 1px solid rgba(0,0,0,0.04);
	animation: fadeInUp .7s cubic-bezier(.2,.9,.2,1);
}
.stat .stat-value {
	font-size: 2rem;
	font-weight: 800;
	color: var(--about-orange);
	line-height: 1;
}
.stat .stat-label {
	margin-top: 6px;
	font-size: .95rem;
	color: #888;
}

.engagements {
	display: grid;
	grid-template-columns: repeat(2,1fr);
	gap: 1.2rem;
	margin-top: 1.2rem;
}
.eng {
	background: var(--about-card);
	padding: 1.2rem;
	border-radius: 12px;
	border: 1px solid #eef2f7;
	position: relative;
	overflow: hidden;
	box-shadow: 0 4px 18px rgba(11,11,11,0.06);
	animation: fadeInUp .8s cubic-bezier(.2,.9,.2,1);
}
.eng h3 {
	margin: 0 0 .5rem;
	color: var(--about-dark);
}
.eng p {
	color: #666;
	margin: 0;
}
.eng:before {
	content: '';
	position: absolute;
	left: -30%;
	top: -40%;
	width: 220px;
	height: 220px;
	background: radial-gradient(circle at 30% 30%, rgba(255,106,0,0.08), transparent 45%);
	transform: rotate(18deg);
}
.eng:hover {
	transform: translateY(-6px) scale(1.03);
	box-shadow: 0 18px 40px rgba(11,11,11,0.08);
	transition: transform .28s, box-shadow .28s;
}

section {
	margin-bottom: 2.2rem;
}

section h2 {
	color: var(--about-green);
	font-size: 1.3rem;
	margin-bottom: .7rem;
	font-weight: 800;
}

.cta {
	background: linear-gradient(90deg,#fff,#fbfbfb);
	padding: 2rem;
	border-radius: 16px;
	margin: 1.5rem 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	box-shadow: 0 4px 18px rgba(11,11,11,0.06);
}
.cta h2 {
	color: var(--about-dark);
	margin: 0 0 .4rem;
}
.cta p {
	color: #888;
	margin-bottom: 1rem;
}
.cta .btn {
	box-shadow: 0 8px 22px rgba(255,106,0,0.08);
	margin-right: .7rem;
	margin-bottom: .5rem;
	font-weight: 700;
	transition: background .18s, transform .18s;
}
.cta .btn:hover {
	background: #ff7d26;
	transform: translateY(-2px) scale(1.04);
}

@media (max-width: 900px) {
	.stats-grid {
		grid-template-columns: repeat(2,1fr);
	}
	.engagements {
		grid-template-columns: 1fr;
	}
	.cta {
		padding: 1.2rem;
	}
}

@media (max-width: 700px) {
	.home-hero.contact-hero {
		padding: 1.2rem 0 1rem 0;
		border-radius: 0 0 18px 18px;
	}
	.stat {
		padding: .7rem;
	}
	.eng {
		padding: .7rem;
	}
}

@keyframes fadeInUp {
	from { opacity: 0; transform: translateY(24px); }
	to { opacity: 1; transform: none; }
}
/* Styles spécifiques à la page À propos */
