
@font-face {
    font-family: 'Noto Sans';
    src: url('xf_/noto-sans.ttf') format('truetype');
	font-display: block;
}

* { font-family: 'Noto Sans'; font-size: 0.8cm; }

html { font-size: 0.7cm; }
html, body { width: 100%; height: 100%; margin: 0px; padding: 0px; overflow: hidden; background-color: #FEFEFE; position: relative; }

table[xf-app-loading-screen] {
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	position: fixed;
	top: 0px;
	right: 0px;
	bottom: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	opacity: 1;
	z-index: 999999999;
	-webkit-transition: all 0.1s;
    transition: all 0.1s;
	-webkit-transform: translateZ(0px);
    transform: translateZ(0px);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
table[xf-app-loading-screen] td { text-align: center; }
table[xf-app-loading-screen].loaderA { opacity: 0; }
table[xf-app-loading-screen].loaderB { opacity: 1; }

table[xf-app-loading-screen] td > div:nth-child(1) {
	background-color: transparent;
	border: 0.2rem rgba(255, 255, 255, 0.05) solid;
	border-top: 0.2rem #ffffff solid;
	border-radius: 50%;
	display: inline-block;
	width: 2rem;
	height: 2rem;
	-webkit-animation: loader-spin 0.8s linear infinite;
	animation: loader-spin 0.8s linear infinite;
}

table[xf-app-loading-screen] td > div:nth-child(2) {
    font-size: 0.4rem;
    color: #ffffff;
    padding-top: 0.5rem;
}

@-webkit-keyframes loader-spin { 0% { -webkit-transform: rotate(0deg); } 100% { -webkit-transform: rotate(360deg); } }
@keyframes loader-spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

table[xf-app-loading-screen=ripple] td > div:nth-child(1) > div { display: none; }

table[xf-app-loading-screen=ripple] td > div:nth-child(1) {
	background-color: transparent;
	border: none;
	border-radius: 0px;
	display: inline-block;
	position: relative;
	width: 3rem;
	height: 3rem;
	-webkit-animation: none;
	animation: none;
}

table[xf-app-loading-screen=ripple] td > div:nth-child(1) > div {
	position: absolute;
	border: 0.15rem solid #ffffff;
	opacity: 1;
	border-radius: 50%;
	display: block;
	-webkit-animation: loader-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
	animation: loader-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
}

table[xf-app-loading-screen=ripple] td > div:nth-child(1) > div:nth-child(2) { -webkit-animation-delay: -0.5s; }

@-webkit-keyframes loader-ripple {
	0% { top: 1.3rem; left: 1.3rem; width: 0; height: 0; opacity: 1; }
	100% { top: -1px; left: -1px; width: 2.7rem; height: 2.7rem; opacity: 0; }
}

@keyframes loader-ripple {
	0% { top: 1.3rem; left: 1.3rem; width: 0; height: 0; opacity: 1; }
	100% { top: -1px; left: -1px; width: 2.7rem; height: 2.7rem; opacity: 0; }
}


table[xf-app-loading-screen=cubes] td > div:nth-child(1) {
	background-color: transparent;
	border: none;
	border-radius: 0px;
	width: 2.7rem;
	height: 2.7rem;
	position: relative;
	margin: auto;
	-webkit-animation: none;
	animation: none;
}

table[xf-app-loading-screen=cubes] td > div:nth-child(1) > div {
	background-color: #ffffff;
	width: 0.7rem;
	height: 0.7rem;
	position: absolute;
	top: 0px;
	left: 0px;
	display: block;
	-webkit-animation: loader-cubes 1.8s infinite ease-in-out;
	animation: loader-cubes 1.8s infinite ease-in-out;
}

table[xf-app-loading-screen=cubes] td > div:nth-child(1) > div:nth-child(2) {  -webkit-animation-delay: -0.9s; animation-delay: -0.9s; }

@-webkit-keyframes loader-cubes {
  25% { -webkit-transform: translateX(1.96rem) rotate(-90deg) scale(0.5) }
  50% { -webkit-transform: translateX(1.96rem) translateY(1.96rem) rotate(-180deg) }
  75% { -webkit-transform: translateX(0px) translateY(1.96rem) rotate(-270deg) scale(0.5) }
  100% { -webkit-transform: rotate(-360deg) }
}

@keyframes loader-cubes {
  25% { transform: translateX(1.96rem) rotate(-90deg) scale(0.5); -webkit-transform: translateX(1.96rem) rotate(-90deg) scale(0.5); }
  50% { transform: translateX(1.96rem) translateY(1.96rem) rotate(-179deg); -webkit-transform: translateX(1.96rem) translateY(1.96rem) rotate(-179deg); }
  50.1% { transform: translateX(1.96rem) translateY(1.96rem) rotate(-180deg); -webkit-transform: translateX(1.96rem) translateY(1.96rem) rotate(-180deg); }
  75% { transform: translateX(0px) translateY(1.96rem) rotate(-270deg) scale(0.5); -webkit-transform: translateX(0px) translateY(1.96rem) rotate(-270deg) scale(0.5); }
  100% { transform: rotate(-360deg); -webkit-transform: rotate(-360deg); }
}

