@import"https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700&family=Noto+Serif+JP:wght@600;700&display=swap";:root{--bg-color: #f5f2eb;--text-main: #242424;--text-muted: #5d5d5d;--accent: #3f6d62;--accent-soft: #8db7ae;--card-bg: #ffffff;--success: #4d845f;--error: #a37d7d;--washi: #fffaf0;--shadow: 0 12px 28px rgba(0, 0, 0, .08);--ring: rgba(63, 109, 98, .24)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased}body{margin:0;padding:0;background:radial-gradient(circle at top right,rgba(63,109,98,.07),transparent 45%),radial-gradient(circle at bottom left,rgba(141,183,174,.12),transparent 42%),var(--bg-color);color:var(--text-main);font-family:Noto Sans SC,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.65}.app-container{max-width:760px;margin:0 auto;padding:2.6rem 1.1rem 2.1rem;min-height:100vh}header{text-align:center;margin-bottom:2.1rem;position:relative}.brand{display:flex;flex-direction:column;align-items:center}.header-lang{position:absolute;top:-.4rem;right:0;display:flex;align-items:center;gap:.35rem;font-size:.74rem;color:#2f5f54;border:1px solid #d4ddd9;background:#ffffffeb;border-radius:999px;padding:.2rem .35rem .2rem .48rem;box-shadow:0 6px 14px #3f6d621f}.header-lang svg{color:var(--accent)}.header-lang select{min-height:30px;border-radius:999px;border:1px solid #d2d7d5;background:linear-gradient(140deg,#fff,#f1f7f5);padding:.2rem .6rem;font-size:.76rem;color:#234640;font-weight:700}.kanji-logo{font-size:2.35rem;border:2px solid var(--accent);width:62px;height:62px;display:flex;align-items:center;justify-content:center;margin:0 auto .95rem;color:var(--accent);border-radius:12px;background:linear-gradient(140deg,#3f6d620f,#ffffffe6);box-shadow:0 10px 18px #3f6d6221;font-family:"Noto Serif JP",Hiragino Mincho ProN,serif}.title-group h1{font-size:1.7rem;margin:0;font-weight:700;letter-spacing:.06em;font-family:"Noto Serif JP",Hiragino Mincho ProN,serif}.title-group h1 small{margin-left:.45rem;font-size:.95rem;letter-spacing:.02em;color:var(--accent)}.title-group p{font-size:.92rem;color:var(--text-muted);margin:.5rem 0 0;letter-spacing:.01em}.mode-options{display:flex;flex-direction:column;gap:.8rem}.mode-options button{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.1rem;background:#f9f8f4;border:1px solid #d9d8d2;border-radius:11px;cursor:pointer;transition:transform .15s ease,border-color .2s ease,box-shadow .2s ease;font-size:.95rem;text-align:left}.mode-options button.active{background:#3f6d621f;border-color:var(--accent);box-shadow:0 8px 16px #3f6d621c}.mode-options button:hover{transform:translateY(-1px)}.library-switch{margin-top:.85rem;display:flex;gap:.55rem}.library-switch button{flex:1;min-height:36px;border:1px solid #d2d7d5;border-radius:9px;background:#fbfbf8;color:#3f4a47;font-size:.8rem;cursor:pointer;transition:border-color .2s ease,background .2s ease}.library-switch button.active{border-color:var(--accent);background:#3f6d6224;color:var(--accent);font-weight:700}.primary-btn{width:100%;padding:1rem 1.1rem;background:var(--accent);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:transform .15s ease,opacity .2s ease}.primary-btn:disabled{opacity:.55;cursor:not-allowed}.primary-btn:not(:disabled):active{transform:translateY(1px)}.quick-start-card{background:var(--card-bg);border-radius:18px;padding:1.4rem;box-shadow:var(--shadow);margin-bottom:1.2rem;border:1px solid rgba(63,109,98,.12)}.launch-btn{margin-top:1rem}.mode-desc{margin:.35rem 0 0;font-size:.84rem;color:var(--text-muted);line-height:1.45}.card-title{display:flex;align-items:center;gap:.6rem;font-size:.94rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.95rem}.status-text{font-size:.8rem;margin:0 0 .8rem;padding:.5rem;border-radius:8px;background:#5d4e6d14;color:var(--accent)}.status-text.loading{background:#5d4e6d1f}.status-text.error{background:#a37d7d1f;color:#a37d7d}.status-text.done{background:#6b8e6b2e;color:#4b6c4b}.library-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;font-size:.8rem;color:var(--text-muted);letter-spacing:.02em;margin-top:1rem}.library-meta span{background:#3f6d6214;padding:.42rem .65rem;border-radius:10px;text-align:center}.library-submenu{margin-top:.95rem}.library-submenu-toggle{width:100%;min-height:40px;border:1px solid #cdd7d3;border-radius:10px;padding:.55rem .75rem;background:#fff;color:var(--text-main);display:flex;align-items:center;justify-content:space-between;font-size:.84rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,background .2s ease}.library-submenu-toggle:hover{border-color:var(--accent);background:#3f6d620a}.library-submenu-toggle svg{transition:transform .2s ease}.library-submenu-toggle.open svg{transform:rotate(180deg)}.library-submenu-body{margin-top:.6rem;display:flex;flex-direction:column;gap:.7rem}.builtin-picker{display:flex;flex-direction:column;gap:.3rem;font-size:.76rem;color:var(--text-muted)}.builtin-picker select{min-height:36px;border-radius:8px;border:1px solid #d2d7d5;padding:.35rem .5rem;font-size:.8rem;background:#fff}.jlpt-picker{display:flex;flex-direction:column;gap:.3rem;font-size:.76rem;color:var(--text-muted)}.jlpt-picker select{min-height:36px;border-radius:8px;border:1px solid #d2d7d5;padding:.35rem .5rem;font-size:.8rem;background:#fff}.import-panel{display:flex;flex-direction:column;gap:.5rem;padding:.58rem;border:1px solid #e1e8e5;border-radius:10px;background:#ffffffb8}.import-controls{display:flex;gap:.5rem;align-items:center}.import-name-input{flex:1;min-height:40px;border:1px solid #d2d7d5;border-radius:10px;padding:.55rem .7rem;font-size:.82rem;outline:none;background:#fff}.import-name-input:focus{border-color:var(--accent)}.import-btn{display:inline-flex;align-items:center;justify-content:center;min-width:180px;min-height:40px;padding:.6rem .9rem;border:1px dashed var(--accent);border-radius:10px;background:#3f6d620f;color:var(--accent);font-size:.86rem;font-weight:600;cursor:pointer;transition:background .2s ease,border-color .2s ease}.import-btn:hover{background:#3f6d621c;border-color:#2f5f54}.import-btn input{display:none}.import-picker{display:flex;flex-direction:column;gap:.3rem;font-size:.76rem;color:var(--text-muted)}.import-picker select{min-height:34px;border-radius:8px;border:1px solid #d2d7d5;padding:.35rem .5rem;font-size:.8rem;background:#fff}.import-note{margin:0;font-size:.76rem;color:var(--accent)}.import-status{margin:0;padding:.5rem .6rem;border-radius:8px;font-size:.78rem;line-height:1.4}.import-status.done{color:#2f6f3f;background:#4d845f1f;border:1px solid rgba(77,132,95,.35)}.import-status.error{color:#8f3030;background:#c744441f;border:1px solid rgba(199,68,68,.35)}.library-stats{font-size:.75rem;color:var(--text-muted);margin-left:auto;align-self:center}.practice-view{display:flex;flex-direction:column}.practice-view.wrong .word-card{border:2px solid #c74444;box-shadow:0 0 0 4px #c744442e,var(--shadow);animation:wrong-shake .22s ease-in-out}.stats-header{display:flex;justify-content:flex-start;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.score-badge{background:var(--accent-soft);color:#fff;padding:.2rem .7rem;border-radius:20px;font-size:.75rem}.exit-link{background:none;border:none;color:var(--text-muted);text-decoration:underline;font-size:.75rem;cursor:pointer}.word-card{background:var(--card-bg);padding:2.5rem 1.2rem;border-radius:16px;box-shadow:var(--shadow);text-align:center;margin-bottom:1.5rem;min-height:180px;display:flex;align-items:center;justify-content:center}.word-display{width:100%}.sentence-display{font-size:1.3rem;text-align:left;width:100%}.underlined-target{display:inline-block;border-bottom:2px solid var(--accent);padding:0 .3rem;margin:0 .3rem;position:relative;font-weight:600;color:var(--accent)}.type-badge{position:absolute;top:-1.2rem;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;font-size:.55rem;padding:.1rem .3rem;border-radius:2px;white-space:nowrap}.target-reading{font-size:2.5rem;color:var(--accent);letter-spacing:.06em}.handwriting-section{background:var(--card-bg);border-radius:12px;padding:.8rem;box-shadow:var(--shadow)}.handwriting-container{position:relative;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.custom-cursor{position:absolute;top:0;left:0;width:30px;height:30px;pointer-events:none;z-index:100;margin-left:-15px;margin-top:-15px;display:none}.canvas-wrapper{background:var(--washi);border:1px solid #dcd3c1;border-radius:8px;padding:0;overflow:hidden;box-shadow:inset 0 2px 4px #00000008;position:relative;touch-action:none;cursor:crosshair}canvas{width:100%;height:300px;display:block;touch-action:none;cursor:crosshair;background-image:linear-gradient(to right,rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(to bottom,rgba(0,0,0,.05) 1px,transparent 1px);background-size:50px 50px;background-position:center}.canvas-actions{display:flex;gap:8px;margin-top:10px}.action-btn{flex:1;padding:.8rem;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.85rem}.action-btn.secondary{background:#e8e4db;color:#555}.action-btn.primary,.action-btn.active{background:var(--accent);color:#fff}.candidates-bar{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px;min-height:50px;align-items:center;justify-content:center;padding:5px}.candidate-btn{min-width:48px;width:auto;height:48px;padding:0 12px;background:var(--card-bg);border:1px solid var(--accent-soft);border-radius:8px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 5px #0000000d;color:var(--text-main);white-space:nowrap}.candidate-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 8px #5d4e6d33}.candidate-btn:active{transform:translateY(0)}.hint-text{font-size:.75rem;color:var(--text-muted)}.input-area{display:flex;gap:.5rem;background:#fff;padding:.4rem;border-radius:12px;border:2px solid transparent;box-shadow:var(--shadow)}.input-area.correct{border-color:var(--success)}.input-area.wrong{border-color:var(--error)}.input-area input{flex:1;border:none;padding:.8rem;font-size:1.1rem;outline:none}.submit-btn{background:var(--accent);color:#fff;border:none;width:44px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}.submit-btn:active{transform:translateY(1px)}.feedback-hint-bar{margin:.85rem 0 1.1rem;display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.feedback-alert{width:100%;margin:.75rem 0 .25rem;padding:.75rem .95rem;border-radius:10px;font-size:.95rem;font-weight:700;letter-spacing:.02em;text-align:center}.feedback-alert.error{color:#fff;background:#c74444;border:1px solid #9f2f2f;box-shadow:0 8px 16px #c7444447}.feedback-alert.success{color:#104a2c;background:linear-gradient(90deg,#81e0acd9,#b1f3cbeb);border:1px solid rgba(38,141,84,.45);box-shadow:0 8px 16px #45ad7038}.hint-btn{background:#fff;border:1px solid var(--accent-soft);color:var(--accent);padding:.5rem 1rem;border-radius:20px;font-size:.8rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.hint-btn:hover{background:var(--accent-soft);color:#fff}.hint-display{font-size:.9rem;color:var(--accent);background:#5d4e6d0d;padding:.8rem 1.5rem;border-radius:8px;border-left:3px solid var(--accent)}button:focus-visible,input:focus-visible{outline:3px solid var(--ring);outline-offset:1px}@keyframes wrong-shake{0%{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-2px)}to{transform:translate(0)}}@media (max-width: 640px){.app-container{max-width:520px;padding:1.25rem .85rem 1.2rem}header{margin-bottom:1.2rem;padding-top:2rem}.header-lang{top:0;right:0;left:auto;margin:0;transform:none;z-index:15}.header-lang span{display:none}.kanji-logo{width:46px;height:46px;font-size:1.8rem}.title-group h1{font-size:1.35rem}.title-group h1 small{font-size:.8rem}.word-card{min-height:150px;padding:1.5rem .9rem;margin-bottom:1rem}.sentence-display{font-size:1.05rem}.target-reading{font-size:2rem}.library-stats{margin-left:0}.library-meta{grid-template-columns:1fr;gap:.45rem}.library-switch{flex-direction:column;gap:.4rem}.import-controls{flex-direction:column;align-items:stretch}.import-btn{width:100%;min-width:0}.stats-header{gap:.4rem}.score-badge,.library-stats,.exit-link{font-size:.7rem}canvas{height:340px}.candidate-btn{min-width:44px;height:44px;font-size:1.05rem}.feedback-hint-bar{position:static;margin:.7rem 0 .9rem;gap:.65rem;z-index:auto}.hint-btn{width:100%;min-height:44px;justify-content:center;border-radius:12px;border-color:#bfd4cf;box-shadow:0 8px 16px #3f6d6224}.hint-display{width:100%;border-radius:10px;padding:.65rem .85rem;font-size:.84rem}}
