/* Shared */
.fastquiz-form { border:1px solid #e5e7eb; padding:16px; margin:16px 0; background:#fff; border-radius:8px; }
.fq-question { padding:14px; background:#f3f4f6; margin-bottom:12px; border-radius:6px; }
.fq-qtitle { font-weight:600; margin-bottom:10px; }
.fq-options-wrap { display:grid; grid-template-columns:1fr; gap:8px; }
.fq-option { display:block; padding:10px; background:#fff; border:1px solid #e5e7eb; border-radius:6px; }
.fq-option input { margin-right:6px; }
.fq-option .fq-explanation{ display:none; margin-top:6px; }
.fq-option.fq-selected .fq-explanation { display:block; }
.fq-image { width:240px; height:160px; overflow:hidden; border:1px solid #e5e7eb; border-radius:6px; }
.fq-image img { width:100%; height:100%; object-fit:cover; display:block; }
.fq-submit { display:inline-block; padding:10px 16px; background:#111827; color:#fff; border:none; border-radius:6px; cursor:pointer; }
.fastquiz-result { padding:16px; border:2px solid #d1d5db; background:#f9fafb; border-radius:8px; margin-bottom:16px; }
.fastquiz-error { padding:10px; background:#fff7ed; border:1px solid #fed7aa; border-radius:6px; }
/* Stepper */
.fq-steps-nav { display:flex; gap:8px; flex-wrap:wrap; margin:10px 0 12px; }
.fq-step-tab { border:1px solid #e5e7eb; background:#fff; padding:6px 10px; border-radius:6px; cursor:pointer; }
.fq-step-tab.active { background:#111827; color:#fff; border-color:#111827; }
.fq-progress { height:6px; background:#e5e7eb; border-radius:999px; overflow:hidden; margin-bottom:12px; }
.fq-progress .bar { height:100%; width:0; background:#111827; }
/* Controls */
.fq-controls { display:flex; gap:10px; margin-top:12px; }
.fq-prev, .fq-next { padding:8px 12px; border:1px solid #e5e7eb; background:#fff; border-radius:6px; cursor:pointer; }
.fq-prev[disabled] { opacity:.5; cursor:not-allowed; }
/* Admin */
.fq-admin .fq-row { margin-bottom:10px; }
.fq-admin .fq-row label { display:block; font-weight:600; margin-bottom:4px; }
.fq-admin .fq-repeater .fq-item { background:#fff; border:1px solid #e5e7eb; padding:10px; border-radius:6px; margin-bottom:8px; }
.fq-admin .fq-options-head { font-weight:700; margin:6px 0; }
.fq-admin .fq-row.three { display:flex; gap:10px; }
.fq-admin .fq-row.three > div { flex:1; }
.fq-admin .button.fq-remove { background:#fee2e2; border-color:#fecaca; }
.fq-media { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.fq-media-preview img { width:80px; height:80px; object-fit:cover; border-radius:6px; border:1px solid #e5e7eb; }
.fq-again { display:inline-block; padding:10px 16px; background:#111827; color:#fff; border:none; border-radius:6px; cursor:pointer; }
