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

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

/* Modal Container */
.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;
    overflow: hidden !important;
}

/* ===== HEADER ===== */
.klaro .cookie-modal .cm-header {
    background: linear-gradient(135deg, #004080 0%, #0066cc 100%) !important;
    padding: 1.5rem !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.9rem !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

/* ===== BODY ===== */
.klaro .cookie-modal .cm-body {
    background: #ffffff !important;
    padding: 1rem !important;
    max-height: 55vh !important;
    overflow-y: auto !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 - GRUEN 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 fuer required - immer gruen/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 ===== */
.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;
}

/* ===== BUTTONS ===== */
.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: all 0.2s ease !important;
    border: none !important;
    flex: 1 !important;
    min-width: 130px !important;
    text-align: center !important;
}

/* Decline - "Nur notwendige" */
.klaro .cookie-modal .cm-btn-decline {
    background: #ffffff !important;
    color: #475569 !important;
    border: 2px solid #e2e8f0 !important;
    order: 1 !important;
}

.klaro .cookie-modal .cm-btn-decline:hover {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
}

/* Info - "Auswahl speichern" */
.klaro .cookie-modal .cm-btn-info {
    background: #ffffff !important;
    color: #475569 !important;
    border: 2px solid #e2e8f0 !important;
    order: 2 !important;
}

.klaro .cookie-modal .cm-btn-info:hover {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
}

/* Accept - "Alle akzeptieren" */
.klaro .cookie-modal .cm-btn-success {
    background: linear-gradient(135deg, #004080, #0066cc) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(0, 64, 128, 0.3) !important;
    order: 3 !important;
}

.klaro .cookie-modal .cm-btn-success:hover {
    background: linear-gradient(135deg, #003366, #004d99) !important;
    transform: translateY(-1px) !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) {
    .klaro .cookie-modal {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 16px !important;
        z-index: 999999 !important;
        background: rgba(0,0,0,0.7) !important;
        overflow: hidden !important;
    }
    
    .klaro .cookie-modal .cm-modal {
        position: relative !important;
        border-radius: 16px !important;
        max-width: 100% !important;
        width: 100% !important;
        max-height: 80vh !important;
        margin: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
        box-shadow: 0 20px 60px rgba(0,0,0,0.4) !important;
    }
    
    .klaro .cookie-modal .cm-modal::before {
        display: none !important;
    }
    
    .klaro .cookie-modal .cm-header {
        padding: 14px 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;
    }
    
    .klaro .cookie-modal .cm-body {
        flex: 1 1 auto !important;
        min-height: 100px !important;
        max-height: 45vh !important;
        overflow-y: auto !important;
        padding: 10px 14px !important;
        -webkit-overflow-scrolling: touch !important;
    }
    
    .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;
    }
    
    .klaro .cookie-modal .cm-footer {
        flex-shrink: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 8px !important;
        padding: 12px 14px !important;
        background: #f8fafc !important;
        border-top: 1px solid #e2e8f0 !important;
    }
    
    .klaro .cookie-modal .cm-btn {
        width: 100% !important;
        padding: 12px 16px !important;
        font-size: 14px !important;
        border-radius: 10px !important;
        margin: 0 !important;
    }
    
    .klaro .cookie-modal .cm-btn-success,
    .klaro .cookie-modal .cm-btn-accept-all {
        order: -2 !important;
    }
    
    .klaro .cookie-modal .cm-btn-decline {
        order: -1 !important;
    }
}

/* ===== 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 {
    background: #334155 !important;
    border-color: #475569 !important;
    color: #e2e8f0 !important;
}

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