@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;min-height:100vh}#root{min-height:100vh}:root{--c-bg: #f4f4f5;--c-bg-2: #ffffff;--c-bg-3: #f0f0f1;--c-bg-4: #e8e8ea;--c-border: #e2e2e5;--c-border-2: #d1d1d6;--c-text: #09090b;--c-text-2: #52525b;--c-text-3: #a1a1aa;--c-accent: #6366f1;--c-accent-2: #4f46e5;--c-accent-glow: rgba(99,102,241,.15);--c-accent-text: #ffffff;--c-green: #22c55e;--c-red: #ef4444;--c-amber: #f59e0b;--c-blue: #3b82f6;--c-shadow: rgba(0,0,0,.06);--c-shadow-lg: rgba(0,0,0,.12);--radius: 12px;--radius-sm: 7px;--radius-lg: 18px;--transition: .2s cubic-bezier(.4,0,.2,1)}html.dark{--c-bg: #09090b;--c-bg-2: #111113;--c-bg-3: #18181b;--c-bg-4: #27272a;--c-border: #27272a;--c-border-2: #3f3f46;--c-text: #fafafa;--c-text-2: #a1a1aa;--c-text-3: #52525b;--c-accent: #818cf8;--c-accent-2: #6366f1;--c-accent-glow: rgba(99,102,241,.2);--c-shadow: rgba(0,0,0,.5);--c-shadow-lg: rgba(0,0,0,.7)}body{background:var(--c-bg);color:var(--c-text);transition:background var(--transition),color var(--transition)}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;border:none;background:none;outline:none}input,select,textarea{outline:none;border:none;background:none}textarea{resize:vertical}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-border-2);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--c-text-3)}.label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-3)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.nav{height:56px;min-height:56px;flex-shrink:0;background:var(--c-bg-2);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.nav-logo{display:flex;align-items:center;gap:12px}.nav-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:900;color:#fff;flex-shrink:0;box-shadow:0 4px 14px #6366f166}.nav-logo-text{display:flex;flex-direction:column;gap:1px}.nav-logo-title{font-size:15px;font-weight:700;letter-spacing:-.3px;color:var(--c-text)}.nav-logo-title span{color:var(--c-accent)}.nav-logo-sub{font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--c-text-3)}.nav-right{display:flex;align-items:center;gap:8px}.nav-divider{width:1px;height:20px;background:var(--c-border);margin:0 4px}.theme-toggle{display:flex;align-items:center;background:var(--c-bg-3);border:1px solid var(--c-border);border-radius:999px;padding:3px;gap:2px}.theme-btn{width:30px;height:26px;border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--c-text-3);font-size:14px;transition:var(--transition)}.theme-btn.active{background:var(--c-bg-2);color:var(--c-accent);box-shadow:0 1px 4px var(--c-shadow)}.theme-btn:not(.active):hover{color:var(--c-text-2);background:var(--c-bg-4)}.nav-btn{display:flex;align-items:center;gap:6px;height:34px;padding:0 12px;border-radius:8px;font-size:12px;font-weight:600;transition:var(--transition);color:var(--c-text-2);background:var(--c-bg-3);border:1px solid var(--c-border)}.nav-btn:hover{background:var(--c-bg-4);color:var(--c-text);border-color:var(--c-border-2)}.nav-btn-active{background:var(--c-accent-glow);border-color:var(--c-accent);color:var(--c-accent)}.nav-btn-active:hover{background:var(--c-accent-glow);color:var(--c-accent)}.nav-btn-primary{background:var(--c-accent);color:var(--c-accent-text);border-color:var(--c-accent)}.nav-btn-primary:hover{background:var(--c-accent-2);border-color:var(--c-accent-2);color:#fff;box-shadow:0 4px 14px var(--c-accent-glow);transform:translateY(-1px)}.main{flex:1;min-height:0;display:grid;grid-template-columns:1fr 320px;gap:0;overflow:hidden}.workspace{display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--c-border)}.workspace-header{padding:12px 20px 10px;border-bottom:1px solid var(--c-border);background:var(--c-bg-2);flex-shrink:0}.workspace-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.workspace-title{font-size:16px;font-weight:800;letter-spacing:-.5px;color:var(--c-text)}.workspace-actions{display:flex;align-items:center;gap:8px}.workspace-stats{display:flex;align-items:center;gap:16px}.stat-chip{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--c-text-3)}.stat-dot{width:6px;height:6px;border-radius:50%}.stat-dot.done{background:var(--c-green)}.stat-dot.error{background:var(--c-red)}.stat-dot.idle{background:var(--c-border-2)}.stat-dot.processing{background:var(--c-accent);animation:pulse-dot 1.2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.workspace-body{flex:1;min-height:0;overflow-y:auto;padding:14px 20px 20px}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;border:2px dashed var(--c-border);border-radius:var(--radius-lg);background:var(--c-bg-2);cursor:pointer;transition:var(--transition);text-align:center}.drop-zone:hover,.drop-zone.dragging{border-color:var(--c-accent);background:var(--c-accent-glow)}.drop-zone-icon{width:64px;height:64px;border-radius:20px;background:var(--c-bg-3);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:20px;transition:var(--transition);border:1px solid var(--c-border)}.drop-zone:hover .drop-zone-icon,.drop-zone.dragging .drop-zone-icon{background:var(--c-accent-glow);border-color:var(--c-accent);transform:scale(1.05)}.drop-zone-title{font-size:18px;font-weight:700;color:var(--c-text);margin-bottom:8px}.drop-zone-sub{font-size:13px;color:var(--c-text-3);max-width:280px;line-height:1.6}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.image-card{background:var(--c-bg-2);border:1px solid var(--c-border);border-radius:var(--radius);overflow:hidden;transition:var(--transition);display:flex;flex-direction:column}.image-card:hover{border-color:var(--c-border-2);box-shadow:0 8px 28px var(--c-shadow);transform:translateY(-2px)}.image-card.status-done{border-left:3px solid var(--c-green)}.image-card.status-error{border-left:3px solid var(--c-red)}.image-card.status-captioning{border-left:3px solid var(--c-accent)}.card-thumb{position:relative;aspect-ratio:4 / 3;background:var(--c-bg-3);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}.card-thumb img{width:100%;height:100%;object-fit:contain;transition:opacity .3s ease;padding:4px}.card-selected{outline:2px solid var(--c-accent);outline-offset:-2px}.card-checkbox{position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:5px;border:2px solid rgba(255,255,255,.6);background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition),background var(--transition),border-color var(--transition)}.image-card:hover .card-checkbox,.card-selected .card-checkbox{opacity:1}.card-checkbox.checked{background:var(--c-accent);border-color:var(--c-accent)}.selection-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;margin-bottom:10px;border-radius:var(--radius);background:var(--c-accent-glow);border:1px solid var(--c-accent);animation:slideDown .15s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.selection-count{font-size:12px;font-weight:600;color:var(--c-accent)}.selection-actions{display:flex;align-items:center;gap:6px}.sel-btn{display:inline-flex;align-items:center;gap:5px;height:28px;padding:0 10px;border-radius:7px;font-size:11px;font-weight:600;background:var(--c-bg-3);border:1px solid var(--c-border);color:var(--c-text-2);cursor:pointer;transition:var(--transition)}.sel-btn:hover{background:var(--c-bg-4);color:var(--c-text);border-color:var(--c-border-2)}.sel-btn-danger{background:#ef444414;border-color:#ef444440;color:var(--c-red)}.sel-btn-danger:hover{background:#ef444426;border-color:#ef444480}.sel-btn:disabled{opacity:.4;cursor:not-allowed}.card-status-badge{position:absolute;top:8px;left:8px;display:flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid}.badge-idle{background:#00000080;color:#d4d4d4;border-color:#ffffff1a}.badge-captioning{background:#6366f1d9;color:#fff;border-color:#6366f166}.badge-done{background:#22c55ed9;color:#fff;border-color:#22c55e66}.badge-error{background:#ef4444d9;color:#fff;border-color:#ef444466}.card-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:var(--transition)}.image-card:hover .card-actions{opacity:1}.card-action-btn{width:26px;height:26px;border-radius:6px;background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;transition:var(--transition);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}.card-action-btn:hover{background:#000000e6}.card-action-btn.danger:hover{background:var(--c-red)}.card-body{padding:10px 12px 8px;flex:1;min-height:0;display:flex;flex-direction:column;gap:6px}.card-name-row{display:flex;align-items:center;gap:6px}.card-name{flex:1;font-size:11px;font-weight:600;color:var(--c-text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-expand-btn{flex-shrink:0;width:22px;height:22px;border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--c-text-3);background:transparent;border:1px solid transparent;transition:var(--transition);cursor:pointer}.card-expand-btn:hover{background:var(--c-bg-4);border-color:var(--c-border);color:var(--c-accent)}.caption-expanded{min-height:220px!important;height:auto!important;max-height:none!important;resize:vertical;transition:min-height var(--transition)}.card-expand-btn.active{color:var(--c-accent);background:var(--c-accent-glow);border-color:var(--c-accent)}.card-caption-area{flex:1}.card-caption{width:100%;min-height:72px;font-size:12px;color:var(--c-text);background:var(--c-bg-3);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:8px 10px;line-height:1.6;resize:vertical;transition:border-color var(--transition)}.card-caption:focus{border-color:var(--c-accent);background:var(--c-bg-2)}.card-caption.caption-error{color:var(--c-red);border-color:#ef44444d;background:#ef44440d}.card-caption::placeholder{color:var(--c-text-3)}.card-toolbar{display:flex;align-items:center;gap:4px;padding:8px 10px;border-top:1px solid var(--c-border);background:var(--c-bg-3);flex-shrink:0;justify-content:space-between}.card-expanded .card-body{display:flex;flex-direction:column}.card-expanded .card-toolbar{border-top:1px solid var(--c-border);border-left:none}.card-toolbar-left,.card-toolbar-right{display:flex;align-items:center;gap:4px}.ctb{display:flex;align-items:center;gap:4px;height:26px;padding:0 8px;border-radius:6px;font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--c-text-3);background:transparent;border:1px solid transparent;transition:var(--transition);white-space:nowrap;cursor:pointer}.ctb:hover{background:var(--c-bg-4);color:var(--c-text);border-color:var(--c-border)}.ctb.ctb-primary{color:var(--c-accent)}.ctb.ctb-primary:hover{background:var(--c-accent-glow);border-color:var(--c-accent);color:var(--c-accent)}.ctb.ctb-danger{color:var(--c-text-3)}.ctb.ctb-danger:hover{background:#ef444414;border-color:#ef444440;color:var(--c-red)}.ctb:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.ctb svg{flex-shrink:0}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:6px}.icon-btn{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--c-text-3);font-size:13px;transition:var(--transition);background:transparent}.icon-btn:hover{background:var(--c-bg-4);color:var(--c-text)}.icon-btn.danger:hover{background:#ef44441a;color:var(--c-red)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .7s linear infinite;display:inline-block}.sidebar{display:flex;flex-direction:column;overflow:hidden;background:var(--c-bg-2);height:100%;min-height:0}.sidebar-header{padding:14px 16px 12px;border-bottom:1px solid var(--c-border);flex-shrink:0}.sidebar-header-title{font-size:13px;font-weight:700;color:var(--c-text);margin-bottom:3px}.sidebar-header-sub{font-size:11px;color:var(--c-text-3)}.sidebar-body{flex:1;min-height:0;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:16px}.setting-group{display:flex;flex-direction:column;gap:12px}.setting-group-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-3);display:flex;align-items:center;gap:6px}.setting-group-title:after{content:"";flex:1;height:1px;background:var(--c-border)}.setting-item{display:flex;flex-direction:column;gap:4px}.setting-label{font-size:11px;font-weight:600;color:var(--c-text-2)}.ps-select{width:100%;height:32px;padding:0 28px 0 9px;background:var(--c-bg-3);border:1px solid var(--c-border);border-radius:7px;font-size:12px;font-weight:500;color:var(--c-text);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;cursor:pointer;transition:var(--transition)}.ps-select:focus,.ps-select:hover{border-color:var(--c-accent);background-color:var(--c-bg-2)}.ps-select option{background:var(--c-bg-3);color:var(--c-text)}.seg-control{display:flex;background:var(--c-bg-3);border:1px solid var(--c-border);border-radius:7px;padding:2px;gap:2px}.seg-btn{flex:1;height:25px;border-radius:5px;font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--c-text-3);transition:var(--transition)}.seg-btn.active{background:var(--c-bg-2);color:var(--c-text);box-shadow:0 1px 4px var(--c-shadow)}.seg-btn:not(.active):hover{background:var(--c-bg-4);color:var(--c-text-2)}.ps-input{width:100%;height:32px;padding:0 9px;background:var(--c-bg-3);border:1px solid var(--c-border);border-radius:7px;font-size:12px;font-weight:500;color:var(--c-text);transition:var(--transition)}.ps-input:focus,.ps-input:hover{border-color:var(--c-accent);background:var(--c-bg-2)}.ps-input::placeholder{color:var(--c-text-3)}.concurrency-hint{font-size:10px;color:var(--c-text-3);line-height:1.5;padding:3px 2px 0}.toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:500;color:var(--c-text-2)}.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{width:36px;height:20px;border-radius:999px;background:var(--c-bg-4);border:1px solid var(--c-border-2);transition:background var(--transition),border-color var(--transition);position:relative}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--c-text-3);transition:var(--transition)}.toggle input:checked+.toggle-track:after{transform:translate(16px);background:#fff}.sidebar-footer{padding:10px 16px 12px;border-top:1px solid var(--c-border);flex-shrink:0;display:flex;flex-direction:column;gap:6px;background:var(--c-bg-2)}.run-btn{width:100%;height:38px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition);position:relative;overflow:hidden}.run-btn-start{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 18px #6366f159}.run-btn-start:hover{transform:translateY(-1px);box-shadow:0 6px 24px #6366f180}.run-btn-start:active{transform:translateY(0)}.run-btn-start:disabled{opacity:.4;cursor:not-allowed;transform:none}.run-btn-stop{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 18px #ef444459}.run-btn-stop:hover{box-shadow:0 6px 24px #ef444480}.sub-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}.sub-btn{height:30px;border-radius:7px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;background:var(--c-bg-3);border:1px solid var(--c-border);color:var(--c-text-2);transition:var(--transition)}.sub-btn:hover{background:var(--c-bg-4);border-color:var(--c-border-2);color:var(--c-text)}.sub-btn:disabled{opacity:.3;cursor:not-allowed}.progress-bar-wrap{width:100%;height:4px;background:var(--c-bg-4);border-radius:999px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1)}.progress-info{display:flex;align-items:center;justify-content:space-between;font-size:10px;font-weight:600;color:var(--c-text-3)}.ambient{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;overflow:hidden}.ambient-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.07}html.dark .ambient-blob{opacity:.12}.ambient-blob-1{width:600px;height:600px;background:#6366f1;top:-200px;right:-100px}.ambient-blob-2{width:400px;height:400px;background:#8b5cf6;bottom:-100px;left:-100px}.toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:500;color:var(--c-text-2)}.toggle{position:relative;width:36px;height:20px}.toggle input{opacity:0;width:0;height:0}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--c-bg-4);border:1px solid var(--c-border);border-radius:999px;cursor:pointer;transition:var(--transition)}.toggle input:checked+.toggle-track{background:var(--c-accent);border-color:var(--c-accent)}.toggle-track:after{content:"";position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:2px;left:2px;transition:var(--transition);box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-track:after{left:18px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--c-bg-3) 25%,var(--c-bg-4) 50%,var(--c-bg-3) 75%);background-size:800px 100%;animation:shimmer 1.5s infinite;border-radius:6px}.empty-grid-card{aspect-ratio:16/10;border:2px dashed var(--c-border);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--c-text-3);font-size:11px;font-weight:500;gap:6px;transition:var(--transition);cursor:pointer}.empty-grid-card:hover{border-color:var(--c-accent);color:var(--c-accent);background:var(--c-accent-glow)}
