@import url('https://fonts.googleapis.com/css?family=Roboto');

:root {
	--color-primary: #2a313f;
	--color-primary-text: #fff;

	--color-secondary: #963458;
	--color-secondary-text: #fff;

	--color-selected: #f8b060;
	--color-selected-text: #333;

	--color-hover: #c3d6e8;
	--color-hover-text: #333;

	--color-background: #eee;
	--color-background-text: #222;

	--color-surface: #fff;
	--color-surface-text: #222;

	--color-grey: #666;
	--color-border: #ccc;

	--color-green: #55bb55;
	--color-green-hover: #81C784;

	--color-yellow: #ffa000;
	--color-yellow-hover: #FFCC80;

	--color-red: #ee7777;
	--color-red-hover: #EF9A9A;

	--transition-duration: 300ms;
	--gap: 5px;
}

* {
	box-sizing: border-box;
}

a {
	color: #333;
}

::-webkit-scrollbar {
	width: 10px;
	height: 10px;
}
::-webkit-scrollbar-thumb {
	background: var(--color-hover);
}
::-webkit-scrollbar-corner {
	background: rgba(0, 0, 0, 0);
}

input:not([type=checkbox]):not([type=radio]),
select,
button {
	padding: 5px 10px;
	background: transparent;
	height: 28px;
	outline-width: 2px;
	font-size: 90%;
	border: 1px solid #ccc;
	background: var(--color-surface);
	color: var(--color-surface-text);
	transition: background var(--transition-duration),
				color var(--transition-duration),
				box-shadow var(--transition-duration),
				border var(--transition-duration);
}
textarea {
	border: 1px solid #ccc;
}
input[type=button],
input[type=reset],
input[type=submit],
button,
select {
	 padding: 5px 12px;
}
input[type=button].selected,
input[type=reset].selected,
input[type=submit].selected,
button.selected {
	background: var(--color-selected);
	color: var(--color-selected-text);
	border: 1px solid var(--color-selected);
}
input[type=button]:hover,
input[type=reset]:hover,
input[type=submit]:hover,
button:hover {
	box-shadow: 0 0 25px rgba(0, 0, 0, 0.15);
	background: var(--color-hover);
	color: var(--color-hover-text);
	border-color: var(--color-hover);
}
input[type=button]:active,
input[type=reset]:active,
input[type=submit]:active,
select:active,
button:active {
	box-shadow: inset 0 0 25px rgba(0, 0, 0, 0.25);
}
button[disabled],
button[disabled]:active,
button[disabled]:hover {
	background: var(--color-hover);
	color: var(--color-hover-text);
	box-shadow: none;
}

button > i {
	margin-right: calc(var(--gap) * 1);
}

button[type=submit],
input[type=submit] {
	background: var(--color-secondary);
	color: var(--color-secondary-text);
	letter-spacing: 1px;
}

input::placeholder {
	color: var(--color-grey);
}

a {
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
	cursor: pointer;
}
a:active {
	color: inherit;
}

@media print {

	button.side {
		display: none !important;
	}

	body > main div.pdf-watermark {
		width: 100%;
		display: block !important;
		background: var(--color-background) !important;
		margin-right: 20px;
		font-size: 110%;
		text-align: right;
		padding: 15px;
		color: var(--color-background-text) !important;
	}
}

.hidden {
	display: none !important;
}

.grey {
	color: #999;
}
.grey:hover {
	background: none;
	color: #999;
}

.notice, .warning {
	padding: 16px;
	box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
	color: #fff;
	border-radius: 0;
}
.notice {
	background: var(--color-green);
}
.warning {
	background: var(--color-red);
}
.NA {
	color: var(--color-grey);
	font-size: 90%;
}
.blur {
	filter: blur(8px);
	opacity: 0.4;
	overflow: hidden;
}

html, body {
	font-family: 'Roboto', sans-serif;
}

body {
	display: flex;
	margin: 0;
	flex-direction: column;
	user-select: none;
	font-size: 14px !important;
	background: var(--color-background);
	color: var(--color-background-text);
}
	body > #ajax-working {
		position: fixed;
		top: 10px;
		left: calc(50% - 40px);
		opacity: 0;
		user-select: none;
		padding: 5px 10px;
		font-size: 12px;
		letter-spacing: 1px;
		transition: opacity var(--transition-duration);
		box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
		background: var(--color-secondary);
		color: var(--color-secondary-text);
		width: 80px;
		z-index: 11;
	}
	body > #ajax-working.show {
		opacity: 1;
	}
	body > .menu-cover {
		width: 100%;
		height: 100%;
		position: absolute;
		background: rgba(0,0,0,0.6);
		z-index: 7;
		transition: background var(--transition-duration);
	}
	body > header {
		background: var(--color-primary);
		color: var(--color-primary-text);
		display: flex;
		position: sticky;
		top: 0;
		z-index: 10;
		flex: 50px 0 0;
		box-shadow: 0 0 25px rgba(0, 0, 0, 0.15);
	}
	body > header::-webkit-scrollbar {
		display: none;
	}
		body > header .logo {
			width: 100%;
			max-width: 220px;
			display: flex;
			overflow: hidden;
			align-items: center;
			justify-content: center;
			max-height: 50px !important;
		}
		body > header .logo:hover {
			background: none;
		}
			body > header .logo img {
				max-width: 85%;
				height: 80%;
			}
			body > header nav {
				display: flex;
				margin-right: auto;
				flex-direction: column;
				margin-right: auto;
				background: var(--color-surface);
				color: var(--color-surface-text);
				position: absolute;
				right: 0;
				top: 100%;
				box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
			}
			body > header nav > a,
			body > header .user-toggle,
			body > header .menu-toggle {
				display: flex;
				padding: 15px 20px;
				letter-spacing: 1px;
				align-items: center;
				transition: background var(--transition-duration),
							color var(--transition-duration),
							box-shadow var(--transition-duration);
			}
			body > header nav a.selected {
				background: var(--color-selected);
				color: var(--color-selected-text);
			}
			body > header nav a:hover {
				text-decoration: none;
				background: var(--color-hover);
				color: var(--color-hover-text);
			}
			body > header nav a:active {
				color: inherit;
				box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.2)
			}
		body > header .user-toggle,
		body > header .nav-toggle {
			display: flex;
			padding: 15px 20px;
			letter-spacing: 1px;
			transition: background var(--transition-duration);
			align-items: center;
			white-space: nowrap;
		}
		body > header .menu-toggle:hover,
		body > header .nav-toggle:hover {
			text-decoration: none;
			background: rgba(255, 255, 255, 0.3);
			cursor: pointer;
			transition: box-shadow var(--transition-duration);
		}

		body > header .menu-toggle:active, body > header .nav-toggle:active {
			background: rgba(255, 255, 255, 0.3);
			box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.2);
		}

		body > header .global-search {
			width: 250px;
			align-self:  center;
			margin: 0 10px 0 auto;
		}

		body > header .user-toggle {
			white-space: nowrap;
			display: flex;
		}
		body > header .user-popup {
			position: absolute;
			right: 0;
			top: 100%;
			background: var(--color-surface);
			color: var(--color-surface-text);
			box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
			padding: 15px;
			display: grid;
			width: 250px;
			flex-wrap: wrap;
			grid-auto-flow: row;
			grid-gap: calc(var(--gap) * 2 );
		}
			body > header .user-popup .name {
				font-size: 125%;
				font-weight: bold;
				width: 100%;
			}
			body > header .user-popup .email {
				color: var(--color-grey);
				width: 100%;
				user-select: text;
			}
			body > header .user-popup .links {
				display: grid;
				grid-template-columns: repeat(3, max-content);
				grid-gap: calc(var(--gap) * 2);
			}
			body > header .user-popup a:hover {
				text-decoration: underline;
				cursor: pointer;
			}

		@media (max-width: 750px) {

			body > header {
				height: auto;
				display: grid;
				grid-template-columns: 1fr max-content;
			}
				body > header .menu-toggle {
					order: 1;
				}
				body > header .logo {
					order: 2;
					margin: 0 auto;
					height: 50px;
				}
				body > header .nav-toggle {
					order: 3;
				}
				body > header .global-search {
					display: none;
					order: 4;
					grid-column: 1 / 4;
					width: 100%;
					border-bottom: 1px solid var(--color-border);
				}
				body > header .global-search.show {
					display: initial;
				}
					body > header .global-search > input.search-input {
						border-radius: 0;
						padding: 10px;
						height: auto;
					}
				body > header .user-popup.show {
					display: flex !important;
					position: static;
					order: 5;
					width: 100%;
					grid-column: 1 / 4;
					box-shadow: none;
					border-bottom: 1px dashed var(--color-border);
				}
				body > header .user-toggle {
					display: none;
				}
				body > header nav {
					position: static;
					order: 6;
					grid-column: 1 / 4;
					width: 100%;
					box-shadow: none;
				}

			main .dialog-box {
				width: calc(100% - calc(var(--gap) * 3)) !important;
				max-height: calc(100% - calc(var(--gap) * 10));
			}
		}

	.block {
		background: var(--color-surface);
		color: var(--color-surface-text);
		box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
	}

	main section.section {
		display: none;
		padding: calc(var(--gap) * 2);
	}
	main section.section.show {
		display: block;
	}
main .loading {
	margin-top: 100px;
	height: 70px;
	background-size: contain;
}

.dialog-box .body ul.user-list {
	list-style-type: none;
	padding: 0px;
	display: grid;
	grid-gap: calc(var(--gap) * 2);
	grid-template-columns: 1fr 1fr 1fr;
	margin: calc(var(--gap) * 2);
}

	.dialog-box .body ul.user-list li {
		display: flex;
		flex-direction: column;
	}

		.dialog-box .body ul.user-list li a {
			color: #333;
			font-size: 110%;
			width: fit-content;
		}
		.dialog-box .body ul.user-list li span {
			color: #999;
			font-size: 90%;
			margin-top: var(--gap);
		}

main .section > h1,
main .section > h2 {
	border-bottom: 1px dashed var(--color-border);
	margin: 0;
	text-transform: capitalize;
	padding: 3px 0 5px;
	font-weight: normal;
}

table {
	border-collapse: collapse;
	width: 100%;
}
	table thead {
		background: var(--color-primary);
		color: var(--color-primary-text);
		font-size: 90%;
	}
		table thead tr th {
			padding: 6px 8px;
			top: 0px;
			z-index: 2;
			font-weight: normal;
			background: var(--color-primary);
			color: var(--color-primary-text);
		}
		table thead th:last-child {
			border-right: 0;
		}
			table thead .sort svg {
				float: right;
				margin: 2px 0 0 var(--gap);
				display: block;
				font-size: 80% !important;
				cursor: pointer;
				opacity: 0;
				transition: opacity var(--transition-duration);
			}
			table thead th:hover .sort svg {
				opacity: 1;
			}
	table tbody tr {
		transition: background var(--transition-duration),
					color var(--transition-duration);
	}
	table tbody tr:nth-child(2n) {
		background: rgba(0, 0, 0, 0.1);
	}
	table:not(.static) tbody tr:hover {
		background: var(--color-hover);
		color: var(--color-hover-text);
	}
	table tbody tr.selected,
	table tbody tr.selected td {
		background: var(--color-selected) !important;
		color: var(--color-selected-text);
	}

		table td {
			padding: 8px;
			position: relative;
			user-select: text;
		}
			table .thin,
			table .action {
				width: 80px;
				text-align: center;
			}
			table tbody th.action,
			table td.action {
				cursor: pointer;
				transition: background var(--transition-duration),
							color var(--transition-duration),
							box-shadow var(--transition-duration);
			}
			table td.action:not(.NA):hover {
				background: var(--color-secondary);
				color: var(--color-secondary-text);
				cursor: pointer;
			}
			table tbody th.action.green:not(.NA):hover,
			table td.action.green:not(.NA):hover {
				background: transparent;
				color: #5b5;
			}
			table tbody th.action.red:not(.NA):hover,
			table td.action.red:not(.NA):hover {
				background: transparent;
				color: #e77;
			}

.form {
	display: grid;
	padding: calc(var(--gap) * 2);
	grid-gap: calc(var(--gap) * 4);
}
	.form label,
	.form .label {
		display: grid;
		grid-gap: var(--gap);
		max-width: 200px;
		white-space: nowrap;
		max-height: max-content;
	}
		.form label > span,
		.form .label > span {
			font-size: 90%;
			font-weight: bold;
			letter-spacing: 0.5px;
			display: flex;
			align-items: center;
		}
			.form label > span span,
			.form .label > span span {
				font-weight: normal;
				margin-left: var(--gap);
			}
			.form label > span .right,
			.form .label > span .right {
				margin-left: auto;
			}
			.form label > span .red,
			.form .label > span .red {
				color: var(--color-red);
			}
.toolbar {
	display: grid;
	grid-gap: calc(var(--gap) * 2);
	grid-auto-columns: max-content;
	padding: calc(var(--gap) * 2) 0;
	grid-template-columns: repeat(auto-fit, minmax(75px, max-content));
}
	main .toolbar button {
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

.dialog-box-blanket {
	background: rgba(0, 0, 0, 0.6);
	position: fixed;
	bottom: 0;
	right: 0;
	top: 0;
	left: 0;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 20px;
}
	.dialog-box {
		display: flex;
		flex-direction: column;
		background: var(--color-background);
		color: var(--color-background-text);
		box-shadow: 0 0 100px rgba(0, 0, 0, 0.5);
		position: fixed;
		max-height: 80%;
		min-width: 40%;
		max-width: 90%;
		align-self: center;
		justify-self: center;
	}
		.dialog-box .body {
			overflow: auto;
		}
		.dialog-box > header {
			display: grid;
			grid-template-columns: max-content 1fr;
			background: var(--color-primary);
			color: var(--color-primary-text);
			box-shadow: 0 0 25px rgba(0, 0, 0, 0.25);
		}
			.dialog-box header h3 {
				margin: 0;
				padding: calc(var(--gap) + 3px);
				font-weight: normal;
				font-size: 100%;
			}
			.dialog-box header span.close {
				cursor: pointer;
				padding: 5px calc(var(--gap) * 2);
				display: flex;
				margin-left: auto;
				align-items: center;
				transition: box-shadow var(--transition-duration),
							background var(--transition-duration);
			}
			.dialog-box header span.close:hover {
				background: rgba(255, 255, 255, 0.3);
			}
			.dialog-box header span.close:active {
				box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.4)
			}

.global-search {
	width: 100%;
	position: relative;
}
	.global-search > input.search-input {
		width: 100%;
		border-radius: 5px;
		border: 0px !important;
		align-self: center;
	}
	.global-search > input.search-input.bottom-border {
		border-radius: 5px 5px 0px 0px;
	}
	.global-search ul {
		margin: 0;
		padding: 5px 0;
		list-style-type: none;
		background: var(--color-surface);
		color: var(--color-surface-text);
		box-shadow: 0 0 25px rgba(0, 0, 0, 0.25);
		position: absolute;
		right: 0;
		left: 0;
		max-height: 400px;
		overflow: auto;
	}
		.global-search ul li {
			outline: 0;
			display: grid;
			transition: background var(--transition-duration), box-shadow var(--transition-duration);
			grid-template-columns: 1fr max-content;
		}
		.global-search ul li:active {
			box-shadow: inset 0 0 25px rgba(0, 0, 0, 0.1);
		}
		.global-search ul li:focus,
		.global-search ul li:hover {
			background: var(--color-hover);
			color: var(--color-hover-text);
		}
			.global-search ul li > span.loading {
				display: flex;
				justify-content: center;
				height: 100%;
				font-size: 150%;
				padding: 5px;
				color: var(--color-surface-text);
				background: var(--color-surface);
			}
			.global-search ul li a {
				outline: 0;
				padding: 10px 10px;
				height: 100%;
				align-items: center;
				display: flex;
			}
			.global-search ul li a:hover {
				background: none;
				text-decoration: none;
			}
			.global-search ul li .li-edit {
				padding: 0 10px;
				align-self: center;
				cursor: pointer;
				opacity: 0;
				transition: var(--transition-duration);
				display: flex;
				height: 100%;
				align-items: center;
				outline: 2px;
			}
			.global-search ul li:focus .li-edit,
			.global-search ul li:hover .li-edit {
				opacity: 1;
			}

.multi-select {
	width: 100%;
	position: relative;
	background: var(--color-surface);
}
.multi-select.stretched {
	display: grid;
	z-index: 0;
}
	.multi-select .screen {
		border: 1px solid var(--color-border);
		padding: 5px 10px;
		font-size: 90%;
		height: 28px;
		width: 100%;
		color: var(--color-grey);
		overflow: hidden;
		display: flex;
	}
	.multi-select.disabled .screen,
	.multi-select.disabled a {
		color: #ccc;
	}
	.multi-select .options {
		display: flex;
		flex-direction: column;
		border: 1px solid var(--color-border);
		background: var(--color-surface);
		color: var(--color-surface-text);
		box-shadow: 0 0 25px rgba(0, 0, 0, 0.15);
		max-height: 250px;
		width: 100%;
		position: absolute;
		z-index: 5;
		overflow: auto;
	}
	.multi-select.top .options {
		bottom: 100%;
		border-bottom: 0;
	}
	.multi-select.bottom .options {
		border-top: 0;
	}
	.multi-select.stretched .options {
		position: initial;
		height: 220px;
		box-shadow: none;
	}
	.multi-select.top.stretched .options {
		grid-row: 1;
	}
		.multi-select .options header,
		.multi-select-expanded .options header {
			border-bottom: 1px dashed #999;
			font-size: 85%;
			display: grid;
			grid-template-columns: repeat(2, auto) 1fr auto;
			justify-content: flex-start;
			color: #999;
			align-items: center;
			position: relative;
		}
			.multi-select .options header a {
				padding: var(--gap);
			}
			.multi-select .options header .search-column-filter.global-filter {
				grid-row: 1;
				grid-column: 1 / 5;
			}
				.multi-select .options header .search-column-filter.global-filter > input {
					width: 100%;
					border: 0;
					border-bottom: 1px solid #ccc;
					height: auto;
				}
			.multi-select .options header select[name=mode] {
				margin-left: auto;
				grid-column: 4;
				border: none;
				height: auto;
				outline: 0;
				width: 100%;
				padding: var(--gap);
			}
			.multi-select .options header select[name=mode]:active {
				box-shadow: none;
			}
		.multi-select .options > .NA,
		.multi-select .options .list > .NA ,
		.multi-select-expanded .options > .NA {
			padding: calc(var(--gap) * 2);
			text-align: center;
			margin: 10px;
			background: var(--color-surface);
		}
		.multi-select .options .list {
			padding: var(--gap) 0;
			max-height: 200px;
			overflow: auto;
		}
			.multi-select .options .list label,
			.multi-select-expanded .options .list label {
				display: grid;
				grid-template-columns: auto 1fr;
				grid-gap: var(--gap);
				align-items: center;
				padding: calc(var(--gap) * 2);
				margin: 0;
				max-width: inherit;
				overflow: hidden;
				white-space: initial;
				transition: background var(--transition-duration),
							box-shadow var(--transition-duration);
				background: var(--color-surface);
				color: var(--color-surface-text);
			}
			.multi-select-expanded .options .list label.grey {
				color: #999;
			}
			.multi-select-expanded .options .list label {
				box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
			}
			.multi-select .options .list label:hover,
			.multi-select .options .list label.hover,
			.multi-select-expanded .options .list label.hover,
			.multi-select-expanded .options .list label:hover {
				background: var(--color-hover);
				color: var(--color-hover-text);
				cursor: pointer;
			}
			.multi-select .options .list label:active,
			.multi-select-expanded .options .list label:active {
				box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.3);
			}
			.multi-select .options .list label.selected,
			.multi-select-expanded .options .list label.selected {
				background: var(--color-selected);
				color: var(--color-selected-text);
			}
				.multi-select .options .list label .option-name,
				.multi-select-expanded .options .list label .option-name {
					display: grid;
				}
					.multi-select .options .list label.grey .option-name span,
					.multi-select-expanded .options .list label.grey .option-name span {
						color: #999;
					}
					.multi-select .options .list label .option-name .subtitle,
					.multi-select-expanded .options .list label .option-name .subtitle {
						color: var(--color-grey);
						font-size: 90%;
						margin-top: var(--gap);
					}
			.multi-select-expanded .search-column-filters {
				margin-bottom: 0;
			}
		.multi-select footer {
			display: grid;
			margin-top: auto;
			grid-template-columns: repeat(4, auto);
			grid-gap: calc(var(--gap) * 2);
			padding: var(--gap);
			font-size: 85%;
			box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
			color: var(--color-grey);
			white-space: nowrap;
			border-top: 1px dashed var(--color-border);
			overflow: auto;
		}
		.multi-select footer::-webkit-scrollbar {
			display: none;
		}
			.multi-select footer > span strong {
				margin-left: 3px;
			}
.multi-select-expanded .options {
}
	.multi-select-expanded .options header {
		grid-template-columns: repeat(3, auto) 1fr auto;
		padding: 10px 0;
		margin: 0 10px;
		grid-gap: calc(var(--gap) * 2);
		position: sticky;
		top: 0;
		background: var(--color-background);
		position: -webkit-sticky;
	}
		.multi-select-expanded header .search-column-filters {
			grid-column: 1 / 6;
			grid-row: 2;
		}
			.multi-select-expanded header > .search-column-filters .NA,
			.multi-select-expanded header > .search-column-filters button {
				font-size: 100%;
			}
		.multi-select-expanded header > .search-column-filter {
			grid-column: 5;
			margin-left: auto;
		}
		.multi-select-expanded header select[name=mode] {
			grid-column: 4;
			margin-left: auto;
		}
	.multi-select-expanded .options .list {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		grid-gap: calc(var(--gap) * 2);
		padding: 10px;
	}
		.multi-select-expanded .options .list label {
			min-height: 55px;
			max-height: 100px;
			overflow: auto;
		}
		.multi-select-expanded .options .list label::-webkit-scrollbar {
			display: none;
		}
	.multi-select-expanded footer {
		padding: 8px 10px;
		display: grid;
		grid-gap: 20px;
		grid-template-columns: repeat(4, max-content);
		background: var(--color-primary);
		color: var(--color-primary-text);
		position: sticky;
		bottom: -1px;
		font-size: 95%;
		box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
	}

.object-roles {
	min-height: 300px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	background: var(--color-surface);
	color: var(--color-surface-text);
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
.dialog-box .object-roles {
	border-top: 1px solid white;
}
	.object-roles > table thead th {
		position: sticky;
		top: 0;
		white-space: nowrap;
		border-right: 1px solid var(--color-border);
		z-index: 0;
	}
	#object-roles-already-viewed thead th:last-child {
		border: 0;
	}
	.object-roles > form {
		width: 100%;
		border-top: 1px solid var(--color-border);
		display: grid;
		position: sticky;
		bottom: 0;
		background: var(--color-surface);
		color: var(--color-surface-text);
		grid-template-columns: 1fr 1fr 1fr;
		grid-auto-flow: column;
		grid-gap: calc(var(--gap) * 2);
		padding: calc(var(--gap) * 2);
		z-index: 2;
	}
	.object-roles table th:last-child {
		border-right: none;
	}

.query-history {
	margin-left: calc(var(--gap) * 2);
}
	.query-history a {
		color: #888;
		width: max-content;
	}
	.query-history .loading {
		display: flex;
		justify-content: center;
		margin-top: 10px;
		height: max-content;
	}
		.query-history .loading > span {
			font-size: large;
		}
	.query-history .info,
	.query-history .list {
		height: 100%;
	}
		.query-history .list .NA {
			padding: calc(var(--gap) * 2);
		}
		.query-history .list h3 {
			margin: 0;
			padding-bottom: 10px;
			font-size: 110%;
			position: sticky;
			top: 0;
			background: var(--color-background);
		}
		.query-history ul {
			margin: 0;
			list-style-type: none;
			padding: 0;
			grid-gap: calc(var(--gap) * 2);
			display: grid;
		}
			.query-history ul li {
				display: grid;
				grid-template-columns: max-content 1fr;
				grid-gap: calc(var(--gap) * 2);
				padding: calc(var(--gap) * 2);
				transition: background var(--transition-duration),
							box-shadow var(--transition-duration);
			}
			.query-history ul li:not(.NA):hover {
				background: var(--color-hover);
				box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
				cursor: pointer;
			}
			.query-history ul li:not(.NA):active {
				box-shadow: inset 0 0 25px rgba(0, 0, 0, 0.15);
			}
				.query-history ul li .clock {
					font-size: 30px;
					padding: 0;
					color: #aaa;
					align-items: center;
					display: flex;
					grid-row: 1 / 3;
				}
		.query-history .list .footer {
			display: flex;
			padding: calc(var(--gap) * 2);
			color: #888;
			font-size: 90%;
			margin-top: calc(var(--gap) * 2);
			background: var(--color-surface);
			color: var(--color-surface-text);
			box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
			cursor: pointer;
			transition: background var(--transition-duration),
						box-shadow var(--transition-duration);
		}
		.query-history .list .footer:hover {
			background: var(--color-hover);
			color: var(--color-hover-text);
		}
		.query-history .list .footer:active {
			box-shadow: inset 0 0 25px rgba(0, 0, 0, 0.15);
		}
			.query-history .list .footer .more {
				margin-left: 45%;
			}
			.query-history .list .footer .more span {
				margin: 0 15px;
			}
		.query-history .list .footer .showing {
			margin-left: auto;
			position: sticky;
			bottom: 0;
		}
		.query-history .info .toolbar {
			position: sticky;
			top: 0;
			background: var(--color-background);
			z-index: 2;
			display: flex;
			align-items: center;
		}
		.query-history .info .toolbar.visualization {
			display: grid;
			grid-auto-columns: max-content;
			grid-template-columns: repeat(auto-fit, minmax(75px, max-content));
			grid-gap: calc(var(--gap) * 2);
		}
			.query-history .info .toolbar.visualization button {
				margin: 0;
			}
			.query-history .info .toolbar button {
				margin-right: calc(var(--gap) * 2);
			}
			.query-history .info .toolbar span {
				padding-right: calc(var(--gap) * 2);
				color: #888;
				margin-left: auto;
			}
		.query-history .info .query input:disabled,
		.query-history .info .query select:disabled {
			color: #333;
		}
		.query-history .info .code-editor {
			height: 100%;
		}

.snack-bar-container {
	display: grid;
	grid-gap: 15px;
	padding: 15px;
	position: fixed;
	overflow: auto;
	max-height: 100vh;
	min-width: 300px;
	max-width: 400px;
	z-index: 6;
}
.snack-bar-container::-webkit-scrollbar {
	display: none;
}
.snack-bar-container.top {
	top: 0;
	left: 50%;
}
.snack-bar-container.top-right {
	top: 0;
	right: 0;
}
.snack-bar-container.bottom-right {
	bottom: 0;
	right: 0;
}
.snack-bar-container.bottom {
	bottom: 0;
	left: 50%;
}
.snack-bar-container.bottom-left {
	bottom: 0;
	left: 0;
}
.snack-bar-container.top-left {
	top: 0;
	left: 0;
}
	.snack-bar {
		background: #eee;
		box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
		border-radius: 4px;
		padding: 10px 20px;
		color: #fff;
		letter-spacing: 1px;
		opacity: 0;
		display: grid;
		align-items: center;
		width: 100%;
		grid-template-columns: max-content 1fr max-content;
		grid-column-gap: calc(var(--gap) * 4);
		grid-row-gap: var(--gap);
		margin-bottom: -50px;
		cursor: pointer;
		transition: opacity var(--transition-duration),
					margin-bottom var(--transition-duration),
					box-shadow var(--transition-duration);
	}
	.snack-bar.show {
		opacity: 1;
		margin-bottom: 0;
	}
	.snack-bar:active {
		box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.2);
	}
	.snack-bar.success {
		background: var(--color-green);
	}
	.snack-bar.warning {
		background: var(--color-yellow);
	}
	.snack-bar.error {
		background: var(--color-red);
	}
		.snack-bar .icon {
			font-size: 125%;
			grid-row: 1 / 3;
		}
		.snack-bar .title {
			margin: 0;
			font-size: 110%;
		}
		.snack-bar .title.no-subtitle {
			grid-row: 1 / 3;
		}
		.snack-bar .subtitle {
			font-size: 90%;
			color: #eee;
			grid-column: 2 / 3;
		}
			.snack-bar .subtitle .NA {
				color: #eee;
			}
		.snack-bar .close {
			font-size: 125%;
			grid-row: 1 / 3;
			grid-column: 3;
			color: #eee;
			transition: color var(--transition-duration);
		}
		.snack-bar .close:hover {
			color: #fff;
		}

@media (max-width: 750px) {

	.snack-bar-container {
		max-width: 100%;
	}

	.dialog-box > header {
		grid-template-columns: 1fr 30px;
	}
	.dialog-box > header::-webkit-scrollbar {
		display: none;
	}
	.multi-select-expanded .options .list {
		grid-template-columns: 1fr;
	}
	.multi-select-expanded .options header {
		grid-template-rows: max-content max-content;
		grid-template-columns: repeat(4, 1fr);
	}
		.multi-select-expanded header > .search-column-filter {
			grid-column: 1 / 5;
			margin-left: 0;
			max-width: 100%;
			width: 100%;
		}
			.multi-select-expanded header > .search-column-filter .searchQuery {
				width: 100%;
			}
		.multi-select-expanded header .search-column-filters {
			grid-column: 1 / 5;
			grid-row: 3;
		}
		.multi-select-expanded header select[name=mode] {
			grid-column: 4;
			margin-left: auto;
		}
	.multi-select-expanded footer {
		overflow: auto;
	}
}

.html-editor {
	position: relative;
}
	.html-editor .editor-toggle {
		display: grid;
		grid-template-columns: max-content max-content;
		grid-gap: calc(var(--gap) * 2);
		position: absolute;
		right: 0;
		top: var(--gap);
		z-index: 2;
		color: var(--color-secondary-text);
		font-size: 90%;
		border-radius: 3px;
		letter-spacing: 1px;
		transition: box-shadow var(--transition-duration);
	}
		.html-editor .editor-toggle > button {
			display: inline-block;
			background: var(--color-secondary);
			color: var(--color-secondary-text);
		}
		.html-editor .editor-toggle > button:hover {
			cursor: pointer;
		}
			.html-editor .editor-toggle button > span {
				display: none;
			}
			.html-editor .editor-toggle button:hover > span {
				display: initial;
				padding-left: 5px;
			}
			.html-editor .editor-toggle button i {
			margin-right: 0;
			}
	.html-editor .editor-toggle:active {
		box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.15);
	}

[data-tooltip] {
	position: relative;
	display: inline-block;
}

[data-tooltip]::before {
	content: "";
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%);
	border-width: 8px 6px 0 6px;
	border-style: solid;
	border-color: rgba(0, 0, 0, 0.7) transparent transparent transparent;
	z-index: 8;
	display: none;
}

[data-tooltip-position='left']::before {
	left: 0%;
	top: 50%;
	margin-left: -12px;
	transform: translateY(-50%) rotate(-90deg)
}

[data-tooltip-position='top']::before {
	left: 50%;
}

[data-tooltip-position='bottom']::before {
	top: 100%;
	margin-top: 8px;
	transform: translateX(-50%) translateY(-100%) rotate(-180deg)
}
[data-tooltip-position='right']::before {
	left: 99%;
	top: 50%;
	margin-left: 1px;
	transform: translateY(-50%) rotate(90deg)
}

[data-tooltip]::after {
	content: attr(data-tooltip);
	position: absolute;
	white-space: pre;
	left: 50%;
	top: -6px;
	transform: translateX(-50%) translateY(-100%);
	background: rgba(0, 0, 0, 0.7);
	text-align: center;
	color: #fff;
	padding: 4px 2px;
	font-size: 10px;
	min-width: 80px;
	border-radius: 5px;
	letter-spacing: 0.4px;
	pointer-events: none;
	padding: 8px;
	z-index: 8;
	display: none;
}

[data-tooltip-position='left']::after {
	left: 0%;
	top: 50%;
	margin-left: -8px;
	transform: translateX(-100%) translateY(-50%);
}

[data-tooltip-position='top']::after {
	left: 50%;
}

[data-tooltip-position='bottom']::after {
	top: 100%;
	margin-top: 8px;
	transform: translateX(-50%) translateY(0%);
}

[data-tooltip-position='right']::after {
	left: 100%;
	top: 50%;
	margin-left: 8px;
	transform: translateX(0%) translateY(-50%);
}

[data-tooltip]:hover::after,
[data-tooltip]:hover::before {
	display: block;
}

.search-column-filters {
	padding: calc(var(--gap) * 2);
	background: var(--color-surface);
	color: var(--color-surface-text);
	margin-bottom: calc(var(--gap) * 2);
	max-height: 200px;
	overflow: auto;
	display: flex;
	justify-content: space-between;
}
@media (max-width:750px) {
	.search-column-filters {
		display: grid;
		grid-gap: calc(var(--gap) * 2);
	}
}
	.search-column-filters .add-filter {
		position: sticky;
		top: 0;
	}
	.search-column-filters .filters {
		display: grid;
		grid-gap: calc(var(--gap) * 2);
		align-items: center;
	}
		.search-column-filters .filters > .NA {
			height: 28px;
			align-items: center;
			display: flex;
		}
		.search-column-filters .search-column-filter {
			display: grid;
			grid-gap: calc(var(--gap) * 2);
			grid-auto-flow: column;
		}
		.search-column-filters .search-column-filter .delete:hover{
			color: var(--color-red);
		}
			.search-column-filters .search-column-filter .delete .delete-icon{
				margin: 0;
			}
		.search-column-filter.global-filter {
			display: flex;
		}
			.search-column-filter.global-filter .advanced {
				padding: 5px 8px;
				border-left: 0;
			}
				.search-column-filter.global-filter .advanced i {
					margin: 0px;
				}
.notification-bar-container {
	width: 100%;
	z-index: 6;
	overflow: auto;
	max-height: 100px;
}
	.notification-bar {
		text-align: center;
		color: #fff;
		padding: var(--gap);
		border-top: 1px solid var(--color-border);
		box-shadow: none;
		display: flex;
		transition: background var(--transition-duration),
					box-shadow var(--transition-duration);
	}
	.notification-bar:first-of-type {
		border-top: 0;
	}
	.notification-bar .title {
		flex: 1;
	}
	.notification-bar.action {
		cursor: pointer;
	}
	.notification-bar.success {
		background: var(--color-green);
	}
	.notification-bar.success.action:hover {
		background-color: var(--color-green-hover);
	}
	.notification-bar.warning {
		background: var(--color-yellow);
	}
	.notification-bar.warning.action:hover {
		background-color: var(--color-yellow-hover);
	}
	.notification-bar.error {
		background: var(--color-red);
	}
	.notification-bar.error.action:hover {
		background-color: var(--color-red-hover);
	}
	.notification-bar.action:active {
		box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.3);
	}
		.notification-bar .close {
			font-size: 100%;
			position: absolute;
			right: 0;
			color: #eee;
			margin-right: 10px;
			transition: color var(--transition-duration),
						box-shadow var(--transition-duration);
		}
		.notification-bar .close:hover {
			color: #fff;
		}
		.notification-bar .close:active {
			box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.4);
		}

.dialog-box-blanket.keyboard-shortcuts .body {
	display: grid;
	grid-gap: 20px;
	padding: 20px;
}
	.dialog-box-blanket.keyboard-shortcuts .shortcut {
		display: grid;
		grid-template-columns: 110px 1fr;
		align-items: center;
		grid-row-gap: var(--gap);
		grid-column-gap: 20px;
	}
		.dialog-box-blanket.keyboard-shortcuts .shortcut .keys {
			grid-row: 1 / 3;
			font-size: 135%;
			text-align: right;
			color: var(--color-secondary);
			font-family: monospace;
		}
		.dialog-box-blanket.keyboard-shortcuts .shortcut .title {
			font-size: 115%;
		}
		.dialog-box-blanket.keyboard-shortcuts .shortcut .description {
			color: var(--color-grey);
		}



/* TinyMCE configurtions for theme */

.mce-notification.mce-notification-warning {
	display: none !important;
}
.tox,
.tox .tox-mbtn,
.tox .tox-menubar,
.tox .tox-toolbar,
.tox .tox-tbtn,
.tox .tox-statusbar {
	background: transparent !important;
	color: inherit !important;
	border: 0 !important;
}
.tox .tox-menu,
.tox .tox-collection__item {
	background: var(--color-surface) !important;
	color: var(--color-surface-text) !important;
}
.tox .tox-collection__item-label > * {
	color: var(--color-surface-text) !important;
}
.tox .tox-collection__item-accessory {
	color: var(--color-grey) !important;
}
.tox .tox-statusbar__resize-handle svg,
.tox .tox-tbtn svg {
	fill: var(--color-surface-text) !important;
}
.tox .tox-tbtn:hover,
.tox .tox-mbtn:hover {
	background: var(--color-hover) !important;
	color: var(--color-hover-text) !important;
}
.tox .tox-menu {
	z-index: 7;
}
.tox .tox-menu,
.tox .tox-collection--list .tox-collection__group,
.tox .tox-toolbar__group:not(:last-of-type) {
	border-color: var(--color-border) !important;
}
.tox .tox-collection__item.tox-collection__item--active {
	background: var(--color-hover) !important;
	color: var(--color-hover-text) !important;
}
.tox .tox-statusbar {
	margin-top: 5px !important;
	font-size: 11px !important;
}
.tox .tox-statusbar__branding {
	display: none;
}
body#tinymce,
body#tinymce table tr {
	background: transparent !important;
	color: initial !important;
}

.tableHeaders {
	cursor: pointer;
}
.add-translations-container {
	display: flex;
	flex-direction: column;
	padding: calc(var(--gap) * 2);
}
	.add-translations-container .translation-editor-label {
		max-width: unset;
	}
		.add-translations-container label span i {
			margin-right: 0;
		}
		.add-translations-container .action.green:not(.NA):hover {
			background: transparent;
			color: #5b5;
		}
		.add-translations-container .action.red:not(.NA):hover {
			background: transparent;
			color: #e77;
		}
		.add-translations-container form {
			padding: calc(var(--gap) * 2) 0 0;
		}
		.add-translations-container .add-form {
			padding: calc(var(--gap) * 2) 0 0;
		}
		.add-translations-container .toolbar {
			grid-gap: var(--gap);
		}
#phrases-translations .translation-grid {
	display: grid;
	grid-gap: calc(var(--gap) * 2);
	text-align: center;
	align-items: center;
	padding: 0;
	margin: 0;
}
	#phrases-translations .translation-grid i {
		margin-right: 0;
	}
	#phrases-translations .translation-grid select,
	#phrases-translations .translation-grid input {
		width: 100%;
	}
#phrases-translations #translations-headers {
	padding: var(--gap) 0;
}
#phrases-translations #list-container{
	display: flex;
	flex-direction: column;
}
	#phrases-translations #list-container .NA {
		padding: calc(var(--gap) * 2) 0 0;
	}
#phrases-translations .add {
	max-width: max-content;
}
#phrases-translations .translation-headers {
	background: var(--color-surface);
	padding: var(--gap);
}
#phrases-translations #list-container .translation-header-container {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
}
#phrases-translations #translations-advanced-search {
	margin-top: calc(var(--gap) * 2);
}
#phrases-translations .translations-list-view {
	padding: 0;
}
#phrases-translations .translations-expanded-row{
	padding-top: var(--gap);
}
.tableHeaders[data-no-sort] {
	cursor: auto;
}
.filters .footer .counts {
	display: none;
}
	.filters .footer .counts .value {
		user-select: all;
	}

.add-translation-label input {
	width: 200px;
}
.add-translation-label .add-translation-button {
	margin-left: calc(var(--gap) * 2);
}
	.add-translation-label .add-translation-button i,
	.add-translation-div i {
		margin-right: 0;
	}
.add-translation-label .add-translation-div {
	display: grid;
	grid-gap: 0;
	grid-template-columns: 1fr 1fr;
}
.add-translation-div span {
	padding-right: var(--gap);
}
.fork {
	padding: 5px 10px 0 10px;
}
.fork-form,
.fork {
	display:grid;
	grid-template-columns: 1fr;
	grid-gap: 10px;
}
	.fork .log-box {
		display: flex;
		flex-direction: column;
	}
		.fork .log-box .log {
			background: var(--color-surface);
			box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.15);
			margin: 5px 0 0 0;
		}
	.fork .log {
		max-height: 100px;
		overflow: auto;
		background: var(--color-surface);
		box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.15);
	}
		.fork .log .green,
		.fork .log-box .green {
			color: var(--color-green);
			padding: 5px;
		}
		.fork .log .red,
		.fork .log-box .red,
		.fork label span .red {
			color: var(--color-red);
			padding: 5px;
		}

	.fork .visualization-fork-target-select {
		max-width: 200px;
	}
	.fork .footer {
		display: grid;
		grid-template-columns: 1fr max-content max-content;
		grid-gap: calc(var(--gap) * 2);
		align-items: flex-end;
		padding: 0 0 10px 0;
	}
		.fork .footer button {
			height: auto;
			padding: 8px 18px;
			font-size: 100%;
			grid-column: 3;
		}
	.fork .fork-progress-bar-container {
		display: flex;
		flex-direction: column;
	}
		.fork .fork-progress-bar-container progress {
			width: 100%;
		}

	.fork-form label,
	.fork-form > div {
		display: flex;
		flex-direction: column;
	}
	.fork-form label {
		max-width: 200px;
	}
	.fork-form label input {
		max-width: 200px;
	}
		.fork-form label span,
		.fork-form > div label span {
			padding: 0 0 5px 0;
		}

.list-manager,
.list-manager .items {
	display: grid;
	grid-gap: calc(var(--gap) * 2);
}
	.list-manager .add-item {
		border-bottom: 1px dashed;
		max-width: max-content;
		padding-bottom: calc(var(--gap) * 2);
	}
		.list-manager .add-item button:hover {
			color: var(--color-green-hover);
		}
	.list-manager .item {
		display: grid;
		grid-gap: calc(var(--gap) * 2);
		grid-template-columns: 200px 65px;
	}
		.list-manager .items .item button:hover {
			color: var(--color-red-hover);
		}
		.list-manager .items .item button i {
			margin: 0;
		}

.no_plan {
	width: 100vw;
	height: calc(100vh - 60px);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 200%;
	font-weight: bold;
	flex-direction: column;
}
 #countdown {
 	    margin: 10px;
 }