/*
 * AIVI Question Create styles.
 * Page-specific CSS for /english/question-create.
 * Shared question-preview and Similar Lab compatibility styles remain in exam_page.css in this first split.
 */

/* Question Create shell, Text AI intake, CSV AI, Gemini status (from exam_page.css lines 135-1293) */
.question-create-page .exam-builder-panel[data-future-menu] {
  display: block;
  margin-bottom: 1.25rem;
}

.question-create-page .exam-builder-panel[data-future-menu]:last-of-type {
  margin-bottom: 0;
}

.question-create-page .exam-builder-steps[data-future-menu] {
  display: grid !important;
}

.question-create-placeholder {
  padding: 1.15rem;
  background: #f8fafc;
}

.question-create-placeholder-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  margin: 1rem 0;
}

.question-create-placeholder-grid > div {
  border: 1px solid var(--exam-line);
  border-radius: 14px;
  background: #fff;
  padding: .95rem;
}

.question-create-placeholder-grid strong {
  display: block;
  color: #0f172a;
  font-size: .9rem;
  font-weight: 900;
}

.question-create-placeholder-grid p {
  margin: .35rem 0 0;
  color: #64748b;
  font-size: .84rem;
  line-height: 1.6;
}

.question-create-shell {
  width: 100%;
  max-width: 1440px;
}

.question-create-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .3rem;
  width: 100%;
  padding: .28rem;
  margin-bottom: 1.1rem;
  border: 1px solid var(--exam-line);
  border-radius: 999px;
  background: #fff;
  box-shadow: var(--exam-shadow);
}

.question-create-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: .65rem 1rem;
  background: transparent;
  color: #475569;
  font-size: .88rem;
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
}

.question-create-tab.is-active {
  border-color: #0f172a;
  background: #0f172a;
  color: #fff;
}

.question-create-panel {
  display: none;
  width: 100%;
  min-width: 0;
}

.question-create-panel.is-active {
  display: block;
}

.question-panel {
  width: 100%;
  min-width: 0;
}

.question-create-content {
  width: 100%;
  min-width: 0;
}

.question-panel-intro {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 1.05rem 1.15rem;
  border: 1px solid var(--exam-line);
  border-radius: 18px;
  background: #fff;
  box-shadow: var(--exam-shadow);
}

.question-section-title {
  margin: 0;
  color: #0f172a;
  font-size: 1.18rem;
  font-weight: 950;
  letter-spacing: 0;
}

.question-section-desc {
  margin: .35rem 0 0;
  color: #64748b;
  font-size: .92rem;
  font-weight: 700;
  line-height: 1.6;
}

.question-panel-grid {
  display: grid;
  gap: 1rem;
  min-width: 0;
}

.question-panel-card {
  width: 100%;
  min-width: 0;
  padding: 1.15rem;
}

.question-panel-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  margin-top: 1rem;
  padding: .9rem 1rem;
  border: 1px solid var(--exam-line);
  border-radius: 16px;
  background: #f8fafc;
}

.question-panel-message {
  color: #475569;
  font-size: .88rem;
  font-weight: 850;
}

.question-import-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
}

.question-import-card {
  padding: 1.15rem;
}

.question-import-card-wide {
  padding: 0;
  overflow: hidden;
}

.question-coming-soon-card {
  max-width: 760px;
}

.question-coming-soon-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.65rem;
  margin: 1rem 0;
}

.question-coming-soon-list span {
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 8px;
  background: #f8fafc;
  color: #475569;
  font-size: 0.86rem;
  font-weight: 700;
  padding: 0.7rem 0.8rem;
}

.question-create-page .question-import-card-wide .exam-builder-panel[data-future-menu] {
  width: 100%;
  margin-bottom: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.question-create-page .question-import-card-wide .exam-builder-panel > .exam-builder-head {
  padding: 1.15rem 1.15rem 0;
}

.question-create-page .question-import-card-wide .exam-builder-panel > .exam-builder-head .exam-builder-actions {
  display: none;
}

.question-create-page .question-import-card-wide .exam-upload-layout {
  padding: 0 1.15rem 1.15rem;
  grid-template-columns: minmax(0, 1fr);
}

.question-paste-box {
  display: grid;
  gap: .8rem;
}

.question-paste-box textarea {
  min-height: 260px;
  width: 100%;
  resize: vertical;
  border: 1px solid var(--exam-line);
  border-radius: 16px;
  padding: .95rem 1rem;
  background: #f8fafc;
  color: #0f172a;
  font-size: .95rem;
  font-weight: 650;
  line-height: 1.65;
  outline: none;
}

#manualCreateText {
  min-height: 260px;
  width: 100%;
  resize: vertical;
  border: 1px solid var(--exam-line);
  border-radius: 16px;
  padding: .95rem 1rem;
  background: #f8fafc;
  color: #0f172a;
  font-size: .95rem;
  font-weight: 650;
  line-height: 1.65;
  outline: none;
}

.text-ai-textarea-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: .45rem;
  margin-bottom: -.2rem;
}

.text-ai-textarea-toolbar > span {
  margin-right: auto;
  color: #64748b;
  font-size: .8rem;
  font-weight: 850;
}

.text-ai-textarea-toolbar .exam-builder-btn {
  min-height: 30px;
  padding: .38rem .62rem;
  border-radius: 999px;
  font-size: .78rem;
}

.question-paste-box textarea:focus,
#manualCreateText:focus {
  border-color: #0f172a;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(15, 23, 42, .08);
}

.text-ai-structure-options-card {
  display: grid;
  gap: .8rem;
  padding: .95rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .04);
}

.text-ai-structure-options-head strong {
  display: block;
  color: #0f172a;
  font-size: .95rem;
  font-weight: 950;
}

.text-ai-structure-options-head p,
.text-ai-tag-rule {
  margin: .25rem 0 0;
  color: #64748b;
  font-size: .82rem;
  font-weight: 750;
  line-height: 1.55;
}

.text-ai-minimal-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .45rem;
}

.text-ai-minimal-tags > span {
  color: #334155;
  font-size: .8rem;
  font-weight: 900;
}

.text-ai-minimal-tags .exam-builder-btn {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  min-height: 30px;
  padding: .38rem .62rem;
  border-radius: 999px;
  font-size: .78rem;
}

.text-ai-minimal-tags .exam-builder-btn span {
  color: #64748b;
  font-size: .7rem;
  font-weight: 850;
}

.question-gemini-mock-panel {
  display: grid;
  gap: .8rem;
  padding: .9rem;
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: #eff6ff;
}

.text-ai-tag-help {
  border-top: 1px solid #e2e8f0;
  padding-top: .65rem;
}

.text-ai-tag-help summary {
  cursor: pointer;
  color: #0f172a;
  font-size: .86rem;
  font-weight: 900;
}

.text-ai-tag-help p {
  margin: .45rem 0;
  color: #64748b;
  font-size: .82rem;
  font-weight: 750;
  line-height: 1.55;
}

.text-ai-tag-help ul {
  margin: .55rem 0 0;
  padding-left: 1.1rem;
  color: #475569;
  font-size: .8rem;
  font-weight: 700;
  line-height: 1.65;
}

.text-ai-tag-help li + li {
  margin-top: .18rem;
}

.text-ai-shortcut-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(115px, 1fr));
  gap: .35rem;
  margin: .55rem 0;
}

.text-ai-shortcut-grid span {
  padding: .42rem .55rem;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #f8fafc;
  color: #334155;
  font-size: .78rem;
  font-weight: 850;
}

.text-ai-tag-help pre {
  max-height: 220px;
  overflow: auto;
  margin: .6rem 0 0;
  padding: .75rem;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #f8fafc;
  color: #0f172a;
  font-size: .78rem;
  line-height: 1.55;
  white-space: pre-wrap;
}

.question-gemini-mock-panel strong {
  display: block;
  color: #1e3a8a;
  font-size: .92rem;
  font-weight: 950;
}

.question-gemini-mock-panel p {
  margin: .25rem 0 0;
  color: #475569;
  font-size: .84rem;
  font-weight: 750;
  line-height: 1.55;
}

.question-gemini-mock-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}

.question-gemini-consent-row {
  display: grid;
  gap: .35rem;
  width: 100%;
  padding: .75rem .85rem;
  border: 1px solid #bfdbfe;
  border-radius: 14px;
  background: #fff;
}

.question-gemini-real-confirm {
  align-items: center;
  justify-content: flex-start;
  color: #1e3a8a;
  font-weight: 900;
}

.question-gemini-real-confirm input {
  width: 1rem;
  height: 1rem;
  accent-color: #2563eb;
}

.question-gemini-consent-row p {
  margin: 0;
  color: #1e3a8a;
  font-size: .8rem;
  font-weight: 750;
  line-height: 1.45;
}

.question-gemini-status-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  width: 100%;
}

.question-gemini-status-card {
  display: grid;
  gap: .7rem;
  width: 100%;
  max-width: 900px;
  min-width: 0;
  padding: .8rem .9rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #fff;
  color: #334155;
  font-size: .84rem;
  font-weight: 800;
  line-height: 1.55;
}

.question-gemini-mock-panel .question-gemini-status-card {
  max-width: none;
}

.question-gemini-mock-panel .question-gemini-status-grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  align-items: stretch;
}

.question-gemini-mock-panel .question-gemini-status-head {
  min-width: 0;
}

.question-gemini-status-card.is-ready {
  border-color: #cbd5e1;
  background: #fff;
}

.question-gemini-status-head {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem .65rem;
  align-items: center;
  justify-content: space-between;
}

.question-gemini-status-head strong {
  color: #0f172a;
  font-size: .92rem;
  font-weight: 950;
}

.question-gemini-status-head span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .12rem .5rem;
  border-radius: 999px;
  background: #f1f5f9;
  color: #334155;
  font-size: .76rem;
  font-weight: 950;
}

.question-gemini-status-card p {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
  color: #64748b;
  font-weight: 750;
}

.question-gemini-log-card {
  display: grid;
  gap: .75rem;
  padding: .85rem .95rem;
  border: 1px solid #cbd5e1;
  border-radius: 14px;
  background: #fff;
  color: #334155;
  font-size: .84rem;
  font-weight: 800;
  line-height: 1.55;
}

.question-gemini-log-card strong {
  display: block;
  color: #0f172a;
  font-size: .92rem;
  font-weight: 950;
}

.question-gemini-log-card p {
  margin: 0;
  color: #64748b;
}

.csv-ai-mock-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
}

.csv-ai-process-guide {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: .65rem;
  margin: .25rem 0 .75rem;
}

.csv-ai-process-step {
  min-width: 0;
  padding: .75rem;
  border: 1px solid #dbe3ef;
  border-radius: 14px;
  background: #fff;
}

.csv-ai-process-step span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  margin-bottom: .45rem;
  border-radius: 999px;
  background: #e0f2fe;
  color: #075985;
  font-size: .78rem;
  font-weight: 950;
}

.csv-ai-process-step strong {
  display: block;
  color: #0f172a;
  font-size: .86rem;
  font-weight: 950;
  line-height: 1.35;
}

.csv-ai-process-step p {
  margin: .18rem 0 0;
  color: #64748b;
  font-size: .76rem;
  font-weight: 750;
  line-height: 1.35;
}

.csv-ai-process-note {
  margin: 0 0 1rem;
  padding: .7rem .85rem;
  border: 1px solid #fde68a;
  border-radius: 14px;
  background: #fffbeb;
  color: #92400e;
  font-size: .82rem;
  font-weight: 850;
  line-height: 1.55;
}

.csv-ai-save-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
  padding-top: .2rem;
}

.csv-ai-preview-card {
  display: grid;
  gap: .85rem;
  padding: .9rem;
  border: 1px solid #dbe3ef;
  border-radius: 14px;
  background: #fff;
}

.csv-ai-preview-summary {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: .55rem;
}

.csv-ai-preview-summary div {
  min-width: 0;
  padding: .65rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f8fafc;
}

.csv-ai-preview-summary span,
.csv-ai-preview-summary strong {
  display: block;
}

.csv-ai-preview-summary span {
  color: #64748b;
  font-size: .76rem;
  font-weight: 850;
}

.csv-ai-preview-summary strong {
  color: #0f172a;
  font-size: 1.05rem;
  font-weight: 950;
}

.csv-ai-format-help,
.csv-ai-row-details {
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #fff;
}

.csv-ai-format-help {
  padding: .7rem .85rem;
}

.csv-ai-format-help summary,
.csv-ai-row-details summary {
  cursor: pointer;
  color: #334155;
  font-weight: 900;
}

.csv-ai-format-help .exam-workbook-tags {
  margin-top: .75rem;
}

.csv-ai-format-help p {
  margin: .75rem 0 0;
}

.csv-ai-row-details {
  display: block;
}

.csv-ai-row-details summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  list-style: none;
}

.csv-ai-row-details summary::-webkit-details-marker {
  display: none;
}

.csv-ai-row-details summary::after {
  content: "펼치기";
  flex: 0 0 auto;
  color: #2563eb;
  font-size: .78rem;
  font-weight: 950;
}

.csv-ai-row-details[open] summary {
  margin-bottom: .75rem;
}

.csv-ai-row-details[open] summary::after {
  content: "접기";
}

.csv-ai-row-details summary span,
.csv-ai-row-details summary small {
  display: block;
}

.csv-ai-row-details summary small {
  color: #64748b;
  font-size: .78rem;
  font-weight: 750;
}

.csv-ai-flow-note {
  padding: .85rem 1rem;
  border: 1px solid #dbeafe;
  border-radius: 12px;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 850;
}

.csv-ai-preview-list {
  display: grid;
  gap: .75rem;
}

.csv-ai-bulk-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .55rem .75rem;
  padding: .75rem .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f8fafc;
}

.csv-ai-bulk-actions .exam-builder-muted {
  margin-left: auto;
  color: #475569;
  font-weight: 850;
}

.csv-ai-action-group {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .4rem;
  padding: .35rem;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
}

.csv-ai-action-group > span {
  padding: 0 .3rem;
  color: #64748b;
  font-size: .74rem;
  font-weight: 900;
  white-space: nowrap;
}

.csv-ai-usage {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .55rem;
}

.csv-ai-usage div {
  min-width: 0;
  padding: .6rem;
  border: 1px solid #bfdbfe;
  border-radius: 12px;
  background: #eff6ff;
}

.csv-ai-usage span,
.csv-ai-usage strong {
  display: block;
}

.csv-ai-usage span {
  color: #1d4ed8;
  font-size: .74rem;
  font-weight: 850;
}

.csv-ai-usage strong {
  color: #1e3a8a;
  font-size: .98rem;
  font-weight: 950;
}

.csv-ai-preview-item {
  border-radius: 14px;
}

.csv-ai-preview-item .question-preview-card-head {
  align-items: center;
}

.csv-ai-cart-check {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  gap: .45rem;
  min-height: 34px;
  padding: .35rem .55rem;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  background: #fff;
  color: #334155;
  font-size: .8rem;
  font-weight: 900;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px rgba(148, 163, 184, .08);
}

.csv-ai-cart-check input {
  width: 1rem;
  height: 1rem;
  accent-color: #16a34a;
}

.csv-ai-cart-check:has(input:checked),
.csv-ai-cart-check.is-selected {
  border-color: #86efac;
  background: #dcfce7;
  color: #166534;
  box-shadow: inset 0 0 0 1px rgba(22, 163, 74, .12);
}

.csv-ai-cart-check:has(input:disabled),
.csv-ai-cart-check.is-disabled {
  cursor: not-allowed;
  opacity: .72;
  border-color: #dbe3ef;
  background: #f8fafc;
  color: #64748b;
}

.csv-ai-cart-check.is-carted:not(.is-selected) {
  background: #f8fafc;
  color: #64748b;
}

.csv-ai-inline-status {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: .35rem .6rem;
  border: 1px dashed #cbd5e1;
  border-radius: 10px;
  color: #64748b;
  font-size: .8rem;
  font-weight: 850;
}

.csv-ai-cart-guide {
  padding: .7rem .8rem;
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  background: #f8fafc;
  color: #475569;
  font-size: .84rem;
  font-weight: 850;
  line-height: 1.5;
}

.csv-ai-validation-detail {
  margin-top: .8rem;
  padding: .8rem;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  background: #fff;
  color: #334155;
}

.csv-ai-validation-detail strong {
  display: block;
  margin-bottom: .35rem;
  color: #0f172a;
}

.csv-ai-validation-detail p {
  margin: .25rem 0 0;
  font-size: .86rem;
  line-height: 1.5;
}

.csv-ai-validation-detail span {
  font-weight: 900;
  color: #475569;
}

.csv-ai-edit-panel {
  margin-top: .1rem;
}

.question-gemini-log-summary {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: .55rem;
}

.question-gemini-log-summary div {
  min-width: 0;
  padding: .65rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f8fafc;
}

.question-gemini-log-summary span,
.question-gemini-log-summary b {
  display: block;
}

.question-gemini-log-summary span {
  color: #64748b;
  font-size: .76rem;
}

.question-gemini-log-summary b {
  margin-top: .15rem;
  color: #0f172a;
  font-size: .98rem;
}

.question-gemini-log-list {
  display: grid;
  gap: .55rem;
}

.question-gemini-log-item {
  padding: .7rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #fff;
}

.question-gemini-log-head,
.question-gemini-log-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem .65rem;
  align-items: center;
}

.question-gemini-log-head {
  justify-content: space-between;
  color: #475569;
}

.question-gemini-log-meta {
  margin-top: .45rem;
  color: #64748b;
  font-size: .78rem;
}

.question-gemini-log-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .15rem .5rem;
  border-radius: 999px;
  background: #e2e8f0;
  color: #334155;
  font-size: .76rem;
  font-weight: 950;
}

.question-gemini-log-badge.status-success {
  background: #dcfce7;
  color: #166534;
}

.question-gemini-log-badge.status-failed {
  background: #fee2e2;
  color: #991b1b;
}

.question-gemini-log-badge.status-blocked,
.question-gemini-log-badge.status-disabled {
  background: #fef3c7;
  color: #92400e;
}

.question-gemini-status-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
  gap: .55rem;
}

.question-gemini-status-grid div {
  min-width: 0;
  padding: .6rem;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #f8fafc;
}

.question-gemini-status-grid span,
.question-gemini-status-grid b {
  display: block;
}

.question-gemini-status-grid span {
  color: #64748b;
  font-size: .74rem;
}

.question-gemini-status-grid b {
  margin-top: .12rem;
  min-width: 0;
  overflow-wrap: anywhere;
  color: #0f172a;
  font-size: .92rem;
}

.question-import-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .7rem;
}

.question-import-message {
  color: #475569;
  font-size: .88rem;
  font-weight: 800;
}

.text-ai-structure-loading {
  margin-top: .9rem;
}

.text-ai-structure-loading-card {
  display: flex;
  align-items: center;
  gap: .85rem;
  padding: .9rem 1rem;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(15, 23, 42, .10);
}

.text-ai-structure-loading-card strong {
  display: block;
  color: #0f172a;
  font-size: .95rem;
  font-weight: 950;
}

.text-ai-structure-loading-card p {
  margin: .2rem 0 0;
  color: #64748b;
  font-size: .84rem;
  line-height: 1.45;
}

.text-ai-structure-spinner {
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
  border: 3px solid #e2e8f0;
  border-top-color: #0f172a;
  border-radius: 999px;
  animation: text-ai-spin .8s linear infinite;
}

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

.question-gemini-mock-result {
  padding: .85rem .95rem;
  border: 1px solid #bfdbfe;
  border-radius: 14px;
  background: #fff;
  color: #334155;
  font-size: .86rem;
  font-weight: 750;
  line-height: 1.6;
}

.question-gemini-mock-result strong,
.question-gemini-mock-result span {
  display: block;
}

.question-gemini-mock-result details {
  margin-top: .65rem;
}

.question-gemini-mock-result summary {
  cursor: pointer;
  color: #1d4ed8;
  font-weight: 900;
}

.question-gemini-mock-result pre {
  max-height: 220px;
  overflow: auto;
  margin: .55rem 0 0;
  padding: .75rem;
  border-radius: 10px;
  background: #0f172a;
  color: #e2e8f0;
  font-size: .78rem;
  white-space: pre-wrap;
}


/* Manual create and workbook builder (from exam_page.css lines 1406-2055) */
.manual-question-panel {
  min-width: 0;
}

.manual-question-grid,
.manual-question-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
}

.manual-question-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
  gap: 1rem;
  align-items: start;
  width: 100%;
  min-width: 0;
}

.manual-question-card {
  padding: 1.15rem;
}

.manual-form-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: .8rem;
  padding: 1rem 1.15rem;
  background: #f8fafc;
}

.manual-question-section {
  display: grid;
  gap: .95rem;
}

.manual-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
}

.manual-field-grid-answer {
  grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
}

.manual-field,
.manual-choice-list {
  display: grid;
  gap: .45rem;
  min-width: 0;
}

.manual-field label,
.manual-option-row label {
  color: #334155;
  font-size: .83rem;
  font-weight: 900;
}

.manual-field input,
.manual-field select,
.manual-field textarea,
.manual-option-row input {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--exam-line);
  border-radius: 12px;
  padding: .68rem .8rem;
  background: #f8fafc;
  color: #0f172a;
  font-size: .92rem;
  font-weight: 700;
  outline: none;
}

.manual-field textarea {
  min-height: 140px;
  resize: vertical;
  line-height: 1.65;
}

.manual-field input:focus,
.manual-field select:focus,
.manual-field textarea:focus,
.manual-option-row input:focus {
  border-color: #0f172a;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(15, 23, 42, .08);
}

.manual-field-wide {
  min-width: 0;
}

.manual-choice-list {
  gap: .65rem;
}

.manual-option-row {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  align-items: center;
  gap: .65rem;
}

.manual-image-placeholder {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  margin-top: .85rem;
  padding: .9rem;
  border: 1px dashed #cbd5e1;
  border-radius: 16px;
  background: #f8fafc;
}

.manual-image-placeholder strong {
  display: block;
  color: #0f172a;
  font-size: .92rem;
  font-weight: 900;
}

.manual-image-placeholder p {
  margin: .25rem 0 0;
  color: #64748b;
  font-size: .86rem;
  font-weight: 700;
  line-height: 1.55;
}

.manual-image-placeholder .exam-builder-btn[disabled] {
  cursor: not-allowed;
  opacity: .65;
}

.manual-check-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}

.manual-check {
  display: flex;
  align-items: center;
  gap: .5rem;
  min-height: 44px;
  padding: .7rem .8rem;
  border: 1px solid var(--exam-line);
  border-radius: 999px;
  background: #f8fafc;
  color: #334155;
  font-size: .88rem;
  font-weight: 850;
}

.manual-check input {
  width: 16px;
  height: 16px;
}

.manual-action-card {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.manual-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

.manual-draft-side {
  display: grid;
  gap: .8rem;
  padding: 1.15rem;
  align-content: start;
}

.manual-question-side {
  background: #fff;
}

.manual-draft-empty {
  padding: 1rem;
  border: 1px dashed #cbd5e1;
  border-radius: 16px;
  background: #f8fafc;
  color: #64748b;
  font-size: .9rem;
  font-weight: 750;
  line-height: 1.65;
}

.manual-draft-list {
  display: grid;
  gap: .7rem;
}

.manual-draft-item {
  display: grid;
  gap: .55rem;
  padding: .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
}

.manual-draft-item-title {
  margin: 0;
  color: #0f172a;
  font-size: .92rem;
  font-weight: 950;
  line-height: 1.45;
}

.manual-draft-item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  color: #64748b;
  font-size: .78rem;
  font-weight: 850;
}

.manual-draft-item-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .45rem;
}

.manual-draft-item-actions .exam-builder-btn {
  min-height: 34px;
  padding: .42rem .55rem;
}

.manual-draft-note {
  padding: .75rem .85rem;
  border-radius: 14px;
  background: #f8fafc;
  color: #64748b;
  font-size: .82rem;
  font-weight: 800;
  line-height: 1.55;
}

.question-workbook-placeholder-grid {
  grid-template-columns: minmax(0, 1fr);
}

.workbook-field-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
}

.workbook-field-wide {
  grid-column: 1 / -1;
}

.workbook-field-wide textarea {
  min-height: 110px;
}

.workbook-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: .95rem;
}

.workbook-source-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.workbook-source-card {
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  align-content: stretch;
  gap: .8rem;
  min-height: 245px;
}

.workbook-source-head {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  min-width: 0;
}

.workbook-source-icon {
  display: inline-grid;
  flex: 0 0 auto;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: .82rem;
  font-weight: 950;
}

.workbook-source-count {
  justify-self: start;
}

.workbook-source-note {
  margin: 0;
  color: #64748b;
  font-size: .83rem;
  font-weight: 750;
  line-height: 1.55;
}

.workbook-selected-card {
  display: grid;
  gap: .9rem;
}

.workbook-recent-card {
  display: grid;
  gap: .9rem;
}

.workbook-selected-empty {
  padding: .9rem 1rem;
  border: 1px dashed #cbd5e1;
  border-radius: 16px;
  background: #f8fafc;
  color: #64748b;
  font-size: .9rem;
  font-weight: 750;
  line-height: 1.6;
}

.workbook-sample-list {
  display: grid;
  gap: .7rem;
}

.workbook-recent-list {
  display: grid;
  gap: .7rem;
}

.workbook-cart-card {
  display: grid;
  gap: .9rem;
}

.workbook-cart-list {
  display: grid;
  gap: .7rem;
}

.workbook-cart-item {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr) auto;
  gap: .85rem;
  align-items: center;
  padding: .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
}

.workbook-cart-index {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: #ecfdf5;
  color: #047857;
  font-size: .86rem;
  font-weight: 950;
}

.workbook-cart-item h3 {
  margin: 0;
  color: #0f172a;
  font-size: .94rem;
  font-weight: 950;
  line-height: 1.45;
}

.workbook-cart-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.workbook-recent-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .8rem;
  align-items: center;
  padding: .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
}

.workbook-recent-item h3 {
  margin: 0;
  color: #0f172a;
  font-size: .94rem;
  font-weight: 950;
  line-height: 1.45;
}

.workbook-save-result {
  display: grid;
  gap: .45rem;
  width: 100%;
  padding: .9rem 1rem;
  border: 1px solid #bbf7d0;
  border-radius: 16px;
  background: #f0fdf4;
  color: #166534;
  font-size: .9rem;
  font-weight: 800;
  line-height: 1.6;
}

.workbook-save-result strong {
  color: #14532d;
  font-size: .96rem;
  font-weight: 950;
}

.workbook-save-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .35rem;
}

.workbook-detail-card {
  width: 100%;
}

.workbook-detail-result {
  display: grid;
  gap: .85rem;
  margin-top: .85rem;
}

.workbook-detail-summary {
  display: grid;
  gap: .25rem;
  padding: .85rem 1rem;
  border: 1px solid #bfdbfe;
  border-radius: 14px;
  background: #eff6ff;
  color: #1e3a8a;
  font-size: .9rem;
  font-weight: 850;
}

.workbook-detail-summary strong {
  color: #172554;
  font-size: .98rem;
}

.workbook-detail-status-note {
  color: #92400e;
  font-size: .84rem;
  font-weight: 800;
}

.workbook-detail-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
}

.workbook-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.workbook-detail-order-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  align-items: center;
}

.workbook-detail-items {
  display: grid;
  gap: .6rem;
}

.workbook-detail-items > strong {
  color: #0f172a;
  font-size: .92rem;
  font-weight: 950;
}

.workbook-detail-item {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: start;
  padding: .8rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #fff;
}

.workbook-detail-item > span {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: #f1f5f9;
  color: #0f172a;
  font-weight: 950;
}

.workbook-detail-item h3,
.workbook-detail-item p {
  margin: 0;
}

.workbook-detail-item h3 {
  color: #0f172a;
  font-size: .9rem;
  font-weight: 950;
}

.workbook-detail-item p {
  margin-top: .25rem;
  color: #475569;
  font-size: .86rem;
  font-weight: 750;
  line-height: 1.45;
}

.workbook-detail-item small {
  display: block;
  margin-top: .3rem;
  color: #64748b;
  font-weight: 800;
}

.workbook-detail-item-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .45rem;
}

.workbook-sample-item {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) minmax(220px, auto);
  gap: .8rem;
  align-items: center;
  padding: .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
}

.workbook-sample-index {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: #f1f5f9;
  color: #0f172a;
  font-weight: 950;
}

.workbook-sample-item h3 {
  margin: 0;
  color: #0f172a;
  font-size: .94rem;
  font-weight: 950;
  line-height: 1.45;
}

.workbook-sample-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-top: .4rem;
}

.workbook-sample-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .18rem .48rem;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #f8fafc;
  color: #64748b;
  font-size: .76rem;
  font-weight: 850;
  line-height: 1;
}

.workbook-sample-meta .workbook-source-badge {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
}

.workbook-sample-meta .workbook-source-badge.upload {
  border-color: #ddd6fe;
  background: #f5f3ff;
  color: #6d28d9;
}

.workbook-sample-meta .workbook-state-badge {
  border-color: #fed7aa;
  background: #fff7ed;
  color: #c2410c;
}

.workbook-sample-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .45rem;
}

.workbook-sample-actions .exam-builder-btn {
  min-height: 34px;
  padding: .42rem .55rem;
}


/* Text AI candidate action bars (from exam_page.css lines 2079-2108) */
.text-ai-candidate-action-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .8rem;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
}

.text-ai-candidate-action-bar[hidden] {
  display: none;
}

.text-ai-candidate-action-bar-top {
  margin-top: -.15rem;
}

.text-ai-candidate-action-bar-bottom {
  justify-content: flex-end;
}

.text-ai-candidate-action-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .45rem;
}


/* Text AI candidate badges and cart confirmation modal (from exam_page.css lines 2128-2319) */
.question-preview-card.text-ai-candidate-card.is-selected {
  border-color: #86efac;
  background: #f0fdf4;
}

.text-ai-select-check {
  align-self: start;
}

.question-candidate-badges,
.text-ai-candidate-meta-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
  margin-top: .45rem;
}

.question-candidate-badges span,
.text-ai-candidate-meta-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .18rem .5rem;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #f8fafc;
  color: #475569;
  font-size: .74rem;
  font-weight: 900;
  line-height: 1;
}

.question-candidate-badges span.is-warning,
.text-ai-candidate-meta-badges span.is-warning {
  border-color: #fde68a;
  background: #fffbeb;
  color: #92400e;
}

.question-candidate-badges span.is-info,
.text-ai-candidate-meta-badges span.is-info {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
}

.question-candidate-badges span.is-policy,
.text-ai-candidate-meta-badges span.is-policy {
  border-color: #bbf7d0;
  background: #ecfdf5;
  color: #166534;
}

.text-ai-cart-modal[hidden] {
  display: none;
}

.text-ai-cart-modal {
  position: fixed;
  inset: 0;
  z-index: 3000;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.text-ai-cart-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .46);
}

.text-ai-cart-dialog {
  position: relative;
  z-index: 1;
  width: min(680px, 100%);
  max-height: min(760px, calc(100vh - 2rem));
  overflow: auto;
  display: grid;
  gap: 1rem;
  padding: 1.15rem;
  border: 1px solid #e2e8f0;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 24px 60px rgba(15, 23, 42, .22);
}

.text-ai-cart-dialog-head h3 {
  margin: 0;
  color: #0f172a;
  font-size: 1.08rem;
  font-weight: 950;
  line-height: 1.35;
}

.text-ai-cart-dialog-head p {
  margin: .35rem 0 0;
  color: #64748b;
  font-size: .9rem;
  font-weight: 700;
  line-height: 1.55;
}

.text-ai-cart-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .65rem;
}

.question-candidate-modal-summary-card,
.text-ai-cart-summary-card {
  min-height: 84px;
  display: grid;
  align-content: center;
  gap: .25rem;
  padding: .75rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #f8fafc;
}

.question-candidate-modal-summary-card span,
.text-ai-cart-summary-card span {
  color: #64748b;
  font-size: .78rem;
  font-weight: 850;
  line-height: 1.35;
}

.question-candidate-modal-summary-card strong,
.text-ai-cart-summary-card strong {
  color: #0f172a;
  font-size: 1.35rem;
  font-weight: 950;
  line-height: 1;
}

.question-candidate-modal-summary-card.is-ok,
.text-ai-cart-summary-card.is-ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.question-candidate-modal-summary-card.is-warning,
.text-ai-cart-summary-card.is-warning {
  border-color: #fde68a;
  background: #fffbeb;
}

.question-candidate-modal-summary-card.is-danger,
.text-ai-cart-summary-card.is-danger {
  border-color: #fecaca;
  background: #fef2f2;
}

.text-ai-cart-warning {
  padding: .8rem .9rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #f8fafc;
  color: #475569;
  font-size: .9rem;
  font-weight: 800;
  line-height: 1.55;
}

.text-ai-cart-warning.is-ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #166534;
}

.text-ai-cart-warning.is-warning {
  border-color: #fde68a;
  background: #fffbeb;
  color: #92400e;
}

.text-ai-cart-warning.is-danger {
  border-color: #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.text-ai-cart-dialog-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .5rem;
}

body.text-ai-cart-modal-open {
  overflow: hidden;
}

/* Text AI TTS and answer validation panels (from exam_page.css lines 2579-2719) */
.text-ai-tts-panel {
  display: grid;
  gap: .65rem;
  padding: .78rem .85rem;
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: #f8fbff;
}

.text-ai-tts-panel.is-ready {
  border-color: #bbf7d0;
  background: #f7fef9;
}

.text-ai-tts-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .85rem;
}

.text-ai-tts-panel-head > div {
  display: grid;
  gap: .18rem;
  min-width: 0;
}

.text-ai-tts-panel-head strong {
  margin: 0;
}

.text-ai-tts-panel-head span,
.text-ai-tts-meta,
.text-ai-tts-message {
  color: #64748b;
  font-size: .82rem;
  font-weight: 750;
  line-height: 1.45;
}

.text-ai-tts-message {
  margin: 0;
}

.text-ai-tts-message.is-error {
  color: #b91c1c;
}

.text-ai-tts-player {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}

.text-ai-tts-player audio {
  width: min(100%, 420px);
  min-width: 240px;
}

.text-ai-tts-player.is-disabled {
  opacity: .72;
}

.text-ai-tts-meta {
  margin: 0;
}

.question-candidate-validation,
.text-ai-answer-validation-card {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .55rem;
  padding: .75rem .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #f8fafc;
}

.question-candidate-validation > div,
.text-ai-answer-validation-card > div {
  display: grid;
  gap: .16rem;
}

.question-candidate-validation span,
.text-ai-answer-validation-card span {
  color: #64748b;
  font-size: .72rem;
  font-weight: 850;
}

.question-candidate-validation strong,
.text-ai-answer-validation-card strong {
  color: #0f172a;
  font-size: .9rem;
  font-weight: 950;
}

.question-candidate-validation p,
.text-ai-answer-validation-card p {
  grid-column: 1 / -1;
  margin: .1rem 0 0;
  color: #475569;
  font-size: .82rem;
  line-height: 1.45;
}

.question-candidate-validation.is-ok,
.text-ai-answer-validation-card.is-ok {
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.question-candidate-validation.is-warning,
.text-ai-answer-validation-card.is-warning {
  border-color: #fde68a;
  background: #fffbeb;
}

.question-candidate-validation.is-muted,
.text-ai-answer-validation-card.is-muted {
  border-color: #e2e8f0;
  background: #f8fafc;
}

@media (max-width: 640px) {
  .question-candidate-validation,
  .text-ai-answer-validation-card {
    grid-template-columns: 1fr;
  }

  .text-ai-edit-action-row {
    align-items: stretch;
    flex-direction: column;
  }

  .text-ai-edit-action-buttons {
    justify-content: flex-start;
  }
}

/* Text AI edit action rows (from exam_page.css lines 2946-2979) */
.text-ai-edit-action-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  padding: .78rem .85rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #fff;
}

.text-ai-edit-action-row > div:first-child {
  display: grid;
  gap: .18rem;
  min-width: 0;
}

.text-ai-edit-action-row strong {
  color: #0f172a;
  font-size: .95rem;
  font-weight: 950;
}

.text-ai-edit-action-row span {
  color: #64748b;
  font-size: .8rem;
  font-weight: 800;
}

.text-ai-edit-action-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .5rem;
  flex: 0 0 auto;
}

/* Text AI edit collapse, choices, short answer, and image controls (from exam_page.css lines 3002-3187) */
.text-ai-edit-collapse {
  display: grid;
  gap: .7rem;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #fff;
  padding: .78rem;
}

.text-ai-edit-collapse summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  cursor: pointer;
  color: #0f172a;
  font-size: .9rem;
  font-weight: 950;
  list-style: none;
}

.text-ai-edit-collapse summary::-webkit-details-marker {
  display: none;
}

.text-ai-edit-collapse summary::after {
  content: "열기";
  color: #2563eb;
  font-size: .78rem;
  font-weight: 950;
}

.text-ai-edit-collapse[open] summary::after {
  content: "닫기";
}

.text-ai-edit-collapse summary b {
  margin-left: auto;
  padding: .18rem .5rem;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #f8fafc;
  color: #64748b;
  font-size: .73rem;
  font-weight: 900;
  line-height: 1;
}

.text-ai-edit-collapse .manual-field {
  margin-top: .7rem;
}

.text-ai-choice-edit-list {
  display: grid;
  gap: .55rem;
}

.is-hidden,
.text-ai-choice-edit-list.is-hidden {
  display: none !important;
}

.text-ai-short-answer-box {
  padding: .8rem;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
  background: #f8fafc;
}

.text-ai-short-answer-box strong {
  display: block;
  margin-bottom: .3rem;
  color: #334155;
  font-size: .82rem;
  font-weight: 950;
}

.text-ai-short-answer-box p {
  margin: 0;
  color: #0f172a;
  font-weight: 800;
}

.text-ai-choice-edit-row {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: start;
  gap: .55rem;
  min-width: 0;
}

.text-ai-choice-edit-row > span {
  min-height: 40px;
  display: flex;
  align-items: center;
  color: #334155;
  font-size: .84rem;
  font-weight: 950;
  line-height: 1.35;
}

.question-preview-edit-panel .text-ai-choice-textarea {
  box-sizing: border-box;
  display: block;
  width: 100%;
  min-height: 42px !important;
  height: 42px;
  max-height: 160px;
  overflow-y: hidden;
  resize: none;
  border: 1px solid var(--exam-line);
  border-radius: 12px;
  padding: .58rem .72rem;
  background: #f8fafc;
  color: #0f172a;
  font-size: .92rem;
  font-weight: 700;
  line-height: 1.45;
  outline: none;
}

.question-preview-edit-panel .text-ai-choice-textarea:focus {
  border-color: #0f172a;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(15, 23, 42, .08);
}

.question-preview-edit-panel .text-ai-choice-textarea.is-expanded {
  overflow-y: auto;
}

.text-ai-edit-inline-grid {
  display: grid;
  grid-template-columns: minmax(160px, 240px) minmax(0, 1fr);
  gap: .75rem;
}

.text-ai-edit-image-box {
  display: grid;
  gap: .75rem;
  margin-top: .7rem;
}

.text-ai-edit-image-check {
  justify-content: flex-start;
}

.text-ai-edit-image-upload input[type="file"] {
  padding: .58rem .7rem;
}

.text-ai-edit-image-preview {
  display: none;
  align-items: center;
  gap: .7rem;
  min-height: 56px;
  padding: .65rem;
  border: 1px dashed #cbd5e1;
  border-radius: 14px;
  background: #f8fafc;
  color: #475569;
  font-size: .84rem;
  font-weight: 850;
}

.text-ai-edit-image-preview.is-open,
.text-ai-edit-image-preview.is-error {
  display: flex;
}

.text-ai-edit-image-preview.is-error {
  border-color: #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.text-ai-edit-image-preview img {
  width: 56px;
  height: 56px;
  object-fit: cover;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: #fff;
}

.text-ai-edit-image-box p {
  margin: 0;
  color: #64748b;
  font-size: .82rem;
  font-weight: 750;
  line-height: 1.55;
}
