Office/Team Profitability Modelling
This use case describes how to model profitability by office, practice or team in a professional services or consulting firm using Model Reef.
You will:
Use branches to represent organisational units such as offices, practices or teams.
Map revenue, staff and Opex into the right branches.
Allocate shared or central costs.
Produce P&Ls and KPIs at both office or team level and firm level.
When to use this pattern
Use this pattern when:
You want to understand profitability at office, practice or team level.
You need to allocate shared overheads such as head office costs to those units.
You want decision makers to be accountable for local performance while seeing the impact of central costs.
This pattern assumes you have already set up rate card, utilisation and pipeline structures that determine revenue.
Architecture overview
Define the organisational units you want to track
Decide what you want to treat as a unit for profitability analysis, for example:
Offices or geographies.
Practices or service lines.
Named teams or squads.
In many firms, a two dimensional view is helpful, such as offices by practice. For modelling purposes, choose one dimension as the primary branch structure and keep the other as a reporting attribute if needed.
In Model Reef, create a branch tree such as:
Firm.Office - London.Office - Manchester.Office - Remote.Overheads.
Or, for practice first:
Firm.Practice - Strategy.Practice - Technology.Practice - Implementation.Overheads.
Map revenue to offices or teams
Ensure that Revenue variables are attached to the branch that actually delivers or owns the work, not just to a single firm level branch.
Depending on your modelling approach, you may:
Create revenue variables per branch that link to billable hours and rates for that branch.
Allocate a share of project or client level revenue to different branches based on delivery mix.
The objective is that each office or team branch has a realistic share of revenue that reflects their contribution.
Map staff and direct costs to offices or teams
Next, ensure that:
Staff variables (salaries, benefits, payroll tax) are assigned to the branch where people sit or where their costs are managed.
Direct Opex such as local office rent, local travel, local marketing and team expenses are also placed in the relevant branch.
Patterns:
Staff - Consultant - LondoninOffice - London.Opex - Office Rent - LondoninOffice - London.Staff - Support Team - FirminOverheadsif they serve the entire firm.
This separation of direct and central costs is critical for clear profitability analysis.
Group central and shared costs
Create an Overheads or Central branch for costs that support the whole firm, such as:
Executive leadership.
Finance, HR and internal IT.
Central marketing.
Firm wide systems and licences.
Office of the managing partner.
Model these as Staff and Opex variables in the Overheads branch.
Firm level P&L at the root branch will include all branches, including Overheads, by default.
Design allocation logic for shared costs
If you want to see fully loaded profitability per office or team, design allocation drivers for central costs, for example:
Revenue share.
Gross margin share.
Headcount share.
Some hybrid of the above.
In the Data Library, create drivers such as:
Allocation Key - Revenue Share - London.Allocation Key - Revenue Share - Manchester.
These should sum to 100 percent across the target branches for each allocation scheme.
Then, in each office or team branch, create Opex variables such as:
Allocated Overheads - London.Allocated Overheads - Manchester.
Define formulas that:
Take total central costs from the
Overheadsbranch.Multiply by the allocation key for each branch.
You can choose to leave central costs in the Overheads branch as well (for reconciliation) or show them only via allocations in profitability views, depending on communication needs.
For the mechanics of cross branch references, see Build Cross Branch Drivers and Dependencies.
Build office or team P&L views
Use reports and dashboards to provide:
P&L per office or team showing:
Revenue.
Direct staff and Opex.
Allocated overheads.
Operating contribution and fully loaded profit.
Consolidated firm P&L at the root branch.
You can add KPIs such as:
Revenue per FTE.
Contribution margin per office.
Profit per partner or per manager.
Present pre allocation and post allocation views so that managers can see both raw and fully loaded performance.
Use scenarios for structural changes
To test structural changes such as office openings, closures or team restructures:
Clone the base model into scenario models representing different structures.
Adjust branch structures, allocation drivers and staff assignments.
Compare office and firm level profitability across scenarios.
This lets you evaluate the impact of:
Consolidating small offices.
Investing in new practices.
Moving roles between locations.
Because scenarios are separate models, you can explore substantial changes without affecting the live plan.
Check your work
Troubleshooting
Related guides
Last updated