/**
 * Complianz — banner compacto premium (claro + oscuro).
 * Carga tardía para ganar a estilos inline del plugin.
 */

/* Overlay suave, no pantalla completa opaca */
#cmplz-cookiebanner-container .cmplz-overlay,
.cmplz-overlay {
  background: rgba(6, 40, 31, 0.28) !important;
  backdrop-filter: blur(6px) saturate(120%) !important;
  -webkit-backdrop-filter: blur(6px) saturate(120%) !important;
}

html[data-theme="dark"] #cmplz-cookiebanner-container .cmplz-overlay,
html.cg-dark #cmplz-cookiebanner-container .cmplz-overlay,
html[data-theme="dark"] .cmplz-overlay,
html.cg-dark .cmplz-overlay {
  background: rgba(0, 0, 0, 0.52) !important;
}

/* Tarjeta compacta — esquina inferior derecha */
.cmplz-cookiebanner,
.cmplz-cookiebanner.cmplz-show {
  position: fixed !important;
  top: auto !important;
  left: auto !important;
  right: max(14px, env(safe-area-inset-right)) !important;
  bottom: max(14px, env(safe-area-inset-bottom)) !important;
  transform: none !important;
  margin: 0 !important;
  width: min(440px, calc(100vw - 28px)) !important;
  max-width: 440px !important;
  max-height: none !important;
  padding: 16px 18px 14px !important;
  border: 1px solid rgba(18, 63, 45, 0.12) !important;
  border-radius: 22px !important;
  background: rgba(255, 253, 248, 0.97) !important;
  color: var(--cgc-text-primary, #10231a) !important;
  box-shadow: 0 18px 50px rgba(18, 63, 45, 0.16), 0 2px 0 rgba(255, 255, 255, 0.65) inset !important;
  backdrop-filter: blur(16px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(140%) !important;
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif !important;
  z-index: 999999 !important;
}

/* Panel preferencias: un poco más ancho, altura acotada + scroll */
.cmplz-cookiebanner.cmplz-view-preferences,
.cmplz-cookiebanner.cmplz-categories-visible {
  width: min(520px, calc(100vw - 28px)) !important;
  max-width: 520px !important;
  max-height: min(78vh, 580px) !important;
  padding: 18px 18px 14px !important;
}

.cmplz-cookiebanner .cmplz-body {
  max-height: none !important;
  overflow: visible !important;
}

.cmplz-cookiebanner.cmplz-view-preferences .cmplz-body,
.cmplz-cookiebanner.cmplz-categories-visible .cmplz-body {
  max-height: min(46vh, 360px) !important;
  overflow-y: auto !important;
  overscroll-behavior: contain;
  padding-right: 2px;
}

.cmplz-cookiebanner .cmplz-header,
.cmplz-cookiebanner .cmplz-body,
.cmplz-cookiebanner .cmplz-footer {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}

.cmplz-cookiebanner .cmplz-header {
  margin-bottom: 8px !important;
  min-height: 0 !important;
}

.cmplz-cookiebanner .cmplz-title {
  font-family: Outfit, Inter, system-ui, sans-serif !important;
  font-size: 1.08rem !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  color: var(--cgc-green-900, #0f3d2e) !important;
  margin: 0 0 6px !important;
}

.cmplz-cookiebanner .cmplz-message,
.cmplz-cookiebanner .cmplz-description,
.cmplz-cookiebanner .cmplz-category-description {
  color: var(--cgc-text-secondary, #4f5f58) !important;
  font-size: 0.86rem !important;
  line-height: 1.55 !important;
  margin: 0 0 12px !important;
}

/* Ocultar categorías en vista inicial — solo al abrir preferencias */
.cmplz-cookiebanner:not(.cmplz-view-preferences):not(.cmplz-categories-visible) .cmplz-categories,
.cmplz-cookiebanner:not(.cmplz-view-preferences):not(.cmplz-categories-visible) .cmplz-categories-wrap {
  display: none !important;
}

.cmplz-cookiebanner .cmplz-categories {
  margin: 10px 0 0 !important;
  display: grid !important;
  gap: 8px !important;
}

.cmplz-cookiebanner .cmplz-category,
.cmplz-cookiebanner .cmplz-categories-wrap {
  border: 1px solid rgba(18, 63, 45, 0.1) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  padding: 10px 12px !important;
}

.cmplz-cookiebanner .cmplz-category-title {
  font-size: 0.92rem !important;
  font-weight: 850 !important;
  color: var(--cgc-green-900, #0f3d2e) !important;
}

.cmplz-cookiebanner .cmplz-always-active {
  color: var(--cgc-green-700, #1f6b45) !important;
  font-size: 0.78rem !important;
  font-weight: 800 !important;
}

.cmplz-cookiebanner .cmplz-links,
.cmplz-cookiebanner .cmplz-documents {
  gap: 8px !important;
  margin-top: 10px !important;
}

.cmplz-cookiebanner .cmplz-links a,
.cmplz-cookiebanner .cmplz-documents a,
.cmplz-cookiebanner .cmplz-link {
  color: var(--cgc-green-700, #1f6b45) !important;
  font-size: 0.78rem !important;
  font-weight: 750 !important;
  text-decoration: none !important;
}

.cmplz-cookiebanner .cmplz-links a:hover,
.cmplz-cookiebanner .cmplz-documents a:hover,
.cmplz-cookiebanner .cmplz-link:hover {
  color: var(--cgc-green-900, #0f3d2e) !important;
  text-decoration: underline !important;
  text-underline-offset: 2px !important;
}

/* Botones compactos */
.cmplz-cookiebanner .cmplz-buttons {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
  margin-top: 12px !important;
}

.cmplz-cookiebanner .cmplz-btn,
.cmplz-cookiebanner button.cmplz-btn,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn {
  min-height: 42px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(18, 63, 45, 0.14) !important;
  font-weight: 850 !important;
  font-size: 0.84rem !important;
  line-height: 1.1 !important;
  box-shadow: none !important;
  transition: transform 0.16s ease, box-shadow 0.16s ease, background 0.16s ease, border-color 0.16s ease, color 0.16s ease !important;
}

.cmplz-cookiebanner .cmplz-btn:hover {
  transform: translateY(-1px) !important;
}

.cmplz-cookiebanner .cmplz-accept,
.cmplz-cookiebanner .cmplz-save-preferences {
  background: linear-gradient(135deg, var(--cgc-green-900, #0f3d2e), var(--cgc-green-700, #1f6b45)) !important;
  color: #fffdf8 !important;
  border-color: rgba(18, 63, 45, 0.22) !important;
  box-shadow: 0 10px 24px rgba(18, 63, 45, 0.18) !important;
}

.cmplz-cookiebanner .cmplz-accept:hover,
.cmplz-cookiebanner .cmplz-save-preferences:hover {
  box-shadow: 0 14px 28px rgba(18, 63, 45, 0.22) !important;
}

.cmplz-cookiebanner .cmplz-deny {
  background: #fff !important;
  color: var(--cgc-green-900, #0f3d2e) !important;
  border-color: rgba(18, 63, 45, 0.18) !important;
}

.cmplz-cookiebanner .cmplz-view-preferences {
  grid-column: 1 / -1 !important;
  background: transparent !important;
  color: var(--cgc-green-800, #123f2d) !important;
  border: 1px dashed rgba(18, 63, 45, 0.22) !important;
  min-height: 38px !important;
  font-size: 0.8rem !important;
  box-shadow: none !important;
}

.cmplz-cookiebanner .cmplz-view-preferences:hover {
  background: rgba(18, 63, 45, 0.04) !important;
  border-style: solid !important;
}

.cmplz-cookiebanner .cmplz-close {
  width: 32px !important;
  height: 32px !important;
  color: var(--cgc-green-900, #0f3d2e) !important;
  opacity: 0.65 !important;
  border-radius: 999px !important;
  transition: opacity 0.16s ease, background 0.16s ease !important;
}

.cmplz-cookiebanner .cmplz-close:hover {
  opacity: 1 !important;
  background: rgba(18, 63, 45, 0.06) !important;
}

/* Toggles Complianz */
.cmplz-cookiebanner .cmplz-banner-checkbox input:checked + label::before,
.cmplz-cookiebanner .cmplz-toggle-checkbox input:checked + .cmplz-label::before {
  background: var(--cgc-green-700, #1f6b45) !important;
}

#cmplz-manage-consent .cmplz-manage-consent,
.cmplz-manage-consent {
  border-radius: 999px !important;
  border: 1px solid rgba(18, 63, 45, 0.16) !important;
  background: var(--cgc-green-900, #0f3d2e) !important;
  color: #fffdf8 !important;
  font-weight: 850 !important;
  font-size: 0.82rem !important;
  padding: 8px 14px !important;
  box-shadow: 0 10px 24px rgba(18, 63, 45, 0.2) !important;
}

#cmplz-manage-consent .cmplz-manage-consent:hover,
.cmplz-manage-consent:hover {
  background: var(--cgc-green-700, #1f6b45) !important;
}

@media (max-width: 520px) {
  .cmplz-cookiebanner,
  .cmplz-cookiebanner.cmplz-show,
  .cmplz-cookiebanner.cmplz-view-preferences,
  .cmplz-cookiebanner.cmplz-categories-visible {
    left: max(10px, env(safe-area-inset-left)) !important;
    right: max(10px, env(safe-area-inset-right)) !important;
    bottom: max(10px, env(safe-area-inset-bottom)) !important;
    width: auto !important;
    max-width: none !important;
    padding: 14px 14px 12px !important;
    border-radius: 18px !important;
  }

  .cmplz-cookiebanner .cmplz-buttons {
    grid-template-columns: 1fr !important;
  }

  .cmplz-cookiebanner .cmplz-title {
    font-size: 1rem !important;
    padding-right: 28px !important;
  }
}

/* ── Modo oscuro ── */
html[data-theme="dark"] .cmplz-cookiebanner,
html.cg-dark .cmplz-cookiebanner,
html[data-theme="dark"] .cmplz-cookiebanner.cmplz-show,
html.cg-dark .cmplz-cookiebanner.cmplz-show {
  background: rgba(14, 32, 26, 0.96) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
  color: var(--cgc-text, #eef6f1) !important;
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.45), 0 1px 0 rgba(255, 255, 255, 0.06) inset !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-title,
html.cg-dark .cmplz-cookiebanner .cmplz-title,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-category-title,
html.cg-dark .cmplz-cookiebanner .cmplz-category-title {
  color: #f4faf6 !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-message,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-description,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-category-description,
html.cg-dark .cmplz-cookiebanner .cmplz-message,
html.cg-dark .cmplz-cookiebanner .cmplz-description,
html.cg-dark .cmplz-cookiebanner .cmplz-category-description {
  color: rgba(238, 246, 241, 0.78) !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-category,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-categories-wrap,
html.cg-dark .cmplz-cookiebanner .cmplz-category,
html.cg-dark .cmplz-cookiebanner .cmplz-categories-wrap {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-links a,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-documents a,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-link,
html.cg-dark .cmplz-cookiebanner .cmplz-links a,
html.cg-dark .cmplz-cookiebanner .cmplz-documents a,
html.cg-dark .cmplz-cookiebanner .cmplz-link {
  color: #8fd4ad !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-accept,
html[data-theme="dark"] .cmplz-cookiebanner .cmplz-save-preferences,
html.cg-dark .cmplz-cookiebanner .cmplz-accept,
html.cg-dark .cmplz-cookiebanner .cmplz-save-preferences {
  background: linear-gradient(135deg, #1f6b45, #2f7d57) !important;
  color: #fffdf8 !important;
  border-color: rgba(143, 212, 173, 0.25) !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-deny,
html.cg-dark .cmplz-cookiebanner .cmplz-deny {
  background: rgba(255, 255, 255, 0.06) !important;
  color: #f4faf6 !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-view-preferences,
html.cg-dark .cmplz-cookiebanner .cmplz-view-preferences {
  color: rgba(238, 246, 241, 0.88) !important;
  border-color: rgba(255, 255, 255, 0.18) !important;
  background: transparent !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-view-preferences:hover,
html.cg-dark .cmplz-cookiebanner .cmplz-view-preferences:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}

html[data-theme="dark"] .cmplz-cookiebanner .cmplz-close,
html.cg-dark .cmplz-cookiebanner .cmplz-close {
  color: #f4faf6 !important;
}

html[data-theme="dark"] #cmplz-manage-consent .cmplz-manage-consent,
html[data-theme="dark"] .cmplz-manage-consent,
html.cg-dark #cmplz-manage-consent .cmplz-manage-consent,
html.cg-dark .cmplz-manage-consent {
  background: #1f6b45 !important;
  border-color: rgba(143, 212, 173, 0.22) !important;
}
