What are withholding taxes in Spain?
What are withholding taxes in Spain?
In Spain, certain invoices are subject to withholding taxes, known as retenciones.A withholding tax is a mechanism where the customer withholds part of the invoice amount and pays it directly to the Spanish tax authorities, instead of paying it to the supplier. As a result, the supplier receives a net amount, reduced by the withholding.In practice, Spanish withholding taxes mainly apply under two legal frameworks:
- IRPF (Impuesto sobre la Renta de las Personas Físicas)
This is the most common case and applies to self-employed professionals and freelancers.
The legal name is Retención a cuenta del IRPF. - Impuesto sobre Sociedades (Corporate Income Tax)
In some cases, withholding taxes also apply to companies.
The legal name is Retención a cuenta del Impuesto sobre Sociedades.
Key accounting impact of withholding taxes
Withholding tax:- is calculated at the invoice header level, not per line
- Reduces the total payable amount
- Does not appear as VAT on invoice lines
- Must be reported separately using specific tax codes
How withholding taxes are handled in Chift
To properly support Spanish withholding taxes, Chift has a dedicated and explicit model.1. withholding_tax attribute on invoices
Awithholding_tax object is available in both input and output, located at the invoice header level (see here its definition).
This object is mandatory when a withholding applies and contains three required attributes:
tax_rate– the withholding rate to apply (expressed as a negative value in standard usage)tax_code– a withholding-specific tax code (see section 3 of this article for more details)tax_amount– the calculated withholding amount ( expressed as a negative value in standard usage)
2. Impact on invoice totals and validation
Withholding taxes directly affect invoice totals. Chift enforces strict validation rules to ensure accounting accuracy.Invoice total validation
When submitting an invoice, Chift validates that:- The withholding tax reduces the total payable amount.
- If this rule is not met, the API returns a validation error.
Header tax_amount calculation
The tax_amount at the invoice header level is computed as:
- VAT reporting remains accurate
- Withholding tax is clearly separated from line-level taxes
- Invoice totals match Spanish accounting expectations
3. Dedicated VAT codes for withholding taxes
To avoid ambiguity and invalid bookings, wihtolding tax codes are explicitly marked. Key points:- Specific attribute:
withholding_taxon VAT codes (trueorfalse) - Marks a tax code as withholding-specific
- Withholding tax VAT codes cannot be used on invoice lines
- Only withholding tax VAT codes can be used in the
withholding_taxattribute - Standard VAT codes remain line-level only
- Mixing VAT and withholding logic
- Incorrect tax reporting
- Connector-specific inconsistencies
Booking an invoice with withholding tax via Chift
To correctly book a Spanish invoice with withholding tax:- Use standard VAT codes on invoice lines
- Lines behave exactly like any regular VAT invoice
- Declare the withholding at header level
- Populate the
withholding_taxobject with:- The correct Spanish withholding tax code
- Rate and calculated amount (negative)
- Populate the
- Adjust
tax_amountandtotalat the invoice header- Amounts must respect the validation rules described above
How withholding taxes are mapped in Business Central
Additional implementation notes
How withholding taxes are mapped in Business Central
Additional implementation notes
Business Central does not natively support withholding taxes as a dedicated accounting concept.
As a result, withholding taxes are implemented using a specific VAT configuration and accounting mapping.
The rules below describe how this is modeled in Business Central and exposed through Chift.
Example of a invoice booked with Withholding tax in Business central 👇
As a result, withholding taxes are implemented using a specific VAT configuration and accounting mapping.
The rules below describe how this is modeled in Business Central and exposed through Chift.
-
VAT codes with a tax rate of 0 and a calculation type set to Full VAT are treated as withholding tax codes.
These VAT codes are exposed via the API withwithholding_tax = true.
To add, or edit Withholding taxes you need to go to “VAT posting setup” page (use the search icon). See example here👇
-
VAT codes flagged as withholding:
- cannot be used on standard invoice lines
- Can only be used in the
withholding_taxattribute at invoice header level and are the only taxes accepted at header level.
- On customer invoices and refunds, the Sales VAT Account defined on the VAT code is used as the general ledger account for the withholding tax.
- On supplier invoices and refunds, the Purchase VAT Account defined on the VAT code is used instead.
-
For calculation purposes, Business Central relies on internal invoice lines linked to these VAT codes.
These lines:- are used to compute the
withholding_taxobject returned by the API - are not included in the
linesarray of the invoice response
- are used to compute the
Example of a invoice booked with Withholding tax in Business central 👇
