/**
 * Jproquest Common Styles CSS
 */
:root {
  --jproquest-primary-color: #5B47E0;
  --jproquest-primary-soft: #EFEEFE;
  --jproquest-primary-textcolor: #ffffff;
  --jproquest-secondary-color: #dbd4d7;
  --jproquest-secondary-textcolor: #272727;
  --jproquest-green-color: #008b20;
  --jproquest-red-color: #d50015;
  --jproquest-orange-color: #cb9800;
  --jproquest-blue-color: #0061c9;
  --jproquest-lightgreen-color: #d8ffe1;
  --jproquest-lightred-color: #ffe4e7;
  --jproquest-lightorange-color: #fff4d5;
  --jproquest-lightblue-color: #d3e8ff;
}

/**
 * Global styles
 */
.jproquest-btn {
  background-color: var(--jproquest-primary-color);
  color: var(--jproquest-primary-textcolor);
  border-radius: 10px;
}
.jproquest-btn:hover {
  background-color: var(--jproquest-secondary-color);
  color: var(--jproquest-secondary-textcolor);
}

.jproquest-hide {
  display: none !important;
}

/**
 * Popup styles
 */
.jproquest-modal-popup {
  position: fixed;
  inset: 0;
  z-index: 99999;
  -webkit-tap-highlight-color: transparent;
  animation: jproquest-fade-in .18s ease-out;
}
@keyframes jproquest-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

body.jproquest-popup-active {
  overflow: hidden;
  touch-action: none;
}

.jproquest-modal-container {
  position: relative;
  width: 100%;
  height: 100%;
  background-color: rgba(8, 20, 102, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.jproquest-modal-container .jproquest-modal-inner-area {
  display: flex;
  width: 100%;
  max-width: 450px;
  margin: 0 auto;
  align-items: center;
  justify-content: center;
}
.jproquest-modal-container .jproquest-modal-content-area {
  position: relative;
  width: 100%;
  max-height: calc(100dvh - 32px);
  border-radius: 14px;
  padding: 24px;
  background-color: #fff;
  box-shadow: 0 24px 60px -10px rgba(8, 20, 102, .35), 0 8px 20px rgba(0, 0, 0, .12);
  display: flex;
  flex-direction: column;
  animation: jproquest-pop-in .22s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes jproquest-pop-in {
  from { opacity: 0; transform: translateY(12px) scale(.96); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
.jproquest-modal-container .jproquest-modal-content-area .jproquest-modalinit-con {
  display: block;
  position: relative;
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
}
.jproquest-videocard-modal .jproquest-modalinit-con {
  min-height: 150px;
  display: flex;
  align-items: center;
}
.jproquest-videocard-modal .jproquest-modal-inner-area {
  max-width: 640px;
}

.jproquest-popup-hide {
  display: none;
}

/* Close button — high specificity + isolated width/min-width to prevent parent
   plugin (.jpro-default a.jobpro-popup-closebtn { width:100% }) from breaking it */
.jproquest-modal-popup .jproquest-modal-content-area > a.jproquest-popup-closebtn,
.jproquest-modal-popup .jproquest-modal-content-area > .jproquest-popup-closebtn,
a.jproquest-popup-closebtn.jobpro-popup-closebtn,
.jproquest-popup-closebtn {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  max-height: 40px !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: #ffffff !important;
  color: #34353C !important;
  font-size: 0 !important;
  line-height: 0 !important;
  text-decoration: none !important;
  z-index: 10 !important;
  border: 1px solid #e1e3ee !important;
  box-shadow: 0 4px 12px rgba(8, 20, 102, .15) !important;
  transition: background-color .2s ease, color .2s ease, transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .2s ease !important;
  -webkit-tap-highlight-color: transparent;
  flex: 0 0 40px !important;
  text-align: center !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}
.jproquest-popup-closebtn svg {
  width: 16px !important;
  height: 16px !important;
  display: block !important;
  pointer-events: none;
  fill: none !important;
}
.jproquest-popup-closebtn svg path {
  stroke: currentColor !important;
}
.jproquest-popup-closebtn:hover {
  background: #FF5050 !important;
  color: #fff !important;
  border-color: #FF5050 !important;
  transform: rotate(90deg) scale(1.05) !important;
  box-shadow: 0 6px 16px rgba(255, 80, 80, .35) !important;
}
.jproquest-popup-closebtn:focus,
.jproquest-popup-closebtn:active {
  background: #FF5050 !important;
  color: #fff !important;
  border-color: #FF5050 !important;
  outline: none !important;
}
/* Hide any leftover jbp-close icon if parent plugin font is loaded */
.jproquest-popup-closebtn .jbp-close,
.jproquest-popup-closebtn i { display: none !important; }

/**
 * Loader styles
 */
.jproquest-loder-con {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.768627451);
  z-index: 9;
}
.jproquest-loder-con .jproquest-loder-iner {
  display: flex;
  width: 40px;
  height: 100%;
  margin: 0 auto;
  align-items: center;
}
.jproquest-loder-con .jproquest-loder-iner .jproquest-loader {
  border: 7px solid #f3f3f3;
  border-radius: 50%;
  border-top: 7px solid var(--jproquest-primary-color);
  width: 40px;
  height: 40px;
  box-sizing: border-box; /* Safari */
  animation: jproquest-spin 1s linear infinite;
}
@keyframes jproquest-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.jproquest-mockquests-main-holdr .jproquest-loder-con {
    position: fixed;
}

.jproquest-confirmsg-con {
  font-size: 15px;
}
/*
 * Confirm Popup Buttons
 */
.confirm-popup-btns {
  display: flex;
  padding: 20px 0 0;
  width: 100%;
  justify-content: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.confirm-popup-btns button {
  padding: 5px 20px;
  font-size: 80%;
  border: none;
  cursor: pointer;
}
.confirm-popup-btns .jproquest-cancel-act {
  background-color: #d2d2d2;
  color: #222;
  border-radius: 2px;
}
.confirm-popup-btns .jproquest-delitm-btn {
  background-color: var(--jproquest-red-color);
  color: #fff;
  border-radius: 2px;
}

/*
 * Action message
 */
.jproquest-alert-msg {
  position: fixed;
  top: 20px;
  right: 30px;
  width: 220px;
  padding: 10px 15px;
  font-size: 85%;
  border: 1px solid;
  border-radius: 4px;
  background-color: var(--jproquest-lightorange-color);
  border-color: var(--jproquest-orange-color);
  color: var(--jproquest-orange-color);
  z-index: 100;
}
.jproquest-alert-msg.jproquest-alert-success {
  background-color: var(--jproquest-lightgreen-color);
  border-color: var(--jproquest-green-color);
  color: var(--jproquest-green-color);
}
.jproquest-alert-msg.jproquest-alert-danger {
  background-color: var(--jproquest-lightred-color);
  border-color: var(--jproquest-red-color);
  color: var(--jproquest-red-color);
}

.jproquest-danger-msg {
  display: inline-block;
  width: 100%;
  padding: 10px 15px;
  border: 1px solid;
  border-radius: 5px;
  font-size: 80%;
  background-color: var(--jproquest-lightred-color);
  border-color: var(--jproquest-red-color);
  color: var(--jproquest-red-color);
}

/*
 * Advance Form Fields
 */
.jproquest-form-switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 30px;
}
.jproquest-form-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.jproquest-btn-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  border-radius: 30px;
  transition: 0.4s;
}
.jproquest-btn-slider::before {
  position: absolute;
  content: "";
  height: 22px;
  width: 22px;
  left: 4px;
  bottom: 4px;
  background-color: #fff;
  border-radius: 50%;
  transition: 0.4s;
}

input:checked + .jproquest-btn-slider {
  background-color: var(--jproquest-blue-color);
}
input:checked + .jproquest-btn-slider::before {
  transform: translateX(26px);
}

.jproquest-form-imgfield {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.jproquest-form-imgfield .jproquest-field-imgcon img {
  max-width: 100%;
  max-height: 250px;
}
.jproquest-form-imgfield .jproquest-field-inputcon input {
  margin: 0;
  min-width: 350px;
}
.jproquest-form-imgfield .jproquest-field-btnscon {
  display: flex;
  gap: 10px;
}

.jproquest-formfields-con {
  position: relative;
}
.jproquest-formfields-con .jproquest-formseting-field {
  display: inline-block;
  position: relative;
  width: 100%;
  margin: 0 0 15px;
}
.jproquest-formfields-con .jproquest-formseting-field > label {
  display: inline-block;
  width: 100%;
  margin: 0 0 5px;
}
.jproquest-formfields-con .jproquest-formseting-field input[type="text"],
.jproquest-formfields-con .jproquest-formseting-field input[type="password"],
.jproquest-formfields-con .jproquest-formseting-field input[type="number"],
.jproquest-formfields-con .jproquest-formseting-field input[type="email"],
.jproquest-formfields-con .jproquest-formseting-field input[type="tel"] {
  display: inline-block;
  width: 100%;
  margin: 0;
  padding: 5px 10px;
  height: 42px;
}
.jproquest-formfields-con .jproquest-formseting-field input[type="text"]:focus,
.jproquest-formfields-con .jproquest-formseting-field input[type="password"]:focus,
.jproquest-formfields-con .jproquest-formseting-field input[type="number"]:focus,
.jproquest-formfields-con .jproquest-formseting-field input[type="email"]:focus,
.jproquest-formfields-con .jproquest-formseting-field input[type="tel"]:focus {
  box-shadow: 0 0 3px 0 #e1e1e1;
  --formfieldbordercolor: #e1e1e1;
}
.jproquest-formfields-con .jproquest-select-field select {
  background: none;
  padding: 5px 7px;
  width: 100%;
}
.jproquest-formfields-con .jproquest-formseting-field textarea {
  display: inline-block;
  width: 100%;
  height: 130px;
  margin: 0;
  padding: 5px 10px;
}
.jproquest-formfields-con .jproquest-formseting-field textarea:focus {
  box-shadow: 0 0 3px 0 #e1e1e1;
  --formfieldbordercolor: #e1e1e1;
}
.jproquest-formfields-con .jproquest-formseting-field label small {
  margin: 0 2px;
  font-size: 16px;
  color: var(--jproquest-red-color);
}
.jproquest-formfields-con .jproquest-formseting-field.jproquest-itmprice-field input {
  padding-left: 46px;
  font-size: 15px;
}
.jproquest-formseting-field.jproquest-itmprice-field .jproquest-curency-con {
  position: absolute;
  width: 50px;
  height: 42px;
  border-top-left-radius: 2px;
  border-bottom-left-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.jproquest-formseting-field.jproquest-itmprice-field .jproquest-curency-con span {
  line-height: 0;
  font-size: 15px;
}
.jproquest-formfields-con .jproquest-formseting-field .select2-container .select2-selection--single {
  height: 40px;
  border: 2px solid #dddddd;
  border-radius: 3px;
}
.jproquest-formfields-con .jproquest-formseting-field .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 38px;
}
.jproquest-formfields-con .jproquest-formseting-field .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 6px;
}
.select2-container--default .select2-selection--single {
  border-color: #e1e1e1;
}
.jproquest-passfield-holdr {
  display: inline-block;
  width: 100%;
  position: relative;
}
.jproquest-formfields-con .jproquest-passfield-holdr input {
  width: 100%;
  margin: 0;
  padding: 5px 40px 5px 10px;
}
.jproquest-formfields-con .jproquest-passfield-holdr input:focus {
  box-shadow: 0 0 3px 0 #e1e1e1;
  --formfieldbordercolor: #e1e1e1;
}
.jproquest-formfields-con .jproquest-passfield-holdr > span {
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.jproquest-formfields-con .jproquest-passfield-holdr > span i {
  font-size: 22px;
  color: #949494;
}
.jproquest-formfields-con .select2-container--default .select2-search--inline .select2-search__field {
  width: auto !important;
}
.jproquest-quiz-questions-holder {
  position: relative;
  width: 100%;
}
.jproquest-dshbrd-chngepass-formholdr {
  position: relative;
}

.quizpitms-grid {
    display: grid;
    width: 100%;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 30px;
    margin-bottom: 40px;
}

.quizpitm-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    position: relative;
    display: flex;
    flex-wrap: wrap;
}

.quizpitm-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 25px rgba(0, 0, 0, 0.15);
}

.quizpitm-image {
  display: flex;
  width: 100%;
  height: 200px;
  overflow: hidden;
  position: relative;
}

.jproquest-body-main .quizpitm-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    transition: transform 0.5s ease;
}

.quizpitm-card:hover .quizpitm-image img {
    transform: scale(1.05);
}

.quizpitm-content {
    padding: 15px 20px;
}
.jproquest-read-more {
  display: flex;
  width: 100%;
  background-color: #081466;
  color: #ffffff;
  padding: 18px 10px;
  line-height: 1;
  justify-content: center;
  align-items: center;
  align-self: flex-end;
}

.quizpitm-title {
    font-size: 1.4rem;
    margin: 0px;
    color: #2c3e50;
}

.quizpitm-title a {
    color: inherit;
    text-decoration: none;
    transition: color 0.3s ease;
}

.quizpitm-card:hover .quizpitm-title a {
    color: #081466;
}

.quizpitm-excerpt {
    color: #7f8c8d;
    margin: 0px;
    font-size: 0.95rem;
}

/* No quizpitms found message */
.no-quizpitms {
    text-align: center;
    padding: 40px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
    grid-column: 1 / -1;
}

.no-quizpitms h3 {
    color: #e74c3c;
    margin-bottom: 15px;
}

.jproquest-cstm-scrlbar::-webkit-scrollbar {
  display: inline-block;
  width: 10px;
}

.jproquest-cstm-scrlbar::-webkit-scrollbar-track {
  background: #e1e1e1;
  border-radius: 5px;
  margin: 5px;
}

.jproquest-cstm-scrlbar::-webkit-scrollbar-thumb {
  background: var(--jproquest-primary-color);
  border-radius: 5px;
}

.jproquest-cstm-scrlbar::-webkit-scrollbar-thumb:hover {
  background: var(--jproquest-secondary-textcolor);
}

.jproquest-user-quiz-modal .jproquest-modal-inner-area {
  max-width: 820px;
  width: 100%;
}

.jproquest-user-quiz-modal .jproquest-modal-container .jproquest-modal-content-area {
  height: min(720px, calc(100dvh - 24px));
  padding: 0;
  overflow: hidden;
}

.jproquest-question-ansr-areacon {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.jproquest-user-quiz-modal .jproquest-modal-container .jproquest-modal-content-area .jproquest-modalinit-con {
  overflow: hidden;
  height: 100%;
  padding: 0;
  display: flex;
  flex-direction: column;
}

/* The quiz inner shell becomes the scroll/sticky context */
.jproquest-user-quiz-modal .jproquest-questionare-maincon {
  display: flex;
  flex-direction: column;
  height: 100%;
  flex: 1 1 auto;
  min-height: 0;
  gap: 0;
}
.jproquest-user-quiz-modal .jproquest-quiz-questions-con {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  height: 100%;
  border-radius: 14px;
  box-shadow: none;
  overflow: hidden;
  background: #fff;
}
.jproquest-user-quiz-modal .jproquest-quiz-questions-holder {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
  position: relative;
}

/* Sticky header */
.jproquest-user-quiz-modal .jproquest-question-top-con {
  flex: 0 0 auto;
  position: sticky;
  top: 0;
  z-index: 4;
  background: #fff;
  border-bottom: 1px solid #E2E3EB;
  padding: 16px 56px 16px 20px; /* room for close button */
}

/* Scrollable middle */
.jproquest-user-quiz-modal .jproquest-question-markup-holdr {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding: 18px 20px;
  scrollbar-width: thin;
  scrollbar-color: var(--jproquest-primary-color, #081466) transparent;
}
.jproquest-user-quiz-modal .jproquest-question-markup-holdr::-webkit-scrollbar {
  width: 6px;
}
.jproquest-user-quiz-modal .jproquest-question-markup-holdr::-webkit-scrollbar-thumb {
  background: rgba(8, 20, 102, .25);
  border-radius: 4px;
}
.jproquest-user-quiz-modal .jproquest-question-markup-holdr::-webkit-scrollbar-thumb:hover {
  background: rgba(8, 20, 102, .55);
}

/* Sticky footer (Next/Prev/Skip + Submit + Continue) */
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap,
.jproquest-user-quiz-modal .jproquest-multiopts-submit-btncon,
.jproquest-user-quiz-modal .jproquest-shrtans-submit-btncon,
.jproquest-user-quiz-modal .jproquest-wlcomsg-btncon {
  flex: 0 0 auto;
  position: sticky;
  bottom: 0;
  z-index: 3;
  background: #fff;
  border-top: 1px solid #eef0fa;
  padding: 16px 24px;
  box-shadow: 0 -4px 16px -8px rgba(8, 20, 102, .08);
}

/* Skip on far left, Prev/Next group on far right (matching reference design) */
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a {
  border-radius: 10px !important;
  padding: 11px 18px !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  min-height: 42px !important;
  background: #fff !important;
  color: #1a1d2e !important;
  border: 1px solid #e7e9f3 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
  transition: background .2s, color .2s, border-color .2s, box-shadow .2s, transform .12s !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-question-skip-btn {
  background: #fbf2df !important;
  color: #7a5e00 !important;
  border: 1px solid #f0e4c0 !important;
  margin-right: auto !important;
  order: -1; /* push skip to leftmost */
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-question-skip-btn:hover {
  background: #f6e9c9 !important;
  border-color: #e6d39a !important;
  color: #5e4800 !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-question-skip-btn i {
  color: inherit !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-prevq-btn {
  background: #fff !important;
  color: #1a1d2e !important;
  border-color: #e7e9f3 !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-prevq-btn:hover {
  background: var(--jproquest-primary-soft, #EFEEFE) !important;
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  color: var(--jproquest-primary-color, #5B47E0) !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-nextq-btn {
  background: var(--jproquest-primary-color, #5B47E0) !important;
  color: #fff !important;
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  box-shadow: 0 4px 12px rgba(91, 71, 224, .35) !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-nextq-btn:hover {
  background: #4938cc !important;
  border-color: #4938cc !important;
  color: #fff !important;
  box-shadow: 0 6px 16px rgba(91, 71, 224, .45) !important;
}
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a:active { transform: translateY(1px); }
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a i { font-size: 12px !important; }

/* =========================================================================
 * NEXT button is disabled until the question is answered (or, for multi-select,
 * until at least one option is selected — then click Next to submit + advance).
 * ========================================================================= */
.jproquest-user-quiz-modal .jproquest-quiz-questions-holder:has(.jproquest-question-main-con:not(.quest-submitted)):not(.jpq-multi-ready):not(.jpq-text-ready) .jproquest-nextq-btn,
.jproquest-user-quiz-modal .jproquest-quiz-questions-holder:has(.jproquest-question-main-con:not(.quest-submitted)):not(.jpq-multi-ready):not(.jpq-text-ready) .jproquest-quest-next-sbtn {
  opacity: .45 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  box-shadow: none !important;
  filter: grayscale(.4);
}
.jproquest-user-quiz-modal .jproquest-quiz-questions-holder:has(.jproquest-question-main-con:not(.quest-submitted)):not(.jpq-multi-ready):not(.jpq-text-ready) .jproquest-question-nxtprv-wrap a.jproquest-nextq-btn {
  background: #c4c8d6 !important;
  border-color: #c4c8d6 !important;
  color: #fff !important;
}
/* Subtle attention hint for the Skip button when user clicks a disabled Next */
.jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-question-skip-btn.jpq-skip-hint {
  animation: jpq-skip-pulse .6s ease-in-out 2;
  background: #fff8ec !important;
  border-color: #f1c95b !important;
  color: #b45309 !important;
}
@keyframes jpq-skip-pulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 0 0 0 rgba(241, 201, 91, 0); }
  50%      { transform: translateY(-2px); box-shadow: 0 0 0 8px rgba(241, 201, 91, .25); }
}
.jproquest-user-quiz-modal .jproquest-multiopts-submit-btncon a,
.jproquest-user-quiz-modal .jproquest-shrtans-submit-btncon a,
.jproquest-user-quiz-modal .jproquest-wlcomsg-btncon a {
  display: inline-flex;
  width: 100%;
  background-color: var(--jproquest-primary-color, #5B47E0);
  color: #fff;
  padding: 13px 20px;
  border-radius: 10px;
  font-weight: 600;
  font-size: 15px;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  transition: background-color .2s, transform .15s, box-shadow .2s;
  min-height: 46px;
  box-shadow: 0 4px 12px rgba(91, 71, 224, .3);
}
.jproquest-user-quiz-modal .jproquest-multiopts-submit-btncon a:hover,
.jproquest-user-quiz-modal .jproquest-shrtans-submit-btncon a:hover,
.jproquest-user-quiz-modal .jproquest-wlcomsg-btncon a:hover {
  background-color: #4938cc;
  box-shadow: 0 6px 16px rgba(91, 71, 224, .4);
}
.jproquest-user-quiz-modal .jproquest-multiopts-submit-btncon a:active,
.jproquest-user-quiz-modal .jproquest-shrtans-submit-btncon a:active,
.jproquest-user-quiz-modal .jproquest-wlcomsg-btncon a:active {
  transform: translateY(1px);
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .quizpitms-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
        gap: 20px;
    }
    .jproquest-user-quiz-modal .jproquest-modal-container {
      padding: 8px;
    }
    .jproquest-user-quiz-modal .jproquest-modal-container .jproquest-modal-content-area {
      height: calc(100dvh - 16px);
      border-radius: 12px;
    }
    .jproquest-user-quiz-modal .jproquest-question-top-con {
      padding: 12px 50px 12px 14px;
    }
    .jproquest-user-quiz-modal .jproquest-question-markup-holdr {
      padding: 14px;
    }
    .jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap,
    .jproquest-user-quiz-modal .jproquest-multiopts-submit-btncon,
    .jproquest-user-quiz-modal .jproquest-shrtans-submit-btncon,
    .jproquest-user-quiz-modal .jproquest-wlcomsg-btncon {
      padding: 10px 14px env(safe-area-inset-bottom, 10px) 14px;
    }
}

@media (max-width: 576px) {
    .quizpitms-grid {
        grid-template-columns: 1fr;
    }
}

/**
 * Quiz Welcome / Instruction / Congratulations message
 * (previously had no/limited CSS)
 */
.jproquest-quiz-wlcomsg-holder {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 32px 28px 24px;
  gap: 18px;
}
.jproquest-quiz-wlcomsg-holder .jproquest-quiz-wlcomsg {
  max-width: 520px;
  margin: 0 auto;
}
.jproquest-quiz-wlcomsg-holder .jproquest-quiz-wlcomsg p {
  font-size: 16px;
  line-height: 1.6;
  color: #34353C;
  margin: 0 0 12px;
}
.jproquest-quiz-wlcomsg-holder .jproquest-quiz-wlcomsg p:last-child {
  margin-bottom: 0;
}
.jproquest-quiz-wlcomsg-holder::before {
  content: "\1F44B";
  font-size: 44px;
  line-height: 1;
}

/* =========================================================================
 * INSTRUCTION / MOCHU MESSAGE — between quiz steps
 * Two card variants: an info card (instructions) and a chat-bubble card (Mochu).
 * ========================================================================= */
.jproquest-quiz-instmsg-maincon {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: left;
  padding: 24px 24px 16px;
  gap: 16px;
}

/* ---- Common holdr base ---- */
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr {
  width: 100%;
  background: #fff;
  border: 1px solid #e7e9f3;
  border-radius: 14px;
  padding: 18px 20px;
  font-size: 15px;
  line-height: 1.6;
  color: #2c2f4a;
  box-shadow: 0 4px 12px rgba(8, 20, 102, .04);
  display: flex;
  align-items: flex-start;
  gap: 14px;
  animation: jpq-instmsg-in .35s cubic-bezier(.2,.9,.3,1.1) both;
}
@keyframes jpq-instmsg-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-content { flex: 1 1 auto; min-width: 0; }
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr p { margin: 0 0 10px; }
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr p:last-child { margin-bottom: 0; }
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr h2,
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr h3,
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr h4 {
  margin: 0 0 8px;
  color: #1a1d2e;
  font-weight: 700;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr ul,
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr ol {
  padding-left: 22px;
  margin: 6px 0;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr strong {
  color: #1a1d2e;
  font-weight: 700;
}

/* ---- Variant A: Info card (general instructions) ---- */
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--info {
  background: linear-gradient(135deg, #f7f8ff 0%, #eef0fe 100%);
  border-color: #d8ddf0;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--info .jproquest-quiz-instmsg-icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: #5b47e0;
  color: #fff;
  box-shadow: 0 4px 10px rgba(91, 71, 224, .35);
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--info strong {
  color: #5b47e0;
}

/* ---- Variant B: Mochu speech bubble ---- */
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--mochu {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 4px 0 0;
  align-items: flex-end;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-avatar {
  position: relative;
  flex: 0 0 auto;
  width: 84px;
  height: 84px;
  display: inline-flex;
  align-items: flex-end;
  justify-content: center;
  background: transparent;
  color: transparent;
  /* soft glow under Mochu */
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-avatar::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 4px;
  width: 60px;
  height: 14px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse, rgba(245, 158, 11, .35) 0%, rgba(245, 158, 11, 0) 70%);
  z-index: 0;
  pointer-events: none;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-avatar img {
  position: relative;
  z-index: 1;
  width: auto;
  height: 100%;
  max-height: 84px;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 4px 8px rgba(8, 20, 102, .18));
  animation: jpq-instmsg-bob 3.2s ease-in-out infinite;
  transform-origin: 50% 100%;
}
@keyframes jpq-instmsg-bob {
  0%, 100% { transform: translateY(0)    rotate(0); }
  25%      { transform: translateY(-3px) rotate(-2deg); }
  50%      { transform: translateY(-5px) rotate(0); }
  75%      { transform: translateY(-3px) rotate(2deg); }
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-bubble {
  position: relative;
  flex: 1 1 auto;
  min-width: 0;
  background: #fff;
  border: 1px solid #f0e4c0;
  border-radius: 14px 14px 14px 4px;
  padding: 14px 18px;
  box-shadow: 0 4px 14px rgba(245, 158, 11, .12);
  align-self: flex-end;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-bubble::before {
  content: "";
  position: absolute;
  bottom: 12px;
  left: -10px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 12px 8px 0;
  border-color: transparent #fff transparent transparent;
  filter: drop-shadow(-1px 0 0 #f0e4c0);
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-author {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #b45309;
  margin-bottom: 6px;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--mochu strong {
  color: #b45309;
}
.jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--mochu .jproquest-quiz-instmsg-content > div:first-child:has(strong) {
  /* Hide a stray "<div><strong>Mochu Msg:</strong></div>" if the admin pasted one
     into the message itself — we already render the author label */
  display: none;
}

@media (max-width: 480px) {
  .jproquest-quiz-instmsg-maincon { padding: 18px 16px 12px; gap: 12px; }
  .jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr { padding: 14px 16px; gap: 12px; }
  .jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-holdr--info .jproquest-quiz-instmsg-icon {
    width: 32px; height: 32px;
  }
  .jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-avatar { width: 64px; height: 64px; }
  .jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-avatar img { max-height: 64px; }
  .jproquest-quiz-instmsg-maincon .jproquest-quiz-instmsg-bubble { padding: 12px 14px; }
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon {
  display: flex !important;
  flex-wrap: wrap;
  gap: 12px;
  padding: 18px 0 4px !important;
  border: none !important;
  box-shadow: none !important;
  position: static !important;
  background: transparent !important;
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 1 1 140px;
  width: auto;
  background: linear-gradient(135deg, #5b47e0 0%, #4938cc 100%) !important;
  color: #fff !important;
  padding: 13px 22px !important;
  border-radius: 10px !important;
  border: 1px solid transparent !important;
  outline: none !important;
  outline-offset: 0 !important;
  text-decoration: none !important;
  text-transform: none !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  min-height: 46px !important;
  box-shadow: 0 6px 14px rgba(91, 71, 224, .35) !important;
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease !important;
  -webkit-tap-highlight-color: transparent;
  appearance: none !important;
  -webkit-appearance: none !important;
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a:hover {
  background: linear-gradient(135deg, #4938cc 0%, #3829b3 100%) !important;
  box-shadow: 0 8px 18px rgba(91, 71, 224, .45) !important;
  transform: translateY(-1px);
  border-color: transparent !important;
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a:focus,
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a:focus-visible {
  outline: none !important;
  border-color: transparent !important;
  box-shadow: 0 6px 14px rgba(91, 71, 224, .35), 0 0 0 3px rgba(91, 71, 224, .25) !important;
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a:active {
  transform: translateY(0);
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a.jproquest-prevq-btn {
  background: #fff !important;
  color: #1a1d2e !important;
  border: 1px solid #e7e9f3 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a.jproquest-prevq-btn:hover {
  background: #fafbff !important;
  border-color: #c4c8d6 !important;
  color: #1a1d2e !important;
  box-shadow: 0 4px 10px rgba(8, 20, 102, .08) !important;
}
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a.jproquest-prevq-btn:focus,
.jproquest-user-quiz-modal .jproquest-quiz-instmsg-maincon .jproquest-wlcomsg-btncon a.jproquest-prevq-btn:focus-visible {
  outline: none !important;
  border-color: #5b47e0 !important;
  box-shadow: 0 0 0 3px rgba(91, 71, 224, .15) !important;
}

/* =========================================================================
 * QUIZ COMPLETION SCREEN — trophy + cong message + redirect countdown
 * ========================================================================= */
.jproquest-quiz-complete-shell {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 32px 28px 24px;
  gap: 18px;
  background: radial-gradient(ellipse at top, rgba(91, 71, 224, .08) 0%, transparent 60%);
  position: relative;
  overflow: hidden;
}
/* Celebration block — trophy + confetti */
.jproquest-quiz-complete-celebrate {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 120px;
  margin-bottom: 4px;
}
.jproquest-quiz-complete-celebrate::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245, 158, 11, .25) 0%, transparent 65%);
  animation: jpq-cong-glow 2.4s ease-in-out infinite;
}
.jproquest-quiz-complete-trophy {
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 8px 16px rgba(245, 158, 11, .35));
  animation: jpq-cong-pop .6s cubic-bezier(.34, 1.56, .64, 1) both, jpq-cong-bob 3s ease-in-out 0.6s infinite;
}
@keyframes jpq-cong-pop {
  0%   { transform: scale(.4) rotate(-15deg); opacity: 0; }
  60%  { transform: scale(1.15) rotate(8deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}
@keyframes jpq-cong-bob {
  0%, 100% { transform: translateY(0) rotate(0); }
  50%      { transform: translateY(-4px) rotate(2deg); }
}
@keyframes jpq-cong-glow {
  0%, 100% { transform: scale(1);   opacity: .8; }
  50%      { transform: scale(1.15); opacity: 1; }
}
/* Confetti dots */
.jproquest-quiz-complete-confetti {
  position: absolute;
  inset: -20px;
  pointer-events: none;
  z-index: 1;
}
.jproquest-quiz-complete-confetti i {
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  opacity: 0;
  animation: jpq-cong-confetti 2.4s ease-out forwards;
}
.jproquest-quiz-complete-confetti i:nth-child(1)  { top:  10%; left: 10%; background: #5b47e0; animation-delay: .15s; --tx: -30px; --ty: -25px; --rot: -120deg; }
.jproquest-quiz-complete-confetti i:nth-child(2)  { top:   5%; left: 50%; background: #f59e0b; animation-delay: .25s; --tx:   0px; --ty: -40px; --rot:   80deg; }
.jproquest-quiz-complete-confetti i:nth-child(3)  { top:  10%; left: 88%; background: #47c392; animation-delay: .20s; --tx:  35px; --ty: -25px; --rot:  140deg; }
.jproquest-quiz-complete-confetti i:nth-child(4)  { top:  35%; left:  0%; background: #ff5050; animation-delay: .35s; --tx: -45px; --ty:   0px; --rot: -200deg; }
.jproquest-quiz-complete-confetti i:nth-child(5)  { top:  35%; left: 95%; background: #ffd86b; animation-delay: .35s; --tx:  45px; --ty:   0px; --rot:  200deg; }
.jproquest-quiz-complete-confetti i:nth-child(6)  { top:  55%; left:  5%; background: #5b47e0; animation-delay: .50s; --tx: -40px; --ty:  20px; --rot: -160deg; }
.jproquest-quiz-complete-confetti i:nth-child(7)  { top:  60%; left: 90%; background: #f59e0b; animation-delay: .50s; --tx:  40px; --ty:  20px; --rot:  160deg; }
.jproquest-quiz-complete-confetti i:nth-child(8)  { top:  85%; left: 15%; background: #47c392; animation-delay: .65s; --tx: -30px; --ty:  35px; --rot: -100deg; }
.jproquest-quiz-complete-confetti i:nth-child(9)  { top:  85%; left: 50%; background: #5b47e0; animation-delay: .70s; --tx:   0px; --ty:  40px; --rot:  -60deg; }
.jproquest-quiz-complete-confetti i:nth-child(10) { top:  85%; left: 80%; background: #ff5050; animation-delay: .65s; --tx:  30px; --ty:  35px; --rot:  100deg; }
.jproquest-quiz-complete-confetti i:nth-child(11) { top:  20%; left: 30%; background: #ffd86b; animation-delay: .80s; --tx: -15px; --ty: -15px; --rot:   40deg; }
.jproquest-quiz-complete-confetti i:nth-child(12) { top:  20%; left: 70%; background: #47c392; animation-delay: .80s; --tx:  15px; --ty: -15px; --rot:  -40deg; }
@keyframes jpq-cong-confetti {
  0%   { opacity: 0; transform: translate(0, 0) rotate(0); }
  20%  { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--tx), var(--ty)) rotate(var(--rot)); }
}

/* Cong message body (admin-supplied HTML) */
.jproquest-quiz-complete-body {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}
.jproquest-quiz-complete-body h1,
.jproquest-quiz-complete-body h2,
.jproquest-quiz-complete-body h3,
.jproquest-quiz-complete-body strong {
  display: block;
  margin: 4px 0 8px;
  color: #1a1d2e;
  font-weight: 800;
  letter-spacing: -.3px;
}
.jproquest-quiz-complete-body h1 { font-size: 26px; }
.jproquest-quiz-complete-body h2 { font-size: 22px; }
.jproquest-quiz-complete-body h3 { font-size: 18px; }
.jproquest-quiz-complete-body p {
  font-size: 15px;
  line-height: 1.6;
  color: #5b5e6e;
  margin: 0 0 8px;
}
.jproquest-quiz-complete-body p:last-child { margin-bottom: 0; }
.jproquest-quiz-complete-body img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

/* Legacy admin-rendered cong wrapper inside .jproquest-quiz-complete-body — strip its outer chrome */
.jproquest-quiz-complete-body .jproquest-quiz-cong-msgcon {
  padding: 0;
  background: transparent;
  display: block;
}
.jproquest-quiz-complete-body .jproquest-quiz-cong-msgcon::before { display: none; }

/* Redirect countdown row */
.jproquest-quiz-complete-redirect {
  margin-top: 12px;
  padding: 14px 18px;
  background: #fff;
  border: 1px solid #e7e9f3;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 4px 16px rgba(8, 20, 102, .06);
  width: 100%;
  max-width: 420px;
}
.jproquest-quiz-complete-countdown {
  position: relative;
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
}
.jproquest-quiz-complete-countdown svg { display: block; width: 36px; height: 36px; }
.jproquest-quiz-complete-countdown-fill { transition: stroke-dashoffset 1s linear; }
.jproquest-quiz-complete-countdown-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 13px;
  font-weight: 700;
  color: #5b47e0;
  line-height: 1;
}
.jproquest-quiz-complete-redirect-text {
  flex: 1 1 auto;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.jproquest-quiz-complete-redirect-text strong {
  font-size: 13px;
  font-weight: 700;
  color: #1a1d2e;
  line-height: 1.2;
}
.jproquest-quiz-complete-redirect-text small {
  font-size: 12px;
  color: #6a6e80;
  line-height: 1.2;
}
.jproquest-quiz-complete-redirect-text small .jproquest-quiz-complete-secs {
  font-weight: 700;
  color: #5b47e0;
  font-variant-numeric: tabular-nums;
}
.jproquest-quiz-complete-continue-btn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  background: #5b47e0;
  color: #fff !important;
  padding: 9px 16px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 13px;
  text-decoration: none !important;
  transition: background .2s, transform .12s, box-shadow .2s;
  box-shadow: 0 3px 10px rgba(91, 71, 224, .35);
  -webkit-tap-highlight-color: transparent;
}
.jproquest-quiz-complete-continue-btn:hover {
  background: #4938cc;
  box-shadow: 0 5px 14px rgba(91, 71, 224, .45);
}
.jproquest-quiz-complete-continue-btn:active { transform: translateY(1px); }

@media (max-width: 480px) {
  .jproquest-quiz-complete-shell { padding: 24px 18px 18px; gap: 14px; }
  .jproquest-quiz-complete-celebrate { width: 96px; height: 96px; }
  .jproquest-quiz-complete-trophy { width: 60px; height: 60px; }
  .jproquest-quiz-complete-body h1 { font-size: 22px; }
  .jproquest-quiz-complete-body h2 { font-size: 19px; }
  .jproquest-quiz-complete-redirect {
    flex-wrap: wrap;
    padding: 12px 14px;
    gap: 10px;
  }
  .jproquest-quiz-complete-redirect-text { flex: 1 1 calc(100% - 50px); }
  .jproquest-quiz-complete-continue-btn { flex: 1 1 100%; justify-content: center; }
}

/* Legacy plain cong-msgcon (for any code path that hasn't been routed through
   the new helper yet) — keep a basic celebratory look. */
.jproquest-quiz-cong-msgcon {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 36px 28px;
  gap: 14px;
}
.jproquest-quiz-cong-msgcon h1,
.jproquest-quiz-cong-msgcon h2,
.jproquest-quiz-cong-msgcon h3 {
  margin: 4px 0 0;
  color: var(--jproquest-primary-color, #5b47e0);
  font-size: 22px;
}
.jproquest-quiz-cong-msgcon p {
  font-size: 15px;
  line-height: 1.6;
  color: #5b5e6e;
  margin: 0;
  max-width: 460px;
}

/**
 * Audio recorder (in-question)
 */
.jproquest-media-question-areacon {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.jproquest-media-question-areacon #jobpro-chat-file-progressBar {
  border-radius: 4px;
  text-align: center;
  font-size: 12px;
  line-height: 18px;
  height: 18px;
  transition: width .2s linear;
}
/* Recorder card UI is defined further down; legacy plain-button + popup styles
 * for .jobpro-quiz-recrdsend-button / .jobpro-audio-popup-wrap removed since the
 * markup now uses .jproquest-recorder-card / .jproquest-recorder-mainbtn. */

/**
 * Video recorder (in-question)
 */
.jobpro-quest-videorec-holder {
  width: 100%;
}
.jobpro-quest-videorec-holder .jobpro-chat-video-rec {
  width: 100%;
  background: #0a0d2e;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
}
.jobpro-quest-videorec-holder #jobpro_videoElement {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  display: block !important;
  background: #000 !important;
  object-fit: cover !important;
}
.jobpro-chat-video-rec-inn {
  padding: 14px;
  background: rgba(8, 20, 102, .9);
  color: #fff;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.jobpro-chat-video-rectme {
  display: flex;
  align-items: center;
  gap: 12px;
}
.jobpro-chat-video-time-txt {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 14px;
  color: #fff;
  white-space: nowrap;
}
.jobpro-chat-video-rectme progress {
  flex: 1 1 auto;
  height: 6px;
  width: 100%;
  border: none;
  border-radius: 3px;
  appearance: none;
  -webkit-appearance: none;
  background: rgba(255, 255, 255, .15);
}
.jobpro-chat-video-rectme progress::-webkit-progress-bar {
  background: rgba(255, 255, 255, .15);
  border-radius: 3px;
}
.jobpro-chat-video-rectme progress::-webkit-progress-value {
  background: linear-gradient(90deg, #FF5050, #ff7e7e);
  border-radius: 3px;
}
.jobpro-chat-video-rectme progress::-moz-progress-bar {
  background: linear-gradient(90deg, #FF5050, #ff7e7e);
  border-radius: 3px;
}
.jobpro-chat-video-btns {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.jobpro-chat-video-play {
  position: relative;
  width: 60px;
  height: 60px;
}
.jobpro-start-recording-btn,
.jobpro-stop-recording-btn {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 4px solid #fff;
  background: #FF5050;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 18px;
  position: relative;
  transition: transform .15s, background .2s;
}
.jobpro-start-recording-btn:hover,
.jobpro-stop-recording-btn:hover { background: #e93f3f; }
.jobpro-start-recording-btn:active,
.jobpro-stop-recording-btn:active { transform: scale(.95); }
.jobpro-stop-recording-btn.hidden,
.jobpro-start-recording-btn.hidden { display: none; }
#stopRecordingProgress {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 60px;
  height: 60px;
  pointer-events: none;
}
#stopRecordingProgress circle {
  fill: none;
  stroke: #fff;
  stroke-width: 3;
  transform: rotate(-90deg);
  transform-origin: 50% 50%;
  transition: stroke-dashoffset 1s linear;
}
.jobpro-send-record-btncon button,
.jobpro-send-record-btncon .jobpro-has-bg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #47C392;
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  min-height: 40px;
  transition: background .2s;
}
.jobpro-send-record-btncon button:hover,
.jobpro-send-record-btncon .jobpro-has-bg:hover { background: #2fa776; }

/* Hide the leftover stop button from the static template */
.jobpro-chat-video-btns > button.jobpro-stop-recording-btn[style*="visibility:hidden"] { display: none !important; }

/* Recorded media preview chip */
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm {
  display: inline-flex;
  width: 100%;
  background: #f5f7ff;
  border: 1px solid #d8ddf0;
  border-radius: 12px;
  padding: 10px 12px;
  margin-top: 8px;
}
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm audio,
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm video {
  max-width: 100%;
  width: 100%;
  border-radius: 8px;
  display: block;
}
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm audio { height: 40px; }

@media (max-height: 750px) {
  .jproquest-user-quiz-modal .jproquest-modal-container .jproquest-modal-content-area {
    height: calc(100dvh - 24px);
  }
}

/* =========================================================================
 * MODERN QUIZ CARD — header, progress bar, answer cards, timer chip,
 * audio + video recorders. Mobile-first. No layout-affecting transitions.
 * ========================================================================= */

/* Question top header — 3-column layout: timer | progresscell | nav */
.jproquest-user-quiz-modal .jproquest-question-top-con {
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  padding: 18px 100px 18px 18px !important; /* right padding leaves room for absolute close button */
  background: #fff !important;
  border-bottom: 1px solid #eef0fa !important;
  flex-wrap: nowrap !important;
}
.jproquest-quest-timercell {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 60px;
}
.jproquest-quest-timercell:empty { display: none; }
.jproquest-quest-progresscell {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}
.jproquest-quest-numb-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.jproquest-quest-numb-label {
  font-size: 11px;
  font-weight: 700;
  color: #8a8fa3;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  line-height: 1;
}
.jproquest-quest-numb-badge {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  background: transparent;
  color: #1a1d2e;
  padding: 0;
  border-radius: 0;
  font-size: 18px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.2px;
  box-shadow: none;
}
.jproquest-quest-numb-badge .jproquest-quest-numb-current { font-size: 18px; color: #1a1d2e; }
.jproquest-quest-numb-badge .jproquest-quest-numb-sep { color: #c4c8d6; margin: 0 2px; font-weight: 600; }
.jproquest-quest-numb-badge .jproquest-quest-numb-total { color: #8a8fa3; font-weight: 700; }

.jproquest-quizeslctn-rtwrcon {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 5px 11px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .4px !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  color: #fff !important;
}
.jproquest-quizeslctn-rtwrcon.jproquest-quizeslctn-right { background: #47C392 !important; }
.jproquest-quizeslctn-rtwrcon.jproquest-quizeslctn-wrong { background: #FF5050 !important; }
.jproquest-quizeslctn-rtwrcon.jproquest-quizeslctn-skip  { background: #EBCA28 !important; color: #1a1a1a !important; }
.jproquest-quizeslctn-rtwrcon svg { display: block; }

/* Prev / Next as square cards */
.jproquest-user-quiz-modal .jproquest-quest-totl-con {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: 0;
}
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-prev-sbtn,
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-next-sbtn {
  width: 40px !important; height: 40px !important;
  border-radius: 10px !important;
  background: #fff !important;
  color: #1a1d2e !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  border: 1px solid #e7e9f3 !important;
  transition: background-color .2s, color .2s, transform .15s, box-shadow .2s, border-color .2s;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
  flex: 0 0 40px !important;
  padding: 0 !important;
  min-width: 40px !important;
}
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-prev-sbtn:hover,
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-next-sbtn:hover {
  background: var(--jproquest-primary-color, #5B47E0) !important;
  color: #fff !important;
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  box-shadow: 0 4px 10px rgba(91, 71, 224, .25) !important;
}
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-prev-sbtn:active,
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-next-sbtn:active {
  transform: scale(.94);
}
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-prev-sbtn svg,
.jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-next-sbtn svg {
  display: block;
  width: 16px; height: 16px;
}

/* Segmented progress bar */
.jproquest-quest-progress-bar {
  position: relative;
  display: flex;
  align-items: center;
  gap: 4px;
  width: 100%;
  height: 6px;
  background: transparent;
  overflow: visible;
  flex: 0 0 auto;
}
.jproquest-quest-progress-seg {
  flex: 1 1 0;
  min-width: 0;
  height: 6px;
  background: #eaecf6;
  border-radius: 3px;
  transition: background-color .3s ease;
}
.jproquest-quest-progress-seg.is-filled {
  background: var(--jproquest-primary-color, #5B47E0);
}

/* Question text */
.jproquest-user-quiz-modal .jproquest-question-main-con {
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  width: 100%;
}
.jproquest-user-quiz-modal .jproquest-question-txt-str {
  width: 100%;
  margin: 0 !important;
  text-decoration: none !important;
  border: none !important;
  border-bottom: none !important;
}
.jproquest-user-quiz-modal .jproquest-question-txt-str strong {
  display: block;
  font-size: 17px;
  line-height: 1.5;
  color: #1a1d2e;
  font-weight: 600;
  margin: 0 0 0 0;
  text-decoration: none !important;
  border: none !important;
  border-bottom: none !important;
}
.jproquest-user-quiz-modal .jproquest-question-txt-str.jproquest-question-txt-str--has-tts {
  gap: 12px !important;
}
/* Hide explanation completely if it sneaks through with empty content */
.jproquest-user-quiz-modal .jproquest-explanation .explanation-text:empty,
.jproquest-user-quiz-modal .jproquest-explanation:not(:has(*:not(:empty))) {
  display: none !important;
}

/* Answer cards (lettered) */
.jproquest-user-quiz-modal .jproquest-question-ansrs-list {
  border: none !important;
  background: transparent !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  border-radius: 0 !important;
  overflow: visible !important;
}
/* Multi-select hint span (rendered by PHP, translatable) */
.jproquest-multiopts-hint {
  display: block;
  width: 100%;
  padding: 8px 12px;
  background: #f3f4fb;
  color: var(--jproquest-primary-color, #5b47e0);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
  border-radius: 8px;
  text-align: center;
  margin: 0 0 4px;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm {
  position: relative;
  display: flex !important;
  width: 100% !important;
  align-items: center !important;
  gap: 18px !important;
  padding: 18px 22px !important;
  min-height: 70px !important;
  background: #fff !important;
  border: 1px solid #e7e9f3 !important;
  border-radius: 14px !important;
  cursor: pointer !important;
  transition: border-color .18s, background-color .18s, box-shadow .18s, transform .12s;
  -webkit-tap-highlight-color: transparent;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm:nth-child(odd),
.jproquest-user-quiz-modal .jproquest-question-ansr-itm:nth-child(even) {
  background: #fff !important;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm:hover {
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  background: #fafaff !important;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm:active {
  transform: scale(.995);
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.slected-ans {
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  background: #fafaff !important;
  box-shadow: 0 0 0 1px var(--jproquest-primary-color, #5B47E0), 0 4px 12px rgba(91, 71, 224, .12);
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-correct-answer {
  border-color: #47C392 !important;
  background: #f0fbf6 !important;
  box-shadow: 0 0 0 1px #47C392, 0 4px 12px rgba(71, 195, 146, .15);
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-wrong-answer {
  border-color: #FF5050 !important;
  background: #fff5f5 !important;
  box-shadow: 0 0 0 1px #FF5050, 0 4px 12px rgba(255, 80, 80, .15);
}
.jproquest-ansritm-letter {
  flex: 0 0 auto;
  width: 38px; height: 38px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--jproquest-primary-soft, #EFEEFE);
  color: var(--jproquest-primary-color, #5B47E0);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0;
  border: none;
  transition: background .2s, color .2s;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm:hover .jproquest-ansritm-letter,
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.slected-ans .jproquest-ansritm-letter {
  background: var(--jproquest-primary-color, #5B47E0);
  color: #fff;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-correct-answer .jproquest-ansritm-letter {
  background: #47C392;
  color: #fff;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-wrong-answer .jproquest-ansritm-letter {
  background: #FF5050;
  color: #fff;
}
.jproquest-user-quiz-modal .jproquest-ansritm-text {
  flex: 1 1 auto !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
  color: #2c2f4a !important;
  font-weight: 500 !important;
}
.jproquest-user-quiz-modal .jproquest-ansritm-circle {
  flex: 0 0 auto;
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1.5px solid #c4c8d6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: border-color .2s, background .2s, border-radius .2s;
}
/* Multi-select questions use rounded SQUARE (checkbox style) instead of round (radio) */
.jproquest-user-quiz-modal .jproquest-question-ansrs-list.is-multi .jproquest-ansritm-circle,
.jproquest-user-quiz-modal .jproquest-question-main-con.multi-ansrs-enabled .jproquest-ansritm-circle {
  border-radius: 6px;
}
.jproquest-user-quiz-modal .jproquest-ansritm-circle i { font-size: 0 !important; line-height: 1; }

/* SELECTED — single (round dot) */
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.slected-ans .jproquest-ansritm-circle {
  border-color: var(--jproquest-primary-color, #5B47E0);
  background: var(--jproquest-primary-color, #5B47E0);
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.slected-ans .jproquest-ansritm-circle::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #fff;
}
/* SELECTED — multi (square checkmark) overrides the dot */
.jproquest-user-quiz-modal .jproquest-question-ansrs-list.is-multi .jproquest-question-ansr-itm.slected-ans .jproquest-ansritm-circle::before,
.jproquest-user-quiz-modal .jproquest-question-main-con.multi-ansrs-enabled .jproquest-question-ansr-itm.slected-ans .jproquest-ansritm-circle::before {
  content: "";
  width: 9px;
  height: 5px;
  border-radius: 0;
  background: transparent;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translate(1px, -1px);
}
.jproquest-user-quiz-modal .jproquest-question-ansrs-list.is-multi .jproquest-question-ansr-itm.jproquest-correct-answer .jproquest-ansritm-circle,
.jproquest-user-quiz-modal .jproquest-question-ansrs-list.is-multi .jproquest-question-ansr-itm.jproquest-wrong-answer .jproquest-ansritm-circle {
  border-radius: 6px;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-correct-answer .jproquest-ansritm-circle {
  border-color: #47C392;
  background: #47C392;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-correct-answer .jproquest-ansritm-circle::before {
  content: "";
  width: 9px; height: 5px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg) translate(1px, -1px);
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-wrong-answer .jproquest-ansritm-circle {
  border-color: #FF5050;
  background: #FF5050;
}
.jproquest-user-quiz-modal .jproquest-question-ansr-itm.jproquest-wrong-answer .jproquest-ansritm-circle::before {
  content: "";
  width: 10px; height: 10px;
  background: linear-gradient(45deg, transparent 44%, #fff 44%, #fff 56%, transparent 56%),
              linear-gradient(135deg, transparent 44%, #fff 44%, #fff 56%, transparent 56%);
}

/* =========================================================================
 * TIMER — card with hourglass icon + arc ring + 2-line text.
 * ========================================================================= */
.jproquest-timer-card {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 8px 16px 8px 8px;
  background: #fff;
  border: 1px solid #e7e9f3;
  border-radius: 14px;
  color: var(--jproquest-primary-color, #5B47E0);
  box-shadow: 0 2px 8px rgba(91, 71, 224, .08);
  transition: border-color .25s, box-shadow .25s, color .25s;
  width: max-content;
}
.jproquest-timer-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  flex: 0 0 auto;
  color: var(--jproquest-primary-color, #5B47E0);
}
.jproquest-timer-icon > svg:not(.jproquest-timer-arc) {
  position: relative;
  z-index: 2;
}
.jproquest-timer-arc {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.jproquest-timer-arc-fill {
  transition: stroke-dashoffset 1s linear, stroke .3s ease;
}
.jproquest-timer-info {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1;
}
.jproquest-timer-value {
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 18px;
  font-weight: 800;
  color: #1a1d2e;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.2px;
  transition: color .25s ease;
}
.jproquest-timer-label {
  font-family: "Reddit Sans", system-ui, sans-serif;
  font-size: 10px;
  font-weight: 700;
  color: #8a8fa3;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  transition: color .25s ease;
}
.jproquest-timer-card.is-warning { color: #f59e0b; border-color: #f1c95b; }
.jproquest-timer-card.is-warning .jproquest-timer-value { color: #b45309; }
.jproquest-timer-card.is-danger {
  color: #FF5050;
  border-color: #FF5050;
  animation: jproquest-timer-pulse 1.2s ease-in-out infinite;
}
.jproquest-timer-card.is-danger .jproquest-timer-value,
.jproquest-timer-card.is-danger .jproquest-timer-label { color: #FF5050; }
.jproquest-timer-card.is-expired {
  background: #FF5050;
  border-color: #FF5050;
  color: #fff;
  animation: none;
}
.jproquest-timer-card.is-expired .jproquest-timer-value,
.jproquest-timer-card.is-expired .jproquest-timer-label { color: #fff; }
@keyframes jproquest-timer-pulse {
  0%, 100% { box-shadow: 0 2px 8px rgba(255, 80, 80, .25); }
  50%      { box-shadow: 0 4px 14px rgba(255, 80, 80, .45); }
}

/* When timer is rendered before the question header (initial paint), keep it
   compact in the source flow until JS moves it into the timer cell */
.jproquest-user-quiz-modal .jproquest-modalinit-con > .jproquest-demotime-countdown-con {
  display: flex !important;
  padding: 14px 18px !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  width: 100% !important;
  justify-content: flex-start !important;
}

/* =========================================================================
 * RECORDER CARDS (audio + video)
 * ========================================================================= */
.jproquest-recorder-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  padding: 22px;
  background: linear-gradient(155deg, #f5f7ff 0%, #ecf0fe 100%);
  border: 1px solid #d8ddf0;
  border-radius: 16px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.6), 0 8px 24px -10px rgba(8, 20, 102, .15);
}

/* --- AUDIO --- */
.jproquest-recorder-audio .jproquest-recorder-stage {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 140px;
}
button.jproquest-recorder-mainbtn,
.jproquest-recorder-mainbtn {
  position: relative !important;
  width: 88px !important;
  height: 88px !important;
  min-width: 88px !important;
  max-width: 88px !important;
  min-height: 88px !important;
  max-height: 88px !important;
  border-radius: 50% !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: linear-gradient(135deg, var(--jproquest-primary-color, #5B47E0) 0%, #4938cc 100%) !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  box-shadow: 0 10px 30px -8px rgba(91, 71, 224, .55) !important;
  transition: transform .2s, box-shadow .2s, background .2s !important;
  -webkit-tap-highlight-color: transparent;
  z-index: 2;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  outline: none !important;
  flex: 0 0 88px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
  font-size: 0 !important;
  line-height: 0 !important;
}
.jproquest-recorder-mainbtn:hover { transform: scale(1.04); box-shadow: 0 12px 36px -8px rgba(91, 71, 224, .7) !important; }
.jproquest-recorder-mainbtn:active { transform: scale(.96); }
.jproquest-recorder-mainbtn .jproquest-recorder-mic-svg {
  display: block !important;
  width: 32px !important;
  height: 32px !important;
  color: #fff;
}
/* Hide any stray icon font glyph that parent plugin may try to inject inside the button */
.jproquest-recorder-mainbtn .jbp-icon,
.jproquest-recorder-mainbtn i { display: none !important; }

/* Recording state */
.jproquest-recorder-card.is-recording .jproquest-recorder-mainbtn {
  background: linear-gradient(135deg, #FF5050 0%, #ff7676 100%) !important;
  box-shadow: 0 0 0 0 rgba(255, 80, 80, .55) !important;
  animation: jproquest-rec-pulse 1.4s ease-out infinite;
}
@keyframes jproquest-rec-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(255, 80, 80, .6); }
  70%  { box-shadow: 0 0 0 24px rgba(255, 80, 80, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 80, 80, 0); }
}
/* Replace mic SVG with stop square when recording */
.jproquest-recorder-card.is-recording .jproquest-recorder-mainbtn .jproquest-recorder-mic-svg { display: none !important; }
.jproquest-recorder-card.is-recording .jproquest-recorder-mainbtn::before {
  content: "";
  width: 26px; height: 26px;
  border-radius: 4px;
  background: #fff;
}
.jproquest-recorder-card.is-ready-submit .jproquest-recorder-mainbtn {
  background: linear-gradient(135deg, #47C392 0%, #2fa776 100%) !important;
  box-shadow: 0 10px 30px -8px rgba(71, 195, 146, .55) !important;
}

/* Waveform */
.jproquest-recorder-wave {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  pointer-events: none;
  opacity: .35;
}
.jproquest-recorder-wave span {
  display: inline-block;
  width: 4px;
  height: 18px;
  background: var(--jproquest-primary-color, #081466);
  border-radius: 2px;
  transform-origin: center;
}
.jproquest-recorder-card.is-recording .jproquest-recorder-wave {
  opacity: 1;
}
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span {
  background: #FF5050;
  animation: jproquest-wave 1s ease-in-out infinite;
}
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(1) { animation-delay: -.9s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(2) { animation-delay: -.8s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(3) { animation-delay: -.7s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(4) { animation-delay: -.6s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(5) { animation-delay: -.5s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(6) { animation-delay: -.4s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(7) { animation-delay: -.3s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(8) { animation-delay: -.2s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(9) { animation-delay: -.1s; }
.jproquest-recorder-card.is-recording .jproquest-recorder-wave span:nth-child(10){ animation-delay: 0s; }
@keyframes jproquest-wave {
  0%, 100% { transform: scaleY(.4); }
  50%      { transform: scaleY(2.2); }
}

.jproquest-recorder-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.jproquest-recorder-status {
  font-size: 13px;
  color: #5b5e6e;
  font-weight: 500;
  flex: 1 1 auto;
}
.jproquest-recorder-card.is-recording .jproquest-recorder-status { color: #FF5050; font-weight: 600; }
.jproquest-recorder-card.is-ready-submit .jproquest-recorder-status { color: #2fa776; font-weight: 600; }

.jproquest-recorder-timer {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 14px;
  font-weight: 700;
  color: var(--jproquest-primary-color, #081466);
  font-variant-numeric: tabular-nums;
}
.jproquest-recorder-timer-sep { opacity: .5; margin: 0 1px; }
.jproquest-recorder-timer .jobpro-audio-max { color: #7B7E8F; font-weight: 500; }

.jproquest-recorder-progress {
  width: 100%;
  height: 6px;
  border-radius: 4px;
  border: none;
  appearance: none;
  -webkit-appearance: none;
  background: rgba(8, 20, 102, .08);
  overflow: hidden;
}
.jproquest-recorder-progress::-webkit-progress-bar { background: rgba(8, 20, 102, .08); border-radius: 4px; }
.jproquest-recorder-progress::-webkit-progress-value {
  background: linear-gradient(90deg, var(--jproquest-primary-color, #081466) 0%, #2138b8 100%);
  border-radius: 4px;
  transition: width .3s linear;
}
.jproquest-recorder-progress::-moz-progress-bar {
  background: linear-gradient(90deg, var(--jproquest-primary-color, #081466) 0%, #2138b8 100%);
  border-radius: 4px;
}
.jproquest-recorder-card.is-recording .jproquest-recorder-progress::-webkit-progress-value {
  background: linear-gradient(90deg, #FF5050 0%, #ff8585 100%);
}
.jproquest-recorder-card.is-recording .jproquest-recorder-progress::-moz-progress-bar {
  background: linear-gradient(90deg, #FF5050 0%, #ff8585 100%);
}

.jproquest-recorder-actions {
  display: flex !important;
  gap: 10px;
  align-items: center;
  justify-content: stretch;
  width: 100%;
}
button.jproquest-recorder-cancel,
.jproquest-recorder-cancel,
a.jproquest-recorder-submit,
.jproquest-recorder-submit {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 11px 20px !important;
  border-radius: 10px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  border: 1px solid transparent !important;
  text-decoration: none !important;
  min-height: 44px !important;
  height: 44px !important;
  line-height: 1 !important;
  transition: background .2s, color .2s, border-color .2s, box-shadow .2s, transform .12s !important;
  -webkit-tap-highlight-color: transparent;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  outline: none !important;
  font-family: inherit !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin: 0 !important;
}
.jproquest-recorder-cancel {
  background: #fff !important;
  color: #6a6e80 !important;
  border-color: #e1e3ee !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 110px;
}
.jproquest-recorder-cancel[disabled],
.jproquest-recorder-cancel:disabled {
  opacity: .45 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  background: #fff !important;
  color: #6a6e80 !important;
  border-color: #e1e3ee !important;
}
.jproquest-recorder-cancel:not(:disabled):hover { background: #ffecec !important; color: #FF5050 !important; border-color: #FF5050 !important; }
.jproquest-recorder-submit {
  background: linear-gradient(135deg, var(--jproquest-primary-color, #5B47E0) 0%, #4938cc 100%) !important;
  color: #fff !important;
  flex: 1 1 auto !important;
  pointer-events: none !important;
  opacity: .45 !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
}
.jproquest-recorder-card.is-ready-submit .jproquest-recorder-submit {
  pointer-events: auto !important;
  opacity: 1 !important;
  background: linear-gradient(135deg, #47C392 0%, #2fa776 100%) !important;
}
.jproquest-recorder-card.is-ready-submit .jproquest-recorder-submit:hover {
  box-shadow: 0 6px 16px rgba(71, 195, 146, .35) !important;
}
.jproquest-recorder-submit:active { transform: translateY(1px); }
.jproquest-recorder-submit svg,
.jproquest-recorder-cancel svg { display: block !important; flex: 0 0 auto; }

/* --- VIDEO --- */
.jproquest-recorder-video {
  padding: 0;
  overflow: hidden;
  background: linear-gradient(155deg, #1a1d2e 0%, #0a0d2e 100%);
  border-color: #0a0d2e;
}
.jproquest-recorder-empty {
  padding: 32px 20px;
  text-align: center;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.jproquest-recorder-empty-icon {
  display: inline-flex;
  width: 80px; height: 80px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, .06);
  color: #fff;
  border: 1px dashed rgba(255, 255, 255, .25);
}
.jproquest-recorder-empty-txt {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: rgba(255, 255, 255, .85);
  max-width: 320px;
}
.jproquest-recorder-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background: linear-gradient(135deg, #FF5050 0%, #ff7676 100%);
  color: #fff;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 8px 24px -4px rgba(255, 80, 80, .55);
  transition: transform .15s, box-shadow .2s;
  -webkit-tap-highlight-color: transparent;
}
.jproquest-recorder-cta:hover { transform: translateY(-1px); box-shadow: 0 12px 28px -4px rgba(255, 80, 80, .65); color: #fff; }
.jproquest-recorder-cta:active { transform: translateY(0); }
.jproquest-recorder-cta .jbp-icon { font-size: 18px; line-height: 1; color: inherit; }
.jproquest-recorder-hint { color: rgba(255, 255, 255, .55); font-size: 12px; }

.jproquest-recorder-card.is-live .jobpro-quest-videorec-holder { display: block; }
.jproquest-recorder-card .jobpro-quest-videorec-holder:empty { display: none; }
.jobpro-quest-videorec-holder .jobpro-chat-video-rec {
  width: 100%;
  border-radius: 0;
  position: relative;
}
.jobpro-quest-videorec-holder #jobpro_videoElement {
  width: 100% !important;
  height: auto !important;
  display: block;
  background: #000;
  aspect-ratio: 16 / 9;
}
.jproquest-recorder-card.is-recording .jobpro-quest-videorec-holder::before {
  content: "REC";
  position: absolute;
  top: 12px; left: 12px;
  background: #FF5050;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .8px;
  padding: 4px 8px;
  border-radius: 4px;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.jproquest-recorder-card.is-recording .jobpro-quest-videorec-holder::after {
  content: "";
  position: absolute;
  top: 18px; left: 18px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #fff;
  animation: jproquest-rec-blink 1.2s ease-in-out infinite;
  z-index: 6;
}
@keyframes jproquest-rec-blink {
  0%, 100% { opacity: 0; }
  50% { opacity: 1; }
}

.jobpro-chat-video-rec-inn {
  padding: 14px 16px;
  background: rgba(8, 20, 102, .92);
  color: #fff;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.jobpro-chat-video-rectme {
  display: flex;
  align-items: center;
  gap: 12px;
}
.jobpro-chat-video-time-txt {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 13px;
  font-weight: 700;
  white-space: nowrap;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.jobpro-chat-video-rectme progress {
  flex: 1 1 auto;
  height: 6px;
  border: none;
  border-radius: 3px;
  appearance: none;
  -webkit-appearance: none;
  background: rgba(255, 255, 255, .12);
}
.jobpro-chat-video-rectme progress::-webkit-progress-bar { background: rgba(255, 255, 255, .12); border-radius: 3px; }
.jobpro-chat-video-rectme progress::-webkit-progress-value { background: linear-gradient(90deg, #FF5050, #ff8585); border-radius: 3px; }
.jobpro-chat-video-rectme progress::-moz-progress-bar { background: linear-gradient(90deg, #FF5050, #ff8585); border-radius: 3px; }
.jobpro-chat-video-btns {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}
.jobpro-chat-video-play {
  position: relative;
  width: 64px; height: 64px;
}
.jobpro-start-recording-btn,
.jobpro-stop-recording-btn {
  width: 64px; height: 64px;
  border-radius: 50%;
  border: 4px solid #fff;
  background: #FF5050;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0;
  position: relative;
  transition: transform .15s, background .2s, box-shadow .2s;
  box-shadow: 0 6px 18px -2px rgba(255, 80, 80, .55);
  -webkit-tap-highlight-color: transparent;
}
.jobpro-start-recording-btn::before {
  content: "";
  width: 22px; height: 22px;
  border-radius: 50%;
  background: #fff;
}
.jobpro-stop-recording-btn::before {
  content: "";
  width: 18px; height: 18px;
  border-radius: 3px;
  background: #fff;
}
.jobpro-start-recording-btn:hover,
.jobpro-stop-recording-btn:hover { background: #e93f3f; transform: scale(1.05); }
.jobpro-start-recording-btn:active,
.jobpro-stop-recording-btn:active { transform: scale(.95); }
.jobpro-stop-recording-btn.hidden,
.jobpro-start-recording-btn.hidden { display: none; }
#stopRecordingProgress {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 64px; height: 64px;
  pointer-events: none;
}
#stopRecordingProgress circle {
  fill: none;
  stroke: #fff;
  stroke-width: 3;
  transform: rotate(-90deg);
  transform-origin: 50% 50%;
  transition: stroke-dashoffset 1s linear;
}
.jobpro-send-record-btncon button,
.jobpro-send-record-btncon .jobpro-has-bg {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #47C392 0%, #2fa776 100%);
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  min-height: 40px;
  transition: box-shadow .2s, transform .12s;
  -webkit-tap-highlight-color: transparent;
}
.jobpro-send-record-btncon button:hover,
.jobpro-send-record-btncon .jobpro-has-bg:hover { box-shadow: 0 6px 16px rgba(71, 195, 146, .45); }
.jobpro-send-record-btncon button:active,
.jobpro-send-record-btncon .jobpro-has-bg:active { transform: translateY(1px); }

/* Upload progress (during file upload) */
.jproquest-upload-progress {
  background-color: var(--jproquest-primary-color, #081466) !important;
  color: #fff !important;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  border-radius: 6px;
  padding: 4px 10px;
  margin-bottom: 12px;
}

/* Recorded media preview chip after submit */
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm {
  display: block;
  width: 100%;
  background: #f5f7ff;
  border: 1px solid #d8ddf0;
  border-radius: 12px;
  padding: 10px 12px;
  margin-top: 12px;
}
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm audio,
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm video {
  max-width: 100%;
  width: 100%;
  border-radius: 8px;
  display: block;
  background: #000;
}
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm video {
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.jobpro-chat-cnt-lstitm.jobpro-chat-lstitm-mediaitm audio { height: 40px; background: transparent; }
.jobpro-attacmnt-img-download {
  display: none; /* hidden inside popup */
}

/* =========================================================================
 * LISTEN-QUESTION (TTS) BUTTON
 * ========================================================================= */
.jproquest-question-txt-str.jproquest-question-txt-str--has-tts {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  width: 100%;
}
.jproquest-question-text-content {
  display: block;
  width: 100%;
}
button.jproquest-tts-btn,
.jproquest-tts-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 9px 18px !important;
  border-radius: 10px !important;
  border: 1.5px solid var(--jproquest-primary-color, #5B47E0) !important;
  background: #fff !important;
  color: var(--jproquest-primary-color, #5B47E0) !important;
  font-family: inherit !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, transform .12s ease;
  min-height: 40px !important;
  outline: none !important;
  outline-offset: 0 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  text-decoration: none !important;
  text-transform: none !important;
  width: auto !important;
  box-shadow: none;
}
.jproquest-tts-btn:hover {
  background: var(--jproquest-primary-soft, #EFEEFE) !important;
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  box-shadow: 0 4px 12px -2px rgba(91, 71, 224, .2) !important;
  transform: translateY(-1px);
}
.jproquest-tts-btn:focus,
.jproquest-tts-btn:focus-visible {
  outline: none !important;
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  box-shadow: 0 0 0 3px rgba(91, 71, 224, .15) !important;
}
.jproquest-tts-btn:active { transform: translateY(0); }
.jproquest-tts-btn-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: transparent;
  color: var(--jproquest-primary-color, #5B47E0);
  flex: 0 0 auto;
  border-radius: 0;
}
.jproquest-tts-btn-icon svg {
  display: block;
  position: relative;
  z-index: 2;
  width: 22px;
  height: 22px;
}
.jproquest-tts-btn .jproquest-tts-icon-stop,
.jproquest-tts-btn .jproquest-tts-wave { display: none !important; }
.jproquest-tts-btn.is-playing .jproquest-tts-icon-play { display: none !important; }
.jproquest-tts-btn.is-playing .jproquest-tts-icon-stop,
.jproquest-tts-btn.is-playing .jproquest-tts-wave { display: inline-flex !important; }
.jproquest-tts-btn-label {
  white-space: nowrap;
}

/* Playing state — wave bars replace icon, button fills purple */
.jproquest-tts-btn.is-playing {
  background: var(--jproquest-primary-color, #5B47E0) !important;
  border-color: var(--jproquest-primary-color, #5B47E0) !important;
  color: #fff !important;
  animation: jproquest-tts-pulse 2s ease-in-out infinite;
}
.jproquest-tts-btn.is-playing .jproquest-tts-btn-icon {
  background: transparent;
  color: #fff;
}
.jproquest-tts-btn.is-playing .jproquest-tts-icon-play { display: none; }
.jproquest-tts-btn.is-playing .jproquest-tts-icon-stop { display: block; }
.jproquest-tts-btn.is-playing .jproquest-tts-wave {
  display: inline-flex;
  position: absolute;
  inset: 0;
  align-items: center;
  justify-content: center;
  gap: 2px;
  pointer-events: none;
}
.jproquest-tts-btn.is-playing .jproquest-tts-icon-stop { opacity: 0; }
.jproquest-tts-btn.is-playing .jproquest-tts-wave span {
  display: inline-block;
  width: 2px;
  height: 8px;
  background: #fff;
  border-radius: 1px;
  animation: jproquest-tts-wave 1s ease-in-out infinite;
}
.jproquest-tts-btn.is-playing .jproquest-tts-wave span:nth-child(1) { animation-delay: -.3s; }
.jproquest-tts-btn.is-playing .jproquest-tts-wave span:nth-child(2) { animation-delay: -.15s; }
.jproquest-tts-btn.is-playing .jproquest-tts-wave span:nth-child(3) { animation-delay: 0s; }
.jproquest-tts-btn.is-playing .jproquest-tts-wave span:nth-child(4) { animation-delay: -.45s; }
@keyframes jproquest-tts-wave {
  0%, 100% { transform: scaleY(.4); }
  50%      { transform: scaleY(1.6); }
}
@keyframes jproquest-tts-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(91, 71, 224, .35); }
  50%      { box-shadow: 0 0 0 6px rgba(91, 71, 224, 0); }
}
/* Hover-on-playing reverts to "click to stop" affordance */
.jproquest-tts-btn.is-playing:hover { background: #FF5050; border-color: #FF5050; }
.jproquest-tts-btn.is-playing:hover .jproquest-tts-icon-stop { opacity: 1; }
.jproquest-tts-btn.is-playing:hover .jproquest-tts-wave { display: none; }

/* Mobile tweaks */
@media (max-width: 480px) {
  .jproquest-quest-numb-badge { padding: 5px 10px; font-size: 12px; }
  .jproquest-quest-numb-badge .jproquest-quest-numb-current { font-size: 14px; }
  .jproquest-user-quiz-modal .jproquest-question-top-con {
    padding: 12px 50px 12px 14px;
    gap: 8px;
  }
  .jproquest-user-quiz-modal .jproquest-question-txt-str strong { font-size: 16px; }
  .jproquest-user-quiz-modal .jproquest-question-ansr-itm { padding: 12px 14px !important; min-height: 56px !important; gap: 12px !important; }
  .jproquest-ansritm-letter { width: 32px; height: 32px; font-size: 14px; border-radius: 8px; }
  .jproquest-user-quiz-modal .jproquest-ansritm-text { font-size: 14px !important; }
  .jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-prev-sbtn,
  .jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-next-sbtn { width: 32px; height: 32px; }
  .jproquest-recorder-card { padding: 18px; }
  .jproquest-recorder-audio .jproquest-recorder-stage { height: 120px; }
  .jproquest-recorder-mainbtn { width: 76px; height: 76px; }
  .jproquest-recorder-mainbtn .jbp-icon { font-size: 28px; }
  .jproquest-recorder-empty { padding: 24px 16px; }
  .jproquest-recorder-empty-icon { width: 64px; height: 64px; }
  .jproquest-recorder-cta { padding: 11px 20px; font-size: 14px; }
  .jproquest-recorder-actions { flex-direction: column; align-items: stretch; }
  .jproquest-recorder-cancel { width: 100%; }
  /* Compact timer card on phones */
  .jproquest-timer-card { gap: 8px; padding: 6px 12px 6px 6px; border-radius: 12px; }
  .jproquest-timer-icon { width: 38px; height: 38px; }
  .jproquest-timer-icon > svg:not(.jproquest-timer-arc) { width: 18px; height: 18px; }
  .jproquest-timer-arc { width: 38px !important; height: 38px !important; }
  .jproquest-timer-value { font-size: 15px; }
  .jproquest-timer-label { font-size: 9px; letter-spacing: .8px; }
  /* Stack the 3-col header on phones */
  .jproquest-user-quiz-modal .jproquest-question-top-con {
    flex-wrap: wrap !important;
    gap: 12px !important;
    padding: 14px 56px 14px 14px !important;
  }
  .jproquest-quest-timercell { order: 0; }
  .jproquest-quest-progresscell { order: 2; flex: 1 1 100% !important; }
  .jproquest-user-quiz-modal .jproquest-quest-totl-con { order: 1; margin-left: auto !important; }
  .jproquest-quest-numb-label { font-size: 10px; }
  .jproquest-quest-numb-badge { font-size: 16px; }
  .jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-prev-sbtn,
  .jproquest-user-quiz-modal .jproquest-question-top-con .jproquest-quest-next-sbtn {
    width: 38px !important; height: 38px !important; min-width: 38px !important; flex: 0 0 38px !important;
  }
  /* Footer: keep skip on its own row */
  .jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a {
    padding: 10px 14px !important;
    font-size: 13px !important;
    min-height: 40px !important;
  }
  .jproquest-user-quiz-modal .jproquest-question-nxtprv-wrap a.jproquest-question-skip-btn {
    flex: 1 1 100% !important;
    margin-right: 0 !important;
    order: 1 !important;
    margin-top: 4px;
  }
  /* Speak button shrinks on phones */
  .jproquest-tts-btn { padding: 7px 14px 7px 7px; font-size: 12px; min-height: 36px; }
  .jproquest-tts-btn-icon { width: 26px; height: 26px; }
}











/* ========================================
   Charts
   ======================================== */





/* ========================================
   Tables
   ======================================== */
.jproquest-qubaz-section {
    background: #fff;
    border-radius: 8px;
    padding: 25px;
    margin: 30px 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.jproquest-qubaz-section h2 {
    margin: 0 0 20px 0;
    font-size: 20px;
    font-weight: 600;
    color: #2c3e50;
}



/* Score Bar */
.jproquest-qubaz-score-bar {
    position: relative;
    width: 120px;
    height: 24px;
    background: #ecf0f1;
    border-radius: 12px;
    overflow: hidden;
}

.jproquest-qubaz-score-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background: linear-gradient(90deg, #43e97b 0%, #38f9d7 100%);
    transition: width 0.3s;
}

.jproquest-qubaz-score-bar .jproquest-qubaz-score-fill[style*="width: 0"] {
    background: #e74c3c;
}

.jproquest-qubaz-score-bar .jproquest-qubaz-score-fill[style*="width: 1"],
.jproquest-qubaz-score-bar .jproquest-qubaz-score-fill[style*="width: 2"],
.jproquest-qubaz-score-bar .jproquest-qubaz-score-fill[style*="width: 3"],
.jproquest-qubaz-score-bar .jproquest-qubaz-score-fill[style*="width: 4"],
.jproquest-qubaz-score-bar .jproquest-qubaz-score-fill[style*="width: 5"] {
    background: linear-gradient(90deg, #fc4a1a 0%, #f7b733 100%);
}

.jproquest-qubaz-score-text {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    font-size: 12px;
    font-weight: bold;
    color: #2c3e50;
    text-shadow: 0 1px 2px rgba(255, 255, 255, 0.8);
}

/* Status Badges */




.jproquest-qubaz-badge-gray {
    background: #6c757d;
    color: #fff;
}

/* ========================================
   Filters & Search
   ======================================== */






#jproquest-qubaz-candidate-search {
    width: 100%;
    max-width: 400px;
    padding: 10px 15px;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
}


/* ========================================
   Bulk Actions
   ======================================== */

#jproquest-qubaz-bulk-action {
    min-width: 200px;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
}

/* ========================================
   Actions Column
   ======================================== */
.jproquest-qubaz-actions {
    white-space: nowrap;
}

.jproquest-qubaz-actions .button {
    margin-right: 5px;
}

.jproquest-qubaz-actions .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

/* ========================================
   Candidate Details
   ======================================== */
.jproquest-qubaz-candidate-header {
    background: #fff;
    border-radius: 8px;
    padding: 30px;
    margin: 30px 0;
    display: flex;
    gap: 30px;
    align-items: center;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.jproquest-qubaz-candidate-avatar img {
    border-radius: 50%;
    border: 4px solid #ecf0f1;
}

.jproquest-qubaz-candidate-info h2 {
    margin: 0 0 15px 0;
    font-size: 28px;
    color: #2c3e50;
}

.jproquest-qubaz-candidate-info p {
    margin: 8px 0;
    color: #666;
    display: flex;
    align-items: center;
    gap: 8px;
}

.jproquest-qubaz-candidate-cell {
    display: flex;
    align-items: center;
    gap: 10px;
}

.jproquest-qubaz-candidate-cell img {
    border-radius: 50%;
}

/* ========================================
   Modal
   ======================================== */
.jproquest-qubaz-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100000;
}

.jproquest-qubaz-modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
}

.jproquest-qubaz-modal-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    border-radius: 8px;
    padding: 30px;
    max-width: 800px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
}

.jproquest-qubaz-modal-close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: transparent;
    border: none;
    font-size: 30px;
    cursor: pointer;
    color: #999;
    line-height: 1;
    padding: 0;
    width: 30px;
    height: 30px;
}

.jproquest-qubaz-modal-close:hover {
    color: #333;
}

/* ========================================
   Empty State
   ======================================== */

.jproquest-qubaz-empty-state .dashicons {
    font-size: 64px;
    width: 64px;
    height: 64px;
    opacity: 0.3;
    margin-bottom: 20px;
}


/* ========================================
   Loading State
   ======================================== */
.jproquest-qubaz-loading {
    text-align: center;
    padding: 40px;
    color: #999;
}

.jproquest-qubaz-loading:after {
    content: "...";
    animation: dots 1.5s infinite;
}

@keyframes dots {
    0%, 20% { content: "."; }
    40% { content: ".."; }
    60%, 100% { content: "..."; }
}

/* ========================================
   View All Link
   ======================================== */

/* ========================================
   Responsive
   ======================================== */
@media (max-width: 782px) {
        
        
        
    .jproquest-qubaz-candidate-header {
        flex-direction: column;
        text-align: center;
    }
    
    .jproquest-qubaz-modal-content {
        width: 95%;
        padding: 20px;
    }
}

@media (max-width: 600px) {
    .jproquest-qubaz-score-bar {
        width: 80px;
    }
    
    .jproquest-qubaz-actions .button {
        padding: 4px 8px;
        font-size: 11px;
    }
    
    }

/* ========================================
   Settings Page
   ======================================== */




.jproquest-qubaz-tab-button.active {
    background: #fff;
    color: #2271b1;
    border-bottom: 2px solid #fff;
    margin-bottom: -2px;
}

.jproquest-qubaz-tab-button .dashicons {
    font-size: 20px;
    width: 20px;
    height: 20px;
}


.jproquest-qubaz-tab-content.active {
    display: block;
}

.jproquest-qubaz-settings-section {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 25px;
    margin-bottom: 25px;
}

.jproquest-qubaz-settings-section h2 {
    margin: 0 0 20px 0;
    font-size: 20px;
    font-weight: 600;
    color: #2c3e50;
    border-bottom: 2px solid #ecf0f1;
    padding-bottom: 10px;
}

.jproquest-qubaz-settings-section h3 {
    margin: 0 0 15px 0;
    font-size: 18px;
    font-weight: 600;
    color: #2c3e50;
}

.jproquest-qubaz-settings-section .form-table {
    margin-top: 20px;
}

.jproquest-qubaz-settings-section .form-table th {
    width: 250px;
    padding: 15px 10px 15px 0;
}

.jproquest-qubaz-settings-section .form-table td {
    padding: 15px 10px;
}

.jproquest-qubaz-test-toggles {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 15px;
    margin-top: 20px;
}

.jproquest-qubaz-toggle-card {
    background: #f8f9fa;
    border: 2px solid #ddd;
    border-radius: 8px;
    padding: 20px;
    cursor: pointer;
    transition: all 0.3s;
    display: block;
}

.jproquest-qubaz-toggle-card:hover {
    border-color: #2271b1;
    background: #f0f6fc;
}

.jproquest-qubaz-toggle-card input[type="checkbox"] {
    float: right;
    margin: 0;
    width: 20px;
    height: 20px;
    cursor: pointer;
}

.jproquest-qubaz-toggle-card input[type="checkbox"]:checked + .jproquest-qubaz-toggle-content {
    color: #2271b1;
}

.jproquest-qubaz-toggle-content {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-right: 30px;
}

.jproquest-qubaz-toggle-icon {
    font-size: 32px;
    line-height: 1;
}

.jproquest-qubaz-settings-footer {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 20px;
    display: flex;
    gap: 15px;
    align-items: center;
    position: sticky;
    bottom: 20px;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
}

.jproquest-qubaz-settings-footer .button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    height: auto;
}

.jproquest-qubaz-settings-footer .button .dashicons {
    font-size: 18px;
    width: 18px;
    height: 18px;
}

/* Logo Preview */


/* Description Text */
.jproquest-qubaz-settings-section p.description {
    margin: 8px 0 0 0;
    color: #666;
    font-style: italic;
}

/* Code Tags */
.jproquest-qubaz-settings-section code {
    background: #f0f0f1;
    padding: 2px 6px;
    border-radius: 3px;
    font-size: 12px;
    color: #d63638;
    font-family: 'Courier New', monospace;
}

/* WordPress Editor */
.jproquest-qubaz-settings-section .wp-editor-wrap {
    margin-top: 10px;
}

/* Input Fields */
.jproquest-qubaz-settings-section input[type="text"],
.jproquest-qubaz-settings-section input[type="email"],
.jproquest-qubaz-settings-section input[type="url"],
.jproquest-qubaz-settings-section input[type="number"] {
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 14px;
}

.jproquest-qubaz-settings-section input[type="text"]:focus,
.jproquest-qubaz-settings-section input[type="email"]:focus,
.jproquest-qubaz-settings-section input[type="url"]:focus,
.jproquest-qubaz-settings-section input[type="number"]:focus {
    border-color: #2271b1;
    outline: none;
    box-shadow: 0 0 0 1px #2271b1;
}

/* Checkboxes */
.jproquest-qubaz-settings-section input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-right: 8px;
    vertical-align: middle;
}

.jproquest-qubaz-settings-section label {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}

/* Responsive */
@media (max-width: 782px) {
        
        
    .jproquest-qubaz-test-toggles {
        grid-template-columns: 1fr;
    }
    
    .jproquest-qubaz-settings-section .form-table th {
        width: 100%;
        display: block;
        padding-bottom: 5px;
    }
    
    .jproquest-qubaz-settings-section .form-table td {
        display: block;
        padding-top: 5px;
    }
    
    .jproquest-qubaz-settings-footer {
        flex-direction: column;
        align-items: stretch;
    }
    
    .jproquest-qubaz-settings-footer .button {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 600px) {
    .jproquest-qubaz-settings-section {
        padding: 15px;
    }
    
        
    .jproquest-qubaz-toggle-content {
        font-size: 14px;
    }
    
    .jproquest-qubaz-toggle-icon {
        font-size: 24px;
    }
}

.jproquest-multiquizs-holder {
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  gap: 30px;
}

.jproquest-multiquiz-itmcon {
  display: flex;
  width: 100%;
  align-items: center;
  gap: 30px;
  justify-content: space-between;
  border: 1px solid #eee;
  border-radius: 10px;
}

.jproquest-quiz-itminer-info {
  display: flex;
  gap: 10px;
}

.jobpro-dashboard-section-wrap {
  position: relative;
}

.jobpro-jproquest-result-modal .jobpro-modal-container {
    width: 80%;
}

.jobpro-jproquest-result-modal .jobpro-modal-container .jobpro-modal-inner-area {
    max-width: 100%;
}




.jobpro-responsive-table {
    display: table;
    width: 100%;
    table-layout: auto; /* Column width based on largest content */
    border-collapse: collapse;
}

.jobpro-qztable-header {
    display: table-row;
    background: #2d3748;
    color: #fff;
    font-weight: bold;
}

.jobpro-qztable-header div {
    display: table-cell;
    padding: 14px;
    border: 1px solid #ddd;
}

.jobpro-qztable-row {
    display: table-row;
}

.jobpro-qztable-cell {
    display: table-cell;
    padding: 14px;
    border: 1px solid #ddd; /* Column + row borders */
    white-space: nowrap;
}
.jproquest-quiz-lvl {
  display: inline-flex;
  padding: 8px 15px;
  background-color: #df6d6d;
  color: #fff;
  border-radius: 100px;
  line-height: 1;
}
.jproquest-quiz-tlt {
  font-size: 18px;
  font-weight: bold;
}

/* Make column width adapt to largest content automatically */
.jobpro-qztable-header div,
.jobpro-qztable-cell {
    width: auto;
}

/* Mobile Layout */
@media (max-width: 768px) {

    .jobpro-qztable-header {
        display: none;
    }

    .jobpro-qztable-row {
        display: flex;
        flex-direction: column;
        border: 1px solid #ddd;
        margin-bottom: 15px;
        border-radius: 8px;
        overflow: hidden;
        background: #fff;
    }

    .jobpro-qztable-cell {
        display: flex;
        justify-content: space-between;
        width: 100%;
        padding: 12px 15px;
        border-right: none;
        border-bottom: 1px solid #eee;
    }

    .jobpro-qztable-cell:last-child {
        border-bottom: none;
    }

    .jobpro-qztable-cell::before {
        content: attr(data-label);
        font-weight: bold;
        margin-right: 10px;
    }
}
@media (max-width: 768px) {
    .jobpro-qztable-row .jobpro-qztable-cell:not(:first-child) {
        display: none;
    }

    .jobpro-qztable-row.active .jobpro-qztable-cell {
        display: flex;
    }

    .jobpro-qztable-row {
        cursor: pointer;
    }

    /* Visible chevron on the first cell so users know rows are tappable. */
    .jobpro-qztable-row .jobpro-qztable-cell:first-child {
        position: relative;
        padding-right: 40px;
        font-weight: 600;
        background: #f8fafc;
    }
    .jobpro-qztable-row .jobpro-qztable-cell:first-child::after {
        content: "";
        position: absolute;
        right: 14px;
        top: 50%;
        width: 10px;
        height: 10px;
        border-right: 2px solid #5b47e0;
        border-bottom: 2px solid #5b47e0;
        transform: translateY(-70%) rotate(45deg);
        transition: transform .2s;
    }
    .jobpro-qztable-row.active .jobpro-qztable-cell:first-child::after {
        transform: translateY(-30%) rotate(-135deg);
    }
}

.jproquest-result-quests-holdr {
max-width: 800px;
margin: 0 auto;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
line-height: 1.6;
color: #2c3e50;
}

.jproquest-result-questans-itm {
background: white;
border-radius: 12px;
padding: 24px;
margin-bottom: 24px;
box-shadow: 0 4px 20px rgba(0,0,0,0.08);
border: 1px solid #edf2f7;
}

.jproquest-result-quest-str {
margin-bottom: 20px;
font-size: 1.1rem;
}

.jproquest-result-quest-str strong {
color: #1a2639;
font-weight: 600;
line-height: 1.5;
display: inline-block;
}

.jproquest-result-ansr-str {
background: #f8fafc;
padding: 18px 20px;
border-radius: 8px;
border-left: 4px solid #3498db;
color: #2c3e50;
margin-top: 8px;
}

.jproquest-mcq-optcsl-str {
margin: 20px 0 12px 0;
color: #4a5568;
font-size: 0.95rem;
letter-spacing: 0.3px;
}

.jproquest-mcq-optcsl-str em {
font-style: normal;
font-weight: 600;
color: #2d3748;
background: #e9ecef;
padding: 4px 12px;
border-radius: 20px;
display: inline-block;
}

.jproquest-mcq-opts-list {
background: #ffffff;
border-radius: 10px;
padding: 12px;
border: 1px solid #e2e8f0;
margin-bottom: 12px;
}

.jproquest-mcq-optitm-str {
padding: 10px 16px;
margin: 4px 0;
border-radius: 6px;
background: #f8fafc;
color: #1a2639;
font-size: 0.98rem;
transition: all 0.2s ease;
border-left: 3px solid #cbd5e0;
}

.jproquest-mcq-optitm-str:last-child {
margin-bottom: 0;
}

/* Correct answer styling */
.jproquest-mcq-corr-itm {
background: #f0fff4;
border-left: 3px solid #2ecc71;
color: #27ae60;
font-weight: 500;
}

.jproquest-mcq-corr-itm::before {
content: "✓ ";
font-weight: 700;
color: #27ae60;
}

/* User selected answer styling */
.jproquest-mcq-slectd-itm {
background: #ebf8ff;
border-left: 3px solid #3182ce;
color: #2c5282;
font-weight: 500;
}

.jproquest-mcq-slectd-itm::before {
content: "► ";
color: #3182ce;
font-size: 0.9rem;
}

/* Special case for items that are both correct AND selected */
.jproquest-mcq-corr-itm.jproquest-mcq-slectd-itm {
background: linear-gradient(135deg, #f0fff4 0%, #ebf8ff 100%);
border-left: 3px solid #2ecc71;
border-right: 3px solid #3182ce;
}

/* Empty/skipped state */
.jproquest-result-ansr-str:contains('User skipped') {
background: #fff9f0;
border-left-color: #ed8936;
color: #c05621;
font-style: italic;
}

/* Spacing and alignment */
.jproquest-mcq-optitm-str:first-child {
margin-top: 0;
}

/* Nested list items */
.jproquest-mcq-opts-list .jproquest-mcq-opts-list {
margin-left: 24px;
border-left: 2px dashed #cbd5e0;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .jproquest-result-quests-holdr {
  padding: 12px;
  }
  .jproquest-result-questans-itm {
      padding: 18px;
  }

  .jproquest-mcq-optitm-str {
      padding: 8px 12px;
      font-size: 0.95rem;
  }
}
.jproquest-qubaz-section thead tr th {
    text-align: left;
}