:root{--bg-color: #121212;--text-color: #e0e0e0;--header-bg: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);--card-bg: #1e1e1e;--sidebar-bg: #181818;--border-color: #333;--accent-color: #3498db;--hover-bg: #2a2a2a;--muted-text: #999;--detail-group-bg: #222;--shadow: 0 4px 12px rgba(0, 0, 0, .5)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--bg-color);color:var(--text-color);-webkit-text-size-adjust:100%;text-size-adjust:100%}.app{display:flex;flex-direction:column;height:100vh}.header{background:var(--header-bg);color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0006;z-index:10}.header h1{font-size:1.5rem;font-weight:600}.header-controls{display:flex;gap:1rem;align-items:center}.header-controls select,.header-controls button{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;cursor:pointer;background:var(--card-bg);color:var(--text-color)}.header-controls button{background:var(--accent-color);color:#fff;border:none;transition:background .2s}.header-controls button:hover{background:#2980b9}.layout-group{display:inline-flex;border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.header-controls .layout-group button{background:var(--card-bg);color:var(--text-color);border:none;border-radius:0;padding:.5rem .75rem;font-size:.85rem;transition:background .15s,color .15s}.header-controls .layout-group button+button{border-left:1px solid var(--border-color)}.header-controls .layout-group button:hover{background:var(--hover-bg)}.header-controls .layout-group button.active{background:var(--accent-color);color:#fff}@media(max-width:991.98px){.layout-group{display:none}}.main-content{display:flex;flex:1;overflow:hidden}.tree-container{flex:1;min-width:0;background:#0f0f0f;position:relative}.person-node-card{background:var(--card-bg);border-radius:12px;padding:10px;width:200px;height:80px;display:flex;align-items:center;box-shadow:var(--shadow);border-top:4px solid #555;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:grab;color:var(--text-color);-webkit-user-select:none;user-select:none}.person-node-card:active{cursor:grabbing}.person-node-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0009}.person-node-card.selected{box-shadow:0 0 0 3px #f39c12}.person-node-content{display:flex;align-items:center;gap:12px}.person-photo-container{width:48px;height:48px;border-radius:25%;overflow:hidden;background:#333;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:700;color:#888}.person-photo{width:100%;height:100%;object-fit:cover}.person-photo-placeholder{font-size:14px;letter-spacing:1px}.person-info{display:flex;flex-direction:column;overflow:hidden}.person-name{font-weight:600;font-size:13px;color:var(--text-color);line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.person-dates{font-size:11px;color:var(--muted-text)}.force-graph-controls{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:5px;z-index:10}.force-graph-controls button{width:32px;height:32px;background:#333;color:#f0f0f0;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .2s}.force-graph-controls button:hover{background:#444}.force-graph-legend{position:absolute;bottom:10px;left:10px;z-index:10}.sidebar{width:var(--sidebar-width, 350px);flex:0 0 var(--sidebar-width, 350px);background:var(--sidebar-bg);border-left:1px solid var(--border-color);overflow-y:auto;padding:1.5rem;color:var(--text-color)}.sidebar-resize-handle{flex:0 0 6px;background:var(--border-color);cursor:col-resize;transition:background-color .15s;touch-action:none}.sidebar-resize-handle:hover,body.is-resizing-sidebar .sidebar-resize-handle{background:var(--accent-color)}body.is-resizing-sidebar,body.is-resizing-sidebar *{cursor:col-resize!important;-webkit-user-select:none;user-select:none}.sidebar h2{font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-color)}.person-details{display:flex;flex-direction:column;gap:1rem}.sidebar-profile-photo{width:100%;height:200px;border-radius:12px;overflow:hidden;margin-bottom:.5rem;cursor:pointer;border:1px solid var(--border-color);background:#222;display:flex;justify-content:center;align-items:center;box-shadow:var(--shadow)}.profile-photo-img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.sidebar-profile-photo:hover .profile-photo-img{transform:scale(1.05)}.detail-group{background:var(--detail-group-bg);padding:1rem;border-radius:8px;border:1px solid var(--border-color)}.detail-group h3{font-size:.85rem;color:var(--muted-text);text-transform:uppercase;margin-bottom:.5rem}.detail-group p{font-size:1rem;color:var(--text-color)}.relatives-list{list-style:none}.relatives-list li{padding:.5rem 0;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s}.relatives-list li:hover{background:var(--hover-bg)}.relatives-list li:last-child{border-bottom:none}.rel-tag{font-size:.8rem;color:var(--muted-text);font-style:italic}.aka-list{list-style:none;display:flex;flex-direction:column;gap:6px}.aka-list li{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px}.aka-name{font-weight:600;color:var(--text-color)}.aka-type{font-size:.75rem;color:var(--accent-color);background:#3498db26;padding:1px 6px;border-radius:4px}.aka-notes{font-size:.85rem;color:var(--muted-text);font-style:italic;width:100%}.events-list{list-style:none;display:flex;flex-direction:column;gap:10px}.events-list li{padding:8px;background:#ffffff08;border-radius:6px;border-left:3px solid var(--accent-color)}.event-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.event-type{font-weight:600;font-size:.9rem;color:var(--text-color)}.event-date{font-size:.8rem;color:var(--muted-text)}.event-place{font-size:.85rem;color:var(--muted-text)}.event-description{font-size:.85rem;color:var(--text-color);margin-top:4px;line-height:1.4}.documents-list{list-style:none;display:flex;flex-direction:column;gap:8px}.documents-list li{padding:8px;background:#ffffff08;border-radius:6px}.document-link{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--accent-color);transition:color .2s}.document-link:hover{color:#2980b9}.document-type-badge{font-size:.7rem;text-transform:uppercase;background:#3498db26;color:var(--accent-color);padding:2px 6px;border-radius:4px;flex-shrink:0}.document-title{font-weight:500}.document-date{font-size:.8rem;color:var(--muted-text);margin-left:8px}.document-description{font-size:.85rem;color:var(--text-color);margin-top:4px;line-height:1.4}.sources-list{list-style:none;display:flex;flex-direction:column;gap:8px}.sources-list li{padding:8px;background:#ffffff08;border-radius:6px;border-left:3px solid var(--muted-text)}.source-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.source-type-badge{font-size:.7rem;text-transform:uppercase;background:#9993;color:var(--muted-text);padding:2px 6px;border-radius:4px;flex-shrink:0}.source-title{font-weight:500;color:var(--text-color)}.source-title a{color:var(--accent-color);text-decoration:none}.source-title a:hover{text-decoration:underline}.source-date{font-size:.8rem;color:var(--muted-text);margin-top:2px}.source-repo{font-size:.8rem;color:var(--muted-text);font-style:italic}.source-description{font-size:.85rem;color:var(--text-color);margin-top:4px;line-height:1.4}.rich-text-content{font-size:.95rem;line-height:1.6;color:var(--text-color)}.rich-text-content p{margin-bottom:.5rem}.rich-text-content ul,.rich-text-content ol{margin-left:1.2rem;margin-bottom:.5rem}.rich-text-content a{color:var(--accent-color);text-decoration:none}.rich-text-content a:hover{text-decoration:underline}.rich-text-content blockquote{border-left:3px solid var(--accent-color);padding-left:.75rem;margin:.5rem 0;color:var(--muted-text);font-style:italic}.rich-text-content img{max-width:100%;border-radius:4px}.rich-text-content table{width:100%;border-collapse:collapse;margin:.5rem 0}.rich-text-content table td,.rich-text-content table th{border:1px solid var(--border-color);padding:4px 8px;font-size:.85rem}.rich-text-content table th{background:#ffffff0d}.biography-content{max-height:400px;overflow-y:auto;padding-right:4px}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-top:5px}.gallery-item{display:flex;flex-direction:column;gap:4px;cursor:pointer}.gallery-photo{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:4px;border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s;cursor:pointer}.gallery-photo:hover{transform:scale(1.05);box-shadow:var(--shadow);z-index:5}.photo-caption{font-size:.75rem;color:var(--muted-text);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.no-selection{color:#666;text-align:center;padding:2rem}.loading{display:flex;justify-content:center;align-items:center;height:100%;font-size:1.2rem;color:#888}.error{color:#e74c3c;text-align:center;padding:2rem}.tree-legend{background:var(--card-bg);padding:12px;border-radius:8px;border:1px solid var(--border-color);box-shadow:var(--shadow);color:var(--text-color);font-size:12px;display:flex;flex-direction:column;gap:8px;margin-bottom:10px!important}.legend-toggle{appearance:none;background:none;border:none;width:100%;padding:0 0 4px;margin:0;font:inherit;font-weight:700;color:var(--accent-color);text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--border-color)}.legend-toggle:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px;border-radius:2px}.legend-chevron{font-size:.9em;opacity:.8}.legend-body{display:flex;flex-direction:column;gap:8px}.tree-legend.collapsed .legend-body{display:none}.tree-legend.collapsed .legend-toggle{padding-bottom:0;border-bottom:none}.legend-item{display:flex;align-items:center;gap:10px}.legend-color{width:14px;height:14px;border-radius:3px;flex-shrink:0}.legend-color.male{background:#2ecc71}.legend-color.female{background:#3498db}.legend-color.other{background:#9b59b6}.legend-divider{height:1px;background:var(--border-color);margin:2px 0}.legend-line{width:20px;height:3px;border-radius:1px;flex-shrink:0}.legend-line.partner{background:#e74c3c}.legend-line.partner.former{background:none;border-bottom:2px dashed #e74c3c;height:0;border-radius:0}.legend-line.parent-child{background:#555}.legend-line.parent-child.adopted{background:none;border-bottom:2px dotted #555;height:0;border-radius:0}.photo-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:1000}.photo-modal-content{position:relative;max-width:90%;max-height:90%;display:flex;flex-direction:column;background:var(--card-bg);border-radius:8px;overflow:hidden;box-shadow:0 0 20px #000c}.photo-modal-close{position:absolute;top:5px;right:15px;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;z-index:1010;text-shadow:0 0 5px rgba(0,0,0,.5)}.photo-modal-image{max-width:100%;max-height:75vh;object-fit:contain;background:#000}.photo-modal-info{padding:1.5rem;background:var(--card-bg);border-top:1px solid var(--border-color)}.photo-modal-caption{margin-bottom:.5rem;color:var(--accent-color);font-size:1.2rem}.photo-modal-description{margin-bottom:1rem;font-size:.95rem;line-height:1.4}.photo-modal-date{font-size:.85rem;color:var(--muted-text)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-color)}.login-box{background:var(--card-bg);padding:2.5rem;border-radius:12px;box-shadow:var(--shadow);width:100%;max-width:400px;border:1px solid var(--border-color)}.login-box h1{font-size:1.5rem;text-align:center;margin-bottom:.5rem;color:var(--text-color)}.login-box h2{font-size:1.1rem;text-align:center;margin-bottom:1.5rem;color:var(--muted-text);font-weight:400}.login-box form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;color:var(--muted-text)}.form-group input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;background:var(--bg-color);color:var(--text-color);transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent-color)}.login-box button{padding:.75rem 1rem;background:var(--accent-color);color:#fff;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.login-box button:hover{background:#2980b9}.login-box button:disabled{background:#555;cursor:not-allowed}.login-error{background:#e74c3c33;color:#e74c3c;padding:.75rem;border-radius:6px;font-size:.9rem;text-align:center}.user-info{font-size:.9rem;color:var(--muted-text)}.user-info strong{color:var(--text-color)}.logout-btn{background:#e74c3c!important}.logout-btn:hover{background:#c0392b!important}@media(max-width:991.98px){.sidebar-resize-handle{display:none}.header{padding:.6rem .8rem;flex-wrap:wrap;gap:.5rem;row-gap:.5rem}.header h1{font-size:1.05rem;flex-basis:100%}.header-controls{flex-wrap:wrap;gap:.4rem;width:100%}.header-controls select,.header-controls button{padding:.35rem .6rem;font-size:.8rem}.header-controls select{max-width:50vw;flex:1 1 auto;min-width:0}.user-info{margin-left:auto;font-size:.7rem}.logout-btn{padding:.3rem .55rem!important;font-size:.75rem!important}.sidebar{width:min(35vw,150px);flex-basis:min(35vw,150px);padding:.75rem}.sidebar h2{font-size:.9rem;margin-bottom:.5rem;padding-bottom:.3rem}.sidebar-profile-photo{height:120px}.detail-group{padding:.5rem}.detail-group h3{font-size:.65rem}.detail-group p{font-size:.75rem}.relatives-list li{padding:.3rem 0;font-size:.75rem}.rel-tag{font-size:.65rem}.event-type{font-size:.75rem}.event-date,.event-place,.event-description{font-size:.65rem}.aka-name{font-size:.75rem}.aka-type{font-size:.6rem}.aka-notes{font-size:.7rem}.tree-legend{font-size:11px;padding:8px 10px;gap:6px}.legend-color{width:11px;height:11px}.legend-line{width:16px}}@media(max-width:991.98px)and (orientation:landscape){.sidebar{width:min(40vw,300px);flex-basis:min(40vw,300px)}}
