Skip to content
https://www.spotify.com

Performance

· 14 checks — Lighthouse + waterfall + sustainability rolled into one auditable list.
SCORE
65
GRADE
D
FIX
5
REVIEW
1
PASS
6
INFO
2

Performance-focused optimization plan with CWV assessment, top offenders, and time estimates

32
Performance Overall performance score (0–100) based on Core Web Vitals and other metrics. 90+ is good.
93
Accessibility Measures how accessible the page is for users with disabilities. Checks color contrast, ARIA labels, and semantic HTML.
96
Best Practices Checks for modern web development best practices including HTTPS, no console errors, and secure JavaScript.
100
SEO Measures basic SEO optimizations: meta tags, crawlability, link text, and mobile friendliness.

First Contentful Paint First Contentful Paint — how long until the browser renders the first piece of content. Under 1.8s is good.

8.66 s

Largest Contentful Paint Largest Contentful Paint — how long until the largest visible element loads. Under 2.5s is good.

22.89 s

Total Blocking Time Total Blocking Time — total time the main thread was blocked, preventing user input. Under 200ms is good.

1.23 s

Cumulative Layout Shift Cumulative Layout Shift — measures visual stability. How much the page layout shifts during loading. Under 0.1 is good.

0.003

Speed Index Speed Index — how quickly content is visually displayed during load. Under 3.4s is good.

9.93 s

Time to Interactive Time to Interactive — how long until the page is fully interactive and responds to user input. Under 3.8s is good.

23.29 s

Page Load Progression

375 ms
750 ms
1.1 s
1.5 s
1.9 s
2.2 s
2.6 s
3.0 s
Checks
14
6 PASS 1 REVIEW 5 FIX
F
Page Weight Budget
Action
4.5 MB transferred, 152 requests
FIX
4.5 MB transferred, 152 requests
Critical::
Page weighs 8.1 MB (4.5 MB transferred)
Warning::
Images are 2.3 MB — compress or use modern formats
Convert images to WebP/AVIF and resize to display dimensions to reduce transfer size.
Got: 2.3 MB
Warning::
JavaScript is 1.1 MB — consider code splitting or lazy loading
Large JavaScript bundles delay interactivity. Split code by route or defer non-critical scripts.
Got: 1.1 MB
Info::
Fonts are 935 KB — consider subsetting or using system fonts
Subset fonts to include only used characters, or switch to system font stacks.
Got: 935 KB
Warning::
152 HTTP requests — consider bundling or reducing
Each request adds latency. Bundle small files, use sprites, or eliminate unnecessary requests.
Info::
Estimated 0.94 g CO2 per page load
4.5 MB / 2.4 MB budget
4.5 MB transferred
152 requests
0.94 g CO2 per page load
Images 2.3 MiB 51%
JavaScript 1.1 MiB 24%
Fonts 935.3 KiB 20%
Other 56.9 KiB 1%
CSS 49.7 KiB 1%
Other 45.4 KiB 1%
HTML 22.0 KiB 0%
Other 4.2 KiB 0%
Other 672 B 0%
Other 0 B 0%
0 2.4 MB 4.9 MB
Over budget

Convert images to WebP/AVIF and resize to display dimensions to reduce transfer size.

Why this matters

Image bandwidth is high — modern formats (WebP/AVIF) and resizing typically cut it 50%+.

Source: web.dev

Large JavaScript bundles delay interactivity. Split code by route or defer non-critical scripts.

Why this matters

JavaScript bundle is large — code-split routes and lazy-load off-screen components to defer.

Source: web.dev

Subset fonts to include only used characters, or switch to system font stacks.

Why this matters

Font payload is large — subset to used glyphs only, or fall back to system fonts (zero load time).

Source: web.dev font loading

Each request adds latency. Bundle small files, use sprites, or eliminate unnecessary requests.

Why this matters

High HTTP request count — bundling, sprite-ing, and HTTP/2 server push can reduce per-request overhead.

Source: web.dev

D
Third-Party Impact
Action
100% third-party, 0 ms blocking
FIX
100% third-party, 0 ms blocking
Warning::
Third-party code accounts for 100% of page weight (4.5 MiB of 4.5 MiB)
Info::
Third-party blocking time is low (0 ms)
100%
First-party Third-party
F
JS Execution Cost
Action
5321ms total JS execution
FIX
5321ms total JS execution
Warning::
https://open.spotifycdn.com/cdn/build/mobile-web-p...: 2437ms CPU time
Warning::
Unattributable: 1515ms CPU time
Warning::
https://www.googletagmanager.com/gtm.js?id=GTM-PZH...: 455ms CPU time
Warning::
https://cdn.cookielaw.org/scripttemplates/202601.2...: 280ms CPU time
Warning::
https://open.spotify.com/: 277ms CPU time
Warning::
Third-party scripts: 5321ms (100% of total)

Main Thread Breakdown

Script Evaluation 52% Other 28% Script Parsing & Compilation 9% Style & Layout 5%
ScriptTotalScriptingParse/CompileParty
https://open.spotifycdn.com/cdn/build/mobile-web-player/vendor~mobile-web-player.adc02ae3.js2437ms2036ms223ms3rd
Unattributable1515ms73ms0ms3rd
https://www.googletagmanager.com/gtm.js?id=GTM-PZHN3VD455ms393ms49ms3rd
https://cdn.cookielaw.org/scripttemplates/202601.2.0/otBannerSdk.js280ms207ms52ms3rd
https://open.spotify.com/277ms5ms1ms3rd
https://open.spotifycdn.com/cdn/build/mobile-web-player/mobile-web-player.64588ce0.js199ms7ms152ms3rd
https://cdn.cookielaw.org/scripttemplates/otSDKStub.js91ms41ms3ms3rd
https://pixel-static.spotify.com/sync.min.js66ms40ms4ms3rd
F
JS Bundles
Action
14 scripts, 595 KB unused
FIX
14 scripts, 595 KB unused
Warning::
https://open.spotifycdn.com/cdn/build/mobile-web-p...: 257 KB unused (78%)
Consider code splitting or tree shaking to reduce unused code.
Warning::
https://open.spotifycdn.com/cdn/build/mobile-web-p...: 180 KB unused (40%)
Consider code splitting or tree shaking to reduce unused code.
Warning::
https://www.googletagmanager.com/gtm.js?id=GTM-PZH...: 83 KB unused (53%)
Consider code splitting or tree shaking to reduce unused code.
Warning::
https://cdn.cookielaw.org/scripttemplates/202601.2...: 74 KB unused (58%)
Consider code splitting or tree shaking to reduce unused code.
Info::
Total unused JavaScript: 595 KB
595 KB unused JavaScript

Downloaded but never executed on this page.

ScriptSizeUnusedMinifiedParty
https://open.spotifycdn.com/cdn/build/mobile-web-player/mobile-web-player.64588ce0.js332 KB257 KB (78%)3rd
https://open.spotifycdn.com/cdn/build/mobile-web-player/vendor~mobile-web-player.adc02ae3.js465 KB180 KB (40%)3rd
https://www.googletagmanager.com/gtm.js?id=GTM-PZHN3VD157 KB83 KB (53%)3rd
https://cdn.cookielaw.org/scripttemplates/202601.2.0/otBannerSdk.js128 KB74 KB (58%)3rd
https://open.spotifycdn.com/cdn/js/retargeting-pixels.02346b5d.js1 KB3rd
https://open.spotifycdn.com/cdn/build/mobile-web-player/mwp-search-landing.c5766988.js2 KB3rd
https://open.spotifycdn.com/cdn/build/mobile-web-player/mwp-search-results.4f1e7d27.js6 KB3rd
https://open.spotifycdn.com/cdn/build/mobile-web-player/mwp-download-page.7990c6f0.js1 KB3rd
https://cdn.cookielaw.org/scripttemplates/otSDKStub.js9 KB3rd
https://open.spotifycdn.com/cdn/build/mobile-web-player/mwp-home-page.b53fc9ee.js6 KB3rd

Consider code splitting or tree shaking to reduce unused code.

Why this matters

This bundle has high unused code — code-split or tree-shake to ship only what executes.

Source: web.dev / Lighthouse coverage

Consider code splitting or tree shaking to reduce unused code.

Why this matters

This bundle has high unused code — code-split or tree-shake to ship only what executes.

Source: web.dev / Lighthouse coverage

Consider code splitting or tree shaking to reduce unused code.

Why this matters

This bundle has high unused code — code-split or tree-shake to ship only what executes.

Source: web.dev / Lighthouse coverage

Consider code splitting or tree shaking to reduce unused code.

Why this matters

This bundle has high unused code — code-split or tree-shake to ship only what executes.

Source: web.dev / Lighthouse coverage

F
HTTP Caching
Action
No cache headers
FIX
No cache headers
Warning::
No Cache-Control header found
Browsers will use heuristic caching, which can be unpredictable. Set explicit cache headers.

No Cache-Control header

Adding a Cache-Control header can significantly improve repeat-visit performance.

C
Image Optimization
Action
91 images, 0 KB saveable
REVIEW
91 images, 0 KB saveable
Warning::
https://i.scdn.co/image/ab67616d00001e027bbde623de... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051744293385d32... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174df2728294f... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174fd0a9fb6c2... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02a3a9e489e7... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174aadc18cac8... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174c8752dd511... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e0271d62ea7ea... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e0249d6942032... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051741ba8fc5f5c... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e0235ea219ce4... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174cb565a8e68... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174e2e8e7ff00... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051747565b356bc... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e025c0540f97b... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02ee6a59212d... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab6761610000517439ba6dcd43... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02882265cd9b... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02f036cfd075... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://charts-images.scdn.co/assets/locale_en/vir... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e021d9a8caa24... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174a00b11c129... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02bbd45c8d36... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02b5a28a256e... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e023dc16f4849... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02603c61308d... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02fb7dcc6287... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174998010cd10... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02fd8d7a8d96... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e0295184f6a95... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174e17c0aa171... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051746e835a500e... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051747eaa373538... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02f8e1043df4... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://charts-images.scdn.co/assets/locale_en/reg... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616100005174ad85a58510... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab6761610000517478e45cfa46... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e028aa339341a... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02a0b1930ce3... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e021e9a057052... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051749e528993a2... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02084a949885... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02982320da13... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e029382b279fa... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e027b1b6f41c1... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e026b219c8d84... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02d72fb55710... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://charts-images.scdn.co/assets/locale_en/reg... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://charts-images.scdn.co/assets/locale_en/vir... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02dd064d1386... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e025d6505356d... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02509cf9888c... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02a53811f379... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02bc18bdade6... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e0296fa88fb17... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://charts-images.scdn.co/assets/locale_en/reg... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02bd247b0f79... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab6761610000517447de0bbc22... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02d9985092cd... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02c5649add07... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://charts-images.scdn.co/assets/locale_en/reg... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02dffaa485f4... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab676161000051744a21b4760d... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02da5d5aeeab... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://pickasso.spotifycdn.com/image/ab67c0de0000... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e023d49234ac7... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
https://i.scdn.co/image/ab67616d00001e02c787ddcc2d... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
91 images 2.3 MB
0 oversized -0 KB
91 legacy format
86 missing dimensions CLS risk

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

Set explicit width and height to prevent CLS.

Why this matters

Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.

Source: web.dev / Core Web Vitals

A+
Text Compression
All text resources are compressed
PASS
All text resources are compressed
Info::
All text resources are compressed
All text resources are properly compressed.
A+
Font Loading
7 fonts (935 KB)
PASS
7 fonts (935 KB)
Info::
7 font(s) use font-display: swap (FOUT risk but functional)

Web fonts

7

935 KB total

Render-blocking

0

of 7

Dominant font-display

swap

Most common across fonts

Font loading timeline
Transfer FOIT (block) FOUT (swap)
0 ms 2.0 s 4.0 s 6.0 s 8.0 s 10.0 s 12.0 s 14.0 s 16.0 s 18.0 s 20.0 s 22.0 s 24.0 s FCP 8.7 s LCP 22.9 shttps://encore.scdn.co/fonts/SpotifyMixUI-Regular-76c92fb1a35c462f73429fa8865163eb.woff2SpotifyMixUI-Regular-76... https://encore.scdn.co/fonts/SpotifyMixUI-Regular-76c92fb1a35c462f73429fa8865163eb.woff2 — 43.7 KiB — 0 ms — font-display: swaphttps://encore.scdn.co/fonts/SpotifyMixMono-Regular-134eeb986fc0f94a9f0acb9cedaeb584.woff2SpotifyMixMono-Regular-... https://encore.scdn.co/fonts/SpotifyMixMono-Regular-134eeb986fc0f94a9f0acb9cedaeb584.woff2 — 33.8 KiB — 0 ms — font-display: swaphttps://encore.scdn.co/fonts/SpotifyMixUITitleVariable-08bab3354d40f74e5177917b5ae80894.woff2SpotifyMixUITitleVariab... https://encore.scdn.co/fonts/SpotifyMixUITitleVariable-08bab3354d40f74e5177917b5ae80894.woff2 — 361.9 KiB — 0 ms — font-display: swaphttps://encore.scdn.co/fonts/SpotifyMixUI-Bold-09c45a3a0ce9d2971e62cb26e97760fb.woff2SpotifyMixUI-Bold-09c45... https://encore.scdn.co/fonts/SpotifyMixUI-Bold-09c45a3a0ce9d2971e62cb26e97760fb.woff2 — 46.7 KiB — 0 ms — font-display: swaphttps://encore.scdn.co/fonts/SpotifyMixUITitleVariable-8769ccfde3379b7ebcadd9529b49d0cc.woff2SpotifyMixUITitleVariab... https://encore.scdn.co/fonts/SpotifyMixUITitleVariable-8769ccfde3379b7ebcadd9529b49d0cc.woff2 — 373.4 KiB — 0 ms — font-display: swaphttps://encore.scdn.co/fonts/SpotifyMixUI-Regular-cc3b1de388efa4cbca6c75cebc24585e.woff2SpotifyMixUI-Regular-cc... https://encore.scdn.co/fonts/SpotifyMixUI-Regular-cc3b1de388efa4cbca6c75cebc24585e.woff2 — 35.0 KiB — 0 ms — font-display: swaphttps://encore.scdn.co/fonts/SpotifyMixUI-Bold-4264b799009b1db5c491778b1bc8e5b7.woff2SpotifyMixUI-Bold-4264b... https://encore.scdn.co/fonts/SpotifyMixUI-Bold-4264b799009b1db5c491778b1bc8e5b7.woff2 — 40.7 KiB — 0 ms — font-display: swap
SpotifyMixUI-Regular-76... woff2 swap
Size 44 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
SpotifyMixMono-Regular-... woff2 swap
Size 34 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
SpotifyMixUITitleVariab... woff2 swap
Size 362 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
  • Subset this font — over 100 KB suggests Latin Extended or full glyph coverage that most pages don't need
SpotifyMixUI-Bold-09c45... woff2 swap
Size 47 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
SpotifyMixUITitleVariab... woff2 swap
Size 373 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
  • Subset this font — over 100 KB suggests Latin Extended or full glyph coverage that most pages don't need
SpotifyMixUI-Regular-cc... woff2 swap
Size 35 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
SpotifyMixUI-Bold-4264b... woff2 swap
Size 41 KB
Load time 0 ms
Start 0 ms
Risk FOUT — text flashes from fallback to web font
Optimization checklist
  • Preload critical fonts (priority=high)
  • Use woff2 format for all fonts
  • Set font-display to swap, optional, or fallback
  • Subset large fonts (≤100 KB each)

Fixing the unchecked items could save ~368 KB and ~736 ms

A+
Resource Caching
All resources properly cached
PASS
All resources properly cached
Info::
No caching issues found
All static resources have appropriate caching headers.
A+
Critical Rendering Path
No render-blocking resources
PASS
No render-blocking resources
Info::
No render-blocking resources detected
A+
Resource Hints
38 hints, 0 missing preconnects
PASS
38 hints, 0 missing preconnects
Info::
Page uses 38 resource hint(s)

Current Resource Hints

preconnect
+6
16
preload
6
dns-prefetch
prefetch
+6
16

38 resource hints configured

A+
Green Hosting
Whether the site is served from green-energy infrastructure
PASS

Green Hosting

This site is hosted on green energy infrastructure

Provider: Google Cloud

Network Waterfall
152 requests over 0ms
INFO

Performance analysis not available for this result.

Third-Party Script Cost
Per-script blocking time, transfer cost, and cache headers
INFO
100% of JavaScript execution is third-party
First-party Third-party 5321ms · 1116KB · $71/mo
open.spotifycdn.com
Other
Costly
Execution 2437ms
Transfer 465 KB
Unused 40%
Monthly Cost $32/mo
Unattributable
Other
Costly
Execution 1515ms
Transfer 0 KB
Monthly Cost $20/mo
Google Tag Manager
Tag Manager
Costly
Execution 455ms
Transfer 157 KB
Unused 53%
Monthly Cost $6/mo
OneTrust
Consent
Essential
Execution 280ms
Transfer 128 KB
Unused 58%
Monthly Cost $4/mo
open.spotify.com
Other
Costly
Execution 277ms
Transfer 22 KB
Monthly Cost $4/mo
open.spotifycdn.com
Other
Optional
Execution 199ms
Transfer 332 KB
Unused 78%
Monthly Cost $3/mo
OneTrust
Consent
Essential
Execution 91ms
Transfer 9 KB
Monthly Cost $1/mo
pixel-static.spotify.com
Other
Optional
Execution 66ms
Transfer 2 KB
Monthly Cost $1/mo

These scripts may cost more than they're worth

  • open.spotifycdn.com adds 2437ms and costs ~$32/month
  • Unattributable adds 1515ms and costs ~$20/month
  • Google Tag Manager adds 455ms and costs ~$6/month
  • open.spotify.com adds 277ms and costs ~$4/month

100% of JavaScript execution time is spent on third-party scripts. Consider auditing which scripts are essential.

Why this matters

When third-party JS execution time exceeds your own, performance gains from frontend work are capped by code you don't own.

Learn more

Every millisecond of third-party JS competes with your own for main-thread time. If their share is bigger than yours, optimization on your code base barely moves the needle. Audit, defer, or remove third-parties before further frontend optimization. Use Lighthouse's third-party audit to identify the worst offenders.

Source: web.dev

open.spotifycdn.com takes 2437ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.

Why this matters

This script has high main-thread execution time — optimize hot paths or defer.

Source: web.dev

Unattributable takes 1515ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.

Why this matters

This script has high main-thread execution time — optimize hot paths or defer.

Source: web.dev

Google Tag Manager takes 455ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.

Why this matters

This script has high main-thread execution time — optimize hot paths or defer.

Source: web.dev

53% of Google Tag Manager's code is unused. The script may be loading features you don't use.

Why this matters

Bundle has high unused-code ratio — tree-shaking and route-splitting recover the wasted bytes.

Source: web.dev

58% of OneTrust's code is unused. The script may be loading features you don't use.

Why this matters

Bundle has high unused-code ratio — tree-shaking and route-splitting recover the wasted bytes.

Source: web.dev

open.spotify.com takes 277ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.

Why this matters

This script has high main-thread execution time — optimize hot paths or defer.

Source: web.dev

78% of open.spotifycdn.com's code is unused. The script may be loading features you don't use.

Why this matters

Bundle has high unused-code ratio — tree-shaking and route-splitting recover the wasted bytes.

Source: web.dev

How third-party costs are calculated

All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.

Send Feedback