Grocery · Shrinkage

Ward watches shrinkage across every store.

Insight cards surface shrinkage patterns your dashboards miss.

Why shrinkage matters
in grocery retail.

Grocery shrinkage splits into theft, spoilage, and admin error, but most retailers can't distinguish the cause until physical inventory. Ward separates these at the store-department level by cross-referencing receiving logs, POS velocity, waste scans, and inventory snapshots to produce cause-attributed shrinkage cards.

Industry benchmarks

US grocery shrink averages 2.0-3.0% of sales, with fresh departments running 4-7% and center store closer to 1-2%. A multi-vertical operator is usually surprised to learn shrink concentrates in three departments per store, not chain-wide, which means three targeted fixes recover more than blanket LP spend.

Quarterly shrinkage review, 450-store chain

One store flags elevated shrinkage well above the estate average for two consecutive periods. Traditional LP assumes shoplifting. Ward traces the majority of variance to receiving dock discrepancies in frozen foods, vendor deliveries consistently short against POs. One process fix, mandatory blind receiving, brings the store back in line within six weeks.

What Ward actually tracks

Ward decomposes shrinkage into theft, spoilage, vendor fraud, and admin error, then tracks inventory-to-sales ratios, receiving accuracy, and waste scan compliance by department. Rising shrinkage in a single department usually signals a process failure, not organized crime.

Data signals

Inventory snapshots, receiving logs and PO variance, POS voids and no-sales by lane, waste scans, employee shift schedules, and physical inventory reconciliation history.

Three pitfalls Ward catches
in grocery shrinkage.

  • 01 Estate-average shrinkage hides the four to seven stores driving 40% of the loss; chain reports never name them.
  • 02 Self-checkout shrinkage is misattributed to staffed-lane theft because the cause-attribution model lumps all front-end voids together.
  • 03 Spoilage in DSD-stocked categories (bread, dairy, beer) is invisible because the vendor owns the markdown decision.

How Ward runs shrinkage
for grocery retailers.

  1. 01

    Decompose shrink into cause categories

    Ward attributes loss across theft, spoilage, vendor short-ship, admin error, and self-checkout, at the store-department level, refreshed weekly.

  2. 02

    Rank by recoverable dollars

    Cards prioritize the cause-store-department combinations where a single intervention yields the most recovered margin in the next quarter.

  3. 03

    Track interventions in the closed loop

    Each LP action (blind receiving, case-locking, scheduling change) is tagged in Ward; subsequent shrink trajectories are tracked back to confirm the fix held.

What a Ward card looks like.

Ward · Shrinkage for Grocery06:47 AM

Store #37 showing 4.2% shrinkage vs 1.8% estate average. Pattern suggests receiving dock discrepancy, not shoplifting.

✓ Action recommendedGrocery context applied
app.getward.ai Live demo
Acme Retail @Merchandising: VP Analyst claude-sonnet default
A

Chat

Ask anything. Ward routes to the right agent and returns cited answers.

Why did Store 37 miss target last week?
You · 9:42 AM
Schema Scout · routed to Merchandising Agent

I pulled Store 37’s last 28 days against the chain baseline. Two root causes, both compounding.

SignalFinding
labor_efficiencyRev/labor-hour −22% vs. cluster, staffing mismatch at 11a–1p peak
inventory.freshFresh fill 83%, backroom replenishment lag at 2–4p
promo.liftBOGO crackers cannibalized Brand Y by 28%, net category +6%

Recommend: re-baseline Store 37 schedule against true peak, raise replen window to 1p, and review the BOGO before next cycle.

8 parallel queries 3 sources cited confidence 0.92
Show me how to fix the staffing mismatch.
You · 9:43 AM
Labor Agent · drafting schedule diff
Querying labor_scheduling
Ask anything, Ward routes to the right agent. Cmd+K

Dashboards

Pinned views built from saved data-lake queries.

Revenue vs. forecast +4.2% WoW
Gross margin % −3.2pp
Fill rate, fresh 83%
Shrink, West region +0.8pp

Models

Browse, search, and manage data–lake model definitions for your tenant.

NameNamespaceVersion
retail_pos_transactionsretail1.0
retail_inventory_snapshotretail1.2
retail_labor_schedulingretail1.0
retail_promo_calendarretail1.1
retail_supplier_performanceretail1.0
sap_inventory_shrinkagesap1.0
ga4_daily_eventsmarketing1.0
meta_ads_ad_levelmarketing1.0

Sources

Connect external systems to the data lake.

NameTypeLast sync
sap_pos_transactionsimport2m ago
sap_inventory_shrinkageimport2m ago
sap_labor_schedulingimport14m ago
retail_inventory_weeklyimport1h ago
retail_google_ads_dailyimport1h ago
retail_meta_ads_dailyimport1h ago
retail_ga4_website_dailyimport1h ago

Architecture

Two ways to connect. Federate against your live systems, or ingest into Ward’s data lake. Toggle below.

Your systems · read-only
SAP Retail
Snowflake
BigQuery
Shopify
Toast POS
Ward Gateway
TLS 1.3 · AES-256
Querying live · data stays put
Federated answers
SELECT * FROM sap.pos
JOIN snow.inventory
WHERE store_id = 37
→ insight cards
Ward Data Lake
→ baselined per store
TLS 1.3 in transit AES-256 at rest Read-only credentials SOC 2 II in progress VPC peering · PrivateLink

Pipelines

Move data from sources into models on a schedule.

NameSourceModelStatusSchedule
sync_sap_pos_transactionssap_pos_transactionspos_transactionsenabledhourly
sync_sap_labor_schedulingsap_labor_schedulinglabor_schedulingenableddaily
sync_sap_inventory_shrinkagesap_inventory_shrinkageinventory_shrinkageenableddaily
sync_retail_inventory_weeklyretail_inventory_weeklyinventory_weeklyenabledweekly
sync_retail_google_ads_dailyretail_google_ads_dailygoogle_ads_dailyenableddaily
sync_retail_ga4_website_dailyretail_ga4_website_dailyga4_website_dailyenableddaily

Streams

Real-time ingestion pipelines.

0events / min
0streams active
0% delivered
  • pos.txn store_037, basket $42.18
  • inv.move dc_west → store_104
  • labor.clock store_022 shift_start
  • pos.txn store_211, basket $19.04

Policies

Browse and manage Cedar access policies for your tenant.

TLS 1.3 AES-256 Read-only SOC 2 II
Policy IDEffectResources
merch-read-defaultpermitModel::*
finance-read-shrinkagepermitModel::"shrinkage"
vendor-blockedforbidModel::"labor_*"
region-west-onlypermitTenant::"acme"

Entities

Principals and resources referenced by Cedar policies.

Entity UIDTypeTenant
Tenant::"acme"Tenantacme
Model::"sap.pos_transactions"Modelacme
Model::"sap.inventory_shrinkage"Modelacme
Model::"sap.labor_scheduling"Modelacme
Model::"retail.toast_pos_daily"Modelacme
Model::"retail.ga4_website_daily"Modelacme

Providers

Manage LLM API keys and the model profiles that use them.

API Keys Model Profiles
NameProviderUsed byCreated
anthropic-defaultAnthropic3 profilesApr 22
openai-defaultOpenAI2 profilesApr 22
gemini-defaultGemini1 profileApr 22
ollama-onpremOllama2 profilesApr 22

LLM-agnostic. Bring your own key, route per task. No lock-in.

Settings

Manage your dashboard preferences and account.

Appearance
Theme • Light ° Dark

Light and dark themes are available. Your choice is remembered per browser.

Account
NameAdmin
Emailadmin@acme.io
Tenantacme-retail
Shrinkage for Grocery, live product demo.

Grocery shrinkage:
the shift.

Without Ward
Found in the quarterly review. Weeks after the damage is done.
  • ×Fresh waste & spoilage
  • ×On-shelf availability gaps
  • ×Promo cannibalization
With Ward
Caught this morning. Root cause attached. Action recommended.
  • Cause-level shrinkage attribution
  • Store-vs-estate benchmarking
  • Receiving dock anomaly detection

Grocery KPI impact.

Shrinkage
Cause-level attribution
Loss prevention shifts from guesswork to targeted intervention.
Fill Rate
24–72hr head start
Stockout prediction cards arrive before customers notice gaps.
Fresh Waste
Flagged before spoilage
Perishable turn rates monitored by store.

Impact timing depends on perishable mix, supply chain maturity, and data integration depth. Retailers with fragmented POS or ERP systems should expect a longer ramp to baseline accuracy.

Questions about grocery shrinkage.

Grocery shrinkage splits into theft, spoilage, and admin error, but most retailers can't distinguish the cause until physical inventory. Ward separates these at the store-department level by cross-referencing receiving logs, POS velocity, waste scans, and inventory snapshots to produce cause-attributed shrinkage cards.

One store flags elevated shrinkage well above the estate average for two consecutive periods. Traditional LP assumes shoplifting. Ward traces the majority of variance to receiving dock discrepancies in frozen foods, vendor deliveries consistently short against POs. One process fix, mandatory blind receiving, brings the store back in line within six weeks.

Ward decomposes shrinkage into theft, spoilage, vendor fraud, and admin error, then tracks inventory-to-sales ratios, receiving accuracy, and waste scan compliance by department. Rising shrinkage in a single department usually signals a process failure, not organized crime.

First shrinkage insight cards arrive within 48 hours. Robust grocery baselines form within two weeks. Impact timing depends on perishable mix, supply chain maturity, and data integration depth. Retailers with fragmented POS or ERP systems should expect a longer ramp to baseline accuracy.

What's shrinkage costing you this year?

Industry-average shrinkage rates run 1.0–1.9% of revenue depending on vertical. Drop in your numbers to see your annual exposure and how much of it Ward typically recovers.

$

Grocery retailers: see what shrinkage problems Ward catches.

Root causes, not just alerts. See it on your data.

Get a demo

Find out what your data has been hiding.

Tell us about your operation. We’ll show you the problems Ward catches, and the ones your current tools miss.

Step 1 of 3
What are your goals?
Step 2 of 3
About your operation
Step 3 of 3
Your contact info