@import "https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700&family=Space+Grotesk:wght@400;500;700&display=swap";:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg:#0a0a0f;--color-bg-secondary:#12121a;--color-bg-tertiary:#1a1a25;--color-surface:#222230;--color-surface-hover:#2a2a3c;--color-border:#2e2e42;--color-border-light:#3d3d54;--color-primary:#6366f1;--color-primary-hover:#818cf8;--color-primary-light:#6366f126;--color-primary-alt:#8b5cf6;--color-accent:#06b6d4;--color-accent-light:#06b6d426;--color-success:#10b981;--color-success-light:#10b98126;--color-warning:#f59e0b;--color-error:#ef4444;--color-error-light:#ef444426;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006;--shadow-lg:0 10px 15px -3px #00000080;--shadow-glow:0 0 20px #6366f14d;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease;--page-gradient:radial-gradient(circle at top left, #6366f11f, transparent 30%), linear-gradient(135deg, #08080d 0%, #11111b 45%, #191925 100%);--header-glass-bg:#12121af2;--modal-overlay-bg:#000000b3;--panel-overlay-bg:#03060eb8;--panel-surface-bg:#12121af5;font-family:Space Grotesk,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-weight:400;line-height:1.5}:root[data-theme=light]{--color-bg:#f2f6fb;--color-bg-secondary:#e9f0f8;--color-bg-tertiary:#eef3f9;--color-surface:#fff;--color-surface-hover:#f5f8fd;--color-border:#d3dfec;--color-border-light:#becee0;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#2563eb1f;--color-primary-alt:#7c3aed;--color-accent:#0891b2;--color-accent-light:#0891b224;--color-success:#16a34a;--color-success-light:#16a34a24;--color-warning:#d97706;--color-error:#dc2626;--color-error-light:#dc262624;--color-text:#0f172a;--color-text-secondary:#334155;--color-text-muted:#64748b;--shadow-sm:0 1px 2px #0f172a14;--shadow-md:0 8px 16px -8px #0f172a29;--shadow-lg:0 16px 28px -12px #0f172a33;--shadow-glow:0 0 18px #2563eb2e;--page-gradient:radial-gradient(circle at top left, #3b82f62e, transparent 30%), linear-gradient(135deg, #f5f8fc 0%, #eef4fb 46%, #f8f6f3 100%);--header-glass-bg:#ffffffeb;--modal-overlay-bg:#0f172a6b;--panel-overlay-bg:#0f172a5c;--panel-surface-bg:#fffffff5}*{box-sizing:border-box}html{scroll-behavior:smooth;height:100%}body{min-width:320px;height:100%;min-height:100vh;color:var(--color-text);background:var(--page-gradient);transition:background var(--transition-base), color var(--transition-base);margin:0;overflow:hidden}button,input,textarea,select{font:inherit}button{cursor:pointer}img,video{max-width:100%}h1,h2{letter-spacing:-.03em;color:var(--color-text);margin:0;font-family:Archivo,PingFang SC,sans-serif}h1{font-size:clamp(2.4rem,4.8vw,4.6rem);line-height:.96}h2{font-size:clamp(1.35rem,2vw,1.8rem);line-height:1.05}p{margin:0}a{color:inherit}#root{height:100%;min-height:100vh}.loading-screen{height:100vh;color:var(--color-text);background:var(--page-gradient);justify-content:center;align-items:center;font-size:.95rem;font-weight:600;display:flex}.theme-switch-btn{border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);min-width:78px;height:34px;color:var(--color-text-secondary);transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);justify-content:center;align-items:center;gap:7px;padding:0 12px;display:inline-flex}.theme-switch-btn svg{fill:currentColor;width:14px;height:14px}.theme-switch-btn span{letter-spacing:.02em;font-size:.76rem;font-weight:700}.theme-switch-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.theme-switch-btn.compact{min-width:72px;height:32px;padding:0 10px}.auth-page{background:var(--page-gradient);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-container{background:var(--panel-surface-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:40px;position:relative}.auth-header{text-align:center;margin-bottom:32px}.auth-tools{position:absolute;top:16px;right:16px}.auth-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:24px;display:flex}.auth-logo svg{width:40px;height:40px;fill:var(--color-primary)}.auth-logo span{color:var(--color-text);font-size:1.5rem;font-weight:700}.auth-header h1{color:var(--color-text);margin-bottom:8px;font-size:1.75rem;font-weight:700}.auth-header p{color:var(--color-text-secondary);font-size:.9375rem}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.form-group input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition-fast);padding:12px 16px;font-size:.9375rem}.form-group input::placeholder{color:var(--color-text-muted)}.auth-error{background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);padding:12px 16px;font-size:.875rem}.auth-submit-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-alt));border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;margin-top:8px;padding:14px 24px;font-size:.9375rem;font-weight:600;display:flex}.auth-submit-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-1px)}.auth-submit-btn:disabled{opacity:.7;cursor:not-allowed}.loading-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-footer{text-align:center;margin-top:24px}.auth-footer p{color:var(--color-text-secondary);font-size:.875rem}.auth-switch-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;margin-left:6px;padding:0;font-size:.875rem;font-weight:600}.auth-switch-btn:hover{color:var(--color-primary-hover);text-decoration:underline}.contact-admin{color:var(--color-text-muted);font-size:.8125rem}@media (width<=480px){.auth-container{padding:32px 24px}.auth-header h1{font-size:1.5rem}}.projects-page{background:var(--color-bg);min-height:100vh}.projects-header{background:var(--header-glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.projects-brand{color:var(--color-text);align-items:center;gap:12px;font-size:1.25rem;font-weight:700;display:flex}.projects-brand svg{width:32px;height:32px;fill:var(--color-primary)}.projects-user{align-items:center;gap:16px;display:flex}.projects-user span{color:var(--color-text-secondary);font-size:.9375rem}.admin-btn{background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius-md);color:var(--color-primary);cursor:pointer;padding:6px 12px;font-size:.8125rem;font-weight:600}.admin-btn:hover{background:var(--color-primary);color:#fff}.change-password-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 12px;font-size:.8125rem;font-weight:500}.logout-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:8px 16px;font-size:.875rem}.projects-main{max-width:1200px;margin:0 auto;padding:32px}.projects-toolbar{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.projects-toolbar h1{color:var(--color-text);font-size:1.75rem;font-weight:700}.create-project-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-alt));border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.9375rem;font-weight:600;display:flex}.create-project-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.create-project-btn svg{fill:currentColor;width:18px;height:18px}.create-project-btn.large{padding:14px 28px;font-size:1rem}.projects-loading{justify-content:center;align-items:center;min-height:400px;display:flex}.loading-spinner-large{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.projects-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.projects-empty .empty-icon{background:var(--color-surface);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:24px;display:flex}.projects-empty .empty-icon svg{width:40px;height:40px;fill:var(--color-text-muted)}.projects-empty h3{color:var(--color-text);margin-bottom:8px;font-size:1.25rem;font-weight:600}.projects-empty p{color:var(--color-text-secondary);margin-bottom:24px}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;display:grid}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);padding:24px}.project-card:hover{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);transform:translateY(-2px)}.project-card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.project-icon{background:var(--color-primary-light);border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.project-icon svg{width:24px;height:24px;fill:var(--color-primary)}.project-status{border-radius:var(--radius-full);text-transform:capitalize;padding:4px 12px;font-size:.75rem;font-weight:600}.project-status.active{background:var(--color-success-light);color:var(--color-success)}.project-status.archived{background:var(--color-surface-hover);color:var(--color-text-muted)}.project-name{color:var(--color-text);margin-bottom:8px;font-size:1.125rem;font-weight:600}.project-description{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:16px;font-size:.875rem;display:-webkit-box;overflow:hidden}.project-meta{color:var(--color-text-muted);font-size:.8125rem}.modal-content .form-group{margin-bottom:20px}.modal-content .form-group input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);padding:12px 16px;font-size:.9375rem}.modal-content .form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.modal-content textarea{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);resize:vertical;min-height:80px;padding:12px 16px;font-family:inherit;font-size:.9375rem}.modal-content textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.btn-secondary{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:10px 20px;font-size:.9375rem}.btn-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;padding:10px 20px;font-size:.9375rem;font-weight:600}@media (width<=768px){.projects-header{padding:16px 20px}.projects-main{padding:20px}.projects-grid{grid-template-columns:1fr}}.app-container{--color-bg:#0a0a0f;--color-bg-secondary:#12121a;--color-bg-tertiary:#1a1a25;--color-surface:#222230;--color-surface-hover:#2a2a3c;--color-border:#2e2e42;--color-border-light:#3d3d54;--color-primary:#6366f1;--color-primary-hover:#818cf8;--color-primary-light:#6366f126;--color-accent:#06b6d4;--color-accent-light:#06b6d426;--color-success:#10b981;--color-success-light:#10b98126;--color-warning:#f59e0b;--color-error:#ef4444;--color-error-light:#ef444426;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006;--shadow-lg:0 10px 15px -3px #00000080;--shadow-glow:0 0 20px #6366f14d;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease;--header-bg:#12121af2;--sidebar-bg-start:#0c0c12fa;--sidebar-bg-end:#101018f5;--sidebar-title-divider:#ffffff0f;--nav-btn-bg:#ffffff05;--nav-btn-active-bg:#6366f129;--slot-preview-bg:#12141cf5;--slot-preview-border:#ffffff14;--slot-preview-shadow:0 18px 40px #00000047;--slot-preview-audio-bg:#6366f12e;--slot-preview-audio-color:#c7d2fe;--slot-preview-title:#f8fafc;--slot-preview-subtitle:#e2e8f0b8;--active-chip-border:#6366f166;--frame-label-bg:#000000b3;--preview-overlay-bg:#000000d9;--panel-overlay-bg:#03060eb8;--panel-bg:#12121af5;--back-btn-bg:#ffffff14;--back-btn-border:#ffffff24;--back-btn-color:#f8fafc;--back-btn-shadow:0 8px 20px #0000002e;--back-btn-hover-bg:#38bdf824;--delete-btn-bg:#0f172aeb;--delete-btn-border:#ffffff2e;--delete-btn-shadow:0 10px 24px #0206175c;--result-primary-hover:#0d9f6e}.app-container.theme-light{--color-bg:#f2f6fb;--color-bg-secondary:#e9f0f8;--color-bg-tertiary:#eef3f9;--color-surface:#fff;--color-surface-hover:#f5f8fd;--color-border:#d3dfec;--color-border-light:#becee0;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#2563eb1f;--color-accent:#0891b2;--color-accent-light:#0891b224;--color-success:#16a34a;--color-success-light:#16a34a24;--color-warning:#d97706;--color-error:#dc2626;--color-error-light:#dc262624;--color-text:#0f172a;--color-text-secondary:#334155;--color-text-muted:#64748b;--shadow-sm:0 1px 2px #0f172a14;--shadow-md:0 8px 16px -8px #0f172a29;--shadow-lg:0 16px 28px -12px #0f172a33;--shadow-glow:0 0 18px #2563eb2e;--header-bg:#ffffffeb;--sidebar-bg-start:#f9fbff;--sidebar-bg-end:#f2f7ff;--sidebar-title-divider:#0f172a1a;--nav-btn-bg:#ffffffbf;--nav-btn-active-bg:#2563eb1f;--slot-preview-bg:#fffffff5;--slot-preview-border:#0f172a1f;--slot-preview-shadow:0 14px 34px #0f172a2e;--slot-preview-audio-bg:#2563eb1f;--slot-preview-audio-color:#1d4ed8;--slot-preview-title:#0f172a;--slot-preview-subtitle:#475569;--active-chip-border:#2563eb59;--frame-label-bg:#0f172ab8;--preview-overlay-bg:#0f172a8c;--panel-overlay-bg:#0f172a66;--panel-bg:#fffffff5;--back-btn-bg:#fffffff0;--back-btn-border:#94a3b866;--back-btn-color:#0f172a;--back-btn-shadow:0 8px 18px #0f172a1a;--back-btn-hover-bg:#2563eb1f;--delete-btn-bg:#0f172adb;--delete-btn-border:#ffffff80;--delete-btn-shadow:0 8px 20px #0f172a33;--result-primary-hover:#15803d}*{box-sizing:border-box;margin:0;padding:0}.app-container{background:var(--color-bg);height:100vh;color:var(--color-text);font-family:Space Grotesk,PingFang SC,Microsoft YaHei,sans-serif;overflow:hidden}.app-header{z-index:101;background:var(--header-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;height:60px;padding:12px 24px;display:flex;position:fixed;top:0;left:0;right:0}.header-brand{color:var(--color-text);align-items:center;gap:10px;font-size:1.25rem;font-weight:700;display:flex}.header-brand svg{width:28px;height:28px;fill:var(--color-primary)}.back-btn{background:var(--back-btn-bg);border:1px solid var(--back-btn-border);cursor:pointer;width:44px;height:44px;color:var(--back-btn-color);box-shadow:var(--back-btn-shadow);transition:transform var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast), color var(--transition-fast);border-radius:14px;justify-content:center;align-items:center;margin-right:10px;display:flex}.back-btn svg{fill:none;stroke:currentColor;width:22px;height:22px;display:block}.back-btn:hover{border-color:var(--color-primary);background:var(--back-btn-hover-bg);color:var(--color-primary);transform:translateY(-1px)}.project-name{color:var(--color-text-secondary);border-left:1px solid var(--color-border);margin-left:8px;padding-left:12px;font-size:.875rem;font-weight:500}.header-status{align-items:center;gap:16px;display:flex}.resource-count{color:var(--color-text-secondary);font-size:.875rem}.status-badge{border-radius:var(--radius-full);align-items:center;gap:6px;padding:6px 14px;font-size:.875rem;font-weight:600;display:flex}.status-badge svg{width:16px;height:16px}.status-neutral{background:var(--color-surface);color:var(--color-text-secondary)}.status-neutral svg{fill:var(--color-text-muted)}.status-accent{background:var(--color-accent-light);color:var(--color-accent)}.status-accent svg{fill:var(--color-accent);animation:2s linear infinite spin}.status-success{background:var(--color-success-light);color:var(--color-success)}.status-success svg{fill:var(--color-success)}.status-danger{background:var(--color-error-light);color:var(--color-error)}.status-danger svg{fill:var(--color-error)}.change-password-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;background:0 0;padding:6px 12px;font-size:.8125rem}.change-password-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.theme-toggle-btn{border:1px solid var(--color-border);background:var(--color-surface);min-width:84px;height:34px;color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--transition-fast), color var(--transition-fast), background var(--transition-fast);border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 12px;display:inline-flex}.theme-toggle-btn svg{fill:currentColor;width:14px;height:14px}.theme-toggle-btn span{letter-spacing:.02em;font-size:.78rem;font-weight:700}.theme-toggle-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.workspace-shell{grid-template-columns:188px minmax(0,1fr);height:calc(100vh - 60px);min-height:0;margin-top:60px;display:grid}.resource-zone{background:var(--color-bg);grid-template-rows:minmax(0,1fr) auto;gap:16px;min-width:0;min-height:0;padding:0;display:grid;position:relative;overflow:visible}.resource-sidebar{border-right:1px solid var(--color-border);background:linear-gradient(180deg, var(--sidebar-bg-start), var(--sidebar-bg-end));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);width:188px;min-height:calc(100vh - 60px);box-shadow:none;z-index:1;flex-direction:column;gap:12px;padding:20px 12px;display:flex;position:relative;overflow-y:auto}.resource-nav-btn{border:1px solid var(--color-border);background:var(--nav-btn-bg);width:100%;min-height:56px;color:var(--color-text-secondary);cursor:pointer;transition:transform var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), background var(--transition-fast);border-radius:16px;flex-direction:row;justify-content:flex-start;align-items:center;gap:12px;padding:10px;display:flex}.resource-nav-btn svg{fill:currentColor;flex-shrink:0;width:18px;height:18px}.resource-nav-copy{align-items:center;gap:8px;min-width:0;display:inline-flex}.resource-nav-copy strong{color:inherit;font-size:.875rem;font-weight:700}.resource-nav-badge{background:color-mix(in srgb, var(--color-primary) 88%, white);color:#fff;min-width:20px;height:20px;box-shadow:0 6px 14px color-mix(in srgb, var(--color-primary) 24%, transparent);border-radius:999px;justify-content:center;align-items:center;padding:0 6px;font-size:.75rem;font-weight:800;line-height:1;display:inline-flex}.resource-nav-btn:hover,.resource-nav-btn.is-active{color:var(--color-text);border-color:var(--color-primary);background:var(--nav-btn-active-bg);transform:none}.sidebar-queue-panel{flex-direction:column;gap:10px;margin-top:auto;padding-top:14px;display:flex}.sidebar-queue-header{color:var(--color-text-secondary);justify-content:space-between;align-items:center;padding:0 4px;font-size:.75rem;font-weight:700;display:flex}.sidebar-queue-header strong{background:color-mix(in srgb, var(--color-primary) 14%, var(--color-surface));min-width:20px;height:20px;color:var(--color-primary);border-radius:999px;justify-content:center;align-items:center;padding:0 6px;font-size:.75rem;display:inline-flex}.sidebar-queue-empty{border:1px dashed var(--color-border);color:var(--color-text-muted);background:color-mix(in srgb, var(--nav-btn-bg) 72%, transparent);border-radius:14px;padding:12px 14px;font-size:.75rem;line-height:1.5}.sidebar-queue-list{flex-direction:column;gap:8px;display:flex}.sidebar-queue-item{border:1px solid var(--color-border);background:color-mix(in srgb, var(--nav-btn-bg) 82%, var(--color-surface));width:100%;color:var(--color-text);text-align:left;cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);border-radius:16px;flex-direction:column;gap:8px;padding:12px 12px 11px;display:flex}.sidebar-queue-item:hover{border-color:var(--color-primary);background:color-mix(in srgb, var(--nav-btn-active-bg) 88%, var(--color-surface));transform:translateY(-1px)}.sidebar-queue-top{align-items:center;gap:6px;min-width:0;display:flex}.sidebar-queue-top strong{color:var(--color-text);font-size:.75rem;font-weight:700}.sidebar-queue-top span:last-child{color:var(--color-text-muted);flex-shrink:0;margin-left:auto;font-size:.6875rem}.sidebar-queue-dot{background:var(--color-border);border-radius:999px;flex-shrink:0;width:8px;height:8px}.sidebar-queue-dot.is-queued{background:var(--color-warning)}.sidebar-queue-dot.is-running{background:var(--color-primary);box-shadow:0 0 0 4px color-mix(in srgb, var(--color-primary) 18%, transparent)}.sidebar-queue-item p{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.75rem;line-height:1.45;display:-webkit-box;overflow:hidden}.resource-zone.drop-active{background:var(--color-primary-light)}.resource-zone.drop-active:before{content:"";border:3px dashed var(--color-primary);pointer-events:none;z-index:50;position:fixed;inset:60px 0 0}.control-dock-wrapper{z-index:10;background:var(--color-surface);border-radius:var(--radius-xl);pointer-events:auto;width:min(860px,100% - 188px);margin:0 auto;padding:16px 0 24px;transition:padding .2s;position:fixed;bottom:16px;left:188px;right:0;box-shadow:0 -4px 24px #0000001f}.control-dock-wrapper.is-collapsed{border-radius:var(--radius-full);padding:10px 0 16px}.control-dock{pointer-events:auto;box-sizing:border-box;padding:0 24px}.control-dock form{flex-direction:column;gap:12px;display:flex}.dock-row{align-items:stretch;gap:12px;display:flex}.active-resources-dropzone{justify-content:stretch}.active-resources-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:center;gap:16px;width:100%;padding:12px 16px;display:flex}.active-resources-slots{flex:1;align-items:center;gap:12px;min-height:48px;display:flex;overflow:visible}.universal-slots{flex-wrap:wrap;align-items:center;gap:8px;display:flex;position:relative;overflow:visible}.slot-hover-preview{background:var(--slot-preview-bg);border:1px solid var(--slot-preview-border);width:220px;box-shadow:var(--slot-preview-shadow);z-index:120;pointer-events:none;border-radius:14px;gap:10px;padding:10px;display:grid;position:absolute;bottom:calc(100% + 14px);left:50%;transform:translate(-50%)}.prompt-hover-preview{position:fixed;bottom:auto;transform:translate(-50%,calc(-100% - 14px))}.prompt-hover-preview:after{top:auto;bottom:-6px;transform:translate(-50%,50%)rotate(45deg)}.slot-hover-preview:after{content:"";background:var(--slot-preview-bg);border-right:1px solid var(--slot-preview-border);border-bottom:1px solid var(--slot-preview-border);width:12px;height:12px;position:absolute;top:100%;left:50%;transform:translate(-50%,-50%)rotate(45deg)}.slot-hover-preview-media{background:#ffffff0f;border-radius:10px;justify-content:center;align-items:center;width:100%;height:132px;display:flex;overflow:hidden}.slot-hover-preview-media img,.slot-hover-preview-media video{object-fit:cover;width:100%;height:100%;display:block}.slot-hover-preview-audio{background:var(--slot-preview-audio-bg);width:56px;height:56px;color:var(--slot-preview-audio-color);border-radius:18px;justify-content:center;align-items:center;display:flex}.slot-hover-preview-audio svg{fill:currentColor;width:24px;height:24px}.slot-hover-preview-meta{flex-direction:column;gap:4px;min-width:0;display:flex}.slot-hover-preview-meta strong,.slot-hover-preview-meta span{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.slot-hover-preview-meta strong{color:var(--slot-preview-title);font-size:.8125rem}.slot-hover-preview-meta span{color:var(--slot-preview-subtitle);font-size:.75rem}.empty-slot{color:var(--color-text-muted);font-size:.8125rem}.active-asset-chip{background:var(--color-primary-light);border:1px solid var(--active-chip-border);border-radius:var(--radius-md);flex-direction:column;align-items:center;gap:4px;min-width:72px;padding:6px 8px;display:flex;position:relative}.active-asset-thumb{border-radius:var(--radius-sm);background:var(--color-surface);flex-shrink:0;justify-content:center;align-items:center;width:64px;height:48px;display:flex;position:relative;overflow:hidden}.active-asset-duration{color:#fff;pointer-events:none;background:#000000a6;border-radius:2px;padding:0 2px;font-size:.6rem;font-weight:600;line-height:1.5;position:absolute;bottom:1px;right:1px}.active-asset-thumb img,.active-asset-thumb video{object-fit:cover;width:100%;height:100%}.active-asset-thumb svg{width:18px;height:18px;fill:var(--color-text-secondary)}.active-alias{color:var(--color-primary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-family:inherit;font-size:.7rem;font-weight:600;line-height:1.2;transition:color .15s,opacity .15s;display:inline-flex}.active-alias:hover{color:var(--color-primary-hover)}.active-alias:focus-visible{outline:none;text-decoration:underline}.remove-active-btn{background:var(--color-error);border-radius:var(--radius-full);cursor:pointer;opacity:0;width:18px;height:18px;transition:opacity var(--transition-fast);border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:-6px;right:-6px}.active-asset-chip:hover .remove-active-btn{opacity:1}.remove-active-btn svg{fill:#fff;width:10px;height:10px}.frame-slots{align-items:center;gap:12px;display:flex}.frame-drop-slot{background:var(--color-bg-tertiary);border:2px dashed var(--color-border);border-radius:var(--radius-md);flex-direction:column;justify-content:center;align-items:center;width:80px;height:80px;display:flex;position:relative;overflow:hidden}.frame-drop-slot.filled{border-style:solid;border-color:var(--color-primary)}.frame-drop-slot img{object-fit:cover;width:100%;height:100%}.frame-drop-slot .drop-hint{color:var(--color-text-muted);text-align:center;padding:8px;font-size:.625rem}.frame-drop-slot .slot-label{background:var(--frame-label-bg);color:#fff;text-align:center;border-radius:var(--radius-sm);padding:2px 4px;font-size:.625rem;position:absolute;bottom:4px;left:4px;right:4px}.remove-frame-btn{background:var(--color-error);border-radius:var(--radius-full);cursor:pointer;border:none;justify-content:center;align-items:center;width:20px;height:20px;padding:0;display:flex;position:absolute;top:4px;right:4px}.remove-frame-btn svg{fill:#fff;width:12px;height:12px}.frame-arrow{color:var(--color-text-muted);font-size:1.25rem}.result-preview-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.result-preview-panel{background:var(--color-surface);border:1px solid var(--color-success);border-radius:var(--radius-lg);width:min(640px,92vw);box-shadow:var(--shadow-md);flex-direction:column;gap:16px;padding:20px;display:flex}.result-preview-header{color:var(--color-success);align-items:center;gap:8px;font-size:.875rem;font-weight:600;display:flex}.result-preview-header svg{width:18px;height:18px;fill:var(--color-success)}.result-preview-content{flex-direction:column;gap:12px;display:flex}.result-video{border-radius:var(--radius-md);background:var(--color-bg);width:100%;max-height:420px}.result-actions{justify-content:center;gap:10px;display:flex}.result-btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;padding:8px 16px;font-size:.875rem;font-weight:600;text-decoration:none}.result-btn.primary{background:var(--color-success);color:#fff}.result-btn.primary:hover{background:var(--result-primary-hover)}.result-btn.secondary{background:var(--color-surface-hover);color:var(--color-text-secondary);border:1px solid var(--color-border)}.result-btn.secondary:hover{background:var(--color-border);color:var(--color-text)}.prompt-box{flex-direction:column;flex:1;gap:10px;display:flex}.prompt-input-wrap{position:relative}.prompt-input-wrap.is-mini{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);align-items:center;gap:8px;padding:6px 6px 6px 10px;display:flex}.prompt-input-wrap.is-mini .prompt-editor{min-height:unset;box-shadow:none;resize:none;background:0 0;border:none;border-radius:0;flex:1;padding:8px 4px;overflow:hidden;height:36px!important}.prompt-input-wrap.is-mini .prompt-editor:focus{box-shadow:none;border:none;outline:none}.mini-add-btn{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.mini-add-btn:hover{color:var(--color-text);border-color:var(--color-primary)}.mini-add-btn svg{fill:currentColor;width:18px;height:18px}.mini-submit-btn{background:var(--color-text);border-radius:var(--radius-full);width:40px;height:40px;color:var(--color-bg);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .15s;display:flex}.mini-submit-btn:disabled{opacity:.4;cursor:not-allowed}.mini-submit-btn svg{fill:currentColor;width:16px;height:16px}.mini-submit-btn.is-loading{opacity:.88}.prompt-editor{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;min-height:80px;color:var(--color-text);resize:none;box-sizing:border-box;white-space:pre-wrap;word-break:break-word;caret-color:var(--color-text);padding:14px 18px;font-family:inherit;font-size:.9375rem;line-height:1.6;overflow:hidden}.prompt-resize-handle{cursor:ns-resize;z-index:10;height:8px;position:absolute;top:-4px;left:0;right:0}.prompt-resize-handle:after{content:"";background:var(--color-border);border-radius:1px;width:32px;height:2px;transition:background .15s;position:absolute;top:3px;left:50%;transform:translate(-50%)}.prompt-resize-handle:hover:after{background:var(--color-primary)}.prompt-editor:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.prompt-editor:empty:before{content:attr(data-placeholder);color:var(--color-text-muted);pointer-events:none}.prompt-inline-mention{background:var(--color-bg);border:1px solid var(--color-border);vertical-align:baseline;pointer-events:auto;border-radius:999px;align-items:center;gap:6px;margin:0 2px;padding:2px 8px 2px 4px;display:inline-flex}.prompt-inline-mention-thumb{background:var(--color-surface-hover);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex;overflow:hidden}.prompt-inline-mention-thumb img,.prompt-inline-mention-thumb video{object-fit:cover;width:100%;height:100%;display:block}.prompt-inline-mention-thumb svg{width:12px;height:12px}.prompt-inline-audio-glyph{color:var(--color-text-secondary);font-size:12px;line-height:1}.prompt-inline-mention-label{color:var(--color-text);font-weight:500}.prompt-aliases{flex-wrap:wrap;gap:8px;display:flex}.alias-btn{border:1px solid var(--color-border);background:color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));color:var(--color-primary);border-radius:999px;padding:6px 10px;font-size:.8125rem;font-weight:600;transition:all .18s}.alias-btn:hover{border-color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 18%, var(--color-surface))}.prompt-mention-menu{z-index:30;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-md);flex-direction:column;gap:6px;max-height:min(280px,40vh);padding:10px;display:flex;position:absolute;bottom:calc(100% + 8px);left:0;right:0;overflow-y:auto}.prompt-mention-option{width:100%;color:var(--color-text);text-align:left;background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:10px 12px;transition:all .18s;display:flex}.prompt-mention-thumb{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex;overflow:hidden}.prompt-mention-thumb img,.prompt-mention-thumb video{object-fit:cover;width:100%;height:100%;display:block}.prompt-mention-thumb svg{width:16px;height:16px;fill:var(--color-text-secondary)}.prompt-mention-copy{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.prompt-mention-copy span{color:var(--color-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.prompt-mention-copy small{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.prompt-mention-option:hover,.prompt-mention-option.is-active{border-color:color-mix(in srgb, var(--color-primary) 28%, var(--color-border));background:color-mix(in srgb, var(--color-primary) 12%, var(--color-surface))}.dock-controls{flex-wrap:nowrap;justify-content:center;align-items:center;gap:10px;display:flex}.control-item{flex-shrink:0;align-items:center;display:flex;position:relative}.control-item>.custom-select{width:100%}.control-item>.custom-select .custom-select-trigger{gap:4px;width:100%;min-width:auto;padding:6px 8px}.control-item>.custom-select .custom-select-icon{width:14px;height:14px}.control-item>.custom-select .custom-select-icon svg{width:12px;height:12px}.control-item>.custom-select .custom-select-value{font-size:.8125rem}.custom-select{align-items:center;display:flex;position:relative}.custom-select-trigger{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:4px;min-width:auto;padding:6px 10px;font-size:.8125rem;font-weight:500;display:flex}.custom-select-trigger:hover{background:var(--color-surface);border-color:var(--color-border-light)}.custom-select-icon{justify-content:center;align-items:center;width:14px;height:14px;display:flex}.custom-select-icon svg{width:12px;height:12px;fill:var(--color-text-secondary)}.custom-select-value{text-align:left;white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.custom-select-chevron{width:16px;height:16px;transition:transform var(--transition-fast);justify-content:center;align-items:center;display:flex}.custom-select-chevron svg{width:14px;height:14px;fill:var(--color-text-muted)}.custom-select-chevron.open{transform:rotate(180deg)}.custom-select-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:100%;box-shadow:var(--shadow-lg);z-index:200;animation:.15s dropdownSlideUp;position:absolute;bottom:calc(100% + 4px);left:0;overflow:hidden}@keyframes dropdownSlideUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.custom-select-option{width:100%;color:var(--color-text-secondary);text-align:left;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;padding:10px 14px;font-size:.875rem;display:block}.custom-select-option:hover{background:var(--color-surface-hover);color:var(--color-text)}.custom-select-option.selected{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.toggle-item{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0;align-items:center;gap:4px;padding:6px 8px;font-size:.75rem;display:flex}.toggle-item:hover{border-color:var(--color-border-light)}.toggle-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary);cursor:pointer}.submit-btn{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-full);color:#fff;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:.8125rem;font-weight:600;display:flex}.submit-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-1px)}.submit-btn.is-loading{gap:8px}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn svg{fill:currentColor;width:14px;height:14px}.submit-spinner{border:2px solid #ffffff47;border-top-color:currentColor;border-radius:999px;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite submit-spin}@keyframes submit-spin{to{transform:rotate(360deg)}}.message-toast{background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);z-index:200;align-items:center;gap:12px;padding:12px 20px;font-size:.875rem;display:flex;position:fixed;top:80px;left:50%;transform:translate(-50%)}.message-toast.success{background:color-mix(in srgb, var(--color-success) 16%, var(--color-surface));border-color:color-mix(in srgb, var(--color-success) 42%, var(--color-border));min-width:240px;color:var(--color-text);box-shadow:var(--shadow-lg);cursor:pointer;justify-content:space-between;top:auto;bottom:20px;left:20px;transform:none}.message-toast-copy{flex-direction:column;align-items:flex-start;gap:2px;min-width:0;display:flex}.message-toast-copy strong{color:var(--color-text);font-size:.875rem;font-weight:700}.message-toast-copy small{color:var(--color-text-secondary);font-size:.75rem}.message-toast-action{color:var(--color-success);flex-shrink:0;font-size:.8125rem;font-weight:700}.message-toast button{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.message-toast button svg{fill:currentColor;width:16px;height:16px}.asset-section{height:100%;min-height:0;padding:24px 24px 600px;overflow-y:auto}.empty-state{min-height:400px;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-icon{width:64px;height:64px;margin-bottom:16px}.empty-icon svg{width:100%;height:100%;fill:var(--color-text-muted)}.asset-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;display:grid}.asset-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);position:relative;overflow:visible}.asset-card:hover{z-index:2;border-color:var(--color-border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.asset-card.in-use{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.asset-thumbnail{aspect-ratio:16/10;background:var(--color-bg-tertiary);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);position:relative;overflow:hidden}.asset-thumbnail img,.asset-thumbnail video{object-fit:cover;width:100%;height:100%}.audio-thumbnail{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.audio-thumbnail svg{width:32px;height:32px;fill:var(--color-text-muted)}.asset-type-badge{border-radius:var(--radius-sm);background:#0009;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:absolute;top:8px;left:8px}.asset-type-badge svg{fill:#fff;width:14px;height:14px}.asset-duration-badge{color:#fff;border-radius:var(--radius-sm);background:#0009;padding:2px 6px;font-size:.75rem;font-weight:600;line-height:1.4;position:absolute;bottom:8px;right:8px}.asset-duration-badge.with-use-btn{right:48px}.asset-video-play-indicator{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.asset-video-play-indicator:before{content:"";-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;border-radius:50%;width:48px;height:48px}.asset-video-play-indicator svg{color:#fff;width:20px;height:20px;position:absolute}.asset-thumbnail .asset-in-use-indicator{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);padding:4px 10px;font-size:.75rem;font-weight:600;position:absolute;top:44px;right:8px}.asset-info .asset-in-use-indicator{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);flex:none;padding:4px 10px;font-size:.75rem;font-weight:600}.asset-info{align-items:center;gap:8px;padding:8px 12px;display:flex}.asset-name{min-width:0;color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;flex:auto;font-size:.8125rem;display:block;overflow:hidden}.asset-resolution{color:#fff;border-radius:var(--radius-sm);pointer-events:none;background:#0009;padding:2px 6px;font-size:.7rem;font-weight:600;line-height:1.4;position:absolute;bottom:8px;left:8px}.asset-actions{gap:8px;padding:0 12px 12px;display:flex}.asset-actions button{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;flex:1;padding:8px 10px;font-size:.75rem;overflow:hidden}.asset-actions button:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-light);color:var(--color-text)}.asset-actions button.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.asset-actions button:disabled{opacity:.5;cursor:not-allowed}.use-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex:none;padding:4px 10px;font-size:.75rem}.use-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-light);color:var(--color-text)}.use-btn.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.use-btn:disabled{opacity:.7;cursor:default}.delete-btn{z-index:4;background:var(--delete-btn-bg);border:1px solid var(--delete-btn-border);color:#fff;border-radius:var(--radius-full);width:24px;height:24px;box-shadow:var(--delete-btn-shadow);justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:-10px;right:-10px}.delete-btn:hover:not(:disabled){background:var(--color-error);border-color:var(--color-error);color:#fff;transform:scale(1.04)}.delete-btn svg{fill:currentColor;width:14px;height:14px;display:block}.asset-type-label{text-align:center;color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;flex:1;padding:8px;font-size:.75rem;overflow:hidden}.preview-modal-overlay{background:var(--preview-overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.preview-modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:800px;overflow:hidden}.panel-modal-overlay{z-index:190;background:var(--panel-overlay-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);justify-content:center;align-items:center;padding:88px 40px 40px;display:flex;position:fixed;inset:0}.panel-modal{background:var(--panel-bg);border:1px solid var(--color-border);border-radius:24px;flex-direction:column;width:min(1120px,100%);max-height:calc(100vh - 140px);display:flex;overflow:hidden;box-shadow:0 28px 80px #00000073}.panel-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:20px;padding:22px 24px 18px;display:flex}.panel-modal-kicker{color:var(--color-accent);letter-spacing:.04em;margin-bottom:8px;font-size:.75rem;font-weight:700;display:inline-block}.panel-modal-header h3{color:var(--color-text);font-size:1.35rem}.panel-modal-close{border:1px solid var(--color-border);width:36px;height:36px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border-radius:12px;justify-content:center;align-items:center;display:flex}.panel-modal-close svg{fill:currentColor;width:18px;height:18px}.panel-modal-body{padding:22px 24px 24px;overflow:auto}.panel-asset-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;display:grid}.panel-empty-state{min-height:320px;color:var(--color-text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex}.panel-empty-state svg{fill:currentColor;width:28px;height:28px}.task-history-list{flex-direction:column;gap:8px;display:flex}.task-history-card{border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);flex-direction:column;gap:8px;padding:14px 16px;transition:border-color .15s;display:flex}.task-history-card:hover{border-color:var(--color-border-light)}.task-history-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.task-history-top-left{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;display:flex}.task-history-time{color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:.75rem}.task-history-meta{flex-wrap:wrap;gap:4px;display:flex}.task-history-meta span{border-radius:var(--radius-full);background:var(--color-bg-tertiary);color:var(--color-text-muted);padding:2px 7px;font-size:.7rem}.task-history-assets{flex-wrap:wrap;gap:4px;display:flex}.task-history-asset-tag{background:color-mix(in srgb, var(--color-primary) 10%, var(--color-surface));color:var(--color-primary);border-radius:var(--radius-full);padding:2px 7px;font-size:.7rem;font-weight:600}.task-history-asset-tag--frame{background:color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));color:var(--color-accent)}.task-history-prompt-wrap{flex-direction:column;gap:4px;display:flex}.task-history-prompt{color:var(--color-text);white-space:pre-wrap;word-break:break-all;font-size:.8125rem;line-height:1.6}.task-history-prompt.is-clamped{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.task-history-expand-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-size:.75rem}.task-history-expand-btn:hover{text-decoration:underline}.task-history-actions{border-top:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px;padding-top:2px;display:flex}.task-history-error{color:#fda4af;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.75rem;overflow:hidden}.task-history-action-group{align-items:center;gap:6px;display:flex}.task-history-link,.task-restore-btn{border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:3px 10px;font-size:.75rem;text-decoration:none;transition:all .15s}.task-history-link:hover,.task-restore-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent)}.project-switch-list{gap:14px;display:grid}.project-switch-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:18px;justify-content:space-between;align-items:center;gap:18px;padding:18px 20px;display:flex}.project-switch-card.is-current{border-color:#38bdf861;box-shadow:0 0 0 1px #38bdf82e}.project-switch-copy{gap:8px;min-width:0;display:grid}.project-switch-top{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.project-switch-top strong{color:var(--color-text);font-size:1rem}.project-switch-copy p{color:var(--color-text-secondary);line-height:1.6}.project-switch-meta{color:var(--color-text-muted);font-size:.8125rem}.project-current-badge{border-radius:var(--radius-full);color:#7dd3fc;background:#38bdf824;border:1px solid #38bdf83d;padding:5px 10px;font-size:.75rem;font-weight:700}.project-switch-btn{color:#f8fdff;cursor:pointer;min-width:132px;transition:all var(--transition-fast);background:linear-gradient(135deg,#0ea5e9eb,#38bdf8d1);border:1px solid #38bdf885;border-radius:12px;flex-shrink:0;padding:11px 18px;font-weight:700;box-shadow:0 12px 24px #0ea5e92e}.project-switch-btn:hover:not(:disabled){background:linear-gradient(135deg,#0284c7fa,#0ea5e9eb);border-color:#7dd3fceb;transform:translateY(-1px);box-shadow:0 16px 28px #0ea5e942}.project-switch-btn:disabled{opacity:.78;color:var(--color-text-muted);box-shadow:none;cursor:not-allowed;background:#38bdf81a;border-color:#38bdf833;transform:none}.preview-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.preview-modal-header h3{color:var(--color-text);font-size:1rem;font-weight:600}.preview-modal-close{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.preview-modal-close svg{width:20px;height:20px;fill:var(--color-text-secondary)}.preview-modal-body{background:var(--color-bg);justify-content:center;align-items:center;padding:20px;display:flex}.preview-modal-body img,.preview-modal-body video{border-radius:var(--radius-md);max-width:100%;max-height:60vh}.preview-modal-footer{border-top:1px solid var(--color-border);gap:12px;padding:16px 20px;display:flex}.preview-modal-footer button{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);padding:10px 20px;font-size:.875rem}.preview-modal-footer button:hover{background:var(--color-surface-hover)}.preview-modal-footer button.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.preview-modal-link{color:var(--color-primary);margin-left:auto;padding:10px 20px;font-size:.875rem;text-decoration:none}.preview-modal-link:hover{text-decoration:underline}.quick-modal-overlay{z-index:220;background:var(--modal-overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.quick-modal{background:var(--color-surface);border:1px solid var(--color-border);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:18px;padding:24px}.quick-modal h3{color:var(--color-text);margin:0 0 16px;font-size:1.125rem}.quick-modal-error{border-radius:var(--radius-md);border:1px solid var(--color-error);background:var(--color-error-light);color:var(--color-error);margin:0 0 16px;padding:10px 12px;font-size:.875rem}.quick-modal-field{margin-bottom:14px}.quick-modal-field label{color:var(--color-text-secondary);margin-bottom:6px;font-size:.875rem;display:block}.quick-modal-field input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-tertiary);width:100%;color:var(--color-text);padding:10px 12px;font-size:.9375rem}.quick-modal-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.quick-modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.quick-modal-actions button{border-radius:var(--radius-md);border:1px solid var(--color-border);cursor:pointer;padding:8px 14px;font-size:.875rem}.quick-modal-actions .secondary{color:var(--color-text-secondary);background:0 0}.quick-modal-actions .secondary:hover{color:var(--color-text);background:var(--color-surface-hover)}.quick-modal-actions .primary{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-alt));color:#fff;border-color:#0000}.quick-modal-actions .primary:disabled{opacity:.65;cursor:not-allowed}@media (width<=768px){.asset-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.dock-controls{flex-wrap:wrap}}.admin-panel{background:var(--color-bg);min-height:100vh}.admin-header{background:var(--header-glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.admin-header-left{align-items:center;gap:16px;display:flex}.admin-header-left h1{color:var(--color-text);font-size:1.25rem;font-weight:700}.back-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:8px 14px;font-size:.875rem;display:flex}.back-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.back-btn svg{fill:currentColor;width:16px;height:16px}.admin-header-right{align-items:center;gap:16px;display:flex}.admin-badge{background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius-full);color:var(--color-primary);padding:4px 10px;font-size:.75rem;font-weight:600}.user-name{color:var(--color-text-secondary);font-size:.875rem}.logout-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;background:0 0;padding:8px 16px;font-size:.875rem}.logout-btn:hover{border-color:var(--color-error);color:var(--color-error)}.admin-main{max-width:1200px;margin:0 auto;padding:32px}.admin-toolbar{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.admin-toolbar h2{color:var(--color-text);font-size:1.125rem;font-weight:600}.create-user-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-alt));border-radius:var(--radius-md);color:#fff;cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;display:flex}.create-user-btn svg{fill:currentColor;width:18px;height:18px}.admin-error{background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);margin-bottom:24px;padding:12px 16px}.users-table-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table th,.users-table td{text-align:left;padding:14px 16px;font-size:.875rem}.users-table th{background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-weight:600}.users-table td{border-top:1px solid var(--color-border);color:var(--color-text)}.users-table tr:hover td{background:var(--color-surface-hover)}.users-table tr.current-user td{background:var(--color-primary-light)}.status-badge{border-radius:var(--radius-full);padding:4px 10px;font-size:.75rem;font-weight:600}.status-badge.active{background:var(--color-success-light);color:var(--color-success)}.status-badge.inactive{background:var(--color-error-light);color:var(--color-error)}.role-badge{border-radius:var(--radius-full);padding:4px 10px;font-size:.75rem;font-weight:600}.role-badge.admin{background:var(--color-primary-light);color:var(--color-primary)}.role-badge.user{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.action-buttons{gap:8px;display:flex}.action-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;padding:6px 12px;font-size:.75rem}.action-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.action-btn.password:hover:not(:disabled){border-color:var(--color-warning);color:var(--color-warning)}.action-btn.delete:hover:not(:disabled){border-color:var(--color-error);color:var(--color-error)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{background:var(--modal-overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:32px}.modal-content h2{color:var(--color-text);margin-bottom:24px;font-size:1.25rem;font-weight:700}.modal-error{background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);margin-bottom:16px;padding:12px 16px;font-size:.875rem}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.btn-secondary{border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;background:0 0;padding:10px 20px;font-size:.875rem}.btn-secondary:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-primary{background:linear-gradient(135deg, var(--color-primary), #8b5cf6);border-radius:var(--radius-md);color:#fff;cursor:pointer;border:none;padding:10px 20px;font-size:.875rem;font-weight:600}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.modal-hint{color:var(--color-text-secondary);margin:-10px 0 16px;font-size:.875rem}.form-group{margin-bottom:16px}.form-group label{color:var(--color-text-secondary);margin-bottom:6px;font-size:.875rem;font-weight:500;display:block}.form-group input{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);padding:10px 14px;font-size:.9375rem}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.admin-loading{text-align:center;color:var(--color-text-secondary);padding:60px}
