/* Klaro Cookie Consent - Custom Styling for Pipette.bio */

/* Override Klaro's default colors to match site theme */
.klaro {
    --primary-color: #D97758;
    --primary-dark: #C56548;
    --primary-light: #E58A6B;
    --bg-dark: #1a1a1d;
    --bg-card: #252528;
    --border-color: #3a3a3d;
    --text-primary: #e9dfdf;
    --text-secondary: #9CA3AF;
}

/* Notice bar (bottom banner) */
.klaro .cookie-notice {
    background: var(--bg-dark) !important;
    border-top: 1px solid var(--border-color) !important;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.5) !important;
}

.klaro .cookie-notice .cn-body {
    padding: 1.25rem 1.5rem !important;
}

.klaro .cookie-notice p {
    color: var(--text-secondary) !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
}

.klaro .cookie-notice .cn-ok {
    display: flex !important;
    gap: 0.75rem !important;
    flex-wrap: wrap !important;
    margin-top: 1rem !important;
}

/* Buttons */
.klaro .cm-btn {
    border-radius: 6px !important;
    padding: 0.6rem 1.25rem !important;
    font-weight: 500 !important;
    font-size: 0.875rem !important;
    transition: all 0.2s ease !important;
    border: none !important;
}

.klaro .cm-btn-success {
    background: var(--primary-color) !important;
    color: white !important;
}

.klaro .cm-btn-success:hover {
    background: var(--primary-dark) !important;
}

.klaro .cm-btn-info,
.klaro .cm-btn-decline {
    background: transparent !important;
    color: var(--text-secondary) !important;
    border: 1px solid var(--border-color) !important;
}

.klaro .cm-btn-info:hover,
.klaro .cm-btn-decline:hover {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}

/* Modal */
.klaro .cookie-modal {
    background: rgba(0, 0, 0, 0.8) !important;
    backdrop-filter: blur(4px) !important;
}

.klaro .cookie-modal .cm-modal {
    background: var(--bg-dark) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6) !important;
    max-width: 640px !important;
}

.klaro .cookie-modal .cm-header {
    background: transparent !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 1.5rem !important;
}

.klaro .cookie-modal .cm-header h1 {
    color: var(--text-primary) !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
}

.klaro .cookie-modal .cm-body {
    padding: 1.5rem !important;
    background: transparent !important;
}

.klaro .cookie-modal .cm-body p {
    color: var(--text-secondary) !important;
}

.klaro .cookie-modal .cm-footer {
    background: transparent !important;
    border-top: 1px solid var(--border-color) !important;
    padding: 1rem 1.5rem !important;
}

/* Purpose sections */
.klaro .cookie-modal .cm-purpose {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: 8px !important;
    margin-bottom: 1rem !important;
    padding: 1rem !important;
}

.klaro .cookie-modal .cm-purpose > .cm-list-title {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 1rem !important;
}

.klaro .cookie-modal .cm-purpose .cm-title {
    color: var(--text-primary) !important;
    font-weight: 500 !important;
    flex: 1 !important;
    min-width: 0 !important;
}

.klaro .cookie-modal .cm-purpose .cm-description {
    color: var(--text-secondary) !important;
    font-size: 0.85rem !important;
    margin-top: 0.5rem !important;
    padding-right: 60px !important;
}

/* Service items */
.klaro .cookie-modal .cm-service {
    border-top: 1px solid var(--border-color) !important;
    padding-top: 0.75rem !important;
    margin-top: 0.75rem !important;
}

.klaro .cookie-modal .cm-service > .cm-list-title {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 1rem !important;
}

.klaro .cookie-modal .cm-service .cm-title {
    color: var(--text-primary) !important;
    flex: 1 !important;
    min-width: 0 !important;
}

.klaro .cookie-modal .cm-service .cm-description {
    color: var(--text-muted) !important;
    font-size: 0.8rem !important;
    margin-top: 0.25rem !important;
    padding-right: 60px !important;
}

/* Toggle switches - fix overlap */
.klaro .cm-list-input:checked + .cm-list-label .slider {
    background: var(--primary-color) !important;
}

.klaro .cm-list-label {
    display: flex !important;
    align-items: flex-start !important;
    gap: 1rem !important;
    padding-right: 0 !important;
}

.klaro .cm-list-label .slider {
    background: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    flex-shrink: 0 !important;
    position: relative !important;
    margin-right: 0.5rem !important;
}

.klaro .cm-list-label .slider::before {
    background: var(--text-primary) !important;
}

/* Fix purpose/service header layout */
.klaro .cm-purpose .cm-list-title,
.klaro .cm-service .cm-list-title {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
}

.klaro .cm-purpose .cm-list-title .cm-title,
.klaro .cm-service .cm-list-title .cm-title {
    flex: 1 !important;
    padding-right: 1rem !important;
}

/* Ensure switch doesn't overlap text */
.klaro .cm-switch {
    flex-shrink: 0 !important;
    margin-left: auto !important;
}

/* Links */
.klaro a {
    color: var(--primary-color) !important;
}

.klaro a:hover {
    color: var(--primary-light) !important;
}

/* Hide powered by */
.klaro .cm-powered-by {
    display: none !important;
}

/* Mobile responsiveness */
@media (max-width: 640px) {
    .klaro .cookie-notice .cn-ok {
        flex-direction: column !important;
    }

    .klaro .cm-btn {
        width: 100% !important;
        text-align: center !important;
    }

    .klaro .cookie-modal .cm-modal {
        margin: 1rem !important;
        max-height: calc(100vh - 2rem) !important;
    }
}
