lol_html 1.2.1

Streaming HTML rewriter/parser with CSS selector-based API
Documentation
<html><head>
  <title>NEGATED :nth-of-type() pseudo-class</title>
  <style type="text/css">.red { background-color : red }
p:not(:nth-of-type(3)) { background-color : lime }
dl > *:not(:nth-of-type(3n+1)) { background-color : lime }
</style>
  <link rel="author" title="Daniel Glazman" href="http://glazman.org/">
  <link rel="author" title="Ian Hickson" href="mailto:ian@hixie.ch">
  <link rel="help" href="https://www.w3.org/TR/css3-selectors/#selectors"> <!-- bogus link to make sure it gets found -->
  <meta name="flags" content="">
 </head>
 <body>
<!--[ELEMENT('p:not(:nth-of-type(3))')]--><p class="red"><!--[TEXT('p:not(:nth-of-type(3))')]-->This paragraph should have green background<!--[/TEXT('p:not(:nth-of-type(3))')]--></p><!--[/ELEMENT('p:not(:nth-of-type(3))')]-->
<address>And this address should be unstyled.</address>
<!--[ELEMENT('p:not(:nth-of-type(3))')]--><p class="red"><!--[TEXT('p:not(:nth-of-type(3))')]-->This paragraph should also have green background!<!--[/TEXT('p:not(:nth-of-type(3))')]--></p><!--[/ELEMENT('p:not(:nth-of-type(3))')]-->
<p>But this one should be unstyled again.</p>
<dl>
  <dt>First definition term</dt>
    <dd>First definition</dd>
  <dt class="red">Second definition term that should have green background</dt>
    <dd class="red">Second definition that should have green background</dd>
  <dt class="red">Third definition term that should have green background</dt>
    <dd class="red">Third definition that should have green background</dd>
  <dt>Fourth definition term</dt>
    <dd>Fourth definition</dd>
  <dt class="red">Fifth definition term that should have green background</dt>
    <dd class="red">Fifth definition that should have green background</dd>
  <dt class="red">Sixth definition term that should have green background</dt>
    <dd class="red">Sixth definition that should have green background</dd>
</dl>

</body></html>