/* dropdown_ */

div.dropdown_ {
	position: relative;

	display: inline-flex;
}

div.dropdown_ > button {
	width: 100%;

    text-align: left;
}

div.dropdown_ > button > div.input span:has(> span.icon) {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
}

div.dropdown_ > button > div.input span.icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

div.dropdown_ > button > div.input span.icon > i,
div.dropdown_ > button > div.input span.icon > ion-icon {
	min-width: 1rem;
	min-height: 1rem;

	display: inline-flex;
	align-items: center;
	justify-content: center;

	font-size: 1rem;
}

div.dropdown_ > aside.floater-dropdown {
	opacity: 0;
	visibility: hidden;
}

aside.floater-dropdown {
	position: fixed;

	z-index: 888888888;
}

/* list */

aside.floater-dropdown {
	background: var(--color-white);
	border: 1px solid var(--color-dark-16);
	box-shadow: 0 0.5rem 5rem -1rem var(--color-dark-16);

	border-radius: 0.75rem;

	padding: 0.25rem 0;

	display: flex;
	flex-direction: column;

	min-width: 10rem;
	max-height: calc(100vh - 4rem);

	overflow-y: auto;
}

aside.floater-dropdown div.block {
    padding: .5rem .75rem;
}

aside.floater-dropdown div.block div.header {
    margin-bottom: .75rem;
    margin-top: -.125rem;
}

aside.floater-dropdown div.block div.header span.title {
    font-size: .875rem;
    font-weight: 600;
}

aside.floater-dropdown div.block div.alert {
    font-size: .875rem;

    padding: .5rem .75rem;
}

aside.floater-dropdown div.block .btn {
    font-size: .85rem;

    padding: .35rem .75rem;

    min-height: 1.25rem;
}

aside.floater-dropdown > ul > li {
	padding: 0.5rem 0.75rem;

	cursor: pointer;

	font-size: 0.75rem;
	font-weight: 500;

	color: var(--color-dark);

	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.75rem;
}

aside.floater-dropdown > ul > li.bg {
	background: var(--color-dark-08);
}

aside.floater-dropdown > ul > li.bg:hover {
	background: var(--color-dark-04);
}

aside.floater-dropdown > ul > li > a,
aside.floater-dropdown > ul > li > .dropdown_ {
	padding: 0.5rem 0.75rem;
    margin: -.5rem -.75rem;

	cursor: pointer;

	font-size: 0.75rem;
	font-weight: 500;

	color: var(--color-dark);

	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.75rem;

    width: calc(100% + (.75rem * 2));
}

aside.floater-dropdown > ul > li > .dropdown_ {
    padding: 0;
}

aside.floater-dropdown > ul > li > .dropdown_> button {
	padding: 0.5rem 0.75rem;
}

aside.floater-dropdown > ul > li span.icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

aside.floater-dropdown > ul > li span.icon:has(> i.fi-br-check) {
	display: none;
}

aside.floater-dropdown > ul > li.selected span.icon:has(> i.fi-br-check) {
	display: inline-flex;

	color: var(--color-primary);
}

aside.floater-dropdown > ul > li span:has(> span.icon) {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

aside.floater-dropdown > ul > li span:has(> span.icon) > span {
	margin-top: 1px;

	display: inline-block;
}

aside.floater-dropdown > ul > li span.icon > i {
	min-width: 0.75rem;
	min-height: 0.75rem;

	display: inline-flex;
	align-items: center;
	justify-content: center;

	font-size: 0.75rem;
}

aside.floater-dropdown > ul > li > i.fi-br-check {
	display: inline-flex;
	
	visibility: hidden;
}

aside.floater-dropdown > ul > li:hover {
	background: var(--color-dark-04);
}

aside.floater-dropdown > ul > li.selected > i.fi-br-check {
	color: var(--color-primary);

	visibility: visible;
}

aside.floater-dropdown > ul > li.action {
	margin-top: 0.25rem;
	margin-bottom: -0.25rem;

	background: var(--color-dark-04);
	color: var(--color-dark-88);

	border-radius: 0 0 0.75rem 0.75rem;
}

aside.floater-dropdown > ul > li.action:hover {
	background: var(--color-dark-08);
	color: var(--color-dark);
}
