diff --git a/packages/docs/pages/users/fees.mdx b/packages/docs/pages/users/fees.mdx
index fdaca2fe..0b4e10b8 100644
--- a/packages/docs/pages/users/fees.mdx
+++ b/packages/docs/pages/users/fees.mdx
@@ -157,6 +157,10 @@ In these examples, `my-implicit` may only have an OSMO balance in their transpar
 In this case, the NAM will be unshielded to the transparent balance of `my-implicit` and then used to pay for the transaction fee.
 So it is requried to unshield just the difference between the gas cost and the transparent balance of the gas payer implicit address.
 
+
+For an atomic batch, the masp fee payment transaction (the first one in the batch) is guaranteed to be committed even if the batch eventually fails.
+
+
 ### Using a disposable gas payer (recommended)
 
 It is also possible to use a disposable gas payer to pay for transaction fees.
diff --git a/packages/specs/pages/base-ledger/fee-system.mdx b/packages/specs/pages/base-ledger/fee-system.mdx
index 8a928adc..1a5960fb 100644
--- a/packages/specs/pages/base-ledger/fee-system.mdx
+++ b/packages/specs/pages/base-ledger/fee-system.mdx
@@ -138,6 +138,10 @@ if this is a **valid MASP transaction**, it then reattempts to perform the same
 If it is successful, the transaction is accepted, otherwise it gets rejected (possibly the entire block is rejected if we are validating a new block).
 So, essentially, MASP fee payment involves allowing the transaction to unshield some tokens to the balance of the fee payer to cover the missing amount.
 
+
+In case of an atomic batch the masp fee payment transaction will be committed even if the batch eventually fails. That is, all the state changes coming from the other inner transactions of the batch will be dropped (as per the default behavior of an atomic batch), but an exception will be made for the fee paying inner transaction that will instead be committed to storage to guarantee that fees are paid.
+
+
 Since this operation comes before the actual payment, it can be exploited as a DoS vector.
 To prevent this, the protocol enforces a maximum gas limit that can be used for this operation.
 When the time comes, the protocol picks the gas limit for this operation as the minimum between the gas available to the transaction and the protocol parameter;