/* SmartDeal — Consent banner + preferences modal
   =====================================================================
   Banner sticky-bottom con 3 acciones: Aceptar todo / Sólo esenciales /
   Personalizar. El modal de personalización permite granularidad por
   categoría (analytics, marketing, funcional). No depende de ningún
   framework ni plugin externo. Diseñado para no bloquear LCP.
   ===================================================================== */

:root {
    --sd-consent-bg: #ffffff;
    --sd-consent-ink: #101418;
    --sd-consent-muted: #5d6773;
    --sd-consent-line: #e4e8ec;
    --sd-consent-brand: #101418;
    --sd-consent-brand-ink: #c5ff3e;
    --sd-consent-radius: 14px;
    --sd-consent-shadow: 0 -8px 28px rgba(16, 20, 24, 0.12);
    --sd-consent-z: 999999;
}

/* Banner Falabella-minimal: banda full-width al pie, gris claro */
.sd-consent-banner {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    background: #eceff3;
    color: #1a1a1a;
    padding: 14px 24px;
    display: none;
    z-index: var(--sd-consent-z);
    font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    line-height: 1.4;
    opacity: 1;
}
.sd-consent-banner.is-visible {
    display: block;
    /* Aparición inmediata sin animación — evita race condition vista en
       Chrome donde la animación quedaba en state:running currentTime:0 y
       dejaba el banner en opacity:0 indefinidamente. La usabilidad manda
       sobre el micro-efecto: el banner DEBE ser visible al instante para
       cumplir con GDPR/CNIL/Ley 19.628. */
    opacity: 1;
    transform: none;
}

@keyframes sdConsentIn {
    from { transform: translateY(20px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}

.sd-consent-banner__inner {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: center;
}
.sd-consent-banner__text {
    flex: 0 1 auto;
    font-size: 14px;
    color: #1a1a1a;
    margin: 0;
    text-align: center;
}
.sd-consent-banner__text a {
    color: #1a1a1a;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.sd-consent-banner__text a:hover { text-decoration: none; }

/* Wrapper de CTAs principales — simetría Rechazar + Aceptar (GDPR/CNIL) */
.sd-consent-banner__actions {
    display: flex;
    gap: 10px;
    flex: 0 0 auto;
}
.sd-consent-banner__accept,
.sd-consent-banner__reject {
    appearance: none;
    padding: 10px 28px;
    border-radius: 100px;
    font-weight: 500;
    font-size: 14px;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.sd-consent-banner__accept {
    border: 1px solid #3a3a3a;
    background: #3a3a3a;
    color: #fff;
}
.sd-consent-banner__accept:hover { background: #1a1a1a; border-color: #1a1a1a; }
.sd-consent-banner__reject {
    border: 1px solid #3a3a3a;
    background: transparent;
    color: #1a1a1a;
}
.sd-consent-banner__reject:hover { background: #dfe3e8; }

.sd-consent-banner__close {
    appearance: none;
    border: none;
    background: transparent;
    color: #666;
    width: 32px;
    height: 32px;
    padding: 0;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    flex: 0 0 auto;
    border-radius: 50%;
    transition: background .15s ease, color .15s ease;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}
.sd-consent-banner__close:hover { background: rgba(0,0,0,0.06); color: #1a1a1a; }

/* Botón genérico (modal hereda) */
.sd-consent-btn {
    appearance: none;
    border: 1px solid var(--sd-consent-line);
    background: #fff;
    color: var(--sd-consent-ink);
    padding: 10px 14px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    white-space: nowrap;
    transition: background .12s, border-color .12s, transform .06s;
}
.sd-consent-btn:hover { background: #f5f7f9; }
.sd-consent-btn:active { transform: translateY(1px); }
.sd-consent-btn--primary {
    background: var(--sd-consent-brand);
    color: var(--sd-consent-brand-ink);
    border-color: var(--sd-consent-brand);
}
.sd-consent-btn--primary:hover { background: #1a1f26; }
.sd-consent-btn--link {
    background: transparent;
    border-color: transparent;
    text-decoration: underline;
    padding: 10px 8px;
}
.sd-consent-btn--link:hover { background: transparent; color: #000; }

/* ── Modal de preferencias (Falabella-minimal) ───────────────────── */
.sd-consent-modal {
    position: fixed;
    inset: 0;
    background: rgba(16, 20, 24, 0.45);
    z-index: calc(var(--sd-consent-z) + 1);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.sd-consent-modal.is-open { display: flex; }
.sd-consent-modal__card {
    background: #fff;
    max-width: 460px;
    width: 100%;
    border-radius: 8px;
    padding: 28px 28px 24px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.18);
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
.sd-consent-modal__x {
    position: absolute;
    top: 12px;
    right: 14px;
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    color: #1a1a1a;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    border-radius: 50%;
    transition: background .12s ease;
}
.sd-consent-modal__x:hover { background: #f5f5f5; }
.sd-consent-modal__title {
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0 0 8px;
    letter-spacing: -0.01em;
}
.sd-consent-modal__lead {
    font-size: 13px;
    color: #555;
    margin: 0 0 20px;
    line-height: 1.5;
}

/* Lista de categorías como accordion minimal */
.sd-consent-list {
    border-top: 1px solid #e5e5e5;
    margin: 0 0 20px;
}
.sd-consent-item {
    border-bottom: 1px solid #e5e5e5;
}
.sd-consent-item__row {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 28px 14px 0;
    cursor: pointer;
    position: relative;
    user-select: none;
}
.sd-consent-item__row::-webkit-details-marker { display: none; }
.sd-consent-item__row::marker { content: ""; }
.sd-consent-item__row::after {
    content: "";
    position: absolute;
    right: 4px;
    top: 50%;
    width: 8px;
    height: 8px;
    border-right: 1.5px solid #666;
    border-bottom: 1.5px solid #666;
    transform: translateY(-70%) rotate(45deg);
    transition: transform .18s ease;
}
.sd-consent-item[open] .sd-consent-item__row::after {
    transform: translateY(-20%) rotate(-135deg);
}
.sd-consent-item__name {
    font-size: 14px;
    font-weight: 500;
    color: #1a1a1a;
    flex: 1;
}
.sd-consent-item__ctrl {
    flex: 0 0 auto;
    margin-right: 8px;
}
.sd-consent-item__desc {
    font-size: 13px;
    color: #555;
    margin: 0 0 14px;
    padding-right: 28px;
    line-height: 1.5;
}

/* Toggle minimal estilo iOS, pero más sobrio */
.sd-consent-toggle {
    position: relative;
    display: inline-block;
    width: 36px;
    height: 20px;
    vertical-align: middle;
}
.sd-consent-toggle input { opacity: 0; width: 0; height: 0; }
.sd-consent-toggle__slider {
    position: absolute;
    inset: 0;
    background: #d0d0d0;
    border-radius: 20px;
    cursor: pointer;
    transition: background .18s;
}
.sd-consent-toggle__slider::before {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    left: 2px;
    top: 2px;
    background: #fff;
    border-radius: 50%;
    transition: transform .18s;
    box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
.sd-consent-toggle input:checked + .sd-consent-toggle__slider {
    background: #1a1a1a;
}
.sd-consent-toggle input:checked + .sd-consent-toggle__slider::before {
    transform: translateX(16px);
}

.sd-consent-modal__footer {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    margin-top: 4px;
    flex-wrap: wrap;
}
.sd-consent-modal__footer .sd-consent-btn {
    border-radius: 4px;
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 500;
}
.sd-consent-btn--ghost {
    background: #fff;
    color: #1a1a1a;
    border: 1px solid #1a1a1a;
}
.sd-consent-btn--ghost:hover { background: #f5f5f5; }
.sd-consent-modal__footer .sd-consent-btn--primary {
    background: #1a1a1a;
    color: #fff;
    border-color: #1a1a1a;
}
.sd-consent-modal__footer .sd-consent-btn--primary:hover { background: #000; }

/* ── Reopen trigger (footer link) ────────────────────────────────── */
.sd-consent-reopen {
    background: none;
    border: none;
    color: inherit;
    font: inherit;
    padding: 0;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ── Mobile ──────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .sd-consent-banner { padding: 14px 16px 14px 16px; }
    .sd-consent-banner__inner {
        flex-direction: column;
        gap: 12px;
        align-items: center;
        padding-right: 32px; /* deja espacio para la X absoluta */
    }
    .sd-consent-banner__text { font-size: 13px; }
    .sd-consent-banner__actions {
        width: 100%;
        max-width: 320px;
        gap: 8px;
    }
    .sd-consent-banner__accept,
    .sd-consent-banner__reject {
        flex: 1 1 0;
        padding: 10px 14px;
    }
    .sd-consent-banner__close { right: 12px; top: 12px; transform: none; }
}

/* ── Prefers-reduced-motion ──────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .sd-consent-banner { animation: none; }
    .sd-consent-toggle__slider,
    .sd-consent-toggle__slider::before { transition: none; }
}
