/* ========================================
   Buttons
   ======================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-2) var(--spacing-4);
  font-family: var(--font-family-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-normal);
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
}
.btn:hover { opacity: 0.9; transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary {
  background: var(--gradient-brand);
  color: #fff;
  border-color: transparent;
}

.btn-secondary {
  background: transparent;
  color: rgb(var(--color-secondary-light));
  border-color: rgb(var(--color-secondary));
}
.btn-secondary:hover {
  background: rgba(var(--color-secondary), 0.1);
}

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

.btn-danger {
  background: rgb(var(--color-alert-critical));
  color: #fff;
}

.btn-sm { padding: var(--spacing-1) var(--spacing-3); font-size: var(--font-size-xs); }
.btn-lg { padding: var(--spacing-3) var(--spacing-6); font-size: var(--font-size-base); }
