Live-Domain-Report

cornelsen.de Datenschutz-Check

Scan-ID: c14a85b0-9b07-414d-9b74-fd9e613c0fbf · 2026-06-13 00:11:56.529194+02

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

Kurz-URL: saferpage.de/cornelsen.de

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

In 20 Sekunden lesen

Was ist bei cornelsen.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ässlichkeitBelastbares Signal mit manuellen Prüfpunkten
Der Report zeigt relevante Datenschutz-Signale; Betreiber sollten die markierten Punkte mit ihren Website-Flows abgleichen.
Belegbar3 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 cornelsen.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 Rechtsfreigabe4Cookie(s) vor Einwilligung gesehen0datenschutzrelevante Drittanbieter-Domains0Formular(e)prüfenImpressum-Link automatisch belegtprüfenDatenschutz-Hinweis automatisch belegt
Scan-Einordnung

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

Einordnung lesen
Datenschutz-Fokus

4 Cookie(s) vor Einwilligung, 0 datenschutzrelevante Drittanbieter-Domain(s), 0 Tracking-Script(s) im gespeicherten Lauf.

Datenschutz-Hub öffnen
Google Consent Mode

Google-Tag-Evidence wurde gesehen; die Detailbewertung ist als Link ausgelagert.

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ässlichkeitBelastbares Signal mit manuellen Prüfpunkten · Signal + BetreiberprüfungFür die EinordnungDer Report zeigt relevante Datenschutz-Signale; Betreiber sollten die markierten Punkte mit ihren Website-Flows abgleichen.BetreiberkontextNicht als Scan-Feststellung im Testresult ausgespielt; Detailprüfung ist verlinkt.

Verlässlichkeitsgrenze: Die sichtbare Evidence ist auswertbar, aber Formulare, Cookies, Drittanbieter, Google-Tags und Rechtsgrundlagen brauchen Betreiberkontext.

Automatisch belegtAus gespeicherter SaferPage-Evidence

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

71 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.

Status
belegbar
Nicht behauptenClaim-Grenzen

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

kein abschließendes Seriositätsurteil über cornelsen.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 soll Betreiber zu konkreten Datenschutz-, Consent-, Formular- und Transparenzprüfungen führen. Er ist kein Freigabesiegel und muss bei Website-Änderungen neu bewertet werden.

Prüfumfang & Grenzen

Was SaferPage geprüft hat - und was nicht

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

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

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

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

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

Formular-Evidenz aus öffentlichem Crawl: 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-HinweisejaGoogle-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 · Google-Evidenz prüfen
Google-Tags oder Google-Domains wurden gesehen; Consent-Mode-Einordnung anhand der konkreten Requests prüfen.
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

/80-jahre/day-camps-erlebenunterseite · HTTP 503/berufliche-bildungunterseite · HTTP 503/berufliche-bildung/alle-bundeslaenderunterseite · HTTP 503/berufliche-bildung/baden-wuerttembergunterseite · 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.

Domaincornelsen.de Score0 Scan-IDc14a85b0-9b07-414d-9b74-fd9e613c0fbf Erstellt2026-06-13 00:11:56.529194+02 Öffentlicher Linksaferpage.de/cornelsen.de ExportPDF/Druck, JSON, CSV, XLSX, ZIP-Nachweise
DNS erreichbarAdressen: 3
HTTPS-Zertifikat gültigTLS: TLSv1.3
HTTP-Status 200Endziel: https://www.cornelsen.de/

Report richtig einordnen

Passive technische Orientierung, kein abschließendes Urteil

SaferPage bewertet sichtbare Website-Signale für cornelsen.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 ModeGoogle-Signale wurden gesehen; Consent-Mode- und Tag-Gating-Befunde mit den konkreten Request-/Tag-Nachweisen prüfen.Drittanbieter-Evidence71 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.

71Browser-Requests im passiven Lauf0datenschutzrelevante Drittanbieter-Domains0Formulare aus Startseite und Crawl-CoveragejaGoogle-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 ModeGoogle-Evidenz prüfen
Google-Tags oder Google-Domains wurden gesehen; Consent Defaults und Tag-Gating anhand der konkreten Requests prüfen.
Consent-Guide öffnen
Consent-/Paywall-Gateskeine besondere Gate-Grenze erkannt
Im gespeicherten Kurzcheck wurde keine besondere Gate-Grenze hervorgehoben.
Grenzen öffnen
Cookies vor Einwilligung4 Cookie(s) gesehen
Der passive Browserlauf speicherte 4 Cookie(s) vor Einwilligung und 0 datenschutzrelevante Drittanbieter-Domain(s).
Cookie-Guide öffnen
Externe Skript-Lieferkettenicht belegt
Der passive Lauf hat keine externen Skriptquellen im Startseiten-Sample gespeichert.
Skript-Guide öffnen
Robots & Sitemaprobots.txt geprüft
Der passive Coverage-Check hat robots.txt erfolgreich abgerufen, 3 Sitemap-Quelle(n) gelesen, 1 Sitemap-Kandidat(en) gesehen, 0 Sitemap-URL(s) und 30 interne Linkziele gespeichert.
Crawl-Grenzen öffnen
Indexierungs-SignaleRobots-Direktiven gesehen
Der passive Abruf sah 1 Meta-Robots-Signal(e), 0 X-Robots-Tag-Wert(e) und 0 begrenzende Direktive(n): follow, index.
Indexierungs-Grenzen öffnen
KI-/Crawler-PolicyAI-Bot-Regeln gesehen
Der passive Same-Origin-Check sah 1 von 5 festen Policy-Datei(en), 0 llms/AI/WARD-Datei(en) und 1 explizite KI-Bot-Regel(n) in robots.txt. robots.txt: explicit_ai_bot_policy; llms/AI/WARD: not_publicly_verified.
KI-/Crawler-Grenzen öffnen
AdTech-Transparenzdateiennicht belegt
Der passive Same-Origin-Check sah 0 von 3 AdTech-Datei(en), 0 ads.txt-Zeile(n), 0 app-ads.txt-Zeile(n), DIRECT 0, RESELLER 0, Exchange-Domains 0 und 0 sellers.json-Seller.
AdTech-Grenzen öffnen
Security-/Trust-PolicySecurity-Kontakt gesehen
Der passive Same-Origin-Check sah 1 von 2 security.txt-Ziel(en), 2 Kontaktfeld(er), 5 strukturierte Feld(er), bevorzugter Well-known-Pfad: ja, Expires-Feld: ja.
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 200 / 200, Textähnlichkeit 1.
Cloaking-Guide öffnen
Hreflang-/SprachalternativenAlternate-Links gesehen
Der HTML-Check sah 2 Hreflang-Alternate(s), davon 0 ungültige Codes, 0 fremde Zielhost(s) und 0 doppelte Sprachziele.
Hreflang-Guide öffnen
BetreibertransparenzLink-Evidenz im Scan nicht belegt
Der passive Lauf hat keinen belastbaren Impressum-Link gespeichert.
Transparenz-Guide öffnen

Methodik-Grenzen öffnen

Behebung ausgelagert

Faktenbasierte Linkziele statt Fix-Anleitung

Diese Testresult-Seite zeigt Scan-Fakten zur geprüften Website. Umsetzungsschritte, Betreiber-Guides und allgemeine Empfehlungen stehen auf getrennten Seiten und werden hier nur verlinkt.

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

Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig.

Guide- und Umsetzungstexte sind ausgelagert; hier bleibt nur der Link.
Gewicht
88/100
Linkziel
öffnen
Sensible URL-Schlüssel im Drittanbieter-Kontexthoch · PII-Datenleck

Sensible URL-Parameter aus Drittanbieter-Requests und Referrern entfernen.

Guide- und Umsetzungstexte sind ausgelagert; hier bleibt nur der Link.
Gewicht
82/100
Linkziel
öffnen
Dateneingabe ohne klaren Datenschutzkontexthoch · DSGVO/Transparenz

Datenschutzhinweise in Formularnähe ergänzen.

Guide- und Umsetzungstexte sind ausgelagert; hier bleibt nur der Link.
Gewicht
82/100
Linkziel
öffnen

Betreiber-Fazit

Nur mit Vorsicht nutzen

Mehrere deutliche Warnsignale sprechen dafür, vor Eingabe persönlicher Daten, Registrierung oder Zahlung genauer hinzusehen.

Spricht dagegenMöglicherweise nicht notwendige Cookies vor EinwilligungSensible URL-Schlüssel im Drittanbieter-KontextKein Impressum-Link erkanntDateneingabe ohne klaren Datenschutzkontext
Spricht dafürTechnisches VertrauenssignalTechnisches VertrauenssignalTechnisches VertrauenssignalTechnisches Vertrauenssignal
Datenschutz & Trackingauffällig0 Tracking-Script(s), 4 Cookie(s) vor Einwilligung, 0 datenschutzrelevante Drittanbieter.
DateneingabeprüfenDie Seite kann Name/personenbezogene Daten abfragen.
BrowserkontaktekritischChromium sah 71 Request(s), 4 Drittanbieter-Domain(s), davon 0 datenschutzrelevant.
DomainhistorieprüfenRDAP liefert kein klares Registrierungsdatum.
Technische BasisunauffälligHTTPS, DNS, Zertifikat, HTTP-Status und wichtige Sicherheitsheader wurden passiv geprüft.
NutzbarkeitprüfenAntwortzeit, 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
Datenschutz, Cookies & Consent18
kritisch

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

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

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

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Google-Dienste & Drittanbieter40
kritisch

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

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

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

Details und Umsetzungshinweise sind ausgelagert; sichtbar bleiben Modulscore, Evidence und Linkziel.Betreiber-Guide öffnen
Impressum, Kontakt & Datenschutzerklärung55
auffällig

Impressum: nein, Datenschutz: nein, Kontakt: ja.

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

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

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

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

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

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

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

Betreiber-Checkliste öffnen

Domainbezogene Betreiber-Fix-Guides öffnen

Betreiber-Werkzeuge

Guides und Runbooks sind ausgelagert

Diese Testresult-Seite bleibt bei Scan-Fakten zur geprüften Website. Betreiber-Guides, Runbooks und allgemeine Checklisten öffnen auf eigenen Seiten.

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; keine Guide-Inhalte im Testresult.

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-13 00:11Score 0 · 27 Hinweis(e)

Betreiber-Risiko

Welche Scan-Hinweise sollte der Website-Betreiber zuerst öffnen?

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

TDDDG/ePrivacyhoch · 3 Hinweis(e)Guide öffnenBSI/Security-Headermittel · 4 Hinweis(e)Guide öffnenDSGVO/Transparenzhoch · 2 Hinweis(e)Guide öffnenBarrierefreiheit/Usabilitymittel · 2 Hinweis(e)Guide öffnenConsent-Nachweishoch · 1 Hinweis(e)Guide öffnenDSGVO/Google-Dienstehoch · 1 Hinweis(e)Guide öffnen

Regelwerks-Scorecard

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

Regelwerks-Matrix

TDDDG/ePrivacyhoch · 4 Befund(e) · Score 112Guide öffnenDSGVO Datenleck/PIIhoch · 3 Befund(e) · Score 70Guide öffnenDSGVO Transparenzhoch · 3 Befund(e) · Score 70Guide öffnenBSI/Sicherheitmittel · 7 Befund(e) · Score 66Guide öffnenGoogle-Dienstehoch · 4 Befund(e) · Score 54Guide öffnenBITV/Usabilitymittel · 2 Befund(e) · Score 28Guide öffnenBetreibervertrauenhoch · 1 Befund(e) · Score 28Guide öffnen

Domainhistorie

Wie lange gibt es die Domain?

RDAP liefert kein klares Registrierungsdatum.

RDAP-Hinweise

Letzte Änderung2025-07-03Statusactive

Datenschutz zuerst

Was sieht ein Nutzer beim ersten Aufruf?

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

Dateneingabe & Zahlung

Welche Daten könnte die Seite abfragen?

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

Erkannte Eingaben

Name/personenbezogene Daten23 Signal(e)

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: 71 · kontaktierte Domains: 5 · Drittanbieter: 4 · Browser-Cookies: 4 · Storage: 2 (0 Tracking-Hinweis(e)) · Banner: Akzeptieren 0 / Ablehnen 1 / Einstellungen 0 · Ablehnen/Akzeptieren: 0 · Reject-Test: geklickt, neue Cookies 1, 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

other4 Domain(s)

CMP & Storage

dataLayerBrowserTCF TC-StringneinTCF Purposes0TCF Vendors0Akzeptieren0Ablehnen1Einstellungen0Ablehnen/Akzeptieren0ablehnenBannerReject-TestgeklicktNeue Cookies nach Ablehnen1Tracking-Storage nach Ablehnen1Neue Tracking-Kontakte0Accept-Testnicht ausgeführtNeue Requests nach Akzeptieren0Neue Cookies nach Akzeptieren0Neue Tracking-Kontakte nach Akzeptieren0GPC-SignalaktivGPC Datenschutz-Domains0GPC Drittanbieter-Cookies0GPC Storage-Hinweise0

Drittanbieter

static.cornelsen.deSonstige · 17 Request(s) · imagel.ecn-ldr.deSonstige · 3 Request(s) · scriptmcw0nd.cornelsen.deSonstige · 2 Request(s) · xhr, scriptid.cornelsen.deSonstige · 1 Request(s) · image

Consent-Zustände

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

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

Betreiber-Guide Consent öffnen

Zustandsnachweis

ErstaufrufCookies 4 · neu 4 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigNach AblehnenCookies 5 · neu 1 · Tracking-Storage 1 · Datenschutz-Domains 0 · hochNach AkzeptierenCookies 0 · neu 0 · Tracking-Storage 0 · Datenschutz-Domains 0 · niedrigGPC-AufrufCookies 4 · 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

mcw0nd.cornelsen.deSonstige · Erstaufruf 2 · Ablehnen neu 1 · Akzeptieren neu 0 · GPC 1static.cornelsen.deSonstige · Erstaufruf 17 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 17l.ecn-ldr.deSonstige · Erstaufruf 3 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 3id.cornelsen.deSonstige · Erstaufruf 1 · Ablehnen neu 0 · Akzeptieren neu 0 · GPC 1

Drittanbieter-Kontakte

Wer bekommt beim ersten Aufruf technische Kontaktpunkte?

4 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant. Score: 87 · Requests: 23 · datenschutzrelevant: 0

Betreiber-Guide Drittanbieter öffnen

Kontaktmatrix

static.cornelsen.deniedrig · Sonstige · 17 Request(s) · image:17l.ecn-ldr.deniedrig · Sonstige · 3 Request(s) · script:3mcw0nd.cornelsen.deniedrig · Sonstige · 2 Request(s) · script:1, xhr:1id.cornelsen.deniedrig · Sonstige · 1 Request(s) · image:1

Betreiber-Verzeichnis

Welche Empfänger und Auftragsverarbeiter sollte der Betreiber dokumentieren?

4 Empfänger-/Anbieter-Eintrag/Einträge aus Browserkontakten und Cookie-Inventar, 0 datenschutzrelevant, 1 mit AVV-/Rollenprüfung. Score: 100 · hoher Prüfbedarf: 0 · AVV/Rolle prüfen: 1
Automatisch aus technischen SaferPage-Signalen abgeleitet; Rollen, Verträge und Rechtsgrundlagen müssen Betreiber fachlich prüfen.

Betreiber-Guide Anbieterinventar öffnen

Anbieterinventar

id.cornelsen.demittel · Sonstige · Technischer Empfänger prüfen · EU/EWR · 1 Request(s) · 1 Cookie(s) · Cookies: ingress-route-oxauth-cde-prodl.ecn-ldr.deniedrig · Sonstige · Technischer Empfänger prüfen · EU/EWR · 3 Request(s) · 0 Cookie(s)static.cornelsen.deniedrig · Sonstige · Technischer Empfänger prüfen · EU/EWR · 17 Request(s) · 0 Cookie(s)mcw0nd.cornelsen.deniedrig · Sonstige · Technischer Empfänger prüfen · EU/EWR · 2 Request(s) · 0 Cookie(s)

Transfer-Risiko

Welche Drittanbieter brauchen eine Drittland- oder Jurisdiktionsprüfung?

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

Transfer Impact Assessment öffnen

Betreiber-Guide Drittlandtransfer öffnen

Anbieter-Prüfliste

static.cornelsen.deniedrig · EU/EWR · EU/EWRl.ecn-ldr.deniedrig · EU/EWR · EU/EWRmcw0nd.cornelsen.deniedrig · EU/EWR · EU/EWRid.cornelsen.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?

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

Betreiber-Guide Referrer- und URL-Leaks öffnen

Leak-Prüfliste

id.cornelsen.desensibler Query-Schlüssel im Drittanbieter-Request oder Referrer · Query: redirect_uri, prompt, etid.cornelsen.deSeiten-URL oder URL-Wert in Drittanbieter-Requestparametern · Query: redirect_uri, prompt, et

Tracking-Pixel & Beacons

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

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

Betreiber-Guide Pixel & Beacons öffnen

Signale

id.cornelsen.debrowser_tracking_request · Sonstige · image · image-Request mit 8 Query-Schlüssel(n).

Fingerprinting & Session-Replay

Liest die Seite Browser-Merkmale oder Interaktionen aus?

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

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

Seitenabdeckung

Welche Unterseiten wurden gefunden?

30 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen. Score: 39 · wichtige Seiten: · Sitemap-URLs: 0 · gelesene Sitemaps: 3 · Unterseiten mit Tracking: 0 · Formularlücken: 0 · Anbieter-Abgleich: 0/1 erwähnt

Priorisierte Seiten

/80-jahre/day-camps-erlebenunterseite · HTTP 503/berufliche-bildungunterseite · HTTP 503/berufliche-bildung/alle-bundeslaenderunterseite · HTTP 503/berufliche-bildung/baden-wuerttembergunterseite · HTTP 200 · Tracking 0 · Cookies 0

Datenschutzerklärung

Keine Datenschutzerklärung-Inhaltsprüfung aus den priorisierten Unterseiten vorhanden.

Anbieter-Abgleich

Google Tag ManagerTracking-ID · fehlt in Datenschutzerklärung

Google Consent Mode

Sind Google-Tags vor Einwilligung begrenzt?

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

Consent Mode öffnen

Nachweis

Google-TagsjaConsent-DefaultneinConsent-UpdateneinGoogle-Consent-Domains0Google-Service-Domains0

Consent-Audit

Haelt die Seite Tracking bis zur Einwilligung zurueck?

Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig. Score: 18 · Cookies vor Einwilligung: 4 · Tracking-Cookies: 0 · Browser-Ablehnen: 1 · Ablehnen/Akzeptieren: 0 · Reject geklickt: ja · neue Cookies nach Ablehnen: 1 · 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 sichtbarpruefenAblehnen gleichwertig erreichbarokEinstellungen oder Auswahl vorhandenpruefenAblehnen im sichtbaren BannerokEinstellungen im sichtbaren BannerokAblehnen nicht deutlich schwaecher dargestelltokAblehnen technisch klickbarokKeine neuen Cookies nach AblehnenpruefenKein Tracking-Storage nach AblehnenpruefenKeine neuen Tracking-Kontakte nach Ablehnenok

Consent-Guide-Link

Consent-Guide öffnen4 Cookie(s) vor Einwilligung, 0 Tracking-Cookie(s), 0 datenschutzrelevante Drittanbieter.

Blockierplan-Link

Blockierplan im Consent-Guide öffnen0 Browser-Request(s), 4 Cookie(s) vor Einwilligung, 0 datenschutzrelevante Drittanbieter.

Banner-UX

Wirkt das Consent-Banner fair und gleichwertig bedienbar?

Consent-Banner-UX: 1 auffällige Prüfpunkt(e), davon 1 hoch. Muster: Ablehnen technisch nicht wirksam. Score: 82 · Akzeptieren: 0 · Ablehnen: 1 · Einstellungen: 0 · Dark-Pattern-Hinweise: 1
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 1, 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 2170.Ablehnen technisch klickbarok · niedrig · Reject-Test: geklickt. Text: ablehnenAblehnen stoppt neue Tracking-Signaleauffällig · hoch · Nach Ablehnen: 1 neue Cookie(s), 1 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?

Quellenmatrix: 10 offizielle/operative Quelle(n) mit Befundbezug und Betreibermaßnahme.
Quellen dienen der technischen Einordnung und Betreiber-Dokumentation; sie ersetzen keine Rechtsberatung.

Quellen: 10 · offizielle Links: 6

Referenzen

DSK Orientierungshilfe digitale DiensteTDDDG/ePrivacy · prüfen · 100 · Guide öffnenDSGVO Art. 6DSGVO Rechtsgrundlagen · prüfen · 95 · Guide öffnenDSGVO Art. 28 und Kapitel VEmpfänger, AVV und Drittlandtransfer · prüfen · 90 · Guide öffnenBSI TLS-Mindeststandard und IT-Grundschutz Webserver/WebanwendungenBSI/Sicherheit · prüfen · 80 · Guide öffnenGoogle Consent Mode DokumentationGoogle-Dienste · prüfen · 75 · Guide öffnenWCAG 2.2 / BFIT / European Accessibility ActBarrierefreiheit · prüfen · 70 · Guide öffnenBFSG/WCAGSaferPage Regelwerks-Scorecard · prüfen · 40 · Guide öffnenBSI/SecuritySaferPage Regelwerks-Scorecard · hoher Prüfbedarf · 40 · Guide öffnenDSGVOSaferPage Regelwerks-Scorecard · hoher Prüfbedarf · 40 · Guide öffnenTDDDG/ePrivacySaferPage Regelwerks-Scorecard · hoher Prüfbedarf · 40 · Guide öffnen

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: 7 · vor Consent auffällig: 3 · unklar/prüfen: 11 · Drittanbieter: 4 · 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: 1 beobachtete Anbieter, 1 Anbieter ohne klare Erwähnung, 0 fehlende Policy-Bausteine.
Automatischer Textabgleich gegen technische Beobachtungen; Schreibweisen und dynamische Inhalte können manuelle Prüfung erfordern.

Score: 0 · Anbieter erkannt: 1 · Anbieter fehlen: 1 · Policy-Lücken: 0

Lücken

Google Tag Manageranbieter · Tracking-ID · fehlt

Datenschutzhinweis

Welche Disclosure-Signale wurden gesehen?

Entwurf aus Scan-Evidenz: 4 Cookie(s), 4 Drittanbieter-Domain(s), 2 Storage-Key(s).
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 öffnen4 Zwecksignal(e), 1 Datenart(en), 4 Lückenhinweis(e).

Cookie-Signale

ingress-route-oxauth-cde-prodNotwendig · meist ohne Einwilligung · kurz (0 Tage) · vor ConsentecpdTimestampUnklar · unklar, prüfen · Session · vor Consentemos_jcsidUnklar · unklar, prüfen · Session · vor ConsentfrontendUnklar · unklar, prüfen · Session · vor Consent

Drittanbieter-Signale

static.cornelsen.deSonstige · EU/EWR · niedrigl.ecn-ldr.deSonstige · EU/EWR · niedrigmcw0nd.cornelsen.deSonstige · EU/EWR · niedrigid.cornelsen.deSonstige · EU/EWR · niedrig

Web-Storage-Signale

Neos.Neos.lastVisitedNodesessionStorage · Unklar · unklar, prüfen · Sitzung/TabecpWidgetAutoLoginTimestampsessionStorage · Funktional · kontextabhängig prüfen · Sitzung/Tab

Cookie-Inventar

Welche Cookies wurden beim ersten Aufruf gesehen?

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

Betreiber-Guide Cookie-Laufzeiten öffnen

Cookies

ingress-route-oxauth-cde-prodNotwendig · First-Party · id.cornelsen.de · ohne Secure, SameSite Lax, kurz (0 Tage), Laufzeitrisiko niedrig · Chromium-Erstaufruf · Quelle: id.cornelsen.de · 1 Browser-Request(s) · image:1ecpdTimestampUnklar · First-Party · cornelsen.de · Secure, SameSite None, Session, Laufzeitrisiko niedrig · Chromium-Erstaufruf · Quelle: cornelsen.de · 48 Browser-Request(s) · document:1, fetch:6, font:8, image:18emos_jcsidUnklar · First-Party · cornelsen.de · ohne Secure, SameSite Lax, Session, Laufzeitrisiko niedrig · Chromium-Erstaufruf · Quelle: cornelsen.de · 48 Browser-Request(s) · document:1, fetch:6, font:8, image:18frontendUnklar · First-Party · cornelsen.de · Secure, SameSite None, Session, Laufzeitrisiko niedrig · Chromium-Erstaufruf · Quelle: cornelsen.de · 48 Browser-Request(s) · document:1, fetch:6, font:8, image:18

Cookie-Disclosure

Welche Cookie-Signale wurden gesehen?

Cookie-Erklärung mit 6 Eintrag/Einträgen aus Cookies und Web Storage: 0 einwilligungspflichtig, 4 unklassifiziert. Score: 78 · einwilligungspflichtig: 0 · vor Consent: 0 · unklassifiziert: 4
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

Unklassifiziert4 Eintrag/Einträge · Zweck oder Erforderlichkeit aus dem technischen Scan nicht sicher bestimmbar.Notwendig1 Eintrag/Einträge · Technisch erforderliche Einträge für Betrieb, Sicherheit oder Consent-Nachweis.Präferenzen1 Eintrag/Einträge · Komfort-, Sprach-, Darstellungs- oder Funktionsspeicherungen.ingress-route-oxauth-cde-prodNotwendig · meist ohne Einwilligung · Anbieter id.cornelsen.de · Laufzeit kurz (0 Tage) · vor Consent gesehenecpdTimestampUnklassifiziert · unklar, prüfen · Anbieter cornelsen.de · Laufzeit Session · vor Consent gesehenemos_jcsidUnklassifiziert · unklar, prüfen · Anbieter cornelsen.de · Laufzeit Session · vor Consent gesehenfrontendUnklassifiziert · unklar, prüfen · Anbieter cornelsen.de · Laufzeit Session · vor Consent gesehenNeos.Neos.lastVisitedNodeUnklassifiziert · unklar, prüfen · Anbieter Eigene Website oder eingebundener Dienst · Laufzeit Sitzung/Tab · vor Consent gesehenecpWidgetAutoLoginTimestampPräferenzen · kontextabhängig 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?

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

Nachweis

Bilder ohne alt1Felder ohne Label0Buttons ohne Namen6HTML langjaH11Viewportja

WCAG/EAA-Prüfpunkte

Alternativtexte für BilderWCAG 1.1.1 Non-text Content · prüfen · Impact mittel · 1 von 31 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 23 Formularfeld(er) ohne erkennbare Beschriftung.Buttons mit Namen versehenWCAG 4.1.2 Name, Role, Value · prüfen · Impact hoch · 6 von 14 Button(s) ohne erkennbaren Namen.Seitensprache auszeichnenWCAG 3.1.1 Language of Page · ok · Impact niedrig · HTML-lang-Attribut gefunden.ÜberschriftenstrukturWCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels · ok · Impact niedrig · 1 H1 und 10 Ü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?

Entwurf mit 2 bekannten Barrierefreiheits-Punkt(en) 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 öffnen2 bekannte Issue-Signal(e) aus dem Scan.Alternativtexte für BilderWCAG 1.1.1 Non-text Content · Impact mittel · 1 von 31 Bild(er) ohne alt-Text im HTML-Sample.Buttons mit Namen versehenWCAG 4.1.2 Name, Role, Value · Impact hoch · 6 von 14 Button(s) ohne erkennbaren Namen.

DSGVO, Cookies & Tracking

Welche Datenschutz-Signale fallen auf?

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

Tracking

Keine bekannten Tracking-Scripts erkannt.

Cookies

Keine Set-Cookie-Header erkannt.

Seiteninhalt & Keywords

Worum geht es auf der Seite?

Cornelsen Verlag | Cornelsen
Der Cornelsen Verlag bietet Bildungsmedien wie Schulbücher, Arbeitshefte und Materialien für den Unterricht für Lernende und Lehrende.

zurück18reihen15cornelsen14fächer12bundesländer12deutsch10buch10lehrwerke9

Technologie-Erkennung

Womit wurde die Seite gebaut?

Server: nginx · Powered-by: nicht erkannt · Generator: nicht erkannt

Google DoubleClickAnalyticsGoogle Tag ManagerAnalyticsMeta/Facebook PixelAnalyticsMicrosoft ClarityAnalyticsPinterest TagAnalyticsnginxServer

CVE & Versionsrisiko

Gibt es Hinweise auf bekannte Schwachstellen?

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

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

Impressum & Betreibertransparenz

Sind rechtliche Hinweise erkennbar?

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

Kein Impressum-Link erkanntwarning

Performance / PageSpeed-Basis

Wirkt die Seite schnell und mobil nutzbar?

Score: 88 · Antwortzeit: 111 ms · HTML: 256071 Bytes · Viewport: ja

HTML-Antwort ist großinfoKomprimierung nicht erkanntinfo

Infrastruktur & TLS-Vertrauen

Wie professionell wirkt DNS, HTTPS und E-Mail-Schutz?

IPs: 3 · IPv6: nein · Zertifikat: 147 Tage · HSTS: ja · MX/SPF/DMARC: ja/ja/ja

CAA-Record fehltinfo

Security-Header

Welche Browser-Schutzheader sind gesetzt?

4 von 9 wichtigen Security-Headern vorhanden, 4 korrekt bewertet. CSP wirksam mit 2 Direktive(n), 0 Warnung(en), 2 Hinweis(e). Score: 70 · vorhanden: 4 · fehlen: 5 · prüfen: 0

Betreiber-Guide Security-Header öffnen

Header-Evidence

HSTSok · max-age=63072000Content-Security-Policyok · frame-ancestors 'self'; report-uri /__csp-reportX-Frame-Optionsfehlt · DENY oder SAMEORIGINX-Content-Type-Optionsok · nosniffReferrer-Policyok · strict-origin-when-cross-originPermissions-Policyfehlt · Nicht benötigte Browser-APIs wie Kamera, Mikrofon und Geolocation sperren.Cross-Origin-Opener-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 öffnen4 vorhanden, 5 fehlen, 0 prüfen.

CSP-Qualität

CSP ohne object-srcinfoCSP ohne base-uriinfo

Skript-Lieferkette

Externe Skript-Lieferkette aus dem gespeicherten Scan

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

Betreiber-Guide externe Skripte öffnen

Skriptquellen

Keine externen Skripte im Startseiten-Sample erkannt.

Zusammenhänge & Servernetzwerk

Welche Domains und IDs wirken verbunden?

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

Signale

Google Tag Managergtm-setupGoogle Tag Managergtm-initGoogle Tag ManagerGTM-K49K738mental-health-coaches.de1 Link(s)veranstaltungen.cornelsen.de1 Link(s)

Servernetz

35.159.188.242IPv4 · ec2-35-159-188-242.eu-central-1.compute.amazonaws.com63.179.172.150IPv4 · ec2-63-179-172-150.eu-central-1.compute.amazonaws.com63.184.61.207IPv4 · ec2-63-184-61-207.eu-central-1.compute.amazonaws.com35.159.188.0/24sichtbares Netz63.179.172.0/24sichtbares Netz63.184.61.0/24sichtbares Netz

SEO, Verhalten & Cloaking

Gibt es manipulative Signale?

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

Canonical zeigt auf fremde Domainwarning

Alle Hinweise

Möglicherweise nicht notwendige Cookies vor Einwilligung Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Sensible URL-Schlüssel im Drittanbieter-Kontext Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Kein Impressum-Link erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Dateneingabe ohne klaren Datenschutzkontext Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Google Consent Mode Default nicht erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Neue Cookies nach Ablehnen erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Tracking-Pixel oder pixelnahe Requests erkannt Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Tracking-Hinweise im Storage nach Ablehnen Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Seiten-URL wird in Drittanbieter-Requests übertragen Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Canonical zeigt auf fremde Domain Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Erkannte Anbieter fehlen in der Datenschutzerklärung 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
Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden 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
Bilder ohne Alternativtext Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
HTML-Antwort ist groß Wichtig für Nutzer Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Komprimierung nicht erkannt 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
Cross-Origin-Embedder-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. Betreiber-Guide öffnen
Mindestens eine priorisierte Unterseite war nicht erfolgreich abrufbar 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
Consent-Banner mit Dark-Pattern-/UX-Risiko Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence.
Permissions-Policy fehlt Technischer Hinweis Scan-Hinweis ohne zusätzliche Detail-Evidence. 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 und daraus abgeleitete Grenzen. Betreiber-Guides, Planungen und allgemeine Empfehlungen sind ausgelagert.",
    "host": "cornelsen.de",
    "normalized_url": "https://cornelsen.de/",
    "score": 0,
    "verdict": {
        "color": "red",
        "label": "riskant",
        "score": 0
    },
    "scan_id": "c14a85b0-9b07-414d-9b74-fd9e613c0fbf",
    "created_at": "2026-06-13 00:11:56.529194+02",
    "evidence": {
        "dns": {
            "ok": true,
            "addresses": [
                "35.159.188.242",
                "63.179.172.150",
                "63.184.61.207"
            ],
            "duration_ms": 12
        },
        "tls": {
            "ok": true,
            "cipher": "TLS_AES_128_GCM_SHA256",
            "issuer": [
                [
                    [
                        "countryName",
                        "US"
                    ]
                ],
                [
                    [
                        "organizationName",
                        "Amazon"
                    ]
                ],
                [
                    [
                        "commonName",
                        "Amazon RSA 2048 M01"
                    ]
                ]
            ],
            "subject": [
                [
                    [
                        "commonName",
                        "cornelsen.de"
                    ]
                ]
            ],
            "version": "TLSv1.3",
            "not_after": "Nov  6 23:59:59 2026 GMT",
            "hostname_matches": true,
            "days_until_expiry": 147,
            "subject_alt_names": [
                "cornelsen.de",
                "*.cornelsen.de",
                "*.mein.cornelsen.de"
            ],
            "issuer_common_name": "Amazon RSA 2048 M01"
        },
        "http": {
            "ok": true,
            "status": 200,
            "headers": {
                "date": "Fri, 12 Jun 2026 22:11:41 GMT",
                "vary": "Accept-Encoding",
                "server": "nginx",
                "connection": "close",
                "content-type": "text/html;charset=UTF-8",
                "content-length": "256071",
                "x-flow-powered": "Flow/8.3 Neos/8.3",
                "referrer-policy": "strict-origin-when-cross-origin",
                "x-xss-protection": "1; mode=block",
                "x-content-type-options": "nosniff",
                "content-security-policy": "frame-ancestors 'self'; report-uri /__csp-report",
                "strict-transport-security": "max-age=63072000"
            },
            "body_size": 200000,
            "final_url": "https://www.cornelsen.de/",
            "duration_ms": 111
        },
        "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": true,
            "caa": false,
            "spf": true,
            "dmarc": true,
            "dnssec": false
        },
        "googlebot_http": {
            "ok": true,
            "status": 200,
            "headers": {
                "date": "Fri, 12 Jun 2026 22:11:41 GMT",
                "vary": "Accept-Encoding",
                "server": "nginx",
                "connection": "close",
                "content-type": "text/html;charset=UTF-8",
                "content-length": "256071",
                "x-flow-powered": "Flow/8.3 Neos/8.3",
                "referrer-policy": "strict-origin-when-cross-origin",
                "x-xss-protection": "1; mode=block",
                "x-content-type-options": "nosniff",
                "content-security-policy": "frame-ancestors 'self'; report-uri /__csp-report",
                "strict-transport-security": "max-age=63072000"
            },
            "body_size": 200000,
            "final_url": "https://www.cornelsen.de/",
            "duration_ms": 692
        },
        "ai_search_policy_evidence": {
            "files": [
                {
                    "id": "robots_txt",
                    "url": "https://www.cornelsen.de/robots.txt",
                    "label": "robots.txt",
                    "reason": "",
                    "status": "found",
                    "body_size": 165,
                    "truncated": false,
                    "body_sha256": "c656cc5f95600a4c810f28091c11bce83333114bff072d45aa71820af06fc79b",
                    "duration_ms": 53,
                    "http_status": 200,
                    "ai_bot_policy": {
                        "bot_directives": {
                            "GPTBot": [
                                {
                                    "value": "/",
                                    "directive": "disallow"
                                }
                            ]
                        },
                        "explicit_ai_bots": [
                            "GPTBot"
                        ],
                        "explicit_ai_bot_count": 1,
                        "wildcard_directive_count": 2,
                        "wildcard_directives_sample": [
                            {
                                "value": "/neos/",
                                "directive": "disallow"
                            },
                            {
                                "value": "/sites/",
                                "directive": "disallow"
                            }
                        ]
                    },
                    "relevant_lines": [
                        "User-agent: *",
                        "Disallow: /neos/",
                        "Disallow: /sites/",
                        "User-agent: GPTBot",
                        "Disallow: /",
                        "User-agent: Bytespider",
                        "Disallow: /",
                        "Sitemap: https://www.cornelsen.de/sitemap.xml"
                    ]
                },
                {
                    "id": "llms_txt",
                    "url": "https://www.cornelsen.de/llms.txt",
                    "label": "llms.txt",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 290,
                    "http_status": 404,
                    "relevant_lines": []
                },
                {
                    "id": "ai_txt",
                    "url": "https://www.cornelsen.de/.well-known/ai.txt",
                    "label": "AI Policy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 318,
                    "http_status": 404,
                    "relevant_lines": []
                },
                {
                    "id": "ai_policy_txt",
                    "url": "https://www.cornelsen.de/.well-known/ai-policy.txt",
                    "label": "AI Policy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 294,
                    "http_status": 404,
                    "relevant_lines": []
                },
                {
                    "id": "ward_txt",
                    "url": "https://www.cornelsen.de/.well-known/ward.txt",
                    "label": "WARD Policy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 312,
                    "http_status": 404,
                    "relevant_lines": []
                }
            ],
            "origin": "https://www.cornelsen.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": 1
            },
            "summary": "1 von 5 Policy-Datei(en) gefunden; 1 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": [
                "GPTBot"
            ],
            "policy_file_count": 0,
            "llms_ward_policy_status": "not_publicly_verified",
            "robots_ai_policy_status": "explicit_ai_bot_policy"
        },
        "adtech_transparency_evidence": {
            "files": [
                {
                    "id": "ads_txt",
                    "url": "https://www.cornelsen.de/ads.txt",
                    "label": "ads.txt",
                    "reason": "http_error",
                    "status": "not_available",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 41,
                    "http_status": 503,
                    "ads_txt_policy": [],
                    "relevant_lines": [],
                    "sellers_json_policy": []
                },
                {
                    "id": "app_ads_txt",
                    "url": "https://www.cornelsen.de/app-ads.txt",
                    "label": "app-ads.txt",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 319,
                    "http_status": 404,
                    "ads_txt_policy": [],
                    "relevant_lines": [],
                    "sellers_json_policy": []
                },
                {
                    "id": "sellers_json",
                    "url": "https://www.cornelsen.de/sellers.json",
                    "label": "sellers.json",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 634,
                    "http_status": 404,
                    "ads_txt_policy": [],
                    "relevant_lines": [],
                    "sellers_json_policy": []
                }
            ],
            "origin": "https://www.cornelsen.de",
            "schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
            "status": "checked",
            "metrics": {
                "file_count": 3,
                "direct_count": 0,
                "reseller_count": 0,
                "found_file_count": 0,
                "ads_txt_entry_count": 0,
                "exchange_domain_count": 0,
                "app_ads_txt_entry_count": 0,
                "sellers_json_seller_count": 0
            },
            "summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
            "available": true,
            "guardrails": [
                "Nur feste Same-Origin-AdTech-Dateien",
                "Keine Off-Host-Redirects",
                "64-KB-Body-Limit",
                "Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
            ],
            "direct_count": 0,
            "ads_txt_found": false,
            "reseller_count": 0,
            "app_ads_txt_found": false,
            "sellers_json_found": false,
            "ads_txt_entry_count": 0,
            "exchange_domain_count": 0,
            "sellers_json_parse_ok": false,
            "app_ads_txt_entry_count": 0,
            "sellers_json_seller_count": 0
        },
        "security_trust_policy_evidence": {
            "files": [
                {
                    "id": "security_txt",
                    "url": "https://www.cornelsen.de/.well-known/security.txt",
                    "label": "security.txt",
                    "reason": "",
                    "status": "found",
                    "body_size": 396,
                    "truncated": false,
                    "body_sha256": "e162d4c8f7f6f1eabaa73770d142aa1011fc295f2d12918a32e4dfab0b61030c",
                    "duration_ms": 349,
                    "http_status": 200,
                    "relevant_lines": [
                        "# Languages",
                        "Preferred-Languages: en, de",
                        "# Please, primarily use our vulnerability disclosure program at Intigriti",
                        "Contact: https://app.intigriti.com/company/programs/cornelsen/cornelsenvdp",
                        "# If this is not an option for you, use email as fallback",
                        "Contact: mailto:security@cornelsen.de",
                        "# Jobs @ Cornelsen",
                        "Hiring: https://www.cornelsen.de/karriere/stellenangebote",
                        "Expires: 2044-11-03T16:09:00.000Z"
                    ],
                    "security_txt_policy": {
                        "field_count": 5,
                        "contact_count": 2,
                        "expires_values": [
                            "2044-11-03T16:09:00.000Z"
                        ],
                        "fields_present": [
                            "contact",
                            "expires",
                            "hiring",
                            "preferred-languages"
                        ],
                        "policy_present": false,
                        "contact_samples": [
                            "https://app.intigriti.com/company/programs/cornelsen/cornelsenvdp",
                            "mailto:security@cornelsen.de"
                        ],
                        "expires_present": true,
                        "canonical_present": false,
                        "encryption_present": false,
                        "preferred_languages": [
                            "en, de"
                        ]
                    }
                },
                {
                    "id": "security_txt_legacy",
                    "url": "https://www.cornelsen.de/security.txt",
                    "label": "security.txt legacy",
                    "reason": "http_error",
                    "status": "missing",
                    "body_size": 0,
                    "truncated": false,
                    "body_sha256": "",
                    "duration_ms": 304,
                    "http_status": 404,
                    "relevant_lines": [],
                    "security_txt_policy": []
                }
            ],
            "origin": "https://www.cornelsen.de",
            "schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
            "status": "checked",
            "metrics": {
                "file_count": 2,
                "field_count": 5,
                "contact_count": 2,
                "found_file_count": 1,
                "preferred_well_known_found": 1
            },
            "summary": "1 von 2 security.txt-Ziel(en) gefunden; 2 Kontaktfeld(er), 5 strukturierte Feld(er).",
            "available": true,
            "guardrails": [
                "Nur feste Same-Origin-security.txt-Ziele",
                "Keine Off-Host-Redirects",
                "64-KB-Body-Limit",
                "Öffentlich nur Hash, Status und kurze relevante Zeilen"
            ],
            "field_count": 5,
            "contact_count": 2,
            "fields_present": [
                "contact",
                "expires",
                "hiring",
                "preferred-languages"
            ],
            "policy_present": false,
            "expires_present": true,
            "encryption_present": false,
            "security_txt_found": true,
            "preferred_well_known_found": true
        }
    },
    "findings": [
        {
            "id": "pre_consent_nonessential_cookies",
            "title": "Möglicherweise nicht notwendige Cookies vor Einwilligung",
            "public": true,
            "source": "chromium_cookie_inventory",
            "cookies": [
                "ecpdTimestamp",
                "emos_jcsid",
                "frontend"
            ],
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 127,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "third_party_sensitive_query_leak",
            "count": 1,
            "title": "Sensible URL-Schlüssel im Drittanbieter-Kontext",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 126,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "imprint_missing",
            "title": "Kein Impressum-Link erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 125,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "data_entry_privacy_context_missing",
            "title": "Dateneingabe ohne klaren Datenschutzkontext",
            "public": true,
            "audience": "nutzer",
            "category": "data_entry",
            "severity": "warning",
            "user_importance": 122,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "consent_state_reject_evidence_failed",
            "title": "Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 120,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "google_consent_mode_missing",
            "title": "Google Consent Mode Default nicht erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 120,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "post_reject_new_cookies",
            "count": 1,
            "title": "Neue Cookies nach Ablehnen erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 119,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "tracking_pixel_detected",
            "count": 1,
            "title": "Tracking-Pixel oder pixelnahe Requests erkannt",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "info",
            "user_importance": 119,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "post_reject_tracking_storage_hints",
            "count": 1,
            "title": "Tracking-Hinweise im Storage nach Ablehnen",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 118,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "third_party_page_url_parameter",
            "count": 1,
            "title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 118,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "external_canonical",
            "title": "Canonical zeigt auf fremde Domain",
            "public": true,
            "audience": "nutzer",
            "category": "seo",
            "severity": "warning",
            "canonical_url": "https://www.cornelsen.de/",
            "user_importance": 118,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "privacy_policy_provider_disclosure_gap",
            "title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
            "public": true,
            "audience": "nutzer",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 116,
            "importance_label": "Wichtig für Nutzer",
            "missing_providers": [
                "Google Tag Manager"
            ]
        },
        {
            "id": "browser_keystroke_listener_signals",
            "count": 220,
            "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": "important_pages_not_discovered",
            "title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
            "public": true,
            "audience": "nutzer",
            "category": "crawl",
            "severity": "warning",
            "user_importance": 88,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "button_name_missing",
            "count": 6,
            "title": "Buttons ohne erkennbaren Namen",
            "public": true,
            "audience": "nutzer",
            "category": "accessibility",
            "severity": "warning",
            "user_importance": 86,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "image_alt_missing",
            "count": 1,
            "title": "Bilder ohne Alternativtext",
            "public": true,
            "audience": "nutzer",
            "category": "accessibility",
            "severity": "info",
            "user_importance": 82,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "large_html_response",
            "title": "HTML-Antwort ist groß",
            "public": true,
            "audience": "nutzer",
            "category": "performance",
            "severity": "info",
            "user_importance": 82,
            "importance_label": "Wichtig für Nutzer"
        },
        {
            "id": "csp_missing_object_src",
            "title": "CSP ohne object-src",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 76,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "compression_missing",
            "title": "Komprimierung nicht erkannt",
            "public": true,
            "audience": "betreiber",
            "category": "performance",
            "severity": "info",
            "user_importance": 76,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "csp_missing_base_uri",
            "title": "CSP ohne base-uri",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 74,
            "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_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": "sampled_internal_page_error",
            "title": "Mindestens eine priorisierte Unterseite war nicht erfolgreich abrufbar",
            "public": true,
            "audience": "betreiber",
            "category": "crawl",
            "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": "consent_banner_dark_pattern_risk",
            "count": 1,
            "title": "Consent-Banner mit Dark-Pattern-/UX-Risiko",
            "public": true,
            "audience": "betreiber",
            "category": "privacy",
            "severity": "warning",
            "user_importance": 60,
            "importance_label": "Technischer Hinweis"
        },
        {
            "id": "missing_permissions_policy",
            "title": "Permissions-Policy fehlt",
            "public": true,
            "audience": "betreiber",
            "category": "security_headers",
            "severity": "info",
            "user_importance": 40,
            "importance_label": "Technischer Hinweis"
        }
    ],
    "audit_modules": [
        {
            "id": "privacy_consent",
            "color": "red",
            "score": 18,
            "title": "Datenschutz, Cookies & Consent",
            "source": "Browser, HTTP-Header, HTML und Consent-/Cookie-Heuristik",
            "status": "kritisch",
            "evidence": "0 Tracking-Script(s), 4 Cookie(s) vor Einwilligung, 0 Tracking-Cookie(s), Ablehnen-Option: nein, Consent-Audit: 18."
        },
        {
            "id": "site_coverage",
            "color": "red",
            "score": 39,
            "title": "Seitenabdeckung & Crawl",
            "source": "Startseiten-Links, Compliance-Links und begrenzter interner Zusatzabruf",
            "status": "kritisch",
            "evidence": "30 interne Linkziele erkannt, 4 priorisierte Unterseite(n) abgerufen."
        },
        {
            "id": "google_third_parties",
            "color": "red",
            "score": 40,
            "title": "Google-Dienste & Drittanbieter",
            "source": "Chromium-Requests, Anbieterklassifikation und Google Consent Mode Heuristik",
            "status": "kritisch",
            "evidence": "Google-Tags: ja, 0 Google-nahe Domain(s), Consent-Default: nein, Analytics: nein, Werbung: nein, Fonts: nein."
        },
        {
            "id": "browser_evidence",
            "color": "red",
            "score": 47,
            "title": "Browser-Nachweis",
            "source": "Headless Chromium mit Screenshot- und Request-Telemetrie",
            "status": "kritisch",
            "evidence": "71 Request(s), 4 Drittanbieter-Domain(s), davon 0 datenschutzrelevant, 4 Browser-Cookie(s), Transfer-Prüfbedarf: 0, Referrer-/URL-Leaks: 1, Fingerprinting-/Replay-Hinweise: 1."
        },
        {
            "id": "operator_transparency",
            "color": "orange",
            "score": 55,
            "title": "Impressum, Kontakt & Datenschutzerklärung",
            "source": "Deutschsprachige Betreiber- und Datenschutzhinweis-Erkennung",
            "status": "auffällig",
            "evidence": "Impressum: nein, Datenschutz: nein, Kontakt: ja."
        },
        {
            "id": "referrer_url_leaks",
            "color": "orange",
            "score": 68,
            "title": "Referrer & URL-Leaks",
            "source": "Chromium-Request-Telemetrie ohne gespeicherte Parameterwerte",
            "status": "auffällig",
            "evidence": "1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 1 sensible Query-Kontexte."
        },
        {
            "id": "security_tls",
            "color": "orange",
            "score": 70,
            "title": "Sicherheit, TLS & Header",
            "source": "DNS, TLS, HTTP-Status, Zertifikat und Security-Header",
            "status": "auffällig",
            "evidence": "1 Infrastruktur-Hinweis(e), Security-Header: 4/9 vorhanden, 5 fehlen, externe Skript-Hosts: 0."
        },
        {
            "id": "accessibility_usability",
            "color": "orange",
            "score": 72,
            "title": "Barrierefreiheit & Usability",
            "source": "Passives HTML-Sample: Bilder, Formulare, Buttons, Sprache, Headings und Viewport",
            "status": "auffällig",
            "evidence": "1 Bild(er) ohne alt, 0 Formularfeld(er) ohne Beschriftung, 6 Button(s) ohne Namen."
        },
        {
            "id": "forms_payments",
            "color": "yellow",
            "score": 75,
            "title": "Formulare, Login & Zahlung",
            "source": "HTML-Formulare, Eingabefelder, Zahlungsanbieter und Kontextlinks",
            "status": "prüfen",
            "evidence": "Die Seite kann Name/personenbezogene Daten abfragen."
        },
        {
            "id": "seo_integrity",
            "color": "yellow",
            "score": 82,
            "title": "SEO-Integrität & Cloaking",
            "source": "HTML-Inhalt, strukturierte Daten, Links und Googlebot-Vergleich",
            "status": "prüfen",
            "evidence": "1 SEO-Spam-Hinweis(e), 0 Cloaking-Hinweis(e)."
        },
        {
            "id": "performance_mobile",
            "color": "yellow",
            "score": 88,
            "title": "Performance & mobile Nutzbarkeit",
            "source": "HTTP-Antwort, HTML-Größe, Komprimierung und mobile Basis",
            "status": "prüfen",
            "evidence": "Performance-Score 88, Antwortzeit 111 ms."
        },
        {
            "id": "cookie_inventory",
            "color": "green",
            "score": 90,
            "title": "Cookie-Inventar",
            "source": "HTTP-Set-Cookie und Chromium-Cookies beim ersten Seitenaufruf",
            "status": "unauffällig",
            "evidence": "4 Cookie(s), 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebig, 0 sehr lang."
        },
        {
            "id": "tracking_pixels_beacons",
            "color": "green",
            "score": 90,
            "title": "Tracking-Pixel & Beacons",
            "source": "HTML-Pixel, Link-Ping-Attribute, Chromium-Requests und Browser-API-Instrumentierung",
            "status": "unauffällig",
            "evidence": "1 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s)."
        },
        {
            "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": "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": "script_supply_chain",
            "color": "green",
            "score": 100,
            "title": "Externe Skripte & SRI",
            "source": "HTML-Script-Tags, Anbieterklassifikation und SRI-Attribute",
            "status": "unauffällig",
            "evidence": "0 externe Skript(e) von 0 Host(s), 0 ohne SRI, 0 Tracking-/Tag-nahe Skript(e)."
        },
        {
            "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."
        }
    ],
    "ai_search_policy_evidence": {
        "files": [
            {
                "id": "robots_txt",
                "url": "https://www.cornelsen.de/robots.txt",
                "label": "robots.txt",
                "reason": "",
                "status": "found",
                "body_size": 165,
                "truncated": false,
                "body_sha256": "c656cc5f95600a4c810f28091c11bce83333114bff072d45aa71820af06fc79b",
                "duration_ms": 53,
                "http_status": 200,
                "ai_bot_policy": {
                    "bot_directives": {
                        "GPTBot": [
                            {
                                "value": "/",
                                "directive": "disallow"
                            }
                        ]
                    },
                    "explicit_ai_bots": [
                        "GPTBot"
                    ],
                    "explicit_ai_bot_count": 1,
                    "wildcard_directive_count": 2,
                    "wildcard_directives_sample": [
                        {
                            "value": "/neos/",
                            "directive": "disallow"
                        },
                        {
                            "value": "/sites/",
                            "directive": "disallow"
                        }
                    ]
                },
                "relevant_lines": [
                    "User-agent: *",
                    "Disallow: /neos/",
                    "Disallow: /sites/",
                    "User-agent: GPTBot",
                    "Disallow: /",
                    "User-agent: Bytespider",
                    "Disallow: /",
                    "Sitemap: https://www.cornelsen.de/sitemap.xml"
                ]
            },
            {
                "id": "llms_txt",
                "url": "https://www.cornelsen.de/llms.txt",
                "label": "llms.txt",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 290,
                "http_status": 404,
                "relevant_lines": []
            },
            {
                "id": "ai_txt",
                "url": "https://www.cornelsen.de/.well-known/ai.txt",
                "label": "AI Policy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 318,
                "http_status": 404,
                "relevant_lines": []
            },
            {
                "id": "ai_policy_txt",
                "url": "https://www.cornelsen.de/.well-known/ai-policy.txt",
                "label": "AI Policy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 294,
                "http_status": 404,
                "relevant_lines": []
            },
            {
                "id": "ward_txt",
                "url": "https://www.cornelsen.de/.well-known/ward.txt",
                "label": "WARD Policy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 312,
                "http_status": 404,
                "relevant_lines": []
            }
        ],
        "origin": "https://www.cornelsen.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": 1
        },
        "summary": "1 von 5 Policy-Datei(en) gefunden; 1 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": [
            "GPTBot"
        ],
        "policy_file_count": 0,
        "llms_ward_policy_status": "not_publicly_verified",
        "robots_ai_policy_status": "explicit_ai_bot_policy"
    },
    "adtech_transparency_evidence": {
        "files": [
            {
                "id": "ads_txt",
                "url": "https://www.cornelsen.de/ads.txt",
                "label": "ads.txt",
                "reason": "http_error",
                "status": "not_available",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 41,
                "http_status": 503,
                "ads_txt_policy": [],
                "relevant_lines": [],
                "sellers_json_policy": []
            },
            {
                "id": "app_ads_txt",
                "url": "https://www.cornelsen.de/app-ads.txt",
                "label": "app-ads.txt",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 319,
                "http_status": 404,
                "ads_txt_policy": [],
                "relevant_lines": [],
                "sellers_json_policy": []
            },
            {
                "id": "sellers_json",
                "url": "https://www.cornelsen.de/sellers.json",
                "label": "sellers.json",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 634,
                "http_status": 404,
                "ads_txt_policy": [],
                "relevant_lines": [],
                "sellers_json_policy": []
            }
        ],
        "origin": "https://www.cornelsen.de",
        "schema": "https://saferpage.de/schemas/adtech-transparency-evidence.v1",
        "status": "checked",
        "metrics": {
            "file_count": 3,
            "direct_count": 0,
            "reseller_count": 0,
            "found_file_count": 0,
            "ads_txt_entry_count": 0,
            "exchange_domain_count": 0,
            "app_ads_txt_entry_count": 0,
            "sellers_json_seller_count": 0
        },
        "summary": "0 von 3 AdTech-Transparenzdatei(en) gefunden; 0 DIRECT- und 0 RESELLER-Zeile(n).",
        "available": true,
        "guardrails": [
            "Nur feste Same-Origin-AdTech-Dateien",
            "Keine Off-Host-Redirects",
            "64-KB-Body-Limit",
            "Öffentlich nur Hash, Status, Zähler und kurze relevante Zeilen"
        ],
        "direct_count": 0,
        "ads_txt_found": false,
        "reseller_count": 0,
        "app_ads_txt_found": false,
        "sellers_json_found": false,
        "ads_txt_entry_count": 0,
        "exchange_domain_count": 0,
        "sellers_json_parse_ok": false,
        "app_ads_txt_entry_count": 0,
        "sellers_json_seller_count": 0
    },
    "security_trust_policy_evidence": {
        "files": [
            {
                "id": "security_txt",
                "url": "https://www.cornelsen.de/.well-known/security.txt",
                "label": "security.txt",
                "reason": "",
                "status": "found",
                "body_size": 396,
                "truncated": false,
                "body_sha256": "e162d4c8f7f6f1eabaa73770d142aa1011fc295f2d12918a32e4dfab0b61030c",
                "duration_ms": 349,
                "http_status": 200,
                "relevant_lines": [
                    "# Languages",
                    "Preferred-Languages: en, de",
                    "# Please, primarily use our vulnerability disclosure program at Intigriti",
                    "Contact: https://app.intigriti.com/company/programs/cornelsen/cornelsenvdp",
                    "# If this is not an option for you, use email as fallback",
                    "Contact: mailto:security@cornelsen.de",
                    "# Jobs @ Cornelsen",
                    "Hiring: https://www.cornelsen.de/karriere/stellenangebote",
                    "Expires: 2044-11-03T16:09:00.000Z"
                ],
                "security_txt_policy": {
                    "field_count": 5,
                    "contact_count": 2,
                    "expires_values": [
                        "2044-11-03T16:09:00.000Z"
                    ],
                    "fields_present": [
                        "contact",
                        "expires",
                        "hiring",
                        "preferred-languages"
                    ],
                    "policy_present": false,
                    "contact_samples": [
                        "https://app.intigriti.com/company/programs/cornelsen/cornelsenvdp",
                        "mailto:security@cornelsen.de"
                    ],
                    "expires_present": true,
                    "canonical_present": false,
                    "encryption_present": false,
                    "preferred_languages": [
                        "en, de"
                    ]
                }
            },
            {
                "id": "security_txt_legacy",
                "url": "https://www.cornelsen.de/security.txt",
                "label": "security.txt legacy",
                "reason": "http_error",
                "status": "missing",
                "body_size": 0,
                "truncated": false,
                "body_sha256": "",
                "duration_ms": 304,
                "http_status": 404,
                "relevant_lines": [],
                "security_txt_policy": []
            }
        ],
        "origin": "https://www.cornelsen.de",
        "schema": "https://saferpage.de/schemas/security-trust-policy-evidence.v1",
        "status": "checked",
        "metrics": {
            "file_count": 2,
            "field_count": 5,
            "contact_count": 2,
            "found_file_count": 1,
            "preferred_well_known_found": 1
        },
        "summary": "1 von 2 security.txt-Ziel(en) gefunden; 2 Kontaktfeld(er), 5 strukturierte Feld(er).",
        "available": true,
        "guardrails": [
            "Nur feste Same-Origin-security.txt-Ziele",
            "Keine Off-Host-Redirects",
            "64-KB-Body-Limit",
            "Öffentlich nur Hash, Status und kurze relevante Zeilen"
        ],
        "field_count": 5,
        "contact_count": 2,
        "fields_present": [
            "contact",
            "expires",
            "hiring",
            "preferred-languages"
        ],
        "policy_present": false,
        "expires_present": true,
        "encryption_present": false,
        "security_txt_found": true,
        "preferred_well_known_found": true
    },
    "site_coverage_analysis": {
        "color": "red",
        "pages": [
            {
                "url": "https://www.cornelsen.de/80-jahre/day-camps-erleben",
                "path": "/80-jahre/day-camps-erleben",
                "text": "80 Day Camps zu gewinnen",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung",
                "path": "/berufliche-bildung",
                "text": "Berufliche Bildung",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/alle-bundeslaender",
                "path": "/berufliche-bildung/alle-bundeslaender",
                "text": "Alle Bundesländer",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/baden-wuerttemberg",
                "path": "/berufliche-bildung/baden-wuerttemberg",
                "text": "Baden-Württemberg",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/bayern",
                "path": "/berufliche-bildung/bayern",
                "text": "Bayern",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher",
                "path": "/berufliche-bildung/faecher",
                "text": "Alle Fächer",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher/deutsch",
                "path": "/berufliche-bildung/faecher/deutsch",
                "text": "Deutsch",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher/deutsch-als-zweitsprache",
                "path": "/berufliche-bildung/faecher/deutsch-als-zweitsprache",
                "text": "Deutsch als Zweitsprache",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher/englisch",
                "path": "/berufliche-bildung/faecher/englisch",
                "text": "Englisch",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher/gesundheit",
                "path": "/berufliche-bildung/faecher/gesundheit",
                "text": "Gesundheit",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher/mathematik",
                "path": "/berufliche-bildung/faecher/mathematik",
                "text": "Mathematik",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            },
            {
                "url": "https://www.cornelsen.de/berufliche-bildung/faecher/metalltechnik-fertigungstechnik",
                "path": "/berufliche-bildung/faecher/metalltechnik-fertigungstechnik",
                "text": "Metalltechnik/Fertigungstechnik",
                "source": "homepage_link",
                "category": "unterseite",
                "priority": 20
            }
        ],
        "score": 39,
        "status": "kritisch",
        "summary": "30 interne Linkziele erkannt (0 aus Sitemap), 4 priorisierte Unterseite(n) zusätzlich abgerufen.",
        "findings": [
            {
                "id": "important_pages_not_discovered",
                "title": "Wichtige Betreiberseiten nicht vollständig in der Linkstruktur gefunden",
                "public": true,
                "category": "crawl",
                "severity": "warning"
            },
            {
                "id": "sampled_internal_page_error",
                "title": "Mindestens eine priorisierte Unterseite war nicht erfolgreich abrufbar",
                "public": true,
                "category": "crawl",
                "severity": "info"
            },
            {
                "id": "privacy_policy_provider_disclosure_gap",
                "title": "Erkannte Anbieter fehlen in der Datenschutzerklärung",
                "public": true,
                "category": "privacy",
                "severity": "warning",
                "missing_providers": [
                    "Google Tag Manager"
                ]
            }
        ],
        "robots_ok": true,
        "categories": {
            "unterseite": 30
        },
        "sample_limit": 4,
        "sampled_count": 4,
        "sampled_pages": [
            {
                "ok": false,
                "url": "https://www.cornelsen.de/80-jahre/day-camps-erleben",
                "path": "/80-jahre/day-camps-erleben",
                "audit": [],
                "forms": 0,
                "title": "",
                "status": 503,
                "category": "unterseite",
                "duration_ms": 25,
                "privacy_hint": false,
                "privacy_policy_audit": []
            },
            {
                "ok": false,
                "url": "https://www.cornelsen.de/berufliche-bildung",
                "path": "/berufliche-bildung",
                "audit": [],
                "forms": 0,
                "title": "",
                "status": 503,
                "category": "unterseite",
                "duration_ms": 23,
                "privacy_hint": false,
                "privacy_policy_audit": []
            },
            {
                "ok": false,
                "url": "https://www.cornelsen.de/berufliche-bildung/alle-bundeslaender",
                "path": "/berufliche-bildung/alle-bundeslaender",
                "audit": [],
                "forms": 0,
                "title": "",
                "status": 503,
                "category": "unterseite",
                "duration_ms": 24,
                "privacy_hint": false,
                "privacy_policy_audit": []
            },
            {
                "ok": true,
                "url": "https://www.cornelsen.de/berufliche-bildung/baden-wuerttemberg",
                "path": "/berufliche-bildung/baden-wuerttemberg",
                "audit": {
                    "form_count": 0,
                    "finding_ids": [
                        "imprint_missing"
                    ],
                    "cookie_count": 0,
                    "imprint_found": false,
                    "consent_hint_found": false,
                    "reject_option_found": false,
                    "privacy_policy_found": false,
                    "tracking_script_count": 0,
                    "pre_consent_cookie_count": 0,
                    "pre_consent_tracking_cookie_count": 0
                },
                "forms": 0,
                "title": "Berufliche Bildung Baden-Württemberg - Schulbücher | Cornelsen",
                "status": 200,
                "category": "unterseite",
                "duration_ms": 390,
                "privacy_hint": false,
                "privacy_policy_audit": []
            }
        ],
        "robots_checked": true,
        "sitemap_sources": [
            "https://www.cornelsen.de/sitemap.xml",
            "https://www.cornelsen.de/sitemap/aaa.xml",
            "https://www.cornelsen.de/sitemap/aab.xml"
        ],
        "sitemap_available": true,
        "sitemap_url_count": 0,
        "homepage_link_count": 205,
        "internal_link_count": 30,
        "privacy_policy_audit": [],
        "sitemap_source_count": 3,
        "provider_disclosure_audit": {
            "color": "red",
            "found": [],
            "score": 0,
            "checks": [
                {
                    "id": "tag_manager_google_tag_manager",
                    "found": false,
                    "category": "tag_manager",
                    "evidence": [
                        "gtm-setup",
                        "gtm-init",
                        "GTM-K49K738"
                    ],
                    "keywords": [
                        "google tag manager",
                        "tag manager",
                        "googletagmanager",
                        "gtm-"
                    ],
                    "provider": "Google Tag Manager",
                    "category_label": "Tracking-ID"
                }
            ],
            "reason": "no_policy_text",
            "status": "kritisch",
            "missing": [
                "Google Tag Manager"
            ],
            "summary": "1 technische Anbieter erkannt, aber keine Datenschutzerklärung im Sample ausgewertet.",
            "available": true,
            "missing_count": 1,
            "detected_count": 1,
            "mentioned_count": 0
        },
        "important_categories_found": [],
        "sampled_tracking_page_count": 0,
        "sampled_form_privacy_gap_count": 0,
        "sitemap_candidate_source_count": 1
    },
    "page_analysis": {
        "h1": [
            "Registrieren und Vorteile genießen"
        ],
        "h2": [
            "Unsere Empfehlungen für Sie",
            "Aktuelles",
            "Neuerscheinungen für die Sekundarstufe",
            "Themenwelten"
        ],
        "title": "Cornelsen Verlag | Cornelsen",
        "keywords": [
            [
                "zurück",
                18
            ],
            [
                "reihen",
                15
            ],
            [
                "cornelsen",
                14
            ],
            [
                "fächer",
                12
            ],
            [
                "bundesländer",
                12
            ],
            [
                "deutsch",
                10
            ],
            [
                "buch",
                10
            ],
            [
                "lehrwerke",
                9
            ],
            [
                "grundschule",
                8
            ],
            [
                "englisch",
                6
            ]
        ],
        "language": "de",
        "description": "Der Cornelsen Verlag bietet \nBildungsmedien wie Schulbücher, Arbeitshefte und Materialien für den Unterricht für Lernende und Lehrende.",
        "favicon_url": "https://www.cornelsen.de/_Resources/Static/Packages/Cornelsen.DesignKitPortals/Favicon/apple-touch-icon-57x57.png",
        "link_counts": {
            "external": 1,
            "internal": 204
        },
        "preview_image": "/cache/screenshots/cornelsen.de-160x150-83c5ba8fdfb02e498d.png",
        "screenshot_url": "/cache/screenshots/cornelsen.de-160x150-83c5ba8fdfb02e498d.png",
        "external_scripts": [],
        "browser_final_url": "https://www.cornelsen.de/",
        "meta_preview_image": "https://www.cornelsen.de/_Resources/Persistent/2/a/1/6/2a1656cdbe5fdcc824fd00c52370afaf20f0d16c/0001100000220_DIGI_CVINHA_220324_002_COR-Illu_DuF_Start-628x628.jpg",
        "screenshot_renderer": "playwright-chromium",
        "external_link_targets": [
            {
                "host": "veranstaltungen.cornelsen.de",
                "count": 1,
                "examples": [
                    {
                        "href": "https://veranstaltungen.cornelsen.de/",
                        "text": "Veranstaltungen"
                    }
                ],
                "nofollow": 0,
                "strength": "strong",
                "follow_count": 1
            }
        ]
    },
    "browser_analysis": {
        "cookies": {
            "items": [
                {
                    "name": "ingress-route-oxauth-cde-prod",
                    "domain": "id.cornelsen.de",
                    "secure": false,
                    "expires": 1781388702.80335,
                    "http_only": true,
                    "same_site": "Lax"
                },
                {
                    "name": "frontend",
                    "domain": ".cornelsen.de",
                    "secure": true,
                    "expires": -1,
                    "http_only": false,
                    "same_site": "None"
                },
                {
                    "name": "ecpdTimestamp",
                    "domain": ".cornelsen.de",
                    "secure": true,
                    "expires": -1,
                    "http_only": true,
                    "same_site": "None"
                },
                {
                    "name": "emos_jcsid",
                    "domain": ".cornelsen.de",
                    "secure": false,
                    "expires": -1,
                    "http_only": false,
                    "same_site": "Lax"
                }
            ],
            "total": 4,
            "third_party": 0
        },
        "storage": {
            "total": 2,
            "local_storage_keys": [],
            "tracking_key_hints": [],
            "local_storage_total": 0,
            "session_storage_keys": [
                "Neos.Neos.lastVisitedNode",
                "ecpWidgetAutoLoginTimestamp"
            ],
            "session_storage_total": 2
        },
        "findings": [
            {
                "id": "post_reject_new_cookies",
                "count": 1,
                "title": "Neue Cookies nach Ablehnen erkannt",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "post_reject_tracking_storage_hints",
                "count": 1,
                "title": "Tracking-Hinweise im Storage nach Ablehnen",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "third_party_page_url_parameter",
                "count": 1,
                "title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "third_party_sensitive_query_leak",
                "count": 1,
                "title": "Sensible URL-Schlüssel im Drittanbieter-Kontext",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "browser_keystroke_listener_signals",
                "count": 220,
                "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
                "public": true,
                "category": "privacy",
                "severity": "info"
            },
            {
                "id": "consent_state_reject_evidence_failed",
                "title": "Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus",
                "public": true,
                "category": "privacy",
                "severity": "warning"
            },
            {
                "id": "tracking_pixel_detected",
                "count": 1,
                "title": "Tracking-Pixel oder pixelnahe Requests erkannt",
                "public": true,
                "category": "privacy",
                "severity": "info"
            }
        ],
        "renderer": "playwright-chromium",
        "final_url": "https://www.cornelsen.de/",
        "consent_ui": {
            "accept_controls": [],
            "accept_max_area": 0,
            "reject_controls": [
                {
                    "tag": "a",
                    "top": 749,
                    "area": 2170,
                    "left": 513,
                    "text": "ablehnen",
                    "color": "rgb(0, 118, 136)",
                    "width": 70,
                    "height": 31,
                    "background": "rgba(0, 0, 0, 0)",
                    "font_weight": "400"
                }
            ],
            "reject_max_area": 2170,
            "settings_controls": [],
            "first_layer_summary": "Akzeptieren 0 / Ablehnen 1 / Einstellungen 0",
            "cookie_context_found": true,
            "reject_less_prominent": false,
            "visible_control_count": 29,
            "reject_prominence_ratio": 0
        },
        "gpc_signal": {
            "error": "",
            "enabled": true,
            "storage": {
                "total": 2,
                "tracking_key_hints": [],
                "local_storage_total": 0,
                "session_storage_total": 2
            },
            "cookie_count": 4,
            "request_count": 70,
            "sec_gpc_header": true,
            "navigator_value": true,
            "contacted_domains": [
                {
                    "host": "cornelsen.de",
                    "count": 48,
                    "category": "other",
                    "provider": "cornelsen.de",
                    "third_party": false,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "font": 8,
                        "fetch": 6,
                        "image": 18,
                        "script": 12,
                        "document": 1,
                        "stylesheet": 3
                    }
                },
                {
                    "host": "static.cornelsen.de",
                    "count": 17,
                    "category": "other",
                    "provider": "static.cornelsen.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "image": 17
                    }
                },
                {
                    "host": "l.ecn-ldr.de",
                    "count": 3,
                    "category": "other",
                    "provider": "l.ecn-ldr.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "script": 3
                    }
                },
                {
                    "host": "id.cornelsen.de",
                    "count": 1,
                    "category": "other",
                    "provider": "id.cornelsen.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "image": 1
                    }
                },
                {
                    "host": "mcw0nd.cornelsen.de",
                    "count": 1,
                    "category": "other",
                    "provider": "mcw0nd.cornelsen.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "script": 1
                    }
                }
            ],
            "contacted_domain_count": 5,
            "privacy_relevant_domains": [],
            "third_party_cookie_count": 0,
            "third_party_domain_count": 4,
            "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": true,
            "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": 71,
        "top_providers": [
            {
                "provider": "static.cornelsen.de",
                "request_count": 17
            },
            {
                "provider": "l.ecn-ldr.de",
                "request_count": 3
            },
            {
                "provider": "mcw0nd.cornelsen.de",
                "request_count": 2
            },
            {
                "provider": "id.cornelsen.de",
                "request_count": 1
            }
        ],
        "request_samples": [
            {
                "host": "mcw0nd.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": 5,
                "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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "static.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "id.cornelsen.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.de",
                    "has_path": false,
                    "has_query": false,
                    "same_site": true,
                    "path_depth": 0,
                    "query_keys": [],
                    "sensitive_query_key_count": 0
                },
                "has_query": true,
                "path_depth": 3,
                "query_keys": [
                    "redirect_uri",
                    "prompt",
                    "et",
                    "state",
                    "scope",
                    "response_type",
                    "approval_prompt",
                    "client_id"
                ],
                "third_party": true,
                "resource_type": "image",
                "query_key_count": 8,
                "url_value_param_count": 1,
                "sensitive_query_key_count": 1,
                "target_url_value_param_count": 1
            },
            {
                "host": "l.ecn-ldr.de",
                "method": "GET",
                "referrer": {
                    "host": "cornelsen.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": "l.ecn-ldr.de",
                "method": "GET",
                "referrer": null,
                "has_query": false,
                "path_depth": 4,
                "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": "l.ecn-ldr.de",
                "method": "GET",
                "referrer": null,
                "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": "mcw0nd.cornelsen.de",
                "method": "POST",
                "referrer": {
                    "host": "cornelsen.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": 0,
                "query_keys": [],
                "third_party": true,
                "resource_type": "xhr",
                "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": "cornelsen.de",
                "count": 48,
                "category": "other",
                "provider": "cornelsen.de",
                "third_party": false,
                "category_label": "Sonstige",
                "resource_types": {
                    "font": 8,
                    "fetch": 6,
                    "image": 18,
                    "script": 12,
                    "document": 1,
                    "stylesheet": 3
                }
            },
            {
                "host": "static.cornelsen.de",
                "count": 17,
                "category": "other",
                "provider": "static.cornelsen.de",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "image": 17
                }
            },
            {
                "host": "l.ecn-ldr.de",
                "count": 3,
                "category": "other",
                "provider": "l.ecn-ldr.de",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "script": 3
                }
            },
            {
                "host": "mcw0nd.cornelsen.de",
                "count": 2,
                "category": "other",
                "provider": "mcw0nd.cornelsen.de",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "xhr": 1,
                    "script": 1
                }
            },
            {
                "host": "id.cornelsen.de",
                "count": 1,
                "category": "other",
                "provider": "id.cornelsen.de",
                "third_party": true,
                "category_label": "Sonstige",
                "resource_types": {
                    "image": 1
                }
            }
        ],
        "consent_interaction": {
            "clicked_text": "ablehnen",
            "reject_clicked": true,
            "reject_available": true,
            "new_domains_after_reject": [
                {
                    "host": "mcw0nd.cornelsen.de",
                    "count": 1,
                    "category": "other",
                    "provider": "mcw0nd.cornelsen.de",
                    "third_party": true,
                    "category_label": "Sonstige",
                    "resource_types": {
                        "xhr": 1,
                        "script": 1
                    }
                }
            ],
            "cookie_count_after_reject": 5,
            "request_count_after_reject": 71,
            "storage_count_after_reject": 3,
            "new_cookie_count_after_reject": 1,
            "new_request_count_after_reject": 1,
            "privacy_relevant_domains_after_reject": [],
            "storage_tracking_hint_count_after_reject": 1,
            "privacy_relevant_domain_count_after_reject": 0
        },
        "privacy_api_metrics": {
            "api_calls": {
                "mutation_observer_count": 4,
                "keyboard_input_listener_count": 220,
                "session_interaction_listener_count": 452
            },
            "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": 220,
            "session_interaction_listener_count": 452
        },
        "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": "",
            "priority_fixes": [],
            "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": "mcw0nd.cornelsen.de",
                    "states": {
                        "gpc": 1,
                        "default": 2,
                        "reject_new": 1
                    },
                    "category": "other",
                    "provider": "mcw0nd.cornelsen.de",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 4
                },
                {
                    "host": "static.cornelsen.de",
                    "states": {
                        "gpc": 17,
                        "default": 17
                    },
                    "category": "other",
                    "provider": "static.cornelsen.de",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 34
                },
                {
                    "host": "l.ecn-ldr.de",
                    "states": {
                        "gpc": 3,
                        "default": 3
                    },
                    "category": "other",
                    "provider": "l.ecn-ldr.de",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 6
                },
                {
                    "host": "id.cornelsen.de",
                    "states": {
                        "gpc": 1,
                        "default": 1
                    },
                    "category": "other",
                    "provider": "id.cornelsen.de",
                    "category_label": "Sonstige",
                    "privacy_relevant": false,
                    "total_request_count": 2
                }
            ],
            "score": 100,
            "states": [
                {
                    "id": "default",
                    "label": "Erstaufruf",
                    "description": "Kontakte ohne Nutzeraktion",
                    "domain_count": 4,
                    "request_count": 23,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "reject_new",
                    "label": "Nach Ablehnen neu",
                    "description": "Neue Kontakte nach Ablehnen-Klick",
                    "domain_count": 1,
                    "request_count": 1,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "accept_new",
                    "label": "Nach Akzeptieren neu",
                    "description": "Neue Kontakte nach Akzeptieren-Klick",
                    "domain_count": 0,
                    "request_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "gpc",
                    "label": "GPC-Aufruf",
                    "description": "Kontakte bei Global Privacy Control",
                    "domain_count": 4,
                    "request_count": 22,
                    "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": 4,
                    "domain_count": 5,
                    "request_count": 71,
                    "storage_total": 2,
                    "new_cookie_count": 4,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 0
                },
                {
                    "id": "reject",
                    "label": "Nach Ablehnen",
                    "status": "geklickt",
                    "evidence": "ablehnen",
                    "risk_level": "hoch",
                    "cookie_count": 5,
                    "domain_count": 1,
                    "request_count": 71,
                    "storage_total": 3,
                    "new_cookie_count": 1,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 1,
                    "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": 4,
                    "domain_count": 5,
                    "request_count": 70,
                    "storage_total": 2,
                    "new_cookie_count": 0,
                    "third_party_cookie_count": 0,
                    "storage_tracking_hint_count": 0,
                    "privacy_relevant_domain_count": 0
                }
            ],
            "color": "orange",
            "score": 70,
            "status": "auffällig",
            "summary": "Consent-State-Evidence: 4 Zustände verglichen, 1 hoch auffällig, 0 mittel auffällig.",
            "findings": [
                {
                    "id": "consent_state_reject_evidence_failed",
                    "title": "Consent-Zustand: Ablehnen löst weiterhin Datenschutz-Signale aus",
                    "public": true,
                    "category": "privacy",
                    "severity": "warning"
                }
            ],
            "available": true,
            "high_count": 1,
            "medium_count": 0,
            "priority_fixes": [
                "Reject-Zustand gegen Cookies, Storage und Drittanbieter prüfen; nicht notwendige Signale nach Ablehnen blockieren."
            ]
        },
        "contacted_domain_count": 5,
        "fingerprinting_analysis": {
            "color": "yellow",
            "score": 88,
            "checks": [
                {
                    "id": "canvas",
                    "ok": true,
                    "count": 0,
                    "label": "Canvas-Auslese",
                    "detail": "0 Pixel-Lesezugriff(e), 0 Export(e)."
                },
                {
                    "id": "webgl",
                    "ok": true,
                    "count": 0,
                    "label": "WebGL-Merkmale",
                    "detail": "0 Parameterzugriff(e), 0 Pixel-Lesezugriff(e)."
                },
                {
                    "id": "audio",
                    "ok": true,
                    "count": 0,
                    "label": "AudioContext",
                    "detail": "0 AudioContext/OfflineAudioContext-Aufruf(e)."
                },
                {
                    "id": "session_replay",
                    "ok": true,
                    "count": 0,
                    "label": "Session-Replay-Anbieter",
                    "detail": "Keine bekannten Anbieter erkannt."
                },
                {
                    "id": "input_listeners",
                    "ok": false,
                    "count": 220,
                    "label": "Tastatur-/Eingabe-Listener",
                    "detail": "220 Tastatur-/Input-Listener, 452 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": 220,
                "session_interaction_listener_count": 452
            },
            "summary": "1 Fingerprinting-/Session-Replay-Hinweis(e) aus dem Browserlauf.",
            "findings": [
                {
                    "id": "browser_keystroke_listener_signals",
                    "count": 220,
                    "title": "Viele Tastatur-/Eingabe-Listener im Browser erkannt",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                }
            ],
            "finding_count": 1,
            "priority_fixes": [],
            "session_replay_domains": []
        },
        "privacy_relevant_domains": [],
        "provider_category_counts": {
            "other": 4
        },
        "provider_category_labels": {
            "other": "other"
        },
        "third_party_domain_count": 4,
        "embedded_content_analysis": {
            "color": "green",
            "items": [],
            "score": 100,
            "status": "unauffällig",
            "summary": "0 externe Embed-/Widget-Dienst(e), 0 davon im ersten Browseraufruf geladen.",
            "findings": [],
            "map_count": 0,
            "total_count": 0,
            "video_count": 0,
            "captcha_count": 0,
            "priority_fixes": [],
            "category_counts": [],
            "social_widget_count": 0,
            "loaded_pre_consent_count": 0,
            "request_count_by_provider": []
        },
        "referrer_leakage_analysis": {
            "color": "orange",
            "items": [
                {
                    "host": "id.cornelsen.de",
                    "category": "other",
                    "provider": "id.cornelsen.de",
                    "query_keys": [
                        "redirect_uri",
                        "prompt",
                        "et",
                        "state",
                        "scope",
                        "response_type",
                        "approval_prompt",
                        "client_id"
                    ],
                    "risk_reason": "sensibler Query-Schlüssel im Drittanbieter-Request oder Referrer",
                    "resource_type": "image",
                    "category_label": "Sonstige",
                    "referrer_query_keys": [],
                    "sensitive_query_key_count": 1,
                    "referrer_sensitive_query_key_count": 0
                },
                {
                    "host": "id.cornelsen.de",
                    "category": "other",
                    "provider": "id.cornelsen.de",
                    "query_keys": [
                        "redirect_uri",
                        "prompt",
                        "et",
                        "state",
                        "scope",
                        "response_type",
                        "approval_prompt",
                        "client_id"
                    ],
                    "risk_reason": "Seiten-URL oder URL-Wert in Drittanbieter-Requestparametern",
                    "resource_type": "image",
                    "category_label": "Sonstige",
                    "referrer_query_keys": [],
                    "url_value_param_count": 1,
                    "target_url_value_param_count": 1
                }
            ],
            "score": 68,
            "status": "auffällig",
            "summary": "1 Drittanbieter-Domain(s) mit Referrer-/URL-Leak-Prüfbedarf, 1 sensible Query-Kontexte.",
            "findings": [
                {
                    "id": "third_party_page_url_parameter",
                    "count": 1,
                    "title": "Seiten-URL wird in Drittanbieter-Requests übertragen",
                    "public": true,
                    "category": "privacy",
                    "severity": "warning"
                },
                {
                    "id": "third_party_sensitive_query_leak",
                    "count": 1,
                    "title": "Sensible URL-Schlüssel im Drittanbieter-Kontext",
                    "public": true,
                    "category": "privacy",
                    "severity": "warning"
                }
            ],
            "sample_count": 23,
            "priority_fixes": [
                "Tracking-/Tag-Parameter für Anbieter wie id.cornelsen.de so konfigurieren, dass keine unnötigen Pfade, Suchparameter oder Formularumfelder gesendet werden.",
                "Sensible Parameter wie E-Mail, Name, Token oder Session-IDs aus URLs entfernen und Drittanbieter-Tags auf solchen Seiten blockieren."
            ],
            "full_referrer_count": 0,
            "page_url_param_count": 1,
            "affected_domain_count": 1,
            "sensitive_query_count": 1
        },
        "third_party_contact_matrix": {
            "color": "yellow",
            "items": [
                {
                    "host": "static.cornelsen.de",
                    "region": "EU/EWR",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "static.cornelsen.de",
                    "risk_level": "niedrig",
                    "request_count": 17,
                    "transfer_risk": "niedrig",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "image",
                            "count": 17
                        }
                    ],
                    "transfer_label": "EU/EWR",
                    "privacy_relevant": false,
                    "recommended_action": "Zweck für Sonstige prüfen und bei Personenbezug dokumentieren.",
                    "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                },
                {
                    "host": "l.ecn-ldr.de",
                    "region": "EU/EWR",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "l.ecn-ldr.de",
                    "risk_level": "niedrig",
                    "request_count": 3,
                    "transfer_risk": "niedrig",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "script",
                            "count": 3
                        }
                    ],
                    "transfer_label": "EU/EWR",
                    "privacy_relevant": false,
                    "recommended_action": "Zweck für Sonstige prüfen und bei Personenbezug dokumentieren.",
                    "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                },
                {
                    "host": "mcw0nd.cornelsen.de",
                    "region": "EU/EWR",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "mcw0nd.cornelsen.de",
                    "risk_level": "niedrig",
                    "request_count": 2,
                    "transfer_risk": "niedrig",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "script",
                            "count": 1
                        },
                        {
                            "type": "xhr",
                            "count": 1
                        }
                    ],
                    "transfer_label": "EU/EWR",
                    "privacy_relevant": false,
                    "recommended_action": "Zweck für Sonstige prüfen und bei Personenbezug dokumentieren.",
                    "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                },
                {
                    "host": "id.cornelsen.de",
                    "region": "EU/EWR",
                    "status": "prüfen",
                    "category": "other",
                    "provider": "id.cornelsen.de",
                    "risk_level": "niedrig",
                    "request_count": 1,
                    "transfer_risk": "niedrig",
                    "category_label": "Sonstige",
                    "resource_types": [
                        {
                            "type": "image",
                            "count": 1
                        }
                    ],
                    "transfer_label": "EU/EWR",
                    "privacy_relevant": false,
                    "recommended_action": "Zweck für Sonstige prüfen und bei Personenbezug dokumentieren.",
                    "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                }
            ],
            "score": 87,
            "status": "prüfen",
            "summary": "4 Drittanbieter-Domain(s) beim ersten Browseraufruf, davon 0 datenschutzrelevant.",
            "priority_fixes": [],
            "category_counts": {
                "Sonstige": 4
            },
            "total_domain_count": 4,
            "total_request_count": 23,
            "privacy_relevant_count": 0,
            "transfer_risk_analysis": {
                "color": "green",
                "items": [
                    {
                        "host": "static.cornelsen.de",
                        "region": "EU/EWR",
                        "provider": "static.cornelsen.de",
                        "request_count": 17,
                        "transfer_risk": "niedrig",
                        "category_label": "Sonstige",
                        "transfer_label": "EU/EWR",
                        "privacy_relevant": false,
                        "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                    },
                    {
                        "host": "l.ecn-ldr.de",
                        "region": "EU/EWR",
                        "provider": "l.ecn-ldr.de",
                        "request_count": 3,
                        "transfer_risk": "niedrig",
                        "category_label": "Sonstige",
                        "transfer_label": "EU/EWR",
                        "privacy_relevant": false,
                        "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                    },
                    {
                        "host": "mcw0nd.cornelsen.de",
                        "region": "EU/EWR",
                        "provider": "mcw0nd.cornelsen.de",
                        "request_count": 2,
                        "transfer_risk": "niedrig",
                        "category_label": "Sonstige",
                        "transfer_label": "EU/EWR",
                        "privacy_relevant": false,
                        "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                    },
                    {
                        "host": "id.cornelsen.de",
                        "region": "EU/EWR",
                        "provider": "id.cornelsen.de",
                        "request_count": 1,
                        "transfer_risk": "niedrig",
                        "category_label": "Sonstige",
                        "transfer_label": "EU/EWR",
                        "privacy_relevant": false,
                        "transfer_recommendation": "Anbieterrolle, AVV und Hostingort dokumentieren."
                    }
                ],
                "score": 100,
                "status": "unauffällig",
                "summary": "4 Drittanbieter für Transfer-/Jurisdiktionsprüfung, 0 mit hohem Prüfbedarf, 0 unklar.",
                "findings": [],
                "unknown_count": 0,
                "priority_fixes": [],
                "high_risk_count": 0,
                "total_vendor_count": 4,
                "third_country_count": 0
            }
        },
        "privacy_relevant_domain_count": 0,
        "tracking_pixel_beacon_analysis": {
            "color": "green",
            "items": [
                {
                    "url": "",
                    "host": "id.cornelsen.de",
                    "kind": "browser_tracking_request",
                    "reason": "image-Request mit 8 Query-Schlüssel(n).",
                    "source": "chromium_request",
                    "category": "other",
                    "provider": "id.cornelsen.de",
                    "query_keys": [
                        "redirect_uri",
                        "prompt",
                        "et",
                        "state",
                        "scope",
                        "response_type",
                        "approval_prompt",
                        "client_id"
                    ],
                    "third_party": true,
                    "resource_type": "image",
                    "category_label": "Sonstige",
                    "recommended_action": "Drittanbieter-Pixel und Telemetrie-Requests vor Einwilligung blockieren oder datensparsam konfigurieren."
                }
            ],
            "score": 90,
            "status": "unauffällig",
            "summary": "1 Pixel-/Bildtracking-Hinweis(e), 0 Beacon-/Telemetry-Hinweis(e), 0 Link-Ping(s).",
            "findings": [
                {
                    "id": "tracking_pixel_detected",
                    "count": 1,
                    "title": "Tracking-Pixel oder pixelnahe Requests erkannt",
                    "public": true,
                    "category": "privacy",
                    "severity": "info"
                }
            ],
            "pixel_count": 1,
            "priority_fixes": [
                "Pixel von id.cornelsen.de erst nach Einwilligung laden, Zweck erklären und unnötige Bild-Tracker entfernen."
            ],
            "link_ping_count": 0,
            "telemetry_count": 0,
            "beacon_api_count": 0,
            "third_party_count": 1,
            "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": [
            {
                "type": "google_tag_manager",
                "value": "gtm-setup",
                "provider": "Google Tag Manager"
            },
            {
                "type": "google_tag_manager",
                "value": "gtm-init",
                "provider": "Google Tag Manager"
            },
            {
                "type": "google_tag_manager",
                "value": "GTM-K49K738",
                "provider": "Google Tag Manager"
            }
        ],
        "tracking_scripts": [],
        "consent_hint_found": false,
        "privacy_policy_hint_found": false
    },
    "consent_audit": {
        "color": "red",
        "score": 18,
        "checks": [
            {
                "id": "banner_visible",
                "ok": false,
                "fix": "Cookie-Banner oder Datenschutzeinstellungen klar sichtbar anbieten.",
                "label": "Cookie-/Consent-Hinweis sichtbar",
                "detail": "Ein Hinweis mit Cookie-/Einwilligungsbezug wurde im sichtbaren Text erkannt."
            },
            {
                "id": "reject_visible",
                "ok": true,
                "fix": "Ablehnen auf der ersten Ebene genauso erreichbar machen wie Akzeptieren.",
                "label": "Ablehnen gleichwertig erreichbar",
                "detail": "Ablehnen oder nur notwendige Cookies wurde im Text oder Browser erkannt. Browser-Buttons: 1."
            },
            {
                "id": "settings_visible",
                "ok": false,
                "fix": "Granulare Zwecke und Anbieter in einer zweiten Ebene anzeigen.",
                "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,
                "fix": "Ablehnen im ersten Banner-Layer sichtbar und genauso leicht erreichbar platzieren.",
                "label": "Ablehnen im sichtbaren Banner",
                "detail": "Sichtbare Banner-Controls: Akzeptieren 0, Ablehnen 1, Einstellungen 0."
            },
            {
                "id": "browser_settings_visible",
                "ok": true,
                "fix": "Eine gut sichtbare Schaltflaeche fuer Cookie-Auswahl oder Datenschutz-Einstellungen anbieten.",
                "label": "Einstellungen im sichtbaren Banner",
                "detail": "Sichtbare Banner-Controls: Akzeptieren 0, Ablehnen 1, Einstellungen 0."
            },
            {
                "id": "reject_equally_prominent",
                "ok": true,
                "fix": "Ablehnen in vergleichbarer Groesse und Sichtbarkeit wie Akzeptieren darstellen.",
                "label": "Ablehnen nicht deutlich schwaecher dargestellt",
                "detail": "Groessen-Verhältnis Ablehnen/Akzeptieren: nicht messbar."
            },
            {
                "id": "reject_button_clickable",
                "ok": true,
                "fix": "Ablehnen-Button als echten Button/Link umsetzen und ohne verdeckte Huerden ausloesen.",
                "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": false,
                "fix": "Nach Ablehnen nur technisch notwendige Cookies setzen und nicht notwendige Eintraege blockieren.",
                "label": "Keine neuen Cookies nach Ablehnen",
                "detail": "1 neue Cookie(s) nach dem Ablehnen-Klick."
            },
            {
                "id": "no_tracking_storage_after_reject",
                "ok": false,
                "fix": "LocalStorage/SessionStorage nach Ablehnen bereinigen und Tracking-IDs erst nach Zustimmung setzen.",
                "label": "Kein Tracking-Storage nach Ablehnen",
                "detail": "1 Tracking-Hinweis(e) im Web Storage nach Ablehnen."
            },
            {
                "id": "no_privacy_domains_after_reject",
                "ok": true,
                "fix": "Tag Manager, Analytics und Werbung nach Ablehnen deaktiviert lassen.",
                "label": "Keine neuen Tracking-Kontakte nach Ablehnen",
                "detail": "0 neue datenschutzrelevante Domain(s) nach Ablehnen."
            },
            {
                "id": "gpc_signal_respected",
                "ok": true,
                "fix": "Global Privacy Control als Opt-out-Signal technisch berücksichtigen und Tracking-/Sharing-Dienste entsprechend begrenzen.",
                "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,
                "fix": "Analytics-/Werbe-Cookies erst nach aktiver Zustimmung setzen.",
                "label": "Keine Tracking-Cookies vor Einwilligung",
                "detail": "0 Tracking-Cookie(s) im Erstaufruf."
            },
            {
                "id": "no_nonessential_cookies_before_consent",
                "ok": false,
                "fix": "Nicht notwendige Cookies blockieren oder als technisch notwendig begruenden.",
                "label": "Keine nicht notwendigen Cookies vor Einwilligung",
                "detail": "3 moeglicherweise nicht notwendige Cookie(s) im Erstaufruf."
            },
            {
                "id": "google_default_restrictive",
                "ok": false,
                "fix": "ad_storage, analytics_storage, ad_user_data und ad_personalization vorab auf denied setzen.",
                "label": "Google Consent Default restriktiv",
                "detail": "Google-Tags brauchen vor dem ersten Laden restriktive Consent-Defaults."
            },
            {
                "id": "third_parties_explained",
                "ok": true,
                "fix": "Drittanbieter reduzieren, lokal hosten oder in Consent und Datenschutzerklaerung konkret benennen.",
                "label": "Drittanbieter begrenzt und erklaerbar",
                "detail": "0 datenschutzrelevante Drittanbieter-Domain(s), 4 Drittanbieter insgesamt."
            },
            {
                "id": "storage_without_tracking_hints",
                "ok": true,
                "fix": "LocalStorage und SessionStorage wie Cookies inventarisieren und an Consent koppeln.",
                "label": "Web Storage ohne Tracking-Hinweise",
                "detail": "2 Storage-Key(s), 0 Tracking-Hinweis(e)."
            },
            {
                "id": "cmp_api_detected_when_needed",
                "ok": true,
                "fix": "Consent technisch nachvollziehbar machen und Widerruf/Status sauber dokumentieren.",
                "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,
                "fix": "Akzeptieren muss technisch klickbar sein; danach geladene Dienste in Cookie-Auswahl und Datenschutzerklärung abbilden.",
                "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,
                "fix": "CMP-Status, TCF-String und Consent-APIs technisch nachvollziehbar bereitstellen.",
                "label": "CMP-/TCF-Zustand auslesbar",
                "detail": "TCF TC-String: nein, Cookiebot: nein, OneTrust: nein, Usercentrics: nein."
            },
            {
                "id": "cmp_default_restrictive",
                "ok": true,
                "fix": "TCF-/CMP-Defaults vor Nutzerentscheidung restriktiv setzen; Statistik, Marketing und Vendors erst nach Einwilligung erlauben.",
                "label": "CMP-Default wirkt restriktiv",
                "detail": "TCF Purposes erlaubt: 0, TCF Vendors erlaubt: 0, Cookiebot Statistik/Marketing: nein."
            }
        ],
        "status": "kritisch",
        "summary": "Consent, Tracking oder Drittanbieter wirken im Erstaufruf deutlich nachbesserungsbeduerftig.",
        "evidence": [
            "4 Cookie(s) beim ersten Aufruf aus HTTP-Headern und Chromium",
            "0 Tracking-Script(s) im HTML",
            "0 datenschutzrelevante Drittanbieter-Domain(s)",
            "2 Storage-Key(s), 0 Tracking-Hinweis(e)",
            "Consent-Banner-Controls: Akzeptieren 0, Ablehnen 1, Einstellungen 0",
            "Ablehnen/Akzeptieren-Prominenz: nicht messbar",
            "Reject-Test: geklickt, neue Cookies 1, Tracking-Storage 1, 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": "google_consent",
                    "level": "hoch",
                    "source": "Google",
                    "target": "Google Consent Defaults",
                    "recipes": [
                        {
                            "tool": "Google Consent Mode v2",
                            "owner": "GTM Manager"
                        },
                        {
                            "tool": "Google Tag Manager",
                            "owner": "GTM Manager"
                        },
                        {
                            "tool": "Cookiebot",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Usercentrics",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "OneTrust",
                            "owner": "CMP/Developer"
                        }
                    ],
                    "category": "tag_manager",
                    "evidence": "Google-Tags erkannt, aber kein Consent-Default vor dem ersten Tag.",
                    "owner_team": "GTM/CMP",
                    "category_label": "Tag-Manager",
                    "recommended_action": "Vor dem ersten Google-Tag Consent Mode Default setzen: ad_storage, analytics_storage, ad_user_data und ad_personalization auf denied."
                },
                {
                    "kind": "cookie",
                    "level": "mittel",
                    "source": "cornelsen.de",
                    "target": "ecpdTimestamp",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager",
                            "owner": "GTM Manager"
                        },
                        {
                            "tool": "Cookiebot",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Usercentrics",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "OneTrust",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Developer-Fallback",
                            "owner": "Developer"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "vor Consent gesetzt · cornelsen.de · Session",
                    "owner_team": "CMP/Developer",
                    "category_label": "Unklar",
                    "recommended_action": "In CMP/Cookie-Kategorie einordnen und vor Einwilligung blockieren, falls nicht technisch erforderlich."
                },
                {
                    "kind": "cookie",
                    "level": "mittel",
                    "source": "cornelsen.de",
                    "target": "emos_jcsid",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager",
                            "owner": "GTM Manager"
                        },
                        {
                            "tool": "Cookiebot",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Usercentrics",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "OneTrust",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Developer-Fallback",
                            "owner": "Developer"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "vor Consent gesetzt · cornelsen.de · Session",
                    "owner_team": "CMP/Developer",
                    "category_label": "Unklar",
                    "recommended_action": "In CMP/Cookie-Kategorie einordnen und vor Einwilligung blockieren, falls nicht technisch erforderlich."
                },
                {
                    "kind": "cookie",
                    "level": "mittel",
                    "source": "cornelsen.de",
                    "target": "frontend",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager",
                            "owner": "GTM Manager"
                        },
                        {
                            "tool": "Cookiebot",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Usercentrics",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "OneTrust",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Developer-Fallback",
                            "owner": "Developer"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "vor Consent gesetzt · cornelsen.de · Session",
                    "owner_team": "CMP/Developer",
                    "category_label": "Unklar",
                    "recommended_action": "In CMP/Cookie-Kategorie einordnen und vor Einwilligung blockieren, falls nicht technisch erforderlich."
                },
                {
                    "kind": "storage",
                    "level": "mittel",
                    "source": "sessionStorage",
                    "target": "Neos.Neos.lastVisitedNode",
                    "recipes": [
                        {
                            "tool": "Google Tag Manager",
                            "owner": "GTM Manager"
                        },
                        {
                            "tool": "Usercentrics",
                            "owner": "CMP/Developer"
                        },
                        {
                            "tool": "Developer-Fallback",
                            "owner": "Developer"
                        }
                    ],
                    "category": "unknown",
                    "evidence": "sessionStorage · Unklar · Sitzung/Tab",
                    "owner_team": "CMP/Developer",
                    "category_label": "Unklar",
                    "recommended_action": "Zweck und Speicherdauer klären; bis zur Klärung nicht für Tracking oder Profilbildung nutzen."
                }
            ],
            "summary": "5 Blockier-/Consent-Maßnahme(n) abgeleitet: 1 hoch, 4 mittel.",
            "available": true,
            "high_count": 1,
            "total_count": 5,
            "type_counts": {
                "cookie": 3,
                "storage": 1,
                "google_consent": 1
            },
            "medium_count": 4
        },
        "tcf_api_found": false,
        "priority_fixes": [
            "Pre-Consent-Blockierplan prüfen: 5 Blockier-/Consent-Maßnahme(n) abgeleitet: 1 hoch, 4 mittel.",
            "Cookie-Banner oder Datenschutzeinstellungen klar sichtbar anbieten.",
            "Granulare Zwecke und Anbieter in einer zweiten Ebene anzeigen.",
            "Nach Ablehnen nur technisch notwendige Cookies setzen und nicht notwendige Eintraege blockieren.",
            "LocalStorage/SessionStorage nach Ablehnen bereinigen und Tracking-IDs erst nach Zustimmung setzen.",
            "Nicht notwendige Cookies blockieren oder als technisch notwendig begruenden."
        ],
        "cookiebot_found": false,
        "accept_test_enabled": false,
        "browser_cookie_count": 4,
        "accept_button_clicked": false,
        "browser_storage_count": 2,
        "reject_button_clicked": true,
        "reject_less_prominent": false,
        "tcf_tc_string_present": false,
        "tracking_script_count": 0,
        "accept_button_available": false,
        "reject_button_available": true,
        "reject_prominence_ratio": 0,
        "pre_consent_cookie_count": 4,
        "pre_consent_cookie_names": [
            "ingress-route-oxauth-cde-prod",
            "ecpdTimestamp",
            "emos_jcsid",
            "frontend"
        ],
        "tcf_vendor_consent_count": 0,
        "third_party_domain_count": 4,
        "tcf_purpose_consent_count": 0,
        "onetrust_active_group_count": 0,
        "usercentrics_services_count": 0,
        "browser_accept_control_count": 0,
        "browser_cookie_context_found": true,
        "browser_reject_control_count": 1,
        "gpc_third_party_cookie_count": 0,
        "post_accept_new_cookie_count": 0,
        "post_reject_new_cookie_count": 1,
        "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": 3,
        "pre_consent_nonessential_cookie_names": [
            "ecpdTimestamp",
            "emos_jcsid",
            "frontend"
        ],
        "post_accept_storage_tracking_hint_count": 0,
        "post_reject_storage_tracking_hint_count": 1,
        "post_accept_privacy_relevant_domain_count": 0,
        "post_reject_privacy_relevant_domain_count": 0
    },
    "cookie_inventory": {
        "color": "green",
        "items": [
            {
                "name": "ingress-route-oxauth-cde-prod",
                "domain": "id.cornelsen.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "necessary",
                "provider": "id.cornelsen.de",
                "tracking": false,
                "http_only": true,
                "same_site": "Lax",
                "expires_at": "2026-06-13T22:11:42+00:00",
                "long_lived": false,
                "persistent": true,
                "first_party": true,
                "origin_host": "id.cornelsen.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Notwendig",
                "retention_risk": "niedrig",
                "expires_in_days": 0,
                "origin_evidence": "1 Browser-Request(s) · image:1",
                "origin_provider": "id.cornelsen.de",
                "retention_class": "short",
                "retention_label": "kurz (0 Tage)",
                "likely_essential": true,
                "origin_script_url": "",
                "origin_resource_type": "image",
                "recommended_retention_action": "Speicherdauer und Zweck in Datenschutzerklärung/Cookie-Liste dokumentieren."
            },
            {
                "name": "ecpdTimestamp",
                "domain": "cornelsen.de",
                "secure": true,
                "sources": [
                    "browser_first_load"
                ],
                "category": "unknown",
                "provider": "cornelsen.de",
                "tracking": false,
                "http_only": true,
                "same_site": "None",
                "expires_at": "",
                "long_lived": false,
                "persistent": false,
                "first_party": true,
                "origin_host": "cornelsen.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Unklar",
                "retention_risk": "niedrig",
                "expires_in_days": null,
                "origin_evidence": "48 Browser-Request(s) · document:1, fetch:6, font:8, image:18",
                "origin_provider": "cornelsen.de",
                "retention_class": "session",
                "retention_label": "Session",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": "",
                "recommended_retention_action": "Session-Cookie auf Notwendigkeit und Sicherheitsattribute prüfen."
            },
            {
                "name": "emos_jcsid",
                "domain": "cornelsen.de",
                "secure": false,
                "sources": [
                    "browser_first_load"
                ],
                "category": "unknown",
                "provider": "cornelsen.de",
                "tracking": false,
                "http_only": false,
                "same_site": "Lax",
                "expires_at": "",
                "long_lived": false,
                "persistent": false,
                "first_party": true,
                "origin_host": "cornelsen.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Unklar",
                "retention_risk": "niedrig",
                "expires_in_days": null,
                "origin_evidence": "48 Browser-Request(s) · document:1, fetch:6, font:8, image:18",
                "origin_provider": "cornelsen.de",
                "retention_class": "session",
                "retention_label": "Session",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": "",
                "recommended_retention_action": "Session-Cookie auf Notwendigkeit und Sicherheitsattribute prüfen."
            },
            {
                "name": "frontend",
                "domain": "cornelsen.de",
                "secure": true,
                "sources": [
                    "browser_first_load"
                ],
                "category": "unknown",
                "provider": "cornelsen.de",
                "tracking": false,
                "http_only": false,
                "same_site": "None",
                "expires_at": "",
                "long_lived": false,
                "persistent": false,
                "first_party": true,
                "origin_host": "cornelsen.de",
                "pre_consent": true,
                "source_label": "Chromium-Erstaufruf",
                "category_label": "Unklar",
                "retention_risk": "niedrig",
                "expires_in_days": null,
                "origin_evidence": "48 Browser-Request(s) · document:1, fetch:6, font:8, image:18",
                "origin_provider": "cornelsen.de",
                "retention_class": "session",
                "retention_label": "Session",
                "likely_essential": false,
                "origin_script_url": "",
                "origin_resource_type": "",
                "recommended_retention_action": "Session-Cookie auf Notwendigkeit und Sicherheitsattribute prüfen."
            }
        ],
        "score": 90,
        "total": 4,
        "status": "unauffällig",
        "summary": "4 Cookie(s) inventarisiert: 0 Tracking-/Werbe-Cookie(s), 0 Drittanbieter-Cookie(s), 0 langlebige Cookie(s), 0 sehr lange Laufzeit(en).",
        "findings": [],
        "categories": {
            "unknown": 3,
            "necessary": 1
        },
        "priority_fixes": [],
        "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": 1,
        "first_party_count": 4,
        "pre_consent_count": 4,
        "retention_classes": {
            "short": 1,
            "session": 3
        },
        "third_party_count": 0,
        "missing_secure_count": 2,
        "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": "orange",
        "score": 70,
        "checks": [
            {
                "ok": true,
                "note": "",
                "label": "HSTS",
                "value": "max-age=63072000",
                "header": "strict-transport-security",
                "present": true,
                "purpose": "Erzwingt HTTPS nach dem ersten sicheren Aufruf.",
                "severity": "warning",
                "recommended": "max-age=31536000; includeSubDomains"
            },
            {
                "ok": true,
                "note": "",
                "label": "Content-Security-Policy",
                "value": "frame-ancestors 'self'; report-uri /__csp-report",
                "header": "content-security-policy",
                "present": true,
                "purpose": "Begrenzt Skript-, Frame- und Ressourcenquellen im Browser.",
                "severity": "warning",
                "recommended": "Schrittweise CSP mit default-src 'self' und expliziten Drittanbietern einführen."
            },
            {
                "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",
                "recommended": "DENY oder SAMEORIGIN"
            },
            {
                "ok": true,
                "note": "",
                "label": "X-Content-Type-Options",
                "value": "nosniff",
                "header": "x-content-type-options",
                "present": true,
                "purpose": "Verhindert MIME-Sniffing bei Skripten und Stylesheets.",
                "severity": "warning",
                "recommended": "nosniff"
            },
            {
                "ok": true,
                "note": "",
                "label": "Referrer-Policy",
                "value": "strict-origin-when-cross-origin",
                "header": "referrer-policy",
                "present": true,
                "purpose": "Begrenzt, welche URL-Informationen an Zielseiten weitergegeben werden.",
                "severity": "info",
                "recommended": "strict-origin-when-cross-origin"
            },
            {
                "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",
                "recommended": "Nicht benötigte Browser-APIs wie Kamera, Mikrofon und Geolocation sperren."
            },
            {
                "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",
                "recommended": "same-origin oder same-origin-allow-popups nach Funktionsprüfung"
            },
            {
                "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",
                "recommended": "same-origin oder same-site nach Ressourcenprüfung"
            },
            {
                "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",
                "recommended": "require-corp nur nach Prüfung aller eingebetteten Drittressourcen"
            }
        ],
        "status": "auffällig",
        "missing": [
            "X-Frame-Options",
            "Permissions-Policy",
            "Cross-Origin-Opener-Policy",
            "Cross-Origin-Resource-Policy",
            "Cross-Origin-Embedder-Policy"
        ],
        "summary": "4 von 9 wichtigen Security-Headern vorhanden, 4 korrekt bewertet. CSP wirksam mit 2 Direktive(n), 0 Warnung(en), 2 Hinweis(e).",
        "findings": [
            {
                "id": "csp_missing_object_src",
                "title": "CSP ohne object-src",
                "public": true,
                "category": "security_headers",
                "severity": "info"
            },
            {
                "id": "csp_missing_base_uri",
                "title": "CSP ohne base-uri",
                "public": true,
                "category": "security_headers",
                "severity": "info"
            }
        ],
        "ok_count": 4,
        "weak_count": 0,
        "csp_analysis": {
            "color": "yellow",
            "score": 88,
            "status": "prüfen",
            "summary": "CSP wirksam mit 2 Direktive(n), 0 Warnung(en), 2 Hinweis(e).",
            "enforced": true,
            "findings": [
                {
                    "id": "csp_missing_object_src",
                    "title": "CSP ohne object-src",
                    "public": true,
                    "category": "security_headers",
                    "severity": "info"
                },
                {
                    "id": "csp_missing_base_uri",
                    "title": "CSP ohne base-uri",
                    "public": true,
                    "category": "security_headers",
                    "severity": "info"
                }
            ],
            "available": true,
            "directives": [
                {
                    "name": "frame-ancestors",
                    "value": "'self'",
                    "values": [
                        "'self'"
                    ]
                },
                {
                    "name": "report-uri",
                    "value": "/__csp-report",
                    "values": [
                        "/__csp-report"
                    ]
                }
            ],
            "info_count": 2,
            "report_only": false,
            "finding_count": 2,
            "warning_count": 0,
            "priority_fixes": [
                "object-src 'none' setzen, wenn keine Plugins oder Objekte benötigt werden.",
                "base-uri 'self' oder 'none' setzen, damit Base-Tag-Manipulation begrenzt wird."
            ]
        },
        "missing_count": 5,
        "present_count": 4,
        "priority_fixes": [
            "X-Frame-Options: DENY oder SAMEORIGIN",
            "object-src 'none' setzen, wenn keine Plugins oder Objekte benötigt werden.",
            "base-uri 'self' oder 'none' setzen, damit Base-Tag-Manipulation begrenzt wird."
        ],
        "missing_info_count": 4,
        "missing_warning_count": 1
    },
    "infrastructure_analysis": {
        "signals": {
            "caa": false,
            "dnssec": false,
            "final_https": true,
            "tls_version": "TLSv1.3",
            "hsts_enabled": true,
            "address_count": 3,
            "ipv6_available": false,
            "email_protection": {
                "mx": true,
                "spf": true,
                "dmarc": true
            },
            "certificate_valid": true,
            "certificate_issuer": "Amazon RSA 2048 M01",
            "certificate_alt_names": [
                "cornelsen.de",
                "*.cornelsen.de",
                "*.mein.cornelsen.de"
            ],
            "multiple_ip_addresses": true,
            "certificate_expires_at": "Nov  6 23:59:59 2026 GMT",
            "certificate_days_remaining": 147,
            "certificate_hostname_matches": true
        },
        "findings": [
            {
                "id": "caa_missing",
                "title": "CAA-Record fehlt",
                "public": true,
                "category": "dns",
                "severity": "info"
            }
        ],
        "risk_level": "low",
        "positive_signals": [
            "Mehrere IP-Adressen gefunden: Hinweis auf redundante Infrastruktur oder CDN.",
            "Moderne TLS-Version aktiv: TLSv1.3.",
            "HSTS ist aktiv.",
            "DMARC ist für die Domain vorhanden."
        ]
    },
    "performance_analysis": {
        "score": 88,
        "signals": {
            "compressed": false,
            "duration_ms": 111,
            "image_count": 31,
            "script_count": 1,
            "cache_control": "",
            "content_length": 256071,
            "viewport_found": true,
            "stylesheet_count": 1
        },
        "findings": [
            {
                "id": "large_html_response",
                "title": "HTML-Antwort ist groß",
                "public": true,
                "category": "performance",
                "severity": "info"
            },
            {
                "id": "compression_missing",
                "title": "Komprimierung nicht erkannt",
                "public": true,
                "category": "performance",
                "severity": "info"
            }
        ],
        "risk_level": "medium"
    },
    "accessibility_analysis": {
        "color": "orange",
        "score": 72,
        "status": "auffällig",
        "signals": {
            "h1_count": 1,
            "image_count": 31,
            "button_count": 14,
            "heading_count": 10,
            "viewport_found": true,
            "html_lang_found": true,
            "form_field_count": 23,
            "image_missing_alt_count": 1,
            "buttons_without_name_count": 6,
            "form_fields_without_label_count": 0
        },
        "summary": "31 Bild(er), 23 Formularfeld(er), 14 Button(s) im passiven HTML-Sample auf Basis-Barrierefreiheit geprüft.",
        "findings": [
            {
                "id": "image_alt_missing",
                "count": 1,
                "title": "Bilder ohne Alternativtext",
                "public": true,
                "category": "accessibility",
                "severity": "info"
            },
            {
                "id": "button_name_missing",
                "count": 6,
                "title": "Buttons ohne erkennbaren Namen",
                "public": true,
                "category": "accessibility",
                "severity": "warning"
            }
        ],
        "wcag_matrix": {
            "rows": [
                {
                    "id": "wcag_non_text_content",
                    "ok": false,
                    "fix": "Inhaltliche Bilder mit aussagekräftigem alt-Text versehen; dekorative Bilder mit leerem alt oder aria-hidden kennzeichnen.",
                    "wcag": "WCAG 1.1.1 Non-text Content",
                    "title": "Alternativtexte für Bilder",
                    "impact": "mittel",
                    "status": "prüfen",
                    "evidence": "1 von 31 Bild(er) ohne alt-Text im HTML-Sample.",
                    "eaa_relevance": "EAA/BFSG-Relevanz: Inhalte müssen auch ohne Bildwahrnehmung verständlich sein."
                },
                {
                    "id": "wcag_form_labels",
                    "ok": true,
                    "fix": "Jedes Eingabefeld mit sichtbarem label, aria-label oder aria-labelledby verbinden.",
                    "wcag": "WCAG 1.3.1 Info and Relationships / 3.3.2 Labels or Instructions",
                    "title": "Formularfelder beschriften",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "0 von 23 Formularfeld(er) ohne erkennbare Beschriftung.",
                    "eaa_relevance": "EAA/BFSG-Relevanz: Formulare müssen mit Tastatur und Screenreader bedienbar sein."
                },
                {
                    "id": "wcag_button_names",
                    "ok": false,
                    "fix": "Buttons mit sichtbarem Text, aria-label oder eindeutigem value auszeichnen.",
                    "wcag": "WCAG 4.1.2 Name, Role, Value",
                    "title": "Buttons mit Namen versehen",
                    "impact": "hoch",
                    "status": "prüfen",
                    "evidence": "6 von 14 Button(s) ohne erkennbaren Namen.",
                    "eaa_relevance": "EAA/BFSG-Relevanz: Schaltflächen müssen technisch und sichtbar verständlich sein."
                },
                {
                    "id": "wcag_page_language",
                    "ok": true,
                    "fix": "Am html-Element die passende Sprache setzen, zum Beispiel lang=\"de\".",
                    "wcag": "WCAG 3.1.1 Language of Page",
                    "title": "Seitensprache auszeichnen",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "HTML-lang-Attribut gefunden.",
                    "eaa_relevance": "EAA/BFSG-Relevanz: Screenreader brauchen die korrekte Sprache für Aussprache und Navigation."
                },
                {
                    "id": "wcag_heading_structure",
                    "ok": true,
                    "fix": "Eine klare H1 und sinnvoll verschachtelte Zwischenüberschriften einsetzen.",
                    "wcag": "WCAG 1.3.1 Info and Relationships / 2.4.6 Headings and Labels",
                    "title": "Überschriftenstruktur",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "1 H1 und 10 Überschrift(en) im HTML-Sample.",
                    "eaa_relevance": "EAA/BFSG-Relevanz: Klare Überschriften erleichtern Orientierung und Bedienung."
                },
                {
                    "id": "wcag_mobile_reflow",
                    "ok": true,
                    "fix": "meta name=\"viewport\" setzen und Layout auf mobile Reflow-Fähigkeit prüfen.",
                    "wcag": "WCAG 1.4.10 Reflow",
                    "title": "Mobile Viewport-Basis",
                    "impact": "niedrig",
                    "status": "ok",
                    "evidence": "Viewport-Meta-Tag gefunden.",
                    "eaa_relevance": "EAA/BFSG-Relevanz: Inhalte müssen auf kleinen Bildschirmen ohne horizontales Scrollen nutzbar bleiben."
                }
            ],
            "summary": "2 WCAG-/EAA-Prüfpunkt(e) auffällig, davon 1 mit hoher Auswirkung.",
            "standard": "WCAG 2.2 orientierte Basisprüfung",
            "available": true,
            "issue_count": 2,
            "priority_fixes": [
                "Inhaltliche Bilder mit aussagekräftigem alt-Text versehen; dekorative Bilder mit leerem alt oder aria-hidden kennzeichnen.",
                "Buttons mit sichtbarem Text, aria-label oder eindeutigem value auszeichnen."
            ],
            "high_impact_count": 1
        },
        "priority_fixes": [
            "Inhaltliche Bilder mit aussagekräftigem alt-Text versehen; dekorative Bilder mit leerem alt oder aria-hidden kennzeichnen.",
            "Buttons mit sichtbarem Text, aria-label oder eindeutigem value auszeichnen."
        ]
    },
    "domain_history": {
        "status": [
            "active"
        ],
        "summary": "RDAP liefert kein klares Registrierungsdatum.",
        "age_days": null,
        "findings": [],
        "available": true,
        "registrar": "",
        "expires_at": "",
        "risk_level": "unknown",
        "registered_at": "",
        "expires_in_days": null,
        "last_changed_at": "2025-07-03T07:24:54+00:00"
    },
    "data_entry_analysis": {
        "forms": [],
        "score": 75,
        "summary": "Die Seite kann Name/personenbezogene Daten abfragen.",
        "findings": [
            {
                "id": "data_entry_privacy_context_missing",
                "title": "Dateneingabe ohne klaren Datenschutzkontext",
                "public": true,
                "category": "data_entry",
                "severity": "warning"
            }
        ],
        "form_count": 0,
        "risk_level": "medium",
        "field_count": 23,
        "asks_for_data": true,
        "payment_providers": [],
        "detected_data_types": [
            {
                "id": "personal",
                "count": 23,
                "label": "Name/personenbezogene Daten"
            }
        ],
        "privacy_context_found": false,
        "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,
        "priority_fixes": [],
        "current_url_hits": [],
        "tracking_context": false,
        "sensitive_get_forms": [],
        "external_form_actions": []
    },
    "scan_history_analysis": {
        "available": false,
        "summary": "Noch kein früherer gespeicherter Scan für diese Domain vorhanden.",
        "history": [
            {
                "scan_id": "c14a85b0-9b07-414d-9b74-fd9e613c0fbf",
                "created_at": "2026-06-13 00:11:56.529194+02",
                "score": 0,
                "verdict": "riskant",
                "finding_count": 27,
                "integrity_root_hash": "624fd82ab14033d98e7de22b1181b6f97fe34cbb5fc0095c7c43c437c14ec4df",
                "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": "cornelsen.de",
        "rank": 1,
        "score": 0,
        "status": "im_mittelfeld",
        "summary": "cornelsen.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.6.",
        "available": true,
        "peer_count": 1234,
        "percentile": 0,
        "query_mode": "php_ttl_cache_refresh",
        "distribution": {
            "0_39": 1230,
            "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": 74,
        "zero_score_count": 1160,
        "top_quartile_score": 0,
        "top_decile_score": 0,
        "qualified_average_score": 17.6,
        "qualified_median_score": 16,
        "qualified_top_quartile_score": 24,
        "qualified_top_decile_score": 36,
        "thresholds": [
            {
                "id": "critical",
                "label": "Kritisch",
                "range": "0-39",
                "met": true,
                "meaning": "Betreiber sollten Eingabe-, Consent- und Transparenzpfade priorisiert prüfen und Korrekturen mit Re-Scan belegen."
            },
            {
                "id": "basic",
                "label": "Basis stabilisieren",
                "range": "40-59",
                "met": false,
                "meaning": "Grundschutz und Transparenz sind teilweise vorhanden, aber wichtige Datenschutzlücken bleiben offen."
            },
            {
                "id": "managed",
                "label": "Gesteuert",
                "range": "60-79",
                "met": false,
                "meaning": "Viele Kontrollen sind sichtbar, Betreiber sollten Nachweise und laufende Prozesse schärfen."
            },
            {
                "id": "strong",
                "label": "Stark",
                "range": "80-100",
                "met": false,
                "meaning": "Öffentliche Evidenz wirkt robust; regelmäßige Regression und Nachweise bleiben nötig."
            }
        ],
        "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://cornelsen.de/",
        "host": "cornelsen.de",
        "status": "verfügbar",
        "bot_url": "https://saferpage.de/bot",
        "summary": "Prüfbeleg für cornelsen.de: kontrollierter HTTP-/Browser-Kurzcheck mit 71 Request(s), 4 Consent-Zustand/Zuständen und 7 Artefakt(en).",
        "renderer": "playwright-chromium",
        "artifacts": [
            {
                "label": "Öffentlicher Kurzreport",
                "detail": "https://saferpage.de/cornelsen.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/cornelsen.de-160x150-83c5ba8fdfb02e498d.png",
                "status": "verfügbar"
            },
            {
                "label": "Cookie-Erklärung",
                "detail": "6 Cookie-/Storage-Eintrag/Einträge.",
                "status": "prüfen"
            },
            {
                "label": "Empfänger-/Anbieterinventar",
                "detail": "4 Anbieterzeile(n), 1 AVV-/Rollenprüfung(en).",
                "status": "unauffällig"
            },
            {
                "label": "Barrierefreiheitserklärung-Entwurf",
                "detail": "2 bekannte Barrierefreiheits-Punkt(e).",
                "status": "Nicht vollständig konform im automatischen Basischeck"
            }
        ],
        "available": true,
        "final_url": "https://www.cornelsen.de/",
        "checked_at": "2026-06-12T22:11:56+00:00",
        "share_text": "SaferPage Prüfbeleg cornelsen.de: 71 Browser-Request(s), 4 Drittanbieter, 6 Cookie-/Storage-Einträge, geprüft am 2026-06-12T22:11:56.",
        "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": "71 Request(s), 4 Drittanbieter-Domain(s), 4 Browser-Cookie(s)."
            },
            {
                "label": "Consent-Zustände",
                "value": "4 Zustand/Zustände: Default, Ablehnen, Akzeptieren und GPC soweit verfügbar."
            },
            {
                "label": "Seitenabdeckung",
                "value": "8 priorisierte Unterseite(n) im Nachweispack."
            },
            {
                "label": "Drittanbieter-Auszug",
                "value": "4 Anbieterzeile(n) im öffentlichen Nachweis."
            },
            {
                "label": "Cookie-Auszug",
                "value": "4 Cookie-Zeile(n) im öffentlichen Nachweis."
            }
        ],
        "confidence_score": 69,
        "browser_final_url": "https://www.cornelsen.de/",
        "methodology_steps": [
            "URL normalisieren, DNS/TLS/HTTP abrufen und Weiterleitungsziel dokumentieren.",
            "Startseite mit SaferPage-User-Agent und Headless Chromium aufrufen.",
            "Netzwerk-Requests, Cookies, Web Storage, Screenshot und sichtbare Consent-Controls erfassen.",
            "Consent-Zustände Default, Ablehnen, Akzeptieren und GPC soweit möglich gegenüberstellen.",
            "Cookies, Anbieter, Rechtsgrundlagen, Banner-UX, Security-Header, Barrierefreiheit und Betreiberaufgaben ableiten."
        ]
    },
    "evidence_integrity_manifest": {
        "host": "cornelsen.de",
        "status": "verfügbar",
        "summary": "Integritätsmanifest für cornelsen.de: 9/9 Nachweisbereich(e) mit SHA-256-Hash dokumentiert.",
        "sections": [
            {
                "id": "audit_receipt",
                "hash": "e04464e17d901575bd805c7162a4a04a2a88f09aee551f483d533a5542e351bf",
                "count": 18,
                "label": "Prüfbeleg",
                "detail": "Kanonischer JSON-Hash des kompakten Prüfbelegs.",
                "status": "verfügbar"
            },
            {
                "id": "protocol",
                "hash": "0e7876eca4878accb53ad2a8a9e9eee5e944845d10a21ffd58362b4bb11912c1",
                "count": 15,
                "label": "Scan-Protokoll",
                "detail": "URL, Endziel, User-Agent, Zeitstempel, HTTP/DNS/TLS und Renderer.",
                "status": "verfügbar"
            },
            {
                "id": "checkpoints",
                "hash": "5187b703f31e97262f5a6c591b5b0f8e77500966e03378a4e80e1e9e3cfade80",
                "count": 6,
                "label": "Prüfschritte",
                "detail": "Kanonischer JSON-Hash der dokumentierten Prüfstationen.",
                "status": "verfügbar"
            },
            {
                "id": "consent_states",
                "hash": "e67d3ee7e5b1382a8b438872691850c60aef5d0147d604ae6f6c14bccadc3272",
                "count": 4,
                "label": "Consent-Zustände",
                "detail": "Default-, Ablehnen-, Akzeptieren- und GPC-Nachweise soweit verfügbar.",
                "status": "verfügbar"
            },
            {
                "id": "third_party_evidence",
                "hash": "972e58f12c4bc4f6fed24959e3e1d25f83b3c2fbc04336e9149609c67d1f6c14",
                "count": 4,
                "label": "Drittanbieter-Auszug",
                "detail": "Sanitisierte Anbieter-, Kategorie-, Transfer- und Request-Zählwerte.",
                "status": "verfügbar"
            },
            {
                "id": "cookie_evidence",
                "hash": "86f10b438e03752cc619e5e3d3fc12d8c8c2c14d34d734dd7beab3ec8656658f",
                "count": 4,
                "label": "Cookie-Auszug",
                "detail": "Sanitisierte Cookie-Metadaten ohne Cookie-Werte.",
                "status": "verfügbar"
            },
            {
                "id": "request_samples",
                "hash": "ded49a895ad95550212e56b9cf15f57dc9588b353492df80eda9ae6837858468",
                "count": 10,
                "label": "Request-Samples",
                "detail": "Sanitisierte Drittanbieter-Samples ohne vollständige Request-URLs.",
                "status": "verfügbar"
            },
            {
                "id": "checked_pages",
                "hash": "8478a8d3edae9d5759ebbe62fc704aa335caad86490729e7bfe4003e013dbe15",
                "count": 8,
                "label": "Geprüfte Unterseiten",
                "detail": "Priorisierte Pfade aus Sitemap, Pflichtseiten und interner Linkstruktur.",
                "status": "verfügbar"
            },
            {
                "id": "screenshot_file",
                "hash": "8d552dc3a65c06c91b57f7c8fa25640960c3612b35e18cfcb3bf809ef3c67b97",
                "count": 6019,
                "label": "160x150 Seitenvorschau-Datei",
                "detail": "/cache/screenshots/cornelsen.de-160x150-83c5ba8fdfb02e498d.png",
                "status": "verfügbar"
            }
        ],
        "algorithm": "sha256",
        "available": true,
        "root_hash": "624fd82ab14033d98e7de22b1181b6f97fe34cbb5fc0095c7c43c437c14ec4df",
        "checked_at": "2026-06-12T22:11:56+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.",
        "verification_steps": [
            "JSON-Export speichern und den jeweiligen Abschnitt kanonisch mit sortierten Schlüsseln serialisieren.",
            "SHA-256 des kanonischen Abschnitts bilden und mit dem Manifest vergleichen.",
            "Screenshot-Datei separat als rohe Datei-Bytes hashen, falls ein Screenshot-Artefakt vorhanden ist.",
            "Bei einem Wiederholungsscan Root-Hash, Zeitstempel und Abschnitts-Hashes getrennt vergleichen."
        ],
        "available_hash_count": 9
    },
    "audit_evidence_pack": {
        "status": "verfügbar",
        "summary": "Nachweisprotokoll mit 71 Browser-Request(s), 4 Cookie-Nachweis(en), 4 Drittanbieter-Auszug/auszügen und 4 Consent-Zustand/Zuständen.",
        "protocol": {
            "host": "cornelsen.de",
            "dns_ok": true,
            "tls_ok": true,
            "bot_url": "https://saferpage.de/bot",
            "renderer": "playwright-chromium",
            "final_url": "https://www.cornelsen.de/",
            "input_url": "https://cornelsen.de/",
            "checked_at": "2026-06-12T22:11:56+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/cornelsen.de-160x150-83c5ba8fdfb02e498d.png",
            "googlebot_status": 200,
            "browser_final_url": "https://www.cornelsen.de/",
            "dns_address_count": 3
        },
        "checkpoints": [
            {
                "label": "DNS",
                "detail": "3 Adresse(n) aufgelöst.",
                "status": "ok"
            },
            {
                "label": "TLS/HTTPS",
                "detail": "TLSv1.3",
                "status": "ok"
            },
            {
                "label": "HTTP-Abruf",
                "detail": "Status 200, Endziel https://www.cornelsen.de/.",
                "status": "ok"
            },
            {
                "label": "Browserlauf",
                "detail": "71 Request(s), 4 Drittanbieter-Domain(s).",
                "status": "ok"
            },
            {
                "label": "Consent-Zustände",
                "detail": "Default, Ablehnen, Akzeptieren und GPC werden soweit möglich gegenübergestellt.",
                "status": "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": "/80-jahre/day-camps-erleben",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung/alle-bundeslaender",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung/baden-wuerttemberg",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung/bayern",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung/faecher",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung/faecher/deutsch",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            },
            {
                "path": "/berufliche-bildung/faecher/deutsch-als-zweitsprache",
                "source": "homepage_link",
                "status": 0,
                "category": "unterseite"
            }
        ],
        "cookie_evidence": [
            {
                "name": "ingress-route-oxauth-cde-prod",
                "domain": "id.cornelsen.de",
                "secure": false,
                "category": "Notwendig",
                "provider": "id.cornelsen.de",
                "tracking": false,
                "retention": "kurz (0 Tage)",
                "same_site": "Lax",
                "pre_consent": true
            },
            {
                "name": "ecpdTimestamp",
                "domain": "cornelsen.de",
                "secure": true,
                "category": "Unklar",
                "provider": "cornelsen.de",
                "tracking": false,
                "retention": "Session",
                "same_site": "None",
                "pre_consent": true
            },
            {
                "name": "emos_jcsid",
                "domain": "cornelsen.de",
                "secure": false,
                "category": "Unklar",
                "provider": "cornelsen.de",
                "tracking": false,
                "retention": "Session",
                "same_site": "Lax",
                "pre_consent": true
            },
            {
                "name": "frontend",
                "domain": "cornelsen.de",
                "secure": true,
                "category": "Unklar",
                "provider": "cornelsen.de",
                "tracking": false,
                "retention": "Session",
                "same_site": "None",
                "pre_consent": true
            }
        ],
        "browser_evidence": {
            "gpc_enabled": true,
            "request_count": 71,
            "storage_total": 2,
            "accept_clicked": false,
            "reject_clicked": true,
            "browser_cookie_count": 4,
            "contacted_domain_count": 5,
            "third_party_domain_count": 4,
            "storage_tracking_hint_count": 0,
            "privacy_relevant_domain_count": 0
        },
        "storage_evidence": {
            "tracking_key_hints": [],
            "local_storage_total": 0,
            "session_storage_total": 2
        },
        "third_party_evidence": [
            {
                "host": "static.cornelsen.de",
                "category": "Sonstige",
                "provider": "static.cornelsen.de",
                "transfer": "EU/EWR",
                "risk_level": "niedrig",
                "request_count": 17,
                "resource_types": [
                    "image"
                ],
                "privacy_relevant": false
            },
            {
                "host": "l.ecn-ldr.de",
                "category": "Sonstige",
                "provider": "l.ecn-ldr.de",
                "transfer": "EU/EWR",
                "risk_level": "niedrig",
                "request_count": 3,
                "resource_types": [
                    "script"
                ],
                "privacy_relevant": false
            },
            {
                "host": "mcw0nd.cornelsen.de",
                "category": "Sonstige",
                "provider": "mcw0nd.cornelsen.de",
                "transfer": "EU/EWR",
                "risk_level": "niedrig",
                "request_count": 2,
                "resource_types": [
                    "script",
                    "xhr"
                ],
                "privacy_relevant": false
            },
            {
                "host": "id.cornelsen.de",
                "category": "Sonstige",
                "provider": "id.cornelsen.de",
                "transfer": "EU/EWR",
                "risk_level": "niedrig",
                "request_count": 1,
                "resource_types": [
                    "image"
                ],
                "privacy_relevant": false
            }
        ],
        "external_script_count": 0,
        "consent_state_evidence": [
            {
                "label": "Erstaufruf",
                "cookie_count": 0,
                "domain_count": 4,
                "request_count": 23,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            },
            {
                "label": "Nach Ablehnen neu",
                "cookie_count": 0,
                "domain_count": 1,
                "request_count": 1,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            },
            {
                "label": "Nach Akzeptieren neu",
                "cookie_count": 0,
                "domain_count": 0,
                "request_count": 0,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            },
            {
                "label": "GPC-Aufruf",
                "cookie_count": 0,
                "domain_count": 4,
                "request_count": 22,
                "storage_tracking_hint_count": 0,
                "privacy_relevant_domain_count": 0
            }
        ],
        "request_sample_evidence": [
            {
                "host": "mcw0nd.cornelsen.de",
                "query_keys": [],
                "resource_type": "script",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            },
            {
                "host": "static.cornelsen.de",
                "query_keys": [],
                "resource_type": "image",
                "query_key_count": 0,
                "referrer_has_path": false,
                "referrer_has_query": false,
                "sensitive_query_key_count": 0
            }
        ]
    }
}