.button-group {
	display: flex;
	gap:8px;
	flex-direction: row;
	justify-content: flex-start;
	align-items: flex-start;
}
a.button, button {
	background: none;
	display: inline-flex;
	gap:5px;
	
	padding: 5px 15px;
	border:2px solid currentColor;
	border-radius: 2px;
}
*:is(a.button, button) > * {
	margin-top: auto;
	margin-bottom: auto;
}
*:is(a.button, button):not([class*="small"],[class*="subtle"],[class*="tiny"]) {
	padding: 15px 15px;
}
*:is(a.button, button)[class*="small"],[class*="subtle"],[class*="tiny"], button {
	border-radius: 20px;
}
*:is(a.button, button):first-child {
	margin-left: -1px;
}
*:is(a.button, button):not(.button-group *) + *:is(a.button, button) {
	margin-left: 10px;

} 

*:is(a.button, button) .fa {
	transition: 0.2s ease-out;
}
*:is(a.button, button):hover  .fa{
	margin-left: 10px;
}
