*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{height:100vh}button{font-family:inherit}button:focus-visible{outline:2px solid #2196f3;outline-offset:2px}.app{max-width:1400px;margin:0 auto;padding:.5rem;height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.sentence-bar{background-color:#2c2c2c;border-radius:12px;padding:.75rem;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 2px 4px #0003;min-height:120px}.sentence-display{flex:1;background-color:#fff;border-radius:8px;padding:.5rem;min-height:100px;display:flex;align-items:center;overflow-x:auto}.placeholder-text{color:#999;font-size:1.1rem;padding:0 1rem}.selected-images{display:flex;gap:.5rem;align-items:center;padding:.5rem}.sentence-image{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:90px;max-width:140px}.sentence-image img{width:auto;height:80px;max-width:120px;object-fit:contain}.sentence-image span{font-size:1.1rem;color:#333;text-align:center;max-width:140px;word-wrap:break-word;font-weight:500}.sentence-actions{display:flex;gap:.5rem;align-items:center}.action-button,.speak-button{width:60px;height:60px;border:none;border-radius:12px;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-button{background-color:#f44;color:#fff}.action-button:hover:not(:disabled){background-color:#f33;transform:scale(1.05)}.speak-button{background-color:#4caf50;color:#fff}.speak-button:hover:not(:disabled){background-color:#45a049;transform:scale(1.05)}.action-button:disabled,.speak-button:disabled{opacity:.3;cursor:not-allowed}.app-main{flex:1;overflow:auto}.app-controls{display:flex;gap:1rem;margin-bottom:1rem;align-items:center}.image-upload{position:relative}.add-button{background-color:#2196f3;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:.75rem}.add-button .add-icon{font-size:1.3rem}.add-button:hover{background-color:#1976d2}.settings-button{background-color:#6c757d;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:.75rem}.settings-button .settings-icon{font-size:1.3rem;filter:drop-shadow(0 0 2px rgba(255,255,255,.3))}.settings-button:hover{background-color:#5a6268}.upload-btn{background-color:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:.75rem}.upload-btn .upload-icon{font-size:1.3rem;filter:drop-shadow(0 0 2px rgba(255,255,255,.3))}.upload-btn:hover{background-color:#0056b3}.settings-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.settings-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0003;width:90%;max-width:500px;max-height:80vh;overflow:auto}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.settings-header h3{margin:0;font-size:1.5rem;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover{background-color:#f0f0f0}.settings-content{padding:1.5rem}.setting-section{margin-bottom:2rem}.setting-section h4{margin:0 0 1rem;color:#333;font-size:1.1rem}.voice-setting{display:flex;flex-direction:column;gap:1rem}.voice-setting label{font-weight:500;color:#333}.custom-dropdown{position:relative;width:100%}.dropdown-trigger{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;transition:border-color .2s,box-shadow .2s}.dropdown-trigger:hover{border-color:#2196f3}.dropdown-trigger:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.dropdown-arrow{transition:transform .2s;font-size:.8rem;color:#666}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 6px 6px;box-shadow:0 2px 8px #0000001a;max-height:250px;overflow:hidden;z-index:1000}.dropdown-search{padding:.5rem;border-bottom:1px solid #eee;background-color:#f9f9f9}.search-input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;outline:none}.search-input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.dropdown-items{max-height:180px;overflow-y:auto}.no-results{padding:1rem;text-align:center;color:#666;font-style:italic}.dropdown-item{width:100%;padding:.75rem;border:none;background:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;transition:background-color .2s;font-size:.95rem}.dropdown-item:hover{background-color:#f5f5f5}.dropdown-item.selected{background-color:#e3f2fd;color:#1976d2}.dropdown-item.saved{border-left:3px solid #4caf50}.voice-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.voice-name{font-weight:500}.voice-lang{font-size:.85rem;color:#666}.voice-default{font-size:.75rem;color:#4caf50;font-weight:600;background-color:#e8f5e8;padding:.1rem .4rem;border-radius:4px;display:inline-block;margin-top:.2rem}.checkmarks{display:flex;gap:.5rem;align-items:center}.selected-checkmark{color:#2196f3;font-weight:700;font-size:1.1rem}.saved-checkmark{color:#4caf50;font-size:1rem}.voice-actions{display:flex;gap:1rem;flex-wrap:wrap}.save-voice-btn{background-color:#ff9800;color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s;align-self:flex-start}.save-voice-btn:hover:not(:disabled){background-color:#f57c00}.save-voice-btn:disabled{background-color:#ccc;color:#888;cursor:not-allowed;opacity:.6}.test-voice-btn{background-color:#4caf50;color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s;align-self:flex-start}.test-voice-btn:hover{background-color:#45a049}.reset-voice-btn{background-color:#9e9e9e;color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s;align-self:flex-start}.reset-voice-btn:hover{background-color:#757575}.loading{color:#666;font-style:italic;padding:.75rem}.settings-actions{padding:1.5rem;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end}.settings-close-btn{background-color:#2196f3;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:background-color .2s}.settings-close-btn:hover{background-color:#1976d2}.upload-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0003;z-index:1000;width:90%;max-width:400px}.upload-modal h3{margin-top:0}.upload-modal input[type=text]{width:100%;padding:.5rem;margin-bottom:1rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.upload-modal input[type=file]{width:100%;margin-bottom:1rem}.preview-image{width:100px;height:100px;object-fit:cover;border-radius:8px;margin-bottom:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-actions button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer}.modal-actions button[type=submit]{background-color:#4caf50;color:#fff}.modal-actions button[type=button]{background-color:#f44336;color:#fff}.modal-drop-zone{border:3px dashed #ccc;border-radius:8px;padding:3rem 2rem;margin:1rem 0;background-color:#fafafa;cursor:pointer;transition:all .3s ease;text-align:center}.modal-drop-zone:hover{border-color:#2196f3;background-color:#f0f8ff}.modal-drop-zone.dragging{border-color:#4caf50;background-color:#f0fff0;transform:scale(1.02)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{font-size:3rem;margin-bottom:.5rem}.drop-zone-content p{font-size:1.1rem;color:#666;margin:0;font-weight:500}.or-divider{font-size:.9rem;color:#999;margin:.5rem 0;font-weight:700}.select-file-btn{background-color:#2196f3;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s;text-transform:uppercase;letter-spacing:.5px}.select-file-btn:hover{background-color:#1976d2}.drop-zone-content small{color:#999;font-size:.85rem;margin-top:.5rem}.image-preview-section{text-align:center;margin:1rem 0;display:flex;flex-direction:column;align-items:center}.image-preview-section .preview-image{width:150px;height:150px;object-fit:cover;border-radius:8px;margin-bottom:1rem;border:2px solid #e0e0e0}.change-image-btn{background-color:#ff9800;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.change-image-btn:hover{background-color:#f57c00}.option-selection{text-align:center}.option-selection h3{margin-top:0;margin-bottom:.5rem}.option-selection p{color:#666;margin-bottom:2rem}.upload-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.option-btn{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;background-color:#fff;cursor:pointer;transition:all .2s;text-align:left}.option-btn:hover{border-color:#2196f3;background-color:#f8f9fa;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.option-icon{font-size:2rem;flex-shrink:0}.option-text{display:flex;flex-direction:column;gap:.25rem}.option-text strong{font-size:1.1rem;color:#333}.option-text small{color:#666;font-size:.9rem}.paste-hint{color:#999;font-size:.85rem;display:block;margin-bottom:1rem}.modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.back-btn{background:none;border:none;color:#2196f3;cursor:pointer;font-size:1rem;padding:.25rem}.back-btn:hover{color:#1976d2}.modal-header h3{margin:0;flex:1}.camera-instructions{text-align:center;padding:2rem;border:2px dashed #ccc;border-radius:8px;margin:1rem 0;background-color:#fafafa}.camera-instructions .upload-icon{font-size:3rem;margin-bottom:1rem}.camera-instructions p{font-size:1.1rem;color:#666;margin-bottom:1.5rem}.camera-section{margin:1rem 0}.camera-error{margin-top:1rem;padding:1rem;background-color:#ffe6e6;border:1px solid #ffcccc;border-radius:6px;text-align:center}.camera-error p{color:#c00;margin-bottom:1rem;font-size:.9rem}.camera-preview{text-align:center}.camera-video{width:100%;max-width:400px;height:auto;border-radius:8px;background-color:#000;margin-bottom:1rem}.camera-controls{display:flex;gap:1rem;justify-content:center;align-items:center}.capture-btn{background-color:#4caf50;color:#fff;border:none;padding:1rem 2rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;text-transform:uppercase}.capture-btn:hover{background-color:#45a049}.cancel-camera-btn{background-color:#f44336;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.cancel-camera-btn:hover{background-color:#da190b}.camera-start-zone{cursor:pointer}.camera-start-zone:hover{border-color:#2196f3;background-color:#f0f8ff}.camera-preview-zone{position:relative;border:3px solid #4caf50!important;background-color:#000;padding:0;overflow:hidden;min-height:300px;display:flex;flex-direction:column}.camera-video-preview{width:100%;height:300px;object-fit:cover;display:block;flex:1;background-color:#000}.camera-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:1rem;display:flex;gap:1rem;justify-content:center;align-items:center}.capture-btn-overlay{background-color:#4caf50;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s;text-transform:uppercase}.capture-btn-overlay:hover{background-color:#45a049}.cancel-camera-btn-overlay{background-color:#f44336e6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.cancel-camera-btn-overlay:hover{background-color:#da190be6}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;padding:1rem}.image-button{background-color:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.5rem;aspect-ratio:1}.image-button:hover{border-color:#2196f3;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.image-button:active{transform:translateY(0)}.image-button img{width:auto;height:80px;max-width:100px;object-fit:contain;flex:1}.image-button span{font-size:1.1rem;font-weight:600;color:#333;text-align:center}@media (max-width: 768px){.image-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.sentence-bar{padding:.5rem;min-height:100px}.sentence-display{min-height:80px}.sentence-image img{width:40px;height:40px}.sentence-image span{font-size:.75rem}.action-button,.speak-button{width:50px;height:50px;font-size:1.25rem}}.main-content{display:flex;flex-direction:column;gap:1.5rem}.image-section,.voice-section{border:1px solid #e0e0e0;border-radius:8px;padding:1rem}.image-options{text-align:center}.image-options p{color:#666;margin-bottom:1rem}.camera-preview{display:flex;flex-direction:column;align-items:center;gap:1rem}.camera-preview video{width:100%;max-width:300px;min-height:200px;height:auto;border-radius:8px;border:2px solid #e0e0e0;background-color:#000;object-fit:cover}.camera-controls{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.capture-btn-overlay{background-color:#4caf50;color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700}.capture-btn-overlay:hover:not(:disabled){background-color:#45a049}.capture-btn-overlay:disabled{background-color:#ccc;cursor:not-allowed}.cancel-camera-btn-overlay{background-color:#f44336;color:#fff;border:none;padding:.75rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem}.cancel-camera-btn-overlay:hover{background-color:#da190b}.camera-error{color:#f44336;text-align:center;padding:1rem;background-color:#ffebee;border-radius:4px;margin:.5rem 0}.camera-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;min-height:200px;justify-content:center}.camera-loading p{margin:0;color:#666;font-size:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-section h4,.voice-section h4{margin:0 0 1rem;font-size:1.1rem;color:#333}.voice-controls{display:flex;flex-direction:column;align-items:center;gap:1rem}.voice-btn{background-color:#4caf50;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:background-color .2s;display:flex;align-items:center;gap:.5rem}.voice-btn:hover{background-color:#45a049}.voice-btn.recording{background-color:#f44336;animation:pulse 1.5s infinite}.voice-btn.recording:hover{background-color:#da190b}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.voice-preview{display:flex;gap:.5rem;align-items:center}.play-voice-btn{background-color:#2196f3;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.play-voice-btn:hover{background-color:#0b7dda}.remove-voice-btn{background-color:#ff5722;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.remove-voice-btn:hover{background-color:#d84315}.recording-interface{display:flex;flex-direction:column;gap:1rem;width:100%}.waveform-container{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:#f8f9fa;border-radius:12px;border:2px solid #e3f2fd}.waveform{display:flex;align-items:flex-end;justify-content:center;gap:3px;height:80px;padding:10px;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:12px;box-shadow:inset 0 2px 8px #0000004d;overflow:hidden}.waveform-bar{width:4px;border-radius:2px;min-height:10%;transform-origin:bottom}@keyframes waveform-pulse{0%{opacity:.7}to{opacity:1}}.recording-controls{display:flex;gap:.75rem;justify-content:center;align-items:center}.stop-btn{background-color:#f44336;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s;display:flex;align-items:center;gap:.4rem;font-weight:500}.stop-btn:hover{background-color:#d32f2f;transform:translateY(-1px);box-shadow:0 4px 8px #f443364d}.reset-btn{background-color:#ff9800;color:#fff;border:none;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s;display:flex;align-items:center;gap:.4rem;font-weight:500}.reset-btn:hover{background-color:#f57c00;transform:translateY(-1px);box-shadow:0 4px 8px #ff98004d}.recording-timer{display:flex;flex-direction:column;gap:.5rem;align-items:center}.timer-text{font-size:1.1rem;font-weight:600;color:#333;text-align:center}.timer-progress{width:100%;height:8px;background-color:#e0e0e0;border-radius:4px;overflow:hidden;position:relative}.timer-fill{height:100%;background:linear-gradient(90deg,#4caf50,#ff9800 70%,#f44336);border-radius:4px;transition:width .1s linear;position:relative}.timer-fill:after{content:"";position:absolute;top:0;right:0;width:2px;height:100%;background-color:#fffc;animation:timer-pulse 1s infinite}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.3}}.add-btn{background-color:#4caf50;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:700;transition:background-color .2s}.add-btn:hover:not(:disabled){background-color:#45a049}.add-btn:disabled{background-color:#ccc;cursor:not-allowed}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.cancel-btn{background-color:#9e9e9e;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:background-color .2s}.cancel-btn:hover{background-color:#757575}.wavesurfer-container{width:100%;height:80px;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:12px;padding:10px;box-shadow:inset 0 2px 8px #0000004d;margin-bottom:.75rem}.microphone-selector{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.microphone-selector label{font-size:.9rem;font-weight:500;color:#333}.mic-dropdown{padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;background-color:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s}.mic-dropdown:hover:not(:disabled){border-color:#4f46e5}.mic-dropdown:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e533}.mic-dropdown:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}
