:root{--primary: #0d6efd;--primary-dark: #0b5ed7;--page: #f6f7fb;--card-bg: #ffffff;--radius: 16px;--transition: .25s ease}*{box-sizing:border-box}html{height:100%}body{min-height:100svh;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--page);display:grid;place-items:center;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.card{width:100%;max-width:420px;padding:32px 28px 36px;background:var(--card-bg);border-radius:var(--radius);box-shadow:0 12px 30px #10182814;text-align:center;animation:fade-in .45s ease both}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.logo{font-size:2rem;font-weight:700;margin-bottom:8px;color:var(--primary)}.subtitle{font-size:.95rem;color:#6b7280;margin-bottom:24px}.field{position:relative;margin-bottom:14px}.field input{width:100%;padding:14px 44px 14px 14px;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb;font-size:.95rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}.field input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #0d6efd1f}.toggle-password{position:absolute;top:50%;right:12px;transform:translateY(-50%);border:none;background:none;cursor:pointer;font-size:1rem;color:#9ca3af;padding:2px 6px;border-radius:8px}.toggle-password:hover{color:var(--primary)}.btn{width:100%;padding:14px;margin-top:6px;font-size:1rem;font-weight:700;color:#fff;background:var(--primary);border:none;border-radius:12px;cursor:pointer;transition:background var(--transition),transform .05s ease}.btn:hover,.btn:focus-visible{background:var(--primary-dark)}.btn:active{transform:translateY(1px)}#message{margin-top:14px;font-size:.93rem;font-weight:500;min-height:1.2em}.error{color:#d52731}.success{color:#269f53}.empty-wrap{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:24px;background:linear-gradient(180deg,#f4f6fb,#f9fafb)}.empty-card{max-width:640px;width:min(92vw,640px);background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 16px 40px #10182814;padding:24px;text-align:center}.empty-illust{margin-bottom:12px}.empty-card h2{margin:6px 0;font-weight:800;font-size:1.25rem;color:#0f172a;letter-spacing:.2px}.empty-card p{margin:0 0 10px;color:#6b7280;font-size:.98rem}.hintline{display:inline-flex;gap:8px;align-items:center;padding:8px 12px;border:1px dashed #e5e7eb;border-radius:10px;color:#374151;background:#f9fafb;font-size:.92rem}.hintline i{color:#2563eb}.logout-icon{position:fixed;top:12px;left:12px;width:26px;height:26px;padding:0;border:none;border-radius:9999px;display:grid;place-items:center;background:var(--primary);color:#fff;cursor:pointer;box-shadow:0 4px 10px #1018281f;transition:background var(--transition),transform .05s ease;z-index:1000}.logout-icon i{font-size:14px;line-height:1}.logout-icon:hover{background:var(--primary-dark)}.logout-icon:active{transform:translateY(1px)}.quiz-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr}.quiz-panel{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:14px}.quiz-label{display:block;font-size:.9rem;color:#6b7280;margin-bottom:6px}.quiz-codebox{width:100%;min-height:420px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.95rem;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px}.quiz-lint{margin-top:8px;font-size:.9rem;min-height:1.1em}.quiz-lint.error{color:#d52731}.quiz-lint.success{color:#269f53}.quiz-preview{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px;min-height:420px;overflow:auto}.quiz-preview .q{padding:10px;border-bottom:1px dashed #e5e7eb}.quiz-preview .q:last-child{border-bottom:none}.quiz-preview .title{font-weight:700;margin-bottom:4px}.quiz-preview .meta{color:#6b7280;font-size:.9rem;margin-bottom:10px}.quiz-preview .opt{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}.btnbar{display:flex;gap:12px;align-items:center;justify-content:flex-end;flex-wrap:nowrap}.btnbar .btn{flex:0 0 auto}.pill{border-radius:9999px!important}.btn.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 18px;background:linear-gradient(180deg,#2563eb,#1d4ed8);color:#fff;border:1px solid #1d4ed8;box-shadow:0 10px 22px #1d4ed82e,0 2px 6px #1d4ed81f;transition:transform .06s ease,box-shadow var(--transition),background var(--transition);white-space:nowrap;min-width:150px;max-width:200px}.btn.btn-primary:hover,.btn.btn-primary:focus-visible{background:linear-gradient(180deg,#1e4fdc,#1b46c8);box-shadow:0 14px 30px #1d4ed838,0 2px 8px #1d4ed824}.btn.btn-primary:active{transform:translateY(1px)}.btn.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 18px;background:#fff;color:#111827;border:1px solid #e5e7eb;box-shadow:0 4px 10px #0000000f;transition:transform .06s ease,box-shadow var(--transition),background var(--transition),border-color var(--transition);white-space:nowrap;min-width:120px;max-width:180px}.btn.btn-ghost:hover,.btn.btn-ghost:focus-visible{background:#f9fafb;border-color:#d1d5db;box-shadow:0 6px 14px #00000014}.btn.btn-ghost:active{transform:translateY(1px)}.has-spinner{position:relative}.has-spinner.is-loading{pointer-events:none;opacity:.9}.has-spinner.is-loading:after{content:"";width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.6);border-top-color:#fff;position:absolute;right:12px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.quiz-codebox,.quiz-preview{min-height:420px}.quiz-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;min-height:60px;flex-wrap:wrap}.quiz-head h1{flex:1 1 280px;min-width:220px}@media (max-width: 860px){.btnbar{width:100%;justify-content:flex-start;margin-top:6px;flex-wrap:wrap}}@media (max-width: 980px){.quiz-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}.q-input.sm{display:inline-block;vertical-align:baseline;margin:0 6px;padding:6px 6px 4px;border:none;border-bottom:2px solid #dbe2ea;background:#fff;font:inherit;line-height:1.2;width:auto;min-width:8ch;max-width:26ch;transition:border-color .15s,box-shadow .15s,background .15s}.q-input.sm::placeholder{color:#9aa4b2;opacity:.9}.q-input.sm:focus{outline:none;border-bottom-color:#93c5fd;box-shadow:0 2px #3b82f659;background:#f8fbff;border-radius:6px 6px 0 0}.q-input.sm:placeholder-shown{background:#fcfdff}.q-select.sm{display:inline-block;vertical-align:baseline;margin:0 6px;padding:6px 28px 6px 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;font:inherit;line-height:1.2;width:auto;min-width:9ch;max-width:36ch;transition:border-color .15s,box-shadow .15s,background .15s}.q-select.sm:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f640;background:#f8fbff}.q-input:focus,.q-select:focus,.q-textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f640}.q-select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#6b7280 50%),linear-gradient(135deg,#6b7280 50%,transparent 50%),linear-gradient(to right,#e5e7eb,#e5e7eb);background-position:calc(100% - 16px) 50%,calc(100% - 10px) 50%,calc(100% - 36px) 50%;background-size:6px 6px,6px 6px,1px 60%;background-repeat:no-repeat}.q-select:invalid{color:#9ca3af}.q-hint{color:#6b7280;font-size:.9rem}.q-chipgroup{display:flex;gap:8px;flex-wrap:wrap}.q-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;cursor:pointer;transition:box-shadow .15s,border-color .15s,background .15s}.q-chip input{appearance:none;width:14px;height:14px;border:2px solid #9ca3af;border-radius:50%}.q-chip:has(input:checked){border-color:#93c5fd;background:#f8fbff;box-shadow:0 0 0 3px #3b82f640}.q-chip:has(input:checked) input{border-color:#2563eb;background:#2563eb}.q-draglist{list-style:none;padding:0;margin:8px 0}.q-draglist li{padding:10px 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;margin:8px 0;cursor:grab}.q-draglist li.dragging{opacity:.6}.q-dragghost{border:1px dashed #93c5fd;background:#f8fbff}.match-wrap{display:grid;grid-template-columns:1fr;gap:10px}@media (min-width:720px){.match-wrap{grid-template-columns:1fr 1fr}}.match-left .match-row{display:flex;align-items:flex-start;gap:10px;margin:10px 0}.match-left .num{min-width:22px;font-weight:700}.match-choices{display:flex;gap:8px;flex-wrap:wrap}.match-right{border:1px solid #eef2f7;background:#fafafa;border-radius:10px;padding:10px}.match-right .rline{margin:6px 0}.q-chip.letter{padding:6px 10px}.q-chip.letter span{font-weight:700}.q-rewrite{margin-top:8px}.q-source{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;margin:6px 0 10px}.q-src-text{color:#0f172a}.q-badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#111827;color:#fff;font-size:.78rem;font-weight:700}.q-badge.ghost{background:#eef2ff;color:#1f2937}.q-field{margin-top:6px}.q-textarea{width:100%;min-height:80px;max-height:320px;resize:vertical;padding:12px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;font:inherit;line-height:1.5;transition:border-color .15s,box-shadow .15s,background .15s}.q-textarea::placeholder{color:#9aa4b2}.q-textarea:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 3px #3b82f640;background:#f8fbff}.q-meta{display:flex;justify-content:flex-end;font-size:.85rem;color:#6b7280;margin-top:6px}select[data-type=cloze-select]{max-width:none!important}select[data-type=cloze-select].break{display:block;width:100%!important;margin:6px 0}
