.btn {
  padding: 0.5rem 0.875rem;
  border: 1px solid var(--color-bone-deep);
  border-radius: var(--border-radius-base);
  background: var(--color-cream);
  font-weight: var(--font-weight-medium);
  font-size: 0.85rem;
  cursor: pointer;
  transition: var(--transition-base);
  text-decoration: none;
  text-align: center;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  color: var(--color-ink);
  letter-spacing: 0.002em;
}

.btn img, .btn svg {
  width: 14px;
  height: 14px;
}

.btn:hover {
  background: var(--color-bone);
  border-color: var(--color-mist);
}

.btn.btn--primary {
  background: var(--color-ink);
  color: var(--color-cream);
  border-color: var(--color-ink);
  min-width: 4rem;
}

.btn.btn--primary:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  opacity: 1;
}

.btn.btn--accent {
  background: var(--color-accent);
  color: var(--color-cream);
  border-color: var(--color-accent);
}

.btn.btn--accent:hover {
  background: var(--color-accent-deep);
  border-color: var(--color-accent-deep);
}

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

.btn.btn--ghost:hover {
  color: var(--color-accent);
  background: transparent;
}

.btn.btn--no-padding {
  padding: 0;
}

.btn.btn--no-padding img, .btn.btn--no-padding svg {
  margin-right: 0.375rem;
}
