/* =========================================================================
   Complianz cookie consent banner — Tessora brand styling.
   Dark glass card + bronze CTA, matched to hero accordion aesthetic.
   !important is needed because Complianz injects inline colors from its
   Colors admin tab; without it our rules lose to the inline style attribute.
   ========================================================================= */

/* Strip background from any wrapper — Complianz container can render an
   opaque white panel behind our translucent banner, killing backdrop-filter. */
#cmplz-cookiebanner-container,
.cmplz-cookiebanner-container,
.cmplz-cookiebanner-wrapper {
    background: transparent !important;
    background-color: transparent !important;
}

.cmplz-cookiebanner,
.cmplz-cookiebanner.banner-a,
.cmplz-cookiebanner.cmplz-categories-type-view-preferences {
    position: fixed !important;
    bottom: 20px !important;
    right: 20px !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    background: rgba(20, 18, 16, 0.62) !important;
    background-color: rgba(20, 18, 16, 0.62) !important;
    backdrop-filter: blur(28px) saturate(140%) !important;
    -webkit-backdrop-filter: blur(28px) saturate(140%) !important;
    border: 1px solid rgba(168, 104, 61, 0.18) !important;
    border-radius: 12px !important;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45) !important;
    color: #ECECEC !important;
    font-family: "Inter", system-ui, sans-serif !important;
    padding: 16px 22px !important;
    width: 50vw !important;
    max-width: 50vw !important;
    box-sizing: border-box !important;
}

/* Force message + body to full width — Complianz lays out the inner blocks
   as a flex/grid row, leaving message squashed to ~50%. */
.cmplz-cookiebanner > div,
.cmplz-cookiebanner > section,
.cmplz-cookiebanner .cmplz-body,
.cmplz-cookiebanner .cmplz-message-wrapper,
.cmplz-cookiebanner .cmplz-summary,
.cmplz-cookiebanner .cmplz-message,
.cmplz-cookiebanner .cmplz-message p,
.cmplz-cookiebanner .cmplz-description {
    width: 100% !important;
    max-width: 100% !important;
    flex: 1 1 100% !important;
    grid-column: 1 / -1 !important;
}

/* Pin to bottom-right corner with a small inset */
.cmplz-cookiebanner.cmplz-bottom-right,
.cmplz-cookiebanner.cmplz-bottom-left {
    right: 20px !important;
    left: auto !important;
    bottom: 20px !important;
    transform: none !important;
}

/* Force header / title visible — Complianz hides it depending on banner mode */
.cmplz-cookiebanner .cmplz-header,
.cmplz-cookiebanner .cmplz-title {
    display: block !important;
    visibility: visible !important;
    color: #FFFFFF !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    line-height: 1.3 !important;
    margin: 0 0 3px 0 !important;
    opacity: 1 !important;
}

.cmplz-cookiebanner .cmplz-message,
.cmplz-cookiebanner .cmplz-message p,
.cmplz-cookiebanner .cmplz-description {
    color: rgba(236, 236, 236, 0.78) !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

.cmplz-cookiebanner a,
.cmplz-cookiebanner .cmplz-links a {
    color: #C7875D !important;
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
    transition: color 0.2s ease !important;
}
.cmplz-cookiebanner a:hover { color: #E1A47B !important; }

.cmplz-cookiebanner .cmplz-close {
    position: absolute !important;
    top: 12px !important;
    right: 14px !important;
    color: rgba(236, 236, 236, 0.6) !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    z-index: 2 !important;
    transition: color 0.2s ease !important;
}
.cmplz-cookiebanner .cmplz-close:hover { color: #FFFFFF !important; }

/* Buttons baseline */
.cmplz-cookiebanner .cmplz-btn,
.cmplz-cookiebanner button.cmplz-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 31px !important;
    border-radius: 6px !important;
    font-family: "Inter", system-ui, sans-serif !important;
    font-weight: 500 !important;
    font-size: 11px !important;
    padding: 0 16px !important;
    border: 1px solid transparent !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
    transition: background 0.25s ease, color 0.25s ease,
                border-color 0.25s ease, transform 0.25s ease !important;
}

/* Accept — primary bronze CTA */
.cmplz-cookiebanner .cmplz-btn.cmplz-accept,
.cmplz-cookiebanner .cmplz-btn.cmplz-accept-all,
.cmplz-cookiebanner .cmplz-btn.cmplz-accept-all-categories,
.cmplz-cookiebanner button.cmplz-accept,
.cmplz-cookiebanner button.cmplz-accept-all {
    background: linear-gradient(138.54deg, #A8683D 0%, #C7875D 94.53%) !important;
    background-color: #A8683D !important;
    color: #FFFFFF !important;
    border-color: transparent !important;
}
.cmplz-cookiebanner .cmplz-btn.cmplz-accept:hover,
.cmplz-cookiebanner .cmplz-btn.cmplz-accept-all:hover,
.cmplz-cookiebanner .cmplz-btn.cmplz-accept-all-categories:hover {
    background: linear-gradient(138.54deg, #B47346 0%, #D2956C 94.53%) !important;
    transform: translateY(-1px) !important;
}

/* Every non-accept button — outline. Catches deny / view-preferences /
   save-preferences / manage-consent / any other secondary button Complianz
   may render. */
.cmplz-cookiebanner .cmplz-btn:not(.cmplz-accept):not(.cmplz-accept-all):not(.cmplz-accept-all-categories) {
    background: transparent !important;
    background-color: transparent !important;
    color: #ECECEC !important;
    border: 1px solid rgba(236, 236, 236, 0.25) !important;
}
.cmplz-cookiebanner .cmplz-btn:not(.cmplz-accept):not(.cmplz-accept-all):not(.cmplz-accept-all-categories):hover {
    background: rgba(168, 104, 61, 0.12) !important;
    border-color: #A8683D !important;
    color: #FFFFFF !important;
}

/* Categories list inside Preferences modal */
.cmplz-cookiebanner .cmplz-category {
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    margin-bottom: 6px !important;
    padding: 10px 14px !important;
}
.cmplz-cookiebanner .cmplz-category .cmplz-category-title {
    color: #FFFFFF !important;
    font-weight: 500 !important;
    font-size: 13px !important;
}

/* Toggle slider — bronze when active */
.cmplz-cookiebanner .cmplz-slider {
    background-color: rgba(255, 255, 255, 0.18) !important;
}
.cmplz-cookiebanner input:checked + .cmplz-label-text + .cmplz-slider,
.cmplz-cookiebanner input:checked ~ .cmplz-slider {
    background: linear-gradient(138.54deg, #A8683D 0%, #C7875D 94.53%) !important;
}

/* Mobile */
@media (max-width: 768px) {
    .cmplz-cookiebanner,
    .cmplz-cookiebanner.banner-a {
        width: calc(100vw - 24px) !important;
        max-width: calc(100vw - 24px) !important;
        padding: 14px 16px !important;
    }
    .cmplz-cookiebanner .cmplz-btn { width: 100% !important; text-align: center !important; }
}
