Audit Result

UUID: 019cf605-9866-7285-8cf8-ca7dd536d4a5

www.easyearningstracker.com

https://www.easyearningstracker.com/

Scanned 17 hours ago

82
Fair Score
39 total checks
Passed
26
Warnings
12
Errors
1

Meta Information

  • Title Tag Warning

    Found 80 characters. Keep title between 30 and 60 characters.

    Fix: Add a unique <title> tag describing the main page intent in 30-60 characters.

  • Found 198 characters. Keep description around 70-160 characters.

    Fix: Add <meta name="description" content="..."> in <head> with a clear page summary.

  • Canonical found: https://www.easyearningstracker.com

  • Favicon Pass

    Favicon found and reachable: /favicon.ico (HTTP 200).

    Favicon
  • Viewport configured: width=device-width, initial-scale=1, maximum-scale=5, user-scalable=yes

  • HTML Lang Pass

    Language declared as "en".

Content Structure

  • H1 Tag Warning

    Found 2 H1 tags.

    Fix: Use a single, descriptive <h1> that states the primary purpose of the page.

  • Valid heading flow across 28 headings.

  • All 18 images include alt text.

Technical Optimization

  • HTTPS Pass

    Page is served over HTTPS.

  • HSTS & HTTPS Redirect Warning

    2 HTTPS hardening issues detected.

    • • HSTS is missing includeSubDomains.
    • • Could not probe the HTTP version of this page.
    • • Strict-Transport-Security: max-age=63072000

    Fix: Set Strict-Transport-Security with a long max-age, add includeSubDomains, and redirect all HTTP requests to HTTPS.

  • Core security headers were detected.

    Full HTTP headers (19)
    • • age: 0
    • • cache-control: private, no-cache, no-store, max-age=0, must-revalidate
    • • content-encoding: br
    • • content-security-policy: default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval' https://js.stripe.com https://*.googletagmanager.com https://*.vercel-scripts.com https://challenges.cloudflare.com https://xpmetric.com; style-src 'self' 'unsafe-inline'; img-src 'self' data: https: https://*.google-analytics.com https://*.googletagmanager.com; font-src 'self' https:; connect-src 'self' https://*.supabase.co wss://*.supabase.co https://api.stripe.com https://*.google-analytics.com https://*.googletagmanager.com https://*.vercel-scripts.com https://challenges.cloudflare.com https://react-tweet.vercel.app https://cdn.syndication.twimg.com https://xpmetric.com; frame-src 'self' https://js.stripe.com https://hooks.stripe.com https://challenges.cloudflare.com https://www.youtube.com https://youtube.com; frame-ancestors 'self';
    • • content-type: text/html; charset=utf-8
    • • date: Mon, 16 Mar 2026 09:41:21 GMT
    • • link: </_next/static/media/46bdd75a3ff56824-s.p.woff2>; rel=preload; as="font"; crossorigin=""; type="font/woff2", </_next/static/media/4cf2300e9c8272f7-s.p.woff2>; rel=preload; as="font"; crossorigin=""; type="font/woff2", </_next/static/media/e4af272ccee01ff0-s.p.woff2>; rel=preload; as="font"; crossorigin=""; type="font/woff2", </_next/static/css/067368008e20d050.css>; rel=preload; as="style", </_next/static/css/43eb71c43c90af18.css>; rel=preload; as="style", </_next/static/css/d690d2f2ce098388.css>; rel=preload; as="style"
    • • permissions-policy: camera=(), microphone=(), geolocation=(), payment=()
    • • referrer-policy: strict-origin-when-cross-origin
    • • server: Vercel
    • • strict-transport-security: max-age=63072000
    • • vary: RSC, Next-Router-State-Tree, Next-Router-Prefetch, Next-Router-Segment-Prefetch
    • • x-content-type-options: nosniff
    • • x-frame-options: SAMEORIGIN
    • • x-matched-path: /
    • • x-powered-by: Next.js
    • • x-vercel-cache: MISS
    • • x-vercel-id: iad1::iad1::99f7d-1773654081302-d65747e50b36
    • • x-xss-protection: 1; mode=block
  • CSP Quality Error

    4 CSP hardening issues detected.

    • • script-src/default-src permits 'unsafe-inline'.
    • • script-src/default-src permits 'unsafe-eval'.
    • • CSP is missing object-src 'none'.
    • • CSP is missing a base-uri restriction.
    • • Content-Security-Policy: default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval' https://js.stripe.com https://*.googletagmanager.com https://*.vercel-scripts.com https://challenges.cloudflare.com https://xpmetric.com; style-src 'self' 'unsafe-inline'; img-src 'self' data: https: https://*.google-analytics.com https://*.googletagmanager.com; font-src 'self' https:; connect-src 'self' https://*.supabase.co wss://*.supabase.co https://api.stripe.com https://*.google-analytics.com https://*.googletagmanager.com https://*.vercel-scripts.com https://challenges.cloudflare.com https://react-tweet.vercel.app https://cdn.syndication.twimg.com https://xpmetric.com; frame-src 'self' https://js.stripe.com https://hooks.stripe.com https://challenges.cloudflare.com https://www.youtube.com https://youtube.com; frame-ancestors 'self';

    Fix: Tighten Content-Security-Policy by removing unsafe directives and adding object-src, base-uri, and frame-ancestors restrictions.

  • Cookie Security Pass

    No first-party cookies were set during the initial page load.

  • Server response headers do not expose version tokens.

  • Cloudflare Proxy Warning

    Domain does not appear to be behind Cloudflare.

  • Loaded in 0.85s (perceived).

  • 1 scripts and 3 styles may block rendering.

    • • script: https://www.easyearningstracker.com/_next/static/chunks/polyfills-42372ed130431b0a.js
    • • style: https://www.easyearningstracker.com/_next/static/css/067368008e20d050.css
    • • style: https://www.easyearningstracker.com/_next/static/css/43eb71c43c90af18.css
    • • style: https://www.easyearningstracker.com/_next/static/css/d690d2f2ce098388.css

    Fix: Defer non-critical scripts and inline critical CSS to improve first paint speed.

  • Compression Warning

    2 text resources look uncompressed.

    • • https://www.easyearningstracker.com/_next/static/chunks/main-app-3f8b01109077cd02.js (application/javascript; charset=utf-8)
    • • https://xpmetric.com/api/event (application/json)

    Fix: Enable Brotli or Gzip compression for HTML, CSS, JS, and JSON responses.

  • Robots.txt Pass

    Found robots.txt (200).

  • Found sitemap (200) at https://www.easyearningstracker.com/sitemap.xml.

  • Robots meta found: index, follow

Accessibility Basics

  • All 0 controls are labeled.

  • Landmarks Warning

    Missing landmarks: header.

    Fix: Use semantic regions (<header>, <nav>, <main>, <footer>) for navigation and assistive tech.

  • Tap Target Size Warning

    18 interactive elements appear smaller than 48px.

    • • button#radix-_r_0_.gap-2.whitespace-nowrap (Toggle theme) - 44x44px
    • • button.flex.items-center (Enter fullscreen) - 122x20px
    • • a.inline-flex.items-center (Start Your Free Trial) - 184x40px
    • • a.text-xs.md:text-sm (@venelinkochev) - 160x20px
    • • a.group.flex ([email protected]) - 208x20px
    • • a.group.flex (Feature Requests) - 159x40px
    • • button.relative.px-6 (Monthly) - 102x44px
    • • button.relative.px-6 (Yearly) - 90x44px
    • • button.inline-flex.items-center (Get Started) - 382x44px
    • • button.inline-flex.items-center (Get Started) - 382x44px
    • • a.text-sm.text-muted-foreground (Or browse & vote on feature requests) - 246x20px
    • • a.text-xs.sm:text-sm (Pricing) - 115x20px
    • • a.text-xs.sm:text-sm (Start Free Trial) - 115x20px
    • • a.text-xs.sm:text-sm (FAQ) - 115x20px
    • • a.text-xs.sm:text-sm (Feature Requests) - 115x20px
    • • a.text-xs.sm:text-sm (Privacy Policy) - 93x20px
    • • a.text-xs.sm:text-sm (Impressum) - 93x20px
    • • a.text-xs.sm:text-sm (ProofSwap) - 72x20px

    Fix: Increase target size to at least 48x48 CSS pixels for touch interactions.

Social & Rich Results

  • Core Open Graph tags are present.

  • og:image is present and absolute.

    Open Graph Image
  • twitter:card set to summary_large_image.

  • JSON-LD schema detected.

  • PWA Metadata Warning

    Manifest or Apple touch icon is missing.

    Fix: Link your web app manifest and apple-touch-icon for improved install/share experiences.

  • 1 social preview quality issues detected.

    • • ISSUE: Preview image aspect ratio (1.60) differs from the recommended ~1.91:1.
    • • GUIDELINE: Optimal og:title length: 40-60 characters (acceptable: 10-70).
    • • GUIDELINE: Optimal og:description length: 110-160 characters (acceptable: 50-200).
    • • GUIDELINE: Optimal preview image size: 1200x630 pixels.
    • • GUIDELINE: Optimal preview image aspect ratio: 1.91:1.
    • • GUIDELINE: Optimal preview image file size: under 5 MB.
    • • GUIDELINE: Recommended twitter:card: summary_large_image.
    • • MEASURED: Image size: 0.28 MB
    • • MEASURED: Image dimensions: 1413x883

    Fix: Use absolute OG/Twitter URLs, keep metadata lengths in recommended ranges, and provide a preview image near 1200x630 under 5MB.

Links Analysis

  • Checked 13 links. No broken internal links found.

  • No broken external links found in checked URLs.

  • All 38 links use non-empty href values.

Performance & Runtime