#modal-pix {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.55);
    
    justify-content: center;
    align-items: center;
    z-index: 1000;
}



#modal-pix .modal-content {
    background: #ffffff;
    border-radius: 12px;
    max-width: 500px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

#modal-pix .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 18px;
    border-bottom: 1px solid #dee2e6;
}

#modal-pix .modal-body {
    padding: 16px 18px;
}

#modal-pix .modal-footer {
    padding: 12px 18px;
    border-top: 1px solid #dee2e6;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

.btn-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: #999;
}

.btn-close:hover {
    color: #495057;
}

.loading-spinner {
    border: 3px solid #f3f3f3;
    border-top: 3px solid #3498db;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    animation: spin 1s linear infinite;
    margin: 10px auto;
}

@keyframes spin { 0% { transform: rotate(0deg);} 100% { transform: rotate(360deg);} }
    100% { transform: rotate(360deg); }
}

.pix-info, .pix-qrcode, .pix-codigo, .pix-status {
    margin-bottom: 20px;
}

.status-info {
    text-align: center;
    padding: 15px;
    background: #f8f9fa;
    border-radius: 8px;
}

.pix-qrcode {
padding:12px; background:#f8f9fa; border:1px dashed #dee2e6; border-radius:12px;
}

.pix-codigo textarea {
width:100%; min-height:80px; padding:10px; background:#f1f3f5; border:1px solid #dee2e6; border-radius:10px; color:#495057;
}

#modal-pix.hidden{ display:none !important; }
#modal-pix.show{ display:flex !important; }


/* ==== PIX MODAL THEME (strong overrides) ==== */

/* Targets both ids, plus new pix-* classes for reliability */
#modal-pix, #pix-modal { backdrop-filter: blur(6px) !important; }
#modal-pix.hidden, #pix-modal.hidden { display: none !important; }
#modal-pix.show,   #pix-modal.show   { display: flex !important; align-items: center; justify-content: center; }

/* Content card */
#modal-pix .modal-content, #pix-modal .modal-content,
.pix-modal-content {
  background: #fff !important;
  color: #495057 !important;
  border: 1px solid #dee2e6 !important;
  border-radius: 12px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05) !important;
  overflow: hidden;
  max-width: 560px;
  width: 92%;
}

/* Header / Body / Footer */
#modal-pix .modal-header, #pix-modal .modal-header, .pix-modal-header {
  border-bottom: 1px solid #dee2e6 !important;
  padding: 16px 18px !important;
  background: linear-gradient(to bottom, rgba(0,0,0,.02), rgba(0,0,0,0)) !important;
}
#modal-pix .modal-body, #pix-modal .modal-body, .pix-modal-body { padding: 16px 18px !important; }
#modal-pix .modal-footer, #pix-modal .modal-footer, .pix-modal-footer {
  border-top: 1px solid #dee2e6 !important;
  padding: 12px 18px !important;
}

/* Sections */
#modal-pix .pix-qrcode, #pix-modal .pix-qrcode {
  padding: 12px !important;
  background: #f8f9fa !important;
  border: 1px dashed #dee2e6 !important;
  border-radius: 12px !important;
}
#modal-pix .pix-codigo textarea, #pix-modal .pix-codigo textarea {
  width: 100% !important;
  min-height: 80px !important;
  padding: 10px !important;
  background: #f1f3f5 !important;
  border: 1px solid #dee2e6 !important;
  border-radius: 10px !important;
  color: #495057 !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

/* Buttons */
#modal-pix .btn, #pix-modal .btn {
  appearance: none;
  border: 1px solid #dee2e6;
  background: #fff;
  color: #495057;
  padding: 10px 14px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
}
#modal-pix .btn:hover, #pix-modal .btn:hover { background: #f8f9fa; }
#modal-pix .btn.btn-primary, #pix-modal .btn.btn-primary {
  background: #e879b9 !important;
  border-color: #e879b9 !important;
  color: #fff !important;
}
#modal-pix .btn.btn-secondary, #pix-modal .btn.btn-secondary {
  background: #495057 !important;
  border-color: #495057 !important;
  color: #fff !important;
}

/* Status badges (aguardando/pago/falha) */
#modal-pix .status-info.wait, #pix-modal .status-info.wait { color: #856404 !important; }
#modal-pix .status-info.paid, #pix-modal .status-info.paid { color: #155724 !important; }
#modal-pix .status-info.fail, #pix-modal .status-info.fail { color: #721c24 !important; }


/* ===== PIX Modal UI Enhancements ===== */
#pix-modal .status-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:600; letter-spacing:.02em; padding:.5rem .75rem;
  border-radius:999px; border:1px solid transparent;
  transition:all .25s ease;
}
#pix-modal .status-badge.pending{ background:#fff3cd; color:#856404; border-color:#ffeeba; }
#pix-modal .status-badge.ok{ background:#d4edda; color:#155724; border-color:#c3e6cb; }
#pix-modal .status-badge.err{ background:#f8d7da; color:#721c24; border-color:#f5c6cb; }

#pix-modal .status-icon{ width:18px;height:18px; display:inline-block; }
#pix-modal .status-icon.spin{
  border:3px solid rgba(0,0,0,.1); border-top-color:currentColor;
  border-radius:50%; animation:spin 1s linear infinite;
}
#pix-modal .status-icon.ok{
  border-radius:50%; position:relative;
}
#pix-modal .status-icon.ok::before{
  content:''; position:absolute; left:5px; top:1px; width:5px; height:10px;
  border:3px solid currentColor; border-top:0; border-left:0; transform:rotate(45deg);
}
#pix-modal .status-icon.err{
  position:relative;
}
#pix-modal .status-icon.err::before, #pix-modal .status-icon.err::after{
  content:''; position:absolute; left:8px; top:2px; width:3px; height:14px; background:currentColor;
}
#pix-modal .status-icon.err::after{ transform:rotate(90deg); }

@keyframes spin { to { transform: rotate(360deg); } }

#pix-modal .progress {
  position:relative; height:6px; background:#e9ecef; border-radius:999px; overflow:hidden; margin:.75rem 0 0;
}
#pix-modal .progress .bar {
  position:absolute; left:0; top:0; bottom:0; width:0%;
  background:#0d6efd; transition:width .5s ease;
}
#pix-modal .pix-success{
  text-align:center; padding:1rem 0 .25rem; font-weight:700; font-size:1.05rem;
}
