IBM Plex Sans + IBM Plex Serif
Grumpy wizards make toxic brew
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.
IBM Plex Sans 600 / IBM Plex Serif 400 — click the text to edit
Why it works
Plex Sans and Plex Serif were drawn together by Mike Abbink and Bold Monday on shared skeletons and identical vertical metrics, so mixing them is less a pairing than two voices of one typeface. The grotesque headings carry IBM's engineered neutrality; the serif body adds a journalistic, almost typewriter-adjacent warmth to running text. The result feels rigorous and bookish at once — well suited to research writing, case studies and technical publications.
More about each face: IBM Plex Sans · IBM Plex Serif
Use this pairing
<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=IBM+Plex+Sans:wght@600&family=IBM+Plex+Serif:wght@400;600&display=swap" rel="stylesheet">h1, h2, h3 {
font-family: 'IBM Plex Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
font-weight: 600;
}
body {
font-family: 'IBM Plex Serif', Georgia, 'Times New Roman', serif;
font-weight: 400;
}import { IBM_Plex_Sans, IBM_Plex_Serif } from "next/font/google";
const heading = IBM_Plex_Sans({
subsets: ["latin"],
weight: "600",
variable: "--font-heading",
});
const body = IBM_Plex_Serif({
subsets: ["latin"],
weight: "400",
variable: "--font-body",
});Related pairings
- Libre Baskerville + Montserratclassic · editorial · elegant
- Merriweather + Open Sansclassic · editorial · warm
- Merriweather + Source Sans 3classic · technical · minimal
- Montserrat + Crimson Textclassic · editorial · elegant
- Montserrat + EB Garamondclassic · elegant · editorial
- Oswald + Merriweatherbold · editorial · classic