/* Exa Jurídico — Cookie banner (AEPD-compliant)
 * Capa simétrica: aceptar / rechazar / configurar igualmente visibles.
 * Cumple art. 22.2 LSSI-CE + Guía de cookies AEPD 2023.
 */

#exa-cookie-banner,
#exa-cookie-modal-overlay {
  font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}

#exa-cookie-banner *,
#exa-cookie-modal-overlay * { box-sizing: border-box; }

/* ===== Banner (capa 1) ===== */
#exa-cookie-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  max-width: 880px;
  margin: 0 auto;
  padding: 22px 26px;
  background: #FFFFFF;
  color: #161616;
  border: 1px solid #CAD2DA;
  border-radius: 14px;
  box-shadow: 0 18px 48px -16px rgba(18, 3, 96, 0.25), 0 1px 0 rgba(255,255,255,0.9) inset;
  z-index: 2147483000;
  display: flex;
  flex-wrap: wrap;
  gap: 18px 22px;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  line-height: 1.55;
  animation: exa-cb-slide .35s ease-out;
}

@keyframes exa-cb-slide {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

#exa-cookie-banner .exa-cb-text {
  flex: 1 1 320px;
  min-width: 240px;
  color: #4D5A66;
}

#exa-cookie-banner .exa-cb-text b {
  display: block;
  font-family: "Montserrat";
  font-size: 16px;
  font-weight: 500;
  color: #120360;
  margin-bottom: 4px;
}

#exa-cookie-banner .exa-cb-text a {
  color: #086D6A;
  text-decoration: underline;
  text-decoration-color: rgba(8,109,106,0.35);
  text-underline-offset: 2px;
  font-weight: 500;
}
#exa-cookie-banner .exa-cb-text a:hover { color: #120360; text-decoration-color: #120360; }

#exa-cookie-banner .exa-cb-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

#exa-cookie-banner button {
  font-family: "Montserrat", -apple-system, sans-serif;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 11px 18px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s, transform .15s;
  white-space: nowrap;
}

/* AEPD: los tres botones tienen el mismo nivel visual.
   Diferenciamos sólo con color de marca (acepta = primary). */
#exa-cookie-banner .exa-cb-btn-reject {
  background: #FFFFFF;
  color: #120360;
  border-color: #CAD2DA;
}
#exa-cookie-banner .exa-cb-btn-reject:hover {
  border-color: #120360;
  color: #120360;
  background: #F0F4F5;
}

#exa-cookie-banner .exa-cb-btn-config {
  background: #FFFFFF;
  color: #548895;
  border-color: #548895;
}
#exa-cookie-banner .exa-cb-btn-config:hover {
  background: #548895;
  color: #FFFFFF;
}

#exa-cookie-banner .exa-cb-btn-accept {
  background: #548895;
  color: #FFFFFF;
  border-color: #548895;
}
#exa-cookie-banner .exa-cb-btn-accept:hover {
  background: #120360;
  border-color: #120360;
  transform: translateY(-1px);
}

@media (max-width: 720px) {
  #exa-cookie-banner {
    left: 8px;
    right: 8px;
    bottom: 8px;
    padding: 18px 18px;
    font-size: 13.5px;
  }
  #exa-cookie-banner .exa-cb-actions {
    width: 100%;
  }
  #exa-cookie-banner .exa-cb-actions button {
    flex: 1 1 0;
    min-width: 0;
    padding: 11px 10px;
    font-size: 13px;
  }
}

@media (max-width: 420px) {
  #exa-cookie-banner .exa-cb-actions {
    flex-direction: column;
    align-items: stretch;
  }
  #exa-cookie-banner .exa-cb-actions button { width: 100%; }
}

/* ===== Modal de preferencias (capa 2) ===== */
#exa-cookie-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(18, 3, 96, 0.42);
  backdrop-filter: blur(4px);
  z-index: 2147483100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: exa-cb-fade .25s ease-out;
}

@keyframes exa-cb-fade { from { opacity: 0; } to { opacity: 1; } }

#exa-cookie-modal {
  background: #FFFFFF;
  color: #161616;
  border-radius: 16px;
  border: 1px solid #CAD2DA;
  box-shadow: 0 30px 60px -20px rgba(18,3,96,0.45);
  max-width: 620px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  padding: 28px 30px 24px;
  font-size: 14px;
  line-height: 1.6;
  position: relative;
}

#exa-cookie-modal h2 {
  font-family: "Montserrat";
  font-weight: 400;
  font-size: 24px;
  color: #120360;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
#exa-cookie-modal h2 em { color: #086D6A; font-style: italic; }

#exa-cookie-modal .exa-cb-modal-intro {
  color: #4D5A66;
  margin: 0 0 22px;
  font-size: 13.5px;
}
#exa-cookie-modal .exa-cb-modal-intro a { color: #086D6A; text-decoration: underline; }

#exa-cookie-modal .exa-cb-cat {
  border: 1px solid #CAD2DA;
  border-radius: 10px;
  padding: 16px 18px;
  margin-bottom: 12px;
  background: #F8FAFB;
  transition: border-color .2s;
}
#exa-cookie-modal .exa-cb-cat:hover { border-color: #548895; }

#exa-cookie-modal .exa-cb-cat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}

#exa-cookie-modal .exa-cb-cat-title {
  font-family: "Montserrat";
  font-weight: 500;
  font-size: 15px;
  color: #120360;
}

#exa-cookie-modal .exa-cb-cat-desc {
  color: #4D5A66;
  font-size: 13px;
  margin: 0;
}

/* Toggle switch */
#exa-cookie-modal .exa-cb-switch {
  position: relative;
  display: inline-block;
  width: 42px;
  height: 24px;
  flex-shrink: 0;
}
#exa-cookie-modal .exa-cb-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
#exa-cookie-modal .exa-cb-slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background: #CAD2DA;
  border-radius: 999px;
  transition: background .2s;
}
#exa-cookie-modal .exa-cb-slider::before {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  left: 3px;
  top: 3px;
  background: #FFFFFF;
  border-radius: 50%;
  transition: transform .2s;
  box-shadow: 0 1px 2px rgba(0,0,0,0.18);
}
#exa-cookie-modal .exa-cb-switch input:checked + .exa-cb-slider {
  background: #548895;
}
#exa-cookie-modal .exa-cb-switch input:checked + .exa-cb-slider::before {
  transform: translateX(18px);
}
#exa-cookie-modal .exa-cb-switch input:disabled + .exa-cb-slider {
  background: #086D6A;
  cursor: not-allowed;
  opacity: 0.7;
}

#exa-cookie-modal .exa-cb-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
  justify-content: flex-end;
}

#exa-cookie-modal .exa-cb-modal-actions button {
  font-family: "Montserrat";
  font-size: 13.5px;
  font-weight: 500;
  padding: 11px 18px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
  white-space: nowrap;
}

#exa-cookie-modal .exa-cb-modal-actions .exa-cb-btn-reject {
  background: #FFFFFF;
  color: #120360;
  border-color: #CAD2DA;
}
#exa-cookie-modal .exa-cb-modal-actions .exa-cb-btn-reject:hover {
  border-color: #120360;
  background: #F0F4F5;
}

#exa-cookie-modal .exa-cb-modal-actions .exa-cb-btn-save {
  background: #FFFFFF;
  color: #548895;
  border-color: #548895;
}
#exa-cookie-modal .exa-cb-modal-actions .exa-cb-btn-save:hover {
  background: #548895;
  color: #FFFFFF;
}

#exa-cookie-modal .exa-cb-modal-actions .exa-cb-btn-accept {
  background: #548895;
  color: #FFFFFF;
  border-color: #548895;
}
#exa-cookie-modal .exa-cb-modal-actions .exa-cb-btn-accept:hover {
  background: #120360;
  border-color: #120360;
}

@media (max-width: 480px) {
  #exa-cookie-modal { padding: 22px 20px 18px; }
  #exa-cookie-modal h2 { font-size: 20px; }
  #exa-cookie-modal .exa-cb-modal-actions { justify-content: stretch; }
  #exa-cookie-modal .exa-cb-modal-actions button { flex: 1 1 0; min-width: 0; }
}

/* ===== Botón flotante "Cookies" en footer (opcional) ===== */
.exa-cb-reopen-link {
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  text-decoration: inherit;
}
