/**
 * Componente: Button — variants primary/secondary/ghost/danger/link, tamaños sm/md/lg, modifiers icon/block.
 * Depende de: andreani-core-variables
 */

.andr-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--andr-sp-2);
	padding: var(--andr-sp-2) var(--andr-sp-4);
	border: 1px solid transparent;
	border-radius: var(--andr-radius-sm);
	font-family: var(--andr-font-body);
	font-size: var(--andr-text-sm);
	font-weight: var(--andr-fw-medium);
	line-height: 1.2;
	cursor: pointer;
	user-select: none;
	text-decoration: none;
	white-space: nowrap;
	transition:
		background-color var(--andr-transition-fast),
		border-color var(--andr-transition-fast),
		color var(--andr-transition-fast),
		box-shadow var(--andr-transition-fast);
}

.andr-btn:focus-visible {
	outline: 2px solid var(--andr-color-border-focus);
	outline-offset: 2px;
}

.andr-btn:disabled,
.andr-btn[aria-disabled="true"] {
	opacity: 0.5;
	cursor: not-allowed;
	pointer-events: none;
}

.andr-btn svg,
.andr-btn .dashicons {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.andr-btn--primary {
	background: var(--andr-color-brand);
	color: var(--andr-color-brand-on-brand);
	border-color: var(--andr-color-brand);
}

.andr-btn--primary:hover {
	background: var(--andr-color-brand-hover);
	border-color: var(--andr-color-brand-hover);
}

.andr-btn--primary:active {
	background: var(--andr-color-brand-pressed);
	border-color: var(--andr-color-brand-pressed);
}

.andr-btn--secondary {
	background: var(--andr-color-surface);
	color: var(--andr-color-text);
	border-color: var(--andr-color-border-strong);
}

.andr-btn--secondary:hover {
	background: var(--andr-color-surface-subtle);
	border-color: var(--andr-color-text-subtle);
}

.andr-btn--ghost {
	background: transparent;
	color: var(--andr-color-text);
	border-color: transparent;
}

.andr-btn--ghost:hover {
	background: var(--andr-color-surface-subtle);
}

.andr-btn--danger {
	background: var(--andr-color-error);
	color: var(--andr-color-text-inverse);
	border-color: var(--andr-color-error);
}

.andr-btn--danger:hover {
	background: var(--andr-color-error-strong);
	border-color: var(--andr-color-error-strong);
}

.andr-btn--link {
	background: transparent;
	color: var(--andr-color-text-link);
	border-color: transparent;
	padding-left: 0;
	padding-right: 0;
}

.andr-btn--link:hover {
	color: var(--andr-color-text-link-hover);
	text-decoration: underline;
}

.andr-btn--sm {
	padding: var(--andr-sp-1) var(--andr-sp-3);
	font-size: var(--andr-text-xs);
	gap: var(--andr-sp-1);
}

.andr-btn--sm svg,
.andr-btn--sm .dashicons {
	width: 14px;
	height: 14px;
}

.andr-btn--lg {
	padding: var(--andr-sp-3) var(--andr-sp-5);
	font-size: var(--andr-text-md);
	gap: var(--andr-sp-2);
}

.andr-btn--lg svg,
.andr-btn--lg .dashicons {
	width: 18px;
	height: 18px;
}

.andr-btn--icon {
	padding: var(--andr-sp-2);
	width: 32px;
	height: 32px;
	gap: 0;
}

.andr-btn--icon.andr-btn--sm {
	width: 28px;
	height: 28px;
	padding: var(--andr-sp-1);
}

.andr-btn--icon.andr-btn--lg {
	width: 40px;
	height: 40px;
	padding: var(--andr-sp-3);
}

.andr-btn--block {
	width: 100%;
}

.andr-btn-group {
	display: inline-flex;
	gap: var(--andr-sp-2);
	flex-wrap: wrap;
}
