:root{--bg: #f5f1e8;--paper: #fdfbf5;--ink: #2a2520;--muted: #6b5d4f;--accent: #8b6f47;--accent-soft: #c9b59a;--line: #d8cdb8;--male: #5a7ba3;--male-soft: #ecf0f6;--male-stroke: #aebfd4;--female: #a05a7b;--female-soft: #f6eaf0;--female-stroke: #d4aebf;--shadow: 0 1px 2px rgba(60, 40, 20, .07), 0 4px 12px rgba(60, 40, 20, .06);--shadow-md: 0 2px 6px rgba(60, 40, 20, .08), 0 12px 28px rgba(60, 40, 20, .1);--radius: 10px}@media(prefers-color-scheme:dark){:root{--bg: #1f1c18;--paper: #2a2620;--ink: #e7dfd2;--muted: #a8997f;--accent: #c9a577;--accent-soft: #6b5a3f;--line: #3a3429;--male-soft: #2a3340;--male-stroke: #4a5d7a;--female-soft: #3a2a35;--female-stroke: #7a4a5d;--shadow: 0 1px 2px rgba(0, 0, 0, .3), 0 4px 12px rgba(0, 0, 0, .3);--shadow-md: 0 2px 6px rgba(0, 0, 0, .35), 0 12px 28px rgba(0, 0, 0, .4)}}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}body{background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}.app{display:grid;grid-template-columns:340px 1fr;min-height:100vh}.sidebar{background:var(--paper);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;min-height:0}.brand{padding:16px 18px 10px;border-bottom:1px solid var(--line)}.brand h1{margin:0;font-size:16px;font-weight:600;letter-spacing:-.2px}.brand a{color:inherit;text-decoration:none}.brand .stats{margin-top:2px;font-size:12px;color:var(--muted)}.search-row{padding:10px 12px;border-bottom:1px solid var(--line);display:grid;gap:8px}.search-row input,.search-row select{width:100%;padding:8px 10px;border-radius:8px;border:1px solid var(--line);background:var(--bg);color:var(--ink);font-size:13px}.search-row input:focus,.search-row select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #8b6f4726}.list{overflow-y:auto;flex:1;padding:4px 0}.row{display:flex;gap:10px;align-items:center;padding:7px 14px;cursor:pointer;border-left:3px solid transparent;text-decoration:none;color:inherit}.row:hover{background:#8b6f4714;text-decoration:none}.row.active{background:#8b6f4729;border-left-color:var(--accent)}.row .meta{min-width:0;flex:1}.row .name{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row .sub{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-empty{padding:14px;color:var(--muted);font-size:13px}.avatar{width:34px;height:34px;border-radius:50%;background:#e0d4ba;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted);overflow:hidden;flex:0 0 auto;border:1px solid var(--line)}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar.male{background:var(--male-soft)}.avatar.female{background:var(--female-soft)}.main{background:var(--bg);min-width:0}.tabs{position:sticky;top:0;z-index:5;background:var(--paper);border-bottom:1px solid var(--line);padding:10px 24px;display:flex;gap:4px;align-items:center}.tab{padding:7px 14px;border-radius:8px;font-size:13px;color:var(--muted);font-weight:500;text-decoration:none}.tab:hover{background:#8b6f4714;color:var(--ink);text-decoration:none}.tab.active{background:#8b6f4729;color:var(--ink)}.tabs .spacer{flex:1}.tabs .selected-name{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}.panel{padding:24px;max-width:1200px;margin:0 auto}.detail-head{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;margin-bottom:20px}.photo{width:160px;height:200px;background:var(--accent-soft);border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}.photo img{width:100%;height:100%;object-fit:cover;display:block;cursor:zoom-in}.photo.placeholder{background:linear-gradient(160deg,var(--accent-soft),var(--line))}.photo.placeholder.male{background:linear-gradient(160deg,var(--male-soft),var(--male-stroke))}.photo.placeholder.female{background:linear-gradient(160deg,var(--female-soft),var(--female-stroke))}.photo .ph-letter{font-size:60px;color:#ffffffd9;font-weight:300}.bio h2{margin:0 0 4px;font-size:26px;font-weight:600;letter-spacing:-.3px;line-height:1.2}.bio .patro{color:var(--muted);font-weight:400}.bio .maiden{color:var(--muted);font-style:italic;font-size:14px;margin-top:2px}.bio .lifespan{margin-top:10px;font-size:14px;color:var(--muted)}.bio .lifespan .age{display:inline-block;padding:2px 8px;background:#8b6f4729;border-radius:999px;color:var(--accent);font-size:12px;margin-left:6px}.facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-top:14px}.fact,.rel-block,.notes-block{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow)}.fact h3,.rel-block h3,.notes-block h3{margin:0 0 8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.row-fact{margin:4px 0;font-size:13.5px}.row-fact .lbl{color:var(--muted);font-size:12px}.fact ul,.notes-block ul{margin:4px 0 0;padding-left:18px}.relations{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-top:14px}.person-chip{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;border:1px solid transparent;text-decoration:none;color:inherit}.person-chip:hover{background:#8b6f4714;border-color:var(--line);text-decoration:none}.person-chip .avatar{width:28px;height:28px;font-size:11px}.person-chip .pchip-name{font-size:13px}.person-chip .pchip-sub{font-size:11px;color:var(--muted)}.notes-block{padding:14px 16px;margin-top:14px}.notes-block p{margin:6px 0;font-size:13.5px;white-space:pre-wrap}.gallery{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.gallery img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:1px solid var(--line);cursor:zoom-in}.tree-controls{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.tree-controls a,.tree-controls button{padding:6px 12px;border-radius:8px;border:1px solid var(--line);background:var(--paper);font-size:12px;color:var(--muted);text-decoration:none}.tree-controls a.active,.tree-controls button.active{background:#8b6f4729;color:var(--ink)}.tree-controls a:hover,.tree-controls button:hover{background:#8b6f4714;color:var(--ink)}.tree-controls .info{font-size:12px;color:var(--muted)}.tree-canvas{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:16px;overflow:auto;min-height:500px;box-shadow:var(--shadow)}.tree-canvas svg{display:block;margin:0 auto}.node-card{cursor:pointer}.node-card rect{transition:fill .15s}.node-card:hover rect{fill:#8b6f471f;stroke:var(--accent)}.node-card.current rect{fill:#8b6f472e;stroke:var(--accent);stroke-width:2}.node-card .nm{font-size:11.5px;font-weight:600;fill:var(--ink)}.node-card .pn{font-size:10px;fill:var(--muted)}.node-card .dt{font-size:9.5px;fill:var(--muted)}.tree-link{stroke:var(--accent-soft);fill:none;stroke-width:1.2}.tree-link.spouse{stroke-dasharray:4 3;stroke:var(--female-stroke)}.surnames-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.surname-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:10px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-decoration:none;color:inherit}.surname-card:hover{background:#8b6f4714;text-decoration:none}.surname-card .cnt{font-size:11px;background:#8b6f4729;color:var(--accent);padding:2px 8px;border-radius:999px}.lightbox{position:fixed;inset:0;background:#140f0ad9;display:none;align-items:center;justify-content:center;z-index:50;cursor:zoom-out}.lightbox.show{display:flex}.lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:var(--shadow-md)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--muted);text-align:center}@media(max-width:760px){.app{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{position:relative;height:auto;max-height:45vh}.detail-head{grid-template-columns:1fr}.photo{width:120px;height:150px}.panel{padding:16px}}
