
body {
	font-family: 'Source Sans Pro','Helvetica','Arial',sans-serif;
	}

div#body {
	min-height: 400px;
}

/* main content box, includes header/footer */
div#content {
	max-width: 100%;
	margin: 0 auto;
	}

a,
a:visited,
a:active {
	color: #18548b;
	text-decoration: underline;
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	transition: all .3s ease;
	}

a:hover {
	color: #2a91f0;
	}

/* style placeholder text (for browsers that support the attribute) - note: can't stack, each must be seperate */
::-webkit-input-placeholder { color: #bbb !important; } /* chrome/opera/safari */
::-moz-placeholder { color: #bbb !important; opacity: 1; } /* ff 19+ */
:-moz-placeholder { color: #bbb !important; opacity: 1; } /* ff 18- */
:-ms-input-placeholder { color: #bbb !important; } /* ie 10+ */
::placeholder { color: #bbb !important; } /* official standard */
.placeholder { color: #bbb !important; } /* generic class */

div#header {
	margin-top: 65px;
	font-family: 'Source Sans Pro','Helvetica','Arial',sans-serif;
	background-color: #eaf5ff;
	background: linear-gradient(180deg, #fff 0%, #eaf5ff 100%);
	text-align: center;
	vertical-align: bottom;
	padding-left: 20px;
	padding-right: 20px;
	border-bottom: 1px solid rgba(24,84,139,0.2); /* #18548b */
	}

div#header img {
	transition: margin 400ms;
	}

div.overflow > p,
div.overflow > p > span,
td.overflow {
	overflow: hidden;
	text-overflow: ellipsis !important;
	white-space: nowrap;
	}

/* RESPONSE MESSAGES *******************************************************/

#message_container {
	z-index: 99998;
	position: fixed;
	top: -80px;
	filter: alpha(opacity=0);
	opacity: 0;
	-moz-opacity:0;
	-khtml-opacity: 0;
	padding: 20px 0;
	max-width: 100%;
	}

#message_text {
	z-index: 99999;
	position: fixed;
	top: -80px;
	left: 0;
	right: 0;
	filter: alpha(opacity=0);
	opacity: 0;
	-moz-opacity:0;
	-khtml-opacity: 0;
	margin: 0 auto;
	vertical-align: middle;
	padding: 15px 0 17px 0;
	text-align: center;
	font-family: Sans-Serif !important;
	font-size: 18px;
	font-weight: 600;
	letter-spacing: -0.03em;
	}

.message_container_mood_default {
	background: #005fb9;
	}

.message_container_mood_positive {
	background: #057700;
	}

.message_container_mood_negative {
	background: #ff0000;
	}

.message_container_mood_alert {
	background: #dc6e00;
	}

.message_text_mood_default {
	color: #ffffff;
	}

.message_text_mood_positive {
	color: #ffffff;
	}

.message_text_mood_negative {
	color: #ffffff;
	}

.message_text_mood_alert {
	color: #ffffff;
	}

/* PRINTING CLASSES *************************************************************************/

@media print {
	.no-print, .no-print * {
		display: none !important;
		}
	}

@media screen {
	.print, .print * {
		display: none !important;
		}
	}

/* Navbar Menu Styles ************************************************************************/

/* navbar brand image */
nav#navbar a.navbar-brand > img {
	margin-top: 12px;
	margin-bottom: 12px;
	height: 100%;
	max-height: 42px;
	width: auto;
	}

/* look of main menu nav bar */
nav#navbar {
	width: 100%;
	margin: 0 auto;
	background: #fff;
	box-shadow: none;
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	transition: all .3s ease;
	}

/* adds drop shadow to menu when scrolling */
nav#navbar.scroll {
	box-shadow: 0 10px 50px -5px rgba(24,84,139,0.2); /* #18548b */
	}

/* main menu items */
nav#navbar.navbar a.nav-link {
	color: #333;
	font-size: 120%;
	line-height: 100%;
	white-space: nowrap;
	letter-spacing: -0.03em;
	background: #fff;
	font-weight: 300;
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	transition: all .3s ease;
	}

/* adds divider lines on menus < lg */
@media screen and (max-width: 991px) {
	nav#navbar.navbar a.nav-link {
		border-top: 1px solid rgba(24,84,139,0.2); /* #18548b */
		}
	}

/* main menu items, and item with a submenu */
nav#navbar.navbar a.nav-link,
nav#navbar.navbar a.dropdown-toggle {
	color: #333;
	text-decoration: none;
	}

/* hover main menu items, and item with a submenu */
nav#navbar.navbar a.nav-link.active {
	color: #2a91f0;
	text-decoration: none !important;
	}


/* center menu items on mobile */
@media screen and (max-width: 991px) {
	nav#navbar.navbar a.nav-link,
	nav#navbar.navbar a.dropdown-toggle {
		text-align: center;
		}
	}

/* hover main menu items, and item with a submenu */
nav#navbar.navbar a.nav-link:hover,
nav#navbar.navbar a.dropdown-toggle:hover {
	color: #2a91f0;
	text-decoration: none !important;
	background: #eaf5ff;
	background: linear-gradient(0deg, #fff 0%, #eaf5ff 100%);
	}

/* main menu item with submenu, hide down arrow */
nav#navbar.navbar a.dropdown-toggle::after {
	display: none !important;
	}

/* submenu container */
@media screen and (max-width: 991px) {
	ul.dropdown-menu {
		margin: 0 0 10px 0 !important;
		border: none;
		background-color: #fff;
		border-radius: 0;
		}
	}
@media screen and (min-width: 992px) {
	ul.dropdown-menu {
		min-width: 100% !important; /* must use min-width */
		padding: 0;
		padding-bottom: 15px;
		margin-top: 0 !important;
		margin-left: 0 !important;
		border: none;
		background-color: #fff;
		border-radius: 0;
		box-shadow: none;
		-webkit-transition: all .3s ease;
		-moz-transition: all .3s ease;
		transition: all .3s ease;
		border-left: 1px solid rgba(24,84,139,0.1);
		border-right: 1px solid rgba(24,84,139,0.1);
		border-bottom: 1px solid rgba(24,84,139,0.1);
		box-shadow: 0 1px 2px -1px rgba(24,84,139,0.2);
		}
	/* adds drop shadow to submenu container when scrolling */
	ul.dropdown-menu.scroll {
		box-shadow: 0 20px 30px -5px rgba(24,84,139,0.15);
		}
	}

/* submenu items */
nav#navbar.navbar a.dropdown-item {
	color: #333;
	padding: 10px 20px;
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	transition: all .3s ease;
	text-align: center;
	}

/* active submenu item */
nav#navbar.navbar a.dropdown-item.active {
	color: #2a91f0;
	background: none !important;
	text-decoration: none !important;
	}

/* hover submenu items */
nav#navbar.navbar a.dropdown-item:hover,
nav#navbar.navbar a.dropdown-item.active:hover {
	color: #2a91f0;
	background: #eaf5ff !important;
	text-decoration: none !important;
	}

/* hamburger menu toggle icon for menus < lg */
nav#navbar button.navbar-toggler {
	color: #18548b;
	border: none !important;
	outline: none !important;
	}

/* hover/active menu toggle icon */
nav#navbar button.navbar-toggler:hover > i.fa-bars,
nav#navbar button.navbar-toggler:focus > i.fa-bars,
nav#navbar button.navbar-toggler:active > i.fa-bars {
	color: #2a91f0;
	border: none !important;
	outline: none !important;
	}

/********************************************************************************************/

table.table-sorter th {
	cursor: pointer;
	}

/* bootstrap override on table row hover background color */
table.table.table-hover > thead > tr:hover > th,
table.table.table-hover > tbody > tr:hover > td {
	--bs-table-hover-bg: rgb(234, 245, 255); /* light blue color from sub-menu items */
	}

/* PAGINATION (PAGING) CONTROLS ************************************************/

.pagination {
	clear: both;
	padding: 0;
	/* remove below to left-align content */
	justify-content: center;
	align-items: center;
	}

.pagination li > a,
.pagination li > span {
	display: inline-block;
	border: 1px solid rgb(33, 37, 41);
	border-radius: 6px;
	transition: all 300ms;
	font-size: 17px;
	height: 38px;
	}

.pagination li a {
	color: rgb(33, 37, 41);
	margin: 1px;
	margin-top: 1px;
	margin-right: 5px;
	padding: 6px 13px;
	text-decoration: none;
	height: 38px;
	}

.pagination li a.mini {
	padding: 6px 6px;
	margin-left: 2.5px;
	margin-right: 2.5px;
	}

.pagination li a:hover,
.pagination li a:active {
	background: rgb(33, 37, 41);
	border: 1px solid rgb(33, 37, 41);
	color: #fff;
	}

.pagination li span.current {
	background-color: rgb(33, 37, 41);
	border: 1px solid rgb(33, 37, 41);
	margin: 1px;
	margin-right: 5px;
	padding: 10px 15px;
	line-height: 1;
	text-decoration: none;
	color: #fff;
	cursor: default;
	font-weight: 600;
	height: 38px;
	}

.pagination li span.current:hover {
	background-color: rgb(66, 70, 73);
	border: 1px solid rgb(66, 70, 73);
	}

.pagination li a.disabled,
.pagination li a.disabled:hover {
	border: 1px solid #ccc;
	color: #ccc;
	cursor: default;
	background: none;
	height: 38px;
	}

.pagination span.ellipsis,
.pagination span.ellipsis:hover {
	border: 0;
	color: rgb(33, 37, 41);
	cursor: default;
	background: none;
	padding-left: 10px;
	padding-right: 14px;
	padding-top: 12px;
	}

.pagination.mini {
    margin-bottom: 0 !important;
	}

/* FORM ELEMENTS ********************************************************************/

form {
	margin: 0;
	}

/* style placeholder text (for browsers that support the attribute) - note: can't stack, each must be seperate */
::-webkit-input-placeholder { color: #c9c9c9 !important; } /* chrome/opera/safari */
::-moz-placeholder { color: #c9c9c9 !important; opacity: 1; } /* ff 19+ */
:-moz-placeholder { color: #c9c9c9 !important; opacity: 1; } /* ff 18- */
:-ms-input-placeholder { color: #c9c9c9 !important; } /* ie 10+ */
::placeholder { color: #c9c9c9 !important; } /* official standard */
.placeholder { color: #c9c9c9 !important; } /* generic class */

/* adds margin between horizontal form elements */
form.form-horizontal input,
form.form-horizontal select,
form.form-inline input,
form.form-inline select,
form.form-inline button {
	margin: 0 2px;
	}

/* overrides above margin for traditional vertical form elements */
form.form-horizontal div.form-group.row input,
form.form-horizontal div.form-group.row select {
	margin: 0;
	}

div.form-group {
	margin-bottom: 10px;
	}

label.control-label.control-label-lg {
	padding-top: 9px;
	}

select.form-control,
select.form-select,
textarea.form-control,
input[type=text].form-control,
input[type=color].form-control,
input[type=number].form-control,
input[type=password].form-control,
input[type=tel].form-control,
input[type=email].form-control,
input[type=date].form-control,
input[type=time].form-control,
input[type=datetime-local].form-control,
label.form-control {
	border: 1px solid rgb(206, 212, 218);
	box-shadow: none;
	}

select.form-control:focus,
select.form-select:focus,
textarea.form-control:focus,
input[type=text].form-control:focus,
input[type=color].form-control:focus,
input[type=number].form-control:focus,
input[type=password].form-control:focus,
input[type=tel].form-control:focus,
input[type=email].form-control:focus,
input[type=date].form-control:focus,
input[type=time].form-control:focus,
input[type=datetime-local].form-control:focus,
label.form-control:focus {
	border: 1px solid rgb(206, 212, 218);
	box-shadow: none;
	}

input[type=checkbox].form-control {
	border: 1px solid rgb(206, 212, 218);
	}

input[type=checkbox].form-control:focus {
	border: 1px solid rgb(206, 212, 218);
	}

textarea.form-control {
	-moz-tab-size : 4;
	-o-tab-size : 4;
	tab-size : 4;
	}

select.form-control,
select.form-select {
	padding-left: 0.8em;
	}

/* left label on form elements */
label.control-label {
	white-space: nowrap;
	}
p.control-label {
	white-space: nowrap;
	margin-top: 0;
	margin-bottom: 5px;
	}

/* right label on checkbox or radio */
label.checkbox_label {
	font-size: 0.95em;
	}

input[type=password].bad,
input[type=password].bad:hover,
input[type=password].bad:active,
input[type=password].bad:focus {
	border-color: #aa2525;
	}

input[type=password].good,
input[type=password].good:hover,
input[type=password].good:active,
input[type=password].good:focus {
	border-color: #2fb22f;
	}

/* removes spinners (increment/decrement controls) inside input fields */
input[type=number] { -moz-appearance: textfield; }
::-webkit-inner-spin-button { -webkit-appearance: none; }
::-webkit-outer-spin-button { -webkit-appearance: none; }

/* disables text input clear 'x' in IE 10+, slows down autosizeInput jquery script */
input[type=text]::-ms-clear {
	display: none;
	}

div input[type=checkbox].slider,
div input[type=radio].slider {
	vertical-align: -2px;
	margin: 0;
	padding: 0;
	display: none !important;
	}

/* text description used under form fields */
.field_desc {
	font-size: 0.9em;
	}

label.control-label {
	font-size: 1.2em;
	}

label.required {
	font-weight: 500;
	color: #4bbe89;
	}

button {
	white-space: nowrap !important;
	}

p {
	font-size: 16px;
	}

p.xs {
	font-size: 14px;
	line-height: 16px;
	}

p.sm {
	font-size: 16px;
	line-height: 18px;
	}

p.md {
	font-size: 18px;
	line-height: 20px;
	}

p.lg {
	font-size: 22px;
	line-height: 26px;
	letter-spacing: -0.03em;
	}

p.xl {
	font-size: 24px;
	line-height: 27px;
	letter-spacing: -0.04em;
	}

p.xl2 {
	font-size: 26px;
	line-height: 29px;
	letter-spacing: -0.04em;
	}

p.xl3 {
	font-size: 28px;
	line-height: 31px;
	letter-spacing: -0.04em;
	}

p.xl4 {
	font-size: 30px;
	line-height: 33px;
	letter-spacing: -0.04em;
	}

p.center {
	text-align: center;
	}

ul, ol {
	margin-top: 0;
	margin-bottom: 30px;
	}

li:not('.nav-item') {
	font-size: 18px;
	}

tr.disabled td:not(:first-child) {
	opacity: 0.5;
	}

/* dropdown button menu */

div.dropdown.dropdown_button ul.dropdown-menu {
	-webkit-transition: none;
	-moz-transition: none;
	transition: none;
	}

/* menu item */
div.dropdown.dropdown_button ul.dropdown-menu > li > a.dropdown-item {
	color: #333;
	padding: 10px 20px;
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	transition: all .3s ease;
	cursor: pointer;
	}

/* active item */
div.dropdown.dropdown_button ul.dropdown-menu > li > a.dropdown-item.active {
	color: #2a91f0;
	background: none !important;
	text-decoration: none !important;
	}

/* hover item */
div.dropdown.dropdown_button ul.dropdown-menu > li > a.dropdown-item:hover,
div.dropdown.dropdown_button ul.dropdown-menu > li > a.dropdown-item.active:hover {
	color: #2a91f0;
	background: #eaf5ff !important;
	text-decoration: none !important;
	}

/* divider */
div.dropdown.dropdown_button ul.dropdown-menu > li > hr.dropdown-divider {
	border-top: 1px solid rgba(24,84,139,0.1);
	margin-top: 1px;
	margin-bottom: 1px;
	}

/* similar padding at top */
div.dropdown.dropdown_button ul.dropdown-menu {
	border-left: 1px solid rgba(24,84,139,0.1);
	border-right: 1px solid rgba(24,84,139,0.1);
	border-bottom: 1px solid rgba(24,84,139,0.1);
	box-shadow: 0 1px 2px -1px rgba(24,84,139,0.2);
	padding-top: 10px;
	}