*{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);font-weight:600}.logout-btn{border:none;border-radius:8px;font-weight:600;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{font-size:14px;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{background:#667eea;margin-left:auto}.manual-upload-badge,.repeat-badge{align-items:center;border-radius:12px;color:#fff;display:inline-flex;font-size:12px;font-weight:600;padding:4px 10px}.manual-upload-badge{background:#f59e0b;margin-left:8px}.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}.scene-controls{align-items:center;display:flex;gap:12px;margin-left:auto}.manual-upload-toggle{align-items:center;background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;cursor:pointer;display:flex;gap:6px;padding:4px 8px;transition:all .2s}.manual-upload-toggle:hover{background:#ffedd5;border-color:#fdba74}.manual-upload-toggle input[type=checkbox]{accent-color:#f59e0b;cursor:pointer;height:14px;width:14px}.manual-upload-label{color:#ea580c;font-size:11px;font-weight:600;white-space:nowrap}.repeat-count-control{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;display:flex;gap:8px;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}.manual-upload-message{background:#fff7ed;border:2px solid #fed7aa;border-radius:8px;color:#ea580c;padding:40px;text-align:center}.manual-upload-message p{font-size:16px;font-weight:600;margin:8px 0}.manual-upload-message .info-text{color:#9a3412;font-size:14px;font-weight:400}.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%}.modal-content.interactive-json-modal{height:95vh;max-height:95vh;max-width:95vw;width:95vw}@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:4px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.modal-action-btn.variations-btn{background:#764ba2;color:#fff}.modal-action-btn.variations-btn:hover{background:#653a8a;box-shadow:0 2px 8px #764ba24d;transform:translateY(-1px)}.modal-action-btn.select-btn{background:#22c55e;color:#fff}.modal-action-btn.select-btn:hover{background:#16a34a;box-shadow:0 2px 8px #22c55e4d;transform:translateY(-1px)}.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)}.delete-datasource-btn{background:#ff4757;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;transition:all .3s;white-space:nowrap}.delete-datasource-btn:hover{background:#ee5a6f;box-shadow:0 4px 12px #ff47574d;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}.ai-generation-section{background:#fff;border:2px solid #e5e7eb;border-left:4px solid #667eea;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:30px;padding:32px}.ai-section-header{align-items:flex-start;display:flex;gap:16px;margin-bottom:24px}.ai-icon{font-size:36px;line-height:1}.ai-section-header h2{color:#667eea;font-size:28px;font-weight:700;margin:0}.ai-subtitle{color:#6b7280;font-size:14px;font-weight:400;margin:8px 0 0}.ai-prompt-container{margin-bottom:20px}.ai-prompt-container label{color:#111827;display:block;font-size:15px;font-weight:600;margin-bottom:12px}.ai-prompt-textarea{background:#fff;border:2px solid #667eea;border-radius:12px;color:#1f2937;font-family:inherit;font-size:15px;min-height:120px;padding:16px;resize:vertical;transition:all .3s;width:100%}.ai-prompt-textarea:focus{border-color:#764ba2;box-shadow:0 0 0 3px #667eea1a;outline:none}.ai-prompt-textarea:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.7}.ai-prompt-textarea::placeholder{color:#9ca3af}.ai-sample-title-input{background:#f9fafb;border:2px solid #d1d5db;border-radius:10px;color:#1f2937;font-family:inherit;font-size:15px;margin-bottom:12px;padding:14px 16px;transition:all .2s;width:100%}.ai-sample-title-input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea14;outline:none}.ai-sample-title-input:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.7}.ai-sample-title-input::placeholder{color:#9ca3af}.char-count{color:#6b7280;font-size:13px;font-weight:500;margin-bottom:16px;margin-top:-8px;text-align:right}.ai-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.ai-generate-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:700;gap:8px;padding:14px 32px;transition:all .3s}.ai-generate-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.ai-generate-btn:active:not(:disabled){transform:translateY(0)}.ai-generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.ai-skip-btn{background:#fff;border:2px solid #667eea;border-radius:10px;color:#667eea;cursor:pointer;font-size:15px;font-weight:600;padding:14px 32px;transition:all .3s}.ai-skip-btn:hover:not(:disabled){background:#667eea;color:#fff}.ai-skip-btn:disabled{cursor:not-allowed;opacity:.5}.ai-error-message{background:#fee2e2;border-left:4px solid #dc2626;color:#991b1b}.ai-error-message,.ai-success-message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:16px;padding:14px 18px}.ai-success-message{animation:slideIn .3s ease-out;background:#d1fae5;border-left:4px solid #10b981;color:#065f46}.ai-info-box{align-items:center;background:#ffffffb3;border:1px solid #e5e7eb;border-radius:8px;color:#4b5563;display:flex;font-size:13px;gap:12px;padding:12px 16px}.info-icon{flex-shrink:0;font-size:18px}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.ai-generation-section{padding:20px}.ai-section-header{flex-direction:column;gap:12px}.ai-section-header h2{font-size:22px}.ai-actions{flex-direction:column}.ai-generate-btn,.ai-skip-btn{justify-content:center;width:100%}}.builder-link{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:block;font-size:14px;font-weight:600;margin:12px 0;padding:10px 16px;text-align:center;text-decoration:none;transition:all .3s}.builder-link:hover{box-shadow:0 4px 12px #667eea66;color:#fff;transform:translateY(-2px)}.datasource-video-type{background:#f0f4ff;border:1px solid #e0e7ff;border-radius:6px;color:#4b5563;font-size:13px;margin-bottom:8px;padding:8px 12px}.datasource-video-type strong{color:#374151}.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{gap:15px}.credits-badge{border-radius:25px;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}.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}.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;border-radius:8px;color:#c62828;padding:12px 20px}.warning-message-box{background-color:#fff3cd;border-left:4px solid #ffc107;border-radius:8px;color:#856404;margin-bottom:20px;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}.success-message{background-color:#d4edda;border-left:4px solid #28a745;border-radius:8px;color:#155724;padding:12px 20px}.clone-variation-btn{background:#3498db;border:none;border-radius:8px;box-shadow:0 4px 12px #3498db4d;color:#fff;cursor:pointer;font-size:1em;font-weight:600;padding:12px 32px;transition:all .3s ease}.clone-variation-btn:hover:not(:disabled){background:#2980b9;box-shadow:0 6px 20px #3498db80;transform:translateY(-2px)}.clone-variation-btn:active:not(:disabled){transform:translateY(0)}.clone-variation-btn:disabled{background:#95a5a6;box-shadow:none;cursor:not-allowed;opacity:.7}.delete-variation-btn{background:#ff4757;border:none;border-radius:8px;box-shadow:0 4px 12px #ff47574d;color:#fff;cursor:pointer;font-size:1em;font-weight:600;padding:12px 32px;transition:all .3s ease}.delete-variation-btn:hover{background:#ee5a6f;box-shadow:0 6px 20px #ff475780;transform:translateY(-2px)}.delete-variation-btn:active{transform:translateY(0)}.preview-variation-btn{background:#f39c12;border:none;border-radius:8px;box-shadow:0 3px 10px #f39c124d;color:#fff;cursor:pointer;display:inline-block;font-size:.85em;font-weight:600;padding:8px 18px;text-decoration:none;transition:all .3s ease}.preview-variation-btn:hover{background:#e67e22;box-shadow:0 5px 15px #f39c1280;color:#fff;transform:translateY(-2px)}.preview-variation-btn:active{transform:translateY(0)}.structures-section{border-bottom:2px solid #e9ecef;margin-bottom:30px;padding-bottom:20px}.structures-section h2{border-bottom:2px solid #f0f0f0;color:#333;margin-bottom:20px;padding-bottom:10px}.structures-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.structure-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border-radius:12px;cursor:pointer;padding:20px;transition:all .3s ease}.structure-card:hover:not(.structure-disabled){border-color:#667eea;box-shadow:0 6px 20px #667eea33;transform:translateY(-3px)}.structure-card.structure-disabled{cursor:not-allowed;opacity:.5}.structure-card-id{color:#667eea;font-size:1em;font-weight:700;margin-bottom:8px;word-break:break-all}.structure-card-description{color:#495057;font-size:.9em;line-height:1.4;margin-bottom:12px}.structure-card-status{align-items:center;display:flex;gap:8px}.structure-badge{border-radius:10px;font-size:.7em;font-weight:600;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.structure-badge.has-json{background:#d1e7dd;color:#0f5132}.structure-badge.no-json{background:#fff3cd;color:#856404}.structure-badge.disabled-badge{background:#f8d7da;color:#842029}.structure-create-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9em;font-weight:600;margin-top:12px;padding:10px 16px;transition:all .3s ease;width:100%}.structure-create-btn:hover:not(:disabled){box-shadow:0 4px 15px #667eea66;transform:translateY(-1px)}.structure-create-btn:disabled{background:#95a5a6;cursor:not-allowed;opacity:.7}.structures-empty{color:#999;font-size:.95em;padding:20px;text-align:center}.manual-fields-page-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.manual-fields-page-header{align-items:flex-start;color:#fff;display:flex;justify-content:space-between;margin-bottom:30px}.manual-fields-page-header h1{font-size:28px;margin:10px 0 0}.manual-fields-page-header .back-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;margin-bottom:10px;padding:8px 16px;transition:all .2s}.manual-fields-page-header .back-btn:hover{background:#ffffff4d}.manual-fields-page-content{margin:0 auto;max-width:1200px}.manual-fields-page-error,.manual-fields-page-loading{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;padding:40px;text-align:center}.error-message{background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;margin-bottom:20px;padding:12px}.success-message{animation:slideIn .3s ease;background:#efe;border:1px solid #cfc;border-radius:6px;color:#3c3;margin-bottom:20px;padding:12px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.no-manual-fields{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;padding:60px 40px;text-align:center}.no-manual-fields h2{color:#667eea;margin-bottom:16px}.no-manual-fields .info-text{color:#666;font-size:14px;margin-top:12px}.summary-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:24px;text-align:center;transition:transform .2s}.stat-card:hover{box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.stat-number{color:#667eea;display:block;font-size:36px;font-weight:700;margin-bottom:8px}.stat-label{color:#666;display:block;font-size:14px;letter-spacing:.5px;text-transform:uppercase}.manual-upload-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:30px;padding:30px}.manual-upload-section h2{color:#667eea;font-size:22px;margin-bottom:8px}.section-description{color:#666;font-size:14px;margin-bottom:20px}.manual-upload-list{display:flex;flex-wrap:wrap;gap:12px}.manual-upload-item{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;font-weight:500;gap:10px;padding:12px 20px}.manual-upload-item .scene-name{font-size:15px}.manual-upload-item .repeat-badge{background:#fff3;border-radius:4px;font-size:13px;padding:4px 8px}.manual-fields-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:30px}.manual-fields-section h2{color:#667eea;font-size:22px;margin-bottom:8px}.scene-manual-fields{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:24px;padding:24px}.scene-manual-fields:last-child{margin-bottom:0}.scene-header{align-items:center;border-bottom:2px solid #667eea;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.scene-header h3{color:#333;font-size:20px;margin:0}.field-count{background:#667eea;border-radius:20px;color:#fff;font-size:13px;font-weight:500;padding:6px 12px}.fields-container{display:flex;flex-direction:column;gap:20px;margin-bottom:20px}.field-link-group{background:#fff;border:2px solid #667eea;border-radius:8px;padding:20px}.link-group-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;gap:10px;margin-bottom:16px;padding-bottom:12px}.link-icon{font-size:20px}.link-name{color:#667eea;font-size:16px;font-weight:600}.linked-count{color:#666;font-size:13px;margin-left:auto}.linked-fields-list{border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px}.linked-fields-label{color:#666;font-size:13px;font-weight:500;margin-bottom:4px;width:100%}.linked-field-path{background:#f0f0f0;border-radius:4px;color:#555;font-family:monospace;font-size:12px;padding:4px 10px}.field-standalone{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px}.field-group{display:flex;flex-direction:column;gap:8px}.field-label{color:#333;font-size:14px;font-weight:500}.field-input{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:12px;resize:vertical;transition:border-color .2s;width:100%}.field-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.scene-actions{border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;padding-top:12px}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:10px 24px;transition:all .2s}.save-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6}.header-right{align-items:center;display:flex;gap:12px}.credits-badge{border-radius:20px;font-weight:500}.credits-badge,.logout-btn{background:#fff3;color:#fff;font-size:14px;padding:8px 16px}.logout-btn{border:1px solid #ffffff4d;border-radius:6px;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#ffffff4d}.json-viewer-section{margin-bottom:20px}.toggle-json-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.toggle-json-btn:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.json-viewer-container{background:#1e1e1e;border:1px solid #333;border-radius:8px;margin-top:12px;max-height:500px;overflow:auto;padding:20px}.json-viewer-hint{align-items:center;background:#667eea1a;border:1px solid #667eea4d;border-radius:6px;color:#667eea;display:flex;font-size:13px;gap:8px;margin-bottom:16px;padding:10px 12px}.hint-icon{font-size:16px}.json-viewer-content{color:#d4d4d4;font-family:Courier New,Courier,monospace;font-size:13px;line-height:1.6}.json-key{color:#9cdcfe;cursor:default}.json-key.manual-field-key{color:#4ec9b0;cursor:pointer;font-weight:600;text-decoration:underline;-webkit-text-decoration-style:dotted;text-decoration-style:dotted;transition:all .2s}.json-key.manual-field-key:hover{color:#6fdfbe;-webkit-text-decoration-style:solid;text-decoration-style:solid;text-shadow:0 0 8px #4ec9b080}.json-key.highlighted-field{animation:pulse 1s ease;background:#ffd7004d;border-radius:3px;padding:2px 4px}@keyframes pulse{0%,to{background:#ffd7004d}50%{background:#ffd70080}}.json-string{color:#ce9178}.json-number{color:#b5cea8}.json-boolean,.json-null{color:#569cd6}.json-bracket{color:#d4d4d4;font-weight:700}.json-colon{margin:0 4px}.json-colon,.json-comma{color:#d4d4d4}.json-array,.json-object{display:block}.json-array-items,.json-object-properties{padding-left:20px}.json-array-item,.json-property{display:block;margin:2px 0}.highlighted-field-container{animation:highlightBorder 1s ease;border:2px solid gold!important;box-shadow:0 0 16px #ffd70066}@keyframes highlightBorder{0%,to{border-color:gold}50%{border-color:#ffed4e}}.json-viewer-modes{border-bottom:2px solid #333;display:flex;gap:8px;margin-bottom:16px;padding-bottom:8px}.mode-btn{align-items:center;background:#667eea1a;border:1px solid #667eea4d;border-radius:6px 6px 0 0;color:#9cdcfe;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.mode-btn:hover{background:#667eea33;border-color:#667eea80}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.pending-badge{animation:fadeIn .3s ease;color:#4ec9b0;display:inline-block;font-size:10px;margin-left:4px}@keyframes fadeIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.pending-manual-field{background:#4ec9b033;border-radius:3px;padding:2px 4px}.clickable-field{cursor:pointer!important}.json-actions{border-top:1px solid #333;display:flex;gap:12px;justify-content:flex-end;margin-top:16px;padding-top:16px}.discard-changes-btn,.save-changes-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:10px 20px;transition:all .2s}.save-changes-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.save-changes-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.save-changes-btn:disabled{cursor:not-allowed;opacity:.6}.discard-changes-btn{background:#f443361a;border:1px solid #f443364d;color:#f44336}.discard-changes-btn:hover{background:#f4433633;border-color:#f4433680}.ai-chat-container{background:#252525;border-radius:8px;display:flex;flex-direction:column;height:500px;overflow:hidden}.ai-chat-messages{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:20px}.ai-chat-welcome{background:#667eea1a;border:1px solid #667eea4d;border-radius:8px;color:#d4d4d4;padding:20px}.ai-chat-welcome h4{color:#667eea;font-size:18px;margin:0 0 12px}.ai-chat-welcome p{color:#9cdcfe;margin:0 0 12px}.ai-chat-welcome ul{color:#d4d4d4;margin:0;padding-left:20px}.ai-chat-welcome li{color:#ce9178;font-style:italic;margin:8px 0}.ai-chat-message{animation:slideInMessage .3s ease;border-radius:8px;display:flex;gap:12px;padding:12px}@keyframes slideInMessage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ai-chat-message.user{align-self:flex-end;background:#667eea1a;border:1px solid #667eea4d;max-width:80%}.ai-chat-message.assistant{align-self:flex-start;background:#4ec9b01a;border:1px solid #4ec9b04d;max-width:80%}.ai-chat-message.error{align-self:flex-start;background:#f443361a;border:1px solid #f443364d;max-width:80%}.message-icon{flex-shrink:0;font-size:20px}.message-content{word-wrap:break-word;color:#d4d4d4;line-height:1.6}.typing-indicator{display:flex;gap:4px;padding:8px 0}.typing-indicator span{animation:typing 1.4s infinite;background:#4ec9b0;border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.7;transform:translateY(0)}30%{opacity:1;transform:translateY(-10px)}}.ai-chat-input-section{background:#1e1e1e;border-top:1px solid #333;display:flex;gap:12px;padding:16px}.ai-chat-input{background:#252525;border:1px solid #444;border-radius:6px;color:#d4d4d4;flex:1 1;font-family:inherit;font-size:14px;padding:12px;resize:vertical;transition:border-color .2s}.ai-chat-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.ai-chat-input:disabled{cursor:not-allowed;opacity:.6}.ai-chat-send-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s;white-space:nowrap}.ai-chat-send-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.ai-chat-send-btn:disabled{cursor:not-allowed;opacity:.6}.diff-viewer{color:#d4d4d4;padding:16px}.diff-section{border-radius:8px;margin-bottom:24px;padding:16px}.diff-section h4{font-size:16px;margin:0 0 12px}.diff-section.added{background:#4caf501a;border:1px solid #4caf504d}.diff-section.added h4{color:#4caf50}.diff-section.modified{background:#ff98001a;border:1px solid #ff98004d}.diff-section.modified h4{color:#ff9800}.diff-section.removed{background:#f443361a;border:1px solid #f443364d}.diff-section.removed h4{color:#f44336}.diff-section ul{margin:0;padding-left:20px}.diff-section li{margin:6px 0}.diff-section code{background:#0000004d;border-radius:3px;font-family:Courier New,Courier,monospace;font-size:12px;padding:2px 6px}.diff-item{background:#0003;border-radius:6px;margin:12px 0;padding:12px}.diff-path{color:#9cdcfe;font-weight:600;margin-bottom:8px}.diff-values{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-top:8px}.diff-new,.diff-old{border-radius:4px;padding:8px}.diff-old{background:#f443361a;border-left:3px solid #f44336}.diff-new{background:#4caf501a;border-left:3px solid #4caf50}.diff-label{display:block;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;opacity:.7;text-transform:uppercase}.no-changes{color:#888;font-style:italic;padding:40px;text-align:center}.tab-navigation{background:#ffffff1a;border-radius:10px;display:flex;gap:4px;margin:0 auto 20px;max-width:1200px;padding:4px}.tab-btn{background:#0000;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s}.tab-btn:hover{background:#ffffff1a;color:#fff}.tab-btn.active{background:#fff;box-shadow:0 2px 8px #00000026;color:#667eea}.media-tab-content{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:30px}.media-upload-zone{background:#fafafa;border:3px dashed #ccc;border-radius:12px;cursor:pointer;margin-bottom:30px;padding:40px;text-align:center;transition:all .3s}.media-upload-zone:focus,.media-upload-zone:hover{background:#f5f5ff;border-color:#667eea;outline:none}.media-upload-zone.drag-over{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea;transform:scale(1.01)}.upload-icon{color:#667eea;font-size:48px;font-weight:700;margin-bottom:16px}.media-upload-zone h3{color:#333;font-size:20px;margin:0 0 8px}.media-upload-zone p{color:#666;font-size:14px;margin:0 0 8px}.upload-hint{color:#999!important;font-size:13px!important}.select-file-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;margin-top:16px;padding:12px 28px;transition:all .2s}.select-file-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.select-file-btn:disabled{cursor:not-allowed;opacity:.6}.media-list-section h2{border-bottom:2px solid #667eea;color:#333;font-size:22px;margin:0 0 20px;padding-bottom:12px}.media-loading,.no-media{color:#666;padding:40px;text-align:center}.no-media p{margin:8px 0}.media-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.media-card{background:#fafafa;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;transition:all .2s}.media-card:hover{border-color:#667eea;box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.media-preview{align-items:center;background:#1e1e1e;display:flex;height:180px;justify-content:center;overflow:hidden;width:100%}.media-preview img{object-fit:contain}.media-preview img,.media-preview video{max-height:100%;max-width:100%}.audio-preview{align-items:center;display:flex;flex-direction:column;gap:12px;padding:20px;width:100%}.audio-icon{color:#667eea;font-size:40px}.audio-preview audio{max-width:250px;width:100%}.media-info{padding:16px}.media-filename{color:#333;font-size:14px;font-weight:600;margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-meta{display:flex;gap:12px;margin-bottom:12px}.media-type{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:11px;font-weight:500;padding:3px 10px;text-transform:uppercase}.media-size{align-items:center;color:#888;display:flex;font-size:12px}.media-url-section{display:flex;gap:8px;margin-bottom:12px}.media-url-input{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#333;flex:1 1;font-family:monospace;font-size:11px;min-width:0;padding:8px 10px}.media-url-input:focus{border-color:#667eea;outline:none}.copy-url-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:8px 12px;transition:all .2s;white-space:nowrap}.copy-url-btn:hover{background:#5a6fd6}.copy-url-btn.copied{background:#4caf50}.delete-media-btn{background:#0000;border:1px solid #f44336;border-radius:6px;color:#f44336;cursor:pointer;font-size:13px;font-weight:500;padding:10px;transition:all .2s;width:100%}.delete-media-btn:hover{background:#f44336;color:#fff}@media (max-width:768px){.manual-fields-page-container{padding:12px}.manual-fields-page-header{flex-direction:column;gap:16px}.manual-fields-page-header h1{font-size:22px}.summary-stats{grid-template-columns:1fr}.scene-header{align-items:flex-start;flex-direction:column;gap:12px}.field-link-group,.field-standalone{padding:16px}.json-viewer-container{max-height:300px;padding:12px}.json-viewer-content{font-size:11px}.tab-navigation{flex-direction:column}.media-tab-content{padding:16px}.media-upload-zone{padding:24px}.media-grid{grid-template-columns:1fr}.media-url-section{flex-direction:column}.copy-url-btn{width:100%}}.loading-screen{align-items:center;color:#fff;display:flex;font-size:24px;justify-content:center;min-height:100vh}
/*# sourceMappingURL=main.fa37fac9.css.map*/