This site is designed for accessibility.
Content is obtainable and functional to any browser or Internet device.
This site's full visual experience is available in a graphical browser
that supports web standards. Please consider
upgrading your web browser.
Cascading Ordering Process
Conflicting rules are intrinsic to the CSS mechanism. To
find the value for an element/property combination, the
following algorithm must be followed:
- Find all declarations that apply to the element and
property in question, for the target media type. Declarations
apply if the associated selector matches the element in
question.
- The primary sort of the declarations is by weight and
origin: for normal declarations, author style sheets override
user style sheets which override the default style sheet. For
"!important" declarations, user style sheets override author
style sheets which override the default style sheet.
"!important" declaration override normal declarations. An
imported style sheet has the same origin as the style sheet
that imported it.
- The secondary sort is by specificity of selector: more
specific selectors will override more general ones.
Pseudo-elements and pseudo-classes are counted as normal
elements and classes, respectively.
- Finally, sort by order specified: if two rules have the
same weight, origin and specificity, the latter specified
wins. Rules in imported style sheets are considered to be
before any rules in the style sheet itself.
Apart from the "!important" setting on individual
declarations, this strategy gives author's style sheets higher
weight than those of the reader. It is therefore important that
the user agent give the user the ability to turn off the
influence of a certain style sheet, e.g., through a pull-down
menu.