/* =========================================================
   COOKIE CONSENT BANNER + PREFERENCES MODAL
========================================================= */

/* Banner — slides up from the bottom on first visit */
.cs-cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 10500;
    background: #fff;
    border-top: 3px solid #0f63c9;
    box-shadow: 0 -4px 28px rgba(0, 0, 0, 0.13);
    transform: translateY(110%);
    transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

.cs-cookie-banner--visible {
    transform: translateY(0);
}

.cs-cookie-banner--hidden {
    transform: translateY(110%);
}

.cs-cookie-banner-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0.9rem 1.75rem;
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
}

/* Text block */
.cs-cookie-text {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    flex: 1 1 480px;
    min-width: 0;
}

.cs-cookie-icon {
    font-size: 1.7rem;
    color: #0f63c9;
    flex-shrink: 0;
    margin-top: 0.05rem;
}

.cs-cookie-text strong {
    display: block;
    font-size: 0.94rem;
    font-weight: 800;
    color: #15417f;
    margin-bottom: 0.18rem;
}

.cs-cookie-text p {
    font-size: 0.83rem;
    color: #5a6777;
    margin: 0;
    line-height: 1.55;
}

.cs-cookie-text a {
    color: #0f63c9;
    font-weight: 600;
}

/* Action buttons */
.cs-cookie-actions {
    display: flex;
    gap: 0.55rem;
    align-items: center;
    flex-wrap: wrap;
    flex-shrink: 0;
}

/* Shared button base */
.cs-btn {
    display: inline-block;
    padding: 0.52rem 1.1rem;
    border-radius: 3px;
    font-size: 0.87rem;
    font-weight: 700;
    cursor: pointer;
    border: 1.5px solid transparent;
    transition: background 0.12s, color 0.12s, border-color 0.12s;
    white-space: nowrap;
    line-height: 1.3;
    text-align: center;
}

.cs-btn-primary {
    background: linear-gradient(180deg, #0f63c9 0%, #0053b0 100%);
    color: #fff;
    border-color: #0053b0;
}

.cs-btn-primary:hover {
    background: #003e87;
    border-color: #003e87;
    color: #fff;
}

.cs-btn-outline {
    background: transparent;
    color: #15417f;
    border-color: #c5d2e4;
}

.cs-btn-outline:hover {
    background: #f0f5fb;
    border-color: #8aaad0;
    color: #0f63c9;
}

/* =========================================================
   PREFERENCES MODAL
========================================================= */

.cs-cookie-modal-content {
    border: 1px solid #e1e6ec;
    border-radius: 4px;
    overflow: hidden;
}

.cs-cookie-modal-header {
    background: linear-gradient(180deg, #1e3a5f 0%, #15417f 100%);
    border-bottom: none;
    padding: 1rem 1.5rem;
}

.cs-cookie-modal-header .btn-close {
    filter: brightness(0) invert(1);
    opacity: 0.8;
}

.cs-cookie-modal-header .btn-close:hover {
    opacity: 1;
}

.cs-modal-header-content {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.cs-modal-icon {
    font-size: 1.35rem;
    color: #7eb3f0;
}

.cs-cookie-modal-header .modal-title {
    color: #fff;
    font-weight: 800;
    font-size: 1.1rem;
    margin: 0;
}

.cs-cookie-modal-body {
    padding: 1.5rem;
    background: #f9fafc;
}

.cs-modal-intro {
    font-size: 0.88rem;
    color: #5a6777;
    margin-bottom: 1.25rem;
    line-height: 1.6;
    background: #fff;
    border: 1px solid #e1e6ec;
    border-radius: 4px;
    padding: 0.85rem 1rem;
}

/* Category cards */
.cs-cookie-category {
    background: #fff;
    border: 1px solid #e1e6ec;
    border-radius: 4px;
    padding: 1rem 1.25rem;
    margin-bottom: 0.65rem;
}

.cs-cookie-category:last-child {
    margin-bottom: 0;
}

.cs-cookie-category-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
}

.cs-cookie-category-text {
    flex: 1;
    min-width: 0;
}

.cs-cat-title {
    font-size: 0.92rem;
    font-weight: 800;
    color: #15417f;
    margin-bottom: 0.3rem;
}

.cs-cat-desc {
    font-size: 0.81rem;
    color: #5a6777;
    margin: 0;
    line-height: 1.5;
}

/* "Always Active" badge */
.cs-badge-always-on {
    display: inline-flex;
    align-items: center;
    background: #e8f4e9;
    color: #1a6032;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0.28rem 0.75rem;
    border-radius: 20px;
    white-space: nowrap;
    flex-shrink: 0;
    border: 1px solid #b3ddb3;
    margin-top: 0.1rem;
}

/* Toggle switch */
.cs-toggle {
    position: relative;
    display: inline-block;
    width: 46px;
    height: 25px;
    flex-shrink: 0;
    cursor: pointer;
    margin-top: 0.1rem;
}

.cs-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}

.cs-toggle-slider {
    position: absolute;
    inset: 0;
    background: #cfd8e4;
    border-radius: 25px;
    transition: background 0.2s;
}

.cs-toggle-slider::before {
    content: '';
    position: absolute;
    width: 19px;
    height: 19px;
    left: 3px;
    top: 3px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}

.cs-toggle input:checked + .cs-toggle-slider {
    background: #0f63c9;
}

.cs-toggle input:checked + .cs-toggle-slider::before {
    transform: translateX(21px);
}

.cs-toggle input:focus-visible + .cs-toggle-slider {
    outline: 2px solid #0f63c9;
    outline-offset: 2px;
}

/* Modal footer */
.cs-cookie-modal-footer {
    padding: 0.85rem 1.5rem;
    border-top: 1px solid #e1e6ec;
    background: #fff;
    display: flex;
    justify-content: flex-end;
    gap: 0.6rem;
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 767.98px) {
    .cs-cookie-banner-inner {
        flex-direction: column;
        padding: 1.1rem 1rem 1.25rem;
        gap: 0.9rem;
    }

    .cs-cookie-text {
        flex: none;
        width: 100%;
    }

    .cs-cookie-actions {
        width: 100%;
        flex-direction: column;
        gap: 0.5rem;
    }

    .cs-btn {
        width: 100%;
        padding: 0.65rem 1rem;
    }

    .cs-cookie-category-header {
        flex-direction: column;
        gap: 0.75rem;
    }

    .cs-badge-always-on,
    .cs-toggle {
        align-self: flex-start;
    }
}
