@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@300;400;500&family=Instrument+Sans:wght@400;500;600;700&display=swap";:root{--bg-primary: #0d0f14;--bg-secondary: #141720;--bg-tertiary: #1a1e2a;--bg-elevated: #1f2435;--border-subtle: rgba(255, 255, 255, .06);--border-active: rgba(255, 255, 255, .12);--text-primary: #e8eaf0;--text-secondary: #8b90a0;--text-muted: #555a6e;--accent-blue: #3B82F6;--accent-green: #10B981;--accent-orange: #F59E0B;--accent-red: #EF4444;--font-display: "Instrument Sans", sans-serif;--font-mono: "DM Mono", monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--glow-blue: 0 0 20px rgba(59, 130, 246, .15);--glow-green: 0 0 20px rgba(16, 185, 129, .15);--transition: .15s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-display);font-size:13px;-webkit-font-smoothing:antialiased}#app{display:flex;flex-direction:column;height:100vh;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(59,130,246,.03) 0%,transparent 60%),var(--bg-primary)}#toolbar-container{flex-shrink:0}.toolbar{display:flex;align-items:center;gap:16px;height:48px;padding:0 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:relative;z-index:100}.toolbar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(59,130,246,.3) 30%,rgba(16,185,129,.3) 70%,transparent 100%)}.toolbar-title{font-family:var(--font-mono);font-weight:500;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary);-webkit-user-select:none;user-select:none;position:relative;padding-left:14px}.toolbar-title:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 8px #10b98180;animation:pulse-dot 3s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.toolbar-spacer{flex:1}.toolbar-btn-group{display:flex;gap:2px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--border-subtle)}.toolbar-btn{all:unset;font-family:var(--font-mono);font-size:11px;font-weight:400;letter-spacing:.06em;padding:5px 14px;border-radius:3px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.toolbar-btn:hover{color:var(--text-secondary);background:#ffffff08}.toolbar-btn-active{color:var(--text-primary);background:var(--bg-tertiary);box-shadow:inset 0 1px #ffffff0a}.toolbar-select{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:5px 10px;cursor:pointer;outline:none;transition:border-color var(--transition);max-width:160px}.toolbar-select:focus{border-color:var(--accent-blue)}.toolbar-select option{background:var(--bg-secondary);color:var(--text-primary)}.toolbar-hints{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.04em;-webkit-user-select:none;user-select:none}.bottom-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-elevated);border:1px solid var(--border-active);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;z-index:800;box-shadow:0 -4px 24px #0000004d}.edge-tooltip{position:fixed;pointer-events:none;z-index:1000;background:var(--bg-elevated);border:1px solid var(--border-active);border-radius:var(--radius-sm);padding:6px 10px;max-width:260px;font-family:var(--font-display);display:none}.edge-tooltip-title{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.3}.edge-tooltip-desc{font-size:11px;color:var(--text-secondary);margin-top:2px;line-height:1.3}#main-area{display:flex;flex:1;overflow:hidden}#sidebar-container{flex-shrink:0;width:250px;z-index:50;display:flex;flex-direction:column;overflow:hidden}.sidebar-resize-handle{width:4px;cursor:col-resize;background:transparent;flex-shrink:0;transition:background var(--transition);z-index:60}.sidebar-resize-handle:hover,.sidebar-resize-handle:active{background:var(--accent-blue)}#viewport-container{flex:1;position:relative;overflow:hidden;background:radial-gradient(circle at 30% 40%,rgba(59,130,246,.02) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(16,185,129,.02) 0%,transparent 50%),var(--bg-primary)}#canvas-2d{display:block;width:100%;height:100%;cursor:default}.sidebar{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);padding:16px 0;overflow-y:auto}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:0 16px 14px;border-bottom:1px solid var(--border-subtle);margin-bottom:8px}.sidebar-title{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted)}.sidebar-add-btn{all:unset;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:16px;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.sidebar-add-btn:hover{color:var(--accent-green);background:#10b9811a}.sidebar-layer-list{list-style:none;padding:0 8px;flex:1}.sidebar-layer-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:var(--radius-md);transition:background var(--transition);margin-bottom:2px}.sidebar-layer-item:hover{background:#ffffff08}.sidebar-layer-swatch{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px #ffffff14}.sidebar-layer-name{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-child-select{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:3px;padding:2px 4px;width:70px;cursor:pointer;outline:none;transition:border-color var(--transition);flex-shrink:0}.sidebar-child-select:focus{border-color:var(--accent-blue)}.sidebar-child-select:disabled{opacity:.3;cursor:default}.sidebar-child-select option{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-child-prefix{color:var(--text-muted);font-size:11px;flex-shrink:0;margin-right:-4px}.sidebar-layer-spacer{flex:1}.sidebar-layer-btn{all:unset;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-muted);border-radius:3px;cursor:pointer;transition:all var(--transition);flex-shrink:0}.sidebar-layer-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff0f}.sidebar-layer-btn:disabled{opacity:.2;cursor:default}.sidebar-layer-delete:hover:not(:disabled){color:var(--accent-red);background:#ef44441a}.sidebar-reset-btn{all:unset;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;padding:8px 16px;margin:12px 16px 0;text-align:center;color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.sidebar-reset-btn:hover{color:var(--accent-orange);border-color:#f59e0b4d;background:#f59e0b0d}.filter-panel{border-top:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);padding:16px 0;background:var(--bg-secondary);overflow-y:auto;flex-shrink:0;max-height:40%}.filter-panel .sidebar-header{margin-bottom:8px}.filter-search{display:block;width:calc(100% - 32px);margin:0 16px 12px;font-family:var(--font-display);font-size:12px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:7px 10px;outline:none;transition:border-color var(--transition)}.filter-search:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f61a}.filter-search::placeholder{color:var(--text-muted)}.filter-group{padding:0 16px;margin-bottom:10px}.filter-group .sidebar-title{margin-bottom:6px}.filter-tag-row{display:flex;flex-wrap:wrap;gap:4px}.filter-tag{all:unset;font-family:var(--font-mono);font-size:10px;letter-spacing:.02em;padding:3px 8px;border-radius:10px;border:1px solid var(--border-active);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.filter-tag:hover{color:var(--text-primary);border-color:#fff3;background:#ffffff0a}.filter-tag-active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.filter-tag-active:hover{background:#4b92ff;border-color:#4b92ff;color:#fff}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modal-fade-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-panel{background:var(--bg-secondary);border:1px solid var(--border-active);border-radius:var(--radius-lg);padding:28px;min-width:400px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px;box-shadow:0 24px 80px #00000080,0 0 1px #ffffff1a,inset 0 1px #ffffff0a;animation:modal-slide-up .25s cubic-bezier(.16,1,.3,1)}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-direction{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);padding:8px 12px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);letter-spacing:.02em}.modal-label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:-8px}.modal-input,.modal-textarea,.modal-select{width:100%;font-family:var(--font-display);font-size:13px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:9px 12px;outline:none;transition:border-color var(--transition)}.modal-input:focus,.modal-textarea:focus,.modal-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f61a}.modal-textarea{resize:vertical;min-height:60px;line-height:1.5}.modal-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555a6e' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.modal-readonly{font-size:13px;color:var(--text-secondary);padding:4px 0;display:block}.modal-placeholder-msg{font-size:13px;color:var(--text-secondary);line-height:1.5;padding:12px 0}.modal-btn-row{display:flex;gap:8px;justify-content:flex-end;margin-top:6px;padding-top:14px;border-top:1px solid var(--border-subtle)}.modal-btn{all:unset;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.06em;padding:8px 20px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.modal-btn-save{background:var(--accent-blue);color:#fff}.modal-btn-save:hover{background:#4b92ff;box-shadow:var(--glow-blue)}.modal-btn-close{color:var(--text-muted);border:1px solid var(--border-subtle)}.modal-btn-close:hover{color:var(--text-secondary);border-color:var(--border-active);background:#ffffff08}.modal-metadata{display:flex;flex-direction:column;gap:8px}.modal-metadata-list{display:flex;flex-direction:column;gap:4px}.modal-metadata-row{display:flex;gap:6px;align-items:center}.modal-meta-key,.modal-meta-value{flex:1;font-family:var(--font-mono);font-size:11px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:3px;padding:6px 8px;outline:none;transition:border-color var(--transition)}.modal-meta-key:focus,.modal-meta-value:focus{border-color:var(--accent-blue)}.modal-meta-remove{all:unset;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);border-radius:3px;cursor:pointer;flex-shrink:0;transition:all var(--transition)}.modal-meta-remove:hover{color:var(--accent-red);background:#ef44441a}.modal-meta-add{all:unset;font-family:var(--font-mono);font-size:10px;color:var(--text-muted);cursor:pointer;padding:4px 0;transition:color var(--transition)}.modal-meta-add:hover{color:var(--accent-green)}.color-picker-section{display:flex;flex-direction:column;gap:8px}.color-palette-row{display:flex;flex-wrap:wrap;gap:6px}.color-swatch{width:26px;height:26px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .1s}.color-swatch:hover{transform:scale(1.15);border-color:#ffffff4d}.color-swatch-selected{border-color:#fff;box-shadow:0 0 6px #fff6}.color-controls-row{display:flex;align-items:center;gap:8px}.modal-color-input{width:40px;height:30px;padding:0;border:1px solid var(--border-active);border-radius:4px;background:transparent;cursor:pointer}.json-modal-textarea{width:100%;min-height:400px;max-height:60vh;font-family:var(--font-mono);font-size:12px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:12px;outline:none;resize:vertical;-moz-tab-size:2;tab-size:2;transition:border-color var(--transition)}.json-modal-textarea:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f61a}.json-modal-error{font-family:var(--font-mono);font-size:11px;color:var(--accent-red);padding:6px 10px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm)}.json-modal-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:12px;color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border-active);border-radius:var(--radius-md);padding:8px 18px;z-index:2000;animation:modal-fade-in .2s ease-out;box-shadow:0 8px 30px #0006}.toolbar-separator{width:1px;height:20px;background:var(--border-subtle);flex-shrink:0}.fps-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:500;pointer-events:none}.fps-crosshair span{position:absolute;background:#fff9;border-radius:1px}.fps-crosshair span:first-child{width:16px;height:2px;top:50%;left:50%;transform:translate(-50%,-50%)}.fps-crosshair span:last-child{width:2px;height:16px;top:50%;left:50%;transform:translate(-50%,-50%)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-active);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.process-float-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:var(--bg-elevated);border:1px solid var(--border-active);border-radius:var(--radius-lg);padding:10px 18px;z-index:900;box-shadow:0 8px 32px #0006;font-family:var(--font-display);font-size:13px;color:var(--text-primary)}.process-float-bar span{margin-right:4px}.processes-panel{flex-shrink:0;max-height:35%;overflow-y:auto;border-top:1px solid var(--border-subtle);padding:0}.processes-panel .sidebar-layer-item{cursor:pointer}.sidebar-process-selected{background:#ffffff12;box-shadow:inset 2px 0 0 var(--accent-blue)}.sidebar-process-selected:hover{background:#ffffff17}.processes-empty{padding:12px 16px;color:var(--text-muted);font-size:12px;font-family:var(--font-display)}.order-list{display:flex;flex-direction:column;gap:4px;max-height:340px;overflow-y:auto}.order-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none;transition:opacity var(--transition),border-color var(--transition),box-shadow var(--transition)}.order-row-dragging{opacity:.45}.order-row-drop-target{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f626}.order-drag-handle{cursor:grab;color:var(--text-muted);font-size:14px;line-height:1;flex-shrink:0}.order-row-index{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);min-width:18px;text-align:center;flex-shrink:0}.order-row-label{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:1px}.order-row-nodes{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.order-row-edge-title{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.order-row-btn{all:unset;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);border-radius:3px;cursor:pointer;flex-shrink:0;transition:all var(--transition)}.order-row-btn:disabled{opacity:.2;cursor:default}.order-row-btn-danger:hover:not(:disabled){color:var(--accent-red);background:#ef44441a}.order-row-btn-dupe:hover{color:var(--accent-blue);background:#3b82f61a}.settings-modal-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 0}.settings-modal-label{font-family:var(--font-display);font-size:12px;color:var(--text-secondary);min-width:120px;flex-shrink:0}.settings-modal-controls{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end}.settings-modal-range{flex:1;max-width:180px;accent-color:var(--accent-blue);height:4px;cursor:pointer}.settings-modal-value{font-family:var(--font-mono);font-size:11px;color:var(--text-primary);min-width:48px;text-align:right}.context-menu{position:fixed;z-index:1500;background:var(--bg-elevated);border:1px solid var(--border-active);border-radius:var(--radius-md);min-width:160px;padding:4px 0;box-shadow:0 12px 40px #00000080,0 0 1px #ffffff1a;animation:modal-fade-in .1s ease-out}.context-menu-title{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.06em;color:var(--text-muted);padding:6px 14px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-bottom:1px solid var(--border-subtle);margin-bottom:2px}.context-menu-item{all:unset;display:block;width:100%;box-sizing:border-box;font-family:var(--font-display);font-size:12px;color:var(--text-primary);padding:7px 14px;cursor:pointer;transition:background var(--transition)}.context-menu-item:hover{background:#ffffff0f}.context-menu-item--danger{color:var(--accent-red)}.context-menu-item--danger:hover{background:#ef44441a}.modal-confirm-msg{font-size:14px;color:var(--text-primary);line-height:1.5;padding:12px 0}.history-panel{flex-shrink:0;max-height:30%;overflow-y:auto;border-top:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);padding:0;background:var(--bg-secondary)}.history-panel .sidebar-header{padding:12px 16px 10px;margin-bottom:0;border-bottom:1px solid var(--border-subtle)}.history-undo-redo{display:flex;gap:2px}.history-undo-redo .sidebar-add-btn:disabled{opacity:.2;cursor:default}.history-list{overflow-y:auto;max-height:calc(30vh - 48px)}.history-entry{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);padding:5px 16px;cursor:pointer;transition:background var(--transition);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-entry:hover{background:#ffffff0a;color:var(--text-primary)}.history-entry-current{color:var(--text-primary);background:#ffffff12;box-shadow:inset 2px 0 0 var(--accent-blue)}.toolbar-scenario-group{align-items:center;gap:6px;margin-left:8px}.toolbar-scenario-label{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.toolbar-scenario-select{max-width:140px}.checkpoints-panel{flex-shrink:0;max-height:30%;overflow-y:auto;border-top:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle);padding:0;background:var(--bg-secondary)}.checkpoints-panel .sidebar-header{padding:12px 16px 10px;margin-bottom:0;border-bottom:1px solid var(--border-subtle)}.checkpoints-list{overflow-y:auto;max-height:calc(30vh - 48px)}.checkpoints-empty{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);padding:12px 16px;opacity:.5}.checkpoint-entry{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;border-bottom:1px solid rgba(255,255,255,.03)}.checkpoint-entry:hover{background:#ffffff0a}.checkpoint-info{min-width:0;flex:1}.checkpoint-label{font-family:var(--font-mono);font-size:11px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.checkpoint-time{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);opacity:.6}.checkpoint-restore-btn{font-family:var(--font-mono);font-size:10px;color:var(--accent-blue);background:none;border:1px solid var(--accent-blue);border-radius:3px;padding:2px 8px;cursor:pointer;opacity:.7;transition:opacity var(--transition);margin-left:8px;flex-shrink:0}.checkpoint-restore-btn:hover{opacity:1}.checkpoint-restore-btn:disabled{opacity:.3;cursor:default}.diff-modal{max-width:640px;max-height:80vh;display:flex;flex-direction:column}.diff-summary{padding:8px 16px;font-size:13px;color:var(--text-secondary, #8b94a7);border-bottom:1px solid var(--bg-secondary, #141720)}.diff-content{flex:1;overflow-y:auto;padding:8px 16px 16px}.diff-empty{color:var(--text-secondary, #8b94a7);font-size:13px;padding:24px 0;text-align:center}.diff-section{margin-bottom:16px}.diff-section-title{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary, #8b94a7);margin:0 0 6px;letter-spacing:.5px}.diff-change{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:4px;margin-bottom:2px}.diff-badge{width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.diff-badge-added{background:#1a3a2a;color:#4ade80}.diff-badge-removed{background:#3a1a1a;color:#f87171}.diff-badge-modified{background:#3a3a1a;color:#facc15}.diff-change-info{display:flex;flex-direction:column;gap:1px;min-width:0}.diff-change-name{font-size:13px;color:var(--text-primary, #e2e8f0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.diff-change-fields{font-size:11px;color:var(--text-secondary, #8b94a7)}.diff-footer{padding:12px 16px;border-top:1px solid var(--bg-secondary, #141720);display:flex;justify-content:flex-end}.diff-merge-btn{background:#2563eb!important;color:#fff!important}.diff-merge-btn:hover{background:#1d4ed8!important}.diff-conflict{padding:8px;margin-bottom:8px;background:#1a1a1a;border-radius:6px;border-left:3px solid #f59e0b}.diff-conflict-title{font-size:13px;font-weight:600;color:#f59e0b;margin-bottom:4px}.diff-conflict-details{font-size:12px;font-family:DM Mono,monospace}.diff-conflict-value{padding:2px 0;color:var(--text-secondary, #8b94a7);word-break:break-all}.diff-conflict-value strong{color:var(--text-primary, #e2e8f0)}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:10000}.login-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:40px;width:360px;max-width:90vw}.login-card h2{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 24px;text-align:center}.login-input{display:block;width:100%;padding:10px 12px;margin-bottom:12px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:13px;box-sizing:border-box}.login-input:focus{outline:none;border-color:var(--accent-blue)}.login-btn{display:block;width:100%;padding:10px;margin-top:4px;background:var(--accent-blue);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font-display);font-size:14px;font-weight:500;cursor:pointer}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-toggle{display:block;width:100%;padding:8px;margin-top:8px;background:none;border:none;color:var(--text-secondary);font-family:var(--font-display);font-size:13px;cursor:pointer;text-align:center}.login-toggle:hover{color:var(--text-primary)}.login-error{color:var(--accent-red);font-size:12px;margin-top:8px;text-align:center;min-height:16px}.file-browser{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary)}.file-browser-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.file-browser-title{font-family:var(--font-mono);font-size:18px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-primary);margin:0}.file-browser-actions{display:flex;gap:8px}.fb-btn{all:unset;font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.04em;padding:8px 18px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.fb-btn-primary{background:var(--accent-blue);color:#fff}.fb-btn-primary:hover{background:#4b92ff;box-shadow:var(--glow-blue)}.fb-btn-secondary{color:var(--text-muted);border:1px solid var(--border-subtle)}.fb-btn-secondary:hover{color:var(--text-secondary);border-color:var(--border-active);background:#ffffff08}.file-browser-body{display:flex;flex:1;min-height:0}.file-browser-sidebar{width:220px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);overflow-y:auto;padding:12px 0}.fb-folder-list{display:flex;flex-direction:column}.fb-folder-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;font-family:var(--font-display);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.fb-folder-item:hover{background:#ffffff0a;color:var(--text-primary)}.fb-folder-active{color:var(--text-primary);background:#3b82f61a;box-shadow:inset 3px 0 0 var(--accent-blue)}.fb-folder-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.fb-folder-actions{display:none;gap:2px}.fb-folder-item:hover .fb-folder-actions{display:flex}.fb-folder-action-btn{all:unset;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);border-radius:3px;cursor:pointer;transition:all var(--transition)}.fb-folder-action-btn:hover{color:var(--text-primary);background:#ffffff14}.fb-folder-action-danger:hover{color:var(--accent-red);background:#ef44441a}.file-browser-grid{flex:1;padding:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;align-content:start;overflow-y:auto}.fb-grid-empty{grid-column:1 / -1;text-align:center;color:var(--text-muted);font-size:14px;padding:60px 0}.file-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition)}.file-card:hover{border-color:var(--border-active);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.file-card-thumbnail{width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--bg-primary);display:flex;align-items:center;justify-content:center}.file-card-thumbnail img{width:100%;height:100%;object-fit:cover}.file-card-thumbnail-placeholder{background:radial-gradient(circle at 30% 40%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(16,185,129,.05) 0%,transparent 50%),var(--bg-primary)}.file-card-info{padding:12px 14px}.file-card-name{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.file-card-date{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.02em}.file-preview-panel{max-width:480px;min-width:380px}.file-preview-thumbnail{width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--bg-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.file-preview-thumbnail img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.file-preview-name{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.file-preview-dates{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);line-height:1.6}.toolbar-home-btn{color:var(--text-secondary)!important}.toolbar-home-btn:hover{color:var(--accent-blue)!important}
