Live-Domain-Report

leichtesprache.lzk-bw.de Datenschutz-Check

Scan-ID: aee1739b-1128-4335-a4bd-1dbcd4402a4c · 2026-06-12 13:40:29.128337+02

Geprüfte Domain-Wurzel: https://leichtesprache.lzk-bw.de/

Kurz-URL: saferpage.de/leichtesprache.lzk-bw.de

Kleine Seitenvorschau von leichtesprache.lzk-bw.de
Screenshot-Vorschau 160x150 · vollständig sichtbar · Headless Chromium · preview_available · page_preview
0 Kritische Hinweise

In 20 Sekunden lesen

Was ist bei leichtesprache.lzk-bw.de wirklich wichtig?

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

VerlässlichkeitPassiver Kurzcheck ohne harte Warnsignale
Keine harten Signale im Kurzcheck, aber keine vollständige Betreiberfreigabe.
Belegbar4 technische Evidence-Punkte aus dem gespeicherten passiven Lauf.Guide-LinkBetreiber-Checkliste öffnenNicht behaupten3 Claim-Grenzen: keine Rechtsfreigabe, kein Zertifikat, kein abschließendes Seriositätsurteil.Fix-PfadFixpfad öffnenNachweiseMethodik · Evidence-Hub

Betreiberentscheidung

Welche Fakten und Linkziele gibt es für leichtesprache.lzk-bw.de?

Der Abschnitt trennt technische Evidence von Betreiber-Background. Er enthält kein Rechtsurteil, keine Freigabe, kein pauschales Misstrauenslabel und keine eingebetteten Guide-Inhalte.

normaler Passivlauf
0Score als Priorisierung, nicht als Rechtsfreigabe0Cookie(s) vor Einwilligung gesehen0datenschutzrelevante Drittanbieter-Domains0Formular(e)jaImpressum-Link automatisch belegtjaDatenschutz-Hinweis automatisch belegt
Scan-Einordnung

Der Score zeigt erhöhten Prüfbedarf aus technischen Signalen; er ist ein Priorisierungssignal, kein Verbot.

Einordnung lesen
Google Consent Mode

Kein Google-Tag, keine Google-Domain und keine Google-Tracking-ID belegt: kein Google-Consent-Mode-Fehler aus dieser Evidenz.

Grenzen prüfen

Betreiber-Checkliste öffnen

Nicht behaupten: SaferPage bestätigt keine DSGVO-Konformität, keine Malwarefreiheit, keine rechtssichere Cookie-Einwilligung und keine abschließende Betreibertransparenz. Relevante Änderungen immer erneut scannen und fachlich freigeben.

Aussage-Ampel

Was dieser Report belegt, was zu prüfen ist und was nicht behauptet werden darf

Diese Einordnung schützt vor überzogenen Scanner-Schlüssen: technische Beobachtung, manuelle Betreiberprüfung und klare Claim-Grenzen bleiben getrennt.

Aussage-VerlässlichkeitPassiver Kurzcheck ohne harte Warnsignale · OrientierungFür die EinordnungKeine harten Signale im Kurzcheck, aber keine vollständige Betreiberfreigabe.BetreiberkontextNicht als Scan-Feststellung im Testresult ausgespielt; Detailprüfung ist verlinkt.

Verlässlichkeitsgrenze: Der passive Lauf zeigt keine dominanten Tracking-, Formular- oder Gate-Signale. Unsichtbare Login-, Zahlungs- oder Betreiberprozesse bleiben außerhalb des Kurzchecks.

Automatisch belegtAus gespeicherter SaferPage-Evidence

Score 0/100 als Priorisierung aus passivem HTTP-, HTML-, Header-, Cookie- und Browserkontakt-Sample.

39 Browser-Request(s), 0 datenschutzrelevante Drittanbieter-Domain(s), 0 Tracking-Script(s) im gespeicherten Lauf.

4 direkt geprüfte Test-URL(s) im Crawl-Abschnitt; die Ziel-Links bleiben im Report nachvollziehbar.

Kein Google-Tag, keine Google-Domain und keine Google-Tracking-ID belegt; kein Google-Consent-Mode-Fehler aus dieser Evidenz.

Status
belegbar
Nicht behauptenClaim-Grenzen

keine DSGVO-Konformität, keine Rechtsberatung und keine Betreiberfreigabe

kein abschließendes Seriositätsurteil über leichtesprache.lzk-bw.de

keine Malwarefreiheit, kein Penetrationstest und keine vollständige Prüfung hinter Login, Paywall oder Geoblocking

Status
nicht freigegeben

Betreiber-Checkliste öffnen

Datenschutz-Fokus: Der Report zeigt konkrete Datenschutz-, Consent-, Formular- und Transparenzsignale. Er ist kein Freigabesiegel und braucht bei Website-Änderungen einen neuen technischen Re-Scan.

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-GrenzeneinGoogle-Consent aus Evidenz
GeprüftAutomatische Evidence aus dem passiven Lauf

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

Cookies und Consent-Startzustand: 0 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: Keine Formularabgabe im passiven Sample belegt.

Status
belegt

Methodik-Grenzen öffnen

Betreiber-Checkliste öffnen

Monitoring-Guide ö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.

Konsolidierungscheck

Sind typische Fehlalarme für Betreiber eingeordnet?

Diese Kontrolle prüft die Report-Darstellung gegen bekannte Schwachstellen: Formular-Widersprüche, Google-Consent-Fehlalarme, doppelte Maßnahmen, Consent-/Paywall-Grenzen und pauschale Besucherwarnungen.

ok
6/6Kontrollen bestanden0doppelte Scan-HinweiseneinGoogle-Consent aus Evidenz erforderlich0Google-Fehlalarme in Scan-Hinweisen0Formulare aus Crawl-CoverageneinConsent-/Paywall-Grenze
Scan-Hinweise dedupliziertok · ok
Gleiche Scan-Hinweise werden nicht doppelt in die Top-Liste geschoben.
Grenze: Deduplizierung fasst gleich benannte Scan-Hinweise zusammen, ersetzt aber keine fachliche Priorisierung.
Prüfkatalog öffnen
Google Consent nur bei Google-Evidenzok · nicht erforderlich
Ohne Google-Tag, Google-Domain oder Google-Tracking-ID wird kein Google-Consent-Mode-Fix gefordert.
Grenze: Ein später eingebauter Google-Tag braucht einen Re-Scan; diese Aussage gilt nur für die gespeicherte Scan-Evidenz.
Consent-Guide öffnen
Formulare konsistent eingeordnetok · im Kurzcheck nicht belegt
Nicht sichtbare, mehrstufige oder Login-Formulare bleiben manuelle Prüfpunkte.
Grenze: SaferPage sendet keine Formulare ab und bewertet Zweck, Pflichtfelder und Rechtsgrundlagen nicht abschließend.
Formular-Guide öffnen
Consent-/Paywall-Grenze berücksichtigtok · normaler Passivlauf
Keine Publisher-/PUR-/Consent-Wall als dominante Scan-Grenze erkannt.
Grenze: Overlays, Logins, Geoblocking und Paywalls können sichtbare Nachweise verdecken und erfordern Betreiberprüfung.
Methodik öffnen
Betreiber-Wording gesichertok · Grenzen sichtbar
Die Top-Liste bleibt bei Scan-Hinweisen und Linkzielen; sie wird nicht als Zertifikat, Rechtsfreigabe oder abschließendes Seriositätsurteil formuliert.
Grenze: Der Kurzreport ist eine technische Orientierung und keine Rechtsberatung, kein Penetrationstest und kein Freigabesiegel.
Einordnung öffnen
Aussage-Ampel exportiertok · maschinenlesbar
JSON und Markdown enthalten belegte Signale, manuelle Prüfpunkte, Claim-Grenzen und Guide-Links.
Grenze: Der Export dokumentiert die automatische Einordnung, ersetzt aber keine manuelle Betreiber- oder Rechtsfreigabe.
Aussage-Grenzen öffnen

Claim-Grenze: Die Qualitätskontrollen erklären Grenzen der automatisierten Priorisierung. Sie beweisen keine Rechtskonformität und ersetzen keine Betreiberfreigabe.

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

Direkte Test-URLs

/wie-sieht-unser-datenschutz-ausdatenschutz · HTTP 200 · Tracking 0 · Cookies 0/impressumimpressum · HTTP 200 · Tracking 0 · Cookies 0/an-welche-gesetze-muessen-sich-zahnaerzte-haltenunterseite · HTTP 200 · Tracking 0 · Cookies 0/der-gesunde-zahnunterseite · HTTP 200 · Tracking 0 · Cookies 0

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.

Domainleichtesprache.lzk-bw.de Score0 Scan-IDaee1739b-1128-4335-a4bd-1dbcd4402a4c Erstellt2026-06-12 13:40:29.128337+02 Öffentlicher Linksaferpage.de/leichtesprache.lzk-bw.de ExportPDF/Druck, JSON, CSV, XLSX, ZIP-Nachweise
DNS erreichbarAdressen: 1
HTTPS-Zertifikat gültigTLS: TLSv1.2
HTTP-Status 200Endziel: https://leichtesprache.lzk-bw.de/

Report richtig einordnen

Passive technische Orientierung, kein abschließendes Urteil

SaferPage bewertet sichtbare Website-Signale für leichtesprache.lzk-bw.de. Der Score hilft beim Priorisieren, ersetzt aber keine Rechtsberatung, keine Zertifizierung, keinen Penetrationstest und keine Betreiberfreigabe.

Automatisch belegtDNS, HTTPS, HTTP, Header, sichtbares HTML, Cookies und Browserkontakte aus dem passiven Lauf.Scan-Grenzekeine besondere Gate-Grenze erkannt · Passiver Kurzcheck: keine Logins, keine Formularübermittlung, kein vollständiger Rechts- oder Sicherheitstest.Formular-EvidenceIm passiven Sample nicht belegt.Google Consent ModeKein Google-Tag, keine Google-Domain und keine Google-Tracking-ID im passiven Check erkannt; Google Consent Mode ist aus dieser Evidenz nicht erforderlich.Drittanbieter-Evidence39 Browser-Request(s), 0 datenschutzrelevante Drittanbieter-Domain(s).Nicht behauptenKeine Aussage wie DSGVO-zertifiziert, rechtssicher, malwarefrei garantiert oder abschließend unbedenklich.

Betreiber-Checkliste öffnen

Grenzen der automatischen Bewertung

Welche Grenzen sind aus der Evidence ableitbar?

Diese Konsolidierung zeigt sichtbare technische Beobachtungen getrennt von allgemeinem Betreiber-Background. Nicht belegte Kontexte werden nur als Guide-Link angeboten.

39Browser-Requests im passiven Lauf0datenschutzrelevante Drittanbieter-Domains0Formulare aus Startseite und Crawl-CoverageneinGoogle-Consent-Prüfung erforderlichneinPublisher-/Consent-Gate-Kontextkeine besondere Gate-Grenze erkanntScan-Grenze
ScorePriorisierung
Der Wert ist aus technischen Signalen berechnet und dient der Reihenfolge der sichtbaren Hinweise.
Methodik öffnen
Formulareim passiven Sample nicht belegt
Der passive Lauf hat keine Formular-Evidence gespeichert.
Formular-Guide öffnen
Google Consent Modenicht aus dieser Evidenz erforderlich
Ohne Google-Tag, Google-Domain oder Google-Tracking-ID wird kein Google-Consent-Mode-Fehler erzeugt.
Consent-Guide öffnen
Consent-/Paywall-Gateskeine besondere Gate-Grenze erkannt
Im gespeicherten Kurzcheck wurde keine besondere Gate-Grenze hervorgehoben.
Grenzen öffnen
Cookies vor Einwilligung0 Cookie(s) gesehen
Der passive Browserlauf speicherte 0 Cookie(s) vor Einwilligung und 0 datenschutzrelevante Drittanbieter-Domain(s).
Cookie-Guide öffnen
Externe Skript-LieferketteSkriptquellen prüfen
Der HTML-Check sah 5 externe Skript(e) von 3 Host(s), davon 5 ohne SRI und 0 Tracking-/Tag-nahe Skript(e).
Skript-Guide öffnen
Robots & Sitemapnicht belegt
Der passive Coverage-Check hat robots.txt nicht belastbar geprüft, 0 Sitemap-Quelle(n) gelesen, 0 Sitemap-Kandidat(en) gesehen, 0 Sitemap-URL(s) und 18 interne Linkziele gespeichert.
Crawl-Grenzen öffnen
Indexierungs-Signalenicht belegt
Der passive Abruf hat keine Meta-Robots- oder X-Robots-Tag-Signale als Schwerpunkt gespeichert.
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 belastbar geprüft
Der ads.txt/app-ads.txt/sellers.json-Check wurde nicht belastbar abgeschlossen; daraus folgt keine Aussage zu Werbepartnern, Consent, Fraud-Freiheit oder Inventarqualität.
AdTech-Grenzen öffnen
Security-/Trust-Policynicht belastbar geprüft
Der security.txt-Check wurde nicht belastbar abgeschlossen; daraus folgt keine Aussage zu Security-Reife, Reaktionszeit oder Vulnerability-Disclosure-Prozess.
Security-/Trust-Grenzen öffnen
Ausgeblendeter Inhaltkein Schwerpunkt
Der HTML-/CSS-Check hat ausgeblendeten Text nicht als Schwerpunkt gespeichert.
Einordnung öffnen
Bewertungs-/Review-Markupnicht belegt
Der passive Lauf hat kein Bewertungs-/Review-Markup als Schwerpunkt gespeichert.
SEO-/Markup-Guide öffnen
Suchmaschinenansichtkeine klare Abweichung
Normaler Abruf und Googlebot-Abruf wurden verglichen: Status – / –, Textähnlichkeit 1.
Cloaking-Guide öffnen
Hreflang-/Sprachalternativennicht belegt
Der passive Lauf hat keine Hreflang-Alternates als Schwerpunkt gespeichert.
Hreflang-Guide öffnen
BetreibertransparenzLink-Evidenz vorhanden
Der passive Lauf hat einen Impressum-Link als Evidence gespeichert.
Transparenz-Guide öffnen

Methodik-Grenzen öffnen

Link-only

Faktenbasierte Linkziele statt Fix-Anleitung

Diese Testresult-Seite zeigt Scan-Fakten zur geprüften Website. Umsetzungsschritte, Betreiber-Guides, Checklisten, Code und allgemeine Empfehlungen stehen auf getrennten Seiten; im Report erscheint nur das Linkziel.

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

Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.

Guide-, Checklisten- und Umsetzungstexte sind ausgelagert; hier bleiben Evidence und Linkziel.
Gewicht
88/100
Linkziel
öffnen
CVE-2018-16845: Memory disclosure in the ngx_http_mp4_modulehoch · BSI/Patchmanagement

Betroffene Software aktualisieren oder kompensierend absichern.

Guide-, Checklisten- und Umsetzungstexte sind ausgelagert; hier bleiben Evidence und Linkziel.
Gewicht
82/100
Linkziel
öffnen
Sicherheit, TLS & Headerhoch · Sicherheit, TLS & Header

1 Infrastruktur-Hinweis(e), Security-Header: 0/9 vorhanden, 9 fehlen, externe Skript-Hosts: 3.

Guide-, Checklisten- und Umsetzungstexte sind ausgelagert; hier bleiben Evidence und Linkziel.
Gewicht
82/100
Linkziel
öffnen

Betreiber-Fazit

Erhöhter Betreiber-Prüfbedarf

Die Kurzfassung zeigt technische Signale aus dem passiven Lauf. Betreiberkontext ohne Scan-Beleg wird nur als Guide-Link angeboten.

Auffällige SignaleCVE-2018-16845: Memory disclosure in the ngx_http_mp4_moduleCVE-2019-9511: Excessive CPU usage in HTTP/2 with small window updatesCVE-2021-23017: 1-byte memory overwrite in resolverCVE-2022-41741: Memory corruption in the ngx_http_mp4_module
Entlastende SignaleBetreiber und Datenschutz sind auffindbarKeine sensible Eingabe erkanntNutzbarkeit wirkt solideTechnisches Vertrauenssignal
Datenschutz & Trackingauffällig0 Tracking-Script(s), 0 Cookie(s) vor Einwilligung, 0 datenschutzrelevante Drittanbieter.
DateneingabeunauffälligKeine Formular- oder Zahlungsabfrage im passiven Startseiten-Sample erkannt.
BrowserkontakteprüfenChromium sah 39 Request(s), 3 Drittanbieter-Domain(s), davon 0 datenschutzrelevant.
DomainhistorieprüfenDomainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.
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.

Betreiber-Checkliste öffnen

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
Sicherheit, TLS & Header34
kritisch

1 Infrastruktur-Hinweis(e), Security-Header: 0/9 vorhanden, 9 fehlen, externe Skript-Hosts: 3.

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Datenschutz, Cookies & Consent67
auffällig

Scan-Evidence in diesem Modul vorhanden; Betreiberkontext ist ausgelagert.

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Barrierefreiheit & Usability68
auffällig

4 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 1 Button(s) ohne Namen.

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Externe Skripte & SRI74
auffällig

5 externe Skript(e) von 3 Host(s), 5 ohne SRI, 0 Tracking-/Tag-nahe Skript(e).

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Browser-Nachweis79
prüfen

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

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Seitenabdeckung & Crawl86
prüfen

18 interne Linkziele erkannt, 4 priorisierte Unterseite(n) abgerufen.

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Performance & mobile Nutzbarkeit94
unauffällig

Performance-Score 94, Antwortzeit 108 ms.

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Consent-Journey-Matrix100
unauffällig

Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 0 im GPC-Aufruf.

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen

Betreiber-Checkliste öffnen

Ausgelagerten Fixpfad öffnen

Verlinkte Betreiber-Details

Guides und Runbooks sind ausgelagert

Der Report zeigt Fakten zur geprüften Website. Hintergrund, Arbeitspfade und Runbooks liegen auf getrennten Zielseiten; hier stehen nur Links.

Link-only Detailmodule

Detailseiten statt eingebetteter Guides

Diese Testresult-Seite bleibt bei Scan-Fakten zur geprüften Website. Nachweise, Badge-Code, Benchmark, Monitoring, Runbooks und Betreiber-Guides öffnen auf eigenen Seiten; im Testresult stehen nur feste Links, keine Guide-Inhalte.

Nachweise öffnenPrüfbeleg, Exportpaket und Hash-NachweiseMonitoring öffnenScan-Verlauf, Änderungen und WiederholungsscansBenchmark öffnenVergleichswerte auf eigener DetailseiteAlerts öffnenÄnderungs- und RisikohinweiseBadge-Center öffnenBadge-Code und Verifizierung ausgelagertMethodik öffnenGrenzen, Crawl-Verhalten und PrüfprofilPriorisierte Scan-Hinweise als JSON anzeigenMaschinenlesbare Befunde mit Evidence und Linkziel

Monitoring

Was hat sich seit dem letzten Scan verändert?

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

Scan-Verlauf

Aktuell · 2026-06-12 13:40Score 0 · 45 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.

BSI/Patchmanagementhoch · 4 Hinweis(e)Guide öffnenBSI/Security-Headermittel · 4 Hinweis(e)Guide öffnenTDDDG/ePrivacyhoch · 2 Hinweis(e)Guide öffnenBarrierefreiheit/Usabilitymittel · 3 Hinweis(e)Guide öffnenDSGVO/Art. 13 Transparenzhoch · 1 Hinweis(e)Guide öffnenDSGVO/Transparenzmittel · 2 Hinweis(e)Guide öffnen

Regelwerks-Scorecard

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

Regelwerks-Matrix

BSI/Sicherheithoch · 31 Befund(e) · Score 702Guide öffnenDSGVO Transparenzhoch · 4 Befund(e) · Score 70Guide öffnenTDDDG/ePrivacyhoch · 2 Befund(e) · Score 56Guide öffnenBITV/Usabilitymittel · 3 Befund(e) · Score 34Guide öffnenBetreibervertrauenmittel · 1 Befund(e) · Score 14Guide öffnenDSGVO Datenleck/PIImittel · 1 Befund(e) · Score 14Guide öffnen

Domainhistorie

Wie lange gibt es die Domain?

Domainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.

RDAP-Hinweise

Die Domainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.

Datenschutz zuerst

Was sieht ein Nutzer beim ersten Aufruf?

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

Dateneingabe & Zahlung

Welche Daten könnte die Seite abfragen?

Im passiven Sample wurde keine Formular-Evidence gespeichert. Datenschutzkontext: ja · Betreiberkontext: ausgelagert

Erkannte Eingaben

Keine klare Dateneingabe oder Zahlung im passiven Startseiten-Sample erkannt.

PII & Datenlecks

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

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

Betreiber-Guide PII-Datenlecks öffnen

Leckpfade

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 Dateneingabeok · Keine Kombination aus Dateneingabe und datenschutzrelevanten Drittanbietern erkannt.

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: 39 · kontaktierte Domains: 4 · Drittanbieter: 3 · Browser-Cookies: 0 · Storage: 2 (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 0, Drittanbieter-Cookies 0 · CMP: nein · Browser: playwright-chromium

Zwecke

other3 Domain(s)

CMP & Storage

TCF 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-Domains0GPC Drittanbieter-Cookies0GPC Storage-Hinweise0

Drittanbieter

cdn.eye-able.comSonstige · 5 Request(s) · image, scripttranslate-cdn.eye-able.comSonstige · 3 Request(s) · fetch, scriptlzkpiwi.lzk-bw.deSonstige · 1 Request(s) · script

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, 0 mittel auffällig. Score: 100

Betreiber-Guide Consent öffnen

Zustandsnachweis

ErstaufrufCookies 0 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigNach AblehnenCookies 0 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigNach AkzeptierenCookies 0 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigGPC-AufrufCookies 0 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrig

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, 0 im GPC-Aufruf. Score: 100 · Ablehnen neu: 0 · Akzeptieren neu: 0 · GPC: 0

Betreiber-Guide Consent öffnen

Zustandsmatrix

cdn.eye-able.comSonstige · Erstaufruf 5 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 5translate-cdn.eye-able.comSonstige · Erstaufruf 3 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 3lzkpiwi.lzk-bw.deSonstige · Erstaufruf 1 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 1

Drittanbieter-Kontakte

Wer bekommt beim ersten Aufruf technische Kontaktpunkte?

3 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant. Score: 95 · Requests: 9 · datenschutzrelevant: 0

Betreiber-Guide Drittanbieter öffnen

Kontaktmatrix

cdn.eye-able.comniedrig · Sonstige · 5 Request(s) · image:2, script:2, stylesheet:1translate-cdn.eye-able.comniedrig · Sonstige · 3 Request(s) · fetch:2, script:1lzkpiwi.lzk-bw.deniedrig · Sonstige · 1 Request(s) · script:1

Betreiber-Verzeichnis

Empfänger- und Auftragsverarbeiter-Signale aus dem Scan

3 Empfänger-/Anbieter-Eintrag/Einträge aus Browserkontakten und Cookie-Inventar, 0 datenschutzrelevant, 2 mit AVV-/Rollenprüfung. Score: 90 · hoher Prüfbedarf: 0 · AVV/Rolle prüfen: 2
Aus diesem Rohfeld wird im Testresult keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise sind ausgelagert.

Betreiber-Guide Anbieterinventar öffnen

Anbieterinventar

cdn.eye-able.committel · Sonstige · Technischer Empfänger prüfen · Jurisdiktion unklar · 5 Request(s) · 0 Cookie(s)translate-cdn.eye-able.committel · Sonstige · Technischer Empfänger prüfen · Jurisdiktion unklar · 3 Request(s) · 0 Cookie(s)lzkpiwi.lzk-bw.deniedrig · Sonstige · Technischer Empfänger prüfen · EU/EWR · 1 Request(s) · 0 Cookie(s)

Transfer-Risiko

Drittanbieter mit Transfer- oder Jurisdiktionssignal

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

Transfer Impact Assessment öffnen

Betreiber-Guide Drittlandtransfer öffnen

Anbieter-Prüfliste

cdn.eye-able.committel · Jurisdiktion unklar · unbekannttranslate-cdn.eye-able.committel · Jurisdiktion unklar · unbekanntlzkpiwi.lzk-bw.deniedrig · EU/EWR · EU/EWR

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

Betreiber-Guide externe Inhalte öffnen

Embed-Prüfliste

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

Referrer & URL-Leaks

Werden Seitenpfade oder Suchparameter an Drittanbieter sichtbar?

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

Betreiber-Guide Referrer- und URL-Leaks öffnen

Leak-Prüfliste

Keine Referrer- oder URL-Leak-Hinweise aus den gespeicherten Chromium-Requests erkannt.

Tracking-Pixel & Beacons

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

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

Betreiber-Guide Pixel & Beacons öffnen

Signale

Keine Tracking-Pixel, Link-Pings oder Beacon-/Keepalive-Hinweise erkannt.

Fingerprinting & Session-Replay

Liest die Seite Browser-Merkmale oder Interaktionen aus?

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

Betreiber-Guide Fingerprinting öffnen

Browser-API-Check

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 · 14 Tastatur-/Input-Listener, 70 Interaktions-Listener, 4 MutationObserver.

Seitenabdeckung

Welche Unterseiten wurden gefunden?

18 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen. Score: 86 · wichtige Seiten: datenschutz, impressum · Sitemap-URLs: 0 · gelesene Sitemaps: 0 · Unterseiten mit Tracking: 0 · Formularlücken: 0 · Datenschutzerklärung: 43 Punkte, fehlende Bausteine 8 · Aktualität: nicht erkannt · Lesbarkeit: 8.9 Wörter/Satz

Priorisierte Seiten

/wie-sieht-unser-datenschutz-ausdatenschutz · HTTP 200 · Tracking 0 · Cookies 0/impressumimpressum · HTTP 200 · Tracking 0 · Cookies 0/an-welche-gesetze-muessen-sich-zahnaerzte-haltenunterseite · HTTP 200 · Tracking 0 · Cookies 0/der-gesunde-zahnunterseite · HTTP 200 · Tracking 0 · Cookies 0

Datenschutzerklärung

Verantwortlicher / AnbieterfehltKontakt / DatenschutzkontaktgefundenZwecke der VerarbeitungfehltRechtsgrundlagenfehltBetroffenenrechtegefundenSpeicherfrist / LöschunggefundenEmpfänger / AuftragsverarbeiterfehltCookies / TrackinggefundenWiderruf / Opt-outgefundenBeschwerde bei AufsichtsbehördefehltDrittlandtransferfehltStand / Aktualitätsdatumfehlt

Anbieter-Abgleich

Kein Anbieter-Abgleich aus Technik und Datenschutzerklärung vorhanden.

Google Consent Mode

Kein Google-Consent-Mode-Fix aus dieser Evidence

Kein Google-Tag, keine Google-Domain und keine Google-Tracking-ID im passiven Check belegt.
SaferPage stellt deshalb keinen Google-Consent-Mode-Fehler dar; spätere Google-Tags brauchen einen neuen technischen Re-Scan.

Evidence-Grenzen öffnen

Google-Consent-Grenze

Google-Tagsnicht belegt Google-Consent-Domains0 Google-Service-Domains0 · nicht automatisch Consent-Mode-pflichtig

Consent-Audit

Haelt die Seite Tracking bis zur Einwilligung zurueck?

Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext. Score: 68 · Cookies vor Einwilligung: 0 · Tracking-Cookies: 0 · 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: 0 · GPC Drittanbieter-Cookies: 0 · Storage-Hinweise: 0 · CMP: nein · datenschutzrelevante Drittanbieter: 0

Pruefpunkte

Cookie-/Consent-Hinweis sichtbarokAblehnen gleichwertig erreichbarpruefenEinstellungen 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-Guide-Link

Keine priorisierten Consent-Signale im passiven Check.

Blockierplan-Link

Keine konkreten Pre-Consent-Blockiersignale im passiven Check.

Banner-UX

Wirkt das Consent-Banner fair und gleichwertig bedienbar?

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

Banner-Vorlage öffnen

Consent-Ledger öffnen

Region-Regeln öffnen

Betreiber-Guide Consent-UX öffnen

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-Hinweiseok · niedrig · GPC: Datenschutz-Domains 0, Drittanbieter-Cookies 0, Storage-Hinweise 0.Keine Tracking-Cookies vor Einwilligungok · niedrig · 0 Tracking-Cookie(s) im Erstaufruf.

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

Betreiber-Guide Consent öffnen

TCF-Zwecke

Keine auswertbaren IAB-TCF-Signale im Browserzustand erkannt.

Quellenmatrix

Welche offiziellen Quellen stützen die Einordnung?

Quellen und Betreiber-Background sind ausgelagert.
Diese Testresult-Seite zeigt dazu nur Zähler und Linkziel; Quellenkommentare sind kein Befund zur geprüften Website.

Quellen: 9 · offizielle Links: 5

Referenzen

Methodik und Quellen öffnen9 Referenzzeile(n) ausgelagert; 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 Betreiberkontext und ist als Guide ausgelagert.

Einwilligungsbezug: 3 · vor Consent auffällig: 0 · unklar/prüfen: 6 · Drittanbieter: 3 · Storage: 2

Rechtsgrundlagen-Guide-Link

Detailprüfung, Rechtsbewertung und Umsetzungshinweise werden nicht im Testresult ausgespielt.

Rechtsgrundlagen-Guide öffnen

Rechtsgrundlagen-Guide öffnen

Disclosure-Abgleich

Passt die Datenschutzerklärung zur beobachteten Technik?

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

Score: 31 · Anbieter erkannt: 4 · Anbieter fehlen: 4 · Policy-Lücken: 8

Lücken

cdn.eye-able.comanbieter · other · prüfentranslate-cdn.eye-able.comanbieter · other · prüfenlzkpiwi.lzk-bw.deanbieter · other · prüfenEigene Website oder eingebundener Dienstcookie_anbieter · Unklassifiziert · prüfenVerantwortlicher / Anbieterpflichtbaustein · Datenschutzerklärung · fehltZwecke der Verarbeitungpflichtbaustein · Datenschutzerklärung · fehltRechtsgrundlagenpflichtbaustein · Datenschutzerklärung · fehltEmpfänger / Auftragsverarbeiterpflichtbaustein · Datenschutzerklärung · fehltBeschwerde bei Aufsichtsbehördepflichtbaustein · Datenschutzerklärung · fehltDrittlandtransferpflichtbaustein · Datenschutzerklärung · fehltStand / Aktualitätsdatumpflichtbaustein · Datenschutzerklärung · fehltDatenschutzkontakt / DPO-Hinweispflichtbaustein · Datenschutzerklärung · fehlt

Datenschutzhinweis

Welche Disclosure-Signale wurden gesehen?

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

Datenschutzhinweis-Guide öffnen

Scan-Zähler

Datenschutzhinweis-Guide öffnen1 Zwecksignal(e), 0 Datenart(en), 3 Lückenhinweis(e); Entwurfstexte sind ausgelagert.

Cookie-Signale

Keine Cookie-Zeilen für den Entwurf vorhanden.

Drittanbieter-Signale

cdn.eye-able.comSonstige · Jurisdiktion unklar · mitteltranslate-cdn.eye-able.comSonstige · Jurisdiktion unklar · mittellzkpiwi.lzk-bw.deSonstige · EU/EWR · niedrig

Web-Storage-Signale

barrierefreiFontSizelocalStorage · Unklar · unklar, prüfen · dauerhaft bis Löschung durch Nutzer/BrowsereaIntrosessionStorage · Unklar · unklar, prüfen · Sitzung/Tab

Cookie-Inventar

Welche Cookies wurden beim ersten Aufruf gesehen?

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

Betreiber-Guide Cookie-Laufzeiten öffnen

Cookies

Keine Cookies im HTTP- oder Browser-Erstaufruf inventarisiert.

Cookie-Disclosure

Welche Cookie-Signale wurden gesehen?

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

Betreiber-Guide Cookie-Erklärung öffnen

Kategorien und Einträge

Unklassifiziert2 Eintrag/Einträge · Zweck oder Erforderlichkeit aus dem technischen Scan nicht sicher bestimmbar.barrierefreiFontSizeUnklassifiziert · unklar, prüfen · Anbieter Eigene Website oder eingebundener Dienst · Laufzeit dauerhaft bis Löschung durch Nutzer/Browser · vor Consent geseheneaIntroUnklassifiziert · unklar, prüfen · Anbieter Eigene Website oder eingebundener Dienst · Laufzeit Sitzung/Tab · vor Consent gesehen

Barrierefreiheit & Usability

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

22 Bild(er), 0 Formularfeld(er), 5 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft. Score: 68
3 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 alt4Felder ohne Label0Buttons ohne Namen1HTML langjaH10Viewportja

WCAG/EAA-Prüfpunkte

Alternativtexte für BilderWCAG 1.1.1 Non-text Content · prüfen · Impact mittel · 4 von 22 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 0 Formularfeld(er) ohne erkennbare Beschriftung.Buttons mit Namen versehenWCAG 4.1.2 Name, Role, Value · prüfen · Impact hoch · 1 von 5 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 · prüfen · Impact mittel · 0 H1 und 0 Ü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 sind ausgelagert.

Betreiber-Guide Barrierefreiheit öffnen

Signale und Link

Barrierefreiheits-Guide öffnen3 bekannte Issue-Signal(e) aus dem Scan.Alternativtexte für BilderWCAG 1.1.1 Non-text Content · Impact mittel · 4 von 22 Bild(er) ohne alt-Text im HTML-Sample.Buttons mit Namen versehenWCAG 4.1.2 Name, Role, Value · Impact hoch · 1 von 5 Button(s) ohne erkennbaren Namen.ÜberschriftenstrukturWCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels · Impact mittel · 0 H1 und 0 Überschrift(en) im HTML-Sample.

DSGVO, Cookies & Tracking

Welche Datenschutz-Signale fallen auf?

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

Tracking

Keine bekannten Tracking-Scripts erkannt.

Cookies

Keine Set-Cookie-Header erkannt.

Seiteninhalt & Keywords

Worum geht es auf der Seite?

Startseite: Landeszahnärztekammer BW Leichte Sprache
Keine Meta-Beschreibung erkannt.

patienten21info21zahn9sprache8kammer6landeszahnärztekammer4leichte4zahnarzt4

Technologie-Erkennung

Womit wurde die Seite gebaut?

Server: nginx/1.14.2 · Powered-by: nicht erkannt · Generator: TYPO3 CMS

MatomoAnalyticsTYPO3CMSnginxServer

CVE & Versionsrisiko

Gibt es Hinweise auf bekannte Schwachstellen?

Advisory-Treffer gefunden. Erkannte Versionen: 1 · Advisory-Treffer: 22 · Versionsregeln: 1

CVE-2018-16845nginx 1.14.2CVE-2019-9511nginx 1.14.2CVE-2021-23017nginx 1.14.2CVE-2022-41741nginx 1.14.2CVE-2022-41742nginx 1.14.2CVE-2025-23419nginx 1.14.2nginx-Version wirkt alt fuer einen oeffentlichen Webservernginx 1.14.2

Impressum & Betreibertransparenz

Sind rechtliche Hinweise erkennbar?

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

Cookie-Hinweis ohne klare Ablehnen-OptionwarningConsent wirkt wie Nur-Akzeptierenwarning

Performance / PageSpeed-Basis

Wirkt die Seite schnell und mobil nutzbar?

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

Viele potenziell blockierende Assetsinfo

Infrastruktur & TLS-Vertrauen

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

IPs: 1 · IPv6: nein · Zertifikat: 153 Tage · HSTS: nein · MX/SPF/DMARC: nein/nein/nein

CAA-Record fehltinfo

Security-Header

Welche Browser-Schutzheader sind gesetzt?

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

Betreiber-Guide Security-Header öffnen

Header-Evidence

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

Security-Header-Guide-Link

Security-Header-Guide öffnen0 vorhanden, 9 fehlen, 0 prüfen.

CSP-Qualität

Keine Content-Security-Policy gefunden.

Skript-Lieferkette

Externe Skript-Lieferkette aus dem gespeicherten Scan

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

Betreiber-Guide externe Skripte öffnen

Skriptquellen

cdn.eye-able.comSonstige · cdn.eye-able.com · SRI fehltcdn.eye-able.comSonstige · cdn.eye-able.com · SRI fehlttranslate-cdn.eye-able.comSonstige · translate-cdn.eye-able.com · SRI fehltoss.maxcdn.comSonstige · oss.maxcdn.com · SRI fehltoss.maxcdn.comSonstige · oss.maxcdn.com · SRI fehlt

Zusammenhänge & Servernetzwerk

Verbindungs- und Servernetz-Signale aus dem Scan

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

Signale

lzk-bw.de82.165.64.234lzk-bw.de2 Link(s)lzk-bw.de1 Link(s)

Servernetz

82.165.64.234IPv482.165.64.0/24sichtbares Netz

SEO, Verhalten & Cloaking

Gibt es manipulative Signale?

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

Keine klaren SEO-, Verhaltens- oder Cloaking-Auffälligkeiten erkannt.

Alle Hinweise

CVE-2018-16845: Memory disclosure in the ngx_http_mp4_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2019-9511: Excessive CPU usage in HTTP/2 with small window updates Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2021-23017: 1-byte memory overwrite in resolver Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2022-41741: Memory corruption in the ngx_http_mp4_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2022-41742: Memory disclosure in the ngx_http_mp4_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2025-23419: SSL session reuse vulnerability Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-1642: SSL upstream injection Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-27654: Buffer overflow in ngx_http_dav_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-27784: Buffer overflow in the ngx_http_mp4_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-28753: Injection in auth_http and XCLIENT Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-32647: Buffer overflow in the ngx_http_mp4_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-42945: Buffer overflow in the ngx_http_rewrite_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-42946: Buffer overread in the ngx_http_scgi_module and ngx_http_uwsgi_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-9256: Buffer overflow in the ngx_http_rewrite_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2018-16843: Excessive memory usage in HTTP/2 Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2018-16844: Excessive CPU usage in HTTP/2 Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2019-9513: Excessive CPU usage in HTTP/2 with priority changes Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2019-9516: Excessive memory usage in HTTP/2 with zero length headers Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2024-7347: Buffer overread in the ngx_http_mp4_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2025-53859: Buffer overread in the ngx_mail_smtp_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-27651: NULL pointer dereference while using CRAM-MD5 or APOP Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
CVE-2026-42934: Buffer overread in the ngx_http_charset_module Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Cookie-Hinweis ohne klare Ablehnen-Option Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Consent wirkt wie Nur-Akzeptieren Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Datenschutzerklärung deckt zentrale Bausteine nicht vollständig ab Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Viele Tastatur-/Eingabe-Listener im Browser erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
nginx-Version wirkt alt fuer einen oeffentlichen Webserver Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Stand der Datenschutzerklärung nicht klar erkennbar Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Datenschutzkontakt oder DPO-Hinweis nicht klar erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Buttons ohne erkennbaren Namen Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Externe Skripte ohne Subresource Integrity Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Meta-Description fehlt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence.
Bilder ohne Alternativtext Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Keine Überschriftenstruktur erkannt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Viele potenziell blockierende Assets Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Content-Security-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
X-Frame-Options fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
X-Content-Type-Options fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Cross-Origin-Embedder-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Cross-Origin-Opener-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Cross-Origin-Resource-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Referrer-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Permissions-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Anbieter-Jurisdiktion nicht klar ableitbar Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
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-/Guide-Links. Betreiber-Guides, Planungen, Checklisten, Code und allgemeine Empfehlungen sind ausgelagert.",
    "host": "leichtesprache.lzk-bw.de",
    "normalized_url": "https://leichtesprache.lzk-bw.de/",
    "score": 0,
    "verdict": {
        "color": "red",
        "label": "riskant",
        "score": 0
    },
    "scan_id": "aee1739b-1128-4335-a4bd-1dbcd4402a4c",
    "created_at": "2026-06-12 13:40:29.128337+02",
    "evidence": {
        "dns": {
            "ok": true,
            "addresses": [
                "82.165.64.234"
            ],
            "duration_ms": 14
        },
        "tls": {
            "ok": true,
            "cipher": "ECDHE-RSA-AES256-GCM-SHA384",
            "issuer": [
                [
                    [
                        "countryName",
                        "GB"
                    ]
                ],
                [
                    [
                        "organizationName",
                        "Sectigo Limited"
                    ]
                ],
                [
                    [
                        "commonName",
                        "Sectigo Public Server Authentication CA DV R36"
                    ]
                ]
            ],
            "subject": [
                [
                    [
                        "commonName",
                        "*.lzk-bw.de"
                    ]
                ]
            ],
            "version": "TLSv1.2",
            "not_after": "Nov 12 23:59:59 2026 GMT",
            "hostname_matches": true,
            "days_until_expiry": 153,
            "subject_alt_names": [
                "*.lzk-bw.de",
                "lzk-bw.de"
            ],
            "issuer_common_name": "Sectigo Public Server Authentication CA DV R36"
        },
        "http": {
            "ok": true,
            "status": 200,
            "headers": {
                "date": "Fri, 12 Jun 2026 11:40:20 GMT",
                "server": "nginx/1.14.2",
                "expires": "Fri, 12 Jun 2026 11:40:19 GMT",
                "connection": "close",
                "content-type": "text/html; charset=utf-8",
                "cache-control": "no-cache",
                "content-language": "de",
                "transfer-encoding": "chunked"
            },
            "body_size": 29406,
            "final_url": "https://leichtesprache.lzk-bw.de/",
            "duration_ms": 108
        },
        "scanner": {
            "bot_url": "https://saferpage.de/bot",
            "context": "crawler",
            "user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests)",
            "default_user_agent": "SaferPageBot/0.2 (+https://saferpage.de/bot; passive website safety check; no attack tests)"
        },
        "domain_records": {
            "mx": false,
            "caa": false,
            "spf": false,
            "dmarc": false,
            "dnssec": false
        },
        "googlebot_http": {
            "ok": true,
            "status": 200,
            "headers": {
                "date": "Fri, 12 Jun 2026 11:40:20 GMT",
                "server": "nginx/1.14.2",
                "expires": "Fri, 12 Jun 2026 11:40:19 GMT",
                "connection": "close",
                "content-type": "text/html; charset=utf-8",
                "cache-control": "no-cache",
                "content-language": "de",
                "transfer-encoding": "chunked"
            },
            "body_size": 29406,
            "final_url": "https://leichtesprache.lzk-bw.de/",
            "duration_ms": 101
        },
        "ai_search_policy_evidence": {
            "files": [
                {
                    "id": "robots_txt",
                    "url": "https://leichtesprache.lzk-bw.de/robots.txt",
                    "label": "robots.txt",
                    "reason": "",
                    "status": "found",
                    "body_size": 107,
                    "truncated": false,
                    "body_sha256": "c2caadb7a66bd25dfda4317ace46990a008823ef984820bebc658d49a603354f",
                    "duration_ms": 66,
                    "http_status": 200,
                    "ai_bot_policy": {
                        "bot_directives": [],
                        "explicit_ai_bots": [],
                        "explicit_ai_bot_count": 0,
                        "wildcard_directive_count": 3,
                        "wildcard_directives_sample": [
                            {
                                "value": "/typo3/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/typo3_src/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/typo3/sysext/frontend/Resources/Public/*",
                                "directive": "allow"
                            }
                        ]
                    },
                    "relevant_lines": [
                        "User-agent: *",
                        "Disallow: /typo3/",
                        "Disallow: /typo3_src/",
                        "Allow: /typo3/sysext/frontend/Resources/Public/*"
                    ]
                },
                {
                    "id": "llms_txt",
                    "url": "https://leichtesprache.lzk-bw.de/llms.txt",
                    "label": "llms.txt",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 103,
                    "http_status": 404,
                    "relevant_lines": []
                },
                {
                    "id": "ai_txt",
                    "url": "https://leichtesprache.lzk-bw.de/.well-known/ai.txt",
                    "label": "AI Policy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 99,
                    "http_status": 404,
                    "relevant_lines": []
                },
                {
                    "id": "ai_policy_txt",
                    "url": "https://leichtesprache.lzk-bw.de/.well-known/ai-policy.txt",
                    "label": "AI Policy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 109,
                    "http_status": 404,
                    "relevant_lines": []
                },
                {
                    "id": "ward_txt",
                    "url": "https://leichtesprache.lzk-bw.de/.well-known/ward.txt",
                    "label": "WARD Policy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 116,
                    "http_status": 404,
                    "relevant_lines": []
                }
            ],
            "origin": "https://leichtesprache.lzk-bw.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"
        }
    },
    "findings": [
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2018-16845: Memory disclosure in the ngx_http_mp4_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2018-16845",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2019-9511: Excessive CPU usage in HTTP/2 with small window updates",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2019-9511",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2021-23017: 1-byte memory overwrite in resolver",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2021-23017",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2022-41741: Memory corruption in the ngx_http_mp4_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2022-41741",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2022-41742: Memory disclosure in the ngx_http_mp4_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2022-41742",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2025-23419: SSL session reuse vulnerability",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2025-23419",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-1642: SSL upstream injection",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-1642",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-27654: Buffer overflow in ngx_http_dav_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-27654",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-27784: Buffer overflow in the ngx_http_mp4_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-27784",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-28753: Injection in auth_http and XCLIENT",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-28753",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-32647: Buffer overflow in the ngx_http_mp4_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-32647",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-42945: Buffer overflow in the ngx_http_rewrite_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-42945",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-42946: Buffer overread in the ngx_http_scgi_module and ngx_http_uwsgi_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-42946",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-9256: Buffer overflow in the ngx_http_rewrite_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-9256",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2018-16843: Excessive memory usage in HTTP/2",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2018-16843",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2018-16844: Excessive CPU usage in HTTP/2",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2018-16844",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2019-9513: Excessive CPU usage in HTTP/2 with priority changes",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2019-9513",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2019-9516: Excessive memory usage in HTTP/2 with zero length headers",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2019-9516",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2024-7347: Buffer overread in the ngx_http_mp4_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2024-7347",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2025-53859: Buffer overread in the ngx_mail_smtp_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2025-53859",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-27651: NULL pointer dereference while using CRAM-MD5 or APOP",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-27651",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "known_vulnerability_advisory",
            "title": "CVE-2026-42934: Buffer overread in the ngx_http_charset_module",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "info",
            "confirmed": true,
            "technology": "nginx",
            "advisory_id": "CVE-2026-42934",
            "user_importance": 135,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "consent_no_reject_option",
            "title": "Cookie-Hinweis ohne klare Ablehnen-Option",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 121,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "consent_accept_only",
            "title": "Consent wirkt wie Nur-Akzeptieren",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 120,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "privacy_policy_required_items_missing",
            "title": "Datenschutzerklärung deckt zentrale Bausteine nicht vollständig ab",
            "public": true,
            "missing": [
                "Verantwortlicher / Anbieter",
                "Zwecke der Verarbeitung",
                "Rechtsgrundlagen",
                "Empfänger / Auftragsverarbeiter",
                "Beschwerde bei Aufsichtsbehörde",
                "Drittlandtransfer",
                "Stand / Aktualitätsdatum",
                "Datenschutzkontakt / DPO-Hinweis"
            ],
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 112,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "browser_keystroke_listener_signals",
            "count": 14,
            "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": "stale_technology_version",
            "title": "nginx-Version wirkt alt fuer einen oeffentlichen Webserver",
            "public": true,
            "version": "1.14.2",
            "audience": "nutzer",
            "category": "vulnerability",
            "severity": "warning",
            "confirmed": true,
            "policy_id": "NGINX-LEGACY-BRANCH",
            "technology": "nginx",
            "user_importance": 94,
            "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": 1,
            "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": 5,
            "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": "missing_meta_description",
            "title": "Meta-Description fehlt",
            "public": true,
            "audience": "nutzer",
            "category": "content",
            "severity": "info",
            "user_importance": 84,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "image_alt_missing",
            "count": 4,
            "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": "heading_structure_missing",
            "title": "Keine Überschriftenstruktur erkannt",
            "public": true,
            "audience": "betreiber",
            "category": "accessibility",
            "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_x_frame_options",
            "title": "X-Frame-Options fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "warning",
            "user_importance": 70,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "missing_x_content_type_options",
            "title": "X-Content-Type-Options fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "warning",
            "user_importance": 70,
            "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_opener_policy",
            "title": "Cross-Origin-Opener-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 66,
            "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": "missing_referrer_policy",
            "title": "Referrer-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 40,
            "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"
        },
        {
            "id": "unknown_vendor_jurisdiction",
            "title": "Anbieter-Jurisdiktion nicht klar ableitbar",
            "public": true,
            "audience": "betreiber",
            "category": "privacy",
            "severity": "info",
            "user_importance": 30,
            "importance_label": "Technischer Hinweis"
        }
    ],
    "audit_modules": [
        {
            "id": "security_tls",
            "color": "red",
            "score": 34,
            "title": "Sicherheit, TLS & Header",
            "source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
            "status": "kritisch",
            "evidence": "1 Infrastruktur-Hinweis(e), Security-Header: 0/9 vorhanden, 9 fehlen, externe Skript-Hosts: 3."
        },
        {
            "id": "privacy_consent",
            "color": "orange",
            "score": 67,
            "title": "Datenschutz, Cookies & Consent",
            "source": "Browser, HTTP-Header, HTML und Consent-/Cookie-Heuristik",
            "status": "auffällig",
            "evidence": "0 Tracking-Script(s), 0 Cookie(s) vor Einwilligung, 0 Tracking-Cookie(s), Ablehnen-Option: nein, Consent-Audit: 68."
        },
        {
            "id": "accessibility_usability",
            "color": "orange",
            "score": 68,
            "title": "Barrierefreiheit & Usability",
            "source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
            "status": "auffällig",
            "evidence": "4 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 1 Button(s) ohne Namen."
        },
        {
            "id": "script_supply_chain",
            "color": "orange",
            "score": 74,
            "title": "Externe Skripte & SRI",
            "source": "HTML-Script-Tags, Anbieterklassifikation und SRI-Attribute",
            "status": "auffällig",
            "evidence": "5 externe Skript(e) von 3 Host(s), 5 ohne SRI, 0 Tracking-/Tag-nahe Skript(e)."
        },
        {
            "id": "browser_evidence",
            "color": "yellow",
            "score": 79,
            "title": "Browser-Nachweis",
            "source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
            "status": "prüfen",
            "evidence": "39 Request(s), 3 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 0 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 0, Fingerprinting-/Replay-Hinweise: 1."
        },
        {
            "id": "site_coverage",
            "color": "yellow",
            "score": 86,
            "title": "Seitenabdeckung & Crawl",
            "source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
            "status": "prüfen",
            "evidence": "18 interne Linkziele erkannt, 4 priorisierte Unterseite(n) abgerufen."
        },
        {
            "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 108 ms."
        },
        {
            "id": "consent_journey",
            "color": "green",
            "score": 100,
            "title": "Consent-Journey-Matrix",
            "source": "Chromium-Zustände: Erstaufruf, Reject, Accept und GPC",
            "status": "unauffällig",
            "evidence": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 0 im GPC-Aufruf."
        },
        {
            "id": "cookie_inventory",
            "color": "green",
            "score": 100,
            "title": "Cookie-Inventar",
            "source": "HTTP-Set-Cookie und Chromium-Cookies beim ersten Seitenaufruf",
            "status": "unauffällig",
            "evidence": "0 Cookie(s), 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebig, 0 sehr lang."
        },
        {
            "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": "forms_payments",
            "color": "green",
            "score": 100,
            "title": "Formulare, Login & Zahlung",
            "source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
            "status": "unauffällig",
            "evidence": "Keine Formular- oder Zahlungsabfrage im passiven Startseiten-Sample erkannt."
        },
        {
            "id": "google_third_parties",
            "color": "green",
            "score": 100,
            "title": "Google-Dienste & Drittanbieter",
            "source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
            "status": "unauffällig",
            "evidence": "Keine Google-Domain, keine Google-Tracking-ID und keine datenschutzrelevanten Drittanbieter im passiven Check erkannt."
        },
        {
            "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."
        },
        {
            "id": "pii_exposure",
            "color": "green",
            "score": 100,
            "title": "PII, URL-Parameter & Datenleck-Schutz",
            "source": "URL-Parameter, interne Links, HTML-Formulare, Browser-Drittanbieter und Dateneingabe-Kontext",
            "status": "unauffällig",
            "evidence": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext."
        },
        {
            "id": "referrer_url_leaks",
            "color": "green",
            "score": 100,
            "title": "Referrer & URL-Leaks",
            "source": "Chromium-Request-Telemetrie ohne gespeicherte Parameterwerte",
            "status": "unauffällig",
            "evidence": "0 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte."
        },
        {
            "id": "seo_integrity",
            "color": "green",
            "score": 100,
            "title": "SEO-Integrität & Cloaking",
            "source": "HTML-Inhalt, strukturierte Daten, Links und Googlebot-Vergleich",
            "status": "unauffällig",
            "evidence": "0 SEO-Spam-Hinweis(e), 0 Cloaking-Hinweis(e)."
        },
        {
            "id": "tracking_pixels_beacons",
            "color": "green",
            "score": 100,
            "title": "Tracking-Pixel & Beacons",
            "source": "HTML-Pixel, Link-Ping-Attribute, Chromium-Requests und Browser-API-Instrumentierung",
            "status": "unauffällig",
            "evidence": "0 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s)."
        }
    ],
    "ai_search_policy_evidence": {
        "files": [
            {
                "id": "robots_txt",
                "url": "https://leichtesprache.lzk-bw.de/robots.txt",
                "label": "robots.txt",
                "reason": "",
                "status": "found",
                "body_size": 107,
                "truncated": false,
                "body_sha256": "c2caadb7a66bd25dfda4317ace46990a008823ef984820bebc658d49a603354f",
                "duration_ms": 66,
                "http_status": 200,
                "ai_bot_policy": {
                    "bot_directives": [],
                    "explicit_ai_bots": [],
                    "explicit_ai_bot_count": 0,
                    "wildcard_directive_count": 3,
                    "wildcard_directives_sample": [
                        {
                            "value": "/typo3/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/typo3_src/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/typo3/sysext/frontend/Resources/Public/*",
                            "directive": "allow"
                        }
                    ]
                },
                "relevant_lines": [
                    "User-agent: *",
                    "Disallow: /typo3/",
                    "Disallow: /typo3_src/",
                    "Allow: /typo3/sysext/frontend/Resources/Public/*"
                ]
            },
            {
                "id": "llms_txt",
                "url": "https://leichtesprache.lzk-bw.de/llms.txt",
                "label": "llms.txt",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 103,
                "http_status": 404,
                "relevant_lines": []
            },
            {
                "id": "ai_txt",
                "url": "https://leichtesprache.lzk-bw.de/.well-known/ai.txt",
                "label": "AI Policy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 99,
                "http_status": 404,
                "relevant_lines": []
            },
            {
                "id": "ai_policy_txt",
                "url": "https://leichtesprache.lzk-bw.de/.well-known/ai-policy.txt",
                "label": "AI Policy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 109,
                "http_status": 404,
                "relevant_lines": []
            },
            {
                "id": "ward_txt",
                "url": "https://leichtesprache.lzk-bw.de/.well-known/ward.txt",
                "label": "WARD Policy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 116,
                "http_status": 404,
                "relevant_lines": []
            }
        ],
        "origin": "https://leichtesprache.lzk-bw.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"
    },
    "site_coverage_analysis": {
        "color": "yellow",
        "pages": [
            {
                "url": "https://leichtesprache.lzk-bw.de/wie-sieht-unser-datenschutz-aus",
                "path": "/wie-sieht-unser-datenschutz-aus",
                "text": "Wie sieht unser Datenschutz aus?",
                "source": "homepage_link",
                "category": "datenschutz",
                "priority": 100
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/impressum",
                "path": "/impressum",
                "text": "Impressum",
                "source": "homepage_link",
                "category": "impressum",
                "priority": 96
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/an-welche-gesetze-muessen-sich-zahnaerzte-halten",
                "path": "/an-welche-gesetze-muessen-sich-zahnaerzte-halten",
                "text": "An welche Gesetze müssen sich Zahnärzte halten?",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/der-gesunde-zahn",
                "path": "/der-gesunde-zahn",
                "text": "Patienten·info: Der gesunde Zahn",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patienteninfo-der-kranke-zahn",
                "path": "/patienteninfo-der-kranke-zahn",
                "text": "Patienten·info: Der kranke Zahn",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patienteninfo-die-behandlung",
                "path": "/patienteninfo-die-behandlung",
                "text": "Patienten·info: Die Behandlung",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patienteninfo-die-untersuchung",
                "path": "/patienteninfo-die-untersuchung",
                "text": "Patienten·info: Die Untersuchung",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patienteninfo-und-wenn-ich-angst-habe",
                "path": "/patienteninfo-und-wenn-ich-angst-habe",
                "text": "Patienten·info: Und wenn ich Angst habe?",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patienteninfo-was-ist-zahnersatz",
                "path": "/patienteninfo-was-ist-zahnersatz",
                "text": "Patienten·info: Was ist Zahn·ersatz?",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patienteninfo-wie-bleiben-die-zaehne-gesund",
                "path": "/patienteninfo-wie-bleiben-die-zaehne-gesund",
                "text": "Patienten·info: Wie bleiben die Zähne gesund?",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/patientenmagazin-patient-aktuell",
                "path": "/patientenmagazin-patient-aktuell",
                "text": "Patientenmagazin „Patient aktuell“",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://leichtesprache.lzk-bw.de/was-ist-ein-zahnaerztliches-gutachten",
                "path": "/was-ist-ein-zahnaerztliches-gutachten",
                "text": "Was ist ein zahnärztliches Gutachten?",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            }
        ],
        "score": 86,
        "status": "prüfen",
        "summary": "18 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen.",
        "findings": [
            {
                "id": "privacy_policy_required_items_missing",
                "title": "Datenschutzerklärung deckt zentrale Bausteine nicht vollständig ab",
                "public": true,
                "missing": [
                    "Verantwortlicher / Anbieter",
                    "Zwecke der Verarbeitung",
                    "Rechtsgrundlagen",
                    "Empfänger / Auftragsverarbeiter",
                    "Beschwerde bei Aufsichtsbehörde",
                    "Drittlandtransfer",
                    "Stand / Aktualitätsdatum",
                    "Datenschutzkontakt / DPO-Hinweis"
                ],
                "category": "privacy",
                "severity": "warning"
            },
            {
                "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"
            }
        ],
        "categories": {
            "impressum": 1,
            "unterseite": 16,
            "datenschutz": 1
        },
        "sample_limit": 4,
        "sampled_count": 4,
        "sampled_pages": [
            {
                "ok": true,
                "url": "https://leichtesprache.lzk-bw.de/wie-sieht-unser-datenschutz-aus",
                "path": "/wie-sieht-unser-datenschutz-aus",
                "audit": {
                    "form_count": 0,
                    "finding_ids": [
                        "consent_no_reject_option",
                        "consent_accept_only"
                    ],
                    "cookie_count": 0,
                    "imprint_found": true,
                    "consent_hint_found": true,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 0,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 0,
                "title": "Wie sieht unser Datenschutz aus?: Landeszahnärztekammer BW Leichte Sprache",
                "status": 200,
                "category": "datenschutz",
                "duration_ms": 77,
                "privacy_hint": true,
                "privacy_policy_audit": {
                    "url": "https://leichtesprache.lzk-bw.de/wie-sieht-unser-datenschutz-aus",
                    "color": "red",
                    "found": [
                        "Kontakt / Datenschutzkontakt",
                        "Betroffenenrechte",
                        "Speicherfrist / Löschung",
                        "Cookies / Tracking",
                        "Widerruf / Opt-out",
                        "Verständliche Satzlänge"
                    ],
                    "score": 43,
                    "checks": [
                        {
                            "id": "controller_identity",
                            "found": false,
                            "label": "Verantwortlicher / Anbieter"
                        },
                        {
                            "id": "contact",
                            "found": true,
                            "label": "Kontakt / Datenschutzkontakt"
                        },
                        {
                            "id": "purposes",
                            "found": false,
                            "label": "Zwecke der Verarbeitung"
                        },
                        {
                            "id": "legal_basis",
                            "found": false,
                            "label": "Rechtsgrundlagen"
                        },
                        {
                            "id": "rights",
                            "found": true,
                            "label": "Betroffenenrechte"
                        },
                        {
                            "id": "retention",
                            "found": true,
                            "label": "Speicherfrist / Löschung"
                        },
                        {
                            "id": "recipients",
                            "found": false,
                            "label": "Empfänger / Auftragsverarbeiter"
                        },
                        {
                            "id": "cookies_tracking",
                            "found": true,
                            "label": "Cookies / Tracking"
                        },
                        {
                            "id": "withdrawal",
                            "found": true,
                            "label": "Widerruf / Opt-out"
                        },
                        {
                            "id": "complaint_authority",
                            "found": false,
                            "label": "Beschwerde bei Aufsichtsbehörde"
                        },
                        {
                            "id": "third_country_transfer",
                            "found": false,
                            "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": "8.9 Wörter/Satz"
                        }
                    ],
                    "status": "kritisch",
                    "missing": [
                        "Verantwortlicher / Anbieter",
                        "Zwecke der Verarbeitung",
                        "Rechtsgrundlagen",
                        "Empfänger / Auftragsverarbeiter",
                        "Beschwerde bei Aufsichtsbehörde",
                        "Drittlandtransfer",
                        "Stand / Aktualitätsdatum",
                        "Datenschutzkontakt / DPO-Hinweis"
                    ],
                    "summary": "6 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": 707,
                    "readability": {
                        "hard_to_read": false,
                        "sentence_count": 79,
                        "avg_sentence_words": 8.9
                    },
                    "missing_count": 8,
                    "dpo_contact_found": false
                }
            },
            {
                "ok": true,
                "url": "https://leichtesprache.lzk-bw.de/impressum",
                "path": "/impressum",
                "audit": {
                    "form_count": 0,
                    "finding_ids": [
                        "privacy_policy_too_thin"
                    ],
                    "cookie_count": 0,
                    "imprint_found": true,
                    "consent_hint_found": false,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 0,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 0,
                "title": "Impressum: Landeszahnärztekammer BW Leichte Sprache",
                "status": 200,
                "category": "impressum",
                "duration_ms": 86,
                "privacy_hint": true,
                "privacy_policy_audit": []
            },
            {
                "ok": true,
                "url": "https://leichtesprache.lzk-bw.de/an-welche-gesetze-muessen-sich-zahnaerzte-halten",
                "path": "/an-welche-gesetze-muessen-sich-zahnaerzte-halten",
                "audit": {
                    "form_count": 0,
                    "finding_ids": [
                        "operator_identity_unclear",
                        "privacy_policy_too_thin"
                    ],
                    "cookie_count": 0,
                    "imprint_found": true,
                    "consent_hint_found": false,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 0,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 0,
                "title": "Aus diesem Rohfeld wird im Testresult keine zusätzliche Scan-Feststellung abgeleitet; Betreiberkontext und Umsetzungshinweise sind ausgelagert.",
                "status": 200,
                "category": "unterseite",
                "duration_ms": 183,
                "privacy_hint": true,
                "privacy_policy_audit": []
            },
            {
                "ok": true,
                "url": "https://leichtesprache.lzk-bw.de/der-gesunde-zahn",
                "path": "/der-gesunde-zahn",
                "audit": {
                    "form_count": 0,
                    "finding_ids": [
                        "operator_identity_unclear",
                        "privacy_policy_too_thin"
                    ],
                    "cookie_count": 0,
                    "imprint_found": true,
                    "consent_hint_found": false,
                    "reject_option_found": false,
                    "privacy_policy_found": true,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 0,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 0,
                "title": "Patienten·info: Der gesunde Zahn: Landeszahnärztekammer BW Leichte Sprache",
                "status": 200,
                "category": "unterseite",
                "duration_ms": 215,
                "privacy_hint": true,
                "privacy_policy_audit": []
            }
        ],
        "sitemap_sources": [],
        "sitemap_available": false,
        "sitemap_url_count": 0,
        "homepage_link_count": 55,
        "internal_link_count": 18,
        "privacy_policy_audit": {
            "url": "https://leichtesprache.lzk-bw.de/wie-sieht-unser-datenschutz-aus",
            "color": "red",
            "found": [
                "Kontakt / Datenschutzkontakt",
                "Betroffenenrechte",
                "Speicherfrist / Löschung",
                "Cookies / Tracking",
                "Widerruf / Opt-out",
                "Verständliche Satzlänge"
            ],
            "score": 43,
            "checks": [
                {
                    "id": "controller_identity",
                    "found": false,
                    "label": "Verantwortlicher / Anbieter"
                },
                {
                    "id": "contact",
                    "found": true,
                    "label": "Kontakt / Datenschutzkontakt"
                },
                {
                    "id": "purposes",
                    "found": false,
                    "label": "Zwecke der Verarbeitung"
                },
                {
                    "id": "legal_basis",
                    "found": false,
                    "label": "Rechtsgrundlagen"
                },
                {
                    "id": "rights",
                    "found": true,
                    "label": "Betroffenenrechte"
                },
                {
                    "id": "retention",
                    "found": true,
                    "label": "Speicherfrist / Löschung"
                },
                {
                    "id": "recipients",
                    "found": false,
                    "label": "Empfänger / Auftragsverarbeiter"
                },
                {
                    "id": "cookies_tracking",
                    "found": true,
                    "label": "Cookies / Tracking"
                },
                {
                    "id": "withdrawal",
                    "found": true,
                    "label": "Widerruf / Opt-out"
                },
                {
                    "id": "complaint_authority",
                    "found": false,
                    "label": "Beschwerde bei Aufsichtsbehörde"
                },
                {
                    "id": "third_country_transfer",
                    "found": false,
                    "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": "8.9 Wörter/Satz"
                }
            ],
            "status": "kritisch",
            "missing": [
                "Verantwortlicher / Anbieter",
                "Zwecke der Verarbeitung",
                "Rechtsgrundlagen",
                "Empfänger / Auftragsverarbeiter",
                "Beschwerde bei Aufsichtsbehörde",
                "Drittlandtransfer",
                "Stand / Aktualitätsdatum",
                "Datenschutzkontakt / DPO-Hinweis"
            ],
            "summary": "6 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": 707,
            "readability": {
                "hard_to_read": false,
                "sentence_count": 79,
                "avg_sentence_words": 8.9
            },
            "missing_count": 8,
            "dpo_contact_found": false
        },
        "sitemap_source_count": 0,
        "provider_disclosure_audit": {
            "found": [],
            "checks": [],
            "reason": "no_detected_services",
            "missing": [],
            "available": false
        },
        "important_categories_found": [
            "datenschutz",
            "impressum"
        ],
        "sampled_tracking_page_count": 0,
        "sampled_form_privacy_gap_count": 0
    },
    "page_analysis": {
        "h1": [],
        "h2": [],
        "title": "Startseite: Landeszahnärztekammer BW Leichte Sprache",
        "keywords": [
            [
                "patienten",
                21
            ],
            [
                "info",
                21
            ],
            [
                "zahn",
                9
            ],
            [
                "sprache",
                8
            ],
            [
                "kammer",
                6
            ],
            [
                "landeszahnärztekammer",
                4
            ],
            [
                "leichte",
                4
            ],
            [
                "zahnarzt",
                4
            ],
            [
                "landes-zahnärzte-kammer",
                4
            ],
            [
                "leichter",
                4
            ]
        ],
        "language": "de-de",
        "description": "",
        "favicon_url": "https://leichtesprache.lzk-bw.de/fileadmin/images/logos/logo.png",
        "link_counts": {
            "external": 1,
            "internal": 54
        },
        "preview_image": "/cache/screenshots/leichtesprache.lzk-bw.de-160x150-a8f21ab7aef1ff8659.png",
        "screenshot_url": "/cache/screenshots/leichtesprache.lzk-bw.de-160x150-a8f21ab7aef1ff8659.png",
        "external_scripts": [
            "https://cdn.eye-able.com/configs/leichtesprache.lzk-bw.de.js",
            "https://cdn.eye-able.com/public/js/eyeAble.js",
            "https://translate-cdn.eye-able.com/eye-able-translate.js",
            "https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js",
            "https://oss.maxcdn.com/respond/1.4.2/respond.min.js"
        ],
        "browser_final_url": "https://leichtesprache.lzk-bw.de/",
        "meta_preview_image": "",
        "screenshot_renderer": "playwright-chromium",
        "external_link_targets": [
            {
                "host": "lzk-bw.de",
                "count": 1,
                "examples": [
                    {
                        "href": "https://lzk-bw.de/",
                        "text": "Zur schweren Sprache wechseln"
                    }
                ],
                "nofollow": 0,
                "strength": "strong",
                "follow_count": 1
            }
        ]
    },
    "browser_analysis": {
        "cookies": {
            "items": [],
            "total": 0,
            "third_party": 0
        },
        "storage": {
            "total": 2,
            "local_storage_keys": [
                "barrierefreiFontSize"
            ],
            "tracking_key_hints": [],
            "local_storage_total": 1,
            "session_storage_keys": [
                "eaIntro"
            ],
            "session_storage_total": 1
        },
        "findings": [
            {
                "id": "unknown_vendor_jurisdiction",
                "title": "Anbieter-Jurisdiktion nicht klar ableitbar",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "browser_keystroke_listener_signals",
                "count": 14,
                "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
                "public": true,
                "category": "privacy",
                "severity": "info"
            }
        ],
        "renderer": "playwright-chromium",
        "final_url": "https://leichtesprache.lzk-bw.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": 26,
            "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": 0,
            "request_count": 38,
            "sec_gpc_header": true,
            "navigator_value": true,
            "contacted_domains": [
                {
                    "host": "leichtesprache.lzk-bw.de",
                    "count": 29,
                    "category": "other",
                    "provider": "leichtesprache.lzk-bw.de",
                    "third_party": false,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "font": 1,
                        "image": 23,
                        "script": 2,
                        "document": 1,
                        "stylesheet": 2
                    }
                },
                {
                    "host": "cdn.eye-able.com",
                    "count": 5,
                    "category": "other",
                    "provider": "cdn.eye-able.com",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "image": 2,
                        "script": 2,
                        "stylesheet": 1
                    }
                },
                {
                    "host": "translate-cdn.eye-able.com",
                    "count": 3,
                    "category": "other",
                    "provider": "translate-cdn.eye-able.com",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "fetch": 2,
                        "script": 1
                    }
                },
                {
                    "host": "lzkpiwi.lzk-bw.de",
                    "count": 1,
                    "category": "other",
                    "provider": "lzkpiwi.lzk-bw.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "script": 1
                    }
                }
            ],
            "contacted_domain_count": 4,
            "privacy_relevant_domains": [],
            "third_party_cookie_count": 0,
            "third_party_domain_count": 3,
            "privacy_relevant_domain_count": 0
        },
        "screenshot": {
            "fit": "contain",
            "width": 160,
            "height": 150,
            "source_width": 1024,
            "source_height": 960,
            "source_capture": "full_page",
            "capture_version": "contain-v3-fullpage-to-160x150"
        },
        "consent_apis": {
            "cmpapi": false,
            "tcfapi": false,
            "onetrust": false,
            "cookiebot": false,
            "data_layer": false,
            "cmp_detected": false,
            "usercentrics": false,
            "google_tag_data": false
        },
        "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": 39,
        "top_providers": [
            {
                "provider": "cdn.eye-able.com",
                "request_count": 5
            },
            {
                "provider": "translate-cdn.eye-able.com",
                "request_count": 3
            },
            {
                "provider": "lzkpiwi.lzk-bw.de",
                "request_count": 1
            }
        ],
        "request_samples": [
            {
                "host": "cdn.eye-able.com",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 2,
                "query_keys": [],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 3,
                "query_keys": [],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "translate-cdn.eye-able.com",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 1,
                "query_keys": [],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "lzkpiwi.lzk-bw.de",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 1,
                "query_keys": [],
                "third_party": true,
                "resource_type": "script",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "translate-cdn.eye-able.com",
                "method": "HEAD",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 2,
                "query_keys": [],
                "third_party": true,
                "resource_type": "fetch",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "translate-cdn.eye-able.com",
                "method": "HEAD",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 2,
                "query_keys": [],
                "third_party": true,
                "resource_type": "fetch",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 3,
                "query_keys": [],
                "third_party": true,
                "resource_type": "stylesheet",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 3,
                "query_keys": [],
                "third_party": true,
                "resource_type": "image",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "method": "GET",
                "referrer": {
                    "host": "leichtesprache.lzk-bw.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": false,
                "path_depth": 3,
                "query_keys": [],
                "third_party": true,
                "resource_type": "image",
                "query_key_count": 0,
                "url_value_param_count": 0,
                "sensitive_query_key_count": 0,
                "target_url_value_param_count": 0
            }
        ],
        "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": "leichtesprache.lzk-bw.de",
                "count": 30,
                "category": "other",
                "provider": "leichtesprache.lzk-bw.de",
                "third_party": false,
                "category_label": "Sonstige",
                "resource_types": {
                    "font": 1,
                    "image": 24,
                    "script": 2,
                    "document": 1,
                    "stylesheet": 2
                }
            },
            {
                "host": "cdn.eye-able.com",
                "count": 5,
                "category": "other",
                "provider": "cdn.eye-able.com",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "image": 2,
                    "script": 2,
                    "stylesheet": 1
                }
            },
            {
                "host": "translate-cdn.eye-able.com",
                "count": 3,
                "category": "other",
                "provider": "translate-cdn.eye-able.com",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "fetch": 2,
                    "script": 1
                }
            },
            {
                "host": "lzkpiwi.lzk-bw.de",
                "count": 1,
                "category": "other",
                "provider": "lzkpiwi.lzk-bw.de",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "script": 1
                }
            }
        ],
        "privacy_api_metrics": {
            "api_calls": {
                "mutation_observer_count": 4,
                "keyboard_input_listener_count": 14
            },
            "beacon_count": 0,
            "webgl_read_count": 0,
            "canvas_read_count": 0,
            "audio_context_count": 0,
            "canvas_export_count": 0,
            "fetch_keepalive_count": 0,
            "webgl_parameter_count": 0,
            "mutation_observer_count": 4,
            "keyboard_input_listener_count": 14
        },
        "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
        },
        "consent_journey_matrix": {
            "color": "green",
            "items": [
                {
                    "host": "cdn.eye-able.com",
                    "states": {
                        "gpc": 5,
                        "default": 5
                    },
                    "category": "other",
                    "provider": "cdn.eye-able.com",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 10
                },
                {
                    "host": "translate-cdn.eye-able.com",
                    "states": {
                        "gpc": 3,
                        "default": 3
                    },
                    "category": "other",
                    "provider": "translate-cdn.eye-able.com",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 6
                },
                {
                    "host": "lzkpiwi.lzk-bw.de",
                    "states": {
                        "gpc": 1,
                        "default": 1
                    },
                    "category": "other",
                    "provider": "lzkpiwi.lzk-bw.de",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 2
                }
            ],
            "score": 100,
            "states": [
                {
                    "id": "default",
                    "label": "Erstaufruf",
                    "description": "Kontakte ohne Nutzeraktion",
                    "domain_count": 3,
                    "request_count": 9,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "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": 3,
                    "request_count": 9,
                    "privacy_relevant_domain_count": 0
                }
            ],
            "status": "unauffällig",
            "summary": "Consent-Journey: 0 neue Datenschutz-Domain(s) nach Ablehnen, 0 nach Akzeptieren, 0 im GPC-Aufruf.",
            "gpc_privacy_relevant_domain_count": 0,
            "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": "niedrig",
                    "cookie_count": 0,
                    "domain_count": 4,
                    "request_count": 39,
                    "storage_total": 2,
                    "new_cookie_count": 0,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "reject",
                    "label": "Nach Ablehnen",
                    "status": "nicht verfügbar",
                    "evidence": "",
                    "risk_level": "niedrig",
                    "cookie_count": 0,
                    "domain_count": 0,
                    "request_count": 0,
                    "storage_total": 2,
                    "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": "niedrig",
                    "cookie_count": 0,
                    "domain_count": 4,
                    "request_count": 38,
                    "storage_total": 1,
                    "new_cookie_count": 0,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 0
                }
            ],
            "color": "green",
            "score": 100,
            "status": "unauffällig",
            "summary": "Consent-State-Evidence: 4 Zustände verglichen, 0 hoch auffällig, 0 mittel auffällig.",
            "findings": [],
            "available": true,
            "high_count": 0,
            "medium_count": 0
        },
        "contacted_domain_count": 4,
        "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": 14,
                    "label": "Tastatur-/Eingabe-Listener",
                    "detail": "14 Tastatur-/Input-Listener, 70 Interaktions-Listener, 4 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": 4,
                "keyboard_input_listener_count": 14
            },
            "summary": "1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
            "findings": [
                {
                    "id": "browser_keystroke_listener_signals",
                    "count": 14,
                    "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                }
            ],
            "finding_count": 1,
            "session_replay_domains": []
        },
        "privacy_relevant_domains": [],
        "provider_category_counts": {
            "other": 3
        },
        "provider_category_labels": {
            "other": "other"
        },
        "third_party_domain_count": 3,
        "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": "green",
            "items": [],
            "score": 100,
            "status": "unauffällig",
            "summary": "0 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 0 sensible Query-Kontexte.",
            "findings": [],
            "sample_count": 9,
            "full_referrer_count": 0,
            "page_url_param_count": 0,
            "affected_domain_count": 0,
            "sensitive_query_count": 0
        },
        "third_party_contact_matrix": {
            "color": "green",
            "items": [
                {
                    "host": "cdn.eye-able.com",
                    "region": "unbekannt",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "cdn.eye-able.com",
                    "risk_level": "niedrig",
                    "request_count": 5,
                    "transfer_risk": "mittel",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "image",
                            "count": 2
                        },
                        {
                            "type": "script",
                            "count": 2
                        },
                        {
                            "type": "stylesheet",
                            "count": 1
                        }
                    ],
                    "transfer_label": "Jurisdiktion unklar",
                    "privacy_relevant": false
                },
                {
                    "host": "translate-cdn.eye-able.com",
                    "region": "unbekannt",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "translate-cdn.eye-able.com",
                    "risk_level": "niedrig",
                    "request_count": 3,
                    "transfer_risk": "mittel",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "fetch",
                            "count": 2
                        },
                        {
                            "type": "script",
                            "count": 1
                        }
                    ],
                    "transfer_label": "Jurisdiktion unklar",
                    "privacy_relevant": false
                },
                {
                    "host": "lzkpiwi.lzk-bw.de",
                    "region": "EU/EWR",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "lzkpiwi.lzk-bw.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
                }
            ],
            "score": 95,
            "status": "unauffällig",
            "summary": "3 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant.",
            "category_counts": {
                "Sonstige": 3
            },
            "total_domain_count": 3,
            "total_request_count": 9,
            "privacy_relevant_count": 0,
            "transfer_risk_analysis": {
                "color": "yellow",
                "items": [
                    {
                        "host": "cdn.eye-able.com",
                        "region": "unbekannt",
                        "provider": "cdn.eye-able.com",
                        "request_count": 5,
                        "transfer_risk": "mittel",
                        "category_label": "Sonstige",
                        "transfer_label": "Jurisdiktion unklar",
                        "privacy_relevant": false
                    },
                    {
                        "host": "translate-cdn.eye-able.com",
                        "region": "unbekannt",
                        "provider": "translate-cdn.eye-able.com",
                        "request_count": 3,
                        "transfer_risk": "mittel",
                        "category_label": "Sonstige",
                        "transfer_label": "Jurisdiktion unklar",
                        "privacy_relevant": false
                    },
                    {
                        "host": "lzkpiwi.lzk-bw.de",
                        "region": "EU/EWR",
                        "provider": "lzkpiwi.lzk-bw.de",
                        "request_count": 1,
                        "transfer_risk": "niedrig",
                        "category_label": "Sonstige",
                        "transfer_label": "EU/EWR",
                        "privacy_relevant": false
                    }
                ],
                "score": 84,
                "status": "prüfen",
                "summary": "3 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 0 mit hohem Prüfbedarf, 2 unklar.",
                "findings": [
                    {
                        "id": "unknown_vendor_jurisdiction",
                        "title": "Anbieter-Jurisdiktion nicht klar ableitbar",
                        "public": true,
                        "category": "privacy",
                        "severity": "info"
                    }
                ],
                "unknown_count": 2,
                "high_risk_count": 0,
                "total_vendor_count": 3,
                "third_country_count": 0
            }
        },
        "privacy_relevant_domain_count": 0,
        "tracking_pixel_beacon_analysis": {
            "color": "green",
            "items": [],
            "score": 100,
            "status": "unauffällig",
            "summary": "0 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).",
            "findings": [],
            "pixel_count": 0,
            "link_ping_count": 0,
            "telemetry_count": 0,
            "beacon_api_count": 0,
            "third_party_count": 0,
            "fetch_keepalive_count": 0,
            "privacy_relevant_count": 0,
            "beacon_code_reference_count": 0,
            "fetch_keepalive_reference_count": 0
        }
    },
    "privacy_analysis": {
        "cookies": {
            "items": [],
            "total": 0,
            "tracking": [],
            "pre_consent": [],
            "missing_secure": [],
            "missing_samesite": [],
            "pre_consent_tracking": [],
            "pre_consent_nonessential": []
        },
        "findings": [],
        "tracking_ids": [],
        "tracking_scripts": [],
        "consent_hint_found": false,
        "privacy_policy_hint_found": true
    },
    "consent_audit": {
        "color": "orange",
        "score": 68,
        "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": false,
                "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": true,
                "label": "GPC-Signal ohne Tracking-Hinweise",
                "detail": "GPC-Aufruf: 0 datenschutzrelevante Domain(s), 0 Drittanbieter-Cookie(s), 0 Storage-Hinweis(e)."
            },
            {
                "id": "no_tracking_cookies_before_consent",
                "ok": true,
                "label": "Keine Tracking-Cookies vor Einwilligung",
                "detail": "0 Tracking-Cookie(s) im Erstaufruf."
            },
            {
                "id": "no_nonessential_cookies_before_consent",
                "ok": true,
                "label": "Keine nicht notwendigen Cookies vor Einwilligung",
                "detail": "0 moeglicherweise nicht notwendige Cookie(s) im Erstaufruf."
            },
            {
                "id": "third_parties_explained",
                "ok": true,
                "label": "Drittanbieter begrenzt und erklaerbar",
                "detail": "0 datenschutzrelevante Drittanbieter-Domain(s), 3 Drittanbieter insgesamt."
            },
            {
                "id": "storage_without_tracking_hints",
                "ok": true,
                "label": "Web Storage ohne Tracking-Hinweise",
                "detail": "2 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": "auffällig",
        "summary": "Consent ist teilweise erkennbar; einzelne Punkte bleiben Betreiberkontext.",
        "evidence": [
            "0 Cookie(s) beim ersten Aufruf aus HTTP-Headern und Chromium",
            "0 Tracking-Script(s) im HTML",
            "0 datenschutzrelevante Drittanbieter-Domain(s)",
            "2 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 0, Drittanbieter-Cookies 0, Storage-Hinweise 0",
            "CMP-/TCF-Signal: nein",
            "Google Consent Default: nein"
        ],
        "gpc_enabled": true,
        "cmp_detected": false,
        "blocking_plan": {
            "items": [
                {
                    "kind": "storage",
                    "level": "mittel",
                    "source": "localStorage",
                    "target": "barrierefreiFontSize",
                    "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"
                },
                {
                    "kind": "storage",
                    "level": "mittel",
                    "source": "sessionStorage",
                    "target": "eaIntro",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager"
                        },
                        {
                            "tool": "Usercentrics"
                        },
                        {
                            "tool": "Developer-Fallback"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "sessionStorage · Unklar · Sitzung/Tab",
                    "category_label": "Unklar"
                }
            ],
            "summary": "2 Blockier-/Consent-Maßnahme(n) abgeleitet: 0 hoch, 2 mittel.",
            "available": true,
            "high_count": 0,
            "total_count": 2,
            "type_counts": {
                "storage": 2
            },
            "medium_count": 2
        },
        "tcf_api_found": false,
        "cookiebot_found": false,
        "accept_test_enabled": false,
        "browser_cookie_count": 0,
        "accept_button_clicked": false,
        "browser_storage_count": 2,
        "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": 0,
        "pre_consent_cookie_names": [],
        "tcf_vendor_consent_count": 0,
        "third_party_domain_count": 3,
        "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": 0,
        "pre_consent_tracking_cookie_count": 0,
        "pre_consent_tracking_cookie_names": [],
        "privacy_relevant_third_party_count": 0,
        "browser_storage_tracking_hint_count": 0,
        "post_accept_third_party_cookie_count": 0,
        "pre_consent_nonessential_cookie_count": 0,
        "pre_consent_nonessential_cookie_names": [],
        "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": "green",
        "items": [],
        "score": 100,
        "total": 0,
        "status": "unauffällig",
        "summary": "0 Cookie(s) inventarisiert: 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebige Cookie(s), 0 sehr lange Laufzeit(en).",
        "findings": [],
        "categories": [],
        "tracking_count": 0,
        "category_labels": {
            "consent": "Consent",
            "payment": "Zahlung",
            "unknown": "Unklar",
            "security": "Sicherheit",
            "analytics": "Analytics",
            "necessary": "Notwendig",
            "functional": "Funktional",
            "advertising": "Werbung"
        },
        "long_lived_count": 0,
        "persistent_count": 0,
        "first_party_count": 0,
        "pre_consent_count": 0,
        "retention_classes": [],
        "third_party_count": 0,
        "missing_secure_count": 0,
        "retention_risk_count": 0,
        "retention_risk_items": [],
        "very_long_lived_count": 0,
        "missing_samesite_count": 0,
        "persistent_unknown_count": 0,
        "long_lived_tracking_count": 0
    },
    "security_header_analysis": {
        "color": "red",
        "score": 34,
        "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": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "X-Frame-Options",
                "value": "",
                "header": "x-frame-options",
                "present": false,
                "purpose": "Reduziert Clickjacking-Risiken bei älteren Browsern.",
                "severity": "warning"
            },
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "X-Content-Type-Options",
                "value": "",
                "header": "x-content-type-options",
                "present": false,
                "purpose": "Verhindert MIME-Sniffing bei Skripten und Stylesheets.",
                "severity": "warning"
            },
            {
                "ok": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "Referrer-Policy",
                "value": "",
                "header": "referrer-policy",
                "present": false,
                "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": false,
                "note": "Fehlt in der HTTP-Antwort.",
                "label": "Cross-Origin-Opener-Policy",
                "value": "",
                "header": "cross-origin-opener-policy",
                "present": false,
                "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": "kritisch",
        "missing": [
            "HSTS",
            "Content-Security-Policy",
            "X-Frame-Options",
            "X-Content-Type-Options",
            "Referrer-Policy",
            "Permissions-Policy",
            "Cross-Origin-Opener-Policy",
            "Cross-Origin-Resource-Policy",
            "Cross-Origin-Embedder-Policy"
        ],
        "summary": "0 von 9 wichtigen Security-Headern vorhanden, 0 korrekt bewertet. Keine Content-Security-Policy gefunden.",
        "findings": [],
        "ok_count": 0,
        "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": 9,
        "present_count": 0,
        "missing_info_count": 5,
        "missing_warning_count": 4
    },
    "infrastructure_analysis": {
        "signals": {
            "caa": false,
            "dnssec": false,
            "final_https": true,
            "tls_version": "TLSv1.2",
            "hsts_enabled": false,
            "address_count": 1,
            "ipv6_available": false,
            "email_protection": {
                "mx": false,
                "spf": false,
                "dmarc": false
            },
            "certificate_valid": true,
            "certificate_issuer": "Sectigo Public Server Authentication CA DV R36",
            "certificate_alt_names": [
                "*.lzk-bw.de",
                "lzk-bw.de"
            ],
            "multiple_ip_addresses": false,
            "certificate_expires_at": "Nov 12 23:59:59 2026 GMT",
            "certificate_days_remaining": 153,
            "certificate_hostname_matches": true
        },
        "findings": [
            {
                "id": "caa_missing",
                "title": "CAA-Record fehlt",
                "public": true,
                "category": "dns",
                "severity": "info"
            }
        ],
        "risk_level": "low",
        "positive_signals": [
            "Moderne TLS-Version aktiv: TLSv1.2."
        ]
    },
    "performance_analysis": {
        "score": 94,
        "signals": {
            "compressed": false,
            "duration_ms": 108,
            "image_count": 22,
            "script_count": 7,
            "cache_control": "no-cache",
            "content_length": 0,
            "viewport_found": true,
            "stylesheet_count": 2
        },
        "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": 68,
        "status": "auffällig",
        "signals": {
            "h1_count": 0,
            "image_count": 22,
            "button_count": 5,
            "heading_count": 0,
            "viewport_found": true,
            "html_lang_found": true,
            "form_field_count": 0,
            "image_missing_alt_count": 4,
            "buttons_without_name_count": 1,
            "form_fields_without_label_count": 0
        },
        "summary": "22 Bild(er), 0 Formularfeld(er), 5 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
        "findings": [
            {
                "id": "image_alt_missing",
                "count": 4,
                "title": "Bilder ohne Alternativtext",
                "public": true,
                "category": "accessibility",
                "severity": "info"
            },
            {
                "id": "button_name_missing",
                "count": 1,
                "title": "Buttons ohne erkennbaren Namen",
                "public": true,
                "category": "accessibility",
                "severity": "warning"
            },
            {
                "id": "heading_structure_missing",
                "title": "Keine Überschriftenstruktur erkannt",
                "public": true,
                "category": "accessibility",
                "severity": "info"
            }
        ],
        "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": "4 von 22 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 0 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": "1 von 5 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": false,
                    "wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
                    "title": "Überschriftenstruktur",
                    "impact": "mittel",
                    "status": "prüfen",
                    "evidence": "0 H1 und 0 Ü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": "3 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 1 mit hoher Auswirkung.",
            "standard": "WCAG 2.2 orientierte Basisprüfung",
            "available": true,
            "issue_count": 3,
            "high_impact_count": 1
        }
    },
    "domain_history": {
        "summary": "Domainhistorie konnte per RDAP nicht zuverlässig abgerufen werden.",
        "findings": [],
        "available": false,
        "risk_level": "unknown"
    },
    "data_entry_analysis": {
        "forms": [],
        "score": 100,
        "summary": "Keine Formular- oder Zahlungsabfrage im passiven Startseiten-Sample erkannt.",
        "findings": [],
        "form_count": 0,
        "risk_level": "low",
        "field_count": 0,
        "asks_for_data": false,
        "payment_providers": [],
        "detected_data_types": [],
        "privacy_context_found": true,
        "operator_context_found": true
    },
    "pii_exposure_analysis": {
        "color": "green",
        "score": 100,
        "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": true,
                "count": 0,
                "label": "Tracking neben Dateneingabe",
                "detail": "Keine Kombination aus Dateneingabe und datenschutzrelevanten Drittanbietern erkannt."
            }
        ],
        "status": "unauffällig",
        "summary": "0 PII-/Datenleck-Hinweis(e) aus URL-, Formular- und Browserkontext.",
        "findings": [],
        "link_hits": [],
        "finding_count": 0,
        "current_url_hits": [],
        "tracking_context": false,
        "sensitive_get_forms": []
    },
    "scan_history_analysis": {
        "available": false,
        "summary": "Noch kein früherer gespeicherter Scan für diese Domain vorhanden.",
        "history": [
            {
                "scan_id": "aee1739b-1128-4335-a4bd-1dbcd4402a4c",
                "created_at": "2026-06-12 13:40:29.128337+02",
                "score": 0,
                "verdict": "riskant",
                "finding_count": 45,
                "integrity_root_hash": "17948617c85c874ca4927503b22c4a9cb6ae99856216b5baff26562261dc05c3",
                "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": "leichtesprache.lzk-bw.de",
        "rank": 1,
        "score": 0,
        "status": "im_mittelfeld",
        "summary": "leichtesprache.lzk-bw.de liegt mit 0 Punkten ungefähr im gespeicherten Vergleichsfeld. Weil viele gespeicherte Checks bei 0 Punkten liegen, zeigt die Detailansicht zusätzlich aktive Peers mit Durchschnitt 17.1.",
        "available": true,
        "peer_count": 1325,
        "percentile": 0,
        "query_mode": "php_ttl_cache_refresh",
        "distribution": {
            "0_39": 1321,
            "40_59": 3,
            "60_79": 1,
            "80_100": 0
        },
        "median_score": 0,
        "average_score": 1.1,
        "comparison_basis": "Neuester gespeicherter SaferPage-Scan je Domain; überwiegend deutschsprachige gespeicherte Checks.",
        "same_score_count": 0,
        "better_than_count": 0,
        "qualified_peer_count": 82,
        "zero_score_count": 1243,
        "top_quartile_score": 0,
        "top_decile_score": 0,
        "qualified_average_score": 17.1,
        "qualified_median_score": 16,
        "qualified_top_quartile_score": 24,
        "qualified_top_decile_score": 32,
        "thresholds": [
            {
                "id": "critical",
                "label": "Kritisch",
                "range": "0-39",
                "met": true
            },
            {
                "id": "basic",
                "label": "Basis stabilisieren",
                "range": "40-59",
                "met": false
            },
            {
                "id": "managed",
                "label": "Gesteuert",
                "range": "60-79",
                "met": false
            },
            {
                "id": "strong",
                "label": "Stark",
                "range": "80-100",
                "met": false
            }
        ],
        "risk_tier": "kritisch",
        "target_score": 40,
        "aspirational_target_score": 60,
        "gap_to_target": 40,
        "gap_to_top_quartile": 24,
        "gap_to_strong": 80,
        "cache_ttl_seconds": 300
    },
    "audit_receipt": {
        "url": "https://leichtesprache.lzk-bw.de/",
        "host": "leichtesprache.lzk-bw.de",
        "status": "verfügbar",
        "bot_url": "https://saferpage.de/bot",
        "summary": "Prüfbeleg für leichtesprache.lzk-bw.de: kontrollierter HTTP-/Browser-Kurzcheck mit 39 Request(s), 4 Consent-Zustand/Zuständen und 7 Artefakt(en).",
        "renderer": "playwright-chromium",
        "artifacts": [
            {
                "label": "Öffentlicher Kurzreport",
                "detail": "https://saferpage.de/leichtesprache.lzk-bw.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/leichtesprache.lzk-bw.de-160x150-a8f21ab7aef1ff8659.png",
                "status": "verfügbar"
            },
            {
                "label": "Cookie-Erklärung",
                "detail": "2 Cookie-/Storage-Eintrag/Einträge.",
                "status": "prüfen"
            },
            {
                "label": "Empfänger-/Anbieterinventar",
                "detail": "3 Anbieterzeile(n), 2 AVV-/Rollenprüfung(en).",
                "status": "unauffällig"
            },
            {
                "label": "Barrierefreiheitserklärung-Entwurf",
                "detail": "3 bekannte Barrierefreiheits-Punkt(e).",
                "status": "Nicht vollständig konform im automatischen Basischeck"
            }
        ],
        "available": true,
        "final_url": "https://leichtesprache.lzk-bw.de/",
        "checked_at": "2026-06-12T11:40:28+00:00",
        "share_text": "SaferPage Prüfbeleg leichtesprache.lzk-bw.de: 39 Browser-Request(s), 3 Drittanbieter, 2 Cookie-/Storage-Einträge, geprüft am 2026-06-12T11:40:28.",
        "user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/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": "crawler",
        "coverage_items": [
            {
                "label": "HTTP/DNS/TLS",
                "value": "HTTP 200 · DNS ok · TLS ok"
            },
            {
                "label": "Browserlauf",
                "value": "39 Request(s), 3 Drittanbieter-Domain(s), 0 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": "3 Anbieterzeile(n) im öffentlichen Nachweis."
            },
            {
                "label": "Cookie-Auszug",
                "value": "0 Cookie-Zeile(n) im öffentlichen Nachweis."
            }
        ],
        "confidence_score": 86,
        "browser_final_url": "https://leichtesprache.lzk-bw.de/"
    },
    "evidence_integrity_manifest": {
        "host": "leichtesprache.lzk-bw.de",
        "status": "verfügbar",
        "summary": "Integritätsmanifest für leichtesprache.lzk-bw.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
        "sections": [
            {
                "id": "audit_receipt",
                "hash": "23b67d42a207394066e3df7e8ce76e07e5a65c5817ff76e8f701b663ebd875a6",
                "count": 18,
                "label": "Prüfbeleg",
                "detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
                "status": "verfügbar"
            },
            {
                "id": "protocol",
                "hash": "e4eb21a67a7551993a4ab452106272dfabe700a9f1538a4bce436d7162ac9ad0",
                "count": 15,
                "label": "Scan-Protokoll",
                "detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
                "status": "verfügbar"
            },
            {
                "id": "checkpoints",
                "hash": "23d631ee02f15719f09ed8f1fb3f058cad77376de03e53053376456e46a8047e",
                "count": 6,
                "label": "Prüfschritte",
                "detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
                "status": "verfügbar"
            },
            {
                "id": "consent_states",
                "hash": "d1d50eeb79cfacdd7f4c8baee22dff05834495b8a38efbc10dce2d1f01c80939",
                "count": 4,
                "label": "Consent-Zustände",
                "detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
                "status": "verfügbar"
            },
            {
                "id": "third_party_evidence",
                "hash": "be1013d02e80df4449af855603659177cb908c1aaee6a4fda7d3ed3065304ac8",
                "count": 3,
                "label": "Drittanbieter-Auszug",
                "detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
                "status": "verfügbar"
            },
            {
                "id": "cookie_evidence",
                "hash": "4f53cda18c2baa0c0354bb5f9a3ecbe5ed12ab4d8e11ba873c2f11161202b945",
                "count": 0,
                "label": "Cookie-Auszug",
                "detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
                "status": "leer"
            },
            {
                "id": "request_samples",
                "hash": "512c25755c9ab32c2b4abf618b301f396eb633fce3fe54cafd2f72c8b614e7d9",
                "count": 9,
                "label": "Request-Samples",
                "detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
                "status": "verfügbar"
            },
            {
                "id": "checked_pages",
                "hash": "c06deb9ce4a93248e4eae58412aa42979d6a8af21f7d78b7d80b05c41a201cec",
                "count": 8,
                "label": "Geprüfte Unterseiten",
                "detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
                "status": "verfügbar"
            },
            {
                "id": "screenshot_file",
                "hash": "67976c900e20249608efe06f1a0ef6f6404485b193dc41adf2b2258fd39de1f6",
                "count": 8500,
                "label": "160x150 Seitenvorschau-Datei",
                "detail": "/cache/screenshots/leichtesprache.lzk-bw.de-160x150-a8f21ab7aef1ff8659.png",
                "status": "verfügbar"
            }
        ],
        "algorithm": "sha256",
        "available": true,
        "root_hash": "17948617c85c874ca4927503b22c4a9cb6ae99856216b5baff26562261dc05c3",
        "checked_at": "2026-06-12T11:40:28+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 39 Browser-Request(s), 0 Cookie-Nachweis(en), 3 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
        "protocol": {
            "host": "leichtesprache.lzk-bw.de",
            "dns_ok": true,
            "tls_ok": true,
            "bot_url": "https://saferpage.de/bot",
            "renderer": "playwright-chromium",
            "final_url": "https://leichtesprache.lzk-bw.de/",
            "input_url": "https://leichtesprache.lzk-bw.de/",
            "checked_at": "2026-06-12T11:40:28+00:00",
            "user_agent": "SaferPageCrawler/0.3 (+https://saferpage.de/bot; schedules passive DACH website checks; report examples: https://saferpage.de/tests)",
            "http_status": 200,
            "scan_context": "crawler",
            "screenshot_url": "/cache/screenshots/leichtesprache.lzk-bw.de-160x150-a8f21ab7aef1ff8659.png",
            "googlebot_status": 200,
            "browser_final_url": "https://leichtesprache.lzk-bw.de/",
            "dns_address_count": 1
        },
        "checkpoints": [
            {
                "label": "DNS",
                "detail": "1 Adresse(n) aufgelöst.",
                "status": "ok"
            },
            {
                "label": "TLS/HTTPS",
                "detail": "TLSv1.2",
                "status": "ok"
            },
            {
                "label": "HTTP-Abruf",
                "detail": "Status 200, Endziel https://leichtesprache.lzk-bw.de/.",
                "status": "ok"
            },
            {
                "label": "Browserlauf",
                "detail": "39 Request(s), 3 Drittanbieter-Domain(s).",
                "status": "ok"
            },
            {
                "label": "Consent-Zustände",
                "detail": "Default, Ablehnen, Akzeptieren und GPC werden soweit möglich gegenübergestellt.",
                "status": "unauffällig"
            },
            {
                "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": "/wie-sieht-unser-datenschutz-aus",
                "source": "homepage_link",
                "status": 0,
                "category": "datenschutz"
            },
            {
                "path": "/impressum",
                "source": "homepage_link",
                "status": 0,
                "category": "impressum"
            },
            {
                "path": "/an-welche-gesetze-muessen-sich-zahnaerzte-halten",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/der-gesunde-zahn",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/patienteninfo-der-kranke-zahn",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/patienteninfo-die-behandlung",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/patienteninfo-die-untersuchung",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/patienteninfo-und-wenn-ich-angst-habe",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            }
        ],
        "cookie_evidence": [],
        "browser_evidence": {
            "gpc_enabled": true,
            "request_count": 39,
            "storage_total": 2,
            "accept_clicked": false,
            "reject_clicked": false,
            "browser_cookie_count": 0,
            "contacted_domain_count": 4,
            "third_party_domain_count": 3,
            "storage_tracking_hint_count": 0,
            "privacy_relevant_domain_count": 0
        },
        "storage_evidence": {
            "tracking_key_hints": [],
            "local_storage_total": 1,
            "session_storage_total": 1
        },
        "third_party_evidence": [
            {
                "host": "cdn.eye-able.com",
                "category": "Sonstige",
                "provider": "cdn.eye-able.com",
                "transfer": "Jurisdiktion unklar",
                "risk_level": "niedrig",
                "request_count": 5,
                "resource_types": [
                    "image",
                    "script",
                    "stylesheet"
                ],
                "privacy_relevant": false
            },
            {
                "host": "translate-cdn.eye-able.com",
                "category": "Sonstige",
                "provider": "translate-cdn.eye-able.com",
                "transfer": "Jurisdiktion unklar",
                "risk_level": "niedrig",
                "request_count": 3,
                "resource_types": [
                    "fetch",
                    "script"
                ],
                "privacy_relevant": false
            },
            {
                "host": "lzkpiwi.lzk-bw.de",
                "category": "Sonstige",
                "provider": "lzkpiwi.lzk-bw.de",
                "transfer": "EU/EWR",
                "risk_level": "niedrig",
                "request_count": 1,
                "resource_types": [
                    "script"
                ],
                "privacy_relevant": false
            }
        ],
        "external_script_count": 5,
        "consent_state_evidence": [
            {
                "label": "Erstaufruf",
                "cookie_count": 0,
                "domain_count": 3,
                "request_count": 9,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            },
            {
                "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": 3,
                "request_count": 9,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            }
        ],
        "request_sample_evidence": [
            {
                "host": "cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "script",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "script",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "translate-cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "script",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "lzkpiwi.lzk-bw.de",
                "query_keys": [],
                "resource_type": "script",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "translate-cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "fetch",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "translate-cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "fetch",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "stylesheet",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "cdn.eye-able.com",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            }
        ]
    },
    "adtech_transparency_evidence": {
        "schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
        "available": false,
        "status": "not_in_stored_report",
        "summary": "Dieser gespeicherte Scan enthält keine AdTech-Transparenzdatei-Evidence. Daraus wird keine Aussage zu Werbeinventarqualität, Fraud-Freiheit, Consent-Konformität oder Anbieterberechtigung abgeleitet.",
        "guardrails": [
            "Nur als Boundary exportiert",
            "Keine Nachbewertung alter Scans",
            "Keine Betreiber-Empfehlung im Testresult-JSON"
        ]
    },
    "security_trust_policy_evidence": {
        "schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
        "available": false,
        "status": "not_in_stored_report",
        "summary": "Dieser gespeicherte Scan enthält keine security.txt-Evidence. Daraus wird keine Aussage zu Security-Reife, Reaktionszeit oder Disclosure-Prozess abgeleitet.",
        "guardrails": [
            "Nur als Boundary exportiert",
            "Keine Nachbewertung alter Scans",
            "Keine Betreiber-Empfehlung im Testresult-JSON"
        ]
    }
}