/* ============================================================
   Klaro! — Tema Énfasis Media
   Design system: #0B0F1A | #504CFF | #FF9E4A | Satoshi
   ============================================================ */

/* ── Variables de Klaro sobreescritas ── */
.klaro {
  --font-family: 'Satoshi', system-ui, sans-serif;
  --font-size: 14px;

  /* Colores base */
  --dark1:  #0B0F1A;
  --dark2:  #131929;
  --dark3:  #a0a8c0;
  --light1: #ffffff;
  --light2: rgba(255,255,255,0.08);
  --light3: rgba(255,255,255,0.04);

  /* Acento principal → purple */
  --blue1:  #504CFF;
  --blue2:  #6663ff;

  /* Toggle ON → purple */
  --green1: #504CFF;
  --green2: #6663ff;

  /* Bordes */
  --border-style: solid;
  --border-width: 1px;
  --border-radius: 8px;
  --border-radius-sm: 6px;
}

/* ── Cookie Notice (banner inferior) ── */
.klaro .cookie-notice {
  background: rgba(11, 15, 26, 0.96) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border: 1px solid rgba(80, 76, 255, 0.25) !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(80,76,255,0.1) !important;
  color: #e2e8f0 !important;
  padding: 20px 24px !important;
  max-width: 480px !important;
  bottom: 20px !important;
  left: 20px !important;
}

.klaro .cookie-notice .cn-title {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  margin-bottom: 8px !important;
}

.klaro .cookie-notice p {
  color: #a0a8c0 !important;
  line-height: 1.6 !important;
  font-size: 13px !important;
}

.klaro .cookie-notice a {
  color: #504CFF !important;
  text-decoration: underline !important;
}

/* ── Cookie Modal (panel de preferencias) ── */
.klaro .cookie-modal .cm-modal {
  background: #0f1424 !important;
  border: 1px solid rgba(80, 76, 255, 0.2) !important;
  border-radius: 12px !important;
  box-shadow: 0 24px 64px rgba(0,0,0,0.7) !important;
  color: #e2e8f0 !important;
}

.klaro .cookie-modal .cm-header {
  background: #0B0F1A !important;
  border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 12px 12px 0 0 !important;
  padding: 20px 24px !important;
}

.klaro .cookie-modal .cm-header h1 {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 18px !important;
}

.klaro .cookie-modal .cm-header p,
.klaro .cookie-modal .cm-body p {
  color: #a0a8c0 !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}

.klaro .cookie-modal .cm-body {
  background: #0f1424 !important;
  padding: 16px 24px !important;
}

.klaro .cookie-modal .cm-footer {
  background: #0B0F1A !important;
  border-top: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 0 0 12px 12px !important;
  padding: 16px 24px !important;
}

/* Separadores de lista */
.klaro .cookie-modal .cm-switch-container,
.klaro .cookie-notice .cm-switch-container {
  border-bottom-color: rgba(255,255,255,0.06) !important;
}

/* Títulos de servicio */
.klaro .cookie-modal .cm-list-title,
.klaro .cookie-notice .cm-list-title {
  color: #e2e8f0 !important;
  font-weight: 600 !important;
}

/* Descripción de servicio */
.klaro .cookie-modal .cm-list-description,
.klaro .cookie-notice .cm-list-description {
  color: #6b7280 !important;
}

/* Títulos de propósito/grupo */
.klaro .cookie-modal .cm-purpose-title {
  color: #504CFF !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

/* ── Botones ── */

/* Aceptar todo → purple sólido */
.klaro .cm-btn.cm-btn-accept-all,
.klaro .cm-btn.cm-btn-accept {
  background: #504CFF !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  padding: 9px 18px !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
}

.klaro .cm-btn.cm-btn-accept-all:hover,
.klaro .cm-btn.cm-btn-accept:hover {
  background: #6663ff !important;
}

/* Guardar selección → amber outline */
.klaro .cm-btn.cm-btn-save {
  background: transparent !important;
  color: #FF9E4A !important;
  border: 1px solid #FF9E4A !important;
  border-radius: 8px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  padding: 9px 18px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.klaro .cm-btn.cm-btn-save:hover {
  background: rgba(255, 158, 74, 0.1) !important;
}

/* Rechazar todo → ghost gris */
.klaro .cm-btn.cm-btn-decline {
  background: transparent !important;
  color: #6b7280 !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 8px !important;
  font-weight: 500 !important;
  font-size: 13px !important;
  padding: 9px 18px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.klaro .cm-btn.cm-btn-decline:hover {
  color: #a0a8c0 !important;
  border-color: rgba(255,255,255,0.2) !important;
}

/* "Gestionar preferencias" link */
.klaro .cookie-notice .cn-learn-more {
  color: #504CFF !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}

/* ── Toggle switches ── */

/* Slider OFF */
.klaro .cookie-modal .cm-list-label .slider,
.klaro .cookie-notice .cm-list-label .slider {
  background-color: #1e2538 !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
}

/* Slider ON → purple */
.klaro .cookie-modal .cm-list-input:checked + .cm-list-label .slider {
  background-color: #504CFF !important;
  border-color: #504CFF !important;
}

/* Slider requerido → purple tenue */
.klaro .cookie-modal .cm-list-input.required:checked + .cm-list-label .slider,
.klaro .cookie-modal .cm-list-input.only-required + .cm-list-label .slider {
  background-color: #504CFF !important;
  opacity: 0.5 !important;
}

/* Overlay del modal */
.klaro .cookie-modal {
  background: rgba(0,0,0,0.7) !important;
  backdrop-filter: blur(4px) !important;
}

/* Botón cerrar modal */
.klaro .cookie-modal .hide {
  color: #6b7280 !important;
  font-size: 20px !important;
}

.klaro .cookie-modal .hide:hover {
  color: #ffffff !important;
}

/* Links generales */
.klaro a {
  color: #504CFF !important;
}
