:root {
    --loading-opacity: 0.85;
    --loading-bar-width:  240px;
    --loading-bar-height:  10px;
    }
#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.4);
	outline: 3px solid var(--color-primary-light);
	outline-offset: 5px;
	border-radius: 10px;
	margin-top: 25px;
	overflow: hidden;
	position: relative;
	-moz-box-shadow: 1px 1px 3px rgba(0,0,0,0.5); 
	-webkit-box-shadow: 1px 1px 3px rgba(0,0,0,0.5); 
	box-shadow: 1px 1px 3px rgba(0,0,0,0.5);
	margin: auto auto 20px auto;
	}

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

@keyframes loading_loop {
  0%,100% {
    transform: translateX(-80px);
  }
  20% {
    transform: translateX(var(--loading-bar-width))
  }
}

.loading-text{
	text-align: center;
	font-size: 1em;
	font-family: var(--font-default);
	margin-top: 30px;
	color: #FFF;
	}