/* ============================================================
   Cookie Shield – Banner CSS  v2.5.1
   ALL rules scoped under #cs-banner to avoid theme conflicts.
   ============================================================ */

/* ── Outer wrapper ──────────────────────────────────────────
   IMPORTANT: Do NOT set display here — let HTML [hidden] keep
   it invisible by default via the browser user-agent stylesheet.
   display:flex is applied ONLY when [hidden] is absent (banner shown). */
#cs-banner {
    position: fixed !important;
    z-index: 2147483646 !important;
    left: 0 !important;
    right: 0 !important;
    justify-content: center !important;
    pointer-events: none !important;
    box-sizing: border-box !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                 Helvetica, Arial, sans-serif !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    color: #1e293b !important;
}

/* Only flex when actually shown (no [hidden] attribute) */
#cs-banner:not([hidden]) {
    display: flex !important;
}

/* Belt-and-suspenders: ensure [hidden] always wins */
#cs-banner[hidden] {
    display: none !important;
    visibility: hidden !important;
}

/* Position variants */
#cs-banner.cs-pos-bottom { bottom: 0 !important; top: auto !important; align-items: flex-end !important; }
#cs-banner.cs-pos-top    { top: 0 !important; bottom: auto !important; align-items: flex-start !important; }
#cs-banner.cs-pos-center {
    top: 0 !important; bottom: 0 !important;
    align-items: center !important;
    background: rgba(0, 0, 0, 0.5) !important;
}

/* ── Inner card ─────────────────────────────────────────────*/
#cs-banner .cs-inner {
    pointer-events: auto !important;  /* re-enable clicks on the card */
    width: 100% !important;
    max-width: 820px !important;
    margin: 0 16px 16px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.22) !important;
}

#cs-banner.cs-pos-top    .cs-inner { margin: 16px 16px 0 !important; }
#cs-banner.cs-pos-center .cs-inner { margin: 16px !important; }

/* Light theme */
#cs-banner.cs-theme-light .cs-inner {
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
}
/* Dark theme */
#cs-banner.cs-theme-dark .cs-inner {
    background: #1e293b !important;
    border: 1px solid #334155 !important;
    color: #f1f5f9 !important;
}

/* ── Content ────────────────────────────────────────────────*/
#cs-banner .cs-content {
    padding: 24px 28px 16px !important;
}

#cs-banner .cs-title {
    display: block !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    margin: 0 0 8px !important;
    color: inherit !important;
}

#cs-banner .cs-desc {
    font-size: 14px !important;
    line-height: 1.65 !important;
    margin: 0 !important;
    color: inherit !important;
    opacity: 0.85 !important;
}

#cs-banner .cs-desc a {
    color: #1b5ebe !important;
    text-decoration: underline !important;
}

#cs-banner.cs-theme-dark .cs-desc a { color: #93c5fd !important; }

/* ── Preferences panel ──────────────────────────────────────
   HTML [hidden] = collapsed, JS removes it to expand.        */
#cs-banner #cs-prefs-panel {
    border-top: 1px solid #e2e8f0 !important;
    max-height: 400px !important;
    overflow-y: auto !important;
}

#cs-banner.cs-theme-dark #cs-prefs-panel { border-top-color: #334155 !important; }

#cs-banner #cs-prefs-panel[hidden] { display: none !important; }

/* ── Category block ─────────────────────────────────────────*/
#cs-banner .cs-cat-block {
    padding: 16px 28px !important;
    border-bottom: 1px solid #f1f5f9 !important;
}

#cs-banner.cs-theme-dark .cs-cat-block { border-bottom-color: #2d3f55 !important; }
#cs-banner .cs-cat-block:last-child { border-bottom: none !important; }

#cs-banner .cs-cat-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 16px !important;
}

#cs-banner .cs-cat-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    flex: 1 !important;
}

#cs-banner .cs-cat-name {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: inherit !important;
}

#cs-banner .cs-cat-desc {
    font-size: 13px !important;
    opacity: 0.75 !important;
    line-height: 1.5 !important;
    color: inherit !important;
}

#cs-banner .cs-always-on {
    flex-shrink: 0 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #16a34a !important;
    background: #f0fdf4 !important;
    border: 1px solid #bbf7d0 !important;
    padding: 4px 10px !important;
    border-radius: 20px !important;
    white-space: nowrap !important;
    margin-top: 2px !important;
}

/* ── Toggle switch ──────────────────────────────────────────
   No theme styles can reach inside here because all rules
   are scoped to #cs-banner.                                  */
#cs-banner .cs-switch {
    display: inline-block !important;
    position: relative !important;
    width: 48px !important;
    height: 26px !important;
    flex-shrink: 0 !important;
    cursor: pointer !important;
    /* Ensure pointer events reach the label */
    pointer-events: auto !important;
    -webkit-tap-highlight-color: transparent !important;
}

/* Hide the real checkbox accessibly (screen readers can still reach it) */
#cs-banner .cs-switch input[type="checkbox"] {
    position: absolute !important;
    opacity: 0 !important;
    width: 100% !important;
    height: 100% !important;
    top: 0 !important;
    left: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    cursor: pointer !important;
    z-index: 1 !important;
    pointer-events: auto !important;
    /* Override ANY theme style that might disable it */
    display: block !important;
    visibility: visible !important;
    appearance: none !important;
    -webkit-appearance: none !important;
}

/* The visual track */
#cs-banner .cs-switch-track {
    display: block !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    background: #cbd5e1 !important;
    border-radius: 26px !important;
    transition: background 0.2s !important;
    pointer-events: none !important;
}

/* The thumb */
#cs-banner .cs-switch-track::before {
    content: '' !important;
    position: absolute !important;
    width: 20px !important;
    height: 20px !important;
    top: 3px !important;
    left: 3px !important;
    background: #fff !important;
    border-radius: 50% !important;
    box-shadow: 0 1px 4px rgba(0,0,0,0.2) !important;
    transition: transform 0.2s !important;
}

/* Checked state — listens to sibling input */
#cs-banner .cs-switch input:checked ~ .cs-switch-track {
    background: #1b5ebe !important;
}
#cs-banner .cs-switch input:checked ~ .cs-switch-track::before {
    transform: translateX(22px) !important;
}

/* Focus ring for accessibility */
#cs-banner .cs-switch input:focus-visible ~ .cs-switch-track {
    outline: 2px solid #1b5ebe !important;
    outline-offset: 2px !important;
}

/* ── Cookie details table ───────────────────────────────────*/
#cs-banner .cs-cookie-details {
    margin-top: 12px !important;
}

#cs-banner .cs-cookie-details > summary {
    font-size: 12.5px !important;
    color: #1b5ebe !important;
    cursor: pointer !important;
    list-style: disclosure-closed !important;
    padding: 4px 0 !important;
    user-select: none !important;
}

#cs-banner .cs-cookie-details[open] > summary {
    list-style: disclosure-open !important;
}

#cs-banner .cs-cookie-table {
    width: 100% !important;
    border-collapse: collapse !important;
    margin-top: 8px !important;
    font-size: 12px !important;
}

#cs-banner .cs-cookie-table th {
    text-align: left !important;
    font-weight: 600 !important;
    padding: 5px 8px !important;
    background: #f8fafc !important;
    border-bottom: 1px solid #e2e8f0 !important;
    color: #475569 !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.4px !important;
}

#cs-banner .cs-cookie-table td {
    padding: 5px 8px !important;
    border-bottom: 1px solid #f1f5f9 !important;
    vertical-align: top !important;
    color: inherit !important;
    font-size: 12px !important;
}

#cs-banner .cs-cookie-table code {
    background: #f1f5f9 !important;
    padding: 1px 5px !important;
    border-radius: 3px !important;
    font-size: 11.5px !important;
    font-family: ui-monospace, "Cascadia Code", monospace !important;
}

#cs-banner.cs-theme-dark .cs-cookie-table th { background: #2d3f55 !important; color: #94a3b8 !important; border-color: #334155 !important; }
#cs-banner.cs-theme-dark .cs-cookie-table td { border-color: #2d3f55 !important; }
#cs-banner.cs-theme-dark .cs-cookie-table code { background: #1e293b !important; }

/* ── Action row ─────────────────────────────────────────────*/
#cs-banner .cs-actions {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 16px 28px 22px !important;
    flex-wrap: wrap !important;
}

#cs-banner .cs-btn-row {
    display: flex !important;
    gap: 10px !important;
    margin-left: auto !important;
    flex-wrap: wrap !important;
}

/* ── Buttons ────────────────────────────────────────────────
   type="button" prevents accidental form submission.
   All styles use !important to beat theme CSS.              */
#cs-banner .cs-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 11px 20px !important;
    min-height: 42px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    border-radius: 7px !important;
    border: 2px solid transparent !important;
    cursor: pointer !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    transition: background 0.15s, border-color 0.15s, box-shadow 0.15s !important;
    pointer-events: auto !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;
    outline: none !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

#cs-banner .cs-btn[hidden] { display: none !important; }

/* Primary – Accept All */
#cs-banner .cs-btn-primary {
    background: #1b5ebe !important;
    color: #ffffff !important;
    border-color: #1b5ebe !important;
}
#cs-banner .cs-btn-primary:hover {
    background: #154ea3 !important;
    border-color: #154ea3 !important;
    box-shadow: 0 2px 8px rgba(27,94,190,0.35) !important;
}

/* Secondary – Reject All / Save Preferences */
#cs-banner .cs-btn-secondary {
    background: #f1f5f9 !important;
    color: #1e293b !important;
    border-color: #e2e8f0 !important;
}
#cs-banner .cs-btn-secondary:hover {
    background: #e2e8f0 !important;
    border-color: #cbd5e1 !important;
}
#cs-banner.cs-theme-dark .cs-btn-secondary {
    background: #334155 !important;
    color: #f1f5f9 !important;
    border-color: #475569 !important;
}
#cs-banner.cs-theme-dark .cs-btn-secondary:hover { background: #475569 !important; }

/* Ghost – Manage Preferences */
#cs-banner .cs-btn-ghost {
    background: transparent !important;
    color: #1b5ebe !important;
    border-color: #1b5ebe !important;
}
#cs-banner .cs-btn-ghost:hover {
    background: #eff6ff !important;
}
#cs-banner.cs-theme-dark .cs-btn-ghost { color: #93c5fd !important; border-color: #93c5fd !important; }
#cs-banner.cs-theme-dark .cs-btn-ghost:hover { background: #1e3a5f !important; }

/* ── Reopen shortcode button ────────────────────────────────*/
.cs-reopen-btn {
    display: inline-flex !important;
    align-items: center !important;
    padding: 8px 16px !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: #1b5ebe !important;
    background: transparent !important;
    border: 1.5px solid #1b5ebe !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: background 0.15s !important;
}
.cs-reopen-btn:hover { background: #eff6ff !important; }

/* ── CCPA mode – symmetric controls ────────────────────────
   In CCPA mode, accept and reject/DNS buttons have equal prominence. */
#cs-banner.cs-symmetric .cs-btn-row .cs-btn {
    background: #f1f5f9 !important;
    color: #1e293b !important;
    border-color: #e2e8f0 !important;
    font-weight: 600 !important;
}
#cs-banner.cs-symmetric .cs-btn-row .cs-btn:hover {
    background: #e2e8f0 !important;
    border-color: #cbd5e1 !important;
}
#cs-banner.cs-symmetric.cs-theme-dark .cs-btn-row .cs-btn {
    background: #334155 !important;
    color: #f1f5f9 !important;
    border-color: #475569 !important;
}
#cs-banner.cs-symmetric.cs-theme-dark .cs-btn-row .cs-btn:hover {
    background: #475569 !important;
}

/* ── GPC acknowledgment ────────────────────────────────────*/
#cs-banner .cs-gpc-ack {
    padding: 20px 28px !important;
    text-align: center !important;
}
#cs-banner .cs-gpc-ack p {
    margin: 0 !important;
    font-size: 14px !important;
    color: #16a34a !important;
    font-weight: 600 !important;
}
#cs-banner .cs-gpc-ack[hidden] { display: none !important; }

/* ── Opt-out confirmation ──────────────────────────────────*/
#cs-banner .cs-opt-out-confirm {
    padding: 20px 28px !important;
    text-align: center !important;
    background: #f0fdf4 !important;
    border-top: 1px solid #bbf7d0 !important;
}
#cs-banner .cs-opt-out-confirm p {
    margin: 0 !important;
    font-size: 14px !important;
    color: #166534 !important;
    font-weight: 600 !important;
}
#cs-banner .cs-opt-out-confirm[hidden] { display: none !important; }
#cs-banner.cs-theme-dark .cs-opt-out-confirm {
    background: #1a2e1a !important;
    border-top-color: #2d5a2d !important;
}
#cs-banner.cs-theme-dark .cs-opt-out-confirm p {
    color: #bbf7d0 !important;
}

/* ── "Do Not Sell" footer link ─────────────────────────────*/
.cs-dns-link {
    display: inline-flex !important;
    align-items: center !important;
    padding: 6px 14px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #1b5ebe !important;
    background: transparent !important;
    border: 1px solid #1b5ebe !important;
    border-radius: 5px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    transition: background 0.15s !important;
}
.cs-dns-link:hover { background: #eff6ff !important; }

/* ── Responsive ─────────────────────────────────────────────*/
@media (max-width: 600px) {
    #cs-banner .cs-inner { margin: 0 !important; border-radius: 0 !important; max-width: 100% !important; }
    #cs-banner.cs-pos-top    .cs-inner { margin: 0 !important; }
    #cs-banner.cs-pos-center .cs-inner { margin: 0 !important; border-radius: 0 !important; }
    #cs-banner .cs-actions   { flex-direction: column !important; align-items: stretch !important; }
    #cs-banner .cs-btn-row   { margin-left: 0 !important; }
    #cs-banner .cs-btn-row .cs-btn { flex: 1 !important; justify-content: center !important; }
    #cs-banner .cs-content   { padding: 20px 18px 14px !important; }
    #cs-banner .cs-cat-block { padding: 14px 18px !important; }
    #cs-banner .cs-actions   { padding: 14px 18px 20px !important; }
}
