: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}}.strategy-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0 16px}.strategy-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:12px 14px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;cursor:pointer;transition:border-color .18s,transform .15s,box-shadow .18s;text-align:left}.strategy-card:hover{border-color:#22c55e;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e26}.strategy-card.selected{border-color:#16a34a;background:#f0fdf4;box-shadow:0 0 0 3px #16a34a26}.strategy-card.selected .strategy-title{color:#15803d}.strategy-emoji{font-size:22px}.strategy-title{font-weight:700;font-size:14px;color:#1f2937}.strategy-desc{font-size:12px;color:#6b7280;line-height:1.4}.manual-config{border:1px solid #e5e7eb;border-radius:10px;padding:0 14px;margin-top:14px}.manual-config summary{padding:12px 0;cursor:pointer;font-weight:600;color:#374151;font-size:14px;-webkit-user-select:none;user-select:none}.manual-config[open] summary{border-bottom:1px solid #e5e7eb;margin-bottom:8px}.btn-mistake{width:100%;padding:12px;background:#fef2f2;border:2px solid #fca5a5;border-radius:10px;color:#dc2626;font-weight:700;font-size:14px;cursor:pointer;transition:background .15s,transform .12s}.btn-mistake:hover{background:#fee2e2;transform:translateY(-1px)}.range-row{display:flex;gap:10px;align-items:center;margin-top:8px}.progress-label{margin-top:6px;font-size:13px;color:#374151;font-weight:600}.hint-text{margin-top:10px;font-size:12px;color:#9ca3af;text-align:center}.score-ring{position:relative;display:flex;align-items:center;justify-content:center;margin:16px auto}.score-inner{position:absolute;display:flex;align-items:baseline;gap:2px}.score-num{font-size:30px;font-weight:800}.score-denom{font-size:16px;color:#9ca3af;font-weight:600}.grade-label{text-align:center;font-size:18px;font-weight:800;margin-bottom:12px}.stats-row{display:flex;gap:8px;justify-content:center;margin-bottom:14px}.stat-chip{padding:5px 14px;border-radius:999px;font-size:13px;font-weight:700}.stat-chip.ok{background:#dcfce7;color:#16a34a}.stat-chip.bad{background:#fee2e2;color:#dc2626}.result-info{flex:1}.result-label{font-weight:700;font-size:14px;color:#1f2937}.result-sub{font-size:12px;color:#6b7280}.result-wrong-ans{font-size:12px;color:#dc2626;margin-top:2px}.result-badge{font-size:18px;font-weight:800}.btn-row{display:flex;gap:10px}.btn-secondary{flex:1;padding:12px;border:2px solid #d1d5db;border-radius:10px;background:#fff;font-weight:700;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:#f3f4f6}.btn-row .btn-primary{flex:1}.quiz-counter{display:flex;align-items:baseline;gap:2px}.counter-cur{font-size:20px;font-weight:800;color:#1f2937}.counter-sep{font-size:14px;color:#9ca3af}.counter-total{font-size:14px;color:#6b7280;font-weight:600}.quiz-category{font-size:12px;color:#6b7280;background:#f3f4f6;padding:3px 9px;border-radius:999px}.timer-badge{font-size:13px;font-weight:700;border:2px solid;border-radius:999px;padding:2px 9px}.progress-track{height:5px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin:8px 0 4px}.progress-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:999px;transition:width .4s ease}.timer-track{height:4px;background:#e5e7eb;border-radius:999px;overflow:hidden;margin-bottom:6px}.timer-fill{height:100%;border-radius:999px;transition:width 1s linear,background .5s}.type-badge{text-align:center;font-size:12px;font-weight:600;color:#6b7280;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:4px 12px;display:inline-block;margin:6px auto 14px}.write-prompt{text-align:center;margin-bottom:8px}.write-reading{font-size:26px;font-weight:800;color:#1e3a5f;letter-spacing:1px}.write-label-hint{font-size:13px;color:#9ca3af;margin-top:2px}.meaning-box{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:8px 14px;color:#14532d;font-weight:600;font-size:14px;margin-bottom:10px;text-align:center}.writer-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:14px;color:#6b7280;background:#fffc}@media(max-width:420px){.strategy-grid{grid-template-columns:1fr}.write-reading{font-size:22px}}.scope-section{border:1.5px solid #e5e7eb;border-radius:12px;overflow:hidden;margin:14px 0}.scope-label{font-weight:700;font-size:13px;color:#374151;padding:10px 14px 8px;border-bottom:1px solid #f3f4f6;background:#fafafa}.scope-tabs{display:flex;border-bottom:1.5px solid #e5e7eb}.scope-tab{flex:1;padding:9px 4px;font-size:12px;font-weight:600;border:none;background:#fff;color:#6b7280;cursor:pointer;transition:background .15s,color .15s;border-right:1px solid #e5e7eb}.scope-tab:last-child{border-right:none}.scope-tab:hover{background:#f0fdf4;color:#16a34a}.scope-tab.active{background:#f0fdf4;color:#15803d;font-weight:800;box-shadow:inset 0 -2px #16a34a}.scope-body{padding:14px}.scope-info{font-size:12px;color:#6b7280;margin-bottom:10px;font-weight:600}.scope-char-preview{margin-top:6px;font-size:12px;color:#374151;font-weight:600;background:#f9fafb;border-radius:6px;padding:5px 10px}.range-from-to{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.range-bound{display:flex;align-items:center;gap:6px;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;padding:6px 10px}.bound-label{font-size:12px;color:#6b7280;font-weight:600;white-space:nowrap}.range-bound input{width:62px;border:1px solid #d1d5db;border-radius:6px;padding:3px 6px;font-size:13px;font-weight:700;text-align:center;outline:none}.range-bound input:focus{border-color:#22c55e}.bound-char{font-size:22px;font-weight:800;color:#1e3a5f;min-width:28px;text-align:center}.range-arrow{font-size:18px;color:#9ca3af;font-weight:700}.range-slider-group{display:flex;flex-direction:column;gap:4px}.cat-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.cat-btn-all,.cat-btn-none{padding:4px 12px;font-size:12px;font-weight:700;border-radius:999px;border:1.5px solid;cursor:pointer;transition:background .15s}.cat-btn-all{border-color:#16a34a;color:#15803d;background:#f0fdf4}.cat-btn-all:hover{background:#dcfce7}.cat-btn-none{border-color:#d1d5db;color:#6b7280;background:#f9fafb}.cat-btn-none:hover{background:#f3f4f6}.cat-count{margin-left:auto;font-size:12px;color:#6b7280;font-weight:600}.cat-list{display:flex;flex-direction:column;gap:4px;max-height:260px;overflow-y:auto;padding-right:4px}.cat-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;border:1.5px solid #e5e7eb;background:#fff;cursor:pointer;transition:border-color .15s,background .15s;font-size:13px}.cat-item:hover{border-color:#86efac;background:#f9fefb}.cat-item.checked{border-color:#22c55e;background:#f0fdf4}.cat-item input[type=checkbox]{accent-color:#16a34a;width:15px;height:15px;flex-shrink:0}.cat-item-name{flex:1;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-item-count{font-size:11px;color:#9ca3af;font-weight:600;background:#f3f4f6;padding:2px 7px;border-radius:999px;flex-shrink:0}.cat-item.checked .cat-item-count{background:#dcfce7;color:#15803d}@media(max-width:420px){.range-from-to{flex-direction:column;align-items:stretch}.range-arrow{text-align:center}.cat-count{margin-left:0}}
