:root {
	--loading-opacity: 0.75;
	--loading-bar-width:  280px;
	--loading-bar-height:  20px;
	}

.cor { color: var(--color); }
.hide { display: none !important; }
#loading{
	pointer-events: none;
	}
#loading.active{
	display: flex;
	align-content: center;
	justify-content: center;
	align-items: center;
	pointer-events: all;
	opacity: 1;
	}
#loading.active > #loading-background{
	position: absolute;
	left: 0px;
	top: 0px;
	right: 0px;
	bottom: 0px;
	background-color: var(--color-primary-dark);
	opacity: var(--loading-opacity);
	z-index: 0;
	}
#loading-stage{
	opacity: 0;
	}
#loading.active > #loading-stage{
	position: relative;
	opacity: 1;
	}
div.loading-bar {
	width: var(--loading-bar-width);
	height: var(--loading-bar-height);
	background-color: rgba(255, 255, 255, 0.6);
	outline: 3px solid var(--color-secondary-light);
	outline-offset: 10px;
	border-radius: 10px;
	border-bottom: solid 1px rgba(255, 255, 255, 0.5);
	border-top: solid 1px rgba(0, 0, 0, 0.5);
	margin-top: 25px;
	overflow: hidden;
	position: relative;
	-moz-box-shadow: 20px 25px 25px rgba(0,0,0,0.3); 
	-webkit-box-shadow: 20px 25px 25px rgba(0,0,0,0.3); 
	box-shadow: 20px 25px 25px rgba(0,0,0,0.3);
	margin: auto auto 20px auto;
	}

div.loading-bar::after {
	content: '';
	width: 120px;
	height: var(--loading-bar-height);
	position: absolute;
	background-color: var(--color-secondary);
	transform: translateX(-20px);
	animation: loading_loop 2000ms ease infinite;
	}

@keyframes loading_loop {
  0%,100% {
	width: 10px;
    transform: translateX(-120px);
  }
  25% {
	width: 120px;
    transform: translateX(var(--loading-bar-width))
  }
}
.loading-text{
	text-align: center;
	font-size: 1em;
	font-family: var(--font-default);
	margin-top: 30px;
	color: #FFF;
	}
.box{
	-moz-border-radius: 25px; 
	-webkit-border-radius: 25px;
	background-color: var(--color-box-transparent-background);
	-moz-box-shadow: 10px 10px 20px rgba(0,0,0,0.2);
	-webkit-box-shadow: 10px 10px 20px rgba(0,0,0,0.2);
	box-shadow: 10px 10px 20px rgba(0,0,0,0.2);
	}