:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--app-height:100%}html,body{width:100%;height:100%;margin:0;padding:0;position:fixed;overflow:hidden}body{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;background-color:#f0f2f5;flex-direction:column;align-items:center;font-family:Malgun Gothic,sans-serif;display:flex}.container{flex-direction:column;align-items:center;width:100%;max-width:400px;height:100dvh;display:flex}.tabs{box-sizing:border-box;background-color:#6fc784;flex-shrink:0;justify-content:space-around;gap:6px;width:100%;padding:12px 8px;display:flex}.tabs button{text-overflow:ellipsis;white-space:nowrap;cursor:pointer;background-color:#e4e6eb;border:none;border-radius:8px;flex:1;min-width:0;padding:10px 2px;font-size:12px;font-weight:700;display:block;overflow:hidden}.tabs button.active{color:#fff;background-color:#28a745}.mode-selector{box-sizing:border-box;background:#e8f4ea;flex-shrink:0;justify-content:center;align-items:center;gap:24px;width:100%;padding:7px 15px;display:flex}.mode-selector label{cursor:pointer;color:#1a5c2a;align-items:center;gap:6px;font-size:14px;font-weight:700;display:flex}.mode-selector input[type=radio]{accent-color:#28a745;cursor:pointer;border:none;width:auto;margin:0;padding:0}.card{text-align:center;box-sizing:border-box;background:#fff;border-radius:15px;flex-direction:column;flex-grow:1;justify-content:start;align-items:center;width:calc(100% - 20px);margin:10px;padding:20px;display:flex;overflow:hidden;box-shadow:0 4px 10px #0000001a}.character{color:#333;margin-top:10vh;margin-bottom:10vh;font-size:clamp(100px,25vw,150px);font-weight:700}.character.word-mode{white-space:nowrap;margin-top:6vh;margin-bottom:6vh;font-size:clamp(50px,15vw,78px)}.text-input{text-align:center;box-sizing:border-box;border:2px solid #ddd;border-radius:8px;width:90%;max-width:300px;margin-top:5vh;margin-bottom:15px;padding:12px;font-size:18px}.submit-btn{color:#fff;cursor:pointer;background-color:#007bff;border:none;border-radius:8px;width:90%;max-width:300px;padding:15px;font-size:16px;font-weight:700;transition:background-color .2s}.submit-btn:active{background-color:#0056b3}.choices{grid-template-columns:1fr 1fr;gap:12px;width:90%;max-width:320px;margin-top:10px;display:grid}.choice-btn{cursor:pointer;color:#333;word-break:keep-all;background:#fff;border:2px solid #ddd;border-radius:10px;padding:18px 8px;font-family:Malgun Gothic,sans-serif;font-size:15px;font-weight:700;transition:all .15s}.choice-btn:active:not(:disabled){transform:scale(.96)}.choice-btn.correct{color:#fff;background:#28a745;border-color:#28a745}.choice-btn.wrong{color:#fff;background:#dc3545;border-color:#dc3545}.choice-btn.dimmed{opacity:.35}.choice-btn:disabled{cursor:default}.feedback{min-height:24px;margin-top:15px;font-size:16px;font-weight:700}.correct{color:#28a745}.incorrect{color:#dc3545}.subtabs{box-sizing:border-box;background-color:#4a9e5c;flex-shrink:0;justify-content:center;gap:8px;width:100%;padding:8px 10px;display:flex}.subtabs button{cursor:pointer;color:#1a5c2a;background-color:#c8e6ce;border:none;border-radius:6px;padding:6px 20px;font-size:14px;font-weight:700}.subtabs button.active{color:#fff;background-color:#1a5c2a}.character ruby{color:#333;ruby-align:center;white-space:nowrap;font-size:clamp(100px,25vw,150px);font-weight:700}.character.word-mode ruby{font-size:inherit;white-space:nowrap}.character ruby rt{color:#555;letter-spacing:.05em;font-size:.45em;font-weight:400}.word-type-subtabs{background-color:#357a45}.exam-tab-btn{font-weight:700;color:#856404!important;background-color:#fff3cd!important;flex:1.2!important}.exam-tab-btn:active{background-color:#ffc107!important}.modal-overlay{z-index:999;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:16px;width:88%;max-width:360px;padding:28px 24px;box-shadow:0 8px 32px #00000038}.modal-title{color:#1a5c2a;text-align:center;margin:0 0 6px;font-size:20px}.modal-desc{color:#666;text-align:center;margin:0 0 18px;font-size:13px}.modal-categories{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px;display:grid}.modal-cat-label{cursor:pointer;color:#444;-webkit-user-select:none;user-select:none;border:2px solid #ddd;border-radius:10px;align-items:center;gap:8px;padding:12px 10px;font-size:14px;font-weight:700;transition:all .15s;display:flex}.modal-cat-label input[type=checkbox]{accent-color:#28a745;cursor:pointer;width:16px;height:16px}.modal-cat-label.selected{color:#1a5c2a;background:#e8f5e9;border-color:#28a745}.modal-level-section{margin-bottom:18px}.modal-level-label{color:#444;margin:0 0 8px;font-size:13px;font-weight:700}.modal-level-hint{color:#999;font-size:11px;font-weight:400}.modal-levels{gap:10px;display:flex}.modal-level-btn{color:#555;cursor:pointer;background:#fff;border:2px solid #ddd;border-radius:8px;flex:1;padding:10px 0;font-size:14px;font-weight:700;transition:all .15s}.modal-level-btn.selected{color:#fff;background:#28a745;border-color:#28a745}.modal-actions{gap:12px;display:flex}.modal-btn-cancel{cursor:pointer;color:#555;background:#fff;border:2px solid #ddd;border-radius:10px;flex:1;padding:14px;font-size:15px;font-weight:700}.modal-btn-create{color:#fff;cursor:pointer;background:#28a745;border:none;border-radius:10px;flex:2;padding:14px;font-size:15px;font-weight:700;transition:background .15s}.modal-btn-create:disabled{cursor:default;background:#aaa}.modal-btn-create:not(:disabled):active{background:#1a7a32}.exam-screen{box-sizing:border-box;flex-direction:column;flex:1;align-items:center;width:100%;padding:0 16px 16px;display:flex;overflow-y:auto}.exam-header{width:100%;padding:12px 0 6px}.exam-progress-track{background:#ddd;border-radius:4px;width:100%;height:8px;margin-bottom:4px;overflow:hidden}.exam-progress-fill{background:#28a745;border-radius:4px;height:100%;transition:width .3s}.exam-counter{text-align:right;color:#888;font-size:13px;font-weight:700}.exam-card{box-sizing:border-box;background:#fff;border-radius:16px;flex-direction:column;align-items:center;width:100%;margin-bottom:14px;padding:24px 16px;display:flex;box-shadow:0 4px 14px #0000001a}.exam-char{color:#222;text-align:center;margin-bottom:24px;font-size:clamp(44px,13vw,72px);font-weight:700}.exam-char ruby{ruby-align:center;font-size:clamp(44px,13vw,72px);font-weight:700}.exam-char ruby rt{color:#555;font-size:.32em;font-weight:400}.exam-choices{grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}.exam-choice-btn{cursor:pointer;color:#333;word-break:keep-all;background:#fff;border:2px solid #ddd;border-radius:10px;padding:18px 8px;font-family:Malgun Gothic,sans-serif;font-size:14px;font-weight:700;transition:all .15s}.exam-choice-btn:active:not(:disabled){transform:scale(.96)}.exam-choice-btn.correct{color:#fff;background:#28a745;border-color:#28a745}.exam-choice-btn.wrong{color:#fff;background:#dc3545;border-color:#dc3545}.exam-choice-btn.dimmed{opacity:.35}.exam-choice-btn:disabled{cursor:default}.exam-quit-btn{color:#dc3545;cursor:pointer;background:#fff;border:2px solid #dc3545;border-radius:10px;width:100%;padding:13px;font-size:14px;font-weight:700}.exam-result{box-sizing:border-box;flex-direction:column;flex:1;align-items:center;width:100%;padding:24px 16px 16px;display:flex;overflow-y:auto}.result-title{color:#1a5c2a;margin:0 0 20px;font-size:22px}.score-circle{background:#28a745;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:140px;height:140px;margin-bottom:22px;display:flex;box-shadow:0 4px 20px #28a74559}.score-pct{color:#fff;font-size:38px;font-weight:700;line-height:1}.score-frac{color:#ffffffd9;margin-top:4px;font-size:14px}.result-bars{gap:12px;width:100%;margin-bottom:20px;display:flex}.result-bar{border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:14px;font-size:13px;font-weight:700;display:flex}.result-bar span{opacity:.75}.result-bar strong{font-size:20px}.correct-bar{color:#155724;background:#d4edda}.wrong-bar{color:#721c24;background:#f8d7da}.result-actions{gap:12px;width:100%;display:flex}.review-btn{color:#fff;cursor:pointer;background:#007bff;border:none;border-radius:10px;flex:2;padding:14px;font-size:15px;font-weight:700}.exam-exit-btn{color:#555;cursor:pointer;background:#fff;border:2px solid #ddd;border-radius:10px;flex:1;padding:14px;font-size:15px;font-weight:700}.review-list{flex-direction:column;gap:12px;width:100%;margin-bottom:20px;display:flex}.review-item{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 2px 8px #00000014}.review-char{color:#222;text-align:center;margin-bottom:10px;font-size:clamp(22px,6vw,30px);font-weight:700}.review-char ruby{font-size:inherit;ruby-align:center}.review-char ruby rt{color:#666;font-size:.35em;font-weight:400}.review-row{align-items:center;gap:10px;margin-top:4px;font-size:14px;display:flex}.review-label{color:#555;background:#eee;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:11px;font-weight:700}.review-correct-val{color:#28a745;font-weight:700}.review-wrong-val{color:#dc3545;font-weight:700}.exam-back-btn{color:#007bff;cursor:pointer;background:#fff;border:2px solid #007bff;border-radius:10px;width:100%;padding:13px;font-size:14px;font-weight:700}
