*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;color:#333;background:#f5f5f5}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:300px;background:#2c3e50;color:#fff;display:flex;flex-direction:column;transition:margin-left .3s ease}.sidebar.collapsed{margin-left:-280px}.sidebar-header{display:flex;align-items:center;padding:1rem;background:#34495e;border-bottom:1px solid #4a5f7a}.sidebar-header h2{flex:1;font-size:16px;font-weight:600}.sidebar-toggle{background:none;border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s}.sidebar-toggle:hover{background:#ffffff1a}.sidebar-toggle.new-mode{background:#3498db}.sidebar-toggle.new-mode:hover{background:#2980b9}.komposition-list{flex:1;overflow-y:auto;padding:.5rem}.komposition-item{display:flex;align-items:center;padding:.75rem;margin-bottom:.5rem;background:#ffffff1a;border-radius:8px;cursor:pointer;transition:background .2s}.komposition-item:hover{background:#fff3}.komposition-item.active{background:#3498db}.komposition-thumbnail{width:40px;height:40px;border-radius:6px;background:#7f8c8d;margin-right:.75rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff}.komposition-thumbnail img{width:100%;height:100%;object-fit:cover;border-radius:6px}.komposition-name{font-weight:500;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.komposition-status{font-size:11px;opacity:.8;text-transform:capitalize}.status-draft{color:#f39c12}.status-processing{color:#3498db}.status-complete{color:#27ae60}.status-error{color:#e74c3c}.main-content{flex:1;display:flex;flex-direction:column;background:#fff}.main-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e0e0e0}.header-left{display:flex;align-items:center;gap:1rem}.hamburger{background:none;border:none;color:#2c3e50;font-size:18px;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.hamburger:hover{background:#ecf0f1}.main-header h1{font-size:20px;font-weight:600;color:#2c3e50;margin:0}.user-info{font-size:12px;color:#7f8c8d;font-family:monospace}.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.llm-selector{padding:1rem 1.5rem;text-align:center;background:#fff;border-bottom:1px solid #e0e0e0}.llm-toggle{display:inline-flex;background:#f0f0f0;border-radius:25px;padding:3px;box-shadow:0 2px 4px #0000001a}.llm-option{padding:8px 16px;border-radius:20px;cursor:pointer;transition:all .2s;border:none;background:none;font-size:13px;font-weight:500}.llm-option.active{background:#3498db;color:#fff;box-shadow:0 2px 8px #3498db4d}.llm-option:not(.active){color:#666}.llm-option:hover:not(.active){background:#e0e0e0;color:#333}.main-panels{flex:1;display:flex;overflow:hidden}.chat-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:300px}.resize-handle{width:8px;background:#e0e0e0;cursor:col-resize;position:relative;flex-shrink:0;transition:background .2s}.resize-handle:hover{background:#3498db}.resize-handle:after{content:"⋮⋮";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#666;font-size:12px}.komposition-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:300px;background:#fff;border-left:1px solid #e0e0e0}.komposition-header{padding:1rem 1.5rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.komposition-header h3{margin:0;font-size:16px;color:#2c3e50}.komposition-actions{display:flex;gap:.5rem}.komposition-actions button{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s}#createVideo{background:#28a745;color:#fff}#createVideo:hover:not(:disabled){background:#218838}#createVideo:disabled{background:#6c757d;cursor:not-allowed}#stopVideo{background:#dc3545;color:#fff}#stopVideo:hover{background:#c82333}#saveKomposition{background:#6c757d;color:#fff}#saveKomposition:hover:not(:disabled){background:#5a6268}#saveKomposition:disabled{background:#adb5bd;cursor:not-allowed}.komposition-content{flex:1;padding:0;overflow:hidden;font-family:SF Mono,Monaco,monospace;font-size:13px;line-height:1.5;background:#f8f9fa;display:flex;flex-direction:column;height:100%}.no-komposition{text-align:center;color:#6c757d;font-style:italic;padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;flex:1;display:flex;align-items:center;justify-content:center}.komposition-json{background:#fff;padding:1rem;border-radius:6px;border:1px solid #e0e0e0;white-space:pre-wrap;word-break:break-word}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:1rem 1.5rem}.welcome-message{text-align:center;padding:2rem;color:#7f8c8d}.welcome-message h3{margin-bottom:.5rem;color:#2c3e50}.message{margin-bottom:1rem;display:flex;flex-direction:column}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.message-content{max-width:80%;padding:.75rem 1rem;border-radius:12px;white-space:pre-wrap}.message.user .message-content{background:#3498db;color:#fff;border-bottom-right-radius:4px}.message.assistant .message-content{background:#ecf0f1;color:#2c3e50;border-bottom-left-radius:4px}.message.system .message-content{background:#fff3e0;color:#e65100;font-style:italic;border-radius:6px;text-align:center;font-size:13px}.message.system.ephemeral .message-content{background:#f5f5f5;color:#757575;font-size:12px;opacity:.7}.message.system.ephemeral .message-time{opacity:.5}.message-time{font-size:11px;color:#7f8c8d;margin-top:.25rem}.load-older{margin:1rem 1.5rem;padding:.5rem 1rem;background:#ecf0f1;border:none;border-radius:6px;cursor:pointer;font-size:13px;color:#2c3e50}.load-older:hover{background:#d5dbdb}.chat-input-container{padding:1rem 1.5rem;background:#fff;border-top:1px solid #e0e0e0}.input-group{display:flex;gap:.5rem}#chatInput{flex:1;padding:.75rem 1rem;border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none}#chatInput:focus{border-color:#3498db}#chatInput:disabled{background:#f8f9fa;color:#6c757d}#sendButton{padding:.75rem 1.5rem;background:#3498db;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}#sendButton:hover:not(:disabled){background:#2980b9}#sendButton:disabled{background:#bdc3c7;cursor:not-allowed}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:12px;width:90%;max-width:400px}.modal-content h3{margin-bottom:1.5rem;color:#2c3e50}.modal-content input,.modal-content select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;margin-bottom:1rem;font-size:14px}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.modal-actions button{padding:.5rem 1.5rem;border-radius:6px;cursor:pointer;font-size:14px}#cancelModal{background:#ecf0f1;border:1px solid #ddd;color:#2c3e50}#cancelModal:hover{background:#d5dbdb}button[type=submit]{background:#3498db;border:none;color:#fff}button[type=submit]:hover{background:#2980b9}.loading{text-align:center;padding:2rem;color:#ffffffb3}.komposition-item{display:flex;align-items:center;padding:.75rem;border-bottom:1px solid rgba(255,255,255,.1);transition:all .2s ease;position:relative}.komposition-item:hover{background:#ffffff0d}.komposition-item.active{background:#3498db4d;border-left:3px solid #3498db}.komposition-content{flex:1;display:flex;align-items:center;cursor:pointer}.komposition-thumbnail{width:40px;height:40px;background:#3498db;color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;margin-right:.75rem;flex-shrink:0}.komposition-thumbnail img{width:100%;height:100%;object-fit:cover;border-radius:8px}.komposition-info{flex:1;min-width:0}.komposition-name{font-weight:600;font-size:14px;color:#ecf0f1;text-shadow:1px 1px 3px rgba(0,0,0,.8);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.komposition-status{font-size:12px;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.komposition-status.status-active{color:#2ecc71}.komposition-status.status-processing{color:#f39c12}.komposition-status.status-error{color:#e74c3c}.delete-komposition{opacity:0;background:none;border:none;color:#e74c3c;font-size:16px;width:32px;height:32px;border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin-left:.5rem}.komposition-item:hover .delete-komposition{opacity:1}.delete-komposition:hover{background:#e74c3c1a;transform:scale(1.1)}.danger{background:#e74c3c!important;color:#fff!important}.danger:hover{background:#c0392b!important}.panel-tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #dee2e6;margin:0}.tab-btn{flex:1;background:none;border:none;padding:12px 16px;cursor:pointer;font-size:14px;color:#6c757d;border-bottom:3px solid transparent;transition:all .2s ease}.tab-btn:hover{background:#e9ecef;color:#495057}.tab-btn.active{color:#007bff;border-bottom-color:#007bff;background:#fff}.tab-content{display:none;height:calc(100% - 50px);overflow-y:auto}.tab-content.active{display:block}.multimedia-uploader{padding:20px;height:100%}.upload-zone{border:2px dashed #ccc;border-radius:8px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#f9f9f9;margin-bottom:20px}.upload-zone:hover,.upload-zone.drag-over{border-color:#007bff;background:#f0f8ff}.upload-icon{font-size:48px;margin-bottom:16px}.upload-text h3{margin:0 0 8px;color:#333;font-size:18px}.upload-text p{margin:4px 0;color:#666}.upload-info{font-size:.9em;margin-top:12px!important}.upload-progress-section{border:1px solid #ddd;border-radius:8px;background:#fff;padding:16px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.progress-header h4{margin:0;color:#333}.clear-btn{padding:4px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:.9em}.clear-btn:hover{background:#f5f5f5}.upload-item{margin-bottom:12px;padding:12px;border-radius:6px;border:1px solid #eee}.upload-item.success{background:#f0f8f0;border-color:#c3e6c3}.upload-item.error{background:#fdf0f0;border-color:#f5c6c6}.upload-item-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.file-name{font-weight:500;color:#333}.upload-status{font-size:.9em;color:#666}.progress-bar{width:100%;height:8px;background:#eee;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease}.error-message{margin-top:8px;color:#d32f2f;font-size:.9em}.file-id{margin-top:8px;color:#666;font-size:.8em;font-family:monospace}.media-library{height:100%;background:#fff;display:flex;flex-direction:column}.library-header{padding:20px;border-bottom:1px solid #eee;flex-shrink:0}.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.header-row:last-child{margin-bottom:0}.library-header h3{margin:0;color:#333}.refresh-btn{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:.9em}.refresh-btn:hover{background:#f5f5f5}.selection-controls{display:flex;gap:8px;align-items:center;font-size:.9em}.select-btn{padding:4px 8px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:.8em}.select-btn:hover{background:#f5f5f5}.library-stats{padding:12px 20px;background:#f9f9f9;border-bottom:1px solid #eee;display:flex;justify-content:space-between;font-size:.9em;color:#666;flex-shrink:0}.files-container{flex:1;overflow-y:auto;padding:20px}.file-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #eee;border-radius:6px;margin-bottom:8px;cursor:pointer;transition:all .2s ease}.file-item:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff26}.file-item.selected{border-color:#007bff;background:#f0f8ff}.file-checkbox{margin:0}.file-icon{font-size:24px;flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{font-weight:500;color:#333;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{display:flex;gap:8px;font-size:.8em;color:#666;margin-bottom:4px}.file-id{font-size:.7em;color:#999;font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delete-btn{background:none;border:none;color:#999;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease;flex-shrink:0}.delete-btn:hover{color:#d32f2f;background:#ffebee;transform:scale(1.1)}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h4{margin:0 0 8px;color:#333}.empty-state p{margin:0}.loading{padding:40px;text-align:center;color:#666;font-size:16px}.error-message{padding:40px;text-align:center;color:#d32f2f}.retry-btn{margin-left:12px;padding:4px 12px;border:1px solid #d32f2f;border-radius:4px;background:#fff;color:#d32f2f;cursor:pointer}.retry-btn:hover{background:#d32f2f;color:#fff}@media (max-width: 768px){.sidebar{position:absolute;height:100%;z-index:100;box-shadow:2px 0 10px #0000001a}.sidebar.collapsed{margin-left:-300px}.main-content{margin-left:0}.panel-tabs{flex-direction:column}.tab-btn{border-bottom:none;border-right:3px solid transparent}.tab-btn.active{border-bottom:none;border-right-color:#007bff}}
