/* ═══════════════════════════════════════════════════════════════
   Styles du tunnel de commande /order
   ═══════════════════════════════════════════════════════════════ */

.orderStep {
	width: 95%;
	margin: 2rem auto;
	padding: 0 1rem;
}

/* Zone de formulaire centrée et de largeur contenue, commune aux étapes */
.orderStep .formZone {
	max-width: 800px;
	margin: auto;
}

/* ─── Barre de progression ───────────────────────────────────── */
.progressBar {
	display: flex;
	justify-content: space-between;
	list-style: none;
	margin: 0 0 2rem 0;
	padding: 0;
	counter-reset: step;
}
.progressBar .progressStep {
	flex: 1;
	text-align: center;
	position: relative;
	color: #999;
	font-size: 0.85rem;
}
.progressBar .progressStep + .progressStep::before {
	content: '';
	position: absolute;
	top: 14px;
	left: -50%;
	width: 100%;
	height: 2px;
	background: #ddd;
	z-index: 0;
}
.progressBar .progressStepNumber {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #ddd;
	color: #fff;
	font-weight: bold;
	position: relative;
	z-index: 1;
}
.progressBar .progressStepLabel {
	display: block;
	margin-top: 0.3rem;
}
.progressBar .progressStepActive .progressStepNumber { background: #1976d2; }
.progressBar .progressStepActive { color: #1976d2; font-weight: bold; }
.progressBar .progressStepDone .progressStepNumber { background: #4caf50; }
.progressBar .progressStepDone + .progressStep::before,
.progressBar .progressStepDone::before { background: #4caf50; }

/* ─── Formulaires (étapes 2 à 5) ─────────────────────────────── */
.fieldGroup { margin-bottom: 1rem; }
.fieldGroup label { display: block; font-weight: 600; margin-bottom: 0.3rem; }
.fieldGroup input[type=text], .fieldGroup input[type=email], .fieldGroup input[type=tel], .fieldGroup input[type=number], .fieldGroup textarea {
	width: 100%;
	padding: 0.5rem;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 1rem;
	box-sizing: border-box;
}
.fieldGroup.row { display: flex; gap: 1rem; }
.fieldGroup.row > div { flex: 1; }
.fieldHint { color: #666; font-size: 0.85rem; margin: 0.3rem 0 0; }
.radioGroup { display: flex; gap: 1.5rem; }
.radioGroup label { display: inline-flex; align-items: center; gap: 0.3rem; font-weight: normal; }

/* ─── Tableau des prix ───────────────────────────────────────── */
.pricesTable {
	width: 100%;
	margin-top: 1rem;
	border-collapse: collapse;
}
.pricesTable td {
	padding: 0.4rem 0;
}
.pricesTable td.price {
	text-align: right;
	font-variant-numeric: tabular-nums;
}
.pricesTable .totalRow { font-weight: bold; border-top: 1px solid #ddd; }
.pricesTable .totalRow td { padding-top: 0.6rem; }

/* ─── Code avantage (collapsible) ───────────────────────────── */
.advantageCodeBlock {
	margin: 1.5rem 0;
	padding: 0.8rem;
	background: #f5f5f5;
	border-radius: 4px;
}
.advantageCodeBlock summary { cursor: pointer; font-weight: 600; }
.advantageCodeBlock input { margin-top: 0.6rem; width: 100%; padding: 0.5rem; border: 1px solid #ccc; border-radius: 4px; box-sizing: border-box; }

/* ─── Bloc CGV / RGPD ────────────────────────────────────────── */
.cgvBlock { margin: 1.5rem 0; }
.cgvBlock label { display: block; margin-bottom: 0.5rem; cursor: pointer; }
.cgvBlock input[type=checkbox] { margin-right: 0.5rem; }

/* ─── Récap (étape Paiement / Confirmation) ─────────────────── */
.orderRecap {
	background: #f9f9f9;
	padding: 1rem;
	border-radius: 4px;
	margin: 1.5rem 0;
}
.orderRecap dl { margin: 0; display: grid; grid-template-columns: max-content 1fr; gap: 0.4rem 1rem; }
.orderRecap dt { font-weight: 600; }
.orderRecap dd { margin: 0; }
.recapTotal { font-weight: bold; font-size: 1.1rem; color: #1976d2; }

/* ─── Boutons d'actions standard ─────────────────────────────── */
.orderActions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid #eee;
}
.orderActions .button {
	display: inline-block;
	padding: 0.6rem 1.2rem;
	border-radius: 4px;
	text-decoration: none;
	border: none;
	cursor: pointer;
	font-size: 0.95rem;
}

.orderActions .buttonCentered {
  margin-left: auto;
	margin-right: auto;
}

.orderActions .button.buttonPrimary { background: #1976d2; color: #fff; }
.orderActions .button.buttonPrimary:hover { background: #1565c0; }
.orderActions .button.buttonLow { background: #f0f0f0; color: #333; }
.orderActions .button.buttonLow:hover { background: #e0e0e0; }
.orderActions .button.buttonCancel { background: #fff; color: #d32f2f; border: 1px solid #d32f2f; }
.orderActions .button.buttonCancel:hover { background: #ffebee; }

/* ─── Erreurs ────────────────────────────────────────────────── */
.errorBanner {
	background: #ffebee;
	color: #c62828;
	padding: 0.8rem;
	border-left: 4px solid #c62828;
	border-radius: 4px;
	margin: 1rem 0;
}

/* ─── Statut de la commande (étape 6) ────────────────────────── */
.statusBlock {
	text-align: center;
	padding: 2rem;
	border-radius: 8px;
	margin: 2rem 0;
}
.statusBlock-success   { background: #e8f5e9; border: 1px solid #c8e6c9; }
.statusBlock-pending   { background: #fff8e1; border: 1px solid #ffe0a3; }
.statusBlock-cancelled { background: #ffebee; border: 1px solid #ffcdd2; }
.statusTitle {
	margin: 0 0 1rem;
	font-size: 1.4rem;
}
.statusBlock-success   .statusTitle { color: #2e7d32; }
.statusBlock-pending   .statusTitle { color: #ef6c00; }
.statusBlock-cancelled .statusTitle { color: #c62828; }
.statusBody         { margin: 0.5rem 0; line-height: 1.5; }
.statusTrackingHint { margin-top: 1rem; font-size: 0.9rem; color: #555; word-break: break-all; }

/* ─── Étape Facturation : bouton loupe inline à droite du SIRET ───── */
.formLine.siret .siretButton {
	margin-left: 0.5rem;
	width: 2.4em;
	height: 2.4em;
	padding: 0;
	background-color: #1976d2;
	border: 1px solid #1976d2;
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3e%3ccircle cx='11' cy='11' r='7'/%3e%3cline x1='20.5' y1='20.5' x2='16.2' y2='16.2'/%3e%3c/svg%3e");
	background-repeat: no-repeat;
	background-position: center;
	background-size: 1.2em 1.2em;
}
.formLine.siret .siretButton:hover {
	background-color: #1565c0;
	border-color: #1565c0;
}
.formLine.siret .siretButton:focus-visible {
	background-color: #1565c0;
	border-color: #1565c0;
	box-shadow: 0 0 0 .25rem rgba(25,118,210,.25);
	outline: 0;
}

/* ─── Responsive mobile ──────────────────────────────────────── */
@media (max-width: 600px) {
	.profileGrid { grid-template-columns: 1fr; }
	.progressBar .progressStepLabel { font-size: 0.7rem; }
	.fieldGroup.row { flex-direction: column; gap: 0; }
	.orderActions { flex-direction: column; gap: 0.5rem; }
	.orderActions .button { width: 100%; text-align: center; }
}

:root {
	--color-walk: #4CAF50;
	--color-bike: #FFEB3B;
	--color-ebike: #FF9800;
	--opacity-walk: 0.5;
	--opacity-bike: 0.4;
	--opacity-ebike: 0.3;

	--font: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	--background:#fff;
	--color:#000;

	--color-main-background: #fff;
	--color-main-border: #000;
	--color-main-font: #000;
	--color-high-background: rgb(255, 243, 205);
	--color-high-border: rgb(255, 236, 181);
	--color-high-font: rgb(102, 77, 3);
	--color-standard-background: rgb(207, 226, 255);
	--color-standard-border: rgb(158, 197, 254);
	--color-standard-font: rgb(5, 44, 101);
	--color-low-background: rgb(226, 227, 229);
	--color-low-border: rgb(196, 200, 203);
	--color-low-font: rgb(43, 47, 50);
	--color-success-background: rgb(209, 231, 221);
	--color-success-border: rgb(163, 207, 187);
	--color-success-font: rgb(10, 54, 34);
	--color-success: rgb(3, 164, 93);
	--color-alert-background: rgb(248, 215, 218);
	--color-alert-border: rgb(241, 174, 181);
	--color-alert-font: rgb(88, 21, 28);
	--color-alert: #ef4444;

	--form-btn-standard-color: #fff;
	--form-btn-standard-bg: #0d6efd;
	--form-btn-standard-border-color: #0d6efd;
	--form-btn-standard-hover-color: #fff;
	--form-btn-standard-hover-bg: #0b5ed7;
	--form-btn-standard-hover-border-color: #0a58ca;
	--form-btn-standard-focus-shadow-rgb: 49, 132, 253;
	--form-btn-standard-active-color: #fff;
	--form-btn-standard-active-bg: #0a58ca;
	--form-btn-standard-active-border-color: #0a53be;
	--form-btn-standard-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
	--form-btn-standard-disabled-color: #fff;
	--form-btn-standard-disabled-bg: #0d6efd;
	--form-btn-standard-disabled-border-color: #0d6efd;
	--form-btn-standard-disabled-opacity:0.65;
	--form-btn-standard-focus-box-shadow: 0 0 0 0.25rem rgba(var(--form-btn-standard-focus-shadow-rgb), .5);

	--form-btn-low-color: #fff;
	--form-btn-low-bg: #6c757d;
	--form-btn-low-border-color: #6c757d;
	--form-btn-low-hover-color: #fff;
	--form-btn-low-hover-bg: #5c636a;
	--form-btn-low-hover-border-color: #565e64;
	--form-btn-low-focus-shadow-rgb: 130, 138, 145;
	--form-btn-low-active-color: #fff;
	--form-btn-low-active-bg: #565e64;
	--form-btn-low-active-border-color: #51585e;
	--form-btn-low-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
	--form-btn-low-disabled-color: #fff;
	--form-btn-low-disabled-bg: #6c757d;
	--form-btn-low-disabled-border-color: #6c757d;
	--form-btn-low-disabled-opacity:0.65;
	--form-btn-low-focus-box-shadow: 0 0 0 0.25rem rgba(var(--form-btn-standard-focus-shadow-rgb), .5);

	--table-border:solid 1px rgb(196, 200, 203);
	--table-tr-background:rgb(207, 226, 255);

	--link-color: #0d6efd;
	--link-color-active: rgb(10, 88, 202);

}
html, body {
	margin: 0;
	padding: 0;
	height: 100%;
	font-size: 15px;
}

/* Réservation de l’espace de la scrollbar pour éviter le déplacement du menu en fonction de sa présence ou non */
html { overflow-y: scroll; }

body {
	font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
	background: #fff;
	color: #000;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
/* Header */
.header {
	padding: 1em;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	background: #fff;
	position: relative;
}
.logo,.logo-URPS {
	height: 4.5em;
	width: auto;
}
.logo { margin-right: auto; /* pousse les autres éléments à droite */ }
.logo-URPS { display: none; }

/* Menu hamburger */
.menu-toggle {
	display: none;
	flex-direction: column;
	cursor: pointer;
	z-index: 520;
	background: none;
	border: none;
	padding: 5px;
}
.menu-toggle span {
	width: 25px;
	height: 3px;
	background-color: #000;
	margin: 3px 0;
	transition: 0.3s;
	border-radius: 2px;
}
.menu-toggle.active span:nth-child(1) {
	transform: rotate(-45deg) translate(-5px, 6px);
}
.menu-toggle.active span:nth-child(2) {
	opacity: 0;
}
.menu-toggle.active span:nth-child(3) {
	transform: rotate(45deg) translate(-5px, -6px);
}

/* Navigation */
.nav-links {
	display: flex;
	gap: 1em;
	align-items: center;
	flex-wrap: wrap;
}
.nav-links a {
	text-decoration: none;
	color: #000;
	font-size: 1em;
	font-weight: normal;
	transition: color 0.3s;
}
.nav-links img {
	height: 1.2em;
	vertical-align: bottom;
	margin-right: 0.3em;
}
.nav-links a.active {
	text-decoration: underline;
}
.nav-links a:hover, .nav-links a:focus {
	color: #1F6EBB;
	text-decoration: underline;
}
@media (min-width: 1400px) { .nav-links a { font-size: 1.1em; } }
@media (min-width: 1600px) { .nav-links a { font-size: 1.2em; } }

/* Titre principal */
.page-title {
	text-align: center;
	padding: 1em;
}
.page-title h1 {
	font-size: 1.7em;
	font-weight: bold;
	margin: 0;
	color: #000;
}
/* Contenu principal */
.main-content {
	flex: 1 0;
	display: flex;
	flex-direction: column;
}
/* Footer */
.footer {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2em;
	font-size: 1em;
	padding: 0.5em;
	border-top: 1px solid #e0e0e0;
	background: #f5f5f5;
}
.footer a {
	text-decoration: none;
	color: #000;
}
.footer a:hover, .footer a:focus {
	color: #1F6EBB;
	text-decoration: underline;
}

.footer img { height: 1em; }

.smallScreen { display: none; }
.mediumScreen { display: none; }
.largeScreen { display: none; }
@media (min-width: 801px) { .largeScreen, .mediumScreen.largeScreen, .smallScreen.mediumScreen.largeScreen { display: inline; } }
@media (min-width: 501px) and (max-width: 800px) { .mediumScreen, .smallScreen.mediumScreen ,.mediumScreen.largeScreen, .smallScreen.mediumScreen.largeScreen { display: inline; } }
@media (max-width: 500px) { .smallScreen,.smallScreen.mediumScreen, .smallScreen.mediumScreen.largeScreen  { display: inline; } }

/* Masquer l'attribution Leaflet */
.leaflet-control-attribution {
	display: none !important;
}

/* Responsive pour le menu */
@media (max-width: 1250px) {
	.menu-toggle {
		display: flex;
	}
	.nav-links {
		position: fixed;
		top: 0;
		right: -100%;
		width: 18em;
		height: 100vh;
		background: #fff;
		flex-direction: column;
		align-items: flex-start;
		padding: 80px 30px 30px;
		box-shadow: -2px 0 10px rgba(0,0,0,0.1);
		transition: right 0.3s ease;
		z-index: 510;
		gap: 20px;
	}
	.nav-links.active {
		right: 0;
	}
	.nav-links a {
		font-size: 1.1rem;
		width: 100%;
		padding: 10px 0;
		border-bottom: 1px solid #f0f0f0;
	}
	/* Overlay */
	.nav-overlay {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: rgba(0,0,0,0.5);
		z-index: 500;
	}
	.nav-overlay.active {
		display: block;
	}
}


@media print {
	@page {
		size: A4 portrait; /* ou portrait selon vos besoins */
		margin: 1cm;
	}
	body {
		width: 100%;
		margin: 0;
		padding: 0;
	}
	.nav-links, .menu-toggle, .footer , #mapUpdateBtn, #settingsBtn,#share-section { display: none !important; }
	.logo-URPS { display: block !important; }
}

