*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1e1e1e;--surface: #252526;--surface2: #2d2d2d;--border: #3c3c3c;--border2: #555;--text: #d4d4d4;--text-dim: #858585;--accent: #0e7fd8;--accent-hover: #1a8fe8;--danger: #e05252;--green: #4ec94e;--orange: #ce9e68;--header-h: 44px;--sidebar-w: 320px}html,body,#root{height:100%}body{font-family:Malgun Gothic,Apple SD Gothic Neo,Segoe UI,sans-serif;font-size:13px;background:var(--bg);color:var(--text);overflow:hidden}.app{display:flex;flex-direction:column;height:100%}.app-header{display:flex;align-items:center;gap:0;height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);padding:0 16px;flex-shrink:0}.app-title{font-size:14px;font-weight:700;color:var(--text);margin-right:20px}.tab-btn{height:var(--header-h);padding:0 18px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-dim);cursor:pointer;font-size:13px;font-family:inherit;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.app-content{flex:1;overflow:hidden}button{font-family:inherit;cursor:pointer}.btn{padding:5px 12px;border-radius:4px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-size:12px;transition:background .1s}.btn:hover{background:#3a3a3a}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-hover)}.btn.danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn.danger:hover{background:#e052521a}.btn:disabled{opacity:.4;cursor:not-allowed}.script-editor{display:flex;flex-direction:column;height:100%}.script-toolbar{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.file-select{background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:4px 8px;border-radius:4px;font-family:inherit;font-size:13px;min-width:220px}.save-status{margin-left:auto;font-size:11px;color:var(--text-dim)}.save-status.saved{color:var(--green)}.save-status.dirty{color:var(--orange)}.script-body{display:flex;flex:1;overflow:hidden}.grid-wrap{flex:1;overflow:auto;position:relative}.grid{border-collapse:collapse;table-layout:fixed}.grid th{position:sticky;top:0;background:var(--surface);border:1px solid var(--border);padding:5px 6px;text-align:left;font-weight:600;font-size:11px;color:var(--text-dim);-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2;overflow:visible}.grid td{border:1px solid var(--border);padding:0;vertical-align:middle;height:28px}.grid tr:hover td{background:#2a2a2a}.grid tr.selected td{background:#0d3a5c!important}.cell-input{width:100%;height:100%;background:transparent;border:none;color:var(--text);padding:0 6px;font-family:inherit;font-size:12px;outline:none}.cell-input:focus{background:#0d3a5c;outline:1px solid var(--accent);outline-offset:-1px}.cell-clickable{width:100%;height:100%;display:flex;align-items:center;padding:0 6px;cursor:pointer;font-size:12px;gap:4px}.cell-clickable:hover{background:#0e7fd826}.cell-clickable.active{background:#0d3a5c;outline:1px solid var(--accent)}.type-chip{font-size:10px;font-weight:700;padding:1px 5px;border-radius:2px;background:#444;color:#ccc;flex-shrink:0}.cell-auto select{width:100%;height:100%;background:transparent;border:none;color:var(--text);padding:0 4px;font-family:inherit;font-size:12px;cursor:pointer}.cell-auto select:focus{background:#0d3a5c;outline:1px solid var(--accent)}.row-add-btn{display:block;width:100%;padding:6px;background:transparent;border:1px dashed var(--border2);color:var(--text-dim);text-align:center;cursor:pointer;font-size:12px}.row-add-btn:hover{color:var(--text);border-color:var(--accent)}.col-drag{width:20px!important;padding:0!important}.col-del{width:28px!important;padding:0!important;text-align:center}.drag-handle{width:20px;text-align:center;color:#444;cursor:grab;-webkit-user-select:none;user-select:none;font-size:13px;padding:0!important}.drag-handle:hover{color:var(--text-dim)}.drag-handle:active{cursor:grabbing}.grid tr.drag-over td{border-top:2px solid var(--accent)!important}.row-del-btn{background:none;border:none;color:#555;cursor:pointer;padding:0 6px;font-size:11px;line-height:28px}.row-del-btn:hover{color:var(--danger)}.cell-placeholder{color:#555}.cell-text-overflow{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{background:#37474f;padding:10px 12px 8px;flex-shrink:0}.sidebar-mode-row{display:flex;align-items:center;gap:7px}.sidebar-mode-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:3px;background:var(--orange);color:#1e1e1e}.sidebar-title{font-size:13px;font-weight:700;color:#eceff1}.sidebar-sub{font-size:11px;color:#90a4ae;margin-top:4px}.sidebar-body{flex:1;overflow-y:auto;padding:12px}.sidebar-idle{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:12px;text-align:center;gap:10px}.sidebar-idle-icon{font-size:28px}.list-item{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:9px 11px;margin-bottom:6px;cursor:pointer;transition:background .1s,border-color .1s}.list-item:hover{background:#1a3a5c;border-color:var(--accent)}.list-item-title{font-weight:700;font-size:13px;color:var(--text);display:flex;align-items:center;gap:6px}.list-item-desc{font-size:11px;color:var(--text-dim);margin-top:3px;line-height:1.4}.auto-badge{background:var(--green);color:#1e1e1e;font-size:9px;padding:1px 5px;border-radius:2px;font-weight:400}.param-field{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:9px 11px;margin-bottom:7px}.param-field-label{display:flex;align-items:center;gap:5px;margin-bottom:4px}.param-key{font-weight:700;font-size:12px}.badge{font-size:10px;padding:1px 5px;border-radius:2px}.badge-req{background:var(--danger);color:#fff}.badge-opt{background:#555;color:#ccc}.param-desc{font-size:11px;color:var(--text-dim);margin-bottom:5px;line-height:1.4}.param-hint{font-size:10px;color:#555;margin-top:3px}.param-field input,.param-field select{width:100%;background:var(--bg);border:1px solid var(--border2);border-radius:4px;color:var(--text);padding:5px 8px;font-family:inherit;font-size:12px}.param-field input:focus,.param-field select:focus{outline:none;border-color:var(--accent)}.no-params{text-align:center;color:var(--text-dim);padding:30px 0;font-size:12px}.ref-editor{display:flex;flex-direction:column;height:100%}.ref-tabs{display:flex;gap:2px;padding:8px 12px 0;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.ref-tab{padding:6px 16px;border:1px solid var(--border);border-bottom:none;border-radius:4px 4px 0 0;background:var(--bg);color:var(--text-dim);cursor:pointer;font-size:12px;font-family:inherit}.ref-tab.active{background:var(--surface2);color:var(--text);border-color:var(--border2)}.ref-body{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:12px;gap:8px}.ref-toolbar{display:flex;align-items:center;gap:8px}.ref-toolbar h3{font-size:13px;margin-right:auto}.ref-table-wrap{flex:1;overflow:auto;border:1px solid var(--border);border-radius:4px}.ref-table{width:100%;border-collapse:collapse;font-size:12px}.ref-table th{position:sticky;top:0;background:var(--surface);border-bottom:1px solid var(--border2);padding:6px 8px;text-align:left;font-weight:600;color:var(--text-dim);white-space:nowrap}.ref-table td{border-bottom:1px solid var(--border);padding:2px 4px;vertical-align:middle}.ref-table tr:hover td{background:#2a2a2a}.ref-table input,.ref-table select{width:100%;background:transparent;border:none;color:var(--text);padding:4px 6px;font-family:inherit;font-size:12px;outline:none}.ref-table input:focus,.ref-table select:focus{background:#0d3a5c;outline:1px solid var(--accent);border-radius:2px}.ref-del-btn{background:transparent;border:none;color:var(--text-dim);cursor:pointer;padding:2px 6px;font-size:14px;border-radius:3px}.ref-del-btn:hover{color:var(--danger);background:#e052521a}.values-editor{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-start}.values-group{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:10px;min-width:150px}.values-group-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}.values-group-title{font-weight:700;font-size:13px;flex:1}.values-group-title-input{background:transparent;border:none;border-bottom:1px solid var(--border2);color:var(--text);font-weight:700;font-size:13px;width:100%;outline:none;font-family:inherit}.values-list{display:flex;flex-direction:column;gap:4px}.values-item{display:flex;align-items:center;gap:4px}.values-item input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--text);padding:3px 6px;font-size:12px;font-family:inherit;outline:none}.values-item input:focus{border-color:var(--accent)}.values-add-btn{width:100%;margin-top:4px;padding:3px;background:transparent;border:1px dashed var(--border2);color:var(--text-dim);border-radius:3px;cursor:pointer;font-size:11px}.values-add-btn:hover{color:var(--text);border-color:var(--accent)}.values-new-btn{margin-top:4px}.mode-switcher{display:flex;margin-left:auto;border:1px solid var(--border2);border-radius:4px;overflow:hidden}.mode-btn{padding:4px 14px;border:none;background:transparent;color:var(--text-dim);font-size:12px;font-family:inherit;cursor:pointer;transition:background .1s,color .1s}.mode-btn:hover{color:var(--text);background:var(--surface2)}.mode-btn.active{background:var(--accent);color:#fff}.file-picker-btn{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--surface2);border:1px solid var(--border2);border-radius:4px;color:var(--text);cursor:pointer;font-size:13px;font-family:inherit;min-width:180px;max-width:320px;transition:border-color .1s}.file-picker-btn:hover{border-color:var(--accent)}.file-picker-icon{font-size:14px;flex-shrink:0}.file-picker-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.file-picker-placeholder{flex:1;color:var(--text-dim);font-style:italic}.file-picker-caret{font-size:10px;color:var(--text-dim);flex-shrink:0}.dirty-dot{color:var(--orange);font-size:14px;flex-shrink:0;line-height:1}.toolbar-sep{width:1px;height:20px;background:var(--border);flex-shrink:0}.save-btn.saved{background:transparent;border-color:var(--green);color:var(--green)}.save-btn.saved:hover{background:#4ec94e1a}.sidebar-toggle-btn{font-size:11px}.sidebar-toggle-btn.active{border-color:var(--accent);color:var(--accent)}.no-file-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:var(--text-dim)}.no-file-icon{font-size:48px;opacity:.4}.no-file-text{font-size:14px}.cell-clickable.readonly{cursor:default}.cell-input[readonly]{cursor:default;color:var(--text-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:13px;font-weight:700;color:var(--text);flex:1}.modal-header-actions{display:flex;gap:6px}.modal-close-btn{background:none;border:none;color:var(--text-dim);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:3px;line-height:1}.modal-close-btn:hover{color:var(--text);background:var(--surface2)}.modal-footer{display:flex;align-items:center;gap:8px;padding:8px 14px;border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.fp-modal{background:var(--surface);border:1px solid var(--border2);border-radius:8px;width:420px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #00000080}.fp-tree-area{flex:1;overflow-y:auto;padding:8px 0}.fp-no-files{text-align:center;color:var(--text-dim);padding:32px;font-size:12px}.fp-item{display:flex;align-items:center;gap:4px;padding:5px 8px;cursor:pointer;font-size:12px;min-height:28px;transition:background .08s}.fp-item:hover{background:var(--surface2)}.fp-item:hover .fp-item-actions{opacity:1}.fp-dir{color:#ace}.fp-file{color:var(--text)}.fp-toggle{width:14px;flex-shrink:0;font-size:11px;color:var(--text-dim)}.fp-icon{font-size:13px;flex-shrink:0}.fp-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fp-item-actions{display:flex;gap:3px;opacity:0;transition:opacity .1s;flex-shrink:0}.fp-item-actions button{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);font-size:10px;padding:1px 5px;border-radius:3px;cursor:pointer;white-space:nowrap}.fp-item-actions button:hover{color:var(--text);border-color:var(--accent)}.fp-empty{color:var(--text-dim);font-size:11px;padding:4px 0;font-style:italic}.fp-inline-input{display:flex;align-items:center;gap:5px;padding:4px 8px;background:#1a2a3a;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.fp-inline-input input{flex:1;background:var(--bg);border:1px solid var(--border2);border-radius:3px;color:var(--text);padding:3px 7px;font-size:12px;font-family:inherit;outline:none}.fp-inline-input input:focus{border-color:var(--accent)}.fp-inline-input button{padding:3px 8px;font-size:11px;border-radius:3px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);cursor:pointer;white-space:nowrap}.fp-inline-input button:first-of-type{background:var(--accent);border-color:var(--accent);color:#fff}.fp-root-create{border-radius:0;margin:0 0 4px;padding:6px 12px}.history-modal{background:var(--surface);border:1px solid var(--border2);border-radius:8px;width:760px;height:70vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #00000080}.history-filename{color:var(--accent)}.history-body{flex:1;display:flex;overflow:hidden}.history-list{width:220px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;padding:4px 0}.history-empty{text-align:center;color:var(--text-dim);padding:32px 16px;font-size:12px}.history-entry{padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .08s}.history-entry:hover{background:var(--surface2)}.history-entry.active{background:#0d3a5c;border-left:2px solid var(--accent)}.history-entry-action{font-size:11px;font-weight:700;color:var(--orange);margin-bottom:2px}.history-entry-ts{font-size:11px;color:var(--text-dim)}.history-rollback-btn{margin-top:6px;font-size:11px;width:100%}.history-preview{flex:1;overflow:auto;display:flex;flex-direction:column}.history-preview-hint{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:12px}.history-preview-table-wrap{flex:1;overflow:auto}.history-preview-table{border-collapse:collapse;font-size:11px;width:100%}.history-preview-table th{position:sticky;top:0;background:var(--surface);border:1px solid var(--border);padding:4px 6px;color:var(--text-dim);font-weight:600;white-space:nowrap}.history-preview-table td{border:1px solid var(--border);padding:3px 6px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.history-count{font-size:11px;color:var(--text-dim);margin-right:auto}.cell-bool{text-align:center;vertical-align:middle}.cell-checkbox{width:15px;height:15px;cursor:pointer;accent-color:var(--accent);vertical-align:middle}.cell-checkbox:disabled{cursor:default;opacity:.7}.resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:3}.resize-handle:hover,.resize-handle:active{background:var(--accent);opacity:.6}.col-spacer{width:auto!important;min-width:0!important;padding:0!important;border-left:none!important}.sidebar-collapse{width:0;flex-shrink:0;overflow:hidden;transition:width .22s ease}.sidebar-collapse.open{width:var(--sidebar-w)}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999}.login-box{background:var(--surface);border:1px solid var(--border2);border-radius:10px;padding:36px 32px 28px;width:320px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 32px #00000080}.login-title{font-size:16px;font-weight:700;color:var(--text);text-align:center}.login-subtitle{font-size:12px;color:var(--text-dim);text-align:center;margin-top:-8px}.login-field{display:flex;flex-direction:column;gap:5px}.login-label{font-size:11px;color:var(--text-dim)}.login-input{background:var(--bg);border:1px solid var(--border2);border-radius:4px;color:var(--text);padding:8px 10px;font-family:inherit;font-size:13px;outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--accent)}.login-error{font-size:12px;color:var(--danger);text-align:center;padding:4px 0}.login-btn{margin-top:4px;padding:9px;background:var(--accent);border:none;border-radius:4px;color:#fff;font-size:13px;font-family:inherit;font-weight:700;cursor:pointer;transition:background .1s}.login-btn:hover:not(:disabled){background:var(--accent-hover)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-loading{color:var(--text-dim);font-size:13px}.header-user{display:flex;align-items:center;gap:8px;margin-left:12px}.header-username{font-size:12px;color:var(--text-dim)}.logout-btn{font-size:11px;padding:3px 10px}
