/* ── Buttons ── */

.btn {
  background: var(--btn-bg, var(--color-surface));
  color: var(--btn-color, var(--color-text-secondary));
  border: var(--btn-border, none);
  border-radius: var(--btn-radius, var(--radius-full));
  padding: var(--btn-padding, 10px 22px);
  font-size: var(--btn-font-size, var(--text-base));
  font-weight: var(--weight-medium);
  font-family: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  transition: background var(--transition-fast), color var(--transition-fast);
  text-decoration: none;
  white-space: nowrap;
}
.btn:hover {
  background: var(--btn-bg-hover, var(--color-surface-hover));
}

/* ── Variants ── */

.btn--primary {
  --btn-bg: var(--color-accent);
  --btn-bg-hover: var(--color-accent-hover);
  --btn-color: var(--color-white);
}

.btn--outline {
  --btn-bg: transparent;
  --btn-bg-hover: var(--color-bg);
  --btn-color: var(--color-text-secondary);
  --btn-border: 1px solid var(--color-border);
}

.btn--danger {
  --btn-bg: rgba(190, 60, 60, 0.1);
  --btn-bg-hover: rgba(190, 60, 60, 0.18);
  --btn-color: var(--color-danger-dark);
  --btn-border: none;
}

.btn--success {
  --btn-bg: rgba(76, 140, 80, 0.12);
  --btn-bg-hover: rgba(76, 140, 80, 0.2);
  --btn-color: var(--color-success);
  --btn-border: none;
}

.btn--ghost {
  --btn-bg: transparent;
  --btn-bg-hover: transparent;
  --btn-color: var(--color-accent);
  --btn-padding: 0;
}
.btn--ghost:hover {
  text-decoration: underline;
}

/* ── Sizes ── */

.btn--sm {
  --btn-padding: 4px 14px;
  --btn-font-size: var(--text-2xs);
}

.btn--lg {
  --btn-padding: 16px 44px;
  --btn-font-size: var(--text-lg);
  letter-spacing: 0.5px;
}

.btn--icon {
  --btn-padding: 0;
  --btn-radius: var(--radius-circle);
  width: 32px;
  height: 32px;
  justify-content: center;
  font-size: var(--text-lg);
  line-height: 1;
}

/* ── Disabled ── */

.btn:disabled,
.btn[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
}
.btn:disabled:hover,
.btn[disabled]:hover {
  background: var(--btn-bg, var(--color-surface));
}
