: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.

Chrome

  1. 4: Not supported
  2. 5 - 14: Support unknown
  3. 15 - 51: Partial support
  4. 52: Partial support
  5. 53 - 105: Supported
  6. 106: Supported
  7. 107 - 109: Supported

Edge

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

Safari

  1. 3.1 - 4: Not supported
  2. 5: Support unknown
  3. 5.1 - 10: Partial support
  4. 10.1 - 15.6: Supported
  5. 16.0: Supported
  6. 16.1 - TP: Supported

Firefox

  1. 2 - 28: Not supported
  2. 29 - 49: Partial support
  3. 50 - 104: Supported
  4. 105: Supported
  5. 106 - 107: 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 - 90: Supported
  6. 91: Supported

IE

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

Chrome for Android

  1. 105: Supported

Safari on iOS

  1. 3.2 - 4.3: Not supported
  2. 5 - 10.2: Partial support
  3. 10.3 - 15.6: Supported
  4. 16.0: Supported
  5. 16.1: Supported

Samsung Internet

  1. 4: Partial support
  2. 5 - 17.0: Supported
  3. 18.0: Supported

Opera Mini

  1. all: Partial support

Opera Mobile

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

UC Browser for Android

  1. 13.4: Supported

Android Browser

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

Firefox for Android

  1. 104: Supported

QQ Browser

  1. 13.1: Supported

Baidu Browser

  1. 13.18: 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`