calc() as CSS unit value

- CR

Method of allowing calculated values for length units, i.e. width: calc(100% - 3em)

IE

  1. 5.5 - 8: Not supported
  2. 9: Partial support
  3. 10: Partial support
  4. 11: Partial support

Edge

  1. 12 - 102: Supported
  2. 103: Supported

Firefox

  1. 2 - 3.6: Not supported
  2. 4 - 15: Supported
  3. 16 - 100: Supported
  4. 101: Supported
  5. 102 - 103: Supported

Chrome

  1. 4 - 18: Not supported
  2. 19 - 25: Supported
  3. 26 - 102: Supported
  4. 103: Supported
  5. 104 - 106: Supported

Safari

  1. 3.1 - 5.1: Not supported
  2. 6: Supported
  3. 6.1 - 15.4: Supported
  4. 15.5: Supported
  5. 16.0 - TP: Supported

Opera

  1. 9 - 12.1: Not supported
  2. 15 - 85: Supported
  3. 86: Supported
  4. 87: Supported

Safari on iOS

  1. 3.2 - 5.1: Not supported
  2. 6: Supported
  3. 7 - 15.4: Supported
  4. 15.5: Supported
  5. 16.0: Supported

Opera Mini

  1. all: Not supported

Android Browser

  1. 2.1 - 4.3: Not supported
  2. 4.4 - 4.4.4: Partial support
  3. 101: Supported

Opera Mobile

  1. 10 - 12.1: Not supported
  2. 64: Supported

Chrome for Android

  1. 102: Supported

Firefox for Android

  1. 101: Supported

UC Browser for Android

  1. 12.12: Supported

Samsung Internet

  1. 4 - 16.0: Supported
  2. 17.0: Supported

QQ Browser

  1. 10.4: Supported

Baidu Browser

  1. 7.12: Supported

KaiOS Browser

  1. 2.5: Supported

Support can be somewhat emulated in older versions of IE using the non-standard expression() syntax.

Due to the way browsers handle sub-pixel rounding differently, layouts using calc() expressions may have unexpected results.

Resources:
MDN Web Docs - calc
Mozilla Hacks article
WebPlatform Docs