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.
-
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.
-
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.
-
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.
Store #37 showing 4.2% shrinkage vs 1.8% estate average. Pattern suggests receiving dock discrepancy, not shoplifting.
Chat
Ask anything. Ward routes to the right agent and returns cited answers.
I pulled Store 37’s last 28 days against the chain baseline. Two root causes, both compounding.
| Signal | Finding |
|---|---|
labor_efficiency | Rev/labor-hour −22% vs. cluster, staffing mismatch at 11a–1p peak |
inventory.fresh | Fresh fill 83%, backroom replenishment lag at 2–4p |
promo.lift | BOGO 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.
labor_scheduling…
Dashboards
Pinned views built from saved data-lake queries.
Models
Browse, search, and manage data–lake model definitions for your tenant.
| Name | Namespace | Version |
|---|---|---|
retail_pos_transactions | retail | 1.0 |
retail_inventory_snapshot | retail | 1.2 |
retail_labor_scheduling | retail | 1.0 |
retail_promo_calendar | retail | 1.1 |
retail_supplier_performance | retail | 1.0 |
sap_inventory_shrinkage | sap | 1.0 |
ga4_daily_events | marketing | 1.0 |
meta_ads_ad_level | marketing | 1.0 |
Sources
Connect external systems to the data lake.
| Name | Type | Last sync |
|---|---|---|
sap_pos_transactions | import | 2m ago |
sap_inventory_shrinkage | import | 2m ago |
sap_labor_scheduling | import | 14m ago |
retail_inventory_weekly | import | 1h ago |
retail_google_ads_daily | import | 1h ago |
retail_meta_ads_daily | import | 1h ago |
retail_ga4_website_daily | import | 1h ago |
Architecture
Two ways to connect. Federate against your live systems, or ingest into Ward’s data lake. Toggle below.
sap.possnow.inventoryPipelines
Move data from sources into models on a schedule.
| Name | Source | Model | Status | Schedule |
|---|---|---|---|---|
sync_sap_pos_transactions | sap_pos_transactions | pos_transactions | enabled | hourly |
sync_sap_labor_scheduling | sap_labor_scheduling | labor_scheduling | enabled | daily |
sync_sap_inventory_shrinkage | sap_inventory_shrinkage | inventory_shrinkage | enabled | daily |
sync_retail_inventory_weekly | retail_inventory_weekly | inventory_weekly | enabled | weekly |
sync_retail_google_ads_daily | retail_google_ads_daily | google_ads_daily | enabled | daily |
sync_retail_ga4_website_daily | retail_ga4_website_daily | ga4_website_daily | enabled | daily |
Streams
Real-time ingestion pipelines.
pos.txnstore_037, basket $42.18inv.movedc_west → store_104labor.clockstore_022 shift_startpos.txnstore_211, basket $19.04
Policies
Browse and manage Cedar access policies for your tenant.
| Policy ID | Effect | Resources |
|---|---|---|
merch-read-default | permit | Model::* |
finance-read-shrinkage | permit | Model::"shrinkage" |
vendor-blocked | forbid | Model::"labor_*" |
region-west-only | permit | Tenant::"acme" |
Entities
Principals and resources referenced by Cedar policies.
| Entity UID | Type | Tenant |
|---|---|---|
Tenant::"acme" | Tenant | acme |
Model::"sap.pos_transactions" | Model | acme |
Model::"sap.inventory_shrinkage" | Model | acme |
Model::"sap.labor_scheduling" | Model | acme |
Model::"retail.toast_pos_daily" | Model | acme |
Model::"retail.ga4_website_daily" | Model | acme |
Providers
Manage LLM API keys and the model profiles that use them.
| Name | Provider | Used by | Created |
|---|---|---|---|
anthropic-default | Anthropic | 3 profiles | Apr 22 |
openai-default | OpenAI | 2 profiles | Apr 22 |
gemini-default | Gemini | 1 profile | Apr 22 |
ollama-onprem | Ollama | 2 profiles | Apr 22 |
LLM-agnostic. Bring your own key, route per task. No lock-in.
Settings
Manage your dashboard preferences and account.
Light and dark themes are available. Your choice is remembered per browser.
Grocery shrinkage:
the shift.
- ×Fresh waste & spoilage
- ×On-shelf availability gaps
- ×Promo cannibalization
- ✓Cause-level shrinkage attribution
- ✓Store-vs-estate benchmarking
- ✓Receiving dock anomaly detection
Grocery KPI impact.
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.
Grocery shrinkage
by data source.
More Grocery insight cards.
Grocery retailers: see what shrinkage problems Ward catches.
Root causes, not just alerts. See it on your data.
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.