:root{color-scheme:light}html,body,#root{height:100%;margin:0;background:var(--bg, #111417)}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica Neue,Arial,Noto Sans,Adobe Kaiti Std,Kaiti SC,Kaiti TC,KaiTi,STKaiti,sans-serif}:root{--page-w: 1100px;--bg: #111417;--panel: #ffffff;--ink: #111;--muted: #6b7280;--br: #e5e7eb;--accent: #3b82f6}@font-face{font-family:KaiTi;src:url(/fonts/KaiTi.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}*{box-sizing:border-box}body{margin:0;background:var(--bg)}.app{min-height:100svh;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica Neue,Arial,Noto Sans,sans-serif;display:grid;place-items:start center}.wrap{width:min(1120px,100%);margin:0 auto;padding:clamp(12px,2vw,28px)}.h1{font-size:clamp(20px,3.4vw,36px);font-weight:800;margin:0 0 16px;color:#fff}.section{background:var(--panel);border:1px solid var(--br);border-radius:14px;box-shadow:0 1px 2px #0000000d;padding:14px;margin:0 auto 14px;width:100%}.row{display:flex;align-items:center;gap:10px;margin:10px 0}.row label{min-width:160px;color:#374151;font-size:13px}.input,.select,.textarea{border:1px solid var(--br);border-radius:10px;padding:8px 10px;font-size:14px;background:#fff}.textarea{width:100%;min-height:54px;resize:vertical}.input[type=range]{width:100%}.number{width:110px}.checkbox{transform:translateY(1px)}.btn{border:1px solid var(--br);background:#111;color:#fff;border-radius:10px;padding:8px 12px;font-size:13px;cursor:pointer}.btn.secondary{background:#eee;color:#111}.btn.ghost{background:#fff;color:#111}.btn:disabled{opacity:.5;cursor:default}.muted{font-size:12px;color:var(--muted)}.warn{font-size:12px;color:#92400e;background:#fef3c7;border:1px solid #fde68a;padding:6px 10px;border-radius:8px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#fff;color:var(--ink)!important;border:1px solid var(--br);min-width:36px;height:36px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:14px}.chip:hover{background:#f9fafb}.chip.active{background:var(--accent);color:#fff!important;border-color:var(--accent)}.stage{display:flex;align-items:center;justify-content:center;padding:12px}.stageInner{align-items:center}.stageBox{width:100%;max-width:480px}.mount{border:2px solid #cfe0ff;border-radius:14px}.stepTitle{display:flex;align-items:baseline;justify-content:space-between}.stepsGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:10px;margin-top:10px}.stepBox{border:1px solid var(--br);border-radius:10px}.bad{color:#b91c1c}.pdfPrev{width:100%;height:480px;border:1px solid var(--br);border-radius:10px}.progressWrap{display:flex;flex-direction:column;gap:6px;width:100%}.progress{height:10px;background:#eef2ff;border:1px solid #dbeafe;border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;background:#3b82f6;width:0%}details.advanced{border-top:1px dashed var(--br);margin-top:8px;padding-top:8px}details.advanced>summary{cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 0;font-weight:600;list-style:none}details.advanced>summary::marker{content:""}details.advanced>summary:after{content:"▼";float:right;color:#9ca3af}details.advanced[open]>summary:after{content:"▲"}@media(max-width:900px){.row{flex-direction:column;align-items:stretch}.row label{min-width:0;margin-bottom:6px}}@media(max-width:560px){.h1{font-size:24px}.stageInner svg.mount{width:100%!important;height:auto!important}}.input,.select,.textarea{background:#fff;color:#111}.input::placeholder,.textarea::placeholder{color:#9ca3af;opacity:1}input[type=number].input,input[type=text].input{color:#111}.input[type=color]{width:44px;height:32px;padding:0;border-radius:8px;-webkit-appearance:none;appearance:none}.input[type=color]::-webkit-color-swatch-wrapper{padding:0}.input[type=color]::-webkit-color-swatch{border:none;border-radius:8px}.input[type=color]::-moz-color-swatch{border:none}.modalOverlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:18px;z-index:60}.modalCard{background:#fff;color:#111;width:100%;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 30px #0000002e;max-height:calc(100vh - 48px);overflow:auto}.modalHeader{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #eef2f7;position:sticky;top:0;background:#fff;z-index:1}.modalTitle{font-weight:700;font-size:18px}.modalBody{padding:12px 14px 16px}:root{--bg: #f3f4f6;--panel: #ffffff;--text: #111827;--muted: #6b7280;--accent: #4ade80;--accent2: #2eb67d;--danger: #ef4444;--card-shadow: 0 4px 12px rgba(0, 0, 0, .1);--radius: 12px;--max-width: 980px}.app-shell{max-width:var(--max-width);margin:2rem auto;padding:2rem;background:var(--bg)}.app-header{text-align:center;margin-bottom:1.5rem}.app-header h1{font-size:clamp(26px,5vw,44px);margin:0;font-weight:700;color:var(--accent)}.review-container{background:var(--panel);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--card-shadow);max-width:780px;margin:1rem auto}.review-container.center{text-align:center}.review-container h2{margin:0 0 .75rem;color:var(--text);font-size:1.25rem;font-weight:700}label{display:block;color:var(--muted);font-weight:600;margin-bottom:.25rem;font-size:.875rem}.select-box,.input-field,select,input[type=number]{-webkit-appearance:none;appearance:none;background:var(--panel);color:var(--text);border:1px solid #d1d5db;padding:.5rem .75rem;border-radius:var(--radius);font-size:.875rem;width:100%;box-sizing:border-box;transition:box-shadow .2s,border-color .2s}.select-box:focus,.input-field:focus{outline:none;border-color:var(--accent2);box-shadow:0 0 0 2px #2ecc7133}.btn-primary{width:100%;background:linear-gradient(180deg,var(--accent),var(--accent2));color:#fff;border:none;padding:.75rem 1rem;border-radius:var(--radius);font-weight:700;cursor:pointer;margin-top:.75rem;transition:transform .1s,box-shadow .2s;box-shadow:0 4px 12px #2ecc7133}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2ecc714d}.btn-small{background:transparent;color:var(--accent2);border:1px solid var(--accent2);padding:.5rem .75rem;border-radius:8px;font-size:.875rem;cursor:pointer;transition:background .2s}.btn-small:hover{background:#4ade801a}.btn-small.danger{background:var(--danger);color:#fff;border:none}.btn-small.danger:hover{opacity:.9}.btn-check{background:var(--accent2);color:#fff;border:none;padding:.6rem 1rem;border-radius:var(--radius);cursor:pointer;font-weight:700;font-size:.875rem}.btn-check:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2ecc7133}.btn-text{background:none;color:var(--accent2);border:none;cursor:pointer;font-size:.875rem;font-weight:600;margin-top:.5rem}.btn-text:hover{text-decoration:underline}.quiz-header{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:.875rem;margin-bottom:1rem}.timer-normal{color:var(--accent2);font-weight:700}.timer-danger{color:var(--danger);font-weight:700}.big-char{font-family:KaiTi,"Han Serif",serif;font-size:clamp(48px,10vw,120px);text-align:center;color:var(--text);margin:.5rem 0 1rem;display:flex;justify-content:center;align-items:center;height:140px}.hint-text{text-align:center;color:var(--muted);margin-bottom:.5rem}.write-prompt{color:var(--muted);margin-bottom:.5rem}.highlight-text{color:var(--accent2);font-weight:700}.writer-box{margin:.75rem auto;width:min(90vw,320px);aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);background:#f9fafb;border:1px solid #e5e7eb;box-shadow:0 4px 12px #0000000d;touch-action:none}.input-group{display:flex;gap:.75rem;margin-top:.5rem}.input-field.big-input{flex:1;font-size:1rem;padding:.5rem .75rem}.feedback-msg{margin-top:.75rem;padding:.75rem;border-radius:var(--radius);text-align:center;font-weight:700}.feedback-msg.correct{background:#4ade8033;color:var(--accent2)}.feedback-msg.wrong{background:#ef444433;color:var(--danger)}.controls-row{display:flex;gap:.75rem;margin-top:.75rem;align-items:center;justify-content:center}.result-list{margin-top:.75rem;max-height:320px;overflow:auto;padding-top:.5rem}.result-row{display:flex;gap:.75rem;align-items:center;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.result-row.ok{background:#4ade801a}.result-row.bad{background:#ef44441a}.char-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;border-radius:8px;background:#4ade801a;color:#fff}.score-box{display:flex;justify-content:center;align-items:baseline;gap:.25rem;margin-bottom:1rem}.score-num{font-size:3rem;font-weight:700;color:var(--accent2)}.score-total{font-size:1.25rem;color:var(--muted)}@media(max-width:720px){.app-shell{padding:1rem;margin:.75rem}.writer-box{width:220px;height:220px}.big-char{font-size:clamp(40px,14vw,80px);height:110px}.row,.controls-row{flex-direction:column}}.tabs{display:flex;gap:8px;margin:0 auto 16px;padding:6px;background:#f1f5f9;border-radius:14px;width:fit-content;box-shadow:inset 0 1px 2px #0000000d}.tab-btn{appearance:none;border:none;background:transparent;padding:10px 18px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;color:#475569;display:flex;align-items:center;gap:6px;transition:background .25s ease,color .25s ease,box-shadow .25s ease,transform .15s ease}.tab-btn:hover{background:#e2e8f0;color:#0f172a}.tab-btn.active{background:#fff;color:#0f172a;box-shadow:0 4px 12px #00000014,inset 0 0 0 1px #e5e7eb;transform:translateY(-1px)}.tab-btn span,.tab-btn:first-letter{font-size:15px}@media(max-width:640px){.tabs{width:100%;justify-content:space-between}.tab-btn{flex:1;justify-content:center;padding:10px 12px;font-size:13px}}.writer-box{margin:.5rem auto;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#f9fafb;border:1px solid #e5e7eb;box-shadow:0 6px 18px #1018280a;overflow:hidden}.writer-box>div{width:100%;height:100%}.controls-row .btn-small{padding:10px 14px;font-size:.95rem}.tabs{display:flex;gap:8px;margin-bottom:12px;justify-content:center}.tab-btn{background:transparent;border:1px solid transparent;padding:8px 12px;border-radius:10px;font-weight:700;cursor:pointer}.tab-btn.active{background:linear-gradient(180deg,#4ade80,#2eb67d);color:#fff;box-shadow:0 6px 16px #2ecc712e}@media(max-width:720px){.input-group{flex-direction:column}.input-field.big-input{width:100%}.controls-row{flex-direction:column;gap:8px}.quiz-header{font-size:.9rem}.big-char{font-size:clamp(36px,18vw,80px);height:auto}}
