:in-range and :out-of-range CSS pseudo-classes

- WD

If a temporal or number <input> has max and/or min attributes, then :in-range matches when the value is within the specified range and :out-of-range matches when the value is outside the specified range. If there are no range constraints, then neither pseudo-class matches.

IE

  1. 5.5 - 10: Not supported
  2. 11: Not supported

Edge

  1. 12: Not supported
  2. 13 - 18: Partial support
  3. 79: Supported
  4. 80: Supported

Firefox

  1. 2 - 28: Not supported
  2. 29 - 49: Partial support
  3. 50 - 73: Supported
  4. 74: Supported
  5. 75 - 76: Supported

Chrome

  1. 4: Not supported
  2. 5 - 14: Support unknown
  3. 15 - 51: Partial support
  4. 52: Partial support
  5. 53 - 79: Supported
  6. 80: Supported
  7. 81 - 83: Supported

Safari

  1. 3.1 - 4: Not supported
  2. 5: Support unknown
  3. 5.1 - 10: Partial support
  4. 10.1 - 12.1: Supported
  5. 13: Supported
  6. 13.1 - TP: Supported

Opera

  1. 9 - 9.6: Support unknown
  2. 10 - 12.1: Partial support
  3. 15 - 38: Partial support
  4. 39: Partial support
  5. 40 - 65: Supported
  6. 66: Supported

iOS Safari

  1. 3.2 - 4.3: Not supported
  2. 5 - 10.2: Partial support
  3. 10.3 - 13.2: Supported
  4. 13.3: Supported
  5. 13.4: Supported

Opera Mini

  1. all: Partial support

Android Browser

  1. 2.1 - 3: Not supported
  2. 4 - 4.4.4: Partial support
  3. 80: Supported

Blackberry Browser

  1. 7: Not supported
  2. 10: Partial support

Opera Mobile

  1. 10 - 12.1: Partial support
  2. 46: Supported

Chrome for Android

  1. 80: Supported

Firefox for Android

  1. 68: Supported

IE Mobile

  1. 10: Not supported
  2. 11: Not supported

UC Browser for Android

  1. 12.12: Supported

Samsung Internet

  1. 4: Partial support
  2. 5 - 10.1: Supported
  3. 11.1: Supported

QQ Browser

  1. 1.2: Supported

Baidu Browser

  1. 7.12: Supported

KaiOS Browser

  1. 2.5: Partial support

Note that <input type="range"> can never match :out-of-range because the user cannot input such a value, and if the initial value is outside the range, the browser immediately clamps it to the minimum or maximum (as appropriate) bound of the range.

Resources:
MDN Web Docs - CSS :out-of-range
WHATWG HTML specification for `:in-range` and `:out-of-range`