How to Fine-Tune Your Font Weights in CSS?

Most of the fonts that you use, come with different font weights. The ones you might have come across frequently are bold and normal (or regular). In this article, you will learn about different font weights available in CSS and what they imply visually.

Font Weight Declaration in CSS

In CSS, the following weight values can be declared for a font (given, of course, that the font family actually has those weight variants / faces otherwise the font weight is substituted):

CSS Value Description
100 Thin (or Hairline)
200 Extra-light (or Ultra Light)
300 Light
400 Normal (or Regular)
500 Medium
600 Semi Bold (or Demi Bold)
700 Bold
800 Extra Bold (or Ultra Bold)
900 Black (or Heavy)
normal Normal (equivalent of numeric font-weight value 400 in CSS)
bold Bold (equivalent of numeric font-weight value 700 in CSS)
bolder One relative font weight darker than the parent element
lighter One relative font weight lighter than the parent element

You may see different descriptions for these font weights in different places, that is because there is no accepted, universal meaning to these weight names / values. The general idea is that you understand that their primary role is to distinguish faces of differing darkness within a single font family.

Please note that when determining relative font weights (i.e. lighter and bolder), only four font weights are considered (i.e. 100, 400, 700, and 900) for relative weight calculation. All other values are ignored.

If a font-weight is missing in a font family, then the browser may try to find a substitute or create a faux bold effect.

Q&A

A few things answered that you may be wondering:

Why Are There Only 9 Numeric Values for the font-weight Property?

The scale of 9 weights has been selected to cover all traditional typographic weights. However, in CSS Fonts Level 4 specification any number between 1 and 1000 is allowed. This provides greater flexibility for variable fonts for example, which can have a more fine-grained control over the font weights.

Why Can't We Use String Values to Define CSS Font Weight?

The numeric values are neutral and can be used independently of the naming scheme of a font.

Why Do the CSS Font Weight Numeric Values Start From 100 and Not From 1?

The font scale of 100 through 900 was introduced by TrueType font format, where 400 is regular (roman or plain). The same scale is also used in CSS and OpenType font format. In CSS Fonts Level 4 specification, however, any number between 1 and 1000 is allowed.


This post was published (and was last revised ) by Daniyal Hamid. Daniyal currently works as the Head of Engineering in Germany and has 20+ years of experience in software engineering, design and marketing. Please show your love and support by sharing this post.