/* Couleurs de marque MPS Kids : rouge #db103f, jaune #ffe13b */
.mpskids-simu {
	--mps-red: #db103f;
	--mps-red-dark: #b30d34;
	--mps-yellow: #ffe13b;
	--mps-text: #333;
	--mps-border: #e6e6e6;
	--mps-slider-track: #e6e6e6;

	max-width: 760px;
	margin: 2rem auto;
	padding: 0 1rem;
	font-family: inherit;
	color: var(--mps-text);
}

.mpskids-simu * {
	box-sizing: border-box;
}

/* ===== FORMULAIRE ===== */
.mpskids-simu__form {
	padding: 1rem;
}

.mpskids-simu__field {
	margin-bottom: 1.75rem;
}

.mpskids-simu__field label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.75rem;
	color: #333;
}

.mpskids-simu__val {
	color: var(--mps-red);
	font-weight: 700;
}

/* Code postal : pilule jaune centrée */
.mpskids-simu__field--cp {
	text-align: center;
}

.mpskids-simu__field--cp label {
	color: var(--mps-yellow);
	text-shadow: 0 0 1px rgba(0, 0, 0, 0.25);
	text-transform: uppercase;
	font-weight: 700;
	letter-spacing: .05em;
	margin-bottom: 1rem;
}

.mpskids-simu .mpskids-simu__field--cp input[type="text"] {
	display: block !important;
	margin: 0 auto !important;
	width: 100% !important;
	max-width: 360px !important;
	padding: 0.9rem 1.5rem !important;
	background: var(--mps-yellow) !important;
	background-color: var(--mps-yellow) !important;
	border: none !important;
	border-radius: 999px !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	text-align: center !important;
	color: #333 !important;
	outline: none !important;
	box-shadow: none !important;
	transition: box-shadow .15s;
}

.mpskids-simu .mpskids-simu__field--cp input[type="text"]::placeholder {
	color: rgba(0, 0, 0, 0.4);
	font-weight: 400;
}

.mpskids-simu .mpskids-simu__field--cp input[type="text"]:focus {
	box-shadow: 0 0 0 3px rgba(219, 16, 63, 0.3) !important;
}

/* Range sliders custom */
.mpskids-simu input[type="range"] {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	height: 14px;
	background: var(--mps-slider-track);
	border-radius: 999px;
	outline: none;
	cursor: pointer;
	--pct: 0%;
	background: linear-gradient(to right, var(--mps-red) 0 var(--pct), var(--mps-slider-track) var(--pct) 100%);
}

.mpskids-simu input[type="range"]::-webkit-slider-thumb {
	-webkit-appearance: none;
	appearance: none;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: #fff;
	border: 3px solid var(--mps-red);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
	cursor: grab;
}

.mpskids-simu input[type="range"]::-moz-range-thumb {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: #fff;
	border: 3px solid var(--mps-red);
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
	cursor: grab;
}

.mpskids-simu input[type="range"]::-webkit-slider-thumb:active,
.mpskids-simu input[type="range"]::-moz-range-thumb:active {
	cursor: grabbing;
}

/* Toggle options avancées */
.mpskids-simu .mpskids-simu__toggle,
.mpskids-simu button.mpskids-simu__toggle {
	display: block !important;
	margin: 1.5rem auto !important;
	padding: 0.75rem 1.75rem !important;
	background: transparent !important;
	background-color: transparent !important;
	border: 2px solid var(--mps-red) !important;
	border-radius: 4px !important;
	color: var(--mps-red) !important;
	font-weight: 600 !important;
	font-size: 1rem !important;
	min-height: 44px !important;
	text-transform: none !important;
	cursor: pointer;
	box-shadow: none !important;
	transition: background .15s, color .15s;
}

.mpskids-simu .mpskids-simu__toggle:hover,
.mpskids-simu button.mpskids-simu__toggle:hover {
	background: var(--mps-red) !important;
	background-color: var(--mps-red) !important;
	color: #fff !important;
}

.mpskids-simu__toggle-icon {
	display: inline-block;
	width: 1em;
	margin-right: 0.25rem;
	font-weight: 700;
}

/* Radios */
.mpskids-simu__radio-label {
	font-weight: 600;
	margin-bottom: 0.4rem;
}

.mpskids-simu__field .mpskids-simu__radio-group {
	display: inline-flex;
	gap: 1.5rem;
}

.mpskids-simu__field input[type="radio"] {
	accent-color: var(--mps-red);
	margin-right: 0.4rem;
}

/* Alertes */
.mpskids-simu__alert {
	margin: .75rem auto 0;
	max-width: 360px;
	padding: .6rem .9rem;
	background: #fff3cd;
	color: #856404;
	border-left: 4px solid var(--mps-yellow);
	border-radius: 4px;
	font-size: .9rem;
	text-align: left;
}

.mpskids-simu__loading {
	text-align: center;
	color: #777;
	padding: 0.5rem;
	font-style: italic;
	font-size: .9rem;
}

/* Séparateur avant résultats */
.mpskids-simu__results {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--mps-border);
	display: grid;
	gap: 1.5rem;
}

/* Cartes résultats */
.mpskids-simu__card {
	border: 1px solid var(--mps-border);
	border-radius: 6px;
	overflow: hidden;
	background: #fff;
}

.mpskids-simu__card-header {
	background: #f5f5f5;
	padding: 1rem;
	text-align: center;
	border-bottom: 1px solid var(--mps-border);
}

.mpskids-simu__card-header h3 {
	margin: 0;
	color: var(--mps-red);
	font-weight: 700;
	font-size: 1.35rem;
}

.mpskids-simu__card-body {
	padding: 1.5rem;
}

.mpskids-simu__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

@media (max-width: 560px) {
	.mpskids-simu__grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 820px) {
	/* Full-bleed : s'échappe des padding empilés d'Elementor */
	.mpskids-simu {
		width: 100vw;
		max-width: 100vw;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		padding-left: .75rem;
		padding-right: .75rem;
		box-sizing: border-box;
	}
	.mpskids-simu__form {
		padding: .5rem;
	}
	.mpskids-simu__card-body {
		padding: 1rem;
	}
}

.mpskids-simu__card p {
	margin: .4rem 0;
	color: #333;
}

.mpskids-simu__card p strong {
	font-weight: 700;
}

.mpskids-simu__card [data-res] {
	color: var(--mps-red);
	font-weight: 600;
}

.mpskids-simu__note {
	margin-top: 1rem;
	font-size: .85rem;
	color: #666;
	border-top: 1px dashed var(--mps-border);
	padding-top: .6rem;
	font-style: italic;
}

.mpskids-simu__note [data-res] {
	color: #666;
	font-weight: 400;
}
