congo/docs/version-2/lighthouse/index.html

341 lines
758 KiB
HTML
Raw Permalink Normal View History

<!doctype html><html lang=en-AU dir=ltr class=scroll-smooth data-default-appearance=light data-auto-appearance=true><head><meta charset=utf-8><meta name=viewport content="width=device-width,initial-scale=1"><meta name=theme-color content="rgb(255,255,255)"><title>&#183; Congo</title>
<meta name=title content=" &#183; Congo"><script type=text/javascript src=/congo/js/appearance.min.74ad8406faea02f3e186ba5126249aaeed9073629e04b05037b903396b188724.js integrity="sha256-dK2EBvrqAvPhhrpRJiSaru2Qc2KeBLBQN7kDOWsYhyQ="></script><link type=text/css rel=stylesheet href=/congo/css/main.bundle.min.9602fe0216290b9ff0322c1fd14e88ab9fc0a13741f4de563f67831708d72bb2.css integrity="sha256-lgL+AhYpC5/wMiwf0U6Iq5/AoTdB9N5WP2eDFwjXK7I="><script defer type=text/javascript id=script-bundle src=/congo/js/main.bundle.min.5ff2b3a0b729a3f13a3d681740c924c9009e2be09e22a8458e486651e9e1af40.js integrity="sha256-X/KzoLcpo/E6PWgXQMkkyQCeK+CeIqhFjkhmUenhr0A=" data-copy=Copy data-copied=Copied></script><meta name=description content="
Lighthouse Report Lighthouse report requires JavaScript.
"><link rel=canonical href=https://jpanther.github.io/congo/docs/version-2/lighthouse/><link rel=apple-touch-icon sizes=180x180 href=/congo/apple-touch-icon.png><link rel=icon type=image/png sizes=32x32 href=/congo/favicon-32x32.png><link rel=icon type=image/png sizes=16x16 href=/congo/favicon-16x16.png><link rel=manifest href=/congo/site.webmanifest><meta property="og:url" content="https://jpanther.github.io/congo/docs/version-2/lighthouse/"><meta property="og:site_name" content="Congo"><meta property="og:title" content="Congo"><meta property="og:description" content="Lighthouse Report Lighthouse report requires JavaScript."><meta property="og:locale" content="en-AU"><meta property="og:type" content="article"><meta property="article:section" content="docs"><meta name=twitter:card content="summary"><meta name=twitter:title content><meta name=twitter:description content="Lighthouse Report Lighthouse report requires JavaScript."><script type=application/ld+json>{"@context":"https://schema.org","@type":"Article","articleSection":"Documentation","name":"","headline":"","abstract":"Lighthouse Report Lighthouse report requires JavaScript.","inLanguage":"en-AU","url":"https:\/\/jpanther.github.io\/congo\/docs\/version-2\/lighthouse\/","author":{"@type":"Person","name":"Congo"},"mainEntityOfPage":"true","wordCount":"4611"}</script><meta name=author content="Congo"><link href=https://twitter.com/ rel=me><link href=https://facebook.com/ rel=me><link href=https://linkedin.com/ rel=me><link href=https://youtube.com/ rel=me></head><body class="m-auto flex h-screen max-w-7xl flex-col bg-neutral px-6 text-lg leading-7 text-neutral-900 sm:px-14 md:px-24 lg:px-32 dark:bg-neutral-800 dark:text-neutral"><div id=the-top class="absolute flex self-center"><a class="-translate-y-8 rounded-b-lg bg-primary-200 px-3 py-1 text-sm focus:translate-y-0 dark:bg-neutral-600" href=#main-content><span class="pe-2 font-bold text-primary-600 dark:text-primary-400">&darr;</span>Skip to main content</a></div><header class="py-6 font-semibold text-neutral-900 print:hidden sm:py-10 dark:text-neutral"><nav class="flex items-start justify-between sm:items-center"><div class="flex flex-row items-center"><a class="decoration-primary-500 hover:underline hover:decoration-2 hover:underline-offset-2" rel=me href=/congo/>Congo</a></div><ul class="flex list-none flex-col text-end sm:flex-row"><li class="group mb-1 sm:mb-0 sm:me-7 sm:last:me-0.5"><a href=/congo/docs/ title><span class="decoration-primary-500 group-hover:underline group-hover:decoration-2 group-hover:underline-offset-2">Docs</span></a></li><li class="group mb-1 sm:mb-0 sm:me-7 sm:last:me-0.5"><a href=/congo/samples/ title><span class="decoration-primary-500 group-hover:underline group-hover:decoration-2 group-hover:underline-offset-2">Samples</span></a></li><li class="group mb-1 sm:mb-0 sm:me-7 sm:last:me-0.5"><a href=/congo/users/ title><span class="decoration-primary-500 group-hover:underline group-hover:decoration-2 group-hover:underline-offset-2">Users</span></a></li><li class="group mb-1 sm:mb-0 sm:me-7 sm:last:me-0.5"><a href=https://github.com/jpanther/congo title target=_blank><span class="group-dark:hover:text-primary-400 transition-colors group-hover:text-primary-600"><span class="icon relative inline-block px-1 align-text-bottom"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><path fill="currentcolor" d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6.0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6.0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3zm44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3.0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1.0-6.2-.3-40.4-.3-61.4.0.0-70 15-84.7-29.8.0.0-11.4-29.1-27.8-36.6.0.0-22.9-15.7 1.6-15.4.0.0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5.0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8
<span class="group-dark:hover:text-primary-400 transition-colors group-hover:text-primary-600"><span class="icon relative inline-block px-1 align-text-bottom"><svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="search" class="svg-inline--fa fa-search fa-w-16" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentcolor" d="M505 442.7 405.3 343c-4.5-4.5-10.6-7-17-7H372c27.6-35.3 44-79.7 44-128C416 93.1 322.9.0 208 0S0 93.1.0 208s93.1 208 208 208c48.3.0 92.7-16.4 128-44v16.3c0 6.4 2.5 12.5 7 17l99.7 99.7c9.4 9.4 24.6 9.4 33.9.0l28.3-28.3c9.4-9.4 9.4-24.6.1-34zM208 336c-70.7.0-128-57.2-128-128 0-70.7 57.2-128 128-128 70.7.0 128 57.2 128 128 0 70.7-57.2 128-128 128z"/></svg>
</span></span><span class="decoration-primary-500 group-hover:underline group-hover:decoration-2 group-hover:underline-offset-2"></span></button></li></ul></nav></header><div class="relative flex grow flex-col"><main id=main-content class=grow><article><header class=max-w-prose><ol class="text-sm text-neutral-500 print:hidden dark:text-neutral-400"><li class="hidden inline"><a class="dark:underline-neutral-600 decoration-neutral-300 hover:underline" href=/congo/>Welcome to Congo! :tada:</a><span class="px-1 text-primary-500">/</span></li><li class=inline><a class="dark:underline-neutral-600 decoration-neutral-300 hover:underline" href=/congo/docs/>Documentation</a><span class="px-1 text-primary-500">/</span></li><li class=inline><a class="dark:underline-neutral-600 decoration-neutral-300 hover:underline" href=/congo/docs/version-2/>What's New in 2.0 ✨</a><span class="px-1 text-primary-500">/</span></li><li class="hidden inline"><a class="dark:underline-neutral-600 decoration-neutral-300 hover:underline" href=/congo/docs/version-2/lighthouse/>docs</a><span class="px-1 text-primary-500">/</span></li></ol><h1 class="mt-0 text-4xl font-extrabold text-neutral-900 dark:text-neutral"></h1><div class="mb-12 mt-8 text-base text-neutral-500 print:hidden dark:text-neutral-400"><div class="flex flex-row flex-wrap items-center"><span title="Reading time">22 mins</span><span class="px-2 text-primary-500">&#183;</span>
<span class=mb-[2px]><a href=https://github.com/jpanther/congo/tree/dev/exampleSite/content/docs/version-2/lighthouse.html class="text-lg hover:text-primary-500" rel="noopener noreferrer" target=_blank title="Edit content"><span class="icon relative inline-block px-1 align-text-bottom"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentcolor" d="M490.3 40.4c21.9 21.87 21.9 57.33.0 79.2l-30 30.1-98-97.98 30.1-30.06C414.3-.2135 449.7-.2135 471.6 21.66L490.3 40.4zM172.4 241.7 339.7 74.34l98 97.96L270.3 339.6C264.2 345.8 256.7 350.4 248.4 353.2l-88.8 29.6C150.1 385.6 141.5 383.4 135 376.1 128.6 370.5 126.4 361 129.2 352.4l29.6-88.8C161.6 255.3 166.2 247.8 172.4 241.7v0zM192 63.1c17.7.0 32 15.23 32 32 0 18.6-14.3 32-32 32H96c-17.67.0-32 15.2-32 32V416c0 17.7 14.33 32 32 32H352c17.7.0 32-14.3 32-32V319.1c0-16.8 14.3-32 32-32s32 15.2 32 32V416c0 53-43 96-96 96H96c-53.02.0-96-43-96-96V159.1c0-53 42.98-96 96-96h96z"/></svg></span></a></span></div></div></header><section class="prose mt-0 flex max-w-full flex-col dark:prose-invert lg:flex-row"><div class="min-h-0 min-w-0 max-w-prose grow"><html lang=en><head><meta charset=utf-8><meta name=viewport content="width=device-width,initial-scale=1,minimum-scale=1"><link rel=icon href=data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAEhklEQVR4AWJxL/BhIAesev1U5tcflpncgNrKIsqNIwzC9feMpDUzs70kOczMzMzJJcxwCTMzncPMnOwtzBwzMzPb0vRfeZPp0VhPS5I39V5fdiXV1/VD+9QC7OVn9BsyH1XIoEI1PfmJvLFowVV564+34DFUHudbmfDh4kVXh//7XwE+WjS/YfXZe3yr4j2rqj1AIhSB7hZ8ZtPZu/zw8cK523U4wE1/rvPfWrz4zs0m9ZdC9yUJAlASdBAgocRegfF/f3/h/PuaFsxMdwjAR0vm1+06eMMfIrhLqTWqdH4EumU2SPfMhigJAlRQbZrgrRsl9U+Y2DYDFCz3ILC9kiAiqSrMwbWT0nceEnR+9Kggc2zjOJCASDENkg0a5HfZZgDP81CM3CrQs2Z1+o7DJ6ePr8sK0AOCHv5Jjdt3evyYSaZ351VIStIxPRAUtrBYbxC6w+BZ0ivVSBKkIhJhemSyZpfB00EiPO2VjzYkxhcqXQqCWCShGplvi3y0QxqbuBurMjyJeWnkHZuAEgIQGsUBqwrfjZ+IlBgKyRJzVVYF8O6qFWdh86YzQzMrZigYmxAyfvHgLZQ/LC1CbeniW2Hkqr/PH16SgvGuf2/uzNMBwJA/njxizGPtSyAf7EziJCMGRDRdhoAC4PL1A/SrKQMAAQkEfpJAcRQdrBJ7gNwjSpJsdwK+CANBkqa1LgQB4IicV9nYUct7gaxuDJUErQIiEAiMxLVOFlKzIktPpT0ggpdpC/8YAHnxbgkUY4tAAFSR7AAXNyAAWHJrA/kHGjzg5nleuwFO7Nd/IoDw4Pm58+4jNLmYG0wRA5bErc2Mr3Y+dXTDW1VvwqbJkzMCHQ4S1GTCBOIgUHJrGdEwqzR+jAp/o2qAZelUDoQnruEEdDclJI6576AlNVfc+22XN/+Y1vnJD0Yind6UpEEvn/Hqq15EYjCW7jZCJEpnNvDgkyelDjs106kuux2AAXCSobULOWP8mLhYlpoDMK4qAFXJGk+grtH8YXVz5KJblqaG1+VUdTc0I290bmUQAriGITRbdQnom0aoFj8kx1+wMD2ifncAXUQE4SkDqN1hE0jEophs1SUwZAOhUAiMCLwRtamtTZtbbmZErSAUHbSysaoEmnrsakiMiUAURi283gN6wans9oX8rOCrj7/JP35DFD+iQ7Au/K2KE1jzx6ujjUnXFH9KjEq6ZlhsTBICrNLJf47Pv/pkHzvup1w4dmUbEei0+bcXRqJuh5kVARQ8byyYxOwNGr7A87xh1tp8sGT+uMInrwi++Xj7TQz2d27NvwEkrOflAFQGIDA5khASBCGdO2/Z/MnLPwYfv5TFhjW7QhVKAB6afwe2LpFlFsCnlQEosgQgDsdOG1/LKeNqJS4JCSPJ/i+TakwEARor7gER1Iva5JmPOJK0RUqmoPnnlzFCtmIAhAAQEIQRgDaiYPIauNXcnDlRIrWNFY3hm7PG9YRqr7IV7HrCgAC17befjEvRq2nGhAHtBqDpOuI/I1diUUAMYIxEdyejBJqLnNoszGZtfiX/CztGv2mq+sdaAAAAAElFTkSuQmCC><title>Lighthouse Report</title><style>.lh-vars{--color-amber-50:#FFF8E1;--color-blue-200:#90CAF9;--color-blue-900:#0D47A1;--color-blue-A700:#2962FF;--color-cyan-500:#00BCD4;--color-gray-100:#F5F5F5;--color-gray-300:#CFCFCF;--color-gray-200:#E0E0E0;--color-gray-400:#BDBDBD;--color-gray-50:#FAFAFA;--color-gray-500:#9E9E9E;--color-gray-600:#757575;--color-gray-700:#616161;--color-gray-800:#424242;--color-gray-900:#212121;--color-gray:#000000;--color-green-700:#018642;--color-green:#0CCE6B;--color-lime-400:#D3E156;--color-orange-50:#FFF3E0;--color-orange-700:#D04900;--color-orange:#FFA400;--color-red-700:#EB0F00;--color-red:#FF4E42;--color-teal-600:#00897B;--color-white:#FFFFFF;--color-average-secondary:var(--color-orange-700);--color-average:var(--color-orange);--color-fail-secondary:var(--color-red-700);--color-fail:var(--color-red);--color-hover:var(--color-gray-50);--color-informative:var(--color-blue-900);--color-pass-secondary:var(--color-green-700);--color-pass:var(--color-green);--color-not-applicable:var(--color-gray-600);--audit-description-padding-left:calc(var(--score-icon-size) + var(--score-icon-margin-left) + var(--score-icon-margin-right));--audit-explan
<span class="lh-scorescale-range lh-scorescale-range--average">5089</span>
<span class="lh-scorescale-range lh-scorescale-range--pass">90100</span></div></template><template id=tmpl-lh-chevron><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg>
</template><template id=tmpl-lh-category-header><div class=lh-category-header><div class=lh-score__gauge role=heading aria-level=2></div><div class=lh-category-header__description></div></div></template><template id=tmpl-lh-clump><details class="lh-clump lh-audit-group"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title></span>
<span class=lh-audit-group__itemcount></span></div><div></div></div></summary></details></template><template id=tmpl-lh-metrics-toggle><div class=lh-metrics-toggle><input class=lh-metrics-toggle__input type=checkbox id=toggle-metric-descriptions aria-label="Toggle the display of metric descriptions">
<label class=lh-metrics-toggle__label for=toggle-metric-descriptions><div class="lh-metrics-toggle__icon lh-metrics-toggle__icon--less" aria-hidden=true><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24" height="24" viewBox="0 0 24 24"><path class="lh-metrics-toggle__lines" d="M4 9h16v2H4zm0 4h10v2H4z"/></svg></div><div class="lh-metrics-toggle__icon lh-metrics-toggle__icon--more" aria-hidden=true><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path class="lh-metrics-toggle__lines" d="M3 18h12v-2H3v2zM3 6v2h18V6H3zm0 7h18v-2H3v2z"/></svg></div></label></div></template><template id=tmpl-lh-audit><div class=lh-audit><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container></div></div></summary><div class=lh-audit__description></div><div class=lh-audit__stackpacks></div></details></div></template><template id=tmpl-lh-metric><div class=lh-metric><div class=lh-metric__innerwrap><span class=lh-metric__title></span><div class=lh-metric__value></div><div class=lh-metric__description></div></div></div></template><template id=tmpl-lh-opportunity><div class="lh-audit lh-audit--load-opportunity"><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><div class=lh-load-opportunity__cols><div class="lh-load-opportunity__col lh-load-opportunity__col--one"><span class=lh-audit__score-icon></span><div class=lh-audit__title></div></div><div class="lh-load-opportunity__col lh-load-opportunity__col--two"><div class=lh-load-opportunity__sparkline><div class=lh-sparkline><div class=lh-sparkline__bar></div></div></div><div class=lh-audit__display-text></div><div class=lh-chevron-container></div></div></div></div></summary><div class=lh-audit__description></div><div class=lh-audit__stackpacks></div></details></div></template><template id=tmpl-lh-opportunity-header><div class="lh-load-opportunity__header lh-load-opportunity__cols"><div class="lh-load-opportunity__col lh-load-opportunity__col--one"></div><div class="lh-load-opportunity__col lh-load-opportunity__col--two"></div></div></template><template id=tmpl-lh-scores-wrapper><style>.lh-scores-container{display:flex;flex-direction:column;padding:var(--scores-container-padding);position:relative;width:100%}.lh-sticky-header{--gauge-circle-size:36px;--plugin-badge-size:18px;--plugin-icon-size:75%;--gauge-wrapper-width:60px;--gauge-percentage-font-size:13px;position:fixed;left:0;right:0;top:var(--topbar-height);font-weight:700;display:none;justify-content:center;background-color:var(--sticky-header-background-color);border-bottom:1px solid var(--color-gray-200);padding-top:var(--score-container-padding);padding-bottom:4px;z-index:1;pointer-events:none}.lh-devtools .lh-sticky-header{position:sticky}.lh-sticky-header--visible{display:grid;grid-auto-flow:column;pointer-events:auto}.lh-sticky-header .lh-gauge-arc{animation:none}.lh-sticky-header .lh-gauge__label{display:none}.lh-highlighter{width:var(--gauge-wrapper-width);height:1px;background-color:var(--highlighter-background-color);position:absolute;grid-column:1;bottom:-1px}.lh-gauge__wrapper:first-of-type{contain:none}</style><div class=lh-scores-wrapper><div class=lh-scores-container><div class=pyro><div class=before></div><div class=after></div></div></div></div></template><template id=tmpl-lh-topbar><style>.lh-topbar{position:sticky;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;height:var(--topbar-height);background-color:var(--topbar-background-color);padding:var(--topbar-padding)}.lh-topbar__logo{width:var(--topbar-logo-size);height:var(--topbar-logo-size);user-select:none;flex:none}.lh-topbar__logo .shape{fill:var(--report-text-color)}.lh-topbar__url{margin:var(--topbar-padding);text-decoration:none;color:var(--report-text-color);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.lh-tools{margin-left:auto;will-change:transform;min-width:var(--report-icon-size)}.lh-tools__button{width:var(--report-icon-size);height:var(--report-icon-size);cursor:pointer;margin-right:5px;display:flex;background:0 0;color:inherit;border:none;padding:0;font:inherit;outline:inherit}.lh-tools__button svg{fill:var(--tools-icon-color)}.dark .lh-tools__button svg{filter:invert(1)}.lh-tools__button.active+.lh-tools__dropdown{opacity:1;clip:rect(-1px,194px,242px,-3px);visibility:visible}.lh-tools__dropdown{position:absolute;background-color:var(--report-background-color);border:1px solid var(--report-border-color);border-radius:3px;padding:calc(var(--default-padding)/2)0;cursor:pointer;top:36px;right:0;box-shadow:1px 1px 3px #ccc;min-width:125px;clip:rect(0,164px,0,0);visibility:hidden;opacity:0;transition:all 200ms cubic-bezier(0,0,.2,1)}.lh-tools__dropdown a{color:curren
<a href class=lh-topbar__url target=_blank rel=noopener></a><div class=lh-tools><button id=lh-tools-button class=lh-tools__button title="Tools menu" aria-label="Toggle report tools menu" aria-haspopup=menu aria-expanded=false aria-controls=lh-tools-dropdown><svg width="100%" height="100%" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 8c1.1.0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1.0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1.0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/></svg></button><div id=lh-tools-dropdown role=menu class=lh-tools__dropdown aria-labelledby=lh-tools-button><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--print" data-i18n=dropdownPrintSummary data-action=print-summary></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--print" data-i18n=dropdownPrintExpanded data-action=print-expanded></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--copy" data-i18n=dropdownCopyJSON data-action=copy></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--download" data-i18n=dropdownSaveHTML data-action=save-html></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--download" data-i18n=dropdownSaveJSON data-action=save-json></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--open" data-i18n=dropdownViewer data-action=open-viewer></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--open" data-i18n=dropdownSaveGist data-action=save-gist></a><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--dark" data-i18n=dropdownDarkTheme data-action=toggle-dark></a></div></div></div></template><template id=tmpl-lh-heading><style>.pyro{display:none;z-index:1;pointer-events:none}.score100 .pyro{display:block}.score100 .lh-lighthouse stop:first-child{stop-color:hsla(200,12%,95%,0)}.score100 .lh-lighthouse stop:last-child{stop-color:#ebf390}.pyro>.before,.pyro>.after{position:absolute;width:5px;height:5px;border-radius:2.5px;box-shadow:0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff,0 0 #fff;animation:1s bang ease-out infinite backwards,1s gravity ease-in infinite backwards,5s position linear infinite backwards;animation-delay:1s,1s,1s}.pyro>.after{animation-delay:2.25s,2.25s,2.25s;animation-duration:1.25s,1.25s,6.25s}.fireworks-paused .pyro>div{animation-play-state:paused}@keyframes bang{to{box-shadow:-70px -115.67px #47ebbc,-28px -99.67px #eb47a4,58px -31.67px #7eeb47,13px -141.67px #eb47c5,-19px 6.33px #7347eb,-2px -74.67px #ebd247,24px -151.67px #eb47e0,57px -138.67px #b4eb47,-51px -104.67px #479eeb,62px 8.33px #ebcf47,-93px .33px #d547eb,-16px -118.67px #47bfeb,53px -84.67px #47eb83,66px -57.67px #eb47bf,-93px -65.67px #91eb47,30px -13.67px #86eb47,-2px -59.67px #83eb47,-44px 1.33px #eb47eb,61px -58.67px #47eb73,5px -22.67px #47e8eb,-66px -28.67px #ebe247,42px -123.67px #eb5547,-75px 26.33px #7beb47,15px -52.67px #a147eb,36px -51.67px #eb8347,-38px -12.67px #eb5547,-46px -59.67px #47eb81,78px -114.67px #eb47ba,15px -156.67px #eb47bf,-36px 1.33px #eb4783,-72px -86.67px #eba147,31px -46.67px #ebe247,-68px 29.33px #47e2eb,-55px 19.33px #ebe047,-56px 27.33px #4776eb,-13px -91.67px #eb5547,-47px -138.67px #47ebc7,-18px -96.67px #eb47ac,11px -88.67px #4783eb,-67px -28.67px #47baeb,53px 10.33px #ba47eb,11px 19.33px #5247eb,-5px -11.67px #eb4791,-68px -4.67px #47eba7,95px -37.67px #eb478b,-67px -162.67px #eb5d47,-54px -120.67px #eb6847,49px -12.67px #ebe047,88px 8.33px #47ebda,97px 33.33px #eb8147,6px -71.67px #ebbc47}}@keyframes gravity{to{transform:translateY(80px);opacity:0}}@keyframes position{0%,19.9%{margin-top:4%;margin-left:47%}20%,39.9%{margin-top:7%;margin-left:
<span class=lh-env__description></span></li></template></ul></div><div class=lh-generated>Generated by <b>Lighthouse</b> <span class=lh-footer__version></span> |
<a href=https://github.com/GoogleChrome/Lighthouse/issues target=_blank rel=noopener class=lh-footer__version_issue>File an issue</a></div></footer></template><template id=tmpl-lh-gauge><a href=# class=lh-gauge__wrapper><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8"/></svg></div><div class=lh-gauge__percentage></div><div class=lh-gauge__label></div></a></template><template id=tmpl-lh-gauge--pwa><style>.lh-gauge--pwa .lh-gauge--pwa__component{display:none}.lh-gauge--pwa__wrapper:not(.lh-badged--all) .lh-gauge--pwa__logo>path{fill:#b0b0b0}.lh-gauge--pwa__disc{fill:var(--color-gray-200)}.lh-gauge--pwa__logo--primary-color{fill:#304ffe}.lh-gauge--pwa__logo--secondary-color{fill:#3d3d3d}.dark .lh-gauge--pwa__logo--secondary-color{fill:#d8b6b6}.lh-gauge--pwa__wrapper:not([class*=lh-badged--]) .lh-gauge--pwa__na-line{display:inline}.lh-gauge--pwa__wrapper.lh-badged--pwa-optimized:not(.lh-badged--pwa-installable) .lh-gauge--pwa__na-line{display:inline}.lh-gauge--pwa__wrapper.lh-badged--pwa-installable .lh-gauge--pwa__installable-badge{display:inline}.lh-gauge--pwa__wrapper.lh-badged--all .lh-gauge--pwa__check-circle{display:inline}</style><a href=# class="lh-gauge__wrapper lh-gauge--pwa__wrapper"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 60 60" class="lh-gauge lh-gauge--pwa"><defs><linearGradient id="lh-gauge--pwa__check-circle__gradient" x1="50%" y1="0" x2="50%" y2="100%"><stop stop-color="#00c852" offset="0"/><stop stop-color="#009688" offset="100%"/></linearGradient><linearGradient id="lh-gauge--pwa__installable__shadow-gradient" x1="76.056%" x2="24.111%" y1="82.995%" y2="24.735%"><stop stop-color="#a5d6a7" offset="0"/><stop stop-color="#80cbc4" offset="100%"/></linearGradient><g id="lh-gauge--pwa__installable-badge"><circle fill="#fff" cx="10" cy="10" r="10"/><path fill="#009688" d="M10 4.167A5.835 5.835.0 004.167 10 5.835 5.835.0 0010 15.833 5.835 5.835.0 0015.833 10 5.835 5.835.0 0010 4.167zm2.917 6.416h-2.334v2.334H9.417v-2.334H7.083V9.417h2.334V7.083h1.166v2.334h2.334v1.166z"/></g></defs><g stroke="none" fill-rule="nonzero"><circle class="lh-gauge--pwa__disc" cx="30" cy="30" r="30"/><g class="lh-gauge--pwa__logo"><path class="lh-gauge--pwa__logo--secondary-color" d="M35.66 19.39l.7-1.75h2L37.4 15l1.2-3 3.4 9h-2.51l-.58-1.61z"/><path class="lh-gauge--pwa__logo--primary-color" d="M33.52 21l3.65-9h-2.42l-2.5 5.82L30.5 12h-1.86l-1.9 5.82-1.35-2.65-1.21 3.72L25.4 21h2.38l1.72-5.2 1.64 5.2z"/><path class="lh-gauge--pwa__logo--secondary-color" fill-rule="nonzero" d="M20.3 17.91h1.48c.45.0.85-.05 1.2-.15l.39-1.18 1.07-3.3a2.64 2.64.0 00-.28-.37c-.55-.6-1.36-.91-2.42-.91H18v9h2.3V17.9zm1.96-3.84c.22.22.33.5.33.87.0.36-.1.65-.29.87-.2.23-.59.35-1.15.35h-.86v-2.41h.87c.52.0.89.1 1.1.32z"/></g><rect class="lh-gauge--pwa__component lh-gauge--pwa__na-line" fill="#fff" x="20" y="32" width="20" height="4" rx="2"/><g class="lh-gauge--pwa__component lh-gauge--pwa__installable-badge" transform="translate(20, 29)"><path fill="url(#lh-gauge--pwa__installable__shadow-gradient)" d="M33.629 19.487c-4.272 5.453-10.391 9.39-17.415 10.869L3 17.142 17.142 3 33.63 19.487z"/><use href="#lh-gauge--pwa__installable-badge"/></g><g class="lh-gauge--pwa__component lh-gauge--pwa__check-circle" transform="translate(18, 28)"><circle fill="#fff" cx="12" cy="12" r="12"/><path fill="url(#lh-gauge--pwa__check-circle__gradient)" d="M12 2a10 10 0 100 20 10 10 0 000-20zm-2 15-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"/></g></g></svg><div class=lh-gauge__label></div></a></template><template id=tmpl-lh-crc><div class=lh-crc-container><style>.lh-crc .tree-marker{width:12px;height:26px;display:block;float:left;background-position:0 0}.lh-crc .horiz-down{background:url('data:image/svg+xml;utf8,<svg width="16" height="26" viewBox="0 0 16 26" xmlns="http://www.w3.org/2000/svg"><g fill="%23D8D8D8" fill-rule="evenodd"><path d="M16 12v2H-2v-2z"/><path d="M9 12v14H7V12z"/></g></svg>')}.lh-crc .r
<span class=lh-3p-ui-string>Show 3rd party resources</span> (<span class=lh-3p-filter-count></span>)</label></div></template><template id=tmpl-lh-snippet><div class=lh-snippet><style>:root{--snippet-highlight-light:#fbf1f2;--snippet-highlight-dark:#ffd6d8}.lh-snippet__header{position:relative;overflow:hidden;padding:10px;border-bottom:none;color:var(--snippet-color);background-color:var(--snippet-background-color);border:1px solid var(--report-border-color-secondary)}.lh-snippet__title{font-weight:700;float:left}.lh-snippet__node{float:left;margin-left:4px}.lh-snippet__toggle-expand{padding:1px 7px;margin-top:-1px;margin-right:-7px;float:right;background:0 0;border:none;cursor:pointer;font-size:14px;color:#0c50c7}.lh-snippet__snippet{overflow:auto;border:1px solid var(--report-border-color-secondary)}.lh-snippet__snippet-inner{display:inline-block;min-width:100%}.lh-snippet:not(.lh-snippet--expanded) .lh-snippet__show-if-expanded{display:none}.lh-snippet.lh-snippet--expanded .lh-snippet__show-if-collapsed{display:none}.lh-snippet__line{background:#fff;white-space:pre;display:flex}.lh-snippet__line:not(.lh-snippet__line--message):first-child{padding-top:4px}.lh-snippet__line:not(.lh-snippet__line--message):last-child{padding-bottom:4px}.lh-snippet__line--content-highlighted{background:var(--snippet-highlight-dark)}.lh-snippet__line--message{background:var(--snippet-highlight-light)}.lh-snippet__line--message .lh-snippet__line-number{padding-top:10px;padding-bottom:10px}.lh-snippet__line--message code{padding:10px;padding-left:5px;color:var(--color-fail);font-family:var(--report-font-family)}.lh-snippet__line--message code{white-space:normal}.lh-snippet__line-icon{padding-top:10px;display:none}.lh-snippet__line--message .lh-snippet__line-icon{display:block}.lh-snippet__line-icon:before{content:"";display:inline-block;vertical-align:middle;margin-right:4px;width:var(--score-icon-size);height:var(--score-icon-size);background-image:var(--fail-icon-url)}.lh-snippet__line-number{flex-shrink:0;width:40px;text-align:right;font-family:monospace;padding-right:5px;margin-right:5px;color:var(--color-gray-600);user-select:none}</style><template id=tmpl-lh-snippet__header><div class=lh-snippet__header><div class=lh-snippet__title></div><div class=lh-snippet__node></div><button class=lh-snippet__toggle-expand>
<span class="lh-snippet__btn-label-collapse lh-snippet__show-if-expanded"></span>
<span class="lh-snippet__btn-label-expand lh-snippet__show-if-collapsed"></span></button></div></template><template id=tmpl-lh-snippet__content><div class=lh-snippet__snippet><div class=lh-snippet__snippet-inner></div></div></template><template id=tmpl-lh-snippet__line><div class=lh-snippet__line><div class=lh-snippet__line-number></div><div class=lh-snippet__line-icon></div><code></code></div></template></div></template><template id=tmpl-lh-element-screenshot><div class=lh-element-screenshot><div class=lh-element-screenshot__content><div class=lh-element-screenshot__mask><svg xmlns="http://www.w3.org/2000/svg" height="0" width="0"><defs><clipPath clipPathUnits="objectBoundingBox"/></defs></svg></div><div class=lh-element-screenshot__image></div><div class=lh-element-screenshot__element-marker></div></div></div></template></div><main><style>.lh-topbar{position:sticky;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;height:var(--topbar-height);background-color:var(--topbar-background-color);padding:var(--topbar-padding)}.lh-topbar__logo{width:var(--topbar-logo-size);height:var(--topbar-logo-size);user-select:none;flex:none}.lh-topbar__logo .shape{fill:var(--report-text-color)}.lh-topbar__url{margin:var(--topbar-padding);text-decoration:none;color:var(--report-text-color);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.lh-tools{margin-left:auto;will-change:transform;min-width:var(--report-icon-size)}.lh-tools__button{width:var(--report-icon-size);height:var(--report-icon-size);cursor:pointer;margin-right:5px;display:flex;background:0 0;color:inherit;border:none;padding:0;font:inherit;outline:inherit}.lh-tools__button svg{fill:var(--tools-icon-color)}.dark .lh-tools__button svg{filter:invert(1)}.lh-tools__button.active+.lh-tools__dropdown{opacity:1;clip:rect(-1px,194px,242px,-3px);visibility:visible}.lh-tools__dropdown{position:absolute;background-color:var(--report-background-color);border:1px solid var(--report-border-color);border-radius:3px;padding:calc(var(--default-padding)/2)0;cursor:pointer;top:36px;right:0;box-shadow:1px 1px 3px #ccc;min-width:125px;clip:rect(0,164px,0,0);visibility:hidden;opacity:0;transition:all 200ms cubic-bezier(0,0,.2,1)}.lh-tools__dropdown a{color:currentColor;text-decoration:none;white-space:nowrap;padding:0 12px;line-height:2}.lh-tools__dropdown a:hover,.lh-tools__dropdown a:focus{background-color:var(--color-gray-200);outline:none}.lh-tools__dropdown a[data-action=save-gist]{display:none}@media screen and (max-width:964px){.lh-tools__dropdown{right:0;left:initial}}@media print{.lh-topbar{position:static;margin-left:0}.lh-tools__dropdown{display:none}}</style><div class=lh-topbar><svg class="lh-topbar__logo" viewBox="0 0 24 24"><defs><linearGradient x1="57.456%" y1="13.086%" x2="18.259%" y2="72.322%" id="lh-topbar__logo--a"><stop stop-color="#262626" stop-opacity=".1" offset="0"/><stop stop-color="#262626" stop-opacity="0" offset="100%"/></linearGradient><linearGradient x1="100%" y1="50%" x2="0" y2="50%" id="lh-topbar__logo--b"><stop stop-color="#262626" stop-opacity=".1" offset="0"/><stop stop-color="#262626" stop-opacity="0" offset="100%"/></linearGradient><linearGradient x1="58.764%" y1="65.756%" x2="36.939%" y2="50.14%" id="lh-topbar__logo--c"><stop stop-color="#262626" stop-opacity=".1" offset="0"/><stop stop-color="#262626" stop-opacity="0" offset="100%"/></linearGradient><linearGradient x1="41.635%" y1="20.358%" x2="72.863%" y2="85.424%" id="lh-topbar__logo--d"><stop stop-color="#fff" stop-opacity=".1" offset="0"/><stop stop-color="#fff" stop-opacity="0" offset="100%"/></linearGradient></defs><g fill="none" fill-rule="evenodd"><path d="M12 3l4.125 2.625v3.75H18v2.25h-1.688l1.5 9.375H6.188l1.5-9.375H6v-2.25h1.875V5.648L12 3zm2.201 9.938L9.54 14.633 9 18.028l5.625-2.062-.424-3.028zM12.005 5.67l-1.88 1.207v2.498h3.75V6.86l-1.87-1.19z" fill="#f44b21"/><path fill="#fff" d="M14.201 12.938 9.54 14.633 9 18.028l5.625-2.062z"/><path d="M6 18c-2.042.0-3.95-.01-5.813.0l1.5-9.375h4.326L6 18z" fill="url(#lh-topbar__logo--a)" fill-rule="nonzero" transform="translate(6
<a href=http://localhost:8008/congo/samples/emoji/ class=lh-topbar__url target=_blank rel=noopener title=http://localhost:8008/congo/samples/emoji/>http://localhost:8008/congo/samples/emoji/</a><div class=lh-tools><button id=lh-tools-button class=lh-tools__button title="Tools menu" aria-label="Toggle report tools menu" aria-haspopup=menu aria-expanded=false aria-controls=lh-tools-dropdown><svg width="100%" height="100%" viewBox="0 0 24 24"><path d="M0 0h24v24H0z" fill="none"/><path d="M12 8c1.1.0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1.0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1.0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/></svg></button><div id=lh-tools-dropdown role=menu class=lh-tools__dropdown aria-labelledby=lh-tools-button><a role=menuitem tabindex=-1 href=# class="report-icon report-icon--print" data-i18n=dropdownPrintSummary data-action=print-summary>Print Summary</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--print" data-i18n=dropdownPrintExpanded data-action=print-expanded>Print Expanded</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--copy" data-i18n=dropdownCopyJSON data-action=copy>Copy JSON</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--download" data-i18n=dropdownSaveHTML data-action=save-html>Save as HTML</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--download" data-i18n=dropdownSaveJSON data-action=save-json>Save as JSON</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--open" data-i18n=dropdownViewer data-action=open-viewer>Open in Viewer</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--open" data-i18n=dropdownSaveGist data-action=save-gist>Save as Gist</a>
<a role=menuitem tabindex=-1 href=# class="report-icon report-icon--dark" data-i18n=dropdownDarkTheme data-action=toggle-dark>Toggle Dark Theme</a></div></div></div><div class=lh-container><div class=lh-sticky-header><a href=#performance class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>Performance</div></a><a href=#accessibility class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>Accessibility</div></a><a href=#best-practices class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>Best Practices</div></a><a href=#seo class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>SEO</div></a><a href=#pwa class="lh-gauge__wrapper lh-gauge--pwa__wrapper lh-badged--pwa-installable" title="Installable: 1/1, PWA Optimized: 6/8"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 60 60" class="lh-gauge lh-gauge--pwa"><defs><linearGradient id="lh-gauge--pwa__check-circle__gradient-1" x1="50%" y1="0" x2="50%" y2="100%"><stop stop-color="#00c852" offset="0"/><stop stop-color="#009688" offset="100%"/></linearGradient><linearGradient id="lh-gauge--pwa__installable__shadow-gradient-1" x1="76.056%" x2="24.111%" y1="82.995%" y2="24.735%"><stop stop-color="#a5d6a7" offset="0"/><stop stop-color="#80cbc4" offset="100%"/></linearGradient><g id="lh-gauge--pwa__installable-badge-1"><circle fill="#fff" cx="10" cy="10" r="10"/><path fill="#009688" d="M10 4.167A5.835 5.835.0 004.167 10 5.835 5.835.0 0010 15.833 5.835 5.835.0 0015.833 10 5.835 5.835.0 0010 4.167zm2.917 6.416h-2.334v2.334H9.417v-2.334H7.083V9.417h2.334V7.083h1.166v2.334h2.334v1.166z"/></g></defs><g stroke="none" fill-rule="nonzero"><circle class="lh-gauge--pwa__disc" cx="30" cy="30" r="30"/><g class="lh-gauge--pwa__logo"><path class="lh-gauge--pwa__logo--secondary-color" d="M35.66 19.39l.7-1.75h2L37.4 15l1.2-3 3.4 9h-2.51l-.58-1.61z"/><path class="lh-gauge--pwa__logo--primary-color" d="M33.52 21l3.65-9h-2.42l-2.5 5.82L30.5 12h-1.86l-1.9 5.82-1.35-2.65-1.21 3.72L25.4 21h2.38l1.72-5.2 1.64 5.2z"/><path class="lh-gauge--pwa__logo--secondary-color" fill-rule="nonzero" d="M20.3 17.91h1.48c.45.0.85-.05 1.2-.15l.39-1.18 1.07-3.3a2.64 2.64.0 00-.28-.37c-.55-.6-1.36-.91-2.42-.91H18v9h2.3V17.9zm1.96-3.84c.22.22.33.5.33.87.0.36-.1.65-.29.87-.2.23-.59.35-1.15.35h-.86v-2.41h.87c.52.0.89.1 1.1.32z"/></g><rect class="lh-gauge--pwa__component lh-gauge--pwa__na-line" fill="#fff" x="20" y="32" width="20" height="4" rx="2"/><g class="lh-gauge--pwa__component lh-gauge--pwa__installable-badge" transform="translate(20, 29)"><path
<span class="lh-scorescale-range lh-scorescale-range--average">5089</span>
<span class="lh-scorescale-range lh-scorescale-range--pass">90100</span></div></div></div></div></div><div class=lh-report><div></div><div class=lh-categories><div class=lh-category-wrapper><div class=lh-category><span class=lh-permalink id=performance></span><div class=lh-category-header><div class=lh-score__gauge role=heading aria-level=2><a href=#performance class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>Performance</div></a></div><div class=lh-category-header__description></div></div><div class="lh-audit-group lh-audit-group--metrics"><div class=lh-audit-group__header><span class=lh-audit-group__title>Metrics</span></div><input class=lh-metrics-toggle__input type=checkbox id=toggle-metric-descriptions aria-label="Toggle the display of metric descriptions">
<label class=lh-metrics-toggle__label for=toggle-metric-descriptions><div class="lh-metrics-toggle__icon lh-metrics-toggle__icon--less" aria-hidden=true><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24" height="24" viewBox="0 0 24 24"><path class="lh-metrics-toggle__lines" d="M4 9h16v2H4zm0 4h10v2H4z"/></svg></div><div class="lh-metrics-toggle__icon lh-metrics-toggle__icon--more" aria-hidden=true><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path class="lh-metrics-toggle__lines" d="M3 18h12v-2H3v2zM3 6v2h18V6H3zm0 7h18v-2H3v2z"/></svg></div></label><div class=lh-metrics-container><div class="lh-metric lh-metric--pass" id=first-contentful-paint><div class=lh-metric__innerwrap><span class=lh-metric__title>First Contentful Paint</span><div class=lh-metric__value>1.4&nbsp;s</div><div class=lh-metric__description><span>First Contentful Paint marks the time at which the first text or image is painted. <a rel=noopener target=_blank href="https://web.dev/first-contentful-paint/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div></div></div><div class="lh-metric lh-metric--pass" id=speed-index><div class=lh-metric__innerwrap><span class=lh-metric__title>Speed Index</span><div class=lh-metric__value>1.4&nbsp;s</div><div class=lh-metric__description><span>Speed Index shows how quickly the contents of a page are visibly populated. <a rel=noopener target=_blank href="https://web.dev/speed-index/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div></div></div><div class="lh-metric lh-metric--pass" id=largest-contentful-paint><div class=lh-metric__innerwrap><span class=lh-metric__title>Largest Contentful Paint</span><div class=lh-metric__value>1.5&nbsp;s</div><div class=lh-metric__description><span>Largest Contentful Paint marks the time at which the largest text or image is painted. <a rel=noopener target=_blank href="https://web.dev/lighthouse-largest-contentful-paint/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span></div></div></div><div class="lh-metric lh-metric--pass" id=interactive><div class=lh-metric__innerwrap><span class=lh-metric__title>Time to Interactive</span><div class=lh-metric__value>1.4&nbsp;s</div><div class=lh-metric__description><span>Time to interactive is the amount of time it takes for the page to become fully interactive. <a rel=noopener target=_blank href="https://web.dev/interactive/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div></div></div><div class="lh-metric lh-metric--pass" id=total-blocking-time><div class=lh-metric__innerwrap><span class=lh-metric__title>Total Blocking Time</span><div class=lh-metric__value>10&nbsp;ms</div><div class=lh-metric__description><span>Sum of all time periods between FCP and Time to Interactive, when task length exceeded 50ms, expressed in milliseconds. <a rel=noopener target=_blank href="https://web.dev/lighthouse-total-blocking-time/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div></div></div><div class="lh-metric lh-metric--pass" id=cumulative-layout-shift><div class=lh-metric__innerwrap><span class=lh-metric__title>Cumulative Layout Shift</span><div class=lh-metric__value>0</div><div class=lh-metric__description><span>Cumulative Layout Shift measures the movement of visible elements within the viewport. <a rel=noopener target=_blank href="https://web.dev/cls/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div></div></div></div><div class=lh-metrics__disclaimer><span>Values are estimated and may vary. The <a rel=noopener target=_blank href="https://web.dev/performance-scoring/?utm_source=lighthouse&amp;utm_medium=cli">performance score is calculated</a> directly from these metrics.</span><a class=lh-calclink target=_blank href="https://googlechrome.github.io/lighthouse/scorecalc/#FCP=1369&amp;SI=1369&amp;LCP=1500&amp;TTI=1400&amp;TBT=6&amp;CLS=0&amp;FMP=1369&amp;device=mobile&amp;version=8.0.0">See calculator.</a></div><div class=lh-buttons><button class="lh-button report-ico
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--bytes><div class=lh-text>Transfer Size</div></th><th class=lh-table-column--bytes><div class=lh-text>Potential Savings</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-url=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css><a rel=noopener target=_blank href=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css class=lh-link>…css/main.bundle.min.6783e34….css</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=40,665&nbsp;bytes>39.7&nbsp;KiB</div></td><td class=lh-table-column--bytes><div class=lh-text title=28,581&nbsp;bytes>27.9&nbsp;KiB</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--load-opportunity lh-audit--numeric lh-audit--average" id=unused-javascript><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><div class=lh-load-opportunity__cols><div class="lh-load-opportunity__col lh-load-opportunity__col--one"><span class=lh-audit__score-icon></span><div class=lh-audit__title><span>Reduce unused JavaScript</span></div></div><div class="lh-load-opportunity__col lh-load-opportunity__col--two"><div class=lh-load-opportunity__sparkline title="Potential savings of 21&nbsp;KiB"><div class=lh-sparkline><div class=lh-sparkline__bar style=width:7.5%></div></div></div><div class=lh-audit__display-text title="Potential savings of 21&nbsp;KiB">0.15&nbsp;s</div><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></div></div></summary><div class=lh-audit__description><span>Reduce unused JavaScript and defer loading scripts until they are required to decrease bytes consumed by network activity. <a rel=noopener target=_blank href="https://web.dev/unused-javascript/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--1><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--1 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--bytes><div class=lh-text>Transfer Size</div></th><th class=lh-table-column--bytes><div class=lh-text>Potential Savings</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js data-url=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js><a rel=noopener target=_blank href=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js class=lh-link>…js/main.bundle.min.81d5d44….js</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=27,861&nbsp;bytes>27.2&nbsp;KiB</div></td><td class=lh-table-column--bytes><div class=lh-text title=21,903&nbsp;bytes>21.4&nbsp;KiB</div></td></tr></tbody></table></details></div></div><div class="lh-audit-group lh-audit-group--diagnostics"><div class=lh-audit-group__header><span class=lh-audit-group__title>Diagnostics</span><span class=lh-audit-group__description>More information about the performance of your application. These numbers don't <a rel=noopener target=_blank href="https://web.dev/performance-scoring/?utm_source=lighthouse&amp;utm_medium=cli">directly affect</a> the Performance score.</span></div><div class="lh-audit lh-audit--informative" id=critical-request-chains><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoid chaining critical requests</span></span>
<span class=lh-audit__display-text>1 chain found</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The Critical Request Chains below show you what resources are loaded with a high priority. Consider reducing the length of chains, reducing the download size of resources, or deferring the download of unnecessary resources to improve page load. <a rel=noopener target=_blank href="https://web.dev/critical-request-chains/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><div class="lh-crc-container lh-details"><style>.lh-crc .tree-marker{width:12px;height:26px;display:block;float:left;background-position:0 0}.lh-crc .horiz-down{background:url('data:image/svg+xml;utf8,<svg width="16" height="26" viewBox="0 0 16 26" xmlns="http://www.w3.org/2000/svg"><g fill="%23D8D8D8" fill-rule="evenodd"><path d="M16 12v2H-2v-2z"/><path d="M9 12v14H7V12z"/></g></svg>')}.lh-crc .right{background:url('data:image/svg+xml;utf8,<svg width="16" height="26" viewBox="0 0 16 26" xmlns="http://www.w3.org/2000/svg"><path d="M16 12v2H0v-2z" fill="%23D8D8D8" fill-rule="evenodd"/></svg>')}.lh-crc .up-right{background:url('data:image/svg+xml;utf8,<svg width="16" height="26" viewBox="0 0 16 26" xmlns="http://www.w3.org/2000/svg"><path d="M7 0h2v14H7zm2 12h7v2H9z" fill="%23D8D8D8" fill-rule="evenodd"/></svg>')}.lh-crc .vert-right{background:url('data:image/svg+xml;utf8,<svg width="16" height="26" viewBox="0 0 16 26" xmlns="http://www.w3.org/2000/svg"><path d="M7 0h2v27H7zm2 12h7v2H9z" fill="%23D8D8D8" fill-rule="evenodd"/></svg>')}.lh-crc .vert{background:url('data:image/svg+xml;utf8,<svg width="16" height="26" viewBox="0 0 16 26" xmlns="http://www.w3.org/2000/svg"><path d="M7 0h2v26H7z" fill="%23D8D8D8" fill-rule="evenodd"/></svg>')}.lh-crc .crc-tree{font-size:14px;width:100%;overflow-x:auto}.lh-crc .crc-node{height:26px;line-height:26px;white-space:nowrap}.lh-crc .crc-node__tree-value{margin-left:10px}.lh-crc .crc-node__tree-value div{display:inline}.lh-crc .crc-node__chain-duration{font-weight:700}.lh-crc .crc-initial-nav{color:#595959;font-style:italic}.lh-crc__summary-value{margin-bottom:10px}</style><div><div class=lh-crc__summary-value><span class=lh-crc__longest_duration_label>Maximum critical path latency:</span> <b class=lh-crc__longest_duration>20&nbsp;ms</b></div></div><div class=lh-crc><div class=crc-initial-nav>Initial Navigation</div><template id=tmpl-lh-crc__chains><div class=crc-node><span class=crc-node__tree-marker></span><span class=crc-node__tree-value></span></div></template><div class=crc-node title=http://localhost:8008/congo/samples/emoji/><span class=crc-node__tree-marker><span class="tree-marker up-right"></span><span class="tree-marker right"></span><span class="tree-marker horiz-down"></span></span>
<span class=crc-node__tree-value><div class=lh-text__url title=http://localhost:8008/congo/samples/emoji/ data-url=http://localhost:8008/congo/samples/emoji/><a rel=noopener target=_blank href=http://localhost:8008/congo/samples/emoji/ class=lh-link>…samples/emoji</a><div class="lh-text lh-text__url-host">(localhost)</div></div></span></div><div class=crc-node title=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css><span class=crc-node__tree-marker><span class=tree-marker></span><span class=tree-marker></span><span class="tree-marker up-right"></span><span class="tree-marker right"></span><span class="tree-marker right"></span></span>
<span class=crc-node__tree-value><div class=lh-text__url title=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-url=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css><a rel=noopener target=_blank href=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css class=lh-link>…css/main.bundle.min.6783e34….css</a><div class="lh-text lh-text__url-host">(localhost)</div></div><span class=crc-node__chain-duration>- 0&nbsp;ms, </span><span class=crc-node__chain-duration>39.71&nbsp;KiB</span></span></div></div></div></details></div><div class="lh-audit lh-audit--informative" id=resource-summary><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Keep request counts low and transfer sizes small</span></span>
<span class=lh-audit__display-text>4 requests • 92 KiB</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>To set budgets for the quantity and size of page resources, add a budget.json file. <a rel=noopener target=_blank href="https://web.dev/use-lighthouse-for-performance-budgets/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--text><div class=lh-text>Resource Type</div></th><th class=lh-table-column--numeric><div class=lh-text>Requests</div></th><th class=lh-table-column--bytes><div class=lh-text>Transfer Size</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Total</div></td><td class=lh-table-column--numeric><div class=lh-numeric>4</div></td><td class=lh-table-column--bytes><div class=lh-text title=93,852&nbsp;bytes>91.7&nbsp;KiB</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Stylesheet</div></td><td class=lh-table-column--numeric><div class=lh-numeric>1</div></td><td class=lh-table-column--bytes><div class=lh-text title=40,665&nbsp;bytes>39.7&nbsp;KiB</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Script</div></td><td class=lh-table-column--numeric><div class=lh-numeric>1</div></td><td class=lh-table-column--bytes><div class=lh-text title=27,861&nbsp;bytes>27.2&nbsp;KiB</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Document</div></td><td class=lh-table-column--numeric><div class=lh-numeric>1</div></td><td class=lh-table-column--bytes><div class=lh-text title=17,411&nbsp;bytes>17.0&nbsp;KiB</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Image</div></td><td class=lh-table-column--numeric><div class=lh-numeric>1</div></td><td class=lh-table-column--bytes><div class=lh-text title=7,915&nbsp;bytes>7.7&nbsp;KiB</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Media</div></td><td class=lh-table-column--numeric><div class=lh-numeric>0</div></td><td class=lh-table-column--bytes><div class=lh-text title=0&nbsp;bytes>0.0&nbsp;KiB</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Font</div></td><td class=lh-table-column--numeric><div class=lh-numeric>0</div></td><td class=lh-table-column--bytes><div class=lh-text title=0&nbsp;bytes>0.0&nbsp;KiB</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Other</div></td><td class=lh-table-column--numeric><div class=lh-numeric>0</div></td><td class=lh-table-column--bytes><div class=lh-text title=0&nbsp;bytes>0.0&nbsp;KiB</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Third-party</div></td><td class=lh-table-column--numeric><div class=lh-numeric>0</div></td><td class=lh-table-column--bytes><div class=lh-text title=0&nbsp;bytes>0.0&nbsp;KiB</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--informative" id=largest-contentful-paint-element><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Largest Contentful Paint element</span></span>
<span class=lh-audit__display-text>1 element found</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>This is the largest contentful element painted within the viewport. <a rel=noopener target=_blank href="https://web.dev/lighthouse-largest-contentful-paint/?utm_source=lighthouse&amp;utm_medium=cli">Learn More</a></span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--node><div class=lh-text>Element</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--node><span class=lh-node title="section.flex > div.min-w-0 > div.flex > span.dark:text-neutral-300" data-path=1,HTML,1,BODY,2,MAIN,0,ARTICLE,1,SECTION,0,DIV,1,DIV,1,SPAN data-selector="section.flex > div.min-w-0 > div.flex > span.dark:text-neutral-300" data-snippet='<span class="dark:text-neutral-300">'><div>Note: The rendering of these glyphs depends on the browser and the platform. To…</div><div class=lh-node__snippet>&lt;span class="dark:text-neutral-300"></div></span></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--informative" id=long-tasks><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoid long main-thread tasks</span></span>
<span class=lh-audit__display-text>2 long tasks found</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Lists the longest tasks on the main thread, useful for identifying worst contributors to input delay. <a rel=noopener target=_blank href="https://web.dev/long-tasks-devtools/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--2><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--2 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--ms><div class=lh-text>Start Time</div></th><th class=lh-table-column--ms><div class=lh-text>Duration</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/samples/emoji/ data-url=http://localhost:8008/congo/samples/emoji/><a rel=noopener target=_blank href=http://localhost:8008/congo/samples/emoji/ class=lh-link>…samples/emoji</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--ms><div class=lh-text>785&nbsp;ms</div></td><td class=lh-table-column--ms><div class=lh-text>584&nbsp;ms</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/samples/emoji/ data-url=http://localhost:8008/congo/samples/emoji/><a rel=noopener target=_blank href=http://localhost:8008/congo/samples/emoji/ class=lh-link>…samples/emoji</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--ms><div class=lh-text>1,369&nbsp;ms</div></td><td class=lh-table-column--ms><div class=lh-text>61&nbsp;ms</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--informative" id=non-composited-animations><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoid non-composited animations</span></span>
<span class=lh-audit__display-text>18 animated elements found</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Animations which are not composited can be janky and increase CLS. <a rel=noopener target=_blank href="https://web.dev/non-composited-animations?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span><span class=lh-audit__adorn title="Relevant to Cumulative Layout Shift">CLS</span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--node><div class=lh-text>Element</div></th><th class=lh-table-column--text><div class=lh-text>Name</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--node><span class=lh-node title="body.flex > div#the-top > a.px-3" data-path=1,HTML,1,BODY,0,DIV,0,A data-selector="body.flex > div#the-top > a.px-3" data-snippet='<a class="px-3 py-1 text-sm -translate-y-8 rounded-b-lg bg-primary-200 dark:bg-neutr…" href="#main-content">'><div>↓Skip to main content</div><div class=lh-node__snippet>&lt;a class="px-3 py-1 text-sm -translate-y-8 rounded-b-lg bg-primary-200 dark:bg-neutr…" href="#main-content"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--even"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: background-color</div></td><td class=lh-table-column--text><div class=lh-text>background-color</div></td></tr><tr class="lh-sub-item-row lh-row--even"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--node><span class=lh-node title="body.flex > header.flex > div > a.hover:underline" data-path=1,HTML,1,BODY,1,HEADER,0,DIV,0,A data-selector="body.flex > header.flex > div > a.hover:underline" data-snippet='<a class="hover:underline hover:decoration-primary-500 hover:decoration-2 hover:unde…" rel="me" href="/congo/">'><div>Congo</div><div class=lh-node__snippet>&lt;a class="hover:underline hover:decoration-primary-500 hover:decoration-2 hover:unde…" rel="me" href="/congo/"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--odd"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr><tr class=lh-row--even><td class=lh-table-column--node><span class=lh-node title="nav > ul.flex > li.mb-1 > a.hover:underline" data-path=1,HTML,1,BODY,1,HEADER,1,NAV,0,UL,0,LI,0,A data-selector="nav > ul.flex > li.mb-1 > a.hover:underline" data-snippet='<a class="hover:underline hover:decoration-primary-500 hover:decoration-2 hover:unde…" href="/congo/docs/">'><div>Docs</div><div class=lh-node__snippet>&lt;a class="hover:underline hover:decoration-primary-500 hover:decoration-2 hover:unde…" href="/congo/docs/"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--even"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--node><span class=lh-node title="nav > ul.flex > li.mb-1 > a.hover:underline" data-path=1,HTML,1,BODY,1,HEADER,1,NAV,0,UL,1,LI,0,A data-selector="nav > ul.flex > li.mb-1 > a.hover:underline" data-snippet='<a class="hover:underline hover:decoration-primary-500 hover:decoration-2 hover:unde…" href="/congo/samples/">'><div>Samples</div><div class=lh-node__snippet>&lt;a class="hover:underline hover:decoration-primary-500 hover:decoration-2 hover:unde…" href="/congo/samples/"></div></span></td><td class=l
Diagrams and Flowcharts
6 March 2019</div><div class=lh-node__snippet>&lt;a class="flex" href="/congo/samples/diagrams-flowcharts/"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--even"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--node><span class=lh-node title="div#search-wrapper > div#search-modal > header.relative > button#close-search-button" data-path=1,HTML,1,BODY,3,DIV,0,DIV,0,HEADER,1,BUTTON data-selector="div#search-wrapper > div#search-modal > header.relative > button#close-search-button" data-snippet='<button id="close-search-button" class="flex items-center justify-center w-8 h-8 text-neutral-700 dark:text-neutra…">'><div>button</div><div class=lh-node__snippet>&lt;button id="close-search-button" class="flex items-center justify-center w-8 h-8 text-neutral-700 dark:text-neutra…"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--odd"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr><tr class=lh-row--even><td class=lh-table-column--node><span class=lh-node title="div.flex > div > p.text-xs > a.hover:underline" data-path=1,HTML,1,BODY,4,FOOTER,0,DIV,0,DIV,1,P,1,A data-selector="div.flex > div > p.text-xs > a.hover:underline" data-snippet='<a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href="https://gohugo.io/" target="_blank" rel="noopener noreferrer">'><div>Hugo</div><div class=lh-node__snippet>&lt;a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href="https://gohugo.io/" target="_blank" rel="noopener noreferrer"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--even"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--node><span class=lh-node title="div.flex > div > p.text-xs > a.hover:underline" data-path=1,HTML,1,BODY,4,FOOTER,0,DIV,0,DIV,1,P,3,A data-selector="div.flex > div > p.text-xs > a.hover:underline" data-snippet='<a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href="https://git.io/hugo-congo" target="_blank" rel="noopener noreferrer">'><div>Congo</div><div class=lh-node__snippet>&lt;a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href="https://git.io/hugo-congo" target="_blank" rel="noopener noreferrer"></div></span></td><td class=lh-table-column--empty></td></tr><tr class="lh-sub-item-row lh-row--odd"><td class=lh-table-column--text><div class=lh-text>Unsupported CSS Property: color</div></td><td class=lh-table-column--text><div class=lh-text>color</div></td></tr></tbody></table></details></div></div><details class="lh-clump lh-audit-group lh-clump--passed"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Passed audits</span>
<span class=lh-audit-group__itemcount>(28)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--numeric lh-audit--pass" id=render-blocking-resources><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Eliminate render-blocking resources</span></span>
<span class=lh-audit__display-text>Potential savings of 0&nbsp;ms</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Resources are blocking the first paint of your page. Consider delivering critical JS/CSS inline and deferring all non-critical JS/styles. <a rel=noopener target=_blank href="https://web.dev/render-blocking-resources/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--3><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--3 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--bytes><div class=lh-text>Transfer Size</div></th><th class=lh-table-column--timespanMs><div class=lh-text>Potential Savings</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-url=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css><a rel=noopener target=_blank href=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css class=lh-link>…css/main.bundle.min.6783e34….css</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=40,665&nbsp;bytes>39.7&nbsp;KiB</div></td><td class=lh-table-column--timespanMs><div class=lh-text>480&nbsp;ms</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=uses-responsive-images><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Properly size images</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Serve images that are appropriately-sized to save cellular data and improve load time. <a rel=noopener target=_blank href="https://web.dev/uses-responsive-images/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=offscreen-images><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Defer offscreen images</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider lazy-loading offscreen and hidden images after all critical resources have finished loading to lower time to interactive. <a rel=noopener target=_blank href="https://web.dev/offscreen-images/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=unminified-css><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Minify CSS</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Minifying CSS files can reduce network payload sizes. <a rel=noopener target=_blank href="https://web.dev/unminified-css/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=unminified-javascript><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Minify JavaScript</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Minifying JavaScript files can reduce payload sizes and script parse time. <a rel=noopener target=_blank href="https://web.dev/unminified-javascript/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=uses-optimized-images><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Efficiently encode images</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Optimized images load faster and consume less cellular data. <a rel=noopener target=_blank href="https://web.dev/uses-optimized-images/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=modern-image-formats><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Serve images in next-gen formats</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Image formats like JPEG 2000, JPEG XR, and WebP often provide better compression than PNG or JPEG, which means faster downloads and less data consumption. <a rel=noopener target=_blank href="https://web.dev/uses-webp-images/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=uses-rel-preconnect><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Preconnect to required origins</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider adding `preconnect` or `dns-prefetch` resource hints to establish early connections to important third-party origins. <a rel=noopener target=_blank href="https://web.dev/uses-rel-preconnect/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=server-response-time><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Initial server response time was short</span></span>
<span class=lh-audit__display-text>Root document took 0&nbsp;ms</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Keep the server response time for the main document short because all other requests depend on it. <a rel=noopener target=_blank href="https://web.dev/time-to-first-byte/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--4><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--4 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--timespanMs><div class=lh-text>Time Spent</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/samples/emoji/ data-url=http://localhost:8008/congo/samples/emoji/><a rel=noopener target=_blank href=http://localhost:8008/congo/samples/emoji/ class=lh-link>…samples/emoji</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--timespanMs><div class=lh-text>0&nbsp;ms</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=redirects><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoid multiple page redirects</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Redirects introduce additional delays before the page can be loaded. <a rel=noopener target=_blank href="https://web.dev/redirects/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=uses-rel-preload><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Preload key requests</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider using `&lt;link rel=preload>` to prioritize fetching resources that are currently requested later in page load. <a rel=noopener target=_blank href="https://web.dev/uses-rel-preload/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=uses-http2><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Use HTTP/2</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>HTTP/2 offers many benefits over HTTP/1.1, including binary headers and multiplexing. <a rel=noopener target=_blank href="https://web.dev/uses-http2/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=efficient-animated-content><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Use video formats for animated content</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Large GIFs are inefficient for delivering animated content. Consider using MPEG4/WebM videos for animations and PNG/WebP for static images instead of GIF to save network bytes. <a rel=noopener target=_blank href="https://web.dev/efficient-animated-content/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=duplicated-javascript><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Remove duplicate modules in JavaScript bundles</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Remove large, duplicate JavaScript modules from bundles to reduce unnecessary bytes consumed by network activity. </span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=legacy-javascript><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoid serving legacy JavaScript to modern browsers</span></span>
<span class=lh-audit__display-text>Potential savings of 0&nbsp;KiB</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Polyfills and transforms enable legacy browsers to use new JavaScript features. However, many aren't necessary for modern browsers. For your bundled JavaScript, adopt a modern script deployment strategy using module/nomodule feature detection to reduce the amount of code shipped to modern browsers, while retaining support for legacy browsers. <a rel=noopener target=_blank href=https://philipwalton.com/articles/deploying-es2015-code-in-production-today/>Learn More</a></span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--5><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--5 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--code><div class=lh-text></div></th><th class=lh-table-column--bytes><div class=lh-text>Potential Savings</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js data-url=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js><a rel=noopener target=_blank href=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js class=lh-link>…js/main.bundle.min.81d5d44….js</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--empty></td><td class=lh-table-column--bytes><div class=lh-text title=168&nbsp;bytes>0.2&nbsp;KiB</div></td></tr><tr class="lh-sub-item-row lh-row--even"><td class=lh-table-column--source-location><div class="lh-text__url lh-source-location" title=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js data-url=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js data-source-url=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js data-source-line=0 data-source-column=2227><a rel=noopener target=_blank href=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js class=lh-link>…js/main.bundle.min.81d5d44….js:1:2227</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--code><pre class=lh-code>@babel/plugin-transform-classes</pre></td><td class=lh-table-column--empty></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=preload-lcp-image><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Preload Largest Contentful Paint image</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Preload the image used by the LCP element in order to improve your LCP time. <a rel=noopener target=_blank href="https://web.dev/optimize-lcp/?utm_source=lighthouse&amp;utm_medium=cli#preload-important-resources">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=total-byte-weight><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids enormous network payloads</span></span>
<span class=lh-audit__display-text>Total size was 92&nbsp;KiB</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Large network payloads cost users real money and are highly correlated with long load times. <a rel=noopener target=_blank href="https://web.dev/total-byte-weight/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--6><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--6 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--bytes><div class=lh-text>Transfer Size</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-url=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css><a rel=noopener target=_blank href=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css class=lh-link>…css/main.bundle.min.6783e34….css</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=40,665&nbsp;bytes>39.7&nbsp;KiB</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js data-url=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js><a rel=noopener target=_blank href=http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js class=lh-link>…js/main.bundle.min.81d5d44….js</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=27,861&nbsp;bytes>27.2&nbsp;KiB</div></td></tr><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/samples/emoji/ data-url=http://localhost:8008/congo/samples/emoji/><a rel=noopener target=_blank href=http://localhost:8008/congo/samples/emoji/ class=lh-link>…samples/emoji</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=17,411&nbsp;bytes>17.0&nbsp;KiB</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/author_hu052d24d60828c1cca42a6aefe45b8b44_54195_192x192_fill_q75_box_smart1.jpg data-url=http://localhost:8008/congo/author_hu052d24d60828c1cca42a6aefe45b8b44_54195_192x192_fill_q75_box_smart1.jpg><a rel=noopener target=_blank href=http://localhost:8008/congo/author_hu052d24d60828c1cca42a6aefe45b8b44_54195_192x192_fill_q75_box_smart1.jpg class=lh-link>/congo/author_hu052d24d…_54195_192x192_fill_q75_box_smart1.jpg</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--bytes><div class=lh-text title=7,915&nbsp;bytes>7.7&nbsp;KiB</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=dom-size><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids an excessive DOM size</span></span>
<span class=lh-audit__display-text>120 elements</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A large DOM will increase memory usage, cause longer <a rel=noopener target=_blank href="https://developers.google.com/web/fundamentals/performance/rendering/reduce-the-scope-and-complexity-of-style-calculations?utm_source=lighthouse&amp;utm_medium=cli">style calculations</a>, and produce costly <a rel=noopener target=_blank href="https://developers.google.com/speed/articles/reflow?utm_source=lighthouse&amp;utm_medium=cli">layout reflows</a>. <a rel=noopener target=_blank href="https://web.dev/dom-size/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--text><div class=lh-text>Statistic</div></th><th class=lh-table-column--node><div class=lh-text>Element</div></th><th class=lh-table-column--numeric><div class=lh-text>Value</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Total DOM Elements</div></td><td class=lh-table-column--empty></td><td class=lh-table-column--numeric><div class=lh-numeric>120</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Maximum DOM Depth</div></td><td class=lh-table-column--node><span class=lh-node title="a.px-1 > span.relative > svg.svg-inline--fa > path" data-path=1,HTML,1,BODY,2,MAIN,0,ARTICLE,2,FOOTER,0,DIV,1,DIV,3,DIV,0,DIV,0,A,0,SPAN,0,svg,0,path data-selector="a.px-1 > span.relative > svg.svg-inline--fa > path" data-snippet='<path fill="currentcolor" d="M459.37 151.716c.325 4.548.325 9.097.325 13.645.0 138.72-105.583 298.558-2…">'><div>path</div><div class=lh-node__snippet>&lt;path fill="currentcolor" d="M459.37 151.716c.325 4.548.325 9.097.325 13.645.0 138.72-105.583 298.558-2…"></div></span></td><td class=lh-table-column--numeric><div class=lh-numeric>12</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Maximum Child Elements</div></td><td class=lh-table-column--node><span class=lh-node title=body.flex data-path=1,HTML,1,BODY data-selector=body.flex data-snippet='<body class="flex flex-col h-screen px-6 m-auto text-lg leading-7 bg-neutral text-neutr…">'><div>body</div><div class=lh-node__snippet>&lt;body class="flex flex-col h-screen px-6 m-auto text-lg leading-7 bg-neutral text-neutr…"></div></span></td><td class=lh-table-column--numeric><div class=lh-numeric>5</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=user-timings><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>User Timing marks and measures</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider instrumenting your app with the User Timing API to measure your app's real-world performance during key user experiences. <a rel=noopener target=_blank href="https://web.dev/user-timings/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=bootup-time><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>JavaScript execution time</span></span>
<span class=lh-audit__display-text>0.0&nbsp;s</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider reducing the time spent parsing, compiling, and executing JS. You may find delivering smaller JS payloads helps with this. <a rel=noopener target=_blank href="https://web.dev/bootup-time/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--7><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--7 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--url><div class=lh-text>URL</div></th><th class=lh-table-column--ms><div class=lh-text>Total CPU Time</div></th><th class=lh-table-column--ms><div class=lh-text>Script Evaluation</div></th><th class=lh-table-column--ms><div class=lh-text>Script Parse</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--url><div class=lh-text__url title=http://localhost:8008/congo/samples/emoji/ data-url=http://localhost:8008/congo/samples/emoji/><a rel=noopener target=_blank href=http://localhost:8008/congo/samples/emoji/ class=lh-link>…samples/emoji</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--ms><div class=lh-text>1,411&nbsp;ms</div></td><td class=lh-table-column--ms><div class=lh-text>4&nbsp;ms</div></td><td class=lh-table-column--ms><div class=lh-text>1&nbsp;ms</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--numeric lh-audit--pass" id=mainthread-work-breakdown><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Minimizes main-thread work</span></span>
<span class=lh-audit__display-text>1.5&nbsp;s</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider reducing the time spent parsing, compiling and executing JS. You may find delivering smaller JS payloads helps with this. <a rel=noopener target=_blank href="https://web.dev/mainthread-work-breakdown/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--text><div class=lh-text>Category</div></th><th class=lh-table-column--ms><div class=lh-text>Time Spent</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Style & Layout</div></td><td class=lh-table-column--ms><div class=lh-text>1,117&nbsp;ms</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Rendering</div></td><td class=lh-table-column--ms><div class=lh-text>252&nbsp;ms</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Other</div></td><td class=lh-table-column--ms><div class=lh-text>53&nbsp;ms</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Script Evaluation</div></td><td class=lh-table-column--ms><div class=lh-text>20&nbsp;ms</div></td></tr><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>Parse HTML & CSS</div></td><td class=lh-table-column--ms><div class=lh-text>8&nbsp;ms</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--text><div class=lh-text>Script Parsing & Compilation</div></td><td class=lh-table-column--ms><div class=lh-text>3&nbsp;ms</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=font-display><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>All text remains visible during webfont loads</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Leverage the font-display CSS feature to ensure text is user-visible while webfonts are loading. <a rel=noopener target=_blank href="https://web.dev/font-display/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to First Contentful Paint">FCP</span><span class=lh-audit__adorn title="Relevant to Largest Contentful Paint">LCP</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=third-party-summary><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Minimize third-party usage</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Third-party code can significantly impact load performance. Limit the number of redundant third-party providers and try to load third-party code after your page has primarily finished loading. <a rel=noopener target=_blank href="https://developers.google.com/web/fundamentals/performance/optimizing-content-efficiency/loading-third-party-javascript/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=third-party-facades><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Lazy load third-party resources with facades</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Some third-party embeds can be lazy loaded. Consider replacing them with a facade until they are required. <a rel=noopener target=_blank href="https://web.dev/third-party-facades/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span><span class=lh-audit__adorn title="Relevant to Total Blocking Time">TBT</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=layout-shift-elements><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoid large layout shifts</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>These DOM elements contribute most to the CLS of the page.</span><span class=lh-audit__adorn title="Relevant to Cumulative Layout Shift">CLS</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=uses-passive-event-listeners><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Uses passive listeners to improve scrolling performance</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Consider marking your touch and wheel event listeners as `passive` to improve your page's scroll performance. <a rel=noopener target=_blank href="https://web.dev/uses-passive-event-listeners/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=no-document-write><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids <code>document.write()</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>For users on slow connections, external scripts dynamically injected via `document.write()` can delay page load by tens of seconds. <a rel=noopener target=_blank href="https://web.dev/no-document-write/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=unsized-images><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Image elements have explicit <code>width</code> and <code>height</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Set an explicit width and height on image elements to reduce layout shifts and improve CLS. <a rel=noopener target=_blank href="https://web.dev/optimize-cls/?utm_source=lighthouse&amp;utm_medium=cli#images-without-dimensions">Learn more</a></span><span class=lh-audit__adorn title="Relevant to Cumulative Layout Shift">CLS</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div></details></div></div><div class=lh-category-wrapper><div class=lh-category><span class=lh-permalink id=accessibility></span><div class=lh-category-header><div class=lh-score__gauge role=heading aria-level=2><a href=#accessibility class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>Accessibility</div></a></div><div class=lh-category-header__description><span>These checks highlight opportunities to <a rel=noopener target=_blank href="https://developers.google.com/web/fundamentals/accessibility?utm_source=lighthouse&amp;utm_medium=cli">improve the accessibility of your web app</a>. Only a subset of accessibility issues can be automatically detected so manual testing is also encouraged.</span></div></div><details class="lh-clump lh-audit-group lh-clump--manual"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Additional items to manually check</span>
<span class=lh-audit-group__itemcount>(10)</span>
<span class=lh-audit-group__description>These items address areas which an automated testing tool cannot cover. Learn more in our guide on <a rel=noopener target=_blank href="https://developers.google.com/web/fundamentals/accessibility/how-to-review?utm_source=lighthouse&amp;utm_medium=cli">conducting an accessibility review</a>.</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--manual lh-audit--pass" id=logical-tab-order><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>The page has a logical tab order</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Tabbing through the page follows the visual layout. Users cannot focus elements that are offscreen. <a rel=noopener target=_blank href="https://web.dev/logical-tab-order/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=focusable-controls><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Interactive controls are keyboard focusable</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Custom interactive controls are keyboard focusable and display a focus indicator. <a rel=noopener target=_blank href="https://web.dev/focusable-controls/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=interactive-element-affordance><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Interactive elements indicate their purpose and state</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Interactive elements, such as links and buttons, should indicate their state and be distinguishable from non-interactive elements. <a rel=noopener target=_blank href="https://web.dev/interactive-element-affordance/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=managed-focus><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>The user's focus is directed to new content added to the page</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>If new content, such as a dialog, is added to the page, the user's focus is directed to it. <a rel=noopener target=_blank href="https://web.dev/managed-focus/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=focus-traps><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>User focus is not accidentally trapped in a region</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A user can tab into and out of any control or region without accidentally trapping their focus. <a rel=noopener target=_blank href="https://web.dev/focus-traps/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=custom-controls-labels><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Custom controls have associated labels</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Custom interactive controls have associated labels, provided by aria-label or aria-labelledby. <a rel=noopener target=_blank href="https://web.dev/custom-controls-labels/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=custom-controls-roles><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Custom controls have ARIA roles</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Custom interactive controls have appropriate ARIA roles. <a rel=noopener target=_blank href="https://web.dev/custom-control-roles/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=visual-order-follows-dom><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Visual order on the page follows DOM order</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>DOM order matches the visual order, improving navigation for assistive technology. <a rel=noopener target=_blank href="https://web.dev/visual-order-follows-dom/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=offscreen-content-hidden><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Offscreen content is hidden from assistive technology</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Offscreen content is hidden with display: none or aria-hidden=true. <a rel=noopener target=_blank href="https://web.dev/offscreen-content-hidden/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=use-landmarks><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>HTML5 landmark elements are used to improve navigation</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Landmark elements (&lt;main>, &lt;nav>, etc.) are used to improve the keyboard navigation of the page for assistive technology. <a rel=noopener target=_blank href="https://web.dev/use-landmarks/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div></details><details class="lh-clump lh-audit-group lh-clump--passed"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Passed audits</span>
<span class=lh-audit-group__itemcount>(18)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--binary lh-audit--pass" id=aria-allowed-attr><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[aria-*]</code> attributes match their roles</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Each ARIA `role` supports a specific subset of `aria-*` attributes. Mismatching these invalidates the `aria-*` attributes. <a rel=noopener target=_blank href="https://web.dev/aria-allowed-attr/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=aria-hidden-body><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[aria-hidden="true"]</code> is not present on the document <code>&lt;body></code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Assistive technologies, like screen readers, work inconsistently when `aria-hidden="true"` is set on the document `&lt;body>`. <a rel=noopener target=_blank href="https://web.dev/aria-hidden-body/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=aria-hidden-focus><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[aria-hidden="true"]</code> elements do not contain focusable descendents</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Focusable descendents within an `[aria-hidden="true"]` element prevent those interactive elements from being available to users of assistive technologies like screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-hidden-focus/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=aria-valid-attr-value><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[aria-*]</code> attributes have valid values</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Assistive technologies, like screen readers, can't interpret ARIA attributes with invalid values. <a rel=noopener target=_blank href="https://web.dev/aria-valid-attr-value/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=aria-valid-attr><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[aria-*]</code> attributes are valid and not misspelled</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Assistive technologies, like screen readers, can't interpret ARIA attributes with invalid names. <a rel=noopener target=_blank href="https://web.dev/aria-valid-attr/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=button-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Buttons have an accessible name</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When a button doesn't have an accessible name, screen readers announce it as "button", making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/button-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=bypass><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>The page contains a heading, skip link, or landmark region</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Adding ways to bypass repetitive content lets keyboard users navigate the page more efficiently. <a rel=noopener target=_blank href="https://web.dev/bypass/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=color-contrast><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Background and foreground colors have a sufficient contrast ratio</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Low-contrast text is difficult or impossible for many users to read. <a rel=noopener target=_blank href="https://web.dev/color-contrast/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=document-title><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document has a <code>&lt;title></code> element</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The title gives screen reader users an overview of the page, and search engine users rely on it heavily to determine if a page is relevant to their search. <a rel=noopener target=_blank href="https://web.dev/document-title/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=duplicate-id-active><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[id]</code> attributes on active, focusable elements are unique</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>All focusable elements must have a unique `id` to ensure that they're visible to assistive technologies. <a rel=noopener target=_blank href="https://web.dev/duplicate-id-active/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=heading-order><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Heading elements appear in a sequentially-descending order</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Properly ordered headings that do not skip levels convey the semantic structure of the page, making it easier to navigate and understand when using assistive technologies. <a rel=noopener target=_blank href="https://web.dev/heading-order/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=html-has-lang><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;html></code> element has a <code>[lang]</code> attribute</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>If a page doesn't specify a lang attribute, a screen reader assumes that the page is in the default language that the user chose when setting up the screen reader. If the page isn't actually in the default language, then the screen reader might not announce the page's text correctly. <a rel=noopener target=_blank href="https://web.dev/html-has-lang/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=html-lang-valid><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;html></code> element has a valid value for its <code>[lang]</code> attribute</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Specifying a valid <a rel=noopener target=_blank href=https://www.w3.org/International/questions/qa-choosing-language-tags#question>BCP 47 language</a> helps screen readers announce text properly. <a rel=noopener target=_blank href="https://web.dev/html-lang-valid/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=image-alt><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Image elements have <code>[alt]</code> attributes</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Informative elements should aim for short, descriptive alternate text. Decorative elements can be ignored with an empty alt attribute. <a rel=noopener target=_blank href="https://web.dev/image-alt/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=link-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Links have a discernible name</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Link text (and alternate text for images, when used as links) that is discernible, unique, and focusable improves the navigation experience for screen reader users. <a rel=noopener target=_blank href="https://web.dev/link-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=list><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Lists contain only <code>&lt;li></code> elements and script supporting elements (<code>&lt;script></code> and <code>&lt;template></code>).</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Screen readers have a specific way of announcing lists. Ensuring proper list structure aids screen reader output. <a rel=noopener target=_blank href="https://web.dev/list/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=listitem><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>List items (<code>&lt;li></code>) are contained within <code>&lt;ul></code> or <code>&lt;ol></code> parent elements</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Screen readers require list items (`&lt;li>`) to be contained within a parent `&lt;ul>` or `&lt;ol>` to be announced properly. <a rel=noopener target=_blank href="https://web.dev/listitem/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=meta-viewport><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[user-scalable="no"]</code> is not used in the <code>&lt;meta name="viewport"></code> element and the <code>[maximum-scale]</code> attribute is not less than 5.</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Disabling zooming is problematic for users with low vision who rely on screen magnification to properly see the contents of a web page. <a rel=noopener target=_blank href="https://web.dev/meta-viewport/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div></details><details class="lh-clump lh-audit-group lh-clump--notapplicable"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Not applicable</span>
<span class=lh-audit-group__itemcount>(26)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=accesskeys><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[accesskey]</code> values are unique</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Access keys let users quickly focus a part of the page. For proper navigation, each access key must be unique. <a rel=noopener target=_blank href="https://web.dev/accesskeys/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-command-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>button</code>, <code>link</code>, and <code>menuitem</code> elements have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an element doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-input-field-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA input fields have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an input field doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-meter-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA <code>meter</code> elements have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an element doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-progressbar-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA <code>progressbar</code> elements have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an element doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-required-attr><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[role]</code>s have all required <code>[aria-*]</code> attributes</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Some ARIA roles have required attributes that describe the state of the element to screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-required-attr/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-required-children><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Elements with an ARIA <code>[role]</code> that require children to contain a specific <code>[role]</code> have all required children.</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Some ARIA parent roles must contain specific child roles to perform their intended accessibility functions. <a rel=noopener target=_blank href="https://web.dev/aria-required-children/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-required-parent><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[role]</code>s are contained by their required parent element</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Some ARIA child roles must be contained by specific parent roles to properly perform their intended accessibility functions. <a rel=noopener target=_blank href="https://web.dev/aria-required-parent/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-roles><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[role]</code> values are valid</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>ARIA roles must have valid values in order to perform their intended accessibility functions. <a rel=noopener target=_blank href="https://web.dev/aria-roles/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-toggle-field-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA toggle fields have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When a toggle field doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-tooltip-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA <code>tooltip</code> elements have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an element doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=aria-treeitem-name><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA <code>treeitem</code> elements have accessible names</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an element doesn't have an accessible name, screen readers announce it with a generic name, making it unusable for users who rely on screen readers. <a rel=noopener target=_blank href="https://web.dev/aria-name/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=definition-list><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;dl></code>'s contain only properly-ordered <code>&lt;dt></code> and <code>&lt;dd></code> groups, <code>&lt;script></code>, <code>&lt;template></code> or <code>&lt;div></code> elements.</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When definition lists are not properly marked up, screen readers may produce confusing or inaccurate output. <a rel=noopener target=_blank href="https://web.dev/definition-list/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=dlitem><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Definition list items are wrapped in <code>&lt;dl></code> elements</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Definition list items (`&lt;dt>` and `&lt;dd>`) must be wrapped in a parent `&lt;dl>` element to ensure that screen readers can properly announce them. <a rel=noopener target=_blank href="https://web.dev/dlitem/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=duplicate-id-aria><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>ARIA IDs are unique</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The value of an ARIA ID must be unique to prevent other instances from being overlooked by assistive technologies. <a rel=noopener target=_blank href="https://web.dev/duplicate-id-aria/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=form-field-multiple-labels><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>No form fields have multiple labels</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Form fields with multiple labels can be confusingly announced by assistive technologies like screen readers which use either the first, the last, or all of the labels. <a rel=noopener target=_blank href="https://web.dev/form-field-multiple-labels/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=frame-title><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;frame></code> or <code>&lt;iframe></code> elements have a title</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Screen reader users rely on frame titles to describe the contents of frames. <a rel=noopener target=_blank href="https://web.dev/frame-title/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=input-image-alt><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;input type="image"></code> elements have <code>[alt]</code> text</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When an image is being used as an `&lt;input>` button, providing alternative text can help screen reader users understand the purpose of the button. <a rel=noopener target=_blank href="https://web.dev/input-image-alt/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=label><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Form elements have associated labels</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Labels ensure that form controls are announced properly by assistive technologies, like screen readers. <a rel=noopener target=_blank href="https://web.dev/label/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=meta-refresh><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>The document does not use <code>&lt;meta http-equiv="refresh"></code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Users do not expect a page to refresh automatically, and doing so will move focus back to the top of the page. This may create a frustrating or confusing experience. <a rel=noopener target=_blank href="https://web.dev/meta-refresh/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=object-alt><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;object></code> elements have <code>[alt]</code> text</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Screen readers cannot translate non-text content. Adding alt text to `&lt;object>` elements helps screen readers convey meaning to users. <a rel=noopener target=_blank href="https://web.dev/object-alt/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=tabindex><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>No element has a <code>[tabindex]</code> value greater than 0</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A value greater than 0 implies an explicit navigation ordering. Although technically valid, this often creates frustrating experiences for users who rely on assistive technologies. <a rel=noopener target=_blank href="https://web.dev/tabindex/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=td-headers-attr><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Cells in a <code>&lt;table></code> element that use the <code>[headers]</code> attribute refer to table cells within the same table.</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Screen readers have features to make navigating tables easier. Ensuring `&lt;td>` cells using the `[headers]` attribute only refer to other cells in the same table may improve the experience for screen reader users. <a rel=noopener target=_blank href="https://web.dev/td-headers-attr/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=th-has-data-cells><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;th></code> elements and elements with <code>[role="columnheader"/"rowheader"]</code> have data cells they describe.</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Screen readers have features to make navigating tables easier. Ensuring table headers always refer to some set of cells may improve the experience for screen reader users. <a rel=noopener target=_blank href="https://web.dev/th-has-data-cells/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=valid-lang><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>[lang]</code> attributes have a valid value</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Specifying a valid <a rel=noopener target=_blank href=https://www.w3.org/International/questions/qa-choosing-language-tags#question>BCP 47 language</a> on elements helps ensure that text is pronounced correctly by a screen reader. <a rel=noopener target=_blank href="https://web.dev/valid-lang/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=video-caption><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span><code>&lt;video></code> elements contain a <code>&lt;track></code> element with <code>[kind="captions"]</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>When a video provides a caption it is easier for deaf and hearing impaired users to access its information. <a rel=noopener target=_blank href="https://web.dev/video-caption/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div></details></div></div><div class=lh-category-wrapper><div class=lh-category><span class=lh-permalink id=best-practices></span><div class=lh-category-header><div class=lh-score__gauge role=heading aria-level=2><a href=#best-practices class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>Best Practices</div></a></div><div class=lh-category-header__description></div></div><div class=lh-clump--failed><div class="lh-audit-group lh-audit-group--best-practices-trust-safety"><div class=lh-audit-group__header><span class=lh-audit-group__title>Trust and Safety</span></div><div class="lh-audit lh-audit--informative" id=csp-xss><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Ensure CSP is effective against XSS attacks</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A strong Content Security Policy (CSP) significantly reduces the risk of cross-site scripting (XSS) attacks. <a rel=noopener target=_blank href="https://web.dev/strict-csp/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--text><div class=lh-text>Description</div></th><th class=lh-table-column--code><div class=lh-text>Directive</div></th><th class=lh-table-column--text><div class=lh-text>Severity</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>No CSP found in enforcement mode</div></td><td class=lh-table-column--empty></td><td class=lh-table-column--text><div class=lh-text>High</div></td></tr></tbody></table></details></div></div></div><details class="lh-clump lh-audit-group lh-clump--passed"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Passed audits</span>
<span class=lh-audit-group__itemcount>(17)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--binary lh-audit--pass" id=is-on-https><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Uses HTTPS</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>All sites should be protected with HTTPS, even ones that don't handle sensitive data. This includes avoiding <a rel=noopener target=_blank href="https://developers.google.com/web/fundamentals/security/prevent-mixed-content/what-is-mixed-content?utm_source=lighthouse&amp;utm_medium=cli">mixed content</a>, where some resources are loaded over HTTP despite the initial request being served over HTTPS. HTTPS prevents intruders from tampering with or passively listening in on the communications between your app and your users, and is a prerequisite for HTTP/2 and many new web platform APIs. <a rel=noopener target=_blank href="https://web.dev/is-on-https/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=external-anchors-use-rel-noopener><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Links to cross-origin destinations are safe</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Add `rel="noopener"` or `rel="noreferrer"` to any external links to improve performance and prevent security vulnerabilities. <a rel=noopener target=_blank href="https://web.dev/external-anchors-use-rel-noopener/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=geolocation-on-start><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids requesting the geolocation permission on page load</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Users are mistrustful of or confused by sites that request their location without context. Consider tying the request to a user action instead. <a rel=noopener target=_blank href="https://web.dev/geolocation-on-start/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=notification-on-start><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids requesting the notification permission on page load</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Users are mistrustful of or confused by sites that request to send notifications without context. Consider tying the request to user gestures instead. <a rel=noopener target=_blank href="https://web.dev/notification-on-start/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=no-vulnerable-libraries><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids front-end JavaScript libraries with known security vulnerabilities</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Some third-party scripts may contain known security vulnerabilities that are easily identified and exploited by attackers. <a rel=noopener target=_blank href="https://web.dev/no-vulnerable-libraries/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=password-inputs-can-be-pasted-into><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Allows users to paste into password fields</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Preventing password pasting undermines good security policy. <a rel=noopener target=_blank href="https://web.dev/password-inputs-can-be-pasted-into/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=image-aspect-ratio><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Displays images with correct aspect ratio</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Image display dimensions should match natural aspect ratio. <a rel=noopener target=_blank href="https://web.dev/image-aspect-ratio/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=image-size-responsive><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Serves images with appropriate resolution</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Image natural dimensions should be proportional to the display size and the pixel ratio to maximize image clarity. <a rel=noopener target=_blank href="https://web.dev/serve-responsive-images/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=doctype><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Page has the HTML doctype</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Specifying a doctype prevents the browser from switching to quirks-mode. <a rel=noopener target=_blank href="https://web.dev/doctype/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=charset><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Properly defines charset</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A character encoding declaration is required. It can be done with a `&lt;meta>` tag in the first 1024 bytes of the HTML or in the Content-Type HTTP response header. <a rel=noopener target=_blank href="https://web.dev/charset/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=no-unload-listeners><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids <code>unload</code> event listeners</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The `unload` event does not fire reliably and listening for it can prevent browser optimizations like the Back-Forward Cache. Consider using the `pagehide` or `visibilitychange` events instead. <a rel=noopener target=_blank href="https://developers.google.com/web/updates/2018/07/page-lifecycle-api?utm_source=lighthouse&amp;utm_medium=cli#the-unload-event">Learn more</a></span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=appcache-manifest><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids Application Cache</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Application Cache is deprecated. <a rel=noopener target=_blank href="https://web.dev/appcache-manifest/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=js-libraries><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Detected JavaScript libraries</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>All front-end JavaScript libraries detected on the page. <a rel=noopener target=_blank href="https://web.dev/js-libraries/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--text><div class=lh-text>Name</div></th><th class=lh-table-column--text><div class=lh-text>Version</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--text><div class=lh-text>FuseJS</div></td><td class=lh-table-column--empty></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=deprecations><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Avoids deprecated APIs</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Deprecated APIs will eventually be removed from the browser. <a rel=noopener target=_blank href="https://web.dev/deprecations/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=errors-in-console><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>No browser errors logged to the console</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Errors logged to the console indicate unresolved problems. They can come from network request failures and other browser concerns. <a rel=noopener target=_blank href="https://web.dev/errors-in-console/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=valid-source-maps><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Page has valid source maps</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Source maps translate minified code to the original source code. This helps developers debug in production. In addition, Lighthouse is able to provide further insights. Consider deploying source maps to take advantage of these benefits. <a rel=noopener target=_blank href="https://developers.google.com/web/tools/chrome-devtools/javascript/source-maps?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=inspector-issues><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>No issues in the <code>Issues</code> panel in Chrome Devtools</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Issues logged to the `Issues` panel in Chrome Devtools indicate unresolved problems. They can come from network request failures, insufficient security controls, and other browser concerns. Open up the Issues panel in Chrome DevTools for more details on each issue.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div></details><details class="lh-clump lh-audit-group lh-clump--notapplicable"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Not applicable</span>
<span class=lh-audit-group__itemcount>(1)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=preload-fonts><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Fonts with <code>font-display: optional</code> are preloaded</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Preload `optional` fonts so first-time visitors may use them. <a rel=noopener target=_blank href="https://web.dev/preload-optional-fonts/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a></span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div></details></div></div><div class=lh-category-wrapper><div class=lh-category><span class=lh-permalink id=seo></span><div class=lh-category-header><div class=lh-score__gauge role=heading aria-level=2><a href=#seo class="lh-gauge__wrapper lh-gauge__wrapper--pass"><div class=lh-gauge__svg-wrapper><svg viewBox="0 0 120 120" class="lh-gauge"><circle class="lh-gauge-base" r="56" cx="60" cy="60" stroke-width="8"/><circle class="lh-gauge-arc" r="56" cx="60" cy="60" stroke-width="8" style="transform:rotate(-87.95372216024705deg);stroke-dasharray:351.85837720205683px,351.85837720205683px"/></svg></div><div class=lh-gauge__percentage>100</div><div class=lh-gauge__label>SEO</div></a></div><div class=lh-category-header__description><span>These checks ensure that your page is optimized for search engine results ranking. There are additional factors Lighthouse does not check that may affect your search ranking. <a rel=noopener target=_blank href=https://support.google.com/webmasters/answer/35769>Learn more</a>.</span></div></div><details class="lh-clump lh-audit-group lh-clump--manual"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Additional items to manually check</span>
<span class=lh-audit-group__itemcount>(1)</span>
<span class=lh-audit-group__description>Run these additional validators on your site to check additional SEO best practices.</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--manual lh-audit--pass" id=structured-data><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Structured data is valid</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Run the <a rel=noopener target=_blank href=https://search.google.com/structured-data/testing-tool/>Structured Data Testing Tool</a> and the <a rel=noopener target=_blank href=http://linter.structured-data.org/>Structured Data Linter</a> to validate structured data. <a rel=noopener target=_blank href="https://web.dev/structured-data/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div></details><details class="lh-clump lh-audit-group lh-clump--passed"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Passed audits</span>
<span class=lh-audit-group__itemcount>(13)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--binary lh-audit--pass" id=viewport><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Has a <code>&lt;meta name="viewport"></code> tag with <code>width</code> or <code>initial-scale</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Add a `&lt;meta name="viewport">` tag to optimize your app for mobile screens. <a rel=noopener target=_blank href="https://web.dev/viewport/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=document-title><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document has a <code>&lt;title></code> element</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The title gives screen reader users an overview of the page, and search engine users rely on it heavily to determine if a page is relevant to their search. <a rel=noopener target=_blank href="https://web.dev/document-title/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=meta-description><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document has a meta description</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Meta descriptions may be included in search results to concisely summarize page content. <a rel=noopener target=_blank href="https://web.dev/meta-description/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=http-status-code><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Page has successful HTTP status code</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Pages with unsuccessful HTTP status codes may not be indexed properly. <a rel=noopener target=_blank href="https://web.dev/http-status-code/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=link-text><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Links have descriptive text</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Descriptive link text helps search engines understand your content. <a rel=noopener target=_blank href="https://web.dev/link-text/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=crawlable-anchors><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Links are crawlable</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Search engines may use `href` attributes on links to crawl websites. Ensure that the `href` attribute of anchor elements links to an appropriate destination, so more pages of the site can be discovered. <a rel=noopener target=_blank href=https://support.google.com/webmasters/answer/9112205>Learn More</a></span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=is-crawlable><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Page isnt blocked from indexing</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Search engines are unable to include your pages in search results if they don't have permission to crawl them. <a rel=noopener target=_blank href="https://web.dev/is-crawable/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=image-alt><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Image elements have <code>[alt]</code> attributes</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Informative elements should aim for short, descriptive alternate text. Decorative elements can be ignored with an empty alt attribute. <a rel=noopener target=_blank href="https://web.dev/image-alt/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=hreflang><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document has a valid <code>hreflang</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>hreflang links tell search engines what version of a page they should list in search results for a given language or region. <a rel=noopener target=_blank href="https://web.dev/hreflang/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=canonical><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document has a valid <code>rel=canonical</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Canonical links suggest which URL to show in search results. <a rel=noopener target=_blank href="https://web.dev/canonical/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=font-size><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document uses legible font sizes</span></span>
<span class=lh-audit__display-text>99.75% legible text</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Font sizes less than 12px are too small to be legible and require mobile visitors to “pinch to zoom” in order to read. Strive to have >60% of page text ≥12px. <a rel=noopener target=_blank href="https://web.dev/font-size/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><div class=lh-3p-filter><label class=lh-3p-filter-label for=lh-3p-filter-label--8><input type=checkbox class=lh-3p-filter-input checked id=lh-3p-filter-label--8 disabled>
<span class=lh-3p-ui-string>Show 3rd-party resources</span> (<span class=lh-3p-filter-count>0</span>)</label></div><table class="lh-table lh-details"><thead><tr><th class=lh-table-column--source-location><div class=lh-text>Source</div></th><th class=lh-table-column--code><div class=lh-text>Selector</div></th><th class=lh-table-column--text><div class=lh-text>% of Page Text</div></th><th class=lh-table-column--text><div class=lh-text>Font Size</div></th></tr></thead><tbody><tr class=lh-row--even><td class=lh-table-column--source-location><div class="lh-text__url lh-source-location" title=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-url=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-source-url=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css data-source-line=0 data-source-column=28538><a rel=noopener target=_blank href=http://localhost:8008/congo/css/main.bundle.min.6783e342ffedbcc698d9afb9ffe11276f4f9de79bfc45cf670b35d5f9948d266086106596bc9e59820d7de0959e5889ce97e073fbafd380be9dc7b33b75295f2.css class=lh-link>…css/main.bundle.min.6783e34….css:1:28538</a><div class="lh-text lh-text__url-host">(localhost)</div></div></td><td class=lh-table-column--code><pre class=lh-code>.text-\[0\.6rem\]</pre></td><td class=lh-table-column--text><div class=lh-text>0.25%</div></td><td class=lh-table-column--text><div class=lh-text>9.6px</div></td></tr><tr class=lh-row--odd><td class=lh-table-column--source-location><pre class=lh-code>Legible text</pre></td><td class=lh-table-column--code><pre class=lh-code></pre></td><td class=lh-table-column--text><div class=lh-text>99.75%</div></td><td class=lh-table-column--text><div class=lh-text>≥ 12px</div></td></tr></tbody></table></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=plugins><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Document avoids plugins</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Search engines can't index plugin content, and many devices restrict plugins or don't support them. <a rel=noopener target=_blank href="https://web.dev/plugins/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=tap-targets><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Tap targets are sized appropriately</span></span>
<span class=lh-audit__display-text>100% appropriately sized tap targets</span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Interactive elements like buttons and links should be large enough (48x48px), and have enough space around them, to be easy enough to tap without overlapping onto other elements. <a rel=noopener target=_blank href="https://web.dev/tap-targets/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div></details><details class="lh-clump lh-audit-group lh-clump--notapplicable"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Not applicable</span>
<span class=lh-audit-group__itemcount>(1)</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=robots-txt><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>robots.txt is valid</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>If your robots.txt file is malformed, crawlers may not be able to understand how you want your website to be crawled or indexed. <a rel=noopener target=_blank href="https://web.dev/robots-txt/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div></details></div></div><div class=lh-category-wrapper><div class=lh-category><span class=lh-permalink id=pwa></span><div class=lh-category-header><div class=lh-score__gauge role=heading aria-level=2><a href=#pwa class="lh-gauge__wrapper lh-gauge--pwa__wrapper lh-badged--pwa-installable" title="Installable: 1/1, PWA Optimized: 6/8"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 60 60" class="lh-gauge lh-gauge--pwa"><defs><linearGradient id="lh-gauge--pwa__check-circle__gradient-2" x1="50%" y1="0" x2="50%" y2="100%"><stop stop-color="#00c852" offset="0"/><stop stop-color="#009688" offset="100%"/></linearGradient><linearGradient id="lh-gauge--pwa__installable__shadow-gradient-2" x1="76.056%" x2="24.111%" y1="82.995%" y2="24.735%"><stop stop-color="#a5d6a7" offset="0"/><stop stop-color="#80cbc4" offset="100%"/></linearGradient><g id="lh-gauge--pwa__installable-badge-2"><circle fill="#fff" cx="10" cy="10" r="10"/><path fill="#009688" d="M10 4.167A5.835 5.835.0 004.167 10 5.835 5.835.0 0010 15.833 5.835 5.835.0 0015.833 10 5.835 5.835.0 0010 4.167zm2.917 6.416h-2.334v2.334H9.417v-2.334H7.083V9.417h2.334V7.083h1.166v2.334h2.334v1.166z"/></g></defs><g stroke="none" fill-rule="nonzero"><circle class="lh-gauge--pwa__disc" cx="30" cy="30" r="30"/><g class="lh-gauge--pwa__logo"><path class="lh-gauge--pwa__logo--secondary-color" d="M35.66 19.39l.7-1.75h2L37.4 15l1.2-3 3.4 9h-2.51l-.58-1.61z"/><path class="lh-gauge--pwa__logo--primary-color" d="M33.52 21l3.65-9h-2.42l-2.5 5.82L30.5 12h-1.86l-1.9 5.82-1.35-2.65-1.21 3.72L25.4 21h2.38l1.72-5.2 1.64 5.2z"/><path class="lh-gauge--pwa__logo--secondary-color" fill-rule="nonzero" d="M20.3 17.91h1.48c.45.0.85-.05 1.2-.15l.39-1.18 1.07-3.3a2.64 2.64.0 00-.28-.37c-.55-.6-1.36-.91-2.42-.91H18v9h2.3V17.9zm1.96-3.84c.22.22.33.5.33.87.0.36-.1.65-.29.87-.2.23-.59.35-1.15.35h-.86v-2.41h.87c.52.0.89.1 1.1.32z"/></g><rect class="lh-gauge--pwa__component lh-gauge--pwa__na-line" fill="#fff" x="20" y="32" width="20" height="4" rx="2"/><g class="lh-gauge--pwa__component lh-gauge--pwa__installable-badge" transform="translate(20, 29)"><path fill="url(#lh-gauge--pwa__installable__shadow-gradient-2)" d="M33.629 19.487c-4.272 5.453-10.391 9.39-17.415 10.869L3 17.142 17.142 3 33.63 19.487z"/><use href="#lh-gauge--pwa__installable-badge-2"/></g><g class="lh-gauge--pwa__component lh-gauge--pwa__check-circle" transform="translate(18, 28)"><circle fill="#fff" cx="12" cy="12" r="12"/><path fill="url(#lh-gauge--pwa__check-circle__gradient-2)" d="M12 2a10 10 0 100 20 10 10 0 000-20zm-2 15-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"/></g></g></svg><div class=lh-gauge__label>Progressive Web App</div></a></div><div class=lh-category-header__description><span>These checks validate the aspects of a Progressive Web App. <a rel=noopener target=_blank href="https://developers.google.com/web/progressive-web-apps/checklist?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div></div><div><div class="lh-audit-group lh-audit-group--pwa-installable lh-badged"><div class=lh-audit-group__header><span class=lh-audit-group__title>Installable</span></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=installable-manifest><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Web app manifest and service worker meet the installability requirements</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Service worker is the technology that enables your app to use many Progressive Web App features, such as offline, add to homescreen, and push notifications. With proper service worker and manifest implementations, browsers can proactively prompt users to add your app to their homescreen, which can lead to higher engagement. <a rel=noopener target=_blank href="https://web.dev/installable-manifest/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div><span class=lh-details></span></details></div></div><div class="lh-audit-group lh-audit-group--pwa-optimized"><div class=lh-audit-group__header><span class=lh-audit-group__title>PWA Optimized</span></div><div class="lh-audit lh-audit--binary lh-audit--fail" id=service-worker><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Does not register a service worker that controls page and <code>start_url</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The service worker is the technology that enables your app to use many Progressive Web App features, such as offline, add to homescreen, and push notifications. <a rel=noopener target=_blank href="https://web.dev/service-worker/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--notapplicable lh-audit--pass" id=redirects-http><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Redirects HTTP traffic to HTTPS</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>If you've already set up HTTPS, make sure that you redirect all HTTP traffic to HTTPS in order to enable secure web features for all your users. <a rel=noopener target=_blank href="https://web.dev/redirects-http/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=splash-screen><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Configured for a custom splash screen</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A themed splash screen ensures a high-quality experience when users launch your app from their homescreens. <a rel=noopener target=_blank href="https://web.dev/splash-screen/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--fail" id=themed-omnibox><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Does not set a theme color for the address bar.</span><div class=lh-audit-explanation>Failures: No `&lt;meta name="theme-color">` tag found.</div></span><span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>The browser address bar can be themed to match your site. <a rel=noopener target=_blank href="https://web.dev/themed-omnibox/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=content-width><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Content is sized correctly for the viewport</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>If the width of your app's content doesn't match the width of the viewport, your app might not be optimized for mobile screens. <a rel=noopener target=_blank href="https://web.dev/content-width/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=viewport><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Has a <code>&lt;meta name="viewport"></code> tag with <code>width</code> or <code>initial-scale</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Add a `&lt;meta name="viewport">` tag to optimize your app for mobile screens. <a rel=noopener target=_blank href="https://web.dev/viewport/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=apple-touch-icon><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Provides a valid <code>apple-touch-icon</code></span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>For ideal appearance on iOS when users add a progressive web app to the home screen, define an `apple-touch-icon`. It must point to a non-transparent 192px (or 180px) square PNG. <a rel=noopener target=_blank href="https://web.dev/apple-touch-icon/?utm_source=lighthouse&amp;utm_medium=cli">Learn More</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--binary lh-audit--pass" id=maskable-icon><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Manifest has a maskable icon</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>A maskable icon ensures that the image fills the entire shape without being letterboxed when installing the app on a device. <a rel=noopener target=_blank href="https://web.dev/maskable-icon-audit/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div></div></div><details class="lh-clump lh-audit-group lh-clump--manual"><summary><div class=lh-audit-group__summary><div class=lh-audit-group__header><span class=lh-audit-group__title>Additional items to manually check</span>
<span class=lh-audit-group__itemcount>(3)</span>
<span class=lh-audit-group__description>These checks are required by the baseline <a rel=noopener target=_blank href="https://developers.google.com/web/progressive-web-apps/checklist?utm_source=lighthouse&amp;utm_medium=cli">PWA Checklist</a> but are not automatically checked by Lighthouse. They do not affect your score but it's important that you verify them manually.</span></div><div></div><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></summary><div class="lh-audit lh-audit--manual lh-audit--pass" id=pwa-cross-browser><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Site works cross-browser</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>To reach the most number of users, sites should work across every major browser. <a rel=noopener target=_blank href="https://web.dev/pwa-cross-browser/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=pwa-page-transitions><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Page transitions don't feel like they block on the network</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Transitions should feel snappy as you tap around, even on a slow network. This experience is key to a user's perception of performance. <a rel=noopener target=_blank href="https://web.dev/pwa-page-transitions/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div><div class="lh-audit lh-audit--manual lh-audit--pass" id=pwa-each-page-has-url><details class=lh-expandable-details><summary><div class="lh-audit__header lh-expandable-details__summary"><span class=lh-audit__score-icon></span>
<span class=lh-audit__title-and-text><span class=lh-audit__title><span>Each page has a URL</span></span>
<span class=lh-audit__display-text></span></span><div class=lh-chevron-container><svg class="lh-chevron" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><g class="lh-chevron__lines"><path class="lh-chevron__line lh-chevron__line-left" d="M10 50h40"/><path class="lh-chevron__line lh-chevron__line-right" d="M90 50H50"/></g></svg></div></div></summary><div class=lh-audit__description><span>Ensure individual pages are deep linkable via URL and that URLs are unique for the purpose of shareability on social media. <a rel=noopener target=_blank href="https://web.dev/pwa-each-page-has-url/?utm_source=lighthouse&amp;utm_medium=cli">Learn more</a>.</span></div><div class=lh-audit__stackpacks></div></details></div></details></div></div></div><style>.lh-footer{padding:var(--footer-padding-vertical)calc(var(--default-padding) * 2);max-width:var(--report-width);margin:0 auto}.lh-footer .lh-generated{text-align:center}.lh-env__title{font-size:var(--env-item-font-size-big);line-height:var(--env-item-line-height-big);text-align:center;padding:var(--score-container-padding)}.lh-env{padding:var(--default-padding)0}.lh-env__items{padding-left:16px;margin:0 0 var(--audits-margin-bottom);padding:0}.lh-env__items .lh-env__item:nth-child(2n){background-color:var(--env-item-background-color)}.lh-env__item{display:flex;padding:var(--env-item-padding);position:relative}span.lh-env__name{font-weight:700;min-width:var(--env-name-min-width);flex:.5;padding:0 8px}span.lh-env__description{text-align:left;flex:1}</style><footer class=lh-footer><div class=lh-env><div class=lh-env__title>Runtime Settings</div><ul class=lh-env__items id=runtime-settings><template id=tmpl-lh-env__items><li class=lh-env__item><span class=lh-env__name></span>
<span class=lh-env__description></span></li></template><li class=lh-env__item><span class=lh-env__name>URL</span>
<span class=lh-env__description>http://localhost:8008/congo/samples/emoji/</span></li><li class=lh-env__item><span class=lh-env__name>Fetch Time</span>
<span class=lh-env__description>Jan 19, 2022, 7:17 PM GMT+11</span></li><li class=lh-env__item><span class=lh-env__name>Device</span>
<span class=lh-env__description>Emulated Moto G4</span></li><li class=lh-env__item><span class=lh-env__name>Network throttling</span>
<span class=lh-env__description>150&nbsp;ms TCP RTT, 1,638.4&nbsp;Kbps throughput (Simulated)</span></li><li class=lh-env__item><span class=lh-env__name>CPU throttling</span>
<span class=lh-env__description>4x slowdown (Simulated)</span></li><li class=lh-env__item><span class=lh-env__name>Channel</span>
<span class=lh-env__description>cli</span></li><li class=lh-env__item><span class=lh-env__name>User agent (host)</span>
<span class=lh-env__description>Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) HeadlessChrome/96.0.4664.110 Safari/537.36</span></li><li class=lh-env__item><span class=lh-env__name>User agent (network)</span>
<span class=lh-env__description>Mozilla/5.0 (Linux; Android 7.0; Moto G (4)) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4420.0 Mobile Safari/537.36 Chrome-Lighthouse</span></li><li class=lh-env__item><span class=lh-env__name>CPU/Memory Power</span>
<span class=lh-env__description>1949</span></li><li class=lh-env__item><span class=lh-env__name>Axe version</span>
<span class=lh-env__description>4.2.1</span></li></ul></div><div class=lh-generated>Generated by <b>Lighthouse</b> <span class=lh-footer__version>8.0.0</span> |
<a href=https://github.com/GoogleChrome/Lighthouse/issues target=_blank rel=noopener class=lh-footer__version_issue>File an issue</a></div></footer></div></div></main><div id=lh-log></div><script>"use strict";const ELLIPSIS="",NBSP="\xa0",PASS_THRESHOLD=.9,SCREENSHOT_PREFIX="data:image/jpeg;base64,",RATINGS={PASS:{label:"pass",minScore:PASS_THRESHOLD},AVERAGE:{label:"average",minScore:.5},FAIL:{label:"fail"},ERROR:{label:"error"}},listOfTlds=["com","co","gov","edu","ac","org","go","gob","or","net","in","ne","nic","gouv","web","spb","blog","jus","kiev","mil","wi","qc","ca","bel","on"];class Util{static get PASS_THRESHOLD(){return PASS_THRESHOLD}static get MS_DISPLAY_VALUE(){return`%10d${NBSP}ms`}static prepareReportResult(e){const t=JSON.parse(JSON.stringify(e));t.configSettings.locale||(t.configSettings.locale="en"),t.configSettings.formFactor||(t.configSettings.formFactor=t.configSettings.emulatedFormFactor);for(const e of Object.values(t.audits))if((e.scoreDisplayMode==="not_applicable"||e.scoreDisplayMode==="not-applicable")&&(e.scoreDisplayMode="notApplicable"),e.details&&((e.details.type===void 0||e.details.type==="diagnostic")&&(e.details.type="debugdata"),e.details.type==="filmstrip"))for(const t of e.details.items)t.data.startsWith(SCREENSHOT_PREFIX)||(t.data=SCREENSHOT_PREFIX+t.data);if(typeof t.categories!="object")throw new Error("No categories provided.");const n=new Map;for(const e of Object.values(t.categories))e.auditRefs.forEach(e=>{if(!e.relevantAudits)return;e.relevantAudits.forEach(t=>{const s=n.get(t)||[];s.push(e),n.set(t,s)})}),e.auditRefs.forEach(e=>{const s=t.audits[e.id];e.result=s,n.has(e.id)&&(e.relevantMetrics=n.get(e.id)),t.stackPacks&&t.stackPacks.forEach(t=>{t.descriptions[e.id]&&(e.stackPacks=e.stackPacks||[],e.stackPacks.push({title:t.title,iconDataURL:t.iconDataURL,description:t.descriptions[e.id]}))})});return t}static showAsPassed(e){switch(e.scoreDisplayMode){case"manual":case"notApplicable":return!0;case"error":case"informative":return!1;case"numeric":case"binary":default:return Number(e.score)>=RATINGS.PASS.minScore}}static calculateRating(e,t){if(t==="manual"||t==="notApplicable")return RATINGS.PASS.label;if(t==="error")return RATINGS.ERROR.label;if(e===null)return RATINGS.FAIL.label;let n=RATINGS.FAIL.label;return e>=RATINGS.PASS.minScore?n=RATINGS.PASS.label:e>=RATINGS.AVERAGE.minScore&&(n=RATINGS.AVERAGE.label),n}static splitMarkdownCodeSpans(e){const t=[],n=e.split(/`(.*?)`/g);for(let e=0;e<n.length;e++){const s=n[e];if(!s)continue;const o=e%2!==0;t.push({isCode:o,text:s})}return t}static splitMarkdownLink(e){const t=[],n=e.split(/\[([^\]]+?)\]\((https?:\/\/.*?)\)/g);for(;n.length;){const[e,s,o]=n.splice(0,3);e&&t.push({isLink:!1,text:e}),s&&o&&t.push({isLink:!0,text:s,linkHref:o})}return t}static getURLDisplayName(e,t){t=t||{numPathParts:void 0,preserveQuery:void 0,preserveHost:void 0};const o=t.numPathParts!==void 0?t.numPathParts:2,i=t.preserveQuery===void 0||t.preserveQuery,a=t.preserveHost||!1;let n;if(e.protocol==="about:"||e.protocol==="data:")n=e.href;else{n=e.pathname;const t=n.split("/").filter(e=>e.length);o&&t.length>o&&(n=ELLIPSIS+t.slice(-1*o).join("/")),a&&(n=`${e.host}/${n.replace(/^\//,"")}`),i&&(n=`${n}${e.search}`)}const s=64;if(n=n.replace(/([a-f0-9]{7})[a-f0-9]{13}[a-f0-9]*/g,`$1${ELLIPSIS}`),n=n.replace(/([a-zA-Z0-9-_]{9})(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9])[a-zA-Z0-9-_]{10,}/g,`$1${ELLIPSIS}`),n=n.replace(/(\d{3})\d{6,}/g,`$1${ELLIPSIS}`),n=n.replace(/\u2026+/g,ELLIPSIS),n.length>s&&n.includes("?")&&(n=n.replace(/\?([^=]*)(=)?.*/,`?$1$2${ELLIPSIS}`),n.length>s&&(n=n.replace(/\?.*/,`?${ELLIPSIS}`))),n.length>s){const e=n.lastIndexOf(".");e>=0?n=n.slice(0,s-1-(n.length-e))+`${ELLIPSIS}${n.slice(e)}`:n=n.slice(0,s-1)+ELLIPSIS}return n}static parseURL(e){const t=new URL(e);return{file:Util.getURLDisplayName(t),hostname:t.hostname,origin:t.origin}}static createOrReturnURL(e){return e instanceof URL?e:new URL(e)}static getTld(e){const t=e.split(".").slice(-2);return listOfTlds.includes(t[0])?`.${t.join(".")}`:`.${t[t.length-1]}`}static getRootDomain(e){const t
Diagrams and Flowcharts
6 March 2019`},subItems:{type:"subitems",items:[{failureReason:"Unsupported CSS Property: color",animation:"color"}]}},{node:{type:"node",lhId:"page-17-BUTTON",path:"1,HTML,1,BODY,3,DIV,0,DIV,0,HEADER,1,BUTTON",selector:"div#search-wrapper > div#search-modal > header.relative > button#close-search-button",boundingRect:{top:25,bottom:57,left:303,right:335,width:32,height:32},snippet:'<button id="close-search-button" class="flex items-center justify-center w-8 h-8 text-neutral-700 dark:text-neutra…">',nodeLabel:"button"},subItems:{type:"subitems",items:[{failureReason:"Unsupported CSS Property: color",animation:"color"}]}},{node:{type:"node",lhId:"page-18-A",path:"1,HTML,1,BODY,4,FOOTER,0,DIV,0,DIV,1,P,1,A",selector:"div.flex > div > p.text-xs > a.hover:underline",boundingRect:{top:1171,bottom:1186,left:93,right:124,width:30,height:15},snippet:'<a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href="https://gohugo.io/" target="_blank" rel="noopener noreferrer">',nodeLabel:"Hugo"},subItems:{type:"subitems",items:[{failureReason:"Unsupported CSS Property: color",animation:"color"}]}},{node:{type:"node",lhId:"page-19-A",path:"1,HTML,1,BODY,4,FOOTER,0,DIV,0,DIV,1,P,3,A",selector:"div.flex > div > p.text-xs > a.hover:underline",boundingRect:{top:1171,bottom:1186,left:139,right:176,width:37,height:15},snippet:'<a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href="https://git.io/hugo-congo" target="_blank" rel="noopener noreferrer">',nodeLabel:"Congo"},subItems:{type:"subitems",items:[{failureReason:"Unsupported CSS Property: color",animation:"color"}]}}]}},"unsized-images":{id:"unsized-images",title:"Image elements have explicit `width` and `height`",description:"Set an explicit width and height on image elements to reduce layout shifts and improve CLS. [Learn more](https://web.dev/optimize-cls/#images-without-dimensions)",score:1,scoreDisplayMode:"binary",details:{type:"table",headings:[],items:[]}},"valid-source-maps":{id:"valid-source-maps",title:"Page has valid source maps",description:"Source maps translate minified code to the original source code. This helps developers debug in production. In addition, Lighthouse is able to provide further insights. Consider deploying source maps to take advantage of these benefits. [Learn more](https://developers.google.com/web/tools/chrome-devtools/javascript/source-maps).",score:1,scoreDisplayMode:"binary",details:{type:"table",headings:[],items:[]}},"preload-lcp-image":{id:"preload-lcp-image",title:"Preload Largest Contentful Paint image",description:"Preload the image used by the LCP element in order to improve your LCP time. [Learn more](https://web.dev/optimize-lcp/#preload-important-resources).",score:1,scoreDisplayMode:"numeric",numericValue:0,numericUnit:"millisecond",displayValue:"",details:{type:"opportunity",headings:[],items:[],overallSavingsMs:0}},"csp-xss":{id:"csp-xss",title:"Ensure CSP is effective against XSS attacks",description:"A strong Content Security Policy (CSP) significantly reduces the risk of cross-site scripting (XSS) attacks. [Learn more](https://web.dev/strict-csp/)",score:null,scoreDisplayMode:"informative",details:{type:"table",headings:[{key:"description",itemType:"text",subItemsHeading:{key:"description"},text:"Description"},{key:"directive",itemType:"code",subItemsHeading:{key:"directive"},text:"Directive"},{key:"severity",itemType:"text",subItemsHeading:{key:"severity"},text:"Severity"}],items:[{severity:"High",description:"No CSP found in enforcement mode"}]}},"script-treemap-data":{id:"script-treemap-data",title:"Script Treemap Data",description:"Used for treemap app",score:null,scoreDisplayMode:"informative",details:{type:"treemap-data",nodes:[{name:"http://localhost:8008/congo/samples/emoji/",resourceBytes:591},{name:"http://localhost:8008/congo/js/main.bundle.min.81d5d44787f3f7c0220442722b6d0c72da50dab39103321d578502e81b226ed5a87e765e5e2a7c0533fdddeb4697bd499a39be89310453fba5c129f5ba69bdea.js",resourceBytes:27661,unusedBytes:21746}]}},"pwa-cross-browser":{id:"pwa-cross-browser",title:
<span class="flex flex-col"><span class="mt-[0.1rem] leading-6 group-hover:underline group-hover:decoration-primary-500">Upgrading from Congo 1.x</span>
<span class="mt-[0.1rem] text-xs text-neutral-500 dark:text-neutral-400"></span></span></a></span><span></span></div></div></footer></article><div class="pointer-events-none absolute bottom-0 end-0 top-[100vh] w-12"><a href=#the-top class="pointer-events-auto sticky top-[calc(100vh-5.5rem)] flex h-12 w-12 items-center justify-center rounded-full bg-neutral/50 text-xl text-neutral-700 backdrop-blur hover:text-primary-600 dark:bg-neutral-800/50 dark:text-neutral dark:hover:text-primary-400" aria-label="Scroll to top" title="Scroll to top">&uarr;</a></div></main><footer class="py-10 print:hidden"><div class="flex items-center justify-between"><div><p class="text-sm text-neutral-500 dark:text-neutral-400">© 2023 Congo contributors</p><p class="text-xs text-neutral-500 dark:text-neutral-400">Powered by <a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href=https://gohugo.io/ target=_blank rel="noopener noreferrer">Hugo</a> & <a class="hover:underline hover:decoration-primary-400 hover:text-primary-500" href=https://github.com/jpanther/congo target=_blank rel="noopener noreferrer">Congo</a></p></div><div class="flex flex-row items-center"><div class="me-14 cursor-pointer text-sm text-neutral-700 hover:text-primary-600 dark:text-neutral dark:hover:text-primary-400"><button id=appearance-switcher-0 type=button aria-label="appearance switcher"><div class="flex h-12 w-12 items-center justify-center dark:hidden" title="Switch to dark appearance"><span class="icon relative inline-block px-1 align-text-bottom"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentcolor" d="M32 256C32 132.2 132.3 32 255.8 32c11.36.0 29.7 1.668 40.9 3.746 9.616 1.777 11.75 14.63 3.279 19.44C245 86.5 211.2 144.6 211.2 207.8c0 109.7 99.71 193 208.3 172.3 9.561-1.805 16.28 9.324 10.11 16.95C387.9 448.6 324.8 480 255.8 480 132.1 480 32 379.6 32 256z"/></svg></span></div><div class="hidden h-12 w-12 items-center justify-center dark:flex" title="Switch to light appearance"><span class="icon relative inline-block px-1 align-text-bottom"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentcolor" d="M256 159.1c-53.02.0-95.1 42.98-95.1 95.1s41.2 96.9 95.1 96.9 95.1-42.98 95.1-95.1S309 159.1 256 159.1zM509.3 347l-63.2-91.9 63.15-91.01c6.332-9.125 1.104-21.74-9.826-23.72l-109-19.7-19.7-109c-1.975-10.93-14.59-16.16-23.72-9.824L256 65.89 164.1 2.736c-9.125-6.332-21.74-1.107-23.72 9.824L121.6 121.6 12.56 141.3C1.633 143.2-3.596 155.9 2.736 164.1L65.89 256 2.74 347.01c-6.332 9.125-1.105 21.74 9.824 23.72l109 19.7 19.7 109c1.975 10.93 14.59 16.16 23.72 9.824L256 446.1l91.01 63.15c9.127 6.334 21.75 1.107 23.72-9.822l19.7-109 109-19.7C510.4 368.8 515.6 356.1 509.3 347zM256 383.1c-70.69.0-127.1-57.31-127.1-127.1.0-70.69 57.31-127.1 127.1-127.1S383.1 186.2 383.1 256c0 70.7-56.4 127.1-127.1 127.1z"/></svg></span></div></button></div></div></div></footer><div id=search-wrapper class="invisible fixed inset-0 z-50 flex h-screen w-screen cursor-default flex-col bg-neutral-500/50 p-4 backdrop-blur-sm sm:p-6 md:p-[10vh] lg:p-[12vh] dark:bg-neutral-900/50" data-url=https://jpanther.github.io/congo/><div id=search-modal class="top-20 mx-auto flex min-h-0 w-full max-w-3xl flex-col rounded-md border border-neutral-200 bg-neutral shadow-lg dark:border-neutral-700 dark:bg-neutral-800"><header class="relative z-10 flex flex-none items-center justify-between px-2"><form class="flex min-w-0 flex-auto items-center"><div class="flex h-8 w-8 items-center justify-center text-neutral-400"><span class="icon relative inline-block px-1 align-text-bottom"><svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="search" class="svg-inline--fa fa-search fa-w-16" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentcolor" d="M505 442.7 405.3 343c-4.5-4.5-10.6-7-17-7H372c27.6-35.3 44-79.7 44-128C416 93.1 322.9.0 208 0S0 93.1.0 208s93.1 208 208 208c48.3.0 92.7-16.4 128-44v16.3c0 6.4 2.5 12.5 7 17l99.7 99.7c9.4 9.4 24.6 9.4 33.9.0l28.3-28.3c9.4-9.4 9.4-24.6.1-34zM208 336c
<span class="icon relative inline-block px-1 align-text-bottom"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512"><path fill="currentcolor" d="M310.6 361.4c12.5 12.5 12.5 32.75.0 45.25C304.4 412.9 296.2 416 288 416s-16.38-3.125-22.62-9.375L160 301.3 54.63 406.6C48.38 412.9 40.19 416 32 416S15.63 412.9 9.375 406.6c-12.5-12.5-12.5-32.75.0-45.25l105.4-105.4L9.375 150.6c-12.5-12.5-12.5-32.75.0-45.25s32.75-12.5 45.25.0L160 210.8l105.4-105.4c12.5-12.5 32.75-12.5 45.25.0s12.5 32.75.0 45.25l-105.4 105.4L310.6 361.4z"/></svg></span></button></header><section class="flex-auto overflow-auto px-2"><ul id=search-results></ul></section></div></div></div></body></html>