TYPEMATCHSEO

TYPEMATCH.

V2.1

700
400
PAIRING ID: RED-ZEN // ETHOS: SANS-SERIF + DISPLAY

Balancing Red Hat Text with Zen Dots

Build a contrast-first system where Red Hat Text leads and Zen Dots keeps long-form content legible.

Display Face

Red Hat Text

Weight: 700

Body Face

Zen Dots

Weight: 400

This pairing is engineered for teams that need a clear hierarchy without sacrificing brand voice. Red Hat Text brings geometric, readable, tech energy to hero units, pricing sections, and campaign headlines. Zen Dots absorbs the heavy lifting for paragraphs, product storytelling, and UI labels with its futuristic, sci-fi, dots texture and dependable rhythm. Together they create a typography stack that scales from high-impact landing pages to dense documentation without retooling your CSS tokens.

Typographic Hierarchy & Scale

H1The Quick Fox
H2The Quick Fox
H3The Quick Fox
PThe quick brown fox jumps over...
Dark Context
Aa

High contrast negative space.

Accent
Gg

Legibility on high-chroma.

Pairing Strategy

Balancing Red Hat Text with Zen Dots

Build a contrast-first system where Red Hat Text leads and Zen Dots keeps long-form content legible.

This pairing is engineered for teams that need a clear hierarchy without sacrificing brand voice. Red Hat Text brings geometric, readable, tech energy to hero units, pricing sections, and campaign headlines. Zen Dots absorbs the heavy lifting for paragraphs, product storytelling, and UI labels with its futuristic, sci-fi, dots texture and dependable rhythm. Together they create a typography stack that scales from high-impact landing pages to dense documentation without retooling your CSS tokens.

Red Hat Text thrives as a headline face thanks to its geometric, readable, tech qualities. Use weights 700–900 for crisp editorial lockups.
Zen Dots excels in paragraphs and UI thanks to its futuristic, sci-fi, dots traits. Keep it between weights 400–600 for optimal readability.
Hierarchy guidance: run a 1:1.4 modular scale and reserve Red Hat Text for H1–H3 while Zen Dots powers captions, body copy, and data tables.

Best-Fit Use Cases

  • High-growth SaaS landing pages that require geometric hero statements with trustworthy product copy.
  • Editorial magazines and thought-leadership hubs where Red Hat Text can dramatize pull quotes while Zen Dots keeps 1,500-word essays skimmable.
  • Conversion funnels or onboarding flows that need Zen Dots's futuristic voice to balance Red Hat Text's attention-grabbing display.

Accessibility Notes

Maintain a minimum 4.5:1 contrast ratio for Zen Dots body copy and loosen letter-spacing to 0.01em for uppercase Red Hat Text moments. Pairing different categories demands disciplined color pairing—test both light and dark themes to ensure Zen Dots does not bloom at small sizes.

CSS Implementation Cheatsheet

:root {
  --tm-header-family: 'Red Hat Text', sans-serif;
  --tm-body-family: 'Zen Dots', display;
  --tm-header-weight: 700;
  --tm-body-weight: 400;
  --tm-header-tracking: -0.01em;
  --tm-body-tracking: 0em;
}
Heading scale: clamp(2.75rem, 4.5vw, 5.25rem) for H1, clamp(1.5rem, 2.8vw, 3rem) for H2, and keep paragraph size at 1rem–1.125rem with 1.6 line-height.
Component guidance: Buttons inherit Red Hat Text at 700 for momentum, while forms, tables, and footnotes stay on Zen Dots with 400 weight for predictable kerning.

FAQs

Why does Red Hat Text make sense as the lead font?

Red Hat Text owns the emotional register of this system. Its geometric, readable, tech profile helps anchor campaign creative, meaning marketing and product teams can reuse the same voice without reinventing the scale.

Where should Zen Dots show up?

Zen Dots is the workhorse. Keep it in paragraphs, long-form editorial, knowledge bases, or anywhere legibility is non-negotiable. Its futuristic, sci-fi, dots qualities reduce fatigue on dense layouts.

Does this pairing support complex localization?

Yes—both families are available on Google Fonts with generous glyph coverage. Test cyrillic/latin accents early, but most Latin-based locales and UI patterns are fully supported.