/**********************
* GLOBAL STYLES
**********************/
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { 
	display: block; 
}

audio, canvas, video {
	display: inline-block; 
	*display: inline; *zoom: 1; 
}
audio:not([controls]) { 
	display: none; 
}
[hidden] { 
	display: none; 
}

html { 
	font-size: 100%; 
	-webkit-text-size-adjust: 100%; 
	-ms-text-size-adjust: 100%; 
	height:100%;
	box-sizing: border-box;
}
html, button, input, select, textarea { 
	font-family: 'Roboto', sans-serif;
	font-weight: 400;
	color: #363636;
}
body { 
    font-family: 'Roboto', sans-serif;
	margin: 0; 
	font-size: 1em;
	line-height: 1.4;
}

::-moz-selection { 
	background: #85dfd8;
	text-shadow: none;
}
::selection { 
	background: #85dfd8;
	text-shadow: none;
}

a { 
	color: #00e; 
}
a:visited { 
	color: #551a8b; 
}
a:hover { 
	color: #06e; 
}
a:focus { 
	outline: thin dotted; 
}
a:hover, a:active { 
	outline: 0; 
}
abbr[title], dfn[title] { 
	border-bottom: 1px dotted #cacaca; 
	cursor: help; 
}
b, strong { 
	font-weight: bold; 
}
blockquote { 
	margin: 1em 40px; 
}
dfn { 
	font-style: italic; 
}
hr { 
	display: block; 
	height: 1px; 
	border: 0; 
	border-top: 1px solid #069; 
	margin: 1em 0; 
	padding: 0;
}
ins { 
	background: #ff9; 
	color: #000; 
	text-decoration: none;
}
mark { 
	background: #ff0; 
	color: #000; 
	font-style: italic; 
	font-weight: bold; 
}
pre, code, kbd, samp { 
	font-family: monospace, serif; _font-family: 'courier new', monospace; 
	font-size: 1em; 
}
code { 
	padding: 1px 4px; 
	font-size: 90%; 
	color: #D14; 
	background-color: #F7F7F9; 
	border: 1px solid #E1E1E8; 
	border-radius: 3px; 
	-webkit-border-radius: 3px; 
}
pre { 
	white-space: pre; 
	white-space: pre-wrap; 
	word-wrap: break-word; 
}

q { 
	quotes: none; 
}
q:before, q:after { 
	content: ""; 
	content: none; 
}
small { 
	font-size: 85%; 
}
sub, sup { 
	font-size: 75%; 
	line-height: 0; 
	position: relative; 
	vertical-align: baseline; 
}
sup { 
	top: -0.5em; 
}
sub { 
	bottom: -0.25em; 
}

ul, ol { 
	margin: 1em 0; 
	padding: 0 0 0 40px; 
}
dd { 
	margin: 0 0 0 40px;
}
nav ul, nav ol { 
	list-style: none; 
	list-style-image: none; 
	margin: 0; 
	padding: 0;
}

img { 
	border: 0; 
	-ms-interpolation-mode: bicubic; 
	vertical-align: middle; 
}
svg:not(:root) { 
	overflow: hidden; 
}
figure { 
	margin: 0; 
}

form { 
	margin: 0; 
}
fieldset { 
	border: 0; 
	margin: 10px 0 0 0; 
	padding: 0; 
}
legend { 
	border: 0; 
	*margin-left: -7px; 
	padding: 0; 
	white-space: normal; 
}
button, input, select, textarea { 
	font-size: 100%; 
	margin: 0; 
	padding: 4px;
	vertical-align: baseline; 
	*vertical-align: middle; 
	border: 1px solid;
	border-color: #ccc;
	border-radius: 5px;
}
button, input { 
	line-height: normal; 
}
button, input[type="button"], input[type="reset"], input[type="submit"], button[type="submit"] { 
	cursor: pointer; 
	-webkit-appearance: button; 
	*overflow: visible; 
}
button[disabled], input[disabled] { 
	cursor: default; 
}
input[type="checkbox"], input[type="radio"] { 
	box-sizing: border-box; 
	padding: 0; 
	*width: 13px; 
	*height: 13px; 
}
input[type="search"] { 
	-webkit-appearance: textfield; 
	-moz-box-sizing: content-box; 
	-webkit-box-sizing: content-box; 
	box-sizing: content-box; 
}


input[type="submit"]:disabled, input[type="button"]:disabled, button[type="submit"]:disabled {
	color: #aaa;
	background-color: #ddd;
	border-color: #ccc;
}
input[type="submit"][disabled]:hover, input[type="button"][disabled]:hover, button[type="submit"]:hover {
	color: #aaa;
	background-color: #ddd;
	border-color: #ccc;
}
input[type="search"]::-webkit-search-decoration, input[type="search"]::-webkit-search-cancel-button { 
	-webkit-appearance: none; 
}
button::-moz-focus-inner, input::-moz-focus-inner { 
	border: 0; 
	padding: 0; 
}
textarea { 
	width: 100%;
	overflow: auto; 
	vertical-align: top; 
	resize: vertical; 
}
input:valid, textarea:valid {  }
input:invalid, textarea:invalid { 
	background-color: #fff; 
}

table { 
	border-collapse: collapse; 
	border-spacing: 0; 
}
td { 
	vertical-align: top; 
}

.chromeframe { 
	margin: 0.2em 0; 
	background: #ccc; 
	color: black; 
	padding: 0.2em 0; 
}

.hidden { 
	display: none; 
}
.visually-hidden { 
	visibility:hidden; 
}
.offscreen { 
	position: absolute; 
	top: 0; 
	left: -900em; 
}


h1, h2, h3, h4, h5, h6 {
	font-family: 'Roboto', sans-serif;
	margin: 0;
}
input[type="text"] {
	width: 100%;
	margin-bottom: 5px;
}
input[type="tel"] {
	width: 100%;
}
input[type="email"] {
	width: 100%;
}
input[type="password"] {
	width: 100%;
	margin-bottom: 5px;
}
  
input[type="submit"], input[type="button"], button[type="submit"], .btn-blue {
	color: #fff;
	background-color: #1894e1;
	padding: 5px;
	font-size: 110%;
	width: 100%;
	border: 1px solid;
	border-color: #1894e1;
	border-radius: 5px;
}
input[type="submit"]:hover, input[type="button"]:hover, button[type="submit"]:hover, .btn-blue:hover {
	background-color: #0B53C1;
    color:#fff;
}
.btn-fancy, input[type="submit"].btn-fancy, input[type="button"].btn-fancy, button[type="submit"].btn-fancy {
    border-radius:0px 43.5px 43.5px 43.5px;
    padding: 16px 16px 19px 16px;
	width: 35%;
}
.btn-fancy-rev, input[type="submit"].btn-fancy-rev, input[type="button"].btn-fancy-rev, button[type="submit"].btn-fancy-rev {
    border-radius: 43.5px 0px 43.5px 43.5px;
    padding: 16px 16px 19px 16px;
}

.inputfield {
	margin: 10px 0 0 0;
}

.error {
	color: #F00;
	margin-bottom: 20px;
	text-align: center;
	border-radius: 5px;
	padding: 5px;
	border: 1px solid;
}

#error-message{
	display: none;
}
#content {
	max-width: 1020px;
	margin: 0 auto;
	padding: 20px;
}
.password-toggle{
	width:30px;height:30px;position:absolute;right:0;top:24px;cursor:pointer;pointer-events:all;
}
.badge.login{background:#4ea6dc;padding:.4em .7em;color:#f2f2f2;}
.badge.login:hover{background:#91c7e9;}
.badge.onlogin{padding:.4em .7em;color:#ccc;}


/* responsive styles for form elements */
@media (min-width: 768px) {
	.password-toggle{
		right: 15%;
		top: 42%;
	}
	label {
		/* display: inline-block;
		margin-right: 10px;
		margin-left: -15px;
		width: 20%;
		text-align: right; */
	}
	input[type="text"] {
		width: 75%;
	}
	input[type="tel"] {
		width: 75%;
	}
	input[type="email"] {
		width: 75%;
	}
	input[type="password"] {
		width: 75%;
	}
	textarea {
		width: 75%;
	}
}

@media (min-width: 380px) AND (max-width: 767px) {
	.password-toggle{right: 15%;
		top: 42%;}

	.login-inputfield input {
		width: 75%;
	}

	header {
		display: none;
	}
}

/**********************
* HEADER STYLES
**********************/
header {
	color: #fff;
	font-family: 'Roboto', sans-serif;
	background-color: #666;
	padding: 10px;
}

/**********************
* FOOTER STYLES
**********************/

footer {
	font-family: 'Roboto', sans-serif;
	font-size: 12px;
	text-align: center;
	position: absolute;
  	right: 0;
  	bottom: 0;
  	left: 0;
  	padding: 1rem;
  	background-color: #f2f2f2;
}

/**********************
* MENU STYLES
**********************/
body {
    overflow-x: hidden;/*height:auto;*/
    position: relative;
  	/*min-height: 100%;*/
}

.main-wrap{position:relative;/*overflow:hidden;*/}
nav {
	color: #fff;
	font-family: 'Roboto', sans-serif;
	font-size: 14px;
	background: #069;
	padding: 15px;
	width: 180px;
	/*height:100%;*/
    /*transform: translateX(-405px);
    transition: transform 0.3s cubic-bezier(0,0,0.3,1);*/
	position: absolute;
    top: 0;
    bottom: 0;
    z-index: 0;
}
nav ul {
	margin-top: 0;
	margin-left: 0px;
	margin-bottom: 30px;
	padding: 0;
}
nav li {
	margin-top: 10px;
}
nav a {
	color: #fff;
	text-decoration: none;
}
nav a:visited {
	color: #fff;
}
nav a:hover {
	color: #fff;
	text-decoration: underline;
}
.site-wrap {
    min-width: 90%;
    /*min-height: 1000px;*/
    /*height:100%;*/
    min-height:100vh;
    overflow-scrolling: auto;
	-webkit-overflow-scrolling: touch;
    background-color: #fff;
    position: relative;
    /*top: 0;
    bottom: 100%;
    left: 0;*/
    z-index: 0;
}
.nav-trigger {
    position: absolute;
    clip: rect(0, 0, 0, 0);
}
.nav-trigger:checked + label {
	left: 215px;
}
.nav-trigger:checked ~ .site-wrap {
    left: 180px;
}
.nav-trigger + label, .site-wrap {
    transition: left 0.2s;
}
@media (min-width: 768px) {
	header {
		display: none;
	}
	nav {
		background: #069;
		font-size: 105%;
		padding: 15px;
		width: 100%;
    	height: auto;
    	position: relative;
    	text-align: center;
	}
	nav ul {
		margin: 0 0;
	}
	nav li {
		display: inline;
		margin: 0 10px;
	}
	.nav_cat {
		margin-bottom: 20px;
	}
	/*.site-wrap {
		position: static;
		min-width: 75%;
	}*/
}



/**********************
* HOME PAGE STYLES
**********************/

#logo {
	max-width: 800px;
	margin: 25px auto 50px auto;
	padding: 10px;
}

/**********************
* ABOUT PAGE STYLES
**********************/

#about {
	max-width: 800px;
	margin: 25px auto 50px auto;
}

/**********************
* CONTACT FORM PAGE STYLES
**********************/

#contact {
	max-width: 600px;
	margin: 25px auto 50px auto;
}

/**********************
* LOGIN FORM PAGE STYLES
**********************/
#loginform {
	margin: 50px auto;
	max-width: 450px;
	background-color: #fff;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 5px 7px rgba(0, 0, 0, 0.1);
    width: auto;
	height: 100%;
    text-align: center;
}

#loginform > div {
    margin-bottom: 20px;
}

#loginform h2 {
    margin-top: 20px;
    font-size: 1.5em;
    color: #333;
}

.login-inputfield {
    text-align: left;
    margin-bottom: 20px;
	display: flex;
    justify-content: center; 
    flex-direction: column; 
    align-items: center; 
}

.login-inputfield input {
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
	box-sizing: border-box;
}

.login-inputfield label {
  align-self: flex-start;
  display: block; 
  margin-bottom: 5px; 
  color: #333; 
  font-size: 0.9em; 
  position: relative;
  left: 13%;
}

.login-inputfield input:focus + label,
.login-inputfield input:not(:placeholder-shown) + label {
    top: -10px;
    background: #fff;
    font-size: 0.75em;
    padding: 0 5px;
}

#login-btn, #next-btn {
	width: 45%;
	padding: 15px 10px 15px 10px;
	margin: 15px 0 15px 0;
	border-radius: 20px;
	background-color: #007aff;
    color: #fff;
	font-weight: bold;
	cursor: pointer;
	transition: background-color 0.3s ease-in;
  }

  #login-btn:hover {
	border: 1px solid #007aff;
	background-color: #fff;
	color: #007aff;
}

#authForm > p {
    text-align: center;
    margin-top: 20px;
	color: #007aff;
}

/* #authForm {
	display: none;
	opacity: 0;
} */

/* Close and SSO links */
#loginform p {
    text-align: center;
    margin-top: 20px;
}

#loginform a {
    display: block;
    color: #007aff !important;
    text-decoration: none;
    margin: 5px 0;
}

#authForm a:hover {
    text-decoration: underline;
}

/**********************
* PASSWORD FORM PAGE STYLES
**********************/
#table1 td {
	padding: 2px 0 5px 5px;
}
.info {
	text-align: center;
	color: #bbb;
	font-size: 80%;
}

/**********************
* LOADER WHEEL
**********************/

/* parent div for balls*/
.bigcircle{
	height: 50px;
	width: 50px;
	transform: scale(.2);
	display: block;
	position: relative;
	right: 13px;
	bottom: 12px;
  }
  /* parent div for ball(singular) in order rotate animation at logo center */
  .balls{
	transform: rotate(45deg);
	z-index: 3;
	margin: 20px;
	position: relative;
	bottom: 175px;
	left: 25px;
	height: 80px;
	width: 80px;
	transform-origin: center;
  }
  
  .ball{
	background-color: #1894e1;
	height: 22px;
	width: 22px;
	border-radius: 50%;
	position: absolute;
  }
  
  #ball2{
	background-color: #00a5a5;
	right: 0px;
  
  }
  
  #ball3{
	background-color: #85dfd8;
	bottom: 0px;
  }
  
  #ball4{
	background-color: #0b53c1;
	right: 0px;
	bottom: 0px;
  }
  
  /* outer ring */ 
  .circle-container {
	width:200px;
	height:200px;
	align-items: center;
	justify-content: center;
  }
  .circle {
	  position: relative;
	  width: 8.4em;
	  height: 8.4em;
	  border-radius: 50%;
	  border: 18px solid rgba(255, 255, 255, 0.0);
	  border-top-color: #1894e1;
	  animation: circle1 1s linear infinite;
  }
  
  #circle2{
	border-top-color: #00a5a5;
	bottom: 170px;
	transform: rotate(90deg);
	animation: circle2 1s linear infinite;
  }
  
  #circle3{
	border-top-color: #0b53c1;
	bottom: 339px;
	transform: rotate(180deg);
	animation: circle3 1s linear infinite;
  }
  
  #circle4 {
	border-top-color: #85dfd8;
	bottom: 509px; 
	transform: rotate(270deg);
	animation: circle4 1s linear infinite;
  }
  
  /* gaps in between outer ring */
  
  .seperator-container{
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	bottom: 340px;
	left: 70px;
  }
  .seperator{
	background-color: white;
	height: 225px;
	width: 10px;
  }
  
  #seperator1{
	position: relative;
	transform: rotate(45deg);
	right:22px;
  }
  
  #seperator2{
	position: relative;
	transform: rotate(135deg);
	right: 7px;
  }

  #loader-wheel {
	display: none;
	align-items: center;
	justify-content: center;
  }


/**********************
* ANIMATIONS	
**********************/

.fade-in {
	animation: fadeIn 0.5s ease-in-out;
}

.fade-out {
	animation: fadeOut 0.5s ease-in-out;
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

@keyframes fadeOut {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}
/* throbber animations */
@keyframes circle1 {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}

}

@keyframes circle2 {
	0% {
		transform: rotate(90deg);
	}

	100% {
		transform: rotate(450deg);
	}

}

@keyframes circle3 {
	0% {
		transform: rotate(180deg);
	}

	100% {
		transform: rotate(540deg);
	}
  }

@keyframes circle4 {
	0% {
		transform: rotate(270deg);
	}

	100% {
		transform: rotate(630deg);
	}
}