*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;background:#f8fafc;height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}#root,.app{flex-direction:column;height:100vh;display:flex}.header{z-index:10;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;box-shadow:0 1px 4px #0000000f}.header-left{align-items:center;gap:10px;display:flex}.logo{background:linear-gradient(135deg,#818cf8,#4f46e5);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.app-name{color:#0f172a;letter-spacing:-.3px;font-size:16px;font-weight:700}.header-right{align-items:center;gap:10px;display:flex}.filename-badge{color:#64748b;text-overflow:ellipsis;white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;max-width:200px;padding:4px 12px;font-size:12px;overflow:hidden}.upload-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#4f46e5;border:none;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.upload-btn:hover{background:#4338ca}.copy-btn{color:#4f46e5;cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #c7d2fe;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.copy-btn:hover{background:#eef2ff;border-color:#a5b4fc}.copy-btn:active{background:#e0e7ff}.edit-btn{color:#475569;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #e2e8f0;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.edit-btn:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.fit-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.fit-btn:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.status-bar{background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0;align-items:center;gap:20px;height:32px;padding:0 20px;display:flex}.status-item{color:#94a3b8;align-items:center;gap:5px;font-size:11.5px;display:flex}.status-item strong{color:#64748b;font-weight:600}.status-dot{border-radius:50%;width:6px;height:6px}.error-banner{color:#b91c1c;background:#fef2f2;border-bottom:1px solid #fecaca;padding:8px 24px;font-size:13px}.main{flex:1;position:relative;overflow:hidden}.chart-viewport{background-color:#f1f5f9;background-image:radial-gradient(circle,#d1d5db 1px,#0000 1px);background-size:24px 24px;width:100%;height:100%;position:relative;overflow:hidden}.chart-canvas{will-change:transform;transform-origin:0 0;position:relative}.chart-svg{pointer-events:none;position:absolute;top:0;left:0;overflow:visible}.zoom-controls{z-index:10;flex-direction:column;gap:4px;display:flex;position:absolute;bottom:20px;right:20px}.zoom-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-family:inherit;font-size:16px;line-height:1;transition:all .12s;display:flex;box-shadow:0 2px 8px #00000014}.zoom-btn:hover{color:#1e293b;background:#f8fafc;box-shadow:0 4px 12px #0000001f}.org-node{cursor:default;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;transition:box-shadow .15s,transform .15s;display:flex;position:absolute;overflow:hidden;box-shadow:0 2px 8px #00000012,0 0 #0000}.org-node:hover{z-index:2;transform:translateY(-2px);box-shadow:0 6px 24px #00000021}.org-node--open{background:#fafbfc;border-style:dashed;border-color:#cbd5e1}.org-node--root{border-color:#c7d2fe;box-shadow:0 4px 24px #4f46e540,0 2px 8px #00000014}.org-node--root .org-node__bar{width:5px}.org-node--root .org-node__name{font-size:13.5px}.org-node__bar{background:var(--dept-color,#64748b);flex-shrink:0;width:4px}.org-node--open .org-node__bar{opacity:.4}.org-node__body{flex-direction:column;flex:1;justify-content:center;gap:2px;min-width:0;padding:9px 11px;display:flex}.org-node__name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:700;line-height:1.3;overflow:hidden}.org-node--open .org-node__name{color:#94a3b8;font-weight:500}.org-node__title{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:10.5px;line-height:1.4;overflow:hidden}.org-node__dept{text-transform:uppercase;letter-spacing:.6px;opacity:.8;margin-top:3px;font-size:9px;font-weight:700}.empty-state{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100%;display:flex}.empty-state p{font-size:15px}.legend{z-index:5;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px 14px;position:absolute;bottom:16px;left:16px;box-shadow:0 2px 8px #00000012}.legend-title{text-transform:uppercase;letter-spacing:.6px;color:#94a3b8;margin-bottom:8px;font-size:10px;font-weight:700}.legend-item{color:#475569;align-items:center;gap:7px;margin-bottom:5px;font-size:11px;display:flex}.legend-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.sheet-overlay{z-index:100;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0f172a40;position:fixed;inset:0}.sheet{z-index:101;background:#fff;flex-direction:column;width:720px;max-width:95vw;animation:.22s slideIn;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-8px 0 40px #00000024}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.sheet-header{border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 20px;display:flex}.sheet-title{color:#0f172a;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.sheet-close{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;transition:background .12s;display:flex}.sheet-close:hover{color:#1e293b;background:#e2e8f0}.sheet-body{flex:1;overflow:auto}.sheet-table{border-collapse:collapse;width:100%;font-size:12.5px}.sheet-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;white-space:nowrap;z-index:2;background:#f8fafc;border-bottom:1.5px solid #e2e8f0;padding:8px 10px;font-size:11px;font-weight:700;position:sticky;top:0}.sheet-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .1s}.sheet-table tbody tr:hover{background:#fafbff}.sheet-table tbody tr.row-open{background:#fafafa}.sheet-table tbody tr.row-open:hover{background:#f5f5ff}.sheet-table td{vertical-align:middle;padding:5px 6px}.cell-with-dot{align-items:center;gap:6px;display:flex}.dept-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.cell-input,.cell-select{color:#1e293b;background:0 0;border:1px solid #0000;border-radius:5px;outline:none;width:100%;min-width:0;padding:4px 6px;font-family:inherit;font-size:12.5px;transition:border-color .12s,background .12s}.cell-input:hover,.cell-select:hover{background:#f8fafc;border-color:#e2e8f0}.cell-input:focus,.cell-select:focus{background:#fff;border-color:#818cf8;box-shadow:0 0 0 2px #818cf826}.cell-select{cursor:pointer}.cell-checkbox{cursor:pointer;accent-color:#4f46e5;width:15px;height:15px}.row-delete{color:#cbd5e1;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-family:inherit;font-size:16px;line-height:1;transition:color .12s,background .12s;display:flex}.row-delete:hover{color:#ef4444;background:#fef2f2}.sheet-footer{border-top:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.add-row-btn{color:#4f46e5;cursor:pointer;background:0 0;border:1.5px dashed #c7d2fe;border-radius:7px;padding:6px 14px;font-family:inherit;font-size:12.5px;font-weight:600;transition:all .12s}.add-row-btn:hover{background:#eef2ff;border-color:#818cf8}.sheet-count{color:#94a3b8;font-size:11.5px}.home{background:#f8fafc;flex-direction:column;height:100vh;display:flex}.home-body{flex:1;padding:40px 48px;overflow-y:auto}.home-content{max-width:1100px;margin:0 auto}.home-section-header{align-items:center;gap:10px;margin-bottom:20px;display:flex}.home-section-title{text-transform:uppercase;letter-spacing:.6px;color:#94a3b8;font-size:13px;font-weight:700}.home-section-count{color:#64748b;background:#e2e8f0;border-radius:20px;padding:1px 7px;font-size:11px;font-weight:700}.org-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.org-card{cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;transition:box-shadow .15s,border-color .15s,transform .15s;overflow:hidden}.org-card:hover{border-color:#c7d2fe;transform:translateY(-2px);box-shadow:0 8px 28px #0000001a}.org-card__preview{background:#f8fafc;border-bottom:1px solid #f1f5f9;justify-content:center;align-items:center;height:110px;padding:12px 16px;display:flex}.org-card__body{padding:14px 16px}.org-card__title{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:14px;font-weight:700;overflow:hidden}.org-card__meta{color:#94a3b8;align-items:center;gap:5px;margin-bottom:12px;font-size:11.5px;display:flex}.meta-sep{color:#cbd5e1}.org-card__actions{align-items:center;gap:6px;display:flex}.card-open-btn{color:#475569;cursor:pointer;text-align:center;background:#f1f5f9;border:none;border-radius:6px;flex:1;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:all .12s}.card-open-btn:hover{color:#4338ca;background:#e0e7ff}.card-action-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .12s;display:flex}.card-action-btn:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.card-action-btn--danger:hover{color:#ef4444;background:#fef2f2;border-color:#fecaca}.home-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;min-height:420px;display:flex}.home-empty-icon{opacity:.6;margin-bottom:8px}.home-empty-title{color:#1e293b;font-size:18px;font-weight:700}.home-empty-sub{color:#94a3b8;max-width:320px;margin-bottom:8px;font-size:14px;line-height:1.5}.home-empty-actions{gap:10px;margin-top:4px;display:flex}.back-btn{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .12s;display:flex}.back-btn:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.header-divider{background:#e2e8f0;flex-shrink:0;width:1px;height:20px}.chart-title{color:#0f172a;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border-radius:6px;align-items:center;gap:7px;max-width:280px;padding:4px 8px;font-size:14.5px;font-weight:700;transition:background .12s;display:flex;overflow:hidden}.chart-title:hover{background:#f1f5f9}.dirty-dot{background:#f59e0b;border-radius:50%;flex-shrink:0;width:7px;height:7px}.title-input{color:#0f172a;background:#fff;border:1.5px solid #818cf8;border-radius:6px;outline:none;max-width:280px;padding:3px 8px;font-family:inherit;font-size:14.5px;font-weight:700;box-shadow:0 0 0 3px #818cf826}.dup-btn{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #e2e8f0;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.dup-btn:hover{color:#1e293b;background:#f8fafc;border-color:#cbd5e1}.save-btn{color:#475569;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.save-btn:hover{color:#1e293b;background:#e2e8f0}.save-btn--dirty{color:#fff;background:#4f46e5;border-color:#4f46e5}.save-btn--dirty:hover{background:#4338ca;border-color:#4338ca}.link-btn{color:#4f46e5;font-size:inherit;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-family:inherit;text-decoration:underline}.link-btn:hover{color:#4338ca}.docs{background:#f8fafc;flex-direction:column;height:100vh;display:flex}.docs-header-title{color:#475569;font-size:14px;font-weight:600}.docs-body{flex:1;padding:48px 24px 80px;overflow-y:auto}.docs-content{max-width:720px;margin:0 auto}.docs-hero{margin-bottom:36px}.docs-h1{color:#0f172a;letter-spacing:-.5px;margin-bottom:12px;font-size:28px;font-weight:800}.docs-lead{color:#475569;font-size:15px;line-height:1.65}.docs-toc{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-wrap:wrap;align-items:center;gap:6px 14px;margin-bottom:48px;padding:12px 16px;display:flex}.docs-toc-label{text-transform:uppercase;letter-spacing:.6px;color:#94a3b8;width:100%;margin-bottom:2px;font-size:11px;font-weight:700}.docs-toc a{color:#4f46e5;font-size:13px;text-decoration:none}.docs-toc a:hover{text-decoration:underline}.docs-section{border-bottom:1px solid #f1f5f9;margin-bottom:56px;padding-bottom:56px}.docs-section--last{border-bottom:none;margin-bottom:0;padding-bottom:0}.docs-h2{color:#0f172a;letter-spacing:-.3px;margin-bottom:12px;padding-top:4px;font-size:19px;font-weight:700}.docs-section p{color:#475569;margin-bottom:14px;font-size:14px;line-height:1.7}.docs-section p:last-child{margin-bottom:0}.docs-subhead{color:#1e293b!important;margin-top:20px!important;margin-bottom:8px!important;font-size:13px!important;font-weight:700!important}.docs-section code,.docs-toc code{color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;padding:1.5px 5px;font-family:SF Mono,Fira Code,Fira Mono,monospace;font-size:12.5px}.docs-code{color:#e2e8f0;white-space:pre;background:#0f172a;border-radius:10px;margin:14px 0;padding:18px 20px;font-family:SF Mono,Fira Code,Fira Mono,monospace;font-size:13px;line-height:1.65;overflow-x:auto}.docs-code code{color:inherit;font-size:inherit;background:0 0;border:none;padding:0}.docs-table{border-collapse:collapse;border:1px solid #e2e8f0;border-radius:8px;width:100%;margin:16px 0;font-size:13.5px;overflow:hidden}.docs-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:9px 14px;font-size:11px;font-weight:700}.docs-table td{color:#475569;vertical-align:top;border-bottom:1px solid #f1f5f9;padding:11px 14px;line-height:1.5}.docs-table tr:last-child td{border-bottom:none}.docs-table td:first-child code{white-space:nowrap;font-size:12px}.docs-badge{white-space:nowrap;border-radius:20px;padding:2px 7px;font-size:10.5px;font-weight:700;display:inline-block}.docs-badge--blue{color:#2563eb;background:#eff6ff}.docs-badge--grey{color:#64748b;background:#f1f5f9}.docs-list{margin:12px 0 14px;padding-left:20px}.docs-list li{color:#475569;margin-bottom:6px;font-size:14px;line-height:1.7}.docs-callout{color:#0369a1;background:#f0f9ff;border:1px solid #bae6fd;border-left:3px solid #38bdf8;border-radius:8px;margin-top:14px;padding:12px 16px;font-size:13.5px;line-height:1.6}.docs-callout--warning{color:#92400e;background:#fffbeb;border-color:#fde68a #fde68a #fde68a #f59e0b}.docs-section a{color:#4f46e5;text-underline-offset:2px;text-decoration:underline}
