The CSS stepped value math functions are now in Baseline 2024  |  Blog  |  web.dev

All major engines now support the CSS stepped value math functions—
round(),
mod(),
and rem().

The stepped value functions all transform a given value according to another
step value.

The round() function

The round() function takes a value to be rounded,
a rounding interval, and an optional rounding strategy.
The value is rounded according to the rounding strategy,
to the nearest integer multiple of the rounding interval.

Either the value to be rounded, or the rounded interval, should be a CSS
custom property. While it’s valid to hardcode both values, there’s little
point rounding a number if you could calculate the value yourself.

The following CSS rounds the value of --my-font-size, to the interval of 1rem.

font-size: round(var(--my-font-size), 1rem);

The default rounding strategy is nearest. The previous example including the
rounding strategy is as follows:

font-size: round(nearest,var(--my-font-size), 1rem);

The possible values for the rounding strategy are:

  • up: Equivalent to JavaScript Math.ceil() method. Rounds the value up
    to the nearest whole multiple of the rounding interval.
  • down: Equivalent to JavaScript Math.floor() method. Rounds the value
    down to the nearest whole multiple of the rounding interval.
  • nearest (default): Equivalent to JavaScript Math.round(). Rounds the
    value up or down, to the nearest whole multiple of the rounding interval.
  • to-zero: Equivalent to JavaScript Math.trunc() method. Rounds the value
    to the nearest integer multiple of the rounding interval closer to zero.

Learn more about round() in
The New CSS Math: round(),
by Dan Wilson.

The rem() and mod() functions

The rem() and mod() CSS functions work in a similar way to the JavaScript
remainder operator (%). They take two values, the first (the dividend) is divided by the second (the divisor),
and the remainder is returned.

margin: rem(18px, 5px); /* returns 3px */

The difference between the two functions is that rem() always takes the sign
of the dividend, therefore if the first value is positive the returned value
will be positive. The mod() function takes the sign of the divisor.

Learn more about rem() and mod() in
The New CSS Math: rem() and mod(),
by Dan Wilson.