/* =====================================================
   XJM COOKIE NOTICE – STABLE FINAL CSS
===================================================== */

/* =========================
   BANNER
========================= */

#xjm-cookie-banner.xjm-cookie-box {
  position: fixed !important;
  width: 420px !important;
  max-width: 95% !important;
  border-radius: 7px;
  box-shadow: 0 -1px 10px 0 #0000004d;
  padding: 20px;
  z-index: 999999 !important;
  display: none;
  box-sizing: border-box !important;
}
#xjm-cookie-banner *, #xjm-cookie-banner *:before, #xjm-cookie-banner *:after {
  box-sizing: border-box !important;
}

/* Positions */
#xjm-cookie-banner.xjm-position-bottom-right { bottom: 20px; right: 20px; }
#xjm-cookie-banner.xjm-position-bottom-left  { bottom: 20px; left: 20px; }
#xjm-cookie-banner.xjm-position-center       { top: 50%; left: 50%; transform: translate(-50%, -50%); }

/* Close X */
#xjm-cookie-banner .xjm-cookie-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 28px;
  line-height: 44px;
  text-align: center;
  opacity: .75;
}
#xjm-cookie-banner .xjm-cookie-close:hover { opacity: 1; }

/* Banner content spacing */
#xjm-cookie-banner .xjm-cookie-header h3 { margin: 0 0 10px !important; }
#xjm-cookie-banner .xjm-cookie-body p { margin: 0 0 18px; line-height: 1.6; }

/* Banner buttons */
#xjm-cookie-banner .xjm-cookie-actions {
  display: flex;
  gap: 14px;
}
#xjm-cookie-banner .xjm-cookie-actions button {
  flex: 1;
  padding: 14px 0;
  border-radius: 6px;
  cursor: pointer;
  font-weight: 600;
}

/* Customize link */
#xjm-cookie-banner .xjm-cookie-links {
  text-align: center;
  margin-top: 5px !important;
}
#xjm-cookie-banner a.xjm-open-settings, #xjm-cookie-banner a.xjm-cookie-policy {
  cursor: pointer !important;
  text-decoration: underline !important;
}
#xjm-cookie-banner a.xjm-open-settings:hover, #xjm-cookie-banner a.xjm-cookie-policy:hover {
  text-decoration: none !important;
}

/* =========================
   MODAL (FINAL SYSTEM)
========================= */

html body #xjm-cookie-modal {
  position: fixed !important;
  inset: 0 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(0,0,0,.55) !important;
  z-index: 2147483647 !important;
}

/* THIS is what JS toggles */
html body #xjm-cookie-modal.is-open {
  display: flex !important;
}

/* Modal box */
#xjm-cookie-modal .xjm-modal-content {
  width: 500px;
  max-width: 95%;
  background: #fff;
  border-radius: 8px;
  padding: 32px;
  position: relative;
  box-shadow: 0 -1px 10px 0 #0000004d;
}

/* Modal close button */
#xjm-cookie-modal .xjm-modal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 30px;
  line-height: 44px;
  text-align: center;
}

/* Modal spacing */
#xjm-cookie-modal h4 {
  margin: 0 0 12px;
}

.xjm-modal-description {
  margin-bottom: 20px;
}

/* Checkbox layout */
.xjm-modal-options {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 24px;
}

.xjm-opt {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* 50% buttons */
.xjm-modal-actions {
  display: flex;
  gap: 12px;
}

.xjm-modal-actions button {
  flex: 1;
  height: 44px;
  border-radius: 4px;
  cursor: pointer;
  font-weight: 500;
}

.xjm-modal-actions button:hover {
  opacity: .92;
}

/* =========================================
   MOBILE FIXES (FULL WIDTH BANNER)
========================================= */

@media (max-width: 768px){

  #xjm-cookie-banner{
    width: 100% !important;
    max-width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    top: auto !important;
    transform: none !important;
    border-radius: 0 !important;
  }

  #xjm-cookie-banner.xjm-position-center{
    top: auto !important;
  }

  #xjm-cookie-banner .xjm-cookie-actions{
    flex-direction: column;
  }

  #xjm-cookie-banner .xjm-cookie-actions button{
    width: 100%;
  }

  #xjm-cookie-modal .xjm-modal-content{
    width: 95%;
    padding: 24px;
  }

  .xjm-modal-actions{
    flex-direction: column;
  }

  .xjm-modal-actions button{
    width: 100%;
  }

}


/* =========================================
   Floating Cookie Icon Button
========================================= */

.xjm-floating-cookie{
  position: fixed;
  bottom: 20px;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  display: none; /* hidden until consent */
  align-items: center;
  justify-content: center;
  z-index: 2147483646;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  transition: transform .2s ease, opacity .2s ease;
}

.xjm-floating-cookie.xjm-pos-left{
  left: 20px;
}

.xjm-floating-cookie.xjm-pos-right{
  right: 20px;
}

.xjm-floating-cookie:hover{
  transform: scale(1.08);
  opacity: .9;
}

/* Pulse animation when no consent */
@keyframes xjmPulse {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.1); }
  100% { transform: scale(1); }
}

.xjm-floating-cookie.pulse{
  animation: xjmPulse 2s infinite;
}