The rem() CSS function returns a remainder left over when the first parameter is divided by the second parameter, similar to the JavaScript remainder operator (%). The remainder is the value left over when one operand, the dividend, is divided by a second operand, the divisor. It always takes the sign of the dividend.
   
    For example, the CSS rem(27, 5) function returns the remainder of 2. When dividing 27 by 5, the result is 5 with a remainder of 2. The full calculation is 27 / 5 = 5 * 5 + 2.
   
   
  
   Syntax
   
    
     
     
line-height: rem(21, 2); 
line-height: rem(14, 5); 
line-height: rem(5.5, 2); 
margin: rem(14%, 3%); 
margin: rem(18px, 5px); 
margin: rem(10rem, 6rem); 
margin: rem(26vmin, 7vmin); 
margin: rem(1000px, 29rem); 
rotate: rem(200deg, 30deg); 
rotate: rem(140deg, -90deg); 
rotate: rem(-90deg, 20deg); 
rotate: rem(-55deg, -15deg); 
scale: rem(10 * 2, 1.7); 
rotate: rem(10turn, 18turn / 3); 
transition-duration: rem(20s / 2, 3000ms * 2); 
     
    
  
  
   Parameter
   
    The rem(dividend, divisor) function accepts two comma-separated values as its parameters. Both parameters must have the same type, number, dimension, or percentage, for the function to be valid. While the units in the two parameters don't need to be the same, they do need of the same dimension type, such as <length>, <angle>, <time>, or <frequency> to be valid.
    
     - 
      dividend
- 
      A calculation that resolves to a <number>,<dimension>, or<percentage>representing the dividend.
 
- 
      divisor
- 
      A calculation that resolves to a <number>,<dimension>, or<percentage>representing the divisor.
 
 
  
  
   Return value
   
    Returns a <number>, <dimension>, or <percentage> (corresponds to the parameters' type) representing the remainder, that is, the operation left over.
    
     - If divisoris0, the result isNaN.
- If dividendisinfinite, the result isNaN.
- If dividendis positive the result is positive (0⁺), and ifdividendis negative the result is negative (0⁻).
 
  
  
   
   
    <rem()> = 
  rem( <calc-sum> , <calc-sum> )  
<calc-sum> = 
  <calc-product> [ [ '+' | '-' ] <calc-product> ]*  
<calc-product> = 
  <calc-value> [ [ '*' | '/' ] <calc-value> ]*  
<calc-value> = 
  <number>         |
  <dimension>      |
  <percentage>     |
  <calc-constant>  |
  ( <calc-sum> )   
<calc-constant> = 
  e          |
  pi         |
  infinity   |
  -infinity  |
  NaN        
    
  
  Specifications
  
  Browser compatibility
  
   
    
     
      
       |  | Desktop | Mobile | 
      
       |  | Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | 
     
     
      
       | rem | No | No | 118 | No | No | 15.4 | No | No | 118 | No | 15.4 | No |