* {
	font-family: 'Open Sans', sans-serif;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-family: 'Open Sans', sans-serif;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	font-size: 62.5%;
	-webkit-font-smoothing: antialiased;
}

body {
	line-height: 1;
	background: #fff;
	font-family: 'Open Sans', sans-serif;
	font-size: 1.5rem;
}

p {
	line-height: 1.5rem;
}

strong {
	font-weight: normal;
	letter-spacing: 0;
}

*:focus {
	outline: none;
}

html, body {
	border: none;
	height: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
}

.vertical-align {
	display: flex;
	align-items: center;
}
.login-image {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	top: 0;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

.login-image-container {
	min-height: 100vh !important;
	position: relative;
}
.app-info-container {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 20;
	color: white;
	padding: 60px;
	background: linear-gradient(to bottom,rgba(0,0,0,0) 0,#000 100%);
}
.app-info-container .app-title {
	font-weight: 700;
	font-size: 36px;
	text-align: left;
	margin-bottom: 20px;
	letter-spacing: .25px;
}
.app-info-container .app-title span.normal {
	font-weight: 100;
}
.app-info-container .app-version {
	color: silver;
	font-weight: 300;
	font-size: 1.3em;
	text-align: left;
	letter-spacing: .25px;
}
.login-container {
	padding: 30px;
}
.login-container .brand {
	font-size: 2em;
	font-weight: 100;
	text-align: left;
	margin-bottom: 30px;
}
.login-container img.keyboard-icon-image {
	width: 15px;
}
.login-container .error {
	background-color: #E2473C;
	padding: 1rem;
	margin: 10px 0 10px 0;
	color: #ffffff;
	text-align: center;
}

.controls input {
	background: linear-gradient(180deg, rgba(58,110,165,1) 0%, rgba(58,110,165,1) 35%, rgba(0,212,255,1) 100%);
	border: 1px solid rgba(0,212,255,1);
	color: white;
	font-size: 1.1em;
	height: 45px;
	width: 100%;
}

a, a:visited {
	color: #348fe2;
}
a:hover {
	color: #2a72b5
}

img {
	border: none;
}

#loginByCode, #loginByUser {
	padding-top: 20px;
	font-size: 1.1em;
	text-align: left;
}

DIV#content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

@media all and (max-width: 720px) {

	table {
		min-width: 300px;
		width: 100%;
	}

	#content {
		padding-left: 10px;
		padding-right: 10px;
	}
}

.hidden {
	display: none;
}
.input-active {
	border-bottom: 4px solid #F2E38F !important
}

input {
	-webkit-transition: all 0.4s ease;
	-moz-transition: all 0.4s ease;
	-o-transition: all 0.4s ease;
	transition: all 0.4s ease;
}
