:root{--teal: #0f766e;--teal-dark: #115e59;--bg: #f8fafc;--card: #ffffff;--text: #1e293b;--muted: #64748b;--line: #e2e8f0;--green: #16a34a;--green-bg: #dcfce7;--red: #dc2626;--red-bg: #fee2e2;--radius: 14px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Noto Sans CJK TC,Microsoft JhengHei,sans-serif;font-size:16px;line-height:1.6}button{font-family:inherit;cursor:pointer}.home,.screen{max-width:720px;margin:0 auto;padding:max(16px,env(safe-area-inset-top)) 16px calc(24px + env(safe-area-inset-bottom))}.hero{text-align:center;padding:24px 0 8px}.hero h1{margin:0;font-size:1.6rem;color:var(--teal-dark)}.hero .sub{margin:4px 0 0;color:var(--muted);font-size:.9rem}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:20px 0}.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:12px 4px;text-align:center}.stat b{display:block;font-size:1.3rem;color:var(--teal-dark)}.stat span{font-size:.75rem;color:var(--muted)}.modes{display:flex;flex-direction:column;gap:12px}.mode-btn{display:flex;flex-direction:column;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;font-size:1.1rem;font-weight:600;color:var(--text);text-align:left;transition:.15s}.mode-btn small{font-weight:400;font-size:.8rem;color:var(--muted);margin-top:2px}.mode-btn.primary{background:var(--teal);color:#fff;border-color:var(--teal)}.mode-btn.primary small{color:#d1fae5}.mode-btn:active{transform:scale(.99)}.mode-btn:disabled{opacity:.5}.link-btn{background:none;border:none;color:var(--teal);text-decoration:underline;font-size:.85rem;padding:4px}.link-btn.danger{color:var(--muted)}.backup-links{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 16px;margin-top:22px}.backup-area{width:100%;min-height:110px;resize:vertical;margin:8px 0;border:1px solid var(--line);border-radius:10px;padding:10px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.78rem;word-break:break-all;box-sizing:border-box}.backup-btns{display:flex;gap:10px}.backup-btns .mode-btn{align-items:center;flex:1}.file-label{text-align:center}.backup-msg{color:var(--green);font-size:.85rem;margin:8px 0 0}.backup-err{color:var(--red);font-size:.85rem;margin:8px 0 0}.foot{text-align:center;color:var(--muted);font-size:.75rem;margin-top:28px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.topbar-title{font-weight:700;color:var(--teal-dark)}.topbar-score{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:600}.back{background:none;border:none;color:var(--teal);font-size:1rem;font-weight:600;padding:4px 0}.progress-bar{height:6px;background:var(--line);border-radius:999px;overflow:hidden;margin-bottom:16px}.progress-bar span{display:block;height:100%;background:var(--teal);transition:width .2s}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:16px}.q-meta{display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted);margin-bottom:10px}.q-stem{margin:0 0 14px;font-size:1.05rem;font-weight:500}.q-image{width:100%;border-radius:10px;margin-bottom:14px;display:block}.q-image-wrap{position:relative;margin-bottom:14px}.q-image-wrap .q-image{margin-bottom:0}.q-image-loading{display:flex;align-items:center;justify-content:center;height:160px;background:var(--bg);border:1px solid var(--line);border-radius:10px}.q-image-loading .spinner{width:30px;height:30px;border-width:3px}.q-image-missing{background:#fffbeb;border:1px dashed #f59e0b;color:#92400e;border-radius:10px;padding:12px;font-size:.85rem;margin-bottom:14px}.options{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.option{width:100%;display:flex;align-items:flex-start;gap:10px;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;font-size:1rem;color:var(--text);transition:.12s}.option:active{transform:scale(.995)}.opt-letter{flex:0 0 26px;width:26px;height:26px;border-radius:50%;background:var(--bg);color:var(--muted);font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem}.opt-text{flex:1}.option.selected{border-color:var(--teal);background:#f0fdfa}.option.selected .opt-letter{background:var(--teal);color:#fff}.option.correct{border-color:var(--green);background:var(--green-bg)}.option.correct .opt-letter{background:var(--green);color:#fff}.option.wrong{border-color:var(--red);background:var(--red-bg)}.option.wrong .opt-letter{background:var(--red);color:#fff}.option:disabled{cursor:default}.answer-box{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line);font-size:.95rem}.answer-box strong{color:var(--teal-dark);font-size:1.1rem}.tag{margin-left:10px;padding:2px 10px;border-radius:999px;font-size:.8rem;font-weight:700}.tag.ok{background:var(--green-bg);color:var(--green)}.tag.ng{background:var(--red-bg);color:var(--red)}.explanation{margin:12px 0 0}.explanation-head{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--teal-dark);font-size:.9rem;margin-bottom:4px}.expl-draft{font-size:.7rem;font-weight:700;color:#92400e;background:#fffbeb;border:1px solid #f59e0b;border-radius:999px;padding:1px 8px}.explanation-body{color:var(--text);font-size:.9rem;line-height:1.7}.explanation-body :first-child{margin-top:0}.explanation-body :last-child{margin-bottom:0}.explanation-body h3{font-size:.92rem;color:var(--teal-dark);margin:14px 0 4px;padding-bottom:3px;border-bottom:1px solid var(--line)}.explanation-body p{margin:6px 0}.explanation-body ul,.explanation-body ol{margin:6px 0;padding-left:1.3em}.explanation-body li{margin:3px 0}.explanation-body blockquote{margin:8px 0;padding:4px 12px;border-left:3px solid var(--line);color:var(--muted);font-size:.85rem}.explanation-body code{background:var(--bg);padding:1px 5px;border-radius:4px;font-size:.85em}.nav{display:flex;gap:12px}.nav button{flex:1;padding:14px;border-radius:12px;font-size:1rem;font-weight:600;border:1.5px solid var(--line);background:#fff;color:var(--text)}.nav button.primary{background:var(--teal);color:#fff;border-color:var(--teal)}.nav button:disabled{opacity:.4}.count-picker{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.count-picker .mode-btn{align-items:center}.mock-limit{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text);margin-top:12px}.mock-limit input{width:18px;height:18px;accent-color:var(--teal)}.mock-custom{display:flex;gap:10px;margin-top:12px}.mock-custom input{flex:1;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;background:var(--card);color:var(--text);font-size:.95rem}.mock-custom .mode-btn{flex:0 0 auto;padding:9px 16px}.topbar-title.time-low{color:var(--red)}.mock-topic-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--line);font-size:.9rem}.mock-topic-row:last-child{border-bottom:none}.mock-topic-name{color:var(--text)}.mock-topic-pct{font-variant-numeric:tabular-nums;color:var(--muted);font-weight:600}.mock-topic-pct.low{color:var(--red)}.jump-row{display:flex;align-items:center;gap:10px;margin-bottom:16px}.jump-row .progress-bar{flex:1;margin-bottom:0}.jump-toggle{flex:0 0 auto;background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-size:.82rem;font-weight:600;color:var(--teal-dark)}.jump-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:12px;margin-bottom:16px;max-height:46vh;overflow-y:auto}.jump-hint{font-size:.78rem;color:var(--muted);margin:0 0 6px;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.jump-hint .dot{width:9px;height:9px;border-radius:50%;background:var(--teal);display:inline-block}.jump-hint .lg{width:12px;height:12px;border-radius:3px;display:inline-block;border:1px solid var(--line)}.jump-hint .lg.ok{background:var(--green-bg);border-color:var(--green)}.jump-hint .lg.no{background:var(--red-bg);border-color:var(--red)}.jump-note{font-size:.74rem;color:var(--muted);margin:0 0 10px}.grid-jump{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px;margin:4px 0 16px}.jump.expl{position:relative}.jump.expl:after{content:"";position:absolute;top:3px;right:3px;width:7px;height:7px;border-radius:50%;background:var(--teal)}.jump{aspect-ratio:1;border:1px solid var(--line);background:var(--card);border-radius:8px;font-size:.8rem;color:var(--muted)}.jump.done{background:#f0fdfa;border-color:var(--teal);color:var(--teal-dark)}.jump.done.ok{background:var(--green-bg);border-color:var(--green);color:var(--green);font-weight:700}.jump.done.no{background:var(--red-bg);border-color:var(--red);color:var(--red);font-weight:700}.jump.cur{outline:2px solid var(--teal);outline-offset:1px;font-weight:700}.result-summary{text-align:center}.big-score{font-size:3rem;font-weight:800;color:var(--teal);line-height:1}.big-score small{font-size:1rem;font-weight:600;margin-left:4px}.review-title{font-weight:700;color:var(--teal-dark);margin:8px 2px}.empty{text-align:center;color:var(--muted);margin:40px 0}.loading{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--muted);font-size:.95rem}.spinner{width:38px;height:38px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--teal);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.picker-hint{color:var(--muted);font-size:.85rem;margin:0 2px 12px}.subject-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.subject-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;color:var(--text)}.subject-name{font-size:1.05rem;font-weight:700}.subject-count{font-size:.78rem;color:var(--muted)}.subject-btn:active{transform:scale(.99)}.subject-stats{padding:16px 18px}.ss-row{display:flex;align-items:center;gap:10px;margin:8px 0}.ss-name{flex:0 0 7.5em;display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600}.ss-dot{width:10px;height:10px;border-radius:50%;flex:0 0 10px}.ss-bar{flex:1;height:8px;background:var(--line);border-radius:999px;overflow:hidden}.ss-bar span{display:block;height:100%;border-radius:999px}.ss-num{flex:0 0 3.2em;text-align:right;font-size:.8rem;color:var(--muted);font-variant-numeric:tabular-nums}.subject-chip{display:inline-block;margin-left:6px;padding:1px 8px;border-radius:999px;font-size:.72rem;font-weight:700}.topic-chip{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.2px;color:var(--teal-dark);background:transparent;border:1px solid var(--teal)}.recycled-chip{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.2px;cursor:help;color:#9a5b00;background:#fff5e6;border:1px solid #f3cf95}[data-theme=dark] .recycled-chip{color:#f0c47e;background:#9a5b002e;border-color:#f3cf9559}.topic-bar{display:flex;gap:6px;overflow-x:auto;margin-bottom:12px;padding-bottom:2px;-webkit-overflow-scrolling:touch}.topic-pill{flex:0 0 auto;border:1px solid var(--line);background:var(--card);border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap}.topic-pill.on{background:var(--teal);border-color:var(--teal);color:#fff}.search-input{width:100%;padding:11px 14px;font-size:1rem;border:1.5px solid var(--line);border-radius:12px;background:var(--card);color:var(--text);margin-bottom:6px}.search-input:focus{outline:none;border-color:var(--teal)}.search-hint{font-size:.8rem;color:var(--muted);margin:0 0 12px}.search-list{display:flex;flex-direction:column;gap:8px}.search-item{text-align:left;border:1px solid var(--line);background:var(--card);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.search-item-meta{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.search-item-meta .subject-chip,.search-item-meta .topic-chip{margin-left:0}.search-id{font-size:.74rem;color:var(--muted);font-variant-numeric:tabular-nums}.search-stem{font-size:.9rem;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-stem mark{background:#fde68a;color:inherit;border-radius:2px;padding:0 1px}[data-theme=dark] .search-stem mark{background:#92400e;color:#fef3c7}.foot p{margin:4px 0}.foot-disc{max-width:560px;margin:8px auto 0;line-height:1.5}.foot-thanks{margin-top:10px;font-size:11px;opacity:.45}.link-inline{background:none;border:none;color:var(--teal);text-decoration:underline;font-size:inherit;padding:0;margin-left:2px}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:100}.modal{background:#fff;border-radius:var(--radius);width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;padding:max(16px,env(safe-area-inset-top)) 0 calc(8px + env(safe-area-inset-bottom))}.modal-title{margin:0 18px;color:var(--teal-dark);font-size:1.25rem}.modal-updated{margin:2px 18px 8px;color:var(--muted);font-size:.78rem}.modal-body{overflow-y:auto;padding:4px 18px;-webkit-overflow-scrolling:touch}.disc-lead{background:#f0fdfa;border:1px solid #99f6e4;border-radius:10px;padding:10px 12px;font-size:.9rem;color:var(--teal-dark)}.disc-sec{margin:14px 0}.disc-sec h3{margin:0 0 4px;font-size:.95rem;color:var(--text)}.disc-sec p{margin:4px 0;font-size:.86rem;color:var(--muted);line-height:1.65}.modal-actions{padding:10px 18px 0;border-top:1px solid var(--line);margin-top:4px}.modal-actions .mode-btn{align-items:center}.update-banner{position:fixed;left:50%;transform:translate(-50%);bottom:calc(12px + env(safe-area-inset-bottom));z-index:200;width:calc(100% - 24px);max-width:520px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--teal-dark);color:#fff;border-radius:12px;padding:10px 14px;box-shadow:0 6px 24px #0f172a4d}.update-text{font-size:.92rem;font-weight:600}.update-actions{display:flex;gap:8px;flex-shrink:0}.update-go{background:#fff;color:var(--teal-dark);border:none;border-radius:8px;padding:7px 14px;font-weight:700;cursor:pointer}.update-skip{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:8px;padding:7px 12px;cursor:pointer}.ver-btn{position:relative}.ver-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);margin-left:6px;vertical-align:middle}.about-date{font-weight:400;color:var(--muted);font-size:.8rem;margin-left:6px}.about-list{margin:4px 0 0;padding-left:18px}.about-list li{font-size:.86rem;color:var(--text);line-height:1.6;margin:3px 0}.about-hint{margin:6px 18px 2px;color:var(--muted);font-size:.78rem}.export-menu{position:relative;display:inline-block}.export-btn{background:var(--card);border:1px solid var(--line);color:var(--teal-dark);border-radius:10px;padding:8px 12px;font-size:.85rem;font-weight:600;cursor:pointer}.export-menu.compact .export-btn{padding:6px 10px;font-size:.8rem}.export-pop{position:absolute;right:0;z-index:60;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 28px #0f172a2e;padding:6px;min-width:220px;display:flex;flex-direction:column;gap:2px}.export-pop.drop-up{bottom:calc(100% + 6px)}.export-pop.drop-down{top:calc(100% + 6px)}.export-pop button{display:flex;flex-direction:column;align-items:flex-start;text-align:left;background:none;border:none;border-radius:8px;padding:9px 10px;cursor:pointer;font-size:.9rem;color:var(--text)}.export-pop button:hover{background:#f1f5f9}.export-pop button small{color:var(--muted);font-size:.74rem;margin-top:1px}.export-toast{position:absolute;right:0;z-index:60;background:var(--teal-dark);color:#fff;border-radius:8px;padding:7px 12px;font-size:.8rem;white-space:nowrap;box-shadow:0 6px 20px #0f172a40}.export-toast.drop-up{bottom:calc(100% + 6px)}.export-toast.drop-down{top:calc(100% + 6px)}.q-export-row{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-top:12px}.q-link-btn{border:1px solid var(--line);background:var(--card);color:var(--teal-dark);border-radius:8px;padding:6px 10px;font-size:.8rem;font-weight:600;white-space:nowrap}.manual-btn{margin-top:10px;background:var(--card);color:var(--teal-dark);border:1px solid var(--teal);border-radius:999px;padding:6px 16px;font-size:.85rem;font-weight:600;cursor:pointer}.manual-btn:hover{background:#f0fdfa}.update-modal{max-width:440px}.update-modal .modal-body .mode-btn{width:100%;margin-top:4px}.update-modal-actions{display:flex;gap:10px}.update-modal-actions .mode-btn{flex:1;align-items:center}.q-meta-right{display:inline-flex;align-items:center;gap:8px}.fav-btn{background:none;border:none;font-size:1.25rem;line-height:1;color:#cbd5e1;padding:0 2px}.fav-btn.on{color:#f59e0b}.report-btn{background:none;border:none;font-size:1.02rem;line-height:1;padding:0 2px;cursor:pointer;opacity:.65}.report-btn:hover{opacity:1}.fb-tabs{display:flex;gap:8px;margin-bottom:14px}.fb-tab{flex:1;border:1.5px solid var(--line);background:var(--card);color:var(--muted);border-radius:10px;padding:9px 8px;font-size:.92rem;font-weight:600;cursor:pointer}.fb-tab.on{border-color:var(--teal);background:var(--teal);color:#fff}.fb-field{display:block;margin:12px 0}.fb-field>span{display:block;font-size:.85rem;color:var(--teal-dark);font-weight:600;margin-bottom:4px}.fb-input{width:100%;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;background:var(--card);color:var(--text);font-size:.95rem}.fb-input:focus,.fb-field .note-area:focus{outline:none;border-color:var(--teal)}.fb-field .note-area{min-height:96px}.fb-note{font-size:.8rem;color:var(--muted);line-height:1.55;margin:10px 0 0}.note-block{margin-top:12px;border-top:1px dashed var(--line);padding-top:10px}.note-toggle{background:none;border:none;color:var(--teal-dark);font-weight:600;font-size:.85rem;padding:2px 0}.note-area{width:100%;min-height:70px;resize:vertical;margin-top:8px;border:1px solid var(--line);border-radius:10px;padding:10px;font-family:inherit;font-size:.9rem;box-sizing:border-box}.stats-link-row{margin-top:12px}.stats-weak{color:#b45309;background:#fffbeb;border:1px solid #fcd34d;border-radius:10px;padding:8px 12px;font-size:.86rem;margin:0 0 12px}.stats-h{font-size:.95rem;color:var(--teal-dark);margin:16px 0 8px}.stats-row{display:flex;align-items:center;gap:10px;margin:6px 0;font-size:.85rem}.stats-name{flex:0 0 92px;display:inline-flex;align-items:center;gap:6px}.stats-bars{flex:1;display:flex;flex-direction:column;gap:3px}.stats-bars .ss-bar{height:6px;background:var(--line);border-radius:999px;overflow:hidden}.stats-bars .ss-bar span{display:block;height:100%;border-radius:999px}.stats-num{flex:0 0 96px;text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}.stats-legend{color:var(--muted);font-size:.75rem;margin-top:10px}.hero-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}[data-theme=dark]{--bg: #0f172a;--card: #1e293b;--text: #e2e8f0;--muted: #94a3b8;--line: #334155;--teal: #14b8a6;--teal-dark: #5eead4;--green: #4ade80;--green-bg: #14532d;--red: #f87171;--red-bg: #7f1d1d}[data-theme=dark] .option,[data-theme=dark] .nav button,[data-theme=dark] .modal,[data-theme=dark] .export-pop,[data-theme=dark] .backup-area,[data-theme=dark] .note-area,[data-theme=dark] textarea,[data-theme=dark] .opt-letter{background:var(--card);color:var(--text)}[data-theme=dark] .mode-btn.primary{color:#022c22}[data-theme=dark] .mode-btn.primary small{color:#022c22;opacity:.75}[data-theme=dark] .update-go{color:#022c22}[data-theme=dark] .option.selected{background:#14b8a629}[data-theme=dark] .disc-lead{background:#14b8a61f;color:var(--teal-dark);border-color:#115e59}[data-theme=dark] .expl-draft,[data-theme=dark] .q-image-missing,[data-theme=dark] .stats-weak{background:#f59e0b26;color:#fcd34d}[data-theme=dark] .explanation-body code,[data-theme=dark] .stat,[data-theme=dark] .card{background:var(--card)}[data-theme=dark] .export-btn{background:var(--card);color:var(--teal-dark)}[data-theme=dark] .opt-letter{background:#0f172a}
