:root{--primary:#4f46e5;--primary-rgb:79,70,229;--primary-light:rgba(79,70,229,.12);--primary-dark:#3730a3;--success:#10b981;--success-light:rgba(16,185,129,.12);--info:#3b82f6;--info-light:rgba(59,130,246,.12);--warning:#f59e0b;--warning-light:rgba(245,158,11,.12);--danger:#ef4444;--danger-light:rgba(239,68,68,.12);--background:#f9fafb;--foreground:#fff;--text-primary:#111827;--text-secondary:#4b5563;--text-tertiary:#9ca3af;--border:#e5e7eb;--border-light:#f3f4f6;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);--font-xs:0.75rem;--font-sm:0.875rem;--font-md:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:1.875rem;--font-4xl:2.25rem;--sidebar-width:280px;--sidebar-collapsed-width:80px;--header-height:64px}.dark-theme{--background:#0a0a0a;--foreground:#1f1f1f;--text-primary:#f3f4f6;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border:#374151;--border-light:#1f2937}body.login-page{background-color:#050505;color:var(--text-primary)}*{margin:0;padding:0}body,html{background-color:var(--background);color:var(--text-primary);line-height:1.5}button{cursor:pointer;font-family:inherit;background:none;border:none;outline:none}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}ol,ul{list-style:none}.card{background-color:var(--foreground);box-shadow:var(--shadow-sm);padding:var(--spacing-lg)}.btn,.card{border-radius:var(--radius-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-weight:500;font-size:var(--font-sm);transition:all .2s ease;gap:var(--spacing-sm)}.btn-icon{margin-right:var(--spacing-xs)}.btn-primary{background-color:var(--primary)}.btn-primary:hover{background-color:var(--primary-dark)}.btn-outline{border:1px solid var(--border);background-color:var(--foreground)}.btn-outline:hover{background-color:var(--border-light)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:var(--spacing-md)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-1{flex:1 1}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}@media (max-width:768px){:root{--sidebar-width:100%}}:root{--primary-color:#0070f3;--secondary-color:#f5f5f5;--accent-color:#10b981;--danger-color:#ef4444;--text-color:#333;--light-text-color:#666;--border-color:#eaeaea}body,html{padding:0;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;color:var(--text-color)}a{color:inherit;text-decoration:none}*{box-sizing:border-box}.container{max-width:800px;margin:0 auto;padding:1rem}.main{min-height:100vh;padding:.3rem 0}.app-header{margin-bottom:1rem}.logo{display:flex;align-items:center;gap:.6rem}.logo h1{margin:0;font-size:1.3rem}.dubbing-container{gap:1rem}.dubbing-container,.form-section{display:flex;flex-direction:column}.form-section{gap:.8rem;background-color:#fff;border-radius:8px;padding:1.2rem;box-shadow:0 1px 6px rgba(0,0,0,.05)}.form-group{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.2rem}.form-group label{font-weight:600;font-size:.85rem}.form-control{padding:.5rem .7rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem}.language-selection{display:flex;align-items:center;gap:.7rem;margin-bottom:.4rem}.language-arrow{margin-top:1.1rem;font-size:1.3rem;color:var(--light-text-color)}.input-source-tabs{display:flex;gap:.3rem;margin-top:.3rem}.source-tab{padding:.3rem .6rem;border:1px solid var(--border-color);border-radius:4px;background-color:#fff;cursor:pointer;font-size:.8rem;transition:all .2s}.source-tab.active{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}.upload-container{margin-top:.4rem}.upload-area{border:1px dashed var(--border-color);border-radius:6px;padding:1.2rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;cursor:pointer;transition:all .2s}.upload-area svg{width:20px;height:20px}.upload-area p{margin:0;font-size:.9rem}.upload-area:hover{border-color:var(--primary-color);background-color:rgba(0,112,243,.05)}.upload-hint{font-size:.7rem;color:var(--light-text-color)}.hidden-input{display:none}.selected-file{margin-top:.7rem;padding:.4rem;background-color:var(--secondary-color);border-radius:5px;flex-direction:column;text-align:center}.file-header,.selected-file{display:flex;align-items:center}.file-header{width:100%;justify-content:center;position:relative;margin-bottom:8px}.file-header p{margin:0;padding-right:20px;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90%}.remove-file-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);background:#e74c3c;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1;opacity:.8;transition:opacity .2s}.remove-file-btn:hover{opacity:1}.selected-file p{margin-bottom:8px;font-size:.85rem}.selected-file audio,.selected-file video{margin:8px auto;border-radius:4px;max-width:100%;box-shadow:0 2px 6px rgba(0,0,0,.1)}.selected-file video{object-fit:contain;height:auto;max-height:270px}.selected-file audio,.selected-file video{width:100%;max-width:480px;background-color:#000}.url-input-container{margin-top:.5rem;position:relative;width:100%}.url-input-container input{width:100%;padding:.8rem 1rem .8rem 2.8rem;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;transition:all .3s ease;box-shadow:0 2px 5px rgba(0,0,0,.05)}.url-input-container input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 2px 10px rgba(0,112,243,.15)}.url-input-container:before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:50%;opacity:.6}.youtube-note{margin-top:.75rem}.youtube-note .note{border-left-color:red;background-color:rgba(255,0,0,.05)}.url-input-container.youtube-input:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23FF0000'%3E%3Cpath d='M19.615 3.184c-3.604-.246-11.631-.245-15.23 0-3.897.266-4.356 2.62-4.385 8.816.029 6.185.484 8.549 4.385 8.816 3.6.245 11.626.246 15.23 0 3.897-.266 4.356-2.62 4.385-8.816-.029-6.185-.484-8.549-4.385-8.816zm-10.615 12.816v-8l8 3.993-8 4.007z'/%3E%3C/svg%3E")}.tiktok-note .note{border-left-color:#00f2ea;background-color:rgba(0,242,234,.05)}.url-input-container.tiktok-input:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300F2EA'%3E%3Cpath d='M12.53.02C13.84 0 15.14.01 16.44 0c.08 1.53.63 3.09 1.75 4.17 1.12 1.11 2.7 1.62 4.24 1.79v4.03c-1.44-.05-2.89-.35-4.2-.97-.57-.26-1.1-.59-1.62-.93-.01 2.92.01 5.84-.02 8.75-.08 1.4-.54 2.79-1.35 3.94-1.31 1.92-3.58 3.17-5.91 3.21-1.43.08-2.86-.31-4.08-1.03-2.02-1.19-3.44-3.37-3.65-5.71-.02-.5-.03-1-.01-1.49.18-1.9 1.12-3.72 2.58-4.96 1.66-1.44 3.98-2.13 6.15-1.72.02 1.48-.04 2.96-.04 4.44-.99-.32-2.15-.23-3.02.37-.63.41-1.11 1.04-1.36 1.75-.21.51-.15 1.07-.14 1.61.24 1.64 1.82 3.02 3.5 2.87 1.12-.01 2.19-.66 2.77-1.61.19-.33.4-.67.41-1.06.1-1.79.06-3.57.07-5.36.01-4.03-.01-8.05.02-12.07z'/%3E%3C/svg%3E")}.url-note .note{border-left-color:#10b981;background-color:rgba(16,185,129,.05)}.url-input-container.url-input:before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2310B981'%3E%3Cpath d='M3.9 12c0-1.71 1.39-3.1 3.1-3.1h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-1.9H7c-1.71 0-3.1-1.39-3.1-3.1zM8 13h8v-2H8v2zm9-6h-4v1.9h4c1.71 0 3.1 1.39 3.1 3.1s-1.39 3.1-3.1 3.1h-4V17h4c2.76 0 5-2.24 5-5s-2.24-5-5-5z'/%3E%3C/svg%3E")}.advanced-options{margin-top:.7rem}.advanced-options summary{cursor:pointer;font-weight:600;color:var(--light-text-color);font-size:.8rem;padding:.3rem 0}.advanced-options-content{margin-top:.6rem;padding:.7rem;background-color:var(--secondary-color);border-radius:4px}.form-footer{display:flex;justify-content:flex-end;gap:.8rem;margin-top:.8rem}.btn{padding:.5rem 1rem;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.85rem}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#0051a8}.btn-secondary{background-color:var(--secondary-color);color:var(--text-color)}.btn-secondary:hover{background-color:#e5e5e5}.btn-large{padding:.6rem 1.5rem;font-size:.9rem}.btn:disabled{opacity:.5;cursor:not-allowed}.progress{margin-top:.8rem;background-color:var(--secondary-color);border-radius:4px;height:16px;position:relative;overflow:hidden}.progress-bar{height:100%;background-color:var(--primary-color);transition:width .3s ease}.progress-text{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;color:#000;font-size:.8rem;font-weight:600}.alert{margin-top:.8rem;padding:.7rem;border-radius:4px;font-size:.85rem}.alert-danger{background-color:#fee2e2;color:#b91c1c;border:1px solid #ef4444}.alert-warning{background-color:#fff7ed;color:#9a3412;border:1px solid #f97316}.result-container{margin-top:2rem;padding:2rem;background-color:#fff;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.05)}.download-options{display:flex;gap:1rem;margin-top:1rem}.workflow-steps{display:flex;justify-content:space-between;margin-bottom:1.2rem;border-bottom:1px solid #eaeaea;padding-bottom:.6rem}.step{display:flex;flex-direction:column;align-items:center;width:18%;position:relative;opacity:.5}.step.active{opacity:1}.step.completed{opacity:.8}.step-number{width:25px;height:25px;border-radius:50%;background-color:#eaeaea;color:#333;display:flex;align-items:center;justify-content:center;margin-bottom:.3rem;font-weight:700;font-size:.85rem}.step.active .step-number{background-color:#0070f3;color:#fff}.step.completed .step-number{background-color:#10b981;color:#fff}.step-title{font-size:.8rem;text-align:center}.transcript-container{margin:.7rem 0;display:flex;flex-direction:column;gap:.8rem}.transcript-box{border:1px solid #eaeaea;border-radius:5px;padding:.8rem}.transcript-content{max-height:250px;overflow-y:auto;background-color:#f9f9f9;padding:.8rem;border-radius:4px;margin:.4rem 0}.transcript-content pre{white-space:pre-wrap;font-family:inherit;margin:0}.download-links{display:flex;gap:1rem;margin-top:.5rem}.download-link{color:#0070f3;text-decoration:none;font-size:.9rem}.download-link:hover{text-decoration:underline}.help-text{font-size:.9rem;color:var(--light-text-color);margin:.5rem 0}.process-buttons{margin:1.5rem 0;display:flex;flex-direction:column;gap:1.5rem}.segmented-audio-container{background-color:var(--secondary-color);border-radius:10px;padding:1.5rem;margin-top:1rem;display:flex;flex-direction:column;gap:1rem}.segmented-audio-container h4{margin:0;color:var(--text-color)}.segmented-audio-container audio{width:100%;margin:.5rem 0}.btn-success{background-color:var(--accent-color);color:#fff}.btn-success:hover{background-color:#0b9669}.processing-message{color:var(--primary-color);font-weight:500;font-style:italic;margin-top:.25rem}.note{font-size:.8rem;color:#e67e22;background-color:#fff3e0;padding:.4rem;border-radius:4px;border-left:2px solid #e67e22}.target-language-notice{color:#e74c3c;font-size:.8rem;margin-top:8px;padding:6px 10px;background-color:rgba(231,76,60,.1);border-left:2px solid #e74c3c;border-radius:0 4px 4px 0}