/**
 * PflegePur Klaro Cookie-Modal Styles
 * Version 4.0
 * 
 * Einbinden: <link rel="stylesheet" href="/navigator/css/klaro-pflegepur.css">
 * NACH dem Klaro CSS laden!
 */

/* ============================================
   KLARO COOKIE MODAL - PFLEGEPUR THEME v4
   Struktur: li.cm-purpose > input + label.cm-list-label > span.cm-list-title + span.cm-switch
   ============================================ */

.klaro {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* Backdrop: Modal immer mittig, mit Luft oben/unten (verhindert Abschneiden).
   position:fixed + sehr hoher z-index -> liegt ÜBER der Seiten-Navigation
   (vorher verdeckte die fixe Nav die obere Modal-Kante). */
.klaro .cookie-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 2147483646 !important;
    background: rgba(0, 0, 0, 0.6) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 3vh 16px !important;
    box-sizing: border-box !important;
    overflow: auto !important;
}

/* Modal Container: EIN Scroll-Container (Header-Text + Body scrollen gemeinsam),
   Höhe gedeckelt -> nichts wird oben/unten abgeschnitten. */
.klaro .cookie-modal .cm-modal {
    background: #ffffff !important;
    border-radius: 20px !important;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.35) !important;
    max-width: 500px !important;
    width: 95% !important;
    max-height: 94vh !important;
    max-height: 94dvh !important; /* dvh: zählt Browserleisten NICHT mit -> kein Abschnitt oben/unten auf Tablet */
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
}

/* ===== HEADER =====
   Markenfarbe über Variablen steuerbar. Default = PflegePur-Navy.
   Ein Regionalportal kann umfärben mit z.B.:
   .klaro { --pp-klaro-c1:#7c3aed !important; --pp-klaro-c2:#a855f7 !important; } */
.klaro .cookie-modal .cm-header {
    background: linear-gradient(135deg, var(--pp-klaro-c1, #004080) 0%, var(--pp-klaro-c2, #0066cc) 100%) !important;
    padding: 2rem 1.5rem 1.25rem !important;
}

.klaro .cookie-modal .cm-header h1 {
    color: #ffffff !important;
    font-size: 1.3rem !important;
    font-weight: 700 !important;
    margin: 0 0 0.5rem 0 !important;
}

.klaro .cookie-modal .cm-header p {
    color: rgba(255, 255, 255, 0.95) !important;
    font-size: 0.8rem !important;
    line-height: 1.45 !important;
    margin: 0 !important;
}

/* ===== BODY ===== */
.klaro .cookie-modal .cm-body {
    background: #ffffff !important;
    padding: 1rem !important;
    /* kein eigener Scroll mehr — das gesamte Modal scrollt als Einheit */
    max-height: none !important;
    overflow: visible !important;
}

/* ===== PURPOSES LIST ===== */
.klaro .cookie-modal ul.cm-purposes {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ===== SINGLE PURPOSE ITEM ===== */
.klaro .cookie-modal li.cm-purpose {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    padding: 1rem 1.25rem !important;
    margin-bottom: 0.75rem !important;
}

/* Hide the actual checkbox input */
.klaro .cookie-modal li.cm-purpose > input.cm-list-input {
    display: none !important;
}

/* ===== LABEL (contains title + switch) ===== */
.klaro .cookie-modal li.cm-purpose > label.cm-list-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    cursor: pointer !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Title */
.klaro .cookie-modal .cm-list-label .cm-list-title {
    color: #1e293b !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    flex-shrink: 0 !important;
}

/* Required Badge */
.klaro .cookie-modal .cm-list-label .cm-required {
    color: #64748b !important;
    font-size: 0.85rem !important;
    font-weight: 400 !important;
}

/* ===== SWITCH - Push to right ===== */
.klaro .cookie-modal .cm-list-label .cm-switch {
    margin-left: auto !important;
    position: relative !important;
    display: inline-block !important;
    width: 44px !important;
    min-width: 44px !important;
    height: 24px !important;
    flex-shrink: 0 !important;
}

/* Slider Track - IMMER GRAU (default) */
.klaro .cookie-modal .cm-switch .slider,
.klaro .cookie-modal .cm-switch .slider.round,
.klaro .cookie-modal .cm-switch .slider.active,
.klaro .cookie-modal .cm-switch .slider.round.active {
    position: absolute !important;
    cursor: pointer !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-color: #cbd5e1 !important;
    transition: 0.3s !important;
    border-radius: 24px !important;
}

/* Slider Track - GRÜN wenn CHECKED */
.klaro .cookie-modal li.cm-purpose input:checked + label .cm-switch .slider,
.klaro .cookie-modal li.cm-purpose input:checked + label .cm-switch .slider.round,
.klaro .cookie-modal li.cm-purpose input:checked + label .cm-switch .slider.active,
.klaro .cookie-modal li.cm-purpose input:checked ~ label .cm-switch .slider,
.klaro .cookie-modal input.cm-list-input:checked + label .cm-switch .slider {
    background: linear-gradient(135deg, #10b981, #059669) !important;
}

/* Slider Knob - IMMER LINKS (default) */
.klaro .cookie-modal .cm-switch .slider::before,
.klaro .cookie-modal .cm-switch .slider.round::before,
.klaro .cookie-modal .cm-switch .slider.active::before,
.klaro .cookie-modal .cm-switch .slider.round.active::before {
    position: absolute !important;
    content: "" !important;
    height: 18px !important;
    width: 18px !important;
    left: 3px !important;
    bottom: 3px !important;
    background-color: white !important;
    transition: 0.3s !important;
    border-radius: 50% !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2) !important;
    transform: translateX(0) !important;
}

/* Slider Knob - RECHTS wenn CHECKED */
.klaro .cookie-modal li.cm-purpose input:checked + label .cm-switch .slider::before,
.klaro .cookie-modal li.cm-purpose input:checked + label .cm-switch .slider.round::before,
.klaro .cookie-modal li.cm-purpose input:checked + label .cm-switch .slider.active::before,
.klaro .cookie-modal li.cm-purpose input:checked ~ label .cm-switch .slider::before,
.klaro .cookie-modal input.cm-list-input:checked + label .cm-switch .slider::before {
    transform: translateX(20px) !important;
}

/* Disabled switch für required - immer grün/aktiv */
.klaro .cookie-modal li.cm-purpose input.only-required + label .cm-switch .slider,
.klaro .cookie-modal li.cm-purpose input.required + label .cm-switch .slider {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    opacity: 0.7 !important;
    cursor: not-allowed !important;
}

.klaro .cookie-modal li.cm-purpose input.only-required + label .cm-switch .slider::before,
.klaro .cookie-modal li.cm-purpose input.required + label .cm-switch .slider::before {
    transform: translateX(20px) !important;
}

/* ===== SERVICES SECTION (↓ 1 Dienst) ===== */
.klaro .cookie-modal .cm-services {
    margin-top: 0.75rem !important;
}

.klaro .cookie-modal .cm-services .cm-caret {
    margin: 0 !important;
}

.klaro .cookie-modal .cm-services .cm-caret a {
    color: #004080 !important;
    font-size: 0.85rem !important;
    text-decoration: none !important;
}

.klaro .cookie-modal .cm-services .cm-caret a:hover {
    text-decoration: underline !important;
}

/* Expanded services list */
.klaro .cookie-modal .cm-services ul.cm-content {
    list-style: none !important;
    margin: 0.75rem 0 0 0 !important;
    padding: 0.75rem 0 0 0 !important;
    border-top: 1px solid #e2e8f0 !important;
}

.klaro .cookie-modal .cm-services li.cm-service {
    padding: 0.5rem 0 !important;
}

.klaro .cookie-modal .cm-service .cm-list-title {
    color: #334155 !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
}

.klaro .cookie-modal .cm-service .cm-list-description {
    color: #64748b !important;
    font-size: 0.8rem !important;
    line-height: 1.4 !important;
    margin-top: 0.25rem !important;
}

.klaro .cookie-modal .cm-service .purposes {
    color: #94a3b8 !important;
    font-size: 0.75rem !important;
    margin-top: 0.25rem !important;
}

/* ===== TOGGLE ALL BOX ===== */
.klaro .cookie-modal li.cm-purpose.cm-toggle-all {
    background: #f0fdf4 !important;
    border: 2px solid #86efac !important;
}

.klaro .cookie-modal li.cm-toggle-all .cm-list-title {
    color: #166534 !important;
}

.klaro .cookie-modal li.cm-toggle-all .cm-list-description {
    color: #4d7c0f !important;
    font-size: 0.85rem !important;
    margin-top: 0.5rem !important;
}

/* ===== FOOTER ===== */
.klaro .cookie-modal .cm-footer {
    background: #f8fafc !important;
    padding: 1.25rem !important;
    border-top: 1px solid #e2e8f0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.75rem !important;
    justify-content: space-between !important;
    /* bleibt beim Scrollen unten kleben -> Buttons immer erreichbar */
    position: sticky !important;
    bottom: 0 !important;
    z-index: 2 !important;
}

/* ===== BUTTONS =====
   DSGVO-Audit 002.01.03: Alle Buttons MÜSSEN in Farbe und Größe gleich sein.
   Kein Button (insbesondere "Alle akzeptieren") darf optisch hervorgehoben
   werden (kein Gradient, kein Schatten, kein Hover-Lift, gleiche Rahmenstärke). */
.klaro .cookie-modal .cm-btn {
    border-radius: 10px !important;
    padding: 0.8rem 1.25rem !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    cursor: pointer !important;
    transition: background 0.2s ease, border-color 0.2s ease !important;
    flex: 1 !important;
    min-width: 130px !important;
    text-align: center !important;
    /* identische Optik für ALLE Buttons */
    background: #ffffff !important;
    color: #1e293b !important;
    border: 2px solid #cbd5e1 !important;
    box-shadow: none !important;
    transform: none !important;
}

/* Gleiche Gestaltung für jede Button-Variante (defensiv inkl. accept/accept-all) */
.klaro .cookie-modal .cm-btn-decline,
.klaro .cookie-modal .cm-btn-info,
.klaro .cookie-modal .cm-btn-success,
.klaro .cookie-modal .cm-btn-accept,
.klaro .cookie-modal .cm-btn-accept-all {
    background: #ffffff !important;
    color: #1e293b !important;
    border: 2px solid #cbd5e1 !important;
    box-shadow: none !important;
    transform: none !important;
}

.klaro .cookie-modal .cm-btn-decline:hover,
.klaro .cookie-modal .cm-btn-info:hover,
.klaro .cookie-modal .cm-btn-success:hover,
.klaro .cookie-modal .cm-btn-accept:hover,
.klaro .cookie-modal .cm-btn-accept-all:hover {
    background: #f1f5f9 !important;
    border-color: #94a3b8 !important;
    transform: none !important;
}

/* Reihenfolge (rein visuelle Anordnung, KEINE Hervorhebung einzelner Buttons) */
.klaro .cookie-modal .cm-btn-decline { order: 1 !important; }
.klaro .cookie-modal .cm-btn-info    { order: 2 !important; }
.klaro .cookie-modal .cm-btn-success { order: 3 !important; }

/* ===== HIDE POWERED BY ===== */
.klaro .cookie-modal .cm-powered-by,
.klaro .cookie-modal .cm-footer-links {
    display: none !important;
}

/* ===== RESPONSIVE MOBILE ===== */
@media (max-width: 600px) {
    /* Backdrop - ZENTRIERT */
    .klaro .cookie-modal {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        display: flex !important;
        align-items: flex-start !important;
        justify-content: center !important;
        padding: 16px !important;
        z-index: 2147483646 !important;
        background: rgba(0,0,0,0.7) !important;
        overflow: hidden !important;
    }
    
    /* Modal Box - oben ausgerichtet, EIN Scroll-Container.
       dvh statt vh: vh zählt auf Mobile die Fläche hinter der Adressleiste mit
       -> Modal wurde höher als sichtbar und der Titel rutschte nach oben raus. */
    .klaro .cookie-modal .cm-modal {
        position: relative !important;
        border-radius: 16px !important;
        max-width: 100% !important;
        width: 100% !important;
        max-height: calc(100vh - 32px) !important;
        max-height: calc(100dvh - 32px) !important;
        margin: 0 !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        box-shadow: 0 20px 60px rgba(0,0,0,0.4) !important;
    }
    
    /* Kein Drag Handle bei zentriertem Modal */
    .klaro .cookie-modal .cm-modal::before {
        display: none !important;
    }
    
    /* Header */
    .klaro .cookie-modal .cm-header {
        padding: 20px 18px 10px !important;
        flex-shrink: 0 !important;
    }
    
    .klaro .cookie-modal .cm-header h1 {
        font-size: 1rem !important;
        margin-bottom: 4px !important;
    }
    
    .klaro .cookie-modal .cm-header p {
        font-size: 0.75rem !important;
        line-height: 1.3 !important;
    }
    
    /* Body - scrollt mit dem Modal (kein eigener Scroll) */
    .klaro .cookie-modal .cm-body {
        max-height: none !important;
        overflow: visible !important;
        padding: 10px 14px !important;
    }
    
    /* Purpose Items */
    .klaro .cookie-modal li.cm-purpose {
        padding: 10px 12px !important;
        margin-bottom: 6px !important;
        border-radius: 10px !important;
    }
    
    .klaro .cookie-modal .cm-list-title {
        font-size: 0.9rem !important;
    }
    
    .klaro .cookie-modal .cm-list-description {
        font-size: 0.75rem !important;
    }
    
    .klaro .cookie-modal li.cm-toggle-all {
        padding: 10px 12px !important;
        margin-bottom: 6px !important;
    }
    
    .klaro .cookie-modal li.cm-toggle-all .cm-list-title {
        font-size: 0.85rem !important;
    }
    
    .klaro .cookie-modal li.cm-toggle-all p {
        font-size: 0.7rem !important;
        margin-top: 2px !important;
    }
    
    /* Footer - klebt unten */
    .klaro .cookie-modal .cm-footer {
        position: sticky !important;
        bottom: 0 !important;
        z-index: 2 !important;
        padding: 12px 14px !important;
        background: #f8fafc !important;
        border-top: 1px solid #e2e8f0 !important;
    }

    /* WICHTIG: Klaro legt die Buttons in .cm-footer-buttons (Default: Zeile).
       Auf Mobile hier untereinander stapeln, sonst werden Buttons abgeschnitten. */
    .klaro .cookie-modal .cm-footer-buttons {
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        width: 100% !important;
    }

    .klaro .cookie-modal .cm-btn {
        width: 100% !important;
        flex: 0 0 auto !important;
        min-width: 0 !important;
        padding: 12px 16px !important;
        font-size: 14px !important;
        border-radius: 10px !important;
        margin: 0 !important;
    }
    /* Reihenfolge (order 1/2/3) wird global gesetzt:
       Nur notwendige -> Auswahl speichern -> Alle akzeptieren */
}

/* ===== DARK MODE ===== */
body.dark-mode .klaro .cookie-modal .cm-modal,
body.dark-mode .klaro .cookie-modal .cm-body {
    background: #1e293b !important;
}

body.dark-mode .klaro .cookie-modal li.cm-purpose {
    background: #334155 !important;
    border-color: #475569 !important;
}

body.dark-mode .klaro .cookie-modal .cm-list-title {
    color: #f1f5f9 !important;
}

body.dark-mode .klaro .cookie-modal .cm-required,
body.dark-mode .klaro .cookie-modal .cm-list-description {
    color: #94a3b8 !important;
}

body.dark-mode .klaro .cookie-modal .cm-footer {
    background: #0f172a !important;
    border-color: #334155 !important;
}

body.dark-mode .klaro .cookie-modal .cm-btn-decline,
body.dark-mode .klaro .cookie-modal .cm-btn-info,
body.dark-mode .klaro .cookie-modal .cm-btn-success,
body.dark-mode .klaro .cookie-modal .cm-btn-accept,
body.dark-mode .klaro .cookie-modal .cm-btn-accept-all {
    background: #334155 !important;
    border: 2px solid #475569 !important;
    color: #e2e8f0 !important;
    box-shadow: none !important;
}

body.dark-mode .klaro .cookie-modal li.cm-toggle-all {
    background: #1e3a2f !important;
    border-color: #10b981 !important;
}

/* ════════════════════════════════════════════════════════════════
   HOST-THEME-ISOLATION (für Apps mit dunklem eigenem CSS, z.B. ausbildung)
   Die zentrale CSS setzte im aufgeklappten Service-Bereich KEINEN
   Hintergrund -> dunkles App-CSS schlug durch. Hier wird das Modal
   durchgängig HELL erzwungen, auch der aufgeklappte Dienst.
   Höhere Spezifität (…cm-modal…) gewinnt gegen App-Regeln.
   Auf hellen Apps ist dieser Block ohne sichtbare Wirkung (gleiche Farben).
   ════════════════════════════════════════════════════════════════ */
.klaro .cookie-modal .cm-modal,
.klaro .cookie-modal .cm-modal .cm-body { background:#ffffff !important; }

.klaro .cookie-modal .cm-modal li.cm-purpose {
    background:#f8fafc !important;
    border:1px solid #e2e8f0 !important;
    color:#1e293b !important;
}

/* Aufgeklappter Dienst-Bereich: heller Hintergrund statt App-Dunkel */
.klaro .cookie-modal .cm-modal .cm-services,
.klaro .cookie-modal .cm-modal .cm-services ul.cm-content { background:transparent !important; }
.klaro .cookie-modal .cm-modal .cm-services li.cm-service {
    background:#ffffff !important;
    border:1px solid #e2e8f0 !important;
    border-radius:10px !important;
    padding:0.6rem 0.75rem !important;
    margin-top:0.5rem !important;
}

/* Texte/Links im Service-Bereich fest neutral (kein App-Akzent/Magenta) */
.klaro .cookie-modal .cm-modal .cm-list-label .cm-list-title { color:#1e293b !important; }
.klaro .cookie-modal .cm-modal .cm-list-label .cm-required { color:#64748b !important; }
.klaro .cookie-modal .cm-modal .cm-services .cm-caret a { color:#004080 !important; }
.klaro .cookie-modal .cm-modal .cm-service .cm-list-title { color:#334155 !important; }
.klaro .cookie-modal .cm-modal .cm-service .cm-list-description { color:#64748b !important; }
.klaro .cookie-modal .cm-modal .cm-service .purposes { color:#94a3b8 !important; }

/* Toggle-All-Box hell halten */
.klaro .cookie-modal .cm-modal li.cm-purpose.cm-toggle-all {
    background:#f0fdf4 !important; border:2px solid #86efac !important;
}

/* ════════════════════════════════════════════════════════════════
   BUTTONS ABSOLUT EINHEITLICH (002.01.03)
   Gegen durchschlagendes App-CSS: Unterstrich ("Auswahl speichern"),
   ungleiche Höhe, ausgegrautes "Nur notwendige". Höchste Spezifität,
   alle Zustände/Varianten hart auf identische Optik.
   ════════════════════════════════════════════════════════════════ */
.klaro .cookie-modal .cm-modal .cm-btn,
.klaro .cookie-modal .cm-modal .cm-footer .cm-btn,
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-success,
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-decline,
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-info,
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-accept,
.klaro .cookie-modal .cm-modal .cm-btn.cm-btn-accept-all {
    background:#ffffff !important;
    color:#1e293b !important;
    border:2px solid #cbd5e1 !important;
    border-radius:10px !important;
    box-shadow:none !important;
    transform:none !important;
    text-decoration:none !important;
    opacity:1 !important;
    filter:none !important;
    font-family:inherit !important;
    font-size:0.9rem !important;
    font-weight:600 !important;
    line-height:1.25 !important;
    letter-spacing:0 !important;
    text-transform:none !important;
    min-width:130px !important;
    min-height:48px !important;
    height:auto !important;
    padding:0.7rem 1rem !important;
    margin:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
    cursor:pointer !important;
}
/* Text/Icons INNERHALB der Buttons: kein Unterstrich, keine App-Farbe */
.klaro .cookie-modal .cm-modal .cm-btn,
.klaro .cookie-modal .cm-modal .cm-btn * {
    text-decoration:none !important;
    color:#1e293b !important;
}
/* Hover/Focus/Active/Disabled identisch (nur dezenter Rahmen-Hover) */
.klaro .cookie-modal .cm-modal .cm-btn:hover,
.klaro .cookie-modal .cm-modal .cm-btn:focus,
.klaro .cookie-modal .cm-modal .cm-btn:active,
.klaro .cookie-modal .cm-modal .cm-btn:disabled,
.klaro .cookie-modal .cm-modal .cm-btn[disabled] {
    background:#ffffff !important;
    color:#1e293b !important;
    border-color:#94a3b8 !important;
    box-shadow:none !important;
    transform:none !important;
    text-decoration:none !important;
    opacity:1 !important;
}
/* Footer: gleichmäßig verteilt, gleiche Breite */
.klaro .cookie-modal .cm-modal .cm-footer,
.klaro .cookie-modal .cm-modal .cm-footer .cm-footer-buttons {
    display:flex !important;
    gap:0.6rem !important;
    flex-wrap:wrap !important;
    align-items:stretch !important;
}
.klaro .cookie-modal .cm-modal .cm-footer .cm-btn { flex:1 1 0 !important; }
