The CSS saga
   The saga of CSS starts in 1994. Håkon Wium Lie works at
    CERN – the cradle of the Web – and the Web is starting
    to be used as a platform for electronic publishing. One crucial
    part of a publishing platform is missing, however: There is no way
    to style documents. For example, there is no way to describe a
    newspaper-like layout in a Web page. Having worked on personalized
    newspaper presentations at the MIT Media Laboratory, Håkon
    saw the need for a style sheet language for the Web.
   
Style sheets in browsers were not an entirely new idea. The
    separation of document structure from the document's layout had
    been a goal of HTML from its inception in 1990. Tim Berners-Lee
    wrote his NeXT browser/editor in such a way that he could
    determine the style with a simple style sheet. However, he didn't
    publish the syntax for the style sheets, considering it a matter
    for each browser to decide how to best display pages to its users.
    In 1992, Pei Wei developed a browser called Viola,
 which
    had its own style sheet language.
   
However, the browsers that followed offered their users fewer
    and fewer options to influence the style. In 1993, NCSA Mosaic,
    the browser that made the Web popular, came out. Stylewise,
    however, it was a backward step because it only allowed its users
    to change certain colors and fonts.
   
Meanwhile, writers of Web pages complained that they didn't have
    enough influence over how their pages looked. One of the first
    questions from an author new to the Web was how to change fonts
    and colors of elements. At that time, HTML did not provide this
    functionality – and rightfully so. This excerpt from a
    message sent to the www-talk mailing list early in 1994
    gives a sense of the tensions between authors and implementors:
   
   
    In fact, it has been a constant source of delight for me over
     the past year to get to continually tell hordes (literally) of
     people who want to -- strap yourselves in, here it comes --
     control what their documents look like in ways that would be
     trivial in TeX, Microsoft Word, and every other common text
     processing environment: "Sorry, you're screwed."
    
   The author of the message was Marc Andreessen, one of the
    programmers behind NCSA Mosaic. He later became a co-founder of
    Netscape, a company eager to fulfill the request of authors. On
    October 13, 1994, Marc Andreessen announced to www-talk
    that the first beta release of Mozilla (which later turned into
    Netscape Navigator) was available for testing. Among the new tags
    the new browser supported was center,
    and more tags were to follow shortly.
   
   Three days before Netscape announced the availability of its new
    browser, Håkon published the first draft of the
    Cascading HTML Style Sheets proposal. Behind the scenes,
    Dave Raggett (the main architect of HTML 3.0) had encouraged the
    release of the draft to go out before the upcoming Mosaic and
    the Web
 conference in Chicago. Dave had realized that HTML
    would and should never turn into a page-description language and
    that a more purpose-built mechanism was needed to satisfy
    requirements from authors. Although the first version of the
    document was immature, it provided a useful basis for discussion.
   
   Among the people who responded to the first draft of CSS was
    Bert Bos. At that time, he was
    building Argo, a highly customizable browser with style sheets,
    and he decided to join forces with Håkon. Both of the two
    proposals look different from present-day CSS, but it is not hard
    to recognize the original concepts.
   
One of the features of the Argo style language was that it was
    general enough to apply to other markup languages in addition to
    HTML. This also became a design goal in CSS and HTML
 was
    soon removed from the title of the specification. Argo also had
    other advanced features that didn't make it into CSS1, in
    particular, attribute selectors and generated text. Both features
    had to wait for CSS2.
   
   Cascading Style Sheets
 wasn't the only proposed style
    language at the time. There was Pei Wei's language from the Viola
    browser, and around 10 other proposals for style sheet languages
    were sent to the www-talk and www-html mailing
    lists. Then, there was DSSSL, a complex style and transformation
    language under development at ISO for printing SGML documents.
    DSSSL could conceivably be applied to HTML as well. But, CSS had
    one feature that distinguished it from all the others: It took
    into account that on the Web, the style of a document couldn't be
    designed by either the author or the reader on their own, but that
    their wishes had to be combined, or cascaded,
 in some way;
    and, in fact, not just the reader's and the author's wishes, but
    also the capabilities of the display device and the browser.
   
As planned, the initial CSS proposal was presented at the Web
    conference in Chicago in November 1994. The presentation at
    Developer's Day caused much discussion. First, the concept of a
    balance between author and user preferences was novel. A
    fictitious screen shot showed a slider with the label user
    on one side and author
 on the other. By adjusting the
    slider, the user could change the mix of his own preferences and
    those of the author. Second, CSS was perceived by some as being
    too simple for the task it was designed for. They argued that to
    style documents, the power of a full programming language was
    needed. CSS went in the exact opposite direction by making a point
    out of being a simple, declarative format.
   
   At the next WWW conference in April 1995, CSS was presented
    again. Both Bert and Håkon were there (in fact, this was the
    first time they met in person) and this time, they could also show
    implementations. Bert presented the support for style sheets in
    Argo, and Håkon showed a version of the Arena browser that
    had been modified to support CSS. Arena had been written by Dave
    Raggett as a testbed for new ideas, and one of them was style
    sheets. What started out as technical presentations ended up in
    political discussions about the author-reader balance.
    Representatives from the author
 side argued that the author
    ultimately had to be in charge of deciding how documents were
    presented. For example, it was argued that there may be legal
    requirements on how warning labels had to be printed and the user
    should not be able to reduce the font size for such warnings. The
    other side, where Bert and Håkon belong, argued that the
    user, whose eyes and ears ultimately have to decode the
    presentation, should be given the last word when conflicts
    arise.
   
   Outside of the political battles, the technical work continued.
    The www-style mailing list was created in May 1995, and
    the discussions there have often influenced the development of the
    CSS specifications. Almost 10 years later, there were more than
    16,000 messages in the archives of the mailing list. And after 20
    years, more than 80,000!
   
    Håkon Wium Lie, 12 December 1995
     
   
   
In 1995, the World Wide Web Consortium (W3C) also became
    operational. Companies were joining the Consortium at a high rate
    and the organization became established. Workshops on various
    topics were found to be a successful way for W3C members and staff
    to meet and discuss future technical development. It was therefore
    decided that another workshop should be organized, this time with
    style sheets as the topic. The W3C technical staff working on
    style sheets (namely Håkon and Bert) were now located in
    Sophia-Antipolis in Southern France where W3C had set up its
    European site. Southern France is not the worst place to lure
    workshop participants to, but because many of the potential
    participants were in the U.S., it was decided to hold the workshop
    in Paris, which is better served by international flights. The
    workshop was also an experiment to see if it was possible for W3C
    to organize events outside the U.S. Indeed, this turned out to be
    possible, and the workshop was a milestone in ensuring style
    sheets their rightful place on the Web. Among the participants was
    Thomas Reardon of Microsoft, who pledged support for CSS in
    upcoming versions of Internet Explorer.
   
    Bert Bos, 12 December 1995
     
   
   
At the end of 1995, W3C set up the HTML Editorial Review Board
    (HTML ERB) to ratify future HTML specifications. Because style
    sheets were within the sphere of interest of the members of the
    new group, the CSS specification was taken up as a work item with
    the goal of making it into a W3C Recommendation. Among the members
    of the HTML ERB was Lou Montulli of Netscape. After Microsoft
    signaled that it was adding CSS support in its browser, it was
    also important to get Netscape on board. Otherwise, we could see
    the Web diverge in different directions with browsers supporting
    different specifications. The battles within the HTML ERB were
    long and hard, but CSS level 1 finally emerged as a W3C
    Recommendation in December 1996.
   
In February 1997, CSS got its own working group inside W3C and
    the new group set out to work on the features which CSS1 didn't
    address. The group was chaired by Chris Lilley, a Scotsman
    recruited to W3C from the University of Manchester. CSS
    level 2 became a Recommendation in May 1998. Since then, the
    group has worked in parallel on new CSS modules and errata for
    CSS 2.
   
The W3C working group has members (around 15 in 1999, around 115
    in 2016) who are delegated by the companies and organizations
    that are members of W3C. They come from all over the world, so the
    meetings
 are usually over the phone, and last about an hour
    every week. About four times each year, they meet somewhere in the
    world.
   
   Browsers
   The CSS saga is not complete without a section on browsers. Had
    it not been for the browsers, CSS would have remained a lofty
    proposal of only academic interest. The first commercial browser
    to support CSS was Microsoft's Internet Explorer 3, which was
    released in August 1996. At that point, the CSS1 specification had
    not yet become a W3C Recommendation and discussions within the
    HTML ERB were to result in changes that Microsoft developers, led
    by Chris Wilson, could not foresee. IE3 reliably supports most of
    the color, background, font, and text properties, but it does not
    implement much of the box model.
   
The next browser to announce support for CSS was Netscape
    Navigator, version 4.0. Since its inception, Netscape had
    been skeptical toward style sheets, and the company's first
    implementation turned out to be a half-hearted attempt to stop
    Microsoft from claiming to be more standards-compliant than
    Netscape. The Netscape implementation supports a broad range of
    features – for example, floating elements – but the
    Netscape developers did not have time to fully test all the
    features that are supposedly supported. The result is that many
    CSS properties cannot be used in Navigator 4.
   
Netscape implemented CSS internally by translating CSS rules
    into snippets of JavaScript, which were then run along with other
    scripts. The company also decided to let developers write JSSS,
    thereby bypassing CSS entirely. If JSSS had been successful, the
    Web would have had one more style sheet than necessary. This,
    fortunately for CSS, turned out not to be the case.
   
Meanwhile, Microsoft continued its efforts to replace Netscape
    from the throne of reigning browsers. In Internet Explorer 4,
    the browser display engine, which among other things is
    responsible for rendering CSS, was replaced by a module code-named
    Trident.
 Trident removed many of the limitations in IE3,
    but also came with its own set of limitations and bugs. Microsoft
    was put under pressure by the Web Standards Project (WaSP), which
    published IE's Top 10 CSS Problems
 in November 1998 (see
    Figure 1).
   
    Figure 1. The WaSP project tracks browser
     conformance to W3C Recommendations. One of their first reviews
     was the CSS support in Microsoft Internet Explorer.
    ![[image]](history-wasp.png) 
   
   Subsequent versions of Internet Explorer have considerably
    improved the support for CSS.
   
     Figure 2. Opera's
    Figure 2. Opera's small-screen rendering
     transforms pages into columns.
   
   The third browser that ventured into CSS was Opera. The browser
    from the small Norwegian company made headlines in 1998 by being
    tiny (it fit on a floppy!) and customizable while supporting most
    features found in the larger offerings from Microsoft and
    Netscape. Opera 3.5 was released in November 1998, and
    supported most of CSS1. The Opera developers (namely Geir
    Ivarsøy) also found time to test the CSS implementation
    before shipping, which is a novelty in this business. Håkon,
    was so impressed with Opera's technology that he joined the
    company as CTO in 1999. One important market for Opera's browser
    is mobile phones. By reformatting pages to fit on a small screen
    (@media is handy here), the Web has been
    freed from the desktop (see Figure 2).
   
The people at Netscape responded to the increasing competition
    with a move that was novel at the time: They released the source
    code for the browser. With the source code public, anyone could
    inspect the internals of their product, improve it, and make
    competing browsers based on in. Much of the code, including the
    CSS implementation, was terminated shortly after the release, and
    the Mozilla
 project was formed to build a new generation
    browser. CSS was in important specification to handle and
    countless hours have been spent by volunteers to make sure pages
    are displayed according to the specification. Several browsers
    have been based on the Mozilla code, including Galeon and Firefox.
   
Apple is often seen as a technology pioneer, but for a long
    time, it did not spend much resources on Web browsers. Apple left
    it to Microsoft to build a browser for its machines, and Internet
    Explorer for Mac actually had better support for CSS than the
    Windows version of the browser. In 2003, Microsoft discontinued
    support for the Mac and Apple announced a new browser called
    Safari.
 Safari isn't entirely new – it is based on
    the open source Konqueror browser, which was developed for the KDE
    system running on Linux.
   
   For Web designers, it is good news to have several competing
    products based on Web standards. Although some efforts to test
    that your pages display well in all browsers are necessary, the
    fact that Web pages can be displayed on a wide range of machines
    is a huge improvement from the past:
   
    Anyone who slaps a this page is best viewed with Browser
     X
 label on a Web page appears to be yearning for the bad old
     days, before the Web, when you had very little chance of reading
     a document written on another computer, another word processor,
     or another network.
 – Tim Berners-Lee in
     Technology Review, July 1996
   
   
   Beyond browsers
   The CSS saga isn't only about Web browsers. Many people outside
    of the few that program Web browsers have made important
    contributions to CSS over the past years.
   
The CSS1 test suite was a landmark development for CSS
    and W3C.
    When the first two CSS implementations came out and could be
    compared, we realized there was a problem. You could not expect
    the style sheet tested only in one browser to work in the other
    browser. To rectify the situation, Eric Meyer – with help
    from countless other volunteers – developed a test suite
    that implementors would test against while there still was time to
    fix the problems. Todd Fahrner created the acid
 test in
    October 1998, which
    became the ultimate challenge. See Figure 3.
   
    Figure 3. The acid test.
    ![[Several colored boxes next and above each other]](sec5526c.gif) 
   
   
   When a test suite is available, someone must do the testing.
    Brian Wilson has done a remarkable job of testing CSS
    implementations and making the results available on the Web.
   
We should also mention the work in more recent years of Gérard
    Talbot and Geoffrey Sneddon on the official CSS testuite. And of
    course of Peter Linss, whose Shepherd server is a great help in
    seeing what tests exist, running them, and generating reports of
    results.
    
   
Without compelling content, CSS hasn't served its purpose. Dave
    Shea created the CSS Zen
    garden to show fellow graphics artists why CSS should be taken
    seriously. He, along with the many people who created submissions,
    showed people how to use CSS creatively.
   
   The Web has been trapped on the desktop for too long. Making it
    available on mobile phones is one important escape. Michael Day
    and Xuehong Liu have shown us another way out: The Prince
    formatter converts HTML and XML documents to PDF and is entirely
    based on CSS. This product enabled Håkon and Bert to abandon
    traditional word processors and use Web standards. Their book was written entirely in HTML
    and CSS.
   
   Web Fonts
   CSS level 2 contained a feature called Web Fonts
,
    i.e., the ability to embed fonts in a Web document. The idea was
    that a designer who wanted a specific font could actually provide
    the font along with the style sheet. During ten years, only
    Microsoft's Internet Explorer browser implemented that feature.
    (Netscape for a short period implemented an alternative, which
    didn't use CSS, wasn't as good, and was probably illegal in many
    countries because it slightly changed how each font looked.)
   
The reason Web Fonts didn't get implemented was twofold. First
    of all there were few fonts whose copyright allowed them to be
    distributed. Most fonts could be used to print documents locally,
    but you weren't allowed to put them on the Web.
   
Secondly, Microsoft and Monotype had developed a format called
    EOT (Embedded OpenType), which contained inside the fonts the
    names (URLs) of the documents that could be rendered with them.
    This allowed an EOT font to be made available on the Web alongside
    a document, because it now couldn't be used for any other
    document. But, the format was proprietary and nobody else but
    Microsoft could use it.
   
All that changed in early 2008. By then there were many more
    free fonts, i.e., fonts whose designers allowed them to be
    distributed for free on the Web. Håkon therefore started lobbying
    browser makers to finally implement Web Fonts (for fonts in the
    standard TrueType and OpenType formats) and Bert asked Microsoft
    if they couldn't open up EOT, so that others could implement it,
    too. In May, Microsoft and Monotype submitted EOT to W3C
    under a royalty-free license. And browsers started implementing
    support for downloading TrueType and OpenType fonts.
   
After further discussion, however, most browser makers decided
    not to implement EOT, but ask W3C to develop a new font format
    instead. The reason was that that they preferred to use the gzip
    compression algorithm (which was already used for HTTP) rather
    than add new code for the MicroType Express algorithm used by EOT.
   
That new format became WOFF.
    Rather than embed the URL of a document in the font, it relies on
    an HTTP feature (the origin
 header), which allows to give
    the domain part of a document's URL: less precise than a full URL,
    but still good enough for most font makers.
   
In the end, however, WOFF still adopted parts of EOT's MicroType
    Express algorithm, and a new compression algorithm (Brotli),
    because it allowed better compression than gzip.
   
Web Fonts have become very popular. Free fonts are used directly
    in the TrueType or OpenType format in which they were made. Less
    free fonts use the WOFF and EOT formats.
   
   There are now online services where you can find and download
    fonts (both free and non-free). And some even offer to host the
    fonts on their servers. In some cases even for free. (Which means
    they provide bandwidth, but in return they gather statistics on
    font usage).
   
   New directions: books and GUIs
   The development of CSS hasn't stopped. Far from it. CSS now has
    more than 60 modules that define different capabilities, some
    already part of the standard, some still in development.
   
   It is now common that books are made with CSS. Not all books,
    though, because CSS is still missing features for the more complex
    layouts. That is one direction in which the language is being
    extended.
   
E-books also use CSS, which requires yet other features. EPUB is
    the most widely implemented format for e-books. It was developed
    by IDPF. IDPF and W3C are currently (December 2016) in the
    process of merging their operations. The next EPUB version should
    then be made at W3C and the development of CSS features for books
    and e-books will be easier.
   
The development of programs (apps
) that use graphical
    user interfaces made out of HTML and CSS has also put new demands
    on CSS. Some of the latest modules of CSS deal with layout of user
    interfaces rather than documents. Although: as they are part of
    the same CSS, nothing prohibits their use for documents, too, if a
    part of a document happens to have a mark-up structure that allows
    it.
   
Over time, some browsers and other implementations have
    disappeared, and new ones have been created. There are now also
    languages derived from CSS for other purposes than styling
    documents. Probably the first language that used the syntax of CSS
    (but not the cascading and inheritance model) was STTS, by Daniel Glazman. That was in 1998. Since then others
    have made their appearance. Three that are currently in use are Qt Style
    Sheets for styling widgets in the Qt GUI toolkit, JavaFX Style Sheets, which does the same for the JavaFX UI
    widgets of Java, and MapCSS for
    describing the style of maps.
   
It is difficult to count how widely CSS is used, but the number
    of HTML pages that does not use CSS is probably not more
    than a few percent. Many people make their living as CSS designers
    or from CSS conferences. And the number of books written about CSS
    can no longer be counted.
   
Some day CSS will be replaced by something else. But before
    that, CSS will have time to celebrate its 21st birthday…