body {
	margin: 0;
	min-width: 550px;	
	font-family: "Calibri Regular", sans-serif;			
}		

div.body {
	display: flex;			
	flex-direction: column;
	height: 100vh;	
}

#mainPane {
	display: flex;
	flex: 1 0 auto;
}

main {
	display: block;
	flex: 1 0 auto;
	width: 70%;
}

aside {
	order: -1;
	flex: 0 0 30%;
	background-image: url(../images/pillars.jpg);
	background-size: cover;	
}

header, footer {
	display: block;
	background: #19679e;	
	color: #fff;		
}

header {			
	height: 24px;			
	padding: 10px 14px;
}		

.logo {
	float: left;
}	

.logo-text {
	font-size: 12px;
	letter-spacing: 2px;
	padding: 5px 0 5px 20px;
}	

.product-name {
	float: left;
	border-left: solid 1px #75a4c5;
	margin-left: 20px;			
}

@font-face {
	font-family: "Fira Sans";
	src: url('FiraSans-LightItalic.otf');
}

.division-name {			
	float: right;
	font-family: "Fira Sans", "Calibri Regular", sans-serif;
	font-style: italic;	
	font-size: 13px;
}

#mainPane {
	background: #d5d5d5;			
}

#mainPane .login-fields {
	padding: 140px 0 0 30px;
	height: 180px;
	background-color: #42a3d8;
	position: relative;
}

.alert, .validations {
	position: absolute;
	top: 182px;
	left: 30px;
	background: #fff url(../images/warning.svg) 7px 3px/25px 25px no-repeat;
	padding: 10px 20px 10px 40px;
	font-size: 13px;
	min-width: 238px;
	margin-right: 30px;
}

.change-password-alerts .alert {
	top: 227px;
}

.validations {
	top: 380px;	
	min-width: 100px;
}

.validations span {
	display: block;
	padding-bottom: 4px;	
}

.alert-error, .validations span.error {
	color: #333;
}

.alert-info {
	background-image: url(../images/info.svg);
	color: #333;
}

input {
	display: block;
	margin-bottom: 24px;
	width: 250px;
	padding: 8px 8px 8px 30px;
	border: none;
}

input:focus {
	outline: none;
}

input::-webkit-input-placeholder {
	font-style: italic;
	color: #939598;
}

#username {
	background: #fff url(../images/user.svg) 8px 7px/15px 15px no-repeat;			
}

input[type=password] {
	background: #fff url(../images/security.svg) 8px 7px/15px 15px no-repeat;
}

.forgot,.forgotUserName,.forgotPassword {
	color: #fff;
	opacity: .85;
	font-size: 13px;
	text-decoration:none;
}
 .forgotUserName:hover,.forgotPassword:hover {
	text-decoration:underline;
	opacity: 1;
}

.warning {
	max-width: 550px;
	font-size: 13px;
	padding: 40px 30px 0 0;
}

.buttons {
	background: #80c342;
}

button {
	background: url(../images/chevron_right.svg) 185px 17px/25px 25px no-repeat;
	color: #fff;
	width: 100%;
	border: none;
	height: 60px;
	text-align: left;
	font-size: 26px;
	cursor: pointer;
	padding-left: 30px;
	opacity: .85;
} 	

.change-password-button {
	width: calc(100% - 150px);
}	

.cancel-button {
	background-image: none;
	width: 150px;
	float: right;
	opacity: .6;
}

button:hover {
	opacity: 1;
}

#topTransparentArea {
	background: rgba(66, 163, 216, 0.6);
	height: 320px;
}

#loginTransparentArea {
	 background: rgba(128, 195, 66, 0.6);
	 height: 60px;
}

#messageArea {
	padding: 15px 50px;
	font-size: 12px; 
	margin: 28px 20px;
	max-width: 400px;
	background: url(../images/exclamation.svg) 0 center/45px 45px no-repeat;
}

footer div {
	font-size: 12px;
	float: left;			
}

#poweredBy {
	font-style: italic;
	float: left;
	padding: 10px 30px 0 10px;
}

#copyright {
	padding: 10px 0 30px 10px;
}

div.logo img {
	margin-top: -8px;
	width: 145px !important;
}