:root{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.3}button{font-family:inherit}a{color:#4a90d9}a:hover{color:#3a7bc8}.app{max-width:800px;margin:0 auto;padding:1rem;min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.app-header h1{font-size:1.8rem;color:#333;margin:0 0 .5rem}.subtitle{color:#666;font-size:1rem;margin:0}.app-main{flex:1}.input-section{margin-bottom:1.5rem}.input-label{display:block;font-weight:600;margin-bottom:.5rem;color:#333}.input-textarea{width:100%;padding:.75rem;font-size:1rem;border:2px solid #ccc;border-radius:8px;resize:vertical;font-family:inherit;line-height:1.5;box-sizing:border-box}.input-textarea:focus{outline:none;border-color:#4a90d9;box-shadow:0 0 0 3px #4a90d933}.input-textarea::placeholder{color:#999}.input-hint{font-size:.85rem;color:#888;margin-top:.5rem;margin-bottom:1rem}.button-group{display:flex;gap:.75rem}.button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background-color:#4a90d9;color:#fff}.button-primary:hover:not(:disabled){background-color:#3a7bc8}.button-secondary{background-color:#e0e0e0;color:#333}.button-secondary:hover:not(:disabled){background-color:#d0d0d0}.button-small{padding:.5rem 1rem;font-size:.9rem;background-color:#f0f0f0;color:#333}.button-small:hover{background-color:#e0e0e0}.error-message{background-color:#fee;border:1px solid #fcc;color:#c00;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem}.output-section{background-color:#f8f9fa;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.output-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.output-header h2{font-size:1.2rem;color:#333;margin:0}.output-controls{display:flex;align-items:center;gap:1rem}.toggle-label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#555;cursor:pointer}.toggle-label input{width:18px;height:18px;cursor:pointer}.vocabulary-list{display:flex;flex-wrap:wrap;gap:.75rem}.vocabulary-item{display:inline-flex;align-items:center;gap:.5rem;background-color:#fff;border:2px solid #4a90d9;border-radius:8px;padding:.5rem .75rem;text-decoration:none;color:#333;transition:all .2s ease}.vocabulary-item:hover{background-color:#4a90d9;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4a90d94d}.vocabulary-index{font-size:.75rem;font-weight:600;background-color:#e8f0fa;color:#4a90d9;padding:.2rem .4rem;border-radius:4px;min-width:1.5rem;text-align:center}.vocabulary-item:hover .vocabulary-index{background-color:#ffffff4d;color:#fff}.vocabulary-word{font-size:1.1rem;font-weight:500}.vocabulary-arrow{font-size:.9rem;opacity:.6}.vocabulary-item:hover .vocabulary-arrow{opacity:1}.output-note{margin-top:1rem;font-size:.85rem;color:#888;text-align:center}.header-badges{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}.learning-badge{display:inline-block;background-color:#e8f5e9;color:#2e7d32;padding:.25rem .75rem;border-radius:20px;font-size:.8rem}.ai-badge{display:inline-block;background-color:#e3f2fd;color:#1565c0;padding:.25rem .75rem;border-radius:20px;font-size:.8rem}.translator-selector{display:flex;gap:1rem;margin:1rem 0;padding:.75rem;background-color:#f5f5f5;border-radius:8px}.translator-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem .75rem;border-radius:6px;transition:background-color .2s}.translator-option:hover{background-color:#e0e0e0}.translator-option input[type=radio]{width:18px;height:18px;cursor:pointer}.translator-label{display:flex;flex-direction:column}.translator-name{font-weight:600;font-size:.95rem;color:#333}.translator-desc{font-size:.75rem;color:#888}.loading-indicator{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#666}.loading-spinner{width:24px;height:24px;border:3px solid #e0e0e0;border-top-color:#4a90d9;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.output-title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.translator-badge{font-size:.75rem;padding:.2rem .6rem;border-radius:12px;font-weight:500}.translator-badge.gemini{background-color:#e3f2fd;color:#1565c0}.translator-badge.rule-based{background-color:#f5f5f5;color:#666}.success-message{background-color:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32;padding:.75rem 1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center}.edit-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem;background-color:#fff3e0;border-radius:8px;margin-bottom:1rem}.edit-hint{font-size:.85rem;color:#888;margin-left:auto}.button-active{background-color:#4a90d9!important;color:#fff!important}.button-add{background-color:#e3f2fd;color:#1976d2}.button-add:hover{background-color:#bbdefb}.button-save{background-color:#4caf50;color:#fff}.button-save:hover{background-color:#43a047}.vocabulary-list-editing{background-color:#fff8e1;padding:1rem;border-radius:8px;border:2px dashed #ffb74d}.vocabulary-item-editable{cursor:grab;-webkit-user-select:none;user-select:none;background-color:#fff;border:2px solid #ff9800}.vocabulary-item-editable:hover{background-color:#fff3e0;transform:translateY(-2px);box-shadow:0 4px 12px #ff98004d;color:#333}.vocabulary-item-editable.dragging{opacity:.5;transform:scale(1.05)}.vocabulary-drag-handle{cursor:grab;color:#999;font-size:1rem;padding-right:.25rem}.vocabulary-delete-btn{background:none;border:none;color:#f44336;font-size:1.2rem;font-weight:700;cursor:pointer;padding:0 .25rem;line-height:1;opacity:.7;transition:opacity .2s}.vocabulary-delete-btn:hover{opacity:1}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;padding:1.5rem;border-radius:12px;width:90%;max-width:400px;box-shadow:0 20px 40px #0003}.modal-title{font-size:1.2rem;margin:0 0 1rem;color:#333}.modal-input{width:100%;padding:.75rem;font-size:1rem;border:2px solid #ccc;border-radius:8px;margin-bottom:1rem;box-sizing:border-box}.modal-input:focus{outline:none;border-color:#4a90d9}.modal-buttons{display:flex;gap:.75rem;justify-content:flex-end}.app-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #e0e0e0;text-align:center}.app-footer p{font-size:.85rem;color:#888;margin:.5rem 0}.app-footer a{color:#4a90d9;text-decoration:none}.app-footer a:hover{text-decoration:underline}@media(max-width:600px){.app{padding:.75rem}.app-header h1{font-size:1.5rem}.button-group{flex-direction:column}.button{width:100%}.output-header{flex-direction:column;align-items:flex-start}.output-controls{width:100%;justify-content:space-between}.vocabulary-item{padding:.4rem .6rem}.vocabulary-word{font-size:1rem}.edit-toolbar{flex-direction:column;align-items:stretch}.edit-hint{margin-left:0;text-align:center}.modal-content{margin:1rem;width:calc(100% - 2rem)}.translator-selector{flex-direction:column;gap:.5rem}.output-title-row{flex-direction:column;align-items:flex-start;gap:.5rem}}
