@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Noto+Sans+JP:wght@300;400;700&family=Noto+Serif+JP:wght@300;400;700&family=Zen+Kurenaido&family=Kaisei+Decol:wght@400;700&display=swap";:root{--bg:#0f0f14;--surface:#1a1a24;--border:#2a2a3a;--text:#e8e0ff;--muted:#6b6580;--accent:#7c6af7;--accent-dim:#3d3478;--success:#4ade80;--error:#ff4757;--font-ui:"Inter", sans-serif;--font-jp:"Noto Sans JP", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);min-height:100vh}#app{flex-direction:column;align-items:center;width:100%;min-height:100vh;display:flex}header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;width:100%;padding:20px 32px;display:flex}.logo{letter-spacing:.12em;color:var(--accent);font-size:1.3rem;font-weight:600}.logo span{color:var(--text)}.header-actions{align-items:center;gap:10px;display:flex}.view-config,.view-test,.view-recap,.view-revision{flex-direction:column;gap:32px;width:100%;max-width:720px;padding:40px 24px;display:flex}.view-test{align-items:center;gap:0}.view-recap{align-items:center;gap:24px}.view-revision{gap:0;max-width:900px}.section-title{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-size:.7rem;font-weight:600}.chip-group{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--border);color:var(--muted);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:999px;padding:7px 16px;font-size:.85rem;transition:all .15s}.chip:hover{border-color:var(--accent);color:var(--text)}.chip.on{background:var(--accent-dim);border-color:var(--accent);color:var(--text)}.row-label{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;padding:9px 0;font-size:.88rem;display:flex}.row-label:last-child{border-bottom:none}.row-label input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:15px;height:15px}.row-label .lbl-main{color:var(--text);flex:1}.row-label .lbl-jp{font-family:var(--font-jp);color:var(--muted);letter-spacing:.04em;white-space:nowrap;font-size:1rem}.kana-groups{flex-direction:column;display:flex}.toggle-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 0;font-size:.9rem;display:flex}.toggle-row:last-child{border-bottom:none}.toggle{width:40px;height:22px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-track{background:var(--border);cursor:pointer;border-radius:999px;transition:background .2s;position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--accent)}.toggle-track:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-track:after{transform:translate(18px)}.btn-primary{background:var(--accent);color:#fff;font-family:var(--font-ui);cursor:pointer;letter-spacing:.04em;border:none;border-radius:10px;align-self:center;padding:14px 32px;font-size:1rem;font-weight:600;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.85}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.35;cursor:not-allowed}.btn-ghost{color:var(--muted);border:1px solid var(--border);font-family:var(--font-ui);cursor:pointer;background:0 0;border-radius:8px;padding:10px 22px;font-size:.85rem;transition:all .15s}.btn-ghost:hover{border-color:var(--muted);color:var(--text)}.config-block{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 22px}.btn-selall{border:1px solid var(--border);color:var(--muted);font-family:var(--font-ui);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:4px 10px;font-size:.72rem;transition:all .15s}.btn-selall:hover{border-color:var(--muted);color:var(--text)}.test-topbar{justify-content:space-between;align-items:center;width:100%;margin-bottom:32px;display:flex}.progress-wrap{flex-direction:column;flex:1;gap:6px;display:flex}.progress-info{color:var(--muted);justify-content:space-between;font-size:.78rem;display:flex}.progress-bar{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.kana-stage{justify-content:center;align-items:center;width:260px;height:260px;margin:0 auto 40px;transition:transform .1s;display:flex;position:relative}.kana-stage.words-mode{width:100%;max-width:560px;height:140px}.kana-stage.fc-clickable{cursor:pointer}.kana-stage.fc-clickable:hover .kana-display{color:var(--accent);transition:color .15s}.kana-stage.fc-clickable:active{transform:scale(.97)}.kana-halo{pointer-events:none;background:radial-gradient(circle,#7c6af72e 0%,#0000 70%);border-radius:50%;width:220px;height:220px;transition:opacity .4s;position:absolute}.kana-halo.revealed{background:radial-gradient(circle,#4ade801f 0%,#0000 70%)}.kana-display{font-family:var(--font-jp);color:var(--text);-webkit-user-select:none;user-select:none;z-index:1;white-space:nowrap;font-size:11rem;line-height:1;position:relative}.kana-display.romaji-mode{font-family:var(--font-ui);letter-spacing:.06em;font-size:4rem;font-weight:300}@keyframes fadeIn{0%{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.kana-display.fade-in{animation:.2s fadeIn}.input-wrap{width:100%;max-width:320px;margin-bottom:8px;position:relative}.kana-input{background:var(--surface);border:1.5px solid var(--border);width:100%;color:var(--text);font-family:var(--font-ui);text-align:center;letter-spacing:.08em;caret-color:var(--accent);border-radius:10px;outline:none;padding:14px 18px;font-size:1.1rem;transition:border-color .15s}.kana-input:focus{border-color:var(--accent)}.kana-input.error{border-color:var(--error);animation:.35s shake}.kana-input.correct{border-color:var(--success)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.hint-text{color:var(--error);text-align:center;min-height:20px;margin-top:8px;font-size:.8rem}.qcm-grid{gap:12px;width:100%;max-width:400px;margin-bottom:8px;display:grid}.qcm-btn{background:var(--surface);border:1.5px solid var(--border);color:var(--text);font-family:var(--font-jp);cursor:pointer;border-radius:10px;padding:18px 12px;font-size:2.4rem;transition:border-color .15s,background .15s;position:relative}.qcm-btn .key-hint{font-family:var(--font-ui);color:var(--muted);font-size:.65rem;font-weight:500;position:absolute;top:6px;left:8px}.qcm-btn:hover{border-color:var(--accent);background:#7c6af714}.qcm-btn.error{border-color:var(--error);background:#ff47571f;animation:.35s shake}.qcm-btn.correct{border-color:var(--success);background:#4ade801f}.qcm-btn:disabled{cursor:default}.flashcard-reveal{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:320px;display:flex}.flashcard-answer{font-family:var(--font-jp);color:var(--success);justify-content:center;align-items:center;min-height:80px;font-size:5rem;line-height:1;display:flex}.flashcard-hint{color:var(--muted);text-align:center;letter-spacing:.04em;font-size:.8rem}.flashcard-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:4px;display:flex}.btn-fc{border:1.5px solid var(--border);font-family:var(--font-ui);cursor:pointer;color:var(--muted);background:0 0;border-radius:8px;padding:10px 20px;font-size:.85rem;transition:all .15s}.btn-fc:hover{border-color:var(--accent);color:var(--text)}.btn-fc.primary{border-color:var(--accent);color:var(--accent)}.btn-fc.primary:hover{background:var(--accent-dim);color:var(--text)}.stats-bar{color:var(--muted);gap:24px;margin-top:32px;font-size:.8rem;display:flex}.stats-bar span{align-items:center;gap:5px;display:flex}.stats-bar b{color:var(--text)}.word-translation{color:var(--muted);letter-spacing:.04em;text-align:center;min-height:22px;margin-top:-28px;margin-bottom:40px;font-size:.95rem}.recap-title{text-align:center;font-size:1.4rem;font-weight:600}.recap-sub{color:var(--muted);text-align:center;font-size:.9rem}.recap-score{color:var(--accent);text-align:center;font-size:3.5rem;font-weight:700}.recap-score span{color:var(--muted);font-size:1.2rem;font-weight:400}.recap-errors{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:480px;padding:18px 20px}.recap-errors-title{text-transform:uppercase;letter-spacing:.15em;color:var(--muted);margin-bottom:12px;font-size:.7rem}.recap-kana-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:7px 0;font-size:.9rem;display:flex}.recap-kana-row:last-child{border-bottom:none}.recap-kana-char{font-family:var(--font-jp);font-size:1.4rem}.recap-kana-errors{color:var(--error);font-size:.82rem}.recap-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.revision-section{margin-bottom:40px}.revision-section-title{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-size:.7rem;font-weight:600}.revision-group-title{color:var(--muted);letter-spacing:.06em;margin:20px 0 8px;font-size:.78rem}.revision-group-title:first-child{margin-top:0}.revision-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px;display:grid}.rev-cell{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;display:flex}.rev-cell .rev-kana{font-family:var(--font-jp);color:var(--text);font-size:1.6rem;line-height:1}.rev-cell .rev-rom{color:var(--muted);letter-spacing:.04em;font-size:.68rem}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
