Benchmark

This example compares performance of different date formatters

<p>This example compares performance of different date formatters</p>
<!DOCTYPE html> <html lang="en"> <head> <base href="/dataviewsjs/demos/en/sample/Benchmarks/DateFormatting/purejs/" /> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="description" content="This example compares performance of different date formatters" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Date Formatting | Benchmarks | GrapeCity DataViewsJS JavaScript Demos</title> <link href="/dataviewsjs/demos/node_modules/normalize.css/normalize.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/static/css/base.css" rel="stylesheet" type="text/css" /> <link href="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.css" rel="stylesheet" type="text/css" /> <link href="styles.css" rel="stylesheet" type="text/css" /> <!-- Google Tag Manager --> <script> (function (w, d, s, l, i) { w[l] = w[l] || []; w[l].push({ 'gtm.start': new Date().getTime(), event: 'gtm.js' }); var f = d.getElementsByTagName(s)[0], j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src = 'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f); })(window, document, 'script', 'dataLayer', 'GTM-WT462SJ'); </script> <!-- End Google Tag Manager --> <script src="/dataviewsjs/demos/static/js/app-polyfills.min.js" type="text/javascript"></script> <script type="text/javascript"> window.process = { env: { NODE_ENV: 'production', USE_NPM: false, USE_CDN: false, SITE_ROOT: '/dataviewsjs/demos', FRAMEWORK: 'purejs', DVJS_LICENSE_KEY: 'E674186349827489#B0LYWQMpFdP3WSHlVaGdjTFtyLCxUQjdFV5MHey9kTyBnY0pkY6tWcr34caJjSPlEVlR6QpJnZEdjSj9kbkRUZChzMsRFS99mN4ZGO72yK7FXe5tmN59Eai5UM7dEVvgUeYN5MqdUTIpWTpBnSTJEWv24YwoFWr9mWEl6UNVmVMxUd5ckUQdlUNV4MDhENaV5KNNWbJtiSwFUYCVUax4GUuBjZDN7T5dWdDpFNyJjSxJkes3mUt94QrdnMK5mZORGeFZ4QyFTMmdWOWdlMmJ4ZJhTS5MmZatyZ7k5c0JXVB3mWVNke7AFRiojITJCLikjNBNjNzcjI0ICSiwSN8AjN9YjMwUTM0IicfJye35XX3JSWUVVOiojIDJCLiEjdgMlSzdXZpZVY4FGRiojIOJyebpjIkJHUiwiI9MDMykDMggDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WSgkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI9gDN7IDO9QzM6gTM4cjNiojIklkI1pjIEJCLi4TPn3UZuJ7cPZTW5hUMtN7MJN6aQFnT5gmd9FEZ4EETlFmW63kU8IGdiRGTJZle5UDbZJHTR34T0JzZoZmbalXQwNmM8EndEFEdSVlMiVnckFmQUJTOahmc7AzRHhlU4I4Vs3kN6lHaHR4LuhWULNIe', SJS_LICENSE_KEY: '*.grapecity.com,E613631884219496#B0qRgJHWSJ7NyBlc8BjNMRHW7g7YldTZXFTQuFnW4hVOCplVSlVV09ERlhEZuVTVKlTazE4Q6VGSw2CdWZUWSVmbjVXbrxmWFVWR8ZzQro7U84WMGdlbuVHb73kS5kjUTN4NvFVdLdXWVR4Nox6Z7UUSysEcXJEMsN6bDN4TxMDVwVmWBRzKxhkTzAXTaJmdD3CRFJTd8R4R6M5RklWa6oUaLlXMwR4R8ZUdtRWVxUUaQh6VXNDdEhlZ7FHR6QXTPJTVvkWcyZnbSdHRtZHcYF6TKN4axYGcZNjTDF7TvFTTr24VqZjVHVjcLd7QkRmdNxkI0IyUiwiI5gDOEF4QGVjI0ICSiwiMzkTO9kTOyMTM0IicfJye35XX3JSSGljQiojIDJCLiITMuYHITpEIkFWZyB7UiojIOJyebpjIkJHUiwiI4MDMyEDMgkDM8ATOxAjMiojI4J7QiwiIt36YukHdpNWZwFmcn9iKiojIz5GRiwiIj9WagkHdpNUZwFmcHJiOiEmTDJCLlVnc4pjIsZXRiwiI6kDN9EjM4gDOxMjNzEjNiojIklkIs4XZzxWYmpjIyNHZisnOiwmbBJye0ICRiwiI34TQ72kNBV6YXpXdGxGWxdHcol4MyUGUHJVbQVHRx44Sw84YxRkS4QnZadDNmhWWxV5QxFlTlZEbBJ5N8gUNQlDb7J6Kl36YHVnb4NGN92UMFdlNORFU8VDSaFlQSVlS4EHTrA5Ohh', }, }; </script> <script src="/dataviewsjs/demos/node_modules/jquery/dist/jquery.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/moment/moment.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/lodash/lodash.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/platform/platform.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/benchmark/benchmark.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/node_modules/bowser/es5.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/js/jsperf.ui.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.common.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/dataviews/gc.dataviews.core.min.js" type="text/javascript"></script> <script src="/dataviewsjs/demos/static/js/license.js" type="text/javascript"></script> </head> <body class="theme-default"> <!-- Google Tag Manager (noscript) --> <noscript ><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-WT462SJ" height="0" width="0" style="display: none; visibility: hidden;" ></iframe ></noscript> <!-- End Google Tag Manager (noscript) --> <noscript>You need to enable JavaScript to run this app.</noscript> <section id="runner"> <h2>Test runner</h2> <div id="options"> <div class="option"> <label>Category</label> <select id="test-category" value="render"> <option value="render">Rendering</option> <option value="sort">Sorting + Rendering</option> <option value="filter">Filtering + Rendering </option> <option value="group">Grouping + Rendering</option> </select> </div> <div class="option"> <label>Data size</label> <select id="data-size" value="1000"> <option value="1000">1000</option> <option value="10000">10000</option> <option value="100000">100000</option> </select> </div> </div> <p id="firebug"> <strong>Warning! For accurate results, please disable Firebug before running the tests.</strong> </p> <p id="java"><strong>Java applet disabled.</strong></p> <div id="test-container"> <div id="controls"> <div id="status"></div> <button id="run" type="button">Run again</button> </div> <table id="test-table"> <caption></caption> <thead> <tr> <th>Test</th> <th title="Operations per second (higher is better)">Ops/sec</th> </tr> </thead> <tbody></tbody> </table> <div id="error-info"></div> </div> </section> <script src="data.js" type="text/javascript"></script> <script src="app.js" type="text/javascript"></script> </body> </html>
var dataSize = parseInt($('#data-size').val(), 10); var data = generateData(dataSize); $('#data-size').change(function () { var dataSize = parseInt($('#data-size').val(), 10); data = generateData(dataSize); }); function formatDates(formatter) { data.slice(0, 10).forEach(function (date) { dateFormats.forEach(function (format) { formatter(format, date); }); }); } function formatSJS(format, date) { var formatter = new GC.Spread.Formatter.GeneralFormatter(format); return formatter.format(date); } function sjsCase() { return { name: 'SpreadJS', homepage: 'https://www.grapecity.com/spreadjs', fn: function fn() { formatDates(formatSJS); }, }; } function dvjsCase() { return { name: 'DataViewsJS', homepage: 'https://www.grapecity.com/dataviewsjs', fn: function fn() { formatDates(GC.DataViews.GeneralFormatter.formatDate); }, }; } function momentFormat(format, date) { return moment(date).format(format); } function momentCase() { return { name: 'MomentJS', homepage: 'https://momentjs.com/', fn: function fn() { formatDates(momentFormat); }, }; } $(function () { window.ui.add(sjsCase()); window.ui.add(dvjsCase()); window.ui.add(momentCase()); });
function repeatOf(k) { switch (k) { case 'M': case 'm': case 'D': case 'd': return [1, 2, 3, 4]; case 'Q': return [1]; case 'Y': case 'y': return [2, 4]; case 'F': case 'f': return [1, 2, 3]; default: return [1, 2]; } } var combinations = function combinations(templates) { return templates.reduce(function (acc, k) { var repeat = repeatOf(k); var combs = repeat.map(function (n) { return _.repeat(k, n); }); return _.isEmpty(acc) ? combs : _.flatten( acc.map(function (a) { return combs.map(function (b) { return ''.concat(a, '-').concat(b); }); }) ); }, []); }; var dateTemplates = combinations(['M', 'D', 'Y']).concat(combinations(['m', 'd', 'y'])); var timeTemplates = combinations(['H', 'm', 'S']) .concat(combinations(['h', 'm', 's'])) .map(function (t) { return t.replace(/-/g, ':'); }); var dateSeparators = ['/', '-', '.', ' ']; var dateFormats = _.flatten( dateSeparators.map(function (s) { return dateTemplates.map(function (f) { return f.replace(/-/g, s); }); }) ); dateFormats.forEach(function (f) { timeTemplates.forEach(function (t) { dateFormats.push(''.concat(f, ' ').concat(t)); dateFormats.push(''.concat(f, ', ').concat(t)); ['t', 'tt'].forEach(function (p) { dateFormats.push(''.concat(f, ' ').concat(t).concat(p)); dateFormats.push(''.concat(f, ', ').concat(t).concat(p)); }); }); }); var ISO_FORMAT = 'YYYY-MM-DDTHH:mm:ss.fffZ'; dateFormats.push(ISO_FORMAT); // week days dateFormats.push('ddd'); dateFormats.push('dddd'); dateFormats.push('DDD'); dateFormats.push('DDDD'); dateFormats.push('ddd, mmm dd'); // additional testing formats dateFormats.concat(['HH:mm:ss.S', 'HH:mm:ss.SS', 'HH:mm:ss.SSS']); var generateData = function generateData(n) { return _.range(0, n).map(function (t) { return new Date( Date.UTC( _.random(2000, 2020), _.random(0, 11), _.random(1, 28), _.random(0, 59), _.random(0, 59), _.random(0, 59) ) ); }); };
html, body, h1, h2, h3, fieldset, #faq, #faq dt, #faq dd { margin: 0; padding: 0; border: 0; } table, p, ul, h1, h2, h3, #error-info, form div, #faq, .bs-rt { margin-bottom: 1em; } button, input, textarea, a, .bs-rt { border-radius: 4px; } html, input, textarea, button { font: 1em/1.5 sans-serif; } body { background: #fff; padding: 0 2.5em; margin: 0 auto; min-height: 100%; } a, .btn-link { color: #357ab0; padding: 0.2em; } a:hover, a:focus, .btn-link:hover, .btn-link:focus { text-decoration: none; } .btn-link { background-color: transparent; border: 0; text-decoration: underline; } .btn-link:hover, .btn-link:focus { cursor: pointer; } blockquote { margin: 0 0 1em; border-left: 5px solid #b4b4b4; padding-left: 0.5em; } table { border-collapse: collapse; } thead th, button:hover, button:focus, .submit:hover, .submit:focus, a:hover, a:focus, .btn-link:hover, .btn-link:focus, #comments .meta a:hover, #comments .meta a:focus, li.current a:hover, li.current a:focus, form h3, #comments .owner .meta { background: #1a6ab9; background-image: linear-gradient(top, #6ca5dd, #1a6ab9); color: #fff; } caption, #comments .meta { background: #bcbcbc; background-image: linear-gradient(top, #d0d0d0, #a7a7a7); color: #555; } thead th, caption { font-weight: bold; } .js tbody th:hover, .js tbody th:focus { text-decoration: underline; cursor: pointer; } tbody th, td { border: solid #b4b4b4; border-width: 0 1px 1px 0; } tbody th { background: #dde4ea; width: 150px; } td.results { text-align: center; border-right: 0; } .results span, small { display: block; font-size: 0.8em; } td, th, caption { padding: 0.2em 0.5em; } td.fastest { background: #9cee82; } tr:last-child td, tr:last-child th { border-bottom: 0; } td.slowest, td.error, .invalid { background: pink; } /* needs its own rule because of buggy IE */ :focus:invalid { background: pink; } td.error { text-transform: uppercase; font-weight: bold; } button, .submit { padding: 0.35em 0.5em; cursor: pointer; color: #000; border: 1px solid #999; background: #dadada; background-image: linear-gradient(top, #ebebeb, #b8b8b8); } .login { padding: 0.35em 0.5em; text-decoration: none; cursor: pointer; color: #000; border: 1px solid #999; background: #dadada; background-image: linear-gradient(top, #ebebeb, #b8b8b8); } a:hover span, a:focus span, #comments .owner .meta a { color: #fff; } #options { display: flex; align-items: center; flex-wrap: wrap; } #options label, #options select { margin-right: 5px; } #options .option { display: inline-block; margin-bottom: 0.5em; } #test-container { display: flex; flex-direction: column; max-width: 800px; } #test-table { flex: 1 1; width: 100%; margin: 0.5em 0; } #controls { display: flex; align-items: center; justify-content: space-between; flex: 1 1; width: 100%; margin: 0.5em 0; } .buttons { float: right; } button:hover, button:focus, .submit:hover, .submit:focus { border-color: #357ab0; } #add-buttons button { padding: 0.15em 0.4em; font-size: 11px; font-weight: bold; } form label { float: left; width: 14em; cursor: pointer; text-align: right; margin-right: 1em; padding: 0.4em; } label.inline { float: none; padding: 0; margin: 0; } label[for=visible], label[for$="][defer]"] { position: relative; top: -0.37em; } label span { display: block; font-size: 90%; color: #b4b4b4; } label em { color: red; font-style: normal; } .js #advanced { display: none; } #show-advanced { display: none; } .js #show-advanced { display: block; } section { display: block; margin: 2em 0; } textarea { resize: vertical; height: 15em; width: 42.6em; *width: 42.4em; /* IE < 8 */ } input, textarea { border: 1px solid #b4b4b4; padding: 0.4em; } input[type=search] { -webkit-appearance: none; } #visible, #calibrate { /* checkboxes, for IE */ border: 0; padding: 0; } form h2, form h3, form h4, p.error, .preview, #add-libraries, #add-buttons { padding-left: 250px; display: block; } hgroup h2, #firebug, #java { display: none; } pre { width: 100%; overflow: auto; white-space: pre; white-space: pre-wrap; word-wrap: break-word; } table #results-1 { width: 100px; } table pre { *padding: 1.5em 0; /* IE < 8 */ *overflow-y: hidden; /* IE < 8 */ } table pre, table td.code { width: 600px; } mark { background: #ff9; padding: 0.2em 0.1em; } h1, h2, h3, h4 { font-weight: bold; font-size: 1em; } h1 { padding-top: 1em; font-size: 1.4em; } form h3 { padding-top: 0.2em; padding-bottom: 0.2em; } h1 em { font-style: normal; } h1 strong { font-style: italic; font-family: Monaco, "Lucida Console", monospace; } li.current a { background: #90ee85; } footer { display: block; margin-top: 2em; border-top: 2px solid #c4c4c4; font-size: 0.9em; overflow: hidden; } footer ul { list-style: none; padding: 0; margin: 0; } footer > ul > li { float: left; width: 15%; } footer > ul > li:first-child { width: 55%; } footer ul ul li { margin-bottom: 0.1em; } footer h4 { margin-bottom: 0.2em; } #add-test { margin-right: 0.3em; } #bs-chart { overflow: auto; } #bs-chart-frame { height: 240px; width: 100%; } #bs-logo { margin: 0; } #bs-logo span, applet { position: absolute; left: -9999em; } #bs-logo a { display: block; width: 232px; height: 39px; filter: none; background: url(//www.browserscope.org/static/img/logo.png) 0 0 no-repeat; } #bs-ua { padding: 0.5em 0.5em 0; color: #555; } #bs-results .bs-rt { font-size: 10pt; padding: 0.5em; background: #ddd; } #bs-results td { border: 1px solid #ddd; padding: 0.4em; white-space: nowrap; } #bs-results .rt-ua-cur { font-style: italic; font-weight: bold; } #bs-results .bs-rt-message { padding: 3em; text-align: center; font-weight: bold; color: #555; } #bs-results .google-visualization-table-tr-head td { white-space: normal; } #comments h1 { padding: 0; } #comments .meta img { position: absolute; left: 0; top: 0; margin: 0; } #comments .meta img { top: 2px; left: 2px; } #comments .meta { padding-left: 35px; margin-top: 0; width: 923px; line-height: 30px; } #comments .meta a { font-weight: bold; color: #555; } #comments article div { padding: 0 1em 0; } #comments article { display: block; border: 1px solid #b4b4b4; position: relative; margin-bottom: 1em; } /* needs its own rule (cannot be grouped with `tbody th`) because of buggy IE */ #comments article:target { background: #dde4ea; } #error-info.show, .meta strong, #firebug strong, #java strong, #status strong { background: pink; border: 1px solid #b00b00; padding: 0.4em; } #error-info.show { padding: 0.5em 1em; } #error-info, code, samp, var, textarea, #slug { font-family: Monaco, monospace; font-size: 0.9em; -moz-tab-size: 2; tab-size: 2; } #java strong { background: #ffffdc; border: 1px solid #faa700; } #slug { font-size: 1em; } #faq dt { margin-top: 1em; font-weight: bold; } #faq dt a { display: none; } #faq dt:hover a { display: inline; } #faq dt:target, #faq dt:target + dd { background: #90ee85; margin: 0 -0.8em; padding: 0 0.8em; } #faq dt:target + dd { padding-bottom: 0.5em; margin-bottom: -0.5em; } #faq dt:target { margin-top: 0.5em; padding-top: 0.5em; } #firebug, #java { margin: 0 0 1em; padding: 0.3em 0; } #prep-code pre { max-height: 500px; overflow: auto; } #firebug.show, #java.show { display: block; } .co1, .co2, .coMULTI { font-style: italic; color: #060; } .error { color: #b00b00; } .imp { color: red; } .kw1, .kw3 { color: #006; } .kw2 { color: #036; } .es0 { color: #009; } .br0 { color: #090; } .sy0 { color: #393; } .st0 { color: #36c; } .nu0 { color: #c00; } .me1 { color: #606; } #carbonads { float: right; width: 130px; font-size: 80%; } #carbonads a { display: block; } /* < 1051px */ @media (max-width: 1050px) { table pre, table td.code { width: 550px; } } /* < 1041px */ @media (max-width: 1040px) { body { margin: 0; border: 0; } body, #comments .meta { width: 100%; box-sizing: border-box; } } /* < 801px */ @media (max-width: 800px) { table pre, table td.code { width: 450px; } } /* < 681px */ @media (max-width: 680px) { table pre, table td.code { width: 350px; } } /* < 651px */ @media (max-width: 650px) { table pre, table td.code { width: 200px; } } /*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["DateFormatting/purejs/build.json","DateFormatting/purejs/build.css"],"names":[],"mappings":"AAAA;;;;;;;;;EASE,SAAA;EACA,UAAA;EACA,SAAA;ACCF;;ADEA;;;;;;;;;;EAUE,kBAAA;ACCF;;ADEA;;;;;EAOE,kBAAA;ACCF;;ADEA;;;;EAIE,wBAAA;ACCF;;ADEA;EACE,gBAAA;EACA,gBAAA;EACA,cAAA;EACA,gBAAA;ACCF;;ADEA;;EAEE,cAAA;EACA,cAAA;ACCF;;ADEA;;;;EAIE,qBAAA;ACCF;;ADEA;EACE,6BAAA;EACA,SAAA;EACA,0BAAA;ACCF;;ADEA;;EAEE,eAAA;ACCF;;ADEA;EACE,eAAA;EACA,8BAAA;EACA,mBAAA;ACCF;;ADEA;EACE,yBAAA;ACCF;;ADEA;;;;;;;;;;;;;;;EAeE,mBAAA;EACA,wDAAA;EACA,WAAA;ACCF;;ADEA;;EAEE,mBAAA;EACA,wDAAA;EACA,WAAA;ACCF;;ADEA;;EAEE,iBAAA;ACCF;;ADEA;;EAEE,0BAAA;EACA,eAAA;ACCF;;ADEA;;EAEE,qBAAA;EACA,yBAAA;ACCF;;ADEA;EACE,mBAAA;EACA,YAAA;ACCF;;ADEA;EACE,kBAAA;EACA,eAAA;ACCF;;ADEA;;EAEE,cAAA;EACA,gBAAA;ACCF;;ADEA;;;EAGE,oBAAA;ACCF;;ADEA;EACE,mBAAA;ACCF;;ADEA;;EAEE,gBAAA;ACCF;;ADEA;;;EAGE,gBAAA;ACCF;;ADEA,2CAAA;AACA;EACE,gBAAA;ACCF;;ADEA;EACE,yBAAA;EACA,iBAAA;ACCF;;ADEA;;EAEE,qBAAA;EACA,eAAA;EACA,WAAA;EACA,sBAAA;EACA,mBAAA;EACA,wDAAA;ACCF;;ADEA;EACE,qBAAA;EACA,qBAAA;EACA,eAAA;EACA,WAAA;EACA,sBAAA;EACA,mBAAA;EACA,wDAAA;ACCF;;ADEA;;;EAGE,WAAA;ACCF;;ADEA;EACE,aAAA;EACA,mBAAA;EACA,eAAA;ACCF;ADCE;;EAEE,iBAAA;ACCJ;ADEE;EACE,qBAAA;EACA,oBAAA;ACAJ;;ADIA;EACE,aAAA;EACA,sBAAA;EACA,gBAAA;ACDF;;ADIA;EACE,SAAA;EACA,WAAA;EACA,eAAA;ACDF;;ADIA;EACE,aAAA;EACA,mBAAA;EACA,8BAAA;EACA,SAAA;EACA,WAAA;EACA,eAAA;ACDF;;ADIA;EACE,YAAA;ACDF;;ADIA;;;;EAIE,qBAAA;ACDF;;ADIA;EACE,qBAAA;EACA,eAAA;EACA,iBAAA;ACDF;;ADIA;EACE,WAAA;EACA,WAAA;EACA,eAAA;EACA,iBAAA;EACA,iBAAA;EACA,cAAA;ACDF;;ADIA;EACE,WAAA;EACA,UAAA;EACA,SAAA;ACDF;;ADIA;;EAEE,kBAAA;EACA,YAAA;ACDF;;ADIA;EACE,cAAA;EACA,cAAA;EACA,cAAA;ACDF;;ADIA;EACE,UAAA;EACA,kBAAA;ACDF;;ADIA;EACE,aAAA;ACDF;;ADIA;EACE,aAAA;ACDF;;ADIA;EACE,cAAA;ACDF;;ADIA;EACE,cAAA;EACA,aAAA;ACDF;;ADIA;EACE,gBAAA;EACA,YAAA;EACA,aAAA;GACA,aAAA;EAAgB,WAAA;ACAlB;;ADGA;;EAEE,yBAAA;EACA,cAAA;ACAF;;ADGA;EACE,wBAAA;ACAF;;ADGA;;EAEE,uBAAA;EACA,SAAA;EACA,UAAA;ACAF;;ADGA;;;;;;;EAOE,mBAAA;EACA,cAAA;ACAF;;ADGA;;;EAGE,aAAA;ACAF;;ADGA;EACE,WAAA;EACA,cAAA;EACA,gBAAA;EACA,qBAAA;EACA,qBAAA;ACAF;;ADGA;EACE,YAAA;ACAF;;ADGA;GACE,gBAAA;EAAmB,WAAA;GACnB,kBAAA;EAAqB,WAAA;ACEvB;;ADCA;;EAEE,YAAA;ACEF;;ADCA;EACE,gBAAA;EACA,oBAAA;ACEF;;ADCA;;;;EAIE,iBAAA;EACA,cAAA;ACEF;;ADCA;EACE,gBAAA;EACA,gBAAA;ACEF;;ADCA;EACE,kBAAA;EACA,qBAAA;ACEF;;ADCA;EACE,kBAAA;ACEF;;ADCA;EACE,kBAAA;EACA,gDAAA;ACEF;;ADCA;EACE,mBAAA;ACEF;;ADCA;EACE,cAAA;EACA,eAAA;EACA,6BAAA;EACA,gBAAA;EACA,gBAAA;ACEF;;ADCA;EACE,gBAAA;EACA,UAAA;EACA,SAAA;ACEF;;ADCA;EACE,WAAA;EACA,UAAA;ACEF;;ADCA;EACE,UAAA;ACEF;;ADCA;EACE,oBAAA;ACEF;;ADCA;EACE,oBAAA;ACEF;;ADCA;EACE,mBAAA;ACEF;;ADCA;EACE,cAAA;ACEF;;ADCA;EACE,aAAA;EACA,WAAA;ACEF;;ADCA;EACE,SAAA;ACEF;;ADCA;;EAEE,kBAAA;EACA,aAAA;ACEF;;ADCA;EACE,cAAA;EACA,YAAA;EACA,YAAA;EACA,YAAA;EACA,yEAAA;ACEF;;ADCA;EACE,sBAAA;EACA,WAAA;ACEF;;ADCA;EACE,eAAA;EACA,cAAA;EACA,gBAAA;ACEF;;ADCA;EACE,sBAAA;EACA,cAAA;EACA,mBAAA;ACEF;;ADCA;EACE,kBAAA;EACA,iBAAA;ACEF;;ADCA;EACE,YAAA;EACA,kBAAA;EACA,iBAAA;EACA,WAAA;ACEF;;ADCA;EACE,mBAAA;ACEF;;ADCA;EACE,UAAA;ACEF;;ADCA;EACE,kBAAA;EACA,OAAA;EACA,MAAA;EACA,SAAA;ACEF;;ADCA;EACE,QAAA;EACA,SAAA;ACEF;;ADCA;EACE,kBAAA;EACA,aAAA;EACA,YAAA;EACA,iBAAA;ACEF;;ADCA;EACE,iBAAA;EACA,WAAA;ACEF;;ADCA;EACE,gBAAA;ACEF;;ADCA;EACE,cAAA;EACA,yBAAA;EACA,kBAAA;EACA,kBAAA;ACEF;;ADCA,+EAAA;AACA;EACE,mBAAA;ACEF;;ADCA;;;;;EAKE,gBAAA;EACA,yBAAA;EACA,cAAA;ACEF;;ADCA;EACE,kBAAA;ACEF;;ADCA;;;;;;EAME,8BAAA;EACA,gBAAA;EACA,gBAAA;EAEA,WAAA;ACEF;;ADCA;EACE,mBAAA;EACA,yBAAA;ACEF;;ADCA;EACE,cAAA;ACEF;;ADCA;EACE,eAAA;EACA,iBAAA;ACEF;;ADCA;EACE,aAAA;ACEF;;ADCA;EACE,eAAA;ACEF;;ADCA;;EAEE,mBAAA;EACA,gBAAA;EACA,gBAAA;ACEF;;ADCA;EACE,qBAAA;EACA,qBAAA;ACEF;;ADCA;EACE,iBAAA;EACA,kBAAA;ACEF;;ADCA;;EAEE,eAAA;EACA,gBAAA;ACEF;;ADCA;EACE,iBAAA;EACA,cAAA;ACEF;;ADCA;;EAEE,cAAA;ACEF;;ADCA;;;EAGE,kBAAA;EACA,WAAA;ACEF;;ADCA;EACE,cAAA;ACEF;;ADCA;EACE,UAAA;ACEF;;ADCA;;EAEE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,WAAA;ACEF;;ADCA;EACE,YAAA;EACA,YAAA;EACA,cAAA;ACEF;;ADCA;EACE,cAAA;ACEF;;ADCA,aAAA;AACA;EACE;;IAEE,YAAA;ECEF;AACF;ADCA,aAAA;AACA;EACE;IACE,SAAA;IACA,SAAA;ECCF;;EDEA;;IAEE,WAAA;IAGA,sBAAA;ECCF;AACF;ADEA,YAAA;AACA;EACE;;IAEE,YAAA;ECAF;AACF;ADGA,YAAA;AACA;EACE;;IAEE,YAAA;ECDF;AACF;ADIA,YAAA;AACA;EACE;;IAEE,YAAA;ECFF;AACF","file":"DateFormatting/purejs/styles.css","sourcesContent":["html,\nbody,\nh1,\nh2,\nh3,\nfieldset,\n#faq,\n#faq dt,\n#faq dd {\n  margin: 0;\n  padding: 0;\n  border: 0;\n}\n\ntable,\np,\nul,\nh1,\nh2,\nh3,\n#error-info,\nform div,\n#faq,\n.bs-rt {\n  margin-bottom: 1em;\n}\n\nbutton,\ninput,\ntextarea,\na,\n.bs-rt {\n  -moz-border-radius: 4px;\n  -webkit-border-radius: 4px;\n  border-radius: 4px;\n}\n\nhtml,\ninput,\ntextarea,\nbutton {\n  font: 1em/1.5 sans-serif;\n}\n\nbody {\n  background: #fff;\n  padding: 0 2.5em;\n  margin: 0 auto;\n  min-height: 100%;\n}\n\na,\n.btn-link {\n  color: #357ab0;\n  padding: 0.2em;\n}\n\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus {\n  text-decoration: none;\n}\n\n.btn-link {\n  background-color: transparent;\n  border: 0;\n  text-decoration: underline;\n}\n\n.btn-link:hover,\n.btn-link:focus {\n  cursor: pointer;\n}\n\nblockquote {\n  margin: 0 0 1em;\n  border-left: 5px solid #b4b4b4;\n  padding-left: 0.5em;\n}\n\ntable {\n  border-collapse: collapse;\n}\n\nthead th,\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus,\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus,\n#comments .meta a:hover,\n#comments .meta a:focus,\nli.current a:hover,\nli.current a:focus,\nform h3,\n#comments .owner .meta {\n  background: #1a6ab9;\n  background-image: linear-gradient(top, #6ca5dd, #1a6ab9);\n  color: #fff;\n}\n\ncaption,\n#comments .meta {\n  background: #bcbcbc;\n  background-image: linear-gradient(top, #d0d0d0, #a7a7a7);\n  color: #555;\n}\n\nthead th,\ncaption {\n  font-weight: bold;\n}\n\n.js tbody th:hover,\n.js tbody th:focus {\n  text-decoration: underline;\n  cursor: pointer;\n}\n\ntbody th,\ntd {\n  border: solid #b4b4b4;\n  border-width: 0 1px 1px 0;\n}\n\ntbody th {\n  background: #dde4ea;\n  width: 150px;\n}\n\ntd.results {\n  text-align: center;\n  border-right: 0;\n}\n\n.results span,\nsmall {\n  display: block;\n  font-size: 0.8em;\n}\n\ntd,\nth,\ncaption {\n  padding: 0.2em 0.5em;\n}\n\ntd.fastest {\n  background: #9cee82;\n}\n\ntr:last-child td,\ntr:last-child th {\n  border-bottom: 0;\n}\n\ntd.slowest,\ntd.error,\n.invalid {\n  background: pink;\n}\n\n/* needs its own rule because of buggy IE */\n:focus:invalid {\n  background: pink;\n}\n\ntd.error {\n  text-transform: uppercase;\n  font-weight: bold;\n}\n\nbutton,\n.submit {\n  padding: 0.35em 0.5em;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\n.login {\n  padding: 0.35em 0.5em;\n  text-decoration: none;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\na:hover span,\na:focus span,\n#comments .owner .meta a {\n  color: #fff;\n}\n\n#options {\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n\n  label,\n  select {\n    margin-right: 5px;\n  }\n\n  .option {\n    display: inline-block;\n    margin-bottom: 0.5em;\n  }\n}\n\n#test-container {\n  display: flex;\n  flex-direction: column;\n  max-width: 800px;\n}\n\n#test-table {\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n#controls {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n.buttons {\n  float: right;\n}\n\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus {\n  border-color: #357ab0;\n}\n\n#add-buttons button {\n  padding: 0.15em 0.4em;\n  font-size: 11px;\n  font-weight: bold;\n}\n\nform label {\n  float: left;\n  width: 14em;\n  cursor: pointer;\n  text-align: right;\n  margin-right: 1em;\n  padding: 0.4em;\n}\n\nlabel.inline {\n  float: none;\n  padding: 0;\n  margin: 0;\n}\n\nlabel[for='visible'],\nlabel[for$='][defer]'] {\n  position: relative;\n  top: -0.37em;\n}\n\nlabel span {\n  display: block;\n  font-size: 90%;\n  color: #b4b4b4;\n}\n\nlabel em {\n  color: red;\n  font-style: normal;\n}\n\n.js #advanced {\n  display: none;\n}\n\n#show-advanced {\n  display: none;\n}\n\n.js #show-advanced {\n  display: block;\n}\n\nsection {\n  display: block;\n  margin: 2em 0;\n}\n\ntextarea {\n  resize: vertical;\n  height: 15em;\n  width: 42.6em;\n  *width: 42.4em; /* IE < 8 */\n}\n\ninput,\ntextarea {\n  border: 1px solid #b4b4b4;\n  padding: 0.4em;\n}\n\ninput[type='search'] {\n  -webkit-appearance: none;\n}\n\n#visible,\n#calibrate {\n  /* checkboxes, for IE */\n  border: 0;\n  padding: 0;\n}\n\nform h2,\nform h3,\nform h4,\np.error,\n.preview,\n#add-libraries,\n#add-buttons {\n  padding-left: 250px;\n  display: block;\n}\n\nhgroup h2,\n#firebug,\n#java {\n  display: none;\n}\n\npre {\n  width: 100%;\n  overflow: auto;\n  white-space: pre;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n}\n\ntable #results-1 {\n  width: 100px;\n}\n\ntable pre {\n  *padding: 1.5em 0; /* IE < 8 */\n  *overflow-y: hidden; /* IE < 8 */\n}\n\ntable pre,\ntable td.code {\n  width: 600px;\n}\n\nmark {\n  background: #ff9;\n  padding: 0.2em 0.1em;\n}\n\nh1,\nh2,\nh3,\nh4 {\n  font-weight: bold;\n  font-size: 1em;\n}\n\nh1 {\n  padding-top: 1em;\n  font-size: 1.4em;\n}\n\nform h3 {\n  padding-top: 0.2em;\n  padding-bottom: 0.2em;\n}\n\nh1 em {\n  font-style: normal;\n}\n\nh1 strong {\n  font-style: italic;\n  font-family: Monaco, 'Lucida Console', monospace;\n}\n\nli.current a {\n  background: #90ee85;\n}\n\nfooter {\n  display: block;\n  margin-top: 2em;\n  border-top: 2px solid #c4c4c4;\n  font-size: 0.9em;\n  overflow: hidden;\n}\n\nfooter ul {\n  list-style: none;\n  padding: 0;\n  margin: 0;\n}\n\nfooter > ul > li {\n  float: left;\n  width: 15%;\n}\n\nfooter > ul > li:first-child {\n  width: 55%;\n}\n\nfooter ul ul li {\n  margin-bottom: 0.1em;\n}\n\nfooter h4 {\n  margin-bottom: 0.2em;\n}\n\n#add-test {\n  margin-right: 0.3em;\n}\n\n#bs-chart {\n  overflow: auto;\n}\n\n#bs-chart-frame {\n  height: 240px;\n  width: 100%;\n}\n\n#bs-logo {\n  margin: 0;\n}\n\n#bs-logo span,\napplet {\n  position: absolute;\n  left: -9999em;\n}\n\n#bs-logo a {\n  display: block;\n  width: 232px;\n  height: 39px;\n  filter: none;\n  background: url(//www.browserscope.org/static/img/logo.png) 0 0 no-repeat;\n}\n\n#bs-ua {\n  padding: 0.5em 0.5em 0;\n  color: #555;\n}\n\n#bs-results .bs-rt {\n  font-size: 10pt;\n  padding: 0.5em;\n  background: #ddd;\n}\n\n#bs-results td {\n  border: 1px solid #ddd;\n  padding: 0.4em;\n  white-space: nowrap;\n}\n\n#bs-results .rt-ua-cur {\n  font-style: italic;\n  font-weight: bold;\n}\n\n#bs-results .bs-rt-message {\n  padding: 3em;\n  text-align: center;\n  font-weight: bold;\n  color: #555;\n}\n\n#bs-results .google-visualization-table-tr-head td {\n  white-space: normal;\n}\n\n#comments h1 {\n  padding: 0;\n}\n\n#comments .meta img {\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0;\n}\n\n#comments .meta img {\n  top: 2px;\n  left: 2px;\n}\n\n#comments .meta {\n  padding-left: 35px;\n  margin-top: 0;\n  width: 923px;\n  line-height: 30px;\n}\n\n#comments .meta a {\n  font-weight: bold;\n  color: #555;\n}\n\n#comments article div {\n  padding: 0 1em 0;\n}\n\n#comments article {\n  display: block;\n  border: 1px solid #b4b4b4;\n  position: relative;\n  margin-bottom: 1em;\n}\n\n/* needs its own rule (cannot be grouped with `tbody th`) because of buggy IE */\n#comments article:target {\n  background: #dde4ea;\n}\n\n#error-info.show,\n.meta strong,\n#firebug strong,\n#java strong,\n#status strong {\n  background: pink;\n  border: 1px solid #b00b00;\n  padding: 0.4em;\n}\n\n#error-info.show {\n  padding: 0.5em 1em;\n}\n\n#error-info,\ncode,\nsamp,\nvar,\ntextarea,\n#slug {\n  font-family: Monaco, monospace;\n  font-size: 0.9em;\n  -moz-tab-size: 2;\n  -o-tab-size: 2;\n  tab-size: 2;\n}\n\n#java strong {\n  background: #ffffdc;\n  border: 1px solid #faa700;\n}\n\n#slug {\n  font-size: 1em;\n}\n\n#faq dt {\n  margin-top: 1em;\n  font-weight: bold;\n}\n\n#faq dt a {\n  display: none;\n}\n\n#faq dt:hover a {\n  display: inline;\n}\n\n#faq dt:target,\n#faq dt:target + dd {\n  background: #90ee85;\n  margin: 0 -0.8em;\n  padding: 0 0.8em;\n}\n\n#faq dt:target + dd {\n  padding-bottom: 0.5em;\n  margin-bottom: -0.5em;\n}\n\n#faq dt:target {\n  margin-top: 0.5em;\n  padding-top: 0.5em;\n}\n\n#firebug,\n#java {\n  margin: 0 0 1em;\n  padding: 0.3em 0;\n}\n\n#prep-code pre {\n  max-height: 500px;\n  overflow: auto;\n}\n\n#firebug.show,\n#java.show {\n  display: block;\n}\n\n.co1,\n.co2,\n.coMULTI {\n  font-style: italic;\n  color: #060;\n}\n\n.error {\n  color: #b00b00;\n}\n\n.imp {\n  color: red;\n}\n\n.kw1,\n.kw3 {\n  color: #006;\n}\n\n.kw2 {\n  color: #036;\n}\n\n.es0 {\n  color: #009;\n}\n\n.br0 {\n  color: #090;\n}\n\n.sy0 {\n  color: #393;\n}\n\n.st0 {\n  color: #36c;\n}\n\n.nu0 {\n  color: #c00;\n}\n\n.me1 {\n  color: #606;\n}\n\n#carbonads {\n  float: right;\n  width: 130px;\n  font-size: 80%;\n}\n\n#carbonads a {\n  display: block;\n}\n\n/* < 1051px */\n@media (max-width: 1050px) {\n  table pre,\n  table td.code {\n    width: 550px;\n  }\n}\n\n/* < 1041px */\n@media (max-width: 1040px) {\n  body {\n    margin: 0;\n    border: 0;\n  }\n\n  body,\n  #comments .meta {\n    width: 100%;\n    -webkit-box-sizing: border-box;\n    -moz-box-sizing: border-box;\n    box-sizing: border-box;\n  }\n}\n\n/* < 801px */\n@media (max-width: 800px) {\n  table pre,\n  table td.code {\n    width: 450px;\n  }\n}\n\n/* < 681px */\n@media (max-width: 680px) {\n  table pre,\n  table td.code {\n    width: 350px;\n  }\n}\n\n/* < 651px */\n@media (max-width: 650px) {\n  table pre,\n  table td.code {\n    width: 200px;\n  }\n}\n","html,\nbody,\nh1,\nh2,\nh3,\nfieldset,\n#faq,\n#faq dt,\n#faq dd {\n  margin: 0;\n  padding: 0;\n  border: 0;\n}\n\ntable,\np,\nul,\nh1,\nh2,\nh3,\n#error-info,\nform div,\n#faq,\n.bs-rt {\n  margin-bottom: 1em;\n}\n\nbutton,\ninput,\ntextarea,\na,\n.bs-rt {\n  -moz-border-radius: 4px;\n  -webkit-border-radius: 4px;\n  border-radius: 4px;\n}\n\nhtml,\ninput,\ntextarea,\nbutton {\n  font: 1em/1.5 sans-serif;\n}\n\nbody {\n  background: #fff;\n  padding: 0 2.5em;\n  margin: 0 auto;\n  min-height: 100%;\n}\n\na,\n.btn-link {\n  color: #357ab0;\n  padding: 0.2em;\n}\n\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus {\n  text-decoration: none;\n}\n\n.btn-link {\n  background-color: transparent;\n  border: 0;\n  text-decoration: underline;\n}\n\n.btn-link:hover,\n.btn-link:focus {\n  cursor: pointer;\n}\n\nblockquote {\n  margin: 0 0 1em;\n  border-left: 5px solid #b4b4b4;\n  padding-left: 0.5em;\n}\n\ntable {\n  border-collapse: collapse;\n}\n\nthead th,\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus,\na:hover,\na:focus,\n.btn-link:hover,\n.btn-link:focus,\n#comments .meta a:hover,\n#comments .meta a:focus,\nli.current a:hover,\nli.current a:focus,\nform h3,\n#comments .owner .meta {\n  background: #1a6ab9;\n  background-image: linear-gradient(top, #6ca5dd, #1a6ab9);\n  color: #fff;\n}\n\ncaption,\n#comments .meta {\n  background: #bcbcbc;\n  background-image: linear-gradient(top, #d0d0d0, #a7a7a7);\n  color: #555;\n}\n\nthead th,\ncaption {\n  font-weight: bold;\n}\n\n.js tbody th:hover,\n.js tbody th:focus {\n  text-decoration: underline;\n  cursor: pointer;\n}\n\ntbody th,\ntd {\n  border: solid #b4b4b4;\n  border-width: 0 1px 1px 0;\n}\n\ntbody th {\n  background: #dde4ea;\n  width: 150px;\n}\n\ntd.results {\n  text-align: center;\n  border-right: 0;\n}\n\n.results span,\nsmall {\n  display: block;\n  font-size: 0.8em;\n}\n\ntd,\nth,\ncaption {\n  padding: 0.2em 0.5em;\n}\n\ntd.fastest {\n  background: #9cee82;\n}\n\ntr:last-child td,\ntr:last-child th {\n  border-bottom: 0;\n}\n\ntd.slowest,\ntd.error,\n.invalid {\n  background: pink;\n}\n\n/* needs its own rule because of buggy IE */\n:focus:invalid {\n  background: pink;\n}\n\ntd.error {\n  text-transform: uppercase;\n  font-weight: bold;\n}\n\nbutton,\n.submit {\n  padding: 0.35em 0.5em;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\n.login {\n  padding: 0.35em 0.5em;\n  text-decoration: none;\n  cursor: pointer;\n  color: #000;\n  border: 1px solid #999;\n  background: #dadada;\n  background-image: linear-gradient(top, #ebebeb, #b8b8b8);\n}\n\na:hover span,\na:focus span,\n#comments .owner .meta a {\n  color: #fff;\n}\n\n#options {\n  display: flex;\n  align-items: center;\n  flex-wrap: wrap;\n}\n#options label,\n#options select {\n  margin-right: 5px;\n}\n#options .option {\n  display: inline-block;\n  margin-bottom: 0.5em;\n}\n\n#test-container {\n  display: flex;\n  flex-direction: column;\n  max-width: 800px;\n}\n\n#test-table {\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n#controls {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex: 1 1;\n  width: 100%;\n  margin: 0.5em 0;\n}\n\n.buttons {\n  float: right;\n}\n\nbutton:hover,\nbutton:focus,\n.submit:hover,\n.submit:focus {\n  border-color: #357ab0;\n}\n\n#add-buttons button {\n  padding: 0.15em 0.4em;\n  font-size: 11px;\n  font-weight: bold;\n}\n\nform label {\n  float: left;\n  width: 14em;\n  cursor: pointer;\n  text-align: right;\n  margin-right: 1em;\n  padding: 0.4em;\n}\n\nlabel.inline {\n  float: none;\n  padding: 0;\n  margin: 0;\n}\n\nlabel[for=visible],\nlabel[for$=\"][defer]\"] {\n  position: relative;\n  top: -0.37em;\n}\n\nlabel span {\n  display: block;\n  font-size: 90%;\n  color: #b4b4b4;\n}\n\nlabel em {\n  color: red;\n  font-style: normal;\n}\n\n.js #advanced {\n  display: none;\n}\n\n#show-advanced {\n  display: none;\n}\n\n.js #show-advanced {\n  display: block;\n}\n\nsection {\n  display: block;\n  margin: 2em 0;\n}\n\ntextarea {\n  resize: vertical;\n  height: 15em;\n  width: 42.6em;\n  *width: 42.4em;\n  /* IE < 8 */\n}\n\ninput,\ntextarea {\n  border: 1px solid #b4b4b4;\n  padding: 0.4em;\n}\n\ninput[type=search] {\n  -webkit-appearance: none;\n}\n\n#visible,\n#calibrate {\n  /* checkboxes, for IE */\n  border: 0;\n  padding: 0;\n}\n\nform h2,\nform h3,\nform h4,\np.error,\n.preview,\n#add-libraries,\n#add-buttons {\n  padding-left: 250px;\n  display: block;\n}\n\nhgroup h2,\n#firebug,\n#java {\n  display: none;\n}\n\npre {\n  width: 100%;\n  overflow: auto;\n  white-space: pre;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n}\n\ntable #results-1 {\n  width: 100px;\n}\n\ntable pre {\n  *padding: 1.5em 0;\n  /* IE < 8 */\n  *overflow-y: hidden;\n  /* IE < 8 */\n}\n\ntable pre,\ntable td.code {\n  width: 600px;\n}\n\nmark {\n  background: #ff9;\n  padding: 0.2em 0.1em;\n}\n\nh1,\nh2,\nh3,\nh4 {\n  font-weight: bold;\n  font-size: 1em;\n}\n\nh1 {\n  padding-top: 1em;\n  font-size: 1.4em;\n}\n\nform h3 {\n  padding-top: 0.2em;\n  padding-bottom: 0.2em;\n}\n\nh1 em {\n  font-style: normal;\n}\n\nh1 strong {\n  font-style: italic;\n  font-family: Monaco, \"Lucida Console\", monospace;\n}\n\nli.current a {\n  background: #90ee85;\n}\n\nfooter {\n  display: block;\n  margin-top: 2em;\n  border-top: 2px solid #c4c4c4;\n  font-size: 0.9em;\n  overflow: hidden;\n}\n\nfooter ul {\n  list-style: none;\n  padding: 0;\n  margin: 0;\n}\n\nfooter > ul > li {\n  float: left;\n  width: 15%;\n}\n\nfooter > ul > li:first-child {\n  width: 55%;\n}\n\nfooter ul ul li {\n  margin-bottom: 0.1em;\n}\n\nfooter h4 {\n  margin-bottom: 0.2em;\n}\n\n#add-test {\n  margin-right: 0.3em;\n}\n\n#bs-chart {\n  overflow: auto;\n}\n\n#bs-chart-frame {\n  height: 240px;\n  width: 100%;\n}\n\n#bs-logo {\n  margin: 0;\n}\n\n#bs-logo span,\napplet {\n  position: absolute;\n  left: -9999em;\n}\n\n#bs-logo a {\n  display: block;\n  width: 232px;\n  height: 39px;\n  filter: none;\n  background: url(//www.browserscope.org/static/img/logo.png) 0 0 no-repeat;\n}\n\n#bs-ua {\n  padding: 0.5em 0.5em 0;\n  color: #555;\n}\n\n#bs-results .bs-rt {\n  font-size: 10pt;\n  padding: 0.5em;\n  background: #ddd;\n}\n\n#bs-results td {\n  border: 1px solid #ddd;\n  padding: 0.4em;\n  white-space: nowrap;\n}\n\n#bs-results .rt-ua-cur {\n  font-style: italic;\n  font-weight: bold;\n}\n\n#bs-results .bs-rt-message {\n  padding: 3em;\n  text-align: center;\n  font-weight: bold;\n  color: #555;\n}\n\n#bs-results .google-visualization-table-tr-head td {\n  white-space: normal;\n}\n\n#comments h1 {\n  padding: 0;\n}\n\n#comments .meta img {\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0;\n}\n\n#comments .meta img {\n  top: 2px;\n  left: 2px;\n}\n\n#comments .meta {\n  padding-left: 35px;\n  margin-top: 0;\n  width: 923px;\n  line-height: 30px;\n}\n\n#comments .meta a {\n  font-weight: bold;\n  color: #555;\n}\n\n#comments article div {\n  padding: 0 1em 0;\n}\n\n#comments article {\n  display: block;\n  border: 1px solid #b4b4b4;\n  position: relative;\n  margin-bottom: 1em;\n}\n\n/* needs its own rule (cannot be grouped with `tbody th`) because of buggy IE */\n#comments article:target {\n  background: #dde4ea;\n}\n\n#error-info.show,\n.meta strong,\n#firebug strong,\n#java strong,\n#status strong {\n  background: pink;\n  border: 1px solid #b00b00;\n  padding: 0.4em;\n}\n\n#error-info.show {\n  padding: 0.5em 1em;\n}\n\n#error-info,\ncode,\nsamp,\nvar,\ntextarea,\n#slug {\n  font-family: Monaco, monospace;\n  font-size: 0.9em;\n  -moz-tab-size: 2;\n  -o-tab-size: 2;\n  tab-size: 2;\n}\n\n#java strong {\n  background: #ffffdc;\n  border: 1px solid #faa700;\n}\n\n#slug {\n  font-size: 1em;\n}\n\n#faq dt {\n  margin-top: 1em;\n  font-weight: bold;\n}\n\n#faq dt a {\n  display: none;\n}\n\n#faq dt:hover a {\n  display: inline;\n}\n\n#faq dt:target,\n#faq dt:target + dd {\n  background: #90ee85;\n  margin: 0 -0.8em;\n  padding: 0 0.8em;\n}\n\n#faq dt:target + dd {\n  padding-bottom: 0.5em;\n  margin-bottom: -0.5em;\n}\n\n#faq dt:target {\n  margin-top: 0.5em;\n  padding-top: 0.5em;\n}\n\n#firebug,\n#java {\n  margin: 0 0 1em;\n  padding: 0.3em 0;\n}\n\n#prep-code pre {\n  max-height: 500px;\n  overflow: auto;\n}\n\n#firebug.show,\n#java.show {\n  display: block;\n}\n\n.co1,\n.co2,\n.coMULTI {\n  font-style: italic;\n  color: #060;\n}\n\n.error {\n  color: #b00b00;\n}\n\n.imp {\n  color: red;\n}\n\n.kw1,\n.kw3 {\n  color: #006;\n}\n\n.kw2 {\n  color: #036;\n}\n\n.es0 {\n  color: #009;\n}\n\n.br0 {\n  color: #090;\n}\n\n.sy0 {\n  color: #393;\n}\n\n.st0 {\n  color: #36c;\n}\n\n.nu0 {\n  color: #c00;\n}\n\n.me1 {\n  color: #606;\n}\n\n#carbonads {\n  float: right;\n  width: 130px;\n  font-size: 80%;\n}\n\n#carbonads a {\n  display: block;\n}\n\n/* < 1051px */\n@media (max-width: 1050px) {\n  table pre,\ntable td.code {\n    width: 550px;\n  }\n}\n/* < 1041px */\n@media (max-width: 1040px) {\n  body {\n    margin: 0;\n    border: 0;\n  }\n\n  body,\n#comments .meta {\n    width: 100%;\n    -webkit-box-sizing: border-box;\n    -moz-box-sizing: border-box;\n    box-sizing: border-box;\n  }\n}\n/* < 801px */\n@media (max-width: 800px) {\n  table pre,\ntable td.code {\n    width: 450px;\n  }\n}\n/* < 681px */\n@media (max-width: 680px) {\n  table pre,\ntable td.code {\n    width: 350px;\n  }\n}\n/* < 651px */\n@media (max-width: 650px) {\n  table pre,\ntable td.code {\n    width: 200px;\n  }\n}"]} */