/* PlaitoMaths quiz editor — builds on tutor.css + tokens.css */
.picker { font: inherit; padding: 7px 10px; border: 1.5px solid var(--border-2); border-radius: var(--r-sm); background: var(--surface); }
.picker.tl { width: 72px; }
.save-state { font-size: var(--fs-sm); color: var(--ink-3); min-width: 90px; text-align: right; }
.save-state.ok { color: var(--ok); font-weight: 700; }
.save-state.dirty { color: var(--amber); font-weight: 700; }
.save-state.err { color: var(--bad); font-weight: 700; }

.ed-main { max-width: 1180px; margin: 0 auto; padding: var(--sp-5);
  display: grid; grid-template-columns: 320px 1fr; gap: var(--sp-5); align-items: start; }
.ed-nav { padding: var(--sp-4); max-height: calc(100dvh - 120px); overflow-y: auto; }
.ed-form { padding: var(--sp-5); min-height: 60vh; }

/* nav tree */
.nav-sec { margin-bottom: var(--sp-4); }
.nav-sec > h4 { margin: 0 0 6px; font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: .03em; color: var(--ink-3); }
.qnav { display: grid; gap: 5px; }
.qnav-item { display: flex; align-items: center; gap: 6px; padding: 8px 10px; border: 1px solid var(--border);
  border-radius: var(--r-sm); background: var(--surface-2); cursor: pointer; font: inherit; text-align: left; }
.qnav-item:hover { border-color: var(--brand); }
.qnav-item.active { border-color: var(--brand); background: var(--brand-50); }
.qnav-item .qn { font-weight: 800; color: var(--ink-2); flex: none; min-width: 18px; }
.qnav-item .qt { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: var(--fs-sm); color: var(--ink); }
.qnav-item .mv { display: flex; flex-direction: column; gap: 1px; }
.qnav-item .mv button { border: 0; background: transparent; cursor: pointer; font-size: .7rem; line-height: 1; color: var(--ink-3); padding: 0 2px; }
.qnav-item .mv button:hover { color: var(--brand); }
.add-q { width: 100%; margin-top: 6px; }
.pass-btn { width: 100%; margin-bottom: 6px; }
.pass-btn.active { background: var(--brand-50); border-color: var(--brand); }
.pass-card { border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-4); margin-bottom: var(--sp-4); background: var(--surface-2); }
.pass-card .fld textarea { font: inherit; }

/* form */
.ed-row { display: flex; align-items: center; gap: var(--sp-3); }
.ed-head { margin-bottom: var(--sp-4); }
.qid-chip { font-size: .78rem; font-weight: 800; padding: 4px 10px; border-radius: var(--r-pill); background: var(--brand-50); color: var(--brand-700); }
.ed-2col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.fld textarea, .fld select { display: block; width: 100%; margin-top: 6px; padding: 10px 12px; font: inherit;
  border: 1.5px solid var(--border-2); border-radius: var(--r-sm); background: var(--surface); box-sizing: border-box; }
.fld textarea { resize: vertical; line-height: 1.45; }
.hint { font-size: var(--fs-sm); color: var(--ink-3); margin: 6px 0 0; }
.btn.sm { padding: 6px 12px; font-size: var(--fs-sm); }
.btn.danger { color: var(--bad); border-color: var(--bad); }

/* images */
.img-list { display: grid; gap: 8px; margin-top: 6px; }
.img-row { display: flex; align-items: center; gap: 10px; padding: 8px; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--surface-2); }
.img-row img { width: 64px; height: 48px; object-fit: contain; background: #fff; border: 1px solid var(--border-2); border-radius: 4px; flex: none; }
.img-row .u { flex: 1; font-size: var(--fs-sm); color: var(--ink-2); word-break: break-all; }
.img-row button { border: 0; background: transparent; color: var(--bad); cursor: pointer; font-size: 1rem; }
.img-actions { display: flex; align-items: center; gap: 10px; margin-top: 8px; }

/* choices */
.choice-list { display: grid; gap: 8px; margin-top: 6px; }
.choice-row { display: flex; align-items: center; gap: 10px; }
.choice-row input[type=radio] { width: 18px; height: 18px; flex: none; }
.choice-row .cid { width: 42px; flex: none; text-align: center; font-weight: 800; padding: 9px 0; border: 1.5px solid var(--border-2); border-radius: var(--r-sm); background: var(--surface); }
.choice-row .ctext { flex: 1; padding: 9px 12px; font: inherit; border: 1.5px solid var(--border-2); border-radius: var(--r-sm); }
.choice-row .rm { border: 0; background: transparent; color: var(--bad); cursor: pointer; font-size: 1.05rem; }
.choice-row.correct .ctext { border-color: var(--ok); background: #f0fdf4; }

@media (max-width: 820px) { .ed-main { grid-template-columns: 1fr; } .ed-2col { grid-template-columns: 1fr; } }
