:root {
  --bg: #f4f7fc;
  --bg-deep: #eaf1ff;
  --surface: #fff;
  --surface-2: #f8fbff;
  --ink: #071b3a;
  --ink-2: #14294c;
  --muted: #64748b;
  --line: #dce6f4;
  --primary: #1258ff;
  --primary-2: #0034a8;
  --primary-soft: #eef5ff;
  --ok: #087443;
  --warn: #b26a00;
  --danger: #b42318;
  --radius: 26px;
  --radius-lg: 34px;
  --radius-sm: 15px;
  --shadow: 0 26px 80px rgba(15, 34, 68, 0.1);
  --shadow-soft: 0 14px 34px rgba(15, 34, 68, 0.06);
  --font: Vazirmatn, IRANSans, Tahoma, Arial, sans-serif;
  --display: Vazirmatn, IRANSans, Tahoma, Arial, sans-serif;
}
* {
  box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
}
body {
  margin: 0;
  min-height: 100vh;
  background: radial-gradient(circle at 80% -10%, #dce9ff 0, #f5f8fd 34%, var(--bg) 100%);
  color: var(--ink);
  font-family: var(--font);
  line-height: 1.9;
  font-size: 15px;
}
a {
  color: var(--primary);
  text-decoration: none;
}
small {
  color: var(--muted);
}
b,
strong {
  font-weight: 800;
}
::selection {
  background: #dbe8ff;
  color: #071b3a;
}
.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  background: rgba(255, 255, 255, 0.88);
  border-bottom: 1px solid rgba(220, 230, 244, 0.9);
  backdrop-filter: blur(18px);
  padding: 14px clamp(14px, 4vw, 40px);
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--ink);
  min-width: 0;
}
.brand-mark {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: linear-gradient(145deg, #062765, var(--primary));
  color: #fff;
  font-weight: 900;
  box-shadow: 0 12px 26px rgba(18, 88, 255, 0.24);
}
.brand-copy {
  display: flex;
  flex-direction: column;
  gap: 0;
  line-height: 1.25;
}
.brand-copy b {
  font-family: var(--display);
  font-size: 20px;
  letter-spacing: -0.02em;
}
.brand-copy small {
  font-size: 11px;
  white-space: nowrap;
  color: #708098;
}
.topbar nav {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.user-chip {
  border: 1px solid #cfe0ff;
  background: var(--primary-soft);
  color: #143d8f;
  border-radius: 999px;
  padding: 6px 12px;
  font-weight: 800;
}
main {
  max-width: 1180px;
  margin: 28px auto;
  padding: 0 clamp(14px, 3vw, 24px);
}
footer {
  text-align: center;
  color: var(--muted);
  font-size: 13px;
  padding: 36px 18px;
}
.home-page main {
  max-width: 1220px;
}
.hero,
.box,
.card,
.notice,
.stat {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.85fr);
  gap: 26px;
  align-items: center;
  padding: clamp(28px, 5vw, 56px);
  overflow: hidden;
  margin-bottom: 18px;
}
.hero h1,
.box h1 {
  font-family: var(--display);
  font-size: clamp(30px, 4.2vw, 54px);
  line-height: 1.25;
  margin: 0.1em 0 0.3em;
  letter-spacing: -0.035em;
}
.lead {
  font-size: 18px;
  color: #34435a;
}
.eyebrow {
  color: var(--primary);
  font-weight: 900;
  margin: 0 0 5px;
}
.hero-panel {
  background: linear-gradient(155deg, #061b42, #124eea);
  color: #fff;
  border-radius: 30px;
  padding: 26px;
  box-shadow: 0 30px 90px rgba(18, 88, 255, 0.25);
}
.hero-panel .clean-list {
  color: #eef4ff;
}
.score-ring {
  width: 138px;
  height: 138px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.28);
  font-family: var(--display);
  font-size: 38px;
  text-align: center;
}
.score-ring span {
  display: block;
  font-family: var(--font);
  font-size: 12px;
  font-weight: 600;
  margin-top: -18px;
}
.clean-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.clean-list li {
  padding: 7px 0;
}
.icon {
  font-size: 30px;
  display: block;
  margin-bottom: 8px;
}
.box {
  padding: 24px;
  margin: 18px 0;
}
.narrow {
  max-width: 790px;
  margin-inline: auto;
}
.grid {
  display: grid;
  gap: 16px;
  margin: 18px 0;
}
.grid.two {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.grid.three {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}
.grid.five {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.card {
  display: block;
  padding: 24px;
  color: var(--ink);
  transition:
    0.18s transform,
    0.18s box-shadow;
}
.card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow);
}
.test-card {
  min-height: 190px;
}
.watson-card {
  background: linear-gradient(180deg, #fff, #f5f8ff);
}
.neo-card {
  background: linear-gradient(180deg, #fff, #f5fff8);
}
.mini-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.mini-meta span {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 9px;
  color: var(--muted);
  font-size: 12px;
}
.button,
button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--primary), #003bd3);
  color: white !important;
  padding: 11px 19px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 900;
  min-height: 44px;
  cursor: pointer;
  box-shadow: 0 14px 30px rgba(18, 88, 255, 0.22);
  transition:
    0.18s transform,
    0.18s box-shadow,
    0.18s background;
}
.button:hover,
button:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 38px rgba(18, 88, 255, 0.25);
}
.button.secondary,
button.secondary {
  background: #f3f7ff;
  color: #123f91 !important;
  border: 1px solid #cfe0ff;
  box-shadow: none;
}
.button.ghost,
button.ghost {
  background: #fff;
  color: #123f91 !important;
  border: 1px solid #cfe0ff;
  box-shadow: none;
}
.button.small {
  padding: 7px 12px;
  min-height: 34px;
}
.button.tiny,
button.tiny {
  padding: 6px 11px;
  min-height: 32px;
  border-radius: 12px;
  font-size: 13px;
}
.actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 16px;
}
button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}
.notice {
  padding: 16px 18px;
  background: #fffdf4;
  border-color: #ffe08a;
}
.notice.ethics {
  border-right: 5px solid #f59e0b;
}
.small-text {
  font-size: 13px;
  color: #475467;
}
.alert {
  padding: 13px 15px;
  border-radius: 15px;
  margin: 12px 0;
}
.alert.danger {
  background: #fff1f0;
  color: var(--danger);
  border: 1px solid #ffccc7;
}
.section-head {
  margin-bottom: 15px;
}
.section-head.row,
.dashboard-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.form-shell {
  background: linear-gradient(180deg, #fff, #f9fbff);
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px;
}
.form-grid label,
.note-form label {
  font-weight: 800;
}
.form-grid input,
.form-grid select,
.note-form select,
.note-form textarea,
.table-search {
  width: 100%;
  margin-top: 6px;
}
.full {
  grid-column: 1/-1;
}
.check {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
  background: #f8fafc;
  border: 1px solid var(--line);
  padding: 12px;
  border-radius: 15px;
  font-weight: 600 !important;
}
.check input {
  width: auto !important;
  margin-top: 7px;
}
.consent-card {
  background: #fbfdff;
  border: 1px dashed #bfd3f7;
  border-radius: 20px;
  padding: 18px;
}
input,
select,
textarea {
  border: 1px solid #cbd5e1;
  border-radius: 14px;
  padding: 11px 12px;
  font: inherit;
  background: #fff;
  color: var(--ink);
}
textarea {
  min-height: 120px;
  resize: vertical;
}
input:focus,
select:focus,
textarea:focus {
  outline: 3px solid #dbe8ff;
  border-color: var(--primary);
}
code {
  background: #f1f5f9;
  border: 1px solid #e2e8f0;
  border-radius: 9px;
  padding: 1px 7px;
  direction: ltr;
  display: inline-block;
}
/* Premium exam layout */
.test-page {
  background: linear-gradient(180deg, #f6f9ff 0, #eef4ff 100%);
}
.test-page main {
  max-width: 1120px;
  margin: 22px auto 0;
}
.test-page footer {
  padding-top: 20px;
}
.exam-shell {
  display: grid;
  gap: 16px;
}
.exam-hero {
  position: relative;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--line);
  border-radius: 32px;
  padding: clamp(22px, 4vw, 42px);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.exam-hero:before {
  content: "";
  position: absolute;
  inset: auto -90px -100px auto;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, #dbe8ff 0, rgba(219, 232, 255, 0) 70%);
  pointer-events: none;
}
.exam-title {
  position: relative;
  max-width: 780px;
}
.exam-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #eef5ff;
  border: 1px solid #cfe0ff;
  color: #174ea6;
  font-weight: 900;
  padding: 6px 13px;
  margin-bottom: 8px;
}
.exam-title h1 {
  font-family: var(--display);
  font-size: clamp(34px, 5vw, 60px);
  line-height: 1.15;
  margin: 0 0 10px;
  letter-spacing: -0.045em;
}
.exam-title p {
  margin: 0;
  color: #40516a;
  font-size: 16px;
  max-width: 760px;
}
.exam-note {
  margin-top: 18px;
  background: #fff8e7;
  border: 1px solid #ffd899;
  color: #594000;
  border-radius: 18px;
  padding: 12px 15px;
  font-size: 13px;
}
.booklet-details {
  position: relative;
  margin: 16px 0 0;
}
.booklet-details summary {
  cursor: pointer;
  font-weight: 900;
  color: #0f4ad9;
  list-style: none;
}
.booklet-details summary::-webkit-details-marker {
  display: none;
}
.booklet-details summary:before {
  content: "▸";
  margin-left: 7px;
}
.booklet-details[open] summary:before {
  content: "▾";
}
.booklet {
  max-height: 320px;
  overflow: auto;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
  white-space: pre-wrap;
  direction: rtl;
  font-family: var(--font);
}
.exam-status-card {
  display: grid;
  grid-template-columns: minmax(250px, 1fr) repeat(2, minmax(150px, 0.45fr)) auto;
  gap: 1px;
  align-items: stretch;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}
.status-item,
.progress-item,
.exam-status-card > button {
  background: rgba(255, 255, 255, 0.95);
  padding: 15px 18px;
}
.status-label {
  display: block;
  font-size: 12px;
  color: var(--muted);
  font-weight: 800;
  margin-bottom: 5px;
}
.status-item b,
.progress-item b {
  font-family: var(--display);
  font-size: 18px;
  color: var(--ink-2);
}
.progress-bar {
  height: 9px;
  background: #e8eef8;
  border-radius: 999px;
  overflow: hidden;
  margin-top: 10px;
}
.progress-bar i {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--primary), #0dcf83);
  border-radius: 999px;
  transition: width 0.25s ease;
}
.exam-status-card > button {
  border-radius: 0;
  box-shadow: none;
  border: 0;
  color: #123f91 !important;
  min-height: 100%;
  white-space: nowrap;
}
.timer {
  font-variant-numeric: tabular-nums;
  direction: ltr;
  unicode-bidi: embed;
  color: var(--ink-2);
}
.test-form.card-mode {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.question-rail {
  position: sticky;
  top: 92px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 13px 10px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--shadow-soft);
  max-height: calc(100vh - 112px);
  overflow: auto;
}
.rail-dot {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  border: 1px solid #d5e0ef;
  background: #fff;
  color: #718096;
  font-weight: 900;
  font-size: 12px;
  box-shadow: none;
  padding: 0;
  min-height: 38px;
}
.rail-dot.is-active {
  background: linear-gradient(135deg, var(--primary), #003bd3);
  border-color: var(--primary);
  color: #fff;
  box-shadow: 0 12px 28px rgba(18, 88, 255, 0.25);
}
.rail-dot.is-answered:not(.is-active) {
  background: #edfdf5;
  border-color: #a7f3d0;
  color: #087443;
}
.rail-dot.is-locked {
  opacity: 0.42;
}
.exam-card-area {
  min-width: 0;
}
.card-stage {
  position: relative;
  min-height: 370px;
}
.card-ui-ready .test-form.card-mode .question {
  display: none;
}
.card-ui-ready .test-form.card-mode .question.active {
  display: block;
  animation: cardIn 0.22s ease-out;
}
@keyframes cardIn {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.992);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.question {
  border: 0;
}
.question-card {
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid var(--line);
  border-radius: 34px;
  box-shadow: var(--shadow);
  padding: clamp(24px, 4vw, 42px);
  min-height: 360px;
  margin: 0;
}
.question-card legend {
  width: 100%;
  padding: 0;
  margin: 0 0 28px;
}
.question-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.step-badge,
.part-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  padding: 7px 12px;
}
.step-badge {
  background: linear-gradient(135deg, var(--primary), #003bd3);
  color: #fff;
  box-shadow: 0 8px 18px rgba(18, 88, 255, 0.2);
}
.part-chip {
  background: #eef5ff;
  color: #174ea6;
  border: 1px solid #cfe0ff;
}
.question-head strong {
  display: block;
  font-family: var(--display);
  font-size: clamp(24px, 3.2vw, 38px);
  line-height: 1.75;
  letter-spacing: -0.025em;
  color: #081a3a;
  max-width: 960px;
}
.question-card .options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 14px;
  margin-top: 24px;
}
.question-card .answer-option {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 68px;
  background: #fff;
  border: 1px solid #d7e3f5;
  border-radius: 22px;
  padding: 15px 18px;
  box-shadow: 0 12px 28px rgba(16, 24, 40, 0.045);
  font-weight: 900;
  cursor: pointer;
  transition:
    0.16s border,
    0.16s background,
    0.16s transform,
    0.16s box-shadow;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.question-card .answer-option:hover {
  transform: translateY(-2px);
  border-color: #9ebcff;
  background: #f8fbff;
}
.question-card .answer-option input {
  appearance: none;
  -webkit-appearance: none;
  order: 2;
  width: 22px;
  height: 22px;
  border: 2px solid #a8b8d0;
  border-radius: 50%;
  padding: 0;
  margin: 0;
  flex: 0 0 auto;
  background: #fff;
  box-shadow: inset 0 0 0 4px #fff;
}
.question-card .answer-option input:checked {
  border: 7px solid var(--primary);
  box-shadow: 0 0 0 5px #dbe8ff;
}
.question-card .answer-option span {
  order: 1;
}
.question-card .answer-option:has(input:checked) {
  border-color: var(--primary);
  background: linear-gradient(180deg, #f9fbff, #eef5ff);
  box-shadow: 0 18px 38px rgba(18, 88, 255, 0.14);
}
.timer.is-over {
  color: #b91c1c;
}
.watson-question-box {
  display: grid;
  align-items: stretch;
  gap: 18px;
}
.watson-context {
  display: grid;
  gap: 10px;
  width: 100%;
  padding: 14px 16px;
  background: #f8fafc;
  border: 1px solid #d9e2ef;
  border-radius: 14px;
  color: #18324f;
  font-size: 14px;
  line-height: 2;
}
.watson-context-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #0f4ad9;
  font-weight: 900;
}
.watson-context-head span {
  padding: 2px 9px;
  background: #eaf1ff;
  border-radius: 999px;
}
.watson-rule b,
.watson-stimulus b {
  color: #071b3a;
}
.watson-stimulus p {
  margin: 4px 0 0;
  color: #263b57;
}
.question-card.unanswered {
  border-color: #f59e0b;
  background: linear-gradient(180deg, #fff, #fff8eb);
  box-shadow:
    0 0 0 5px rgba(245, 158, 11, 0.13),
    var(--shadow);
}
.answer-hint {
  margin: 14px 0 0;
  border: 1px solid #dbe6f5;
  border-radius: 18px;
  background: #f8fbff;
  color: #607086;
  padding: 12px 16px;
  text-align: center;
  font-size: 13px;
}
.answer-hint.is-ok {
  background: #ecfdf3;
  border-color: #abefc6;
  color: #067647;
}
.answer-hint.is-warn {
  background: #fff7e6;
  border-color: #ffd899;
  color: #9a6700;
}
.card-nav {
  grid-column: 2;
  position: sticky;
  bottom: 14px;
  z-index: 22;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0;
  padding: 14px;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid var(--line);
  border-radius: 26px;
  box-shadow: 0 26px 80px rgba(15, 34, 68, 0.18);
  backdrop-filter: blur(18px);
}
.card-nav .submit-final {
  margin-right: auto;
  background: linear-gradient(135deg, #087443, #12a166);
}
.card-ui-ready .sticky-submit {
  display: none;
}
/* Reports and tables */
table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  margin: 12px 0;
}
th,
td {
  padding: 11px 12px;
  border-bottom: 1px solid var(--line);
  text-align: right;
  vertical-align: top;
}
th {
  background: #eef4ff;
  font-weight: 900;
}
tr:last-child td {
  border-bottom: 0;
}
.metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.metrics span {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 13px;
  padding: 8px 10px;
}
.badge {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  border-radius: 999px;
  padding: 5px 10px;
  font-weight: 900;
  font-size: 12px;
  border: 1px solid;
}
.badge.ok {
  background: #ecfdf3;
  color: #067647;
  border-color: #abefc6;
}
.badge.notice {
  background: #eef4ff;
  color: #175cd3;
  border-color: #c7d7fe;
}
.badge.warning {
  background: #fff7e6;
  color: #9a6700;
  border-color: #ffd899;
}
.badge.block,
.badge.danger {
  background: #fff1f0;
  color: #b42318;
  border-color: #ffccc7;
}
.flags li {
  margin: 6px 0;
}
.flags .warning {
  color: var(--warn);
}
.flags .block,
.flags .danger {
  color: var(--danger);
}
.flags .notice {
  color: var(--primary);
}
.result-highlight {
  border-color: #b9ccff;
  background: linear-gradient(180deg, #fff, #f7faff);
}
.big-score {
  font-size: 30px;
  font-weight: 900;
  color: var(--primary);
  font-family: var(--display);
}
.bar {
  position: relative;
  height: 28px;
  border-radius: 999px;
  background: #eef2f7;
  overflow: hidden;
  min-width: 160px;
}
.bar i {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, #8cb3ff, var(--primary));
  border-radius: 999px;
}
.bar span {
  position: relative;
  z-index: 1;
  display: block;
  text-align: center;
  line-height: 28px;
  font-weight: 900;
  color: #0f172a;
}
.bar.total {
  height: 34px;
  margin: 10px 0 14px;
  max-width: 520px;
}
.bar.total span {
  line-height: 34px;
}
.prompt-list li {
  margin: 10px 0;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px;
}
.stat {
  padding: 18px;
  text-align: center;
}
.stat span {
  display: block;
  font-size: 28px;
  font-family: var(--display);
  color: var(--primary);
  font-weight: 900;
}
.stat b {
  color: var(--muted);
}
.note-form {
  display: grid;
  gap: 12px;
  margin-bottom: 16px;
}
.note-list {
  list-style: none;
  padding: 0;
}
.note-list li {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 15px;
  padding: 12px;
  margin: 10px 0;
}
.admin-only {
  border-right: 5px solid #7c3aed;
}
.report-header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
}
.report-header .full {
  grid-column: 1/-1;
}
@media (max-width: 900px) {
  .hero {
    grid-template-columns: 1fr;
  }
  .topbar {
    align-items: flex-start;
    flex-direction: column;
  }
  .brand-copy small {
    white-space: normal;
  }
  .dashboard-head {
    align-items: stretch;
    flex-direction: column;
  }
  .exam-status-card {
    grid-template-columns: 1fr 1fr;
  }
  .progress-item {
    grid-column: 1/-1;
  }
  .exam-status-card > button {
    grid-column: 1/-1;
  }
  .test-form.card-mode {
    grid-template-columns: 1fr;
  }
  .question-rail {
    position: static;
    flex-direction: row;
    justify-content: flex-start;
    max-height: none;
    overflow-x: auto;
    padding: 10px;
    border-radius: 22px;
  }
  .rail-dot {
    width: 34px;
    height: 34px;
    min-height: 34px;
    flex: 0 0 auto;
  }
  .card-nav {
    grid-column: 1;
  }
  .report-header {
    grid-template-columns: 1fr;
  }
  table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}
@media (max-width: 560px) {
  body {
    font-size: 14px;
  }
  .topbar {
    padding: 10px 12px;
  }
  .brand-mark {
    width: 34px;
    height: 34px;
  }
  .brand-copy b {
    font-size: 17px;
  }
  .topbar nav {
    width: 100%;
    gap: 8px;
  }
  .topbar nav a,
  .user-chip {
    font-size: 12px;
  }
  .test-page main {
    margin: 10px auto;
    padding: 0 10px;
  }
  .exam-hero {
    border-radius: 24px;
    padding: 20px 16px;
  }
  .exam-title h1 {
    font-size: 32px;
  }
  .exam-title p {
    font-size: 14px;
  }
  .exam-note {
    font-size: 12px;
  }
  .exam-status-card {
    grid-template-columns: 1fr;
    border-radius: 22px;
  }
  .status-item,
  .exam-status-card > button {
    padding: 12px 14px;
  }
  .question-card {
    border-radius: 26px;
    padding: 20px 14px;
    min-height: calc(100vh - 360px);
  }
  .question-head strong {
    font-size: 22px;
    line-height: 1.85;
  }
  .question-card .options {
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 18px;
  }
  .question-card .answer-option {
    min-height: 54px;
    border-radius: 16px;
    padding: 12px 14px;
  }
  .answer-hint {
    text-align: right;
  }
  .card-nav {
    bottom: 8px;
    border-radius: 22px;
    padding: 10px;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .card-nav .submit-final {
    grid-column: 1/-1;
    margin: 0;
  }
  .card-nav button {
    min-height: 48px;
    width: 100%;
  }
  .booklet {
    max-height: 220px;
  }
  .grid.two,
  .grid.three,
  .grid.five {
    grid-template-columns: 1fr;
  }
}
.watson-question-box {
  display: grid;
  align-items: stretch;
  gap: 16px;
}
.watson-question-box .question-title {
  align-self: center;
}
@media (max-width: 560px) {
  .watson-context {
    padding: 12px;
    font-size: 13px;
    line-height: 1.85;
  }
  .watson-context-head {
    display: grid;
    justify-content: stretch;
  }
}

/* Minimal focused exam box */
.test-page main {
  width: min(100%, 820px);
  margin: 18px auto 34px;
}
.exam-shell {
  gap: 12px;
}
.exam-hero {
  max-width: 760px;
  margin-inline: auto;
  padding: 14px 18px;
  border-radius: 14px;
  box-shadow: none;
}
.exam-chip {
  display: none;
}
.exam-title h1 {
  font-size: 24px;
}
.exam-title p {
  font-size: 12px;
}
.booklet-details {
  display: none;
}
.exam-status-card {
  max-width: 760px;
  margin-inline: auto;
  grid-template-columns: 1fr auto auto;
  background: transparent;
  border: 0;
  box-shadow: none;
  gap: 8px;
}
.status-item,
.progress-item {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 8px 12px;
}
.status-label {
  display: none;
}
.progress-bar {
  margin-top: 6px;
}
.question-rail {
  display: none !important;
}
.test-form.card-mode {
  max-width: 760px;
  margin-inline: auto;
}
.exam-card-area {
  width: 100%;
}
.question-card {
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  display: grid;
  gap: 10px;
}
.question-card legend,
.question-head,
.step-badge,
.part-chip {
  display: none !important;
}
.question-title {
  max-width: 100%;
  margin: 0;
  font-family: var(--font);
  font-size: 20px;
  line-height: 1.9;
  text-align: right;
  color: #071b3a;
  font-weight: 800;
}
.question-box,
.options-panel {
  width: 100%;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(15, 34, 68, 0.06);
}
.question-box {
  min-height: 150px;
  display: flex;
  align-items: center;
  padding: 24px 28px;
}
.options-panel {
  padding: 14px;
}
.question-card .options,
.question-card .options.neo {
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
  margin-top: 0;
}
.question-card .options.watson:has(.answer-option:nth-child(2):last-child) {
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  max-width: 560px;
  margin-inline: auto;
}
.question-card .answer-option {
  min-height: 44px;
  border-radius: 12px;
  padding: 8px 10px;
  font-size: 12px;
}
.question-card .answer-option span {
  white-space: nowrap;
}
.card-nav {
  width: 100%;
  justify-content: flex-start;
  border-radius: 14px;
  padding: 8px;
}
.card-nav button {
  min-height: 36px;
  padding: 7px 12px;
}
.card-nav .submit-final {
  margin-right: 0;
}
@media (max-width: 560px) {
  .test-page main {
    width: 100%;
    margin-top: 10px;
  }
  .exam-status-card {
    grid-template-columns: 1fr;
  }
  .question-card {
    padding: 0;
  }
  .question-box {
    min-height: 130px;
    padding: 18px 16px;
  }
  .options-panel {
    padding: 10px;
  }
  .question-title {
    font-size: 17px;
    line-height: 1.9;
  }
  .question-card .options,
  .question-card .options.neo {
    grid-template-columns: 1fr;
  }
  .question-card .options.watson:has(.answer-option:nth-child(2):last-child) {
    grid-template-columns: 1fr;
    max-width: none;
  }
  .question-card .answer-option span {
    white-space: normal;
  }
}
@media print {
  body {
    background: #fff;
  }
  .topbar,
  footer,
  .no-print,
  .sticky-submit,
  .exam-status-card,
  .question-rail,
  .card-nav,
  .button,
  button {
    display: none !important;
  }
  main {
    max-width: none;
    margin: 0;
    padding: 0;
  }
  .box,
  .card,
  .notice,
  .question,
  .question-card {
    box-shadow: none;
    break-inside: avoid;
  }
  .card-ui-ready .test-form.card-mode .question {
    display: block !important;
  }
  .test-form.card-mode {
    display: block;
  }
  a {
    color: #000;
  }
  .bar {
    border: 1px solid #999;
  }
}
.rail-dot {
  color: #718096 !important;
  background: #fff !important;
}
.rail-dot.is-active {
  color: #fff !important;
  background: linear-gradient(135deg, var(--primary), #003bd3) !important;
}
.rail-dot.is-answered:not(.is-active) {
  color: #087443 !important;
  background: #edfdf5 !important;
}
.rail-dot.is-locked {
  color: #94a3b8 !important;
  background: #f8fafc !important;
}

/* Excel-like admin reports */
.excel-report {
  direction: rtl;
  border-color: #1d4ed8;
  background: #fff;
  overflow: auto;
}
.excel-title {
  background: #3f3f3f;
  color: #fff;
  text-align: center;
  font-size: 22px;
  font-weight: 900;
  padding: 14px;
  margin: -24px -24px 16px;
}
.excel-score-table,
.neo-excel-table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  border-radius: 0;
  border: 2px solid #111;
  font-size: 14px;
}
.excel-score-table th,
.excel-score-table td,
.neo-excel-table th,
.neo-excel-table td {
  border: 1px solid #111;
  padding: 9px 10px;
  vertical-align: middle;
}
.excel-score-table thead th,
.neo-excel-table thead th {
  background: #4f8fd6;
  color: #fff;
  text-align: center;
}
.excel-score-table tbody th {
  background: #f1dddd;
  width: 38%;
}
.watson-main-table td:nth-child(2),
.watson-main-table td:nth-child(3),
.watson-model-table td {
  text-align: center;
  font-weight: 900;
  font-size: 22px;
}
.watson-main-table small {
  display: block;
  color: #111;
  font-size: 12px;
  line-height: 1;
}
.watson-model-table thead th {
  background: #0578bd;
  color: #fff;
  font-size: 18px;
}
.watson-model-table tbody th {
  background: #f3f3f3;
  font-size: 20px;
}
.excel-total th,
.excel-total td {
  background: #b8b8b8 !important;
  font-weight: 900;
}
.excel-bar {
  position: relative;
  height: 34px;
  background: #f4f4f4;
  border: 1px solid #ddd;
  overflow: hidden;
}
.excel-bar i {
  position: absolute;
  inset: 0 0 0 auto;
  background: #ffc000;
}
.excel-bar b {
  position: relative;
  z-index: 1;
  display: block;
  line-height: 34px;
  text-align: center;
  font-size: 18px;
}
.excel-note {
  margin: 12px 0 18px;
  font-size: 13px;
  color: #475467;
}
.watson-chart {
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 44px;
  min-height: 330px;
  margin-top: 18px;
  padding: 42px 38px 18px;
  background:
    linear-gradient(145deg, transparent 0 8%, #888 8.3%, transparent 8.6%) 0 0 / 100% 20% repeat-y,
    repeating-linear-gradient(to top, transparent 0 54px, #9b9b9b 55px),
    #fff;
  border: 1px solid #999;
}
.watson-chart-col {
  position: relative;
  width: 120px;
  height: 260px;
  display: flex;
  align-items: center;
  justify-content: end;
  flex-direction: column;
  gap: 8px;
  text-align: center;
  font-weight: 800;
}
.watson-chart-col i {
  position: relative;
  width: 76px;
  min-height: 4px;
  background: #c74f4b;
  display: block;
  box-shadow: 24px -16px 0 #873432;
}
.watson-chart-col:first-child i {
  background: #d00000;
  box-shadow: 24px -16px 0 #7d0000;
}
.watson-chart-col i:before {
  content: "";
  position: absolute;
  top: -16px;
  right: 0;
  width: 76px;
  height: 16px;
  background: #a13d3a;
  transform: skewX(-50deg);
  transform-origin: bottom right;
}
.watson-chart-col:first-child i:before {
  background: #9f0000;
}
.watson-chart-col span {
  min-height: 44px;
  font-size: 15px;
}
.watson-chart-col b {
  position: absolute;
  color: #fff;
  bottom: 132px;
  z-index: 1;
  font-size: 19px;
}
.neo-excel-table {
  min-width: 980px;
}
.neo-excel-table thead th {
  background: #e5b8b7;
  color: #111;
}
.neo-domain-code,
.neo-domain-title,
.neo-domain-score,
.neo-domain-band {
  text-align: center;
  font-weight: 900;
  background: #f2f2f2;
}
.neo-domain-title {
  font-size: 22px;
}
.neo-domain-desc {
  width: 34%;
  line-height: 2;
  font-size: 13px;
}
.neo-profile-chart {
  min-width: 1180px;
  min-height: 470px;
  margin-top: 18px;
  padding: 14px;
  border: 1px solid #999;
  background: #fff;
}
.neo-profile-svg {
  width: 100%;
  min-width: 1180px;
  height: 440px;
  display: block;
}
.neo-grid line {
  stroke: #8d8d8d;
  stroke-width: 1;
  stroke-dasharray: 4 3;
}
.neo-line {
  fill: none;
  stroke: #5d5d5d;
  stroke-width: 7;
  stroke-linejoin: round;
  stroke-linecap: round;
}
.neo-points circle {
  fill: #5d5d5d;
  stroke: #5d5d5d;
}
.neo-points circle.level-1,
.neo-points circle.level-2 {
  fill: #d8544f;
}
.neo-xlabels text,
.neo-ylabels text {
  font-family: Peyda, Tahoma, Arial, sans-serif;
  font-size: 13px;
  fill: #111;
}
.neo-description-table,
.neo-label-table {
  min-width: 980px;
  border-collapse: collapse;
  border-spacing: 0;
  border: 2px solid #111;
  border-radius: 0;
  margin-top: 10px;
}
.neo-description-table th,
.neo-description-table td,
.neo-label-table th,
.neo-label-table td {
  border: 1px solid #111;
  padding: 9px 10px;
  vertical-align: top;
}
.neo-description-table thead th,
.neo-label-table thead th {
  background: #111;
  color: #fff;
}
.neo-description-table tbody tr:nth-child(odd) td,
.neo-description-table tbody tr:nth-child(odd) th {
  background: #f4f4f4;
}
.neo-label-table td:nth-child(1),
.neo-label-table td:nth-child(2) {
  direction: ltr;
  text-align: left;
}

/* Refined exam UI */
.test-page {
  background: #f3f7ff;
}
.test-page .topbar {
  position: static;
  min-height: 52px;
  padding: 8px clamp(18px, 4vw, 42px);
  box-shadow: none;
}
.test-page .brand-mark,
.test-page .brand-copy small {
  display: none;
}
.test-page .brand-copy b {
  font-family: var(--font);
  font-size: 14px;
}
.test-page .topbar nav {
  gap: 8px;
}
.test-page .topbar nav a,
.test-page .user-chip {
  min-height: 28px;
  padding: 4px 9px;
  border-radius: 10px;
  font-size: 12px;
}
.test-page main {
  width: min(100%, 980px);
  margin: 14px auto 28px;
  padding: 0 16px;
}
.test-page footer {
  display: none;
}
.exam-shell {
  gap: 10px;
}
.exam-hero {
  border-radius: 18px;
  padding: 18px 22px;
  box-shadow: 0 12px 36px rgba(20, 41, 76, 0.06);
}
.exam-hero:before {
  display: none;
}
.exam-title {
  max-width: none;
}
.exam-chip {
  padding: 4px 10px;
  margin-bottom: 6px;
  font-size: 11px;
}
.exam-title h1 {
  font-family: var(--font);
  font-size: 34px;
  line-height: 1.35;
  margin: 0;
  letter-spacing: 0;
}
.exam-title p {
  margin-top: 4px;
  font-size: 13px;
}
.booklet-details {
  margin-top: 8px;
}
.booklet-details summary {
  display: inline-flex;
  font-size: 12px;
}
.booklet {
  max-height: 220px;
  margin: 8px 0 0;
  border-radius: 12px;
  padding: 12px;
  font-size: 13px;
}
.exam-status-card {
  grid-template-columns: minmax(260px, 1fr) 120px 150px;
  border-radius: 14px;
  box-shadow: none;
}
.status-item,
.progress-item {
  padding: 10px 14px;
}
.status-label {
  font-size: 11px;
  margin-bottom: 2px;
}
.status-item b,
.progress-item b {
  font-family: var(--font);
  font-size: 13px;
}
.progress-bar {
  height: 6px;
  margin-top: 8px;
}
.test-form.card-mode {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.question-rail {
  order: 1;
  position: static;
  flex-direction: row;
  align-items: center;
  width: 100%;
  max-height: none;
  overflow-x: auto;
  padding: 8px;
  border-radius: 14px;
  box-shadow: none;
  scrollbar-width: thin;
}
.rail-dot {
  width: 30px;
  height: 30px;
  min-height: 30px;
  flex: 0 0 30px;
  font-size: 11px;
}
.exam-card-area {
  order: 2;
}
.card-stage {
  min-height: 0;
}
.question-card {
  border-radius: 20px;
  padding: 26px 30px 30px;
  min-height: 0;
  box-shadow: 0 16px 42px rgba(20, 41, 76, 0.08);
}
.question-card legend {
  margin-bottom: 22px;
}
.question-meta {
  justify-content: center;
  margin-bottom: 10px;
}
.step-badge {
  padding: 5px 11px;
  font-size: 11px;
  box-shadow: none;
}
.question-head strong {
  max-width: 820px;
  margin: 0 auto;
  font-family: var(--font);
  font-size: 25px;
  line-height: 1.85;
  letter-spacing: 0;
  text-align: center;
}
.question-card .options {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 20px;
}
.question-card .options.neo {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
.question-card .answer-option {
  min-height: 50px;
  justify-content: flex-start;
  gap: 9px;
  border-radius: 14px;
  padding: 10px 12px;
  box-shadow: none;
  font-size: 13px;
}
.question-card .answer-option:hover {
  transform: none;
}
.question-card .answer-option input {
  order: 0;
  width: 17px;
  height: 17px;
  border-width: 1.5px;
  box-shadow: inset 0 0 0 3px #fff;
}
.question-card .answer-option input:checked {
  border-width: 5px;
  box-shadow: 0 0 0 3px #dbe8ff;
}
.question-card .answer-option span {
  order: 1;
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
}
.answer-hint {
  display: none;
}
.card-nav {
  order: 3;
  position: static;
  display: flex;
  grid-column: auto;
  margin: 0;
  padding: 10px;
  border-radius: 16px;
  box-shadow: none;
  backdrop-filter: none;
}
.card-nav button {
  min-height: 40px;
  border-radius: 12px;
  padding: 8px 14px;
  font-size: 13px;
}
.card-nav .submit-final {
  margin-right: auto;
}
@media (max-width: 900px) {
  .test-page main {
    width: min(100%, 760px);
  }
  .exam-status-card {
    grid-template-columns: 1fr 1fr;
  }
  .progress-item {
    grid-column: 1/-1;
  }
  .question-card .options,
  .question-card .options.neo {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px) {
  .test-page main {
    margin-top: 8px;
    padding: 0 10px;
  }
  .exam-hero {
    padding: 14px;
    border-radius: 16px;
  }
  .exam-title h1 {
    font-size: 26px;
  }
  .exam-status-card {
    grid-template-columns: 1fr;
  }
  .question-card {
    padding: 18px 14px 20px;
    border-radius: 16px;
  }
  .question-head strong {
    font-size: 19px;
    line-height: 1.9;
  }
  .question-card .options,
  .question-card .options.neo {
    grid-template-columns: 1fr;
  }
  .card-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .card-nav .submit-final {
    grid-column: 1/-1;
    margin: 0;
  }
}

/* Critical-thinking booklet layout: instruction/stimulus, then item, then options. */
.test-page .watson-question-box {
  display: grid !important;
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 18px;
  min-height: 0;
  padding: 20px 22px;
}
.test-page .watson-context {
  width: min(100%, 680px);
  justify-self: center;
  padding: 16px 18px;
  font-size: 13px;
  line-height: 1.9;
}
.test-page .watson-stimulus p {
  max-height: 220px;
  overflow: auto;
  padding-left: 6px;
}
.test-page .watson-question-box .question-title {
  width: min(100%, 680px);
  justify-self: center;
  margin: 0;
  font-size: 22px;
  line-height: 1.9;
  text-align: center;
}
.test-page .question-card:has(.watson-question-box) {
  width: min(100%, 760px);
  margin-inline: auto;
  padding: 18px;
}
.test-page .question-card:has(.watson-question-box) .options-panel {
  width: min(100%, 760px);
  margin-inline: auto;
}
.test-page .question-card:has(.watson-question-box) .options.watson {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}
@media (max-width: 900px) {
  .test-page .question-card:has(.watson-question-box) .options.watson {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px) {
  .test-page .watson-question-box {
    padding: 14px;
  }
  .test-page .watson-context {
    width: 100%;
    padding: 12px;
    line-height: 1.85;
  }
  .test-page .watson-stimulus p {
    max-height: none;
  }
  .test-page .watson-question-box .question-title {
    font-size: 18px;
  }
  .test-page .question-card:has(.watson-question-box) {
    padding: 12px;
  }
  .test-page .question-card:has(.watson-question-box) .options.watson {
    grid-template-columns: 1fr;
  }
}

/* Stable critical-thinking exam frame. */
.test-page:has(.watson-question-box) .exam-shell {
  width: min(100%, 1180px);
  margin-inline: auto;
  display: grid;
  grid-template-columns: minmax(340px, 1.7fr) minmax(170px, 0.75fr) minmax(150px, 0.65fr) minmax(260px, 1.1fr);
  gap: 10px;
  align-items: stretch;
}
.test-page:has(.watson-question-box) .exam-hero {
  grid-column: auto;
  max-width: none;
  min-height: 86px;
  height: 86px;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.test-page:has(.watson-question-box) .exam-title h1 {
  font-size: 28px;
  line-height: 1.35;
}
.test-page:has(.watson-question-box) .exam-title p {
  font-size: 12px;
  line-height: 1.7;
}
.test-page:has(.watson-question-box) .exam-status-card {
  display: contents;
}
.test-page:has(.watson-question-box) .status-item,
.test-page:has(.watson-question-box) .progress-item {
  min-height: 86px;
  height: 86px;
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 12px 30px rgba(15, 34, 68, 0.05);
}
.test-page:has(.watson-question-box) .test-form.card-mode {
  grid-column: 1 / -1;
}
.test-page .question-card:has(.watson-question-box) {
  min-height: 610px;
  max-height: none;
  display: grid;
  grid-template-rows: minmax(0, auto);
}
.test-page .question-card:has(.watson-question-box) .watson-context {
  min-height: 250px;
}
.test-page .question-card:has(.watson-question-box) .watson-guide-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.test-page .question-card:has(.watson-question-box) .watson-guide {
  min-height: 66px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid #e3ebf7;
  border-radius: 12px;
}
.test-page .question-card:has(.watson-question-box) .watson-guide b,
.test-page .question-card:has(.watson-question-box) .watson-stimulus b {
  display: block;
  margin-bottom: 4px;
}
.test-page .question-card:has(.watson-question-box) .watson-guide p {
  margin: 0;
}
.test-page .question-card:has(.watson-question-box) .watson-stimulus {
  min-height: 128px;
}
.test-page .question-card:has(.watson-question-box) .question-title {
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.test-page .question-card:has(.watson-question-box) .options-panel {
  min-height: 78px;
}
.test-page .question-card:has(.watson-question-box) .answer-option {
  height: 56px;
}
@media (max-width: 1100px) {
  .test-page:has(.watson-question-box) .exam-shell {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .test-page:has(.watson-question-box) .exam-hero {
    grid-column: 1 / -1;
  }
}
@media (max-width: 700px) {
  .test-page:has(.watson-question-box) .exam-shell {
    grid-template-columns: 1fr;
  }
  .test-page:has(.watson-question-box) .exam-hero,
  .test-page:has(.watson-question-box) .status-item,
.test-page:has(.watson-question-box) .progress-item {
    height: auto;
    min-height: 74px;
  }
  .test-page .question-card:has(.watson-question-box) {
    min-height: 0;
  }
  .test-page .question-card:has(.watson-question-box) .watson-guide-row {
    grid-template-columns: 1fr;
  }
  .test-page .question-card:has(.watson-question-box) .watson-context,
  .test-page .question-card:has(.watson-question-box) .watson-stimulus,
  .test-page .question-card:has(.watson-question-box) .question-title,
  .test-page .question-card:has(.watson-question-box) .options-panel {
    min-height: 0;
  }
  .test-page .question-card:has(.watson-question-box) .answer-option {
    height: auto;
    min-height: 52px;
  }
}

/* Final critical-thinking desktop/mobile composition. */
.test-page:has(.watson-question-box) main {
  width: min(100%, 1180px);
  padding-inline: 16px;
}
.test-page:has(.watson-question-box) .test-form.card-mode {
  width: min(100%, 1080px);
  max-width: 1080px;
}
.test-page:has(.watson-question-box) .exam-card-area,
.test-page:has(.watson-question-box) .card-stage {
  width: 100%;
}
.test-page .question-card:has(.watson-question-box) {
  width: 100%;
  max-width: 1080px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 18px 46px rgba(20, 41, 76, 0.08);
}
.test-page .question-card:has(.watson-question-box) .watson-question-box,
.test-page .question-card:has(.watson-question-box) .options-panel {
  width: 100%;
  max-width: none;
  margin: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.test-page .question-card:has(.watson-question-box) .watson-question-box {
  padding: 0;
  gap: 14px;
}
.test-page .question-card:has(.watson-question-box) .watson-context {
  width: 100%;
  max-width: none;
  padding: 14px 16px;
  font-size: 12.5px;
  line-height: 1.8;
}
.test-page .question-card:has(.watson-question-box) .watson-stimulus p {
  max-height: none;
  overflow: visible;
  padding-left: 0;
}
.test-page .question-card:has(.watson-question-box) .question-title {
  width: 100%;
  max-width: none;
  font-size: 21px;
  line-height: 1.75;
}
.test-page .question-card:has(.watson-question-box) .options-panel {
  padding: 8px 0 0;
  border-top: 1px solid #e3ebf7;
}
.test-page .question-card:has(.watson-question-box) .options.watson {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}
.test-page .question-card:has(.watson-question-box) .answer-option {
  min-height: 54px;
}
.test-page:has(.watson-question-box) .card-nav {
  width: min(100%, 1080px);
  margin-inline: auto;
}
@media (max-width: 900px) {
  .test-page:has(.watson-question-box) main {
    width: 100%;
    padding-inline: 12px;
  }
  .test-page:has(.watson-question-box) .test-form.card-mode,
  .test-page:has(.watson-question-box) .card-nav {
    width: 100%;
    max-width: none;
  }
  .test-page .question-card:has(.watson-question-box) .options.watson {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 560px) {
  .test-page:has(.watson-question-box) main {
    padding-inline: 8px;
  }
  .test-page .question-card:has(.watson-question-box) {
    padding: 12px;
    border-radius: 16px;
  }
  .test-page .question-card:has(.watson-question-box) .watson-context {
    padding: 11px 12px;
    font-size: 12px;
  }
  .test-page .question-card:has(.watson-question-box) .question-title {
    font-size: 17px;
  }
  .test-page .question-card:has(.watson-question-box) .options.watson {
    grid-template-columns: 1fr;
  }
}

/* v5 time-control additions */
.time-lock-card {
  text-align: center;
}
.time-lock-card .notice {
  margin-top: 16px;
  text-align: right;
}
[data-save-state].is-ok {
  color: #0f766e;
}
.test-time-expired .exam-status-card {
  border-color: #f59e0b;
  box-shadow: 0 18px 40px rgba(245, 158, 11, .14);
}
.admin-time-form input[type="number"],
.grant-form input[type="number"] {
  width: 92px;
}
.grant-form {
  display: grid;
  grid-template-columns: 86px minmax(150px, 1fr) auto;
  gap: 8px;
  align-items: center;
  min-width: 330px;
}
.grant-form input {
  min-height: 38px;
  border-radius: 12px;
  border: 1px solid #dbe5f2;
  padding: 8px 10px;
}
.badge.danger {
  background: #fff7ed;
  color: #c2410c;
  border-color: #fed7aa;
}
.badge.ok {
  background: #ecfdf5;
  color: #047857;
  border-color: #a7f3d0;
}
.alert.success {
  border-color: #99f6e4;
  background: #f0fdfa;
  color: #0f766e;
}
@media (max-width: 760px) {
  .grant-form {
    grid-template-columns: 1fr;
    min-width: 0;
  }
  .grant-form input[type="number"] {
    width: 100%;
  }
}

/* v0.028 standard session-flow additions */
.card-status {
  display: flex;
  justify-content: flex-start;
  margin: 0 0 10px;
}
.test-card .button.tiny {
  margin-top: 16px;
}
.test-card.is-locked {
  opacity: .82;
  cursor: not-allowed;
}
.test-card.is-locked:hover {
  transform: none;
  box-shadow: none;
}
.start-card .metrics {
  margin: 18px 0;
}
