/* ------------------------------------------------------------------
   VARS – copied from Complianz, prefixed for SCM
------------------------------------------------------------------ */
:root {
    --scm_banner_width: 526px;
    --scm_banner_background_color: #ffffff;
    --scm_banner_border_color: #f2f2f2;
    --scm_banner_border_width: 0px 0px 0px 0px;
    --scm_banner_border_radius: 12px 12px 12px 12px;
    --scm_banner_margin: 10px;
    --scm_categories_height: 110px;
    --scm_title_font_size: 15px;
    --scm_text_font_size: 12px;
    --scm_text_line_height: calc(var(--scm_text_font_size) * 1.5);
    --scm_text_color: #222222;
    --scm_hyperlink_color: #1E73BE;
    --scm_link_font_size: 12px;
    --scm_category_body_font_size: 12px;
    --scm_button_accept_background_color: #1E73BE;
    --scm_button_accept_border_color: #1E73BE;
    --scm_button_accept_text_color: #ffffff;
    --scm_button_deny_background_color: #f9f9f9;
    --scm_button_deny_border_color: #f2f2f2;
    --scm_button_deny_text_color: #222222;
    --scm_button_settings_background_color: #f9f9f9;
    --scm_button_settings_border_color: #f2f2f2;
    --scm_button_settings_text_color: #333333;
    --scm_button_border_radius: 6px 6px 6px 6px;
    --scm_button_font_size: 15px;
    --scm_category_header_always_active_color: green;
    --scm_category_header_title_font_size: 14px;
    --scm_category_header_active_font_size: 12px;
    --scm_slider_active_color: #1e73be;
    --scm_slider_inactive_color: #F56E28;
    --scm_slider_bullet_color: #ffffff;
}

/* ------------------------------------------------------------------
   BANNER CONTAINER – match Complianz layout
------------------------------------------------------------------ */

.scm-cookiebanner {
    box-sizing: border-box;
    max-height: calc(100vh - 20px);
    position: fixed;
    height: auto;
    right: 10px;
    bottom: 10px;
    z-index: 99999;
    background: var(--scm_banner_background_color);
    border-style: solid;
    border-color: var(--scm_banner_border_color);
    border-width: var(--scm_banner_border_width);
    border-radius: var(--scm_banner_border_radius);
    padding: 15px 20px;
    display: none;
    grid-template-rows: minmax(0, 1fr);
    grid-row-gap: 10px;
    grid-template-columns: 1fr 1fr 1fr;
    box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px,
                rgba(0, 0, 0, 0.23) 0px 6px 6px;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* show state */
.scm-cookiebanner.scm-show {
    display: grid;
}

/* HEADER --------------------------------------------------------- */

.scm-header {
    grid-template-columns: 100px 1fr 100px;
    align-items: center;
    display: grid;
    grid-column: span 3;
    padding: 0;
}

.scm-logo {
    width: auto;
    height: auto;
    border-radius: 0;
    background: transparent;
}

.scm-title {
    justify-self: center;
    grid-column-start: 2;
    font-size: var(--scm_title_font_size);
    color: var(--scm_text_color);
    font-weight: 500;
}

.scm-close {
    line-height: 20px;
    justify-self: end;
    grid-column-start: 3;
    font-size: 20px;
    cursor: pointer;
    width: 20px;
    height: 20px;
    color: var(--scm_text_color);
    background: none;
    border: 0;
    padding: 0;
}

/* BODY ----------------------------------------------------------- */

.scm-body {
    width: 100%;
    grid-column: span 3;
    overflow-y: auto;
    overflow-x: hidden;
    max-height: 55vh;
    padding: 0;
}

.scm-message {
    word-wrap: break-word;
    font-size: var(--scm_text_font_size);
    line-height: var(--scm_text_line_height);
    color: var(--scm_text_color);
    margin-bottom: 5px;
}

.scm-message a {
    color: var(--scm_hyperlink_color);
}

.scm-divider {
    height: 1px;
    background: #e5e7eb;
    grid-column: span 3;
    margin-left: -20px;
    margin-right: -20px;
}

/* ------------------------------------------------------------------
   CATEGORIES – mimicking Complianz
------------------------------------------------------------------ */

/* hidden initially; JS adds .scm-show-preferences on banner */
#scm-preferences {
    display: none;
}

#scm-cookiebanner.scm-show-preferences #scm-preferences {
    display: block;
    animation: scmFadeIn 0.5s;
}

@keyframes scmFadeIn {
    0% { opacity:0; }
    100% { opacity:1; }
}

.scm-categories {
    grid-column: span 3;
    border-radius: 8px;
    border: none;
    padding: 0;
    max-height: var(--scm_categories_height);
    overflow-y: auto;
}

.scm-category {
    background-color: rgba(239, 239, 239, 0.5);
    border-radius: 6px;
    margin-bottom: 10px;
}

.scm-category:last-child {
    margin-bottom: 0;
}

.scm-category summary {
    display: block;
    list-style: none;
}

.scm-category summary::marker,
.scm-category summary::-webkit-details-marker {
    display: none;
    content: '';
}

.scm-category-header {
    display: grid;
    grid-template-columns: 1fr auto 15px;
    align-items: center;
    grid-gap: 10px;
    padding: 10px;
    cursor: pointer;
}

.scm-category-title {
    font-weight: 500;
    justify-self: start;
    font-size: var(--scm_category_header_title_font_size);
    color: var(--scm_text_color);
    margin: 0;
}

.scm-always-active {
    font-size: var(--scm_category_header_active_font_size);
    font-weight: 500;
    color: var(--scm_category_header_always_active_color);
    margin: 0;
}

.scm-banner-checkbox {
    display: flex;
    align-items: center;
    margin: 0;
}

/* Functional checkbox is “always active” – hide switch UI (optional) */
.scm-functional .scm-banner-checkbox {
    display: none;
}

.scm-icon.scm-open {
    grid-column-start: 3;
    cursor: pointer;
    transform: rotate(0deg);
    transition: all 0.5s ease;
    font-size: 14px;
}

.scm-category[open] .scm-icon.scm-open {
    transform: rotate(180deg);
}

.scm-description {
    font-size: var(--scm_category_body_font_size);
    color: var(--scm_text_color);
    margin: 0;
    padding: 10px;
}

/* ------------------------------------------------------------------
   TOGGLE: restyle SCM switch more like Complianz
------------------------------------------------------------------ */

.scm-switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 20px;
}

.scm-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.scm-slider {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: var(--scm_slider_inactive_color);
    transition: .3s;
    border-radius: 10px;
}

.scm-slider:before {
    position: absolute;
    content: "";
    height: 11px;
    width: 11px;
    left: 4px;
    top: 4px;
    background-color: var(--scm_slider_bullet_color);
    transition: .3s;
    border-radius: 10px;
}

.scm-switch input:checked + .scm-slider {
    background-color: var(--scm_slider_active_color);
}

.scm-switch input:checked + .scm-slider:before {
    transform: translateX(16px);
}

/* ------------------------------------------------------------------
   BUTTONS – match Complianz look
------------------------------------------------------------------ */

.scm-buttons {
    display: flex;
    gap: var(--scm_banner_margin);
    grid-column: span 3;
    padding: 0;
}

.scm-btn {
    height: 45px;
    padding: 10px;
    margin: 0;
    width: 100%;
    white-space: nowrap;
    border-radius: var(--scm_button_border_radius);
    cursor: pointer;
    font-size: var(--scm_button_font_size);
    font-weight: 500;
    text-decoration: none;
    line-height: 20px;
    text-align: center;
    flex: initial;
    border: 1px solid transparent;
}

.scm-btn.scm-accept {
    background-color: var(--scm_button_accept_background_color);
    border-color: var(--scm_button_accept_border_color);
    color: var(--scm_button_accept_text_color);
}

.scm-btn.scm-deny {
    background-color: var(--scm_button_deny_background_color);
    border-color: var(--scm_button_deny_border_color);
    color: var(--scm_button_deny_text_color);
}

.scm-btn.scm-view-preferences {
    background-color: var(--scm_button_settings_background_color);
    border-color: var(--scm_button_settings_border_color);
    color: var(--scm_button_settings_text_color);
}

.scm-documents {
    grid-column: span 3;
    border-top: none;
    padding: 0;
}

.scm-documents ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    gap: var(--scm_banner_margin);
    justify-content: center;
}

.scm-documents a {
    color: var(--scm_hyperlink_color);
    font-size: var(--scm_link_font_size);
    text-decoration: underline;
}
.scm-documents a:hover {
    color: var(--scm_hyperlink_color);
}

/* ------------------------------------------------------------------
   RESPONSIVE
------------------------------------------------------------------ */

@media (min-width: 768px) {
    .scm-cookiebanner {
        min-width: var(--scm_banner_width);
        max-width: 100%;
    }

    .scm-message,
    .scm-categories {
        width: calc(var(--scm_banner_width) - 42px);
    }
}

@media (max-width: 768px) {
    .scm-cookiebanner {
        left: initial;
        right: initial;
        bottom: 0;
        top: initial;
        transform: none;
        width: 100%;
    }

    .scm-buttons {
        flex-direction: column;
    }
}

@media (max-width: 425px) {
    .scm-header .scm-title {
        display: none;
    }

    .scm-message {
        margin-right: 5px;
    }

    .scm-category-header {
        grid-template-columns: 1fr !important;
    }
}
