/**
 * Quiz Modal Additional Styles
 * Additional CSS for quiz modal functionality
 * 
 * @version 2.1.0
 */

/* SweetAlert2 Custom Styles for Quiz Modal */
.swal2-popup.quiz-modal-popup {
  font-family: inherit !important;
  border-radius: 12px !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3) !important;
  max-width: 90vw !important;
  width: 800px !important;
}

.swal2-popup.quiz-modal-popup .swal2-title {
  color: #333 !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 20px !important;
}

.swal2-popup.quiz-modal-popup .swal2-html-container {
  margin: 0 !important;
  padding: 0 !important;
}

/* Quiz Container Styles */
.quiz-modal-wrapper {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

/* QSM Quiz Integration Styles */
.quiz-modal-wrapper .qsm-quiz-container {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-question-container {
  background: #f8f9fa !important;
  border-radius: 8px !important;
  padding: 20px !important;
  margin-bottom: 20px !important;
  border: 1px solid #e9ecef !important;
}

/* Question Font Sizes - Desktop and Mobile */
.quiz-modal-wrapper .qsm-quiz-container .qsm-question,
.quiz-modal-wrapper .qsm-quiz-container .mlw_qmn_new_question {
  font-size: 32px !important;
  font-weight: 600 !important;
  color: #333 !important;
  line-height: 1.4 !important;
  margin-bottom: 20px !important;
}

/* Mobile Responsive Font Sizes */
@media (max-width: 768px) {
  .quiz-modal-wrapper .qsm-quiz-container .qsm-question,
  .quiz-modal-wrapper .qsm-quiz-container .mlw_qmn_new_question {
    font-size: 24px !important;
    line-height: 1.3 !important;
  }
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-answers {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  margin-bottom: 20px !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-answer {
  background: white !important;
  border: 2px solid #e9ecef !important;
  border-radius: 8px !important;
  padding: 15px 20px !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  font-size: 16px !important;
  line-height: 1.4 !important;
  color: #333 !important;
  position: relative !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-answer:hover {
  background-color: #f8f9fa !important;
  border-color: #007cba !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0, 124, 186, 0.15) !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-answer.selected {
  background-color: #007cba !important;
  color: white !important;
  border-color: #007cba !important;
  box-shadow: 0 4px 12px rgba(0, 124, 186, 0.3) !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-answer input[type="radio"],
.quiz-modal-wrapper .qsm-quiz-container .qsm-answer input[type="checkbox"] {
  margin-right: 10px !important;
  transform: scale(1.2) !important;
}

/* Quiz Pagination Styles */
.quiz-pagination-wrapper {
  background: #f8f9fa !important;
  border-radius: 12px !important;
  padding: 20px !important;
  margin: 20px 0 !important;
  border: 1px solid #e9ecef !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
}

.quiz-progress {
  text-align: center !important;
  margin-bottom: 20px !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #007cba !important;
}

.quiz-progress .current-question {
  font-size: 24px !important;
  font-weight: bold !important;
  color: #007cba !important;
}

.quiz-progress .total-questions {
  font-size: 18px !important;
  color: #666 !important;
}

.quiz-navigation {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 15px !important;
}

.quiz-navigation button {
  padding: 12px 24px !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: all 0.3s ease !important;
  text-decoration: none !important;
  display: inline-block !important;
  text-align: center !important;
  min-width: 120px !important;
}

.quiz-navigation button:hover:not(:disabled) {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.quiz-navigation button:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

.quiz-navigation .prev-btn {
  background-color: #6c757d !important;
  color: white !important;
}

.quiz-navigation .prev-btn:hover:not(:disabled) {
  background-color: #545b62 !important;
}

.quiz-navigation .next-btn {
  background-color: #007cba !important;
  color: white !important;
}

.quiz-navigation .next-btn:hover:not(:disabled) {
  background-color: #005a8b !important;
}

.quiz-navigation .submit-btn {
  background-color: #28a745 !important;
  color: white !important;
}

.quiz-navigation .submit-btn:hover:not(:disabled) {
  background-color: #1e7e34 !important;
}

/* Hide all questions by default for pagination */
.quiz-modal-wrapper .qsm-quiz-container .qsm-question-wrapper {
  display: none !important;
}

/* Show only the active question */
.quiz-modal-wrapper .qsm-quiz-container .qsm-question-wrapper.active {
  display: block !important;
}

/* Additional specificity to ensure questions are hidden */
.qsm-quiz-container .qsm-question-wrapper {
  display: none !important;
}

.qsm-quiz-container .qsm-question-wrapper.active {
  display: block !important;
}

/* Ensure the quiz begin section is always visible */
.qsm-quiz-container .quiz_section.quiz_begin {
  display: block !important;
}

/* Navigation Buttons */
.quiz-modal-wrapper .qsm-quiz-container .qsm-navigation {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-top: 30px !important;
  padding-top: 20px !important;
  border-top: 1px solid #e9ecef !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-button {
  padding: 12px 24px !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: all 0.3s ease !important;
  text-decoration: none !important;
  display: inline-block !important;
  text-align: center !important;
  min-width: 120px !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-next {
  background-color: #007cba !important;
  color: white !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-next:hover {
  background-color: #005a8b !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-previous {
  background-color: #6c757d !important;
  color: white !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-previous:hover {
  background-color: #545b62 !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-submit {
  background-color: #28a745 !important;
  color: white !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-submit:hover {
  background-color: #1e7e34 !important;
}

/* Progress Bar */
.quiz-modal-wrapper .qsm-quiz-container .qsm-progress-bar {
  background-color: #e9ecef !important;
  border-radius: 10px !important;
  height: 8px !important;
  margin-bottom: 20px !important;
  overflow: hidden !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-progress-bar .qsm-progress-fill {
  background-color: #007cba !important;
  height: 100% !important;
  transition: width 0.3s ease !important;
}

/* Quiz Results */
.quiz-modal-wrapper .qsm-quiz-container .qsm-results {
  text-align: center !important;
  padding: 30px 20px !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-results .qsm-score {
  font-size: 48px !important;
  font-weight: bold !important;
  color: #007cba !important;
  margin-bottom: 20px !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-results .qsm-message {
  font-size: 18px !important;
  color: #333 !important;
  margin-bottom: 20px !important;
  line-height: 1.5 !important;
}

/* Loading States */
.quiz-modal-wrapper .qsm-quiz-container .qsm-loading {
  text-align: center !important;
  padding: 40px 20px !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-loading .qsm-spinner {
  border: 4px solid #f3f3f3 !important;
  border-top: 4px solid #007cba !important;
  border-radius: 50% !important;
  width: 40px !important;
  height: 40px !important;
  animation: qsm-spin 1s linear infinite !important;
  margin: 0 auto 20px !important;
}

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

/* Responsive Design */
@media (max-width: 768px) {
  .swal2-popup.quiz-modal-popup {
    width: 95vw !important;
    margin: 10px auto !important;
  }

  .swal2-popup.quiz-modal-popup .swal2-title {
    font-size: 20px !important;
  }

  .quiz-modal-wrapper .qsm-quiz-container .qsm-answer {
    padding: 12px 16px !important;
    font-size: 14px !important;
  }

  .quiz-navigation {
    flex-direction: column !important;
    gap: 10px !important;
  }

  .quiz-navigation button {
    width: 100% !important;
    padding: 15px 20px !important;
    font-size: 16px !important;
  }

  .quiz-navigation-wrapper .quiz-navigation {
    flex-direction: column !important;
    gap: 10px !important;
  }

  .quiz-navigation-wrapper .quiz-navigation button {
    width: 100% !important;
    padding: 15px 20px !important;
    font-size: 16px !important;
  }

  .quiz-pagination-wrapper {
    padding: 15px !important;
    margin: 15px 0 !important;
  }

  .quiz-progress {
    font-size: 16px !important;
    margin-bottom: 15px !important;
  }

  .quiz-progress .current-question {
    font-size: 20px !important;
  }
}

@media (max-width: 480px) {
  .swal2-popup.quiz-modal-popup {
    width: 98vw !important;
    margin: 5px auto !important;
  }

  .quiz-modal-wrapper .qsm-quiz-container .qsm-question-container {
    padding: 15px !important;
  }

  .quiz-modal-wrapper .qsm-quiz-container .qsm-answer {
    padding: 10px 12px !important;
    font-size: 13px !important;
  }

  .quiz-navigation button {
    padding: 12px 16px !important;
    font-size: 14px !important;
    min-width: 100px !important;
  }

  .quiz-navigation-wrapper .quiz-navigation button {
    padding: 12px 16px !important;
    font-size: 14px !important;
    min-width: 100px !important;
  }
}

/* Accessibility Improvements */
.quiz-modal-wrapper .qsm-quiz-container .qsm-answer:focus {
  outline: 2px solid #007cba !important;
  outline-offset: 2px !important;
}

.quiz-modal-wrapper .qsm-quiz-container .qsm-button:focus,
.quiz-navigation button:focus {
  outline: 2px solid #007cba !important;
  outline-offset: 2px !important;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
  .quiz-modal-wrapper .qsm-quiz-container .qsm-answer {
    border-width: 3px !important;
  }

  .quiz-modal-wrapper .qsm-quiz-container .qsm-button,
  .quiz-navigation button {
    border: 2px solid currentColor !important;
  }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
  .quiz-modal-wrapper .qsm-quiz-container .qsm-answer,
  .quiz-modal-wrapper .qsm-quiz-container .qsm-button,
  .quiz-modal-wrapper .qsm-quiz-container .qsm-progress-bar .qsm-progress-fill,
  .quiz-navigation button {
    transition: none !important;
  }

  .quiz-modal-wrapper .qsm-quiz-container .qsm-answer:hover,
  .quiz-navigation button:hover:not(:disabled) {
    transform: none !important;
  }

  .quiz-modal-wrapper .qsm-quiz-container .qsm-button:hover {
    transform: none !important;
  }
}

/* Quiz Navigation Wrapper - Positioned below questions */
.quiz-navigation-wrapper {
  margin-top: 30px !important;
  padding-top: 20px !important;
  border-top: 1px solid #e9ecef !important;
  text-align: center !important;
}

.quiz-navigation-wrapper .quiz-navigation {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 15px !important;
  max-width: 100% !important;
  margin: 0 auto !important;
}

.quiz-navigation-wrapper .quiz-navigation button {
  padding: 12px 24px !important;
  border: none !important;
  border-radius: 6px !important;
  cursor: pointer !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: all 0.3s ease !important;
  text-decoration: none !important;
  display: inline-block !important;
  text-align: center !important;
  min-width: 120px !important;
}

.quiz-navigation-wrapper .quiz-navigation button:hover:not(:disabled) {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}

.quiz-navigation-wrapper .quiz-navigation button:disabled {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
}

.quiz-navigation-wrapper .quiz-navigation .prev-btn {
  background-color: #6c757d !important;
  color: white !important;
}

.quiz-navigation-wrapper .quiz-navigation .prev-btn:hover:not(:disabled) {
  background-color: #545b62 !important;
}

.quiz-navigation-wrapper .quiz-navigation .next-btn {
  background-color: #6a1f74 !important;
  color: white !important;
}

.quiz-navigation-wrapper .quiz-navigation .next-btn:hover:not(:disabled) {
  background-color: #6a1f74 !important;
}

.quiz-navigation-wrapper .quiz-navigation .submit-btn {
  background-color: #ee8f27 !important;
  color: white !important;
}

.quiz-navigation-wrapper .quiz-navigation .submit-btn:hover:not(:disabled) {
  background-color: #ee8f27 !important;
}

/* Hide all QSM submit buttons completely */
.quiz-modal-wrapper .qsm-submit,
.quiz-modal-wrapper .qsm-button[type="submit"],
.quiz-modal-wrapper input[type="submit"],
.quiz-modal-wrapper button[type="submit"],
.quiz-modal-wrapper .qsm-button.qsm-submit {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  position: absolute !important;
  left: -9999px !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
}

/* Ensure our custom submit button is visible when needed */
.quiz-modal-wrapper .quiz-navigation-wrapper .submit-btn {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: static !important;
  left: auto !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  clip: auto !important;
  margin: 0 10px !important;
  padding: 10px 20px !important;
  border: 1px solid #007cba !important;
}

/* Force submit button visibility on last question when all questions are answered */
.quiz-modal-wrapper .quiz-navigation-wrapper .submit-btn.show-submit {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: static !important;
  left: auto !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;
  clip: auto !important;
  margin: 0 10px !important;
  padding: 10px 20px !important;
  border: 1px solid #007cba !important;
  background-color: #28a745 !important;
  color: white !important;
  cursor: pointer !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  border-radius: 6px !important;
  transition: all 0.3s ease !important;
  z-index: 1000 !important;
}
.qsm-before-message p {
  display: none !important;
}

/* Additional fallback for submit button visibility */
.quiz-modal-wrapper
  .quiz-navigation-wrapper
  .submit-btn[style*="display: inline-block"] {
  display: inline-block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.quiz-modal-wrapper .quiz-navigation-wrapper .submit-btn.show-submit:hover {
  background-color: #1e7e34 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
}
