button,
.btn {
  border: 1px solid transparent;
  background: var(--surface);
  color: var(--text);
  padding: var(--space-2-5) var(--space-3);
  border-radius: var(--space-3);
  cursor: pointer;
  box-shadow: var(--shadow);
  font-weight: 600;
  letter-spacing: 0.2px;
  transition:
    0.2s ease background,
    0.2s ease transform;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1-5);
  text-decoration: none;
}

button:hover,
.btn:hover {
  transform: translateY(-1px);
  background: var(--muted);
}

.btn-accent {
  background: linear-gradient(180deg, var(--accent), var(--accent2));
  color: var(--btn-accent-text);
}

.btn-danger {
  background: linear-gradient(180deg, var(--danger), var(--danger2));
  color: var(--btn-danger-text);
}

.btn-outline {
  background: transparent;
  border-color: var(--muted);
}

.btn .icon {
  margin-right: var(--space-1);
}

.btn .icon:last-child {
  margin-right: 0;
}

@media (max-width: 480px) {
  button,
  .btn {
    padding: var(--space-2) calc(var(--space-2) + var(--space-1));
  }
}
