:root{--primary: #2D6BFF;--primary-hover: #1F57DB;--primary-tint: #EAF1FF;--primary-tint-2: #DCE7FF;--navy: #1B2B4B;--navy-2: #243962;--navy-border: #2A3F5F;--teal: #4DB8C8;--teal-soft: #E1F2F5;--bg: #F4F6FA;--bg-deep: #EAEEF5;--surface: #FFFFFF;--surface-2: #F8FAFC;--surface-3: #EEF2F8;--ink: #111827;--ink-2: #1F2937;--ink-soft: #6B7280;--ink-mute: #9CA3AF;--line: #E5E9F2;--line-strong: #D1D5DB;--accent: var(--teal);--accent-soft: var(--teal-soft);--ai: var(--primary);--ai-soft: var(--primary-tint);--ok: #16A34A;--warn: #B45309;--err: #DC2626;--shadow-sm: 0 1px 0 rgba(17, 24, 39, .03), 0 1px 2px rgba(17, 24, 39, .05);--shadow-md: 0 4px 16px -8px rgba(17, 24, 39, .18), 0 1px 2px rgba(17, 24, 39, .05);--shadow-lg: 0 24px 60px -20px rgba(27, 43, 75, .3), 0 8px 16px -8px rgba(17, 24, 39, .1);--shadow-focus: 0 0 0 3px rgba(45, 107, 255, .18);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:Geist,system-ui,sans-serif;font-feature-settings:"ss01","cv11";background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea,select{font:inherit;color:inherit}.app{height:100vh;display:grid;grid-template-rows:56px 1fr;background:var(--bg)}.topbar{display:flex;align-items:center;gap:12px;padding:0 14px 0 16px;border-bottom:1px solid var(--line);background:var(--surface);position:relative;z-index:10;min-width:0;overflow:hidden}.brand{min-width:0;flex-shrink:0}.brand>:last-child{white-space:nowrap}.brand{display:flex;align-items:center;gap:10px;font-family:Newsreader,serif;font-weight:600;font-size:17px;color:var(--ink);letter-spacing:-.01em}.brand-mark{width:28px;height:28px;border-radius:7px;background:var(--navy);color:var(--surface);display:grid;place-items:center;font-family:Geist,sans-serif;font-weight:700;font-size:13px;overflow:hidden;flex-shrink:0}.brand-mark img{width:100%;height:100%;object-fit:cover;display:block}.brand-divider{width:1px;height:20px;background:var(--line-strong)}.crumbs{display:flex;align-items:center;gap:8px;color:var(--ink-soft);font-size:13px;min-width:0;flex:0 1 auto;overflow:hidden}.crumbs>span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex-shrink:1}.crumbs .crumb-current{color:var(--ink);font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--r-sm);cursor:pointer;transition:background 80ms;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px;flex-shrink:1;min-width:0}.crumbs .crumb-current:hover{background:var(--surface-3)}.crumbs .sep{opacity:.5}.spacer{flex:1}.topbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.save-indicator{flex-shrink:0}@media (max-width: 1280px){.topbar .save-indicator .save-text{display:none}}@media (max-width: 1180px){.topbar .save-indicator,.topbar-actions .label-collapse{display:none}}@media (max-width: 960px){.topbar .crumbs,.topbar .brand-divider{display:none}}.btn{display:inline-flex;align-items:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;color:var(--ink);cursor:pointer;font-weight:500;font-size:13px;transition:all 80ms;white-space:nowrap}.btn:hover{background:var(--surface-3)}.btn-ghost{color:var(--ink-soft)}.btn-ghost:hover{color:var(--ink)}.btn-secondary{background:var(--surface-2);border-color:var(--line-strong)}.btn-secondary:hover{background:var(--surface-3)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px #1118270d,inset 0 1px #ffffff1f}.btn-primary:hover{background:var(--primary-hover)}.btn-ai{background:var(--navy);color:#fff;background:linear-gradient(180deg,var(--navy-2),var(--navy));box-shadow:0 1px #1118270d,inset 0 1px #ffffff14}.btn-ai:hover{filter:brightness(1.1)}.btn-icon{width:32px;padding:0;justify-content:center}.btn-pill{height:26px;padding:0 10px;border-radius:999px;font-size:12px;background:var(--surface-2);border:1px solid var(--line)}.btn-pill:hover{background:var(--surface-3)}.toggle-group{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:2px;gap:2px}.toggle-group button{border:0;background:transparent;height:26px;padding:0 10px;border-radius:4px;font-size:12px;color:var(--ink-soft);cursor:pointer;font-weight:500}.toggle-group button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 7px;border-radius:999px;font-size:11px;font-weight:500;background:var(--surface-3);color:var(--ink-soft)}.badge.err{background:#fee2e2;color:var(--err)}.badge.ai{background:var(--primary-tint);color:var(--primary)}.badge.draft{background:var(--teal-soft);color:#1d7d8d}.body{display:grid;grid-template-columns:280px 1fr;min-height:0;overflow:hidden}.sidebar{border-right:1px solid var(--line);background:var(--surface);display:flex;flex-direction:column;min-height:0;overflow:hidden}.sidebar-section{padding:14px 16px 8px}.sidebar-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sidebar-label{font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute)}.sidebar-add{width:22px;height:22px;border-radius:5px;border:0;background:transparent;color:var(--ink-soft);cursor:pointer;display:grid;place-items:center}.sidebar-add:hover{background:var(--surface-3);color:var(--ink)}.quiz-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;margin:0 6px;border:1px solid transparent}.quiz-row:hover{background:var(--surface-2)}.quiz-row.active{background:var(--surface-2);border-color:var(--line)}.quiz-row .title{flex:1;font-weight:500;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quiz-row .meta{font-size:11px;color:var(--ink-mute);font-variant-numeric:tabular-nums}.q-list{flex:1;overflow-y:auto;padding:4px 6px 6px;min-height:0}.q-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;margin-bottom:2px;border:1px solid transparent;position:relative}.q-item:hover{background:var(--surface-2)}.q-item.active{background:var(--primary);color:#fff;border-color:var(--primary)}.q-item.active .q-num,.q-item.active .q-type{color:#ffffffb8}.q-item.active .q-status-dot{border-color:#ffffff73}.q-num{font-family:Geist Mono,monospace;font-size:11px;font-weight:500;color:var(--ink-mute);width:22px;font-variant-numeric:tabular-nums}.q-body{flex:1;min-width:0}.q-body .q-text{font-size:13px;font-weight:500;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.q-body .q-text.placeholder{color:var(--ink-mute);font-style:italic;font-weight:400}.q-type{font-size:10.5px;color:var(--ink-mute);letter-spacing:.04em;text-transform:uppercase;margin-top:1px}.q-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.q-status-dot.ok{background:var(--ok)}.q-status-dot.warn{background:var(--warn)}.q-status-dot.draft{background:var(--accent)}.q-status-dot.empty{background:transparent;border:1.5px solid var(--ink-mute)}.q-item.active .q-status-dot.ok{background:#86efac}.q-item.active .q-status-dot.warn{background:#fcd34d}.q-item.active .q-status-dot.draft{background:#fda4af}.sidebar-footer{padding:12px 14px;border-top:1px solid var(--line);background:var(--surface);display:flex;flex-direction:column;gap:6px}.sidebar-add-btn{display:flex;align-items:center;gap:8px;background:transparent;border:1px dashed var(--line-strong);color:var(--ink-soft);border-radius:var(--r-sm);padding:8px 10px;cursor:pointer;font-weight:500;font-size:13px;text-align:left;width:100%}.sidebar-add-btn:hover{background:var(--surface-2);color:var(--ink);border-color:var(--primary)}.ai-cta{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--navy-2),var(--navy));color:#fff;border:0;border-radius:var(--r-md);padding:12px;cursor:pointer;font-weight:500;font-size:13px;text-align:left;width:100%;transition:transform 80ms}.ai-cta:hover{transform:translateY(-1px)}.ai-cta .icon{width:22px;height:22px;border-radius:6px;background:#ffffff24;display:grid;place-items:center}.ai-cta .sub{display:block;font-size:11px;font-weight:400;opacity:.65;margin-top:1px}.canvas{overflow-y:auto;background:var(--bg);position:relative}.canvas-inner{max-width:760px;margin:0 auto;padding:40px 56px 96px}.canvas-header{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:28px}.canvas-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:6px;font-family:Geist Mono,monospace}.canvas-title{font-family:Newsreader,serif;font-size:30px;font-weight:500;letter-spacing:-.015em;line-height:1.1;margin:0;color:var(--ink)}.canvas-meta{display:flex;align-items:center;gap:8px}.field{margin-bottom:22px}.field-label{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:500;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.005em}.field-label .hint{font-weight:400;color:var(--ink-mute);font-size:11.5px}.prompt-area{width:100%;min-height:100px;border:1px solid var(--line-strong);background:var(--surface);border-radius:var(--r-md);padding:14px 16px;font-family:Newsreader,serif;font-size:19px;line-height:1.4;resize:vertical;outline:none;color:var(--ink);transition:border-color 80ms,box-shadow 80ms}.prompt-area:focus{border-color:var(--primary);box-shadow:var(--shadow-focus)}.prompt-area::placeholder{color:var(--ink-mute);font-style:italic}.text-input,.select-input{width:100%;height:36px;padding:0 12px;border-radius:var(--r-sm);border:1px solid var(--line-strong);background:var(--surface);outline:none;font-size:13.5px;color:var(--ink);transition:border-color 80ms,box-shadow 80ms}.text-input:focus,.select-input:focus{border-color:var(--primary);box-shadow:var(--shadow-focus)}textarea.text-input{height:auto;min-height:80px;padding:10px 12px;font-family:inherit;resize:vertical}.meta-strip{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:22px}.meta-strip .meta-chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:var(--r-sm);background:transparent;border:0;cursor:pointer;font-size:13px;font-weight:500;color:var(--ink)}.meta-strip .meta-chip:hover{background:var(--surface)}.meta-strip .meta-chip .label-mute{color:var(--ink-mute);font-weight:400}.meta-strip .meta-divider{width:1px;height:18px;background:var(--line)}.options-list{display:flex;flex-direction:column;gap:6px}.option-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:4px 6px 4px 12px;transition:border-color 80ms,box-shadow 80ms}.option-row:focus-within{border-color:var(--primary);box-shadow:var(--shadow-focus)}.option-row.correct{background:#ecfdf5;border-color:#16a34a52}.option-correct{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line-strong);background:var(--surface);cursor:pointer;display:grid;place-items:center;color:transparent;flex-shrink:0;transition:all 80ms}.option-correct.checked{background:var(--ok);border-color:var(--ok);color:#fff}.option-correct.square{border-radius:5px}.option-input{flex:1;border:0;background:transparent;outline:none;padding:8px 0;font-size:14px;color:var(--ink)}.option-input::placeholder{color:var(--ink-mute)}.option-actions{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity .1s}.option-row:hover .option-actions{opacity:1}.option-action{width:28px;height:28px;border-radius:5px;border:0;background:transparent;color:var(--ink-mute);cursor:pointer;display:grid;place-items:center}.option-action:hover{background:var(--surface-2);color:var(--ink)}.add-option-btn{display:inline-flex;align-items:center;gap:6px;margin-top:8px;height:32px;padding:0 12px;background:transparent;border:0;color:var(--ink-soft);cursor:pointer;border-radius:var(--r-sm);font-size:13px;font-weight:500}.add-option-btn:hover{background:var(--surface-2);color:var(--ink)}.tf-group{display:flex;gap:8px}.tf-option{flex:1;height:64px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-size:15px;font-weight:500;transition:all 80ms}.tf-option:hover{border-color:var(--ink-soft)}.tf-option.correct{background:#ecfdf5;border-color:var(--ok);color:var(--ok)}.accepted-list{display:flex;flex-wrap:wrap;gap:6px;padding:8px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-md);min-height:60px;align-content:flex-start}.accepted-pill{display:inline-flex;align-items:center;gap:4px;height:26px;padding:0 4px 0 10px;border-radius:999px;background:var(--surface-3);font-size:12.5px}.accepted-pill button{width:18px;height:18px;border-radius:50%;border:0;background:transparent;color:var(--ink-mute);cursor:pointer;display:grid;place-items:center}.accepted-pill button:hover{background:#1118270f;color:var(--ink)}.accepted-input{flex:1;min-width:100px;border:0;background:transparent;outline:none;font-size:13px;padding:4px 6px}.ai-hero{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:32px 36px 28px;box-shadow:var(--shadow-sm)}.ai-hero-head{display:flex;align-items:flex-start;gap:18px;margin-bottom:24px}.ai-hero-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--navy));color:#fff;display:grid;place-items:center;flex-shrink:0}.ai-hero-title{font-family:Newsreader,serif;font-size:24px;font-weight:500;letter-spacing:-.015em;margin:0 0 4px}.ai-hero-sub{color:var(--ink-soft);font-size:13.5px}.dropzone{border:1.5px dashed var(--line-strong);border-radius:var(--r-lg);padding:28px;text-align:center;background:var(--surface-2);cursor:pointer;transition:all 80ms}.dropzone:hover{border-color:var(--primary);background:var(--surface)}.dropzone.has-file{border-style:solid;border-color:var(--ok);background:#ecfdf5;text-align:left;padding:16px 20px;display:flex;align-items:center;gap:14px}.dropzone-icon{width:36px;height:36px;border-radius:8px;background:var(--surface-3);display:grid;place-items:center;margin:0 auto 10px;color:var(--ink-soft)}.dropzone.has-file .dropzone-icon{margin:0;background:#fff;color:var(--ok)}.dropzone-title{font-weight:500;font-size:14px}.dropzone-sub{font-size:12px;color:var(--ink-mute);margin-top:2px}.ai-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}.ai-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px}.ai-card-label{font-size:11px;color:var(--ink-soft);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}.stepper{display:flex;align-items:center;justify-content:space-between}.stepper-val{font-family:Newsreader,serif;font-size:26px;font-weight:500;font-variant-numeric:tabular-nums}.stepper-btns{display:flex;gap:4px}.stepper-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;display:grid;place-items:center;color:var(--ink-soft);font-size:14px}.stepper-btn:hover{background:var(--surface-3);color:var(--ink)}.model-pick{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:8px 10px 8px 14px;margin-bottom:14px}.model-name{flex:1;font-size:13px;font-weight:500}.model-name .mute{color:var(--ink-mute);font-weight:400;font-size:12px;margin-left:6px}.btn-generate{width:100%;height:44px;border:0;border-radius:var(--r-md);background:var(--primary);color:#fff;box-shadow:inset 0 1px #ffffff24;font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:8px;transition:filter 80ms,transform 80ms}.btn-generate:hover{filter:brightness(1.1)}.btn-generate:active{transform:scale(.99)}.ai-progress{margin-top:18px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:12px}.spinner{width:16px;height:16px;border:2px solid var(--line-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b2b4b52;z-index:20;opacity:0;pointer-events:none;transition:opacity .16s}.drawer-scrim.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:92vw;background:var(--surface);border-left:1px solid var(--line);z-index:21;transform:translate(100%);transition:transform .22s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.drawer.open{transform:translate(0)}.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 14px;border-bottom:1px solid var(--line)}.drawer-title{font-family:Newsreader,serif;font-size:19px;font-weight:500;margin:0;letter-spacing:-.01em}.drawer-body{flex:1;overflow-y:auto;padding:18px}.validation-row{display:flex;gap:10px;padding:10px 12px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface-2);margin-bottom:6px;cursor:pointer}.validation-row:hover{background:var(--surface-3)}.validation-row .v-icon{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;margin-top:1px}.validation-row.err .v-icon{background:#fee2e2;color:var(--err)}.validation-row.warn .v-icon{background:#fef3c7;color:var(--warn)}.validation-row .v-body{flex:1}.validation-row .v-title{font-weight:500;font-size:13px}.validation-row .v-where{font-size:11.5px;color:var(--ink-mute);margin-top:1px}.tabs{display:flex;gap:2px;margin-bottom:18px;border-bottom:1px solid var(--line)}.tab-btn{background:transparent;border:0;padding:8px 10px;font-size:13px;color:var(--ink-soft);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500}.tab-btn.on{color:var(--primary);border-bottom-color:var(--primary)}.tab-btn:hover{color:var(--ink)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.preview-shell{max-width:720px;margin:0 auto;padding:48px 48px 96px}.preview-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 32px;margin-bottom:16px}.preview-quiz-title{font-family:Newsreader,serif;font-size:32px;font-weight:500;letter-spacing:-.015em;margin:0 0 4px}.preview-quiz-meta{color:var(--ink-soft);font-size:13px;display:flex;gap:14px}.preview-q{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 28px;margin-bottom:12px}.preview-q-num{font-family:Geist Mono,monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.08em;text-transform:uppercase}.preview-q-prompt{font-family:Newsreader,serif;font-size:19px;line-height:1.4;margin:4px 0 16px}.preview-choice{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:6px;cursor:pointer}.preview-choice:hover{background:var(--surface-2)}.preview-choice .circle,.preview-choice .square{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line-strong)}.preview-choice .square{border-radius:4px}.save-indicator{display:inline-flex;align-items:center;gap:6px;color:var(--ink-mute);font-size:12px}.save-indicator .dot{width:6px;height:6px;border-radius:50%;background:var(--ok)}.canvas::-webkit-scrollbar,.q-list::-webkit-scrollbar,.drawer-body::-webkit-scrollbar{width:10px}.canvas::-webkit-scrollbar-thumb,.q-list::-webkit-scrollbar-thumb,.drawer-body::-webkit-scrollbar-thumb{background:#11182724;border-radius:999px;border:2px solid transparent;background-clip:padding-box}.canvas::-webkit-scrollbar-thumb:hover,.q-list::-webkit-scrollbar-thumb:hover{background-color:#11182742;background-clip:padding-box;border:2px solid transparent}.menu-pop{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:4px;min-width:200px;z-index:30}.menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:0;background:transparent;text-align:left;border-radius:var(--r-sm);cursor:pointer;font-size:13px;color:var(--ink)}.menu-item:hover{background:var(--surface-2)}.menu-item .ico{color:var(--ink-mute)}.menu-divider{height:1px;background:var(--line);margin:4px 0}.pop-anchor{position:relative}.ai-banner{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--primary-tint);border:1px solid rgba(45,107,255,.18);color:var(--primary);border-radius:var(--r-md);font-size:12.5px;margin-bottom:18px}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}.section-group{margin-bottom:2px}.section-head{display:flex;align-items:center;gap:6px;padding:6px 12px 6px 8px;margin:0 6px;border-radius:var(--r-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.section-head:hover{background:var(--surface-2)}.section-title{flex:1;font-size:11.5px;font-weight:600;letter-spacing:.02em;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-count{font-size:10.5px;color:var(--ink-mute);font-variant-numeric:tabular-nums;font-family:Geist Mono,monospace}.section-flag{font-size:11px;color:var(--ink-mute)}.q-type-pill{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:18px;padding:0 5px;border-radius:4px;font-family:Geist Mono,monospace;font-size:9.5px;font-weight:600;letter-spacing:.02em;background:var(--surface-3);color:var(--ink-soft)}.q-item.active .q-type-pill{background:#fbf7ea26;color:#fbf7eacc}.needs-review-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary);margin-left:6px;box-shadow:0 0 0 2px #2d6bff2e}.menu-section-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);padding:8px 10px 4px}.type-pill{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:20px;padding:0 6px;border-radius:4px;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;background:var(--surface-3);color:var(--ink-soft)}.difficulty-bars{display:inline-flex;gap:2px;align-items:flex-end;height:14px}.difficulty-bars .bar{width:3px;height:6px;border-radius:1px;background:var(--line-strong)}.difficulty-bars .bar:nth-child(2){height:8px}.difficulty-bars .bar:nth-child(3){height:10px}.difficulty-bars .bar:nth-child(4){height:12px}.difficulty-bars .bar:nth-child(5){height:14px}.difficulty-bars .bar.on{background:var(--primary)}.weight-input{display:inline-flex;align-items:center;gap:2px;border-left:1px solid var(--line);padding:0 8px;height:28px;font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.weight-input input{width:38px;border:0;background:transparent;outline:none;text-align:right;font-weight:500;color:var(--ink);font-variant-numeric:tabular-nums}.weight-input span{margin-left:2px;color:var(--ink-mute)}.option-feedback{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 38px;font-size:12px}.option-feedback .fb-label{color:var(--ink-mute);white-space:nowrap;flex-shrink:0}.option-feedback .option-input{background:var(--surface-2);border:1px solid var(--line);border-radius:6px;padding:4px 8px;font-size:12.5px;height:28px}.advanced-block{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;margin-top:18px}.advanced-block-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}.sub-label{font-size:11px;color:var(--ink-mute);margin-bottom:4px;font-weight:500}.hint-line{font-size:11.5px;color:var(--ink-mute);margin-top:6px}.hint-line code{font-family:Geist Mono,monospace;background:var(--surface);padding:1px 4px;border-radius:3px;border:1px solid var(--line)}.ai-banner.reviewed{background:#ecfdf5;border-color:#16a34a38;color:var(--ok);font-size:12px}.ai-banner-action{background:transparent;border:0;color:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:4px;font-size:12px;padding:4px 8px;border-radius:5px}.ai-banner-action:hover{background:#2d6bff1a}.msa-list{display:flex;flex-direction:column;gap:8px}.msa-blank{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 12px}.msa-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}.msa-num{width:22px;height:22px;border-radius:50%;background:var(--surface-3);color:var(--ink-soft);display:grid;place-items:center;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}.msa-label{flex:1;border:0;background:transparent;outline:none;font-weight:500;font-size:13px}.msa-accepted{display:flex;flex-wrap:wrap;gap:5px;align-items:center;padding:4px 0 0 30px}.msa-accepted .accepted-input{flex:1;min-width:140px;font-size:12.5px;padding:4px 6px;border:0;background:transparent}.fib-preview{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;font-family:Newsreader,serif;font-size:17px;line-height:1.6;margin-bottom:10px}.fib-blank-chip{display:inline-block;background:var(--primary-tint);color:var(--primary);font-weight:500;padding:2px 10px;border-radius:4px;font-family:Geist,sans-serif;font-size:13px;margin:0 2px}.fib-edit-list{display:flex;flex-direction:column;gap:4px}.fib-row{display:flex;align-items:center;gap:8px;padding:4px 6px 4px 4px;background:var(--surface);border:1px solid var(--line);border-radius:8px}.fib-row.blank{background:var(--primary-tint);border-color:#2d6bff2e}.fib-row-tag{font-family:Geist Mono,monospace;font-size:9.5px;font-weight:600;letter-spacing:.05em;background:var(--surface-3);color:var(--ink-soft);padding:2px 6px;border-radius:3px;min-width:44px;text-align:center}.fib-row.blank .fib-row-tag{background:#2d6bff2e;color:var(--primary)}.matching-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.matching-head,.matching-row{display:grid;grid-template-columns:28px 1fr 16px 1fr 28px;gap:10px;align-items:center;padding:6px 10px}.matching-head{background:var(--surface-2);border-bottom:1px solid var(--line);font-size:11px;font-weight:600;color:var(--ink-mute);letter-spacing:.05em;text-transform:uppercase}.matching-head span:first-child,.matching-head span:last-child{text-align:center}.matching-row{border-bottom:1px solid var(--line)}.matching-row:last-child{border-bottom:0}.match-num{width:22px;height:22px;border-radius:50%;background:var(--surface-3);color:var(--ink-soft);display:grid;place-items:center;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}.matching-row .option-input{background:var(--surface-2);border:1px solid transparent;padding:6px 10px;border-radius:6px}.matching-row .option-input:focus{border-color:var(--ink-soft);background:var(--surface)}.distractor-list{display:flex;flex-wrap:wrap;gap:6px;padding:8px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-md);min-height:50px;align-content:flex-start}.ord-num{width:24px;height:24px;border-radius:6px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:600;font-family:Geist Mono,monospace;flex-shrink:0}.option-action:disabled{opacity:.3;cursor:not-allowed}.option-action:nth-child(1) svg{transform:rotate(180deg)}.var-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.var-head,.var-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr 28px;gap:0;align-items:center;padding:4px 6px}.var-head{background:var(--surface-2);border-bottom:1px solid var(--line);font-size:11px;font-weight:600;color:var(--ink-mute);letter-spacing:.05em;text-transform:uppercase;padding:8px 10px}.var-row{border-bottom:1px solid var(--line)}.var-row:last-child{border-bottom:0}.var-cell{border:0;background:transparent;padding:6px 8px;outline:none;font-size:13px;border-right:1px solid var(--line)}.var-row .var-cell:last-of-type{border-right:0}.var-cell.mono{font-family:Geist Mono,monospace;font-size:12.5px}.var-cell:focus{background:var(--surface-2)}.likert-preview{display:flex;justify-content:space-between;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;margin-top:8px}.likert-pip{text-align:center;flex:1;font-size:11px;color:var(--ink-soft)}.likert-pip .dot{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line-strong);margin:0 auto 6px}.preview-likert{width:100%;border-collapse:collapse}.preview-likert th,.preview-likert td{border:1px solid var(--line);padding:8px 10px;text-align:center;font-size:12px;font-weight:400;color:var(--ink-soft)}.preview-likert th:first-child,.preview-likert td:first-child{text-align:left}.preview-likert .likert-statement{font-size:13px;color:var(--ink)}.preview-likert .radio-dot{display:inline-block;width:14px;height:14px;border-radius:50%;border:1.5px solid var(--line-strong)}.preview-fib{font-family:Newsreader,serif;font-size:17px;line-height:1.8}.preview-fib-blank{display:inline-block;border:0;border-bottom:1.5px solid var(--ink-2);background:transparent;outline:none;font:inherit;margin:0 4px;padding:0 4px}.preview-fib-blank:focus{border-bottom-color:var(--primary);background:var(--primary-tint)}.preview-matching{width:100%;border-collapse:collapse}.preview-matching td{padding:6px 8px;border-bottom:1px solid var(--line)}.preview-matching td.match-left{font-weight:500;width:40%}.preview-matching tr:last-child td{border-bottom:0}.preview-ordering{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.preview-ordering li{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);cursor:grab;color:var(--ink-mute)}.preview-ordering li span{color:var(--ink)}.preview-ordering li:hover{background:var(--surface-3)}.preview-section-title{font-size:11.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);margin:18px 4px 8px;font-family:Geist Mono,monospace}.stepper-inline{display:inline-flex;align-items:center;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:var(--surface);overflow:hidden}.stepper-inline input{width:50px;border:0;outline:none;text-align:center;padding:4px 0;font-variant-numeric:tabular-nums;background:transparent}.stepper-inline .stepper-btn{width:24px;height:28px;border:0;border-radius:0;background:var(--surface-2);cursor:pointer;color:var(--ink-soft)}.stepper-inline .stepper-btn:hover{background:var(--surface-3);color:var(--ink)}.ai-more{margin-top:6px}.ai-more summary{cursor:pointer;font-size:12px;color:var(--ink-soft);padding:6px 0;list-style:none;display:inline-flex;align-items:center;gap:4px}.ai-more summary::-webkit-details-marker{display:none}.ai-more summary:before{content:"▸";font-size:10px;transition:transform .12s;display:inline-block}.ai-more[open] summary:before{transform:rotate(90deg)}.ai-more summary:hover{color:var(--ink)}.canvas{position:relative}.canvas.drag-over{background:var(--surface-2)}.canvas-drop-overlay{position:absolute;top:16px;right:16px;bottom:16px;left:16px;background:#2d6bff0f;border:2.5px dashed var(--primary);border-radius:var(--r-xl);z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.canvas-drop-overlay .drop-icon{width:64px;height:64px;border-radius:18px;background:var(--primary);color:#fff;display:grid;place-items:center;margin-bottom:14px;box-shadow:var(--shadow-lg)}.canvas-drop-overlay .drop-title{font-family:Newsreader,serif;font-size:24px;font-weight:500;color:var(--ink)}.canvas-drop-overlay .drop-sub{font-size:13px;color:var(--ink-soft);margin-top:4px}.media-block-list{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.media-block{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin:0;transition:border-color 80ms}.media-block:hover{border-color:var(--ink-soft)}.media-block img{display:block;width:100%;max-height:360px;object-fit:contain;background:var(--surface-3)}.media-block.small img{max-height:120px}.media-block-controls{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .1s}.media-block:hover .media-block-controls{opacity:1}.media-ctrl{display:inline-flex;align-items:center;gap:4px;height:26px;padding:0 8px;border-radius:5px;border:0;background:#1b2b4bd9;color:var(--surface);font-size:11px;font-weight:500;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.media-ctrl:hover{background:var(--navy)}.media-alt{font-size:12px;color:var(--ink-soft);padding:8px 14px;border-top:1px solid var(--line);background:var(--surface-2);font-style:italic}.media-alt.missing{background:#fef3c7;color:var(--warn);display:flex;align-items:center;gap:6px;font-style:normal}.media-alt-editor{padding:10px 14px;border-top:1px solid var(--line);background:var(--surface-2)}.option-row.with-image{padding:6px 6px 6px 10px}.option-image{position:relative;flex-shrink:0;width:56px;height:56px;border-radius:6px;overflow:hidden;background:var(--surface-3);border:1px solid var(--line)}.option-image img{width:100%;height:100%;object-fit:cover;display:block}.option-image-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;border:0;background:#1b2b4bd9;color:#fff;cursor:pointer;display:grid;place-items:center;opacity:0;transition:opacity .1s}.option-image:hover .option-image-remove{opacity:1}.option-image-btn{width:28px;height:28px;border-radius:5px;border:0;background:transparent;color:var(--ink-mute);cursor:pointer;display:grid;place-items:center;flex-shrink:0;opacity:0;transition:opacity .1s}.option-row:hover .option-image-btn{opacity:1}.option-image-btn:hover{background:var(--surface-2);color:var(--ink)}.media-actions{display:flex;gap:8px;margin-bottom:10px}.media-drop{border:1.5px dashed var(--line-strong);border-radius:var(--r-md);padding:12px;text-align:center;font-size:12.5px;color:var(--ink-mute);background:var(--surface-2);margin-bottom:14px;transition:all 80ms}.media-drop.over{border-color:var(--primary);background:var(--primary-tint);color:var(--ink)}.media-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.media-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all 80ms}.media-card:hover{border-color:var(--ink-soft);transform:translateY(-1px)}.media-card.sel{border-color:var(--primary);box-shadow:0 0 0 2px #2d6bff33}.media-thumb{aspect-ratio:16 / 10;background:var(--surface-3);overflow:hidden;display:grid;place-items:center}.media-thumb img{width:100%;height:100%;object-fit:cover;display:block}.media-meta{padding:8px 10px}.media-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-sub{font-size:10.5px;color:var(--ink-mute);margin-top:2px;font-variant-numeric:tabular-nums}.media-detail{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}.media-detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.media-detail-preview{background:var(--surface-3);border-radius:var(--r-md);overflow:hidden;margin-bottom:14px}.media-detail-preview img{display:block;width:100%;max-height:200px;object-fit:contain}.q-drag{display:inline-flex;align-items:center;justify-content:center;width:14px;height:18px;flex-shrink:0;color:var(--ink-mute);cursor:grab;opacity:0;transition:opacity .1s;margin-right:-4px}.q-item:hover .q-drag{opacity:.7}.q-item.active .q-drag{color:#fff9}.q-item.active:hover .q-drag{opacity:1}.q-drag:active{cursor:grabbing}.q-item.drag-over{box-shadow:inset 0 2px 0 0 var(--primary)}.option-drag{display:inline-flex;align-items:center;justify-content:center;width:14px;height:28px;flex-shrink:0;color:var(--ink-mute);cursor:grab;opacity:0;transition:opacity .1s;margin-right:-2px}.option-row:hover .option-drag{opacity:.7}.option-drag:active{cursor:grabbing}.option-row.drag-over{box-shadow:inset 0 2px 0 0 var(--primary),var(--shadow-focus);border-color:var(--primary)}.section-head.drag-over{background:var(--primary-tint);box-shadow:inset 0 0 0 1.5px var(--primary)}.section-head.drag-over .section-title{color:var(--primary)}.section-empty-drop{margin:4px 12px 8px;padding:14px 10px;border:1.5px dashed var(--line-strong);border-radius:var(--r-md);background:transparent;color:var(--ink-mute);font-size:11.5px;text-align:center;font-style:italic}.section-empty-drop.drag-over{border-color:var(--primary);background:var(--primary-tint);color:var(--primary);font-style:normal}.media-card{position:relative}.media-card-x{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:0;background:#111827c7;color:#fff;cursor:pointer;display:grid;place-items:center;z-index:2;opacity:0;transition:opacity .1s,transform .1s,background .1s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 1px 4px #11182740}.media-card:hover .media-card-x{opacity:1}.media-card-x:hover{background:var(--err);transform:scale(1.05)}.sidebar-quick-row{display:flex;gap:6px;padding:0 6px}.sidebar-quick{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;height:30px;padding:0 10px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface-2);color:var(--ink-soft);cursor:pointer;font-weight:500;font-size:12.5px;transition:all 80ms}.sidebar-quick:hover{background:var(--primary-tint);color:var(--primary);border-color:#2d6bff47}.bank-cats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.bank-cats-col{display:flex;flex-direction:column;gap:3px}.bank-cats-label{font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px;padding-left:2px}.bank-cat-pill{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);cursor:pointer;font-size:12.5px;font-weight:500;text-align:left;transition:all 80ms}.bank-cat-pill:hover{background:var(--surface-2);color:var(--ink)}.bank-cat-pill.on{background:var(--primary-tint);color:var(--primary);border-color:#2d6bff47}.bank-cat-pill>span:first-child{flex:1}.bank-count{font-size:10.5px;font-family:Geist Mono,monospace;font-variant-numeric:tabular-nums;color:var(--ink-mute);background:var(--surface-2);padding:1px 5px;border-radius:3px}.bank-cat-pill.on .bank-count{background:#fff;color:var(--primary)}.bank-q-list{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.bank-q-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface);cursor:pointer;transition:all 80ms}.bank-q-row:hover{border-color:var(--line-strong);background:var(--surface-2)}.bank-q-row.on{border-color:var(--primary);background:var(--primary-tint);box-shadow:var(--shadow-focus)}.bank-preview{margin-top:14px;padding:14px 16px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg)}.bank-preview-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.bank-preview-body .preview-choice{background:var(--surface)}.lib-filters{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:8px}.lib-filters .select-input{height:32px;font-size:12.5px}.lib-grid{display:grid;grid-template-columns:1fr;gap:8px}.lib-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 14px 12px;cursor:pointer;transition:all 80ms}.lib-card:hover{border-color:var(--line-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.lib-card.sel{border-color:var(--primary);box-shadow:0 0 0 2px #2d6bff2e}.lib-card-head{display:flex;gap:5px;margin-bottom:8px;flex-wrap:wrap}.lib-pill{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 8px;border-radius:999px;background:var(--primary-tint);color:var(--primary);font-size:10.5px;font-weight:600;letter-spacing:.01em}.lib-pill.subtle{background:var(--surface-3);color:var(--ink-soft)}.lib-pill.warn{background:#fef3c7;color:var(--warn)}.lib-card-title{font-family:Newsreader,serif;font-size:17px;font-weight:500;line-height:1.25;letter-spacing:-.01em;margin-bottom:4px;color:var(--ink)}.lib-card-author{font-size:11.5px;color:var(--ink-soft);margin-bottom:8px}.lib-card-desc{font-size:12.5px;line-height:1.45;color:var(--ink-2);margin-bottom:10px}.lib-card-foot{display:flex;align-items:center;gap:12px;padding-top:10px;border-top:1px solid var(--line)}.lib-card-stat{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--ink-mute);font-variant-numeric:tabular-nums}.lib-detail{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}.lib-detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.publish-summary{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px}.vis-options{display:flex;flex-direction:column;gap:6px}.vis-card{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:pointer;text-align:left;transition:all 80ms}.vis-card:hover{border-color:var(--line-strong);background:var(--surface-2)}.vis-card.on{border-color:var(--primary);background:var(--primary-tint);box-shadow:var(--shadow-focus)}.vis-card-icon{width:32px;height:32px;border-radius:8px;background:var(--surface-2);display:grid;place-items:center;color:var(--ink-soft);flex-shrink:0;margin-top:1px}.vis-card.on .vis-card-icon{background:#2d6bff26;color:var(--primary)}.vis-card-radio{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line-strong);display:grid;place-items:center;background:var(--surface);color:transparent;flex-shrink:0;margin-top:6px}.vis-card-radio.on{background:var(--primary);border-color:var(--primary);color:#fff}.publish-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:30;display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-lg);border-radius:var(--r-lg);padding:12px 12px 12px 14px;min-width:380px;max-width:560px;animation:toast-in .22s cubic-bezier(.2,.8,.2,1)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.publish-toast-icon{width:30px;height:30px;border-radius:50%;background:#dcfce7;color:var(--ok);display:grid;place-items:center;flex-shrink:0}.publish-toast-link{font-family:Geist Mono,monospace;font-size:11.5px;color:var(--primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-media{margin:0 0 14px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}.preview-media img{display:block;width:100%;max-height:380px;object-fit:contain;background:var(--surface-3)}.preview-media figcaption{font-size:11.5px;color:var(--ink-soft);padding:6px 12px;font-style:italic}.preview-choice-img{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}.workspace{display:grid;grid-template-columns:260px 1fr 280px;overflow:hidden;height:100%}.right-panel{border-left:1px solid var(--line);background:var(--surface);overflow-y:auto}.right-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-mute);border-bottom:1px solid var(--line)}.validation-list{padding:6px 0}.validation-msg{display:flex;align-items:flex-start;gap:8px;padding:8px 14px;font-size:13px;cursor:pointer;color:var(--warn)}.validation-msg:hover{background:var(--surface-2)}.validation-msg.error{color:var(--err)}.validation-empty{display:flex;align-items:center;gap:8px;padding:12px 14px;font-size:13px;color:var(--ink-soft)}.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--ink-mute)}.dashboard{max-width:860px;margin:0 auto;padding:48px 24px}.dashboard-header{margin-bottom:32px}.dashboard-title{font-family:Newsreader,serif;font-size:28px;font-weight:500;margin:0 0 6px}.dashboard-sub{font-size:14px;color:var(--ink-soft);margin:0}.dashboard-actions{margin-bottom:24px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.project-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;cursor:pointer;transition:box-shadow .12s}.project-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.project-card-title{font-family:Newsreader,serif;font-size:17px;font-weight:500;margin-bottom:6px}.project-card-meta{font-size:12.5px;color:var(--ink-soft)}.empty-state{text-align:center;padding:48px;color:var(--ink-mute)}.loading-state{padding:24px;color:var(--ink-mute);font-size:13px}.editor-fields{display:flex;flex-direction:column;gap:0}.field-row{display:flex}.option-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;padding:8px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);transition:border-color 80ms}.option-row.correct{border-color:var(--ok);background:#ecfdf5}.option-check{width:20px;height:20px;border-radius:4px;border:1.5px solid var(--line-strong);display:grid;place-items:center;background:transparent;cursor:pointer;flex-shrink:0;transition:background 80ms,border-color 80ms}.option-check.on{background:var(--ok);border-color:var(--ok);color:#fff}.option-text{flex:1;border:none!important;box-shadow:none!important;padding:0!important}.option-del{background:transparent;border:none;cursor:pointer;color:var(--ink-mute);padding:4px;display:flex;border-radius:var(--r-sm)}.option-del:hover{color:var(--err);background:#fee2e2}.add-option-btn{background:transparent;border:1px dashed var(--line-strong);border-radius:var(--r-sm);padding:6px 12px;cursor:pointer;font-size:13px;color:var(--ink-soft);display:inline-flex;align-items:center;gap:6px}.add-option-btn:hover{border-color:var(--primary);color:var(--primary)}.preview-question{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px}.preview-prompt{font-size:15px;font-weight:500;margin-bottom:16px}.preview-options{display:flex;flex-direction:column;gap:8px}.preview-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px solid var(--line);border-radius:var(--r-md);cursor:pointer;font-size:14px;transition:all 80ms}.preview-option:hover,.preview-option.selected{border-color:var(--primary);background:var(--primary-tint)}.preview-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--line-strong);display:grid;place-items:center;flex-shrink:0}.preview-option.selected .preview-radio{background:var(--primary);border-color:var(--primary);color:#fff}.preview-short{width:100%}.preview-meta{margin-top:12px;font-size:12px;color:var(--ink-mute)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:11px;font-weight:600;background:var(--primary-tint);color:var(--primary)}.badge.warn{background:#fef3c7;color:var(--warn)}.badge.ok{background:#dcfce7;color:var(--ok)}.ai-banner{display:flex;align-items:flex-start;gap:10px;background:var(--primary-tint);border:1px solid var(--primary-tint-2);border-radius:var(--r-md);padding:12px 14px;margin-bottom:20px;font-size:13.5px;color:var(--primary)}.meta-chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--surface);cursor:pointer;font-size:13px}.meta-chip.active{background:var(--primary-tint);border-color:var(--primary);color:var(--primary)}
