/* consent.css — HUDA Radio módulo de consentimiento de cookies (AEPD 2023).
   Estética alineada con la portada P0.10: fondo casi negro tinte violeta,
   acento violeta puntual, Inter para UI. */

:root {
    --huda-c-ink: #0a0510;
    --huda-c-ink-2: #120a22;
    --huda-c-paper: #f5efe6;
    --huda-c-paper-mute: #a89cbf;
    --huda-c-rule: rgba(245, 239, 230, .14);
    --huda-c-accent: #c084fc;
    --huda-c-accent-strong: #a855f7;
    --huda-c-danger: #ef4444;
    --huda-c-bg-overlay: rgba(5, 2, 12, .68);
    --huda-c-shadow: 0 24px 60px rgba(0, 0, 0, .55);
}

/* ---------- Banner (capa 1) ---------- */

.huda-consent-banner {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 12000;
    width: min(480px, calc(100vw - 36px));
    display: none;
    padding: 22px 22px 18px;
    border-radius: 18px;
    background: var(--huda-c-ink-2);
    color: var(--huda-c-paper);
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
    border: 1px solid var(--huda-c-rule);
    box-shadow: var(--huda-c-shadow);
}
.huda-consent-banner.is-visible { display: block; }

.huda-consent-banner__kicker {
    display: inline-block;
    margin-bottom: 8px;
    font-size: .7rem;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--huda-c-accent);
}

.huda-consent-banner__title {
    margin: 0 0 6px;
    font-size: 1.18rem;
    line-height: 1.2;
    color: #fff;
    font-weight: 700;
}

.huda-consent-banner__text {
    margin: 0;
    color: rgba(245, 239, 230, .82);
    font-size: .92rem;
    line-height: 1.5;
}

.huda-consent-banner__text a {
    color: var(--huda-c-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.huda-consent-banner__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 16px;
}

/* Botones: misma jerarquía visual (AEPD). Mismo tamaño y peso.
   Solo cambia el color de fondo. */
.huda-consent-btn {
    flex: 1 1 auto;
    min-width: 110px;
    min-height: 42px;
    border-radius: 10px;
    padding: 10px 14px;
    font-family: inherit;
    font-size: .92rem;
    font-weight: 700;
    line-height: 1.1;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background-color .15s ease, transform .15s ease, border-color .15s ease;
}
.huda-consent-btn:focus-visible {
    outline: 2px solid var(--huda-c-accent);
    outline-offset: 2px;
}
.huda-consent-btn--accept {
    background: var(--huda-c-accent-strong);
    color: #fff;
}
.huda-consent-btn--accept:hover { background: var(--huda-c-accent); }

.huda-consent-btn--reject {
    background: transparent;
    color: var(--huda-c-paper);
    border-color: var(--huda-c-rule);
}
.huda-consent-btn--reject:hover {
    background: rgba(245, 239, 230, .08);
    border-color: rgba(245, 239, 230, .3);
}

.huda-consent-btn--config {
    background: rgba(168, 85, 247, .12);
    color: var(--huda-c-accent);
    border-color: rgba(168, 85, 247, .3);
}
.huda-consent-btn--config:hover {
    background: rgba(168, 85, 247, .2);
}

/* ---------- Panel preferencias (modal capa 1 detallada) ---------- */

.huda-consent-panel {
    position: fixed;
    inset: 0;
    z-index: 12100;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 16px;
    background: var(--huda-c-bg-overlay);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Arial, sans-serif;
}
.huda-consent-panel.is-visible { display: flex; }

body.huda-consent-modal-open { overflow: hidden; }

.huda-consent-panel__dialog {
    width: min(560px, 100%);
    max-height: calc(100vh - 32px);
    overflow-y: auto;
    background: var(--huda-c-ink);
    color: var(--huda-c-paper);
    border: 1px solid var(--huda-c-rule);
    border-radius: 20px;
    box-shadow: var(--huda-c-shadow);
    padding: 28px;
}

.huda-consent-panel__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.huda-consent-panel__title {
    margin: 0;
    font-size: 1.3rem;
    color: #fff;
    font-weight: 700;
}

.huda-consent-panel__close {
    background: transparent;
    border: 0;
    color: var(--huda-c-paper-mute);
    font-size: 1.6rem;
    line-height: 1;
    padding: 4px 8px;
    cursor: pointer;
    border-radius: 8px;
}
.huda-consent-panel__close:hover { color: var(--huda-c-paper); background: rgba(255,255,255,.06); }
.huda-consent-panel__close:focus-visible { outline: 2px solid var(--huda-c-accent); }

.huda-consent-panel__intro {
    margin: 0 0 18px;
    color: var(--huda-c-paper-mute);
    font-size: .92rem;
    line-height: 1.55;
}

.huda-consent-category {
    border-top: 1px solid var(--huda-c-rule);
    padding: 16px 0;
}
.huda-consent-category:last-of-type { border-bottom: 1px solid var(--huda-c-rule); }

.huda-consent-category__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.huda-consent-category__title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
}

.huda-consent-category__lock {
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--huda-c-paper-mute);
    padding: 4px 8px;
    border-radius: 6px;
    background: rgba(255,255,255,.06);
}

.huda-consent-category__desc {
    margin: 8px 0 0;
    color: var(--huda-c-paper-mute);
    font-size: .88rem;
    line-height: 1.55;
}

.huda-consent-category__cookies {
    margin: 8px 0 0;
    color: rgba(168, 156, 191, .8);
    font-size: .78rem;
    font-family: ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
}

/* Switch accesible */
.huda-consent-switch {
    --w: 44px;
    --h: 24px;
    position: relative;
    display: inline-block;
    width: var(--w);
    height: var(--h);
    flex: 0 0 auto;
}
.huda-consent-switch input {
    position: absolute;
    inset: 0;
    opacity: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    cursor: pointer;
}
.huda-consent-switch .track {
    position: absolute;
    inset: 0;
    background: rgba(168, 156, 191, .25);
    border-radius: 999px;
    transition: background-color .15s ease;
}
.huda-consent-switch .thumb {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    transition: transform .15s ease;
}
.huda-consent-switch input:checked + .track { background: var(--huda-c-accent-strong); }
.huda-consent-switch input:checked + .track + .thumb { transform: translateX(20px); }
.huda-consent-switch input:focus-visible + .track {
    outline: 2px solid var(--huda-c-accent);
    outline-offset: 2px;
}
.huda-consent-switch input:disabled + .track { opacity: .5; cursor: not-allowed; }
.huda-consent-switch input:disabled ~ .thumb { opacity: .5; }

.huda-consent-category--locked .huda-consent-switch input:checked + .track { background: rgba(168, 156, 191, .45); }

.huda-consent-panel__foot {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 20px;
    align-items: center;
    justify-content: flex-end;
}
.huda-consent-panel__foot .huda-consent-btn { flex: 0 0 auto; }

/* ---------- Icono flotante persistente ---------- */

.huda-consent-icon {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 11900;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--huda-c-rule);
    background: var(--huda-c-ink-2);
    color: var(--huda-c-paper);
    box-shadow: 0 10px 26px rgba(0, 0, 0, .35);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .15s ease, background-color .15s ease;
    padding: 0;
}
.huda-consent-icon:hover { transform: translateY(-1px); background: #1a0f33; }
.huda-consent-icon:focus-visible { outline: 2px solid var(--huda-c-accent); outline-offset: 2px; }
.huda-consent-icon.is-hidden { display: none; }
.huda-consent-icon svg {
    width: 22px;
    height: 22px;
    fill: var(--huda-c-accent);
}

/* ---------- Mobile ---------- */
@media (max-width: 640px) {
    .huda-consent-banner {
        right: 8px;
        bottom: 8px;
        width: calc(100vw - 16px);
        padding: 18px 18px 14px;
        border-radius: 14px;
    }
    .huda-consent-banner__actions { gap: 6px; }
    .huda-consent-btn { min-width: 90px; padding: 9px 10px; font-size: .88rem; }
    .huda-consent-panel__dialog { padding: 22px; border-radius: 16px; }
    .huda-consent-icon { left: 12px; bottom: 12px; width: 42px; height: 42px; }
}

/* ---------- Modo claro forzado en páginas legales ---------- */
/* Las páginas legales tienen body.legal-page con fondo claro. El banner y panel
   mantienen su estética oscura, pero el icono se atenúa para no chocar visualmente. */
body.legal-page .huda-consent-icon { box-shadow: 0 6px 18px rgba(10,5,16,.18); }

/* ---------- Reduce motion ---------- */
@media (prefers-reduced-motion: reduce) {
    .huda-consent-btn,
    .huda-consent-icon,
    .huda-consent-switch .track,
    .huda-consent-switch .thumb,
    .huda-consent-panel__close { transition: none; }
}
