:root{--bg: #f1f5f9;--surface: #fff;--text: #1e293b;--muted: #64748b;--border: #e2e8f0;--accent: #2563eb;--accent-hover: #1d4ed8;--nav: rgb(82, 53, 227);--scrollbar-track: #e8edf3;--scrollbar-thumb: #94a3b8;--scrollbar-thumb-hover: #64748b}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--text: #e2e8f0;--muted: #94a3b8;--border: #334155;--accent: #3b82f6;--accent-hover: #2563eb;--nav: #1e293b;--scrollbar-track: #0f172a;--scrollbar-thumb: #475569;--scrollbar-thumb-hover: #64748b}html,body,#root{height:100%;width:100%;max-width:100vw;margin:0;overflow:hidden}body{font-family:DM Sans,system-ui,sans-serif;background:var(--bg);color:var(--text)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:100px}*::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:100px;border:2px solid var(--scrollbar-track);background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover);border:2px solid var(--scrollbar-track)}*::-webkit-scrollbar-corner{background:var(--scrollbar-track)}.app-root{display:flex;flex-direction:column;width:100%;max-width:100vw;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden;margin:0 auto}.app-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:var(--nav);color:#f1f5f9;flex-wrap:wrap;border-bottom:1px solid var(--border)}.app-nav-path{flex:1;min-width:0;display:flex;flex-direction:row;align-items:center;gap:8px}.app-nav-path>strong{flex-shrink:0}.app-nav-breadcrumb{font-size:13px;min-width:0;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.5) transparent}.app-nav-crumb{background:none;border:none;color:#93c5fd;cursor:pointer;padding:0;font:inherit}.app-nav-crumb:hover{text-decoration:underline}.app-nav a{color:#93c5fd}.app-nav-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:6px;flex-shrink:0;max-width:100%}.nav-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.375rem;height:2.375rem;padding:0;border-radius:8px;border:1px solid rgba(148,163,184,.55);background:transparent;color:#e2e8f0;cursor:pointer;text-decoration:none;font-family:inherit}.nav-icon-btn:hover{border-color:#93c5fd;color:#93c5fd}.nav-icon-btn:disabled{opacity:.45;cursor:not-allowed}.nav-icon-btn.nav-icon-danger{color:#f87171;border-color:#f8717173}.nav-icon-btn.nav-icon-danger:hover:not(:disabled){border-color:#f87171;color:#fca5a5}.nav-icon-btn svg{flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px}.modal-box{background:var(--surface);color:var(--text);border-radius:12px;padding:20px 24px;max-width:420px;width:100%;box-shadow:0 20px 50px #00000040}.modal-box--wide{max-width:min(560px,100%)}.modal-box h3{margin:0 0 12px;font-size:18px}.modal-box p{margin:0 0 12px;font-size:14px;color:var(--muted);word-break:break-all}.modal-box input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;margin-bottom:16px}.modal-paths-label{margin:0 0 6px;font-size:13px;color:var(--text)}.modal-paths{margin:0 0 12px;padding:10px 12px;max-height:200px;min-height:2.75rem;overflow:auto;font-size:12px;line-height:1.45;background:var(--bg);border:1px solid var(--border);border-radius:8px;white-space:pre-wrap;word-break:break-all;font-family:ui-monospace,Cascadia Code,monospace}.modal-dest-wrap{position:relative;margin-bottom:16px}.modal-dest-wrap input{margin-bottom:0}.modal-dest-suggest{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:10;max-height:220px;overflow-y:auto;margin:0;padding:4px 0;list-style:none;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 28px #0003}.modal-dest-suggest li{padding:8px 12px;font-size:12px;line-height:1.35;font-family:ui-monospace,Cascadia Code,monospace;color:var(--text);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-dest-suggest li:hover,.modal-dest-suggest li.active{background:var(--bg)}.modal-dest-suggest-placeholder{cursor:default;color:var(--muted);font-family:inherit}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.modal-actions button{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;font-family:inherit}.modal-actions button.primary{background:var(--accent);border-color:var(--accent);color:#fff}.app-main{display:flex;flex:1;min-height:0}.sidebar{min-height:0;border-right:none;background:var(--surface);display:flex;flex-direction:column;overflow:hidden}.sidebar-resizer{flex-shrink:0;width:6px;margin-left:-3px;margin-right:-3px;cursor:col-resize;background:transparent;box-shadow:inset 1px 0 0 var(--border);position:relative;z-index:2;touch-action:none}.sidebar-resizer:hover,.sidebar-resizer:focus-visible{background:var(--accent);opacity:.45}.sidebar-resizer:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;opacity:1}.sidebar-search{padding:10px;border-bottom:1px solid var(--border)}.sidebar-search input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text)}.upload-panel{flex-shrink:0;padding:0 10px 10px;border-bottom:1px solid var(--border)}.upload-panel-path{margin:0 0 8px;font-size:11px;line-height:1.35;color:var(--muted);word-break:break-all}.upload-panel-path-label{font-weight:600;color:var(--text)}.upload-panel-path-value{font-family:ui-monospace,Cascadia Code,monospace;font-size:10px}.upload-dropzone{position:relative;border:2px dashed var(--border);border-radius:10px;padding:18px 14px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.upload-dropzone-active{border-color:var(--accent);background:#2563eb14}.upload-dropzone-disabled{opacity:.45;cursor:not-allowed}.upload-dropzone-text{font-size:14px;color:var(--text);margin-bottom:6px}.upload-dropzone-sub{font-size:12px;color:var(--muted)}.upload-panel-file-input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.upload-jobs-header{display:flex;justify-content:space-between;align-items:center;margin:10px 0 6px;font-size:12px;color:var(--muted)}.upload-jobs-clear{border:none;background:transparent;color:var(--accent);cursor:pointer;font-size:12px;font-family:inherit;padding:2px 6px}.upload-jobs-clear:hover{text-decoration:underline}.upload-job-list{list-style:none;margin:0;padding:0;max-height:240px;overflow-y:auto}.upload-job-card{margin-bottom:10px;padding:10px 12px;border-radius:8px;border:1px solid var(--border);background:var(--bg)}.upload-job-card.error{border-color:#b91c1c73}.upload-job-name{font-size:13px;color:var(--text);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-job-bar-wrap{height:8px;border-radius:4px;background:#94a3b840;overflow:hidden;margin-bottom:6px}[data-theme=dark] .upload-job-bar-wrap{background:#94a3b81f}.upload-job-bar{height:100%;border-radius:4px;background:var(--accent);transition:width .12s ease-out}.upload-job-meta{display:flex;gap:12px;font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}.upload-job-eta{flex:1;min-width:0;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-menu{position:fixed;z-index:4000;min-width:220px;padding:6px 0;margin:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 12px 40px #0000002e}.context-menu-meta{padding:6px 14px 8px;font-size:11px;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:4px}.context-menu-meta-subtle{word-break:break-all}.context-menu-sep{height:1px;margin:6px 0;background:var(--border);border:none;padding:0}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 14px;border:none;background:transparent;color:var(--text);font-size:13px;text-align:left;cursor:pointer;font-family:inherit}.context-menu-item svg{width:17px;height:17px;flex-shrink:0}.context-menu-item>span{flex:1;min-width:0}.context-menu-item:hover:not(:disabled){background:var(--bg)}.context-menu-item:disabled{opacity:.45;cursor:not-allowed}.context-menu-item.danger{color:#b91c1c}[data-theme=dark] .context-menu-item.danger{color:#f87171}.context-menu-item.danger:hover:not(:disabled){background:#b91c1c1f}.file-list{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:8px;-webkit-overflow-scrolling:touch;outline:none;container-type:inline-size;container-name:filelist}.file-list:focus-visible{box-shadow:inset 0 0 0 2px #2563eb59;border-radius:8px}.file-row{display:grid;grid-template-columns:minmax(0,1fr);gap:0 10px;align-items:center;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:14px;-webkit-user-select:none;user-select:none}.file-row-icon-label{display:flex;align-items:center;gap:6px;min-width:0}.file-row-emoji{flex-shrink:0}.file-row-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-row-size,.file-row-mtime{display:none;font-size:11px;line-height:1.3;color:var(--muted);white-space:nowrap;justify-self:end;font-variant-numeric:tabular-nums}@container filelist (min-width: 380px){.file-row{grid-template-columns:minmax(0,1fr) minmax(3.5rem,max-content) minmax(6.5rem,max-content)}.file-row-size,.file-row-mtime{display:block}}.file-row:hover{background:var(--bg)}.file-row.selected{background:#2563eb2e;outline:1px solid rgba(37,99,235,.35)}.file-row.active{background:#2563eb1f}.file-row.selected.active{background:#2563eb38}.editor-pane{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;background:var(--surface)}.editor-toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);flex-wrap:wrap}.editor-toolbar button{padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:13px}.editor-toolbar button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.editor-toolbar button.primary:hover{background:var(--accent-hover)}.editor-toolbar button:disabled{opacity:.5;cursor:not-allowed}.editor-wrap{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.editor-empty{flex:1;display:flex;flex-direction:column;align-items:stretch;justify-content:center;min-height:0;padding:24px;overflow:auto}.upload-panel--editor{border-bottom:none;padding:0;flex:0 1 auto;max-width:520px;width:100%;margin:0 auto}.upload-panel--editor .upload-panel-path{text-align:center;margin-bottom:14px}.upload-panel--editor .upload-dropzone{padding:36px 28px;min-height:148px;display:flex;flex-direction:column;justify-content:center;align-items:center}.upload-panel--editor .upload-dropzone-text{font-size:16px}.upload-panel--editor .upload-job-list{max-height:min(40vh,280px)}.login-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#1e293b,#0f172a)}.login-card{width:100%;max-width:380px;padding:32px;background:#1e293b;border-radius:12px;color:#e2e8f0;box-shadow:0 20px 40px #0000004d}.login-card h1{margin:0 0 8px;font-size:22px}.login-card label{display:block;font-size:13px;color:#94a3b8;margin:16px 0 6px}.login-card input{width:100%;padding:12px 14px;border-radius:8px;border:1px solid #334155;background:#0f172a;color:#e2e8f0}.login-card button{width:100%;margin-top:24px;padding:12px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-weight:600;cursor:pointer}.login-error{margin-top:12px;color:#fca5a5;font-size:14px}.app-route-loading{display:flex;align-items:center;justify-content:center;min-height:100%;padding:24px;color:var(--muted);font-size:15px}.empty-state{padding:24px;color:var(--muted)}.toast{position:fixed;top:24px;right:24px;max-width:min(360px,calc(100vw - 32px));padding:12px 16px;font-size:14px;font-weight:600;line-height:1.35;color:#fff;border-radius:8px;box-shadow:0 10px 28px #00000038;z-index:5000}.toast-success{background:#15803d}.toast-error{background:#b91c1c}.toast-warning{background:#b45309}.toast-info{background:#1d4ed8}
