code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.family-member-node{font-size:13px;max-width:240px;min-width:200px}.family-member-node.selected .member-card{box-shadow:0 0 0 2px #2563eb;transform:scale(1.02);transition:all .2s ease}.member-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;cursor:pointer;transition:all .2s ease}.member-card:hover{border-color:#c0cddf;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;transform:translateY(-1px)}.member-card.founding-generation{position:relative;transition:all .3s ease}.member-card.founding-generation:before{animation:foundingGlow 3s ease-in-out infinite alternate;background:linear-gradient(45deg,#0000,#ffd7001a,#0000);border-radius:14px;bottom:-2px;content:"";left:-2px;position:absolute;right:-2px;top:-2px;z-index:-1}.member-card.founding-generation:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px) scale(1.02)}@keyframes foundingGlow{0%{opacity:.3}to{opacity:.7}}.member-header{align-items:center;display:flex;margin-bottom:8px}.member-name{flex:1 1;min-width:0}.name-text{color:#020817;font-size:14px;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.generation-info{margin-top:4px}.member-position{align-items:center;border-top:1px solid #e2e8f0;display:flex;margin:8px 0;padding:6px 0}.position-text{color:#64748b;flex:1 1;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-meta{border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;padding-top:8px}.member-meta .ant-tag{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;font-size:11px;line-height:18px;margin:0;padding:2px 6px}.family-member-tooltip{font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif;max-width:320px}.family-member-tooltip>div{color:#020817;font-size:13px;line-height:1.5;margin-bottom:6px}.family-member-tooltip>div:last-child{margin-bottom:0}.family-member-tooltip strong{color:#020817;font-weight:600}.react-flow__handle{background:#64748b;border:2px solid #fff;border-radius:50%;height:10px;width:10px}.react-flow__handle:hover{background:#2563eb}.react-flow__handle-top{top:-5px}.react-flow__handle-bottom{bottom:-5px}@media (max-width:768px){.family-member-node{max-width:180px;min-width:150px}.name-text{font-size:12px}.position-text{font-size:10px}}.member-card{background:#fff!important;border-color:#e2e8f0!important}.name-text{color:#020817!important}.position-text{color:#64748b!important}.member-meta,.member-position{border-color:#e2e8f0!important}.ant-tooltip-inner{font-size:12px!important}.has-collapsed-children{box-shadow:0 2px 8px #1890ff33!important;position:relative}.has-collapsed-children:hover{box-shadow:0 4px 12px #1890ff4d!important;transform:translateY(-1px);transition:all .2s ease}.collapse-indicator-bottom{align-items:center;background:#fff;border:1px solid #1890ff;border-radius:50%;bottom:-8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;height:18px;justify-content:center;left:50%;position:absolute;transform:translateX(-50%);width:18px;z-index:10}.collapse-indicator-bottom:hover{background:#f0f8ff;transform:translateX(-50%) scale(1.1);transition:all .2s ease}@media (max-width:768px){.collapse-indicator-bottom{bottom:-6px;height:16px;width:16px}}.react-flow{direction:ltr}.react-flow__container{height:100%;left:0;position:absolute;top:0;width:100%}.react-flow__pane{cursor:grab;z-index:1}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{pointer-events:none;transform-origin:0 0;z-index:2}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{overflow:visible;pointer-events:none}.react-flow__connection-path,.react-flow__edge-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{cursor:pointer;pointer-events:visibleStroke}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{box-sizing:border-box;cursor:grab;pointer-events:all;position:absolute;transform-origin:0 0;-webkit-user-select:none;user-select:none}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{pointer-events:none;transform-origin:left top;z-index:3}.react-flow__nodesselection-rect{cursor:grab;pointer-events:all;position:absolute}.react-flow__handle{background:#1a192b;border:1px solid #fff;border-radius:100%;height:6px;min-height:5px;min-width:5px;pointer-events:none;position:absolute;width:6px}.react-flow__handle.connectionindicator{cursor:crosshair;pointer-events:all}.react-flow__handle-bottom{bottom:-4px;left:50%;top:auto;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{left:-4px;top:50%;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{margin:15px;position:absolute;z-index:5}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translateX(-50%)}.react-flow__attribution{background:#ffffff80;font-size:10px;margin:0;padding:2px 3px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{height:100%;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{background-color:#fff;border:1px solid #1a192b;border-radius:3px;color:#222;font-size:12px;padding:10px;text-align:center;width:150px}.react-flow__node-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{background:#fefefe;border-bottom:1px solid #eee;box-sizing:initial;cursor:pointer;height:16px;padding:5px;-webkit-user-select:none;user-select:none;width:16px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{max-height:12px;max-width:12px;width:100%}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;height:4px;transform:translate(-50%,-50%);width:4px}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{height:100%;top:0;transform:translate(-50%);width:1px}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.bottom,.react-flow__resize-control.line.top{height:1px;left:0;transform:translateY(-50%);width:100%}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.family-tree-container{background:#fff;display:flex;flex-direction:column;height:100vh}.family-tree-container.fullscreen{background:#fff;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}.unified-navbar{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;flex-shrink:0;justify-content:space-between;padding:12px 24px;z-index:1000}.navbar-left,.unified-navbar{align-items:center;display:flex}.navbar-left{gap:16px}.logo{border-radius:8px;height:40px;justify-content:left}.title h1{color:#020817;font-size:20px;font-weight:600;line-height:1.2;margin:0}.title .subtitle{color:#64748b;display:block;font-size:12px;margin-top:2px}.navbar-right{align-items:center;display:flex;gap:16px}.status-info{align-items:flex-end;flex-direction:column;gap:2px;min-width:80px}.count-info,.quick-actions,.search-section{align-items:center;display:flex}.quick-actions{gap:8px}.status-badge{display:inline-block;line-height:1.2;padding:2px 6px;white-space:nowrap}.status-badge.focus{border:1px solid #fdd9bd;color:#f97819}.admin-control-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;margin:16px 24px}.control-main-row{align-items:center;display:flex;gap:20px;justify-content:space-between;padding:12px 20px}.control-left{align-items:center;display:flex;flex:0 0 auto;gap:12px;padding-left:20px}.control-left .ant-select{position:relative}.control-left .ant-select .ant-select-selector{padding-left:0!important}.control-left .ant-select .ant-select-selector .ant-select-selection-search{left:0!important}.control-left .ant-select .ant-select-selector .ant-select-selection-search .ant-select-selection-search-input{padding-left:32px!important}.control-left .ant-input-affix-wrapper{position:relative}.control-left .ant-input-affix-wrapper .ant-input-prefix{color:#64748b;left:11px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:10}.control-left .ant-input-affix-wrapper .ant-input{padding-left:32px!important;padding-right:11px!important}.ant-select-dropdown .ant-select-item{padding:8px 12px}.ant-select-dropdown .ant-select-item-option-content{align-items:center;display:flex;justify-content:space-between;width:100%}.control-center{flex:1 1;justify-content:center}.control-center,.control-right{align-items:center;display:flex}.control-right{flex:0 0 auto}.status-indicator{align-items:center;display:flex}.status-badge{border-radius:4px;font-size:11px;font-weight:500;line-height:1.4;padding:2px 8px}.status-badge.complete{background:#edfdf3;border:1px solid #c1f7d5;color:#16a34a}.status-badge.focus{background:#fef3eb;border:1px solid #fdd5ba;color:#d65b05}.status-badge.search{background:#f3ecfd;border:1px solid #d6c1f9;color:#5f14df}.status-badge.smart{background:#effbf9;border:1px solid #c7f0ec;color:#1e766c}.drawer-content{font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif}.drawer-section{margin-bottom:24px}.drawer-section h4{color:#020817;font-size:14px;font-weight:600;margin:0 0 12px}.generation-filter-drawer{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.statistics-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.stat-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;flex-direction:column;padding:12px}.stat-label{color:#64748b;font-size:11px;margin-bottom:4px}.stat-value{color:#020817;font-size:18px;font-weight:600}.stat-value.male{color:#2563eb}.stat-value.female{color:#e11d48}.control-row .ant-btn-primary.ant-btn-lg{background:linear-gradient(135deg,#2563eb,#7c3aed);border:none;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;font-weight:600;height:40px;padding:0 24px}.control-row .ant-btn-primary.ant-btn-lg:hover{background:linear-gradient(135deg,#1555e2,#6c22eb);box-shadow:0 6px 8px -1px #00000026,0 4px 6px -2px #0000001a;transform:translateY(-1px)}.control-row .ant-btn-primary.ant-btn-lg:active{transform:translateY(0)}.floating-hint{animation:fadeInUp .5s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff;background:#fffffff2;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;padding:8px 16px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.selected-node-info{font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif}.selected-node-info p{color:#020817;line-height:1.5}.selected-node-info strong{color:#020817;font-weight:600}.react-flow__panel .ant-card{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a!important;max-height:600px}.react-flow__panel .ant-card-head{background:#f8fafc!important;border-bottom:1px solid #e2e8f0!important;color:#020817!important}.react-flow__panel .ant-card-body{background:#fff!important;color:#020817!important}.flow-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;flex:1 1;margin:16px 24px 24px;overflow:hidden}.family-tree-loading{align-items:center;display:flex;flex-direction:column;height:400px;justify-content:center}.selected-node-info p{font-size:13px;line-height:1;margin-bottom:8px}.selected-node-info p:last-child{margin-bottom:0}.react-flow__node-familyMember{background:#0000;border:none;padding:0}.react-flow__edge-default{stroke:#64748b;stroke-width:2;stroke-dasharray:none;fill:none}.react-flow__edge-selected{stroke:#2563eb;stroke-width:3}.react-flow__edge-path{stroke-linecap:round;stroke-linejoin:round}.react-flow__edge .react-flow__edge-path{stroke:#64748b;stroke-width:2}.react-flow__controls{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d}.react-flow__controls-button{align-items:center;background:#0000;border:none;color:#64748b;display:flex;font-size:16px;height:32px;justify-content:center;width:32px}.react-flow__controls-button:hover{background:#f8fafc;color:#020817}.react-flow__minimap{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d}.react-flow__background{background:#f8fafc}.react-flow__panel{background:#0000;margin-top:200px}.flow-container{-webkit-overflow-scrolling:touch;touch-action:manipulation;-webkit-user-select:none;user-select:none}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}@media (max-width:768px){.react-flow{height:calc(100vh - 140px)!important;touch-action:manipulation}.mobile-layout .react-flow{height:calc(100vh - 104px)!important;width:100%!important}.mobile-layout .react-flow__renderer{height:100%!important;width:100%!important}.react-flow__pane{cursor:grab;touch-action:manipulation}.react-flow__pane:active{cursor:grabbing}.react-flow__node{pointer-events:auto;touch-action:manipulation}.react-flow__controls{bottom:20px!important;right:10px!important;z-index:1000}.react-flow__controls button{border-radius:8px!important;box-shadow:0 2px 8px #00000026!important;font-size:18px!important;height:44px!important;width:44px!important}.react-flow__edge{pointer-events:none}.react-flow__nodesselection,.react-flow__selection{display:none}}@media (max-width:1200px){.admin-control-panel{margin:12px 16px}.flow-container{margin:0 16px 16px}.control-main-row{gap:12px}.control-left .ant-input-search{width:200px!important}}@media (max-width:768px){.family-tree-container{height:100vh}.mobile-layout .family-tree-container{height:calc(100vh - 56px)}.unified-navbar{flex-wrap:wrap;gap:8px;padding:8px 16px}.mobile-layout .unified-navbar{align-items:center;background:#fff;border-bottom:.5px solid #e5e5e5;flex-wrap:nowrap!important;gap:8px;min-height:44px;padding:4px 12px}.mobile-layout .navbar-left{flex:1 1;gap:8px;min-width:0}.mobile-layout .logo{flex-shrink:0;height:32px;width:32px}.mobile-layout .title h1{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-layout .navbar-right{flex-shrink:0;gap:4px}.mobile-layout .control-left{flex:1 1;min-width:0}.mobile-layout .control-left .ant-input-search{max-width:150px;width:100%!important}.mobile-layout .control-right{flex-shrink:0;gap:4px}.mobile-layout .control-right .ant-typography{font-size:12px;white-space:nowrap}.mobile-layout .ant-dropdown-trigger,.mobile-layout .control-right .ant-btn:not(.mode-toggle):not(.member-count),.mobile-layout .control-right .ant-btn[title*=\66F4\591A],.mobile-layout .control-right .ant-btn[title*=\83DC\5355],.mobile-layout .control-right .ant-btn[title*=\8BBE\7F6E],.mobile-layout .control-right .ant-dropdown,.mobile-layout .navbar-right .ant-dropdown{display:none!important}.mobile-layout .navbar-right{gap:2px}.mobile-layout .control-right>:not(.mode-toggle):not(.member-count){display:none!important}.mobile-layout .mode-toggle{font-size:12px!important;height:28px!important;padding:4px 8px!important}.mobile-layout .member-count{font-size:11px!important;height:24px!important;padding:2px 6px!important}.navbar-left{gap:12px}.logo{height:32px;width:32px}.title h1{font-size:18px}.title .subtitle{font-size:11px}.navbar-right{gap:12px}.status-info{gap:1px;min-width:60px}.status-badge{font-size:10px;padding:1px 4px}.count-info .ant-typography{font-size:10px!important}.search-section .ant-select{width:160px!important}.quick-actions{gap:6px}.admin-control-panel{margin:8px 12px}.flow-container{margin:0 12px 12px}.control-main-row{flex-direction:column;gap:12px;padding:16px}.control-center,.control-left,.control-right{justify-content:center;width:100%}.control-left{flex-direction:column;gap:8px}.control-left .ant-input-search{width:100%!important}.statistics-grid{grid-template-columns:1fr}.react-flow__panel{margin:8px;position:relative!important;transform:none!important}.react-flow__panel .ant-card{max-width:none!important;width:calc(100vw - 32px)!important}}@media (max-width:480px){.admin-control-panel{margin:8px}.flow-container{margin:0 8px 8px}.control-main-row{padding:12px}.control-center .ant-space{flex-wrap:wrap;justify-content:center}.react-flow__controls{bottom:60px}}.control-panel,.family-tree-container,.flow-container{background:#fff!important}@media print{.control-panel{display:none}.family-tree-container{height:auto}.flow-container{border-radius:0;box-shadow:none;height:100vh;margin:0}.react-flow__controls,.react-flow__minimap{display:none}}.ant-select-selection-placeholder{padding-left:34px!important}.compact-search-alert{animation:slideInDown .3s ease-out;font-size:12px!important}.compact-search-alert.fade-out{animation:fadeOut .5s ease-out forwards}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.compact-search-alert .ant-alert-message{font-size:12px!important;font-weight:500!important;margin-bottom:0!important}.compact-search-alert .ant-alert-description{font-size:11px!important;margin-top:2px!important}.compact-search-alert .ant-alert-close-icon{font-size:11px!important}.sidebar{background:linear-gradient(180deg,#6b46c1,#7c3aed 50%,#8b5cf6);box-shadow:4px 0 20px #0000001a;display:flex;flex-direction:column;height:100vh;left:0;padding:16px 0;position:fixed;top:0;transition:width .3s ease;width:140px;z-index:1000}.sidebar.collapsed{width:60px}.sidebar.collapsed .logo-text{display:none}.sidebar.collapsed .nav-link{justify-content:center;padding:12px 8px}.logo{align-items:center;display:flex;gap:8px;margin-bottom:24px;padding:0 12px;position:relative}.logo-icon{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:1px solid #ffffff1a;border-radius:8px;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.logo-icon,.logo-text{color:#fff;font-size:14px;font-weight:600}.logo-text{letter-spacing:.5px;transition:opacity .3s ease}.collapse-toggle{position:absolute;right:-12px;top:50%;transform:translateY(-50%);z-index:1001}.collapse-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #8b5cf64d;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#8b5cf6;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;transition:all .3s ease;width:24px}.collapse-btn:hover{background:#8b5cf6;box-shadow:0 4px 12px #8b5cf64d;color:#fff;transform:scale(1.1)}.collapse-btn:active{transform:scale(.95)}.sidebar.collapsed .collapse-toggle{right:-12px}.sidebar.collapsed .collapse-btn{transform:rotate(180deg)}.sidebar.collapsed .collapse-btn:hover{transform:rotate(180deg) scale(1.1)}.nav-menu{flex:1 1;list-style:none;margin:0;padding:0}.nav-item{margin-bottom:4px}.nav-link{align-items:center;background:none;border:none;border-radius:8px;color:#fffc;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;margin:0 8px;padding:12px;position:relative;text-align:left;text-decoration:none;transition:all .3s ease;width:calc(100% - 16px)}.nav-link:hover{background:#ffffff1a;color:#fff;text-decoration:none}.nav-item.active .nav-link{background:#ffffff26;color:#fff;position:relative}.nav-item.active .nav-link:before{background:#fff;border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.nav-icon{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.nav-icon .anticon{font-size:16px}@media (max-width:1024px){.sidebar{width:120px}.sidebar.collapsed{width:60px}.logo-text{font-size:13px}.nav-link{font-size:12px;padding:10px}}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}.sidebar-overlay{background:#00000080;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;transition:all .3s ease;visibility:hidden;z-index:999}.sidebar-overlay.show{opacity:1;visibility:visible}}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#ffffff1a}.sidebar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff80}.user-section{border-top:1px solid #ffffff1a;margin-top:auto;padding:12px 8px 0}.user-profile-sidebar{align-items:center;background:#ffffff1a;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:all .3s ease}.user-profile-sidebar:hover{background:#ffffff26}.user-profile-sidebar.collapsed{justify-content:center;padding:8px}.user-avatar-sidebar{align-items:center;background:#fff3;border:1px solid #ffffff1a;border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.user-info-sidebar{flex:1 1;min-width:0}.user-name-sidebar{color:#fff;font-size:12px;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-logout-sidebar{color:#ffffffb3;cursor:pointer;font-size:11px;transition:color .2s ease}.user-logout-sidebar:hover{color:#fff}.family-search-bar{align-items:center;display:flex;gap:12px}.status-info{align-items:center;display:flex;gap:8px}.count-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;font-size:11px;padding:2px 6px}.search-section{position:relative}.family-search-input{background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:13px;height:28px;transition:border-color .2s ease}.family-search-input:hover{border-color:#9ca3af}.family-search-input.ant-input-focused,.family-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.family-search-input .ant-input-prefix{color:#6b7280;margin-right:6px}.family-search-dropdown{border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;max-height:200px;overflow:hidden}.family-search-dropdown .ant-select-item{border-bottom:1px solid #f3f4f6;font-size:12px;padding:6px 12px;transition:background-color .15s ease}.family-search-dropdown .ant-select-item:last-child{border-bottom:none}.family-search-dropdown .ant-select-item:hover{background:#f9fafb}.family-search-dropdown .ant-select-item-option-selected{background:#dbeafe;color:#1d4ed8}@media (max-width:768px){.family-search-bar{align-items:stretch;flex-direction:column;gap:12px}.search-section{width:100%}.search-section .ant-select{width:100%!important}.family-search-input{font-size:16px}.status-info{justify-content:center}}@media (max-width:480px){.family-search-bar{gap:8px}.count-info{font-size:11px;padding:3px 6px}}.family-search-bar.loading .family-search-input{background:#f1f5f9;cursor:wait}.family-search-bar.error .family-search-input{background:#fef2f2;border-color:#ef4444}.family-search-bar.error .family-search-input:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.family-search-bar.success .family-search-input{background:#f0fdf4;border-color:#10b981}.family-search-dropdown .ant-select-item[data-type=member]{background:#fff;border-left:2px solid #10b981}.family-search-dropdown .ant-select-item[data-type=member]:hover{background:#f0fdf4}.family-search-input.searching{border-color:#3b82f6}.tenant-selector{align-items:center;display:flex;gap:8px}.tenant-selector .ant-select{min-width:200px}.tenant-selector .ant-select-selector{border:1px solid #d9d9d9;border-radius:6px;transition:all .3s}.tenant-selector .ant-select-selector:hover{border-color:#40a9ff}.tenant-selector .ant-select-focused .ant-select-selector{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.tenant-selector .ant-btn{align-items:center;border-radius:6px;display:flex;justify-content:center}.tenant-selector .ant-btn:hover{border-color:#40a9ff;color:#40a9ff}.tenant-selector .ant-select-dropdown{border-radius:8px;box-shadow:0 6px 16px 0 #00000014,0 3px 6px -4px #0000001f,0 9px 28px 8px #0000000d}.tenant-selector .ant-select-item{border-radius:4px;margin:2px 4px;padding:8px 12px}.tenant-selector .ant-select-item:hover{background-color:#f5f5f5}.tenant-selector .ant-select-item-option-selected{background-color:#e6f7ff;font-weight:500}.tenant-selector .ant-select-dropdown .ant-btn{border:none;box-shadow:none;color:#1890ff;font-weight:500}.tenant-selector .ant-select-dropdown .ant-btn:hover{background-color:#f0f8ff;color:#1890ff}.tenant-selector .anticon-delete{opacity:0;transition:opacity .2s}.tenant-selector .ant-select-item:hover .anticon-delete{opacity:1}.tenant-selector .anticon-delete:hover{color:#ff4d4f!important;transform:scale(1.1)}.tenant-selector .anticon-home{color:#1890ff}@media (max-width:768px){.tenant-selector{align-items:stretch;flex-direction:column;gap:12px}.tenant-selector .ant-select{min-width:auto;width:100%}.tenant-selector .ant-space{width:100%}.tenant-selector .ant-space-item:first-child{flex:1 1}}.tenant-selector .ant-modal-header{border-bottom:1px solid #f0f0f0;padding:16px 24px}.tenant-selector .ant-modal-title{color:#262626;font-size:16px;font-weight:600}.tenant-selector .ant-modal-body{padding:24px}.tenant-selector .ant-form-item-label>label{color:#262626;font-weight:500}.tenant-selector .ant-form-item-extra{color:#8c8c8c;font-size:12px;margin-top:4px}.tenant-selector .ant-input,.tenant-selector .ant-input-focused,.tenant-selector .ant-input:focus{border-radius:6px}.tenant-selector .ant-switch{background-color:#f0f0f0}.tenant-selector .ant-switch-checked{background-color:#1890ff}.tenant-selector .ant-select-loading,.tenant-selector .ant-spin-dot{color:#1890ff}.tenant-selector .ant-tooltip-inner{background-color:#262626;border-radius:4px;font-size:12px}.tenant-selector .ant-tooltip-arrow:before{background-color:#262626}.main-content{background:#f8fafc;margin-left:140px;min-height:100vh;position:relative;transition:margin-left .3s ease}.main-content.sidebar-collapsed{margin-left:60px}.header{background:#fff;box-shadow:0 1px 4px #0000000a;gap:16px;justify-content:space-between;min-height:48px;padding:8px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header .header-left{align-items:center;display:flex}.header .header-left{flex:1 1}.header .header-right{align-items:center;display:flex}.cover-image{background:linear-gradient(135deg,#667eea,#764ba2);height:200px;overflow:hidden;position:relative}.cover-image:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='25' cy='25' r='1' fill='%23fff' opacity='.1'/%3E%3Ccircle cx='75' cy='75' r='1' fill='%23fff' opacity='.1'/%3E%3Ccircle cx='50' cy='10' r='.5' fill='%23fff' opacity='.15'/%3E%3Ccircle cx='10' cy='60' r='.5' fill='%23fff' opacity='.15'/%3E%3Ccircle cx='90' cy='40' r='.5' fill='%23fff' opacity='.15'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.content-container{box-sizing:border-box;display:flex;flex-direction:column;height:calc(100vh - 80px);margin:0 auto;max-width:1400px;padding:32px}@media (max-width:1024px){.main-content{margin-left:120px}.main-content.sidebar-collapsed{margin-left:60px}.header{padding:16px 24px}.content-container{padding:24px}}@media (max-width:768px){.main-content{margin-left:0}.header{flex-direction:column;gap:16px;padding:12px 16px;position:relative}.search-box{max-width:none;order:2}.user-profile{align-self:flex-end;order:1}.user-info{display:none}.cover-image{height:120px}.content-container{padding:16px}}@media (max-width:480px){.search-input,.user-avatar{font-size:16px}.user-avatar{height:40px;width:40px}}.app-layout{background:#f8fafc;position:relative}.sidebar-wrapper{height:100vh;left:0;position:fixed;top:0;transition:width .3s ease;z-index:1000}.sidebar-wrapper.collapsed{width:60px}.sidebar-overlay{background:#00000080;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;transition:all .3s ease;visibility:hidden;z-index:999}.sidebar-overlay.show{opacity:1;visibility:visible}.mobile-menu-btn{align-items:center;background:#fff;border:none;border-radius:12px;box-shadow:0 4px 12px #00000026;cursor:pointer;display:none;flex-direction:column;gap:4px;height:44px;justify-content:center;left:20px;position:fixed;top:20px;transition:all .3s ease;width:44px;z-index:1001}.mobile-menu-btn:hover{background:#f8fafc;transform:scale(1.05)}.mobile-menu-btn span{background:#64748b;border-radius:1px;height:2px;transition:all .3s ease;width:20px}.mobile-menu-btn:hover span{background:#8b5cf6}.content-grid{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:300px 1fr 280px}.space-y-5>*+*{margin-top:20px}.space-y-4>*+*{margin-top:16px}.space-y-3>*+*{margin-top:12px}@media (max-width:1200px){.content-grid{gap:24px;grid-template-columns:280px 1fr 260px}}@media (max-width:1024px){.content-grid{gap:20px;grid-template-columns:1fr 240px}}@media (max-width:768px){.sidebar-wrapper{transform:translateX(-100%);transition:transform .3s ease}.sidebar-wrapper.open{transform:translateX(0)}.mobile-menu-btn{display:flex}.content-grid{gap:16px;grid-template-columns:1fr}}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0;padding:0}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::selection{background:#8b5cf633;color:#1e293b}:focus-visible{outline:2px solid #8b5cf6;outline-offset:2px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.slide-in-left{animation:slideInLeft .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.slide-in-right{animation:slideInRight .3s ease-out}.family-tree-page{display:flex;flex-direction:column;height:100%;min-height:600px}.family-tree-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;flex:1 1;min-height:500px;overflow:hidden;position:relative}.family-tree-wrapper .family-tree-container{background:#0000!important;display:flex!important;flex-direction:column!important;height:100%!important}.family-tree-wrapper .family-tree-container>div:last-child{flex:1 1!important;height:auto!important}.family-tree-wrapper .react-flow{background:#fff;height:100%}.family-tree-wrapper .react-flow__viewport{height:100%}@media (max-width:768px){.family-tree-page{height:calc(100vh - 120px)}.family-tree-wrapper{border-radius:12px;margin:0 -16px;min-height:400px}}.settings-page{height:100%;overflow:auto;padding-bottom:80px}.settings-container{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:600px}.settings-card{border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 2px 4px #0000000f;transition:all .3s ease}.settings-card:hover{box-shadow:0 4px 12px #0000001a}.settings-list-item{border-bottom:1px solid #f1f5f9;padding:16px 0}.settings-list-item:last-child{border-bottom:none}.settings-icon{align-items:center;color:#8b5cf6;display:flex;font-size:18px;height:24px;justify-content:center;width:24px}.settings-title{color:#1e293b;font-size:15px;font-weight:600}.settings-description{color:#64748b;font-size:13px;line-height:1.4}.stat-item{padding:8px 0;text-align:center}.control-button{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;display:flex;height:auto;justify-content:flex-start;min-height:56px;padding:16px;text-align:left;transition:all .3s ease}.control-button:hover{background:#faf9ff;border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf626;transform:translateY(-1px)}.control-button.ant-btn-dangerous{background:#fff2f0;border-color:#ff7875}.control-button.ant-btn-dangerous:hover{background:#ffebe6;border-color:#ff4d4f;box-shadow:0 4px 12px #ff4d4f33;transform:translateY(-1px)}.control-button.ant-btn-dangerous .control-title{color:#cf1322}.control-button.ant-btn-dangerous .control-description{color:#a8071a}.control-title{color:#1e293b;font-size:15px;font-weight:600;margin-bottom:4px}.control-description{color:#64748b;font-size:13px;font-weight:400;line-height:1.4}.about-button{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;height:56px;transition:all .3s ease}.about-button:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 8px 16px #8b5cf64d;color:#fff;transform:translateY(-1px)}@media (max-width:768px){.settings-container{padding:0 16px}.settings-card{border-radius:12px}.control-button{min-height:48px;padding:12px}.control-title{font-size:14px}.control-description{font-size:12px}.about-button{font-size:15px;height:48px}}.settings-list-item .ant-switch{background-color:#e2e8f0}.settings-list-item .ant-switch-checked{background-color:#8b5cf6}.settings-list-item .ant-switch:focus{box-shadow:0 0 0 2px #8b5cf633}.settings-card .ant-tag{border-radius:8px;font-weight:500;padding:4px 12px}.settings-card .ant-divider{border-color:#f1f5f9}.ant-modal-content{border-radius:16px;overflow:hidden}.ant-modal-header{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-bottom:none;padding:20px 24px}.ant-modal-title{color:#fff;font-weight:600}.ant-modal-close{color:#fff}.ant-modal-close:hover{color:#fffc}.data-management-page{background:#f7f7f8;min-height:calc(100vh - 80px)}.page-header{margin-bottom:24px}.page-header h1{color:#1e1e2d;font-size:28px;font-weight:600;margin:0 0 6px}.page-header p{color:#6b7280;font-size:16px;margin:0}.table-toolbar{align-items:center;display:flex;gap:8px}.table-toolbar .ant-btn-sm{font-size:12px;height:28px;padding:0 8px}.ant-card{border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000f}.ant-card-head{border-bottom:1px solid #f0f0f0;font-weight:600;padding:12px 16px}.ant-card-body{padding:16px}.ant-modal-body{padding:16px 24px}.ant-modal-body h4{color:#374151;font-size:14px;font-weight:600;margin:0 0 12px}.preview-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin-top:12px}.preview{background:#fafafa;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.preview img{display:block;height:80px;object-fit:cover;width:100%}.json-output{background:#f8fafc;color:#374151;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;resize:vertical}.stats-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:12px}@media (max-width:768px){.data-management-page{padding:16px}.page-header h1{font-size:24px}.page-header p{font-size:14px}.table-toolbar{align-items:flex-start;flex-direction:column;gap:8px}.ant-card-body{padding:12px}.ant-modal{margin:16px}}.creator-page{background:#f7f7f8;padding:24px}.creator-header h1{color:#1e1e2d;margin:0 0 6px}.creator-header p{color:#6b7280;margin:0 0 16px}.card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #00000014;margin-bottom:18px}.card-padding{padding:16px}.uploader{align-items:center;display:flex;gap:10px;margin:10px 0 12px}.btn{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#111827;cursor:pointer;font-weight:600;padding:8px 12px}.btn.primary{background:#a303a0;border-color:#a303a0;color:#fff}.btn:disabled{cursor:not-allowed;opacity:.5}.discover-page{background:#f4f5f7}.discover-cover{background:linear-gradient(135deg,#d63384,#a855f7);border-radius:5px;height:280px;margin-bottom:40px;position:relative}.discover-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:260px 1fr 260px;margin-top:-120px;position:relative;z-index:10}.center-column,.left-column,.right-column{display:block}.profile-card-box{background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000000f;padding:30px;text-align:center}.profile-card-avatar{background:#fbb03b;border-radius:50%;display:block;height:180px;margin:0 auto 30px;object-fit:cover;width:180px}.profile-card-name{color:#a303a0;font-size:30px;font-weight:800;margin:0 0 10px}.profile-card-location{color:#a303a0b3;margin:0 0 30px}.profile-card-actions{display:flex;gap:12px;justify-content:center;margin-bottom:30px}.profile-card-actions .message-btn{align-items:center;background:#a303a0;border:none;border-radius:50%;color:#fff;display:flex;height:46px;justify-content:center;width:46px}.profile-card-actions .follow-btn{background:#a303a0;border:none;border-radius:10px;color:#fff;font-weight:600;padding:10px 18px}.profile-card-actions .family-btn{background:#0000;border:1px solid #a303a0;border-radius:10px;color:#a303a0;font-weight:600;padding:10px 18px}.profile-card-actions .icon{height:24px;width:24px}.about-card-box{background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000000f;padding:30px}.about-title{color:#a303a0;font-size:18px;font-weight:800;margin:0 0 20px}.about-list{display:flex;flex-direction:column;gap:8px}.about-row{align-items:center;border-bottom:1px solid #0302291a;display:flex;padding:8px 0}.about-row:last-child{border-bottom:none}.about-row .icon.purple{color:#a303a0;height:24px;margin-right:10px;width:24px}.about-text{color:#490057b3}.center-column{background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000000f;padding:30px}.feed-tabs{border-bottom:1px solid #0302291a;display:flex;gap:30px;margin-bottom:30px;padding-bottom:12px}.tab{background:#0000;border:none;color:#a303a0b3;cursor:pointer;font-size:20px;padding:0}.tab.active{color:#a303a0;font-weight:800}.posts-list{display:flex;flex-direction:column;gap:40px}.post-card{border-bottom:1px solid #0302291a;padding-bottom:40px}.post-card:last-child{border-bottom:none}.post-header{margin-bottom:12px}.post-header,.post-user{align-items:center;display:flex}.post-user{gap:12px}.post-avatar{border-radius:50%;height:80px;width:80px}.post-user-name{color:#490057;font-weight:800}.post-time{color:#49005799;font-size:10px;margin-top:2px}.more-btn{background:#0000;border:none;cursor:pointer;margin-left:auto}.post-image{border-radius:10px;height:256px;margin:12px 0 16px;object-fit:cover;width:100%}.post-text{color:#490057;margin:0 0 16px}.post-actions-row{gap:20px}.action,.post-actions-row{align-items:center;display:flex}.action{color:#a303a0;font-weight:800;gap:8px}.action .icon{height:28px;width:28px}.action-text{color:#a303a0}.right-column{display:flex;flex-direction:column;gap:20px}.side-card{background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000000f;padding:25px}.side-title{color:#490057;font-weight:800;margin:0 0 16px}.side-list{display:flex;flex-direction:column;gap:14px}.side-row{align-items:center;display:flex;gap:12px;padding-bottom:12px}.side-row.with-border{border-bottom:1px solid #0000000d}.side-avatar{border-radius:50%;height:34px;width:34px}.side-meta .side-name{color:#490057;font-size:12px;margin-bottom:2px}.side-meta .side-sub{color:#49005780;font-size:10px}.status-dot{border-radius:50%;height:5px;margin-left:auto;width:5px}.status-dot.online{background:#2cc84a}.status-dot.busy{background:#ff8f6b}.status-dot.offline{background:#9ca3af}@media (max-width:1100px){.discover-grid{grid-template-columns:1fr;margin-top:-40px}.right-column{order:3}.left-column{order:1}.center-column{order:2}}@media (max-width:768px){.discover-cover{height:220px}.about-card-box,.center-column,.profile-card-box,.side-card{padding:20px}}.app-layout{background:#fff;min-height:100vh}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 2px 0 #0000000d;padding:0 24px;position:relative;z-index:10}.header-content{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:16px 0}.header-content h2{color:#020817!important;font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif;font-size:24px;font-weight:700;letter-spacing:-.025em;line-height:1.2;margin:0!important}.header-content span{color:#64748b!important;font-size:14px;font-weight:400;margin:0}.app-content{background:#fff;min-height:calc(100vh - 64px);padding:0}@media (max-width:768px){.app-header{padding:0 16px}.header-content{align-items:flex-start;flex-direction:column;gap:4px;padding:12px 0}.header-content h2{color:#020817!important;font-size:20px!important}.header-content span{color:#64748b!important;font-size:12px!important}}@media (max-width:480px){.app-header{padding:0 12px}.header-content{padding:8px 0}.header-content h2{color:#020817!important;font-size:18px!important}}.ant-layout,.ant-layout-header,.app-content,.app-layout{background:#fff!important}.ant-layout-header{border-bottom:1px solid #e2e8f0!important}.ant-layout-content{background:#fff!important}.ant-typography{color:#020817!important}.ant-typography.ant-typography-secondary{color:#64748b!important}.ant-tooltip{z-index:9999!important}.ant-tooltip-inner{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a!important;color:#020817!important;font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif!important;font-size:13px!important;line-height:1.5!important;max-width:320px!important;padding:12px 16px!important}.ant-tooltip-arrow{display:none!important}.ant-tooltip-arrow:before{background:#fff!important;border:1px solid #e2e8f0!important}.ant-tooltip-inner strong{color:#020817!important;font-weight:600!important}.ant-tooltip-inner div{color:#020817!important;margin-bottom:6px!important}.ant-tooltip-inner div:last-child{margin-bottom:0!important}.ant-slider-tooltip .ant-tooltip-inner{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:6px!important;box-shadow:0 2px 4px -1px #0000001a!important;color:#020817!important;font-size:12px!important;min-height:auto!important;padding:4px 8px!important}.ant-slider-tooltip .ant-tooltip-arrow{display:none!important}@media print{.app-header{display:none}.app-content{min-height:auto;padding:0}}.mobile-layout{height:100vh}.mobile-layout,.mobile-layout .ant-layout{background:#f5f5f5}.mobile-layout .ant-layout-content{height:100%;overflow:hidden;padding:0}.mobile-layout .ant-tabs{display:flex;flex-direction:column;height:100%}.mobile-layout .ant-tabs-content-holder{flex:1 1;overflow:hidden}.mobile-layout .ant-tabs-tabpane{height:100%;overflow:hidden}.mobile-layout .ant-tabs-tab{align-items:center;background:#0000;border:none;display:flex;flex:1 1;flex-direction:column;justify-content:center;margin:0!important;min-height:56px;padding:6px 8px!important;position:relative;text-align:center;transition:all .2s ease}.mobile-layout .ant-tabs-tab-btn{align-items:center;color:#999;display:flex;flex-direction:column;font-size:10px;gap:2px;line-height:1.2;transition:color .2s ease}.mobile-layout .ant-tabs-tab-btn .anticon{font-size:22px;margin:0;transition:color .2s ease}.mobile-layout .ant-tabs-tab.ant-tabs-tab-active .ant-tabs-tab-btn,.mobile-layout .ant-tabs-tab.ant-tabs-tab-active .anticon{color:#07c160}.mobile-layout .ant-tabs-ink-bar{display:none}.mobile-layout .ant-tabs-tab-bar{background:#f7f7f7;border-top:.5px solid #e5e5e5;margin:0;padding:0}.desktop-layout{height:100vh}.desktop-layout .ant-layout{background:#f0f2f5}.desktop-layout .ant-layout-content{height:100%;padding:0}@media (max-width:768px){.react-flow{height:calc(100vh - 70px)!important}.mobile-layout .react-flow__attribution,.mobile-layout .react-flow__controls,.mobile-layout .react-flow__minimap,.mobile-layout .react-flow__panel{display:none!important}.mobile-layout .react-flow__node{font-size:12px}.mobile-layout .react-flow__edge{stroke-width:1px}.mobile-layout .ant-tabs-tabpane{height:calc(100vh - 56px)!important;overflow:hidden}.mobile-layout .family-tree-container{height:100%!important;position:relative}}@media (hover:none) and (pointer:coarse){.ant-btn,.ant-card,.ant-list-item{cursor:default}.ant-btn:hover,.ant-card:hover,.ant-list-item:hover{transform:none}.ant-switch{min-height:28px;min-width:48px}.ant-tabs-tab{min-height:60px;min-width:60px}}@supports (padding:max(0px)){.mobile-layout,.mobile-layout .ant-tabs-tab-bar{padding-bottom:max(0px,env(safe-area-inset-bottom))}.mobile-layout .ant-tabs-tab-bar{height:56px;height:max(56px,calc(56px + env(safe-area-inset-bottom)))}.mobile-layout .ant-tabs-tabpane{height:calc(100vh - 56px)!important;height:calc(100vh - 112px)!important;padding-bottom:env(safe-area-inset-bottom,0)}}
/*# sourceMappingURL=main.014edac6.css.map*/