*{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 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}.compression-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;text-align:center}.compression-loading p{color:#666;font-size:1rem;margin:0}.compression-stats{margin-bottom:1rem;padding:.75rem;background-color:#e8f5e8;border-radius:6px;border-left:4px solid #4caf50}.compression-info{font-size:.9rem;color:#2e7d32;margin:0;text-align:center}.compression-savings{font-weight:600;color:#1b5e20}.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}.options-grid{display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:center;width:100%}.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-selector{margin-bottom:1rem;text-align:left}.camera-selector label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.camera-dropdown{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:6px;background-color:#fff;font-size:.9rem;cursor:pointer}.camera-dropdown:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.active-camera-selector{position:absolute;top:10px;right:10px;z-index:10}.camera-dropdown-overlay{padding:.4rem .6rem;border:1px solid rgba(255,255,255,.3);border-radius:6px;background-color:#000000b3;color:#fff;font-size:.8rem;cursor:pointer;min-width:120px}.camera-dropdown-overlay:focus{outline:none;border-color:#fffc;background-color:#000000e6}.camera-toggle-buttons{display:flex;gap:.5rem;margin-top:.5rem}.camera-toggle-btn{flex:1;padding:.75rem 1rem;border:2px solid #ddd;border-radius:8px;background-color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.camera-toggle-btn.active{border-color:#007bff;background-color:#007bff;color:#fff}.camera-toggle-btn:hover:not(.active){border-color:#007bff;background-color:#f8f9fa}.camera-toggle-btn:disabled{opacity:.6;cursor:not-allowed}.camera-switch-btn{padding:.5rem;border:1px solid rgba(255,255,255,.3);border-radius:50%;background-color:#000000b3;color:#fff;font-size:1.2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.camera-switch-btn:hover{background-color:#000000e6;border-color:#fffc}.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;position:relative}.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}.image-button.edit-mode{border-color:#ff9800;cursor:default}.image-button.edit-mode:hover{transform:none;box-shadow:0 2px 4px #0000001a}.delete-button{position:absolute;top:-8px;right:-8px;background-color:#f44336;color:#fff;border:2px solid white;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:all .2s;z-index:2}.delete-button:hover{background-color:#d32f2f;transform:scale(1.1)}.edit-mode-button{background-color:#ff9800;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1.1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.edit-mode-button:hover{background-color:#e68900;transform:scale(1.02)}.edit-mode-button.active{background-color:#4caf50}.edit-mode-button.active:hover{background-color:#45a049}.password-strength{margin-top:.5rem}.strength-bar{width:100%;height:6px;background-color:#e0e0e0;border-radius:3px;overflow:hidden;margin-bottom:.25rem}.strength-fill{height:100%;border-radius:3px;transition:all .3s ease}.strength-feedback{font-size:.85rem;font-weight:500;transition:color .3s ease}@media (max-width: 480px){.app{padding:.25rem}.image-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;padding:.75rem}.image-button{padding:.75rem;aspect-ratio:1}.image-button img{height:60px;max-width:80px}.image-button span{font-size:.9rem;font-weight:600}.sentence-bar{padding:.5rem;min-height:90px}.sentence-display{min-height:70px;padding:.25rem}.sentence-image{min-width:70px;max-width:100px}.sentence-image img{width:auto;height:50px;max-width:80px}.sentence-image span{font-size:.8rem;font-weight:500}.action-button,.speak-button{width:45px;height:45px;font-size:1.1rem}.app-controls{flex-direction:column;gap:.75rem;margin-bottom:.75rem}.add-button,.settings-button,.edit-mode-button{width:100%;justify-content:center;padding:.75rem 1rem;font-size:1rem}.user-info{flex-direction:column;gap:.5rem;text-align:center}}@media (min-width: 481px) and (max-width: 768px){.app{padding:.5rem}.image-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;padding:.75rem}.image-button{padding:.75rem;aspect-ratio:1}.image-button img{height:70px;max-width:90px}.image-button span{font-size:1rem;font-weight:600}.sentence-bar{padding:.75rem;min-height:110px}.sentence-display{min-height:90px;padding:.5rem}.sentence-image{min-width:80px;max-width:120px}.sentence-image img{width:auto;height:60px;max-width:100px}.sentence-image span{font-size:.9rem;font-weight:500}.action-button,.speak-button{width:55px;height:55px;font-size:1.3rem}.app-controls{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.add-button,.settings-button,.edit-mode-button{flex:1;min-width:140px;justify-content:center;padding:.75rem 1rem}.user-info{gap:.75rem;padding:.75rem 1rem}}@media (min-width: 769px) and (max-width: 1024px){.image-grid{grid-template-columns:repeat(4,1fr);gap:1rem;padding:1rem}.sentence-bar{padding:.75rem;min-height:120px}.sentence-display{min-height:100px}.sentence-image img{height:70px;max-width:110px}.sentence-image span{font-size:1rem}.action-button,.speak-button{width:60px;height:60px;font-size:1.4rem}}@media (max-width: 768px){.image-button:hover{transform:none}.image-button:active{transform:scale(.95);transition:transform .1s}.sentence-display{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.sentence-display::-webkit-scrollbar{display:none}.upload-modal{width:95%;margin:1rem;max-height:90vh;padding:1.5rem}.settings-modal{width:95%;margin:1rem;max-height:90vh}.modal-actions,.auth-buttons{flex-direction:column;gap:.75rem}.form-group input{font-size:16px;padding:1rem .75rem}.voice-controls{gap:1rem}.voice-btn{padding:1rem 1.5rem;font-size:1.1rem;min-height:50px}.camera-video{max-width:100%;height:auto;min-height:250px}.dropdown-trigger{padding:1rem .75rem;font-size:16px}.dropdown-item{padding:1rem .75rem;font-size:1rem}}.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}.modal-overlay{position:fixed;inset:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:all .3s ease}.upload-modal{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000004d;width:90%;max-width:600px;max-height:85vh;overflow:auto;position:relative;animation:modalSlideIn .3s ease-out;padding:2rem}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:3000}.auth-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;width:90%;max-width:400px;padding:2rem}.auth-modal h2{margin:0 0 1.5rem;text-align:center;color:#333;font-size:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.auth-error{background-color:#ffebee;color:#c62828;padding:.75rem;border-radius:6px;font-size:.9rem;text-align:center}.auth-buttons{display:flex;gap:1rem;margin-top:1rem}.auth-button{flex:1;padding:.75rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-button.primary{background-color:#2196f3;color:#fff}.auth-button.primary:hover:not(:disabled){background-color:#1976d2}.auth-button.secondary{background-color:#f5f5f5;color:#333;border:1px solid #ddd}.auth-button.secondary:hover:not(:disabled){background-color:#eee}.password-input-container{position:relative;display:flex;align-items:center}.password-input-container input{flex:1;padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.2rem;color:#666;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:4px;transition:color .2s,background-color .2s}.password-toggle:hover:not(:disabled){background-color:#f0f0f0;color:#333}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.user-info{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background-color:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.user-info span{color:#333;font-weight:500}.logout-btn{background-color:#f44336;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.logout-btn:hover{background-color:#d32f2f}
