Live-Domain-Report

pkp.de Datenschutz-Check

Scan-ID: 15f79e95-d7a3-4c52-a5ca-462c3bfe4676 · 2026-06-17 12:35:53.973371+02

Geprüfte Domain-Wurzel: https://pkp.de/

Kurz-URL: saferpage.de/pkp.de

Kleine Seitenvorschau von pkp.de
Screenshot-Vorschau 160x150 · vollständig sichtbar · Headless Chromium · preview_available · page_preview

Datenschutz-Score

52/100 Hinweise gefunden

In 20 Sekunden lesen

Was ist bei pkp.de wirklich wichtig?

Nutzen Sie diese Kurzfassung zuerst als Evidence-Checkliste: belegte Signale, Claim-Grenzen und Links stehen im Vordergrund; Betreiberkontext ohne Scan-Beleg wird nur verlinkt.

Was ist das Ergebnis?Score 52/100 · Hinweise gefunden. Der Wert ist Priorisierung, kein Urteil.Warum ist der Score so?Score-Erklärung öffnenWas wurde tatsächlich gesehen?36 Request(s), 2 Datenschutz-Domain(s), 4 Cookie(s) vor Einwilligung, 8 Formular(e), 5 fehlende Header.Was muss man manuell prüfen?4 Review-Ausloeser; Login, Checkout, Rechtskontext und Betreiberprozesse bleiben ausserhalb des passiven Kurzchecks.Was zuerst öffnen?Fixpfad öffnenWelche Nachweise gibt es?Report-Evidence · Methodik · Evidence-HubIst der Report falsch oder veraltet?Korrektur melden mit Domain, Report-URL, Scan-ID und kurzer Begruendung.VerlässlichkeitBelastbares Signal mit manuellen Prüfpunkten
Der Report zeigt relevante Datenschutz-Signale; der Abgleich mit den Website-Flows bleibt Sache des Betreibers.
Belegbar4 technische Evidence-Punkte aus dem gespeicherten passiven Lauf.Hintergrund-LinkMehr erfahrenNicht behaupten3 Claim-Grenzen: keine Rechtsfreigabe, kein Zertifikat, kein abschließendes Seriositätsurteil.Fix-PfadFixpfad öffnenNachweiseMethodik · Evidence-Hub

Score-Erklärung

Warum ist der Score so?

Diese Erklärung macht die Gesamtaussage lesbar: Score-Treiber, entlastende Signale, Gate-/Grenzsignale und manuelle Prüfpunkte bleiben getrennt. Der Score ist kein Verbot, kein Gütesiegel und keine Rechtsfreigabe. Score-Methodik öffnen

52/100 · Hinweise gefunden
52/100Gesamtscore als Priorisierung6Score-Treiber sichtbar5entlastende Signale3Gate-/Grenzsignale4manuelle PruefausloeserSignal + BetreiberprüfungAussage-Verlaesslichkeit
Score-TreiberAus dem gespeicherten Scan abgeleitete Prioritaeten

4 Cookie(s) vor Einwilligung im gespeicherten Lauf.

2 datenschutzrelevante Drittanbieter-Domain(s) aus Browserkontakten.

8 Formular(e) auf 4 geprüften Seite(n) als Eingabepunkte.

5 wichtige Security-Header fehlen oder sind nicht belegt.

Tracking und Consent zuerst prüfen: Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig.

Sensible URL-Schlüssel im Drittanbieter-Kontext: Sensible URL-Parameter aus Drittanbieter-Requests und Referrern entfernen.

Quelle
Scan-Evidence
Entlastende SignaleGegenueber dem Gesamtwert separat lesen

0 Tracking-Script(s) im gespeicherten Lauf.

Impressum-Link wurde im passiven Sample belegt.

Datenschutz-Hinweis wurde im passiven Sample belegt.

4 Security-Header sind vorhanden.

Performance-Basiswert liegt bei 94/100.

Quelle
Scan-Evidence
Gate-/GrenzsignaleWas die automatische Aussage begrenzt

Score unter 75: priorisierte Betreiberpruefung empfohlen.

4 manuelle Review-Ausloeser aus der Scope-Grenze.

4 nicht automatisch gepruefte Bereiche, etwa Login, Checkout, Vertrags- oder Rechtskontext.

Grenze
manuell pruefen

Mehr erfahren

Korrektur melden: Wenn Score-Treiber durch Consent-Wall, Paywall, veraltete Inhalte oder falsch erkannte Betreiberinformationen verzerrt sind, melden Sie Domain, Report-URL, Scan-ID und kurze Begruendung ueber Kontakt.

Prüfumfang & Grenzen

Was SaferPage geprüft hat - und was nicht

Prüfumfang und Grenzen des passiven SaferPage-Kurzchecks: getestet, nicht getestet, manuell zu prüfen und erneut zu scannen.

normaler Passivlauf
4geprüfte Bereiche4nicht geprüfte Grenzen4manuelle Review-Auslöser4Re-Scan-AuslöserneinConsent-/Paywall-GrenzejaGoogle-Consent aus Evidenz
GeprüftAutomatische Evidence aus dem passiven Lauf

Passiver HTTP-/Browser-Sample: 36 Browser-Request(s), 2 datenschutzrelevante Drittanbieter-Domain(s).

Cookies und Consent-Startzustand: 4 Cookie(s) vor Einwilligung im gespeicherten Lauf.

Öffentlich erreichbare Test-URLs: 4 direkt geprüfte Test-URL(s) im Crawl-/Coverage-Abschnitt.

Formular-Evidenz aus öffentlichem Crawl: 8 Formular(e) auf 4 Seite(n) erkannt.

Status
belegt

Methodik-Grenzen öffnen

Mehr erfahren

Monitoring öffnen

Claim-Grenze: Der Prüfumfang beschreibt den gespeicherten passiven Kurzcheck. Er ersetzt keine Rechtsberatung, keine Betreiberfreigabe und keinen Deep-Scan hinter Login, Paywall oder Interaktion.

Zuletzt geprüfte Seiten

Welche Test-URLs wurden wirklich abgerufen?

Der Kurzreport zeigt hier die priorisierten Unterseiten aus dem letzten Crawl mit direktem Link zur geprüften Ziel-URL. Die Screenshot-Vorschau oben ist eine kleine 160x150-Evidence zum geprüften Seitenzustand; die Liste darunter macht sichtbar, ob Datenschutz-, Impressum-, Formular- oder andere wichtige Seiten im Test enthalten waren.

4 abgerufene Unterseite(n) · 12 zusätzlich entdeckte interne Linkziele.

Vollständiges Seiteninventar öffnen · Agentur-DeepScan öffnen

/de/kontakt/datenschutzdatenschutz · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2 · Ablehnen ja/de/kontakt/impressumimpressum · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2/de/kontaktkontakt · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2/de/kontakt/allgemeine-geschaeftsbedingungenkontakt · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2

Audit-Ausgabe

PDF-/Druckbericht für Betreiber und Prüfer

Dieser Bericht ist für die Browser-Funktion „Drucken“ beziehungsweise „Als PDF speichern“ optimiert. Rohdaten und auditfähige Nachweise bleiben zusätzlich über JSON, CSV, Excel-Tabellen und ein ZIP-Nachweispaket mit getrennten Cookie-, Drittanbieter-, Consent-, Request- und Aufgaben-Tabellen exportierbar.

Domainpkp.de Score52 Scan-ID15f79e95-d7a3-4c52-a5ca-462c3bfe4676 Erstellt2026-06-17 12:35:53.973371+02 Öffentlicher Linksaferpage.de/pkp.de ExportPDF/Druck, JSON, CSV, XLSX, ZIP-Nachweise
DNS erreichbarAdressen: 2
HTTPS-Zertifikat gültigTLS: TLSv1.3
HTTP-Status 200Endziel: https://www.pkp.de/de

Link-only

Die wichtigsten Befunde zuerst

Dieser Report zeigt Scan-Fakten zur geprüften Website. Umsetzungsschritte, Hintergrundseiten, Checklisten, Code und allgemeine Empfehlungen stehen auf getrennten Seiten; im Report erscheint nur der Link.

3priorisierte Scan-Hinweise3hoch gewichtete Scan-HinweiseLink-onlykeine Hintergrundinhalte im ReportFaktenReport bleibt bei Evidence und Grenzen
Tracking und Consent zuerst prüfenhoch · Consent

Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig.

Guide-, Checklisten- und Umsetzungstexte stehen auf separaten Seiten; hier bleiben Evidence und Link.
Gewicht
88/100
Mehr dazu
öffnen
Sensible URL-Schlüssel im Drittanbieter-Kontexthoch · PII-Datenleck

Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten.

Guide-, Checklisten- und Umsetzungstexte stehen auf separaten Seiten; hier bleiben Evidence und Link.
Gewicht
82/100
Mehr dazu
öffnen
Erkannte Anbieter fehlen in der Datenschutzerklärunghoch · DSGVO/Transparenz

Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten.

Guide-, Checklisten- und Umsetzungstexte stehen auf separaten Seiten; hier bleiben Evidence und Link.
Gewicht
82/100
Mehr dazu
öffnen

Betreiber-Fazit

Vor Nutzung prüfen

Die Website hat auffällige Datenschutz- oder Vertrauenssignale. Für reine Information kann sie nutzbar sein, bei Daten oder Zahlungen ist Vorsicht sinnvoll.

Auffällige SignaleTracking-Cookies vor Einwilligung gesetztMöglicherweise nicht notwendige Cookies vor EinwilligungSensible URL-Schlüssel im Drittanbieter-KontextLanglebige Tracking-/Marketing-Cookies
Entlastende SignaleBetreiber und Datenschutz sind auffindbarDateneingabe hat KontextNutzbarkeit wirkt solideTechnisches Vertrauenssignal
Datenschutz & Trackingauffällig0 Tracking-Script(s), 4 Cookie(s) vor Einwilligung, 2 datenschutzrelevante Drittanbieter.
DateneingabeprüfenCrawl fand 8 Formular(e) auf 4 geprüften Seite(n), u. a. /de/kontakt/datenschutz, /de/kontakt/impressum, /de/kontakt, /de/kontakt/allgemeine-geschaeftsbedingungen.
BrowserkontaktekritischChromium sah 36 Request(s), 4 Drittanbieter-Domain(s), davon 2 datenschutzrelevant.
DomainhistorieprüfenRDAP liefert kein klares Registrierungsdatum.
Technische BasisprüfenHTTPS, DNS, Zertifikat, HTTP-Status und wichtige Sicherheitsheader wurden passiv geprüft.
NutzbarkeitunauffälligAntwortzeit, mobile Viewport-Basis und auffällige Browser-Verhaltensmuster wurden eingeordnet.

Mehr erfahren

Prüfprofil

Für welchen Betreiber-Kontext wurde priorisiert?

Prüfprofil Deutschland -> DACH: Allgemeine Website, Zielgruppe Gemischte Zielgruppe. 4 Schwerpunkt(e) für Betreiber priorisiert.
Das Profil priorisiert technische Prüfpunkte für Betreiber; es ersetzt keine rechtliche Einzelfallprüfung.

Website-Typ: Allgemeine Website · Betreiber: Deutschland · Zielregion: DACH

Schwerpunkte

DSGVO/TDDDGrelevant · hoch · Profil: Betreiber-/ZielregionBFSG/WCAGrelevant · hoch · Profil: Website-Typ und WCAG-SignaleDDG/Anbieterkennzeichnungrelevant · hoch · Profil: öffentliches WebangebotDrittanbieter und internationale Transfersrelevant · prüfen · Profil: AngebotskomplexitätSensible DatenKontext · hoch · Profil: Website-Typ/Zielgruppe

Prüfmodule

Welche Bereiche wurden geprüft?

Methodik
Datenschutz, Cookies & Consent18
kritisch

Scan-Evidence in diesem Modul vorhanden; Betreiberkontext steht auf einer separaten Seite.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Browser-Nachweis19
kritisch

36 Request(s), 4 Drittanbieter-Domain(s), davon 2 datenschutzrelevant, 4 Browser-Cookie(s), Transfer-Prüfbedarf: 3, Referrer-/URL-Leaks: 3, Fingerprinting-/Replay-Hinweise: 1.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Referrer & URL-Leaks31
kritisch

3 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 2 sensible Query-Kontexte.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Cookie-Inventar40
kritisch

4 Cookie(s), 2 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 2 langlebig, 0 sehr lang.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Barrierefreiheit & Usability56
auffällig

5 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 11 Button(s) ohne Namen.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Google-Dienste & Drittanbieter58
auffällig

Google-Tags: ja, 3 Google-nahe Domain(s), Consent-Default: nein, Analytics: ja, Werbung: nein, Fonts: nein.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Sicherheit, TLS & Header58
auffällig

2 Infrastruktur-Hinweis(e), Security-Header: 4/9 vorhanden, 5 fehlen, externe Skript-Hosts: 1.

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren
Tracking-Pixel & Beacons66
auffällig

0 Pixel-/Bildtracking-Hinweis(e), 4 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).

Details und Umsetzungshinweise stehen auf separaten Seiten; sichtbar bleiben Modulscore, Evidence und Link.Mehr erfahren

Mehr erfahren

Link-only Detailmodule

Detailseiten statt eingebettetem Hintergrund

Dieser Report bleibt bei Scan-Fakten zur geprüften Website. Nachweise, Badge-Code, Benchmark, Monitoring, Arbeitspfade und Hintergrundseiten öffnen auf eigenen Seiten; im Report stehen nur feste Links, keine Hintergrundinhalte.

Nachweise öffnenPrüfbeleg, Exportpaket und Hash-NachweiseMonitoring öffnenScan-Verlauf, Änderungen und WiederholungsscansMethodik öffnenGrenzen, Crawl-Verhalten und PrüfprofilPriorisierte Scan-Hinweise als JSON anzeigenMaschinenlesbare Befunde mit Evidence und Link

Monitoring

Was hat sich seit dem letzten Scan verändert?

Noch kein Vergleich
Noch kein früherer gespeicherter Scan für diese Domain vorhanden.

1Tests insgesamt0frühere Tests1sichtbar im VerlaufneinÄnderungsvergleich
Aktuell · 2026-06-17 12:35Score 52 · 30 Hinweis(e)

Betreiber-Risiko

Priorisierte Scan-Hinweise aus dem gespeicherten Report

Hoher Betreiber-Handlungsbedarf
Abgeleitet aus dem Datenschutz-Webseiten-Report: Datenschutz, TDDDG/ePrivacy, BSI-Sicherheit, Google-Qualität und Nutzbarkeit werden nach passiven Befunden priorisiert.

DSGVO/Transparenzhoch · 4 Hinweis(e)Detailseite öffnenTDDDG/ePrivacyhoch · 3 Hinweis(e)Detailseite öffnenBSI/Security-Headermittel · 4 Hinweis(e)Detailseite öffnenBarrierefreiheit/Usabilitymittel · 2 Hinweis(e)Detailseite öffnenBeacon-/Telemetry-Trackinghoch · 1 Hinweis(e)Detailseite öffnenCookie-Laufzeithoch · 1 Hinweis(e)Detailseite öffnen

Regelwerks-Scorecard

DSGVOScore 0/100 · hoher Prüfbedarf · 15 Befund(e)Transparenz, Datenflüsse, Empfänger, Speicherdauer und technische Sicherheit personenbezogener Daten.Detailseite öffnenTDDDG/ePrivacyScore 16/100 · hoher Prüfbedarf · 4 Befund(e)Cookies, Endgerätezugriff, Tracking, Consent-Zustände, GPC und Widerruf.Detailseite öffnenBFSG/WCAGScore 72/100 · prüfen · 2 Befund(e)Barrierefreiheit, Tastatur-/Screenreader-Nutzbarkeit, Formulare, Buttons und mobile Basis.Detailseite öffnenBSI/SecurityScore 54/100 · prüfen · 5 Befund(e)TLS, Security-Header, CSP, Patchstand, Referrer-Schutz und technische Härtung.Detailseite öffnenDDG/BetreibervertrauenScore 44/100 · hoher Prüfbedarf · 3 Befund(e)Impressum, Kontakt, Anbieterkennzeichnung und erkennbare Betreiberidentität.Detailseite öffnen

Regelwerks-Matrix

DSGVO Transparenzhoch · 7 Befund(e) · Score 126Detailseite öffnenDSGVO Datenleck/PIIhoch · 4 Befund(e) · Score 98Detailseite öffnenTDDDG/ePrivacyhoch · 4 Befund(e) · Score 84Detailseite öffnenBetreibervertrauenhoch · 3 Befund(e) · Score 56Detailseite öffnenGoogle-Dienstehoch · 3 Befund(e) · Score 48Detailseite öffnenBSI/Sicherheitmittel · 5 Befund(e) · Score 46Detailseite öffnenBITV/Usabilitymittel · 2 Befund(e) · Score 28Detailseite öffnenDSGVO Cookie-Laufzeitenhoch · 1 Befund(e) · Score 28Detailseite öffnen

Domainhistorie

Wie lange gibt es die Domain?

RDAP liefert kein klares Registrierungsdatum.

Letzte Änderung2021-06-21Statusactive

Datenschutz zuerst

Was sieht ein Nutzer beim ersten Aufruf?

Cookies beim ersten Aufruf: 1 · Tracking-Skripte: 0 · Datenschutzerklärung: ja · Impressum: ja · Ablehnen-Option: ja

Dateneingabe & Zahlung

Welche Daten könnte die Seite abfragen?

Crawl fand 8 Formular(e) auf 4 geprüften Seite(n). Datenschutzkontext: ja · Details auf der verlinkten Seite

8Formulare insgesamt erkannt8aus gecrawlten Test-URLs4Formular-UnterseitenverlinktDatenschutzkontextHintergrund-LinkDetails auf der verlinkten Seite

Mehr erfahren

/de/kontakt/datenschutzCrawl · 2 Formular(e)/de/kontakt/impressumCrawl · 2 Formular(e)/de/kontaktCrawl · 2 Formular(e)/de/kontakt/allgemeine-geschaeftsbedingungenCrawl · 2 Formular(e)Kontaktformular1 Signal(e)Newsletter1 Signal(e)FormularFormular · 0 Feld(er)FormularFormular · 0 Feld(er)FormularFormular · 0 Feld(er)FormularFormular · 0 Feld(er)

PII & Datenlecks

Könnten personenbezogene Werte in URL, Referrer oder Tracking landen?

1 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext. Score: 82 · Hinweise: 1

Mehr erfahren

Aktuelle URLok · Keine sensiblen Query-Parameter erkannt.Link-Parameterok · Keine sensiblen Link-Querys erkannt.GET-Formulareok · Keine personenbezogenen GET-Formulare erkannt.Externe Formularzieleok · Keine externen Formularziele mit personenbezogenen Feldern erkannt.Tracking neben Dateneingabeauffällig · 2 datenschutzrelevante Drittanbieter.

Kurzantwort

Kann man der Website vertrauen?

Der Check bleibt passiv und formuliert die wichtigsten Punkte als Betreiberhinweise. Technische Details bleiben nachvollziehbar im JSON erhalten.

Browser-Sicht

Was lädt die Seite im Chromium-Browser nach?

Requests: 36 · kontaktierte Domains: 5 · Drittanbieter: 4 · Browser-Cookies: 4 · Storage: 1 (0 Tracking-Hinweis(e)) · Banner: Akzeptieren 0 / Ablehnen 0 / Einstellungen 0 · Ablehnen/Akzeptieren: 0 · Reject-Test: nicht gefunden, neue Cookies 0, neue Tracking-Kontakte 0 · Accept-Test: nicht ausgeführt, neue Cookies 0, neue Tracking-Kontakte 0 · TCF-String: nein, Purposes 0, Vendors 0 · GPC: aktiv, Datenschutz-Domains 2, Drittanbieter-Cookies 0 · Viewport-Signale: Datenschutz 0 / Impressum 0 / Kontakt 1 / Cookie 0 · CMP: nein · Browser: playwright-chromium

Zwecke

other2 Domain(s)Analytics1 Domain(s)Tag-Manager1 Domain(s)

CMP & Storage

dataLayerBrowserGoogle Tag DataBrowserTCF TC-StringneinTCF Purposes0TCF Vendors0Akzeptieren0Ablehnen0Einstellungen0Ablehnen/Akzeptieren0Reject-TestoffenNeue Cookies nach Ablehnen0Tracking-Storage nach Ablehnen0Neue Tracking-Kontakte0Accept-Testnicht ausgeführtNeue Requests nach Akzeptieren0Neue Cookies nach Akzeptieren0Neue Tracking-Kontakte nach Akzeptieren0GPC-SignalaktivGPC Datenschutz-Domains2GPC Drittanbieter-Cookies0GPC Storage-Hinweise0

Viewport-Transparenz

KontaktKontakt · x749 y64

Drittanbieter

Google Tag ManagerTag-Manager · 3 Request(s) · scriptcloud.ccm19.deSonstige · 1 Request(s) · scriptgoogle.comSonstige · 1 Request(s) · fetchGoogle AnalyticsAnalytics · 1 Request(s) · fetch

Consent-Zustände

Was passiert beim Erstaufruf, nach Ablehnen, nach Akzeptieren und mit GPC?

Consent-State-Evidence: 4 Zustände verglichen, 0 hoch auffällig, 2 mittel auffällig. Score: 80

Mehr erfahren

ErstaufrufCookies 4 · neu 4 · Tracking-Storage 0 · Datenschutz-Domains 2 · mittelNach AblehnenCookies 4 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigNach AkzeptierenCookies 0 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigGPC-AufrufCookies 4 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 2 · mittel

Consent-Journey

Welche Anbieter erscheinen im Erstaufruf, nach Ablehnen, nach Akzeptieren und bei GPC?

Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 2 im GPC-Aufruf. Score: 84 · Ablehnen neu: 0 · Akzeptieren neu: 0 · GPC: 2

Mehr erfahren

Google Tag ManagerTag-Manager · Erstaufruf 3 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 3Google AnalyticsAnalytics · Erstaufruf 1 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 1cloud.ccm19.deSonstige · Erstaufruf 1 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 1google.comSonstige · Erstaufruf 1 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 1

Drittanbieter-Kontakte

Wer bekommt beim ersten Aufruf technische Kontaktpunkte?

4 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 2 datenschutzrelevant. Score: 60 · Requests: 6 · datenschutzrelevant: 2

Mehr erfahren

Google Tag Managerhoch · Tag-Manager · 3 Request(s) · script:3 · googletagmanager.comGoogle Analyticsmittel · Analytics · 1 Request(s) · fetch:1 · region1.google-analytics.comcloud.ccm19.deniedrig · Sonstige · 1 Request(s) · script:1google.comniedrig · Sonstige · 1 Request(s) · fetch:1

Betreiber-Verzeichnis

Empfänger- und Auftragsverarbeiter-Signale aus dem Scan

4 Empfänger-/Anbieter-Eintrag/Einträge aus Browserkontakten und Cookie-Inventar, 2 datenschutzrelevant, 2 mit AVV-/Rollenprüfung. Score: 47 · hoher Prüfbedarf: 2 · AVV/Rolle prüfen: 2
Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten.

Mehr erfahren

Google Tag Managerhoch · Tag-Manager · Auftragsverarbeiter/Empfänger prüfen · Drittland/USA · 3 Request(s) · 0 Cookie(s) · googletagmanager.comGoogle Analyticshoch · Analytics · Auftragsverarbeiter/Empfänger prüfen · Drittland/USA · 1 Request(s) · 0 Cookie(s) · region1.google-analytics.comgoogle.committel · Sonstige · Technischer Empfänger prüfen · Drittland/USA · 1 Request(s) · 0 Cookie(s)cloud.ccm19.deniedrig · Sonstige · Technischer Empfänger prüfen · EU/EWR · 1 Request(s) · 0 Cookie(s)

Transfer-Risiko

Drittanbieter mit Transfer- oder Jurisdiktionssignal

4 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 3 mit hohem Prüfbedarf, 0 unklar. Score: 55 · hoher Prüfbedarf: 3 · unklar: 0

Transfer Impact Assessment öffnen

Mehr erfahren

Google Tag Managerhoch · Drittland/USA · US · googletagmanager.comGoogle Analyticshoch · Drittland/USA · US · region1.google-analytics.comcloud.ccm19.deniedrig · EU/EWR · EU/EWRgoogle.comhoch · Drittland/USA · US

Externe Inhalte

Laden Videos, Karten, Captchas oder Social-Widgets schon beim Seitenaufruf?

0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen. Score: 100 · vorab geladen: 0 · Captcha: 0

Mehr erfahren

Keine Video-, Karten-, Captcha- oder Social-Embeds aus HTML und Browserlauf erkannt.

Referrer & URL-Leaks

Werden Seitenpfade oder Suchparameter an Drittanbieter sichtbar?

3 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 2 sensible Query-Kontexte. Score: 31 · Domains: 3 · sensible Kontexte: 2

Mehr erfahren

cloud.ccm19.desensibler Query-Schlüssel im Drittanbieter-Request oder Referrer · Query: apikey, domainGoogle Analyticssensibler Query-Schlüssel im Drittanbieter-Request oder Referrer · region1.google-analytics.com · Query: v, tid, gtmGoogle AnalyticsSeiten-URL oder URL-Wert in Drittanbieter-Requestparametern · region1.google-analytics.com · Query: v, tid, gtmgoogle.comSeiten-URL oder URL-Wert in Drittanbieter-Requestparametern · Query: rcb, frm, auid

Tracking-Pixel & Beacons

Sendet die Seite unsichtbare Pixel, Link-Pings oder Beacon-Telemetrie?

0 Pixel-/Bildtracking-Hinweis(e), 4 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s). Score: 66 · Pixel: 0 · Beacons/Telemetry: 4 · Link-Pings: 0

Mehr erfahren

Beacon-/Keepalive-APIbeacon_api · Telemetry · beacon · sendBeacon API 0 Aufruf(e), 0 Code-Hinweis(e); keepalive 2 Aufruf(e), 0 Code-Hinweis(e).Google Analyticsbrowser_tracking_request · Analytics · fetch · fetch-Request mit 37 Query-Schlüssel(n).

Fingerprinting & Session-Replay

Liest die Seite Browser-Merkmale oder Interaktionen aus?

1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf. Score: 88 · Hinweise: 1

Mehr erfahren

Canvas-Ausleseok · 0 Pixel-Lesezugriff(e), 0 Export(e).WebGL-Merkmaleok · 0 Parameterzugriff(e), 0 Pixel-Lesezugriff(e).AudioContextok · 0 AudioContext/OfflineAudioContext-Aufruf(e).Session-Replay-Anbieterok · Keine bekannten Anbieter erkannt.Tastatur-/Eingabe-Listenerauffällig · 12 Tastatur-/Input-Listener, 25 Interaktions-Listener, 71 MutationObserver.

Seitenabdeckung

Welche Unterseiten wurden gefunden?

19 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen. Score: 95 · wichtige Seiten: datenschutz, impressum, kontakt · Sitemap-URLs: 0 · gelesene Sitemaps: 1 · Unterseiten mit Tracking: 0 · Formularlücken: 0 · Datenschutzerklärung: 86 Punkte, fehlende Bausteine 2 · Aktualität: nicht erkannt · Lesbarkeit: 10.9 Wörter/Satz · Anbieter-Abgleich: 2/3 erwähnt

Priorisierte Seiten

/de/kontakt/datenschutzdatenschutz · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2 · Ablehnen ja/de/kontakt/impressumimpressum · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2/de/kontaktkontakt · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2/de/kontakt/allgemeine-geschaeftsbedingungenkontakt · HTTP 200 · Tracking 0 · Cookies 1 · Formulare 2

Datenschutzerklärung

Verantwortlicher / AnbietergefundenKontakt / DatenschutzkontaktgefundenZwecke der VerarbeitunggefundenRechtsgrundlagengefundenBetroffenenrechtegefundenSpeicherfrist / LöschunggefundenEmpfänger / AuftragsverarbeitergefundenCookies / TrackinggefundenWiderruf / Opt-outgefundenBeschwerde bei AufsichtsbehördegefundenDrittlandtransfergefundenStand / Aktualitätsdatumfehlt

Anbieter-Abgleich

Google Tag ManagerTracking-ID · in Datenschutzerklärung erwähntGoogleAnalytics · in Datenschutzerklärung erwähntGoogle AnalyticsAnalytics · fehlt in Datenschutzerklärung

Google Consent Mode

Sind Google-Tags vor Einwilligung begrenzt?

Google-Consent-Mode-Signale wurden aus GTM/Analytics/Ads-Tags, passenden Browserkontakten und Tracking-IDs abgeleitet; reine Google-Service-Kontakte werden separat gezählt. Score: 58

Consent Mode öffnen

Google-TagsjaConsent-DefaultneinConsent-UpdateneinGoogle-Consent-Domains2Google-Service-Domains3

Consent-Audit

Hält die Seite Tracking bis zur Einwilligung zurück?

Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig. Score: 18 · Cookies vor Einwilligung: 4 · Tracking-Cookies: 2 · Browser-Ablehnen: 0 · Ablehnen/Akzeptieren: 0 · Reject geklickt: nein · neue Cookies nach Ablehnen: 0 · Accept geklickt: nein · neue Cookies nach Akzeptieren: 0 · neue Tracking-Kontakte nach Akzeptieren: 0 · TCF-String: nein · TCF Purposes: 0 · TCF Vendors: 0 · GPC Datenschutz-Domains: 2 · GPC Drittanbieter-Cookies: 0 · Storage-Hinweise: 0 · CMP: nein · datenschutzrelevante Drittanbieter: 0

Prüfpunkte

Cookie-/Consent-Hinweis sichtbarokAblehnen gleichwertig erreichbarokEinstellungen oder Auswahl vorhandenpruefenAblehnen im sichtbaren BannerokEinstellungen im sichtbaren BannerokAblehnen nicht deutlich schwaecher dargestelltokAblehnen technisch klickbarokKeine neuen Cookies nach AblehnenokKein Tracking-Storage nach AblehnenokKeine neuen Tracking-Kontakte nach Ablehnenok

Consent reparieren

Mehr erfahren4 Cookie(s) vor Einwilligung, 2 Tracking-Cookie(s), 0 datenschutzrelevante Drittanbieter.

Blockierplan

Mehr erfahren0 Browser-Request(s), 4 Cookie(s) vor Einwilligung, 0 datenschutzrelevante Drittanbieter.

Banner-UX

Wirkt das Consent-Banner fair und gleichwertig bedienbar?

Consent-Banner-UX: 2 auffällige Prüfpunkt(e), davon 1 hoch. Muster: Tracking vor Einwilligung. Score: 74 · Akzeptieren: 0 · Ablehnen: 0 · Einstellungen: 0 · Dark-Pattern-Hinweise: 1
Automatisch aus sichtbaren Banner-Controls und Browser-Interaktionen abgeleitet; visuelle Details und Rechtmäßigkeit fachlich prüfen.

Consent-Visual-Salienz

Welche Consent-Controls waren im ersten Viewport sichtbar? Status: measured_dom_viewport_signal · Akzeptieren: 0 · Ablehnen: 0 · Einstellungen: 0 · sichtbare Controls: 13 · Ablehnen/Akzeptieren: nicht messbar
Consent-Visual-Salienz ist ein DOM-/Viewport-Signal aus dem ersten Browserlauf. Sie ist keine Rechtsbewertung, kein Dark-Pattern-Endurteil und kein Nachweis fuer spaetere Consent-Zustaende, Scrollbereiche, Loginbereiche oder manuelle Betreiberkontexte.

Banner-Vorlage öffnen

Mehr erfahren

UX-Prüfpunkte

Ablehnen auf erster Ebene sichtbarok · niedrig · Sichtbare Controls: Akzeptieren 0, Ablehnen 0, Einstellungen 0.Einstellungen sichtbar erreichbarok · niedrig · Einstellungs-/Auswahl-Controls im Banner: 0.Ablehnen und Akzeptieren wirken gleichwertigok · niedrig · Größenverhältnis Ablehnen/Akzeptieren: nicht messbar. Accept-Fläche 0, Reject-Fläche 0.Ablehnen technisch klickbarok · niedrig · Reject-Test: kein Button gefunden. Text:Ablehnen stoppt neue Tracking-Signaleok · niedrig · Nach Ablehnen: 0 neue Cookie(s), 0 Tracking-Storage-Hinweis(e), 0 neue Datenschutz-Domain(s).Akzeptieren-Wirkung nachvollziehbarok · niedrig · Accept-Test: nicht verfügbar; neue Cookies 0, neue Datenschutz-Domains 0.GPC-Aufruf ohne neue Tracking-Hinweiseauffällig · mittel · GPC: Datenschutz-Domains 2, Drittanbieter-Cookies 0, Storage-Hinweise 0.Keine Tracking-Cookies vor Einwilligungauffällig · hoch · 2 Tracking-Cookie(s) im Erstaufruf.

Gemessene Control-Proben

Sichtbare Consent-Controls ohne klassifizierte Probe13 sichtbare Control(s) im ersten Viewport; keine klassifizierte Accept-/Reject-/Settings-Probe. Samples enthalten nur klassifizierte Accept-/Reject-/Settings-Controls. Weitere sichtbare Consent-Controls bleiben als Zaehler erhalten, werden aber ohne Klassifizierung nicht als Ablehnen-, Akzeptieren- oder Einstellungsprobe behauptet.

TCF-Decoder

Welche IAB-TCF-Zwecke wirken im Erstaufruf erlaubt?

TCF-Decoder: 0 Zweck(e) mit Consent/LI-Signal, 0 Vendor-Consent(s), 0 Vendor-LI-Signal(e). Score: 100 · TC-String: nein · Purposes Consent: 0 · Purposes LI: 0 · Vendor Consent: 0 · Vendor LI: 0

Mehr erfahren

Keine auswertbaren IAB-TCF-Signale im Browserzustand erkannt.

Quellenmatrix

Welche offiziellen Quellen stützen die Einordnung?

Quellen und Betreiber-Background stehen auf separaten Seiten.
Dieser Report zeigt dazu nur Zähler und Link; Quellenkommentare sind kein Befund zur geprüften Website.

Quellen: 10 · offizielle Links: 6

Methodik und Quellen öffnen10 Referenzzeile(n) stehen auf separaten Seiten; Quellenkommentare sind kein Befund zur geprüften Website.

DSGVO & TDDDG

Welche Signale mit Rechtsgrundlagen-Bezug wurden gezählt?

Der passive Scan stellt keine Rechtsgrundlage fest.
Er zählt nur beobachtete Cookie-, Storage-, Drittanbieter-, Formular- und Consent-Signale. Die fachliche Rechtsgrundlagenprüfung bleibt Sache des Betreibers und ist als Guide verlinkt.

Einwilligungsbezug: 10 · vor Consent auffällig: 4 · unklar/prüfen: 10 · Drittanbieter: 4 · Storage: 1

Detailprüfung, Rechtsbewertung und Umsetzungshinweise werden nicht im Report angezeigt.

Mehr erfahren

Mehr erfahren

Disclosure-Abgleich

Passt die Datenschutzerklärung zur beobachteten Technik?

Disclosure-Abgleich: 3 beobachtete Anbieter, 1 Anbieter ohne klare Erwähnung, 2 fehlende Policy-Bausteine.
Automatischer Textabgleich gegen technische Beobachtungen; Schreibweisen und dynamische Inhalte können manuelle Prüfung erfordern.

Score: 67 · Anbieter erkannt: 3 · Anbieter fehlen: 1 · Policy-Lücken: 2

Lücken

Google Analyticsanbieter · Analytics · fehltStand / Aktualitätsdatumpflichtbaustein · Datenschutzerklärung · fehltDatenschutzkontakt / DPO-Hinweispflichtbaustein · Datenschutzerklärung · fehlt

Datenschutzhinweis

Welche Disclosure-Signale wurden gesehen?

Disclosure-Signale aus dem Scan.
Der Report zeigt hier nur Zähler, beobachtete Signale und Links; redaktionelle Inhalte und Betreiber-Background stehen auf separaten Seiten.

Mehr erfahren

Scan-Zähler

Mehr erfahren4 Zwecksignal(e), 2 Datenart(en), 3 Lückenhinweis(e); Entwurfstexte stehen auf separaten Seiten.

Cookie-Signale

_gaAnalytics · Einwilligung erforderlich · lang (399 Tage) · vor Consent_ga_5EBT50JLF8Analytics · Einwilligung erforderlich · lang (399 Tage) · vor Consent15506c5c2936092e3ec13f6e93cdc469Unklar · unklar, prüfen · Session · vor Consent_gcl_auUnklar · unklar, prüfen · mittel (89 Tage) · vor Consent

Drittanbieter-Signale

Google Tag ManagerTag-Manager · Drittland/USA · hoch · datenschutzrelevantcloud.ccm19.deSonstige · EU/EWR · niedriggoogle.comSonstige · Drittland/USA · hochGoogle AnalyticsAnalytics · Drittland/USA · hoch · datenschutzrelevant

Web-Storage-Signale

_gcl_lslocalStorage · Unklar · unklar, prüfen · dauerhaft bis Löschung durch Nutzer/Browser

Cookie-Inventar

Welche Cookies wurden beim ersten Aufruf gesehen?

4 Cookie(s) inventarisiert: 2 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 2 langlebige Cookie(s), 0 sehr lange Laufzeit(en). Score: 40 · ohne Secure: 4 · ohne SameSite: 0 · persistent: 3 · langlebiges Tracking: 2 · sehr lang: 0 · Laufzeitrisiko: 2

Mehr erfahren

_gaAnalytics · First-Party · Google · ohne Secure, SameSite Lax, lang (399 Tage), Laufzeitrisiko hoch · Chromium-Erstaufruf · Quelle: pkp.de · 30 Browser-Request(s) · document:1, font:3, image:12, script:9_ga_5EBT50JLF8Analytics · First-Party · Google · ohne Secure, SameSite Lax, lang (399 Tage), Laufzeitrisiko hoch · Chromium-Erstaufruf · Quelle: pkp.de · 30 Browser-Request(s) · document:1, font:3, image:12, script:915506c5c2936092e3ec13f6e93cdc469Unklar · First-Party · pkp.de · ohne Secure, SameSite Lax, Session, Laufzeitrisiko niedrig · HTTP Set-Cookie, Chromium-Erstaufruf · Quelle: pkp.de · 30 Browser-Request(s) · document:1, font:3, image:12, script:9_gcl_auUnklar · First-Party · pkp.de · ohne Secure, SameSite Lax, mittel (89 Tage), Laufzeitrisiko niedrig · Chromium-Erstaufruf · Quelle: pkp.de · 30 Browser-Request(s) · document:1, font:3, image:12, script:9

Cookie-Disclosure

Welche Cookie-Signale wurden gesehen?

Cookie-Erklärung mit 5 Eintrag/Einträgen aus Cookies und Web Storage: 2 einwilligungspflichtig, 3 unklassifiziert. Score: 54 · einwilligungspflichtig: 2 · vor Consent: 2 · unklassifiziert: 3
Automatisch aus SaferPage-Cookie- und Web-Storage-Signalen abgeleitet; Kategorien und Zwecke vor Veröffentlichung fachlich prüfen.

Mehr erfahren

Unklassifiziert3 Eintrag/Einträge · Zweck oder Erforderlichkeit aus dem technischen Scan nicht sicher bestimmbar.Statistik2 Eintrag/Einträge · Reichweitenmessung und Nutzungsstatistik._gaStatistik · Einwilligung erforderlich · Anbieter Google · Laufzeit lang (399 Tage) · vor Consent gesehen_ga_5EBT50JLF8Statistik · Einwilligung erforderlich · Anbieter Google · Laufzeit lang (399 Tage) · vor Consent gesehen15506c5c2936092e3ec13f6e93cdc469Unklassifiziert · unklar, prüfen · Anbieter pkp.de · Laufzeit Session · vor Consent gesehen_gcl_auUnklassifiziert · unklar, prüfen · Anbieter pkp.de · Laufzeit mittel (89 Tage) · vor Consent gesehen_gcl_lsUnklassifiziert · unklar, prüfen · Anbieter Eigene Website oder eingebundener Dienst · Laufzeit dauerhaft bis Löschung durch Nutzer/Browser · vor Consent gesehen

Barrierefreiheit & Usability

Sind Basis-Signale für Screenreader und Tastatur erkennbar?

15 Bild(er), 2 Formularfeld(er), 11 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft. Score: 56
2 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 1 mit hoher Auswirkung. Automatisch aus HTML-Signalen abgeleitet; ersetzt keine vollständige manuelle WCAG-/BITV-Prüfung.

Nachweis

Bilder ohne alt5Felder ohne Label0Buttons ohne Namen11HTML langjaH11Viewportja

WCAG/EAA-Prüfpunkte

Alternativtexte für BilderWCAG 1.1.1 Non-text Content · prüfen · Impact mittel · 5 von 15 Bild(er) ohne alt-Text im HTML-Sample.Formularfelder beschriftenWCAG 1.3.1 Info and Relationships / 3.3.2 Labels or Instructions · ok · Impact niedrig · 0 von 2 Formularfeld(er) ohne erkennbare Beschriftung.Buttons mit Namen versehenWCAG 4.1.2 Name, Role, Value · prüfen · Impact hoch · 11 von 11 Button(s) ohne erkennbaren Namen.Seitensprache auszeichnenWCAG 3.1.1 Language of Page · ok · Impact niedrig · HTML-lang-Attribut gefunden.ÜberschriftenstrukturWCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels · ok · Impact niedrig · 1 H1 und 18 Überschrift(en) im HTML-Sample.Mobile Viewport-BasisWCAG 1.4.10 Reflow · ok · Impact niedrig · Viewport-Meta-Tag gefunden.

BFSG/WCAG

Welche Erklärungs-Signale liegen vor?

Barrierefreiheits-Signale aus dem Scan. Status: Nicht vollständig konform im automatischen Basischeck
Erklärungstexte und allgemeine Umsetzungshinweise stehen auf separaten Seiten.

Mehr erfahren

Mehr erfahren2 bekannte Issue-Signal(e) aus dem Scan.Alternativtexte für BilderWCAG 1.1.1 Non-text Content · Impact mittel · 5 von 15 Bild(er) ohne alt-Text im HTML-Sample.Buttons mit Namen versehenWCAG 4.1.2 Name, Role, Value · Impact hoch · 11 von 11 Button(s) ohne erkennbaren Namen.

DSGVO, Cookies & Tracking

Welche Datenschutz-Signale fallen auf?

Consent-Hinweis: nein · Datenschutz-Hinweis: ja · Cookies: 1

Tracking

Keine bekannten Tracking-Scripts erkannt.

Cookies

15506c5c2936092e3ec13f6e93cdc469

Seiteninhalt & Keywords

Worum geht es auf der Seite?

Startseite - PKP Prozessmesstechnik GmbH
Messtechnik aus einer Hand - innovative Komponenten für die Messung und Überwachung von: Durchfluss, Füllstand, Druck, Temperatur. Überall, wo Durchflüsse, Füllstände, Drücke oder Temperaturen gemessen oder überwacht werden müssen, kommen unsere Produkte zum Einsatz.

durchfluss9füllstand9druck9temperatur9zubehör8prozessmesstechnik5produkte5informationen5

Technologie-Erkennung

Womit wurde die Seite gebaut?

Server: nginx · Powered-by: nicht erkannt · Generator: Joomla! - Open Source Content Management

Google Tag ManagerAnalyticsJoomlaCMSjQueryLibrarynginxServer

CVE & Versionsrisiko

Gibt es Hinweise auf bekannte Schwachstellen?

Keine Treffer in der konfigurierten Advisory-Quelle. Erkannte Versionen: 0 · Advisory-Treffer: 0 · Versionsregeln: 0

Ohne sichtbare Versionsnummern ist ein passiver CVE-Abgleich nur eingeschränkt möglich.

Impressum & Betreibertransparenz

Sind rechtliche Hinweise erkennbar?

Impressum: ja · Datenschutz: ja · Ablehnen-Option: ja

Keine auffälligen Impressum-/DSGVO-Muster erkannt.

Performance / PageSpeed-Basis

Wirkt die Seite schnell und mobil nutzbar?

Score: 94 · Antwortzeit: 1072 ms · HTML: 0 Bytes · Viewport: ja

Viele potenziell blockierende Assetsinfo

Infrastruktur & TLS-Vertrauen

DNS-, HTTPS- und E-Mail-Schutzsignale aus dem Scan

IPs: 2 · IPv6: ja · Zertifikat: 124 Tage · HSTS: nein · MX/SPF/DMARC: ja/ja/nein

DMARC fehltinfoCAA-Record fehltinfo

Security-Header

Welche Browser-Schutzheader sind gesetzt?

4 von 9 wichtigen Security-Headern vorhanden, 4 korrekt bewertet. Keine Content-Security-Policy gefunden. Score: 58 · vorhanden: 4 · fehlen: 5 · prüfen: 0

Mehr erfahren

Header-Evidence

HSTSfehlt · max-age=31536000; includeSubDomainsContent-Security-Policyfehlt · Schrittweise CSP mit default-src 'self' und expliziten Drittanbietern einführen.X-Frame-Optionsok · SAMEORIGINX-Content-Type-Optionsok · nosniffReferrer-Policyok · strict-origin-when-cross-originPermissions-Policyfehlt · Nicht benötigte Browser-APIs wie Kamera, Mikrofon und Geolocation sperren.Cross-Origin-Opener-Policyok · same-originCross-Origin-Resource-Policyfehlt · same-origin oder same-site nach RessourcenprüfungCross-Origin-Embedder-Policyfehlt · require-corp nur nach Prüfung aller eingebetteten Drittressourcen

Header-Vorlagen

Mehr erfahren4 vorhanden, 5 fehlen, 0 prüfen.

CSP-Qualität

Keine Content-Security-Policy gefunden.

Skript-Lieferkette

Externe Skript-Lieferkette aus dem gespeicherten Scan

1 externe Skript(e) von 1 Host(s), 1 ohne SRI, 0 Tracking-/Tag-nahe Skript(e). Score: 96 · Hosts: 1 · ohne SRI: 1 · Tracking/Tags: 0

Mehr erfahren

cloud.ccm19.deSonstige · cloud.ccm19.de · SRI fehlt

Zusammenhänge & Servernetzwerk

Verbindungs- und Servernetz-Signale aus dem Scan

Ad-/Tracking-IDs: 1 · gleiche-IP-Nachbarn: 0 · bekannte eingehende Links: 0 · Servernetze: 2

Signale

Google Tag ManagerGTM-KGDSV84sinfoweb.de1 Link(s)

Servernetz

2a00:1169:103:cab0::IPv6 · sh22996.ispgateway.de92.205.212.38IPv4 · sh22996.ispgateway.de2a00:1169:103:cab0::/64sichtbares Netz92.205.212.0/24sichtbares Netz

SEO, Verhalten & Cloaking

Gibt es manipulative Signale?

SEO-Risiko: high · Browser-Verhalten: low · Cloaking: low

Canonical zeigt auf fremde Domainwarning

Weitere technische Signale

Index-, KI-Crawler-, AdTech- und security.txt-Signale

Öffentlich abrufbare Same-Origin-Signale aus robots.txt, Sitemaps, Meta-/X-Robots, KI-/Crawler-Policys, ads.txt/sellers.json, security.txt und Hreflang. Jede Zeile ist ein technischer Beleg, kein abschließendes Urteil.

0Sitemap-URLs im passiven Lauf1Index-Direktiven (Meta/X-Robots)0explizite KI-Bot-Regeln0AdTech-Transparenzdateien0security.txt-Ziele2Hreflang-Alternates
Robots & Sitemaprobots.txt geprüft
Der passive Coverage-Check hat robots.txt erfolgreich abgerufen, 1 Sitemap-Quelle(n) gelesen, 1 Sitemap-Kandidat(en) gesehen, 0 Sitemap-URL(s) und 19 interne Linkziele gespeichert.
Crawl-Grenzen öffnen
Indexierungs-SignaleRobots-Direktiven gesehen
Der passive Abruf sah 1 Meta-Robots-Signal(e), 0 X-Robots-Tag-Wert(e) und 0 begrenzende Direktive(n): max-image-preview:large, max-snippet:-1, max-video-preview:-1.
Indexierungs-Grenzen öffnen
KI-/Crawler-PolicyPolicy-Dateien gesehen
Der passive Same-Origin-Check sah 1 von 5 festen Policy-Datei(en), 0 llms/AI/WARD-Datei(en) und 0 explizite KI-Bot-Regel(n) in robots.txt. robots.txt: generic_robots_policy; llms/AI/WARD: not_publicly_verified.
KI-/Crawler-Grenzen öffnen
AdTech-Transparenzdateiennicht belegt
Der passive Same-Origin-Check sah 0 von 3 AdTech-Datei(en), 0 ads.txt-Zeile(n), 0 app-ads.txt-Zeile(n), DIRECT 0, RESELLER 0, Exchange-Domains 0 und 0 sellers.json-Seller.
AdTech-Grenzen öffnen
Security-/Trust-Policynicht belegt
Der passive Same-Origin-Check sah 0 von 2 security.txt-Ziel(en), 0 Kontaktfeld(er), 0 strukturierte Feld(er), bevorzugter Well-known-Pfad: nein, Expires-Feld: nein.
Security-/Trust-Grenzen öffnen
Hreflang-/SprachalternativenAlternate-Links gesehen
Der HTML-Check sah 2 Hreflang-Alternate(s), davon 0 ungültige Codes, 0 fremde Zielhost(s) und 0 doppelte Sprachziele.
Mehr erfahren

Methodik-Grenzen öffnen

Alle Hinweise

Tracking-Cookies vor Einwilligung gesetzt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Möglicherweise nicht notwendige Cookies vor Einwilligung Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Sensible URL-Schlüssel im Drittanbieter-Kontext Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Langlebige Tracking-/Marketing-Cookies Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Google Consent Mode Default nicht erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Seiten-URL wird in Drittanbieter-Requests übertragen Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Dateneingabe und datenschutzrelevante Drittanbieter im selben Browseraufruf Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Canonical zeigt auf fremde Domain Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Datenschutzrelevante Kontakte trotz GPC-Signal Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Beacon-/Keepalive-Telemetrie erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Erkannte Anbieter fehlen in der Datenschutzerklärung Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Consent-Zustand: GPC mit Tracking-Hinweisen Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Viele Tastatur-/Eingabe-Listener im Browser erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Cookie ohne Secure-Flag Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Cookie ohne SameSite-Attribut Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Stand der Datenschutzerklärung nicht klar erkennbar Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Datenschutzkontakt oder DPO-Hinweis nicht klar erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Buttons ohne erkennbaren Namen Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Externe Skripte ohne Subresource Integrity Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Bilder ohne Alternativtext Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
HSTS fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Keine gängige CMP-/TCF-API im Browser erkannt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Viele potenziell blockierende Assets Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Content-Security-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Cross-Origin-Embedder-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Cross-Origin-Resource-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Datenschutzrelevante Drittanbieter im Browseraufruf Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Drittland-/US-Anbieter im Browseraufruf prüfen Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Consent-Banner mit Dark-Pattern-/UX-Risiko Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence.
Permissions-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Mehr erfahren
Scan-Fakten als JSON anzeigen
{
    "schema": "https://saferpage.de/schemas/public-scan-facts.v1",
    "claim_boundary": "Öffentliche Rohdaten enthalten nur Scan-Fakten, Statuswerte, Evidence-Grenzen und feste Detail-/Hintergrund-Links. Betreiber-Hintergrund, Planungen, Checklisten, Code und allgemeine Empfehlungen stehen auf separaten Seiten.",
    "current_evidence_policy": {
        "schema": "https://saferpage.de/schemas/public-scan-current-evidence-policy.v1",
        "status": "current_scan_fields_only",
        "summary": "Der Fakten-JSON exportiert nur Felder, die im gespeicherten aktuellen Scan wirklich vorhanden sind. Fehlende neue Evidence wird nicht aus alten Testergebnisformaten nachgebaut.",
        "guardrails": [
            "Keine synthetischen Boundary-Fallbacks fuer alte Scans",
            "Keine Nachbewertung alter Testergebnisse im Fakten-JSON",
            "Keine Betreiber-Empfehlung im Report-JSON"
        ]
    },
    "host": "pkp.de",
    "normalized_url": "https://pkp.de/",
    "score": 52,
    "verdict": {
        "color": "orange",
        "label": "auffällig",
        "score": 52
    },
    "scan_id": "15f79e95-d7a3-4c52-a5ca-462c3bfe4676",
    "created_at": "2026-06-17 12:35:53.973371+02",
    "evidence": {
        "dns": {
            "ok": true,
            "addresses": [
                "2a00:1169:103:cab0::",
                "92.205.212.38"
            ],
            "duration_ms": 102
        },
        "tls": {
            "ok": true,
            "cipher": "TLS_AES_256_GCM_SHA384",
            "issuer": [
                [
                    [
                        "countryName",
                        "US"
                    ]
                ],
                [
                    [
                        "stateOrProvinceName",
                        "Arizona"
                    ]
                ],
                [
                    [
                        "localityName",
                        "Scottsdale"
                    ]
                ],
                [
                    [
                        "organizationName",
                        "Starfield Technologies, Inc."
                    ]
                ],
                [
                    [
                        "organizationalUnitName",
                        "http://certs.starfieldtech.com/repository/"
                    ]
                ],
                [
                    [
                        "commonName",
                        "Starfield Secure Certificate Authority - G2"
                    ]
                ]
            ],
            "subject": [
                [
                    [
                        "commonName",
                        "pkp.de"
                    ]
                ]
            ],
            "version": "TLSv1.3",
            "not_after": "Oct 20 07:25:09 2026 GMT",
            "hostname_matches": true,
            "days_until_expiry": 124,
            "subject_alt_names": [
                "pkp.de",
                "www.pkp.de"
            ],
            "issuer_common_name": "Starfield Secure Certificate Authority - G2"
        },
        "http": {
            "ok": true,
            "status": 200,
            "headers": {
                "date": "Wed, 17 Jun 2026 10:35:42 GMT",
                "vary": "Accept-Encoding",
                "pragma": "no-cache",
                "server": "nginx",
                "expires": "Wed, 17 Aug 2005 00:00:00 GMT",
                "connection": "close",
                "set-cookie": "15506c5c2936092e3ec13f6e93cdc469=6rd6ekdbstj2lv3oofklo9gcqa; path=/; HttpOnly",
                "content-type": "text/html; charset=utf-8",
                "cache-control": "no-store, no-cache, must-revalidate, post-check=0, pre-check=0",
                "last-modified": "Wed, 17 Jun 2026 10:35:42 GMT",
                "x-cache-status": "MISS",
                "referrer-policy": "strict-origin-when-cross-origin",
                "x-frame-options": "SAMEORIGIN",
                "transfer-encoding": "chunked",
                "x-content-type-options": "nosniff",
                "cross-origin-opener-policy": "same-origin"
            },
            "body_size": 52540,
            "final_url": "https://www.pkp.de/de",
            "duration_ms": 1072
        },
        "scanner": {
            "bot_url": "https://saferpage.de/bot",
            "context": "manual",
            "user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)",
            "default_user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)"
        },
        "domain_records": {
            "mx": true,
            "caa": false,
            "spf": true,
            "dmarc": false,
            "dnssec": false,
            "records": {
                "mx": [
                    "100 mxlb.ispgateway.de."
                ],
                "ns": [
                    "ns82.domaincontrol.com.",
                    "ns81.domaincontrol.com."
                ],
                "caa": [],
                "txt": [
                    "v=spf1 mx a include:ispgateway.de -all"
                ],
                "cname": [],
                "dmarc": [
                    "v=spf1 mx a include:ispgateway.de -all"
                ],
                "dnskey_present": false
            },
            "spf_includes": [
                "ispgateway.de"
            ],
            "verifications": []
        },
        "googlebot_http": {
            "ok": true,
            "status": 200,
            "headers": {
                "date": "Wed, 17 Jun 2026 10:35:42 GMT",
                "vary": "Accept-Encoding",
                "pragma": "no-cache",
                "server": "nginx",
                "expires": "Wed, 17 Aug 2005 00:00:00 GMT",
                "connection": "close",
                "set-cookie": "15506c5c2936092e3ec13f6e93cdc469=jfb81cetm2glmqp7tfq53bl649; path=/; HttpOnly",
                "content-type": "text/html; charset=utf-8",
                "cache-control": "no-store, no-cache, must-revalidate, post-check=0, pre-check=0",
                "last-modified": "Wed, 17 Jun 2026 10:35:42 GMT",
                "x-cache-status": "MISS",
                "referrer-policy": "strict-origin-when-cross-origin",
                "x-frame-options": "SAMEORIGIN",
                "transfer-encoding": "chunked",
                "x-content-type-options": "nosniff",
                "cross-origin-opener-policy": "same-origin"
            },
            "body_size": 52540,
            "final_url": "https://www.pkp.de/de",
            "duration_ms": 1074
        },
        "ai_search_policy_evidence": {
            "files": [
                {
                    "id": "robots_txt",
                    "url": "https://www.pkp.de/robots.txt",
                    "label": "robots.txt",
                    "reason": "",
                    "status": "found",
                    "body_size": 793,
                    "truncated": false,
                    "body_sha256": "7a08435e433c689c1aa5942596006845764567f32dd07d488955405137338e56",
                    "duration_ms": 88,
                    "http_status": 200,
                    "ai_bot_policy": {
                        "bot_directives": [],
                        "explicit_ai_bots": [],
                        "explicit_ai_bot_count": 0,
                        "wildcard_directive_count": 15,
                        "wildcard_directives_sample": [
                            {
                                "value": "/administrator/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/api/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/bin/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/cache/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/cli/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/components/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/includes/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/installation/",
                                "directive": "disallow"
                            }
                        ]
                    },
                    "relevant_lines": [
                        "# eg the Disallow rule for the /administrator/ folder MUST",
                        "# Disallow: /joomla/administrator/",
                        "User-agent: *",
                        "Disallow: /administrator/",
                        "Disallow: /api/",
                        "Disallow: /bin/",
                        "Disallow: /cache/",
                        "Disallow: /cli/",
                        "Disallow: /components/",
                        "Disallow: /includes/",
                        "Disallow: /installation/",
                        "Disallow: /language/",
                        "Disallow: /layouts/",
                        "Disallow: /libraries/",
                        "Disallow: /logs/",
                        "Disallow: /modules/"
                    ]
                },
                {
                    "id": "llms_txt",
                    "url": "https://www.pkp.de/llms.txt",
                    "label": "llms.txt",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 298,
                    "http_status": 301,
                    "relevant_lines": []
                },
                {
                    "id": "ai_txt",
                    "url": "https://www.pkp.de/.well-known/ai.txt",
                    "label": "AI Policy",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 220,
                    "http_status": 301,
                    "relevant_lines": []
                },
                {
                    "id": "ai_policy_txt",
                    "url": "https://www.pkp.de/.well-known/ai-policy.txt",
                    "label": "AI Policy",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 195,
                    "http_status": 301,
                    "relevant_lines": []
                },
                {
                    "id": "ward_txt",
                    "url": "https://www.pkp.de/.well-known/ward.txt",
                    "label": "WARD Policy",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 168,
                    "http_status": 301,
                    "relevant_lines": []
                }
            ],
            "origin": "https://www.pkp.de",
            "schema": "https://saferpage.de/schemas/ai-search-policy-evidence.v1",
            "status": "checked",
            "metrics": {
                "file_count": 5,
                "found_file_count": 1,
                "policy_file_count": 0,
                "explicit_ai_bot_count": 0
            },
            "summary": "1 von 5 Policy-Datei(en) gefunden; 0 explizite KI-Bot-Regel(n) in robots.txt.",
            "available": true,
            "guardrails": [
                "Nur feste Same-Origin-Policy-Dateien",
                "Keine Off-Host-Redirects",
                "64-KB-Body-Limit",
                "Öffentlich nur Hash, Status und kurze relevante Zeilen"
            ],
            "known_ai_bots": [
                "GPTBot",
                "ChatGPT-User",
                "Google-Extended",
                "ClaudeBot",
                "PerplexityBot",
                "CCBot"
            ],
            "explicit_ai_bots": [],
            "policy_file_count": 0,
            "llms_ward_policy_status": "not_publicly_verified",
            "robots_ai_policy_status": "generic_robots_policy"
        },
        "adtech_transparency_evidence": {
            "files": [
                {
                    "id": "ads_txt",
                    "url": "https://www.pkp.de/ads.txt",
                    "label": "ads.txt",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 302,
                    "http_status": 301,
                    "ads_txt_policy": [],
                    "relevant_lines": [],
                    "sellers_json_policy": []
                },
                {
                    "id": "app_ads_txt",
                    "url": "https://www.pkp.de/app-ads.txt",
                    "label": "app-ads.txt",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 216,
                    "http_status": 301,
                    "ads_txt_policy": [],
                    "relevant_lines": [],
                    "sellers_json_policy": []
                },
                {
                    "id": "sellers_json",
                    "url": "https://www.pkp.de/sellers.json",
                    "label": "sellers.json",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 217,
                    "http_status": 301,
                    "ads_txt_policy": [],
                    "relevant_lines": [],
                    "sellers_json_policy": []
                }
            ],
            "origin": "https://www.pkp.de",
            "schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
            "status": "checked",
            "metrics": {
                "file_count": 3,
                "direct_count": 0,
                "reseller_count": 0,
                "found_file_count": 0,
                "ads_txt_entry_count": 0,
                "exchange_domain_count": 0,
                "app_ads_txt_entry_count": 0,
                "sellers_json_seller_count": 0
            },
            "summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
            "available": true,
            "guardrails": [
                "Nur feste Same-Origin-AdTech-Dateien",
                "Keine Off-Host-Redirects",
                "64-KB-Body-Limit",
                "Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
            ],
            "direct_count": 0,
            "ads_txt_found": false,
            "reseller_count": 0,
            "app_ads_txt_found": false,
            "sellers_json_found": false,
            "ads_txt_entry_count": 0,
            "exchange_domain_count": 0,
            "sellers_json_parse_ok": false,
            "app_ads_txt_entry_count": 0,
            "sellers_json_seller_count": 0
        },
        "security_trust_policy_evidence": {
            "files": [
                {
                    "id": "security_txt",
                    "url": "https://www.pkp.de/.well-known/security.txt",
                    "label": "security.txt",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 257,
                    "http_status": 301,
                    "relevant_lines": [],
                    "security_txt_policy": []
                },
                {
                    "id": "security_txt_legacy",
                    "url": "https://www.pkp.de/security.txt",
                    "label": "security.txt legacy",
                    "reason": "redirect_blocked",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 173,
                    "http_status": 301,
                    "relevant_lines": [],
                    "security_txt_policy": []
                }
            ],
            "origin": "https://www.pkp.de",
            "schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
            "status": "checked",
            "metrics": {
                "file_count": 2,
                "field_count": 0,
                "contact_count": 0,
                "found_file_count": 0,
                "preferred_well_known_found": 0
            },
            "summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
            "available": true,
            "guardrails": [
                "Nur feste Same-Origin-security.txt-Ziele",
                "Keine Off-Host-Redirects",
                "64-KB-Body-Limit",
                "Öffentlich nur Hash, Status und kurze relevante Zeilen"
            ],
            "field_count": 0,
            "contact_count": 0,
            "fields_present": [],
            "policy_present": false,
            "expires_present": false,
            "encryption_present": false,
            "security_txt_found": false,
            "preferred_well_known_found": false
        }
    },
    "findings": [
        {
            "id": "pre_consent_tracking_cookies",
            "title": "Tracking-Cookies vor Einwilligung gesetzt",
            "public": true,
            "source": "chromium_cookie_inventory",
            "cookies": [
                "_ga",
                "_ga_5EBT50JLF8"
            ],
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 128,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "pre_consent_nonessential_cookies",
            "title": "Möglicherweise nicht notwendige Cookies vor Einwilligung",
            "public": true,
            "cookies": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ],
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 127,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "third_party_sensitive_query_leak",
            "count": 2,
            "title": "Sensible URL-Schlüssel im Drittanbieter-Kontext",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 126,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "long_lived_tracking_cookie",
            "count": 2,
            "title": "Langlebige Tracking-/Marketing-Cookies",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 122,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "google_consent_mode_missing",
            "title": "Google Consent Mode Default nicht erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 120,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "third_party_page_url_parameter",
            "count": 2,
            "title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 118,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "pii_tracking_on_data_entry_page",
            "title": "Dateneingabe und datenschutzrelevante Drittanbieter im selben Browseraufruf",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 118,
            "importance_label": "Wichtig für Nutzer",
            "third_party_count": 2
        },
        {
            "id": "external_canonical",
            "title": "Canonical zeigt auf fremde Domain",
            "public": true,
            "audience": "nutzer",
            "category": "seo",
            "severity": "warning",
            "canonical_url": "https://www.pkp.de/de",
            "user_importance": 118,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "gpc_privacy_domains_present",
            "count": 2,
            "title": "Datenschutzrelevante Kontakte trotz GPC-Signal",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 116,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "beacon_api_usage",
            "count": 4,
            "title": "Beacon-/Keepalive-Telemetrie erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 116,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "privacy_policy_provider_disclosure_gap",
            "title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 116,
            "importance_label": "Wichtig für Nutzer",
            "missing_providers": [
                "Google Analytics"
            ]
        },
        {
            "id": "consent_state_gpc_evidence_review",
            "title": "Consent-Zustand: GPC mit Tracking-Hinweisen",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 112,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "browser_keystroke_listener_signals",
            "count": 12,
            "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 110,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "cookie_missing_secure",
            "title": "Cookie ohne Secure-Flag",
            "public": true,
            "cookies": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ],
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 102,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "cookie_missing_samesite",
            "title": "Cookie ohne SameSite-Attribut",
            "public": true,
            "cookies": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ],
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 98,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "privacy_policy_update_date_missing",
            "title": "Stand der Datenschutzerklärung nicht klar erkennbar",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 94,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "privacy_policy_dpo_contact_missing",
            "title": "Datenschutzkontakt oder DPO-Hinweis nicht klar erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 90,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "button_name_missing",
            "count": 11,
            "title": "Buttons ohne erkennbaren Namen",
            "public": true,
            "audience": "nutzer",
            "category": "accessibility",
            "severity": "warning",
            "user_importance": 86,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "external_script_without_sri",
            "count": 1,
            "title": "Externe Skripte ohne Subresource Integrity",
            "public": true,
            "audience": "nutzer",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 84,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "image_alt_missing",
            "count": 5,
            "title": "Bilder ohne Alternativtext",
            "public": true,
            "audience": "nutzer",
            "category": "accessibility",
            "severity": "info",
            "user_importance": 82,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "missing_hsts",
            "title": "HSTS fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "warning",
            "user_importance": 78,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "cmp_api_not_detected",
            "title": "Keine gängige CMP-/TCF-API im Browser erkannt",
            "public": true,
            "audience": "betreiber",
            "category": "privacy",
            "severity": "info",
            "user_importance": 74,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "too_many_render_blocking_assets",
            "title": "Viele potenziell blockierende Assets",
            "public": true,
            "audience": "betreiber",
            "category": "performance",
            "severity": "info",
            "user_importance": 74,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "missing_csp",
            "title": "Content-Security-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "warning",
            "user_importance": 72,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "missing_cross_origin_embedder_policy",
            "title": "Cross-Origin-Embedder-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 68,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "missing_cross_origin_resource_policy",
            "title": "Cross-Origin-Resource-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 64,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "browser_privacy_relevant_third_parties",
            "title": "Datenschutzrelevante Drittanbieter im Browseraufruf",
            "public": true,
            "audience": "betreiber",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 60,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "third_country_transfer_review",
            "title": "Drittland-/US-Anbieter im Browseraufruf prüfen",
            "public": true,
            "audience": "betreiber",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 60,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "consent_banner_dark_pattern_risk",
            "count": 1,
            "title": "Consent-Banner mit Dark-Pattern-/UX-Risiko",
            "public": true,
            "audience": "betreiber",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 60,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "missing_permissions_policy",
            "title": "Permissions-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 40,
            "importance_label": "Technischer Hinweis"
        }
    ],
    "audit_modules": [
        {
            "id": "privacy_consent",
            "color": "red",
            "score": 18,
            "title": "Datenschutz, Cookies & Consent",
            "source": "Browser, HTTP-Header, HTML und Consent-/Cookie-Heuristik",
            "status": "kritisch",
            "evidence": "0 Tracking-Script(s), 4 Cookie(s) vor Einwilligung, 2 Tracking-Cookie(s), Ablehnen-Option: ja, Consent-Audit: 18."
        },
        {
            "id": "browser_evidence",
            "color": "red",
            "score": 19,
            "title": "Browser-Nachweis",
            "source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
            "status": "kritisch",
            "evidence": "36 Request(s), 4 Drittanbieter-Domain(s), davon 2 datenschutzrelevant, 4 Browser-Cookie(s), Transfer-Prüfbedarf: 3, Referrer-/URL-Leaks: 3, Fingerprinting-/Replay-Hinweise: 1."
        },
        {
            "id": "referrer_url_leaks",
            "color": "red",
            "score": 31,
            "title": "Referrer & URL-Leaks",
            "source": "Chromium-Request-Telemetrie ohne gespeicherte Parameterwerte",
            "status": "kritisch",
            "evidence": "3 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 2 sensible Query-Kontexte."
        },
        {
            "id": "cookie_inventory",
            "color": "red",
            "score": 40,
            "title": "Cookie-Inventar",
            "source": "HTTP-Set-Cookie und Chromium-Cookies beim ersten Seitenaufruf",
            "status": "kritisch",
            "evidence": "4 Cookie(s), 2 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 2 langlebig, 0 sehr lang."
        },
        {
            "id": "accessibility_usability",
            "color": "orange",
            "score": 56,
            "title": "Barrierefreiheit & Usability",
            "source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
            "status": "auffällig",
            "evidence": "5 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 11 Button(s) ohne Namen."
        },
        {
            "id": "google_third_parties",
            "color": "orange",
            "score": 58,
            "title": "Google-Dienste & Drittanbieter",
            "source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
            "status": "auffällig",
            "evidence": "Google-Tags: ja, 3 Google-nahe Domain(s), Consent-Default: nein, Analytics: ja, Werbung: nein, Fonts: nein."
        },
        {
            "id": "security_tls",
            "color": "orange",
            "score": 58,
            "title": "Sicherheit, TLS & Header",
            "source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
            "status": "auffällig",
            "evidence": "2 Infrastruktur-Hinweis(e), Security-Header: 4/9 vorhanden, 5 fehlen, externe Skript-Hosts: 1."
        },
        {
            "id": "tracking_pixels_beacons",
            "color": "orange",
            "score": 66,
            "title": "Tracking-Pixel & Beacons",
            "source": "HTML-Pixel, Link-Ping-Attribute, Chromium-Requests und Browser-API-Instrumentierung",
            "status": "auffällig",
            "evidence": "0 Pixel-/Bildtracking-Hinweis(e), 4 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s)."
        },
        {
            "id": "forms_payments",
            "color": "yellow",
            "score": 82,
            "title": "Formulare, Login & Zahlung",
            "source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
            "status": "prüfen",
            "evidence": "Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten."
        },
        {
            "id": "pii_exposure",
            "color": "yellow",
            "score": 82,
            "title": "PII, URL-Parameter & Datenleck-Schutz",
            "source": "URL-Parameter, interne Links, HTML-Formulare, Browser-Drittanbieter und Dateneingabe-Kontext",
            "status": "prüfen",
            "evidence": "1 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext."
        },
        {
            "id": "seo_integrity",
            "color": "yellow",
            "score": 82,
            "title": "SEO-Integrität & Cloaking",
            "source": "HTML-Inhalt, strukturierte Daten, Links und Googlebot-Vergleich",
            "status": "prüfen",
            "evidence": "1 SEO-Spam-Hinweis(e), 0 Cloaking-Hinweis(e)."
        },
        {
            "id": "consent_journey",
            "color": "yellow",
            "score": 84,
            "title": "Consent-Journey-Matrix",
            "source": "Chromium-Zustände: Erstaufruf, Reject, Accept und GPC",
            "status": "prüfen",
            "evidence": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 2 im GPC-Aufruf."
        },
        {
            "id": "performance_mobile",
            "color": "green",
            "score": 94,
            "title": "Performance & mobile Nutzbarkeit",
            "source": "HTTP-Antwort, HTML-Größe, Komprimierung und mobile Basis",
            "status": "unauffällig",
            "evidence": "Performance-Score 94, Antwortzeit 1072 ms."
        },
        {
            "id": "site_coverage",
            "color": "green",
            "score": 95,
            "title": "Seitenabdeckung & Crawl",
            "source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
            "status": "unauffällig",
            "evidence": "19 interne Linkziele erkannt, 4 priorisierte Unterseite(n) abgerufen."
        },
        {
            "id": "script_supply_chain",
            "color": "green",
            "score": 96,
            "title": "Externe Skripte & SRI",
            "source": "HTML-Script-Tags, Anbieterklassifikation und SRI-Attribute",
            "status": "unauffällig",
            "evidence": "1 externe Skript(e) von 1 Host(s), 1 ohne SRI, 0 Tracking-/Tag-nahe Skript(e)."
        },
        {
            "id": "embedded_content",
            "color": "green",
            "score": 100,
            "title": "Externe Inhalte & Widgets",
            "source": "HTML-Embeds und Chromium-Drittanbieter-Requests",
            "status": "unauffällig",
            "evidence": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen."
        },
        {
            "id": "operator_transparency",
            "color": "green",
            "score": 100,
            "title": "Impressum, Kontakt & Datenschutzerklärung",
            "source": "Deutschsprachige Betreiber- und Datenschutzhinweis-Erkennung",
            "status": "unauffällig",
            "evidence": "Impressum: ja, Datenschutz: ja, Kontakt: ja."
        }
    ],
    "ai_search_policy_evidence": {
        "files": [
            {
                "id": "robots_txt",
                "url": "https://www.pkp.de/robots.txt",
                "label": "robots.txt",
                "reason": "",
                "status": "found",
                "body_size": 793,
                "truncated": false,
                "body_sha256": "7a08435e433c689c1aa5942596006845764567f32dd07d488955405137338e56",
                "duration_ms": 88,
                "http_status": 200,
                "ai_bot_policy": {
                    "bot_directives": [],
                    "explicit_ai_bots": [],
                    "explicit_ai_bot_count": 0,
                    "wildcard_directive_count": 15,
                    "wildcard_directives_sample": [
                        {
                            "value": "/administrator/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/api/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/bin/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/cache/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/cli/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/components/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/includes/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/installation/",
                            "directive": "disallow"
                        }
                    ]
                },
                "relevant_lines": [
                    "# eg the Disallow rule for the /administrator/ folder MUST",
                    "# Disallow: /joomla/administrator/",
                    "User-agent: *",
                    "Disallow: /administrator/",
                    "Disallow: /api/",
                    "Disallow: /bin/",
                    "Disallow: /cache/",
                    "Disallow: /cli/",
                    "Disallow: /components/",
                    "Disallow: /includes/",
                    "Disallow: /installation/",
                    "Disallow: /language/",
                    "Disallow: /layouts/",
                    "Disallow: /libraries/",
                    "Disallow: /logs/",
                    "Disallow: /modules/"
                ]
            },
            {
                "id": "llms_txt",
                "url": "https://www.pkp.de/llms.txt",
                "label": "llms.txt",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 298,
                "http_status": 301,
                "relevant_lines": []
            },
            {
                "id": "ai_txt",
                "url": "https://www.pkp.de/.well-known/ai.txt",
                "label": "AI Policy",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 220,
                "http_status": 301,
                "relevant_lines": []
            },
            {
                "id": "ai_policy_txt",
                "url": "https://www.pkp.de/.well-known/ai-policy.txt",
                "label": "AI Policy",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 195,
                "http_status": 301,
                "relevant_lines": []
            },
            {
                "id": "ward_txt",
                "url": "https://www.pkp.de/.well-known/ward.txt",
                "label": "WARD Policy",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 168,
                "http_status": 301,
                "relevant_lines": []
            }
        ],
        "origin": "https://www.pkp.de",
        "schema": "https://saferpage.de/schemas/ai-search-policy-evidence.v1",
        "status": "checked",
        "metrics": {
            "file_count": 5,
            "found_file_count": 1,
            "policy_file_count": 0,
            "explicit_ai_bot_count": 0
        },
        "summary": "1 von 5 Policy-Datei(en) gefunden; 0 explizite KI-Bot-Regel(n) in robots.txt.",
        "available": true,
        "guardrails": [
            "Nur feste Same-Origin-Policy-Dateien",
            "Keine Off-Host-Redirects",
            "64-KB-Body-Limit",
            "Öffentlich nur Hash, Status und kurze relevante Zeilen"
        ],
        "known_ai_bots": [
            "GPTBot",
            "ChatGPT-User",
            "Google-Extended",
            "ClaudeBot",
            "PerplexityBot",
            "CCBot"
        ],
        "explicit_ai_bots": [],
        "policy_file_count": 0,
        "llms_ward_policy_status": "not_publicly_verified",
        "robots_ai_policy_status": "generic_robots_policy"
    },
    "adtech_transparency_evidence": {
        "files": [
            {
                "id": "ads_txt",
                "url": "https://www.pkp.de/ads.txt",
                "label": "ads.txt",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 302,
                "http_status": 301,
                "ads_txt_policy": [],
                "relevant_lines": [],
                "sellers_json_policy": []
            },
            {
                "id": "app_ads_txt",
                "url": "https://www.pkp.de/app-ads.txt",
                "label": "app-ads.txt",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 216,
                "http_status": 301,
                "ads_txt_policy": [],
                "relevant_lines": [],
                "sellers_json_policy": []
            },
            {
                "id": "sellers_json",
                "url": "https://www.pkp.de/sellers.json",
                "label": "sellers.json",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 217,
                "http_status": 301,
                "ads_txt_policy": [],
                "relevant_lines": [],
                "sellers_json_policy": []
            }
        ],
        "origin": "https://www.pkp.de",
        "schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
        "status": "checked",
        "metrics": {
            "file_count": 3,
            "direct_count": 0,
            "reseller_count": 0,
            "found_file_count": 0,
            "ads_txt_entry_count": 0,
            "exchange_domain_count": 0,
            "app_ads_txt_entry_count": 0,
            "sellers_json_seller_count": 0
        },
        "summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
        "available": true,
        "guardrails": [
            "Nur feste Same-Origin-AdTech-Dateien",
            "Keine Off-Host-Redirects",
            "64-KB-Body-Limit",
            "Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
        ],
        "direct_count": 0,
        "ads_txt_found": false,
        "reseller_count": 0,
        "app_ads_txt_found": false,
        "sellers_json_found": false,
        "ads_txt_entry_count": 0,
        "exchange_domain_count": 0,
        "sellers_json_parse_ok": false,
        "app_ads_txt_entry_count": 0,
        "sellers_json_seller_count": 0
    },
    "security_trust_policy_evidence": {
        "files": [
            {
                "id": "security_txt",
                "url": "https://www.pkp.de/.well-known/security.txt",
                "label": "security.txt",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 257,
                "http_status": 301,
                "relevant_lines": [],
                "security_txt_policy": []
            },
            {
                "id": "security_txt_legacy",
                "url": "https://www.pkp.de/security.txt",
                "label": "security.txt legacy",
                "reason": "redirect_blocked",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 173,
                "http_status": 301,
                "relevant_lines": [],
                "security_txt_policy": []
            }
        ],
        "origin": "https://www.pkp.de",
        "schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
        "status": "checked",
        "metrics": {
            "file_count": 2,
            "field_count": 0,
            "contact_count": 0,
            "found_file_count": 0,
            "preferred_well_known_found": 0
        },
        "summary": "0 von 2 security.txt-Ziel(en) gefunden; 0 Kontaktfeld(er), 0 strukturierte Feld(er).",
        "available": true,
        "guardrails": [
            "Nur feste Same-Origin-security.txt-Ziele",
            "Keine Off-Host-Redirects",
            "64-KB-Body-Limit",
            "Öffentlich nur Hash, Status und kurze relevante Zeilen"
        ],
        "field_count": 0,
        "contact_count": 0,
        "fields_present": [],
        "policy_present": false,
        "expires_present": false,
        "encryption_present": false,
        "security_txt_found": false,
        "preferred_well_known_found": false
    },
    "site_coverage_analysis": {
        "color": "green",
        "pages": [
            {
                "url": "https://www.pkp.de/de/kontakt/datenschutz",
                "path": "/de/kontakt/datenschutz",
                "text": "Datenschutz",
                "source": "homepage_link",
                "category": "datenschutz",
                "priority": 100
            },
            {
                "url": "https://www.pkp.de/de/kontakt/impressum",
                "path": "/de/kontakt/impressum",
                "text": "Impressum",
                "source": "homepage_link",
                "category": "impressum",
                "priority": 96
            },
            {
                "url": "https://www.pkp.de/de/kontakt",
                "path": "/de/kontakt",
                "text": "Kontakt",
                "source": "homepage_link",
                "category": "kontakt",
                "priority": 90
            },
            {
                "url": "https://www.pkp.de/de/kontakt/allgemeine-geschaeftsbedingungen",
                "path": "/de/kontakt/allgemeine-geschaeftsbedingungen",
                "text": "AGBs",
                "source": "homepage_link",
                "category": "kontakt",
                "priority": 90
            },
            {
                "url": "https://www.pkp.de/de/info-anfrage-downloads",
                "path": "/de/info-anfrage-downloads",
                "text": "Info/Anfrage/Downloads",
                "source": "homepage_link",
                "category": "newsletter",
                "priority": 64
            },
            {
                "url": "https://www.pkp.de/de",
                "path": "/de",
                "text": "",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.pkp.de/de/pkp-produkte",
                "path": "/de/pkp-produkte",
                "text": "Produkte",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.pkp.de/de/pkp-produkte/druck",
                "path": "/de/pkp-produkte/druck",
                "text": "Druck",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.pkp.de/de/pkp-produkte/durchfluss",
                "path": "/de/pkp-produkte/durchfluss",
                "text": "Durchfluss",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.pkp.de/de/pkp-produkte/durchfluss/fluegelrad-turbinendurchflussmesser/dr20b-dw-fs-schaufelrad-durchflusstransmitter",
                "path": "/de/pkp-produkte/durchfluss/fluegelrad-turbinendurchflussmesser/dr20b-dw-fs-schaufelrad-durchflusstransmitter",
                "text": "DR20B Schaufelrad-Durchflusstransmitter",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.pkp.de/de/pkp-produkte/fuellstand",
                "path": "/de/pkp-produkte/fuellstand",
                "text": "Füllstand",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.pkp.de/de/pkp-produkte/suche",
                "path": "/de/pkp-produkte/suche",
                "text": "Suche",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            }
        ],
        "score": 95,
        "status": "unauffällig",
        "summary": "19 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen.",
        "findings": [
            {
                "id": "privacy_policy_update_date_missing",
                "title": "Stand der Datenschutzerklärung nicht klar erkennbar",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "privacy_policy_dpo_contact_missing",
                "title": "Datenschutzkontakt oder DPO-Hinweis nicht klar erkannt",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "privacy_policy_provider_disclosure_gap",
                "title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
                "public": true,
                "category": "privacy",
                "severity": "warning",
                "missing_providers": [
                    "Google Analytics"
                ]
            }
        ],
        "robots_ok": true,
        "categories": {
            "kontakt": 2,
            "impressum": 1,
            "newsletter": 1,
            "unterseite": 14,
            "datenschutz": 1
        },
        "sample_limit": 4,
        "sampled_count": 4,
        "sampled_pages": [
            {
                "ok": true,
                "url": "https://www.pkp.de/de/kontakt/datenschutz",
                "path": "/de/kontakt/datenschutz",
                "audit": {
                    "form_count": 2,
                    "finding_ids": [
                        "cookie_missing_secure",
                        "cookie_missing_samesite"
                    ],
                    "cookie_count": 1,
                    "imprint_found": true,
                    "consent_hint_found": true,
                    "reject_option_found": true,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 1,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 2,
                "title": "PKP GmbH - Datenschutz",
                "status": 200,
                "category": "datenschutz",
                "duration_ms": 450,
                "privacy_hint": true,
                "privacy_policy_audit": {
                    "url": "https://www.pkp.de/de/kontakt/datenschutz",
                    "color": "yellow",
                    "found": [
                        "Verantwortlicher / Anbieter",
                        "Kontakt / Datenschutzkontakt",
                        "Zwecke der Verarbeitung",
                        "Rechtsgrundlagen",
                        "Betroffenenrechte",
                        "Speicherfrist / Löschung",
                        "Empfänger / Auftragsverarbeiter",
                        "Cookies / Tracking",
                        "Widerruf / Opt-out",
                        "Beschwerde bei Aufsichtsbehörde",
                        "Drittlandtransfer",
                        "Verständliche Satzlänge"
                    ],
                    "score": 86,
                    "checks": [
                        {
                            "id": "controller_identity",
                            "found": true,
                            "label": "Verantwortlicher / Anbieter"
                        },
                        {
                            "id": "contact",
                            "found": true,
                            "label": "Kontakt / Datenschutzkontakt"
                        },
                        {
                            "id": "purposes",
                            "found": true,
                            "label": "Zwecke der Verarbeitung"
                        },
                        {
                            "id": "legal_basis",
                            "found": true,
                            "label": "Rechtsgrundlagen"
                        },
                        {
                            "id": "rights",
                            "found": true,
                            "label": "Betroffenenrechte"
                        },
                        {
                            "id": "retention",
                            "found": true,
                            "label": "Speicherfrist / Löschung"
                        },
                        {
                            "id": "recipients",
                            "found": true,
                            "label": "Empfänger / Auftragsverarbeiter"
                        },
                        {
                            "id": "cookies_tracking",
                            "found": true,
                            "label": "Cookies / Tracking"
                        },
                        {
                            "id": "withdrawal",
                            "found": true,
                            "label": "Widerruf / Opt-out"
                        },
                        {
                            "id": "complaint_authority",
                            "found": true,
                            "label": "Beschwerde bei Aufsichtsbehörde"
                        },
                        {
                            "id": "third_country_transfer",
                            "found": true,
                            "label": "Drittlandtransfer"
                        },
                        {
                            "id": "update_date",
                            "found": false,
                            "label": "Stand / Aktualitätsdatum",
                            "detail": ""
                        },
                        {
                            "id": "dpo_contact",
                            "found": false,
                            "label": "Datenschutzkontakt / DPO-Hinweis"
                        },
                        {
                            "id": "readability",
                            "found": true,
                            "label": "Verständliche Satzlänge",
                            "detail": "10.9 Wörter/Satz"
                        }
                    ],
                    "status": "prüfen",
                    "missing": [
                        "Stand / Aktualitätsdatum",
                        "Datenschutzkontakt / DPO-Hinweis"
                    ],
                    "summary": "12 von 14 zentralen Datenschutz-Bausteinen erkannt.",
                    "findings": [
                        {
                            "id": "privacy_policy_update_date_missing",
                            "title": "Stand der Datenschutzerklärung nicht klar erkennbar",
                            "public": true,
                            "category": "privacy",
                            "severity": "info"
                        },
                        {
                            "id": "privacy_policy_dpo_contact_missing",
                            "title": "Datenschutzkontakt oder DPO-Hinweis nicht klar erkannt",
                            "public": true,
                            "category": "privacy",
                            "severity": "info"
                        }
                    ],
                    "available": true,
                    "freshness": {
                        "stale": false,
                        "age_days": null,
                        "last_updated": "",
                        "update_date_found": false
                    },
                    "word_count": 4153,
                    "readability": {
                        "hard_to_read": false,
                        "sentence_count": 382,
                        "avg_sentence_words": 10.9
                    },
                    "missing_count": 2,
                    "dpo_contact_found": false
                }
            },
            {
                "ok": true,
                "url": "https://www.pkp.de/de/kontakt/impressum",
                "path": "/de/kontakt/impressum",
                "audit": {
                    "form_count": 2,
                    "finding_ids": [
                        "pre_consent_nonessential_cookies",
                        "cookie_missing_secure",
                        "cookie_missing_samesite",
                        "privacy_policy_too_thin",
                        "consent_no_reject_option",
                        "consent_accept_only"
                    ],
                    "cookie_count": 1,
                    "imprint_found": true,
                    "consent_hint_found": true,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 1,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 2,
                "title": "PKP GmbH - Impressum",
                "status": 200,
                "category": "impressum",
                "duration_ms": 432,
                "privacy_hint": true,
                "privacy_policy_audit": []
            },
            {
                "ok": true,
                "url": "https://www.pkp.de/de/kontakt",
                "path": "/de/kontakt",
                "audit": {
                    "form_count": 2,
                    "finding_ids": [
                        "pre_consent_nonessential_cookies",
                        "cookie_missing_secure",
                        "cookie_missing_samesite",
                        "privacy_policy_too_thin",
                        "consent_no_reject_option",
                        "consent_accept_only"
                    ],
                    "cookie_count": 1,
                    "imprint_found": true,
                    "consent_hint_found": true,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 1,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 2,
                "title": "Kontakt - PKP Prozessmesstechnik GmbH",
                "status": 200,
                "category": "kontakt",
                "duration_ms": 463,
                "privacy_hint": true,
                "privacy_policy_audit": []
            },
            {
                "ok": true,
                "url": "https://www.pkp.de/de/kontakt/allgemeine-geschaeftsbedingungen",
                "path": "/de/kontakt/allgemeine-geschaeftsbedingungen",
                "audit": {
                    "form_count": 2,
                    "finding_ids": [
                        "pre_consent_nonessential_cookies",
                        "cookie_missing_secure",
                        "cookie_missing_samesite",
                        "privacy_policy_too_thin",
                        "consent_no_reject_option",
                        "consent_accept_only"
                    ],
                    "cookie_count": 1,
                    "imprint_found": true,
                    "consent_hint_found": true,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 1,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 2,
                "title": "PKP GmbH - Allgemeine Geschäftsbedingungen",
                "status": 200,
                "category": "kontakt",
                "duration_ms": 449,
                "privacy_hint": true,
                "privacy_policy_audit": []
            }
        ],
        "robots_checked": true,
        "sitemap_sources": [
            "https://www.pkp.de/sitemap.xml"
        ],
        "sitemap_available": true,
        "sitemap_url_count": 0,
        "homepage_link_count": 54,
        "internal_link_count": 19,
        "privacy_policy_audit": {
            "url": "https://www.pkp.de/de/kontakt/datenschutz",
            "color": "yellow",
            "found": [
                "Verantwortlicher / Anbieter",
                "Kontakt / Datenschutzkontakt",
                "Zwecke der Verarbeitung",
                "Rechtsgrundlagen",
                "Betroffenenrechte",
                "Speicherfrist / Löschung",
                "Empfänger / Auftragsverarbeiter",
                "Cookies / Tracking",
                "Widerruf / Opt-out",
                "Beschwerde bei Aufsichtsbehörde",
                "Drittlandtransfer",
                "Verständliche Satzlänge"
            ],
            "score": 86,
            "checks": [
                {
                    "id": "controller_identity",
                    "found": true,
                    "label": "Verantwortlicher / Anbieter"
                },
                {
                    "id": "contact",
                    "found": true,
                    "label": "Kontakt / Datenschutzkontakt"
                },
                {
                    "id": "purposes",
                    "found": true,
                    "label": "Zwecke der Verarbeitung"
                },
                {
                    "id": "legal_basis",
                    "found": true,
                    "label": "Rechtsgrundlagen"
                },
                {
                    "id": "rights",
                    "found": true,
                    "label": "Betroffenenrechte"
                },
                {
                    "id": "retention",
                    "found": true,
                    "label": "Speicherfrist / Löschung"
                },
                {
                    "id": "recipients",
                    "found": true,
                    "label": "Empfänger / Auftragsverarbeiter"
                },
                {
                    "id": "cookies_tracking",
                    "found": true,
                    "label": "Cookies / Tracking"
                },
                {
                    "id": "withdrawal",
                    "found": true,
                    "label": "Widerruf / Opt-out"
                },
                {
                    "id": "complaint_authority",
                    "found": true,
                    "label": "Beschwerde bei Aufsichtsbehörde"
                },
                {
                    "id": "third_country_transfer",
                    "found": true,
                    "label": "Drittlandtransfer"
                },
                {
                    "id": "update_date",
                    "found": false,
                    "label": "Stand / Aktualitätsdatum",
                    "detail": ""
                },
                {
                    "id": "dpo_contact",
                    "found": false,
                    "label": "Datenschutzkontakt / DPO-Hinweis"
                },
                {
                    "id": "readability",
                    "found": true,
                    "label": "Verständliche Satzlänge",
                    "detail": "10.9 Wörter/Satz"
                }
            ],
            "status": "prüfen",
            "missing": [
                "Stand / Aktualitätsdatum",
                "Datenschutzkontakt / DPO-Hinweis"
            ],
            "summary": "12 von 14 zentralen Datenschutz-Bausteinen erkannt.",
            "findings": [
                {
                    "id": "privacy_policy_update_date_missing",
                    "title": "Stand der Datenschutzerklärung nicht klar erkennbar",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                },
                {
                    "id": "privacy_policy_dpo_contact_missing",
                    "title": "Datenschutzkontakt oder DPO-Hinweis nicht klar erkannt",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                }
            ],
            "available": true,
            "freshness": {
                "stale": false,
                "age_days": null,
                "last_updated": "",
                "update_date_found": false
            },
            "word_count": 4153,
            "readability": {
                "hard_to_read": false,
                "sentence_count": 382,
                "avg_sentence_words": 10.9
            },
            "missing_count": 2,
            "dpo_contact_found": false
        },
        "sitemap_source_count": 1,
        "provider_disclosure_audit": {
            "color": "orange",
            "found": [
                "Google Tag Manager",
                "Google"
            ],
            "score": 67,
            "checks": [
                {
                    "id": "tag_manager_google_tag_manager",
                    "found": true,
                    "category": "tag_manager",
                    "evidence": [
                        "GTM-KGDSV84",
                        "googletagmanager.com"
                    ],
                    "keywords": [
                        "google tag manager",
                        "tag manager",
                        "googletagmanager",
                        "gtm-"
                    ],
                    "provider": "Google Tag Manager",
                    "category_label": "Tracking-ID"
                },
                {
                    "id": "analytics_google",
                    "found": true,
                    "category": "analytics",
                    "evidence": [
                        "_ga",
                        "_ga_5EBT50JLF8"
                    ],
                    "keywords": [
                        "google",
                        "tracking",
                        "analytics",
                        "werbung"
                    ],
                    "provider": "Google",
                    "category_label": "Analytics"
                },
                {
                    "id": "analytics_google_analytics",
                    "found": false,
                    "category": "analytics",
                    "evidence": [
                        "region1.google-analytics.com"
                    ],
                    "keywords": [
                        "google analytics",
                        "analytics.google",
                        "_ga",
                        "ga4",
                        "gtag"
                    ],
                    "provider": "Google Analytics",
                    "category_label": "Analytics"
                }
            ],
            "status": "auffällig",
            "missing": [
                "Google Analytics"
            ],
            "summary": "2 von 3 technisch erkannten Anbieter(n) wurden in der Datenschutzerklärung erwähnt.",
            "available": true,
            "missing_count": 1,
            "detected_count": 3,
            "mentioned_count": 2
        },
        "important_categories_found": [
            "datenschutz",
            "impressum",
            "kontakt"
        ],
        "sampled_tracking_page_count": 0,
        "sampled_form_privacy_gap_count": 0,
        "sitemap_candidate_source_count": 1
    },
    "page_analysis": {
        "h1": [
            "<p>PKP Prozessmesstechnik</p>"
        ],
        "h2": [
            "<span style=\"color: #e03e2d;\">❚</span>Durchfluss",
            "<span style=\"color: #e03e2d;\">❚</span>Durchfluss",
            "<span style=\"color: rgb(23, 63, 237);\">❚</span>Füllstand",
            "<span style=\"color: rgb(23, 63, 237);\">❚</span>Füllstand",
            "<span style=\"color: rgb(201, 214, 11);\">❚</span>Druck",
            "<span style=\"color: rgb(201, 214, 11);\">❚</span>Druck",
            "<span style=\"color: rgb(230, 126, 35);\">❚</span>Temperatur",
            "<span style=\"color: rgb(230, 126, 35);\">❚</span>Temperatur",
            "<span style=\"color: rgb(22, 145, 121);\">❚</span>Zubehör",
            "<span style=\"color: rgb(22, 145, 121);\">❚</span>Zubehör"
        ],
        "title": "Startseite - PKP Prozessmesstechnik GmbH",
        "keywords": [
            [
                "durchfluss",
                9
            ],
            [
                "füllstand",
                9
            ],
            [
                "druck",
                9
            ],
            [
                "temperatur",
                9
            ],
            [
                "zubehör",
                8
            ],
            [
                "prozessmesstechnik",
                5
            ],
            [
                "produkte",
                5
            ],
            [
                "informationen",
                5
            ],
            [
                "messung",
                4
            ],
            [
                "gmbh",
                3
            ]
        ],
        "language": "de-de",
        "description": "Aus diesem Rohfeld wird im Report keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise stehen auf separaten Seiten.",
        "favicon_url": "https://www.pkp.de/images/pkp/apple-icon-180x180.png",
        "link_counts": {
            "external": 1,
            "internal": 53
        },
        "preview_image": "/cache/screenshots/pkp.de-160x150-d1d6544f2bddaae78a.png",
        "screenshot_url": "/cache/screenshots/pkp.de-160x150-d1d6544f2bddaae78a.png",
        "external_scripts": [
            "https://cloud.ccm19.de/app.js?apiKey=f6fe0fff623ff7ca074cd2ad6f3d92be33590d22e39f9ea1&amp;domain=68e7b643b3ea8d3195029aee"
        ],
        "browser_final_url": "https://www.pkp.de/de",
        "meta_preview_image": "",
        "screenshot_renderer": "playwright-chromium",
        "external_link_targets": [
            {
                "host": "sinfoweb.de",
                "count": 1,
                "examples": [
                    {
                        "href": "https://www.sinfoweb.de/",
                        "text": "sinfoweb"
                    }
                ],
                "nofollow": 0,
                "strength": "strong",
                "follow_count": 1
            }
        ]
    },
    "browser_analysis": {
        "cookies": {
            "items": [
                {
                    "name": "15506c5c2936092e3ec13f6e93cdc469",
                    "domain": "www.pkp.de",
                    "secure": false,
                    "expires": -1,
                    "http_only": true,
                    "same_site": "Lax"
                },
                {
                    "name": "_ga_5EBT50JLF8",
                    "domain": ".pkp.de",
                    "secure": false,
                    "expires": 1816252543.591899,
                    "http_only": false,
                    "same_site": "Lax"
                },
                {
                    "name": "_ga",
                    "domain": ".pkp.de",
                    "secure": false,
                    "expires": 1816252543.592188,
                    "http_only": false,
                    "same_site": "Lax"
                },
                {
                    "name": "_gcl_au",
                    "domain": ".pkp.de",
                    "secure": false,
                    "expires": 1789468543,
                    "http_only": false,
                    "same_site": "Lax"
                }
            ],
            "total": 4,
            "third_party": 0
        },
        "storage": {
            "total": 1,
            "local_storage_keys": [
                "_gcl_ls"
            ],
            "tracking_key_hints": [],
            "local_storage_total": 1,
            "session_storage_keys": [],
            "session_storage_total": 0
        },
        "findings": [
            {
                "id": "browser_privacy_relevant_third_parties",
                "title": "Datenschutzrelevante Drittanbieter im Browseraufruf",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "gpc_privacy_domains_present",
                "count": 2,
                "title": "Datenschutzrelevante Kontakte trotz GPC-Signal",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "cmp_api_not_detected",
                "title": "Keine gängige CMP-/TCF-API im Browser erkannt",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "third_country_transfer_review",
                "title": "Drittland-/US-Anbieter im Browseraufruf prüfen",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "third_party_page_url_parameter",
                "count": 2,
                "title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "third_party_sensitive_query_leak",
                "count": 2,
                "title": "Sensible URL-Schlüssel im Drittanbieter-Kontext",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "browser_keystroke_listener_signals",
                "count": 12,
                "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "consent_state_gpc_evidence_review",
                "title": "Consent-Zustand: GPC mit Tracking-Hinweisen",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "beacon_api_usage",
                "count": 4,
                "title": "Beacon-/Keepalive-Telemetrie erkannt",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            }
        ],
        "renderer": "playwright-chromium",
        "final_url": "https://www.pkp.de/de",
        "consent_ui": {
            "accept_controls": [],
            "accept_max_area": 0,
            "reject_controls": [],
            "reject_max_area": 0,
            "settings_controls": [],
            "first_layer_summary": "Akzeptieren 0 / Ablehnen 0 / Einstellungen 0",
            "cookie_context_found": true,
            "reject_less_prominent": false,
            "visible_control_count": 13,
            "reject_prominence_ratio": 0
        },
        "gpc_signal": {
            "error": "",
            "enabled": true,
            "storage": {
                "total": 1,
                "tracking_key_hints": [],
                "local_storage_total": 1,
                "session_storage_total": 0
            },
            "cookie_count": 4,
            "request_count": 36,
            "sec_gpc_header": true,
            "navigator_value": true,
            "contacted_domains": [
                {
                    "host": "pkp.de",
                    "count": 30,
                    "category": "other",
                    "provider": "pkp.de",
                    "third_party": false,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "font": 3,
                        "image": 12,
                        "script": 9,
                        "document": 1,
                        "stylesheet": 5
                    }
                },
                {
                    "host": "googletagmanager.com",
                    "count": 3,
                    "category": "tag_manager",
                    "provider": "Google Tag Manager",
                    "third_party": true,
                    "category_label": "Tag-Manager",
                    "resource_types": {
                        "script": 3
                    }
                },
                {
                    "host": "cloud.ccm19.de",
                    "count": 1,
                    "category": "other",
                    "provider": "cloud.ccm19.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "script": 1
                    }
                },
                {
                    "host": "google.com",
                    "count": 1,
                    "category": "other",
                    "provider": "google.com",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "fetch": 1
                    }
                },
                {
                    "host": "region1.google-analytics.com",
                    "count": 1,
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "third_party": true,
                    "category_label": "Analytics",
                    "resource_types": {
                        "fetch": 1
                    }
                }
            ],
            "contacted_domain_count": 5,
            "privacy_relevant_domains": [
                {
                    "host": "googletagmanager.com",
                    "count": 3,
                    "category": "tag_manager",
                    "provider": "Google Tag Manager",
                    "third_party": true,
                    "category_label": "Tag-Manager",
                    "resource_types": {
                        "script": 3
                    }
                },
                {
                    "host": "region1.google-analytics.com",
                    "count": 1,
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "third_party": true,
                    "category_label": "Analytics",
                    "resource_types": {
                        "fetch": 1
                    }
                }
            ],
            "third_party_cookie_count": 0,
            "third_party_domain_count": 4,
            "privacy_relevant_domain_count": 2
        },
        "screenshot": {
            "fit": "contain",
            "width": 160,
            "height": 150,
            "source_width": 1024,
            "source_height": 960,
            "source_capture": "full_page",
            "capture_version": "contain-v4-viewport-transparency-160x150"
        },
        "consent_apis": {
            "cmpapi": false,
            "tcfapi": false,
            "onetrust": false,
            "cookiebot": false,
            "data_layer": true,
            "cmp_detected": false,
            "usercentrics": false,
            "google_tag_data": true
        },
        "accept_signal": {
            "error": "",
            "enabled": false,
            "storage": {
                "total": 0,
                "tracking_key_hints": [],
                "local_storage_total": 0,
                "session_storage_total": 0
            },
            "clicked_text": "",
            "accept_clicked": false,
            "accept_available": false,
            "contacted_domains": [],
            "contacted_domain_count": 0,
            "new_domains_after_accept": [],
            "privacy_relevant_domains": [],
            "third_party_domain_count": 0,
            "cookie_count_after_accept": 0,
            "cookie_count_before_accept": 0,
            "request_count_after_accept": 0,
            "storage_count_after_accept": 0,
            "request_count_before_accept": 0,
            "new_cookie_count_after_accept": 0,
            "privacy_relevant_domain_count": 0,
            "new_request_count_after_accept": 0,
            "third_party_cookie_count_after_accept": 0,
            "storage_tracking_hint_count_after_accept": 0,
            "new_privacy_relevant_domains_after_accept": [],
            "new_privacy_relevant_domain_count_after_accept": 0
        },
        "request_count": 36,
        "top_providers": [
            {
                "provider": "Google Tag Manager",
                "request_count": 3
            },
            {
                "provider": "cloud.ccm19.de",
                "request_count": 1
            },
            {
                "provider": "google.com",
                "request_count": 1
            },
            {
                "provider": "Google Analytics",
                "request_count": 1
            }
        ],
        "request_samples": [
            {
                "host": "cloud.ccm19.de",
                "method": "GET",
                "referrer": {
                    "host": "pkp.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 1,
                "query_keys": [
                    "apikey",
                    "domain"
                ],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 2,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 1,
                "target_url_value_param_count": 0
            },
            {
                "host": "googletagmanager.com",
                "method": "GET",
                "referrer": {
                    "host": "pkp.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 1,
                "query_keys": [
                    "id"
                ],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 1,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "googletagmanager.com",
                "method": "GET",
                "referrer": {
                    "host": "pkp.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 2,
                "query_keys": [
                    "id",
                    "cx",
                    "gtm"
                ],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 3,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "googletagmanager.com",
                "method": "GET",
                "referrer": {
                    "host": "pkp.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 2,
                "query_keys": [
                    "id",
                    "cx",
                    "gtm"
                ],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 3,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "region1.google-analytics.com",
                "method": "POST",
                "referrer": {
                    "host": "pkp.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 2,
                "query_keys": [
                    "v",
                    "tid",
                    "gtm",
                    "_p",
                    "gcd",
                    "npa",
                    "dma_cps",
                    "dma",
                    "_eu",
                    "are",
                    "cid",
                    "frm"
                ],
                "third_party": true,
                "resource_type": "fetch",
                "query_key_count": 37,
                "url_value_param_count": 1,
                "sensitive_query_key_count": 1,
                "target_url_value_param_count": 1
            },
            {
                "host": "google.com",
                "method": "POST",
                "referrer": {
                    "host": "pkp.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 2,
                "query_keys": [
                    "rcb",
                    "frm",
                    "auid",
                    "dt",
                    "en",
                    "dl",
                    "scrsrc",
                    "rnd",
                    "navt",
                    "npa",
                    "gtm",
                    "gcd"
                ],
                "third_party": true,
                "resource_type": "fetch",
                "query_key_count": 22,
                "url_value_param_count": 1,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 1
            }
        ],
        "cmp_consent_state": {
            "tcf": {
                "api_found": false,
                "vendor_li": [],
                "cmp_loaded": false,
                "cmp_status": "",
                "purpose_li": [],
                "event_status": "",
                "gdpr_applies": null,
                "ping_success": false,
                "policy_version": "",
                "vendor_consents": [],
                "vendor_li_count": 0,
                "purpose_consents": [],
                "purpose_li_count": 0,
                "tc_string_length": 0,
                "tc_string_present": false,
                "vendor_consent_count": 0,
                "purpose_consent_count": 0
            },
            "onetrust": {
                "found": false,
                "active_groups": [],
                "active_group_count": 0
            },
            "cookiebot": {
                "found": false,
                "declined": false,
                "consented": false,
                "has_response": false,
                "consent_marketing": null,
                "consent_statistics": null,
                "consent_preferences": null
            },
            "usercentrics": {
                "found": false,
                "has_response": false,
                "services_count": 0,
                "accepted_services_count": 0
            }
        },
        "contacted_domains": [
            {
                "host": "pkp.de",
                "count": 30,
                "category": "other",
                "provider": "pkp.de",
                "third_party": false,
                "category_label": "Sonstige",
                "resource_types": {
                    "font": 3,
                    "image": 12,
                    "script": 9,
                    "document": 1,
                    "stylesheet": 5
                }
            },
            {
                "host": "googletagmanager.com",
                "count": 3,
                "category": "tag_manager",
                "provider": "Google Tag Manager",
                "third_party": true,
                "category_label": "Tag-Manager",
                "resource_types": {
                    "script": 3
                }
            },
            {
                "host": "cloud.ccm19.de",
                "count": 1,
                "category": "other",
                "provider": "cloud.ccm19.de",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "script": 1
                }
            },
            {
                "host": "google.com",
                "count": 1,
                "category": "other",
                "provider": "google.com",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "fetch": 1
                }
            },
            {
                "host": "region1.google-analytics.com",
                "count": 1,
                "category": "analytics",
                "provider": "Google Analytics",
                "third_party": true,
                "category_label": "Analytics",
                "resource_types": {
                    "fetch": 1
                }
            }
        ],
        "privacy_api_metrics": {
            "api_calls": {
                "fetch_keepalive_count": 2,
                "mutation_observer_count": 71,
                "keyboard_input_listener_count": 12
            },
            "beacon_count": 0,
            "webgl_read_count": 0,
            "canvas_read_count": 0,
            "audio_context_count": 0,
            "canvas_export_count": 0,
            "fetch_keepalive_count": 2,
            "webgl_parameter_count": 0,
            "mutation_observer_count": 71,
            "keyboard_input_listener_count": 12
        },
        "tcf_consent_analysis": {
            "color": "green",
            "score": 100,
            "status": "unauffällig",
            "summary": "TCF-Decoder: 0 Zweck(e) mit Consent/LI-Signal, 0 Vendor-Consent(s), 0 Vendor-LI-Signal(e).",
            "findings": [],
            "api_found": false,
            "available": false,
            "cmp_loaded": false,
            "cmp_status": "",
            "event_status": "",
            "gdpr_applies": null,
            "ping_success": false,
            "purpose_rows": [
                {
                    "id": 1,
                    "label": "Informationen auf einem Gerät speichern und/oder abrufen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 2,
                    "label": "Einfache Anzeigen auswählen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 3,
                    "label": "Personalisiertes Anzeigen-Profil erstellen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 4,
                    "label": "Personalisierte Anzeigen auswählen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 5,
                    "label": "Personalisiertes Inhalts-Profil erstellen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 6,
                    "label": "Personalisierte Inhalte auswählen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 7,
                    "label": "Anzeigen-Leistung messen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 8,
                    "label": "Inhalte-Leistung messen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 9,
                    "label": "Marktforschung zur Generierung von Erkenntnissen nutzen",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 10,
                    "label": "Produkte entwickeln und verbessern",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                },
                {
                    "id": 11,
                    "label": "Begrenzte Daten zur Anzeigen-Auswahl verwenden",
                    "status": "nicht_erlaubt",
                    "risk_level": "niedrig",
                    "consent_granted": false,
                    "legitimate_interest_granted": false
                }
            ],
            "vendor_li_ids": [],
            "policy_version": "",
            "vendor_li_count": 0,
            "purpose_li_count": 0,
            "tc_string_length": 0,
            "tc_string_present": false,
            "vendor_consent_ids": [],
            "granted_purpose_rows": [],
            "vendor_consent_count": 0,
            "purpose_consent_count": 0,
            "high_risk_purpose_count": 0,
            "medium_risk_purpose_count": 0
        },
        "viewport_transparency": {
            "samples": [
                {
                    "tag": "a",
                    "top": 64,
                    "href": "/de/kontakt",
                    "left": 749,
                    "text": "Kontakt",
                    "width": 57,
                    "height": 80,
                    "category": "contact"
                }
            ],
            "available": true,
            "sample_count": 1,
            "claim_boundary": "Sichtbarkeits-Evidence aus dem ersten Headless-Chromium-Viewport; keine Aussage ueber Footer nach Scrollen, Loginbereiche oder rechtliche Vollstaendigkeit.",
            "viewport_width": 1024,
            "category_counts": {
                "contact": 1
            },
            "contact_visible": true,
            "imprint_visible": false,
            "viewport_height": 960,
            "cookie_consent_visible": false,
            "privacy_notice_visible": false
        },
        "consent_journey_matrix": {
            "color": "yellow",
            "items": [
                {
                    "host": "googletagmanager.com",
                    "states": {
                        "gpc": 3,
                        "default": 3
                    },
                    "category": "tag_manager",
                    "provider": "Google Tag Manager",
                    "category_label": "Tag-Manager",
                    "privacy_relevant": true,
                    "total_request_count": 6
                },
                {
                    "host": "region1.google-analytics.com",
                    "states": {
                        "gpc": 1,
                        "default": 1
                    },
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "category_label": "Analytics",
                    "privacy_relevant": true,
                    "total_request_count": 2
                },
                {
                    "host": "cloud.ccm19.de",
                    "states": {
                        "gpc": 1,
                        "default": 1
                    },
                    "category": "other",
                    "provider": "cloud.ccm19.de",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 2
                },
                {
                    "host": "google.com",
                    "states": {
                        "gpc": 1,
                        "default": 1
                    },
                    "category": "other",
                    "provider": "google.com",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 2
                }
            ],
            "score": 84,
            "states": [
                {
                    "id": "default",
                    "label": "Erstaufruf",
                    "description": "Kontakte ohne Nutzeraktion",
                    "domain_count": 4,
                    "request_count": 6,
                    "privacy_relevant_domain_count": 2
                },
                {
                    "id": "reject_new",
                    "label": "Nach Ablehnen neu",
                    "description": "Neue Kontakte nach Ablehnen-Klick",
                    "domain_count": 0,
                    "request_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "accept_new",
                    "label": "Nach Akzeptieren neu",
                    "description": "Neue Kontakte nach Akzeptieren-Klick",
                    "domain_count": 0,
                    "request_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "gpc",
                    "label": "GPC-Aufruf",
                    "description": "Kontakte bei Global Privacy Control",
                    "domain_count": 4,
                    "request_count": 6,
                    "privacy_relevant_domain_count": 2
                }
            ],
            "status": "prüfen",
            "summary": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 2 im GPC-Aufruf.",
            "gpc_privacy_relevant_domain_count": 2,
            "accept_privacy_relevant_domain_count": 0,
            "reject_privacy_relevant_domain_count": 0
        },
        "consent_state_evidence": {
            "rows": [
                {
                    "id": "default",
                    "label": "Erstaufruf",
                    "status": "ohne Nutzeraktion",
                    "evidence": "Baseline aus erstem Chromium-Aufruf ohne Banner-Interaktion.",
                    "risk_level": "mittel",
                    "cookie_count": 4,
                    "domain_count": 5,
                    "request_count": 36,
                    "storage_total": 1,
                    "new_cookie_count": 4,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 2
                },
                {
                    "id": "reject",
                    "label": "Nach Ablehnen",
                    "status": "nicht verfügbar",
                    "evidence": "",
                    "risk_level": "niedrig",
                    "cookie_count": 4,
                    "domain_count": 0,
                    "request_count": 0,
                    "storage_total": 1,
                    "new_cookie_count": 0,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "accept",
                    "label": "Nach Akzeptieren",
                    "status": "nicht ausgeführt",
                    "evidence": "",
                    "risk_level": "niedrig",
                    "cookie_count": 0,
                    "domain_count": 0,
                    "request_count": 0,
                    "storage_total": 0,
                    "new_cookie_count": 0,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "gpc",
                    "label": "GPC-Aufruf",
                    "status": "aktiv",
                    "evidence": "Navigator-GPC und Sec-GPC wurden im gesonderten Browserlauf gesetzt.",
                    "risk_level": "mittel",
                    "cookie_count": 4,
                    "domain_count": 5,
                    "request_count": 36,
                    "storage_total": 1,
                    "new_cookie_count": 0,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 2
                }
            ],
            "color": "yellow",
            "score": 80,
            "status": "prüfen",
            "summary": "Consent-State-Evidence: 4 Zustände verglichen, 0 hoch auffällig, 2 mittel auffällig.",
            "findings": [
                {
                    "id": "consent_state_gpc_evidence_review",
                    "title": "Consent-Zustand: GPC mit Tracking-Hinweisen",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                }
            ],
            "available": true,
            "high_count": 0,
            "medium_count": 2
        },
        "contacted_domain_count": 5,
        "fingerprinting_analysis": {
            "color": "yellow",
            "score": 88,
            "checks": [
                {
                    "id": "canvas",
                    "ok": true,
                    "count": 0,
                    "label": "Canvas-Auslese",
                    "detail": "0 Pixel-Lesezugriff(e), 0 Export(e)."
                },
                {
                    "id": "webgl",
                    "ok": true,
                    "count": 0,
                    "label": "WebGL-Merkmale",
                    "detail": "0 Parameterzugriff(e), 0 Pixel-Lesezugriff(e)."
                },
                {
                    "id": "audio",
                    "ok": true,
                    "count": 0,
                    "label": "AudioContext",
                    "detail": "0 AudioContext/OfflineAudioContext-Aufruf(e)."
                },
                {
                    "id": "session_replay",
                    "ok": true,
                    "count": 0,
                    "label": "Session-Replay-Anbieter",
                    "detail": "Keine bekannten Anbieter erkannt."
                },
                {
                    "id": "input_listeners",
                    "ok": false,
                    "count": 12,
                    "label": "Tastatur-/Eingabe-Listener",
                    "detail": "12 Tastatur-/Input-Listener, 25 Interaktions-Listener, 71 MutationObserver."
                }
            ],
            "status": "prüfen",
            "metrics": {
                "webgl_read_count": 0,
                "canvas_read_count": 0,
                "audio_context_count": 0,
                "canvas_export_count": 0,
                "webgl_parameter_count": 0,
                "mutation_observer_count": 71,
                "keyboard_input_listener_count": 12
            },
            "summary": "1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
            "findings": [
                {
                    "id": "browser_keystroke_listener_signals",
                    "count": 12,
                    "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                }
            ],
            "finding_count": 1,
            "session_replay_domains": []
        },
        "privacy_relevant_domains": [
            {
                "host": "googletagmanager.com",
                "count": 3,
                "category": "tag_manager",
                "provider": "Google Tag Manager",
                "third_party": true,
                "category_label": "Tag-Manager",
                "resource_types": {
                    "script": 3
                }
            },
            {
                "host": "region1.google-analytics.com",
                "count": 1,
                "category": "analytics",
                "provider": "Google Analytics",
                "third_party": true,
                "category_label": "Analytics",
                "resource_types": {
                    "fetch": 1
                }
            }
        ],
        "provider_category_counts": {
            "other": 2,
            "analytics": 1,
            "tag_manager": 1
        },
        "provider_category_labels": {
            "other": "other",
            "analytics": "Analytics",
            "tag_manager": "Tag-Manager"
        },
        "third_party_domain_count": 4,
        "embedded_content_analysis": {
            "color": "green",
            "items": [],
            "score": 100,
            "status": "unauffällig",
            "summary": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen.",
            "findings": [],
            "map_count": 0,
            "total_count": 0,
            "video_count": 0,
            "captcha_count": 0,
            "category_counts": [],
            "social_widget_count": 0,
            "loaded_pre_consent_count": 0,
            "request_count_by_provider": []
        },
        "referrer_leakage_analysis": {
            "color": "red",
            "items": [
                {
                    "host": "cloud.ccm19.de",
                    "category": "other",
                    "provider": "cloud.ccm19.de",
                    "query_keys": [
                        "apikey",
                        "domain"
                    ],
                    "risk_reason": "sensibler Query-Schlüssel im Drittanbieter-Request oder Referrer",
                    "resource_type": "script",
                    "category_label": "Sonstige",
                    "referrer_query_keys": [],
                    "sensitive_query_key_count": 1,
                    "referrer_sensitive_query_key_count": 0
                },
                {
                    "host": "region1.google-analytics.com",
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "query_keys": [
                        "v",
                        "tid",
                        "gtm",
                        "_p",
                        "gcd",
                        "npa",
                        "dma_cps",
                        "dma"
                    ],
                    "risk_reason": "sensibler Query-Schlüssel im Drittanbieter-Request oder Referrer",
                    "resource_type": "fetch",
                    "category_label": "Analytics",
                    "referrer_query_keys": [],
                    "sensitive_query_key_count": 1,
                    "referrer_sensitive_query_key_count": 0
                },
                {
                    "host": "region1.google-analytics.com",
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "query_keys": [
                        "v",
                        "tid",
                        "gtm",
                        "_p",
                        "gcd",
                        "npa",
                        "dma_cps",
                        "dma"
                    ],
                    "risk_reason": "Seiten-URL oder URL-Wert in Drittanbieter-Requestparametern",
                    "resource_type": "fetch",
                    "category_label": "Analytics",
                    "referrer_query_keys": [],
                    "url_value_param_count": 1,
                    "target_url_value_param_count": 1
                },
                {
                    "host": "google.com",
                    "category": "other",
                    "provider": "google.com",
                    "query_keys": [
                        "rcb",
                        "frm",
                        "auid",
                        "dt",
                        "en",
                        "dl",
                        "scrsrc",
                        "rnd"
                    ],
                    "risk_reason": "Seiten-URL oder URL-Wert in Drittanbieter-Requestparametern",
                    "resource_type": "fetch",
                    "category_label": "Sonstige",
                    "referrer_query_keys": [],
                    "url_value_param_count": 1,
                    "target_url_value_param_count": 1
                }
            ],
            "score": 31,
            "status": "kritisch",
            "summary": "3 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 2 sensible Query-Kontexte.",
            "findings": [
                {
                    "id": "third_party_page_url_parameter",
                    "count": 2,
                    "title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
                    "public": true,
                    "category": "privacy",
                    "severity": "warning"
                },
                {
                    "id": "third_party_sensitive_query_leak",
                    "count": 2,
                    "title": "Sensible URL-Schlüssel im Drittanbieter-Kontext",
                    "public": true,
                    "category": "privacy",
                    "severity": "warning"
                }
            ],
            "sample_count": 6,
            "full_referrer_count": 0,
            "page_url_param_count": 2,
            "affected_domain_count": 3,
            "sensitive_query_count": 2
        },
        "third_party_contact_matrix": {
            "color": "orange",
            "items": [
                {
                    "host": "googletagmanager.com",
                    "region": "US",
                    "status": "vor Einwilligung prüfen",
                    "category": "tag_manager",
                    "provider": "Google Tag Manager",
                    "risk_level": "hoch",
                    "request_count": 3,
                    "transfer_risk": "hoch",
                    "category_label": "Tag-Manager",
                    "resource_types": [
                        {
                            "type": "script",
                            "count": 3
                        }
                    ],
                    "transfer_label": "Drittland/USA",
                    "privacy_relevant": true
                },
                {
                    "host": "region1.google-analytics.com",
                    "region": "US",
                    "status": "dokumentieren",
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "risk_level": "mittel",
                    "request_count": 1,
                    "transfer_risk": "hoch",
                    "category_label": "Analytics",
                    "resource_types": [
                        {
                            "type": "fetch",
                            "count": 1
                        }
                    ],
                    "transfer_label": "Drittland/USA",
                    "privacy_relevant": true
                },
                {
                    "host": "cloud.ccm19.de",
                    "region": "EU/EWR",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "cloud.ccm19.de",
                    "risk_level": "niedrig",
                    "request_count": 1,
                    "transfer_risk": "niedrig",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "script",
                            "count": 1
                        }
                    ],
                    "transfer_label": "EU/EWR",
                    "privacy_relevant": false
                },
                {
                    "host": "google.com",
                    "region": "US",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "google.com",
                    "risk_level": "niedrig",
                    "request_count": 1,
                    "transfer_risk": "hoch",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "fetch",
                            "count": 1
                        }
                    ],
                    "transfer_label": "Drittland/USA",
                    "privacy_relevant": false
                }
            ],
            "score": 60,
            "status": "auffällig",
            "summary": "4 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 2 datenschutzrelevant.",
            "category_counts": {
                "Sonstige": 2,
                "Analytics": 1,
                "Tag-Manager": 1
            },
            "total_domain_count": 4,
            "total_request_count": 6,
            "privacy_relevant_count": 2,
            "transfer_risk_analysis": {
                "color": "orange",
                "items": [
                    {
                        "host": "googletagmanager.com",
                        "region": "US",
                        "provider": "Google Tag Manager",
                        "request_count": 3,
                        "transfer_risk": "hoch",
                        "category_label": "Tag-Manager",
                        "transfer_label": "Drittland/USA",
                        "privacy_relevant": true
                    },
                    {
                        "host": "region1.google-analytics.com",
                        "region": "US",
                        "provider": "Google Analytics",
                        "request_count": 1,
                        "transfer_risk": "hoch",
                        "category_label": "Analytics",
                        "transfer_label": "Drittland/USA",
                        "privacy_relevant": true
                    },
                    {
                        "host": "cloud.ccm19.de",
                        "region": "EU/EWR",
                        "provider": "cloud.ccm19.de",
                        "request_count": 1,
                        "transfer_risk": "niedrig",
                        "category_label": "Sonstige",
                        "transfer_label": "EU/EWR",
                        "privacy_relevant": false
                    },
                    {
                        "host": "google.com",
                        "region": "US",
                        "provider": "google.com",
                        "request_count": 1,
                        "transfer_risk": "hoch",
                        "category_label": "Sonstige",
                        "transfer_label": "Drittland/USA",
                        "privacy_relevant": false
                    }
                ],
                "score": 55,
                "status": "auffällig",
                "summary": "4 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 3 mit hohem Prüfbedarf, 0 unklar.",
                "findings": [
                    {
                        "id": "third_country_transfer_review",
                        "title": "Drittland-/US-Anbieter im Browseraufruf prüfen",
                        "public": true,
                        "category": "privacy",
                        "severity": "warning"
                    }
                ],
                "unknown_count": 0,
                "high_risk_count": 3,
                "total_vendor_count": 4,
                "third_country_count": 3
            }
        },
        "privacy_relevant_domain_count": 2,
        "tracking_pixel_beacon_analysis": {
            "color": "orange",
            "items": [
                {
                    "url": "",
                    "host": "pkp.de",
                    "kind": "beacon_api",
                    "reason": "sendBeacon API 0 Aufruf(e), 0 Code-Hinweis(e); keepalive 2 Aufruf(e), 0 Code-Hinweis(e).",
                    "source": "javascript_api",
                    "category": "telemetry",
                    "provider": "Beacon-/Keepalive-API",
                    "third_party": false,
                    "resource_type": "beacon",
                    "category_label": "Telemetry"
                },
                {
                    "url": "",
                    "host": "region1.google-analytics.com",
                    "kind": "browser_tracking_request",
                    "reason": "fetch-Request mit 37 Query-Schlüssel(n).",
                    "source": "chromium_request",
                    "category": "analytics",
                    "provider": "Google Analytics",
                    "query_keys": [
                        "v",
                        "tid",
                        "gtm",
                        "_p",
                        "gcd",
                        "npa",
                        "dma_cps",
                        "dma"
                    ],
                    "third_party": true,
                    "resource_type": "fetch",
                    "category_label": "Analytics"
                }
            ],
            "score": 66,
            "status": "auffällig",
            "summary": "0 Pixel-/Bildtracking-Hinweis(e), 4 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).",
            "findings": [
                {
                    "id": "beacon_api_usage",
                    "count": 4,
                    "title": "Beacon-/Keepalive-Telemetrie erkannt",
                    "public": true,
                    "category": "privacy",
                    "severity": "warning"
                }
            ],
            "pixel_count": 0,
            "link_ping_count": 0,
            "telemetry_count": 2,
            "beacon_api_count": 0,
            "third_party_count": 1,
            "fetch_keepalive_count": 2,
            "privacy_relevant_count": 1,
            "beacon_code_reference_count": 0,
            "fetch_keepalive_reference_count": 0
        }
    },
    "privacy_analysis": {
        "cookies": {
            "items": [
                {
                    "name": "15506c5c2936092e3ec13f6e93cdc469",
                    "secure": false,
                    "samesite": false,
                    "tracking": false,
                    "pre_consent": true,
                    "likely_essential": false
                }
            ],
            "total": 1,
            "tracking": [],
            "pre_consent": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ],
            "missing_secure": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ],
            "missing_samesite": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ],
            "pre_consent_tracking": [],
            "pre_consent_nonessential": [
                "15506c5c2936092e3ec13f6e93cdc469"
            ]
        },
        "findings": [
            {
                "id": "pre_consent_nonessential_cookies",
                "title": "Möglicherweise nicht notwendige Cookies vor Einwilligung",
                "public": true,
                "cookies": [
                    "15506c5c2936092e3ec13f6e93cdc469"
                ],
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "cookie_missing_secure",
                "title": "Cookie ohne Secure-Flag",
                "public": true,
                "cookies": [
                    "15506c5c2936092e3ec13f6e93cdc469"
                ],
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "cookie_missing_samesite",
                "title": "Cookie ohne SameSite-Attribut",
                "public": true,
                "cookies": [
                    "15506c5c2936092e3ec13f6e93cdc469"
                ],
                "category": "privacy",
                "severity": "info"
            }
        ],
        "tracking_ids": [
            {
                "type": "google_tag_manager",
                "value": "GTM-KGDSV84",
                "provider": "Google Tag Manager"
            }
        ],
        "tracking_scripts": [],
        "consent_hint_found": false,
        "privacy_policy_hint_found": true
    },
    "consent_audit": {
        "color": "red",
        "score": 18,
        "checks": [
            {
                "id": "banner_visible",
                "ok": true,
                "label": "Cookie-/Consent-Hinweis sichtbar",
                "detail": "Ein Hinweis mit Cookie-/Einwilligungsbezug wurde im sichtbaren Text erkannt."
            },
            {
                "id": "reject_visible",
                "ok": true,
                "label": "Ablehnen gleichwertig erreichbar",
                "detail": "Ablehnen oder nur notwendige Cookies wurde im Text oder Browser erkannt. Browser-Buttons: 0."
            },
            {
                "id": "settings_visible",
                "ok": false,
                "label": "Einstellungen oder Auswahl vorhanden",
                "detail": "Eine Einstellungs- oder Auswahlmoeglichkeit wurde im Text oder Browser erkannt. Browser-Buttons: 0."
            },
            {
                "id": "browser_reject_visible",
                "ok": true,
                "label": "Ablehnen im sichtbaren Banner",
                "detail": "Sichtbare Banner-Controls: Akzeptieren 0, Ablehnen 0, Einstellungen 0."
            },
            {
                "id": "browser_settings_visible",
                "ok": true,
                "label": "Einstellungen im sichtbaren Banner",
                "detail": "Sichtbare Banner-Controls: Akzeptieren 0, Ablehnen 0, Einstellungen 0."
            },
            {
                "id": "reject_equally_prominent",
                "ok": true,
                "label": "Ablehnen nicht deutlich schwaecher dargestellt",
                "detail": "Groessen-Verhältnis Ablehnen/Akzeptieren: nicht messbar."
            },
            {
                "id": "reject_button_clickable",
                "ok": true,
                "label": "Ablehnen technisch klickbar",
                "detail": "Wenn ein Ablehnen-Button sichtbar ist, klickt SaferPage ihn im Chromium-Browser einmal an."
            },
            {
                "id": "no_new_cookies_after_reject",
                "ok": true,
                "label": "Keine neuen Cookies nach Ablehnen",
                "detail": "0 neue Cookie(s) nach dem Ablehnen-Klick."
            },
            {
                "id": "no_tracking_storage_after_reject",
                "ok": true,
                "label": "Kein Tracking-Storage nach Ablehnen",
                "detail": "0 Tracking-Hinweis(e) im Web Storage nach Ablehnen."
            },
            {
                "id": "no_privacy_domains_after_reject",
                "ok": true,
                "label": "Keine neuen Tracking-Kontakte nach Ablehnen",
                "detail": "0 neue datenschutzrelevante Domain(s) nach Ablehnen."
            },
            {
                "id": "gpc_signal_respected",
                "ok": false,
                "label": "GPC-Signal ohne Tracking-Hinweise",
                "detail": "GPC-Aufruf: 2 datenschutzrelevante Domain(s), 0 Drittanbieter-Cookie(s), 0 Storage-Hinweis(e)."
            },
            {
                "id": "no_tracking_cookies_before_consent",
                "ok": false,
                "label": "Keine Tracking-Cookies vor Einwilligung",
                "detail": "2 Tracking-Cookie(s) im Erstaufruf."
            },
            {
                "id": "no_nonessential_cookies_before_consent",
                "ok": false,
                "label": "Keine nicht notwendigen Cookies vor Einwilligung",
                "detail": "4 moeglicherweise nicht notwendige Cookie(s) im Erstaufruf."
            },
            {
                "id": "google_default_restrictive",
                "ok": false,
                "label": "Google Consent Default restriktiv",
                "detail": "Google-Tags brauchen vor dem ersten Laden restriktive Consent-Defaults."
            },
            {
                "id": "third_parties_explained",
                "ok": true,
                "label": "Drittanbieter begrenzt und erklaerbar",
                "detail": "0 datenschutzrelevante Drittanbieter-Domain(s), 4 Drittanbieter insgesamt."
            },
            {
                "id": "storage_without_tracking_hints",
                "ok": true,
                "label": "Web Storage ohne Tracking-Hinweise",
                "detail": "1 Storage-Key(s), 0 Tracking-Hinweis(e)."
            },
            {
                "id": "cmp_api_detected_when_needed",
                "ok": true,
                "label": "CMP-/TCF-Signal bei Tracking erkennbar",
                "detail": "Gängige CMP-/TCF-Indikatoren: __tcfapi, __cmp, Cookiebot, OneTrust oder Usercentrics."
            },
            {
                "id": "accept_click_documented",
                "ok": true,
                "label": "Akzeptieren-Klick nachvollziehbar",
                "detail": "Accept-Test: nicht ausgefuehrt, neue Requests 0, neue Cookies 0, neue Datenschutz-Domains 0."
            },
            {
                "id": "cmp_state_readable",
                "ok": true,
                "label": "CMP-/TCF-Zustand auslesbar",
                "detail": "TCF TC-String: nein, Cookiebot: nein, OneTrust: nein, Usercentrics: nein."
            },
            {
                "id": "cmp_default_restrictive",
                "ok": true,
                "label": "CMP-Default wirkt restriktiv",
                "detail": "TCF Purposes erlaubt: 0, TCF Vendors erlaubt: 0, Cookiebot Statistik/Marketing: nein."
            }
        ],
        "status": "kritisch",
        "summary": "Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig.",
        "evidence": [
            "4 Cookie(s) beim ersten Aufruf aus HTTP-Headern und Chromium",
            "0 Tracking-Script(s) im HTML",
            "0 datenschutzrelevante Drittanbieter-Domain(s)",
            "1 Storage-Key(s), 0 Tracking-Hinweis(e)",
            "Consent-Banner-Controls: Akzeptieren 0, Ablehnen 0, Einstellungen 0",
            "Ablehnen/Akzeptieren-Prominenz: nicht messbar",
            "Reject-Test: nicht ausgefuehrt, neue Cookies 0, Tracking-Storage 0, neue Datenschutz-Domains 0",
            "Accept-Test: nicht ausgefuehrt, neue Requests 0, neue Cookies 0, neue Datenschutz-Domains 0, Drittanbieter-Cookies 0",
            "CMP-State: TCF-String nein, TCF Purposes 0, TCF Vendors 0, Cookiebot nein, OneTrust-Gruppen 0, Usercentrics-Services 0",
            "GPC-Test: aktiv, Datenschutz-Domains 2, Drittanbieter-Cookies 0, Storage-Hinweise 0",
            "CMP-/TCF-Signal: nein",
            "Google Consent Default: nein"
        ],
        "gpc_enabled": true,
        "cmp_detected": false,
        "blocking_plan": {
            "items": [
                {
                    "kind": "cookie",
                    "level": "hoch",
                    "source": "Google",
                    "target": "_ga",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "analytics",
                    "evidence": "vor Consent gesetzt · pkp.de · lang (399 Tage)",
                    "category_label": "Analytics"
                },
                {
                    "kind": "cookie",
                    "level": "hoch",
                    "source": "Google",
                    "target": "_ga_5EBT50JLF8",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "analytics",
                    "evidence": "vor Consent gesetzt · pkp.de · lang (399 Tage)",
                    "category_label": "Analytics"
                },
                {
                    "kind": "google_consent",
                    "level": "hoch",
                    "source": "Google",
                    "target": "Google Consent Defaults",
                    "recipes": [
                        {
                            "tool": "Google Consent Mode v2"
                        },
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        }
                    ],
                    "category": "tag_manager",
                    "evidence": "Google-Tags erkannt, aber kein Consent-Default vor dem ersten Tag.",
                    "category_label": "Tag-Manager"
                },
                {
                    "kind": "third_party_request",
                    "level": "hoch",
                    "source": "Google Tag Manager",
                    "target": "googletagmanager.com",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "tag_manager",
                    "evidence": "3 Request(s) im Erstaufruf · Tag-Manager",
                    "category_label": "Tag-Manager"
                },
                {
                    "kind": "third_party_request",
                    "level": "hoch",
                    "source": "Google Analytics",
                    "target": "region1.google-analytics.com",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "analytics",
                    "evidence": "1 Request(s) im Erstaufruf · Analytics",
                    "category_label": "Analytics"
                },
                {
                    "kind": "cookie",
                    "level": "mittel",
                    "source": "pkp.de",
                    "target": "15506c5c2936092e3ec13f6e93cdc469",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "vor Consent gesetzt · pkp.de · Session",
                    "category_label": "Unklar"
                },
                {
                    "kind": "cookie",
                    "level": "mittel",
                    "source": "pkp.de",
                    "target": "_gcl_au",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Cookiebot"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "OneTrust"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "vor Consent gesetzt · pkp.de · mittel (89 Tage)",
                    "category_label": "Unklar"
                },
                {
                    "kind": "storage",
                    "level": "mittel",
                    "source": "localStorage",
                    "target": "_gcl_ls",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "localStorage · Unklar · dauerhaft bis Löschung durch Nutzer/Browser",
                    "category_label": "Unklar"
                }
            ],
            "summary": "8 Blockier-/Consent-Maßnahme(n) abgeleitet: 5 hoch, 3 mittel.",
            "available": true,
            "high_count": 5,
            "total_count": 8,
            "type_counts": {
                "cookie": 4,
                "storage": 1,
                "google_consent": 1,
                "third_party_request": 2
            },
            "medium_count": 3
        },
        "tcf_api_found": false,
        "cookiebot_found": false,
        "accept_test_enabled": false,
        "browser_cookie_count": 4,
        "accept_button_clicked": false,
        "browser_storage_count": 1,
        "reject_button_clicked": false,
        "reject_less_prominent": false,
        "tcf_tc_string_present": false,
        "tracking_script_count": 0,
        "accept_button_available": false,
        "reject_button_available": false,
        "reject_prominence_ratio": 0,
        "pre_consent_cookie_count": 4,
        "pre_consent_cookie_names": [
            "15506c5c2936092e3ec13f6e93cdc469",
            "_ga",
            "_ga_5EBT50JLF8",
            "_gcl_au"
        ],
        "tcf_vendor_consent_count": 0,
        "third_party_domain_count": 4,
        "tcf_purpose_consent_count": 0,
        "onetrust_active_group_count": 0,
        "usercentrics_services_count": 0,
        "browser_accept_control_count": 0,
        "browser_cookie_context_found": true,
        "browser_reject_control_count": 0,
        "gpc_third_party_cookie_count": 0,
        "post_accept_new_cookie_count": 0,
        "post_reject_new_cookie_count": 0,
        "post_accept_new_request_count": 0,
        "browser_settings_control_count": 0,
        "gpc_storage_tracking_hint_count": 0,
        "cookiebot_marketing_or_statistics": false,
        "gpc_privacy_relevant_domain_count": 2,
        "pre_consent_tracking_cookie_count": 2,
        "pre_consent_tracking_cookie_names": [
            "_ga",
            "_ga_5EBT50JLF8"
        ],
        "privacy_relevant_third_party_count": 0,
        "browser_storage_tracking_hint_count": 0,
        "post_accept_third_party_cookie_count": 0,
        "pre_consent_nonessential_cookie_count": 4,
        "pre_consent_nonessential_cookie_names": [
            "15506c5c2936092e3ec13f6e93cdc469",
            "_ga",
            "_ga_5EBT50JLF8",
            "_gcl_au"
        ],
        "post_accept_storage_tracking_hint_count": 0,
        "post_reject_storage_tracking_hint_count": 0,
        "post_accept_privacy_relevant_domain_count": 0,
        "post_reject_privacy_relevant_domain_count": 0
    },
    "cookie_inventory": {
        "color": "red",
        "items": [
            {
                "name": "_ga",
                "domain": "pkp.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "analytics",
                "provider": "Google",
                "tracking": true,
                "http_only": false,
                "same_site": "Lax",
                "expires_at": "2027-07-22T10:35:43+00:00",
                "long_lived": true,
                "persistent": true,
                "first_party": true,
                "origin_host": "pkp.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Analytics",
                "retention_risk": "hoch",
                "expires_in_days": 399,
                "origin_evidence": "30 Browser-Request(s) · document:1, font:3, image:12, script:9",
                "origin_provider": "pkp.de",
                "retention_class": "long",
                "retention_label": "lang (399 Tage)",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": ""
            },
            {
                "name": "_ga_5EBT50JLF8",
                "domain": "pkp.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "analytics",
                "provider": "Google",
                "tracking": true,
                "http_only": false,
                "same_site": "Lax",
                "expires_at": "2027-07-22T10:35:43+00:00",
                "long_lived": true,
                "persistent": true,
                "first_party": true,
                "origin_host": "pkp.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Analytics",
                "retention_risk": "hoch",
                "expires_in_days": 399,
                "origin_evidence": "30 Browser-Request(s) · document:1, font:3, image:12, script:9",
                "origin_provider": "pkp.de",
                "retention_class": "long",
                "retention_label": "lang (399 Tage)",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": ""
            },
            {
                "name": "15506c5c2936092e3ec13f6e93cdc469",
                "domain": "pkp.de",
                "secure": false,
                "sources": [
                    "http_set_cookie",
                    "browser_first_load"
                ],
                "category": "unknown",
                "provider": "pkp.de",
                "tracking": false,
                "http_only": true,
                "same_site": "Lax",
                "expires_at": "",
                "long_lived": false,
                "persistent": false,
                "first_party": true,
                "origin_host": "pkp.de",
                "pre_consent": true,
                "source_label": "HTTP Set-Cookie, Chromium-Erstaufruf",
                "category_label": "Unklar",
                "retention_risk": "niedrig",
                "expires_in_days": null,
                "origin_evidence": "30 Browser-Request(s) · document:1, font:3, image:12, script:9",
                "origin_provider": "pkp.de",
                "retention_class": "session",
                "retention_label": "Session",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": ""
            },
            {
                "name": "_gcl_au",
                "domain": "pkp.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "unknown",
                "provider": "pkp.de",
                "tracking": false,
                "http_only": false,
                "same_site": "Lax",
                "expires_at": "2026-09-15T10:35:43+00:00",
                "long_lived": false,
                "persistent": true,
                "first_party": true,
                "origin_host": "pkp.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Unklar",
                "retention_risk": "niedrig",
                "expires_in_days": 89,
                "origin_evidence": "30 Browser-Request(s) · document:1, font:3, image:12, script:9",
                "origin_provider": "pkp.de",
                "retention_class": "medium",
                "retention_label": "mittel (89 Tage)",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": ""
            }
        ],
        "score": 40,
        "total": 4,
        "status": "kritisch",
        "summary": "4 Cookie(s) inventarisiert: 2 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 2 langlebige Cookie(s), 0 sehr lange Laufzeit(en).",
        "findings": [
            {
                "id": "long_lived_tracking_cookie",
                "count": 2,
                "title": "Langlebige Tracking-/Marketing-Cookies",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            }
        ],
        "categories": {
            "unknown": 2,
            "analytics": 2
        },
        "tracking_count": 2,
        "category_labels": {
            "consent": "Consent",
            "payment": "Zahlung",
            "unknown": "Unklar",
            "security": "Sicherheit",
            "analytics": "Analytics",
            "necessary": "Notwendig",
            "functional": "Funktional",
            "advertising": "Werbung"
        },
        "long_lived_count": 2,
        "persistent_count": 3,
        "first_party_count": 4,
        "pre_consent_count": 4,
        "retention_classes": {
            "long": 2,
            "medium": 1,
            "session": 1
        },
        "third_party_count": 0,
        "missing_secure_count": 4,
        "retention_risk_count": 2,
        "retention_risk_items": [
            {
                "name": "_ga",
                "domain": "pkp.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "analytics",
                "provider": "Google",
                "tracking": true,
                "http_only": false,
                "same_site": "Lax",
                "expires_at": "2027-07-22T10:35:43+00:00",
                "long_lived": true,
                "persistent": true,
                "first_party": true,
                "origin_host": "pkp.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Analytics",
                "retention_risk": "hoch",
                "expires_in_days": 399,
                "origin_evidence": "30 Browser-Request(s) · document:1, font:3, image:12, script:9",
                "origin_provider": "pkp.de",
                "retention_class": "long",
                "retention_label": "lang (399 Tage)",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": ""
            },
            {
                "name": "_ga_5EBT50JLF8",
                "domain": "pkp.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "analytics",
                "provider": "Google",
                "tracking": true,
                "http_only": false,
                "same_site": "Lax",
                "expires_at": "2027-07-22T10:35:43+00:00",
                "long_lived": true,
                "persistent": true,
                "first_party": true,
                "origin_host": "pkp.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Analytics",
                "retention_risk": "hoch",
                "expires_in_days": 399,
                "origin_evidence": "30 Browser-Request(s) · document:1, font:3, image:12, script:9",
                "origin_provider": "pkp.de",
                "retention_class": "long",
                "retention_label": "lang (399 Tage)",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": ""
            }
        ],
        "very_long_lived_count": 0,
        "missing_samesite_count": 0,
        "persistent_unknown_count": 0,
        "long_lived_tracking_count": 2
    },
    "security_header_analysis": {
        "color": "orange",
        "score": 58,
        "checks": [
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "HSTS",
                "value": "",
                "header": "strict-transport-security",
                "present": false,
                "purpose": "Erzwingt HTTPS nach dem ersten sicheren Aufruf.",
                "severity": "warning"
            },
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "Content-Security-Policy",
                "value": "",
                "header": "content-security-policy",
                "present": false,
                "purpose": "Begrenzt Skript-, Frame- und Ressourcenquellen im Browser.",
                "severity": "warning"
            },
            {
                "ok": true,
                "note": "",
                "label": "X-Frame-Options",
                "value": "SAMEORIGIN",
                "header": "x-frame-options",
                "present": true,
                "purpose": "Reduziert Clickjacking-Risiken bei älteren Browsern.",
                "severity": "warning"
            },
            {
                "ok": true,
                "note": "",
                "label": "X-Content-Type-Options",
                "value": "nosniff",
                "header": "x-content-type-options",
                "present": true,
                "purpose": "Verhindert MIME-Sniffing bei Skripten und Stylesheets.",
                "severity": "warning"
            },
            {
                "ok": true,
                "note": "",
                "label": "Referrer-Policy",
                "value": "strict-origin-when-cross-origin",
                "header": "referrer-policy",
                "present": true,
                "purpose": "Begrenzt, welche URL-Informationen an Zielseiten weitergegeben werden.",
                "severity": "info"
            },
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "Permissions-Policy",
                "value": "",
                "header": "permissions-policy",
                "present": false,
                "purpose": "Begrenzt sensible Browser-Funktionen pro Seite.",
                "severity": "info"
            },
            {
                "ok": true,
                "note": "",
                "label": "Cross-Origin-Opener-Policy",
                "value": "same-origin",
                "header": "cross-origin-opener-policy",
                "present": true,
                "purpose": "Isoliert Top-Level-Fenster und reduziert Cross-Origin-Seiteneffekte.",
                "severity": "info"
            },
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "Cross-Origin-Resource-Policy",
                "value": "",
                "header": "cross-origin-resource-policy",
                "present": false,
                "purpose": "Begrenzt, welche fremden Seiten Ressourcen einbetten dürfen.",
                "severity": "info"
            },
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "Cross-Origin-Embedder-Policy",
                "value": "",
                "header": "cross-origin-embedder-policy",
                "present": false,
                "purpose": "Erzwingt kontrollierte Cross-Origin-Einbettungen und kann Cross-Origin Isolation ermöglichen.",
                "severity": "info"
            }
        ],
        "status": "auffällig",
        "missing": [
            "HSTS",
            "Content-Security-Policy",
            "Permissions-Policy",
            "Cross-Origin-Resource-Policy",
            "Cross-Origin-Embedder-Policy"
        ],
        "summary": "4 von 9 wichtigen Security-Headern vorhanden, 4 korrekt bewertet. Keine Content-Security-Policy gefunden.",
        "findings": [],
        "ok_count": 4,
        "weak_count": 0,
        "csp_analysis": {
            "color": "red",
            "score": 0,
            "status": "fehlt",
            "summary": "Keine Content-Security-Policy gefunden.",
            "enforced": false,
            "findings": [],
            "available": false,
            "directives": [],
            "report_only": false,
            "finding_count": 0,
            "warning_count": 0
        },
        "missing_count": 5,
        "present_count": 4,
        "missing_info_count": 3,
        "missing_warning_count": 2
    },
    "infrastructure_analysis": {
        "signals": {
            "caa": false,
            "dnssec": false,
            "final_https": true,
            "tls_version": "TLSv1.3",
            "hsts_enabled": false,
            "address_count": 2,
            "ipv6_available": true,
            "email_protection": {
                "mx": true,
                "spf": true,
                "dmarc": false
            },
            "certificate_valid": true,
            "certificate_issuer": "Starfield Secure Certificate Authority - G2",
            "certificate_alt_names": [
                "pkp.de",
                "www.pkp.de"
            ],
            "multiple_ip_addresses": true,
            "certificate_expires_at": "Oct 20 07:25:09 2026 GMT",
            "certificate_days_remaining": 124,
            "certificate_hostname_matches": true
        },
        "findings": [
            {
                "id": "dmarc_missing",
                "title": "DMARC fehlt",
                "public": true,
                "category": "email",
                "severity": "info"
            },
            {
                "id": "caa_missing",
                "title": "CAA-Record fehlt",
                "public": true,
                "category": "dns",
                "severity": "info"
            }
        ],
        "risk_level": "low",
        "positive_signals": [
            "Mehrere IP-Adressen gefunden: Hinweis auf redundante Infrastruktur oder CDN.",
            "IPv6 ist vorhanden.",
            "Moderne TLS-Version aktiv: TLSv1.3."
        ]
    },
    "performance_analysis": {
        "score": 94,
        "signals": {
            "compressed": false,
            "duration_ms": 1072,
            "image_count": 15,
            "script_count": 10,
            "cache_control": "no-store, no-cache, must-revalidate, post-check=0, pre-check=0",
            "content_length": 0,
            "viewport_found": true,
            "stylesheet_count": 5
        },
        "findings": [
            {
                "id": "too_many_render_blocking_assets",
                "title": "Viele potenziell blockierende Assets",
                "public": true,
                "category": "performance",
                "severity": "info"
            }
        ],
        "risk_level": "medium"
    },
    "accessibility_analysis": {
        "color": "orange",
        "score": 56,
        "status": "auffällig",
        "signals": {
            "h1_count": 1,
            "image_count": 15,
            "button_count": 11,
            "heading_count": 18,
            "viewport_found": true,
            "html_lang_found": true,
            "form_field_count": 2,
            "image_missing_alt_count": 5,
            "buttons_without_name_count": 11,
            "form_fields_without_label_count": 0
        },
        "summary": "15 Bild(er), 2 Formularfeld(er), 11 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
        "findings": [
            {
                "id": "image_alt_missing",
                "count": 5,
                "title": "Bilder ohne Alternativtext",
                "public": true,
                "category": "accessibility",
                "severity": "info"
            },
            {
                "id": "button_name_missing",
                "count": 11,
                "title": "Buttons ohne erkennbaren Namen",
                "public": true,
                "category": "accessibility",
                "severity": "warning"
            }
        ],
        "wcag_matrix": {
            "rows": [
                {
                    "id": "wcag_non_text_content",
                    "ok": false,
                    "wcag": "WCAG 1.1.1 Non-text Content",
                    "title": "Alternativtexte für Bilder",
                    "impact": "mittel",
                    "status": "prüfen",
                    "evidence": "5 von 15 Bild(er) ohne alt-Text im HTML-Sample."
                },
                {
                    "id": "wcag_form_labels",
                    "ok": true,
                    "wcag": "WCAG 1.3.1 Info and Relationships / 3.3.2 Labels or Instructions",
                    "title": "Formularfelder beschriften",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "0 von 2 Formularfeld(er) ohne erkennbare Beschriftung."
                },
                {
                    "id": "wcag_button_names",
                    "ok": false,
                    "wcag": "WCAG 4.1.2 Name, Role, Value",
                    "title": "Buttons mit Namen versehen",
                    "impact": "hoch",
                    "status": "prüfen",
                    "evidence": "11 von 11 Button(s) ohne erkennbaren Namen."
                },
                {
                    "id": "wcag_page_language",
                    "ok": true,
                    "wcag": "WCAG 3.1.1 Language of Page",
                    "title": "Seitensprache auszeichnen",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "HTML-lang-Attribut gefunden."
                },
                {
                    "id": "wcag_heading_structure",
                    "ok": true,
                    "wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
                    "title": "Überschriftenstruktur",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "1 H1 und 18 Überschrift(en) im HTML-Sample."
                },
                {
                    "id": "wcag_mobile_reflow",
                    "ok": true,
                    "wcag": "WCAG 1.4.10 Reflow",
                    "title": "Mobile Viewport-Basis",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "Viewport-Meta-Tag gefunden."
                }
            ],
            "summary": "2 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 1 mit hoher Auswirkung.",
            "standard": "WCAG 2.2 orientierte Basisprüfung",
            "available": true,
            "issue_count": 2,
            "high_impact_count": 1
        }
    },
    "domain_history": {
        "status": [
            "active"
        ],
        "summary": "RDAP liefert kein klares Registrierungsdatum.",
        "age_days": null,
        "findings": [],
        "available": true,
        "registrar": "",
        "expires_at": "",
        "risk_level": "unknown",
        "registered_at": "",
        "expires_in_days": null,
        "last_changed_at": "2021-06-21T19:49:30+00:00"
    },
    "data_entry_analysis": {
        "forms": [
            {
                "url": "https://www.pkp.de/de/kontakt/datenschutz",
                "path": "/de/kontakt/datenschutz",
                "method": "UNBEKANNT",
                "source": "crawl",
                "purpose": "Formular",
                "data_types": [],
                "field_count": 0
            },
            {
                "url": "https://www.pkp.de/de/kontakt/impressum",
                "path": "/de/kontakt/impressum",
                "method": "UNBEKANNT",
                "source": "crawl",
                "purpose": "Formular",
                "data_types": [],
                "field_count": 0
            },
            {
                "url": "https://www.pkp.de/de/kontakt",
                "path": "/de/kontakt",
                "method": "UNBEKANNT",
                "source": "crawl",
                "purpose": "Formular",
                "data_types": [],
                "field_count": 0
            },
            {
                "url": "https://www.pkp.de/de/kontakt/allgemeine-geschaeftsbedingungen",
                "path": "/de/kontakt/allgemeine-geschaeftsbedingungen",
                "method": "UNBEKANNT",
                "source": "crawl",
                "purpose": "Formular",
                "data_types": [],
                "field_count": 0
            },
            {
                "purpose": "Formular",
                "field_count": 0,
                "source": "crawl",
                "path": "/de/kontakt/datenschutz",
                "url": "https://www.pkp.de/de/kontakt/datenschutz"
            },
            {
                "purpose": "Formular",
                "field_count": 0,
                "source": "crawl",
                "path": "/de/kontakt/impressum",
                "url": "https://www.pkp.de/de/kontakt/impressum"
            },
            {
                "purpose": "Formular",
                "field_count": 0,
                "source": "crawl",
                "path": "/de/kontakt",
                "url": "https://www.pkp.de/de/kontakt"
            },
            {
                "purpose": "Formular",
                "field_count": 0,
                "source": "crawl",
                "path": "/de/kontakt/allgemeine-geschaeftsbedingungen",
                "url": "https://www.pkp.de/de/kontakt/allgemeine-geschaeftsbedingungen"
            }
        ],
        "score": 84,
        "summary": "Crawl fand 8 Formular(e) auf 4 geprüften Seite(n), u. a. /de/kontakt/datenschutz, /de/kontakt/impressum, /de/kontakt, /de/kontakt/allgemeine-geschaeftsbedingungen.",
        "findings": [],
        "form_count": 8,
        "risk_level": "medium",
        "field_count": 2,
        "asks_for_data": true,
        "crawl_form_pages": [
            {
                "url": "https://www.pkp.de/de/kontakt/datenschutz",
                "path": "/de/kontakt/datenschutz",
                "category": "datenschutz",
                "form_count": 2
            },
            {
                "url": "https://www.pkp.de/de/kontakt/impressum",
                "path": "/de/kontakt/impressum",
                "category": "impressum",
                "form_count": 2
            },
            {
                "url": "https://www.pkp.de/de/kontakt",
                "path": "/de/kontakt",
                "category": "kontakt",
                "form_count": 2
            },
            {
                "url": "https://www.pkp.de/de/kontakt/allgemeine-geschaeftsbedingungen",
                "path": "/de/kontakt/allgemeine-geschaeftsbedingungen",
                "category": "kontakt",
                "form_count": 2
            }
        ],
        "payment_providers": [],
        "detected_data_types": [
            {
                "id": "contact",
                "count": 1,
                "label": "Kontaktformular"
            },
            {
                "id": "newsletter",
                "count": 1,
                "label": "Newsletter"
            }
        ],
        "crawl_form_page_count": 4,
        "privacy_context_found": true,
        "operator_context_found": true
    },
    "pii_exposure_analysis": {
        "color": "yellow",
        "score": 82,
        "checks": [
            {
                "id": "current_url",
                "ok": true,
                "count": 0,
                "label": "Aktuelle URL",
                "detail": "Keine sensiblen Query-Parameter erkannt."
            },
            {
                "id": "link_queries",
                "ok": true,
                "count": 0,
                "label": "Link-Parameter",
                "detail": "Keine sensiblen Link-Querys erkannt."
            },
            {
                "id": "get_forms",
                "ok": true,
                "count": 0,
                "label": "GET-Formulare",
                "detail": "Keine personenbezogenen GET-Formulare erkannt."
            },
            {
                "id": "external_forms",
                "ok": true,
                "count": 0,
                "label": "Externe Formularziele",
                "detail": "Keine externen Formularziele mit personenbezogenen Feldern erkannt."
            },
            {
                "id": "tracking_context",
                "ok": false,
                "count": 2,
                "label": "Tracking neben Dateneingabe",
                "detail": "2 datenschutzrelevante Drittanbieter."
            }
        ],
        "status": "prüfen",
        "summary": "1 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext.",
        "findings": [
            {
                "id": "pii_tracking_on_data_entry_page",
                "title": "Dateneingabe und datenschutzrelevante Drittanbieter im selben Browseraufruf",
                "public": true,
                "category": "privacy",
                "severity": "warning",
                "third_party_count": 2
            }
        ],
        "link_hits": [],
        "finding_count": 1,
        "current_url_hits": [],
        "tracking_context": true,
        "sensitive_get_forms": []
    },
    "scan_history_analysis": {
        "available": false,
        "summary": "Noch kein früherer gespeicherter Scan für diese Domain vorhanden.",
        "total_scan_count": 1,
        "previous_scan_count": 0,
        "history": [
            {
                "scan_id": "15f79e95-d7a3-4c52-a5ca-462c3bfe4676",
                "created_at": "2026-06-17 12:35:53.973371+02",
                "score": 52,
                "verdict": "auffällig",
                "finding_count": 30,
                "integrity_root_hash": "af9baec62cfe798d7fd5de4bb942b7d8b0d36c4014675f87653d1eec11b6974b",
                "integrity_available_hash_count": 9,
                "current": true
            }
        ],
        "new_findings": [],
        "resolved_findings": [],
        "technical_changes": {
            "available": false,
            "summary": "Noch kein früherer Scan für technische Änderungen vorhanden."
        }
    },
    "benchmark_analysis": {
        "host": "pkp.de",
        "rank": 1,
        "score": 52,
        "status": "im_mittelfeld",
        "summary": "pkp.de liegt mit 52 Punkten ungefähr im gespeicherten Vergleichsfeld.",
        "available": true,
        "peer_count": 2088,
        "percentile": 0,
        "query_mode": "php_ttl_cache_refresh",
        "distribution": {
            "0_39": 244,
            "40_59": 984,
            "60_79": 857,
            "80_100": 3
        },
        "median_score": 58,
        "average_score": 53.8,
        "comparison_basis": "Neuester gespeicherter SaferPage-Scan je Domain; überwiegend deutschsprachige gespeicherte Checks.",
        "same_score_count": 0,
        "better_than_count": 0,
        "qualified_peer_count": 2013,
        "zero_score_count": 75,
        "top_quartile_score": 64,
        "top_decile_score": 68,
        "qualified_average_score": 55.8,
        "qualified_median_score": 58,
        "qualified_top_quartile_score": 64,
        "qualified_top_decile_score": 68,
        "thresholds": [
            {
                "id": "critical",
                "label": "Kritisch",
                "range": "0-39",
                "met": false
            },
            {
                "id": "basic",
                "label": "Basis stabilisieren",
                "range": "40-59",
                "met": true
            },
            {
                "id": "managed",
                "label": "Gesteuert",
                "range": "60-79",
                "met": false
            },
            {
                "id": "strong",
                "label": "Stark",
                "range": "80-100",
                "met": false
            }
        ],
        "risk_tier": "basis",
        "target_score": 60,
        "aspirational_target_score": 68,
        "gap_to_target": 8,
        "gap_to_top_quartile": 12,
        "gap_to_strong": 28,
        "cache_ttl_seconds": 300
    },
    "audit_receipt": {
        "url": "https://pkp.de/",
        "host": "pkp.de",
        "status": "verfügbar",
        "bot_url": "https://saferpage.de/bot",
        "summary": "Prüfbeleg für pkp.de: kontrollierter HTTP-/Browser-Kurzcheck mit 36 Request(s), 4 Consent-Zustand/Zuständen und 7 Artefakt(en).",
        "renderer": "playwright-chromium",
        "artifacts": [
            {
                "label": "Öffentlicher Kurzreport",
                "detail": "https://saferpage.de/pkp.de",
                "status": "verfügbar"
            },
            {
                "label": "JSON-Export",
                "detail": "Maschinenlesbarer Report mit Modulen, Nachweisen und Tabellen.",
                "status": "verfügbar"
            },
            {
                "label": "CSV-Export",
                "detail": "Tabellarische Prüfzeilen für Betreiber, Datenschutz und Technik.",
                "status": "verfügbar"
            },
            {
                "label": "160x150 Seitenvorschau",
                "detail": "/cache/screenshots/pkp.de-160x150-d1d6544f2bddaae78a.png",
                "status": "verfügbar"
            },
            {
                "label": "Cookie-Erklärung",
                "detail": "5 Cookie-/Storage-Eintrag/Einträge.",
                "status": "auffällig"
            },
            {
                "label": "Empfänger-/Anbieterinventar",
                "detail": "4 Anbieterzeile(n), 2 AVV-/Rollenprüfung(en).",
                "status": "kritisch"
            },
            {
                "label": "Barrierefreiheitserklärung-Entwurf",
                "detail": "2 bekannte Barrierefreiheits-Punkt(e).",
                "status": "Nicht vollständig konform im automatischen Basischeck"
            }
        ],
        "available": true,
        "final_url": "https://www.pkp.de/de",
        "checked_at": "2026-06-17T10:35:53+00:00",
        "share_text": "SaferPage Prüfbeleg pkp.de: 36 Browser-Request(s), 4 Drittanbieter, 5 Cookie-/Storage-Einträge, geprüft am 2026-06-17T10:35:53.",
        "user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)",
        "limitations": [
            "Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
            "Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
            "Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
        ],
        "scan_context": "manual",
        "coverage_items": [
            {
                "label": "HTTP/DNS/TLS",
                "value": "HTTP 200 · DNS ok · TLS ok"
            },
            {
                "label": "Browserlauf",
                "value": "36 Request(s), 4 Drittanbieter-Domain(s), 4 Browser-Cookie(s)."
            },
            {
                "label": "Consent-Zustände",
                "value": "4 Zustand/Zustände: Default, Ablehnen, Akzeptieren und GPC soweit verfügbar."
            },
            {
                "label": "Seitenabdeckung",
                "value": "8 priorisierte Unterseite(n) im Nachweispack."
            },
            {
                "label": "Drittanbieter-Auszug",
                "value": "4 Anbieterzeile(n) im öffentlichen Nachweis."
            },
            {
                "label": "Cookie-Auszug",
                "value": "4 Cookie-Zeile(n) im öffentlichen Nachweis."
            }
        ],
        "confidence_score": 48,
        "browser_final_url": "https://www.pkp.de/de"
    },
    "evidence_integrity_manifest": {
        "host": "pkp.de",
        "status": "verfügbar",
        "summary": "Integritätsmanifest für pkp.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
        "sections": [
            {
                "id": "audit_receipt",
                "hash": "570e7fb5ceee2b82c073c690cd473080509cf6d10098936a9bb9b51fd2d5ff43",
                "count": 18,
                "label": "Prüfbeleg",
                "detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
                "status": "verfügbar"
            },
            {
                "id": "protocol",
                "hash": "13fa7115193dde925a582f5fda98783595a4afc2ddc418c750a28e88156032cf",
                "count": 15,
                "label": "Scan-Protokoll",
                "detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
                "status": "verfügbar"
            },
            {
                "id": "checkpoints",
                "hash": "61dea19d383924e7147f6496bc07c8c5d99859d8b8d01c36b07d3741a1ae4f61",
                "count": 6,
                "label": "Prüfschritte",
                "detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
                "status": "verfügbar"
            },
            {
                "id": "consent_states",
                "hash": "e47cf322cf9cbad1a173bb5ade240ff1a02a0d086c86e276cf1ba743fa6ebb9f",
                "count": 4,
                "label": "Consent-Zustände",
                "detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
                "status": "verfügbar"
            },
            {
                "id": "third_party_evidence",
                "hash": "59e553a5db45885857b41547fcdd7194bb0caaf9d1680407e35b50936a2abbb3",
                "count": 4,
                "label": "Drittanbieter-Auszug",
                "detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
                "status": "verfügbar"
            },
            {
                "id": "cookie_evidence",
                "hash": "19d99a2b883834867dbe6a66e027579409bf922314369bfc2e42f2e5a3bb30ac",
                "count": 4,
                "label": "Cookie-Auszug",
                "detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
                "status": "verfügbar"
            },
            {
                "id": "request_samples",
                "hash": "7190fc6e429137cdb98dee1a0d317c3a228a46321ff8f2b7ea7174cb47eedd8d",
                "count": 6,
                "label": "Request-Samples",
                "detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
                "status": "verfügbar"
            },
            {
                "id": "checked_pages",
                "hash": "80004333fa01f1a47f718f681c30cba754d97e2a197f7ea30db3d0b655c8b9fc",
                "count": 8,
                "label": "Geprüfte Unterseiten",
                "detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
                "status": "verfügbar"
            },
            {
                "id": "screenshot_file",
                "hash": "b0fe1b9f76960d8447316b463efc2647ede043f3321d633d129ff556203e55c1",
                "count": 11803,
                "label": "160x150 Seitenvorschau-Datei",
                "detail": "/cache/screenshots/pkp.de-160x150-d1d6544f2bddaae78a.png",
                "status": "verfügbar"
            }
        ],
        "algorithm": "sha256",
        "available": true,
        "root_hash": "af9baec62cfe798d7fd5de4bb942b7d8b0d36c4014675f87653d1eec11b6974b",
        "checked_at": "2026-06-17T10:35:53+00:00",
        "limitations": [
            "Das Manifest schützt die im Report veröffentlichten/sanitisierten Nachweise, nicht verdeckte Cookie-Werte oder vollständige Request-URLs.",
            "Ohne externe qualifizierte Zeitstempelung beweist der Hash Integrität des exportierten Artefakts, aber keine amtliche Zustellung."
        ],
        "section_count": 9,
        "canonicalization": "JSON UTF-8, sort_keys=true, kompakte Separatoren; Screenshot als rohe Datei-Bytes.",
        "available_hash_count": 9
    },
    "audit_evidence_pack": {
        "status": "verfügbar",
        "summary": "Nachweisprotokoll mit 36 Browser-Request(s), 4 Cookie-Nachweis(en), 4 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
        "protocol": {
            "host": "pkp.de",
            "dns_ok": true,
            "tls_ok": true,
            "bot_url": "https://saferpage.de/bot",
            "renderer": "playwright-chromium",
            "final_url": "https://www.pkp.de/de",
            "input_url": "https://pkp.de/",
            "checked_at": "2026-06-17T10:35:53+00:00",
            "user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)",
            "http_status": 200,
            "scan_context": "manual",
            "screenshot_url": "/cache/screenshots/pkp.de-160x150-d1d6544f2bddaae78a.png",
            "googlebot_status": 200,
            "browser_final_url": "https://www.pkp.de/de",
            "dns_address_count": 2
        },
        "checkpoints": [
            {
                "label": "DNS",
                "detail": "2 Adresse(n) aufgelöst.",
                "status": "ok"
            },
            {
                "label": "TLS/HTTPS",
                "detail": "TLSv1.3",
                "status": "ok"
            },
            {
                "label": "HTTP-Abruf",
                "detail": "Status 200, Endziel https://www.pkp.de/de.",
                "status": "ok"
            },
            {
                "label": "Browserlauf",
                "detail": "36 Request(s), 4 Drittanbieter-Domain(s).",
                "status": "ok"
            },
            {
                "label": "Consent-Zustände",
                "detail": "Default, Ablehnen, Akzeptieren und GPC werden soweit möglich gegenübergestellt.",
                "status": "prüfen"
            },
            {
                "label": "Exports",
                "detail": "PDF/Druck, JSON und CSV enthalten die wesentlichen Prüfnachweise.",
                "status": "verfügbar"
            }
        ],
        "limitations": [
            "Öffentliche Nachweise enthalten keine Cookie-Werte und keine vollständigen Request-URLs.",
            "Der Scan ist ein passiver Browser- und HTTP-Kurzcheck; rechtliche Bewertung bleibt Betreiberaufgabe.",
            "Dynamische Inhalte können sich je nach Region, Zeit, Gerät und Consent-Auswahl ändern."
        ],
        "checked_pages": [
            {
                "path": "/de/kontakt/datenschutz",
                "source": "homepage_link",
                "status": 0,
                "category": "datenschutz"
            },
            {
                "path": "/de/kontakt/impressum",
                "source": "homepage_link",
                "status": 0,
                "category": "impressum"
            },
            {
                "path": "/de/kontakt",
                "source": "homepage_link",
                "status": 0,
                "category": "kontakt"
            },
            {
                "path": "/de/kontakt/allgemeine-geschaeftsbedingungen",
                "source": "homepage_link",
                "status": 0,
                "category": "kontakt"
            },
            {
                "path": "/de/info-anfrage-downloads",
                "source": "homepage_link",
                "status": 0,
                "category": "newsletter"
            },
            {
                "path": "/de",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/de/pkp-produkte",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/de/pkp-produkte/druck",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            }
        ],
        "cookie_evidence": [
            {
                "name": "_ga",
                "domain": "pkp.de",
                "secure": false,
                "category": "Analytics",
                "provider": "Google",
                "tracking": true,
                "retention": "lang (399 Tage)",
                "same_site": "Lax",
                "pre_consent": true
            },
            {
                "name": "_ga_5EBT50JLF8",
                "domain": "pkp.de",
                "secure": false,
                "category": "Analytics",
                "provider": "Google",
                "tracking": true,
                "retention": "lang (399 Tage)",
                "same_site": "Lax",
                "pre_consent": true
            },
            {
                "name": "15506c5c2936092e3ec13f6e93cdc469",
                "domain": "pkp.de",
                "secure": false,
                "category": "Unklar",
                "provider": "pkp.de",
                "tracking": false,
                "retention": "Session",
                "same_site": "Lax",
                "pre_consent": true
            },
            {
                "name": "_gcl_au",
                "domain": "pkp.de",
                "secure": false,
                "category": "Unklar",
                "provider": "pkp.de",
                "tracking": false,
                "retention": "mittel (89 Tage)",
                "same_site": "Lax",
                "pre_consent": true
            }
        ],
        "browser_evidence": {
            "gpc_enabled": true,
            "request_count": 36,
            "storage_total": 1,
            "accept_clicked": false,
            "reject_clicked": false,
            "browser_cookie_count": 4,
            "contacted_domain_count": 5,
            "third_party_domain_count": 4,
            "storage_tracking_hint_count": 0,
            "privacy_relevant_domain_count": 2
        },
        "storage_evidence": {
            "tracking_key_hints": [],
            "local_storage_total": 1,
            "session_storage_total": 0
        },
        "third_party_evidence": [
            {
                "host": "googletagmanager.com",
                "category": "Tag-Manager",
                "provider": "Google Tag Manager",
                "transfer": "Drittland/USA",
                "risk_level": "hoch",
                "request_count": 3,
                "resource_types": [
                    "script"
                ],
                "privacy_relevant": true
            },
            {
                "host": "region1.google-analytics.com",
                "category": "Analytics",
                "provider": "Google Analytics",
                "transfer": "Drittland/USA",
                "risk_level": "mittel",
                "request_count": 1,
                "resource_types": [
                    "fetch"
                ],
                "privacy_relevant": true
            },
            {
                "host": "cloud.ccm19.de",
                "category": "Sonstige",
                "provider": "cloud.ccm19.de",
                "transfer": "EU/EWR",
                "risk_level": "niedrig",
                "request_count": 1,
                "resource_types": [
                    "script"
                ],
                "privacy_relevant": false
            },
            {
                "host": "google.com",
                "category": "Sonstige",
                "provider": "google.com",
                "transfer": "Drittland/USA",
                "risk_level": "niedrig",
                "request_count": 1,
                "resource_types": [
                    "fetch"
                ],
                "privacy_relevant": false
            }
        ],
        "external_script_count": 1,
        "consent_state_evidence": [
            {
                "label": "Erstaufruf",
                "cookie_count": 0,
                "domain_count": 4,
                "request_count": 6,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 2
            },
            {
                "label": "Nach Ablehnen neu",
                "cookie_count": 0,
                "domain_count": 0,
                "request_count": 0,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            },
            {
                "label": "Nach Akzeptieren neu",
                "cookie_count": 0,
                "domain_count": 0,
                "request_count": 0,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            },
            {
                "label": "GPC-Aufruf",
                "cookie_count": 0,
                "domain_count": 4,
                "request_count": 6,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 2
            }
        ],
        "request_sample_evidence": [
            {
                "host": "cloud.ccm19.de",
                "query_keys": [
                    "apikey",
                    "domain"
                ],
                "resource_type": "script",
                "query_key_count": 2,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 1
            },
            {
                "host": "googletagmanager.com",
                "query_keys": [
                    "id"
                ],
                "resource_type": "script",
                "query_key_count": 1,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "googletagmanager.com",
                "query_keys": [
                    "id",
                    "cx",
                    "gtm"
                ],
                "resource_type": "script",
                "query_key_count": 3,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "googletagmanager.com",
                "query_keys": [
                    "id",
                    "cx",
                    "gtm"
                ],
                "resource_type": "script",
                "query_key_count": 3,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "region1.google-analytics.com",
                "query_keys": [
                    "v",
                    "tid",
                    "gtm",
                    "_p",
                    "gcd",
                    "npa",
                    "dma_cps",
                    "dma"
                ],
                "resource_type": "fetch",
                "query_key_count": 37,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 1
            },
            {
                "host": "google.com",
                "query_keys": [
                    "rcb",
                    "frm",
                    "auid",
                    "dt",
                    "en",
                    "dl",
                    "scrsrc",
                    "rnd"
                ],
                "resource_type": "fetch",
                "query_key_count": 22,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            }
        ]
    },
    "consent_visual_salience_evidence": {
        "schema": "https://saferpage.de/schemas/consent-visual-salience-evidence.v1",
        "status": "measured_dom_viewport_signal",
        "available": true,
        "evidence_level": "dom_viewport_signal_only",
        "summary": "Der erste Headless-Chromium-Viewport liefert sichtbare Consent-Control-Signale mit Text, Position, Groesse und typografischen Hinweisen.",
        "sample_status": "visible_controls_without_classified_samples",
        "classified_sample_count": 0,
        "accept_control_count": 0,
        "reject_control_count": 0,
        "settings_control_count": 0,
        "visible_control_count": 13,
        "accept_max_area": 0,
        "reject_max_area": 0,
        "reject_prominence_ratio": "nicht messbar",
        "samples": [],
        "sample_boundary": "Samples enthalten nur klassifizierte Accept-/Reject-/Settings-Controls. Weitere sichtbare Consent-Controls bleiben als Zaehler erhalten, werden aber ohne Klassifizierung nicht als Ablehnen-, Akzeptieren- oder Einstellungsprobe behauptet.",
        "claim_boundary": "Consent-Visual-Salienz ist ein DOM-/Viewport-Signal aus dem ersten Browserlauf. Sie ist keine Rechtsbewertung, kein Dark-Pattern-Endurteil und kein Nachweis fuer spaetere Consent-Zustaende, Scrollbereiche, Loginbereiche oder manuelle Betreiberkontexte."
    }
}