Playfair Display + Lato

Grumpy wizards make toxic brew

A standfirst set in Lato, one size up — where a pairing starts earning trust.

The five boxing wizards jump quickly over the lazy dog, mixing jugs of quiet vodka while the jury watches. Click anywhere in this preview and type your own text to try the pairing.

“Type is a beautiful group of letters, not a group of beautiful letters.”

— Matthew Carter

Fig. 1 — Playfair Display over Lato, in the wild.

Playfair Display 700 / Lato 400 — click any section and type your own copy.

Why it works

Playfair's high-contrast didone headlines bring the drama; Lato answers with quiet, warm paragraphs that never compete for attention. This is the same serif-display-over-humanist-sans formula as Playfair with Inter or Open Sans, but Lato's slightly rounded details soften the pairing, nudging it from crisp editorial toward inviting — a good fit when elegance needs to feel personal rather than austere.

More about each face: Playfair Display · Lato

Use this pairing

HTML — Google Fonts embed
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700&family=Lato:wght@400;700&display=swap" rel="stylesheet">
CSS
h1, h2, h3 {
  font-family: 'Playfair Display', Georgia, 'Times New Roman', serif;
  font-weight: 700;
}

body {
  font-family: 'Lato', Helvetica, Arial, sans-serif;
  font-weight: 400;
}
Next.js — next/font
import { Playfair_Display, Lato } from "next/font/google";

const heading = Playfair_Display({
  subsets: ["latin"],
  weight: "700",
  variable: "--font-heading",
});

const body = Lato({
  subsets: ["latin"],
  weight: "400",
  variable: "--font-body",
});

Related pairings