Compilation of CSS 2.1 and W3C Recommendations that replace sections
- 1 About the CSS 2.1 Specification
- 1 CSS 2.1 vs CSS 2
- 2 Reading the specification
- 3 How the specification is organized
- 4 Conventions
- 1 Document language elements and attributes
- 2 CSS property definitions
- 1 Value
- 2 Initial
- 3 Applies to
- 4 Inherited
- 5 Percentage values
- 6 Media groups
- 7 Computed value
- 3 Shorthand properties
- 4 Notes and examples
- 5 Images and long descriptions
- 5 Acknowledgments
- 2 Introduction to CSS 2.1
- 1 A brief CSS 2.1 tutorial for HTML
- 2 A brief CSS 2.1 tutorial for XML
- 3 The CSS 2.1 processing model
- 1 The canvas
- 2 CSS 2.1 addressing model
- 4 CSS design principles
- 3 Conformance: Requirements and Recommendations
- 1 Definitions
- 2 UA Conformance
- 3 Error conditions
- 4 The text/css content type
- 4 Syntax and basic data types
- 1 Syntax ghg@4.1 = [CSS-SYNTAX-3]@
- 1 Tokenization
- 2 Keywords
- 1 Vendor-specific extensions
- 2 Informative Historical Notes
- 3 Characters and case
- 4 Statements
- 5 At-rules
- 6 Blocks
- 7 Rule sets, declaration blocks, and selectors
- 8 Declarations and properties
- 9 Comments
- 2 Rules for handling parsing errors ghg@4.2 = [CSS-SYNTAX-3]@
- 3 Values
- 1 Integers and real numbers
- 2 Lengths
- 3 Percentages
- 4 URLs and URIs
- 5 Counters
- 6 Colors
- 7 Strings
- 8 Unsupported Values
- 4 CSS style sheet representation ghg@4.4 = [CSS-SYNTAX-3]@
- 1 Referring to characters not represented in a character encoding
- 1 Syntax ghg@4.1 = [CSS-SYNTAX-3]@
- 5 Selectors
- 1 Pattern matching
- 2 Selector syntax
- 1 Grouping
- 3 Universal selector
- 4 Type selectors
- 5 Descendant selectors
- 6 Child selectors
- 7 Adjacent sibling selectors
- 8 Attribute selectors
- 1 Matching attributes and attribute values
- 2 Default attribute values in DTDs
- 3 Class selectors
- 9 ID selectors
- 10 Pseudo-elements and pseudo-classes
- 11 Pseudo-classes
- 1
:first-child
pseudo-class - 2 The link pseudo-classes:
:link
and:visited
- 3 The dynamic pseudo-classes:
:hover
,:active
, and:focus
- 4 The language pseudo-class:
:lang
- 1
- 12 Pseudo-elements
- 1 The
:first-line
pseudo-element - 2 The
:first-letter
pseudo-element - 3 The
:before
and:after
pseudo-elements
- 1 The
- 6 Assigning property values, Cascading, and Inheritance
- 1 Specified, computed, and actual values
- 1 Specified values
- 2 Computed values
- 3 Used values
- 4 Actual values
- 2 Inheritance
- 1 The
inherit
value
- 1 The
- 3 The
@import
rule - 4 The cascade
- 1 Cascading order
- 2
!important
rules - 3 Calculating a selector's specificity
- 4 Precedence of non-CSS presentational hints
- 1 Specified, computed, and actual values
- 7 Media types
- 1 Introduction to media types
- 2 Specifying media-dependent style sheets
- 1 The
@media
rule
- 1 The
- 3 Recognized media types ghg@7.3 = [CSS3-MEDIAQUERIES]@
- 1 Media groups
- 8 Box model
- 1 Box dimensions
- 2 Example of margins, padding, and borders
- 3 Margin properties:
margin-top
,margin-right
,margin-bottom
,margin-left
, andmargin
- 1 Collapsing margins
- 4 Padding properties:
padding-top
,padding-right
,padding-bottom
,padding-left
, andpadding
- 5 Border properties
- 1 Border width:
border-top-width
,border-right-width
,border-bottom-width
,border-left-width
, andborder-width
- 2 Border color:
border-top-color
,border-right-color
,border-bottom-color
,border-left-color
, andborder-color
- 3 Border style:
border-top-style
,border-right-style
,border-bottom-style
,border-left-style
, andborder-style
- 4 Border shorthand properties:
border-top
,border-right
,border-bottom
,border-left
, andborder
- 1 Border width:
- 6 The box model for inline elements in bidirectional context
- 9 Visual formatting model
- 1 Introduction to the visual formatting model
- 1 The viewport
- 2 Containing blocks
- 2 Controlling box generation
- 1 Block-level elements and block boxes
- 1 Anonymous block boxes
- 2 Inline-level elements and inline boxes
- 1 Anonymous inline boxes
- 3 Run-in boxes
- 4 The
display
property
- 1 Block-level elements and block boxes
- 3 Positioning schemes
- 1 Choosing a positioning scheme:
position
property - 2 Box offsets:
top
,right
,bottom
,left
- 1 Choosing a positioning scheme:
- 4 Normal flow
- 1 Block formatting contexts
- 2 Inline formatting contexts
- 3 Relative positioning
- 5 Floats
- 1 Positioning the float: the
float
property - 2 Controlling flow next to floats: the
clear
property
- 1 Positioning the float: the
- 6 Absolute positioning
- 1 Fixed positioning
- 7 Relationships between
display
,position
, andfloat
- 8 Comparison of normal flow, floats, and absolute positioning
- 1 Normal flow
- 2 Relative positioning
- 3 Floating a box
- 4 Absolute positioning
- 9 Layered presentation
- 1 Specifying the stack level: the
z-index
property
- 1 Specifying the stack level: the
- 10 Text direction: the
direction
andunicode-bidi
properties
- 1 Introduction to the visual formatting model
- 10 Visual formatting model details
- 1 Definition of "containing block"
- 2 Content width: the
width
property - 3 Calculating widths and margins
- 1 Inline, non-replaced elements
- 2 Inline, replaced elements
- 3 Block-level, non-replaced elements in normal flow
- 4 Block-level, replaced elements in normal flow
- 5 Floating, non-replaced elements
- 6 Floating, replaced elements
- 7 Absolutely positioned, non-replaced elements
- 8 Absolutely positioned, replaced elements
- 9
inline-block
, non-replaced elements in normal flow - 10
inline-block
, replaced elements in normal flow
- 4 Minimum and maximum widths:
min-width
andmax-width
- 5 Content height: the
height
property - 6 Calculating heights and margins
- 1 Inline, non-replaced elements
- 2 Inline replaced elements, block-level replaced elements in normal flow,
inline-block
replaced elements in normal flow and floating replaced elements - 3 Block-level non-replaced elements in normal flow when
overflow
computes tovisible
- 4 Absolutely positioned, non-replaced elements
- 5 Absolutely positioned, replaced elements
- 6 Complicated cases
- 7
auto
heights for block formatting context roots
- 7 Minimum and maximum heights:
min-height
andmax-height
- 8 Line height calculations: the
line-height
andvertical-align
properties- 1 Leading and half-leading
- 11 Visual effects
- 1 Overflow and clipping
- 1 Overflow: the
overflow
property - 2 Clipping: the
clip
property
- 1 Overflow: the
- 2 Visibility: the
visibility
property
- 1 Overflow and clipping
- 12 Generated content, automatic numbering, and lists
- 1 The
:before
and:after
pseudo-elements - 2 The
content
property - 3 Quotation marks
- 1 Specifying quotes with the
quotes
property - 2 Inserting quotes with the
content
property
- 1 Specifying quotes with the
- 4 Automatic counters and numbering
- 1 Nested counters and scope
- 2 Counter styles
- 3 Counters in elements with 'display: none'
- 5 Lists
- 1 Lists: the
list-style-type
,list-style-image
,list-style-position
, andlist-style
properties
- 1 Lists: the
- 1 The
- 13 Paged media
- 1 Introduction to paged media
- 2 Page boxes: the
@page
rule- 1 Page margins
- 2 Page selectors: selecting left, right, and first pages
- 3 Content outside the page box
- 3 Page breaks
- 1 Page break properties:
page-break-before
,page-break-after
,page-break-inside
- 2 Breaks inside elements:
orphans
,widows
- 3 Allowed page breaks
- 4 Forced page breaks
- 5 "Best" page breaks
- 1 Page break properties:
- 4 Cascading in the page context
- 14 Colors and Backgrounds
- 1 Foreground color: the
color
property - 2 The background
- 1 Background properties:
background-color
,background-image
,background-repeat
,background-attachment
,background-position
, andbackground
- 1 Background properties:
- 1 Foreground color: the
- 15 Fonts
- 1 Introduction
- 2 Font matching algorithm
- 3 Font family: the
font-family
property- 1 Generic font families
- 1
serif
- 2
sans-serif
- 3
cursive
- 4
fantasy
- 5
monospace
- 1
- 1 Generic font families
- 4 Font styling: the
font-style
property - 5 Small-caps: the
font-variant
property - 6 Font boldness: the
font-weight
property - 7 Font size: the
font-size
property - 8 Shorthand font property: the
font
property
- 16 Text
- 1 Indentation: the
text-indent
property - 2 Alignment: the
text-align
property - 3 Decoration
- 1 Underlining, overlining, striking, and blinking: the
text-decoration
property
- 1 Underlining, overlining, striking, and blinking: the
- 4 Letter and word spacing: the
letter-spacing
andword-spacing
properties - 5 Capitalization: the
text-transform
property - 6 White space: the
white-space
property- 1 The
white-space
processing model - 2 Example of bidirectionality with white space collapsing
- 3 Control and combining characters' details
- 1 The
- 1 Indentation: the
- 17 Tables
- 1 Introduction to tables
- 2 The CSS table model
- 1 Anonymous table objects
- 3 Columns
- 4 Tables in the visual formatting model
- 1 Caption position and alignment
- 5 Visual layout of table contents
- 1 Table layers and transparency
- 2 Table width algorithms: the
table-layout
property- 1 Fixed table layout
- 2 Automatic table layout
- 3 Table height algorithms
- 4 Horizontal alignment in a column
- 5 Dynamic row and column effects
- 6 Borders
- 1 The separated borders model
- 1 Borders and Backgrounds around empty cells: the
empty-cells
property
- 1 Borders and Backgrounds around empty cells: the
- 2 The collapsing border model
- 1 Border conflict resolution
- 3 Border styles
- 1 The separated borders model
- 18 User interface
- 1 Cursors: the
cursor
property - 2 System Colors
- 3 User preferences for fonts
- 4 Dynamic outlines: the
outline
property- 1 Outlines and the focus
- 5 Magnification
- 1 Cursors: the
Replaces: =
Extends and supersedes: +
not: !
- CSS2§4.1 = [CSS-SYNTAX-3]
- CSS2§4.2 = [CSS-SYNTAX-3]
- CSS2§4.4 = [CSS-SYNTAX-3] CSS Syntax Level 3 b@[CSS-SYNTAX-3]@ Replaces p@CSS2§4.1@, p@CSS2§4.2@, p@CSS2§4.4@, and CSS2§G, redefining how CSS is parsed. CSS Style Attributes bhb@[CSS-STYLE-ATTR]@ Defines how CSS declarations can be embedded in markup attributes. Media Queries Level 3 bhb@[CSS3-MEDIAQUERIES]@ Replaces p@CSS2§7.3@ and expands on the syntax for media-specific styles.
- CSS2§7.3 = [CSS3-MEDIAQUERIES]
CSS Conditional Rules Level 3 bhb@[CSS-CONDITIONAL-3]@
Extends and supersedes p@CSS2§7.2@, updating the definition of
@media
rules to allow nesting and introducing the@supports
rule for feature-support queries. - CSS2§7.2 = [CSS-CONDITIONAL-3] Selectors Level 3 bhb@[SELECTORS-3]@ Replaces p@CSS2§5@ and p@CSS2§6.4.3@, defining an extended range of selectors.
- 5 = [SELECTORS-3]
- 6.4.3 = [SELECTORS-3] CSS Namespaces bhb@[CSS3-NAMESPACE]@ Introduces an @namespace rule to allow namespace-prefixed selectors. CSS Cascading and Inheritance Level 4 bhb@[CSS-CASCADE-4]@ Extends and supersedes p@CSS2§1.4.3@ and p@CSS2§6@, as well as bhb@[CSS-CASCADE-3]@. Describes how to collate style rules and assign values to all properties on all elements. By way of cascading and inheritance, values are propagated for all properties on all elements.
- 1.4.3 + [CSS-CASCADE-4]
- 6 + [CSS-CASCADE-4]
- [CSS-CASCADE-3] + [CSS-CASCADE-4] CSS Values and Units Level 3 bhb@[CSS-VALUES-3]@ Extends and supersedes p@CSS2§1.4.2.1@, p@CSS2§4.3@, and CSS2§A.2.1–3, defining CSS’s property definition syntax and expanding its set of units.
- 1.4.2.1 + [CSS-VALUES-3]
- 4.3 + [CSS-VALUES-3]
- A.2.1–3 + [CSS-VALUES-3] CSS Custom Properties for Cascading Variables Module Level 1 bhb@[CSS-VARIABLES-1]@ Introduces cascading variables as a new primitive value type that is accepted by all CSS properties, and custom properties for defining them. CSS Box Model Level 3 bhb@[CSS-BOX-3]@ Replaces p@CSS2§8.1@, p@CSS2§8.2@, p@CSS2§8.3@ (but not p@CSS2§8.3.1@), and p@CSS2§8.4@.
- 8.1 = [CSS-BOX-3]
- 8.2 = [CSS-BOX-3]
- 8.3 !8.3.1 = [CSS-BOX-3]
- 8.4 = [CSS-BOX-3] CSS Color Level 4 bhb@[CSS-COLOR-4]@ Extends and supersedes p@CSS2§4.3.6@, p@CSS2§14.1@, and p@CSS2§18.2@, also extends and supersedes bhb@[CSS-COLOR-3]@, introducing an extended range of color spaces beyond sRGB, extended color values, and CSS Object Model extensions for color. Also defines the opacity property.
- 4.3.6 + [CSS-COLOR-4]
- 14.1 + [CSS-COLOR-4]
- 18.2 + [CSS-COLOR-4]
- [CSS-COLOR-3] + [CSS-COLOR-4] CSS Backgrounds and Borders Level 3 bhb@[CSS-BACKGROUNDS-3]@ Extends and supersedes p@CSS2§8.5@ and p@CSS2§14.2@, providing more control of backgrounds and borders, including layered background images, image borders, and drop shadows.
- 8.5 + [CSS-BACKGROUNDS-3]
- 14.2 + [CSS-BACKGROUNDS-3] CSS Images Level 3 bhb@[CSS-IMAGES-3]@ Redefines and incorporates the external 2D image value type, introduces native 2D gradients, and adds additional controls for replaced element sizing and rendering. CSS Fonts Level 3 bhb@[CSS-FONTS-3]@ Extends and supersedes p@CSS2§15@ and provides more control over font choice and feature selection.
- 2§15 + [CSS-FONTS-3] CSS Writing Modes Level 3 bhb@[CSS-WRITING-MODES-3]@ Defines CSS support for various international writing modes, such as left-to-right (e.g. Latin or Indic), right-to-left (e.g. Hebrew or Arabic), bidirectional (e.g. mixed Latin and Arabic) and vertical (e.g. Asian scripts). Replaces and extends p@CSS2§8.6@ and p@CSS2§9.10@.
- 8.6 = [CSS-WRITING-MODES-3]
- 9.10 = [CSS-WRITING-MODES-3] CSS Multi-column Layout Level 1 bhb@[CSS-MULTICOL-1]@ Introduces multi-column flows to CSS layout. CSS Flexible Box Module Level 1 bhb@[CSS-FLEXBOX-1]@ Introduces a flexible linear layout model for CSS. CSS User Interface Module Level 3 bhb@[CSS-UI-3]@ Extends and supersedes p@CSS2§18.1@ and p@CSS2§18.4@, defining cursor, outline, and several new CSS features that also enhance the user interface.
- 18.1 + [CSS-UI-3]
- 18.4 + [CSS-UI-3]
CSS Containment Module Level 1 bhb@[CSS-CONTAIN-1]@
Introduces the contain property, which enforces the independent CSS processing of an element’s subtree in order to enable heavy optimizations by user agents when used well.
CSS Transforms Level 1 bhb@[CSS-TRANSFORMS-1]@
Introduces coordinate-based graphical transformations to CSS.
CSS Compositing and Blending Level 1 bhb@[COMPOSITING]@
Defines the compositing and blending of overlaid content and introduces features to control their modes.
CSS Easing Functions Level 1 bhb@[CSS-EASING-1]@.
Describes a way for authors to define a transformation that controls the rate of change of some value. Applied to animations, such transformations can be used to produce animations that mimic physical phenomena such as momentum or to cause the animation to move in discrete steps producing robot-like movement.
CSS Counter Styles Level 3 bhb@[CSS-COUNTER-STYLES-3]@
Introduces the
@counter-style
rule, which allows authors to define their own custom counter styles for use with CSS list-marker and generated-content counters bhb@[CSS-LISTS-3]@. It also predefines a set of common counter styles, including the ones present in CSS2 and CSS2.1.