:root{--paper:#f5efe2;--paper-deep:#ede4d2;--surface:#fbf7eb;--surface-hi:#fff;--ink:#1c1814;--ink-2:#3a3329;--ink-3:#6a6052;--ink-4:#9b917f;--line:#1c18141f;--line-2:#1c18140f;--line-strong:#1c181438;--accent:#8a1717;--accent-2:#c44a2f;--accent-soft:#f0d9d5;--secondary:#2d4a4e;--tertiary:#b8895b;--gold:#a07d2b;--radius-sm:4px;--radius:8px;--radius-lg:14px;--shadow-sm:0 1px 2px #1c18140f;--shadow:0 4px 14px -4px #1c18142e, 0 1px 2px #1c181414;--shadow-lg:0 24px 60px -16px #1c181447;--font-serif:"Noto Serif SC", "Songti SC", "SimSun", serif;--font-sans:"Noto Sans SC", "PingFang SC", "Helvetica Neue", system-ui, sans-serif;--font-kai:"Ma Shan Zheng", "STKaiti", "KaiTi", "Noto Serif SC", serif;--font-mono:"JetBrains Mono", "SF Mono", ui-monospace, monospace}[data-theme=qing]{--accent:#2d4a4e;--accent-2:#4a747a;--accent-soft:#d9e5e5}[data-theme=zhe]{--accent:#a05c2b;--accent-2:#c47a44;--accent-soft:#efddca}[data-dark="1"]{--paper:#1a1614;--paper-deep:#14110f;--surface:#221d19;--surface-hi:#2a2420;--ink:#f0e8d8;--ink-2:#d4ccba;--ink-3:#a39c8c;--ink-4:#6e695c;--line:#f0e8d81f;--line-2:#f0e8d80f;--line-strong:#f0e8d838;--accent:#c44a2f;--accent-2:#d96b50;--accent-soft:#3a1f1a}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--paper);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-feature-settings:"kern";background-image:radial-gradient(#1c181406 1px, transparent 1px), linear-gradient(180deg, var(--paper) 0%, var(--paper-deep) 100%);background-size:22px 22px,100% 100%;min-height:100vh;font-size:14px;line-height:1.55}button{cursor:pointer;font-family:inherit}.app{grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{background:linear-gradient(180deg, var(--surface) 0%, var(--paper) 100%);border-right:1px solid var(--line);flex-direction:column;gap:4px;height:100vh;padding:22px 16px 16px;display:flex;position:sticky;top:0;overflow-y:auto}.brand{border-bottom:1px solid var(--line);align-items:center;gap:12px;margin-bottom:14px;padding:4px 6px 18px;display:flex}.brand .seal{background:var(--accent);color:#f6e9d3;width:38px;height:38px;font-family:var(--font-serif);letter-spacing:1px;box-shadow:inset 0 0 0 2px var(--accent), inset 0 0 0 3px #f6e9d3;border-radius:4px;place-items:center;font-size:16px;font-weight:700;display:grid;transform:rotate(-2deg)}.brand .name{font-family:var(--font-serif);letter-spacing:1px;font-size:16px;font-weight:600}.brand .name small{font-family:var(--font-sans);color:var(--ink-3);letter-spacing:2px;margin-top:2px;font-size:11px;font-weight:400;display:block}.family-switcher{background:var(--surface-hi);border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;align-items:center;gap:8px;margin-bottom:14px;padding:8px 10px;font-size:13px;display:flex;position:relative}.family-switcher:hover{border-color:var(--line-strong)}.family-switcher .tang{font-family:var(--font-serif);flex:1;font-weight:600}.family-switcher .meta{color:var(--ink-3);font-size:11px}.nav-group{letter-spacing:2px;color:var(--ink-4);text-transform:uppercase;padding:14px 10px 6px;font-size:10px}.nav-item{border-radius:var(--radius);color:var(--ink-2);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--line-2);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-16px}.nav-item .ico{opacity:.8;flex-shrink:0;width:16px;height:16px}.nav-item .badge{background:var(--accent);color:#fff;text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:11px}.sidebar-foot{border-top:1px solid var(--line);color:var(--ink-3);align-items:center;gap:10px;margin-top:auto;padding-top:14px;font-size:12px;display:flex}.avatar{background:var(--secondary);color:#f0e8d8;width:30px;height:30px;font-family:var(--font-serif);border-radius:50%;flex-shrink:0;place-items:center;font-weight:600;display:grid}.main{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--line);background:var(--paper);z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:center;gap:14px;padding:14px 28px;display:flex;position:sticky;top:0}.topbar h1{font-family:var(--font-serif);letter-spacing:.5px;margin:0;font-size:19px;font-weight:600}.topbar .crumbs{color:var(--ink-3);align-items:center;gap:6px;font-size:12px;display:flex}.topbar .spacer{flex:1}.search{background:var(--surface-hi);border:1px solid var(--line);color:var(--ink-3);border-radius:999px;align-items:center;gap:8px;min-width:240px;padding:6px 12px;font-size:13px;display:flex}.search input{color:var(--ink);background:0 0;border:0;outline:none;flex:1;min-width:0;font-family:inherit;font-size:13px}.btn{border-radius:var(--radius);background:var(--ink);color:var(--paper);border:1px solid var(--ink);align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;display:inline-flex}.btn:hover{background:var(--ink-2)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-2)}.btn.ghost{color:var(--ink-2);border-color:var(--line-strong);background:0 0}.btn.ghost:hover{background:var(--line-2);color:var(--ink)}.btn.sm{padding:4px 10px;font-size:12px}.btn.danger{background:var(--accent);border-color:var(--accent);color:#fff}.chip{background:var(--line-2);color:var(--ink-2);border:1px solid var(--line);border-radius:999px;align-items:center;gap:5px;padding:2px 9px;font-size:11.5px;display:inline-flex}.chip.accent{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}.chip.gold{color:var(--gold);background:#f5e9c8;border-color:#ead8a6}.chip.qing{color:var(--secondary);background:#d9e5e5;border-color:#c4d2d2}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px}.card-hd{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.card-hd h2{font-family:var(--font-serif);letter-spacing:.5px;margin:0;font-size:17px;font-weight:600}.card-hd .more{color:var(--ink-3);font-size:12px}.section-title{font-family:var(--font-serif);letter-spacing:2px;align-items:center;gap:12px;font-size:22px;font-weight:600;display:flex}.section-title:before{content:"";background:var(--accent);width:12px;height:12px;display:inline-block;transform:rotate(45deg)}.section-title:after{content:"";background:linear-gradient(90deg, var(--line-strong), transparent);flex:1;height:1px}.dot-rule{background:repeating-linear-gradient(90deg, var(--line-strong) 0 4px, transparent 4px 8px);border:0;height:1px}.stamp{background:var(--accent);color:#f6e9d3;width:50px;height:50px;font-family:var(--font-serif);letter-spacing:0;box-shadow:inset 0 0 0 2px var(--accent), inset 0 0 0 3px #f6e9d3;border-radius:4px;grid-template-columns:repeat(2,1fr);place-content:center;place-items:center;font-size:16px;font-weight:700;display:inline-grid;transform:rotate(-3deg)}.stamp.lg{width:70px;height:70px;font-size:22px}.stamp span{padding:2px;line-height:1}.page{width:100%;padding:28px 36px 80px}@media (max-width:860px){.app{grid-template-columns:1fr}.sidebar{z-index:100;width:240px;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.topbar{padding:12px 16px}.page{padding:18px 16px 80px}.search{flex:1;min-width:0}}.hero{grid-template-columns:1.6fr 1fr;gap:22px;margin-bottom:24px;display:grid}.hero .scroll-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:radial-gradient(circle at 20% 30%,#fff9,#0000 60%),linear-gradient(#fbf3df 0%,#f3e7c7 100%);min-height:240px;padding:32px 32px 28px;position:relative;overflow:hidden}[data-dark="1"] .hero .scroll-card{background:radial-gradient(circle at 20% 30%,#f0e8d814,#0000 60%),linear-gradient(#2a2420 0%,#1f1a16 100%)}.hero .scroll-card:before,.hero .scroll-card:after{content:"";opacity:.4;background:repeating-linear-gradient(90deg,#1c18142e 0 2px,#0000 2px 10px);height:14px;position:absolute;left:0;right:0}.hero .scroll-card:before{top:0}.hero .scroll-card:after{bottom:0}.hero .title-vert{font-family:var(--font-serif);color:var(--ink-3);letter-spacing:4px;writing-mode:vertical-rl;flex-direction:column;gap:6px;font-size:13px;display:flex;position:absolute;top:30px;right:24px}.hero .clan{font-family:var(--font-serif);letter-spacing:6px;margin:0 0 6px;font-size:38px;font-weight:600}.hero .tang-name{font-family:var(--font-kai);color:var(--accent);letter-spacing:8px;margin-bottom:18px;font-size:22px}.hero .motto{font-family:var(--font-serif);color:var(--ink-3);letter-spacing:1px;max-width:380px;margin-bottom:22px;font-size:14px;line-height:1.8}.hero .stats{gap:28px;display:flex}.hero .stat .n{font-family:var(--font-serif);color:var(--ink);font-size:26px;font-weight:600}.hero .stat .l{color:var(--ink-3);letter-spacing:2px;font-size:11.5px}.activity-list{flex-direction:column;gap:14px;display:flex}.activity-list li{grid-template-columns:32px 1fr auto;align-items:start;gap:12px;list-style:none;display:grid}.activity-list .dot{background:var(--accent-soft);width:30px;height:30px;color:var(--accent);font-family:var(--font-serif);border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:600;display:grid}.activity-list .who{color:var(--ink);font-size:13px;font-weight:500}.activity-list .what{color:var(--ink-3);font-size:12.5px;line-height:1.5}.activity-list .when{color:var(--ink-4);white-space:nowrap;font-size:11px}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}.kpi .lbl{letter-spacing:2px;color:var(--ink-3);text-transform:uppercase;font-size:11px}.kpi .v{font-family:var(--font-serif);margin:4px 0 2px;font-size:26px;font-weight:600}.kpi .d{color:var(--ink-4);font-size:11.5px}.kpi .d.up{color:#2d6a4f}.kpi .d.down{color:var(--accent)}.split-2{grid-template-columns:1.4fr 1fr;gap:22px;display:grid}@media (max-width:1100px){.split-2,.hero{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1400px){.page{padding:28px 48px 80px}.hero{grid-template-columns:minmax(380px,640px) 1fr}}@media (min-width:1800px){.page{padding:32px 64px 80px}.hero{grid-template-columns:minmax(400px,680px) 1fr}.kpi-grid{gap:18px}.split-2{gap:28px}}.tree-toolbar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);align-items:center;gap:10px;margin-bottom:14px;padding:8px 12px;display:flex}.tree-toolbar .seg{background:var(--line-2);border-radius:6px;padding:2px;display:flex}.tree-toolbar .seg button{color:var(--ink-3);background:0 0;border:0;border-radius:5px;padding:4px 12px;font-size:12px}.tree-toolbar .seg button.on{background:var(--surface-hi);color:var(--ink);box-shadow:var(--shadow-sm);font-weight:500}.tree-toolbar .gen-pick{color:var(--ink-3);align-items:center;gap:6px;font-size:12px;display:flex}.tree-toolbar .gen-pick select{border:1px solid var(--line);background:var(--surface-hi);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:12px}.tree-canvas{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);background-image:linear-gradient(#1c18140a 1px,#0000 1px),linear-gradient(90deg,#1c18140a 1px,#0000 1px);background-size:28px 28px;height:calc(100vh - 220px);min-height:540px;position:relative;overflow:hidden}.tree-stage{transform-origin:0 0;cursor:grab;position:absolute;inset:0}.tree-stage:active{cursor:grabbing}.tree-svg{pointer-events:none;position:absolute;top:0;left:0}.t-node{background:var(--surface-hi);border:1px solid var(--line-strong);width:132px;height:84px;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:6px;flex-direction:column;padding:8px 10px;transition:transform .12s,box-shadow .12s;display:flex;position:absolute}.t-node:hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-1px)}.t-node .gen-tag{background:var(--ink);color:var(--paper);font-family:var(--font-serif);letter-spacing:1px;border-radius:3px;padding:1px 6px;font-size:10px;position:absolute;top:-8px;left:10px}.t-node.female{border-color:var(--tertiary)}.t-node.female .gen-tag{background:var(--tertiary)}.t-node.deceased:after{content:"";background:var(--ink-4);border-radius:50%;width:4px;height:4px;position:absolute;top:10px;right:10px}.t-node.founder{border-color:var(--accent);background:linear-gradient(180deg, #fff7e0 0%, var(--surface-hi) 60%);border-width:2px}.t-node .nm{font-family:var(--font-serif);letter-spacing:2px;margin-top:2px;font-size:16px;font-weight:600}.t-node .zi{color:var(--ink-3);letter-spacing:1px;font-size:10.5px}.t-node .yrs{color:var(--ink-4);font-variant-numeric:tabular-nums;margin-top:auto;font-size:10.5px}.t-node.selected{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.density-compact .t-node{width:108px;height:70px;padding:6px 8px}.density-compact .t-node .nm{font-size:14px}.book-page{background:var(--surface-hi);border:1px solid var(--line);border-radius:var(--radius-lg);background-image:linear-gradient(180deg, transparent 32px, var(--line-2) 32px, var(--line-2) 33px, transparent 33px);background-size:100% 34px;padding:28px;position:relative}.gen-row{border-bottom:1px dashed var(--line);grid-template-columns:60px 1fr;gap:16px;padding:14px 0;display:grid}.gen-row:last-child{border-bottom:0}.gen-label{font-family:var(--font-serif);writing-mode:vertical-rl;letter-spacing:8px;color:var(--accent);border-left:2px solid var(--accent);text-align:center;padding:6px 0;font-size:16px}.gen-members{flex-wrap:wrap;gap:10px;display:flex}.gen-mini{border:1px solid var(--line);background:var(--surface);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:inline-flex}.gen-mini:hover{border-color:var(--accent)}.gen-mini .nm{font-family:var(--font-serif);letter-spacing:1px;font-weight:600}.gen-mini .branch{color:var(--ink-3);letter-spacing:1px;font-size:10px}.drawer-mask{z-index:90;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;pointer-events:none;background:#1c181466;transition:opacity .2s;position:fixed;inset:0}.drawer-mask.open{opacity:1;pointer-events:auto}.drawer{background:var(--paper);z-index:91;width:min(560px,100vw);box-shadow:var(--shadow-lg);transition:transform .25s cubic-bezier(.3,.7,.4,1);position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%)}.drawer.open{transform:translate(0)}.drawer .head{z-index:2;background:var(--paper);border-bottom:1px solid var(--line);align-items:center;gap:10px;padding:14px 22px;display:flex;position:sticky;top:0}.drawer .body{padding:24px 28px 60px}.member-hero{border-bottom:1px dashed var(--line);grid-template-columns:88px 1fr auto;align-items:start;gap:16px;margin-bottom:22px;padding-bottom:22px;display:grid}.portrait{border:1px solid var(--line);width:88px;height:110px;color:var(--ink-3);font-family:var(--font-serif);background:linear-gradient(135deg,#ede4d2 0%,#d8cab1 100%);border-radius:4px;place-items:center;font-size:28px;display:grid;position:relative}.portrait .placeholder{color:var(--ink-4);letter-spacing:2px;margin-top:4px;font-size:10px}.member-hero .ttl{font-family:var(--font-serif);letter-spacing:6px;margin:0 0 4px;font-size:30px;font-weight:600}.member-hero .sub{color:var(--ink-3);letter-spacing:1.5px;font-size:13px}.member-hero .tags{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.field-grid{grid-template-columns:repeat(2,1fr);gap:16px 22px;margin-bottom:22px;display:grid}.field{flex-direction:column;gap:3px;display:flex}.field .k{letter-spacing:2px;color:var(--ink-4);text-transform:uppercase;font-size:11px}.field .v{color:var(--ink);font-size:14px;font-family:var(--font-serif);letter-spacing:.5px}.field .v.masked{color:var(--ink-4);font-family:var(--font-mono);background:var(--line-2);border-radius:4px;align-self:flex-start;padding:1px 6px;font-size:12px}.field .v.masked .eye{color:var(--accent);cursor:pointer;margin-left:6px}.bio{background:var(--surface);border-left:3px solid var(--accent);font-family:var(--font-serif);letter-spacing:1px;color:var(--ink-2);border-radius:0 var(--radius) var(--radius) 0;padding:14px 16px;font-size:14px;line-height:1.9}.rel-block{grid-template-columns:1fr 1fr;gap:18px;display:grid}.rel-block h4{font-family:var(--font-serif);color:var(--ink-3);letter-spacing:2px;margin:0 0 8px;font-size:13px;font-weight:600}.rel-list{flex-direction:column;gap:6px;display:flex}.rel-list .r{background:var(--surface);border:1px solid var(--line);cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 10px;font-size:13px;display:flex}.rel-list .r:hover{border-color:var(--accent)}.rel-list .r .role{color:var(--ink-4);margin-left:auto;font-size:11px}.form-grid{grid-template-columns:repeat(2,1fr);gap:16px 22px;display:grid}.form-grid.wide{grid-template-columns:1fr}.field-input{flex-direction:column;gap:6px;display:flex}.field-input label{color:var(--ink-3);letter-spacing:1px;font-size:12px}.field-input label .req{color:var(--accent);margin-left:2px}.field-input input,.field-input select,.field-input textarea{background:var(--surface-hi);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);outline:none;padding:9px 12px;font-family:inherit;font-size:13.5px}.field-input input:focus,.field-input select:focus,.field-input textarea:focus{border-color:var(--accent)}.field-input textarea{font-family:var(--font-serif);resize:vertical;min-height:120px;line-height:1.8}.field-input .hint{color:var(--ink-4);font-size:11px}.form-section-title{font-family:var(--font-serif);letter-spacing:2px;color:var(--accent);align-items:center;gap:10px;margin:8px 0 4px;font-size:15px;display:flex}.form-section-title .dot{background:var(--accent);width:6px;height:6px;transform:rotate(45deg)}.perm-table{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}.perm-row{border-bottom:1px solid var(--line);grid-template-columns:36px 1.6fr 1fr 1fr 1fr 80px;align-items:center;gap:16px;padding:14px 22px;font-size:13px;display:grid}.perm-row.head{background:var(--paper-deep);letter-spacing:2px;color:var(--ink-3);text-transform:uppercase;font-size:11px}.perm-row:last-child{border-bottom:0}.perm-row .nm{font-weight:500}.perm-row .em{color:var(--ink-3);font-size:12px;font-family:var(--font-mono)}.role-pill{border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:11.5px;font-weight:500;display:inline-flex}.role-pill.owner{background:var(--accent-soft);color:var(--accent)}.role-pill.admin{color:var(--gold);background:#f5e9c8}.role-pill.editor{color:var(--secondary);background:#d9e5e5}.role-pill.viewer{background:var(--line-2);color:var(--ink-3)}.access-toggle-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);cursor:pointer;grid-template-columns:60px 1fr auto;align-items:center;gap:16px;margin-bottom:14px;padding:18px 22px;display:grid}.access-toggle-card.active{border-color:var(--accent);background:var(--accent-soft)}.access-toggle-card .ico-wrap{background:var(--surface-hi);border:1px solid var(--line);width:48px;height:48px;color:var(--ink-2);border-radius:50%;place-items:center;display:grid}.access-toggle-card.active .ico-wrap{color:var(--accent);border-color:var(--accent)}.access-toggle-card .ttl{font-family:var(--font-serif);font-size:16px;font-weight:600}.access-toggle-card .desc{color:var(--ink-3);margin-top:2px;font-size:12px;line-height:1.5}.access-toggle-card .radio{border:2px solid var(--line-strong);border-radius:50%;width:18px;height:18px;position:relative}.access-toggle-card.active .radio{border-color:var(--accent)}.access-toggle-card.active .radio:after{content:"";background:var(--accent);border-radius:50%;position:absolute;inset:3px}.timeline{padding:12px 0;position:relative}.timeline:before{content:"";background:var(--accent);background-image:repeating-linear-gradient(180deg, var(--accent) 0 8px, transparent 8px 14px);width:2px;position:absolute;top:0;bottom:0;left:120px}.tl-row{grid-template-columns:120px 40px 1fr;align-items:start;gap:0;padding:14px 0;display:grid}.tl-row .yr{text-align:right;font-family:var(--font-serif);color:var(--ink-2);padding-right:18px;font-size:22px;font-weight:600;line-height:1}.tl-row .yr small{color:var(--ink-4);letter-spacing:2px;margin-top:4px;font-size:11px;font-weight:400;display:block}.tl-row .node{background:var(--paper);z-index:1;place-items:center;width:40px;height:40px;display:grid;position:relative}.tl-row .node .pt{background:var(--accent);border:3px solid var(--paper);width:12px;height:12px;box-shadow:0 0 0 2px var(--accent);border-radius:50%}.tl-row.major .node .pt{background:#fff;width:16px;height:16px}.tl-row .content{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px}.tl-row .ttl{font-family:var(--font-serif);margin-bottom:4px;font-size:16px;font-weight:600}.tl-row .desc{color:var(--ink-2);font-size:13px;line-height:1.7}.tl-row .actors{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.map-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:linear-gradient(#fbf3df 0%,#f0e3c2 100%);padding:0;position:relative;overflow:hidden}[data-dark="1"] .map-card{background:linear-gradient(#2a2420 0%,#1f1a16 100%)}.map-svg{width:100%;height:540px;display:block}.map-legend{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:var(--radius);background:#fbf7ebeb;min-width:200px;padding:12px 14px;font-size:12px;position:absolute;top:18px;right:18px}[data-dark="1"] .map-legend{background:#221d19eb}.map-legend h4{font-family:var(--font-serif);letter-spacing:2px;margin:0 0 8px;font-size:13px;font-weight:600}.map-legend .lg-row{color:var(--ink-3);align-items:center;gap:8px;padding:3px 0;font-size:11.5px;display:flex}.map-legend .lg-row .sw{border-radius:2px;width:12px;height:12px}.map-info-card{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:var(--radius);background:#fbf7ebf2;max-width:320px;padding:14px 18px;position:absolute;bottom:18px;left:18px}[data-dark="1"] .map-info-card{background:#221d19f2}.map-info-card .gen{color:var(--accent);letter-spacing:2px;font-size:11px}.map-info-card .ttl{font-family:var(--font-serif);letter-spacing:1px;margin:4px 0;font-size:18px;font-weight:600}.map-info-card .desc{color:var(--ink-3);font-size:12.5px;line-height:1.6}.gen-rail{background:var(--surface);border-top:1px solid var(--line);gap:8px;padding:16px 22px;display:flex}.gen-rail button{border:1px solid var(--line);font-family:var(--font-serif);color:var(--ink-2);letter-spacing:2px;background:0 0;border-radius:6px;flex:1;padding:10px 8px;font-size:13px}.gen-rail button.on{background:var(--accent);color:#fff;border-color:var(--accent)}.ai-pop{background:linear-gradient(135deg, var(--secondary), var(--accent));color:#fff;border-radius:var(--radius-lg);grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:18px 22px;display:grid}.ai-pop .ico{background:#ffffff2e;border-radius:8px;place-items:center;width:38px;height:38px;display:grid}.ai-pop .ttl{font-family:var(--font-serif);letter-spacing:1.5px;font-size:16px;font-weight:600}.ai-pop .ds{opacity:.85;margin-top:2px;font-size:12px}.ai-pop button{color:var(--ink);background:#fffffff2;border:0;border-radius:6px;padding:8px 14px;font-size:12.5px;font-weight:500}.invite-banner{background:var(--accent-soft);border-radius:var(--radius);color:var(--accent);align-items:center;gap:12px;margin-bottom:18px;padding:12px 16px;font-size:13px;display:flex}.invite-banner b{font-family:var(--font-serif);letter-spacing:1px}.invite-banner .sp{flex:1}.menu-btn{border:1px solid var(--line);background:0 0;border-radius:6px;padding:6px 10px;display:none}@media (max-width:860px){.menu-btn{display:inline-flex}}.auth-shell{background:var(--paper);grid-template-columns:1.05fr 1fr;min-height:100vh;display:grid}.auth-left{color:#f5e8d5;background:radial-gradient(circle at 25% 20%,#ffffff14,#0000 50%),linear-gradient(160deg,#5a0e0e 0%,#2c0606 100%);flex-direction:column;padding:48px 56px 36px;display:flex;position:relative;overflow:hidden}[data-theme=qing] .auth-left{background:radial-gradient(circle at 25% 20%,#ffffff14,#0000 50%),linear-gradient(160deg,#1d3c40 0%,#0d2426 100%)}[data-theme=zhe] .auth-left{background:radial-gradient(circle at 25% 20%,#ffffff14,#0000 50%),linear-gradient(160deg,#5e3617 0%,#2d1808 100%)}.auth-vert{writing-mode:vertical-rl;font-family:var(--font-serif);color:#f5e8d573;letter-spacing:6px;font-size:12px;position:absolute;top:36px;right:22px}.auth-brand{align-items:center;gap:16px;margin-bottom:36px;display:flex}.auth-clan{font-family:var(--font-serif);letter-spacing:6px;font-size:28px;font-weight:600}.auth-tang{letter-spacing:6px;opacity:.6;margin-top:4px;font-size:11px}.auth-tagline{font-family:var(--font-serif);letter-spacing:4px;margin-top:auto;font-size:30px;font-weight:500;line-height:1.6}.auth-bullets{flex-direction:column;gap:10px;margin:28px 0 0;padding:0;list-style:none;display:flex}.auth-bullets li{font-family:var(--font-serif);letter-spacing:1px;color:#f5e8d5c7;align-items:center;gap:10px;font-size:14px;display:flex}.auth-bullets .dot{background:#f5e8d599;flex-shrink:0;width:6px;height:6px;transform:rotate(45deg)}.auth-foot{gap:8px;margin-top:36px;display:flex}.auth-foot .chip{color:#f5e8d5d9;background:#ffffff14;border-color:#ffffff26;font-size:11px}.auth-tree-deco{opacity:.35;pointer-events:none;width:280px;height:320px;position:absolute;bottom:-20px;right:-30px}.auth-right{flex-direction:column;justify-content:center;align-items:center;padding:56px;display:flex;position:relative}.auth-card{width:100%;max-width:400px;position:relative}.auth-tabs{background:var(--line-2);border-radius:8px;margin-bottom:32px;padding:3px;display:flex;position:relative}.auth-tabs button{font-family:var(--font-serif);letter-spacing:6px;color:var(--ink-3);z-index:1;background:0 0;border:0;flex:1;padding:9px 0;font-size:14px;position:relative}.auth-tabs button.on{color:var(--ink);font-weight:600}.auth-tabs-thumb{background:var(--surface-hi);width:calc(50% - 4px);box-shadow:var(--shadow-sm);border-radius:6px;transition:left .2s;position:absolute;top:3px;bottom:3px}.auth-h2{font-family:var(--font-serif);letter-spacing:4px;margin:0 0 6px;font-size:26px;font-weight:600}.auth-sub{color:var(--ink-3);margin-bottom:24px;font-size:13px}.auth-divider{color:var(--ink-4);letter-spacing:2px;align-items:center;gap:12px;margin:24px 0 18px;font-size:11px;display:flex}.auth-divider span{background:var(--line-strong);flex:1;height:1px}.auth-input{background:var(--surface-hi);border:1px solid var(--line);border-radius:8px;align-items:center;height:44px;padding:0 14px;display:flex}.auth-input:focus-within{border-color:var(--accent)}.auth-input input{height:100%;font:inherit;color:var(--ink);background:0 0;border:0;outline:none;flex:1;font-size:14px}.auth-input .prefix{border-right:1px solid var(--line);color:var(--ink-2);margin-right:12px;padding-right:12px;font-size:13px;font-weight:500}.auth-input .suffix-btn{color:var(--accent);border:0;border-left:1px solid var(--line);background:0 0;margin-left:10px;padding-left:10px;font-size:12px}.auth-submit{background:var(--accent);color:#fff;width:100%;font-family:var(--font-serif);letter-spacing:4px;cursor:pointer;border:0;border-radius:8px;margin-top:20px;padding:13px;font-size:16px;font-weight:500}.auth-submit:hover{background:var(--accent-2)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-err{background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent);border-radius:6px;margin-top:14px;padding:10px 14px;font-size:13px}.auth-terms{color:var(--ink-4);letter-spacing:.5px;text-align:center;margin-top:24px;font-size:11px;line-height:1.7}.auth-terms span{color:var(--ink-2);cursor:pointer;text-decoration:underline}@media (max-width:900px){.auth-shell{grid-template-columns:1fr}.auth-left{min-height:280px;padding:28px}.auth-tagline{margin-top:24px;font-size:22px}.auth-bullets,.auth-foot,.auth-tree-deco{display:none}.auth-right{padding:28px}}.explore-shell{min-height:100vh}.explore-topbar{z-index:10;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f5efe2eb;align-items:center;gap:14px;padding:14px 36px;display:flex;position:sticky;top:0}.explore-topbar .brand .seal{width:32px;height:32px;font-size:13px}.explore-topbar .brand .name{font-size:14px}.explore-topbar .brand .name small{font-size:10px}.explore-hero{border-bottom:1px solid var(--line);background:radial-gradient(circle at 15% 20%,#ffffff80,#0000 60%),linear-gradient(#fbf3df 0%,#f0e3c2 100%);padding:60px 36px 70px;position:relative;overflow:hidden}[data-dark="1"] .explore-hero{background:radial-gradient(circle at 15% 20%,#f0e8d814,#0000 60%),linear-gradient(#2a2420 0%,#1f1a16 100%)}.explore-hero-inner{z-index:1;flex-direction:column;gap:16px;max-width:1200px;margin:0 auto;display:flex;position:relative}.explore-h1{font-family:var(--font-serif);letter-spacing:16px;margin:0;font-size:56px;font-weight:600;line-height:1.2}.explore-h-sub{font-family:var(--font-serif);color:var(--ink-2);letter-spacing:1px;max-width:640px;font-size:15px;line-height:1.8}.explore-chips{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.explore-hero-stamp{z-index:1;position:absolute;top:50%;right:60px;transform:translateY(-50%)}.explore-filterbar{z-index:2;background:var(--surface-hi);border:1px solid var(--line);border-radius:var(--radius-lg);max-width:1200px;box-shadow:var(--shadow);flex-direction:column;gap:14px;margin:-36px auto 0;padding:18px 22px;display:flex;position:relative}.filter-row{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.filter-row .lbl{letter-spacing:2px;color:var(--ink-3);flex-shrink:0;font-size:11px}.surname-chips{flex-wrap:wrap;flex:1;gap:6px;display:flex}.surname-chips button{border:1px solid var(--line);background:var(--surface);font-family:var(--font-serif);color:var(--ink-2);letter-spacing:1px;border-radius:999px;min-width:36px;padding:5px 12px;font-size:14px;font-weight:500}.surname-chips button.on{background:var(--accent);color:#fff;border-color:var(--accent)}.explore-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;max-width:1200px;margin:24px auto;padding:0 36px 60px;display:grid}.fam-card{background:var(--surface-hi);border:1px solid var(--line);border-radius:var(--radius-lg);cursor:pointer;color:inherit;padding:22px;text-decoration:none;transition:transform .15s,box-shadow .15s;display:block;position:relative;overflow:hidden}.fam-card:hover{box-shadow:var(--shadow);border-color:var(--accent);transform:translateY(-2px)}.fam-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);opacity:.2;height:2px;position:absolute;top:0;left:22px;right:22px}.fam-card-top{grid-template-columns:56px 1fr auto;align-items:center;gap:14px;margin-bottom:14px;display:grid}.fam-stamp{background:var(--accent);color:#f6e9d3;width:52px;height:52px;font-family:var(--font-serif);border-radius:4px;flex-direction:column;justify-content:center;align-items:center;font-weight:700;display:flex;transform:rotate(-3deg);box-shadow:inset 0 0 0 2px,inset 0 0 0 3px #f6e9d3}.fam-stamp .big{font-size:18px;line-height:1}.fam-stamp .small{letter-spacing:2px;opacity:.8;margin-top:2px;font-size:9px}.fam-tang{font-family:var(--font-serif);letter-spacing:3px;font-size:18px;font-weight:600}.fam-sub{color:var(--ink-3);margin-top:2px;font-size:12px}.fam-desc{font-family:var(--font-serif);color:var(--ink-2);letter-spacing:.5px;border-bottom:1px dashed var(--line);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-bottom:12px;padding-bottom:14px;font-size:13px;line-height:1.8;display:-webkit-box;overflow:hidden}.fam-stats{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px;display:grid}.fam-stats .fs{text-align:center}.fam-stats .n{font-family:var(--font-serif);font-size:16px;font-weight:600}.fam-stats .l{color:var(--ink-4);letter-spacing:1px;margin-top:2px;font-size:10px}.fam-foot{justify-content:space-between;align-items:center;font-size:12px;display:flex}.fam-link{color:var(--accent);font-weight:500}@media (max-width:900px){.explore-h1{letter-spacing:10px;font-size:36px}.explore-hero{padding:36px 20px}.explore-hero-stamp{display:none}.explore-filterbar{margin:0 12px}.explore-grid{grid-template-columns:1fr;padding:0 12px 40px}.explore-topbar{padding:12px 14px}}.cw-shell{z-index:95;background:var(--paper);flex-direction:column;display:flex;position:fixed;inset:0}.cw-head{border-bottom:1px solid var(--line);background:var(--surface);justify-content:space-between;align-items:center;padding:14px 32px;display:flex}.cw-stepper{gap:0;display:flex}.cw-st{align-items:center;gap:8px;padding:0 18px;display:flex;position:relative}.cw-st:not(:last-child):after{content:"";background:var(--line-strong);width:24px;height:1px;position:absolute;top:50%;right:0}.cw-st .num{background:var(--line-2);width:26px;height:26px;color:var(--ink-4);font-family:var(--font-serif);border-radius:50%;place-items:center;font-size:13px;font-weight:600;display:grid}.cw-st.on .num{background:var(--accent);color:#fff}.cw-st.done .num{background:var(--secondary);color:#fff}.cw-st .lbl{font-family:var(--font-serif);letter-spacing:2px;color:var(--ink-3);font-size:13px}.cw-st.on .lbl{color:var(--ink);font-weight:600}.cw-body{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:32px 64px;overflow-y:auto}.cw-step-h{margin-bottom:32px}.cw-step-sub{letter-spacing:4px;color:var(--accent);font-size:11px}.cw-step-t{font-family:var(--font-serif);letter-spacing:6px;margin-top:4px;font-size:32px;font-weight:600}.cw-step-line{background:var(--accent);width:60px;height:1px;margin-top:14px}.cw-grid-2{grid-template-columns:1fr 1fr;gap:40px;display:grid}.cw-foot{border-top:1px solid var(--line);background:var(--surface);justify-content:space-between;align-items:center;padding:14px 32px;display:flex}.surname-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.surname-grid button{background:var(--surface-hi);border:1px solid var(--line);font-family:var(--font-serif);color:var(--ink-2);letter-spacing:2px;border-radius:6px;padding:10px 4px;font-size:18px;font-weight:500}.surname-grid button:hover{border-color:var(--accent);color:var(--accent)}.surname-grid button.on{background:var(--accent);color:#fff;border-color:var(--accent)}.zibei-input input{background:var(--surface-hi);border:1px solid var(--line);width:100%;font-family:var(--font-serif);letter-spacing:8px;text-align:center;color:var(--ink);border-radius:10px;outline:none;padding:16px 20px;font-size:22px}.zibei-input input:focus{border-color:var(--accent)}.zibei-preview{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.zb-c{background:var(--surface-hi);border:1px solid var(--line);text-align:center;border-radius:6px;padding:10px 6px}.zb-c .zb-num{color:var(--ink-4);letter-spacing:1px;font-size:10px}.zb-c .zb-ch{font-family:var(--font-serif);color:var(--accent);margin-top:4px;font-size:22px;font-weight:600}.founder-preview{border:1px solid var(--accent);border-radius:var(--radius-lg);text-align:center;background:linear-gradient(#fbf3df 0%,#f0e3c2 100%);padding:28px 24px;position:relative}.fp-name{font-family:var(--font-serif);letter-spacing:8px;font-size:28px;font-weight:600}.fp-zi{color:var(--ink-3);letter-spacing:2px;margin-top:4px;font-size:13px}.fp-yrs{color:var(--ink-4);font-size:12px;font-family:var(--font-serif);margin-top:4px}.fp-bio{font-family:var(--font-serif);color:var(--ink-2);letter-spacing:1px;text-align:left;border-left:3px solid var(--accent);background:#ffffff80;padding:12px 14px;font-size:13px;line-height:1.9}.fp-tag{color:var(--accent);letter-spacing:3px;border:1px solid var(--accent);border-radius:999px;margin-top:18px;padding:3px 10px;font-size:11px;display:inline-block}.fam-switch-pop{background:var(--surface-hi);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:50;padding:6px;position:absolute;top:calc(100% + 6px);left:0;right:0}.fam-switch-pop .item{cursor:pointer;border-radius:6px;grid-template-columns:26px 1fr auto;align-items:center;gap:8px;padding:8px;font-size:13px;display:grid}.fam-switch-pop .item:hover{background:var(--line-2)}.fam-switch-pop .item.on{background:var(--accent-soft);color:var(--accent)}.fam-switch-pop .item .mini-stamp{background:var(--accent);color:#f6e9d3;width:22px;height:22px;font-family:var(--font-serif);border-radius:2px;place-items:center;font-size:11px;font-weight:700;display:grid}.fam-switch-pop .divider{background:var(--line);height:1px;margin:4px 2px}.fam-switch-pop .add{cursor:pointer;color:var(--accent);border-radius:6px;align-items:center;gap:8px;padding:8px;font-size:13px;display:flex}.fam-switch-pop .add:hover{background:var(--accent-soft)}@media (max-width:900px){.cw-grid-2{grid-template-columns:1fr;gap:24px}.cw-body{padding:20px}.cw-stepper{display:none}}
