:root{--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #a5b4fc;--color-secondary: #64748b;--color-secondary-hover: #475569;--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-success: #22c55e;--color-warning: #f59e0b;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-overlay: rgba(0, 0, 0, .7);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-color-light: #475569;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", Monaco, "Courier New", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-sans);font-size:16px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased}#root{height:100%}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--border-color-light)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:.25rem .5rem;font-size:.75rem}.btn-md{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.input,.textarea,.select{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:border-color .15s ease}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--color-primary)}.textarea{min-height:100px;resize:vertical}.input-error .input,.input-error .textarea,.input-error .select{border-color:var(--color-danger)}.input-error-message{font-size:.75rem;color:var(--color-danger)}.input-hint{font-size:.75rem;color:var(--text-muted)}.tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-xs);background:var(--bg-secondary);border-radius:var(--radius-md)}.tab{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .15s ease}.tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab-active{background:var(--color-primary);color:#fff}.tab-panel{padding:var(--spacing-md)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:90vh;overflow:auto}.modal-sm{width:400px}.modal-md{width:600px}.modal-lg{width:900px}.modal-full{width:95vw;height:95vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer}.modal-body{padding:var(--spacing-md)}.modal-body-content,.create-video-form,.ai-generation-form,.youtube-download-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-color)}.reference-image-upload,.file-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-sm)}.file-input{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer}.file-input:focus{outline:none;border-color:var(--color-primary)}.reference-image-info{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-secondary)}.cookies-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.cookies-toggle{background:none;border:none;color:var(--text-secondary);padding:var(--spacing-sm) 0;cursor:pointer;font-size:.875rem;text-align:left;transition:color .15s ease}.cookies-toggle:hover{color:var(--text-primary)}.cookies-toggle-text{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:500}.cookies-content{animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.info-modal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.info-modal-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.info-modal-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.info-modal-value{font-size:.875rem;color:var(--text-primary);word-break:break-all}.app-layout{display:flex;flex-direction:column;height:100%}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.logo{font-size:1.25rem;font-weight:700;color:var(--color-primary);text-decoration:none}.header-title{color:var(--text-secondary);font-size:.875rem}.header-nav{display:flex;gap:var(--spacing-md)}.nav-link{color:var(--text-secondary);font-size:.875rem;transition:color .15s ease}.nav-link:hover{color:var(--text-primary);text-decoration:none}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.user-menu{position:relative}.user-menu-trigger{width:32px;height:32px;border-radius:var(--radius-full);border:none;cursor:pointer;overflow:hidden;background:var(--bg-tertiary)}.user-avatar{width:100%;height:100%;object-fit:cover}.user-avatar-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-weight:600;color:var(--text-primary)}.user-menu-dropdown{position:absolute;right:0;top:100%;margin-top:var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-lg);z-index:100}.user-menu-info{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.user-menu-dropdown hr{border:none;border-top:1px solid var(--border-color)}.menu-item{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;text-align:left;color:var(--text-secondary);cursor:pointer}.menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.app-main{flex:1;overflow:hidden}.resizable-panels{display:flex;height:100%}.resizable-panels.is-dragging{-webkit-user-select:none;user-select:none}.panel{height:100%;overflow:auto}.panel-left{flex-shrink:0}.panel-right{flex:1;min-width:0}.panel-divider{width:8px;background:var(--bg-secondary);cursor:col-resize;display:flex;align-items:center;justify-content:center}.panel-divider:hover{background:var(--border-color)}.divider-handle{width:2px;height:40px;background:var(--border-color-light);border-radius:var(--radius-full)}.chat-history{display:flex;flex-direction:column;height:100%}.chat-messages-container{flex:1;overflow-y:auto;padding:var(--spacing-md)}.chat-message{margin-bottom:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;flex-direction:column}.chat-message.role-user{align-self:flex-start;margin-right:20%}.chat-message.role-assistant{align-self:flex-end;margin-left:20%}.chat-message-user{background:var(--bg-tertiary);margin-left:var(--spacing-xl)}.chat-message-assistant{background:var(--bg-secondary);margin-right:var(--spacing-xl);border:1px solid var(--border-color)}.chat-message-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);font-size:.75rem;color:var(--text-muted)}.chat-message-role{font-weight:600;color:var(--text-secondary)}.chat-message-model{background:var(--color-primary);color:#fff;padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.625rem}.chat-message-content{white-space:pre-wrap;word-break:break-word}.chat-message-image{margin-top:8px}.chat-message-image img{max-width:100%;max-height:400px;border-radius:8px;display:block}.chat-message-image-info{font-size:.75rem;color:var(--text-secondary);margin-top:4px}.dismiss-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:0;margin-left:auto;opacity:0;transition:opacity .2s}.dismiss-btn:hover{color:var(--color-danger)}.chat-message:hover .dismiss-btn{opacity:1}.chat-message-streaming .chat-cursor{display:inline-block;width:8px;height:1em;background:var(--color-primary);animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.chat-input-form{padding:var(--spacing-md);border-top:1px solid var(--border-color)}.chat-input-container{display:flex;gap:var(--spacing-sm)}.chat-input-textarea{flex:1;padding:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);resize:none}.chat-input-textarea:focus{outline:none;border-color:var(--color-primary)}.chat-input-hint{margin-top:var(--spacing-xs);font-size:.75rem;color:var(--text-muted)}.chat-empty{text-align:center;padding:var(--spacing-xl);color:var(--text-muted)}.chat-scroll-bottom{position:absolute;bottom:100px;left:50%;transform:translate(-50%);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer}.chat-load-more{text-align:center;padding:var(--spacing-sm)}.media-player{display:flex;flex-direction:column;align-items:center}.media-player-video,.media-player-image{max-width:100%;max-height:70vh;border-radius:var(--radius-md)}.media-player-audio-container{width:100%;padding:var(--spacing-lg)}.audio-visualization{display:flex;align-items:center;justify-content:center;height:200px;margin-bottom:var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:3rem}.media-player-audio{width:100%}.media-player-loading,.media-player-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl)}.media-player-controls{margin-top:var(--spacing-md)}.media-player-hint{font-size:.75rem;color:var(--text-muted)}.file-uploader{padding:var(--spacing-md)}.upload-zone{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;transition:all .15s ease;cursor:pointer}.upload-zone.drag-over{border-color:var(--color-primary);background:#6366f11a}.upload-input{display:none}.upload-label{cursor:pointer}.upload-icon{font-size:2rem;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.upload-text{color:var(--text-secondary)}.upload-link{color:var(--color-primary)}.upload-hint{font-size:.75rem;color:var(--text-muted);margin-top:var(--spacing-sm)}.upload-list{margin-top:var(--spacing-md)}.upload-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.upload-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs)}.upload-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress{width:100px;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.upload-progress-bar{height:100%;background:var(--color-primary);transition:width .15s ease}.upload-status-icon{color:var(--color-success)}.upload-error{color:var(--color-danger);font-size:.75rem}.media-library{height:100%;display:flex;flex-direction:column}.library-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.library-controls{display:flex;gap:var(--spacing-sm)}.library-stats{display:flex;gap:var(--spacing-md);font-size:.875rem;color:var(--text-secondary)}.library-selection-controls{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);align-items:center}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md);padding:var(--spacing-md);overflow-y:auto;flex:1}.library-item{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all .15s ease}.library-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.library-item.selected{ring:2px solid var(--color-primary)}.library-item-preview{aspect-ratio:1;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.library-item-preview img{width:100%;height:100%;object-fit:cover}.library-item-icon{font-size:2rem;color:var(--text-muted)}.library-item-info{padding:var(--spacing-sm)}.library-item-name{display:block;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.library-item-meta{font-size:.75rem;color:var(--text-muted)}.library-loading,.library-error,.library-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted)}.loading-spinner,.spinner{width:24px;height:24px;border:2px solid var(--bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--spacing-md)}.landing{min-height:100%;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-xl)}.landing-logo a{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.landing-hero{padding:var(--spacing-xl);text-align:center}.carousel{position:relative;height:400px;border-radius:var(--radius-lg);overflow:hidden}.carousel-slide{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;transition:opacity .5s ease}.carousel-content{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-xl);background:linear-gradient(transparent,#000c)}.carousel-content h1{margin-bottom:var(--spacing-sm)}.carousel-controls{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);display:flex;gap:var(--spacing-sm);align-items:center}.carousel-prev,.carousel-next{background:var(--bg-overlay);border:none;color:#fff;padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-sm)}.carousel-dots{display:flex;gap:var(--spacing-xs)}.carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--text-muted);cursor:pointer}.carousel-dot.active{background:var(--color-primary)}.hero-cta{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-xl)}.landing-features{padding:var(--spacing-xl)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.feature-card{background:var(--bg-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center}.feature-icon{font-size:2rem;margin-bottom:var(--spacing-md);color:var(--color-primary)}.landing-footer{padding:var(--spacing-xl);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.footer-content{display:flex;justify-content:space-between;max-width:1200px;margin:0 auto}.footer-links{display:flex;gap:var(--spacing-md)}.footer-bottom{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color);font-size:.75rem;color:var(--text-muted)}.komposition-app{display:flex;height:100%}.app-sidebar{width:250px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:width .2s ease}.app-sidebar.collapsed{width:48px}.sidebar-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.sidebar-toggle{width:32px;height:32px;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer}.sidebar-actions{padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.sidebar-item:hover{background:var(--bg-tertiary)}.sidebar-item.active{background:var(--color-primary)}.item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem}.item-status{font-size:.625rem;padding:.125rem .375rem;border-radius:var(--radius-full);text-transform:uppercase}.status-draft{background:var(--bg-tertiary)}.status-processing{background:var(--color-warning);color:#000}.status-complete{background:var(--color-success);color:#000}.status-error{background:var(--color-danger)}.item-delete{background:none;border:none;color:var(--color-danger);font-size:.75rem;cursor:pointer;opacity:0}.sidebar-item:hover .item-delete{opacity:1}.app-content{flex:1;overflow:hidden}.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted)}.chat-panel,.editor-panel{height:100%;display:flex;flex-direction:column}.editor-toolbar{display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.komposition-editor{flex:1;width:100%;padding:var(--spacing-md);background:var(--bg-primary);border:none;color:var(--text-primary);font-family:var(--font-mono);font-size:.875rem;resize:none}.komposition-editor:focus{outline:none}.job-panel{padding:var(--spacing-md);margin:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.job-progress{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--spacing-sm)}.job-error{color:var(--color-danger);margin-top:var(--spacing-sm)}.admin-dashboard{padding:var(--spacing-lg);max-width:1200px;margin:0 auto}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-lg)}.metric-card{background:var(--bg-card);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center}.metric-value{font-size:2rem;font-weight:700;color:var(--color-primary)}.quick-links{margin-top:var(--spacing-xl)}.links-grid{display:flex;gap:var(--spacing-md);flex-wrap:wrap;margin-top:var(--spacing-md)}.links-grid a{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--spacing-sm);text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{background:var(--bg-secondary);font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--text-muted)}.invitation-form{background:var(--bg-secondary);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.form-row{display:flex;gap:var(--spacing-md);align-items:flex-end}.settings-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.setting-item{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.setting-item input[type=checkbox]{width:18px;height:18px}.enrollment-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.enrollment-container{max-width:500px;width:100%}.invitation-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden}.invitation-header{background:var(--color-primary);padding:var(--spacing-lg);text-align:center}.invitation-body{padding:var(--spacing-lg)}.invitation-field{margin-bottom:var(--spacing-md)}.invitation-field label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:var(--spacing-xs)}.invitation-role{font-size:1.25rem;font-weight:600;color:var(--color-primary)}.invitation-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--border-color)}.invitation-error,.invitation-success{padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center;margin:var(--spacing-md)}.invitation-error{background:#ef44441a;color:var(--color-danger)}.invitation-success{background:#22c55e1a;color:var(--color-success)}.llm-response-details{margin-top:var(--spacing-sm);font-size:.75rem}.llm-response-details summary{cursor:pointer;color:var(--text-muted)}.llm-response-content{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-primary);border-radius:var(--radius-sm)}.llm-response-stats{display:flex;gap:var(--spacing-md);color:var(--text-muted)}.llm-tool-calls{margin-top:var(--spacing-sm)}.tool-call{margin-top:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.tool-call-name{font-weight:600;color:var(--color-primary)}.tool-call-input,.tool-call-output{font-family:var(--font-mono);font-size:.625rem;overflow-x:auto;margin-top:var(--spacing-xs)}.multimedia-app{height:100%}.content-panel{height:100%;display:flex;flex-direction:column}.ai-images-panel,.video-panel,.youtube-panel{padding:var(--spacing-md)}.reference-image-section{margin-bottom:var(--spacing-lg)}.reference-preview{display:flex;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.reference-preview img{width:100px;height:100px;object-fit:cover;border-radius:var(--radius-md)}.staging-section{margin-top:var(--spacing-lg)}.staging-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-sm)}.staging-item{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden}.staging-item img{width:100%;aspect-ratio:1;object-fit:cover;cursor:pointer}.staging-item-info{padding:var(--spacing-sm)}.tasks-section{margin-top:var(--spacing-lg)}.task-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs)}.task-type{font-weight:500}.task-status{font-size:.75rem;padding:.125rem .5rem;border-radius:var(--radius-full);background:var(--bg-tertiary)}.task-running .task-status{background:var(--color-warning);color:#000}.youtube-form{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.youtube-form .input-group{flex:1}.youtube-cookies{margin-top:var(--spacing-lg)}.youtube-cookies textarea{width:100%;margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:.75rem}.login-prompt,.access-denied{display:flex;align-items:center;justify-content:center;height:100%}.login-prompt-content,.access-denied-content{text-align:center;max-width:400px}.login-prompt-content h1,.access-denied-content h1{margin-bottom:var(--spacing-md)}.login-prompt-content p,.access-denied-content p{margin-bottom:var(--spacing-lg);color:var(--text-secondary)}.error-message{padding:var(--spacing-md);background:#ef44441a;border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger)}.app-page{height:100%;display:flex;flex-direction:column}.context-panel{display:flex;flex-direction:column;height:100%}.context-panel-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:auto}.portfolio-grid .empty-state{padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.portfolio-grid .empty-state h2{margin-bottom:var(--spacing-md);color:var(--text-primary)}.productions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md);padding:var(--spacing-md)}.production-card{border-radius:var(--radius-md);overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border-color)}.production-card .thumbnail{position:relative;aspect-ratio:16/9}.production-card .thumbnail img{width:100%;height:100%;object-fit:cover}.production-card .overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.production-card:hover .overlay{opacity:1}.production-card .production-info{padding:var(--spacing-sm)}.production-card .name{display:block;font-weight:500}.production-card .meta{font-size:.75rem;color:var(--text-muted)}.library-panel{height:100%}.komposition-panel,.komposition-list-view{flex:1;display:flex;flex-direction:column;min-height:0}.komposition-list-view .list-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.komposition-list-view .list-header h3{margin:0}.komposition-list{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.komposition-list-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.komposition-list-item:hover{background:var(--bg-tertiary)}.komposition-list-item .item-type-icon{flex-shrink:0;font-size:1.1em}.komposition-list-item .item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.komposition-list-item .item-status{flex-shrink:0}.komposition-editor-view{display:flex;flex-direction:column;flex:1;min-height:0}.komposition-editor-view .editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-color);flex-shrink:0}.komposition-editor-view .toolbar-actions{display:flex;gap:var(--spacing-sm)}.komposition-editor-view .komposition-editor{flex:1;min-height:200px}.komposition-panel .empty-state{padding:var(--spacing-xl);text-align:center;color:var(--text-muted)}.context-menu-container{position:relative}.context-menu-trigger{cursor:pointer}.context-menu-dropdown{position:fixed;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);min-width:180px;box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden}.context-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;text-align:left;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .15s ease}.context-menu-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.context-menu-item-default{color:var(--text-secondary)}.context-menu-item-default:hover{background:var(--bg-tertiary);color:var(--text-primary)}.context-menu-item-danger{color:var(--color-danger)}.context-menu-item-danger:hover{background:#ef44441a;color:var(--color-danger)}.context-menu-icon{display:flex;align-items:center;justify-content:center;font-size:1rem}.context-menu-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.context-menu-divider{border:none;border-top:1px solid var(--border-color);margin:0}.menu-section{padding:var(--spacing-sm) var(--spacing-md)}.menu-section-label{font-size:.65rem;font-weight:600;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--spacing-sm);letter-spacing:.5px}.model-selector{display:flex;flex-direction:column;gap:var(--spacing-xs)}.model-option{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;text-align:left}.model-option:hover{background:var(--bg-primary);border-color:var(--color-primary);color:var(--text-primary)}.model-option.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.model-name{font-weight:500;font-size:.875rem}.model-description{font-size:.65rem;opacity:.8}.menu-item-link{display:flex;align-items:center;color:inherit;text-decoration:none}.menu-item-danger{color:var(--color-danger)}.menu-item-danger:hover{background:#ef44441a;color:var(--color-danger)}.jobs-panel{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);width:320px;max-height:400px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;display:flex;flex-direction:column;overflow:hidden}.jobs-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.jobs-panel-header h3{margin:0;font-size:.875rem;font-weight:600;color:var(--text-primary)}.jobs-count{font-size:.75rem;color:var(--color-primary);background:#6366f126;padding:2px 8px;border-radius:var(--radius-full)}.jobs-list{flex:1;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.job-card{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden}.job-card.job-active{border-color:var(--color-primary)}.job-card.job-success{border-color:var(--color-success)}.job-card.job-failed{border-color:var(--color-danger)}.job-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background:#0003}.job-type{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.job-dismiss{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;font-size:1rem;line-height:1;opacity:.6;transition:opacity .15s}.job-dismiss:hover{opacity:1;color:var(--text-primary)}.job-card-body{padding:var(--spacing-sm)}.job-description{margin:0 0 var(--spacing-xs);font-size:.8rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-status{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.status-badge{font-size:.65rem;font-weight:500;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase}.status-badge.status-pending{background:#f59e0b33;color:var(--color-warning)}.status-badge.status-running{background:#6366f133;color:var(--color-primary)}.status-badge.status-succeeded{background:#22c55e33;color:var(--color-success)}.status-badge.status-failed,.status-badge.status-timed_out,.status-badge.status-cancelled{background:#ef444433;color:var(--color-danger)}.job-phase{font-size:.7rem;color:var(--text-muted)}.job-progress{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--spacing-xs)}.job-progress-bar{height:100%;background:var(--color-primary);transition:width .3s ease}.job-error{margin:var(--spacing-xs) 0 0;font-size:.75rem;color:var(--color-danger)}.job-outputs{margin-top:var(--spacing-xs);display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.job-output-link{font-size:.7rem;color:var(--color-primary);text-decoration:none}.job-output-link:hover{text-decoration:underline}
