/* ─── Cookie Consent Banner ───
   Module-specific styling for the cookie consent banner.
   Uses IBIS CSS framework tokens via var() for consistency. */

/* Banner outer — fixed bottom bar with slide-up animation */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: var(--surface-raised);
    color: var(--content);
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.15);
    transform: translateY(100%);
    transition: transform var(--transition);
}

.cookie-banner.show {
    transform: translateY(0);
}

/* Close button */
.cookie-close {
    position: absolute;
    top: var(--sp-1);
    right: var(--sp-2);
    background: none;
    border: none;
    color: var(--content-subtle);
    font-size: var(--fs-500);
    cursor: pointer;
    padding: var(--sp-1) var(--sp-2);
    line-height: 1;
    transition: color var(--transition-fast);
}

.cookie-close:hover {
    color: var(--content);
}

/* Compact buttons inside the banner — same height, no wrapping */
.cookie-banner .button,
.cookie-banner .button.alt {
    margin: 0;
    white-space: nowrap;
}

/* ─── Preferences Page ─── */

/* Compact table for cookie details */
.cookie-table {
    font-size: var(--fs-300);
}

.cookie-table code {
    font-size: var(--fs-300);
    background-color: var(--surface-subtle);
}

/* Badges — coloured inline labels */
.cookie-badge {
    display: inline-block;
    padding: 0.15rem 0.45rem;
    border-radius: var(--radius-sm);
    font-size: var(--fs-200);
    font-weight: var(--fw-semibold);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    line-height: var(--lh-snug);
}

.cookie-badge.essential {
    background: var(--brand);
    color: var(--brand-contrast);
}

.cookie-badge.preference {
    background: var(--accent-warning);
    color: var(--brand-contrast);
}

/* Legend row */
.cookie-legend {
    font-size: var(--fs-300);
    color: var(--content-muted);
}

/* Status indicators */
.cookie-status {
    padding: var(--sp-3) var(--sp-4);
    border-radius: var(--radius);
    font-weight: var(--fw-medium);
}

.cookie-status-none {
    background: color-mix(in srgb, var(--accent-warning) 10%, transparent);
    color: var(--accent-warning);
    border-left: 3px solid var(--accent-warning);
}

.cookie-status-accepted {
    background: color-mix(in srgb, var(--success) 10%, transparent);
    color: var(--success);
    border-left: 3px solid var(--success);
}

.cookie-status-essential {
    background: color-mix(in srgb, var(--accent-info) 10%, transparent);
    color: var(--accent-info);
    border-left: 3px solid var(--accent-info);
}

/* Preference action buttons */
.cookie-preference-actions {
    display: flex;
    gap: var(--sp-4);
    margin-top: var(--sp-4);
    flex-wrap: wrap;
}

.inline-form {
    display: inline;
}

/* ─── Responsive ─── */
@media (max-width: 48rem) {
    .cookie-banner > div {
        flex-direction: column;
        align-items: stretch;
    }

    .cookie-banner > div > div:first-child {
        flex: none;
    }

    .cookie-banner .flex.gap-3 {
        justify-content: stretch;
    }

    .cookie-banner .flex.gap-3 .button {
        flex: 1;
        text-align: center;
    }

    .cookie-table {
        font-size: var(--fs-200);
    }
}
