.gDropMenu {
}

.gDropMenu .gDropMenuTrigger {
	cursor: pointer;
}

.gDropMenu .gDropMenuContent {
	display: none;
	position: absolute;
	background-color: white;
	border: 1px solid var(--grey4, #e5e5e5);
	color: var(--body-text, #596269);
	text-align: left;
	padding: 10px;
	min-width: 160px;
	box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
	z-index: 2001;
}

.gDropMenu .gDropMenuContent .gDropMenuOption {
	cursor: pointer;
	display: block;
	padding: 5px 10px;
}

.gDropMenu .gDropMenuContent .gDropMenuOption:hover {
	background-color: var(--grey7, #f4f5f6);
}

.gDropMenu .gDropMenuHeader {
	padding: 5px 10px;
	font-size: 0.85em;
	background: var(--grey6);
	text-align: center;
}

.gLinkSubMenu {
}

.gLinkSubMenu>a:hover {
	text-decoration: none;
}
.gLinkSubMenu .gSubMenu {
	display: none;
	position: absolute;
	background-color: var(--body-bg, #ffffff);
	border: 1px solid var(--grey4, #e5e5e5);
	color: var(--body-text, #596269);
	min-width: 100px;
	width: min-content;
	max-width: 90vw;
	z-index: 2;
}

/*.tab-group .tab-head .tab-tab*/
/*.tab-group .tab-body*/

.tab-group .tab-head { user-select: none; margin: 0; margin-top: 1rem; border-bottom: 1px solid #ccc; display: flex; max-width: 100%; overflow-x: auto; overflow-y: hidden; scrollbar-width: none;}
.tab-group .tab-tab { display: inline-block; border: 1px solid #bbb; background: #ddd; padding: 0.3em 1em; cursor: pointer; font-size: 0.9em; margin-bottom: -1px; border-right-width: 0; line-height: 1.2em; }
.tab-group .tab-tab:last-child { border-right-width: 1px; }
.tab-group .tab-tab:hover { background: #eee; }
.tab-group .tab-tab.active { background: #fff; border-bottom: 1px dashed #eee; cursor: default; }
.tab-group .tab-body { display: none; padding: 1em; border: 1px solid #ccc; border-top: none; }
.tab-group .tab-body.active { display: block; }

/* .tab-grou.cards = column cards on larger displays and tabs only on small displays */
/* note: add class break-m or break-l on tab-body to force a break after depending on m (2-col) or l (3-col) */
@media (min-width: 900px) {
	.tab-group.cards {
		columns: 2;
	}
	.tab-group.cards .tab-head {
		display:none;
	}
	.tab-group.cards .tab-body {
		display: block;
		padding: 10px;
		border: 1px solid #ccc;
		border-radius: 5px;
		break-inside: avoid-column;
		margin-bottom: 20px;
	}
	.tab-group.cards .tab-body.break-m {
		break-after: column;
	}
}
@media (min-width: 1500px) {
	.tab-group.cards {
		columns: 3;
	}
	.tab-group.cards .tab-body.break-l {
		break-after: column;
	}
}

.gIconPickerField {
	display: flex;
	gap: 8px;
	align-items: stretch;
}

.gIconPickerField > input,
.gIconPickerField > textarea,
.gIconPickerField > select {
	flex: 1 1 auto;
	min-width: 0;
}

.gIconPickerActions {
	display: flex;
	gap: 6px;
	flex: 0 0 auto;
}

.gIconPickerPreview {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	white-space: nowrap;
}

.gIconPickerPreview i {
	width: 1.2em;
	text-align: center;
}

.gIconPickerModal {
	width: 100%;
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
}

.modal.gIconPickerModalShell .modalguts {
	width: min(1100px, calc(100vw - 40px));
	max-width: min(1100px, calc(100vw - 40px));
}

.modal.gIconPickerModalShell .globalmodalcontent {
	overflow-x: hidden;
}

.gIconPickerToolbar {
	display: flex;
	gap: 10px;
	align-items: center;
	margin-bottom: 12px;
}

.gIconPickerSearchWrap {
	position: relative;
	flex: 1 1 auto;
}

.gIconPickerSearchWrap i {
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--grey2);
	pointer-events: none;
}

.gIconPickerSearchWrap input {
	width: 100%;
	max-width: 100%;
	padding-left: 32px;
	box-sizing: border-box;
}

.gIconPickerSelected {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	background: var(--grey8, #f9f9f9);
	border: 1px solid var(--grey4, #ccc);
	border-radius: 6px;
	margin-bottom: 12px;
}

.gIconPickerSelectedIcon {
	width: 42px;
	height: 42px;
	border-radius: 6px;
	background: white;
	border: 1px solid var(--grey4, #ccc);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	flex: 0 0 auto;
}

.gIconPickerSelectedText {
	font-family: monospace;
	font-size: 14px;
	word-break: break-word;
}

.gIconPickerResults {
	max-height: min(62vh, 700px);
	overflow: auto;
	padding-right: 2px;
}

.gIconPickerResultMeta {
	color: var(--grey2, #888);
	font-size: 0.85em;
	margin-bottom: 10px;
}

.gIconPickerGrid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 8px;
}

.gIconPickerItem {
	border: 1px solid var(--grey5, #ddd);
	background: white;
	border-radius: 6px;
	padding: 10px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 64px;
	cursor: pointer;
}

.gIconPickerItem:hover {
	border-color: var(--brand, #1976D2);
	background: var(--grey8, #f9f9f9);
}

.gIconPickerItem.active {
	border-color: var(--brand, #1976D2);
	background: var(--brand-light, #BBDEFB);
}

.gIconPickerItem i {
	font-size: 20px;
}

.gColorPickerField {
	display: flex;
	gap: 8px;
	align-items: stretch;
	position: relative;
}

.gColorPickerField > input,
.gColorPickerField > textarea,
.gColorPickerField > select {
	flex: 1 1 auto;
	min-width: 0;
}

.gColorPickerActions {
	display: flex;
	gap: 6px;
	flex: 0 0 auto;
}

button.gColorPickerPreview,
.button.gColorPickerPreview {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: nowrap;
	gap: 8px;
	white-space: nowrap;
	line-height: 1;
	padding: 4px 10px;
}

.gColorPickerPreviewSwatch {
	width: 18px;
	height: 18px;
	border-radius: 999px;
	border: 1px solid var(--grey4, #ccc);
	display: block;
	flex: 0 0 auto;
}

.gColorPickerPreviewLabel {
	display: inline-block;
	line-height: 1.1;
	white-space: nowrap;
}

.gColorPickerPreviewSwatch.empty {
	background: linear-gradient(135deg, #fff 0%, #fff 45%, #ddd 45%, #ddd 55%, #fff 55%, #fff 100%);
}

.gColorPickerPanel {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	z-index: 2002;
	background: white;
	border: 1px solid var(--grey4, #ccc);
	border-radius: 8px;
	padding: 10px;
	box-shadow: 0 8px 16px rgba(0,0,0,0.12);
	display: none;
	width: min(320px, calc(100vw - 60px));
	box-sizing: border-box;
}

.gColorPickerPanel .gColorPickerGrid {
	display: grid;
	grid-template-columns: repeat(8, minmax(0, 1fr));
	gap: 8px;
}

.gColorPickerItem {
	padding: 0;
	border: 1px solid var(--grey5, #ddd);
	background: white;
	border-radius: 999px;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}

.gColorPickerItem:hover,
.gColorPickerField.open .gColorPickerPreview {
	border-color: var(--brand, #1976D2);
}

.gColorPickerSwatch {
	width: 20px;
	height: 20px;
	border-radius: 999px;
	border: 1px solid rgba(0,0,0,0.08);
	display: inline-block;
}

@media (max-width: 700px) {
	.gIconPickerField {
		flex-direction: column;
	}
	.gIconPickerActions {
		justify-content: flex-start;
	}
	.gIconPickerModal {
		min-width: 0;
	}
	.gIconPickerGrid {
		grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
	}
	.gColorPickerField {
		flex-direction: column;
	}
	.gColorPickerActions {
		justify-content: flex-start;
	}
}
