<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>@csstools/normalize.css — Greenflagged</title>
  <link rel="icon" href="data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><rect width='100' height='100' rx='20' fill='%23227a68'/><text x='50' y='72' font-size='60' font-weight='800' font-family='system-ui' text-anchor='middle' fill='white'>G</text></svg>">
  <link rel="preconnect" href="https://fonts.googleapis.com">
  <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
  <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap" rel="stylesheet">
  <link rel="stylesheet" href="/style.css">
  <script src="https://unpkg.com/htmx.org@2.0.4"></script>
  <script src="/confirm.js"></script>
  <script src="/local-time.js"></script>
</head>
<body>
  <!--
    Section is derived from activePage so existing pages don't have to opt
    in to the new sub-nav. Keep the lists below in sync when adding pages.
  -->
  
  <nav id="main-nav">
    <a href="/" class="brand">
      <span class="mark">G</span>
      greenflagged
    </a>
    <button class="nav-toggle" onclick="document.getElementById('main-nav').classList.toggle('menu-open')" aria-label="Toggle menu">&#9776;</button>
    
    <span class="spacer"></span>
    
    <a href="/login" class="auth-link">Login</a>
  </nav>
  <nav id="sub-nav" class="sub-nav">
    
      <a href="/packages" class="active">All</a>
      <a href="/packages/stale">Stale</a>
      <a href="/packages/provenance">Provenance</a>
      <a href="/incidents">Detected</a>
    
    
    
  </nav>
  
  <div class="container"><main>
  
  <p class="text-sm mb-1"><a href="/" class="link">&larr; Home</a></p>

  <div class="sticky-bar" id="sticky-bar">
    <span class="sticky-name">@csstools/normalize.css</span>
    <span class="sticky-stat">CC0-1.0</span>
    <span class="sticky-stat">10 versions</span>
    
    
    
  </div>

  <h1>@csstools/normalize.css</h1>

  <div class="flex-between">
    <div class="link-bar">
      <a href="https://www.npmjs.com/package/@csstools/normalize.css" target="_blank" rel="noopener">npm</a>
      <a href="https://github.com/csstools/normalize.css" target="_blank" rel="noopener">Repository</a>
      <a href="https://github.com/csstools/normalize.css#readme" target="_blank" rel="noopener">Homepage</a>
    </div>
    
  </div>

  <div class="card">
    <p class="text-sm">A cross-browser CSS foundation</p>
  </div>

  <div class="stats" style="margin-top: 1rem;">
    <div class="stat">
      <div class="value">10</div>
      <div class="label">Versions</div>
    </div>
    <div class="stat">
      <div class="value">CC0-1.0</div>
      <div class="label">License</div>
    </div>
    <div class="stat">
      <div class="value">No</div>
      <div class="label">Install Scripts</div>
    </div>
    <div class="stat warn">
      <div class="value">Missing</div>
      <div class="label">Provenance</div>
    </div>
  </div>

  <!-- Provenance status — always shown so reviewers can push the angle.
       SLSA attestations are the strongest supply-chain integrity signal;
       only ~12% of npm packages have them. -->
  <div class="card">
    <h2>Supply chain provenance</h2>
    <p class="text-sm text-muted" style="margin-bottom: 0.5rem;">
      Status for the latest visible version.
    </p>
    <div style="display: flex; flex-wrap: wrap; gap: 0.5rem;">
      <span class="badge badge-rejected">No SLSA provenance</span>
      <span class="badge badge-approved">npm registry signatures</span>
      <span class="badge badge-approved">gitHead linked</span>
    </div>
    <p class="text-sm text-muted" style="margin-top: 0.5rem;">
      Without SLSA provenance there is no cryptographic link between this
      tarball and the public source — the axios compromise (March 2026)
      relied on exactly this gap.
    </p>
  </div>

  <!-- Author Trust -->
  

  <!-- Fallback maintainers -->
  <div class="card">
    <h2>Maintainers</h2>
    <div class="maintainer-list">
      <span class="maintainer-chip">romainmenke</span><span class="maintainer-chip">alaguna</span><span class="maintainer-chip">jonathantneal</span>
    </div>
  </div>

  <!-- Keywords -->
  <div class="card">
    <h2>Keywords</h2>
    <div class="keyword-list">
      <span class="keyword-chip">css</span><span class="keyword-chip">normalizes</span><span class="keyword-chip">browsers</span><span class="keyword-chip">fixes</span>
    </div>
  </div>

  
  <div class="card">
    <h2>Accepted risks</h2>
    <p class="text-sm text-muted" style="margin-bottom: 0.5rem;">
      Findings the reviewer chose to accept rather than block on.
    </p>
    <table>
      <thead>
        <tr><th>Source</th><th>Rule</th><th>Reason</th><th>Accepted by</th><th>When</th></tr>
      </thead>
      <tbody>
        <tr>
          <td><span class="badge badge-sm">provenance</span></td>
          <td class="mono text-sm">publisher-changed</td>
          <td class="text-sm">AI (provenance): romainmenke is a well-established csstools org maintainer with 900 approved packages and 0 rejections; the jonathantneal→romainmenke transition is a documented legitimate org handoff.</td>
          <td class="text-sm text-muted">ai</td>
          <td class="text-sm text-muted">
            <time class="local-time"
                  datetime="2026-04-24T13:13:08.670078Z">2026/04/24</time>
          </td>
        </tr>
        <tr>
          <td><span class="badge badge-sm">maintainer-change</span></td>
          <td class="mono text-sm">maintainer-added</td>
          <td class="text-sm">AI (maintainer-change): New maintainers romainmenke and alaguna are part of the csstools org; this is a legitimate team expansion, not a suspicious takeover.</td>
          <td class="text-sm text-muted">ai</td>
          <td class="text-sm text-muted">
            <time class="local-time"
                  datetime="2026-04-24T13:13:08.670078Z">2026/04/24</time>
          </td>
        </tr>
        <tr>
          <td><span class="badge badge-sm">provenance</span></td>
          <td class="mono text-sm">no-provenance</td>
          <td class="text-sm">AI (provenance): Pure CSS package with no executable code; lack of provenance attestation carries negligible risk for this package type.</td>
          <td class="text-sm text-muted">ai</td>
          <td class="text-sm text-muted">
            <time class="local-time"
                  datetime="2026-04-24T13:13:08.670078Z">2026/04/24</time>
          </td>
        </tr>
      </tbody>
    </table>
  </div>

  <!-- Versions -->
  <div class="card">
    <div class="flex-between">
      <h2>Versions <span class="text-muted text-sm">(showing 10 of 10)</span></h2>
      <div style="display: flex; gap: 0.3rem;">
        
        
        
      </div>
    </div>

    <!-- Bulk action bar -->
    

    <table>
      <thead>
        <tr>
          
          <th>Version</th>
          
          
          <th>Deps</th>
          
          
          <th>Published</th>
        </tr>
      </thead>
      <tbody>
        <tr id="vrow-10929">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/12.1.1" class="mono link fw-500">12.1.1</a>
          </td>
          
          
          <td class="text-sm">0 / 0</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2023-12-29T14:35:59.531Z">2023-12-29</time>
            
          </td>
        </tr>
        <tr id="vrow-1266915">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/12.1.0" class="mono link fw-500">12.1.0</a>
          </td>
          
          
          <td class="text-sm">0 / 0</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2023-12-29T14:33:23.510Z">2023-12-29</time>
            
          </td>
        </tr>
        <tr id="vrow-1266914">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/12.0.0" class="mono link fw-500">12.0.0</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2021-09-15T12:32:42.826Z">2021-09-15</time>
            
          </td>
        </tr>
        <tr id="vrow-1266913">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/11.0.1" class="mono link fw-500">11.0.1</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2020-08-20T08:16:25.577Z">2020-08-20</time>
            
          </td>
        </tr>
        <tr id="vrow-1266912">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/11.0.0" class="mono link fw-500">11.0.0</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2020-08-20T02:43:23.269Z">2020-08-20</time>
            
          </td>
        </tr>
        <tr id="vrow-1266911">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/10.1.0" class="mono link fw-500">10.1.0</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2019-06-03T17:25:43.665Z">2019-06-03</time>
            
          </td>
        </tr>
        <tr id="vrow-1266910">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/10.0.0" class="mono link fw-500">10.0.0</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2019-05-17T06:24:05.971Z">2019-05-17</time>
            
          </td>
        </tr>
        <tr id="vrow-1266909">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/9.0.1" class="mono link fw-500">9.0.1</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2018-09-04T12:47:15.795Z">2018-09-04</time>
            
          </td>
        </tr>
        <tr id="vrow-1266908">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/9.0.0" class="mono link fw-500">9.0.0</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2018-08-22T15:48:25.468Z">2018-08-22</time>
            
          </td>
        </tr>
        <tr id="vrow-1266907">
          
          <td>
            <a href="/packages/@csstools/normalize.css/v/8.0.0" class="mono link fw-500">8.0.0</a>
          </td>
          
          
          <td class="text-sm">0 / 2</td>
          
          
          <td class="text-sm text-muted">
            <time class="local-time" data-format="date"
                  datetime="2018-06-16T00:44:56.783Z">2018-06-16</time>
            
          </td>
        </tr>
      </tbody>
    </table>

    

    
  </div>

  <!-- Public per-version findings: only shown for versions with vuln/malware,
       provenance signals, or HIGH/CRITICAL findings from any analyzer.
       Suppressed for admins — the version table's "Findings" count plus the
       per-version page (/packages/{name}/v/{version}) carry the full detail,
       so the list page stays light and doesn't ship every version's
       sast_results blob. The auth check is per-render, not per-row, so it
       wraps the loop instead of riding on each card. -->
  
    
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/12.1.0" class="link">v12.1.0</a>
        </h2>
        <span class="text-sm text-muted">2 findings</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-high">HIGH</span>
          <span class="finding-title">Publisher changed: jonathantneal → romainmenke (on 2023-12-29)</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">This version was published by a different npm account than previous versions on 2023-12-29. This could indicate a legitimate maintainer transition or an account compromise.</p>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">LOW</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">Package was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/12.0.0" class="link">v12.0.0</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">LOW</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">Package was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/11.0.1" class="link">v11.0.1</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/11.0.0" class="link">v11.0.0</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Only ~12% of npm packages have provenance, so this is common but not ideal.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/10.1.0" class="link">v10.1.0</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/10.0.0" class="link">v10.0.0</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Consider requesting the maintainer enable provenance via CI/CD.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/9.0.1" class="link">v9.0.1</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Only ~12% of npm packages have provenance, so this is common but not ideal.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/9.0.0" class="link">v9.0.0</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Only ~12% of npm packages have provenance, so this is common but not ideal.</p>
      </div>
    </div>
    <div class="card">
      <div class="flex-between">
        <h2>
          <a href="/packages/@csstools/normalize.css/v/8.0.0" class="link">v8.0.0</a>
        </h2>
        <span class="text-sm text-muted">1 finding</span>
      </div>

      <div class="finding-card">
        <div class="finding-header">
          <span class="severity risk-low">INFO</span>
          <span class="finding-title">No provenance attestation</span>
          <span class="badge badge-sm" style="margin-left: auto;">provenance</span>
        </div>
        <p class="finding-detail linkify">[Accepted risk] Package was published without Sigstore provenance. Only ~12% of npm packages have provenance, so this is common but not ideal.</p>
      </div>
    </div>
  

  <script>
    document.querySelectorAll('.linkify').forEach(function(el) {
      el.innerHTML = el.textContent.replace(
        /(https?:\/\/[^\s<]+)/g,
        '<a href="$1" target="_blank" rel="noopener" class="link">$1</a>'
      );
    });
  </script>
</main></div>
</body>
</html>
