.mr-app {
	max-width: 480px;
	margin: 0 auto;
	font-family: inherit;
}

.mr-paso {
	margin-bottom: 1.5em;
}

.mr-app label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.5em;
}

.mr-app input {
	width: 100%;
	padding: 0.6em;
	margin-bottom: 0.6em;
	border: 1px solid #ccc;
	border-radius: 6px;
	box-sizing: border-box;
}

.mr-horas {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5em;
}

.mr-hora-btn {
	padding: 0.6em 1em;
	border: 1px solid #888;
	border-radius: 6px;
	background: #fff;
	cursor: pointer;
}

.mr-hora-btn.mr-seleccionado {
	background: #222;
	color: #fff;
	border-color: #222;
}

.mr-hora-btn.mr-completo {
	opacity: 0.4;
	cursor: not-allowed;
}

#mr-submit {
	padding: 0.7em 1.4em;
	background: #222;
	color: #fff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
}

#mr-submit:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.mr-mensaje {
	color: #b00020;
	font-size: 0.9em;
}

.mr-qr-img {
	width: 220px;
	height: 220px;
	margin-top: 1em;
}
