.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:22px;font-weight:700}.modal-close-btn{background:#f2f2f7;border:none;font-size:14px;font-weight:600;padding:8px 16px;border-radius:var(--radius-full);cursor:pointer;color:var(--text-primary)}.modal-close-btn:hover{background:#e5e5ea}.modal-body{padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.search-input-wrapper{position:relative}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{width:100%;padding:12px 14px 12px 42px;font-size:15px;background-color:#f2f2f7;border:none;border-radius:var(--radius-md);outline:none}.search-input:focus{background-color:#e5e5ea}.action-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.action-row{display:flex;align-items:center;gap:12px;padding:16px;width:100%;background:none;border:none;text-align:left;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s ease}.action-row:not(:last-child){border-bottom:1px solid var(--border-color)}.action-row:hover{background-color:#f8f8fb}.action-row.orange{color:var(--accent-orange)}.action-row.red{color:var(--error-color)}.word-list-section{display:flex;flex-direction:column;gap:8px}.word-list-title{font-size:14px;font-weight:700;color:var(--text-secondary);margin-bottom:4px}.word-item-card{background:#f8f9fa;border-radius:var(--radius-md);padding:12px 16px;display:flex;justify-content:space-between;align-items:flex-start}.word-item-en{font-size:16px;font-weight:700}.word-item-ja{font-size:15px;color:var(--text-secondary)}.word-item-ex{font-size:13px;color:var(--text-muted);margin-top:4px}.home-header{text-align:center;margin-bottom:28px}.home-title{font-size:32px;font-weight:800;letter-spacing:-.5px;margin-bottom:4px}.home-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.top-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.section-title{font-size:18px;font-weight:700;margin-bottom:14px}.mode-list{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}.mode-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;border:2px solid transparent;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.mode-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.mode-card.selected{border-color:var(--primary-color);background-color:#fff}.mode-left{display:flex;align-items:center;gap:16px}.mode-icon-box{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mode-icon-box.purple{background-color:#f3e8ff;color:#a855f7}.mode-icon-box.blue{background-color:#e0f2fe;color:#0284c7}.mode-icon-box.cyan{background-color:#e0f7fa;color:#00acc1}.mode-icon-box.orange{background-color:#ffedd5;color:#ea580c}.mode-icon-box.indigo{background-color:#e0e7ff;color:#4f46e5}.mode-title-text{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:2px}.mode-desc-text{font-size:13px;color:var(--text-muted)}.check-circle-icon{width:22px;height:22px;border-radius:50%;background-color:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.count-selector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:32px}.count-btn{padding:14px 0;background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:16px;font-weight:700;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.count-btn.selected{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 4px 12px #007aff33}.quiz-question-card{background-color:var(--card-bg);border-radius:var(--radius-lg);padding:32px 24px;text-align:center;box-shadow:var(--shadow-sm);margin-bottom:24px;border:1px solid rgba(0,0,0,.04)}.quiz-instruction{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.quiz-main-term{font-size:36px;font-weight:700;color:var(--text-primary);margin-bottom:16px;letter-spacing:-.5px}.quiz-example-sentence{font-size:15px;font-style:italic;color:var(--text-muted);line-height:1.4}.options-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.option-card{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;background-color:#fff;border:2px solid #e5e5ea;border-radius:var(--radius-md);font-size:18px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.option-card:hover:not(:disabled){border-color:var(--primary-color);background-color:var(--primary-light)}.option-card.correct{background-color:var(--success-bg);border-color:var(--success-border);color:#1b5e20;font-weight:600}.option-card.incorrect{background-color:var(--error-bg);border-color:var(--error-border);color:#b71c1c;font-weight:600}.option-card.dimmed{opacity:.5}.option-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%}.option-icon.correct-icon{background-color:var(--success-color);color:#fff}.option-icon.incorrect-icon{background-color:var(--error-color);color:#fff}.btn-green{background-color:#34c759;color:#fff;box-shadow:0 4px 12px #34c75940}.btn-green:hover{background-color:#2fb350}.handwriting-container{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:16px}.handwriting-header{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--text-secondary);flex-wrap:wrap;gap:8px}.pencil-instruction{display:flex;align-items:center;gap:6px}.mode-toggle-group{display:flex;align-items:center;gap:8px}.mode-toggle-btn{background:#e5e5ea;border:none;font-size:12px;font-weight:600;padding:4px 10px;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mode-toggle-btn.active{background:var(--primary-color);color:#fff}.clear-btn{background:none;border:none;color:#ff3b30;font-size:14px;font-weight:500;display:flex;align-items:center;gap:4px;cursor:pointer;padding:4px 8px;border-radius:6px}.clear-btn:hover{background-color:#ffefee}.canvas-wrapper{position:relative;width:100%;height:220px;background-color:#fff;border:2px solid #b3d7ff;border-radius:var(--radius-md);overflow:hidden;box-shadow:inset 0 2px 4px #00000005;touch-action:none;user-select:none;-webkit-user-select:none}.canvas-placeholder{position:absolute;top:16px;left:16px;color:#c7c7cc;font-size:16px;pointer-events:none;z-index:1}.drawing-canvas{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2}.scribble-textarea{position:absolute;top:0;left:0;width:100%;height:100%;z-index:3;border:none;outline:none;resize:none;font-size:24px;padding:16px;background:transparent;color:transparent;caret-color:transparent!important;line-height:1.4;touch-action:none;-webkit-user-modify:read-write-plaintext-only!important;-webkit-text-decorations-in-effect:none!important;text-decoration:none!important;border-bottom:none!important}.scribble-textarea:focus{outline:none}.recognition-result-section{display:flex;flex-direction:column;gap:8px;margin-top:8px}.recognition-label{font-size:13px;color:var(--text-secondary)}.recognition-input-wrapper{position:relative;display:flex;align-items:center}.recognition-input-icon{position:absolute;left:14px;color:var(--primary-color);font-size:16px;font-weight:600}.recognition-input{width:100%;padding:14px 14px 14px 40px;font-size:18px;font-weight:500;border:1px solid var(--border-color);border-radius:var(--radius-md);background-color:#fff;color:var(--text-primary);outline:none;transition:border-color .2s ease;-webkit-user-modify:read-write-plaintext-only;-webkit-text-decorations-in-effect:none;text-decoration:none!important}.recognition-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #007aff26}.handwriting-question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;min-height:28px}.hint-btn{background:none;border:none;color:#ff9500;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.sentence-highlight{color:var(--primary-color);font-size:24px;font-weight:700;margin:12px 0;line-height:1.4}.blank-underline{display:inline-block;min-width:80px;border-bottom:2px solid var(--primary-color);text-align:center}.feedback-message{margin-top:16px;padding:14px;border-radius:var(--radius-md);font-size:15px;font-weight:600;text-align:center}.feedback-message.error{background-color:var(--error-bg);color:var(--error-color);border:1px solid var(--error-border)}.feedback-message.success{background-color:var(--success-bg);color:var(--success-color);border:1px solid var(--success-border)}.quiz-top-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:12px;position:relative}.quiz-close-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:50%}.quiz-close-btn:hover{background-color:#e5e5ea}.quiz-progress-text{font-size:16px;font-weight:600;color:var(--text-secondary)}.quiz-progress-bar-bg{width:100%;height:4px;background-color:#e5e5ea;border-radius:2px;margin-bottom:20px;overflow:hidden}.quiz-progress-bar-fill{height:100%;background-color:var(--primary-color);transition:width .3s ease}.quiz-step-badge-container{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;min-height:28px}.result-container{max-width:680px;margin:0 auto;padding:16px 16px 24px;text-align:center;display:flex;flex-direction:column;height:calc(100vh - 40px);max-height:900px}.result-header-group{flex-shrink:0}.result-trophy{font-size:56px;margin-bottom:4px;display:inline-block}.result-title{font-size:28px;font-weight:800;color:var(--text-primary);margin-bottom:4px}.result-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:20px}.result-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;flex-shrink:0}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;justify-content:center}.stat-label{font-size:13px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.stat-value-green{font-size:32px;font-weight:800;color:#34c759}.stat-value-blue{font-size:32px;font-weight:800;color:#007aff}.result-list-section{text-align:left;margin-bottom:20px;flex:1;display:flex;flex-direction:column;min-height:300px;overflow:hidden}.result-list-title{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:12px;flex-shrink:0}.result-word-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;min-height:300px;padding-right:4px}.result-word-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff;border-radius:var(--radius-md);box-shadow:0 1px 3px #00000008}.result-word-left{display:flex;align-items:center;gap:14px}.result-icon-check{width:22px;height:22px;border-radius:50%;background-color:#34c759;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.result-icon-cross{width:22px;height:22px;border-radius:50%;background-color:#ff3b30;color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.result-word-en{font-size:17px;font-weight:700;color:var(--text-primary)}.result-word-ja{font-size:13px;color:var(--text-secondary)}.result-step-tag{background-color:#e5e5ea;color:var(--text-secondary);font-size:12px;font-weight:600;padding:4px 12px;border-radius:var(--radius-full)}.result-footer-btn{flex-shrink:0;margin-top:auto}:root{--primary-color: #007aff;--primary-hover: #0066cc;--primary-light: #e5f1ff;--accent-orange: #ff8800;--accent-orange-hover: #e07700;--bg-main: #f2f4f8;--card-bg: #ffffff;--text-primary: #1c1c1e;--text-secondary: #6c6c70;--text-muted: #8e8e93;--border-color: #e5e5ea;--success-color: #34c759;--success-bg: #e6f4ea;--success-border: #34c759;--error-color: #ff3b30;--error-bg: #fce8e6;--error-border: #ff3b30;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);--font-family: "Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body{width:100%;height:100%;overflow-x:hidden;touch-action:manipulation;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);background-color:var(--bg-main);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;user-select:none;-webkit-user-select:none}#root{min-height:100vh;display:flex;flex-direction:column}.container{max-width:720px;margin:0 auto;padding:20px 16px 40px;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;font-size:16px;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s ease;width:100%}.btn:active{transform:scale(.98)}.btn-primary{background-color:var(--primary-color);color:#fff;box-shadow:0 4px 12px #007aff40}.btn-primary:hover{background-color:var(--primary-hover)}.btn-orange{background-color:var(--accent-orange);color:#fff;box-shadow:0 4px 12px #ff880040}.btn-orange:hover{background-color:var(--accent-orange-hover)}.btn-secondary{background-color:#fff;color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:#f8f8fb}.badge{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-full);font-size:13px;font-weight:600}.badge-blue{background-color:#e6f0ff;color:#06f}.badge-orange{background-color:#fff4e6;color:#f80}.card{background:var(--card-bg);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.03);margin-bottom:20px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}.modal-content{background:var(--card-bg);border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .25s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
