Airbnb Arbitrage: An Accounting Guide for Xero

Airbnb Arbitrage Accounting in Xero

Who should read this guide?

This is an accounting guide for those operating Airbnb Arbitrage listings and who are using Xero accounting software. Airbnb Arbitrage is a business model where an operator rents a property from an owner on a master lease and subleases said property to guests on Airbnb. This business model thrives in markets where Airbnb short-term income potential is higher than local long-term rental prices. Keeping a close eye on your numbers with an automated accounting system will make a great difference in navigating the success of your operations. In this guide, you’ll learn how to implement and automate accounting for the Airbnb Arbitrage business model using Xero.

USING QUICKBOOKS? READ THIS ARTICLE INSTEAD

NOTE: In this guide, we only cover income accounting, not costs. For a guide about Airbnb costs and chart of accounts to consider, check out this guide instead: Airbnb Costs and Chart of Accounts to Consider

About Airbnb Arbitrage

The benefits of the Airbnb Arbitrage business model are several. First, in markets where Airbnb travel is trending and local long-term rental rates are low, the Airbnb Arbitrage operator can stand to gain 30-50% gross profit margins (some areas even greater), which is much higher than the standard 15-20% Airbnb property management commission-based model. Second, the Airbnb Arbitrage operator has greater control over the property since the operator is a tenant with legal possession of the property. This means there’s much less overhead in dealing with the owner, the operator does not need to report monthly financials, they just pay rent to the owner and the operator has the most freedom to operate without actually owning the property.

The downside of this business model is the risk of the lease itself. In a market downturn, or in a market where travel becomes jeopardized this may not be favorable. If revenues start to dry up, margins can become slim as you continue to make fixed rental payments. Then in good times, unless mitigations are implemented in the master lease, the owner may increase the rent, also eating into the operator’s profit margins. The operator is also usually the one who purchases all the furnishings and fixtures for the property, taking on greater upfront costs than a property manager, who may share or completely pass these costs onto the property owner.

Table of Contents

Here’s what you’ll get from this guide:

  1. A template for Xero with detailed chart of accounts for Airbnb arbitrage
  2. Learn how to automate Airbnb arbitrage accounting with Bnbtally
  3. Execute common transaction workflows in Xero
  4. Generate monthly reports for you and your firm

Cash Flow Diagram

Airbnb Arbitrage Cash Flow Diagram

Who should not read this guide?

There are other business models that may be more suitable in your particular scenario, which are covered better in the following guides:


Airbnb Arbitrage: Xero Chart of Accounts for Airbnb Income

In this section, we’ll go over the details of our Xero chart of accounts template for the Airbnb arbitrage business model:

Account Codes

No. AccountType
24200Rental Liability – Airbnb Custom Taxes PayableLiability
42100Rental Revenue – Airbnb Income – Accommodation FareRevenue
42200Rental Revenue – Airbnb Income – Cleaning FeeRevenue
42300Rental Revenue – Airbnb Income – Resolution AdjustmentRevenue
42400Rental Revenue – Airbnb Refund – Accommodation FareRevenue
42500Rental Revenue – Airbnb Refund – Cleaning FeeRevenue
42600Rental Revenue – Airbnb Refund – Resolution AdjustmentRevenue
51100Rental Costs – Airbnb Service FeeDirect Cost
61100Airbnb Tax WithholdingsExpense

NOTE: In this guide, we only cover income accounting, not costs. For a guide about Airbnb costs and chart of accounts to consider, check out this guide instead: Airbnb Costs and Chart of Accounts to Consider

Detailed Explanation of Accounts

To learn more about each specific account code, we’ve listed each definition here:

Rental Liabilities

24200 – Rental Liability – Airbnb Custom Taxes Payable – This represents all Custom Taxes collected from Airbnb and payable to a tax authority.

Rental Revenues

42100 – Rental Revenue – Airbnb Income – Accommodation Fare – This account tracks the accommodation fare portion of each Airbnb reservation. The accommodation fare is equal to the number of nights multiplied by the average nightly rate of each reservation.

42200 – Rental Revenue – Airbnb Income – Cleaning Fee – This account tracks the cleaning fee portion of each Airbnb reservation.

42300 – Rental Revenue – Airbnb Income – Resolution Adjustment – This account tracks any resolution adjustments collected from Airbnb.

42400 – Rental Revenue – Airbnb Refund – Accommodation Fare – This account tracks accommodation fare refunds executed by Airbnb.

42500 – Rental Revenue – Airbnb Refund – Cleaning Fee – This account tracks cleaning fee refunds executed by Airbnb.

42600 – Rental Revenue – Airbnb Refund – Resolution Adjustment – This account tracks resolution adjustment refunds executed by Airbnb.

Rental Costs

51100 – Rental Costs – Airbnb Service Fee – This account tracks service fee costs from Airbnb for each reservation, which is subtracted from the income.

61100 – Airbnb Tax Withholdings – This account tracks any taxes withheld by Airbnb for income tax obligations. This is very rare and usually due to the Airbnb account holder lacking tax identification information. Ideally, this account should not contain any balance and is seldom (if ever) used. To avoid income tax withholdings from Airbnb, be sure to update your Airbnb account with your tax identification information and verify your account.

Accounts not included in this template

For the scope of this guide, we’re mainly focused on Airbnb revenue recognition. It is important to point out that our template does not include many general accounts. We also make reference to some accounts not included in this particular template, which we’ll list here:

  • 11000 – Airbnb Payment Clearing Account – This account is created by Bnbtally but is not included in this template in particular. This account is used to apply payments to Airbnb invoices upon the day the Airbnb reservation payout is posted. Payouts can take 3-5 days (or longer) to arrive in the bank account after posted from Airbnb. Monies owed are held in this clearing account until the payouts are received in the bank. This account also helps to automate the reconciliation process in Xero.
  • 1XXXX – Operations Bank Account – This is your business operations bank account set up with your financial institution. It’s a cash asset account to facilitate your Airbnb Arbitrage day-to-day business operations.
  • 5XXXX – Master Lease Rent Payments – This is an account used to track the amounts you’re paying to owners for master leases.
  • 4XXXX – Billable Expenses Income – This is a general account for capturing income received for the payment of billable expenses by owners, which may include a markup.
  • 7XXXX – Billable Expenses – This is a general account for tracking billable expenses for any owners.

Quick Setup Steps

Here’s how to import the above chart of accounts template. The chart of accounts discussed in this article can be imported into Xero automatically using Bnbtally’s setup tools. Here’s how to access this utility…

  1. If you haven’t already, Sign Up to Bnbtally. It includes free use of this template.
  2. Once registered, go to the Connections manager in Bnbtally. Connect your Airbnb account, connect your Xero account and then create a connection between the two.
  3. Within the Connection settings, select “Set Up Xero”

How to Automate Airbnb Arbitrage Accounting

With Bnbtally, you can automate your Airbnb arbitrage accounting so that you can focus on building a more profitable business. We’ll discuss how to use the preset settings in this section, which are designed for syncing reservations for an Airbnb arbitrage business model. Here we’ll make use of the chart of accounts discussed above.

Bnbtally Listing Presets

Once you’ve connected your Airbnb and Xero accounts, Bnbtally will guide you through setting up the accounting rules for your Airbnb arbitrage listing. You can also edit these presets if needed before enabling them for automation.

Airbnb Arbitrage Accounting Automation Bnbtally Presets for Xero

Explanation of Preset Lines

100% of all income from Airbnb is allocated as revenue to the business. This includes the accommodation fare, cleaning fee, Airbnb service fee (subtracted), any resolution adjustments, custom taxes (optional) and tax withholdings (if they exist)

Airbnb Price Item%Account
Accommodation Fare100%42100 – Rental Revenue – Airbnb Income – Accommodation Fare
Cleaning Fee100%42200 – Rental Revenue – Airbnb Income – Cleaning Fee
Airbnb Service Fee100%51100 – Rental Costs – Airbnb Service Fee
Resolution Adjustment100%42300 – Rental Revenue – Airbnb Income – Resolution Adjustment
Custom Taxes100%24200 – Rental Liability – Airbnb Custom Taxes Payable
Tax Withholdings100%61100 – Airbnb Tax Withholdings
Example Reservation

Let’s say you have Bnbtally set up for this listing using the preset settings above. Let’s say Airbnb sends a payout for a current reservation with the following itinerary price items:

  • Accommodation Fare: $2540
  • Cleaning Fee: $310
  • Airbnb Service Fee: -$70
  • Airbnb Transient Occupancy Taxes: $230
  • Reservation Total: $3010

Bnbtally accounts for all the income received by Airbnb, separating out each price item. The total amount to be received from Airbnb for this reservation is $2440, which is allocated to the Airbnb Payment Clearing Account to be later reconciled against the resulting bank deposit.

AccountDebitCredit
42100 – Rental Revenue – Airbnb Income – Accommodation Fare$2540
42200 – Rental Revenue – Airbnb Income – Cleaning Fee$310
51100 – Rental Costs – Airbnb Service Fee$70
24200 – Rental Liability – Airbnb Custom Taxes Payable$230
11000 – Airbnb Payment Clearing Account (Asset)$3010

Finally, on the date the reservation payout is received from Airbnb into your Operations Bank Account (3-5 days later), a bank rule in Xero can automatically reconcile the amount back to the Airbnb Payment Clearing Account:

AccountDebitCredit
1XXXX – Operations Bank Account$3010
11000 – Airbnb Payment Clearing Account (Asset)$3010

Set Invoice Customer & Tracking Categories

The best way to manage your guests in Xero is by creating a general contact in Xero for these transactions, we recommend calling it “Airbnb Guests”. However, if you prefer, you can set the guest as the contact in Bnbtally. In such case we’ll create each guest as a contact in Xero and will set them as the customer of the invoice for each reservation.

If you have more than one listing, you’ll also want to create a tracking category for each listing in Xero, many users will literally name the tracking category “Arbitrage – ” followed by the address of the listing. See below example:

Airbnb Arbitrage Accounting Xero Tracking Categories

Automate Additional Bills & Invoices (Optional)

With Bnbtally, you’re also able to automate the creation of additional bills and invoices for each reservation. Consider the following:

  • Create a bill for each reservation to automate amounts payable to a tax authority.
  • Create a bill for each reservation to automate amounts payable to a cleaning service for turnover of each reservation.
  • Create additional invoice for each reservation to automate amounts receivable by any third party.

Quick Setup Steps

All of the above settings can be quickly set up using Bnbtally’s presets for your listings. Here’s how to set up these presets…

  1. If you haven’t already, Sign Up to Bnbtally.
  2. After logging into Bnbtally, set up your connections, then go to Listing Rules.
  3. Select any listing you’d like to automate that hasn’t already been set up.
  4. Select “Load Presets”.

From here, presets will be loaded as your listing accounting rules and you can edit as needed.


Airbnb Arbitrage: Common Transaction Workflows in Xero

The following is a list of common transaction workflows for Airbnb Arbitrage in Xero.

Paying Rent to Owners

Owners receive a fixed rent each month, which means it’s easy to create a recurring payment. Each rent payment can be reconciled to “5XXXX – Master Lease Rent Payments”.

Example Transaction

You, the Airbnb Arbitrage operator, are paying the owner, Heather Rosa, $1575 rent per month for the property located at 1171 Ashburn Ln through a recurring bank transaction which happens monthly. Once the transfer is posted and complete, reconcile the outgoing transaction from the Operations Bank Account using the following entry:

DebitCreditTracking Category
1XXXX – Operations Bank Account (Asset)$1,575Arbitrage – 1171 Ashburn Ln
5XXXX – Master Lease Rent Payments (Cost)$1,575Arbitrage – 1171 Ashburn Ln

Detailed instructions for Xero

Paying Expenses on Behalf of Owners

If you need to purchase maintenance items and pay for it quickly, you may need to do so with the funds in your operations bank account. If your rental agreement allows, when rent is due again after paying off this expense, remove those additional monies from next month’s payment going towards landowner(s).

Example

A property owned by Claudia Smith needs a bathroom faucet to be replaced by a professional plumber. The service costs a total of $312 and needs to be rectified quickly as there are guests checking in later in the day. You also charge a 25% markup for allocating funds and administering the service for the owner.

First, you’ll need to pay the plumbing company from your Operations Bank Account either via bank transfer, ACH, check, Venmo or other means. Once the transaction is posted and complete, record the outgoing transaction from your Operations Bank Account using the following entry:

DebitCreditTracking Category
1XXXX – Operations Bank Account (Asset)$312Arbitrage – 1171 Ashburn Ln
7XXXX – Billable Expenses (Expense)$312Arbitrage – 1171 Ashburn Ln

When you pay your next rent payment (rent is $1575), subtract the amount billed plus a 25% markup ($312 * 1.25 = $390). This equals a payment of $1185 ($1575 – $390 = $1185). Once the transaction is posted and complete, record the outgoing transaction from the Operations Bank Account using the following entry:

DebitCreditTracking Category
1XXXX – Operations Bank Account (Asset)$1185Arbitrage – 1171 Ashburn Ln
5XXXX – Master Lease Rent Payments (Cost)$1575Arbitrage – 1171 Ashburn Ln
4XXXX – Billable Expenses Income (Revenue)$390Arbitrage – 1171 Ashburn Ln

Detailed instructions for Xero

Remitting Custom Taxes

In most areas, Airbnb will help collect taxes and remit them to your tax authority on your behalf. In such case, you can skip this section. But if you want more control over your funds, you should choose to receive custom taxes directly from Airbnb and remit them yourself. If you go this route in Airbnb, Bnbtally will automatically allocate any custom taxes associated with each reservation using the Custom Taxes line in our preset. You can then pay out to the tax authority following the example below.

Example

The listing, 1171 Ashburn Ln, is set up on Airbnb to receive custom taxes for all reservations. In Bnbtally, these amounts are allocated to “24200 – Rental Liability – Airbnb Custom Taxes Payable”. After running a balance sheet report on this listing in Xero, you see that $235 is owed for transient occupancy taxes.

First, you’ll need to send your payment to the tax authority either via bank transfer, ACH, check or other means. Once the transaction is posted and complete, record the outgoing transaction from the Operations Bank Account using the following entry:

DebitCreditTracking Category
1XXXX – Operations Bank Account (Asset)$235Arbitrage – 1171 Ashburn Ln
24200 – Rental Liability – Airbnb Custom Taxes Payable$235Arbitrage – 1171 Ashburn Ln

Detailed instructions for Xero


Monthly Reporting for Airbnb Arbitrage

Using Bnbtally, Airbnb reservation data is automatically processed in Xero without a hitch. Once your expenses are recorded in Xero, you can produce beautiful monthly reports with ease and can observe the performance of each listing without any hassle at all.

Profit & Loss by Listing

This report is for those who want to compare how their Airbnb Arbitrage listings are performing against each other. It can be found under the Xero left menu label “Reports”. From there, look for “Profit and Loss”. From here you want to edit the layout. Add a column and set the listing for each column you’d like to track. The profitability of each listing for your Airbnb Arbitrage operations can be viewed in this report – the most profitable listings will be clear.

Airbnb Arbitrage Accounting Profit and Loss Report in Xero

Account Transactions Grouped by Listing

To get in-depth insight into the transaction history of each listing for any particular duration of time, you can produce an Account Transaction report grouped by Listings. To do this in Xero, under reports select “Account Transactions”, from there you want to select all Airbnb Income and Airbnb Cost accounts, select to group by listing and then in the filter select only the listings you’d like to get a report on. An example report is as follows:

Airbnb Arbitrage Accounting Transaction Report in Xero

Conclusion

Airbnb arbitrage can be an incredibly lucrative business model that requires modest up-front costs yet allows you to retain control over your accommodation brand. However, keeping a close eye on your numbers is key, especially when it comes to acquiring more properties and negotiating with current and upcoming landlords. It is important to consistently monitor your listing performance and process the correct numbers in order to understand how well your operations are performing – which, in turn, will allow you to make the most profitable decisions.

A streamlined accounting method provides a great deal of transparency into the success of your business – something we hope you have received from this guide as you build your firm. To automate Airbnb Arbitrage accounting, check out the link below!

Finally, there are other business models that are not covered in this guide but are covered better in the following guides. Be sure to check these out :