:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--primary-color: #667eea;--primary-dark: #764ba2;--success-color: #27ae60;--danger-color: #e74c3c;--warning-color: #f39c12;--info-color: #3498db;--text-primary: #2c3e50;--text-secondary: #7f8c8d;--text-light: #bdc3c7;--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--border-color: #e0e0e0;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--transition: all .3s ease}html,body,#root{height:100%;margin:0;display:flex;justify-content:center;align-items:flex-start;width:100%}.app{width:100%;min-height:100vh;padding:20px 0;margin-left:300px;background:var(--bg-secondary);box-sizing:border-box;display:block;transition:margin-left .3s ease}.page-container{width:100%;display:block;background:transparent}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px;box-sizing:border-box}.section{background:var(--bg-primary);border-radius:var(--border-radius);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-md)}.label-with-link,.label-with-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:600;color:var(--text-primary)}.help-link{color:var(--info-color);text-decoration:none;font-size:.9rem;font-weight:500;transition:var(--transition)}.help-link:hover{color:var(--primary-dark);text-decoration:underline}.info-tag{background:var(--bg-secondary);padding:4px 10px;border-radius:12px;font-size:.8rem;color:var(--text-secondary);font-weight:500}.input-key,.textarea-prompt{width:100%;padding:14px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:1rem;font-family:Monaco,Courier New,monospace;transition:var(--transition);box-sizing:border-box}.input-key:focus,.textarea-prompt:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.textarea-prompt{resize:vertical;min-height:100px;font-family:inherit}.hint{margin-top:8px;font-size:.85rem;color:var(--text-secondary)}.chinese-warning{background:#fff3cd;border-left:4px solid var(--warning-color);padding:12px 16px;border-radius:var(--border-radius-sm);color:#856404;margin-top:12px;font-size:.9rem}.upload-area{border:2px dashed var(--border-color);border-radius:var(--border-radius);padding:32px;text-align:center;transition:var(--transition);background:var(--bg-secondary)}.upload-area.drag-over{border-color:var(--primary-color);background:#667eea0d}.upload-hint{margin-top:12px;font-size:.9rem;color:var(--text-secondary)}.preview-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.preview-item{position:relative;display:inline-block}.preview-image{width:120px;height:120px;object-fit:cover;border-radius:var(--border-radius-sm);border:2px solid var(--primary-color);box-shadow:var(--shadow-sm)}.preview-remove{position:absolute;top:-8px;right:-8px;background:var(--danger-color);color:#fff;border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-weight:700;font-size:18px;box-shadow:var(--shadow-sm);transition:var(--transition)}.preview-remove:hover{background:#c0392b;transform:scale(1.1)}.preview-index{position:absolute;bottom:4px;left:4px;background:#0009;color:#fff;padding:2px 6px;border-radius:4px;font-size:12px}.preview-success{margin:12px 0 0;color:var(--success-color);font-size:14px;font-weight:700}.uploading-section{margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:var(--border-radius-sm);border:2px dashed #dee2e6}.uploading-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.preview-item.uploading{position:relative}.upload-progress-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);z-index:10}.progress-circle .progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:600}.uploading-filename{margin-top:4px;font-size:11px;color:var(--text-secondary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.params-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.param-item{display:flex;flex-direction:column;gap:8px}.param-label{font-weight:600;color:var(--text-primary);font-size:.95rem}.param-select{padding:10px 14px;border:2px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:1rem;background:#fff;cursor:pointer;transition:var(--transition)}.param-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.param-slider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;cursor:pointer}.param-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;-webkit-transition:var(--transition);transition:var(--transition)}.param-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #667eea33}.param-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none;-moz-transition:var(--transition);transition:var(--transition)}.param-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #667eea33}.param-hint{display:flex;justify-content:space-between;font-size:.8rem;color:var(--text-secondary);margin-top:4px}.btn{padding:14px 32px;border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--text-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background:var(--text-primary)}.btn-upload{background:var(--info-color);color:#fff;padding:12px 24px;border:none;border-radius:var(--border-radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-upload:hover{background:#2980b9;transform:translateY(-2px)}.btn-generate{width:100%;padding:16px;font-size:1.1rem;background:linear-gradient(135deg,var(--success-color) 0%,#229954 100%);color:#fff;border:none;border-radius:var(--border-radius);font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-md)}.btn-generate:hover:not(:disabled){transform:translateY(-3px);box-shadow:var(--shadow-lg)}.btn-generate:disabled{background:linear-gradient(135deg,#95a5a6,#7f8c8d);cursor:not-allowed}.generate-hint{text-align:center;margin-top:12px;font-size:.9rem;color:var(--text-secondary)}.results-panel{margin-top:24px}.progress-section{margin-bottom:24px;padding:20px;background:#e3f2fd;border-left:4px solid var(--info-color);border-radius:var(--border-radius)}.progress-title{margin:0 0 12px;color:#1976d2;font-size:1.2rem}.progress-bar-container{position:relative;width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-bar-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,var(--primary-dark) 100%);transition:width .3s ease-out}.progress-section .progress-text{margin:0 0 8px;color:#1976d2;font-size:14px;font-weight:500}.progress-hint{margin:0;color:#666;font-size:12px}.results-section{animation:fadeIn .3s ease-out}.results-header{margin-bottom:20px;padding:16px;background:#d5f4e6;border-left:4px solid var(--success-color);border-radius:var(--border-radius)}.results-title{margin:0 0 8px;color:var(--success-color);font-size:1.2rem}.results-meta{display:flex;gap:16px;flex-wrap:wrap;color:#16a085;font-size:14px}.results-meta span{display:inline-flex;align-items:center;gap:4px}.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:24px}.result-card{position:relative;border:2px solid var(--primary-color);border-radius:var(--border-radius);padding:12px;background:#fff;box-shadow:var(--shadow-md);animation:fadeIn .3s ease-out;transition:transform .3s ease,box-shadow .3s ease}.result-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.result-badge{position:absolute;top:-12px;right:-12px;background:var(--success-color);color:#fff;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:700;box-shadow:var(--shadow-sm);z-index:1}.result-image-container{position:relative;cursor:pointer;border-radius:var(--border-radius-sm);overflow:hidden}.result-image{width:100%;height:auto;display:block;border-radius:var(--border-radius-sm);transition:var(--transition)}.result-image-container:hover .result-image{transform:scale(1.05)}.result-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition);border-radius:var(--border-radius-sm)}.result-image-container:hover .result-overlay{opacity:1}.overlay-text{color:#fff;font-weight:600;font-size:1rem}.result-actions{margin-top:12px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.result-btn{padding:8px 14px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none;display:inline-block}.result-btn-primary{background:var(--info-color);color:#fff}.result-btn-primary:hover{background:#2980b9}.result-btn-secondary{background:#9b59b6;color:#fff}.result-btn-secondary:hover{background:#8e44ad}.result-btn.copied{background:var(--success-color)}.batch-actions{display:flex;gap:12px;justify-content:center;padding:20px;background:var(--bg-secondary);border-radius:var(--border-radius)}.results-error{padding:32px;text-align:center;background:#fadbd8;border-left:4px solid var(--danger-color);border-radius:var(--border-radius);color:#c0392b}.error-icon{font-size:3rem;margin-bottom:16px}.results-error h3{margin:0 0 12px;font-size:1.5rem}.results-error>p{margin:0 0 20px;font-size:1rem}.error-suggestions{text-align:left;background:#fff;padding:20px;border-radius:var(--border-radius-sm);margin-top:20px}.error-suggestions strong{color:var(--text-primary)}.error-suggestions ul{margin:12px 0 0 20px;color:var(--text-secondary)}.error-suggestions li{margin:8px 0}.hint-item{display:inline-flex;align-items:baseline;gap:6px;flex:1;justify-content:center}.hint-icon{font-size:16px;display:inline-block;transform:translateY(2px)}.hint-text{font-size:12px;color:#666;font-weight:500;white-space:nowrap;display:inline-block}@media(max-width:1024px){.app{margin-left:240px}}@media(max-width:768px){.app{margin-left:120px}.container{padding:20px 12px}.section{padding:16px}.params-grid,.results-grid{grid-template-columns:1fr}.batch-actions{flex-direction:column}}@media(max-width:480px){.app{margin-left:80px}.btn{padding:12px 24px}.result-actions{flex-direction:column}}.data-management-grid{display:flex;gap:10px}.btn-equal{flex:1;text-align:center;padding:12px 0;font-size:1rem;border-radius:8px}.verify-code-input{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.verify-code-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.verify-code-header h3{margin:0;font-size:18px;color:#333}.verify-code-status{padding:4px 12px;border-radius:16px;font-size:14px;font-weight:500}.status-empty{background-color:#f0f0f0;color:#666}.status-saved{background-color:#e8f5e9;color:#2e7d32}.verify-code-description{margin-bottom:16px;padding:12px;background-color:#f5f5f5;border-radius:8px}.verify-code-description p{margin:0;font-size:14px;color:#666;line-height:1.5}.verify-code-description p+p{margin-top:8px}.verify-code-description .hint{color:#1976d2;font-weight:500}.verify-code-input-wrapper{position:relative;margin-bottom:16px}.verify-code-input-field{box-sizing:border-box;width:100%;padding:12px 50px 12px 16px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .3s;font-family:Courier New,monospace}.verify-code-input-field:focus{outline:none;border-color:#1976d2}.verify-code-input-field::placeholder{color:#999;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.btn-toggle-visibility{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;cursor:pointer;padding:8px;transition:opacity .2s}.btn-toggle-visibility:hover{opacity:.7}.verify-code-actions{display:flex;gap:12px}.verify-code-actions button{flex:1;padding:10px 16px;font-size:14px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .3s}.btn-save{background-color:#1976d2;color:#fff}.btn-save:hover{background-color:#1565c0;transform:translateY(-1px);box-shadow:0 2px 8px #1976d24d}.btn-clear{background-color:#f5f5f5;color:#666}.btn-clear:hover{background-color:#e0e0e0}@media(max-width:768px){.verify-code-input{padding:16px}.verify-code-header h3{font-size:16px}.verify-code-actions{flex-direction:column}.verify-code-actions button{width:100%}}.verify-message{padding:10px 14px;margin-bottom:12px;border-radius:6px;font-size:14px;font-weight:500;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.verify-message-success{background-color:#e8f5e9;color:#2e7d32;border-left:4px solid #4caf50}.verify-message-warning{background-color:#fff3e0;color:#e65100;border-left:4px solid #ff9800}.verify-message-error{background-color:#ffebee;color:#c62828;border-left:4px solid #f44336}.confirm-body p{margin:0;font-size:15px;color:#666;line-height:1.6}@media(max-width:768px){.verify-code-input{padding:16px}.verify-code-header h3{font-size:16px}.verify-code-actions{flex-direction:column}.verify-code-actions button{width:100%}.confirm-dialog{min-width:280px}.confirm-actions{flex-direction:column-reverse}.confirm-actions button{width:100%}}.toast-container{position:fixed;top:20px;right:20px;z-index:99999;display:flex;flex-direction:column;gap:12px;pointer-events:none;max-width:500px}.toast{min-width:280px;max-width:100%;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:flex-start;gap:12px;font-size:14px;font-weight:500;pointer-events:auto;cursor:pointer;animation:slideIn .3s ease;word-break:break-word}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-icon{font-size:20px;font-weight:700;flex-shrink:0;line-height:1;margin-top:2px}.toast-message{flex:1;line-height:1.5;white-space:pre-line;word-wrap:break-word}.toast-success{background:#4caf50;color:#fff}.toast-error{background:#f44336;color:#fff}.toast-warning{background:#ff9800;color:#fff}.toast-info{background:#2196f3;color:#fff}@media(max-width:768px){.toast-container{left:10px;right:10px;top:10px;max-width:none}.toast{min-width:auto;width:100%;padding:14px 16px;font-size:13px}.toast-icon{font-size:18px}}.model-rate-info{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea14,#764ba214);padding:10px 12px;border-radius:6px;margin:8px 0;border-left:3px solid #667eea}.model-rate-info .detail-label{font-size:.85rem;font-weight:600;color:#555;white-space:nowrap}.model-rate-info .detail-rate{font-weight:700;color:#667eea;font-size:.95rem}@media(max-width:768px){.model-rate-info{padding:8px 10px;margin:6px 0}.model-rate-info .detail-label{font-size:.8rem}.model-rate-info .detail-rate{font-size:.9rem}}.queue-hint{margin-top:12px;padding:10px 16px;background:#e3f2fd;border-left:4px solid #2196f3;border-radius:6px;font-size:13px;color:#1565c0;line-height:1.5}.task-count{font-size:12px;opacity:.8;margin-left:4px}.task-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:16px;margin-bottom:12px;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.task-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.task-status-generating{border-left:4px solid #9b59b6}.task-status-completed{border-left:4px solid #2ecc71}.task-status-failed{border-left:4px solid #e74c3c}.task-status-cancelled{border-left:4px solid #95a5a6;opacity:.8}.task-status-pending{border-left:4px solid #ffa500}.task-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e0e0e0;gap:12px;flex-wrap:nowrap}.task-header-left{display:flex;align-items:center;gap:8px;flex-shrink:0}.task-header-center{display:flex;justify-content:center;align-items:center;flex:1;min-width:0;overflow:hidden}.task-header-actions{display:flex;align-items:center;gap:6px}.task-status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-weight:600;font-size:12px;color:#fff;white-space:nowrap}.status-icon{font-size:16px}.task-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:#666;flex-shrink:0;white-space:nowrap}.task-id{font-family:monospace;background:#f5f5f5;padding:2px 6px;border-radius:3px;font-size:11px}.task-image-count{font-size:11px;color:#2ecc71;font-weight:600}.task-time{font-size:11px}.task-duration{font-size:11px;color:#666}.task-prompt-section{margin-bottom:12px;font-size:14px;line-height:1.6}.task-prompt-label{color:#666;font-weight:500;margin-right:4px}.task-prompt-text{color:#333}.task-params-detail{display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none}.task-params-detail::-webkit-scrollbar{display:none}.task-param-item{display:flex;align-items:center;gap:3px;padding:3px 8px;background:#f5f5f5;border-radius:5px;font-size:11px;white-space:nowrap;flex-shrink:0}.task-param-label{color:#666;font-weight:500}.task-param-value{color:#333;font-weight:600}.task-progress{margin-bottom:12px}.task-progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:6px}.task-progress-fill{height:100%;background:linear-gradient(90deg,#9b59b6,#3498db);border-radius:4px;transition:width .3s ease;animation:taskShimmer 2s infinite}@keyframes taskShimmer{0%{background-position:-100% 0}to{background-position:100% 0}}.task-progress-text{font-size:12px;color:#666}.task-error{display:flex;align-items:flex-start;gap:8px;background:#fee;border:1px solid #fcc;border-radius:6px;padding:8px 12px;margin-bottom:12px}.error-icon{font-size:14px;flex-shrink:0}.error-text{font-size:12px;color:#c33;line-height:1.4}.task-thumbnails{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:12px}.task-thumbnail{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s ease}.task-thumbnail:hover{border-color:#3498db;transform:scale(1.05)}.task-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;font-size:24px}.task-thumbnail:hover .thumbnail-overlay{opacity:1}.thumbnail-more{background:#f5f5f5;display:flex;align-items:center;justify-content:center;font-size:20px;color:#666;font-weight:600;border:2px dashed #ccc}.thumbnail-more:hover{background:#e8e8e8;border-color:#999}.task-stats{display:flex;gap:16px;font-size:13px;color:#666;margin-bottom:12px;padding:8px;background:#f8f9fa;border-radius:6px;flex-wrap:wrap}.url-expiry-notice{color:#ff9800;font-weight:600;cursor:help;padding:2px 6px;background:#ff98001a;border-radius:4px;font-size:11px;transition:all .2s;white-space:nowrap}.url-expiry-notice:hover{background:#ff980033}.task-actions{display:flex;gap:8px;flex-wrap:wrap}.task-btn{padding:5px 10px;border:none;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#f5f5f5;color:#333;white-space:nowrap}.task-btn:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.task-btn-cancel{background:#ff6b6b;color:#fff}.task-btn-cancel:hover{background:#ff5252}.task-btn-retry{background:#3498db;color:#fff}.task-btn-retry:hover{background:#2980b9}.task-btn-download{background:#2ecc71;color:#fff}.task-btn-download:hover{background:#27ae60}.task-btn-expand{background:#9b59b6;color:#fff}.task-btn-expand:hover{background:#8e44ad}.task-btn-delete{background:#95a5a6;color:#fff}.task-btn-delete:hover{background:#7f8c8d}.image-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.image-viewer-content{position:relative;max-width:90vw;max-height:90vh;background:#fff;border-radius:12px;overflow:hidden;animation:slideUp .3s ease}.viewer-close{position:absolute;top:16px;right:16px;background:#000000b3;color:#fff;border:none;width:36px;height:36px;border-radius:50%;font-size:20px;cursor:pointer;transition:all .2s ease;z-index:10}.viewer-close:hover{background:#000000e6;transform:scale(1.1)}.viewer-header{padding:16px 20px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.viewer-header h3{margin:0;font-size:16px;color:#333}.viewer-image-container{max-height:calc(90vh - 140px);overflow:auto;display:flex;align-items:center;justify-content:center;padding:20px;background:#f5f5f5}.viewer-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}.viewer-actions{padding:5px 20px;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:center}.btn{padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary{background:#3498db;color:#fff}.btn-secondary:hover{background:#2980b9;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.task-client-id{font-size:11px;color:#999;text-align:right;margin-top:8px;font-family:Courier New,Courier,monospace;-webkit-user-select:all;-moz-user-select:all;user-select:all}@media(max-width:768px){.task-thumbnails{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.task-actions{flex-direction:column}.task-btn{width:100%}}.task-queue-panel{width:100%;max-width:1200px;margin:0 auto}.queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d}.queue-title{margin:0;font-size:20px;font-weight:700;color:#fff}.queue-count{font-size:16px;color:#fffc;font-weight:400}.queue-actions{display:flex;gap:8px}.queue-action-btn{padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fa709a,#fee140)}.queue-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.queue-action-btn:active{transform:translateY(0)}.queue-action-danger{background:linear-gradient(135deg,#f093fb,#f5576c)}.queue-filters{display:flex;gap:8px;margin-bottom:16px;padding:8px;background:#f8f9fa;border-radius:12px;overflow-x:auto}.filter-tab{padding:8px 16px;border:2px solid transparent;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#495057;white-space:nowrap}.filter-tab:hover{background:#e9ecef;transform:translateY(-1px)}.filter-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.queue-tasks{display:flex;flex-direction:column;gap:0}.queue-empty,.queue-empty-filter{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 15px #667eea4d}.queue-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding:16px;background:#f8f9fa;border-radius:12px}.pagination-btn{padding:8px 20px;border:2px solid #667eea;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#667eea}.pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.pagination-btn:active:not(:disabled){transform:translateY(0)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed;border-color:#ced4da;color:#6c757d}.pagination-info{font-size:14px;font-weight:600;color:#495057;min-width:200px;text-align:center}@media(max-width:768px){.queue-header{flex-direction:column;align-items:flex-start;gap:12px}.queue-actions{width:100%;flex-direction:column}.queue-action-btn{width:100%}.queue-filters{padding:4px}.filter-tab{font-size:12px;padding:6px 12px}.video-task-queue-empty-icon{font-size:48px}.video-task-queue-empty-text{font-size:16px}.video-task-queue-empty-hint{font-size:12px}.queue-pagination{flex-direction:column;gap:12px}.pagination-btn{width:100%}.pagination-info{font-size:12px;min-width:auto}}.video-model-selector{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.selector-header{margin-bottom:15px}.selector-header h3{margin:0;font-size:1.25rem;color:#333}.selector-control{margin-bottom:20px}.model-select{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;outline:none}.model-select:hover{border-color:#4caf50}.model-select:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.model-details{background:#f9f9f9;border-radius:8px;padding:15px;margin-bottom:15px}.model-detail-row{display:flex;align-items:flex-start;margin-bottom:10px;gap:10px}.model-detail-row:last-child{margin-bottom:0}.detail-label{font-weight:600;color:#555;min-width:80px;flex-shrink:0;font-size:.9rem}.detail-value{color:#333;font-size:.9rem;flex:1}.model-rate-info{background:linear-gradient(135deg,#667eea14,#764ba214);padding:10px;border-radius:6px;margin:10px 0;border-left:3px solid #667eea}.detail-rate{font-weight:600;color:#667eea;font-size:1rem}.model-features{display:flex;align-items:flex-start;gap:10px;margin-top:10px}.features-tags{display:flex;flex-wrap:wrap;gap:8px;flex:1}.feature-tag{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:20px;font-size:.8rem;font-weight:500;box-shadow:0 2px 4px #0000001a}.model-tip{padding:12px 16px;border-radius:8px;font-size:.9rem;line-height:1.5;margin-top:10px}.tip-success{background:#e8f5e9;border-left:4px solid #4CAF50;color:#2e7d32}.tip-info{background:#e3f2fd;border-left:4px solid #2196F3;color:#1565c0}.tip-warning{background:#fff3e0;border-left:4px solid #ff9800;color:#e65100}@media(max-width:768px){.video-model-selector{padding:15px}.selector-header h3{font-size:1.1rem}.model-detail-row{flex-direction:column;gap:5px}.detail-label{min-width:auto}.model-features{flex-direction:column;gap:5px}.model-select{font-size:.95rem;padding:10px 14px}}@media(max-width:480px){.selector-header h3{font-size:1rem}.model-select{font-size:.9rem}.detail-label,.detail-value{font-size:.85rem}.feature-tag{font-size:.75rem;padding:3px 10px}.model-tip{font-size:.85rem;padding:10px 12px}}@media(prefers-color-scheme:dark){.video-model-selector{background:#2d2d2d;color:#e0e0e0}.selector-header h3{color:#e0e0e0}.model-select{background:#3d3d3d;border-color:#555;color:#e0e0e0}.model-select:hover,.model-select:focus{border-color:#4caf50}.model-details{background:#3d3d3d}.detail-label{color:#b0b0b0}.detail-value{color:#e0e0e0}.tip-success{background:#1b5e20;color:#a5d6a7}.tip-info{background:#0d47a1;color:#90caf9}.tip-warning{background:#e65100;color:#ffcc80}}.video-image-upload{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.upload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.upload-header h3{margin:0;font-size:1.25rem;color:#333}.model-info{display:flex;align-items:center;gap:8px;font-size:.9rem}.info-label{color:#666}.info-value{font-weight:600;color:#4caf50}.info-limit{color:#999;font-size:.85rem}.btn-clear-all{padding:6px 12px;background:#f44336;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.btn-clear-all:hover{background:#d32f2f;transform:translateY(-1px)}.upload-zone{border:2px dashed #ccc;border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa;margin-bottom:20px}.upload-zone:hover{border-color:#4caf50;background:#f0f8f0}.upload-zone.drag-over{border-color:#4caf50;background:#e8f5e9;transform:scale(1.02)}.upload-icon{font-size:3rem;margin-bottom:10px}.upload-text{font-size:1.1rem;color:#333;margin:10px 0;font-weight:500}.upload-hint{font-size:.9rem;color:#666;margin:5px 0}.upload-hint-feature{font-size:.85rem;color:#4caf50;margin-top:10px;font-weight:500}.images-preview-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:20px}.image-preview-item{border:2px solid #e0e0e0;border-radius:12px;padding:15px;background:#fff;transition:all .3s ease;position:relative;overflow:hidden}.image-preview-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.image-preview-item.role-first-frame{border-color:#4caf50;background:linear-gradient(to bottom,#e8f5e9,#fff 50px)}.image-preview-item.role-last-frame{border-color:#2196f3;background:linear-gradient(to bottom,#e3f2fd,#fff 50px)}.image-preview-item.role-reference{border-color:#9e9e9e;background:linear-gradient(to bottom,#f5f5f5,#fff 50px)}.image-role-badge{position:absolute;top:10px;right:10px;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:10;box-shadow:0 2px 4px #0003}.role-first-frame .image-role-badge{background:#4caf50;color:#fff}.role-last-frame .image-role-badge{background:#2196f3;color:#fff}.role-reference .image-role-badge{background:#9e9e9e;color:#fff}.image-preview-wrapper{width:100%;height:180px;border-radius:8px;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.image-preview{max-width:100%;max-height:100%;object-fit:contain}.image-info{margin-bottom:12px}.image-filename{font-size:.9rem;color:#333;margin:0 0 4px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-order{font-size:.8rem;color:#999;margin:0}.image-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-toggle-role,.btn-remove-image{flex:1;padding:8px 12px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s ease;min-width:100px}.btn-toggle-role{background:#2196f3;color:#fff}.btn-toggle-role:hover{background:#1976d2;transform:translateY(-1px)}.btn-remove-image{background:#f44336;color:#fff}.btn-remove-image:hover{background:#d32f2f;transform:translateY(-1px)}.upload-tip{padding:12px 16px;background:#e3f2fd;border-left:4px solid #2196F3;border-radius:6px;color:#1565c0;font-size:.9rem;margin-top:15px}.upload-disabled{text-align:center;padding:60px 20px;background:#fafafa;border-radius:12px;border:2px dashed #e0e0e0}.disabled-text{font-size:1.1rem;color:#666;margin:0 0 10px}.disabled-text strong{color:#f44336}.disabled-hint{font-size:.9rem;color:#999;margin:0}@media(max-width:768px){.video-image-upload{padding:15px}.upload-header{flex-direction:column;align-items:flex-start}.images-preview-list{grid-template-columns:1fr}.upload-zone{padding:30px 15px}.upload-icon{font-size:2.5rem}.upload-text{font-size:1rem}.image-actions{flex-direction:column}.btn-toggle-role,.btn-remove-image{width:100%;min-width:auto}}@media(max-width:480px){.upload-header h3{font-size:1.1rem}.model-info{flex-direction:column;align-items:flex-start;gap:4px}.image-preview-wrapper{height:150px}.upload-zone{padding:25px 10px}.upload-icon{font-size:2rem}}.uploading-section{margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:12px;border:2px dashed #dee2e6}.uploading-header{margin-bottom:12px}.uploading-title{font-size:.95rem;font-weight:600;color:#333}.image-preview-item.uploading{position:relative}.upload-progress-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;z-index:10}.progress-circle{position:relative;width:60px;height:60px;margin-bottom:8px}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:600}.upload-status-text{color:#fff;font-size:12px;margin:0;text-align:center}.upload-success,.upload-error{display:flex;flex-direction:column;align-items:center;gap:8px}.success-icon{width:50px;height:50px;border-radius:50%;background:#4caf50;color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700}.error-icon{width:50px;height:50px;border-radius:50%;background:#f44336;color:#fff;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.image-preview-item{animation:fadeIn .3s ease}@media(prefers-color-scheme:dark){.video-image-upload{background:#2d2d2d;color:#e0e0e0}.upload-header h3{color:#e0e0e0}.upload-zone{background:#3d3d3d;border-color:#555}.upload-zone:hover{background:#4d4d4d}.image-preview-item{background:#3d3d3d;border-color:#555}.image-filename{color:#e0e0e0}.disabled-text{color:#b0b0b0}}.video-audio-upload{margin:20px 0}.audio-upload-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.audio-label{font-size:14px;font-weight:600;color:#333}.audio-hint{font-size:12px;color:#999}.audio-upload-area{border:2px dashed #d9d9d9;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa}.audio-upload-area:hover{border-color:#40a9ff;background:#f0f8ff}.audio-upload-area.drag-over{border-color:#1890ff;background:#e6f7ff}.audio-upload-area.disabled{cursor:not-allowed;opacity:.5;background:#f5f5f5}.audio-upload-icon{font-size:48px;margin-bottom:12px}.audio-upload-text{font-size:14px;color:#666;margin-bottom:8px}.audio-upload-hint{font-size:12px;color:#999}.audio-uploading{display:flex;flex-direction:column;align-items:center;gap:12px}.audio-upload-spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top-color:#1890ff;border-radius:50%;animation:audioSpin 1s linear infinite}@keyframes audioSpin{to{transform:rotate(360deg)}}.audio-upload-progress-bar{width:200px;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.audio-upload-progress-fill{height:100%;background:linear-gradient(90deg,#1890ff,#40a9ff);transition:width .3s ease;border-radius:3px}.audio-preview{border:1px solid #e8e8e8;border-radius:8px;padding:16px;background:#fff}.audio-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.audio-icon{font-size:32px;flex-shrink:0}.audio-details{flex:1;min-width:0}.audio-name{font-size:14px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.audio-meta{font-size:12px;color:#999;display:flex;align-items:center;gap:6px}.audio-divider{color:#d9d9d9}.audio-remove-btn{width:28px;height:28px;border:none;background:#ff4d4f;color:#fff;border-radius:50%;cursor:pointer;font-size:16px;flex-shrink:0;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.audio-remove-btn:hover:not(:disabled){background:#ff7875;transform:scale(1.1)}.audio-remove-btn:active:not(:disabled){transform:scale(.95)}.audio-remove-btn:disabled{cursor:not-allowed;opacity:.5}.audio-player{width:100%;height:40px;outline:none}.audio-player::-webkit-media-controls-panel{background:#f5f5f5}.audio-player::-webkit-media-controls-play-button,.audio-player::-webkit-media-controls-timeline,.audio-player::-webkit-media-controls-current-time-display,.audio-player::-webkit-media-controls-time-remaining-display,.audio-player::-webkit-media-controls-mute-button,.audio-player::-webkit-media-controls-volume-slider{filter:invert(40%) sepia(15%) saturate(1000%) hue-rotate(180deg)}@media(max-width:768px){.audio-upload-area{padding:30px 15px}.audio-upload-icon{font-size:36px}.audio-upload-header{flex-direction:column;align-items:flex-start;gap:4px}}.video-prompt-input{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.video-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:15px;color:#fff;font-size:1rem;z-index:10;background:#000000b3;padding:20px 30px;border-radius:12px}.loading-spinner{width:40px;height:40px;border:4px solid #333;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.prompt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.prompt-header h3{margin:0;font-size:1.25rem;color:#333}.char-count{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600;transition:all .3s ease}.count-empty{background:#f5f5f5;color:#999}.count-short{background:#fff3e0;color:#e65100}.count-good{background:#e8f5e9;color:#2e7d32}.count-long{background:#e3f2fd;color:#1565c0}.count-too-long{background:#ffebee;color:#c62828}.prompt-textarea{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:all .2s ease;resize:vertical;min-height:120px;line-height:1.6;font-family:system-ui,-apple-system,sans-serif;margin-bottom:15px;box-sizing:border-box}.prompt-textarea:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.prompt-textarea::placeholder{color:#999;line-height:1.6}.prompt-actions{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.prompt-actions button{padding:10px 16px;border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease}.prompt-actions button:disabled{opacity:.5;cursor:not-allowed}.btn-templates{background:#2196f3;color:#fff;flex:1}.btn-templates:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px #2196f34d}.btn-clear{background:#f44336;color:#fff;min-width:100px}.btn-clear:hover:not(:disabled){background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 8px #f443364d}.templates-panel{background:#f9f9f9;border-radius:8px;padding:15px;margin-bottom:15px;max-height:400px;overflow-y:auto;border:2px solid #e0e0e0}.templates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.templates-header h4{margin:0;font-size:1.1rem;color:#333}.btn-close-templates{background:transparent;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.btn-close-templates:hover{background:#e0e0e0;color:#333}.templates-content{display:flex;flex-direction:column;gap:20px}.template-category{margin-bottom:10px}.category-title{font-size:1rem;color:#555;margin:0 0 10px;font-weight:600}.template-items{display:flex;flex-direction:column;gap:8px}.template-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:10px 12px;text-align:left;cursor:pointer;font-size:.9rem;color:#333;transition:all .3s ease;display:flex;align-items:center;gap:8px}.template-item:hover{background:#e8f5e9;border-color:#4caf50;transform:translate(5px)}.template-icon{color:#4caf50;font-size:1rem;flex-shrink:0}.prompt-hints{background:#f9f9f9;border-radius:8px;padding:12px 16px}.hint-item{margin:8px 0;font-size:.9rem;color:#666;line-height:1.5}.templates-panel::-webkit-scrollbar{width:8px}.templates-panel::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.templates-panel::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.templates-panel::-webkit-scrollbar-thumb:hover{background:#999}@media(max-width:768px){.video-prompt-input{padding:15px}.prompt-header{flex-direction:column;align-items:flex-start}.prompt-header h3{font-size:1.1rem}.prompt-textarea{font-size:.95rem;min-height:100px}.prompt-actions{flex-direction:column}.btn-templates,.btn-clear{width:100%;min-width:auto}.templates-panel{max-height:300px}}@media(max-width:480px){.prompt-header h3{font-size:1rem}.prompt-textarea,.prompt-actions button{font-size:.9rem;padding:10px 14px}.hint-item{font-size:.85rem}.template-item{font-size:.85rem;padding:8px 10px}.category-title{font-size:.95rem}}@media(prefers-color-scheme:dark){.video-prompt-input{background:#2d2d2d;color:#e0e0e0}.prompt-header h3{color:#e0e0e0}.prompt-textarea{background:#3d3d3d;border-color:#555;color:#e0e0e0}.prompt-textarea:focus{border-color:#4caf50}.prompt-textarea::placeholder{color:#888}.templates-panel{background:#3d3d3d;border-color:#555}.templates-header{border-bottom-color:#555}.templates-header h4{color:#e0e0e0}.btn-close-templates{color:#b0b0b0}.btn-close-templates:hover{background:#4d4d4d;color:#e0e0e0}.category-title{color:#b0b0b0}.template-item{background:#2d2d2d;border-color:#555;color:#e0e0e0}.template-item:hover{background:#1b5e20;border-color:#4caf50}.prompt-hints{background:#3d3d3d}.hint-item{color:#b0b0b0}.templates-panel::-webkit-scrollbar-track{background:#3d3d3d}.templates-panel::-webkit-scrollbar-thumb{background:#555}.templates-panel::-webkit-scrollbar-thumb:hover{background:#666}}.video-params-panel{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.params-header{margin-bottom:20px}.params-header h3{margin:0;font-size:1.25rem;color:#333}.header-buttons{display:flex;gap:10px;align-items:center}.btn-reset{padding:8px 16px;background:#ff9800;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease}.btn-reset:hover{background:#f57c00;transform:translateY(-1px);box-shadow:0 2px 8px #ff98004d}.btn-clear-cache{padding:8px 16px;background:#e74c3c;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease}.btn-clear-cache:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 2px 8px #e74c3c4d}.params-content{display:flex;flex-direction:column;gap:25px}.param-item{display:flex;flex-direction:column;gap:10px}.param-label{display:flex;align-items:center;gap:8px;font-weight:600;color:#333;font-size:1rem}.label-icon{font-size:1.2rem}.label-text{flex:1}.param-control{display:flex;flex-direction:column;gap:8px}.param-hint{margin:0;font-size:.85rem;color:#666;font-style:italic}.param-select{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;outline:none}.param-select:hover{border-color:#4caf50}.param-select:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.duration-options{display:flex;gap:10px;flex-wrap:wrap}.duration-btn{flex:1;min-width:100px;padding:12px 20px;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;color:#333}.duration-btn:hover{background:#e8f5e9;border-color:#4caf50}.duration-btn.active{background:#4caf50;border-color:#4caf50;color:#fff;box-shadow:0 2px 8px #4caf504d}.ratio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}.ratio-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:16px 12px;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;min-height:80px}.ratio-btn:hover{background:#e3f2fd;border-color:#2196f3}.ratio-btn.active{background:#2196f3;border-color:#2196f3;color:#fff;box-shadow:0 2px 8px #2196f34d}.ratio-visual{font-size:1.5rem;color:#555}.ratio-btn.active .ratio-visual{color:#fff}.ratio-text{font-size:.9rem;font-weight:600}.params-summary{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;padding:15px;margin-top:10px}.summary-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;color:#fff}.summary-item:last-child{margin-bottom:0}.summary-label{font-weight:500;font-size:.9rem}.summary-value{font-weight:600;font-size:.95rem}.cache-clear-hint{width:315px;display:flex;align-items:center;gap:8px;margin-top:20px;padding:12px 16px;background:#fff5f5;border-left:4px solid #e74c3c;border-radius:4px}.hint-icon{position:relative;width:20px;height:20px;background:#e74c3c;border-radius:50%;flex-shrink:0}.hint-icon:before{content:"!";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.75rem;font-weight:700;font-family:Arial,sans-serif;line-height:1}.hint-text{font-size:.85rem;color:#c0392b;line-height:1.4}@media(max-width:768px){.video-params-panel{padding:15px}.params-header{flex-direction:column;align-items:flex-start}.params-header h3{font-size:1.1rem}.duration-options{flex-direction:column}.duration-btn{width:100%;min-width:auto}.ratio-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.ratio-btn{min-height:70px;padding:12px 8px}.summary-item{flex-direction:column;align-items:flex-start;gap:4px}}@media(max-width:480px){.params-header h3{font-size:1rem}.param-label{font-size:.95rem}.param-select{font-size:.9rem;padding:10px 14px}.duration-btn{font-size:.9rem;padding:10px 16px}.ratio-grid{grid-template-columns:repeat(3,1fr)}.ratio-btn{min-height:65px;padding:10px 6px}.ratio-visual{font-size:1.3rem}.ratio-text,.param-hint{font-size:.8rem}.summary-label,.summary-value{font-size:.85rem}}@media(prefers-color-scheme:dark){.video-params-panel{background:#2d2d2d;color:#e0e0e0}.params-header h3,.param-label{color:#e0e0e0}.param-select{background:#3d3d3d;border-color:#555;color:#e0e0e0}.param-select:hover,.param-select:focus{border-color:#4caf50}.duration-btn,.ratio-btn{background:#3d3d3d;border-color:#555;color:#e0e0e0}.duration-btn:hover,.ratio-btn:hover{background:#4d4d4d}.duration-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.ratio-btn.active{background:#2196f3;border-color:#2196f3;color:#fff}.ratio-visual{color:#b0b0b0}.ratio-btn.active .ratio-visual{color:#fff}.param-hint{color:#b0b0b0}}.auto-duration-hint{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#e3f2fd,#f3e5f5);border-left:4px solid #2196f3;border-radius:8px;color:#1976d2;font-size:.95rem;line-height:1.5}.auto-duration-hint .hint-icon{font-size:1.2rem;flex-shrink:0}.auto-duration-hint .hint-text{flex:1;font-weight:500}.audio-switch-container{margin-bottom:12px}.audio-switch{position:relative;display:inline-flex;align-items:center;width:180px;height:36px;background:#e0e0e0;border-radius:18px;cursor:pointer;transition:background-color .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.audio-switch:hover{background:#d0d0d0}.audio-switch.active{background:linear-gradient(135deg,#667eea,#764ba2)}.audio-switch:focus{outline:2px solid #667eea;outline-offset:2px}.switch-slider{position:absolute;width:88px;height:32px;background:#fff;border-radius:16px;box-shadow:0 2px 6px #00000026;transition:transform .3s ease;left:2px}.audio-switch.active .switch-slider{transform:translate(88px)}.switch-label-off,.switch-label-on{position:absolute;width:88px;height:100%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;transition:all .3s ease;pointer-events:none}.switch-label-off{left:2px;color:#666}.switch-label-on{right:2px;color:#ffffff80}.audio-switch.active .switch-label-off{color:#ffffff80}.audio-switch.active .switch-label-on{color:#fff}@media(prefers-color-scheme:dark){.audio-switch{background:#4d4d4d}.audio-switch:hover{background:#5d5d5d}.audio-switch.active{background:linear-gradient(135deg,#667eea,#764ba2)}.switch-slider{background:#2d2d2d}.switch-label-off{color:#b0b0b0}.audio-switch.active .switch-label-off{color:#fff6}}.video-generate-button,.btn-generate{width:100%;padding:18px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:1.2rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s ease;box-shadow:0 4px 12px #667eea66}.btn-generate:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.btn-generate:active{transform:translateY(0)}.btn-icon{font-size:1.5rem}.btn-text{font-size:1.1rem}.generating-status{display:flex;flex-direction:column;gap:15px}.progress-bar-container{width:100%;height:40px;background:#f5f5f5;border-radius:20px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:20px;transition:width .5s ease;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.progress-bar-fill:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{color:#fff;font-weight:600;font-size:1rem;z-index:1}.status-message{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;background:#e3f2fd;border-radius:8px;font-size:1rem;color:#1565c0}.status-icon{font-size:1.2rem}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-text{font-weight:500}.btn-cancel{width:100%;padding:12px 20px;background:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease}.btn-cancel:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 8px #f443364d}.generate-hints{margin-top:15px;padding:12px 16px;background:#fff3e0;border-radius:8px;border-left:4px solid #ff9800}.hint-item{margin:6px 0;font-size:.9rem;color:#e65100;line-height:1.5}.hint-item:first-child{margin-top:0}.hint-item:last-child{margin-bottom:0}@media(max-width:768px){.video-generate-button{padding:15px}.btn-generate{padding:16px 20px;font-size:1.1rem}.btn-icon{font-size:1.3rem}.btn-text{font-size:1rem}.progress-bar-container{height:35px}.progress-text{font-size:.9rem}.status-message,.btn-cancel{font-size:.95rem}}@media(max-width:480px){.btn-generate{padding:14px 18px;font-size:1rem}.btn-icon{font-size:1.2rem}.btn-text{font-size:.95rem}.progress-bar-container{height:32px}.progress-text{font-size:.85rem}.status-message{font-size:.9rem;padding:10px}.status-icon{font-size:1.1rem}.btn-cancel{font-size:.9rem;padding:10px 16px}.hint-item{font-size:.85rem}}@media(prefers-color-scheme:dark){.video-generate-button{background:#2d2d2d}.progress-bar-container{background:#3d3d3d}.status-message{background:#0d47a1;color:#90caf9}.generate-hints{background:#e65100;border-left-color:#ff9800}.hint-item{color:#ffcc80}}.confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.confirm-dialog{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;min-width:320px;max-width:90%;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-header{padding:20px 24px 16px;border-bottom:1px solid #e0e0e0}.confirm-header h4{margin:0;font-size:18px;color:#333;font-weight:600}.confirm-body{padding:20px 24px}.confirm-body p{margin:0 0 8px;font-size:15px;color:#666;line-height:1.6}.confirm-actions{padding:16px 24px 20px;display:flex;gap:12px;justify-content:flex-end}.confirm-actions button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;min-width:80px}.confirm-actions .btn-cancel{background-color:#1976d2!important;color:#fff!important}.confirm-actions .btn-cancel:hover{background-color:#1565c0!important;transform:translateY(-1px);box-shadow:0 2px 8px #1976d24d}.confirm-actions .btn-confirm{background-color:#e74c3c!important;color:#fff!important}.confirm-actions .btn-confirm:hover{background-color:#c0392b!important;transform:translateY(-1px);box-shadow:0 2px 8px #e74c3c4d}@media(max-width:768px){.confirm-dialog{min-width:280px}.confirm-actions{flex-direction:column-reverse}.confirm-actions button{width:100%}}@media(prefers-color-scheme:dark){.confirm-dialog{background:#2d2d2d}.confirm-header{border-bottom-color:#444}.confirm-header h4{color:#fff}.confirm-body p{color:#ccc}}.video-task-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;margin-bottom:16px;box-shadow:0 4px 15px #667eea4d;transition:transform .2s,box-shadow .2s;color:#fff}.video-task-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.video-task-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.2)}.video-task-header-left{display:flex;align-items:center;gap:12px;flex:0 0 auto}.video-task-header-center{display:flex;justify-content:center;align-items:center;flex:1}.video-task-info{display:flex;align-items:center;gap:12px;flex:0 0 auto}.video-task-status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003}.video-task-time,.video-task-duration{font-size:12px;color:#fffc}.video-task-actions{display:flex;gap:8px}.video-task-btn{padding:6px 12px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;background:#fff3;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.video-task-btn:hover{background:#ffffff4d;transform:scale(1.05)}.video-task-btn:active{transform:scale(.95)}.video-task-btn-cancel{background:linear-gradient(135deg,#ff6b6b,#ee5a6f)}.video-task-btn-retry{background:linear-gradient(135deg,#4facfe,#00f2fe)}.video-task-btn-delete{background:linear-gradient(135deg,#f093fb,#f5576c)}.video-task-btn-download{background:linear-gradient(135deg,#43e97b,#38f9d7)}.video-task-btn-lastframe{background:linear-gradient(135deg,#a855f7,#6366f1);margin-left:auto;flex-shrink:0}.video-task-params{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.video-task-param-item{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#ffffff1a;border-radius:8px;font-size:13px}.video-task-param-label{color:#ffffffb3;font-weight:500}.video-task-param-value{color:#fff;font-weight:600}.video-task-prompt{margin-bottom:12px;padding:12px;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:baseline;gap:4px;overflow:hidden}.video-task-prompt-label{font-size:12px;color:#ffffffb3;font-weight:500;flex-shrink:0}.video-task-prompt-text{font-size:14px;line-height:1.6;color:#fff;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-task-progress{margin-top:12px}.video-task-progress-bar{height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:6px}.video-task-progress-fill{height:100%;background:linear-gradient(90deg,#43e97b,#38f9d7);transition:width .3s ease;border-radius:4px}.video-task-progress-text{font-size:12px;color:#ffffffe6;text-align:center}.video-task-error{display:flex;align-items:center;gap:8px;padding:12px;background:#e74c3c33;border:1px solid rgba(231,76,60,.5);border-radius:8px;margin-top:12px}.video-task-error-icon{font-size:16px}.video-task-error-text{flex:1;font-size:13px;color:#fcc;line-height:1.4}.video-task-result{margin-top:12px}.video-task-preview{width:100%;height:auto;max-height:500px;border-radius:12px;background:#000;cursor:pointer;transition:all .3s ease;display:block;object-fit:contain}.video-task-preview:hover{transform:scale(1.02)}.video-task-preview-placeholder{width:100%;height:60px;border-radius:12px;background:linear-gradient(135deg,#667eea4d,#764ba24d);border:2px dashed rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .3s ease}.video-task-preview-placeholder:hover{background:linear-gradient(135deg,#667eea80,#764ba280);border-color:#ffffff80;transform:scale(1.01)}.video-preview-play-icon{font-size:24px;color:#ffffffe6}.video-preview-hint{font-size:14px;color:#ffffffe6;font-weight:500}.video-task-footer{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.2);display:flex;justify-content:space-between;align-items:center}.video-task-duration{font-size:12px;color:#ffffffb3}.video-url-expiry-notice{font-size:12px;color:#ffb74d;font-weight:600;cursor:help;padding:4px 8px;background:#ffb74d26;border-radius:6px;transition:all .2s}.video-url-expiry-notice:hover{background:#ffb74d40}.video-task-draft-actions{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding:12px;background:#ffc10726;border:1px solid rgba(255,193,7,.4);border-radius:10px}.draft-badge{font-size:13px;font-weight:600;color:#ffc107;padding:4px 10px;background:#ffc10733;border-radius:8px}.draft-final-controls{display:flex;align-items:center;gap:8px}.draft-resolution-select{padding:6px 10px;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff26;color:#fff;font-size:13px;font-weight:600;cursor:pointer;outline:none}.draft-resolution-select:focus{border-color:#fff9}.draft-resolution-select option{background:#333;color:#fff}.video-task-btn-generate-final{background:linear-gradient(135deg,#ff9800,#f57c00);padding:8px 16px;font-size:14px}.video-task-btn-generate-final:hover{background:linear-gradient(135deg,#ffb74d,#ff9800)}.video-task-client-id{font-size:11px;color:#fff6;text-align:right;margin-top:8px;font-family:Courier New,Courier,monospace;-webkit-user-select:all;-moz-user-select:all;user-select:all}@media(max-width:768px){.video-task-card{padding:16px}.video-task-header{flex-direction:column;align-items:flex-start;gap:12px}.video-task-params{grid-template-columns:repeat(2,1fr)}.video-task-btn{font-size:12px;padding:5px 10px}}.video-task-queue-panel{width:100%;max-width:1200px;margin:0 auto}.video-task-queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d}.video-task-queue-title{margin:0;font-size:20px;font-weight:700;color:#fff}.video-task-queue-actions{display:flex;gap:8px}.video-task-queue-btn{padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.video-task-queue-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.video-task-queue-btn:active{transform:translateY(0)}.video-task-queue-btn-clear-completed{background:linear-gradient(135deg,#fa709a,#fee140)}.video-task-queue-btn-clear-all{background:linear-gradient(135deg,#f093fb,#f5576c)}.video-task-queue-filters{display:flex;gap:8px;margin-bottom:16px;padding:8px;background:#f8f9fa;border-radius:12px;overflow-x:auto}.video-task-queue-filter-btn{padding:8px 16px;border:2px solid transparent;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#495057;white-space:nowrap}.video-task-queue-filter-btn:hover{background:#e9ecef;transform:translateY(-1px)}.video-task-queue-filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.video-task-queue-list{display:flex;flex-direction:column;gap:0}.video-task-queue-empty,.video-task-queue-empty-filter{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 15px #667eea4d}.video-task-queue-empty-icon{font-size:64px;margin-bottom:16px;animation:float 3s ease-in-out infinite}.video-task-queue-empty-text{font-size:20px;font-weight:600;color:#fff;margin-bottom:8px}.video-task-queue-empty-hint{font-size:14px;color:#fffc;max-width:400px}.video-task-queue-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding:16px;background:#f8f9fa;border-radius:12px}.video-pagination-btn{padding:8px 20px;border:2px solid #667eea;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#667eea}.video-pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.video-pagination-btn:active:not(:disabled){transform:translateY(0)}.video-pagination-btn:disabled{opacity:.4;cursor:not-allowed;border-color:#ced4da;color:#6c757d}.video-pagination-info{font-size:14px;font-weight:600;color:#495057;min-width:200px;text-align:center}@media(max-width:768px){.video-task-queue-header{flex-direction:column;align-items:flex-start;gap:12px}.video-task-queue-actions{width:100%;flex-direction:column}.video-task-queue-btn{width:100%}.video-task-queue-filters{padding:4px}.video-task-queue-filter-btn{font-size:12px;padding:6px 12px}.video-task-queue-empty-icon{font-size:48px}.video-task-queue-empty-text{font-size:16px}.video-task-queue-empty-hint{font-size:12px}.video-task-queue-pagination{flex-direction:column;gap:12px}.video-pagination-btn{width:100%}.video-pagination-info{font-size:12px;min-width:auto}}.video-page-container{width:100%;max-width:900px;margin:0 auto;padding:0 20px;box-sizing:border-box}.page-header{text-align:center;margin-bottom:30px;padding:30px 20px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 16px #0000001a;transition:padding .3s ease}.page-header h1{margin:0 0 10px;font-size:2.5rem;color:#333;font-weight:700}.page-subtitle{margin:0;font-size:1.1rem;color:#666;font-weight:400}.page-section{margin-bottom:20px;animation:fadeInUp .5s ease;width:100%;box-sizing:border-box}.page-footer{margin-top:40px;padding:20px;background:#ffffffe6;border-radius:12px;text-align:center;transition:padding .3s ease}.footer-tip{margin:8px 0;font-size:.95rem;color:#666;line-height:1.6}.footer-tip:first-child{margin-top:0}.footer-tip:last-child{margin-bottom:0}@media(max-width:1024px)and (min-width:769px){.video-page-container{max-width:800px;padding:0 18px}.page-header{padding:25px 18px}.page-header h1{font-size:2.2rem}.page-subtitle{font-size:1.05rem}}@media(max-width:768px){.video-page{padding:15px 0}.video-page-container{padding:0 15px}.page-header{padding:20px 15px;margin-bottom:20px}.page-header h1{font-size:2rem}.page-subtitle{font-size:1rem}.page-section{margin-bottom:15px}.page-footer{margin-top:30px;padding:15px}.footer-tip{font-size:.9rem}}@media(max-width:480px){.video-page{padding:10px 0}.video-page-container{padding:0 10px}.page-header{padding:15px 10px;margin-bottom:15px}.page-header h1{font-size:1.75rem}.page-subtitle{font-size:.95rem}.page-section{margin-bottom:12px}.page-footer{margin-top:25px;padding:12px}.footer-tip{font-size:.85rem}}@media(prefers-color-scheme:dark){.video-page{background:linear-gradient(135deg,#1a1a2e,#16213e)}.page-header{background:#2d2d2df2}.page-header h1{color:#e0e0e0}.page-subtitle{color:#b0b0b0}.page-footer{background:#2d2d2de6}.footer-tip{color:#b0b0b0}}.video-page{scroll-behavior:smooth}.page-section.loading{opacity:.6;pointer-events:none}.page-section:focus-within{outline:none}.gallery-header{text-align:center;margin-bottom:32px}.gallery-header h1{margin:0 0 8px;color:var(--text-primary);font-size:2.5rem}.gallery-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px;transition:all .3s ease}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:8px 16px;border:2px solid var(--border-color);border-radius:8px;background:#fff;color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.filter-btn:hover{border-color:var(--primary-color);background:#667eea0d}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;max-width:100%;margin:0 auto;transition:gap .3s ease}.gallery-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .3s ease}.gallery-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026}.gallery-card-preview{position:relative;width:100%;aspect-ratio:4 / 3;min-height:200px;max-height:300px;overflow:hidden;background:var(--bg-secondary);display:grid;grid-template-columns:repeat(2,1fr);gap:2px}.gallery-card-preview:has(img:only-child){grid-template-columns:1fr}.gallery-preview-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-card-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2)}.placeholder-icon{font-size:3rem;margin-bottom:12px;opacity:.6;animation:float 3s ease-in-out infinite}.placeholder-text{font-size:.9rem;color:#666;font-weight:500;text-align:center;padding:0 16px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.gallery-preview-img{animation:fadeIn .3s ease-in}.gallery-card-placeholder:has(.placeholder-text:contains("正在加载")){background:linear-gradient(135deg,#667eea,#764ba2)}.gallery-card-placeholder:has(.placeholder-text:contains("正在加载")) .placeholder-text{color:#fff;font-weight:600}.gallery-card-placeholder:has(.placeholder-text:contains("正在加载")) .placeholder-icon{opacity:.9;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.placeholder-icon{font-size:2.5rem}.placeholder-text{font-size:.85rem}}@media(max-width:480px){.placeholder-icon{font-size:2rem;margin-bottom:8px}.placeholder-text{font-size:.8rem}}.gallery-card:hover .gallery-preview-img{transform:scale(1.05)}.gallery-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);padding:16px;display:flex;justify-content:flex-end}.image-count-badge{background:#ffffffe6;color:var(--text-primary);padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600}.gallery-card-info{padding:16px}.gallery-card-prompt{margin:0 0 12px;color:var(--text-primary);font-size:.95rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gallery-card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:.85rem;color:var(--text-secondary)}.meta-time,.meta-params{display:flex;align-items:center;gap:4px}.gallery-card-actions{display:flex;gap:8px;justify-content:flex-end}.card-action-btn{padding:6px 12px;border:1px solid var(--border-color);border-radius:6px;background:#fff;color:var(--text-primary);font-size:1.2rem;cursor:pointer;transition:all .3s ease}.card-action-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.card-action-btn.danger:hover{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .3s ease}.modal-content.gallery-modal{background:#fff;border-radius:16px;padding:32px;max-width:900px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:16px;background:var(--danger-color);color:#fff;border:none;border-radius:50%;width:36px;height:36px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;line-height:1}.modal-close:hover{background:#c0392b;transform:scale(1.1)}.modal-content h2{margin:0 0 24px;color:var(--text-primary);font-size:1.8rem}.modal-section{margin-bottom:32px}.modal-section h3{margin:0 0 16px;color:var(--text-primary);font-size:1.2rem}.prompt-display{background:var(--bg-secondary);padding:16px;border-radius:8px;color:var(--text-primary);line-height:1.6;margin-bottom:12px;word-wrap:break-word}.params-display{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;background:var(--bg-secondary);padding:16px;border-radius:8px}.param-item-display{display:flex;gap:8px}.param-item-display .param-label{font-weight:600;color:var(--text-secondary)}.param-item-display .param-value{color:var(--text-primary)}.modal-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;transition:gap .3s ease}.modal-image-item{background:var(--bg-secondary);border-radius:8px;overflow:hidden;border:2px solid var(--border-color)}.modal-image-item img{width:100%;height:auto;display:block;object-fit:contain;background:#fff}.modal-image-actions{display:flex;gap:8px;padding:12px;background:#fff}.modal-actions{display:flex;gap:12px;justify-content:center;padding-top:24px;border-top:1px solid var(--border-color)}@media(max-width:1200px)and (min-width:901px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}}@media(max-width:900px)and (min-width:769px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px;padding:0 14px}.gallery-card-preview{min-height:180px;max-height:250px}}@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;padding:0 12px}.gallery-header h1{font-size:2rem}.gallery-toolbar{flex-direction:column;align-items:stretch}.filter-buttons{justify-content:center}.modal-content.gallery-modal{padding:24px 16px;max-width:95%}.modal-images-grid,.params-display{grid-template-columns:1fr}}@media(max-width:480px){.gallery-grid{grid-template-columns:1fr;gap:12px;padding:0 10px}.gallery-card-preview{padding-top:56.25%;aspect-ratio:16 / 9;min-height:180px;max-height:220px}.modal-content h2{font-size:1.4rem}.modal-images-grid{grid-template-columns:1fr;gap:12px}}.image-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.viewer-close{position:fixed;top:20px;right:20px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5);border-radius:50%;width:48px;height:48px;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10002}.viewer-close:hover{background:#ffffff4d;transform:scale(1.1)}.viewer-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.viewer-image{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #00000080}.viewer-info{margin-top:16px;color:#fff;font-size:1rem;text-align:center;background:#00000080;padding:8px 16px;border-radius:20px}.viewer-nav{position:fixed;top:50%;transform:translateY(-50%);background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.5);border-radius:50%;width:56px;height:56px;font-size:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10001}.viewer-nav:hover{background:#ffffff4d;transform:translateY(-50%) scale(1.1)}.viewer-nav-prev{left:40px}.viewer-nav-next{right:40px}@media(max-width:768px){.viewer-close{width:40px;height:40px;font-size:20px;top:12px;right:12px}.viewer-nav{width:44px;height:44px;font-size:28px}.viewer-nav-prev{left:12px}.viewer-nav-next{right:12px}.viewer-info{font-size:.9rem;padding:6px 12px}}.speech-text-input{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;box-sizing:border-box}.speech-text-input .input-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.speech-text-input .input-header h3{margin:0;font-size:1.25rem;color:#333;display:flex;align-items:center;gap:8px}.speech-text-input .header-icon{font-size:1.2rem}.speech-text-input .char-count{padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600;background:#e8f5e9;color:#2e7d32;transition:all .3s ease}.speech-text-input .char-count.over-limit{background:#ffebee;color:#c62828}.speech-text-input .textarea-wrapper{position:relative;margin-bottom:15px}.speech-text-input .text-input{width:100%;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:all .2s ease;resize:vertical;min-height:120px;line-height:1.6;font-family:system-ui,-apple-system,sans-serif;box-sizing:border-box}.speech-text-input .text-input:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.speech-text-input .text-input.error{border-color:#f44336}.speech-text-input .text-input.error:focus{box-shadow:0 0 0 3px #f443361a}.speech-text-input .text-input::placeholder{color:#999;line-height:1.6}.speech-text-input .error-hint{margin-top:8px;font-size:.85rem;color:#c62828}.speech-text-input .mood-tags-section{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.speech-text-input .mood-tags-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:1rem;color:#333;font-weight:600}.speech-text-input .mood-tags-header .hint{color:#999;font-size:.85rem;font-weight:400}.speech-text-input .mood-tags-grid{display:flex;flex-wrap:wrap;gap:8px}.speech-text-input .mood-tag-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:.9rem;color:#555;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;transition:all .2s ease}.speech-text-input .mood-tag-btn:hover:not(:disabled){color:#4caf50;border-color:#4caf50;background:#e8f5e9;transform:translateY(-1px)}.speech-text-input .mood-tag-btn:active:not(:disabled){transform:translateY(0)}.speech-text-input .mood-tag-btn:disabled{opacity:.5;cursor:not-allowed}.speech-text-input .mood-icon{font-size:1rem}.speech-text-input .mood-label{font-size:.85rem}.speech-text-input .mood-tags-disabled-hint{margin-top:20px;padding:12px 16px;font-size:.9rem;color:#e65100;background:#fff3e0;border-radius:8px;border-left:4px solid #ff9800;display:flex;align-items:center;gap:10px}.speech-text-input .mood-tags-disabled-hint .hint-icon{font-size:1.1rem}@media(max-width:768px){.speech-text-input{padding:15px}.speech-text-input .input-header{flex-direction:column;align-items:flex-start}.speech-text-input .input-header h3{font-size:1.1rem}.speech-text-input .text-input{font-size:.95rem;min-height:100px}.speech-text-input .mood-tags-grid{gap:6px}.speech-text-input .mood-tag-btn{padding:6px 12px;font-size:.85rem}}@media(max-width:480px){.speech-text-input .input-header h3{font-size:1rem}.speech-text-input .text-input{font-size:.9rem;padding:10px 14px}.speech-text-input .mood-tag-btn{padding:5px 10px;font-size:.8rem}.speech-text-input .mood-icon{font-size:.9rem}.speech-text-input .mood-label{font-size:.8rem}}@media(prefers-color-scheme:dark){.speech-text-input{background:#2d2d2d;color:#e0e0e0}.speech-text-input .input-header h3{color:#e0e0e0}.speech-text-input .char-count{background:#1b5e20;color:#a5d6a7}.speech-text-input .char-count.over-limit{background:#b71c1c;color:#ef9a9a}.speech-text-input .text-input{background:#3d3d3d;border-color:#555;color:#e0e0e0}.speech-text-input .text-input:focus{border-color:#4caf50}.speech-text-input .text-input::placeholder{color:#888}.speech-text-input .mood-tags-section{border-top-color:#555}.speech-text-input .mood-tags-header{color:#e0e0e0}.speech-text-input .mood-tags-header .hint{color:#888}.speech-text-input .mood-tag-btn{background:#3d3d3d;border-color:#555;color:#b0b0b0}.speech-text-input .mood-tag-btn:hover:not(:disabled){background:#1b5e20;border-color:#4caf50;color:#a5d6a7}.speech-text-input .mood-tags-disabled-hint{background:#e65100;border-left-color:#ff9800;color:#ffcc80}}.speech-voice-selector{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;box-sizing:border-box}.speech-voice-selector .selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.speech-voice-selector .selector-header h3{margin:0;font-size:1.25rem;color:#333;display:flex;align-items:center;gap:8px}.speech-voice-selector .header-icon{font-size:1.2rem}.speech-voice-selector .selected-info{font-size:.9rem;color:#666}.speech-voice-selector .selected-info .voice-name{color:#4caf50;font-weight:600}.speech-voice-selector .filter-section{padding:15px;background:#f9f9f9;border-radius:8px;margin-bottom:15px;border:2px solid #e0e0e0}.speech-voice-selector .filter-group{display:flex;align-items:center;gap:12px;margin-bottom:12px}.speech-voice-selector .filter-group:last-of-type{margin-bottom:0}.speech-voice-selector .filter-label{font-size:.9rem;font-weight:600;color:#555;min-width:48px}.speech-voice-selector .filter-options{display:flex;flex-wrap:wrap;gap:8px}.speech-voice-selector .filter-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;font-size:.85rem;color:#555;background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;transition:all .2s ease}.speech-voice-selector .filter-btn:hover{border-color:#4caf50;color:#4caf50}.speech-voice-selector .filter-btn.active{color:#fff;background:#4caf50;border-color:#4caf50}.speech-voice-selector .filter-icon{font-size:.9rem}.speech-voice-selector .reset-filter-btn{margin-top:12px;padding:6px 14px;font-size:.85rem;color:#999;background:transparent;border:1px dashed #ccc;border-radius:6px;cursor:pointer;transition:all .2s ease}.speech-voice-selector .reset-filter-btn:hover{color:#666;border-color:#999}.speech-voice-selector .voice-list{max-height:400px;overflow-y:auto}.speech-voice-selector .voice-count{font-size:.85rem;color:#999;margin-bottom:12px}.speech-voice-selector .voice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.speech-voice-selector .voice-card{position:relative;padding:12px;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left}.speech-voice-selector .voice-card:hover{border-color:#4caf50;background:#e8f5e9;transform:translateY(-2px)}.speech-voice-selector .voice-card.selected{border-color:#4caf50;background:#e8f5e9;box-shadow:0 2px 8px #4caf504d}.speech-voice-selector .voice-card-content{display:flex;flex-direction:column;gap:4px}.speech-voice-selector .voice-card .voice-name{font-size:.95rem;font-weight:600;color:#333}.speech-voice-selector .voice-card .voice-desc{font-size:.8rem;color:#777;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.speech-voice-selector .voice-tags{display:flex;gap:6px;margin-top:6px}.speech-voice-selector .voice-tags .tag{font-size:.7rem;padding:2px 6px;border-radius:4px;background:#e0e0e0;color:#666}.speech-voice-selector .voice-tags .tag.gender{background:#e3f2fd;color:#1976d2}.speech-voice-selector .voice-tags .tag.age{background:#e8f5e9;color:#388e3c}.speech-voice-selector .selected-badge{position:absolute;top:8px;right:8px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff;background:#4caf50;border-radius:50%}.speech-voice-selector .empty-hint{text-align:center;padding:40px 20px;color:#999;font-size:.95rem}.speech-voice-selector .voice-list::-webkit-scrollbar{width:8px}.speech-voice-selector .voice-list::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.speech-voice-selector .voice-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.speech-voice-selector .voice-list::-webkit-scrollbar-thumb:hover{background:#999}@media(max-width:768px){.speech-voice-selector{padding:15px}.speech-voice-selector .selector-header{flex-direction:column;align-items:flex-start}.speech-voice-selector .selector-header h3{font-size:1.1rem}.speech-voice-selector .filter-section{padding:12px}.speech-voice-selector .filter-group{flex-direction:column;align-items:flex-start;gap:8px}.speech-voice-selector .voice-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.speech-voice-selector .voice-card{padding:10px}}@media(max-width:480px){.speech-voice-selector .selector-header h3{font-size:1rem}.speech-voice-selector .voice-grid{grid-template-columns:repeat(2,1fr)}.speech-voice-selector .voice-card .voice-name{font-size:.9rem}.speech-voice-selector .voice-card .voice-desc{font-size:.75rem}}@media(prefers-color-scheme:dark){.speech-voice-selector{background:#2d2d2d;color:#e0e0e0}.speech-voice-selector .selector-header h3{color:#e0e0e0}.speech-voice-selector .selected-info{color:#b0b0b0}.speech-voice-selector .selected-info .voice-name{color:#81c784}.speech-voice-selector .filter-section{background:#3d3d3d;border-color:#555}.speech-voice-selector .filter-label{color:#b0b0b0}.speech-voice-selector .filter-btn{background:#2d2d2d;border-color:#555;color:#b0b0b0}.speech-voice-selector .filter-btn:hover{border-color:#4caf50;color:#81c784}.speech-voice-selector .filter-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.speech-voice-selector .reset-filter-btn{color:#888;border-color:#555}.speech-voice-selector .reset-filter-btn:hover{color:#b0b0b0;border-color:#888}.speech-voice-selector .voice-count{color:#888}.speech-voice-selector .voice-card{background:#3d3d3d;border-color:#555}.speech-voice-selector .voice-card:hover,.speech-voice-selector .voice-card.selected{background:#1b5e20;border-color:#4caf50}.speech-voice-selector .voice-card .voice-name{color:#e0e0e0}.speech-voice-selector .voice-card .voice-desc{color:#999}.speech-voice-selector .voice-tags .tag{background:#4d4d4d;color:#b0b0b0}.speech-voice-selector .voice-tags .tag.gender{background:#0d47a1;color:#90caf9}.speech-voice-selector .voice-tags .tag.age{background:#1b5e20;color:#a5d6a7}.speech-voice-selector .empty-hint{color:#888}.speech-voice-selector .voice-list::-webkit-scrollbar-track{background:#3d3d3d}.speech-voice-selector .voice-list::-webkit-scrollbar-thumb{background:#555}.speech-voice-selector .voice-list::-webkit-scrollbar-thumb:hover{background:#666}}.speech-params-panel{width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;box-sizing:border-box}.speech-params-panel .params-header{margin-bottom:20px}.speech-params-panel .params-header h3{margin:0;font-size:1.25rem;color:#333;display:flex;align-items:center;gap:8px}.speech-params-panel .header-icon{font-size:1.2rem}.speech-params-panel .params-content{display:flex;flex-direction:column;gap:25px}.speech-params-panel .param-item{display:flex;flex-direction:column;gap:10px}.speech-params-panel .param-label{display:flex;align-items:center;gap:8px;font-weight:600;color:#333;font-size:1rem}.speech-params-panel .label-icon{font-size:1.2rem}.speech-params-panel .label-text{flex:1}.speech-params-panel .param-value{margin-left:auto;font-size:.9rem;color:#4caf50;font-weight:600}.speech-params-panel .param-control{display:flex;flex-direction:column;gap:8px}.speech-params-panel .param-hint{margin:0;font-size:.85rem;color:#666;font-style:italic}.speech-params-panel .model-options{display:flex;flex-wrap:wrap;gap:10px}.speech-params-panel .model-btn{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:12px 16px;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:left;min-width:140px}.speech-params-panel .model-btn:hover{border-color:#4caf50;background:#e8f5e9}.speech-params-panel .model-btn.active{border-color:#4caf50;background:#e8f5e9;box-shadow:0 2px 8px #4caf504d}.speech-params-panel .model-name{font-size:.95rem;font-weight:600;color:#333}.speech-params-panel .model-badge{font-size:.75rem;padding:2px 8px;background:#e8f5e9;color:#4caf50;border-radius:4px}.speech-params-panel .model-btn.active .model-badge{background:#4caf50;color:#fff}.speech-params-panel .speed-slider-wrapper{display:flex;align-items:center;gap:12px}.speech-params-panel .speed-label-min,.speech-params-panel .speed-label-max{font-size:.85rem;color:#666;min-width:32px}.speech-params-panel .speed-slider{flex:1;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e0e0e0;border-radius:4px;cursor:pointer}.speech-params-panel .speed-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:#4caf50;border-radius:50%;cursor:pointer;-webkit-transition:transform .2s,box-shadow .2s;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 6px #4caf504d}.speech-params-panel .speed-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 2px 10px #4caf5080}.speech-params-panel .speed-slider::-moz-range-thumb{width:20px;height:20px;background:#4caf50;border:none;border-radius:50%;cursor:pointer}.speech-params-panel .speed-marks{display:flex;justify-content:space-between;padding:4px 44px 0;font-size:.75rem;color:#999}.speech-params-panel .emotion-options{display:flex;flex-wrap:wrap;gap:10px}.speech-params-panel .emotion-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;min-width:70px}.speech-params-panel .emotion-btn:hover{border-color:#2196f3;background:#e3f2fd;transform:translateY(-2px)}.speech-params-panel .emotion-btn.active{border-color:#2196f3;background:#2196f3;color:#fff;box-shadow:0 2px 8px #2196f34d}.speech-params-panel .emotion-icon{font-size:1.5rem}.speech-params-panel .emotion-label{font-size:.85rem;color:#666;font-weight:500}.speech-params-panel .emotion-btn.active .emotion-label{color:#fff}@media(max-width:768px){.speech-params-panel{padding:15px}.speech-params-panel .params-header h3{font-size:1.1rem}.speech-params-panel .model-options{flex-direction:column}.speech-params-panel .model-btn{width:100%;min-width:unset}.speech-params-panel .emotion-options{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.speech-params-panel .emotion-btn{min-width:unset;padding:10px 8px}.speech-params-panel .emotion-icon{font-size:1.3rem}.speech-params-panel .emotion-label{font-size:.75rem}}@media(max-width:480px){.speech-params-panel .params-header h3{font-size:1rem}.speech-params-panel .param-label{font-size:.95rem}.speech-params-panel .emotion-options{grid-template-columns:repeat(3,1fr)}.speech-params-panel .emotion-btn{padding:8px 6px}.speech-params-panel .emotion-icon{font-size:1.2rem}.speech-params-panel .emotion-label{font-size:.7rem}}@media(prefers-color-scheme:dark){.speech-params-panel{background:#2d2d2d;color:#e0e0e0}.speech-params-panel .params-header h3,.speech-params-panel .param-label{color:#e0e0e0}.speech-params-panel .param-value{color:#81c784}.speech-params-panel .param-hint{color:#b0b0b0}.speech-params-panel .model-btn,.speech-params-panel .emotion-btn{background:#3d3d3d;border-color:#555;color:#e0e0e0}.speech-params-panel .model-btn:hover,.speech-params-panel .model-btn.active{background:#1b5e20;border-color:#4caf50}.speech-params-panel .model-name{color:#e0e0e0}.speech-params-panel .model-badge{background:#1b5e20;color:#a5d6a7}.speech-params-panel .model-btn.active .model-badge{background:#4caf50;color:#fff}.speech-params-panel .speed-slider{background:#555}.speech-params-panel .speed-label-min,.speech-params-panel .speed-label-max{color:#b0b0b0}.speech-params-panel .speed-marks{color:#888}.speech-params-panel .emotion-btn:hover{background:#0d47a1;border-color:#2196f3}.speech-params-panel .emotion-btn.active{background:#2196f3;border-color:#2196f3}.speech-params-panel .emotion-label{color:#b0b0b0}.speech-params-panel .emotion-btn.active .emotion-label{color:#fff}}.speech-generate-button{width:100%;display:flex;flex-direction:column;align-items:center;gap:15px}.speech-generate-button .generate-btn{width:100%;padding:18px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:1.2rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .3s ease;box-shadow:0 4px 12px #667eea66}.speech-generate-button .generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.speech-generate-button .generate-btn:active:not(:disabled){transform:translateY(0)}.speech-generate-button .generate-btn.disabled,.speech-generate-button .generate-btn:disabled{background:#e0e0e0;color:#999;cursor:not-allowed;box-shadow:none}.speech-generate-button .generate-btn.generating{background:linear-gradient(135deg,#4caf50,#8bc34a);cursor:wait}.speech-generate-button .btn-icon{font-size:1.5rem}.speech-generate-button .task-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 6px;background:#ffffff40;border-radius:12px;font-size:.85rem;font-weight:700;margin-left:4px}.speech-generate-button .loading-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.speech-generate-button .generate-hint{margin:0;font-size:.9rem;color:#666;text-align:center;line-height:1.5}.speech-generate-button .generating-status{width:100%;display:flex;flex-direction:column;gap:15px}.speech-generate-button .status-message{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;background:#e3f2fd;border-radius:8px;font-size:1rem;color:#1565c0}.speech-generate-button .status-icon{font-size:1.2rem}.speech-generate-button .status-text{font-weight:500}@media(max-width:768px){.speech-generate-button .generate-btn{padding:16px 20px;font-size:1.1rem}.speech-generate-button .btn-icon{font-size:1.3rem}.speech-generate-button .generate-hint{font-size:.85rem}.speech-generate-button .status-message{font-size:.95rem}}@media(max-width:480px){.speech-generate-button .generate-btn{padding:14px 18px;font-size:1rem}.speech-generate-button .btn-icon{font-size:1.2rem}.speech-generate-button .generate-hint{font-size:.8rem}.speech-generate-button .status-message{font-size:.9rem;padding:10px}.speech-generate-button .status-icon{font-size:1.1rem}}@media(prefers-color-scheme:dark){.speech-generate-button .generate-btn.disabled,.speech-generate-button .generate-btn:disabled{background:#3d3d3d;color:#888}.speech-generate-button .generate-hint{color:#b0b0b0}.speech-generate-button .status-message{background:#0d47a1;color:#90caf9}}.speech-task-card{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e0e0e0;transition:all .3s ease}.speech-task-card:hover{box-shadow:0 4px 12px #0000001f}.speech-task-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:12px;flex-wrap:wrap}.speech-task-header-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.speech-task-status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.85rem;font-weight:600;color:#fff;white-space:nowrap}.speech-task-actions{display:flex;gap:8px;flex-wrap:wrap}.speech-task-btn{padding:4px 10px;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.speech-task-btn:hover{transform:translateY(-1px)}.speech-task-btn-cancel{background:#ffebee;color:#e74c3c}.speech-task-btn-cancel:hover{background:#ffcdd2}.speech-task-btn-retry{background:#e3f2fd;color:#2196f3}.speech-task-btn-retry:hover{background:#bbdefb}.speech-task-btn-download{background:#e8f5e9;color:#4caf50}.speech-task-btn-download:hover{background:#c8e6c9}.speech-task-btn-delete{background:#f5f5f5;color:#757575}.speech-task-btn-delete:hover{background:#e0e0e0}.speech-task-header-center{flex:1;min-width:200px}.speech-task-params{display:flex;flex-wrap:wrap;gap:8px 16px}.speech-task-param-item{display:flex;align-items:center;gap:4px;font-size:.85rem}.speech-task-param-label{color:#999}.speech-task-param-value{color:#333;font-weight:500}.speech-task-info{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:120px}.speech-task-time{font-size:.8rem;color:#999}.speech-task-duration,.speech-task-process-time{font-size:.8rem;color:#666}.speech-task-text{padding:10px 12px;background:#f8f9fa;border-radius:8px;margin-bottom:12px;font-size:.9rem;line-height:1.5}.speech-task-text-label{color:#999;font-weight:500}.speech-task-text-content{color:#333;word-break:break-all}.speech-task-progress{margin-bottom:12px}.speech-task-progress-bar{height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:6px}.speech-task-progress-fill{height:100%;background:linear-gradient(90deg,#9b59b6,#8e44ad);border-radius:4px;transition:width .3s ease}.speech-task-progress-text{font-size:.8rem;color:#666;text-align:center}.speech-task-error{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#ffebee;border-radius:8px;margin-bottom:12px}.speech-task-error-icon{font-size:1rem}.speech-task-error-text{font-size:.85rem;color:#e74c3c}.speech-task-player{display:flex;align-items:center;gap:12px;padding:12px;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.speech-task-play-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:linear-gradient(135deg,#4caf50,#8bc34a);border:none;border-radius:50%;cursor:pointer;transition:all .2s;flex-shrink:0;box-shadow:0 2px 8px #4caf504d}.speech-task-play-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #4caf5066}.speech-task-play-btn:active{transform:scale(.95)}.speech-task-player-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.speech-task-player-progress{position:relative;height:6px;background:#e0e0e0;border-radius:3px;cursor:pointer;overflow:visible}.speech-task-player-progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:3px;transition:width .1s}.speech-task-player-progress-thumb{position:absolute;top:50%;width:12px;height:12px;background:#4caf50;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 1px 4px #0003;transition:left .1s}.speech-task-player-progress:hover .speech-task-player-progress-thumb{transform:translate(-50%,-50%) scale(1.2)}.speech-task-player-time{display:flex;gap:4px;font-size:.8rem;color:#666}.speech-task-file-size{font-size:.8rem;color:#999;white-space:nowrap}@media(max-width:768px){.speech-task-card{padding:12px}.speech-task-header{flex-direction:column;gap:10px}.speech-task-header-left{width:100%;justify-content:space-between}.speech-task-header-center{width:100%}.speech-task-info{width:100%;flex-direction:row;flex-wrap:wrap;justify-content:flex-start;gap:8px}.speech-task-player{flex-wrap:wrap}.speech-task-player-info{width:100%;order:2}.speech-task-file-size{order:3;width:100%;text-align:center;margin-top:8px}}@media(prefers-color-scheme:dark){.speech-task-card{background:#2d2d2d;border-color:#444}.speech-task-param-label,.speech-task-time{color:#999}.speech-task-param-value,.speech-task-text-content{color:#e0e0e0}.speech-task-text{background:#3d3d3d}.speech-task-progress-bar,.speech-task-player-progress{background:#555}.speech-task-player{background:#3d3d3d;border-color:#555}.speech-task-btn-delete{background:#3d3d3d;color:#b0b0b0}.speech-task-btn-delete:hover{background:#4d4d4d}}.speech-task-queue-panel{width:100%;max-width:100%;box-sizing:border-box}.speech-task-queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px;background:linear-gradient(135deg,#4caf50,#8bc34a);border-radius:12px;box-shadow:0 4px 15px #4caf504d}.speech-task-queue-title{margin:0;font-size:1.25rem;font-weight:700;color:#fff}.speech-task-queue-actions{display:flex;gap:8px}.speech-task-queue-btn{padding:8px 16px;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.speech-task-queue-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.speech-task-queue-btn:active{transform:translateY(0)}.speech-task-queue-btn-clear-completed{background:linear-gradient(135deg,#ff9800,#ffc107)}.speech-task-queue-btn-clear-all{background:linear-gradient(135deg,#f44336,#ff5722)}.speech-task-queue-filters{display:flex;gap:8px;margin-bottom:16px;padding:8px;background:#f8f9fa;border-radius:12px;overflow-x:auto}.speech-task-queue-filter-btn{padding:8px 16px;border:2px solid transparent;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#495057;white-space:nowrap}.speech-task-queue-filter-btn:hover{background:#e9ecef;transform:translateY(-1px)}.speech-task-queue-filter-btn.active{background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff;border-color:#4caf50}.speech-task-queue-list{display:flex;flex-direction:column;gap:0}.speech-task-queue-empty,.speech-task-queue-empty-filter{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;background:linear-gradient(135deg,#4caf50,#8bc34a);border-radius:16px;box-shadow:0 4px 15px #4caf504d}.speech-task-queue-empty-icon{font-size:64px;margin-bottom:16px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.speech-task-queue-empty-text{font-size:1.25rem;font-weight:600;color:#fff;margin-bottom:8px}.speech-task-queue-empty-hint{font-size:.9rem;color:#fffc;max-width:400px}.speech-task-queue-pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding:16px;background:#f8f9fa;border-radius:12px}.speech-pagination-btn{padding:8px 20px;border:2px solid #4CAF50;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;background:#fff;color:#4caf50}.speech-pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.speech-pagination-btn:active:not(:disabled){transform:translateY(0)}.speech-pagination-btn:disabled{opacity:.4;cursor:not-allowed;border-color:#ced4da;color:#6c757d}.speech-pagination-info{font-size:.875rem;font-weight:600;color:#495057;min-width:200px;text-align:center}@media(max-width:768px){.speech-task-queue-header{flex-direction:column;align-items:flex-start;gap:12px}.speech-task-queue-actions{width:100%;flex-direction:column}.speech-task-queue-btn{width:100%}.speech-task-queue-filters{padding:4px}.speech-task-queue-filter-btn{font-size:.75rem;padding:6px 12px}.speech-task-queue-empty-icon{font-size:48px}.speech-task-queue-empty-text{font-size:1rem}.speech-task-queue-empty-hint{font-size:.8rem}.speech-task-queue-pagination{flex-direction:column;gap:12px}.speech-pagination-btn{width:100%}.speech-pagination-info{font-size:.8rem;min-width:auto}}@media(prefers-color-scheme:dark){.speech-task-queue-filters,.speech-task-queue-pagination{background:#2d2d2d}.speech-task-queue-filter-btn{background:#3d3d3d;color:#e0e0e0}.speech-task-queue-filter-btn:hover{background:#4d4d4d}.speech-task-queue-filter-btn.active{background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff}.speech-pagination-btn{background:#3d3d3d;color:#4caf50}.speech-pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff}.speech-pagination-info{color:#e0e0e0}}.speech-page-container{width:100%;max-width:900px;margin:0 auto;padding:0 20px;box-sizing:border-box}.speech-page .page-header{text-align:center;margin-bottom:30px;padding:30px 20px;background:#fffffff2;border-radius:16px;box-shadow:0 4px 16px #0000001a;transition:padding .3s ease}.speech-page .page-header h1{margin:0 0 10px;font-size:2.5rem;color:#333;font-weight:700}.speech-page .page-subtitle{margin:0;font-size:1.1rem;color:#666;font-weight:400}.speech-page .page-section{margin-bottom:20px;animation:fadeInUp .5s ease;width:100%;box-sizing:border-box}.speech-page .page-footer{margin-top:40px;padding:20px;background:#ffffffe6;border-radius:12px;text-align:center;transition:padding .3s ease}.speech-page .footer-tip{margin:8px 0;font-size:.95rem;color:#666;line-height:1.6}.speech-page .footer-tip:first-child{margin-top:0}.speech-page .footer-tip:last-child{margin-bottom:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px)and (min-width:769px){.speech-page-container{max-width:800px;padding:0 18px}.speech-page .page-header{padding:25px 18px}.speech-page .page-header h1{font-size:2.2rem}.speech-page .page-subtitle{font-size:1.05rem}}@media(max-width:768px){.speech-page{padding:15px 0}.speech-page-container{padding:0 15px}.speech-page .page-header{padding:20px 15px;margin-bottom:20px}.speech-page .page-header h1{font-size:2rem}.speech-page .page-subtitle{font-size:1rem}.speech-page .page-section{margin-bottom:15px}.speech-page .page-footer{margin-top:30px;padding:15px}.speech-page .footer-tip{font-size:.9rem}}@media(max-width:480px){.speech-page{padding:10px 0}.speech-page-container{padding:0 10px}.speech-page .page-header{padding:15px 10px;margin-bottom:15px}.speech-page .page-header h1{font-size:1.75rem}.speech-page .page-subtitle{font-size:.95rem}.speech-page .page-section{margin-bottom:12px}.speech-page .page-footer{margin-top:25px;padding:12px}.speech-page .footer-tip{font-size:.85rem}}@media(prefers-color-scheme:dark){.speech-page{background:linear-gradient(135deg,#1a1a2e,#16213e)}.speech-page .page-header{background:#2d2d2df2}.speech-page .page-header h1{color:#e0e0e0}.speech-page .page-subtitle{color:#b0b0b0}.speech-page .page-footer{background:#2d2d2de6}.speech-page .footer-tip{color:#b0b0b0}}.speech-page{scroll-behavior:smooth}.speech-page .page-section.loading{opacity:.6;pointer-events:none}.speech-page .page-section:focus-within{outline:none}.credits-display{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-radius:12px;padding:16px;box-shadow:0 4px 12px #00000014;margin-bottom:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:all .3s ease;width:100%;box-sizing:border-box;overflow:hidden}.credits-display:hover{box-shadow:0 6px 16px #0000001f;transform:translateY(-2px)}.credits-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.credits-header h3{margin:0;font-size:14px;color:#667eea;font-weight:700;display:flex;align-items:center;gap:6px}.btn-refresh{background:#667eea1a;border:none;width:28px;height:28px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s ease;flex-shrink:0}.btn-refresh:hover:not(:disabled){background:#667eea33}.btn-refresh:active:not(:disabled){transform:scale(.95);transition:transform .1s ease}.btn-refresh:disabled{opacity:.5;cursor:not-allowed}.credits-empty{text-align:center;padding:20px 12px}.empty-icon{font-size:40px;margin-bottom:10px;opacity:.6}@keyframes pulse{0%,to{opacity:.6}50%{opacity:.3}}.empty-text{font-size:14px;font-weight:600;color:#666;margin-bottom:4px}.empty-hint{font-size:12px;color:#999}.credits-loading{text-align:center;padding:24px 12px}.loading-spinner{width:32px;height:32px;border:3px solid rgba(102,126,234,.2);border-top-color:#667eea;border-radius:50%;margin:0 auto 10px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:12px;color:#999}.credits-error{text-align:center;padding:18px 12px}.error-icon{font-size:36px;margin-bottom:8px;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-text{font-size:12px;color:#f44336;margin-bottom:10px;font-weight:500}.btn-retry{padding:6px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 8px #667eea4d}.btn-retry:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.credits-info{margin-bottom:12px}.credits-main{text-align:center;margin-bottom:12px;padding:12px;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000d}.credits-remaining{display:flex;align-items:baseline;justify-content:center;gap:0;line-height:1}.credits-number{font-size:36px;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-1px}.credits-label{font-size:11px;color:#999;font-weight:600;margin-left:4px}.credits-total{font-size:36px;color:#999;font-weight:600;line-height:1}.credits-progress-bar{width:100%;height:6px;background:#0000000d;border-radius:10px;overflow:hidden;margin-bottom:10px;box-shadow:inset 0 2px 4px #0000000f}.credits-progress-fill{height:100%;border-radius:10px;transition:width .6s cubic-bezier(.4,0,.2,1),background-color .3s ease;background:linear-gradient(90deg,#4caf50,#8bc34a);box-shadow:0 0 10px #4caf5066}.credits-details{display:flex;justify-content:space-around;align-items:center;background:#fff;padding:10px 12px;border-radius:8px;margin-bottom:10px;box-shadow:0 2px 4px #0000000d;gap:16px}.credits-detail-item{align-items:center;gap:4px;flex:1;justify-content:center}.detail-label{font-size:11px;color:#999;font-weight:600;white-space:nowrap}.detail-value{font-size:16px;font-weight:700;color:#667eea}@media(max-width:1024px)and (min-width:769px){.credits-display{padding:14px}.credits-number,.credits-total{font-size:32px}.credits-header h3{font-size:13px}}@media(max-width:768px){.credits-display{padding:8px;margin-bottom:15px}.credits-header{margin-bottom:8px}.credits-header h3{font-size:9px;writing-mode:vertical-rl;letter-spacing:1px}.btn-refresh{width:18px;height:18px;font-size:9px}.credits-main{padding:6px 2px;margin-bottom:6px}.credits-remaining{flex-direction:column;align-items:center;gap:2px}.credits-number{font-size:18px;writing-mode:horizontal-tb;letter-spacing:-.5px}.credits-total{font-size:10px;writing-mode:horizontal-tb}.credits-label{font-size:8px;margin-left:0;margin-top:2px}.credits-progress-bar{height:3px;margin-bottom:4px}.credits-details{display:none}.empty-icon{font-size:20px}.empty-text{font-size:9px}.empty-hint{font-size:8px}}.nav-bar .credits-display{margin-bottom:0;background:#fffffff2;border:1px solid rgba(255,255,255,.3)}.nav-bar .credits-header h3{color:#667eea}.nav-bar .credits-main{background:linear-gradient(135deg,#667eea0d,#764ba20d)}@media(max-width:768px){.nav-bar .credits-header h3{writing-mode:vertical-rl;font-size:9px;letter-spacing:1px}.nav-bar .credits-main{padding:6px 2px}.nav-bar .credits-number{font-size:18px!important}.nav-bar .credits-total{font-size:10px!important}}.credits-display{animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.credits-number,.credits-total{animation:countUp .6s ease-out}@keyframes countUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.nav-bar{background:linear-gradient(180deg,#667eea,#764ba2);box-shadow:2px 0 10px #0000001a;position:fixed;left:0;top:0;bottom:0;width:240px;display:flex;flex-direction:column;padding:30px 20px;z-index:1000;transition:width .3s ease,padding .3s ease}.nav-brand{display:flex;flex-direction:column;align-items:center;gap:10px;color:#fff;font-weight:700;margin-bottom:10px;padding-bottom:0;border-bottom:1px solid rgba(255,255,255,.2);transition:all .3s ease}.nav-credits{margin-bottom:20px;padding:0 10px}.nav-credits .credits-display{background:#fffffff2;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000026}.nav-credits .credits-header h3{font-size:16px;color:#333}.nav-credits .credits-number{font-size:28px;color:#667eea}.nav-credits .credits-total{font-size:14px}.nav-credits .credits-progress-bar{height:6px;margin-bottom:10px}.nav-credits .credits-details{padding:10px;font-size:12px}.nav-credits .credits-empty{padding:20px 12px}.nav-credits .empty-icon{font-size:32px}.nav-credits .empty-text{font-size:14px}.nav-credits .empty-hint{font-size:12px}.nav-credits .credits-loading,.nav-credits .credits-error{padding:20px 12px}.nav-credits .loading-spinner{width:24px;height:24px;border-width:2px}.nav-credits .loading-text,.nav-credits .error-text{font-size:12px}.brand-icon{width:100%;height:auto;object-fit:contain;animation:bounce 2s infinite;transition:all .3s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.brand-text{font-size:1.3rem;background:linear-gradient(to right,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;flex-direction:column;gap:15px;flex:1}.nav-link{display:flex;align-items:center;gap:15px;padding:15px 20px;color:#ffffffd9;text-decoration:none;border-radius:12px;transition:all .3s ease;font-size:1.05rem;font-weight:500;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-link:hover{background:#fff3;color:#fff;transform:translate(5px);box-shadow:0 4px 12px #00000026}.nav-link.active{background:#fff;color:#667eea;box-shadow:0 4px 15px #0003;transform:translate(5px)}.nav-icon{font-size:1.5rem;display:flex;align-items:center;min-width:30px;justify-content:center}.nav-label{font-size:1rem}.nav-footer{margin-top:auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.2);text-align:center}.version{color:#fff9;font-size:.85rem}@media(max-width:1024px)and (min-width:769px){.nav-bar{width:200px;padding:25px 15px}.nav-link{padding:12px 15px;font-size:1rem}.brand-text{font-size:1.1rem}}@media(max-width:768px){.nav-bar{width:80px;padding:20px 10px}.brand-text{display:none}.nav-brand{margin-bottom:30px;padding-bottom:20px}.nav-links{gap:10px}.nav-link{padding:15px 10px;justify-content:center}.nav-label{display:none}.nav-icon{font-size:1.8rem}.nav-footer{display:none}.brand-icon{max-width:50px}}.version-mismatch-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.version-mismatch-modal{background:#fff;border-radius:16px;max-width:600px;width:90%;padding:0;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out;overflow:hidden}.modal-header{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:24px 32px;text-align:center}.modal-icon{font-size:48px;margin-bottom:12px;animation:pulse 2s ease-in-out infinite}.modal-header h2{margin:0;font-size:24px;font-weight:600}.modal-body{padding:32px}.warning-text{font-size:16px;line-height:1.6;color:#333;margin:0 0 24px;text-align:center}.version-info{display:flex;align-items:center;justify-content:center;gap:20px;margin:24px 0;padding:20px;background:#f8f9fa;border-radius:12px}.version-item{display:flex;flex-direction:column;align-items:center;gap:8px}.version-item label{font-size:14px;color:#666;font-weight:500}.version-number{font-size:20px;font-weight:700;padding:8px 16px;border-radius:8px}.version-item.current .version-number{background:#fee;color:#e53935}.version-item.required .version-number{background:#e8f5e9;color:#2e7d32}.version-arrow{font-size:24px;color:#999;font-weight:700}.update-instructions{margin-top:24px;padding:20px;background:#fff3cd;border-left:4px solid #ffc107;border-radius:8px}.update-instructions h3{margin:0 0 12px;font-size:16px;color:#856404}.update-instructions ol{margin:0;padding-left:20px;color:#856404}.update-instructions li{margin:8px 0;line-height:1.5}.modal-footer{display:flex;gap:12px;padding:0 32px 24px}.modal-footer button{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-refresh{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-refresh:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.btn-download{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.btn-download:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2196f366}.modal-note{text-align:center;font-size:13px;color:#999;margin:0;padding:0 32px 24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:768px){.version-mismatch-modal{width:95%;max-width:none}.modal-header{padding:20px 24px}.modal-icon{font-size:36px}.modal-header h2{font-size:20px}.modal-body{padding:24px}.version-info{flex-direction:column;gap:12px}.version-arrow{transform:rotate(90deg)}.modal-footer{flex-direction:column;padding:0 24px 20px}.modal-footer button{width:100%}}
