Style Guide
Live spec for the Bay State design system. Every visual primitive is rendered here from theme.json + assets/css/theme.css. If it’s wrong here, it’s wrong everywhere.
Brand colors
Blue is the brand chrome (links, headings on white, primary surfaces). Red is the action color (Call Now, Request a Quote, conversion CTAs). Use red sparingly so it always carries weight.
Neutrals
Two surface tones (Base behind Surface), three ink levels for hierarchy, two rule weights for dividers.
Typography
Inter Variable across the entire system. Differentiation comes from weight + size + tracking, not multiple families. Headings use tighter letter-spacing; eyebrows and overlines use loose tracking + uppercase.
Lochinvar Boilers Stocked in Springfield
Built for contractors who can’t wait.
In-stock inventory, fast counter pickup
Why Lochinvar?
Section header
Eyebrow / Overline
Body copy. Bay State Plumbing & Heating Supply has stocked the parts contractors actually need since 1949 — Watts mixing valves, Lochinvar boilers, Webstone isolation valves, and a counter staff that knows the difference between residential and commercial spec.
Small / meta. Quote turnaround usually under 2 hours during business hours. After-hours quotes go to the morning queue.
Spacing scale
Generated from theme.json: 7 steps, each 1.5x the previous, base 1.5rem. Values surface as --wp--preset--spacing--{slug}.
- 10 · 0.444rem
- 20 · 0.666rem
- 30 · 1rem
- 40 · 1.5rem (medium)
- 50 · 2.25rem
- 60 · 3.375rem
- 70 · 5.063rem
Elevation
Restrained scale. Use md for cards, lg for floating panels, xl only for modals.
- sm · 1px hairline
- md · cards
- lg · floating
- xl · modals
Buttons
Three variants. Red accent (default) for the primary action on a page (Call Now, Request a Quote). Blue primary for secondary actions tied to brand. Ghost for tertiary or destructive-confirm flows.
Small
Form fields
Sharp corners, generous touch targets, blue focus ring with soft halo. Used by the Quote Request form throughout the site.
Links
Underlined by default for clarity. Hover transitions to red.
Inline link in body copy: our Lochinvar boiler page opens to the full lineup. Tap a brand to see what we stock locally.
Agent attributes
Every meaningful interactive or navigational element carries data-agent-* attrs so AI agents can target them. These are not for analytics — they’re semantic role declarations.
data-agent-purpose— what this DOM node is ("site-header","hero","category-grid","quote-form","contact-strip")data-agent-interactive— what action this triggers ("primary-cta","routing","click-to-call","open-modal","form-submit")data-agent-content-source— backing data origin where applicable ("cms/posts","cpt/bsp_brand","api/products")