/* Cookie consent banner — pinned to viewport bottom, gates GA4 load. */

.consent[hidden] {
    display: none;
}

.consent {
    position: fixed;
    inset-inline: 1.5rem;
    inset-block-end: 1.5rem;
    max-inline-size: 45rem;
    margin-inline: auto;
    padding: 1rem 1.25rem;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: 0 0.25rem 1rem rgba(0, 0, 0, 0.08);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    z-index: 50;
    transform: translateY(calc(100% + 1.5rem));
    opacity: 0;
}

.consent--visible {
    transform: translateY(0);
    opacity: 1;
}

@media (prefers-reduced-motion: no-preference) {
    .consent {
        transition: transform 280ms ease, opacity 200ms ease;
    }
}

.consent__copy {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--color-text-muted);
    max-inline-size: 60ch;
    flex: 1 1 20rem;
}

.consent__link {
    color: var(--color-primary);
    text-decoration: underline;
}

.consent__link:hover {
    opacity: 0.85;
    color: var(--color-primary);
}

.consent__actions {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

.consent__btn {
    font: inherit;
    font-size: 0.875rem;
    font-weight: 600;
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text);
    cursor: pointer;
    transition: background-color 150ms, color 150ms, border-color 150ms;
}

.consent__btn:hover {
    background: var(--color-bg);
}

.consent__btn--accept {
    background: var(--color-primary);
    color: var(--color-text-inverse);
    border-color: var(--color-primary);
}

.consent__btn--accept:hover {
    background: #a82f2f;
    color: var(--color-text-inverse);
}

/* Footer "Cookie settings" trigger. */
.consent-trigger {
    background: none;
    border: 0;
    padding: 0;
    font-family: inherit;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-muted);
    cursor: pointer;
}

.consent-trigger:hover {
    color: var(--default-link-hover);
}
