body{background:#ede0c8!important;font-family:"Noto Serif SC","Source Han Serif SC",SimSun,STSong,serif!important}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(139,69,19,.015) 2px,rgba(139,69,19,.015) 4px);pointer-events:none;z-index:-1}.classical-header-bg{background:radial-gradient(ellipse at 20% 50%,rgba(201,169,110,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(201,169,110,.08) 0%,transparent 50%)}.ant-layout-sider{background:linear-gradient(180deg,#f5e6c8,#ede0c8)!important;border-right:2px solid #C9A96E!important;box-shadow:2px 0 12px #8b451314!important;position:relative}.ant-layout-sider:after{content:"";position:absolute;top:0;right:-1px;width:3px;height:100%;background:linear-gradient(180deg,#c9a96e,#8b4513,#c9a96e);opacity:.4}.sider-title{font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;font-size:20px!important;font-weight:700!important;color:#8b4513!important;letter-spacing:4px;text-align:center;padding:16px 0;border-bottom:2px solid #C9A96E;position:relative;text-shadow:1px 1px 2px rgba(139,69,19,.1);transition:all .3s ease}.sider-title:hover{color:#b22222!important}.sider-title:before,.sider-title:after{content:"◆";color:#c9a96e;font-size:10px;margin:0 8px;vertical-align:middle}.ant-layout-sider-collapsed .sider-title{border-bottom:none!important;padding:20px 0 16px!important}.ant-layout-sider-collapsed .sider-title:before,.ant-layout-sider-collapsed .sider-title:after{display:none!important}.ant-menu{background:transparent!important;border-right:none!important}.ant-menu-item{font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;font-size:15px!important;color:#5c3d2e!important;border-radius:6px!important;margin:4px 8px!important;padding:6px 16px!important;transition:all .3s ease!important;position:relative}.ant-menu-item:hover{color:#b22222!important;background:#b222220f!important}.ant-menu-item-selected{color:#b22222!important;background:#b222221a!important;font-weight:600!important}.ant-menu-item-selected:before{content:"";position:absolute;left:0;top:25%;height:50%;width:3px;background:#b22222;border-radius:2px}.ant-layout-content{background:#f5e6c8!important}.ant-card{background:#fff8dc!important;border:1px solid #C9A96E!important;border-radius:8px!important;box-shadow:0 2px 8px #8b451314!important;position:relative}.ant-card-bordered{border-color:#c9a96e!important}.ant-card-head{border-bottom:1px solid #C9A96E!important;color:#8b4513!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;font-weight:600}.ant-btn-primary{background:linear-gradient(135deg,#b22222,#8b0000)!important;border-color:#8b0000!important;color:#fff!important;box-shadow:0 2px 6px #b222224d!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important}.ant-btn-primary:hover{background:linear-gradient(135deg,#c62828,#b22222)!important;border-color:#b22222!important;box-shadow:0 4px 12px #b2222266!important}.ant-btn-default{border-color:#c9a96e!important;color:#8b4513!important;background:#fff8dc!important}.ant-btn-default:hover{border-color:#b22222!important;color:#b22222!important;background:#fff0e0!important}.ant-btn-dashed{border-color:#c9a96e!important;color:#8b4513!important;background:transparent!important}.ant-btn-dashed:hover{border-color:#b22222!important;color:#b22222!important}.ant-tag{font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;border-radius:4px!important;padding:1px 8px!important}.ant-input{background:#fffaf0!important;border-color:#d4c5a0!important;color:#2c2c2c!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important}.ant-input:hover,.ant-input:focus{border-color:#b22222!important;box-shadow:0 0 0 2px #b222221a!important}.ant-input-affix-wrapper{background:#fffaf0!important;border-color:#d4c5a0!important}.ant-input-affix-wrapper:hover,.ant-input-affix-wrapper-focused{border-color:#b22222!important;box-shadow:0 0 0 2px #b222221a!important}.ant-select-selector{background:#fffaf0!important;border-color:#d4c5a0!important}.ant-select:hover .ant-select-selector{border-color:#b22222!important}.ant-picker{background:#fffaf0!important;border-color:#d4c5a0!important}.ant-picker:hover,.ant-picker-focused{border-color:#b22222!important}.ant-table{background:#fff8dc!important}.ant-table-thead>tr>th{background:#ede0c8!important;color:#8b4513!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;font-weight:600!important;border-bottom:2px solid #C9A96E!important}.ant-table-tbody>tr>td{border-bottom:1px solid #E8DCC8!important}.ant-table-tbody>tr:hover>td{background:#b222220a!important}.ant-modal-content{background:#fff8dc!important;border:1px solid #C9A96E!important}.ant-modal-header{background:#fff8dc!important;border-bottom:1px solid #C9A96E!important}.ant-modal-title{color:#8b4513!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;font-weight:600!important}.member-node{background:#fff8dc!important;border-color:#c9a96e!important;box-shadow:0 2px 6px #8b45131a!important;position:relative;transition:all .3s ease!important}.member-node:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid rgba(201,169,110,.3);border-radius:9px;pointer-events:none}.member-node:hover{border-color:#b22222!important;box-shadow:0 4px 16px #b2222226!important;transform:translateY(-2px)}.member-node.selected{border-color:#b22222!important;box-shadow:0 0 0 2px #b2222240!important}.member-node.deceased{background:#f5f0e0!important;opacity:.85}.member-node .avatar-wrapper{border-color:#c9a96e!important;background:#f5e6c8!important}.details-panel{background:linear-gradient(180deg,#fff8dc,#f5e6c8)!important;border-left:2px solid #C9A96E!important;box-shadow:-4px 0 20px #8b45131f!important}.lunar-result{background:#fff8dc!important;border-color:#c9a96e!important;position:relative}.lunar-result:before{content:"☰";position:absolute;top:-10px;left:50%;transform:translate(-50%);color:#c9a96e;font-size:16px}.stat-card{background:#fff8dc!important;border:1px solid #C9A96E!important;border-radius:8px!important;transition:all .3s ease}.stat-card:hover{border-color:#b22222!important;box-shadow:0 4px 12px #b222221a}.ant-collapse{background:#fff8dc!important;border-color:#c9a96e!important}.ant-collapse-header{color:#8b4513!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important}.ant-collapse-content{background:#fffaf0!important;border-color:#c9a96e!important}.tree-connector{background:#c9a96e!important}.gen-label{background:#f5e6c8!important;border-color:#c9a96e!important;color:#8b4513!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important;letter-spacing:2px}.ant-upload{font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important}.ant-divider{border-color:#c9a96e!important}.ant-steps-item-title{font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important}.ant-tooltip-inner{background:#5c3d2e!important;font-family:"Noto Serif SC",STKaiti,KaiTi,serif!important}.ant-tooltip-arrow:before{background:#5c3d2e!important}.ant-empty-description{color:#8b4513!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ede0c8}::-webkit-scrollbar-thumb{background:#c9a96e;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#b8976a}@media (max-width: 768px){.sider-title:before,.sider-title:after{display:none}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f5f5}.family-tree-container{width:100%;overflow:auto;padding:20px;min-height:600px}.tree-horizontal{display:flex;flex-direction:column;align-items:center;gap:40px;padding:40px 20px;min-width:fit-content}.tree-generation{display:flex;flex-direction:column;align-items:center;gap:16px;position:relative;width:100%}.gen-label{font-size:14px;font-weight:600;color:#8b4513;background:#fff8dc;padding:4px 16px;border-radius:12px;border:1px solid #DEB887;white-space:nowrap}.gen-members{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;position:relative}.tree-connector{width:2px;height:24px;background:#deb887;margin:0 auto}.member-node{background:#fff;border:2px solid #DEB887;border-radius:12px;padding:12px 16px;cursor:pointer;transition:all .2s;min-width:120px;max-width:160px;text-align:center;position:relative}.member-node:hover{border-color:#8b4513;box-shadow:0 4px 12px #8b451326;transform:translateY(-2px)}.member-node.selected{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff33}.member-node.deceased{background:#fafafa;opacity:.85}.member-node .avatar-wrapper{width:48px;height:48px;border-radius:50%;overflow:hidden;margin:0 auto 8px;background:#fff8dc;border:2px solid #DEB887;display:flex;align-items:center;justify-content:center}.member-node .avatar-wrapper img{width:100%;height:100%;object-fit:cover}.member-node .avatar-wrapper .no-avatar{font-size:20px;color:#8b4513}.member-node .node-name{font-weight:600;font-size:14px;color:#333;line-height:1.4}.member-node .node-pai{font-size:11px;color:#999}.member-node .node-years{font-size:11px;color:#999;margin-top:2px}.member-node .add-btn{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:24px;height:24px;border-radius:50%;background:#52c41a;color:#fff;border:2px solid white;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;opacity:0;transition:opacity .2s;z-index:2}.member-node:hover .add-btn{opacity:1}.member-node .gender-badge{display:inline-block;width:16px;height:16px;border-radius:50%;font-size:10px;line-height:16px;text-align:center;margin-left:4px}.member-node .gender-badge.male{background:#e6f7ff;color:#1890ff}.member-node .gender-badge.female{background:#fff0f6;color:#eb2f96}.details-panel{position:fixed;right:0;top:0;width:360px;height:100vh;background:#fff;box-shadow:-4px 0 20px #0000001a;padding:24px;overflow-y:auto;z-index:100;transition:transform .3s}.details-panel.closed{transform:translate(100%)}.lunar-calendar{max-width:400px;margin:0 auto}.lunar-result{background:#fff8dc;border:1px solid #DEB887;border-radius:8px;padding:16px;margin-top:12px;text-align:center}.lunar-result .lunar-title{font-size:13px;color:#8b4513;margin-bottom:8px}.lunar-result .lunar-text{font-size:18px;font-weight:600;color:#333;line-height:1.6}.stat-card{text-align:center;padding:20px;background:#fff;border-radius:12px;border:1px solid #f0f0f0}.stat-card .stat-value{font-size:32px;font-weight:700;color:#8b4513}.stat-card .stat-label{font-size:14px;color:#999;margin-top:4px}@media (max-width: 768px){.details-panel{width:100%}.member-node{min-width:100px;padding:8px 12px}}
