/**
 * Styles spécifiques à la page d'accueil (front-page.php).
 */

/* ============================================
   HERO ACCUEIL
   ============================================ */

.home-hero {
	position: relative;
	padding-block: clamp(60px, 12vw, 140px) clamp(40px, 8vw, 100px);
	overflow: hidden;
	background:
		radial-gradient(ellipse 80% 60% at 70% 20%, rgba(201, 169, 97, 0.15), transparent 60%),
		radial-gradient(ellipse 60% 60% at 20% 80%, rgba(201, 169, 97, 0.08), transparent 50%),
		var(--bg);
}

.home-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(45deg, transparent 49%, var(--accent) 49%, var(--accent) 51%, transparent 51%);
	background-size: 24px 24px;
	opacity: 0.025;
	pointer-events: none;
}

.home-hero__inner {
	position: relative;
	z-index: 2;
	display: grid;
	gap: var(--space-2xl);
	grid-template-columns: 1.4fr 1fr;
	align-items: center;
}

@media (max-width: 900px) {
	.home-hero__inner { grid-template-columns: 1fr; }
}

.home-hero__overline {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: var(--fs-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.25em;
	color: var(--accent);
	margin-bottom: var(--space-md);
}

.home-hero__overline::before {
	content: '';
	width: 32px;
	height: 1px;
	background: var(--accent);
}

.home-hero__title {
	font-size: clamp(var(--fs-3xl), 6vw, var(--fs-5xl));
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-lg);
}

.home-hero__title em {
	font-style: italic;
	color: var(--accent);
}

.home-hero__lead {
	font-size: clamp(var(--fs-md), 1.6vw, var(--fs-lg));
	color: var(--text-muted);
	max-width: 540px;
	margin-bottom: var(--space-xl);
}

.home-hero__actions {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
}

.home-hero__trust {
	display: flex;
	gap: var(--space-lg);
	margin-top: var(--space-2xl);
	flex-wrap: wrap;
	color: var(--text-muted);
	font-size: var(--fs-sm);
}

.home-hero__trust-item {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}

.home-hero__trust-item svg {
	width: 18px;
	height: 18px;
	color: var(--accent);
}

/* Card flottante à droite */
.home-hero__card {
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: var(--radius-xl);
	padding: var(--space-xl);
	box-shadow: var(--shadow-lg);
	position: relative;
}

.home-hero__card::before {
	content: '';
	position: absolute;
	top: -1px; left: -1px; right: -1px; bottom: -1px;
	border-radius: var(--radius-xl);
	padding: 1px;
	background: linear-gradient(135deg, var(--accent), transparent 40%);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

.home-hero__card-label {
	font-size: var(--fs-xs);
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--accent);
	margin-bottom: var(--space-sm);
}

.home-hero__card-num {
	font-family: var(--font-display);
	font-size: clamp(var(--fs-4xl), 8vw, var(--fs-5xl));
	font-weight: 700;
	color: var(--accent);
	line-height: 1;
	margin-bottom: var(--space-sm);
}

.home-hero__card-text {
	color: var(--text-muted);
	font-size: var(--fs-sm);
	line-height: var(--lh-relaxed);
}

.home-hero__card-divider {
	height: 1px;
	background: var(--border);
	margin: var(--space-lg) 0;
}

.home-hero__card-rating {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	color: var(--accent);
	font-weight: 700;
}

/* ============================================
   SECTIONS HOME
   ============================================ */

.home-section {
	padding-block: clamp(96px, 12vw, 180px);
}

/* Sépare visuellement 2 sections consécutives partageant le même fond */
.home-section + .home-section:not(.home-section--alt),
.home-section--alt + .home-section--alt {
	border-top: 1px solid var(--border);
}

.home-section--alt {
	background: var(--bg-alt);
}

.home-section__header {
	max-width: 760px;
	margin-bottom: clamp(40px, 5vw, 72px);
}

.home-section__overline {
	display: inline-block;
	font-size: var(--fs-xs);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.25em;
	color: var(--accent);
	margin-bottom: var(--space-lg);
}

.home-section__title {
	font-size: clamp(var(--fs-2xl), 4vw, var(--fs-4xl));
	line-height: 1.15;
	margin-bottom: var(--space-lg);
	text-wrap: balance;
}

.home-section__lead {
	font-size: var(--fs-lg);
	line-height: 1.55;
	color: var(--text-muted);
}

/* ============================================
   SERVICES (grille de 4 cartes)
   ============================================ */

.services-grid {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.service-card {
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.home-section--alt .service-card { background: var(--bg-elevated); }

.service-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--shadow-lg);
	border-color: var(--accent);
}

.service-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: var(--radius-md);
	background: linear-gradient(135deg, var(--accent), var(--accent-hover));
	color: var(--on-accent);
}

.service-card__icon svg { width: 28px; height: 28px; }

.service-card__title {
	font-size: var(--fs-xl);
	margin: 0;
}

.service-card__text {
	color: var(--text-muted);
	font-size: var(--fs-base);
	line-height: var(--lh-relaxed);
	flex: 1;
}

.service-card__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	color: var(--accent);
	font-weight: 600;
	font-size: var(--fs-sm);
	margin-top: auto;
}

.service-card__link:hover { gap: var(--space-md); }

/* ============================================
   FLOTTE
   ============================================ */

.fleet-grid {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.fleet-card {
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.home-section--alt .fleet-card { background: var(--bg); }

.fleet-card__visual {
	aspect-ratio: 4/3;
	background: linear-gradient(135deg, var(--bg-elevated), var(--bg-alt));
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--accent);
	position: relative;
}

.fleet-card__visual::after {
	content: 'Photo à venir';
	position: absolute;
	bottom: 8px;
	right: 8px;
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--text-muted);
	background: rgba(0,0,0,0.4);
	padding: 2px 8px;
	border-radius: var(--radius-pill);
}

.fleet-card__visual svg {
	width: 80px;
	height: 80px;
	opacity: 0.7;
}

.fleet-card__body {
	padding: var(--space-lg);
}

.fleet-card__name {
	font-size: var(--fs-lg);
	font-weight: 700;
	margin-bottom: var(--space-xs);
	color: var(--text);
}

.fleet-card__capacity {
	font-size: var(--fs-sm);
	color: var(--accent);
	font-weight: 600;
	margin-bottom: var(--space-sm);
}

.fleet-card__features {
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: var(--fs-sm);
	color: var(--text-muted);
}

.fleet-card__features li {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	padding: var(--space-xs) 0;
}

.fleet-card__features li::before {
	content: '✓';
	color: var(--accent);
	font-weight: 700;
}

/* ============================================
   TRUST / CHIFFRES
   ============================================ */

.trust-strip {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: var(--space-xl);
	padding: var(--space-2xl);
	background: var(--bg-alt);
	border-radius: var(--radius-xl);
	border: 1px solid var(--border);
}

.home-section--alt .trust-strip { background: var(--bg); }

.trust-stat {
	text-align: center;
}

.trust-stat__num {
	font-family: var(--font-display);
	font-size: clamp(var(--fs-3xl), 5vw, var(--fs-4xl));
	font-weight: 700;
	color: var(--accent);
	line-height: 1;
	margin-bottom: var(--space-xs);
}

.trust-stat__label {
	font-size: var(--fs-sm);
	color: var(--text-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

/* ============================================
   AVIS GOOGLE (placeholder)
   ============================================ */

.reviews-grid {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.review-card {
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
}

.home-section--alt .review-card { background: var(--bg); }

.review-card__stars {
	color: #FFB400;
	font-size: var(--fs-md);
	letter-spacing: 2px;
	margin-bottom: var(--space-sm);
}

.review-card__text {
	color: var(--text);
	font-style: italic;
	line-height: var(--lh-relaxed);
	margin-bottom: var(--space-md);
}

.review-card__author {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: var(--fs-sm);
	color: var(--text-muted);
}

.review-card__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--accent), var(--accent-hover));
	color: var(--on-accent);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
}

/* ============================================
   CTA SIMULATEUR
   ============================================ */

.simulator-cta {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: var(--space-2xl);
	align-items: center;
	padding: clamp(40px, 6vw, 80px);
	background:
		radial-gradient(ellipse at top right, rgba(201, 169, 97, 0.15), transparent 60%),
		var(--bg-alt);
	border-radius: var(--radius-xl);
	border: 1px solid var(--border);
}

.home-section--alt .simulator-cta {
	background:
		radial-gradient(ellipse at top right, rgba(201, 169, 97, 0.15), transparent 60%),
		var(--bg);
}

@media (max-width: 800px) {
	.simulator-cta { grid-template-columns: 1fr; }
}

.simulator-cta__visual {
	font-family: var(--font-display);
	text-align: right;
}

.simulator-cta__price {
	font-size: clamp(var(--fs-3xl), 6vw, var(--fs-5xl));
	color: var(--accent);
	font-weight: 700;
	line-height: 1;
}

.simulator-cta__price small {
	font-size: 40%;
	color: var(--text-muted);
	font-weight: 400;
	display: block;
	margin-top: var(--space-sm);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* ============================================
   CTA FINAL
   ============================================ */

.final-cta {
	text-align: center;
	padding-block: clamp(60px, 10vw, 120px);
	background:
		radial-gradient(ellipse at center, rgba(201, 169, 97, 0.12), transparent 70%),
		var(--bg);
}

.final-cta__title {
	font-size: clamp(var(--fs-2xl), 4vw, var(--fs-4xl));
	margin-bottom: var(--space-md);
	/* Évite que la ponctuation finale (?, !) tombe seule sur une ligne */
	text-wrap: balance;
}

.final-cta__lead {
	color: var(--text-muted);
	font-size: var(--fs-lg);
	max-width: 580px;
	margin: 0 auto var(--space-xl);
}

.final-cta__actions {
	display: inline-flex;
	gap: var(--space-md);
	flex-wrap: wrap;
	justify-content: center;
}
