#loading{
	align-items: center;
	display: flex;
	margin: 10px;
	min-height: 100px;
	position: fixed;
	text-align: center;
	width: calc(100% - 20px);
}

@keyframes spinner {
	0% {
		background-position: 0 0, 100% 0, 100% 100%, 0 100%;
		background-size: 0 3px, 3px 0, 0 3px, 3px 0;
	}
	13% { background-size: 100% 3px, 3px 0, 0 3px, 3px 0; }
	25% { background-size: 100% 3px, 3px 100%, 0 3px, 3px 0; }
	37% { background-size: 100% 3px, 3px 100%, 100% 3px, 3px 0; }
	49% { background-position: 0 0, 100% 0, 100% 100%, 0 100%; }
	50% {
		background-position: 100% 0, 100% 100%, 0 100%, 0 0;
		background-size: 100% 3px, 3px 100%, 100% 3px, 3px 100%;
	}
	63% { background-size: 0 3px, 3px 100%, 100% 3px, 3px 100%; }
	75% { background-size: 0 3px, 3px 0, 100% 3px, 3px 100%; }
	87% { background-size: 0 3px, 3px 0, 0 3px, 3px 100%; }
	100% {
		background-position: 100% 0, 100% 100%, 0 100%, 0 0;
		background-size: 0 3px, 3px 0, 0 3px, 3px 0;
	}
}
#loading:after{
	animation-play-state: running;
	animation: spinner 10s linear infinite;
	background-image: linear-gradient(to left, var(--grayLight) 100%, var(--grayLight) 100%), linear-gradient(to bottom, var(--grayLight) 100%, var(--grayLight) 100%), linear-gradient(to right, var(--grayLight) 100%, var(--grayLight) 100%), linear-gradient(to bottom, var(--grayLight) 100%, var(--grayLight) 100%);
	background-position: 0 0, 100% 0, 100% 100%, 0 100%;
	background-repeat: no-repeat;
	content: "";
	height: calc(100% + 6px);
	left: -3px;
	position: absolute;
	top: -3px;
	width: calc(100% + 6px);
} #body.dark #loading:after{ background-image: linear-gradient(to left, var(--grayDark) 100%, var(--grayDark) 100%), linear-gradient(to bottom, var(--grayDark) 100%, var(--grayDark) 100%), linear-gradient(to right, var(--grayDark) 100%, var(--grayDark) 100%), linear-gradient(to bottom, var(--grayDark) 100%, var(--grayDark) 100%); }

#loading .wrap{
	color: var(--grayLight);
	flex: 1;
}  #body.dark #loading .wrap{ color: var(--grayDark); }
#loading .wrap h1{
	font-size: 60px;
	margin: 0px;
}
#loading .wrap .warning{
	display: none;
	font-size: 22px;
	font-style: italic;
	margin: 5px 0 0 0;
}

iframe{
	border: none;
	opacity: 0;
	overflow: hidden;
	width: 100%;
}

#error{
	align-items: center;
	display: none;
	text-align: center;
}
#error .wrap{
	align-self: center;
	flex: 1 1 auto;
	margin: 0px auto;
	max-width: 800px;
	padding: 10px;
	position: relative;
}
#error .wrap svg{
	display: block;
	fill: var(--red);
	height: 100px;
	margin: 0px auto;
	width: 100px;
}
#error .wrap .error{
	color: var(--gray);
	font-size: 14px;
	font-style: italic;
}
#error .refresh{
	color: var(--blue);
	cursor: pointer;
	text-decoration: underline;
}

@media print{
	iframe{ display:none; }
	#print{
		opacity:1;
		display:block !important;
	}
}