Headless or Liquid? A practical decision framework for 2026
When Hydrogen makes sense, when Liquid is better, and the hybrid pattern most agencies miss.

Half the agencies on Twitter want to sell you a headless storefront. The other half tell you Liquid is "good enough." Both are wrong, because the answer is contextual — and the hybrid pattern almost no one talks about is usually the correct one.
The real tradeoffs
Headless gives you: build-time performance ceilings, full design freedom, edge-rendered marketing pages, and the ability to ship a real frontend team without waiting on Shopify. It costs you: ~$80K–$300K more on the build, a measurable ongoing engineering tax, and complexity in the checkout/customer-account surfaces that Shopify doesn’t expose cleanly to headless.
Liquid gives you: every Shopify feature on day one, a checkout you can’t customize but that converts well, an apps ecosystem that mostly works, and a 60-80% cheaper build. It costs you: rendering performance ceilings (LCP under 1s is brutal on Liquid), and a frontend developer experience that has aged poorly.
The hybrid pattern
Here’s what we ship for ~70% of clients above $10M ARR: headless for the marketing surface (Hydrogen on the home, collection, PDP, and editorial pages) and Liquid for the cart and checkout. You get the conversion gains of edge-rendered PDPs and the conversion safety of Shopify’s checkout, without the engineering cost of a fully custom checkout.
Going fully headless is rarely the right answer. Going partially headless almost always is.
When fully headless is correct
- You have a 6+ person frontend team and an annual budget over $50M.
- Your brand experience is a core differentiator — luxury, configurators, AR.
- You operate in 5+ markets and need real edge personalization.
When Liquid is correct
- You're under $10M ARR.
- You don't have a dedicated frontend team.
- Your conversion ceiling is being held back by merchandising, not by milliseconds.
If you’re between $10M and $50M, you’re almost certainly the hybrid case.


