/* Composants — taxi-product */

/* ── Boutons ───────────────────────────────────────────────────────────── */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
	padding: .8rem 1.4rem; border-radius: var(--radius-sm);
	font-weight: 600; font-size: .98rem; line-height: 1;
	transition: transform var(--transition), box-shadow var(--transition), background var(--transition);
	white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn .icon { flex: none; }

.btn--primary, .btn--secondary { background: var(--color-primary); color: var(--color-on-primary); box-shadow: var(--shadow-sm); }
.btn--secondary { background: var(--color-secondary); color: #1c1303; }
.btn--call { background: var(--color-secondary); color: #1c1303; box-shadow: var(--shadow-sm); }
.btn--ghost { background: transparent; color: var(--color-primary); border: 2px solid currentColor; }
.btn--ghost:hover { background: var(--color-primary); color: #fff; }
.btn--lg { padding: 1rem 1.7rem; font-size: 1.05rem; }
.btn--xl { padding: 1.15rem 2.2rem; font-size: 1.2rem; }
.btn--sm { padding: .6rem 1rem; font-size: .9rem; }

.call-button-block { text-align: center; }

/* ── Sections génériques ───────────────────────────────────────────────── */
.section--steps { background: var(--color-surface); }
.section--zones, .section--testimonials { background: var(--color-bg); }
.section--fleet { background: var(--color-surface); }

/* ── Hero ──────────────────────────────────────────────────────────────── */
.section--hero {
	background:
		radial-gradient(900px 380px at 80% -10%, var(--color-primary-tint), transparent),
		var(--color-primary);
	color: #fff;
}
.section--hero h1, .section--hero .section__title { color: #fff; }
.hero__eyebrow { display: inline-flex; align-items: center; gap: .4rem; margin-bottom: .9rem; }
.hero__title { margin-bottom: .8rem; }
.hero__lead { font-size: 1.15rem; color: rgba(255,255,255,.86); margin-bottom: 1.6rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; }
.section--hero .btn--ghost { color: #fff; }
.section--hero .btn--ghost:hover { background: #fff; color: var(--color-primary); }
.hero__form {
	background: var(--color-surface); color: var(--color-text);
	border-radius: var(--radius); padding: clamp(1.25rem, 1rem + 2vw, 2rem);
	box-shadow: var(--shadow);
}
.hero__form-title { margin-bottom: 1rem; }

/* ── Bandeau d'urgence ─────────────────────────────────────────────────── */
.urgency-banner { background: var(--color-secondary); color: #1c1303; }
.urgency-banner__inner {
	max-width: var(--max-width); margin-inline: auto;
	padding: .85rem var(--gutter);
	display: flex; align-items: center; justify-content: center;
	gap: .8rem; flex-wrap: wrap; text-align: center;
}
.urgency-banner__pulse {
	width: 11px; height: 11px; border-radius: 50%; background: #1e7a45; flex: none;
	box-shadow: 0 0 0 0 rgba(30,122,69,.7); animation: taxip-pulse 2s infinite;
}
@keyframes taxip-pulse {
	70% { box-shadow: 0 0 0 12px rgba(30,122,69,0); }
	100% { box-shadow: 0 0 0 0 rgba(30,122,69,0); }
}
.urgency-banner__text { margin: 0; }
.urgency-banner__call { font-weight: 700; display: inline-flex; align-items: center; gap: .35rem; }

/* ── Étapes ────────────────────────────────────────────────────────────── */
.step-card {
	background: var(--color-bg); border: 1px solid var(--color-border);
	border-radius: var(--radius); padding: 1.75rem 1.5rem; text-align: center;
}
.step-card__icon {
	display: inline-flex; padding: .9rem; border-radius: 50%;
	background: var(--color-primary); color: #fff; margin-bottom: .9rem;
}
.step-card__title { margin-bottom: .45rem; }
.step-card__text { color: var(--color-text-muted); }

/* ── Zones ─────────────────────────────────────────────────────────────── */
.zones-map {
	height: 340px; border-radius: var(--radius); overflow: hidden;
	box-shadow: var(--shadow-sm); background: #dfe6ea;
}
.zones-list {
	display: grid; gap: .55rem;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}
.zones-list__item {
	display: flex; align-items: center; gap: .5rem;
	background: var(--color-surface); border: 1px solid var(--color-border);
	border-radius: var(--radius-sm); padding: .65rem .8rem;
}
.zones-list__item .icon { color: var(--color-secondary); flex: none; }
.zones-list__name { font-weight: 600; }
.zones-list__postal { margin-left: auto; color: var(--color-text-muted); font-size: .85rem; }

/* ── Flotte ────────────────────────────────────────────────────────────── */
.vehicle-card {
	background: var(--color-bg); border: 1px solid var(--color-border);
	border-radius: var(--radius); overflow: hidden; display: flex; flex-direction: column;
}
.vehicle-card__media { aspect-ratio: 16 / 10; background: var(--color-primary); display: grid; place-items: center; }
.vehicle-card__img { width: 100%; height: 100%; object-fit: cover; }
.vehicle-card__placeholder { color: rgba(255,255,255,.5); }
.vehicle-card__body { padding: 1.25rem; display: flex; flex-direction: column; gap: .55rem; }
.vehicle-card__capacity { display: flex; align-items: center; gap: .4rem; color: var(--color-text-muted); font-weight: 600; }
.vehicle-card__excerpt { color: var(--color-text-muted); font-size: .95rem; }
.vehicle-card__features { display: flex; flex-direction: column; gap: .3rem; margin-top: .25rem; }
.vehicle-card__features li { display: flex; align-items: center; gap: .4rem; font-size: .92rem; }
.vehicle-card__features .icon { color: var(--color-success); }

/* ── Témoignages ───────────────────────────────────────────────────────── */
.testimonial-card {
	background: var(--color-surface); border: 1px solid var(--color-border);
	border-radius: var(--radius); padding: 1.6rem; display: flex; flex-direction: column; gap: .7rem;
}
.testimonial-card__stars { display: flex; gap: .15rem; color: var(--color-secondary); }
.testimonial-card__stars .icon { fill: var(--color-secondary); }
.testimonial-card__quote { font-style: italic; color: var(--color-text); }
.testimonial-card__author { font-weight: 700; color: var(--color-primary); }

/* ── CTA final ─────────────────────────────────────────────────────────── */
.section--cta { background: var(--color-bg); }
.cta-box {
	background: var(--color-primary); color: #fff; border-radius: var(--radius);
	padding: clamp(2rem, 1.5rem + 3vw, 3.5rem); text-align: center; box-shadow: var(--shadow);
}
.cta-box__title { color: #fff; margin-bottom: .5rem; }
.cta-box__text { color: rgba(255,255,255,.85); margin-bottom: 1.5rem; }
.cta-box__actions { display: flex; gap: .8rem; justify-content: center; flex-wrap: wrap; }

/* ── Grille tarifaire ──────────────────────────────────────────────────── */
.pricing-table {
	max-width: 760px; margin-inline: auto;
	border: 1px solid var(--color-border); border-radius: var(--radius);
	overflow: hidden; background: var(--color-surface);
}
.pricing-table__head {
	display: flex; justify-content: space-between;
	background: var(--color-primary); color: #fff;
	padding: .8rem 1.2rem; font-weight: 600; font-family: var(--font-display);
}
.pricing-table__row {
	display: flex; justify-content: space-between; align-items: center; gap: 1rem;
	padding: .9rem 1.2rem; border-top: 1px solid var(--color-border);
}
.pricing-table__row:nth-child(even) { background: var(--color-bg); }
.pricing-table__label { display: flex; flex-direction: column; }
.pricing-table__label small { color: var(--color-text-muted); }
.pricing-table__price { font-weight: 700; color: var(--color-primary); white-space: nowrap; }
.pricing-note {
	max-width: 760px; margin: 1rem auto 0; display: flex; gap: .45rem;
	align-items: flex-start; color: var(--color-text-muted); font-size: .9rem;
}
.pricing-note .icon { color: var(--color-secondary); flex: none; margin-top: 2px; }

/* ── Divers ────────────────────────────────────────────────────────────── */
.post-card { padding: 1.25rem 0; border-bottom: 1px solid var(--color-border); }
.error-404 { text-align: center; }
.error-404 .btn { margin-block: 1rem; }
