/* creado el 20/08/2014 */
/* actualizado el 25/02/2016 */

@import "reset.css";

* {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
}
html, body {
	height: 100%;
}
body {
	font-family: Arial,Helvetica,sans-serif;
	color: #58585a;
	background-color: #fff;
	line-height: normal;
}
a {
	color: #f08800;
	text-decoration: none;
}
a:hover {
	color: #000;
}
.container {
	position: relative;
	width: 100%;
	min-height: 100%;
	overflow: auto;
	padding-bottom: 20px;
}
.notFound {
	background: #14bce5 url(../imagenes/error02a.jpg) repeat-x 0 0;
}
.maintenance {
	background: transparent url(../imagenes/error03.jpg) no-repeat center 0;
}
.panel {
	position: relative;
	width: 70%;
	max-width: 800px;
	margin: 0 auto;
	padding-top: 50px;
}
.systemError .panel {
	background: transparent url(../imagenes/error01.png) no-repeat center 50px;
}
.notFound .panel {
	background: transparent url(../imagenes/error02b.png) no-repeat center 140px;
	width: 100%;
	max-width: 1800px;
	min-height: 808px;
}
.noAccess .panel {
	margin-top: calc((100vh - 550px) / 2);
	padding: 0;
	background: transparent url(../imagenes/logo01.png) no-repeat center 90px;
}
.message01, .message02, .message03 {
	position: relative;
	text-align: center;
	padding: 0 30px;
}
.message01 {
	font-size: 3.2em;
}
.systemError .message01 {
	padding-top: 360px;
}
.notFound .message01 {
	padding-top: 30px;
}
.maintenance .message01 {
	padding-top: 400px;
}
.systemError .message02, .maintenance .message02 {
	padding-top: 5px;
	font-size: 1.4em;
}
.notFound .message02 {
	padding-top: 380px;
	font-size: 1.5em;
	color: #005195;
}
.systemError .message03 {
	padding-top: 15px;
	font-size: 1.6em;
}
.notFound .message03 {
	padding-top: 15px;
	font-size: 1.4em;
	color: #005195;
}
.noAccess .message03 {
	padding-top: 450px;
	font-size: 1.6em;
}
.message03 a, .message03 a span  {
	display: inline-block;
	font-weight: bold;
	cursor: pointer;
}
.message03 > a, .message03 > span {
	vertical-align: middle;
	display: inline-block;
}
.notFound .message03 a, .notFound .message03 span {
	font-style: italic;
}
.message03 a span.icon {
	position: relative;
	float: right;
	width: 24px;
	height: 24px;
	margin-top: 5px;
}
.notFound .message03 a span.icon {
	margin-top: 2px;
}
.systemError .message03 a.buttonGo span.icon, .buttonGo span.icon {
	background: transparent url(../imagenes/iconos4.png) no-repeat left 0;
	*display: none; /* IE7*/
}
.systemError .message03 a.buttonGo:hover span.icon {
	background: transparent url(../imagenes/iconos4.png) no-repeat -28px 0;
}
.notFound .message03 a.buttonGo span.icon {
	background: transparent url(../imagenes/iconos4.png) no-repeat left -28px;
	*display: none; /* IE7 */
}
.notFound .message03 a.buttonGo:hover span.icon {
	background: transparent url(../imagenes/iconos4.png) no-repeat -28px -28px;
}
.message03 a span.icon img {
	width: 24px;
	height: 24px;
}
.noAccess .line, .noAccess .shadow {
	position: absolute;
	top: 45%;
	left: -5%;
	width: 110%;
	height: 100px;
}
.noAccess .line {
	background: #FFED00 url(../imagenes/403_bg.png) repeat-x center 0;
	z-index: 1\9; /* IE8 */
}
.noAccess .line:nth-child(1) {
	transform: rotate(-10deg);
	z-index: 1;
}
.noAccess .line:nth-child(2) {
	transform: rotate(10deg);
	z-index: 2;
}
.noAccess .shadow {
	z-index: 1;
	background-color: transparent;
	transform: rotate(-10deg);
	overflow: hidden;
}
.noAccess .shadow:after {
	content: '';
	position: relative;
	display: block;
	top: -10px;
	width: 800px;
	height: 130px;
	margin: 0 auto;
	transform: rotate(20deg);
	background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.5) 30%, rgba(0,0,0,0.5) 70%, rgba(0,0,0,0) 100%);
	background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.5) 30%, rgba(0,0,0,0.5) 70%, rgba(0,0,0,0) 100%);
	background: -o-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.5) 30%, rgba(0,0,0,0.5) 70%, rgba(0,0,0,0) 100%);
	background: linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.5) 30%, rgba(0,0,0,0.5) 70%, rgba(0,0,0,0) 100%);
}
@media screen and (max-width: 1060px) {
	.panel {
		width: 100%;
	}	
}
@media screen and (max-width: 860px) {
	.notFound {
		background-position: 0 -10px;
		background-size: 75px auto;
	}
	.notFound .panel {
		padding-top: 0;
		background-position: center 100px;
		background-size: 1400px auto;
	}
	.notFound .message01 {
		font-size: 2.7em;
	}
	.notFound .message02 {
		padding-top: 300px;
		font-size: 1.4em;	
	}
	.notFound .message03 {
		font-size: 1.3em;
	}
	.notFound .message03 a span.icon, .notFound .message03 a span.icon img {
		width: 16px;
		height: 16px;
	}
	.notFound .message03 a.buttonGo span.icon {
		background: transparent url(../imagenes/iconos4.png) no-repeat -4px -60px;
		*display: none; /* IE7*/
		margin-top: 4px;
	}
	.notFound .message03 a.buttonGo:hover span.icon {
		background: transparent url(../imagenes/iconos4.png) no-repeat -32px -60px;
	}
}
@media screen and (max-width: 780px) {
	.noAccess .message01 {
		font-size: 2.4em;
		line-height: 1em;
	}
	.noAccess .message03 {
		font-size: 1.2em;
	}
	.noAccess .message03 a span.icon {
		margin-top: 4px;
	}
	.noAccess .message03 a span.icon, .noAccess .message03 a span.icon img {
		width: 16px;
		height: 16px;
	}
	.noAccess .message03 a.buttonGo span.icon {
		background: transparent url(../imagenes/iconos4.png) no-repeat -4px -60px;
		*display: none; /* IE7*/
	}
	.noAccess .message03 a.buttonGo:hover span.icon {
		background: transparent url(../imagenes/iconos4.png) no-repeat -32px -60px;
	}
}
@media screen and (max-width: 720px) {
	.maintenance {
		background-size: 560px auto;
	}
	.maintenance .message01 {
		font-size: 2.4em;
		padding-top: 340px;
	}
	.noAccess .message01 {
		font-size: 2.4em;
	}
}
@media screen and (max-width: 640px) {
	.systemError .panel {
		background-size: 400px auto;
	}
	.notFound {
		background-position: 0 -30px;
	}
	.notFound .panel {
		background-position: center 80px;
	}
	.systemError .message01 {
		font-size: 2em;
		padding-top: 280px;
	}
	.systemError .message02 {
		font-size: 1em;
	}
	.systemError .message03 {
		font-size: 1.2em;
		line-height: 1.2em;
	}
	.notFound .message01 {
		font-size: 2em;
		padding: 30px 10px 0;
	}
	.notFound .message02 {
		padding: 300px 10px 0;
		font-size: 1.3em;	
	}
	.notFound .message03 {
		font-size: 1.2em;
		padding: 10px 10px 0;
	}
	.message03 a span.icon {
		margin-top: 4px;
	}
	.message03 a span.icon, .message03 a span.icon img {
		width: 16px;
		height: 16px;
	}
	.systemError .message03 a.buttonGo span.icon {
		background: transparent url(../imagenes/iconos4.png) no-repeat -4px -60px;
		*display: none; /* IE7*/
	}
	.systemError .message03 a.buttonGo:hover span.icon {
		background: transparent url(../imagenes/iconos4.png) no-repeat -32px -60px;
	}
	.notFound .message03 a.buttonGo span.icon {
		margin-top: 3px;
	}
}
@media screen and (max-width: 540px) {
	.maintenance {
		background-size: 380px auto;
	}
	.maintenance .message01 {
		font-size: 1.4em;
		padding-top: 220px;
	}
	.maintenance .message02 {
		font-size: 0.9em;
	}
}
@media screen and (max-width: 480px) {
	.systemError .panel {
		background-size: 300px auto;
	}
	.notFound {
		background-position: 0 -10px;
		background-size: 54px auto;
	}
	.notFound .panel {
		background-position: center 70px;
		background-size: 1000px auto;
	}
	.message01, .message02, .message03 {
		padding: 0 10px;
	}
	.systemError .message01 {
		padding-top: 220px;
		font-size: 1.4em;
	}
	.systemError .message02 {
		font-size: 0.9em;
	}
	.systemError .message03 {
		font-size: 1em;
		line-height: 1.1em;
	}
	.notFound .message01 {
		font-size: 1.3em;
		padding: 25px 10px 0;
	}
	.notFound .message02 {
		font-size: 0.9em;
		padding-top: 220px;
	}
	.notFound .message03 {
		font-size: 0.9em;
		line-height: 1.2em;
	}
	.message03 a span.icon {
		margin-top: 1px;
	}
	.notFound .message03 a.buttonGo span.icon {
		margin-top: 0;
	}
}
@media screen and (max-width: 320px) {
	.systemError .panel {
		background-size: 240px auto;
	}
	.systemError .message01 {
		padding-top: 180px;
	}
	.maintenance {
		background-size: 270px auto;
	}
	.maintenance .message01 {
		padding-top: 140px;
	}	
}