@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800;900&display=swap";.member-node{width:160px;padding:.5rem .75rem;border-radius:3px;display:flex;align-items:center;gap:.6rem;cursor:pointer;background:var(--card-bg);border:1px solid var(--card-border);color:var(--text-primary);transition:all var(--transition-speed) cubic-bezier(.16,1,.3,1);position:relative;z-index:2}.member-node.female{border-radius:20px}.member-node:hover{transform:translateY(-2px);border-color:#0003;background:#fff;box-shadow:0 6px 15px #0000000d}.member-node.selected{background:#000!important;border-color:#000!important;color:#fff!important;box-shadow:0 8px 25px #00000026}.avatar-placeholder{aspect-ratio:1;width:28px;height:28px;border-radius:4px;background:#1a1a1a;border:none;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.8rem;color:#fff;transition:all var(--transition-speed) ease}.member-node.female .avatar-placeholder{border-radius:50%;background:#fff;border:1.5px solid rgba(0,0,0,.15);color:#1a1a1a}.member-node.selected .avatar-placeholder{background:#fff;color:#000;border:none}.member-node.selected.female .avatar-placeholder{background:#000;color:#fff;border:1px solid rgba(255,255,255,.25)}.name-container{display:flex;flex-direction:column;line-height:1.2}.name-container .first-name{font-size:.8rem;font-weight:700;letter-spacing:.01em}.name-container .last-name{font-size:.72rem;font-weight:300;opacity:.65;letter-spacing:.01em}.member-node.selected .name-container{color:#fff}.canvas-container{width:100%;height:100%;cursor:grab;position:relative;overflow:hidden;--canvas-center-y: 50vh}.canvas-container:active{cursor:grabbing}.canvas-layer{position:absolute;top:0;left:0;transform-origin:0 0;transform:translate(calc(50vw + var(--tx, 0px)),calc(var(--canvas-center-y, 50vh) + var(--ty, 0px))) scale(var(--scale, 1));transition:var(--transition-style, transform .05s linear)}.edges-layer{overflow:visible;position:absolute;top:0;left:0}.node-wrapper{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:30px;z-index:var(--z-index, 1)}.tree-link{fill:none;stroke:var(--line-color);stroke-width:1px;stroke-linecap:round;transition:stroke var(--transition-speed) ease}.spouse-link{stroke-dasharray:4 4;stroke-width:1px;opacity:.5}.focal-spouse-link{stroke-dasharray:6 4;stroke-width:2.5px;stroke:#000000b3;opacity:.95}.paternal-link{stroke-width:2px;stroke:#00000073}.nodes-layer{position:absolute;top:0;left:0}.canvas-controls{position:absolute;bottom:2rem;left:2rem;display:flex;flex-direction:column;gap:.5rem;padding:.5rem;border-radius:8px;z-index:10;box-shadow:0 4px 25px #00000014}.control-btn{width:36px;height:36px;border-radius:6px;background:#fff9;border:1px solid var(--card-border);color:var(--text-primary);font-size:1.2rem;font-weight:500;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-speed) ease}.control-btn:hover{background:#000;color:#fff;border-color:#000}.control-btn.reset-btn{font-size:1.3rem}@media(max-width:767px){.canvas-container.has-selected{--canvas-center-y: 20vh}.canvas-controls{bottom:1.5rem;left:1rem;flex-direction:column;gap:.4rem;padding:.4rem;transition:bottom .3s cubic-bezier(.16,1,.3,1)}.canvas-container.has-selected .canvas-controls{bottom:calc(60vh + 1rem)}.control-btn{width:42px;height:42px;font-size:1.4rem}}.detail-panel{position:absolute;top:0;right:0;bottom:0;width:340px;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--card-border);padding:2rem 1.5rem;box-shadow:-10px 0 40px #0000000a;z-index:20;overflow-y:auto;transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s ease,visibility .3s;visibility:hidden;opacity:0}.detail-panel.open{transform:translate(0);visibility:visible;opacity:1}.close-btn{position:absolute;top:1.25rem;right:1.25rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;padding:0;border-radius:50%;background:#00000005;border:1px solid var(--card-border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-speed) ease}.close-btn:hover{background:#0000000f;color:#000;border-color:#0003}.panel-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1.5rem;margin-bottom:2rem;text-align:center}.panel-header h2{font-size:1.25rem;font-weight:700;letter-spacing:.01em;color:var(--text-primary)}.panel-avatar{width:80px;height:80px;border-radius:8px;background:#1a1a1a;border:none;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:2.2rem;color:#fff;transition:all var(--transition-speed) ease}.panel-avatar.female{border-radius:50%;background:#fff;border:1.5px solid rgba(0,0,0,.15);color:#1a1a1a}.panel-content h4{color:var(--text-secondary);font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;font-weight:800;margin-bottom:.5rem}.info-group{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid rgba(0,0,0,.05)}.info-group p{font-size:.95rem;font-weight:300;color:var(--text-primary)}.children-list{list-style:none}.children-list li{padding:.4rem 0;color:var(--text-primary);font-size:.95rem;border-bottom:1px dashed rgba(0,0,0,.04)}.children-list li:last-child{border-bottom:none}.bio-text,.no-data{color:var(--text-secondary)!important;font-size:.85rem!important;font-style:italic;line-height:1.4}.clickable-relative{cursor:pointer;color:var(--text-secondary);font-weight:500;transition:all var(--transition-speed) ease}.clickable-relative:hover{color:#000;text-decoration:underline}.spouse-item{display:flex;flex-direction:column;gap:.15rem;padding:.5rem 0!important}.spouse-main{font-weight:500}.spouse-relatives{font-size:.8rem;color:var(--text-secondary);padding-left:.5rem}.spouse-relatives-label{font-weight:500;color:var(--text-muted)}.panel-handle{display:none}@media(max-width:767px){.panel-handle{display:block;width:40px;height:5px;background:#0000001f;border-radius:3px;margin:-.5rem auto 1rem}.detail-panel{inset:auto 0 0;width:100%;height:60vh;border-left:none;border-top:1px solid var(--card-border);padding:1.25rem 1rem 2rem;box-shadow:0 -10px 40px #0000000d;border-radius:24px 24px 0 0;transform:translateY(100%)}.close-btn{top:.75rem;right:.75rem;width:44px;height:44px;font-size:1.6rem}.panel-header{margin-top:.5rem;margin-bottom:1.5rem}}.modal-backdrop{position:fixed;inset:0;background:#0006;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease forwards}.modal-content{width:520px;max-width:90%;padding:2.5rem 2.25rem;border-radius:16px;background:#ffffffd9;box-shadow:0 10px 40px #00000014;display:flex;flex-direction:column;gap:1.5rem;animation:scaleIn .3s cubic-bezier(.16,1,.3,1) forwards}.modal-header{text-align:center}.modal-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.25rem}.modal-header h3{font-size:.85rem;font-weight:400;text-transform:uppercase;letter-spacing:.12em;color:var(--text-secondary)}.modal-desc{font-size:.9rem;line-height:1.5;color:var(--text-primary);font-weight:300;text-align:center;margin-bottom:.5rem}.feature-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem}.feature-item{display:flex;gap:1rem;align-items:flex-start}.feature-icon{width:38px;height:38px;border-radius:8px;background:#0000000a;border:1px solid var(--card-border);color:var(--text-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-text h4{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.15rem}.feature-text p{font-size:.8rem;line-height:1.4;color:var(--text-secondary);font-weight:300}.dismiss-btn{margin-top:.5rem;width:100%;padding:.8rem 1rem!important;font-size:.9rem!important;font-weight:600!important;border-radius:6px!important;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:767px){.modal-content{padding:2rem 1.5rem;gap:1.25rem}.modal-header h2{font-size:1.3rem}.modal-header h3{font-size:.75rem}.modal-desc{font-size:.85rem}.feature-icon{width:34px;height:34px}.feature-text h4{font-size:.85rem}.feature-text p{font-size:.75rem}}.app-container{display:flex;flex-direction:column;height:100vh;background:var(--bg-color)}.app-header{position:absolute;top:0;left:0;right:0;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:10;background:#fff6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--card-border)}.app-header h1{font-size:.9rem;font-weight:300;letter-spacing:.25em;text-transform:uppercase;color:var(--text-primary)}.lang-switcher{display:flex;gap:.25rem}.lang-switcher .btn{font-weight:400}.lang-switcher .btn.active{font-weight:800}.app-main{flex:1;position:relative;overflow:hidden;height:calc(100vh - 60px);margin-top:60px}@media(max-width:767px){.app-header{height:50px;padding:0 1rem}.app-header h1{font-size:.8rem;letter-spacing:.12em}.app-main{height:calc(100vh - 50px);margin-top:50px}.btn{padding:.4rem .8rem;font-size:.75rem}}:root{--bg-color: #f8f9fa;--bg-gradient: radial-gradient(circle at 50% 0%, #ffffff 30%, #f1f3f5 100%);--text-primary: #1a1a1a;--text-secondary: #6c757d;--text-muted: #adb5bd;--accent-color: #000000;--accent-glow: rgba(0, 0, 0, .05);--female-color: #000000;--female-glow: rgba(0, 0, 0, .05);--card-bg: rgba(255, 255, 255, .8);--card-border: rgba(0, 0, 0, .08);--line-color: rgba(0, 0, 0, .12);--font-family: "Montserrat", sans-serif;--transition-speed: .25s}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-primary);min-height:100vh;overflow:hidden;position:relative}body:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:30px 30px;pointer-events:none;z-index:0}.glass{background:var(--card-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--card-border);box-shadow:0 4px 25px #0000000a}.btn{background:#00000005;border:1px solid var(--card-border);color:var(--text-primary);padding:.5rem 1.25rem;border-radius:4px;cursor:pointer;font-family:var(--font-family);font-weight:500;font-size:.85rem;letter-spacing:.05em;transition:all var(--transition-speed) ease}.btn:hover{background:#0000000f;border-color:#0003}.btn.active{background:#000;color:#fff;border-color:#000}
