.loading {
	position: fixed;
	z-index: 9999;
	height: 2em;
	width: 2em;
	overflow: show;
	margin: auto;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}

.loading:before {
	content: '';
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(rgba(20, 20, 20, .8), rgba(0, 0, 0, .8));

	background: -webkit-radial-gradient(rgba(20, 20, 20, .8), rgba(0, 0, 0, .8));
}

.loading:not(:required) {
	/* hide "loading..." text */
	font: 0/0 a;
	color: transparent;
	text-shadow: none;
	background-color: transparent;
	border: 0;
}

.loading:not(:required):after {
	content: '';
	display: block;
	font-size: 10px;
	width: 1em;
	height: 1em;
	margin-top: -0.5em;
	background: url('/img/OlabLoader.gif');
}


.loader {
	position: fixed;
	width: 100%;
	height: 100vh;
	background: #21242d91 center;
	z-index: 999;
}

.loader .dot {
	-webkit-animation-name: movement;
	animation-name: movement;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease-in-out;
	animation-timing-function: ease-in-out;
	height: 1rem;
	position: absolute;
	top: 50%;
	transform: translate3d(0, -25px, 0) scale(1);
	width: 1rem;
}

.loader .dot:nth-of-type(1) {
	-webkit-animation-delay: -0.1s;
	animation-delay: -0.1s;
	left: 64%;
}

.loader .dot:nth-of-type(1)::before {
	-webkit-animation-delay: -0.1s;
	animation-delay: -0.1s;
}

.loader .dot:nth-of-type(2) {
	-webkit-animation-delay: -1.2s;
	animation-delay: -1.2s;
	left: 64%;
}

.loader .dot:nth-of-type(2)::before {
	-webkit-animation-delay: -1.2s;
	animation-delay: -1.2s;
}

.loader .dot:nth-of-type(3) {
	-webkit-animation-delay: -0.3s;
	animation-delay: -0.3s;
	left: 62%;
}

.loader .dot:nth-of-type(3)::before {
	-webkit-animation-delay: -0.3s;
	animation-delay: -0.3s;
}

.loader .dot:nth-of-type(4) {
	-webkit-animation-delay: -1.4s;
	animation-delay: -1.4s;
	left: 62%;
}

.loader .dot:nth-of-type(4)::before {
	-webkit-animation-delay: -1.4s;
	animation-delay: -1.4s;
}

.loader .dot:nth-of-type(5) {
	-webkit-animation-delay: -0.5s;
	animation-delay: -0.5s;
	left: 60%;
}

.loader .dot:nth-of-type(5)::before {
	-webkit-animation-delay: -0.5s;
	animation-delay: -0.5s;
}

.loader .dot:nth-of-type(6) {
	-webkit-animation-delay: -1.6s;
	animation-delay: -1.6s;
	left: 60%;
}

.loader .dot:nth-of-type(6)::before {
	-webkit-animation-delay: -1.6s;
	animation-delay: -1.6s;
}

.loader .dot:nth-of-type(7) {
	-webkit-animation-delay: -0.7s;
	animation-delay: -0.7s;
	left: 58%;
}

.loader .dot:nth-of-type(7)::before {
	-webkit-animation-delay: -0.7s;
	animation-delay: -0.7s;
}

.loader .dot:nth-of-type(8) {
	-webkit-animation-delay: -1.8s;
	animation-delay: -1.8s;
	left: 58%;
}

.loader .dot:nth-of-type(8)::before {
	-webkit-animation-delay: -1.8s;
	animation-delay: -1.8s;
}

.loader .dot:nth-of-type(9) {
	-webkit-animation-delay: -0.9s;
	animation-delay: -0.9s;
	left: 56%;
}

.loader .dot:nth-of-type(9)::before {
	-webkit-animation-delay: -0.9s;
	animation-delay: -0.9s;
}

.loader .dot:nth-of-type(10) {
	-webkit-animation-delay: -2s;
	animation-delay: -2s;
	left: 56%;
}

.loader .dot:nth-of-type(10)::before {
	-webkit-animation-delay: -2s;
	animation-delay: -2s;
}

.loader .dot:nth-of-type(11) {
	-webkit-animation-delay: -1.1s;
	animation-delay: -1.1s;
	left: 54%;
}

.loader .dot:nth-of-type(11)::before {
	-webkit-animation-delay: -1.1s;
	animation-delay: -1.1s;
}

.loader .dot:nth-of-type(12) {
	-webkit-animation-delay: -2.2s;
	animation-delay: -2.2s;
	left: 54%;
}

.loader .dot:nth-of-type(12)::before {
	-webkit-animation-delay: -2.2s;
	animation-delay: -2.2s;
}

.loader .dot:nth-of-type(13) {
	-webkit-animation-delay: -1.3s;
	animation-delay: -1.3s;
	left: 52%;
}

.loader .dot:nth-of-type(13)::before {
	-webkit-animation-delay: -1.3s;
	animation-delay: -1.3s;
}

.loader .dot:nth-of-type(14) {
	-webkit-animation-delay: -2.4s;
	animation-delay: -2.4s;
	left: 52%;
}

.loader .dot:nth-of-type(14)::before {
	-webkit-animation-delay: -2.4s;
	animation-delay: -2.4s;
}

.loader .dot:nth-of-type(15) {
	-webkit-animation-delay: -1.5s;
	animation-delay: -1.5s;
	left: 50%;
}

.loader .dot:nth-of-type(15)::before {
	-webkit-animation-delay: -1.5s;
	animation-delay: -1.5s;
}

.loader .dot:nth-of-type(16) {
	-webkit-animation-delay: -2.6s;
	animation-delay: -2.6s;
	left: 50%;
}

.loader .dot:nth-of-type(16)::before {
	-webkit-animation-delay: -2.6s;
	animation-delay: -2.6s;
}

.loader .dot:nth-of-type(17) {
	-webkit-animation-delay: -1.7s;
	animation-delay: -1.7s;
	left: 48%;
}

.loader .dot:nth-of-type(17)::before {
	-webkit-animation-delay: -1.7s;
	animation-delay: -1.7s;
}

.loader .dot:nth-of-type(18) {
	-webkit-animation-delay: -2.8s;
	animation-delay: -2.8s;
	left: 48%;
}

.loader .dot:nth-of-type(18)::before {
	-webkit-animation-delay: -2.8s;
	animation-delay: -2.8s;
}

.loader .dot:nth-of-type(19) {
	-webkit-animation-delay: -1.9s;
	animation-delay: -1.9s;
	left: 46%;
}

.loader .dot:nth-of-type(19)::before {
	-webkit-animation-delay: -1.9s;
	animation-delay: -1.9s;
}

.loader .dot:nth-of-type(20) {
	-webkit-animation-delay: -3s;
	animation-delay: -3s;
	left: 46%;
}

.loader .dot:nth-of-type(20)::before {
	-webkit-animation-delay: -3s;
	animation-delay: -3s;
}

.loader .dot:nth-of-type(21) {
	-webkit-animation-delay: -2.1s;
	animation-delay: -2.1s;
	left: 44%;
}

.loader .dot:nth-of-type(21)::before {
	-webkit-animation-delay: -2.1s;
	animation-delay: -2.1s;
}

.loader .dot:nth-of-type(22) {
	-webkit-animation-delay: -3.2s;
	animation-delay: -3.2s;
	left: 44%;
}

.loader .dot:nth-of-type(22)::before {
	-webkit-animation-delay: -3.2s;
	animation-delay: -3.2s;
}

.loader .dot:nth-of-type(23) {
	-webkit-animation-delay: -2.3s;
	animation-delay: -2.3s;
	left: 42%;
}

.loader .dot:nth-of-type(23)::before {
	-webkit-animation-delay: -2.3s;
	animation-delay: -2.3s;
}

.loader .dot:nth-of-type(24) {
	-webkit-animation-delay: -3.4s;
	animation-delay: -3.4s;
	left: 42%;
}

.loader .dot:nth-of-type(24)::before {
	-webkit-animation-delay: -3.4s;
	animation-delay: -3.4s;
}

.loader .dot:nth-of-type(25) {
	-webkit-animation-delay: -2.5s;
	animation-delay: -2.5s;
	left: 41%;
}

.loader .dot:nth-of-type(25)::before {
	-webkit-animation-delay: -2.5s;
	animation-delay: -2.5s;
}

.loader .dot:nth-of-type(26) {
	-webkit-animation-delay: -3.6s;
	animation-delay: -3.6s;
	left: 41%;
}

.loader .dot:nth-of-type(26)::before {
	-webkit-animation-delay: -3.6s;
	animation-delay: -3.6s;
}

.loader .dot.Olab::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #d7282f;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Olab:nth-of-type(even)::before {
	background-color: #f18a00;
	box-shadow: inset 0 0 4px #ff4d00;
}

.loader .dot.Azteca::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #005cb9;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Azteca:nth-of-type(even)::before {
	background-color: #f5a800;
	box-shadow: inset 0 0 4px #f5a800;
}

.loader .dot.Jenner::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #0071ce;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Jenner:nth-of-type(even)::before {
	background-color: #df1683;
	box-shadow: inset 0 0 4px #df1683;
}

.loader .dot.Swiss::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #194f9e;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Swiss:nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.FamilyLabs::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.FamilyLabs:nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Liacsa::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Liacsa:nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Polab::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Polab:nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Moreira::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Moreira:nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Exakta::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #007853;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Exakta:nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Asesores ::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Asesores :nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Lister ::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Lister :nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Biomedica ::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #F2A0A7;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Biomedica :nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}

.loader .dot.Promedic ::before {
	-webkit-animation-name: size-opacity;
	animation-name: size-opacity;
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: ease;
	animation-timing-function: ease;
	background: #009D4F;
	border-radius: 50%;
	content: "";
	display: block;
	height: 100%;
	width: 100%;
}

.loader .dot.Promedic :nth-of-type(even)::before {
	background-color: #98989a;
	box-shadow: inset 0 0 4px #98989a;
}
@-webkit-keyframes movement {
	0% {
		transform: translate3d(0, -25px, 0);
		z-index: 0;
	}

	50% {
		transform: translate3d(0, 25px, 0);
		z-index: 10;
	}

	100% {
		transform: translate3d(0, -25px, 0);
		z-index: -5;
	}
}

@keyframes movement {
	0% {
		transform: translate3d(0, -25px, 0);
		z-index: 0;
	}

	50% {
		transform: translate3d(0, 25px, 0);
		z-index: 10;
	}

	100% {
		transform: translate3d(0, -25px, 0);
		z-index: -5;
	}
}

@-webkit-keyframes size-opacity {
	0% {
		opacity: 1;
		transform: scale(1);
	}

	25% {
		transform: scale(1.5);
	}

	50% {
		opacity: 1;
	}

	75% {
		opacity: 0.35;
		transform: scale(0.5);
	}

	100% {
		opacity: 1;
		transform: scale(1);
	}
}

@keyframes size-opacity {
	0% {
		opacity: 1;
		transform: scale(1);
	}

	25% {
		transform: scale(1.5);
	}

	50% {
		opacity: 1;
	}

	75% {
		opacity: 0.35;
		transform: scale(0.5);
	}

	100% {
		opacity: 1;
		transform: scale(1);
	}
}