*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-box{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:450px;padding:40px;width:100%}.auth-title{color:#667eea;font-size:36px;font-weight:700;margin-bottom:8px;text-align:center}.auth-subtitle{color:#666;font-size:14px;margin-bottom:30px;text-align:center}.auth-tabs{display:flex;gap:10px;margin-bottom:30px}.auth-tabs button{background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px;transition:all .3s}.auth-tabs button.active{background:#667eea;color:#fff}.auth-tabs button:hover{opacity:.8}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .3s}.form-group input:focus{border-color:#667eea;outline:none}.submit-btn{padding:14px}.dashboard-loading{align-items:center;color:#fff;display:flex;font-size:24px;justify-content:center;min-height:100vh}.dashboard-container{min-height:100vh;padding:20px}.dashboard-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:24px 32px}.dashboard-header h1{color:#667eea;font-size:28px;margin-bottom:4px}.dashboard-header p{color:#666;font-size:14px}.header-right{gap:16px}.credits-badge{border-radius:8px}.logout-btn{background:#fff;border:2px solid #667eea;color:#667eea;padding:10px 24px}.logout-btn:hover{background:#667eea;color:#fff}.dashboard-content{margin:0 auto;max-width:1200px}.create-project-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-bottom:30px;padding:32px}.create-project-section h2{color:#333;font-size:22px;margin-bottom:20px}.create-project-form{display:flex;gap:12px}.create-project-form input{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:16px;padding:14px 18px;transition:border-color .3s}.create-project-form input:focus{border-color:#667eea;outline:none}.create-project-form button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:transform .2s;white-space:nowrap}.create-project-form button:hover:not(:disabled){transform:translateY(-2px)}.create-project-form button:disabled{cursor:not-allowed;opacity:.6}.error-message{margin-top:16px}.projects-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;padding:32px}.projects-section h2{color:#333;font-size:22px;margin-bottom:24px}.no-projects{color:#999;padding:60px 20px;text-align:center}.no-projects p{font-size:18px}.projects-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.project-card{align-items:center;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;padding:24px;transition:all .3s}.project-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.project-info h3{color:#333;font-size:18px;margin-bottom:8px}.project-date{color:#999;font-size:13px;margin:0}.project-videotype{color:#667eea;font-size:13px;font-weight:600;margin:8px 0 0}.delete-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:background .3s}.delete-btn:hover{background:#c82333}.project-page-error,.project-page-loading{align-items:center;color:#fff;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:100vh}.project-page-error button{background:#fff;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-weight:600;padding:12px 24px}.project-page-container{min-height:100vh;padding:20px}.project-page-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:24px 32px}.project-page-header .back-btn{align-items:center;background:#667eea!important;border:2px solid #667eea!important;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff!important;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;margin-bottom:12px;padding:10px 20px;transition:all .3s}.project-page-header .back-btn:hover{background:#5568d3!important;border-color:#5568d3!important;box-shadow:0 4px 8px #00000026;transform:translateX(-2px)}.project-page-header h1{color:#333;font-size:28px;margin:0}.credits-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.credits-badge,.logout-btn{font-size:14px;font-weight:600}.logout-btn{border:none;border-radius:8px;cursor:pointer;padding:10px 20px;transition:all .3s}.logout-btn:hover{box-shadow:0 4px 12px #ff47574d}.project-page-content{margin:0 auto;max-width:1200px}.video-type-selection,.video-type-set{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;padding:40px}.video-type-selection h2,.video-type-set h2{color:#333;font-size:24px;margin-bottom:8px}.subtitle{color:#666;font-size:14px;margin-bottom:30px}.video-type-display{align-items:center;background:#f0fdf4;border:2px solid #86efac;border-radius:12px;display:flex;gap:20px;margin-top:20px;padding:24px}.video-type-icon{align-items:center;background:#22c55e;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:50px;justify-content:center;width:50px}.video-type-display h3{color:#166534;font-size:20px;margin:0 0 4px}.video-type-display p{color:#15803d;font-size:14px;margin:0}.video-type-form{gap:24px}.form-group,.video-type-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input,.form-group select{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:14px 16px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{border-color:#667eea;outline:none}.form-group select{cursor:pointer}.error-message{background:#fee;color:#c33;font-size:14px;padding:12px;text-align:center}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:16px;transition:transform .2s}.submit-btn:hover:not(:disabled){transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.warning-message{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:14px;margin:0;padding:12px;text-align:center}.scene-types-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-top:30px;padding:40px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h2{color:#333;font-size:24px;margin:0}.edit-btn{background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s}.edit-btn:hover{background:#667eea;color:#fff}.selected-scenes-display{margin-top:20px}.info-text{color:#666;font-size:14px;margin-bottom:16px}.scene-order-list{display:flex;flex-direction:column;gap:12px}.scene-order-item{align-items:center;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:16px;padding:16px 20px;transition:all .3s}.scene-order-item:hover{background:#e9ecef;border-color:#667eea;transform:translateX(4px)}.scene-order-item.active{background:#e7f0ff;border-color:#667eea;box-shadow:0 2px 8px #667eea33}.scene-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:5%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:32px;justify-content:center;min-width:32px}.scene-name{color:#333;flex:1 1;font-size:16px;font-weight:500}.repeat-badge{align-items:center;background:#667eea;border-radius:12px;color:#fff;display:inline-flex;font-size:12px;font-weight:600;margin-left:auto;padding:4px 10px}.scene-order-group{background:#f0f4ff;border:3px solid #667eea;border-radius:12px;margin-bottom:16px;overflow:hidden}.scene-order-group-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:12px 16px}.scene-order-group-header .group-label{font-size:14px;font-weight:600}.scene-order-group-header .repeat-badge{margin-left:0}.scene-order-item.grouped{border-radius:6px;margin:8px}.scene-selection{margin-top:10px}.scene-selection-layout{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-bottom:20px}.available-scenes-column,.selected-scenes-column{min-height:400px}.available-scenes-column h3,.selected-scenes-column h3{color:#333;font-size:18px;margin-bottom:4px}.column-subtitle{color:#999;font-size:13px;margin-bottom:16px}.scene-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;max-height:400px;overflow-y:auto;padding-right:8px}.scene-list::-webkit-scrollbar{width:6px}.scene-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.scene-list::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.scene-checkbox{align-items:center;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;display:flex;gap:10px;padding:12px 16px;transition:all .3s;-webkit-user-select:none;user-select:none}.scene-checkbox:hover{background:#f0f0ff;border-color:#667eea}.scene-checkbox input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.scene-checkbox span{color:#333;font-size:14px;font-weight:500}.new-scene-input{display:flex;gap:8px;margin-bottom:16px}.new-scene-input input{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:14px;padding:10px 14px}.new-scene-input input:focus{border-color:#667eea;outline:none}.create-btn{background:#22c55e;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .3s}.create-btn:hover{background:#16a34a}.cancel-btn{background:#999;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background .3s}.cancel-btn:hover{background:#777}.add-new-scene-btn{background:#fff;border:2px dashed #667eea;border-radius:8px;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s;width:100%}.add-new-scene-btn:hover{background:#f0f0ff;border-style:solid}.selected-scenes-column{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;padding:20px}.empty-selection{align-items:center;color:#999;display:flex;flex-direction:column;height:300px;justify-content:center;padding:60px 20px;text-align:center}.empty-selection p{font-size:14px;margin:4px 0}.selected-scene-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto;padding-right:8px}.selected-scene-list::-webkit-scrollbar{width:6px}.selected-scene-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.selected-scene-list::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.selected-scene-item{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:move;display:flex;gap:12px;padding:12px 16px;transition:all .3s}.selected-scene-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33}.drag-handle{color:#999;cursor:grab;font-size:16px;-webkit-user-select:none;user-select:none}.selected-scene-item:active .drag-handle{cursor:grabbing}.selected-scene-item .scene-name{flex:1 1;font-size:14px}.repeat-count-control{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;display:flex;gap:8px;margin-left:auto;padding:4px 8px}.repeat-label{color:#666;font-size:12px;font-weight:600;margin:0}.repeat-input{border:1px solid #ccc;border-radius:4px;color:#333;font-size:14px;font-weight:600;padding:4px 8px;text-align:center;transition:all .3s;width:50px}.repeat-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.repeat-input::-webkit-inner-spin-button,.repeat-input::-webkit-outer-spin-button{opacity:1}.repeat-times{color:#667eea;font-size:14px;font-weight:700}.remove-scene-btn{align-items:center;background:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:24px;justify-content:center;line-height:1;transition:background .3s;width:24px}.remove-scene-btn:hover{background:#c82333}.group-selected-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-bottom:12px;padding:12px;transition:background .3s;width:100%}.group-selected-btn:hover{background:#5568d3}.scene-group{background:#f0f4ff;border:3px solid #667eea;border-radius:12px;margin-bottom:16px;overflow:hidden}.scene-group-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:12px;padding:12px 16px}.group-label{flex:1 1;font-size:14px;font-weight:600}.scene-group-header .repeat-count-control{background:#fff;border-color:#fff}.scene-group-header .repeat-label{color:#666}.ungroup-btn{background:#fff;border:none;border-radius:6px;color:#667eea;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s}.ungroup-btn:hover{background:#f0f0f0;transform:scale(1.05)}.grouped-scenes{display:flex;flex-direction:column;gap:6px;padding:8px}.grouped-scene-item{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:6px;display:flex;gap:12px;margin-left:20px;padding:10px 12px}.grouped-scene-item .scene-number{align-items:center;background:#667eea;display:flex;font-size:12px;height:28px;justify-content:center;min-width:28px}.grouped-scene-item .scene-name{color:#555;font-size:14px}.scene-checkbox{accent-color:#667eea;cursor:pointer;height:18px;width:18px}.selected-scene-item.selected{background:#f0f4ff;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.action-buttons{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.cancel-action-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s}.cancel-action-btn:hover{border-color:#999;color:#333}@media (max-width:968px){.scene-selection-layout{grid-template-columns:1fr}}.datasource-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-top:30px;padding:40px}.datasource-section .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.datasource-section h2{color:#333;font-size:24px;margin:0}.datasource-empty,.datasource-loading{background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;color:#666;padding:40px;text-align:center}.datasource-empty .info-text{color:#999;font-size:12px;margin-top:8px}.datasource-list{display:flex;flex-direction:column;gap:20px;margin-bottom:30px;max-height:500px;overflow-y:auto;padding:20px}.datasource-item,.datasource-list{border:1px solid #e0e0e0;border-radius:8px}.datasource-item{background:#f8f9fa;padding:16px;transition:box-shadow .2s}.datasource-item:hover{box-shadow:0 2px 8px #0000001a}.datasource-header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.datasource-number{align-items:center;background:#667eea;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:28px;justify-content:center;width:28px}.datasource-date{color:#999;font-size:12px}.datasource-json{background:#fff;border:1px solid #ddd;border-radius:6px;font-family:Courier New,monospace;font-size:11px;line-height:1.4;overflow-x:auto;padding:12px}.datasource-json pre{word-wrap:break-word;color:#333;margin:0;white-space:pre-wrap}.datasource-form{background:#f8f9fa;border:2px solid #667eea;border-radius:8px;margin-bottom:20px;padding:24px}.datasource-form h3{color:#333;font-size:16px;margin:0 0 20px}.json-textarea{border:1px solid #ddd;border-radius:6px;font-family:Courier New,monospace;font-size:12px;line-height:1.4;padding:12px;resize:vertical;width:100%}.json-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.json-textarea:disabled{background:#f0f0f0;color:#999;cursor:not-allowed}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.add-datasource-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:background .2s}.add-datasource-btn:hover{background:#5568d3}.add-datasource-btn:disabled{background:#ccc;cursor:not-allowed}.datasource-selection-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-top:30px;padding:40px}.datasource-selection-section .section-header{margin-bottom:30px}.datasource-selection-section .subtitle{font-size:14px;margin:8px 0 0}.scene-list-for-datasource{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-bottom:30px}.scene-item-for-datasource{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;padding:16px;transition:all .3s}.scene-item-for-datasource:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.scene-item-for-datasource.active{background:#e7f0ff;border-color:#667eea;box-shadow:0 4px 12px #667eea33}.scene-item-for-datasource.has-datasource{background:#f0fdf4;border-color:#86efac}.scene-item-for-datasource.has-datasource:hover{border-color:#22c55e}.scene-item-info{gap:8px}.scene-badges,.scene-item-info{display:flex;flex-direction:column}.scene-badges{gap:6px}.datasource-selected-badge{background:#22c55e;font-size:11px}.datasource-selected-badge,.variation-selected-badge{align-self:flex-start;border-radius:12px;color:#fff;font-weight:600;padding:4px 12px}.variation-selected-badge{background:#667eea;font-family:monospace;font-size:10px}.datasource-grid-container{border-top:2px solid #e0e0e0;margin-top:30px;padding-top:30px}.datasource-grid-container h3{color:#333;font-size:20px;margin-bottom:20px}.no-datasources-message{background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;color:#666;padding:40px;text-align:center}.datasource-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.datasource-card{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;display:flex;flex-direction:column;padding:20px;transition:all .3s}.datasource-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.datasource-card.selected{background:#f0fdf4;border-color:#22c55e;border-width:3px}.datasource-card-header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.datasource-card-date{color:#666;font-size:12px;font-weight:500}.selected-badge{background:#22c55e;border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:4px 12px}.datasource-card-preview{background:#fff;border:1px solid #ddd;border-radius:8px;flex:1 1;margin-bottom:16px;max-height:120px;overflow:hidden;padding:12px}.datasource-card-preview pre{color:#333;font-family:Courier New,monospace;font-size:11px;line-height:1.4;margin:0;overflow:hidden;text-overflow:ellipsis}.datasource-card-actions{display:flex;flex-direction:column;gap:8px}.datasource-action-btn{border:none;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;padding:10px 16px;transition:all .3s}.datasource-action-btn.view-btn{background:#667eea;color:#fff}.datasource-action-btn.view-btn:hover{background:#5568d3;box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}.datasource-action-btn.variations-btn{background:#764ba2;color:#fff}.datasource-action-btn.variations-btn:hover{background:#653a8a;box-shadow:0 2px 8px #764ba24d;transform:translateY(-1px)}.datasource-action-btn.select-btn{background:#22c55e;color:#fff}.datasource-action-btn.select-btn:hover:not(:disabled){background:#16a34a;box-shadow:0 2px 8px #22c55e4d;transform:translateY(-1px)}.datasource-action-btn.select-btn.selected,.datasource-action-btn.select-btn:disabled{background:#86efac;cursor:not-allowed;opacity:.7}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding:24px 30px}.modal-header h3{color:#333;font-size:22px;margin:0}.modal-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.modal-close-btn:hover{background:#f0f0f0;color:#333}.modal-body{flex:1 1;overflow-y:auto;padding:30px}.datasource-metadata{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:16px}.datasource-metadata p{color:#555;font-size:14px;margin:8px 0}.datasource-metadata strong{color:#333;font-weight:600}.json-viewer{background:#1e1e1e;border-radius:8px;overflow-x:auto;padding:20px}.json-viewer pre{color:#d4d4d4;font-family:Courier New,monospace;font-size:13px;line-height:1.6;margin:0}.modal-footer{border-top:2px solid #f0f0f0;display:flex;gap:12px;justify-content:flex-end;padding:20px 30px}.modal-action-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s}.modal-action-btn.variations-btn{background:#764ba2;color:#fff}.modal-action-btn.variations-btn:hover{background:#653a8a;box-shadow:0 4px 12px #764ba24d;transform:translateY(-2px)}.modal-action-btn.select-btn{background:#22c55e;color:#fff}.modal-action-btn.select-btn:hover{background:#16a34a;box-shadow:0 4px 12px #22c55e4d;transform:translateY(-2px)}.modal-action-btn.close-btn{background:#e0e0e0;color:#333}.modal-action-btn.close-btn:hover{background:#d0d0d0}.see-variations-btn-inline{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;transition:all .3s;white-space:nowrap}.see-variations-btn-inline:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}@media (max-width:768px){.datasource-grid,.scene-list-for-datasource{grid-template-columns:1fr}.modal-content{margin:10px;max-height:95vh}.modal-footer{flex-direction:column}.modal-action-btn{width:100%}}.datasource-status{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.datasource-status.status-pending{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}.datasource-status.status-jsoned{background:#d1fae5;border:1px solid #34d399;color:#065f46}.datasource-action-btn.variations-btn:disabled,.modal-action-btn.variations-btn:disabled,.see-variations-btn-inline:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.datasource-action-btn.variations-btn:disabled:hover,.modal-action-btn.variations-btn:disabled:hover,.see-variations-btn-inline:disabled:hover{box-shadow:none;transform:none}.variations-page-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.variations-page-header{align-items:flex-start;color:#fff;display:flex;justify-content:space-between;margin-bottom:30px}.variations-page-header h1{font-size:2em;margin:10px 0 5px}.datasource-id{align-items:center;display:flex;font-family:monospace;font-size:.9em;gap:12px;margin:0;opacity:.9}.datasource-status-badge{border-radius:12px;font-family:sans-serif;font-size:.75em;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.datasource-status-badge.status-pending{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}.datasource-status-badge.status-jsoned{background:#d1fae5;border:1px solid #34d399;color:#065f46}.header-right{align-items:center;display:flex;gap:15px}.credits-badge{background:#fff3;border-radius:25px;font-weight:500;padding:10px 20px}.back-btn,.logout-btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s ease}.back-btn{background:#fff3;color:#fff;margin-bottom:10px}.back-btn:hover{background:#ffffff4d;transform:translateX(-5px)}.logout-btn{background:#ff4757;color:#fff}.logout-btn:hover{background:#ee5a6f;box-shadow:0 5px 15px #0003;transform:translateY(-2px)}.create-variation-btn{background:#2ecc71;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.create-variation-btn:hover:not(:disabled){background:#27ae60;box-shadow:0 5px 15px #2ecc714d;transform:translateY(-2px)}.create-variation-btn:disabled{background:#95a5a6;cursor:not-allowed;opacity:.7}.variations-page-content{background:#fff;border-radius:15px;box-shadow:0 10px 40px #0000001a;margin:0 auto;max-width:1200px;padding:30px}.variations-page-loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:center;min-height:100vh}.variations-empty{color:#666;padding:60px 20px;text-align:center}.variations-empty p:first-child{color:#333;font-size:1.3em;margin-bottom:10px}.info-text{color:#999;font-size:.95em}.variations-list h2{border-bottom:2px solid #f0f0f0;color:#333;margin-bottom:30px;padding-bottom:15px}.variations-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.variation-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:12px;display:flex;flex-direction:column;overflow:hidden;padding:0;transition:all .3s ease}.variation-card:hover{border-color:#667eea;box-shadow:0 8px 25px #0000001f;transform:translateY(-4px)}.variation-card.selected-variation{background:linear-gradient(180deg,#f0fdf4 0,#fff);border:3px solid #22c55e;box-shadow:0 8px 25px #22c55e40}.variation-card-header{align-items:center;background:#fff;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;padding:16px 20px}.variation-header-left{align-items:center;display:flex;gap:12px}.variation-number{color:#667eea;font-size:1.1em;font-weight:700}.variation-status{border-radius:12px;font-size:.75em;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.status-pending{background:#fff3cd;color:#856404}.status-processing{background:#cfe2ff;color:#084298}.status-completed{background:#d1e7dd;color:#0f5132}.status-failed{background:#f8d7da;color:#842029}.currently-selected-badge{animation:pulse-selected 2s ease-in-out infinite;background:#22c55e;border-radius:12px;color:#fff;font-size:.7em;font-weight:700;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}@keyframes pulse-selected{0%,to{opacity:1}50%{opacity:.7}}.variation-date{color:#6c757d;font-size:.85em;font-weight:500}.variation-id-container{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;font-family:monospace;gap:8px;padding:12px 20px}.variation-id-label{color:#6c757d;font-size:.75em;font-weight:600;text-transform:uppercase}.variation-id-value{color:#495057;flex:1 1;font-size:.8em;word-break:break-all}.variation-video-container{aspect-ratio:16/9;background:#000;position:relative;width:100%}.variation-video{display:block;height:100%;object-fit:contain;width:100%}.variation-video-placeholder{align-items:center;aspect-ratio:16/9;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;justify-content:center;width:100%}.placeholder-content{color:#6c757d;text-align:center}.placeholder-content svg{animation:pulse 2s ease-in-out infinite;margin-bottom:16px;opacity:.5}.placeholder-content p{color:#495057;font-size:1em;font-weight:500;margin:0}@keyframes pulse{0%,to{opacity:.5}50%{opacity:.8}}.variation-action-container{background:#fff;border-bottom:2px solid #e9ecef;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;padding:20px}.design-variation-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;font-size:1em;font-weight:600;padding:12px 32px;transition:all .3s ease}.design-variation-btn:hover{box-shadow:0 6px 20px #667eea80;transform:translateY(-2px)}.design-variation-btn:active{transform:translateY(0)}.select-variation-btn{background:#2ecc71;border:none;border-radius:8px;box-shadow:0 4px 12px #2ecc714d;color:#fff;cursor:pointer;font-size:1em;font-weight:600;padding:12px 32px;transition:all .3s ease}.select-variation-btn:hover{background:#27ae60;box-shadow:0 6px 20px #2ecc7180;transform:translateY(-2px)}.select-variation-btn:active{transform:translateY(0)}.variation-data{background:#fff;display:flex;flex:1 1;flex-direction:column;padding:0}.variation-data-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:16px 20px}.variation-data-header h4{color:#333;font-size:.95em;font-weight:600;margin:0}.download-json-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.8em;font-weight:600;padding:6px 14px;transition:all .3s}.download-json-btn:hover{background:#5568d3;box-shadow:0 2px 8px #667eea4d;transform:translateY(-1px)}.variation-data pre{color:#333;font-family:Courier New,monospace;font-size:.85em;line-height:1.6;margin:0;max-height:300px;overflow-x:auto;overflow-y:auto;padding:20px}.variation-data pre::-webkit-scrollbar{height:8px;width:8px}.variation-data pre::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.variation-data pre::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.variation-data pre::-webkit-scrollbar-thumb:hover{background:#5568d3}@media (max-width:768px){.variations-grid{grid-template-columns:1fr}.variation-card-header{align-items:flex-start;flex-direction:column;gap:8px}.variation-header-left{justify-content:space-between;width:100%}.variation-data-header{align-items:flex-start;flex-direction:column;gap:10px}.download-json-btn{width:100%}.header-right{flex-wrap:wrap}}.error-message{background-color:#ffebee;border-left:4px solid #c62828;color:#c62828;padding:12px 20px}.error-message,.warning-message-box{border-radius:8px;margin-bottom:20px}.warning-message-box{background-color:#fff3cd;border-left:4px solid #ffc107;color:#856404;padding:16px 20px}.warning-message-box strong{display:block;font-size:1.1em;margin-bottom:8px}.warning-message-box p{font-size:.95em;margin:0}.loading-screen{align-items:center;color:#fff;display:flex;font-size:24px;justify-content:center;min-height:100vh}
/*# sourceMappingURL=main.1f9f7e26.css.map*/