/**
 * Modal Positioning Fix
 * Fixes modals appearing too far left on all dashboards
 * Version: 1.0.0 (2025-11-25)
 */

/* Base modal overlay - ensures full screen coverage and proper centering.
   IMPORTANT: Do NOT force display here; let modal scripts control visibility. */
.modal,
.modal-overlay,
[class*="modal"] {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(0, 0, 0, 0.5) !important;
  z-index: 9999 !important;
  padding: 20px !important;
  box-sizing: border-box !important;
}

/* Modal content - properly centered */
.modal-content,
.modal > div:first-child,
[class*="modal"] > div:first-child:not(.modal-overlay) {
  position: relative !important;
  margin: auto !important;
  max-width: 90% !important;
  max-height: 90vh !important;
  width: auto !important;
  min-width: 300px !important;
  background: white !important;
  border-radius: 8px !important;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2) !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  animation: modalSlideIn 0.3s ease !important;
}

/* Different modal sizes */
.modal-content.modal-small,
.modal-small .modal-content {
  max-width: 400px !important;
}

.modal-content.modal-medium,
.modal-medium .modal-content {
  max-width: 600px !important;
}

.modal-content.modal-large,
.modal-large .modal-content {
  max-width: 800px !important;
}

.modal-content.modal-full,
.modal-full .modal-content {
  max-width: 95% !important;
  width: 95% !important;
}

/* Modal header */
.modal-header {
  padding: 20px !important;
  border-bottom: 1px solid #eee !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background: #f9f9f9 !important;
}

.modal-header h3,
.modal-header h4 {
  margin: 0 !important;
  font-size: 18px !important;
  color: #333 !important;
}

/* Close button */
.modal-header .close-btn,
.modal-header button[class*="close"],
.modal-header .btn-close {
  background: none !important;
  border: none !important;
  font-size: 24px !important;
  cursor: pointer !important;
  color: #666 !important;
  padding: 0 !important;
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  transition: background 0.2s !important;
}

.modal-header .close-btn:hover,
.modal-header button[class*="close"]:hover {
  background: rgba(0, 0, 0, 0.1) !important;
}

/* Modal body */
.modal-body {
  padding: 20px !important;
  max-height: 60vh !important;
  overflow-y: auto !important;
}

/* Modal footer */
.modal-footer {
  padding: 15px 20px !important;
  border-top: 1px solid #eee !important;
  display: flex !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  background: #f9f9f9 !important;
}

/* Form elements inside modals */
.modal-content .form-group {
  margin-bottom: 15px !important;
}

.modal-content .form-group label {
  display: block !important;
  margin-bottom: 5px !important;
  font-weight: 500 !important;
  color: #333 !important;
}

.modal-content .form-group input,
.modal-content .form-group select,
.modal-content .form-group textarea {
  width: 100% !important;
  padding: 10px 12px !important;
  border: 1px solid #ddd !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  box-sizing: border-box !important;
  transition: border-color 0.2s !important;
}

.modal-content .form-group input:focus,
.modal-content .form-group select:focus,
.modal-content .form-group textarea:focus {
  border-color: #4CAF50 !important;
  outline: none !important;
}

/* Buttons in modal */
.modal-content button {
  padding: 10px 20px !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
}

.modal-content .primary-button,
.modal-content button.primary,
.modal-content button[type="submit"] {
  background: #4CAF50 !important;
  color: white !important;
  border: none !important;
}

.modal-content .primary-button:hover,
.modal-content button.primary:hover,
.modal-content button[type="submit"]:hover {
  background: #45a049 !important;
}

.modal-content .secondary-button,
.modal-content button.secondary,
.modal-content button[type="button"] {
  background: #f5f5f5 !important;
  color: #333 !important;
  border: 1px solid #ddd !important;
}

.modal-content .secondary-button:hover,
.modal-content button.secondary:hover {
  background: #e0e0e0 !important;
}

/* Animation */
@keyframes modalSlideIn {
  from {
    opacity: 0;
    transform: translateY(-30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Mobile responsive */
@media screen and (max-width: 768px) {
  .modal,
  .modal-overlay {
    padding: 10px !important;
  }
  
  .modal-content,
  .modal > div:first-child {
    width: 100% !important;
    max-width: 100% !important;
    min-width: unset !important;
    max-height: 95vh !important;
    border-radius: 8px !important;
  }
  
  .modal-header {
    padding: 15px !important;
  }
  
  .modal-body {
    padding: 15px !important;
    max-height: 55vh !important;
  }
  
  .modal-footer {
    padding: 10px 15px !important;
    flex-direction: column !important;
  }
  
  .modal-footer button {
    width: 100% !important;
  }
}

/* Fix for any inline styled modals */
div[style*="position: fixed"][style*="z-index"] {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Ensure body doesn't scroll when modal is open */
body.modal-open {
  overflow: hidden !important;
}

/* Add Staff Modal Specific Fix */
#add-staff-modal .modal-content,
[id*="staff"] .modal-content,
[id*="task"] .modal-content,
[id*="schedule"] .modal-content {
  margin: auto !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
}

/* Override any transform-based centering that might cause left shift */
.modal-content[style*="transform"] {
  transform: none !important;
  margin: auto !important;
}
