/**
 * ConsentX Pro v3.0.0 — Premium CSS Bundle
 * Complete redesign: luxury glassmorphism, refined typography, premium animations
 */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Sora:wght@600;700&display=swap');

/* ── Reset ── */
#consentx-wrapper,
#consentx-wrapper * { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Animations ── */
@keyframes cx-slide-up   { from { transform: translateY(28px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes cx-slide-down { from { transform: translateY(-28px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes cx-slide-in-left  { from { transform: translateX(-32px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes cx-slide-in-right { from { transform: translateX(32px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes cx-scale-in { from { transform: translate(-50%,-50%) scale(0.88); opacity: 0; } to { transform: translate(-50%,-50%) scale(1); opacity: 1; } }
@keyframes cx-fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes cx-pulse-ring { 0% { box-shadow: 0 0 0 0 var(--cx-primary-glow,rgba(99,102,241,.45)); } 70% { box-shadow: 0 0 0 10px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
@keyframes cx-widget-bounce { 0%,100% { transform: translateY(0) scale(1); } 30% { transform: translateY(-6px) scale(1.06); } 60% { transform: translateY(-2px) scale(1.02); } }
@keyframes cx-toast-in  { from { transform: translateX(-20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes cx-progress  { from { width: 100%; } to { width: 0%; } }
@keyframes cx-dot-blink { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

/* ── Main Wrapper ── */
#consentx-wrapper {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    line-height: 1.55; font-size: 14px; color: var(--cx-text, #111827);
    z-index: 999999;
    backdrop-filter: var(--cx-blur, blur(20px));
    -webkit-backdrop-filter: var(--cx-blur, blur(20px));
    background: var(--cx-bg, rgba(255,255,255,0.88));
    box-shadow: var(--cx-shadow, 0 20px 60px rgba(0,0,0,0.18));
    border: var(--cx-border, 1px solid rgba(255,255,255,0.7));
    overflow: hidden;
}
#consentx-wrapper::after {
    content: none;
}

/* ── Panel ── */
.cx-panel { padding: 20px 24px 20px; padding-top: 20px; max-height: 90vh; overflow-y: auto; scrollbar-width: thin; scrollbar-color: rgba(0,0,0,.15) transparent; position: relative; }
.cx-panel::-webkit-scrollbar { width: 4px; }
.cx-panel::-webkit-scrollbar-thumb { background: rgba(0,0,0,.15); border-radius: 4px; }

/* ── Header ── */
.cx-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; gap: 10px; }
.cx-logo-wrap { display: flex; align-items: center; gap: 9px; }
.cx-logo-icon {
    width: 36px; height: 36px; border-radius: 10px;
    background: var(--cx-primary-soft, rgba(99,102,241,0.12));
    display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0;
    border: 1px solid var(--cx-primary-soft-border, rgba(99,102,241,0.2));
}
.cx-logo-badge {
    font-size: 10px; font-weight: 600; letter-spacing: 0.4px; color: var(--cx-subtext,#888);
    line-height: 1; text-transform: uppercase; opacity: 0.65;
}

/* ── Close Button ── */
.cx-close {
    background: none; border: 1px solid var(--cx-border-subtle, rgba(0,0,0,0.09));
    cursor: pointer; font-size: 13px; color: var(--cx-subtext, #888); opacity: .8;
    width: 28px; height: 28px; border-radius: 7px; transition: all .18s ease;
    display: flex; align-items: center; justify-content: center; line-height: 1; flex-shrink: 0;
}
.cx-close:hover { opacity: 1; background: rgba(0,0,0,.06); border-color: rgba(0,0,0,.15); transform: rotate(90deg); }

/* ── Text ── */
.cx-title {
    font-family: 'Sora','Inter',sans-serif; font-size: 17px; font-weight: 700;
    color: var(--cx-text,#111827); margin-bottom: 8px; letter-spacing: -0.2px; line-height: 1.3;
}
.cx-desc { font-size: 13px; color: var(--cx-subtext,#6b7280); line-height: 1.6; margin-bottom: 16px; }
.cx-privacy-link { color: var(--cx-primary,#6366f1); text-decoration: none; font-weight: 500; border-bottom: 1px solid transparent; transition: border-color .15s; }
.cx-privacy-link:hover { border-bottom-color: var(--cx-primary,#6366f1); }

/* ── Compliance Badge ── */
.cx-compliance-badge {
    display: inline-flex; align-items: center; gap: 5px;
    background: var(--cx-primary-soft,rgba(99,102,241,0.08));
    color: var(--cx-primary,#6366f1);
    border: 1px solid var(--cx-primary-soft-border,rgba(99,102,241,0.18));
    border-radius: 20px; padding: 3px 9px; font-size: 10px; font-weight: 600;
    letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 11px; width: fit-content;
}
.cx-compliance-badge::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: currentColor; animation: cx-dot-blink 2s infinite; }

/* ── Footer ── */
.cx-footer {
    margin-top: 15px; font-size: 10px; color: var(--cx-subtext,#9ca3af); opacity: .55;
    text-align: center; letter-spacing: .3px; display: flex; align-items: center; justify-content: center; gap: 6px;
}
.cx-footer::before,.cx-footer::after { content: ''; flex: 1; height: 1px; background: var(--cx-divider,rgba(0,0,0,0.07)); max-width: 40px; }

/* ── Categories ── */
.cx-cats { margin-bottom: 16px; border: 1px solid var(--cx-divider,rgba(0,0,0,0.07)); border-radius: 11px; overflow: hidden; background: var(--cx-cats-bg,rgba(0,0,0,.018)); }
.cx-cat-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 14px; border-bottom: 1px solid var(--cx-divider,rgba(0,0,0,.055)); transition: background .15s; }
.cx-cat-row:last-child { border-bottom: none; }
.cx-cat-row:hover { background: var(--cx-row-hover,rgba(99,102,241,.04)); }
.cx-cat-info { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.cx-cat-name { font-size: 13px; font-weight: 600; color: var(--cx-text,#111827); display: flex; align-items: center; gap: 6px; }
.cx-cat-name .cx-required-tag { font-size: 9px; font-weight: 600; background: var(--cx-primary-soft,rgba(99,102,241,.1)); color: var(--cx-primary,#6366f1); border-radius: 4px; padding: 1px 5px; letter-spacing: .4px; text-transform: uppercase; }
.cx-cat-desc { font-size: 11.5px; color: var(--cx-subtext,#9ca3af); margin-top: 3px; line-height: 1.5; }

/* ── Premium Toggle ── */
.cx-switch { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.cx-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.cx-switch-track { position: absolute; inset: 0; background: var(--cx-switch-off,rgba(0,0,0,.13)); border-radius: 24px; transition: background .22s cubic-bezier(.4,0,.2,1); cursor: pointer; border: 1px solid transparent; }
.cx-switch-track::before { content: ''; position: absolute; width: 18px; height: 18px; left: 2px; top: 2px; background: #fff; border-radius: 50%; transition: transform .22s cubic-bezier(.4,0,.2,1); box-shadow: 0 1px 5px rgba(0,0,0,.2),0 0 0 1px rgba(0,0,0,.06); }
.cx-switch input:checked + .cx-switch-track { background: var(--cx-primary,#6366f1); box-shadow: 0 0 0 3px var(--cx-primary-soft,rgba(99,102,241,.15)); }
.cx-switch input:checked + .cx-switch-track::before { transform: translateX(18px); box-shadow: 0 1px 5px rgba(99,102,241,.4); }
.cx-switch input:disabled + .cx-switch-track { background: var(--cx-primary,#6366f1); opacity: .5; cursor: not-allowed; }

/* ── Premium Buttons ── */
.cx-actions { display: flex; flex-wrap: wrap; gap: 9px; align-items: center; }
.cx-btn {
    flex: 1; min-width: 90px; padding: 10px 18px; border: none; border-radius: 9px;
    font-size: 13px; font-weight: 600; cursor: pointer;
    transition: all .18s cubic-bezier(.4,0,.2,1); white-space: nowrap; line-height: 1.2;
    font-family: 'Inter',inherit; letter-spacing: .05px; position: relative; overflow: hidden;
}
.cx-btn:active { transform: scale(.97) translateY(1px); }
.cx-primary {
    background: var(--cx-btn-primary-bg, linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%));
    color: #fff; border: none;
    box-shadow: 0 4px 14px var(--cx-primary-glow,rgba(99,102,241,.38)), 0 1px 0 rgba(255,255,255,.2) inset;
}
.cx-primary:hover { box-shadow: 0 6px 20px var(--cx-primary-glow,rgba(99,102,241,.48)); transform: translateY(-1px); }
.cx-secondary {
    background: var(--cx-btn-secondary-bg,rgba(0,0,0,.055));
    color: var(--cx-text,#374151); border: 1px solid var(--cx-border-subtle,rgba(0,0,0,.09));
}
.cx-secondary:hover { background: var(--cx-btn-secondary-hover,rgba(0,0,0,.08)); transform: translateY(-1px); }
.cx-ghost { background: transparent; color: var(--cx-subtext,#6b7280); border: 1px solid var(--cx-border-subtle,rgba(0,0,0,.1)); }
.cx-ghost:hover { background: rgba(0,0,0,.04); color: var(--cx-text,#374151); border-color: rgba(0,0,0,.15); transform: translateY(-1px); }

/* ── Utility ── */
.cx-hidden { display: none !important; }

/* ── Overlay ── */
#consentx-wrapper.cx-has-overlay::before { content: ''; position: fixed; inset: 0; background: rgba(0,0,10,.5); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); z-index: -1; animation: cx-fade-in .25s ease; }

/* ── Floating Widget ── */
#consentx-widget {
    position: fixed; bottom: 22px; left: 22px; width: 48px; height: 48px; border-radius: 14px;
    background: var(--cx-widget-bg,linear-gradient(135deg,#6366f1,#8b5cf6));
    color: #fff; border: none; cursor: pointer; font-size: 22px;
    box-shadow: 0 6px 20px var(--cx-primary-glow,rgba(99,102,241,.42)), 0 1px 0 rgba(255,255,255,.25) inset;
    z-index: 999998; display: flex; align-items: center; justify-content: center;
    transition: transform .2s cubic-bezier(.4,0,.2,1), box-shadow .2s;
    animation: cx-fade-in .3s ease, cx-widget-bounce .6s ease .4s;
}
#consentx-widget:hover { transform: scale(1.12) translateY(-2px); box-shadow: 0 10px 28px var(--cx-primary-glow,rgba(99,102,241,.52)); }
#consentx-widget:active { transform: scale(.95); }
#consentx-widget::before { content: ''; position: absolute; inset: 0; border-radius: inherit; animation: cx-pulse-ring 2.8s ease-out 1.2s infinite; pointer-events: none; }

/* ── Premium Toast ── */
#cx-undo-toast {
    position: fixed; bottom: 88px; left: 22px;
    background: var(--cx-toast-bg,#1e1e30); color: #fff;
    padding: 13px 16px; border-radius: 12px; font-size: 13px;
    font-family: 'Inter',-apple-system,sans-serif; z-index: 9999999;
    display: flex; align-items: center; gap: 12px;
    box-shadow: 0 8px 30px rgba(0,0,0,.35), 0 1px 0 rgba(255,255,255,.08) inset;
    animation: cx-toast-in .3s cubic-bezier(.4,0,.2,1);
    max-width: 300px; border: 1px solid rgba(255,255,255,.08); overflow: hidden;
}
#cx-undo-toast::after { content: ''; position: absolute; bottom: 0; left: 0; height: 2px; background: var(--cx-primary,#6366f1); animation: cx-progress 5s linear forwards; border-radius: 0 0 12px 12px; }
.cx-toast-undo-btn {
    background: rgba(99,102,241,.25); border: 1px solid rgba(99,102,241,.35);
    color: #c7d2fe; padding: 4px 10px; border-radius: 6px; cursor: pointer;
    font-size: 12px; font-weight: 600; font-family: 'Inter',sans-serif; transition: background .15s; flex-shrink: 0;
}
.cx-toast-undo-btn:hover { background: rgba(99,102,241,.4); }

/* ════ THEME VARIABLES ════ */
#consentx-wrapper[data-theme="glassmorphism"] {
    --cx-bg: rgba(255,255,255,0.82); --cx-blur: blur(22px) saturate(180%);
    --cx-shadow: 0 20px 60px rgba(99,102,241,.14),0 4px 16px rgba(0,0,0,.1),0 1px 0 rgba(255,255,255,.9) inset;
    --cx-border: 1px solid rgba(255,255,255,.72); --cx-text: #111827; --cx-subtext: #6b7280;
    --cx-primary: #6366f1; --cx-primary-hover: #4f46e5; --cx-primary-glow: rgba(99,102,241,.35);
    --cx-primary-soft: rgba(99,102,241,.08); --cx-primary-soft-border: rgba(99,102,241,.18);
    --cx-btn-primary-bg: linear-gradient(135deg,#6366f1,#8b5cf6);
    --cx-radius: 16px; --cx-divider: rgba(0,0,0,.07); --cx-border-subtle: rgba(0,0,0,.09);
    --cx-accent-line: linear-gradient(90deg,#6366f1,#8b5cf6,#06b6d4);
    --cx-switch-off: rgba(0,0,0,.12); --cx-cats-bg: rgba(0,0,0,.02); --cx-row-hover: rgba(99,102,241,.04);
    --cx-widget-bg: linear-gradient(135deg,#6366f1,#8b5cf6); --cx-toast-bg: #18181e;
}
#consentx-wrapper[data-theme="minimal-dark"] {
    --cx-bg: #111118; --cx-blur: none;
    --cx-shadow: 0 24px 60px rgba(0,0,0,.55),0 1px 0 rgba(255,255,255,.05) inset;
    --cx-border: 1px solid rgba(255,255,255,.08); --cx-text: #f1f0ff; --cx-subtext: #8b8a9e;
    --cx-primary: #818cf8; --cx-primary-hover: #6366f1; --cx-primary-glow: rgba(129,140,248,.4);
    --cx-primary-soft: rgba(129,140,248,.1); --cx-primary-soft-border: rgba(129,140,248,.22);
    --cx-btn-primary-bg: linear-gradient(135deg,#6366f1,#818cf8); --cx-btn-secondary-bg: rgba(255,255,255,.07);
    --cx-btn-secondary-hover: rgba(255,255,255,.11);
    --cx-radius: 14px; --cx-divider: rgba(255,255,255,.07); --cx-border-subtle: rgba(255,255,255,.08);
    --cx-accent-line: linear-gradient(90deg,#818cf8,#a78bfa,#38bdf8);
    --cx-switch-off: rgba(255,255,255,.14); --cx-cats-bg: rgba(255,255,255,.03); --cx-row-hover: rgba(129,140,248,.06);
    --cx-widget-bg: linear-gradient(135deg,#6366f1,#818cf8); --cx-toast-bg: #0e0e14;
}
#consentx-wrapper[data-theme="minimal-dark"] .cx-close,
#consentx-wrapper[data-theme="minimal-dark"] .cx-ghost { color: #8b8a9e; border-color: rgba(255,255,255,.1); }
#consentx-wrapper[data-theme="minimal-dark"] .cx-close:hover,
#consentx-wrapper[data-theme="minimal-dark"] .cx-ghost:hover { background: rgba(255,255,255,.07); color: #f1f0ff; border-color: rgba(255,255,255,.18); }
#consentx-wrapper[data-theme="minimal-dark"] .cx-secondary { color: #c4c3d8; }

#consentx-wrapper[data-theme="elegant-light"] {
    --cx-bg: #ffffff; --cx-blur: none;
    --cx-shadow: 0 2px 0 rgba(0,0,0,.04),0 10px 40px rgba(0,0,0,.1);
    --cx-border: 1px solid #e5e7eb; --cx-text: #111827; --cx-subtext: #6b7280;
    --cx-primary: #2563eb; --cx-primary-hover: #1d4ed8; --cx-primary-glow: rgba(37,99,235,.3);
    --cx-primary-soft: rgba(37,99,235,.07); --cx-primary-soft-border: rgba(37,99,235,.15);
    --cx-btn-primary-bg: linear-gradient(135deg,#2563eb,#3b82f6);
    --cx-radius: 12px; --cx-divider: rgba(0,0,0,.07); --cx-border-subtle: #e5e7eb;
    --cx-accent-line: linear-gradient(90deg,#2563eb,#3b82f6,#06b6d4);
    --cx-switch-off: #d1d5db; --cx-cats-bg: #f9fafb; --cx-row-hover: #f0f4ff;
    --cx-widget-bg: linear-gradient(135deg,#2563eb,#3b82f6); --cx-toast-bg: #111827;
}
#consentx-wrapper[data-theme="neumorphic"] {
    --cx-bg: #e8ecf2; --cx-blur: none;
    --cx-shadow: 8px 8px 20px #c4c8d0,-8px -8px 20px #ffffff;
    --cx-border: none; --cx-text: #2d3142; --cx-subtext: #6b7280;
    --cx-primary: #5b21b6; --cx-primary-hover: #4c1d95; --cx-primary-glow: rgba(91,33,182,.3);
    --cx-primary-soft: rgba(91,33,182,.07); --cx-primary-soft-border: rgba(91,33,182,.15);
    --cx-btn-primary-bg: linear-gradient(135deg,#5b21b6,#7c3aed); --cx-btn-secondary-bg: #e8ecf2;
    --cx-radius: 18px; --cx-divider: rgba(0,0,0,.06); --cx-border-subtle: rgba(0,0,0,.06);
    --cx-accent-line: linear-gradient(90deg,#5b21b6,#7c3aed,#2563eb);
    --cx-switch-off: #c4c8d0; --cx-cats-bg: rgba(255,255,255,.35); --cx-row-hover: rgba(91,33,182,.04);
    --cx-widget-bg: linear-gradient(135deg,#5b21b6,#7c3aed); --cx-toast-bg: #1e1a2d;
}
#consentx-wrapper[data-theme="neumorphic"] .cx-btn.cx-secondary,
#consentx-wrapper[data-theme="neumorphic"] .cx-btn.cx-ghost { box-shadow: 4px 4px 8px #c4c8d0,-4px -4px 8px #ffffff; border: none; background: #e8ecf2; }

/* ── Aurora Theme (NEW) ── */
#consentx-wrapper[data-theme="aurora"] {
    --cx-bg: rgba(8,8,24,0.92); --cx-blur: blur(24px) saturate(180%);
    --cx-shadow: 0 0 0 1px rgba(168,85,247,.18),0 24px 64px rgba(0,0,0,.6);
    --cx-border: 1px solid rgba(168,85,247,.22); --cx-text: #f5f3ff; --cx-subtext: #a78bfa;
    --cx-primary: #a855f7; --cx-primary-hover: #9333ea; --cx-primary-glow: rgba(168,85,247,.45);
    --cx-primary-soft: rgba(168,85,247,.12); --cx-primary-soft-border: rgba(168,85,247,.25);
    --cx-btn-primary-bg: linear-gradient(135deg,#a855f7,#ec4899); --cx-btn-secondary-bg: rgba(168,85,247,.1);
    --cx-radius: 16px; --cx-divider: rgba(168,85,247,.15); --cx-border-subtle: rgba(168,85,247,.15);
    --cx-accent-line: linear-gradient(90deg,#a855f7,#ec4899,#f59e0b);
    --cx-switch-off: rgba(255,255,255,.12); --cx-cats-bg: rgba(168,85,247,.04); --cx-row-hover: rgba(168,85,247,.07);
    --cx-widget-bg: linear-gradient(135deg,#a855f7,#ec4899); --cx-toast-bg: #08081a;
}
#consentx-wrapper[data-theme="aurora"] { background-image: radial-gradient(ellipse at top left,rgba(168,85,247,.08) 0%,transparent 60%),radial-gradient(ellipse at bottom right,rgba(236,72,153,.06) 0%,transparent 60%); }
#consentx-wrapper[data-theme="aurora"] .cx-close,
#consentx-wrapper[data-theme="aurora"] .cx-ghost { color: #a78bfa; border-color: rgba(168,85,247,.2); }
#consentx-wrapper[data-theme="aurora"] .cx-close:hover,
#consentx-wrapper[data-theme="aurora"] .cx-ghost:hover { background: rgba(168,85,247,.1); color: #f5f3ff; border-color: rgba(168,85,247,.35); }
#consentx-wrapper[data-theme="aurora"] .cx-secondary { color: #c4b5fd; }

/* ── Frost White Theme (NEW) ── */
#consentx-wrapper[data-theme="frost"] {
    --cx-bg: rgba(248,250,255,0.95); --cx-blur: blur(20px);
    --cx-shadow: 0 1px 0 rgba(255,255,255,1) inset,0 16px 48px rgba(99,102,241,.12),0 2px 8px rgba(0,0,0,.06);
    --cx-border: 1px solid rgba(199,210,254,.5); --cx-text: #1e1b4b; --cx-subtext: #6366f1;
    --cx-primary: #4f46e5; --cx-primary-hover: #4338ca; --cx-primary-glow: rgba(79,70,229,.3);
    --cx-primary-soft: rgba(79,70,229,.07); --cx-primary-soft-border: rgba(79,70,229,.15);
    --cx-btn-primary-bg: linear-gradient(135deg,#4f46e5,#7c3aed);
    --cx-radius: 18px; --cx-divider: rgba(99,102,241,.1); --cx-border-subtle: rgba(199,210,254,.5);
    --cx-accent-line: linear-gradient(90deg,#4f46e5,#7c3aed,#0ea5e9);
    --cx-switch-off: rgba(79,70,229,.15); --cx-cats-bg: rgba(238,242,255,.5); --cx-row-hover: rgba(238,242,255,.8);
    --cx-widget-bg: linear-gradient(135deg,#4f46e5,#7c3aed); --cx-toast-bg: #1e1b4b;
}

/* ── Responsive ── */
@media (max-width: 480px) {
    #consentx-wrapper { left:0!important;right:0!important;bottom:0!important;top:auto!important;max-width:100%!important;width:100%!important;border-radius:18px 18px 0 0!important;transform:none!important; }
    /* accent line bar uses js-inserted div, no ::after needed */
    .cx-btn { min-width:80px;font-size:12.5px;padding:9px 14px; }
    .cx-panel { padding: 18px 20px 16px; }
}

/* ── Admin preview note ── */
.cx-banner-preview-note { background: linear-gradient(135deg,#eff6ff,#f0f4ff); border-left: 3px solid #6366f1; padding: 11px 15px; border-radius: 0 8px 8px 0; font-size: 13px; margin: 16px 0; color: #374151; }
