body.js-loading {
	margin: 0;
	overflow: hidden;
}

body.js-loading:before {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: " ";
	z-index: 999999;
	position: fixed;
	overflow: hidden;
	background: #eee;
}

body.js-loading:after {
	top: 50%;
	left: 50%;
	position: fixed;
	z-index: 1000000;
	overflow: hidden;
	pointer-events: none;
	width: 100px;
	height: 100px;
	margin-top: -50px;
	margin-left: -50px;
	border-radius: 50%;
	border: 5px solid #ccc;
	border-color: #ccc transparent;
	text-align: center;
	-webkit-animation: rotating 2s linear infinite;
	-moz-animation: rotating 2s linear infinite;
	-ms-animation: rotating 2s linear infinite;
	-o-animation: rotating 2s linear infinite;
	animation: rotating 2s linear infinite;
	content: "";
}

@-webkit-keyframes rotating {
	from {
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	to {
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@keyframes rotating {
	from {
		-ms-transform: rotate(0deg);
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	to {
		-ms-transform: rotate(360deg);
		-moz-transform: rotate(360deg);
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}