@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 8px 20px rgba(0, 0, 0, .06);--ring: rgba(63, 109, 98, .24);--safe-bottom: env(safe-area-inset-bottom, 0px);--bottom-bar-h: calc(56px + var(--safe-bottom))}*{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:100%;margin:0 auto;padding:1rem .85rem;padding-bottom:calc(1rem + var(--safe-bottom));min-height:100vh}@media (min-width: 640px){.app-container{max-width:540px;padding:1.8rem 1.1rem}}@media (min-width: 1024px){.app-container{max-width:760px;padding:2.6rem 1.1rem 2.1rem}}.home-header{text-align:center;margin-bottom:1.5rem;padding-top:.5rem}.home-logo{font-size:1.8rem;border:2px solid var(--accent);width:48px;height:48px;display:flex;align-items:center;justify-content:center;margin:0 auto .6rem;color:var(--accent);border-radius:12px;background:linear-gradient(140deg,#3f6d620f,#ffffffe6);box-shadow:0 6px 14px #3f6d6221;font-family:"Noto Serif JP",Hiragino Mincho ProN,serif}.home-title{font-size:1.35rem;margin:0;font-weight:700;letter-spacing:.04em;font-family:"Noto Serif JP",Hiragino Mincho ProN,serif}.home-title small{margin-left:.35rem;font-size:.8rem;color:var(--accent)}@media (min-width: 640px){.home-logo{width:62px;height:62px;font-size:2.35rem;margin-bottom:.95rem}.home-title{font-size:1.7rem}.home-title small{font-size:.95rem}}.mode-cards{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1rem}.mode-card{display:flex;align-items:center;gap:.85rem;padding:.9rem 1rem;background:var(--card-bg);border:2px solid transparent;border-radius:14px;cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;box-shadow:var(--shadow);min-height:72px;text-align:left;width:100%;font-family:inherit;font-size:inherit}.mode-card.selected{border-color:var(--accent);background:#3f6d620f;box-shadow:0 8px 16px #3f6d621c}.mode-card:active{transform:translateY(1px)}.mode-card-icon{font-size:1.5rem;flex-shrink:0;width:40px;text-align:center}.mode-card-text strong{display:block;font-size:.95rem;color:var(--text-main)}.mode-card-text p{margin:.2rem 0 0;font-size:.8rem;color:var(--text-muted);line-height:1.4}.jlpt-chips{display:flex;gap:.45rem;margin-bottom:1rem;flex-wrap:wrap}.jlpt-chip{flex:1;min-width:52px;height:40px;border-radius:999px;border:1.5px solid #d2d7d5;background:var(--card-bg);color:var(--text-muted);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.jlpt-chip.selected{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 4px 10px #3f6d6233}.jlpt-chip:active{transform:translateY(1px)}@media (min-width: 640px){.jlpt-chip{height:44px;font-size:.88rem}}.start-bar{position:fixed;bottom:0;left:0;right:0;z-index:20;background:#fffffff2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid rgba(63,109,98,.1);padding:.6rem .85rem;padding-bottom:calc(.6rem + var(--safe-bottom));display:flex;align-items:center;gap:.6rem}.start-bar .primary-btn{flex:1}.start-bar-lang{display:flex;align-items:center;gap:.25rem;font-size:.72rem;color:var(--accent)}.start-bar-lang select{min-height:32px;border-radius:8px;border:1px solid #d2d7d5;background:#fff;padding:.15rem .35rem;font-size:.75rem;color:#234640;font-weight:600}@media (min-width: 640px){.start-bar{position:static;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border-top:none;padding:1rem 0 0}}.primary-btn{display:flex;align-items:center;justify-content:center;width:100%;min-height:48px;padding:.85rem 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,opacity .2s;font-family:inherit}.primary-btn:disabled{opacity:.55;cursor:not-allowed}.primary-btn:not(:disabled):active{transform:translateY(1px)}.home-bottom-spacer{height:var(--bottom-bar-h)}@media (min-width: 640px){.home-bottom-spacer{display:none}}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid var(--ring);outline-offset:1px}.library-submenu{margin-bottom:1rem}.library-submenu-toggle{width:100%;min-height:44px;border:1px solid #cdd7d3;border-radius:12px;padding:.55rem .75rem;background:var(--card-bg);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,background .2s;font-family:inherit}.library-submenu-toggle:hover{border-color:var(--accent);background:#3f6d620a}.library-submenu-toggle svg{transition:transform .2s}.library-submenu-toggle.open svg{transform:rotate(180deg)}.library-submenu-body{margin-top:.6rem;display:flex;flex-direction:column;gap:.7rem}.library-switch{display:flex;flex-direction:column;gap:.4rem}.library-switch button{flex:1;min-height:40px;border:1px solid #d2d7d5;border-radius:10px;background:#fbfbf8;color:#3f4a47;font-size:.82rem;cursor:pointer;transition:border-color .2s,background .2s;font-family:inherit}.library-switch button.active{border-color:var(--accent);background:#3f6d6224;color:var(--accent);font-weight:700}@media (min-width: 640px){.library-switch{flex-direction:row;gap:.55rem}}.builtin-picker,.jlpt-picker{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;color:var(--text-muted)}.builtin-picker select,.jlpt-picker select{min-height:40px;border-radius:10px;border:1px solid #d2d7d5;padding:.4rem .5rem;font-size:.82rem;background:#fff}.import-note{margin:0;font-size:.76rem;color:var(--accent)}.library-meta{display:grid;grid-template-columns:1fr;gap:.45rem;font-size:.8rem;color:var(--text-muted);letter-spacing:.02em}.library-meta span{background:#3f6d6214;padding:.42rem .65rem;border-radius:10px;text-align:center}@media (min-width: 640px){.library-meta{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}}.import-panel{display:flex;flex-direction:column;gap:.5rem;padding:.58rem;border:1px solid #e1e8e5;border-radius:10px;background:#ffffffb8}.import-controls{display:flex;flex-direction:column;gap:.5rem;align-items:stretch}.import-name-input{flex:1;min-height:44px;border:1px solid #d2d7d5;border-radius:10px;padding:.55rem .7rem;font-size:.84rem;outline:none;background:#fff}.import-name-input:focus{border-color:var(--accent)}.import-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;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,border-color .2s}.import-btn:hover{background:#3f6d621c;border-color:#2f5f54}.import-btn input{display:none}@media (min-width: 640px){.import-controls{flex-direction:row;align-items:center}.import-btn{min-width:180px}}.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)}.practice-view{position:relative;display:flex;flex-direction:column;min-height:calc(100vh - 2rem);padding-bottom:var(--bottom-bar-h)}.practice-topbar{margin-bottom:.6rem}.status-text{font-size:.8rem;margin:0;padding:.4rem .65rem;border-radius:999px;text-align:center;font-weight:600}.status-text.loading{background:#5d4e6d14;color:var(--accent)}.status-text.error{background:#a37d7d1f;color:var(--error)}.status-text.done{background:#6b8e6b1f;color:#4b6c4b}.question-card{background:var(--card-bg);padding:1rem .9rem;border-radius:16px;box-shadow:var(--shadow);text-align:center;margin-bottom:.8rem;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.6rem;border:2px solid transparent;transition:border-color .3s,background .3s}.question-card.feedback-correct{border-color:var(--success);background:linear-gradient(to bottom,rgba(77,132,95,.08),var(--card-bg))}.question-card.feedback-wrong{border-color:var(--error);background:linear-gradient(to bottom,rgba(163,125,125,.08),var(--card-bg));animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@media (min-width: 640px){.question-card{padding:1.5rem 1.4rem;margin-bottom:1.2rem;gap:.85rem}}.card-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:.35rem;font-size:.7rem;color:#3c3c3c99;width:100%}.card-stats span{background:#3f6d620f;padding:.15rem .45rem;border-radius:999px}@media (min-width: 640px){.card-stats{gap:.5rem;font-size:.75rem}}.word-display{width:100%}.sentence-display{font-size:1.05rem;text-align:left;line-height:1.8;padding-top:1rem}.underlined-target{display:inline-block;border-bottom:2px solid var(--accent);padding:0 .3rem;margin:0 .15rem;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:.08rem .28rem;border-radius:3px;white-space:nowrap}.target-reading{font-size:2rem;color:var(--accent);letter-spacing:.06em}@media (min-width: 640px){.sentence-display{font-size:1.3rem}.target-reading{font-size:2.5rem}}.feedback-inline{display:flex;align-items:center;justify-content:center;gap:.35rem;font-size:.82rem;font-weight:600;padding:.35rem .65rem;border-radius:8px;width:100%}.feedback-inline.success{color:var(--success);background:#4d845f1a}.feedback-inline.error{color:var(--error);background:#a37d7d1a}.hint-inline{font-size:.85rem;color:var(--accent);padding:.5rem .7rem;border-radius:8px;background:#3f6d620f;border:1px solid rgba(63,109,98,.15);width:100%;text-align:left;overflow:hidden}.hw-char-progress{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:.4rem;width:100%}.hw-char{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;font-size:1.2rem;border-radius:8px;border:2px solid transparent;transition:all .2s}.hw-char.done{color:var(--text-main);background:#81e0ac40;border-color:#268d5459;font-weight:700}.hw-char.active{color:var(--accent);background:#5d4e6d14;border-color:var(--accent);font-weight:700}.hw-char.pending{color:#3c3c3c59}.hw-tip{font-size:.8rem;font-weight:600;text-align:center;margin-bottom:.5rem;padding:.35rem .6rem;border-radius:8px;color:var(--accent);background:#5d4e6d0f}.bottom-bar{position:fixed;bottom:0;left:0;right:0;z-index:20;height:var(--bottom-bar-h);background:#fffffff2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid rgba(63,109,98,.1);display:flex;align-items:center;justify-content:space-between;padding:0 .85rem;padding-bottom:var(--safe-bottom)}.bottom-bar-btn{display:flex;align-items:center;gap:.3rem;background:none;border:none;color:var(--accent);font-size:.78rem;font-weight:600;cursor:pointer;padding:.5rem;min-width:48px;min-height:48px;justify-content:center;border-radius:10px;transition:background .2s;font-family:inherit}.bottom-bar-btn:active{background:#3f6d6214}.bottom-bar-btn.hint-btn.active{color:#fff;background:var(--accent);border-radius:10px}.bottom-bar-lang{display:flex;align-items:center;gap:.2rem;color:var(--accent)}.bottom-bar-lang select{min-height:32px;border-radius:8px;border:1px solid #d2d7d5;background:#fff;padding:.1rem .3rem;font-size:.72rem;color:#234640;font-weight:600}.input-stack{display:flex;flex-direction:column;gap:.55rem}.input-mode-toggle{display:inline-flex;align-items:center;gap:.35rem;background:#5d4e6d14;padding:.2rem;border-radius:999px;width:fit-content}.input-mode-toggle button{border:none;background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;padding:.35rem .65rem;border-radius:999px;cursor:pointer;transition:all .2s;font-family:inherit}.input-mode-toggle button.active{background:#fff;color:var(--accent);box-shadow:0 4px 10px #3f6d621f}.input-area{display:flex;gap:.5rem;background:#fff;padding:.35rem;border-radius:12px;border:2px solid transparent;box-shadow:var(--shadow)}.input-area input{flex:1;border:none;padding:.75rem;font-size:1rem;outline:none;min-height:44px}.submit-btn{background:var(--accent);color:#fff;border:none;width:48px;min-height:48px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s}.submit-btn:active{transform:translateY(1px)}.kana-input-area{display:flex;flex-direction:column;gap:.5rem}.kana-display{min-height:44px;flex:1;display:flex;align-items:center;padding:.75rem;font-size:1rem;color:var(--text-main);background:#fff;border:none}.handwriting-section{background:var(--card-bg);border-radius:12px;padding:.6rem;box-shadow:var(--shadow)}.handwriting-container{position:relative;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.custom-cursor{display:none}.canvas-wrapper{background:var(--washi);border:1px solid #dcd3c1;border-radius:8px;overflow:hidden;box-shadow:inset 0 2px 4px #00000008;position:relative;touch-action:none;cursor:crosshair}canvas{width:100%;height:280px;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}@media (min-width: 640px){canvas{height:300px}}.canvas-actions{display:flex;gap:8px;margin-top:8px;align-items:center}.tool-toggle{display:flex;gap:4px;background:#f3efe7;padding:3px;border-radius:999px;border:1px solid rgba(93,78,109,.16)}.action-group{margin-left:auto;display:flex;gap:6px}.action-btn{padding:.55rem .7rem;border-radius:10px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;font-size:.8rem;font-weight:600;min-height:44px;transition:transform .12s,background .2s,color .2s;font-family:inherit}.action-btn.toggle{border-radius:999px;background:transparent;color:#5b5561;border:1px solid transparent}.action-btn.toggle.active{background:var(--accent);color:#fff;box-shadow:0 4px 10px #5d4e6d33}.action-btn.ghost{background:#f1ece2;color:#5e5a55;border:1px solid rgba(93,78,109,.18)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.recognize-hint{position:absolute;right:8px;bottom:8px;font-size:.7rem;color:#2828288c;padding:2px 6px;border-radius:999px;background:#ffffff8c;pointer-events:none}.recognize-hint.active{color:#282828b3;font-weight:600;background:#ffffffb3}.kana-pad{display:flex;flex-direction:column;gap:.5rem;background:#fffffff5;border-radius:14px;padding:.5rem;border:1px solid rgba(93,78,109,.18);box-shadow:var(--shadow)}.kana-type-toggle{display:inline-flex;align-items:center;gap:.3rem;background:#5d4e6d14;padding:.2rem;border-radius:999px;width:fit-content}.kana-type-toggle button{border:none;background:transparent;color:var(--text-muted);font-size:.7rem;font-weight:600;padding:.28rem .55rem;border-radius:999px;cursor:pointer;transition:all .2s;font-family:inherit}.kana-type-toggle button.active{background:#fff;color:var(--accent);box-shadow:0 4px 10px #3f6d621f}.kana-flick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.4rem}.kana-flick-key{position:relative;height:52px;border-radius:12px;border:1px solid rgba(93,78,109,.14);background:#fff;color:#2f3f3b;font-size:.95rem;cursor:pointer;touch-action:none;user-select:none;-webkit-user-select:none;transition:transform .1s,background .2s}.kana-flick-key:active{transform:translateY(1px)}.kana-center{font-size:1rem;font-weight:700}.kana-hint{position:absolute;font-size:.55rem;color:var(--text-muted);opacity:.7}.kana-hint.up{top:4px;left:50%;transform:translate(-50%)}.kana-hint.down{bottom:4px;left:50%;transform:translate(-50%)}.kana-hint.left{left:5px;top:50%;transform:translateY(-50%)}.kana-hint.right{right:5px;top:50%;transform:translateY(-50%)}@media (min-width: 640px){.kana-flick-key{height:64px;font-size:1.05rem}.kana-hint{font-size:.62rem}.kana-center{font-size:1.1rem}}.kana-flick-overlay{position:absolute;width:120px;height:120px;top:-8px;left:50%;transform:translate(-50%,-100%) scale(.95);border-radius:50%;background:#fffffff5;border:2px solid rgba(93,78,109,.25);box-shadow:0 10px 22px #3f6d6233;display:none;pointer-events:none;z-index:2}.kana-flick-overlay.active{display:block;transform:translate(-50%,-100%) scale(1)}.kana-overlay{position:absolute;font-size:.8rem;font-weight:700;color:var(--accent)}.kana-overlay.active{color:#0f2d26;background:#81e0ac73;border-radius:999px;padding:.1rem .35rem}.kana-overlay.up{top:10px;left:50%;transform:translate(-50%)}.kana-overlay.down{bottom:10px;left:50%;transform:translate(-50%)}.kana-overlay.left{left:12px;top:50%;transform:translateY(-50%)}.kana-overlay.right{right:12px;top:50%;transform:translateY(-50%)}.kana-overlay.center{top:50%;left:50%;transform:translate(-50%,-50%);font-size:.95rem;color:#1f2b28}.kana-actions{display:flex;gap:.4rem}.kana-action-btn{flex:1;height:44px;border-radius:10px;border:1px solid rgba(93,78,109,.2);background:#fff;color:var(--accent);font-weight:600;cursor:pointer;font-size:.82rem;font-family:inherit}.candidates-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;min-height:48px;align-items:center;justify-content:center;padding:4px;background:#ffffff80;border:1px solid rgba(93,78,109,.08);border-radius:12px}.candidate-btn{min-width:44px;height:44px;padding:0 10px;background:var(--card-bg);border:1px solid var(--accent-soft);border-radius:8px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 5px #0000000d;color:var(--text-main)}.candidate-btn:active{background:var(--accent);color:#fff;border-color:var(--accent)}.question-card.skeleton{min-height:140px;width:100%}.skeleton-line{height:.9rem;border-radius:6px;background:#3f6d6214;animation:pulse 1.4s ease-in-out infinite}.skeleton-line.w60{width:60%}.skeleton-line.w80{width:80%}.skeleton-line.w40{width:40%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton-status{font-size:.78rem;color:var(--text-muted);margin:0;animation:pulse 1.4s ease-in-out infinite}.skeleton-center{flex:1;display:flex;align-items:center;justify-content:center}
