:before, :after {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

* {
	margin: 0;
	padding: 0;
	border: 0;
	outline: none;
}

[class*="fi-"] {
	display: inline;
	width: auto;
	height: auto;
	line-height: inherit;
	vertical-align: baseline;
	background-image: none;
	background-position: 0 0;
	background-repeat: repeat;
}

[class*="fi-"]:before {
	font-weight: 400;
	font-style: normal;
	text-decoration: inherit;
}

html {
	height: 100%;
	left: 0;
}

body {
	height: 100%;
	box-sizing: border-box;
	min-height: 100%;
	min-width: 100%;
	position: relative;
	z-index: 1;
	margin: 0;
	padding: 0;
	overflow: hidden;
}

body, .preloader {
	background-color: #111;
}

body > .main-container {
	height: 100%;
	min-height: 100%;
	min-width: 100%;
	transition: all .6s ease-in-out;
	-webkit-transition: all .6s ease-in-out;
	-moz-transition: all .6s ease-in-out;
	-o-transition: all .6s ease-in-out;
	z-index: 0;
	overflow: hidden;
	position: initial !important;
	overflow-y: auto;
}

body > .main-container:after {
	content: "";
	display: block;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background-color: #111;
	opacity: .4;
	z-index: -1;
	position: absolute;
}

.center {
	clear: both;
	content: "";
	display: block;
	margin: 0 auto;
	max-width: 1020px;
	width: 100%;
	padding: 0 10px;
	box-sizing: border-box;
	text-align: center;
}

.logotype {
	max-width: 100%;
}

#wrapper {
	width: 100%;
	height: calc(100% - 90px);
	position: relative;
	display: inline-block;
}

header {
	position: relative;
	display: inline-block;
	width: 100%;
}

.site-content {
	position: relative;
	display: inline-block;
	width: 100%;
	left: 0;
	top: 0;
	color: #fff;
}

.site-content .description p {
	font-size: 14px;
	margin: 0;
	line-height: normal;
}

.site-content .description p {
	margin-bottom: 10px;
}

.site-content p {
	font-size: 16px;
	margin: 0 0 15px;
	line-height: 24px;
}

footer {
	position: relative;
	top: 0;
	display: inline-block;
	width: 100%;
	color: #fff;
	margin: 25px 0 20px;
}

footer .center {
	padding: 0;
}

.logo-box {
	padding: 50px 0 30px;
}

.site-title {
	font-family: inherit;
	font-weight: lighter;
	text-align: center;
	padding: 0 0 20px;
	vertical-align: middle;
}

.preloader {
	display: block;
	height: 100%;
	position: absolute;
	width: 100%;
	z-index: 99999991;
}

.preloader i, .preloader img {
	font-size: 56px;
	background: none repeat scroll 0 0 rgba(0, 0, 0, 0);
	display: inline-block;
	left: 50%;
	top: 50%;
	-ms-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	position: absolute;
	color: inherit;
	-webkit-animation-name: spin;
	-webkit-animation-duration: 2200ms;
	-webkit-animation-iteration-count: infinite;
	-webkit-animation-timing-function: linear;
	-moz-animation-name: spin;
	-moz-animation-duration: 2200ms;
	-moz-animation-iteration-count: infinite;
	-moz-animation-timing-function: linear;
	-ms-animation-name: spin;
	-ms-animation-duration: 2200ms;
	-ms-animation-iteration-count: infinite;
	-ms-animation-timing-function: linear;
	animation-name: spin;
	animation-duration: 2200ms;
	animation-iteration-count: infinite;
	animation-timing-function: linear;
}

.site-title, .preloader i, .login-form, .login-form a.lost-pass, .btn-open-login-form, .site-content, .user-content-wrapper, .user-content, footer, .maintenance a {
	color: #fff;
}

@-ms-keyframes spin {
	from {
		-ms-transform: translate(-50%, -50%) rotate(0deg);
	}
	
	to {
		-ms-transform: translate(-50%, -50%) rotate(360deg);
	}
}

@-moz-keyframes spin {
	from {
		-moz-transform: translate(-50%, -50%) rotate(0deg);
	}
	
	to {
		-moz-transform: translate(-50%, -50%) rotate(360deg);
	}
}

@-webkit-keyframes spin {
	from {
		-webkit-transform: translate(-50%, -50%) rotate(0deg);
	}
	
	to {
		-webkit-transform: translate(-50%, -50%) rotate(360deg);
	}
}

@keyframes spin {
	from {
		transform: translate(-50%, -50%) rotate(0deg);
	}
	
	to {
		transform: translate(-50%, -50%) rotate(360deg);
	}
}

::-webkit-input-placeholder {
	font-size: 20px;
	color: inherit;
	font-family: inherit;
	opacity: 1;
}

:-moz-placeholder {
	font-size: 20px;
	color: inherit;
	font-family: inherit;
	opacity: 1;
}

::-moz-placeholder {
	font-size: 20px;
	color: inherit;
	font-family: inherit;
	opacity: 1;
}

:-ms-input-placeholder {
	font-size: 20px;
	color: inherit;
	font-family: inherit;
	opacity: 1;
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : landscape) {
	.center {
		max-width: 1004px;
	}
}

@media screen and (max-width: 480px) {
	.center {
		max-width: 460px;
	}
}

@media screen and (max-width: 360px) {
	.center {
		max-width: 340px;
	}
}

@media screen and (max-width: 320px) {
	.center {
		max-width: 300px;
	}
}

.bg-img {
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.bg-img img, .bg-img source {
	position: absolute;
	visibility: visible;
	z-index: -1;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: auto;
	height: auto;
	min-width: 100%;
	min-height: 100%;
}

@supports (object-fit: cover) {
	.bg-img img, .bg-img source {
		min-height: 100%;
		min-width: 100%;
		object-fit: cover;
		max-width: 100%;
		max-height: 100%;
	}
}