.grecaptcha-badge {
	visibility: hidden;
}

.tippy-tooltip.light-theme {
	font-family: 'Roboto', sans-serif;
	font-size: 13px;
	font-weight: 300;
	text-align: justify;
	background-color: #ffffff !important;
}

/* Customize the label (the container) */
.checkbox_container {
	display: block;
	position: relative;
	padding-left: 20px;
	margin-bottom: 5px;
	cursor: pointer;
	font-size: 13px;
	font-family: "Roboto";
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

/* Hide the browser's default checkbox */
.checkbox_container input {
	position: absolute;
	opacity: 0;
	cursor: pointer;
	height: 0;
	width: 0;
}

/* Create a custom checkbox */
.checkbox_checkmark {
	position: absolute;
	top: 2px;
	left: 0;
	height: 12px;
	width: 12px;
	background-color: #eee;
}

/* On mouse-over, add a grey background color */
.checkbox_container:hover input~.checkbox_checkmark {
	background-color: #ccc;
}

/* When the checkbox is checked, add a blue background */
.checkbox_container input:checked~.checkbox_checkmark {
	background-color: #999999;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkbox_checkmark:after {
	content: "";
	position: absolute;
	display: none;
}

/* Show the checkmark when checked */
.checkbox_container input:checked~.checkbox_checkmark:after {
	display: block;
}

/* Style the checkmark/indicator */
.checkbox_container .checkbox_checkmark:after {
	left: 5px;
	top: 2px;
	width: 2px;
	height: 6px;
	border: solid white;
	border-width: 0 1px 1px 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

.checkbox_count_label {
	font-size: 11px;
	display: inline;
	padding-top: 2px;
	padding-left: 3px;
	color: #555555;
}

/* color tags */
.tag-editor .red-tag .tag-editor-tag {
	color: #c65353;
	background: #ffd7d7;
}

.tag-editor .red-tag .tag-editor-delete {
	background-color: #ffd7d7;
}

.tag-editor .green-tag .tag-editor-tag {
	color: #45872c;
	background: #e1f3da;
}

.tag-editor .green-tag .tag-editor-delete {
	background-color: #e1f3da;
}

.search_submit {
	color: #555555;
	padding: 3px 10px;
	background: #eee;
	border: 1px solid darkgray !important;
	cursor: pointer;
	-webkit-border-radius: 5px;
	border-radius: 5px;
	outline: 0;
}

.search_submit:hover {
	background: #ddd;
	border: 1px solid gray !important;
	cursor: pointer;
}

.button_download_small {
	font-size: 11px;
	display: inline-block;
}

button:focus {
	outline: 0;
}

.data_row_record {
	font-size: 12px;
	color: #666666;
	overflow: hidden;
	padding-left: 25px;
	padding-top: 3px;
	padding-bottom: 3px;
	border: none;
	background-color: #fafafa;
	position: relative;
}

.data_row_record:nth-child(even) {
	background-color: #ffffff;
}

.data_row_record.small {
	width: 70% !important;
}

.data_row_record:hover {
	background-color: #eaeaea !important;
	/* trick: need this for the other elements not to be overlapped with */
	opacity: .99;
}

.searched {
	display: inline;
	font-weight: bold;
	background-color: #D1D5F1;
}

.css_keyword {
	display: inline;
	float: left;
	border: 1px solid #ffa1a1;
	border-radius: 5px;
	padding-left: 3px !important;
	padding-right: 3px !important;
	margin-left: 2px !important;
	margin-right: 2px !important;
	margin-top: 1px !important;
	margin-bottom: 1px !important;
	cursor: pointer;
}

.css_keyword_disabled {
	display: inline;
	float: left;
	border: 1px solid #e1e1e1;
	border-radius: 5px;
	padding-left: 0px !important;
	padding-right: 3px !important;
	margin-left: 2px !important;
	margin-right: 2px !important;
	margin-top: 0px !important;
	margin-bottom: 0px !important;
}

.search {
	font-family: 'Roboto', sans-serif;
	font-size: 12px;
	border: 0.8px solid #c1c1c1;
	padding: 2px;
	padding-left: 4px;
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	outline: none;
	color: #555555;
	width: 200px;
}

.div_default_title {
	background: linear-gradient(to right, #f1f1f1, #ffffff);
	font-size: 16px;
	padding: 3px;
	color: #555555;
	margin-bottom: 10px;
	border-bottom: 1px solid;
	/* width: 60%; */
}

.div_default_title_small {
	width: 50%;
	background: linear-gradient(to right, #f1f1f1, #ffffff);
	font-size: 14px;
	padding: 3px;
	color: #555555;
	margin-bottom: 10px;
}

.basic_not_found_message {
	background: linear-gradient(to right, #f1a1a1, #ffffff);
	font-size: 16px;
	padding: 7px;
	color: #555555;
	margin-top: 50px;
	margin-bottom: 50px;
	border-bottom: 1px solid;
	width: 100%;
	text-align: center;
}

.run_id_button_image {
	width: 16px;
	vertical-align: middle;
	padding-right: 6px;
}

.base_section {
	margin-top: 5px;
	font-size: 12px;
	color: #666666;
	word-break: break-word;
}

.base_section.col {
	border: 0px solid #dddddd;
	padding-left: 5px;
	padding-right: 5px;
	vertical-align: top;
}

.base_section.col.notes {
	font-size: 12px;
	max-width: 1400px;
}

.base_section.col.textual {
	font-size: 12px;
}

.base_section .col .last_change {
	font-size: 12px;
	white-space: nowrap;
}

.base_section .col .nowrap {
	white-space: nowrap;
}

.base_section .title_td {
	font-weight: bold;
	/* white-space: nowrap; */
	text-align: right;
	padding-right: 10px;
}

.pagination {
	display: inline-block !important;
	font-size: 12px !important;
	/*      vertical-align: text-bottom; */
}

.pagination a {
	color: black !important;
	padding: 3px 5px !important;
	text-decoration: none !important;
	transition: background-color.3s !important;
}

.pagination a.active {
	background-color: #4CAF50 !important;
	color: white !important;
}

.pagination a.inactive {
	color: gray !important;
}

.pagination a:hover:not(.active) {
	background-color: #ddd !important;
}

.sub_header_line {
	padding-left: 10px;
	padding-bottom: 3px;
	background-color: #ffffff;
	width: 100%;
	border-bottom: 1px solid #f1f1f1;
	padding-top: 10px;
	display: flex;
	justify-content: space-between;
}

.sort_button {
	font-size: 12px;
	margin-left: 5px;
	user-select: none;
	text-align: center;
	cursor: pointer;
	margin-right: 15px;
	display: inline-block;
	border-radius: 5px;
	padding-left: 10px;
	padding-right: 10px;
	padding-top: 2px;
	padding-bottom: 2px;
	margin-bottom: 5px;
	background: #eaeaea;
}

.sort_column {
	color: gray;
	white-space: nowrap;
	-webkit-touch-callout: none;
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.sort_column:hover {
	background-color: #e1e1e1 !important;
	cursor: pointer;
}

.sort_column a {
	color: gray !important;
}

.sort_column a:hover {
	text-decoration: none !important;
}

.default_card_container {
	border-bottom: 1px dashed #f1f1f1;
	border-right: 1px dashed #e1e1e1;
	border-left: 1px dashed #e1e1e1;
	/* position: relative; */
	margin-top: 10px;
	max-height: 100vh;
	min-height: 20vh;
}

.default_card_container .card-body {
	overflow: auto;
	padding: unset;
}

.default_title {
	float: left;
	padding-left: 7px;
	padding-top: 3px;
}

.default_header_control {
	user-select: none;
	height: 22px;
	font-size: 14px;
	margin-bottom: 5px;
	background-color: #f1f1f1;
	color: #666666;
	/* table font color */
}

.default_header_control_container {
	border-bottom: 1px dashed #cccccc;
	background-color: #ffffff;
	padding: unset;
}

.quick_filter {
	background-color: #fefefe;
	border: 1px solid #fafafa;
	border-radius: 5px;
	outline: none;
	margin-top: 2px;
	margin-left: 10px;
	height: 18px;
	padding-left: 5px;
}

.quick_filter_cancel {
	cursor: pointer;
	display: none;
	padding-top: 0px;
	margin-top: 5px;
	margin-left: -15px;
	height: 10px;
	float: left;
	border-radius: 5px;
	border: 1px solid #555555;
}

.env_bar_container {
	right: 110px;
	top: 7px;
	position: absolute
}

.default_card_table {
	border-bottom: 1px dashed #f1f1f1;
	border-right: 1px dashed #e1e1e1;
	border-left: 1px dashed #e1e1e1;
	height: 80vh;
}

.default_card_table .card-body {
	overflow: auto;
	padding: unset;
}

.card-body.waiting {
	opacity: 0.5;
}

/* ---------- DNA loader spinner style ------------ */
.parent_loader {
	display: flex;
	justify-content: center;
	margin-top: 20px;
}

.loader {
	position: relative;
	display: flex;
	justify-content: center;
	align-content: center;
	width: 120px;
	height: 20px;
	margin-right: 10px;
}

.dot {
	position: relative;
	flex: 1;
	display: flex;
	justify-content: center;
	align-content: center;
	margin: 0 5px;
	height: 20px;
	width: 2px;
}

.dot:first-of-type {
	margin-left: 0
}

.dot:last-of-type {
	margin-right: 0
}

.dot::before,
.dot::after {
	content: "";
	position: absolute;
	bottom: -5px;
	display: block;
	width: 4px;
	height: 4px;
	background: #1d3f72;
	border-radius: 4px;
	box-shadow: 1px 1px 4px rgba(0, 0, 0, .15);
	animation: helix 1.25s ease-in-out infinite;
}

.dot::after {
	bottom: 100%;
	animation: helix-reversed 1.25s ease-in-out infinite;
}

.dot i {
	position: absolute;
	z-index: 25;
	align-self: center;
	width: 2px;
	height: 10px;
	background: #1d3f72;
	animation: helix-bar 1.25s ease-in-out infinite;
}

.dot2::before,
.dot2::after,
.dot2 i {
	animation-delay: 0.05s;
	background: #1d3f72;
}

.dot3::before,
.dot3::after,
.dot3 i {
	animation-delay: 0.10s;
	background: #5699d2;
}

.dot4::before,
.dot4::after,
.dot4 i {
	animation-delay: 0.15s;
	background: #5699d2;
}

.dot5::before,
.dot5::after,
.dot5 i {
	animation-delay: 0.20s;
	background: #d8ebf9;
}

.dot6::before,
.dot6::after,
.dot6 i {
	animation-delay: 0.25s;
	background: #71c2cc;
}

.dot7::before,
.dot7::after,
.dot7 i {
	animation-delay: 0.30s;
	background: #71c2cc;
}

.dot8::before,
.dot8::after,
.dot8 i {
	animation-delay: 0.35s;
	background: #4996a2;
}

.dot9::before,
.dot9::after,
.dot9 i {
	animation-delay: 0.40s;
	background: #4996a2;
}

.accordion {
	background: linear-gradient(to right, #f1f1f1, #ffffff);
	color: #444;
	cursor: pointer;
	padding: 9px;
	width: 100%;
	border: none;
	text-align: left;
	outline: none;
	transition: 0.4s;
	margin-top: 5px;
	margin-left: 3%;
}

.active.accordion:hover {
	background-color: #ccc;
}

.accordion:after {
	content: '\002B';
	color: #777;
	font-weight: bold;
	float: right;
	margin-left: 5px;
}

.active.accordion:after {
	content: "\2212";
}

.panel {
	padding: 0 18px;
	background-color: white;
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.2s ease-out;
}

@keyframes helix {
	0% {
		width: 5px;
		height: 5px;
		bottom: -5px;
		z-index: 10
	}

	25% {
		width: 2px;
		height: 2px
	}

	50% {
		width: 5px;
		height: 5px;
		bottom: 100%;
		z-index: 20
	}

	75% {
		width: 8px;
		height: 8px
	}

	100% {
		width: 5px;
		height: 5px;
		bottom: -5px
	}
}

@keyframes helix-reversed {
	0% {
		width: 5px;
		height: 5px;
		bottom: 100%;
		z-index: 20
	}

	25% {
		width: 8px;
		height: 8px
	}

	50% {
		width: 5px;
		height: 5px;
		bottom: -5px;
		z-index: 10
	}

	75% {
		width: 2px;
		height: 2px
	}

	100% {
		width: 5px;
		height: 5px;
		bottom: 100%
	}
}

@keyframes helix-bar {
	0% {
		height: 15px
	}

	25% {
		height: 8px
	}

	50% {
		height: 15px
	}

	75% {
		height: 8px
	}

	100% {
		height: 15px
	}
}

@keyframes animate-blinking {
	0% {
		opacity: 0.0;
	}

	50% {
		opacity: 0.7;
	}

	100% {
		opacity: 0.0;
	}
}

.tagify {
	max-width: -webkit-fill-available;
}

.tagify__tag {
	--tag-inset-shadow-size: 100vh;
	max-width: inherit;
	overflow-wrap: anywhere;
}

.tagify__input {
	max-width: inherit;
}
