﻿button:focus {
	outline: none;
}

fieldset:disabled #markersAssigned {
	cursor: not-allowed;
}
fieldset:disabled #markersAssigned .list-group-item {
	padding-right: 14px;
	pointer-events: none;
}

fieldset:disabled #markersAssigned .list-group-item > button {
	display: none;
}

.ui-menu {
	background: white;
	border: 1px solid #e4e4e4;
	list-style: none;
	padding-left: 0;
	position: absolute;
	box-shadow: 2px 3px 15px rgba(0, 0, 0, .1);
}
.ui-menu-item {
	cursor: pointer;
	padding: 8px 10px;
}
.ui-menu-item:hover {
	background-color: #e4e4e4;
}

.ui-helper-hidden-accessible {
	display: none;
}

.d-none {
	display: none;
}

.list-group {
	padding: 0;
	font-family: 'Poppins', sans-serif;
	margin: 0;
}
.list-group .list-group {
	padding: 10px 0 10px 10px;
}

.list-group-item {
	list-style: none;
	font-weight: normal;
	user-select: none;
	line-height: 25px;
	position: relative;
}
.list-group-item > button {
	border: none;
	border-left: 3px solid transparent;
	width: 20px;
	height: 20px;
	padding: 3px;
	cursor: pointer;
	line-height: 0;
	border: 2px solid #333;
	font-weight: 700;
	background: none;
	color: #333;
	font-size: 18px;
	position: absolute;
	right: 15px;
	top: 15px;
}
.list-group-item > .list-group {
	margin-top: 0 !important;
}

.list-group-item.contains_selected > button {
	border-color: var(--primary);
	background: var(--primary);
	color: white;
}
.list-group-item.contains_selected > span::before {
	/* 10px margin + 2px border (to look same as a tag) */
	content: '';
	position: absolute;
	height: calc(100% + 2 * 12px);
	top: -12px;
	bottom: -12px;
	left: -12px;
	border-left: 4px solid var(--primary);
}
.list-group-item:first-child {
	margin-top: 0;
}
.list-group-item:last-child {
	margin-bottom: 0;
}

#markersAssigned .list-group-item,
.marker-selector:not([avoid-display]) {
	color: #333;
	font-size: 12px;
	text-transform: uppercase;
	font-weight: bold;
	cursor: pointer;
	border: 2px solid #e4e4e4;
	padding: 0 14px;
	display: inline-block;
	margin: 4px 3px;
}

.list-group-item.contains_selected >
.marker-selector:not([avoid-display]):not([state=selected])
{
	background-color: #e4e4e4;
}

.list-group-item button + span {
	/* line-height: 50px; */
	position: relative;
	margin: 10px !important;
	border: 2px solid transparent;
	display: inline-block;
}
.list-group-item {
	margin: 10px 0;
	border: 1px solid #e4e4e4;
}
.list-group-item > .list-group {
	margin-top: 10px;
	/* border: 1px solid #e4e4e4; */
	/* border-bottom: none; */
	margin-left: -1px;
	margin-right: -1px;
}

.list-group-item > .list-group .list-group-item:not(.marker-selector) {
	margin: 0;
}
.list-group-item > .list-group .list-group-item:not(.marker-selector) + .list-group-item:not(.marker-selector) {
	border-top: none;
}
.list-group-item > .list-group .list-group-item.marker-selector + .list-group-item:not(.marker-selector),
.list-group-item > .list-group .list-group-item:not(.marker-selector) + .list-group-item.marker-selector
{
	margin-top: 10px;
}

.list-group-item > .list-group {
	margin-left: 20px;
}

#markersAssigned .list-group-item[state=selected],
.marker-selector[state=selected] {
	border-color: black;
	background-color: black;
	color: white;
	font-weight: bold;
}

#markersAssigned {
	display: flex;
	grid-gap: 10px;
	flex-wrap: wrap;
	align-items: start;
	align-content: start;
	margin: 0;
}
#markersAssigned .list-group-item {
	margin: 0;
	padding-right: calc(5px + 30px);
}
#markersAssigned .btn {
	background: unset;
	color: #333;
	font-weight: 700;
	height: unset;
	padding: 0;
	position: absolute;
	top: -2px;
	right: -2px;
	bottom: -2px;
	width: 30px;
	border: none;
}
#markersAssigned .list-group-item[state=selected] .btn {
	color: white;
}
#markersAssigned .btn:hover {
	color: white;
	background-color: red;
	background-image: url(/defs.svg#close);
}
