:root{--background-color: #1a1a1a;--surface-color: #2c2c2c;--primary-color: #007bff;--primary-hover-color: #0056b3;--text-color: #f0f0f0;--text-secondary-color: #a0a0a0;--border-color: #444;--error-color: #ff4d4d;--success-color: #4caf50}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji",Noto Sans TC,sans-serif;background-color:var(--background-color);color:var(--text-color);line-height:1.6}#root{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;min-height:100vh}.container{width:100%;max-width:1600px;display:flex;flex-direction:column;gap:2rem;padding:0 1rem}h1{text-align:center;color:var(--text-color);font-size:2.5rem;margin-bottom:1rem}.input-section{background-color:var(--surface-color);border-radius:12px;padding:1.5rem;border:1px solid var(--border-color);display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}label{font-weight:600;color:var(--text-secondary-color)}.upload-area{border:2px dashed var(--border-color);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s,background-color .2s}.upload-area:hover,.upload-area.drag-over{border-color:var(--primary-color);background-color:#007bff0d}.upload-area p{color:var(--text-secondary-color)}#file-upload{display:none}.image-preview{max-width:100%;max-height:200px;border-radius:8px;margin-top:1rem;object-fit:contain}.radio-group{display:flex;gap:1rem}.radio-group label{background-color:#3a3a3a;padding:.5rem 1rem;border-radius:20px;cursor:pointer;transition:background-color .2s,color .2s;color:var(--text-secondary-color);border:1px solid var(--border-color)}.radio-group input[type=radio]{display:none}.radio-group input[type=radio]:checked+label{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}textarea,input[type=number]{width:100%;background-color:#3a3a3a;border:1px solid var(--border-color);border-radius:8px;padding:.75rem;color:var(--text-color);font-size:1rem;transition:border-color .2s,box-shadow .2s}textarea:focus,input[type=number]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #007bff40}textarea{resize:vertical;min-height:100px}.btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:background-color .2s,transform .1s;display:inline-flex;justify-content:center;align-items:center;gap:.5rem}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover-color)}.btn-secondary{background-color:#4f4f4f;color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:#5a5a5a}.btn:disabled{background-color:#555;color:#999;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.98)}.project-actions{display:flex;gap:1rem;margin-top:-.5rem;border-top:1px solid var(--border-color);padding-top:1.5rem}.loading-section,.result-section{width:100%;text-align:center}.spinner{border:4px solid rgba(255,255,255,.2);border-left-color:var(--primary-color);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{font-size:1.1rem;color:var(--text-secondary-color)}.result-header{display:flex;justify-content:flex-end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.video-generation-controls{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.video-generation-controls .btn{white-space:nowrap}.btn-warning{background-color:#f39c12;color:#fff}.btn-warning:hover:not(:disabled){background-color:#e67e22}.storyboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}@media(min-width:768px){.storyboard-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media(min-width:1200px){.storyboard-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}.cut-card{background-color:var(--surface-color);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;display:flex;flex-direction:column}.cut-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#0003;border-bottom:1px solid var(--border-color)}.cut-header h3{margin:0;padding:0;background:none;border:none}.btn-delete{background-color:transparent;color:var(--error-color);border:1px solid var(--error-color);padding:.25rem .5rem;font-size:1.2rem;line-height:1;border-radius:4px;cursor:pointer;transition:background-color .2s,color .2s;min-width:30px;height:30px;display:flex;align-items:center;justify-content:center}.btn-delete:hover:not(:disabled){background-color:var(--error-color);color:#fff}.btn-delete:disabled{opacity:.3;cursor:not-allowed;border-color:#666;color:#666}.cut-card img{width:100%;height:auto;object-fit:cover;background-color:#222}.image-placeholder{width:100%;background-color:#222;display:flex;justify-content:center;align-items:center;color:var(--text-secondary-color);font-size:.9rem}.prompt-area{padding:1rem;text-align:left;border-top:1px solid var(--border-color)}.prompt-area label{font-size:.9rem;margin-bottom:.5rem;display:block}.prompt-text-container{display:flex;gap:.5rem;align-items:flex-start}.prompt-text{flex-grow:1;background-color:#3a3a3a;padding:.5rem .75rem;border-radius:6px;color:var(--text-secondary-color);font-size:.9rem;white-space:pre-wrap;word-wrap:break-word;min-height:50px}.prompt-text.editable{width:100%;border:1px solid var(--border-color);color:var(--text-color);resize:vertical;min-height:80px}.prompt-text.editable:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #007bff40}.btn-copy{padding:.5rem;background-color:#444;color:var(--text-color);flex-shrink:0}.btn-copy:hover{background-color:#555}.btn-copy.copied{background-color:var(--success-color)}.error-message{color:var(--error-color);background-color:#ff4d4d1a;border:1px solid var(--error-color);border-radius:8px;padding:1rem;text-align:center}.header{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1rem}.header h1{margin:0;flex:1;text-align:center}.btn-settings{background-color:transparent;border:1px solid var(--border-color);padding:.5rem;font-size:1.5rem;border-radius:50%;width:45px;height:45px;display:flex;align-items:center;justify-content:center;transition:background-color .2s,border-color .2s;flex-shrink:0}.btn-settings:hover{background-color:#3a3a3a;border-color:var(--primary-color)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:var(--surface-color);border-radius:12px;border:1px solid var(--border-color);padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-content h2{margin-bottom:1.5rem;color:var(--text-color)}.settings-form{display:flex;flex-direction:column;gap:1rem}.settings-form input[type=text],.settings-form input[type=password]{width:100%;background-color:#3a3a3a;border:1px solid var(--border-color);border-radius:8px;padding:.75rem;color:var(--text-color);font-size:1rem;transition:border-color .2s,box-shadow .2s}.settings-form input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #007bff40}.modal-actions{display:flex;gap:1rem;margin-top:1rem;justify-content:flex-end}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background-color:#45a049}.video-progress{margin:1rem 0;padding:1rem;background-color:var(--surface-color);border-radius:8px;border:1px solid var(--border-color)}.video-progress p{color:var(--text-secondary-color);font-size:1rem;margin-top:.5rem}.btn-preview{background-color:#9b59b6;color:#fff}.btn-preview:hover:not(:disabled){background-color:#8e44ad}.btn-merge{background-color:#e67e22;color:#fff}.btn-merge:hover:not(:disabled){background-color:#d35400}.btn-regenerate{background-color:#3498db;color:#fff;width:100%;margin-top:.5rem}.btn-regenerate:hover:not(:disabled){background-color:#2980b9}.video-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.btn-close{background-color:transparent;color:var(--text-color);border:1px solid var(--border-color);padding:.5rem;font-size:1.2rem;min-width:auto}.btn-close:hover:not(:disabled){background-color:var(--error-color);color:#fff;border-color:var(--error-color)}.video-preview-modal{max-width:900px;width:95%;padding:0;overflow:hidden}.video-preview-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background-color:#0000004d;border-bottom:1px solid var(--border-color)}.video-preview-header h2{margin:0;color:var(--text-color);font-size:1.5rem}.video-preview-container{padding:2rem;background-color:#000;display:flex;justify-content:center;align-items:center;min-height:400px}.preview-video{max-width:100%;max-height:70vh;border-radius:8px;box-shadow:0 4px 12px #00000080}.video-preview-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:var(--surface-color);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.video-preview-info{color:var(--text-color);font-size:1rem;font-weight:600}.video-preview-actions{display:flex;gap:1rem;padding:1.5rem;justify-content:center;background-color:#0003}.video-preview-actions .btn{min-width:200px}@media(max-width:768px){.video-preview-modal{width:100%;max-width:none;height:100vh;max-height:none;border-radius:0}.video-preview-container{min-height:300px}.preview-video{max-height:50vh}.video-preview-controls{flex-direction:column;gap:1rem}.video-preview-actions{flex-direction:column}.video-preview-actions .btn{width:100%}.result-header{flex-wrap:wrap}.result-header .btn{flex:1 1 auto;min-width:150px}}.notification-toast{position:fixed;top:2rem;right:2rem;min-width:300px;max-width:500px;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #00000080;z-index:2000;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-success{background-color:var(--success-color);color:#fff}.notification-error{background-color:var(--error-color);color:#fff}.notification-info{background-color:var(--primary-color);color:#fff}.notification-content{display:flex;align-items:flex-start;gap:.75rem;flex:1}.notification-icon{font-size:1.2rem;font-weight:700;flex-shrink:0}.notification-message{font-size:.95rem;line-height:1.4}.notification-close{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;opacity:.8;transition:opacity .2s;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.notification-close:hover{opacity:1}.confirm-dialog{max-width:400px}.confirm-dialog h3{margin-bottom:1rem;color:var(--text-color)}.confirm-dialog p{margin-bottom:1.5rem;color:var(--text-secondary-color);line-height:1.6}@media(max-width:768px){.notification-toast{top:1rem;right:1rem;left:1rem;min-width:auto}}.merged-video-section{background-color:var(--surface-color);border-radius:12px;border:2px solid var(--success-color);overflow:hidden;margin-bottom:2rem;box-shadow:0 4px 12px #4caf5033}.merged-video-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:linear-gradient(135deg,#4caf5033,#4caf500d);border-bottom:1px solid var(--border-color)}.merged-video-header h2{margin:0;color:var(--success-color);font-size:1.5rem}.merged-video-container{padding:2rem;background-color:#000;display:flex;justify-content:center;align-items:center}.merged-video-player{width:100%;max-height:70vh;border-radius:8px;box-shadow:0 4px 20px #00000080}@media(max-width:768px){.merged-video-header{flex-direction:column;gap:1rem;align-items:stretch}.merged-video-header .btn{width:100%}.merged-video-container{padding:1rem}.merged-video-player{max-height:400px}}.batch-regenerate-controls{background-color:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);padding:1rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.selection-info{color:var(--text-color);font-weight:600;font-size:1rem;min-width:120px}.batch-buttons{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.btn-regenerate-batch{background-color:#e74c3c;color:#fff;padding:.75rem 1.5rem;font-weight:600;white-space:nowrap}.btn-regenerate-batch:hover:not(:disabled){background-color:#c0392b}.cut-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 2px #007bff4d}.cut-header-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.image-select-label,.video-select-label{display:flex;align-items:center;gap:.4rem;cursor:pointer;padding:.3rem .6rem;background-color:#ffffff0d;border-radius:6px;border:1px solid var(--border-color);transition:all .2s ease;-webkit-user-select:none;user-select:none;font-size:.85rem}.image-select-label:hover,.video-select-label:hover{background-color:#ffffff1a;border-color:var(--primary-color);transform:translateY(-1px)}.image-select-label{border-color:#4caf50}.image-select-label:hover{border-color:#45a049;background-color:#4caf501a}.video-select-label{border-color:#3498db}.video-select-label:hover{border-color:#2980b9;background-color:#3498db1a}.image-select-checkbox,.video-select-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--success-color)}.video-select-checkbox{accent-color:var(--primary-color)}.image-select-checkbox:disabled,.video-select-checkbox:disabled{cursor:not-allowed;opacity:.5}.checkbox-label-text{color:var(--text-color);font-size:.8rem;font-weight:500;white-space:nowrap}.checkbox-text{color:var(--text-color);font-size:.9rem;font-weight:500}@media(max-width:768px){.batch-regenerate-controls{flex-direction:column;align-items:stretch}.selection-info{text-align:center;width:100%}.batch-buttons{width:100%;justify-content:center}.batch-buttons .btn{flex:1 1 auto}.btn-regenerate-batch{width:100%}}.image-container{position:relative;width:100%;overflow:hidden}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent 40%,transparent 60%,rgba(0,0,0,.7));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;pointer-events:none}.image-container:hover .image-overlay{opacity:1;pointer-events:auto}.btn-replace-image{background-color:#007bffe6;color:#fff;border:2px solid white;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap}.btn-replace-image:hover{background-color:#005bbbf2;transform:scale(1.05);box-shadow:0 6px 16px #0006}.btn-replace-image:active{transform:scale(.98)}@media(max-width:768px){.image-overlay{opacity:1;background:linear-gradient(to bottom,transparent,transparent 70%,rgba(0,0,0,.8));align-items:flex-end;padding-bottom:1rem;pointer-events:auto}.btn-replace-image{font-size:.9rem;padding:.6rem 1.2rem}}.mode-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-top:.75rem}.mode-card{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);border:2px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem 1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;gap:.75rem;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--card-color-1),var(--card-color-2));opacity:.15;transition:opacity .3s ease;z-index:0}.mode-card:hover:before{opacity:.25}.mode-card.active:before{opacity:.35}.mode-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:var(--card-color-1)}.mode-card.active{border-color:var(--card-color-1);box-shadow:0 4px 16px var(--card-shadow);transform:scale(1.02)}.mode-icon{font-size:2.5rem;position:relative;z-index:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:transform .3s ease}.mode-card:hover .mode-icon{transform:scale(1.15)}.mode-card.active .mode-icon{transform:scale(1.1)}.mode-title{font-weight:600;font-size:.95rem;color:var(--text-color);text-align:center;position:relative;z-index:1;line-height:1.3}.mode-card-purple{--card-color-1: #9b59b6;--card-color-2: #8e44ad;--card-shadow: rgba(155, 89, 182, .4)}.mode-card-blue{--card-color-1: #3498db;--card-color-2: #2980b9;--card-shadow: rgba(52, 152, 219, .4)}.mode-card-green{--card-color-1: #2ecc71;--card-color-2: #27ae60;--card-shadow: rgba(46, 204, 113, .4)}.mode-card-orange{--card-color-1: #e67e22;--card-color-2: #d35400;--card-shadow: rgba(230, 126, 34, .4)}.mode-card-pink{--card-color-1: #e91e63;--card-color-2: #c2185b;--card-shadow: rgba(233, 30, 99, .4)}.mode-card-teal{--card-color-1: #1abc9c;--card-color-2: #16a085;--card-shadow: rgba(26, 188, 156, .4)}.checkbox-container{display:flex;align-items:center;background:linear-gradient(135deg,#ffffff14,#ffffff08);border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem 1.25rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.checkbox-container:hover{background:linear-gradient(135deg,#ffffff1f,#ffffff0d);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.modern-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border:2px solid var(--border-color);border-radius:6px;background-color:#ffffff0d;cursor:pointer;position:relative;transition:all .3s ease;flex-shrink:0;margin-right:1rem}.modern-checkbox:hover{border-color:var(--primary-color);background-color:#007bff1a}.modern-checkbox:checked{background:linear-gradient(135deg,#4caf50,#45a049);border-color:#4caf50}.checkbox-label{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;flex:1;font-weight:500;margin:0;gap:.75rem}.checkbox-icon{position:absolute;left:0;top:50%;transform:translateY(-50%);color:#fff;font-size:1rem;font-weight:700;opacity:0;transition:opacity .2s ease;pointer-events:none;margin-left:.25rem}.modern-checkbox:checked~.checkbox-label .checkbox-icon,.checkbox-container:has(.modern-checkbox:checked) .checkbox-icon{opacity:1}.checkbox-text{color:var(--text-color);line-height:1.5;font-size:.95rem}@media(max-width:768px){.mode-cards-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.mode-card{padding:1.25rem .75rem}.mode-icon{font-size:2rem}.mode-title{font-size:.85rem}.checkbox-container{padding:.875rem 1rem}.modern-checkbox{width:20px;height:20px;margin-right:.75rem}.checkbox-text{font-size:.875rem}}@media(max-width:480px){.mode-cards-grid{grid-template-columns:repeat(2,1fr)}}.cut-card-compact{background-color:var(--surface-color);border:2px solid var(--border-color);border-radius:12px;padding:1rem;transition:all .3s ease;position:relative}.cut-card-compact.selected{border-color:var(--success-color);box-shadow:0 0 15px #4caf504d}.image-container-clickable{position:relative;overflow:hidden;border-radius:8px;margin:.5rem 0}.image-container-clickable img{width:100%;display:block;transition:transform .3s ease}.image-container-clickable:hover img{transform:scale(1.05)}.image-click-hint{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:1rem;text-align:center;opacity:0;transition:opacity .3s ease;pointer-events:none}.image-container-clickable:hover .image-click-hint{opacity:1}.image-click-hint span{color:#fff;font-size:.9rem;font-weight:600}.video-status-badge{display:inline-block;background-color:var(--success-color);color:#fff;padding:.3rem .8rem;border-radius:12px;font-size:.85rem;margin-top:.5rem;font-weight:600}.cut-detail-modal{width:95%;max-width:1800px;max-height:95vh;overflow:hidden;display:flex;flex-direction:column}.cut-detail-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid var(--border-color);margin-bottom:1rem;flex-shrink:0}.cut-detail-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;overflow-y:auto;padding-right:.5rem}.cut-detail-left,.cut-detail-right{display:flex;flex-direction:column;gap:1rem}.detail-image-container,.detail-video-container{width:100%;border-radius:8px;overflow:hidden;background-color:#1a1a1a;display:flex;align-items:center;justify-content:center;min-height:400px;max-height:65vh}.detail-image-container img{width:100%;height:100%;object-fit:contain;display:block}.detail-video{width:100%;height:100%;object-fit:contain}.image-actions,.video-detail-actions{display:flex;gap:.5rem;flex-wrap:wrap}.image-actions button,.video-detail-actions button,.video-detail-actions a{flex:1;min-width:120px}.prompt-section{display:flex;flex-direction:column;gap:.5rem}.prompt-section label{font-weight:600;color:var(--text-color)}.prompt-section textarea{background-color:#1a1a1a;border:1px solid var(--border-color);border-radius:6px;padding:.75rem;color:var(--text-color);font-family:inherit;resize:vertical;min-height:100px}.prompt-section textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff1a}.no-video-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary-color);padding:2rem;text-align:center}.no-video-placeholder p{margin:.5rem 0}@media(max-width:1024px){.cut-detail-content{grid-template-columns:1fr}.cut-detail-modal{width:98%}}@media(max-width:768px){.image-click-hint{opacity:1;background:linear-gradient(to top,rgba(0,0,0,.9),transparent)}.video-status-badge{font-size:.75rem;padding:.25rem .6rem}}.ref-image-preview{width:24px;height:24px;object-fit:cover;border-radius:4px;transition:transform .2s ease,box-shadow .2s ease,z-index .2s ease;cursor:zoom-in;position:relative;z-index:1}.ref-image-preview:hover{transform:scale(8) translate(-10px,-5px);box-shadow:0 4px 15px #000c;z-index:1000}
