.ols-base {
	--primaryDark: #0f2544;
	--primary: #003566;
	--primaryLighter: #627297;
	--primaryLight: #bec5d5;

	--grey-500: #666;
	--grey-400: #8c8c8c;
	--grey-200: #d9d9d9;
	--grey-100: #f5f5f5;
	--grey-50: #fafafa;

	--white: #fff;
	--accent: #006fd6;
	--success: #08cca9;
	--danger: #e73801;

	--paginationLinksHover: #004bb5;
}

/* ========== Prevent flash ========== */
[v-cloak] {
	display: none;
}
[v-cloak] > * {
	display: none;
}
[v-cloak]::before {
	content: "";
}

/* ========== Fonts ========== */
@font-face {
	font-family: 'Open Sans';
	src: url('fonts/OpenSans-Regular.ttf');
	font-weight: 400;
}
@font-face {
	font-family: 'Open Sans';
	src: url('fonts/OpenSans-Medium.ttf');
	font-weight: 500;
}
@font-face {
	font-family: 'Open Sans';
	src: url('fonts/OpenSans-SemiBold.ttf');
	font-weight: 600;
}
@font-face {
	font-family: 'Open Sans';
	src: url('fonts/OpenSans-Bold.ttf');
	font-weight: 700;
}

/* ========== Override ols.css ========== */
.navbar-nav {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-direction: column;
	flex-direction: column;
	padding-left: 0;
	margin-bottom: 0;
	list-style: none;
}

.navbar-nav > li {
	display: inherit;
	width: inherit;
}

.dropdown-toggle {
	margin: inherit;
}

.navbar-nav {
	float: none;
	text-align: inherit;
	margin: inherit;
	padding: inherit;
}

/* ========== Global config ========== */
html, body {
	margin: 0;
	padding: 0;
}
html {
	height: 100%;
	font-size: 16px;
}
body {
	background-color: #f5f5f5;
	min-height: 100%;
	height: 100%;
}

body > * {
	font-size: 0.875rem;
	font-family: 'Open Sans', sans-serif;
}

.ols-base .form-control {
	border-radius: 0;
	border: 1px solid var(--grey-200);
}

.ols-base .btn {
	border-radius: 0;
	font-weight: 500;
}

.ols-base .footer {
	background-color: white;
}

.ols-base select {
	font-size: inherit;
	border-color: var(--grey-200);
	padding: 0.3rem 0.5rem;
}

/* ========== Custom multiselect ========== */
.ols-base .multiselect,
.ols-base .multiselect__input,
.ols-base .multiselect__single {
	font-size: 0.875rem;
}

.ols-base .multiselect__content-wrapper,
.ols-base .multiselect__tags {
	border-radius: 0;
	border-color: var(--grey-200);
}

.ols-base .multiselect__tags {
	min-height: 38px;
	max-height: 38px;
}

.ols-base .multiselect__option {
	background-color: var(--grey-50);
	border-bottom: 1px solid var(--grey-200);
}

.ols-base .multiselect__option--highlight {
	background-color: var(--grey-200);
	color: #000;
}

.ols-base .multiselect__placeholder {
	color: #000;
	display: inline-block;
	margin-bottom: 0;
	padding-top: 0;
	padding-left: 5px;
}

.ols-base .multiselect__content-wrapper {
	width: fit-content;
	min-width: 100%;
}

/* ========== Custom navbar ========== */
.ols-base .top-navbar--container {
	background-color: white;
	border-bottom: 1px solid var(--grey-200);
}

.ols-base .top-navbar--main .dropdown-item {
	color: var(--primary);
	font-weight: 500;
	font-size: 0.875rem;
}

.ols-base .top-navbar--main {
	align-items: center;
}

.ols-base .top-navbar--container .nav-link {
	color: var(--primary);
	padding-left: 1rem;
	padding-right: 1rem;
	font-weight: 500;
}

.ols-base .top-navbar--container .top-navbar--brand {
	color: var(--primary);
	font-weight: 600;
	padding: 0;
}

.ols-base .top-navbar--container .top-navbar--help {
	color: #6c6c6c;
	font-size: 1.2rem;
	line-height: 1;
	cursor: pointer;
}

/* ========== Custom list ========== */
.ols-base .list-style-disc {
	list-style-type: disc;
}

.ols-base .list-style-circle {
	list-style-type: circle;
}

/* ========== Custom card ========== */
.ols-base .card {
	border: 0;
	border-radius: 0;
}

.ols-base .card-header {
	background-color: var(--white);
	padding-bottom: 0;
	border-bottom: 1px solid var(--grey-200);
}

/* ========== Utility classes ========== */
.ols-base .width-fit-content {
	width: fit-content !important;
}

.ols-base .height-inherit {
	height: inherit !important;
}

.ols-base .color-primary {
	color: var(--primary) !important;
}

.ols-base .color-primary-dark {
	color: var(--primaryDark) !important;
}

.ols-base .color-red {
	color: var(--red) !important;
}

.ols-base .color-danger {
	color: var(--red) !important;
}

.ols-base .color-grey-400 {
	color: var(--grey-400) !important;
}

.ols-base .color-grey-500 {
	color: var(--grey-500) !important;
}

.ols-base .color-accent {
	color: var(--accent) !important;
}

.ols-base .font-base {
	font-size: 0.875rem !important;
	font-weight: 400 !important;
}

.ols-base .font-base-bold {
	font-size: 0.875rem !important;
	font-weight: 500 !important;
}

.ols-base .font-base-large {
	font-size: 1rem !important;
}

.ols-base .font-base-large-bold {
	font-weight: 600 !important;
	font-size: 1rem !important;
}

.ols-base .heading {
	font-weight: 700 !important;
}

.ols-base .heading-big {
	font-size: 1.625rem !important;
}

.ols-base .heading-small {
	font-size: 1.25rem !important;
}

.ols-base .cursor-pointer {
	cursor: pointer !important;
}

.ols-base .bg-primary-dark {
	background-color: var(--primaryDark) !important;
}

.ols-base .text-primary-dark {
	color: var(--primaryDark) !important;
}

.ols-base .border-primary {
	color: var(--primary) !important;
}
/* ========== Custom classes ========== */
.ols-base .error-message {
	color: var(--red);
	font-size: 0.75rem;
	font-weight: 400;
}

.ols-base .page-title {
	font-size: 1.5rem;
	font-weight: 600;
}

.ols-base .form-navbar--title {
	font-weight: 600;
	color: var(--grey-400);
}

.ols-base .form-navbar--description {
	font-size: 0.9rem;
	color: var(--grey-400);
}

.ols-base .form-navbar .nav-link {
	border: 1px solid transparent;
}

.ols-base .form-navbar .nav-link.active {
	border-color: var(--grey-200);
	background-color: white;
}

.ols-base .form-navbar .nav-link.active .form-navbar--title {
	color: var(--primary);
}
.ols-base .form-navbar .nav-link.active .form-navbar--description {
	color: var(--primary);
}

.ols-base .form-section .nav-link {
	border: 0;
	border-bottom: 1px solid transparent;
	color: var(--grey-400);
}

.ols-base .form-section .nav-link.active {
	border-color: var(--accent);
	color: var(--accent);
	font-weight: 600;
}

.ols-base .form--reference-code {
	background-color: var(--primaryLight);
	color: var(--primaryDark);
}

.ols-base .menu-item {
	padding-left: 2rem;
	padding-right: 2rem;
	padding-top: 2.5rem;
	padding-bottom: 2.5rem;
	background-color: white;
	display: flex;
	flex-direction: column;
	cursor: pointer;
	height: 14rem;
}

.ols-base .menu-item--shadow {
	box-shadow: 0 0 0.5rem rgba(0, 0, 0, .15);
}

.ols-base .menu-item--icon {
	font-size: 2rem;
	color: var(--primary);
}

.ols-base .menu-item--title {
	font-weight: 600;
	color: var(--primary);
}

.ols-base .menu-item--description {
	color: var(--grey-500);
}

.ols-base .copyright {
	text-align: center;
	color: var(--grey-400);
	padding: 1rem;
}

.ols-base .triage-form--description {
	font-size: 0.75rem;
}

/* ========== Form ============ */
.ols-base .form-group .form-label {
	color: var(--grey-500);
	font-weight: 500;
	font-size: 0.875rem;
	margin-bottom: 0.25rem;
}

.ols-base .form--help-text {
	font-size: 0.625rem;
	color: var(--grey-500);
	margin-bottom: 0;
}

/* ========== Button ========== */
.ols-base .ols-btn--primary {
	background-color: var(--primary);
	color: var(--white);
	border-color: var(--primary);
}

.ols-base .ols-btn--primary:hover {
	background-color: #4c7193;
	color: var(--white);
	border-color: #4c7193;
}

.ols-base .ols-btn--primary-outline {
	background-color: var(--white);
	color: var(--primary);
	border-color: var(--primary);
}

.ols-base .ols-btn--primary-outline:hover {
	background-color: var(--grey-400);
	color: var(--white);
	border-color: var(--grey-400);
}

.ols-base .ols-btn--label {
	font-weight: 500;
}

/* ========= Checkbox ======= */
.ols-base .custom-checkbox .custom-control-label::before {
	border-radius: 0;
}
.ols-base .custom-control-input:checked ~ .custom-control-label::before {
	color: var(--white);
	border-color: var(--primary);
	background-color: var(--primary);
}
.ols-base .custom-control-label::before {
	border: 1px solid var(--grey-400);
	background-color: var(--grey-200);
}
.ols-base .custom-control-label::before {
	top: 0.1rem;
}
.ols-base .custom-control-label {
	font-size: 0.9rem;
}
.ols-base .custom-control-label::after {
	top: 0.1rem;
}

.ols-base .horizontal-line {
	width: 2.5rem;
	height: 0.3rem;
	background-color: var(--primary);
	border-radius: 3px;
}

.ols-base .section {
	padding: 2rem;
	height: 100%;
}

.ols-base .section--login {
	background-color: var(--white);
}

.ols-base .section--intro {
	background-color: var(--grey-100);
}

.ols-base .intro-paragraph {
	color: var(--grey-500);
	margin-top: 1.5rem;
}

.ols-base .img-logo {
	max-height: 100px;
	min-height: 100px;
}

.ols-base .logo-link:focus-visible {
	outline-color: var(--color-accent);
	display: inline-block;
}

.ols-base .link {
	color: var(--accent);
	text-decoration: none;
}

.ols-base .link:hover {
	color: var(--primary);
}

/* ========== Custom modal ========== */
.ols-base .modal-content {
	border-radius: 0;
}

.ols-base .modal-header {
	border: 2px solid var(--white);
	border-radius: 0;
	padding: 0.6rem 1.3rem;
	color: var(--white);
	background-color: var(--primary);
}

.ols-base .modal-body {
	padding: 1.5rem;
	font-size: 0.875rem;
}

.ols-base .modal-body__header {
	font-size: 1rem;
	margin-top: 0;
	font-weight: 500;
	line-height: 1.2;
}

.ols-base .modal-footer {
	border: 0;
	border-radius: 0;
}

.ols-base .header-group {
	display: flex;
	align-items: center;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.ols-base .header-group--icon {
	font-size: 2rem;
	line-height: 1.2;
}

.ols-base .header-group--title {
	margin: 0;
	font-size: 1.4rem;
	font-weight: 400;
}

/* ========== Custom toast ========== */
.toast-body {
	padding: 0.5rem;
}

.toast-body__custom-content {
	display: flex;
	align-items: center;
}

.toast-body .custom-content__icon {
	width: fit-content;
	font-size: 2.5rem;
	margin-left: 0.5rem;
}

.toast-body .custom-content__desc {
	margin-left: 1rem;
}

.content-desc__title {
	font-size: 1rem;
	margin-bottom: 0.2rem;
	font-weight: 500;
}

.content-desc__message {
	font-size: 0.875rem;
}

.b-toast .toast {
	border-radius: 0;
}

.b-toast .toast.toast-error {
	border: 1px solid #bd3c3c;
	border-left: 4px solid #bd3c3c;
	background: #ffe2e2;
	color: #c22f3d;
}

.b-toast .toast.toast-success {
	border: 1px solid #457d57;
	border-left: 4px solid #457d57;
	background: #e9f7ee;
	color: #457d57;
}

/* ========== Custom table ========== */
.ols-base .table thead th {
	border-bottom: 0;
	vertical-align: top;
}

.ols-base .table thead th > div {
	color: var(--primaryDark);
}

.ols-base .table {
	border: 1px solid var(--grey-200);
}

.ols-base thead {
	background-color: var(--white);
}

.ols-base .table th,
.ols-base .table td {
	border-top: 1px solid var(--grey-200);
	color: var(--primaryDark);
}

.ols-base .table td {
	vertical-align: top;
}

.ols-base .table-striped tbody tr:nth-of-type(odd) {
	background-color: #e9ecef;
}

.ols-base .table-striped tbody tr:nth-of-type(even) {
	background-color: var(--white);
}

.ols-base tbody tr.b-table-row-selected.table-active.b-table-has-details,
.ols-base .b-table-row-selected.b-table-has-details + .d-none + .b-table-details {
	background-color: #f8f9fa;
}

.table.b-table > tbody > .table-active,
.table.b-table > tbody >.table-active>td,
.table.b-table > tbody >.table-active>th {
	background-color: inherit;
}

.ols-base .table.b-table>tfoot>tr>[aria-sort]:not(.b-table-sort-icon-left),
.ols-base .table.b-table>thead>tr>[aria-sort]:not(.b-table-sort-icon-left) {
	background-position: right 1rem;
}

/* ========== Custom pagination ========== */
.ols-base .pagination {
	margin-bottom: 0;
}

.ols-base .pagination-info {
	color: #3f59ba;
}

.ols-base .pagination .page-link {
	background-color: transparent;
	border-color: transparent;
	font-weight: bold;
}

.ols-base .page-item .page-link {
	color: var(--primaryDark);
}

.ols-base .page-item .page-link:hover {
	color: var(--paginationLinksHover);
}

.ols-base .page-item.active .page-link {
	border: 1px solid var(--grey-200);
}

/* ========== Custom footer ========== */
.ols-base .ols-footer .list-group-item {
	padding: 0.5rem;
	border-radius: 0;
	border: 0;
	background-color: transparent;
}

.ols-base .ols-footer .list-group-item a {
	color: var(--grey-500);
}

.ols-base .ols-footer .list-group-item a:hover {
	text-decoration: none;
}

.btn.btn--skip-link {
	position: fixed;
	z-index: 0;
	opacity: 0;
}

.btn.btn--skip-link:focus {
	opacity: 1;
	z-index: 100;
}

.btn-primary {
    color: #fff;
    background-color: #007bff;
    border-color: #007bff;
}

.btn-primary:focus, .btn-primary.focus {
	color: #fff;
	background-color: #0069d9;
	border-color: #0062cc;
	border-radius: 0.25rem;
	box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.5);
	background-image: none;
	font-size: 1rem;
	font-weight: 400;
}

/* ========== Custom responsive ========== */
@media (min-width: 768px) {
	.ols-base .section {
		padding-top: 40%;
	}
}

@media (min-width: 1200px) {
	.ols-base .section {
		padding-left: 15%;
		padding-right: 15%;
	}
}

@media (min-width: 1400px) {
	.ols-base .section {
		padding-top: 30%;
		padding-left: 20%;
		padding-right: 20%;
	}
}

@media (min-width: 992px) {
	.ols-base .max-width-500 {
		max-width: 500px;
		width: 100%;
		margin-left: auto;
		margin-right: auto;
	}
}