.lh-vars {
    --color-amber-50: #FFF8E1;
    --color-blue-200: #90CAF9;
    --color-blue-900: #0D47A1;
    --color-blue-A700: #2962FF;
    --color-blue-primary: #06f;
    --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: #080;
    --color-green: #0c6;
    --color-lime-400: #D3E156;
    --color-orange-50: #FFF3E0;
    --color-orange-700: #C33300;
    --color-orange: #fa3;
    --color-red-700: #c00;
    --color-red: #f33;
    --color-teal-600: #00897B;
    --color-white: #FFFFFF;

    /* Context-specific colors */
    --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);

    /* Component variables */
    --audit-description-padding-left: calc(var(--score-icon-size) + var(--score-icon-margin-left) + var(--score-icon-margin-right));
    --audit-explanation-line-height: 16px;
    --audit-group-margin-bottom: calc(var(--default-padding) * 6);
    --audit-group-padding-vertical: 8px;
    --audit-margin-horizontal: 5px;
    --audit-padding-vertical: 8px;
    --category-padding: calc(var(--default-padding) * 6) var(--edge-gap-padding) calc(var(--default-padding) * 4);
    --chevron-line-stroke: var(--color-gray-600);
    --chevron-size: 12px;
    --default-padding: 8px;
    --edge-gap-padding: calc(var(--default-padding) * 4);
    --env-item-background-color: var(--color-gray-100);
    --env-item-font-size: 28px;
    --env-item-line-height: 36px;
    --env-item-padding: 10px 0px;
    --env-name-min-width: 220px;
    --footer-padding-vertical: 16px;
    --gauge-circle-size-big: 96px;
    --gauge-circle-size: 48px;
    --gauge-circle-size-sm: 32px;
    --gauge-label-font-size-big: 18px;
    --gauge-label-font-size: var(--report-font-size-secondary);
    --gauge-label-line-height-big: 24px;
    --gauge-label-line-height: var(--report-line-height-secondary);
    --gauge-percentage-font-size-big: 38px;
    --gauge-percentage-font-size: var(--report-font-size-secondary);
    --gauge-wrapper-width: 120px;
    --header-line-height: 24px;
    --highlighter-background-color: var(--report-text-color);
    --icon-square-size: calc(var(--score-icon-size) * 0.88);
    --image-preview-size: 48px;
    --link-color: var(--color-blue-primary);
    --locale-selector-background-color: var(--color-white);
    --metric-toggle-lines-fill: #7F7F7F;
    --metric-value-font-size: calc(var(--report-font-size) * 1.8);
    --metrics-toggle-background-color: var(--color-gray-200);
    --plugin-badge-background-color: var(--color-white);
    --plugin-badge-size-big: calc(var(--gauge-circle-size-big) / 2.7);
    --plugin-badge-size: calc(var(--gauge-circle-size) / 2.7);
    --plugin-icon-size: 65%;
    --pwa-icon-margin: 0 var(--default-padding);
    --pwa-icon-size: var(--topbar-logo-size);
    --report-background-color: #fff;
    --report-border-color-secondary: #ebebeb;
    --report-font-family-monospace: 'Roboto Mono', 'Menlo', 'dejavu sans mono', 'Consolas', 'Lucida Console', monospace;
    --report-font-family: Roboto, Helvetica, Arial, sans-serif;
    --report-font-size: 14px;
    --report-font-size-secondary: 12px;
    --report-icon-size: var(--score-icon-background-size);
    --report-line-height: 24px;
    --report-line-height-secondary: 20px;
    --report-monospace-font-size: calc(var(--report-font-size) * 0.85);
    --report-text-color-secondary: var(--color-gray-800);
    --report-text-color: var(--color-gray-900);
    --report-content-max-width: calc(60 * var(--report-font-size));
    /* defaults to 840px */
    --report-content-min-width: 360px;
    --report-content-max-width-minus-edge-gap: calc(var(--report-content-max-width) - var(--edge-gap-padding) * 2);
    --score-container-padding: 8px;
    --score-icon-background-size: 24px;
    --score-icon-margin-left: 6px;
    --score-icon-margin-right: 14px;
    --score-icon-margin: 0 var(--score-icon-margin-right) 0 var(--score-icon-margin-left);
    --score-icon-size: 12px;
    --score-icon-size-big: 16px;
    --screenshot-overlay-background: rgba(0, 0, 0, 0.3);
    --section-padding-vertical: calc(var(--default-padding) * 6);
    --snippet-background-color: var(--color-gray-50);
    --snippet-color: #0938C2;
    --stackpack-padding-horizontal: 10px;
    --sticky-header-background-color: var(--report-background-color);
    --sticky-header-buffer: var(--topbar-height);
    --sticky-header-height: calc(var(--gauge-circle-size-sm) + var(--score-container-padding) * 2 + 1em);
    --table-group-header-background-color: #EEF1F4;
    --table-group-header-text-color: var(--color-gray-700);
    --table-higlight-background-color: #F5F7FA;
    --tools-icon-color: var(--color-gray-600);
    --topbar-background-color: var(--color-white);
    --topbar-height: 32px;
    --topbar-logo-size: 24px;
    --topbar-padding: 0 8px;
    --toplevel-warning-background-color: hsla(30, 100%, 75%, 10%);
    --toplevel-warning-message-text-color: var(--color-average-secondary);
    --toplevel-warning-padding: 18px;
    --toplevel-warning-text-color: var(--report-text-color);

    /* SVGs */
    --plugin-icon-url-dark: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24px" height="24px" viewBox="0 0 24 24" fill="%23FFFFFF"><path d="M0 0h24v24H0z" fill="none"/><path d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5C13 2.12 11.88 1 10.5 1S8 2.12 8 3.5V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5c1.38 0 2.5-1.12 2.5-2.5S21.88 11 20.5 11z"/></svg>');
    --plugin-icon-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24px" height="24px" viewBox="0 0 24 24" fill="%23757575"><path d="M0 0h24v24H0z" fill="none"/><path d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5C13 2.12 11.88 1 10.5 1S8 2.12 8 3.5V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5c1.38 0 2.5-1.12 2.5-2.5S21.88 11 20.5 11z"/></svg>');

    --pass-icon-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48"><title>check</title><path fill="%23178239" d="M24 4C12.95 4 4 12.95 4 24c0 11.04 8.95 20 20 20 11.04 0 20-8.96 20-20 0-11.05-8.96-20-20-20zm-4 30L10 24l2.83-2.83L20 28.34l15.17-15.17L38 16 20 34z"/></svg>');
    --average-icon-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48"><title>info</title><path fill="%23E67700" d="M24 4C12.95 4 4 12.95 4 24s8.95 20 20 20 20-8.95 20-20S35.05 4 24 4zm2 30h-4V22h4v12zm0-16h-4v-4h4v4z"/></svg>');
    --fail-icon-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48"><title>warn</title><path fill="%23C7221F" d="M2 42h44L24 4 2 42zm24-6h-4v-4h4v4zm0-8h-4v-8h4v8z"/></svg>');
    --error-icon-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 3 15"><title>error</title><path d="M0 15H 3V 12H 0V" fill="%23FF4E42"/><path d="M0 9H 3V 0H 0V" fill="%23FF4E42"/></svg>');

    --pwa-installable-gray-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="nonzero"><circle fill="%23DAE0E3" cx="12" cy="12" r="12"/><path d="M12 5a7 7 0 1 0 0 14 7 7 0 0 0 0-14zm3.5 7.7h-2.8v2.8h-1.4v-2.8H8.5v-1.4h2.8V8.5h1.4v2.8h2.8v1.4z" fill="%23FFF"/></g></svg>');
    --pwa-optimized-gray-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><rect fill="%23DAE0E3" width="24" height="24" rx="12"/><path fill="%23FFF" d="M12 15.07l3.6 2.18-.95-4.1 3.18-2.76-4.2-.36L12 6.17l-1.64 3.86-4.2.36 3.2 2.76-.96 4.1z"/><path d="M5 5h14v14H5z"/></g></svg>');

    --pwa-installable-gray-url-dark: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="nonzero"><circle fill="%23424242" cx="12" cy="12" r="12"/><path d="M12 5a7 7 0 1 0 0 14 7 7 0 0 0 0-14zm3.5 7.7h-2.8v2.8h-1.4v-2.8H8.5v-1.4h2.8V8.5h1.4v2.8h2.8v1.4z" fill="%23FFF"/></g></svg>');
    --pwa-optimized-gray-url-dark: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><rect fill="%23424242" width="24" height="24" rx="12"/><path fill="%23FFF" d="M12 15.07l3.6 2.18-.95-4.1 3.18-2.76-4.2-.36L12 6.17l-1.64 3.86-4.2.36 3.2 2.76-.96 4.1z"/><path d="M5 5h14v14H5z"/></g></svg>');

    --pwa-installable-color-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><g fill-rule="nonzero" fill="none"><circle fill="%230CCE6B" cx="12" cy="12" r="12"/><path d="M12 5a7 7 0 1 0 0 14 7 7 0 0 0 0-14zm3.5 7.7h-2.8v2.8h-1.4v-2.8H8.5v-1.4h2.8V8.5h1.4v2.8h2.8v1.4z" fill="%23FFF"/></g></svg>');
    --pwa-optimized-color-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><rect fill="%230CCE6B" width="24" height="24" rx="12"/><path d="M5 5h14v14H5z"/><path fill="%23FFF" d="M12 15.07l3.6 2.18-.95-4.1 3.18-2.76-4.2-.36L12 6.17l-1.64 3.86-4.2.36 3.2 2.76-.96 4.1z"/></g></svg>');

    --swap-locale-icon-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="#000000"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z"/></svg>');
}

@media not print {
    .lh-dark {
        /* Pallete */
        --color-gray-200: var(--color-gray-800);
        --color-gray-300: #616161;
        --color-gray-400: var(--color-gray-600);
        --color-gray-700: var(--color-gray-400);
        --color-gray-50: #757575;
        --color-gray-600: var(--color-gray-500);
        --color-green-700: var(--color-green);
        --color-orange-700: var(--color-orange);
        --color-red-700: var(--color-red);
        --color-teal-600: var(--color-cyan-500);

        /* Context-specific colors */
        --color-hover: rgba(0, 0, 0, 0.2);
        --color-informative: var(--color-blue-200);

        /* Component variables */
        --env-item-background-color: #393535;
        --link-color: var(--color-blue-200);
        --locale-selector-background-color: var(--color-gray-200);
        --plugin-badge-background-color: var(--color-gray-800);
        --report-background-color: var(--color-gray-900);
        --report-border-color-secondary: var(--color-gray-200);
        --report-text-color-secondary: var(--color-gray-400);
        --report-text-color: var(--color-gray-100);
        --snippet-color: var(--color-cyan-500);
        --topbar-background-color: var(--color-gray);
        --toplevel-warning-background-color: hsl(33deg 14% 18%);
        --toplevel-warning-message-text-color: var(--color-orange-700);
        --toplevel-warning-text-color: var(--color-gray-100);
        --table-group-header-background-color: rgba(186, 196, 206, 0.15);
        --table-group-header-text-color: var(--color-gray-100);
        --table-higlight-background-color: rgba(186, 196, 206, 0.09);

        /* SVGs */
        --plugin-icon-url: var(--plugin-icon-url-dark);
        --pwa-installable-gray-url: var(--pwa-installable-gray-url-dark);
        --pwa-optimized-gray-url: var(--pwa-optimized-gray-url-dark);
    }
}

@media only screen and (max-width: 480px) {
    .lh-vars {
        --audit-group-margin-bottom: 20px;
        --edge-gap-padding: var(--default-padding);
        --env-name-min-width: 120px;
        --gauge-circle-size-big: 96px;
        --gauge-circle-size: 72px;
        --gauge-label-font-size-big: 22px;
        --gauge-label-font-size: 14px;
        --gauge-label-line-height-big: 26px;
        --gauge-label-line-height: 20px;
        --gauge-percentage-font-size-big: 34px;
        --gauge-percentage-font-size: 26px;
        --gauge-wrapper-width: 112px;
        --header-padding: 16px 0 16px 0;
        --image-preview-size: 24px;
        --plugin-icon-size: 75%;
        --pwa-icon-margin: 0 7px 0 -3px;
        --report-font-size: 14px;
        --report-line-height: 20px;
        --score-icon-margin-left: 2px;
        --score-icon-size: 10px;
        --topbar-height: 28px;
        --topbar-logo-size: 20px;
    }
}

.lh-vars.lh-devtools {
    --audit-explanation-line-height: 14px;
    --audit-group-margin-bottom: 20px;
    --audit-group-padding-vertical: 12px;
    --audit-padding-vertical: 4px;
    --category-padding: 12px;
    --default-padding: 12px;
    --env-name-min-width: 120px;
    --footer-padding-vertical: 8px;
    --gauge-circle-size-big: 72px;
    --gauge-circle-size: 64px;
    --gauge-label-font-size-big: 22px;
    --gauge-label-font-size: 14px;
    --gauge-label-line-height-big: 26px;
    --gauge-label-line-height: 20px;
    --gauge-percentage-font-size-big: 34px;
    --gauge-percentage-font-size: 26px;
    --gauge-wrapper-width: 97px;
    --header-line-height: 20px;
    --header-padding: 16px 0 16px 0;
    --screenshot-overlay-background: transparent;
    --plugin-icon-size: 75%;
    --pwa-icon-margin: 0 7px 0 -3px;
    --report-font-family-monospace: 'Menlo', 'dejavu sans mono', 'Consolas', 'Lucida Console', monospace;
    --report-font-family: '.SFNSDisplay-Regular', 'Helvetica Neue', 'Lucida Grande', sans-serif;
    --report-font-size: 12px;
    --report-line-height: 20px;
    --score-icon-margin-left: 2px;
    --score-icon-size: 10px;
    --section-padding-vertical: 8px;
}

.lh-container:has(.lh-sticky-header) {
    --sticky-header-buffer: calc(var(--topbar-height) + var(--sticky-header-height));
}

.lh-container:not(.lh-topbar + .lh-container) {
    --topbar-height: 0;
    --sticky-header-height: 0;
    --sticky-header-buffer: 0;
}

.lh-max-viewport {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    width: 100%;
}

.lh-devtools.lh-root {
    height: 100%;
}

.lh-devtools.lh-root img {
    /* Override devtools default 'min-width: 0' so svg without size in a flexbox isn't collapsed. */
    min-width: auto;
}

.lh-devtools .lh-container {
    overflow-y: scroll;
    height: calc(100% - var(--topbar-height));
    /** The .lh-container is the scroll parent in DevTools so we exclude the topbar from the sticky header buffer. */
    --sticky-header-buffer: 0;
}

.lh-devtools .lh-container:has(.lh-sticky-header) {
    /** The .lh-container is the scroll parent in DevTools so we exclude the topbar from the sticky header buffer. */
    --sticky-header-buffer: var(--sticky-header-height);
}

@media print {
    .lh-devtools .lh-container {
        overflow: unset;
    }
}

.lh-devtools .lh-sticky-header {
    /* This is normally the height of the topbar, but we want it to stick to the top of our scroll container .lh-container` */
    top: 0;
}

.lh-devtools .lh-element-screenshot__overlay {
    position: absolute;
}

@keyframes fadeIn {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 0.6;
    }
}

.lh-root *,
.lh-root *::before,
.lh-root *::after {
    box-sizing: border-box;
}

.lh-root {
    font-family: var(--report-font-family);
    font-size: var(--report-font-size);
    margin: 0;
    line-height: var(--report-line-height);
    background: var(--report-background-color);
    color: var(--report-text-color);
}

.lh-root :focus-visible {
    outline: -webkit-focus-ring-color auto 3px;
}

.lh-root summary:focus {
    outline: none;
    box-shadow: 0 0 0 1px hsl(217, 89%, 61%);
}

.lh-root [hidden] {
    display: none !important;
}

.lh-root pre {
    margin: 0;
}

.lh-root pre,
.lh-root code {
    font-family: var(--report-font-family-monospace);
}

.lh-root details>summary {
    cursor: pointer;
}

.lh-hidden {
    display: none !important;
}

.lh-container {
    /*
Text wrapping in the report is so much FUN!
We have a `word-break: break-word;` globally here to prevent a few common scenarios, namely
long non-breakable text (usually URLs) found in:
1. The footer
2. .lh-node (outerHTML)
3. .lh-code

With that sorted, the next challenge is appropriate column sizing and text wrapping inside our
.lh-details tables. Even more fun.
* We don't want table headers ("Potential Savings (ms)") to wrap or their column values, but
we'd be happy for the URL column to wrap if the URLs are particularly long.
* We want the narrow columns to remain narrow, providing the most column width for URL
* We don't want the table to extend past 100% width.
* Long URLs in the URL column can wrap. Util.getURLDisplayName maxes them out at 64 characters,
but they do not get any overflow:ellipsis treatment.
*/
    word-break: break-word;
}

.lh-audit-group a,
.lh-category-header__description a,
.lh-audit__description a,
.lh-warnings a,
.lh-footer a,
.lh-table-column--link a {
    color: var(--link-color);
}

.lh-audit__description,
.lh-audit__stackpack {
    --inner-audit-padding-right: var(--stackpack-padding-horizontal);
    padding-left: var(--audit-description-padding-left);
    padding-right: var(--inner-audit-padding-right);
    padding-top: 8px;
    padding-bottom: 8px;
}

.lh-details {
    margin-top: var(--default-padding);
    margin-bottom: var(--default-padding);
    margin-left: var(--audit-description-padding-left);
    /* whatever the .lh-details side margins are */
    width: 100%;
}

.lh-audit__stackpack {
    display: flex;
    align-items: center;
}

.lh-audit__stackpack__img {
    max-width: 30px;
    margin-right: var(--default-padding)
}

/* Report header */

.lh-report-icon {
    display: flex;
    align-items: center;
    padding: 10px 12px;
    cursor: pointer;
}

.lh-report-icon[disabled] {
    opacity: 0.3;
    pointer-events: none;
}

.lh-report-icon::before {
    content: "";
    margin: 4px;
    background-repeat: no-repeat;
    width: var(--report-icon-size);
    height: var(--report-icon-size);
    opacity: 0.7;
    display: inline-block;
    vertical-align: middle;
}

.lh-report-icon:hover::before {
    opacity: 1;
}

.lh-dark .lh-report-icon::before {
    filter: invert(1);
}

.lh-report-icon--print::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M19 8H5c-1.66 0-3 1.34-3 3v6h4v4h12v-4h4v-6c0-1.66-1.34-3-3-3zm-3 11H8v-5h8v5zm3-7c-.55 0-1-.45-1-1s.45-1 1-1 1 .45 1 1-.45 1-1 1zm-1-9H6v4h12V3z"/><path fill="none" d="M0 0h24v24H0z"/></svg>');
}

.lh-report-icon--copy::before {
    background-image: url('data:image/svg+xml;utf8,<svg height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M0 0h24v24H0z" fill="none"/><path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"/></svg>');
}

.lh-report-icon--open::before {
    background-image: url('data:image/svg+xml;utf8,<svg height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M0 0h24v24H0z" fill="none"/><path d="M19 4H5c-1.11 0-2 .9-2 2v12c0 1.1.89 2 2 2h4v-2H5V8h14v10h-4v2h4c1.1 0 2-.9 2-2V6c0-1.1-.89-2-2-2zm-7 6l-4 4h3v6h2v-6h3l-4-4z"/></svg>');
}

.lh-report-icon--download::before {
    background-image: url('data:image/svg+xml;utf8,<svg height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M19 9h-4V3H9v6H5l7 7 7-7zM5 18v2h14v-2H5z"/><path d="M0 0h24v24H0z" fill="none"/></svg>');
}

.lh-report-icon--dark::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 100 125"><path d="M50 23.587c-16.27 0-22.799 12.574-22.799 21.417 0 12.917 10.117 22.451 12.436 32.471h20.726c2.32-10.02 12.436-19.554 12.436-32.471 0-8.843-6.528-21.417-22.799-21.417zM39.637 87.161c0 3.001 1.18 4.181 4.181 4.181h.426l.41 1.231C45.278 94.449 46.042 95 48.019 95h3.963c1.978 0 2.74-.551 3.365-2.427l.409-1.231h.427c3.002 0 4.18-1.18 4.18-4.181V80.91H39.637v6.251zM50 18.265c1.26 0 2.072-.814 2.072-2.073v-9.12C52.072 5.813 51.26 5 50 5c-1.259 0-2.072.813-2.072 2.073v9.12c0 1.259.813 2.072 2.072 2.072zM68.313 23.727c.994.774 2.135.634 2.91-.357l5.614-7.187c.776-.992.636-2.135-.356-2.909-.992-.776-2.135-.636-2.91.357l-5.613 7.186c-.778.993-.636 2.135.355 2.91zM91.157 36.373c-.306-1.222-1.291-1.815-2.513-1.51l-8.85 2.207c-1.222.305-1.814 1.29-1.51 2.512.305 1.223 1.291 1.814 2.513 1.51l8.849-2.206c1.223-.305 1.816-1.291 1.511-2.513zM86.757 60.48l-8.331-3.709c-1.15-.512-2.225-.099-2.736 1.052-.512 1.151-.1 2.224 1.051 2.737l8.33 3.707c1.15.514 2.225.101 2.736-1.05.513-1.149.1-2.223-1.05-2.737zM28.779 23.37c.775.992 1.917 1.131 2.909.357.992-.776 1.132-1.917.357-2.91l-5.615-7.186c-.775-.992-1.917-1.132-2.909-.357s-1.131 1.917-.356 2.909l5.614 7.187zM21.715 39.583c.305-1.223-.288-2.208-1.51-2.513l-8.849-2.207c-1.222-.303-2.208.289-2.513 1.511-.303 1.222.288 2.207 1.511 2.512l8.848 2.206c1.222.304 2.208-.287 2.513-1.509zM21.575 56.771l-8.331 3.711c-1.151.511-1.563 1.586-1.05 2.735.511 1.151 1.586 1.563 2.736 1.052l8.331-3.711c1.151-.511 1.563-1.586 1.05-2.735-.512-1.15-1.585-1.562-2.736-1.052z"/></svg>');
}

.lh-report-icon--treemap::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="black"><path d="M3 5v14h19V5H3zm2 2h15v4H5V7zm0 10v-4h4v4H5zm6 0v-4h9v4h-9z"/></svg>');
}

.lh-report-icon--date::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M7 11h2v2H7v-2zm14-5v14a2 2 0 01-2 2H5a2 2 0 01-2-2V6c0-1.1.9-2 2-2h1V2h2v2h8V2h2v2h1a2 2 0 012 2zM5 8h14V6H5v2zm14 12V10H5v10h14zm-4-7h2v-2h-2v2zm-4 0h2v-2h-2v2z"/></svg>');
}

.lh-report-icon--devices::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 6h18V4H4a2 2 0 00-2 2v11H0v3h14v-3H4V6zm19 2h-6a1 1 0 00-1 1v10c0 .6.5 1 1 1h6c.6 0 1-.5 1-1V9c0-.6-.5-1-1-1zm-1 9h-4v-7h4v7z"/></svg>');
}

.lh-report-icon--world::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20zm7 6h-3c-.3-1.3-.8-2.5-1.4-3.6A8 8 0 0 1 18.9 8zm-7-4a14 14 0 0 1 2 4h-4a14 14 0 0 1 2-4zM4.3 14a8.2 8.2 0 0 1 0-4h3.3a16.5 16.5 0 0 0 0 4H4.3zm.8 2h3a14 14 0 0 0 1.3 3.6A8 8 0 0 1 5.1 16zm3-8H5a8 8 0 0 1 4.3-3.6L8 8zM12 20a14 14 0 0 1-2-4h4a14 14 0 0 1-2 4zm2.3-6H9.7a14.7 14.7 0 0 1 0-4h4.6a14.6 14.6 0 0 1 0 4zm.3 5.6c.6-1.2 1-2.4 1.4-3.6h3a8 8 0 0 1-4.4 3.6zm1.8-5.6a16.5 16.5 0 0 0 0-4h3.3a8.2 8.2 0 0 1 0 4h-3.3z"/></svg>');
}

.lh-report-icon--stopwatch::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M15 1H9v2h6V1zm-4 13h2V8h-2v6zm8.1-6.6L20.5 6l-1.4-1.4L17.7 6A9 9 0 0 0 3 13a9 9 0 1 0 16-5.6zm-7 12.6a7 7 0 1 1 0-14 7 7 0 0 1 0 14z"/></svg>');
}

.lh-report-icon--networkspeed::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M15.9 5c-.2 0-.3 0-.4.2v.2L10.1 17a2 2 0 0 0-.2 1 2 2 0 0 0 4 .4l2.4-12.9c0-.3-.2-.5-.5-.5zM1 9l2 2c2.9-2.9 6.8-4 10.5-3.6l1.2-2.7C10 3.8 4.7 5.3 1 9zm20 2 2-2a15.4 15.4 0 0 0-5.6-3.6L17 8.2c1.5.7 2.9 1.6 4.1 2.8zm-4 4 2-2a9.9 9.9 0 0 0-2.7-1.9l-.5 3 1.2.9zM5 13l2 2a7.1 7.1 0 0 1 4-2l1.3-2.9C9.7 10.1 7 11 5 13z"/></svg>');
}

.lh-report-icon--samples-one::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><circle cx="7" cy="14" r="3"/><path d="M7 18a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm4-2a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm5.6 17.6a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/></svg>');
}

.lh-report-icon--samples-many::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M7 18a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm4-2a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm5.6 17.6a4 4 0 1 1 0-8 4 4 0 0 1 0 8zm0-6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z"/><circle cx="7" cy="14" r="3"/><circle cx="11" cy="6" r="3"/></svg>');
}

.lh-report-icon--chrome::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="-50 -50 562 562"><path d="M256 25.6v25.6a204 204 0 0 1 144.8 60 204 204 0 0 1 60 144.8 204 204 0 0 1-60 144.8 204 204 0 0 1-144.8 60 204 204 0 0 1-144.8-60 204 204 0 0 1-60-144.8 204 204 0 0 1 60-144.8 204 204 0 0 1 144.8-60V0a256 256 0 1 0 0 512 256 256 0 0 0 0-512v25.6z"/><path d="M256 179.2v25.6a51.3 51.3 0 0 1 0 102.4 51.3 51.3 0 0 1 0-102.4v-51.2a102.3 102.3 0 1 0-.1 204.7 102.3 102.3 0 0 0 .1-204.7v25.6z"/><path d="M256 204.8h217.6a25.6 25.6 0 0 0 0-51.2H256a25.6 25.6 0 0 0 0 51.2m44.3 76.8L191.5 470.1a25.6 25.6 0 1 0 44.4 25.6l108.8-188.5a25.6 25.6 0 1 0-44.4-25.6m-88.6 0L102.9 93.2a25.7 25.7 0 0 0-35-9.4 25.7 25.7 0 0 0-9.4 35l108.8 188.5a25.7 25.7 0 0 0 35 9.4 25.9 25.9 0 0 0 9.4-35.1"/></svg>');
}

.lh-report-icon--external::before {
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><path d="M3.15 11.9a1.01 1.01 0 0 1-.743-.307 1.01 1.01 0 0 1-.306-.743v-7.7c0-.292.102-.54.306-.744a1.01 1.01 0 0 1 .744-.306H7v1.05H3.15v7.7h7.7V7h1.05v3.85c0 .291-.103.54-.307.743a1.01 1.01 0 0 1-.743.307h-7.7Zm2.494-2.8-.743-.744 5.206-5.206H8.401V2.1h3.5v3.5h-1.05V3.893L5.644 9.1Z"/></svg>');
}

.lh-buttons {
    display: flex;
    flex-wrap: wrap;
    margin: var(--default-padding) 0;
}

.lh-button {
    height: 32px;
    border: 1px solid var(--report-border-color-secondary);
    border-radius: 3px;
    color: var(--link-color);
    background-color: var(--report-background-color);
    margin: 5px;
}

.lh-button:first-of-type {
    margin-left: 0;
}

/* Node */
.lh-node__snippet {
    font-family: var(--report-font-family-monospace);
    color: var(--snippet-color);
    font-size: var(--report-monospace-font-size);
    line-height: 20px;
}

/* Score */

.lh-audit__score-icon {
    width: var(--score-icon-size);
    height: var(--score-icon-size);
    margin: var(--score-icon-margin);
}

.lh-audit--pass .lh-audit__display-text {
    color: var(--color-pass-secondary);
}

.lh-audit--pass .lh-audit__score-icon,
.lh-scorescale-range--pass::before {
    border-radius: 100%;
    background: var(--color-pass);
}

.lh-audit--average .lh-audit__display-text {
    color: var(--color-average-secondary);
}

.lh-audit--average .lh-audit__score-icon,
.lh-scorescale-range--average::before {
    background: var(--color-average);
    width: var(--icon-square-size);
    height: var(--icon-square-size);
}

.lh-audit--fail .lh-audit__display-text {
    color: var(--color-fail-secondary);
}

.lh-audit--fail .lh-audit__score-icon,
.lh-audit--error .lh-audit__score-icon,
.lh-scorescale-range--fail::before {
    border-left: calc(var(--score-icon-size) / 2) solid transparent;
    border-right: calc(var(--score-icon-size) / 2) solid transparent;
    border-bottom: var(--score-icon-size) solid var(--color-fail);
}

.lh-audit--error .lh-audit__score-icon,
.lh-metric--error .lh-metric__icon {
    background-image: var(--error-icon-url);
    background-repeat: no-repeat;
    background-position: center;
    border: none;
}

.lh-gauge__wrapper--fail .lh-gauge--error {
    background-image: var(--error-icon-url);
    background-repeat: no-repeat;
    background-position: center;
    transform: scale(0.5);
    top: var(--score-container-padding);
}

.lh-audit--manual .lh-audit__display-text,
.lh-audit--notapplicable .lh-audit__display-text {
    color: var(--color-gray-600);
}

.lh-audit--manual .lh-audit__score-icon,
.lh-audit--notapplicable .lh-audit__score-icon {
    border: calc(0.2 * var(--score-icon-size)) solid var(--color-gray-400);
    border-radius: 100%;
    background: none;
}

.lh-audit--informative .lh-audit__display-text {
    color: var(--color-gray-600);
}

.lh-audit--informative .lh-audit__score-icon {
    border: calc(0.2 * var(--score-icon-size)) solid var(--color-gray-400);
    border-radius: 100%;
}

.lh-audit__description,
.lh-audit__stackpack {
    color: var(--report-text-color-secondary);
}

.lh-audit__adorn {
    border: 1px solid var(--color-gray-500);
    border-radius: 3px;
    margin: 0 3px;
    padding: 0 2px;
    line-height: 1.1;
    display: inline-block;
    font-size: 90%;
    color: var(--report-text-color-secondary);
}

.lh-category-header__description {
    text-align: center;
    color: var(--color-gray-700);
    margin: 0px auto;
    max-width: 400px;
}


.lh-audit__display-text,
.lh-chevron-container {
    margin: 0 var(--audit-margin-horizontal);
}

.lh-chevron-container {
    margin-right: 0;
}

.lh-audit__title-and-text {
    flex: 1;
}

.lh-audit__title-and-text code {
    color: var(--snippet-color);
    font-size: var(--report-monospace-font-size);
}

/* Prepend display text with em dash separator. */
.lh-audit__display-text:not(:empty):before {
    content: '—';
    margin-right: var(--audit-margin-horizontal);
}

/* Expandable Details (Audit Groups, Audits) */
.lh-audit__header {
    display: flex;
    align-items: center;
    padding: var(--default-padding);
}


.lh-metricfilter {
    display: grid;
    justify-content: end;
    align-items: center;
    grid-auto-flow: column;
    gap: 4px;
    color: var(--color-gray-700);
}

.lh-metricfilter__radio {
    /*
* Instead of hiding, position offscreen so it's still accessible to screen readers
* https://bugs.chromium.org/p/chromium/issues/detail?id=1439785
*/
    position: fixed;
    left: -9999px;
}

.lh-metricfilter input[type='radio']:focus-visible+label {
    outline: -webkit-focus-ring-color auto 1px;
}

.lh-metricfilter__label {
    display: inline-flex;
    padding: 0 4px;
    height: 16px;
    text-decoration: underline;
    align-items: center;
    cursor: pointer;
    font-size: 90%;
}

.lh-metricfilter__label--active {
    background: var(--color-blue-primary);
    color: var(--color-white);
    border-radius: 3px;
    text-decoration: none;
}

/* Give the 'All' choice a more muted display */
.lh-metricfilter__label--active[for="metric-All"] {
    background-color: var(--color-blue-200) !important;
    color: black !important;
}

.lh-metricfilter__text {
    margin-right: 8px;
}

/* If audits are filtered, hide the itemcount for Passed Audits… */
.lh-category--filtered .lh-audit-group .lh-audit-group__itemcount {
    display: none;
}


.lh-audit__header:hover {
    background-color: var(--color-hover);
}

/* We want to hide the browser's default arrow marker on summary elements. Admittedly, it's complicated. */
.lh-root details>summary {
    /* Blink 89+ and Firefox will hide the arrow when display is changed from (new) default of `list-item` to block.  https://chromestatus.com/feature/6730096436051968*/
    display: block;
}

/* Safari and Blink <=88 require using the -webkit-details-marker selector */
.lh-root details>summary::-webkit-details-marker {
    display: none;
}

/* Perf Metric */

.lh-metrics-container {
    display: grid;
    grid-auto-rows: 1fr;
    grid-template-columns: 1fr 1fr;
    grid-column-gap: var(--report-line-height);
    margin-bottom: var(--default-padding);
}

.lh-metric {
    border-top: 1px solid var(--report-border-color-secondary);
}

.lh-category:not(.lh--hoisted-meta) .lh-metric:nth-last-child(-n+2) {
    border-bottom: 1px solid var(--report-border-color-secondary);
}

.lh-metric__innerwrap {
    display: grid;
    /**
* Icon -- Metric Name
*      -- Metric Value
*/
    grid-template-columns: calc(var(--score-icon-size) + var(--score-icon-margin-left) + var(--score-icon-margin-right)) 1fr;
    align-items: center;
    padding: var(--default-padding);
}

.lh-metric__details {
    order: -1;
}

.lh-metric__title {
    flex: 1;
}

.lh-calclink {
    padding-left: calc(1ex / 3);
}

.lh-metric__description {
    display: none;
    grid-column-start: 2;
    grid-column-end: 4;
    color: var(--report-text-color-secondary);
}

.lh-metric__value {
    font-size: var(--metric-value-font-size);
    margin: calc(var(--default-padding) / 2) 0;
    white-space: nowrap;
    /* No wrapping between metric value and the icon */
    grid-column-start: 2;
}


@media screen and (max-width: 535px) {
    .lh-metrics-container {
        display: block;
    }

    .lh-metric {
        border-bottom: none !important;
    }

    .lh-category:not(.lh--hoisted-meta) .lh-metric:nth-last-child(1) {
        border-bottom: 1px solid var(--report-border-color-secondary) !important;
    }

    /* Change the grid to 3 columns for narrow viewport. */
    .lh-metric__innerwrap {
        /**
* Icon -- Metric Name -- Metric Value
*/
        grid-template-columns: calc(var(--score-icon-size) + var(--score-icon-margin-left) + var(--score-icon-margin-right)) 2fr 1fr;
    }

    .lh-metric__value {
        justify-self: end;
        grid-column-start: unset;
    }
}

/* No-JS toggle switch */
/* Keep this selector sync'd w/ `magicSelector` in report-ui-features-test.js */
.lh-metrics-toggle__input:checked~.lh-metrics-container .lh-metric__description {
    display: block;
}

/* TODO get rid of the SVGS and clean up these some more */
.lh-metrics-toggle__input {
    opacity: 0;
    position: absolute;
    right: 0;
    top: 0px;
}

.lh-metrics-toggle__input+div>label>.lh-metrics-toggle__labeltext--hide,
.lh-metrics-toggle__input:checked+div>label>.lh-metrics-toggle__labeltext--show {
    display: none;
}

.lh-metrics-toggle__input:checked+div>label>.lh-metrics-toggle__labeltext--hide {
    display: inline;
}

.lh-metrics-toggle__input:focus+div>label {
    outline: -webkit-focus-ring-color auto 3px;
}

.lh-metrics-toggle__label {
    cursor: pointer;
    font-size: var(--report-font-size-secondary);
    line-height: var(--report-line-height-secondary);
    color: var(--color-gray-700);
}

/* Pushes the metric description toggle button to the right. */
.lh-audit-group--metrics .lh-audit-group__header {
    display: flex;
    justify-content: space-between;
}

.lh-metric__icon,
.lh-scorescale-range::before {
    content: '';
    width: var(--score-icon-size);
    height: var(--score-icon-size);
    display: inline-block;
    margin: var(--score-icon-margin);
}

.lh-metric--pass .lh-metric__value {
    color: var(--color-pass-secondary);
}

.lh-metric--pass .lh-metric__icon {
    border-radius: 100%;
    background: var(--color-pass);
}

.lh-metric--average .lh-metric__value {
    color: var(--color-average-secondary);
}

.lh-metric--average .lh-metric__icon {
    background: var(--color-average);
    width: var(--icon-square-size);
    height: var(--icon-square-size);
}

.lh-metric--fail .lh-metric__value {
    color: var(--color-fail-secondary);
}

.lh-metric--fail .lh-metric__icon {
    border-left: calc(var(--score-icon-size) / 2) solid transparent;
    border-right: calc(var(--score-icon-size) / 2) solid transparent;
    border-bottom: var(--score-icon-size) solid var(--color-fail);
}

.lh-metric--error .lh-metric__value,
.lh-metric--error .lh-metric__description {
    color: var(--color-fail-secondary);
}

/* Filmstrip */

.lh-filmstrip-container {
    /* smaller gap between metrics and filmstrip */
    margin: -8px auto 0 auto;
}

.lh-filmstrip {
    display: grid;
    justify-content: space-between;
    padding-bottom: var(--default-padding);
    width: 100%;
    grid-template-columns: repeat(auto-fit, 90px);
}

.lh-filmstrip__frame {
    text-align: right;
    position: relative;
}

.lh-filmstrip__thumbnail {
    border: 1px solid var(--report-border-color-secondary);
    max-height: 150px;
    max-width: 120px;
}

/* Audit */

.lh-audit {
    border-bottom: 1px solid var(--report-border-color-secondary);
}

/* Apply border-top to just the first audit. */
.lh-audit {
    border-top: 1px solid var(--report-border-color-secondary);
}

.lh-audit~.lh-audit {
    border-top: none;
}


.lh-audit--error .lh-audit__display-text {
    color: var(--color-fail-secondary);
}

/* Audit Group */

.lh-audit-group {
    margin-bottom: var(--audit-group-margin-bottom);
    position: relative;
}

.lh-audit-group--metrics {
    margin-bottom: calc(var(--audit-group-margin-bottom) / 2);
}

.lh-audit-group__header::before {
    /* By default, groups don't get an icon */
    content: none;
    width: var(--pwa-icon-size);
    height: var(--pwa-icon-size);
    margin: var(--pwa-icon-margin);
    display: inline-block;
    vertical-align: middle;
}

/* Style the "over budget" columns red. */
.lh-audit-group--budgets #performance-budget tbody tr td:nth-child(4),
.lh-audit-group--budgets #performance-budget tbody tr td:nth-child(5),
.lh-audit-group--budgets #timing-budget tbody tr td:nth-child(3) {
    color: var(--color-red-700);
}

/* Align the "over budget request count" text to be close to the "over budget bytes" column. */
.lh-audit-group--budgets .lh-table tbody tr td:nth-child(4) {
    text-align: right;
}

.lh-audit-group--budgets .lh-details--budget {
    width: 100%;
    margin: 0 0 var(--default-padding);
}

.lh-audit-group--pwa-installable .lh-audit-group__header::before {
    content: '';
    background-image: var(--pwa-installable-gray-url);
}

.lh-audit-group--pwa-optimized .lh-audit-group__header::before {
    content: '';
    background-image: var(--pwa-optimized-gray-url);
}

.lh-audit-group--pwa-installable.lh-badged .lh-audit-group__header::before {
    background-image: var(--pwa-installable-color-url);
}

.lh-audit-group--pwa-optimized.lh-badged .lh-audit-group__header::before {
    background-image: var(--pwa-optimized-color-url);
}

.lh-audit-group--metrics .lh-audit-group__summary {
    margin-top: 0;
    margin-bottom: 0;
}

.lh-audit-group__summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.lh-audit-group__header .lh-chevron {
    margin-top: calc((var(--report-line-height) - 5px) / 2);
}

.lh-audit-group__header {
    letter-spacing: 0.8px;
    padding: var(--default-padding);
    padding-left: 0;
}

.lh-audit-group__header,
.lh-audit-group__summary {
    font-size: var(--report-font-size-secondary);
    line-height: var(--report-line-height-secondary);
    color: var(--color-gray-700);
}

.lh-audit-group__title {
    text-transform: uppercase;
    font-weight: 500;
}

.lh-audit-group__itemcount {
    color: var(--color-gray-600);
}

.lh-audit-group__footer {
    color: var(--color-gray-600);
    display: block;
    margin-top: var(--default-padding);
}

.lh-details,
.lh-category-header__description,
.lh-audit-group__footer {
    font-size: var(--report-font-size-secondary);
    line-height: var(--report-line-height-secondary);
}

.lh-audit-explanation {
    margin: var(--audit-padding-vertical) 0 calc(var(--audit-padding-vertical) / 2) var(--audit-margin-horizontal);
    line-height: var(--audit-explanation-line-height);
    display: inline-block;
}

.lh-audit--fail .lh-audit-explanation {
    color: var(--color-fail-secondary);
}

/* Report */
.lh-list> :not(:last-child) {
    margin-bottom: calc(var(--default-padding) * 2);
}

.lh-header-container {
    display: block;
    margin: 0 auto;
    position: relative;
    word-wrap: break-word;
}

.lh-header-container .lh-scores-wrapper {
    border-bottom: 1px solid var(--color-gray-200);
}


.lh-report {
    min-width: var(--report-content-min-width);
}

.lh-exception {
    font-size: large;
}

.lh-code {
    white-space: normal;
    margin-top: 0;
    font-size: var(--report-monospace-font-size);
}

.lh-warnings {
    --item-margin: calc(var(--report-line-height) / 6);
    color: var(--color-average-secondary);
    margin: var(--audit-padding-vertical) 0;
    padding: var(--default-padding) var(--default-padding) var(--default-padding) calc(var(--audit-description-padding-left));
    background-color: var(--toplevel-warning-background-color);
}

.lh-warnings span {
    font-weight: bold;
}

.lh-warnings--toplevel {
    --item-margin: calc(var(--header-line-height) / 4);
    color: var(--toplevel-warning-text-color);
    margin-left: auto;
    margin-right: auto;
    max-width: var(--report-content-max-width-minus-edge-gap);
    padding: var(--toplevel-warning-padding);
    border-radius: 8px;
}

.lh-warnings__msg {
    color: var(--toplevel-warning-message-text-color);
    margin: 0;
}

.lh-warnings ul {
    margin: 0;
}

.lh-warnings li {
    margin: var(--item-margin) 0;
}

.lh-warnings li:last-of-type {
    margin-bottom: 0;
}

.lh-scores-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.lh-scores-header__solo {
    padding: 0;
    border: 0;
}

/* Gauge */

.lh-gauge__wrapper--pass {
    color: var(--color-pass-secondary);
    fill: var(--color-pass);
    stroke: var(--color-pass);
}

.lh-gauge__wrapper--average {
    color: var(--color-average-secondary);
    fill: var(--color-average);
    stroke: var(--color-average);
}

.lh-gauge__wrapper--fail {
    color: var(--color-fail-secondary);
    fill: var(--color-fail);
    stroke: var(--color-fail);
}

.lh-gauge__wrapper--not-applicable {
    color: var(--color-not-applicable);
    fill: var(--color-not-applicable);
    stroke: var(--color-not-applicable);
}

.lh-fraction__wrapper .lh-fraction__content::before {
    content: '';
    height: var(--score-icon-size);
    width: var(--score-icon-size);
    margin: var(--score-icon-margin);
    display: inline-block;
}

.lh-fraction__wrapper--pass .lh-fraction__content {
    color: var(--color-pass-secondary);
}

.lh-fraction__wrapper--pass .lh-fraction__background {
    background-color: var(--color-pass);
}

.lh-fraction__wrapper--pass .lh-fraction__content::before {
    background-color: var(--color-pass);
    border-radius: 50%;
}

.lh-fraction__wrapper--average .lh-fraction__content {
    color: var(--color-average-secondary);
}

.lh-fraction__wrapper--average .lh-fraction__background,
.lh-fraction__wrapper--average .lh-fraction__content::before {
    background-color: var(--color-average);
}

.lh-fraction__wrapper--fail .lh-fraction__content {
    color: var(--color-fail);
}

.lh-fraction__wrapper--fail .lh-fraction__background {
    background-color: var(--color-fail);
}

.lh-fraction__wrapper--fail .lh-fraction__content::before {
    border-left: calc(var(--score-icon-size) / 2) solid transparent;
    border-right: calc(var(--score-icon-size) / 2) solid transparent;
    border-bottom: var(--score-icon-size) solid var(--color-fail);
}

.lh-fraction__wrapper--null .lh-fraction__content {
    color: var(--color-gray-700);
}

.lh-fraction__wrapper--null .lh-fraction__background {
    background-color: var(--color-gray-700);
}

.lh-fraction__wrapper--null .lh-fraction__content::before {
    border-radius: 50%;
    border: calc(0.2 * var(--score-icon-size)) solid var(--color-gray-700);
}

.lh-fraction__background {
    position: absolute;
    height: 100%;
    width: 100%;
    border-radius: calc(var(--gauge-circle-size) / 2);
    opacity: 0.1;
    z-index: -1;
}

.lh-fraction__content-wrapper {
    height: var(--gauge-circle-size);
    display: flex;
    align-items: center;
}

.lh-fraction__content {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center;
    font-size: calc(0.3 * var(--gauge-circle-size));
    line-height: calc(0.4 * var(--gauge-circle-size));
    width: max-content;
    min-width: calc(1.5 * var(--gauge-circle-size));
    padding: calc(0.1 * var(--gauge-circle-size)) calc(0.2 * var(--gauge-circle-size));
    --score-icon-size: calc(0.21 * var(--gauge-circle-size));
    --score-icon-margin: 0 calc(0.15 * var(--gauge-circle-size)) 0 0;
}

.lh-gauge {
    stroke-linecap: round;
    width: var(--gauge-circle-size);
    height: var(--gauge-circle-size);
}

.lh-category .lh-gauge {
    --gauge-circle-size: var(--gauge-circle-size-big);
}

.lh-gauge-base {
    opacity: 0.1;
}

.lh-gauge-arc {
    fill: none;
    transform-origin: 50% 50%;
    animation: load-gauge var(--transition-length) ease both;
    animation-delay: 250ms;
}

.lh-gauge__svg-wrapper {
    position: relative;
    height: var(--gauge-circle-size);
}

.lh-category .lh-gauge__svg-wrapper,
.lh-category .lh-fraction__wrapper {
    --gauge-circle-size: var(--gauge-circle-size-big);
}

/* The plugin badge overlay */
.lh-gauge__wrapper--plugin .lh-gauge__svg-wrapper::before {
    width: var(--plugin-badge-size);
    height: var(--plugin-badge-size);
    background-color: var(--plugin-badge-background-color);
    background-image: var(--plugin-icon-url);
    background-repeat: no-repeat;
    background-size: var(--plugin-icon-size);
    background-position: 58% 50%;
    content: "";
    position: absolute;
    right: -6px;
    bottom: 0px;
    display: block;
    z-index: 100;
    box-shadow: 0 0 4px rgba(0, 0, 0, .2);
    border-radius: 25%;
}

.lh-category .lh-gauge__wrapper--plugin .lh-gauge__svg-wrapper::before {
    width: var(--plugin-badge-size-big);
    height: var(--plugin-badge-size-big);
}

@keyframes load-gauge {
    from {
        stroke-dasharray: 0 352;
    }
}

.lh-gauge__percentage {
    width: 100%;
    height: var(--gauge-circle-size);
    line-height: var(--gauge-circle-size);
    position: absolute;
    font-family: var(--report-font-family-monospace);
    font-size: calc(var(--gauge-circle-size) * 0.34 + 1.3px);
    text-align: center;
    top: var(--score-container-padding);
}

.lh-category .lh-gauge__percentage {
    --gauge-circle-size: var(--gauge-circle-size-big);
    --gauge-percentage-font-size: var(--gauge-percentage-font-size-big);
}

.lh-gauge__wrapper,
.lh-fraction__wrapper {
    position: relative;
    display: flex;
    align-items: center;
    flex-direction: column;
    text-decoration: none;
    padding: var(--score-container-padding);

    --transition-length: 1s;

    /* Contain the layout style paint & layers during animation*/
    contain: content;
    will-change: opacity;
    /* Only using for layer promotion */
}

.lh-gauge__label,
.lh-fraction__label {
    font-size: var(--gauge-label-font-size);
    font-weight: 500;
    line-height: var(--gauge-label-line-height);
    margin-top: 10px;
    text-align: center;
    color: var(--report-text-color);
    word-break: keep-all;
}

/* TODO(#8185) use more BEM (.lh-gauge__label--big) instead of relying on descendant selector */
.lh-category .lh-gauge__label,
.lh-category .lh-fraction__label {
    --gauge-label-font-size: var(--gauge-label-font-size-big);
    --gauge-label-line-height: var(--gauge-label-line-height-big);
    margin-top: 14px;
}

.lh-scores-header .lh-gauge__wrapper,
.lh-scores-header .lh-fraction__wrapper,
.lh-scores-header .lh-gauge--pwa__wrapper,
.lh-sticky-header .lh-gauge__wrapper,
.lh-sticky-header .lh-fraction__wrapper,
.lh-sticky-header .lh-gauge--pwa__wrapper {
    width: var(--gauge-wrapper-width);
}

.lh-scorescale {
    display: inline-flex;

    gap: calc(var(--default-padding) * 4);
    margin: 16px auto 0 auto;
    font-size: var(--report-font-size-secondary);
    color: var(--color-gray-700);

}

.lh-scorescale-range {
    display: flex;
    align-items: center;
    font-family: var(--report-font-family-monospace);
    white-space: nowrap;
}

.lh-category-header__finalscreenshot .lh-scorescale {
    border: 0;
    display: flex;
    justify-content: center;
}

.lh-category-header__finalscreenshot .lh-scorescale-range {
    font-family: unset;
    font-size: 12px;
}

.lh-scorescale-wrap {
    display: contents;
}

/* Hide category score gauages if it's a single category report */
.lh-header--solo-category .lh-scores-wrapper {
    display: none;
}


.lh-categories {
    width: 100%;
}

.lh-category {
    padding: var(--category-padding);
    max-width: var(--report-content-max-width);
    margin: 0 auto;

    scroll-margin-top: calc(var(--sticky-header-buffer) - 1em);
}

.lh-category-wrapper {
    border-bottom: 1px solid var(--color-gray-200);
}

.lh-category-wrapper:last-of-type {
    border-bottom: 0;
}

.lh-category-header {
    margin-bottom: var(--section-padding-vertical);
}

.lh-category-header .lh-score__gauge {
    max-width: 400px;
    width: auto;
    margin: 0px auto;
}

.lh-category-header__finalscreenshot {
    display: grid;
    grid-template: none / 1fr 1px 1fr;
    justify-items: center;
    align-items: center;
    gap: var(--report-line-height);
    min-height: 288px;
    margin-bottom: var(--default-padding);
}

.lh-final-ss-image {
    /* constrain the size of the image to not be too large */
    max-height: calc(var(--gauge-circle-size-big) * 2.8);
    max-width: calc(var(--gauge-circle-size-big) * 3.5);
    border: 1px solid var(--color-gray-200);
    padding: 4px;
    border-radius: 3px;
    display: block;
}

.lh-category-headercol--separator {
    background: var(--color-gray-200);
    width: 1px;
    height: var(--gauge-circle-size-big);
}

@media screen and (max-width: 780px) {
    .lh-category-header__finalscreenshot {
        grid-template: 1fr 1fr / none
    }

    .lh-category-headercol--separator {
        display: none;
    }
}


/* 964 fits the min-width of the filmstrip */
@media screen and (max-width: 964px) {
    .lh-report {
        margin-left: 0;
        width: 100%;
    }
}

@media print {
    body {
        -webkit-print-color-adjust: exact;
        /* print background colors */
    }

    .lh-container {
        display: block;
    }

    .lh-report {
        margin-left: 0;
        padding-top: 0;
    }

    .lh-categories {
        margin-top: 0;
    }
}

.lh-table {
    position: relative;
    border-collapse: separate;
    border-spacing: 0;
    /* Can't assign padding to table, so shorten the width instead. */
    width: calc(100% - var(--audit-description-padding-left) - var(--stackpack-padding-horizontal));
    border: 1px solid var(--report-border-color-secondary);
}

.lh-table thead th {
    position: sticky;
    top: var(--sticky-header-buffer);
    z-index: 1;
    background-color: var(--report-background-color);
    border-bottom: 1px solid var(--report-border-color-secondary);
    font-weight: normal;
    color: var(--color-gray-600);
    /* See text-wrapping comment on .lh-container. */
    word-break: normal;
}

.lh-row--group {
    background-color: var(--table-group-header-background-color);
}

.lh-row--group td {
    font-weight: bold;
    font-size: 1.05em;
    color: var(--table-group-header-text-color);
}

.lh-row--group td:first-child {
    display: block;
    min-width: max-content;
    font-weight: normal;
}

.lh-row--group .lh-text {
    color: inherit;
    text-decoration: none;
    display: inline-block;
}

.lh-row--group a.lh-link:hover {
    text-decoration: underline;
}

.lh-row--group .lh-audit__adorn {
    text-transform: capitalize;
    font-weight: normal;
    padding: 2px 3px 1px 3px;
}

.lh-row--group .lh-audit__adorn1p {
    color: var(--link-color);
    border-color: var(--link-color);
}

.lh-row--group .lh-report-icon--external::before {
    content: "";
    background-repeat: no-repeat;
    width: 14px;
    height: 16px;
    opacity: 0.7;
    display: inline-block;
    vertical-align: middle;
}

.lh-row--group .lh-report-icon--external {
    visibility: hidden;
}

.lh-row--group:hover .lh-report-icon--external {
    visibility: visible;
}

.lh-dark .lh-report-icon--external::before {
    filter: invert(1);
}

/** Manages indentation of two-level and three-level nested adjacent rows */

.lh-row--group~[data-entity]:not(.lh-row--group) td:first-child {
    padding-left: 20px;
}

.lh-row--group~[data-entity]:not(.lh-row--group)~.lh-sub-item-row td:first-child {
    padding-left: 40px;
}

.lh-row--even {
    background-color: var(--table-group-header-background-color);
}

.lh-row--hidden {
    display: none;
}

.lh-table th,
.lh-table td {
    padding: var(--default-padding);
}

.lh-table tr {
    vertical-align: middle;
}

.lh-table tr:hover {
    background-color: var(--table-higlight-background-color);
}

/* Looks unnecessary, but mostly for keeping the <th>s left-aligned */
.lh-table-column--text,
.lh-table-column--source-location,
.lh-table-column--url,
/* .lh-table-column--thumbnail, */
/* .lh-table-column--empty,*/
.lh-table-column--code,
.lh-table-column--node {
    text-align: left;
}

.lh-table-column--code {
    min-width: 100px;
}

.lh-table-column--bytes,
.lh-table-column--timespanMs,
.lh-table-column--ms,
.lh-table-column--numeric {
    text-align: right;
    word-break: normal;
}



.lh-table .lh-table-column--thumbnail {
    width: var(--image-preview-size);
}

.lh-table-column--url {
    min-width: 250px;
}

.lh-table-column--text {
    min-width: 80px;
}

/* Keep columns narrow if they follow the URL column */
/* 12% was determined to be a decent narrow width, but wide enough for column headings */
.lh-table-column--url+th.lh-table-column--bytes,
.lh-table-column--url+.lh-table-column--bytes+th.lh-table-column--bytes,
.lh-table-column--url+.lh-table-column--ms,
.lh-table-column--url+.lh-table-column--ms+th.lh-table-column--bytes,
.lh-table-column--url+.lh-table-column--bytes+th.lh-table-column--timespanMs {
    width: 12%;
}

.lh-text__url-host {
    display: inline;
}

.lh-text__url-host {
    margin-left: calc(var(--report-font-size) / 2);
    opacity: 0.6;
    font-size: 90%
}

.lh-thumbnail {
    object-fit: cover;
    width: var(--image-preview-size);
    height: var(--image-preview-size);
    display: block;
}

.lh-unknown pre {
    overflow: scroll;
    border: solid 1px var(--color-gray-200);
}

.lh-text__url>a {
    color: inherit;
    text-decoration: none;
}

.lh-text__url>a:hover {
    text-decoration: underline dotted #999;
}

.lh-sub-item-row {
    margin-left: 20px;
    margin-bottom: 0;
    color: var(--color-gray-700);
}

.lh-sub-item-row td {
    padding-top: 4px;
    padding-bottom: 4px;
    padding-left: 20px;
}

/* Chevron
https://codepen.io/paulirish/pen/LmzEmK
*/
.lh-chevron {
    --chevron-angle: 42deg;
    /* Edge doesn't support transform: rotate(calc(...)), so we define it here */
    --chevron-angle-right: -42deg;
    width: var(--chevron-size);
    height: var(--chevron-size);
    margin-top: calc((var(--report-line-height) - 12px) / 2);
}

.lh-chevron__lines {
    transition: transform 0.4s;
    transform: translateY(var(--report-line-height));
}

.lh-chevron__line {
    stroke: var(--chevron-line-stroke);
    stroke-width: var(--chevron-size);
    stroke-linecap: square;
    transform-origin: 50%;
    transform: rotate(var(--chevron-angle));
    transition: transform 300ms, stroke 300ms;
}

.lh-expandable-details .lh-chevron__line-right,
.lh-expandable-details[open] .lh-chevron__line-left {
    transform: rotate(var(--chevron-angle-right));
}

.lh-expandable-details[open] .lh-chevron__line-right {
    transform: rotate(var(--chevron-angle));
}


.lh-expandable-details[open] .lh-chevron__lines {
    transform: translateY(calc(var(--chevron-size) * -1));
}

.lh-expandable-details[open] {
    animation: 300ms openDetails forwards;
    padding-bottom: var(--default-padding);
}

@keyframes openDetails {
    from {
        outline: 1px solid var(--report-background-color);
    }

    to {
        outline: 1px solid;
        box-shadow: 0 2px 4px rgba(0, 0, 0, .24);
    }
}

@media screen and (max-width: 780px) {

    /* no black outline if we're not confident the entire table can be displayed within bounds */
    .lh-expandable-details[open] {
        animation: none;
    }
}

.lh-expandable-details[open] summary,
details.lh-clump>summary {
    border-bottom: 1px solid var(--report-border-color-secondary);
}

details.lh-clump[open]>summary {
    border-bottom-width: 0;
}



details .lh-clump-toggletext--hide,
details[open] .lh-clump-toggletext--show {
    display: none;
}

details[open] .lh-clump-toggletext--hide {
    display: block;
}


/* Tooltip */
.lh-tooltip-boundary {
    position: relative;
}

.lh-tooltip {
    position: absolute;
    display: none;
    /* Don't retain these layers when not needed */
    opacity: 0;
    background: #ffffff;
    white-space: pre-line;
    /* Render newlines in the text */
    min-width: 246px;
    max-width: 275px;
    padding: 15px;
    border-radius: 5px;
    text-align: initial;
    line-height: 1.4;
}

/* shrink tooltips to not be cutoff on left edge of narrow viewports
45vw is chosen to be ~= width of the left column of metrics
*/
@media screen and (max-width: 535px) {
    .lh-tooltip {
        min-width: 45vw;
        padding: 3vw;
    }
}

.lh-tooltip-boundary:hover .lh-tooltip {
    display: block;
    animation: fadeInTooltip 250ms;
    animation-fill-mode: forwards;
    animation-delay: 850ms;
    bottom: 100%;
    z-index: 1;
    will-change: opacity;
    right: 0;
    pointer-events: none;
}

.lh-tooltip::before {
    content: "";
    border: solid transparent;
    border-bottom-color: #fff;
    border-width: 10px;
    position: absolute;
    bottom: -20px;
    right: 6px;
    transform: rotate(180deg);
    pointer-events: none;
}

@keyframes fadeInTooltip {
    0% {
        opacity: 0;
    }

    75% {
        opacity: 1;
    }

    100% {
        opacity: 1;
        filter: drop-shadow(1px 0px 1px #aaa) drop-shadow(0px 2px 4px hsla(206, 6%, 25%, 0.15));
        pointer-events: auto;
    }
}

/* Element screenshot */
.lh-element-screenshot {
    float: left;
    margin-right: 20px;
}

.lh-element-screenshot__content {
    overflow: hidden;
    min-width: 110px;
    display: flex;
    justify-content: center;
    background-color: var(--report-background-color);
}

.lh-element-screenshot__image {
    position: relative;
    /* Set by ElementScreenshotRenderer.installFullPageScreenshotCssVariable */
    background-image: var(--element-screenshot-url);
    outline: 2px solid #777;
    background-color: white;
    background-repeat: no-repeat;
}

.lh-element-screenshot__mask {
    position: absolute;
    background: #555;
    opacity: 0.8;
}

.lh-element-screenshot__element-marker {
    position: absolute;
    outline: 2px solid var(--color-lime-400);
}

.lh-element-screenshot__overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2000;
    /* .lh-topbar is 1000 */
    background: var(--screenshot-overlay-background);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-out;
}

.lh-element-screenshot__overlay .lh-element-screenshot {
    margin-right: 0;
    /* clearing margin used in thumbnail case */
    outline: 1px solid var(--color-gray-700);
}

.lh-screenshot-overlay--enabled .lh-element-screenshot {
    cursor: zoom-out;
}

.lh-screenshot-overlay--enabled .lh-node .lh-element-screenshot {
    cursor: zoom-in;
}


.lh-meta__items {
    --meta-icon-size: calc(var(--report-icon-size) * 0.667);
    padding: var(--default-padding);
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    background-color: var(--env-item-background-color);
    border-radius: 3px;
    margin: 0 0 var(--default-padding) 0;
    font-size: 12px;
    column-gap: var(--default-padding);
    color: var(--color-gray-700);
}

.lh-meta__item {
    display: block;
    list-style-type: none;
    position: relative;
    padding: 0 0 0 calc(var(--meta-icon-size) + var(--default-padding) * 2);
    cursor: unset;
    /* disable pointer cursor from report-icon */
}

.lh-meta__item.lh-tooltip-boundary {
    text-decoration: dotted underline var(--color-gray-500);
    cursor: help;
}

.lh-meta__item.lh-report-icon::before {
    position: absolute;
    left: var(--default-padding);
    width: var(--meta-icon-size);
    height: var(--meta-icon-size);
}

.lh-meta__item.lh-report-icon:hover::before {
    opacity: 0.7;
}

.lh-meta__item .lh-tooltip {
    color: var(--color-gray-800);
}

.lh-meta__item .lh-tooltip::before {
    right: auto;
    /* Set the tooltip arrow to the leftside */
    left: 6px;
}

/* Change the grid for narrow viewport. */
@media screen and (max-width: 640px) {
    .lh-meta__items {
        grid-template-columns: 1fr 1fr;
    }
}

@media screen and (max-width: 535px) {
    .lh-meta__items {
        display: block;
    }
}

/* Explodey gauge */

.lh-exp-gauge-component {
    margin-bottom: 10px;
}

.lh-exp-gauge-component circle {
    stroke: currentcolor;
    r: var(--radius);
}

.lh-exp-gauge-component text {
    font-size: calc(var(--radius) * 0.2);
}

.lh-exp-gauge-component .lh-exp-gauge {
    margin: 0 auto;
    width: 225px;
    stroke-width: var(--stroke-width);
    stroke-linecap: round;

    /* for better rendering perf */
    contain: strict;
    height: 225px;
    will-change: transform;
}

.lh-exp-gauge-component .lh-exp-gauge--faded {
    opacity: 0.1;
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper {
    font-family: var(--report-font-family-monospace);
    text-align: center;
    text-decoration: none;
    transition: .3s;
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper--pass {
    color: var(--color-pass);
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper--average {
    color: var(--color-average);
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper--fail {
    color: var(--color-fail);
}

.lh-exp-gauge-component .state--expanded {
    transition: color .3s;
}

.lh-exp-gauge-component .state--highlight {
    color: var(--color-highlight);
}

.lh-exp-gauge-component .lh-exp-gauge__svg-wrapper {
    display: flex;
    flex-direction: column-reverse;
}

.lh-exp-gauge-component .lh-exp-gauge__label {
    fill: var(--report-text-color);
    font-family: var(--report-font-family);
    font-size: 12px;
}

.lh-exp-gauge-component .lh-exp-gauge__cutout {
    opacity: .999;
    transition: opacity .3s;
}

.lh-exp-gauge-component .state--highlight .lh-exp-gauge__cutout {
    opacity: 0;
}

.lh-exp-gauge-component .lh-exp-gauge__inner {
    color: inherit;
}

.lh-exp-gauge-component .lh-exp-gauge__base {
    fill: currentcolor;
}


.lh-exp-gauge-component .lh-exp-gauge__arc {
    fill: none;
    transition: opacity .3s;
}

.lh-exp-gauge-component .lh-exp-gauge__arc--metric {
    color: var(--metric-color);
    stroke-dashoffset: var(--metric-offset);
    opacity: 0.3;
}

.lh-exp-gauge-component .lh-exp-gauge-hovertarget {
    color: currentcolor;
    opacity: 0.001;
    stroke-linecap: butt;
    stroke-width: 24;
    /* hack. move the hover target out of the center. ideally i tweak the r instead but that rquires considerably more math. */
    transform: scale(1.15);
}

.lh-exp-gauge-component .lh-exp-gauge__arc--metric.lh-exp-gauge--miniarc {
    opacity: 0;
    stroke-dasharray: 0 calc(var(--circle-meas) * var(--radius));
    transition: 0s .005s;
}

.lh-exp-gauge-component .state--expanded .lh-exp-gauge__arc--metric.lh-exp-gauge--miniarc {
    opacity: .999;
    stroke-dasharray: var(--metric-array);
    transition: 0.3s;
    /*  calc(.005s + var(--i)*.05s); entrace animation */
}

.lh-exp-gauge-component .state--expanded .lh-exp-gauge__inner .lh-exp-gauge__arc {
    opacity: 0;
}


.lh-exp-gauge-component .lh-exp-gauge__percentage {
    text-anchor: middle;
    dominant-baseline: middle;
    opacity: .999;
    font-size: calc(var(--radius) * 0.625);
    transition: opacity .3s ease-in;
}

.lh-exp-gauge-component .state--highlight .lh-exp-gauge__percentage {
    opacity: 0;
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper--fail .lh-exp-gauge__percentage {
    fill: var(--color-fail);
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper--average .lh-exp-gauge__percentage {
    fill: var(--color-average);
}

.lh-exp-gauge-component .lh-exp-gauge__wrapper--pass .lh-exp-gauge__percentage {
    fill: var(--color-pass);
}

.lh-exp-gauge-component .lh-cover {
    fill: none;
    opacity: .001;
    pointer-events: none;
}

.lh-exp-gauge-component .state--expanded .lh-cover {
    pointer-events: auto;
}

.lh-exp-gauge-component .metric {
    transform: scale(var(--scale-initial));
    opacity: 0;
    transition: transform .1s .2s ease-out, opacity .3s ease-out;
    pointer-events: none;
}

.lh-exp-gauge-component .metric text {
    pointer-events: none;
}

.lh-exp-gauge-component .metric__value {
    fill: currentcolor;
    opacity: 0;
    transition: opacity 0.2s;
}

.lh-exp-gauge-component .state--expanded .metric {
    transform: scale(1);
    opacity: .999;
    transition: transform .3s ease-out, opacity .3s ease-in, stroke-width .1s ease-out;
    transition-delay: calc(var(--i)*.05s);
    pointer-events: auto;
}

.lh-exp-gauge-component .state--highlight .metric {
    opacity: .3;
}

.lh-exp-gauge-component .state--highlight .metric--highlight {
    opacity: .999;
    stroke-width: calc(1.5*var(--stroke-width));
}

.lh-exp-gauge-component .state--highlight .metric--highlight .metric__value {
    opacity: 0.999;
}


/*
the initial first load peek
*/
.lh-exp-gauge-component .lh-exp-gauge__bg {
    /* needed for the use zindex stacking w/ transparency */
    fill: var(--report-background-color);
    stroke: var(--report-background-color);
}

.lh-exp-gauge-component .state--peek .metric {
    transition-delay: 0ms;
    animation: peek var(--peek-dur) cubic-bezier(0.46, 0.03, 0.52, 0.96);
    animation-fill-mode: forwards;
}

.lh-exp-gauge-component .state--peek .lh-exp-gauge__inner .lh-exp-gauge__arc {
    opacity: 1;
}

.lh-exp-gauge-component .state--peek .lh-exp-gauge__arc.lh-exp-gauge--faded {
    opacity: 0.3;
    /* just a tad stronger cuz its fighting with a big solid arg */
}

/* do i need to set expanded and override this? */
.lh-exp-gauge-component .state--peek .lh-exp-gauge__arc--metric.lh-exp-gauge--miniarc {
    transition: opacity 0.3s;
}

.lh-exp-gauge-component .state--peek {
    color: unset;
}

.lh-exp-gauge-component .state--peek .metric__label {
    display: none;
}

.lh-exp-gauge-component .metric__label {
    fill: var(--report-text-color);
}

@keyframes peek {

    /* biggest it should go is 0.92. smallest is 0.8 */
    0% {
        transform: scale(0.8);
        opacity: 0.8;
    }

    50% {
        transform: scale(0.92);
        opacity: 1;
    }

    100% {
        transform: scale(0.8);
        opacity: 0.8;
    }
}

.lh-exp-gauge-component .wrapper {
    width: 620px;
}