Oswald + Roboto

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.

Oswald 500 / Roboto 400 — click the text to edit

Why it works

Condensed Oswald headlines tower over Roboto's even, neutral paragraphs, producing a sporty, high-energy hierarchy that suits dashboards, fitness brands and product launches. Both families share grotesque DNA, so despite the size drama the page still feels like one system rather than two fonts arguing.

More about each face: Oswald · Roboto

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=Oswald:wght@500&family=Roboto:wght@400;700&display=swap" rel="stylesheet">
CSS
h1, h2, h3 {
  font-family: 'Oswald', 'Arial Narrow', Arial, sans-serif;
  font-weight: 500;
}

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

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

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

Related pairings