.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    visibility: hidden;
    line-height: 0;
    height: 0;
}
 
.clearfix {
    display: inline-block;
}

body
{
	background-color: white;
	font-family: "Lucida Sans", "Lucida Grande",lucida sans, arial, sans-serif;
    font-size:12px;
    color:#414142;
    line-height:140%;
}
body.usuario
{
	background-color: #0c629d;
	text-align: center;
}

form {
	text-align: left;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
	background-color: white;
	padding: 15px;
	background:#fff url(/images/redlogos.png) no-repeat  center -25px;
}

form fieldset {
}

form fieldset legend {
	font-family: 'Gudea', sans-serif;
	font-size:16px;
	font-style:italic;
	font-weight:normal;
	line-height:110%;
	border-bottom:1px solid gray;
	padding:25px 0 5px 0;
	margin:10px 0;
	width:99%;
}

form fieldset p
{
	clear: left;
}

form fieldset label {
	display: block;
	float: left;
	margin: 2px;
	font-style: italic;
	text-align: right;
}

form fieldset label.enlinea {
	display: inline;
	float: none;
}

form fieldset label.requerido {
	color:#444;
}

.extralargo {
	width: 320px;
	margin-left:5px;
	padding:4px 5px;
}

.largo {
	width: 220px;
	margin-left:5px;
	padding:4px 5px;
}

.mediano {
	width: 120px;
	margin-left:5px;
	padding:4px 5px;
}

.corto {
	width: 60px;
	margin-left:5px;
	padding:4px 5px;
}

/*    */

h1{
	font-family: 'Gudea', sans-serif;
	font-size:22px;
	/*font-style:italic;*/
	font-weight:normal;
	line-height:110%;
	border-bottom:1px solid #ddd;
	margin:10px 0;
	padding:10px 0;
	text-transform:uppercase;
}

form fieldset label {
	font-family: 'Gudea', sans-serif;
	font-size:16px;
	color:#24394a;
}

form input, select{
	border:1px solid gray;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	padding:4px;
}


.boton{
	background:#2189d0;
	font-family: 'Gudea', sans-serif;
	color:#fff;
	text-transform:uppercase;
	font-size:14px;
	padding:3px 18px;
	margin:25px 0;
	width:200px;
	cursor: pointer;
	border: 2px solid #2189d0;
}
.boton:hover{
	color:#fff;
	border: 2px solid #04416B;
}

p{
	padding:2px;
}

.error {
	border-color: red;
}

#error {
	position: absolute;
	display: none;
	width: 100px;
	z-index: 1000;
	background-image: url(/skin/default/img/error-arrow.png);
	background-position: center top;
	background-repeat: no-repeat;
}

#error #mensaje {
	display: block;
	background-color: black;
	color: white;
	margin-top: 5px;
	padding: 5px;
	border-bottom: 1px solid white;
	border-left: 1px solid white;
	border-right: 1px solid white;
}

.popup {
	min-width: inherit;
	overflow:hidden;
}

.popup h2{
	background:#0b619b url(/skin/default/img/bg-top-azul.jpg);
	padding:20px;
	text-transform:uppercase;
	font-size:15px;
	color:#fff;
	font-weight:normal;
	margin: 0 0 4px 0;
}

.popup form{
	background:#eee;
	padding: 10px;
	margin-top: 5px;
}

.popup label{
	width:120px;
	text-align:right;
	clear:left;
	padding:5px;
	display:block;
	float:left;
	margin-top:6px;
}

.popup label.enlinea {
	display: inline;
	float: none;
	width: inherit;
}

.popup input{
	width:230px;
	padding:9px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.popup input.enlinea {
	width: inherit;
}

.popup input.enviar, .popup .enviar{
	background:#0a76bf;
	width:230px;
	margin: 5px auto;
	text-transform:uppercase;
	font-size:13px;
	color:#fff;
	padding:8px;
	cursor:pointer;
	display:block;
	text-align:center;
	margin-left:90px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;

}

.popup .enviar{
	margin-left:110px;
	padding:6px;
}
	

.popup span {
	padding:10px 20px;
	display:block;
	
}

.popup h3{
	background:#eee;
	padding:8px 20px;
	font-size:13px;
	margin:10px 0 0 0;
}
.logos-red{
	width:440px;
	padding:5px 0;
}

.errors {
	color: red;
	font-weight: bold;
}

.errors ul {
	list-style: disc;
	padding-left: 30px;
}

.messages {
	color: green;
	font-weight: bold;
}

.messages ul {
	list-style: disc;
	padding-left: 30px;
}

/* Registro */
#etapas {
	margin-top: 2px;
	width: 100%;
}

#etapas ul {
	width: 100%;
}

#etapas ul > li {
	display: block;
	float: left;
	width: 20%;
	height: 70px;
	background-color: #f3f3f5;
	background-image: url(../images/reg-etapas.png);
	background-repeat: no-repeat;
	background-position: center right;
	color:#838385;
}

#etapas ul > li.actual {
	background-color: #0b619b;
	color:#ffffff;
}

#etapas ul > li.anterior {
	background-image: url(../images/reg-etapas-anterior.png);
	background-color: #0b619b;
	color:#ffffff;
}

#etapas span {
	margin-left: 10px;
	margin-right: 10px;
	padding: inherit;
}

#etapas span.titulo {
	margin-top: 10px;
	font-size: 12px;
	font-weight: bold;
}

#etapas span.desc {
	font-size: 11px;
	font-weight: normal;
	margin-bottom: 10px;
}

form p { margin: auto 10px; }
form legend { margin: 20px 10px 10px 10px; float: left; }


/*
.popup span {
	padding: 5px;
	display: inline;
}
.popup form {
	padding: 5px;
	margin: 0;
}
*/

@media screen and (max-width: 768px) {
	h1 {
		padding: auto 20px;
	}

	form p { margin: auto 0; }
	form legend { margin: 20px 0 10px 0; float: left; }

	.form-group {
		padding: 0 0 !important;
	}

	.logos-red{
		width:100%;
	}

	.g-recaptcha {
		overflow: hidden;
	}

	.g-recaptcha div, .g-recaptcha div iframe {
		
	}

	.g-recaptcha div iframe .rc-anchor-normal-footer {
		display: none !important;
	}
}