/* Formularios en general */



.campo,
fieldset {
	position: relative;
	margin-top: 1.1rem;
	margin-bottom: 1.1rem;
	width: 100%;
}

label {
	/* A retirar en futuras revisiones */
	display: block;
}

/*label,*/
.rotulo_campo.de_campo,
legend {
	font-family: robb;
}
.rotulo_campo.de_campo{
	color: #127594;
	margin-top: 0.7rem;
}

legend {
	position: absolute;
	top: 1rem;
	font-size: 1.3rem;
	color: rgba(9, 65, 82, 0.2);

}

.rotulo_campo.bloque {
	display: block;
}

.rotulo_campo.linea {
	display: inline-block;
}

.item_lista_campo {
	margin: 0.4rem;
	position: relative;
}

.item_lista_campo input {
	margin-right: 0.2rem;
}

option {
	font-family: robb;
}



input,
select,
textarea {
	margin: 0.2rem 0;
}

input[type="file"] {
	margin: 0;
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="date"],
input[type="time"],
select,
textarea
{
	padding: 0.3rem 0.5rem;
	border: 1px solid #9abac9;
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="date"],
input[type="time"],
select
{
	height: 2.5rem;
}

select[multiple] {
	padding: 0;
	height: auto;
}
option {
	padding: 0.3rem 0.5rem;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
input[type="time"]:focus, 
select:focus,
textarea:focus {
	box-shadow: 0 0 0.5rem #9abac9 inset;
}

input[type="password"] {
	font-size: 2rem;
}

input[type="submit"],
button {
	padding: 0.3rem;
	/*margin: 0.6rem 0;*/
	display: block;
}

/* Casillas personalizadas */
input[type="checkbox"] {
	opacity: 0;
	position: absolute;
}
input[type="checkbox"] + label {
	padding-left: 1.4rem;
}
input[type="checkbox"] + label::before {
	content: " ";
	position: absolute;
	left: 0;
	top: 0;
	width: 1rem;
	height: 1rem;
	border: 1px solid #127594;
	background-color: white;
}
input[type="checkbox"] + label::after {
	content: " ";
	position: absolute;
	left: 0;
	top: -0.5rem;
	width: 1.7rem;
	height: 1.7rem;
	background-image: url('/img/iconos/md-checkmark-azul.svg');
	background-repeat: no-repeat;
	background-position: bottom;
	opacity: 0;
	transition: 
		opacity 0.06s ease-in 0s;

}
input[type="checkbox"]:checked + label::after {
	opacity: 1;
}
input[type="checkbox"]:disabled + label::before {
	border: 1px solid #9abac9;
	background-color: rgb(250, 250, 250);
}
input[type="checkbox"]:disabled:checked + label::after {
	background-image: url('/img/iconos/md-checkmark-desactivado-azul.svg');
}


input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
select,
textarea {
	width: 100%;
}

input[type="date"],
input[type="time"] {
	width: auto;
}

/* Círculos */
input[type="radio"] {
	opacity: 0;
	position: absolute;
}
input[type="radio"] + label {
	padding-left: 1.4rem;
}
input[type="radio"]:not(:checked) + label::before {
	content: " ";
	position: absolute;
	left: 0;
	top: 0;
	width: 1.3rem;
	height: 1.3rem;
	background-image: url('/img/iconos/ios-radio-button-off-azul.svg');
	background-repeat: no-repeat;
	/*background-size: 1rem;*/
	background-position-y: -0.1rem;
	background-position-x: -0.1rem;
}
input[type="radio"]:checked + label::after {
	content: " ";
	position: absolute;
	left: 0;
	top: 0;
	width: 1.3rem;
	height: 1.3rem;
	background-image: url('/img/iconos/ios-radio-button-on-azul.svg');
	background-repeat: no-repeat;
	/*background-size: 1rem;*/
	background-position-y: -0.1rem;
	background-position-x: -0.1rem;
}
input[type="radio"]:disabled:not(:checked) + label::before {
	content: " ";
	position: absolute;
	left: 0;
	top: 0;
	width: 1.3rem;
	height: 1.3rem;
	background-image: url('/img/iconos/ios-radio-button-off-desactivado-azul.svg');
	background-repeat: no-repeat;
	/*background-size: 1rem;*/
	background-position-y: -0.1rem;
	background-position-x: -0.1rem;
}
input[type="radio"]:disabled:checked + label::after {
	content: " ";
	position: absolute;
	left: 0;
	top: 0;
	width: 1.3rem;
	height: 1.3rem;
	background-image: url('/img/iconos/ios-radio-button-on-desactivado-azul.svg');
	background-repeat: no-repeat;
	/*background-size: 1rem;*/
	background-position-y: bottom;
	background-position-x: -0.1rem;
}

/* Selector de ficheros */
.selector_ficheros_boton {
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: center;
	padding: 0.3rem;
	width: 10rem;
	height: 2.5rem;
	background-color: #127594;
	color: white;
	cursor: pointer;
	font-family: robb;
	font-size: 0.9rem;
	margin-top: 0.2rem;
	margin-bottom: 0.2rem;
}

.selector_ficheros_boton:hover,
.selector_ficheros_contenedor:focus-within .selector_ficheros_boton {
	border: 0.2rem solid #9abac9;
}

.selector_ficheros_contenedor {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.selector_ficheros_contenedor input[type=file] {
	position: relative;
	height: 0;
	width: 0;
	opacity: 0;
}

/* Resalta casillas y círculos cuando hover o puntero */
input[type="checkbox"]:hover:not(:disabled) + label,
input[type="radio"]:hover:not(:disabled) + label {
	color: #127594;
}
input[type="checkbox"]:focus:not(:disabled) + label,
input[type="radio"]:focus:not(:disabled) + label {
	color: #127594;

}

/*input[type="checkbox"]:focus:not(:disabled) + label:before,
input[type="radio"]:focus:not(:disabled) + label:before {
	content: "\25B8";
	position: absolute;
	right: -2.2rem;
}*/


/* Indicadores de campo requerido */
.campo .indicador_campo_requerido,
.indicador_item_requerido {
	color: rgb(158, 31, 71);
	padding-left: 0.1rem;
}
.indicador_item_requerido {
	font-family: robb;
}


/* Textos de ayuda a los campos de formularios */
.campo .texto_ayuda {
	font-size: 0.9rem;
	margin-top: 0.1rem;
	opacity: 0.7;
	/*	color: #127594;
		font-style: italic;*/
}


/* Fieldsets */
fieldset {
	background-color: rgba(0, 0, 0, 0.05);
	border: none;
	padding: 1rem;
}

fieldset.tiene_rotulo {
	padding-top: 3rem;
}