/* JDM Consent Manager — banner + modal */
.cmp-no-scroll{overflow:hidden}

/* JDM brand accent (overrides any inherited --accent in cart context) */
.cmp-banner,.cmp-modal{--accent:#1eb1b4}

/* ─── Banner ─────────────────────────────────────────────────────── */
.cmp-banner{
    position:fixed;
    left:16px;
    right:16px;
    bottom:16px;
    z-index:9990;
    background:#0f1530;
    color:#e2e8f0;
    border:1px solid rgba(255,255,255,.08);
    border-radius:14px;
    box-shadow:0 20px 50px rgba(0,0,0,.35);
    padding:20px 24px;
    max-width:1180px;
    margin:0 auto;
    animation:cmp-rise .28s ease-out;
}
@keyframes cmp-rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.cmp-banner-inner{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.cmp-banner-text{flex:1;min-width:280px}
.cmp-banner-title{font-size:1rem;font-weight:700;color:#fff;margin:0 0 6px}
.cmp-banner-text p{font-size:.85rem;line-height:1.55;color:rgba(255,255,255,.78);margin:0}
.cmp-banner-text a{color:var(--accent);text-decoration:underline}
.cmp-banner-actions{display:flex;gap:10px;flex-wrap:wrap}

/* ─── Buttons ────────────────────────────────────────────────────── */
.cmp-btn{
    appearance:none;
    border:none;
    font:inherit;
    font-size:.85rem;
    font-weight:700;
    padding:11px 20px;
    border-radius:10px;
    cursor:pointer;
    transition:transform .15s,background .2s,border-color .2s,color .2s;
    white-space:nowrap;
}
.cmp-btn-primary{background:var(--accent);color:#fff}
.cmp-btn-primary:hover{background:#2ec4c7;transform:translateY(-1px)}
.cmp-btn-secondary{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.18)}
.cmp-btn-secondary:hover{background:rgba(255,255,255,.14)}
.cmp-btn-ghost{background:transparent;color:rgba(255,255,255,.75);border:1px solid transparent}
.cmp-btn-ghost:hover{color:#fff;background:rgba(255,255,255,.06)}

/* ─── Modal ──────────────────────────────────────────────────────── */
.cmp-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:cmp-fade .25s ease-out}
@keyframes cmp-fade{from{opacity:0}to{opacity:1}}
.cmp-modal-overlay{position:absolute;inset:0;background:rgba(8,12,28,.7);backdrop-filter:blur(2px)}
.cmp-modal-box{
    position:relative;
    background:#fff;
    color:var(--txt-dark);
    border-radius:16px;
    max-width:560px;
    width:100%;
    max-height:90vh;
    overflow:auto;
    padding:28px 28px 24px;
    box-shadow:0 30px 70px rgba(0,0,0,.45);
}
.cmp-modal-close{position:absolute;top:10px;right:14px;background:none;border:none;font-size:1.6rem;line-height:1;color:var(--txt-muted);cursor:pointer;padding:6px 10px}
.cmp-modal-close:hover{color:var(--txt-dark)}
.cmp-modal-title{font-size:1.25rem;font-weight:700;margin:0 0 8px;color:var(--txt-dark)}
.cmp-modal-lead{font-size:.88rem;line-height:1.55;color:var(--txt-body);margin:0 0 18px}

.cmp-cat{display:block;border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,background .2s}
.cmp-cat:hover{border-color:var(--accent);background:rgba(30,177,180,.04)}
.cmp-cat:first-of-type{cursor:default;background:rgba(15,23,42,.03)}
.cmp-cat:first-of-type:hover{border-color:var(--border);background:rgba(15,23,42,.03)}
.cmp-cat-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.cmp-cat strong{display:block;font-size:.95rem;color:var(--txt-dark)}
.cmp-cat-desc{display:block;font-size:.78rem;color:var(--txt-muted);margin-top:3px;line-height:1.45}
.cmp-cat-required{font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent);background:rgba(30,177,180,.1);padding:6px 12px;border-radius:50px;white-space:nowrap}

/* ─── Toggle switch ──────────────────────────────────────────────── */
.cmp-toggle{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}
.cmp-toggle input{opacity:0;width:0;height:0;position:absolute}
.cmp-toggle-slider{position:absolute;inset:0;background:#cbd5e1;border-radius:50px;transition:background .25s;cursor:pointer}
.cmp-toggle-slider::before{content:'';position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.cmp-toggle input:checked + .cmp-toggle-slider{background:var(--accent)}
.cmp-toggle input:checked + .cmp-toggle-slider::before{transform:translateX(18px)}
.cmp-toggle input:focus-visible + .cmp-toggle-slider{box-shadow:0 0 0 2px rgba(30,177,180,.4)}

.cmp-modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}

@media(max-width:640px){
    .cmp-banner{padding:16px 18px;left:8px;right:8px;bottom:8px}
    .cmp-banner-inner{flex-direction:column;align-items:stretch;gap:14px}
    .cmp-banner-actions{flex-direction:column}
    .cmp-banner-actions .cmp-btn{width:100%;text-align:center}
    .cmp-modal-box{padding:22px 18px}
    .cmp-modal-actions{flex-direction:column-reverse}
    .cmp-modal-actions .cmp-btn{width:100%;text-align:center}
}
