:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a25;--bg-card: #16161f;--bg-card-hover: #1e1e2a;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #6b6b7b;--accent-primary: #667eea;--accent-secondary: #764ba2;--accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--accent-glow: rgba(102, 126, 234, .4);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--border-color: rgba(255, 255, 255, .08);--border-color-active: rgba(102, 126, 234, .5);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s ease;--transition-normal: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 20%,rgba(102,126,234,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(118,75,162,.08) 0%,transparent 50%);pointer-events:none;z-index:-1}#app{min-height:100vh;display:flex;flex-direction:column}.header{background:#12121acc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{width:40px;height:40px}.logo-icon svg{width:100%;height:100%}.logo-text{font-size:1.25rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.nav{display:flex;gap:.5rem;background:var(--bg-tertiary);padding:4px;border-radius:var(--radius-md)}.nav-btn{background:transparent;border:none;color:var(--text-secondary);padding:.5rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.nav-btn:hover{color:var(--text-primary)}.nav-btn.active{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 15px var(--accent-glow)}.connection-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-tertiary);border-radius:var(--radius-lg);font-size:.85rem}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--warning);animation:pulse 2s infinite}.connection-status.connected .status-dot{background:var(--success)}.connection-status.disconnected .status-dot{background:var(--error);animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-actions{display:flex;align-items:center;gap:.75rem}.settings-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.settings-btn svg{width:20px;height:20px}.settings-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-color-active)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0fd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-overlay.active{display:flex}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:500px;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600}.modal-header h3 svg{width:24px;height:24px;color:var(--accent-primary)}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-close svg{width:20px;height:20px}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border-color)}.form-group input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem;color:var(--text-primary);font-family:inherit;font-size:1rem;width:100%;transition:all var(--transition-fast)}.file-upload-wrapper{position:relative;background:var(--bg-tertiary);border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:2rem;text-align:center;cursor:pointer;transition:all var(--transition-fast);margin-bottom:1rem}.file-upload-wrapper:hover{border-color:var(--accent-primary);background:var(--bg-card-hover)}.file-upload-wrapper input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-upload-placeholder{pointer-events:none;display:flex;flex-direction:column;gap:.5rem;align-items:center;color:var(--text-muted)}.file-name{color:var(--accent-primary);font-weight:500;font-size:.9rem}.image-preview{max-width:100%;max-height:200px;object-fit:cover;border-radius:6px;margin-top:10px}.hidden,.grok-only{display:none!important}.grok-only.visible{display:block!important}.mt-2{margin-top:1rem}.flex-1{flex:1}.form-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.form-group input::placeholder{color:var(--text-muted)}.input-with-toggle{position:relative;display:flex}.input-with-toggle input{padding-right:3rem}.toggle-visibility{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.toggle-visibility:hover{color:var(--text-primary)}.toggle-visibility svg{width:20px;height:20px}.form-hint{font-size:.8rem;color:var(--text-muted);margin-top:.5rem}.form-hint a{color:var(--accent-primary);text-decoration:none}.form-hint a:hover{text-decoration:underline}.api-key-status{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-top:1rem}.api-key-status .status-icon:before{content:"";display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--error)}.api-key-status.configured .status-icon:before{background:var(--success)}.api-key-status .status-message{font-size:.9rem;color:var(--text-secondary)}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--accent-gradient);border:none;border-radius:var(--radius-md);color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-primary:hover{box-shadow:0 4px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color-active)}.main{flex:1;max-width:1400px;margin:0 auto;padding:2rem;width:100%}.tab-content{display:none;animation:fadeIn .3s ease}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}#generateTab{display:none;grid-template-columns:1fr 1fr;gap:2rem}#generateTab.active{display:grid}@media (max-width: 1024px){#generateTab.active{grid-template-columns:1fr}}.generator-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem}.mode-selector{display:flex;gap:1rem;margin-bottom:2rem}.mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.mode-btn svg{width:24px;height:24px}.mode-btn:hover{border-color:var(--border-color-active);color:var(--text-primary)}.mode-btn.active{background:var(--accent-gradient);border-color:transparent;color:#fff;box-shadow:0 8px 30px var(--accent-glow)}.generator-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text-secondary)}.form-group label svg{width:16px;height:16px;opacity:.7}.form-group textarea,.form-group select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem;color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all var(--transition-fast);resize:none}.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.form-group textarea::placeholder{color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.video-only{display:none}body.video-mode .video-only{display:flex}.model-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.model-card{position:relative;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.model-card input{position:absolute;opacity:0;pointer-events:none}.model-card:hover{border-color:var(--border-color-active)}.model-card:has(input:checked){background:linear-gradient(135deg,#667eea33,#764ba233);border-color:var(--accent-primary)}.model-info{text-align:center}.model-name{display:block;font-weight:600;font-size:1rem;margin-bottom:.25rem}.model-provider{display:block;font-size:.75rem;color:var(--text-muted)}.generate-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.25rem 2rem;background:var(--accent-gradient);border:none;border-radius:var(--radius-md);color:#fff;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);margin-top:1rem}.generate-btn svg{width:24px;height:24px}.generate-btn:hover{transform:translateY(-2px);box-shadow:0 10px 40px var(--accent-glow)}.generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.result-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);min-height:400px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.result-placeholder{text-align:center;color:var(--text-muted);padding:2rem}.result-placeholder svg{width:80px;height:80px;margin-bottom:1rem;opacity:.3}.result-content{width:100%;height:100%;padding:1.5rem}.result-content img,.result-content video{width:100%;height:auto;max-height:500px;object-fit:contain;border-radius:var(--radius-md)}.result-actions{position:absolute;bottom:1.5rem;right:1.5rem;display:flex;gap:.75rem}.result-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-md);color:#fff;font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.result-action-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary)}.result-action-btn svg{width:18px;height:18px}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.history-header h2{font-size:1.5rem;font-weight:700}.refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.refresh-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.refresh-btn svg{width:18px;height:18px}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.history-empty{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:var(--text-muted)}.history-empty svg{width:60px;height:60px;margin-bottom:1rem;opacity:.3}.history-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-normal)}.history-card:hover{transform:translateY(-4px);border-color:var(--border-color-active);box-shadow:0 20px 40px #0000004d}.history-card-preview{aspect-ratio:16/9;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden}.history-card-preview img,.history-card-preview video{width:100%;height:100%;object-fit:cover}.history-card-info{padding:1rem}.history-card-type{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;text-transform:uppercase;margin-bottom:.75rem}.history-card-type.image{color:var(--info)}.history-card-type.video{color:var(--accent-primary)}.history-card-prompt{font-size:.9rem;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.75rem}.history-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:var(--text-muted)}.history-card-status{display:flex;align-items:center;gap:.375rem}.history-card-status:before{content:"";width:6px;height:6px;border-radius:50%}.history-card-status.processing:before{background:var(--warning)}.history-card-status.completed:before{background:var(--success)}.history-card-status.failed:before{background:var(--error)}.toast-container{position:fixed;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:.75rem;z-index:1000;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 10px 40px #0006;animation:slideIn .3s ease;pointer-events:auto}.toast.success{border-left:4px solid var(--success)}.toast.error{border-left:4px solid var(--error)}.toast.warning{border-left:4px solid var(--warning)}.toast.info{border-left:4px solid var(--info)}.toast-icon{width:24px;height:24px;flex-shrink:0}.toast.success .toast-icon{color:var(--success)}.toast.error .toast-icon{color:var(--error)}.toast-message{font-size:.9rem}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0fe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:1000}.loading-overlay.active{display:flex}.loading-content{text-align:center}.loading-spinner{width:60px;height:60px;border:3px solid var(--bg-tertiary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.loading-subtext{color:var(--text-muted);font-size:.9rem}@media (max-width: 768px){.header-content{padding:1rem;flex-wrap:wrap;gap:1rem}.nav{order:3;width:100%;justify-content:center}.main{padding:1rem}.form-row,.model-cards{grid-template-columns:1fr}}
