@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1623;--bg-card: #1a2332;--bg-hover: #1e2a3a;--bg-input: #1e2a3a;--bg-muted: #1a2332;--surface-0: #0f1623;--surface-1: #1a2332;--surface-2: #1e2a3a;--surface-3: #243044;--c-bg: #0f1623;--c-surface: #1a2332;--c-surface2: #1e2a3a;--c-surface3: #243044;--border: #2a3a52;--border-1: #2a3a52;--border-2: #334866;--c-border: #2a3a52;--c-border2: #334866;--text-1: #f1f5f9;--text-2: #94a3b8;--text-3: #64748b;--text-4: #3d5068;--text-muted: #64748b;--c-text1: #f1f5f9;--c-text2: #94a3b8;--c-text3: #64748b;--c-text4: #3d5068;--brand: #22c55e;--brand-h: #16a34a;--brand-muted: rgba(34,197,94,.1);--brand-dim: rgba(34,197,94,.1);--brand-border: rgba(34,197,94,.22);--brand-light: #86efac;--c-brand: #22c55e;--c-brand-h: #16a34a;--c-brand-bg: rgba(34,197,94,.1);--c-brand-br: rgba(34,197,94,.22);--ok: #22c55e;--ok-bg: rgba(34,197,94,.1);--ok-border: rgba(34,197,94,.22);--red: #f87171;--red-border: rgba(248,113,113,.22);--err: #f87171;--err-bg: rgba(248,113,113,.08);--err-border: rgba(248,113,113,.22);--c-red: #f87171;--c-red-bg: rgba(248,113,113,.08);--c-red-br: rgba(248,113,113,.22);--amber: #fbbf24;--c-amber: #fbbf24;--blue: #60a5fa;--blue-muted: rgba(96,165,250,.1);--blue-border: rgba(96,165,250,.22);--c-blue: #60a5fa;--c-blue-bg: rgba(96,165,250,.1);--c-blue-br: rgba(96,165,250,.22);--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-full: 999px;--radius: 8px;--radius-sm: 6px;--radius-lg: 12px;--radius-xl: 16px;--shadow: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 24px rgba(0,0,0,.5);--shadow-sm: 0 1px 2px rgba(0,0,0,.3)}body.light{--bg: #f1f5f9;--bg-card: #ffffff;--bg-hover: #f8fafc;--bg-input: #ffffff;--bg-muted: #f8fafc;--surface-0: #f1f5f9;--surface-1: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--c-bg: #f1f5f9;--c-surface: #ffffff;--c-surface2: #f8fafc;--c-surface3: #f1f5f9;--border: #e2e8f0;--border-1: #e2e8f0;--border-2: #cbd5e1;--c-border: #e2e8f0;--c-border2: #cbd5e1;--text-1: #0f172a;--text-2: #475569;--text-3: #94a3b8;--text-4: #cbd5e1;--text-muted: #94a3b8;--c-text1: #0f172a;--c-text2: #475569;--c-text3: #94a3b8;--c-text4: #cbd5e1;--brand: #16a34a;--brand-h: #15803d;--brand-muted: rgba(22,163,74,.08);--brand-dim: rgba(22,163,74,.08);--brand-border: rgba(22,163,74,.22);--c-brand: #16a34a;--c-brand-h: #15803d;--c-brand-bg: rgba(22,163,74,.08);--c-brand-br: rgba(22,163,74,.22);--ok: #16a34a;--ok-bg: rgba(22,163,74,.08);--ok-border: rgba(22,163,74,.22);--red: #ef4444;--err: #ef4444;--err-bg: rgba(239,68,68,.06);--err-border: rgba(239,68,68,.22);--c-red: #ef4444;--c-red-bg: rgba(239,68,68,.06);--c-red-br: rgba(239,68,68,.22);--blue: #3b82f6;--blue-muted: rgba(59,130,246,.08);--blue-border: rgba(59,130,246,.22);--c-blue: #3b82f6;--c-blue-bg: rgba(59,130,246,.08);--c-blue-br: rgba(59,130,246,.22);--shadow: 0 1px 3px rgba(0,0,0,.07);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--shadow-sm: 0 1px 2px rgba(0,0,0,.05)}html{-webkit-font-smoothing:antialiased}body{font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5;background:var(--bg);color:var(--text-1);transition:background .2s,color .2s;min-height:100vh}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;overflow-y:auto;min-width:0}.page{max-width:1000px;margin:0 auto;padding:28px 22px}.sidebar{width:220px;flex-shrink:0;background:var(--surface-1);border-right:1px solid var(--border-1);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{padding:16px 14px;border-bottom:1px solid var(--border-1);display:flex;align-items:center;gap:10px}.sidebar-nav{flex:1;padding:8px 6px;display:flex;flex-direction:column;gap:1px}.nav-section-label{font-size:10px;font-weight:600;color:var(--text-4);text-transform:uppercase;letter-spacing:.08em;padding:12px 10px 4px}.nav-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--r-md);font-size:13px;font-weight:400;color:var(--text-3);cursor:pointer;transition:all .12s;border:none;background:none;width:100%;text-align:left}.nav-item svg{flex-shrink:0}.nav-item:hover{background:var(--surface-2);color:var(--text-1)}.nav-item.active{background:var(--brand-muted);color:var(--brand);font-weight:500}.sidebar-footer{padding:8px 6px;border-top:1px solid var(--border-1)}.user-card{display:flex;align-items:center;gap:8px;padding:8px 10px}.user-avatar{width:27px;height:27px;border-radius:50%;background:var(--brand-muted);border:1px solid var(--brand-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--brand);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:12px;font-weight:500;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:10px;color:var(--text-4);text-transform:uppercase;letter-spacing:.04em}.logout-btn{width:24px;height:24px;border-radius:var(--r-sm);border:none;background:none;color:var(--text-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}.logout-btn:hover{background:var(--err-bg);color:var(--err)}.card{background:var(--bg-card);border:1px solid var(--border-1);border-radius:var(--r-xl);padding:20px}.card-sm{background:var(--bg-card);border:1px solid var(--border-1);border-radius:var(--r-lg);padding:14px 16px}.card-inner{background:var(--surface-2);border:1px solid var(--border-1);border-radius:var(--r-md);padding:12px 14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:0 13px;height:32px;border:none;border-radius:var(--r-md);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap;line-height:1}.btn:disabled{opacity:.38;cursor:not-allowed}.btn-primary{background:var(--brand);color:#000;font-weight:600}.btn-primary:hover:not(:disabled){background:var(--brand-h)}.btn-secondary{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border-1)}.btn-secondary:hover:not(:disabled){background:var(--surface-3);color:var(--text-1)}.btn-ghost{background:transparent;color:var(--text-3);border:1px solid var(--border-1)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text-1)}.btn-danger{background:var(--err-bg);color:var(--err);border:1px solid var(--err-border)}.btn-danger:hover:not(:disabled){background:#f8717124}.btn-success{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-border)}.btn-success:hover:not(:disabled){background:#22c55e29}.btn-brand{background:var(--brand);color:#000;font-weight:600;border:1px solid var(--brand)}.btn-brand:hover:not(:disabled){background:var(--brand-h)}.btn-lg{height:36px;padding:0 16px;font-size:14px;border-radius:var(--r-lg)}.btn-sm{height:27px;padding:0 10px;font-size:12px;border-radius:var(--r-sm)}.btn-xs{height:23px;padding:0 8px;font-size:11px;border-radius:var(--r-sm)}.input,.textarea,.select{width:100%;background:var(--bg-input);border:1px solid var(--border-2);border-radius:var(--r-md);color:var(--text-1);font-family:inherit;font-size:13px;padding:7px 11px;outline:none;transition:border-color .15s,box-shadow .15s}.input::placeholder,.textarea::placeholder{color:var(--text-4)}.input:focus,.textarea:focus,.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-muted)}.textarea{resize:vertical;font-family:JetBrains Mono,monospace;font-size:12.5px;line-height:1.7}.textarea.prose{font-family:inherit;font-size:13px}.select{cursor:pointer;height:32px;padding:0 11px}.select option,.select optgroup{background:var(--bg-input);color:var(--text-1)}.input-mono{font-family:JetBrains Mono,monospace;font-size:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--r-full);font-size:11px;font-weight:500;border:1px solid}.badge-pending{background:var(--surface-2);color:var(--text-3);border-color:var(--border-1)}.badge-processing{background:var(--brand-muted);color:var(--brand);border-color:var(--brand-border)}.badge-done{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-border)}.badge-error{background:var(--err-bg);color:var(--err);border-color:var(--err-border)}.badge-admin{background:#fbbf2414;color:var(--amber);border-color:#fbbf2433}.badge-va{background:var(--blue-muted);color:var(--blue);border-color:var(--blue-border)}.toggle{position:relative;display:inline-flex;width:36px;height:20px;cursor:pointer;flex-shrink:0}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-2);border-radius:var(--r-full);transition:.2s}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px #0000004d}.toggle input:checked+.toggle-slider{background:var(--brand)}.toggle input:checked+.toggle-slider:before{left:18px;background:#000}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:9px 14px;font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-1);background:var(--surface-2);white-space:nowrap}.table td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--border-1);color:var(--text-2)}.table tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--surface-2)}.progress-bar{height:3px;background:var(--surface-3);border-radius:var(--r-full);overflow:hidden}.progress-fill{height:100%;background:var(--brand);border-radius:var(--r-full);transition:width .5s}.spinner{border:2px solid var(--border-2);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dots{display:flex;gap:4px;align-items:center}.dots span{width:6px;height:6px;border-radius:50%;background:var(--text-3);animation:dot-b 1.4s ease-in-out infinite}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes dot-b{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.info-box{background:var(--brand-muted);border:1px solid var(--brand-border);border-radius:var(--r-md);padding:10px 12px;font-size:12.5px;color:var(--text-2);line-height:1.6}.warn-box{background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:var(--r-md);padding:10px 12px;font-size:12.5px;color:var(--amber)}.err-box{background:var(--err-bg);border:1px solid var(--err-border);border-radius:var(--r-md);padding:10px 12px;font-size:12.5px;color:var(--err)}.tab-bar{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--border-1);border-radius:var(--r-lg);padding:3px;margin-bottom:20px}.tab-btn{flex:1;height:30px;border:none;border-radius:var(--r-md);font-family:inherit;font-size:12.5px;font-weight:400;color:var(--text-3);background:transparent;cursor:pointer;transition:all .12s}.tab-btn:hover{color:var(--text-1);background:var(--surface-3)}.tab-btn.active{background:var(--surface-1);color:var(--text-1);font-weight:600;box-shadow:var(--shadow)}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:10px 16px;border-radius:var(--r-lg);border:1px solid;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);animation:toast-in .2s ease;max-width:320px}@keyframes toast-in{0%{opacity:0;transform:translate(8px)}to{opacity:1}}.toast-ok{background:var(--surface-1);border-color:var(--ok-border);color:var(--ok)}.toast-err{background:var(--surface-1);border-color:var(--err-border);color:var(--err)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--surface-1);border:1px solid var(--border-1);border-radius:var(--r-xl);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-in .15s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.modal-header{padding:20px 20px 0}.modal-body{padding:14px 20px}.modal-footer{padding:0 20px 20px;display:flex;gap:8px;justify-content:flex-end}.queue-card{background:var(--bg-card);border:1px solid var(--border-1);border-left:2px solid var(--border-1);border-radius:var(--r-xl);overflow:hidden;transition:box-shadow .15s}.queue-card.status-processing,.queue-card.status-done{border-left-color:var(--brand)}.queue-card.status-error{border-left-color:var(--err)}.output-panel{margin:0 14px 10px;border:1px solid var(--border-1);border-radius:var(--r-lg);overflow:hidden;transition:border-color .15s}.output-panel.editing{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-muted)}.output-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface-2);border-bottom:1px solid var(--border-1);min-height:36px;gap:8px}.output-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3)}.output-actions{display:flex;gap:4px;flex-wrap:wrap;align-items:center}.output-body{padding:12px 14px;font-size:13px;color:var(--text-2);white-space:pre-wrap;line-height:1.7;max-height:280px;overflow-y:auto;background:var(--bg-card)}.output-body.mono{font-family:JetBrains Mono,monospace;font-size:12px}.output-refine{padding:8px 12px;background:var(--surface-2);border-top:1px solid var(--border-1);display:flex;gap:6px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{width:44px;height:44px;border-radius:var(--r-lg);background:var(--surface-2);border:1px solid var(--border-1);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.empty-title{font-size:14px;font-weight:500;color:var(--text-2);margin-bottom:4px}.empty-desc{font-size:13px;color:var(--text-3)}.divider{height:1px;background:var(--border-1);margin:16px 0}code{font-family:JetBrains Mono,monospace;font-size:11.5px;background:var(--surface-2);border:1px solid var(--border-1);padding:1px 5px;border-radius:4px;color:var(--brand)}label{font-size:12px;font-weight:500;color:var(--text-2);display:block}.form-group{display:flex;flex-direction:column;gap:5px}.form-hint{font-size:11.5px;color:var(--text-3);line-height:1.5}.ph-tag{display:inline-flex;align-items:center;height:20px;padding:0 7px;border-radius:var(--r-full);font-size:11px;font-family:JetBrains Mono,monospace;cursor:pointer;border:1px solid;transition:opacity .12s;-webkit-user-select:none;user-select:none}.ph-tag:hover{opacity:.7}.ph-green{background:var(--brand-muted);border-color:var(--brand-border);color:var(--brand)}.ph-blue{background:var(--blue-muted);border-color:var(--blue-border);color:var(--blue)}.fade-in{animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(3px)}to{opacity:1}}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.w-full{width:100%}.ml-auto{margin-left:auto}.shrink-0{flex-shrink:0}.min-w-0{min-width:0}.flex-1{flex:1}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.sidebar{display:none}.grid-2,.grid-3{grid-template-columns:1fr}}
