Consider code splitting or tree shaking to reduce unused code.
Info::
i
Total unused JavaScript: 347 KB
347 KBunused JavaScript
Downloaded but never executed on this page.
Script
Size
Unused
Minified
Party
https://danbritdirect.dk/_nuxt/CawlrmtO.js
183 KB
136 KB (74%)
✓
1st
https://danbritdirect.dk/_nuxt/oOnxIdNT.js
189 KB
99 KB (52%)
✓
1st
https://danbritdirect.dk/_nuxt/Dhhuls5Z.js
216 KB
91 KB (42%)
✓
1st
https://danbritdirect.dk/_nuxt/Cvx4-kRg.js
29 KB
21 KB (73%)
✓
1st
https://danbritdirect.dk/_nuxt/C_JFDrwi.js
12 KB
—
✓
1st
https://danbritdirect.dk/_nuxt/DMIgmvcg.js
3 KB
—
✓
1st
https://danbritdirect.dk/_nuxt/DlAUqK2U.js
0 KB
—
✓
1st
https://danbritdirect.dk/_nuxt/CgObTMGp.js
15 KB
—
✓
1st
https://danbritdirect.dk/_nuxt/DITiaI51.js
6 KB
—
✓
1st
https://danbritdirect.dk/_nuxt/CKVBbhkI.js
10 KB
—
✓
1st
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.
B
Page Weight Budget
1.5 MB transferred, 115 requests
REVIEW
1.5 MB transferred, 115 requests
Info::
i
Page weighs 3.6 MB (1.5 MB transferred)
Warning::
!
JavaScript is 779 KB — consider code splitting or lazy loading
Large JavaScript bundles delay interactivity. Split code by route or defer non-critical scripts.
Got: 779 KB
Warning::
!
115 HTTP requests — consider bundling or reducing
Each request adds latency. Bundle small files, use sprites, or eliminate unnecessary requests.
Info::
i
Estimated 0.31 g CO2 per page load
1.5 MBtransferred
115 requests
0.31 g CO2 per page load
JavaScript778.8 KiB51%
Images457.1 KiB30%
Other168.8 KiB11%
Fonts46.3 KiB3%
CSS45.5 KiB3%
HTML25.3 KiB2%
Other5.2 KiB0%
Other0 B0%
02.4 MB4.9 MB
Approaching limit
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
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
B
Image Optimization
31 images, 0 KB saveable
REVIEW
31 images, 0 KB saveable
Warning::
!
https://api.live.danbrit.norriq.dev/images/proxy/_... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
!
https://danbritdirect.dk/images/logo.svg is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
!
https://api.live.danbrit.norriq.dev/images/proxy/_... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
!
https://api.live.danbrit.norriq.dev/images/proxy/_... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
!
https://api.live.danbrit.norriq.dev/images/proxy/_... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
Warning::
!
https://api.live.danbrit.norriq.dev/images/proxy/_... is missing width/height — may cause layout shift
Set explicit width and height to prevent CLS.
31images457 KB
0oversized-0 KB
1legacy format
6missing dimensionsCLS 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
B
HTTP/3 (QUIC)
HTTP/3 not advertised
REVIEW
HTTP/3 not advertised
Info::
i
HTTP/3 (QUIC) is not advertised
HTTP/3 isn't advertised via Alt-Svc and the worker didn't negotiate h3. HTTP/3 reduces handshake latency (1-RTT instead of 2-3 RTTs) and is more resilient on lossy connections. Most modern CDNs (Cloudflare, Fastly, AWS CloudFront, Google Cloud CDN) support HTTP/3 with a single config switch -- consider enabling for mobile-heavy workloads.
B
Compression Algorithm
Main response uses gzip; brotli would be ~20% smaller
REVIEW
Main response uses gzip; brotli would be ~20% smaller
Info::
i
Main HTML response uses gzip (brotli would be ~20% smaller)
All current browsers support brotli. Most CDNs (Cloudflare, Fastly, AWS CloudFront, Vercel, Netlify) can switch from gzip to brotli with a single config flag. Origin servers (nginx, Apache) need a brotli module compiled in -- nginx-brotli or Apache mod_brotli.
B
Main HTML Cache-Control
No Cache-Control header on main HTML response
REVIEW
No Cache-Control header on main HTML response
Info::
i
Main HTML response has no Cache-Control header
Without an explicit Cache-Control, browsers fall back to heuristic caching (~10% of Last-Modified age). Set `Cache-Control: no-cache` or `max-age=300` for HTML to control freshness explicitly -- prevents stale auth state and SPA shell drift.
B
Server-Timing Observability
No Server-Timing header found
REVIEW
No Server-Timing header found
Info::
i
No Server-Timing header found
Server-Timing exposes backend timing breakdowns to browser DevTools (e.g., `db: 45ms; render: 120ms; cache: 2ms`). Useful for diagnosing slow pages without backend log access. Most modern frameworks (Next.js, Cloudflare Workers, Fastly) emit it automatically; absence on a managed platform usually means telemetry headers are stripped at the edge.
1 render-blocking <script src> tag(s) without async/defer
Each `<script src=...>` without `async`, `defer`, or `type="module"` blocks HTML parsing while the browser fetches and executes it. The block lasts the entire round-trip + execution time -- on slow networks this translates directly into LCP delay. Add `defer` (executes after parse, in source order) for scripts that interact with the DOM, or `async` (executes whenever ready) for analytics / independent scripts. Module scripts (`type="module"`) are deferred by default.
Warning::
!
Total JS execution time is 8.5 s -- over the 3.5s budget
Total JavaScript execution (parse + compile + run) across all scripts exceeds 3.5 seconds. On low-end devices that becomes 7-15+ seconds and shows up directly in TBT and INP. Reduce by: tree-shaking unused dependencies, code-splitting (dynamic `import()`), removing or deferring third-party tracking, and replacing heavy frameworks where they're not needed.
A
Third-Party Impact
22% third-party, 0 ms blocking
PASS
22% third-party, 0 ms blocking
Info::
i
Third-party code accounts for 22% of page weight (337.9 KiB of 1.5 MiB)
Info::
✓
Third-party blocking time is low (0 ms)
78%
22%
First-party Third-party
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
2 fonts (46 KB)
PASS
2 fonts (46 KB)
Info::
i
2 font(s) use font-display: swap (FOUT risk but functional)
Web fonts
2
46 KB total
Render-blocking
0
of 2
Dominant font-display
swap
Most common across fonts
Font loading timeline
TransferFOIT (block)FOUT (swap)
Lato-normal-400-latin.B...woff2swap
Size23 KB
Load time149 ms
Start768 ms
RiskFOUT — text flashes from fallback to web font
Lato-normal-700-latin.B...woff2swap
Size23 KB
Load time160 ms
Start768 ms
RiskFOUT — 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)
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
No optimization needed
PASS
No optimization needed
Info::
✓
No resource hint issues
A+
LCP Image Preload
LCP preload audit not available
PASS
LCP preload audit not available
Info::
✓
LCP image preload audit not available for this scan
A+
Server Response Intelligence
2 server-response signal(s) detected
PASS
2 server-response signal(s) detected
Info::
✓
`Vary` header declared: Accept-Encoding
The page declares a `Vary` header, telling downstream caches which request headers the response varies on. Critical for content-negotiated responses (compression, language, cookies, device class).
Info::
i
No `ETag` or `Last-Modified` -- conditional GET not supported
Without either header, browsers can't issue conditional GETs and refresh always re-downloads the full response body even when nothing changed. Add `ETag: "<hash>"` (or `Last-Modified: <date>`) on cacheable responses; the server returns 304 Not Modified when the client's cached copy is still valid, saving bandwidth.
Each `<link rel="stylesheet">` without a non-blocking `media` attribute holds up the first paint. Browsers download all of them before painting any content. Consolidate into 1-2 critical-path stylesheets; defer non-critical CSS via `<link rel="stylesheet" media="print" onload="this.media='all'">` or via the loadCSS pattern; inline above-the-fold CSS in `<style>` to short-circuit the request entirely.
A+
Green Hosting
Whether the site is served from green-energy infrastructure
PASS
Green Hosting
This site is hosted on green energy infrastructure
Provider: team.blue Denmark A/S
Network Waterfall
115 requests over 4581ms
INFO
HTML JavaScript CSS Images Fonts XHR/Fetch Other
Image Optimization
31 images, 244 KB total, 0 KB wasted
INFO
Image Optimization Audit
Total Images
31
Total Size
244 KB
26 missing dimensions26 missing lazy loading
All checks on this page are automated. Results are estimates - run targeted manual reviews when the score affects a release decision.