*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);min-height:100vh;color:#e8e8e8;line-height:1.4}.app-main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem;width:100%}.app-header{text-align:center;margin-bottom:2.5rem}.gradient-title{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;background:linear-gradient(90deg,#e94560,#f39c6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{margin:0;font-size:.95rem;color:#a0a0b0}.tree-container{display:flex;flex-direction:column;height:70vh;min-height:400px;max-height:calc(100vh - 6rem);background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.08);overflow:hidden;width:100%}.tree-toolbar{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}.tree-toolbar label{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:#a0a0b0}.tree-toolbar select{background:#0000004d;color:#e8e8e8;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.35rem .6rem;font-size:.9rem;min-width:140px;max-width:min(220px,50vw)}.tree-zoom{display:flex;align-items:center;gap:.25rem;margin-left:auto}.tree-zoom button{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:2rem;padding:0 .5rem;background:#0000004d;color:#e8e8e8;border:1px solid rgba(255,255,255,.15);border-radius:6px;font-size:1.1rem;line-height:1;cursor:pointer}.tree-zoom button:hover{background:#e9456040;border-color:#e9456066}.zoom-label{font-size:.8rem;color:#a0a0b0;min-width:2.5rem;text-align:center}.zoom-fit{font-size:.8rem!important;margin-left:.25rem}.tree-scroll{flex:1;min-height:0;overflow:auto;position:relative;-webkit-overflow-scrolling:touch;overflow-anchor:none}.tree-zoom-wrapper{position:relative;min-width:100%;min-height:100%}.tree-content{position:relative}.tree-links{position:absolute;pointer-events:none}.link{stroke:#fff3;stroke-width:1.5;fill:none}.link-parent-child{stroke:#e9456080}.link-spouse{stroke:#f39c6b99;stroke-dasharray:4 4}.tree-nodes{position:absolute;pointer-events:none}.node{position:absolute;pointer-events:auto;display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;background:#1a1a2ef2;border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 2px 8px #0000004d;cursor:pointer}.node.node-male{background:#b41e1e73;border-color:#dc3c3c80}.node.node-female{background:#1e6e3c73;border-color:#3ca05a80}.node.node-male:hover{border-color:#dc3c3ce6;box-shadow:0 4px 12px #c828284d}.node.node-female:hover{border-color:#3ca05ae6;box-shadow:0 4px 12px #28a0504d}.node.node-placeholder{opacity:.85;cursor:default}.node:focus{outline:2px solid rgba(233,69,96,.6);outline-offset:2px}.node-avatar{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;overflow:hidden}.node-male .node-avatar{background:#ff646440}.node-female .node-avatar{background:#50c87840}.node-avatar img{width:100%;height:100%;object-fit:cover}.node-initial{font-size:1rem;font-weight:600;color:#ffffffd9}.node-info{min-width:0;display:flex;flex-direction:column;gap:.1rem}.node-name{font-size:.8rem;font-weight:600;color:#f0f0f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-birth{font-size:.7rem;color:#a0a0b0}.tree-empty{padding:2rem;text-align:center;color:#a0a0b0}@media (max-width: 768px){.app-main{padding:1rem .75rem}.app-header{margin-bottom:1.5rem}.gradient-title{font-size:1.5rem}.subtitle{font-size:.85rem}.tree-container{height:60vh;min-height:320px;max-height:calc(100vh - 5rem)}.tree-toolbar{padding:.5rem .75rem;gap:.5rem}.tree-toolbar select{min-width:120px;max-width:45vw}.tree-zoom{margin-left:0;width:100%;justify-content:flex-end}}@media (max-width: 480px){.tree-toolbar{flex-direction:column;align-items:stretch}.tree-toolbar select{max-width:none}.tree-zoom{width:auto;justify-content:center}}.ctx-menu{position:fixed;z-index:200;background:#141424f7;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:.25rem;box-shadow:0 4px 16px #00000080;min-width:140px}.ctx-menu-item{display:block;width:100%;padding:.45rem .75rem;background:none;border:none;border-radius:5px;color:#e8e8e8;font-size:.88rem;text-align:left;cursor:pointer}.ctx-menu-item:hover{background:#e9456033}.ctx-menu-item-danger{color:#e94560}.ctx-menu-item-danger:hover{background:#e945604d}.topbar{position:fixed;top:0;right:0;z-index:100;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem}.topbar-user{font-size:.85rem;color:#a0a0b0}.topbar-btn{padding:.3rem .75rem;background:#0000004d;color:#e8e8e8;border:1px solid rgba(255,255,255,.15);border-radius:6px;font-size:.8rem;cursor:pointer}.topbar-btn:hover{background:#e9456040;border-color:#e9456066}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{position:relative;width:100%;max-width:400px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem}.login-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:#a0a0b0;font-size:1rem;cursor:pointer;padding:4px 6px;border-radius:4px}.login-close:hover{color:#e8e8e8;background:#ffffff14}.login-title{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;background:linear-gradient(90deg,#e94560,#f39c6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{margin:0 0 1.5rem;font-size:.9rem;color:#a0a0b0}.login-form{display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.3rem}.login-field label{font-size:.85rem;color:#a0a0b0}.login-field input{background:#0000004d;color:#e8e8e8;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.5rem .75rem;font-size:.95rem;outline:none}.login-field input:focus{border-color:#e9456099}.login-error{font-size:.85rem;color:#e94560}.login-btn{margin-top:.5rem;padding:.6rem 1.25rem;background:linear-gradient(90deg,#e94560,#c0392b);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer}.login-btn:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#0009;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-card{width:100%;max-width:440px;background:#141424fa;border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 8px 32px #0009;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}.modal-title{font-size:1rem;font-weight:600;color:#f0f0f0}.modal-close{background:none;border:none;color:#a0a0b0;font-size:1rem;cursor:pointer;padding:.1rem .3rem;border-radius:4px}.modal-close:hover{color:#e8e8e8;background:#ffffff14}.modal-form{display:flex;flex-direction:column;gap:.85rem;padding:1rem}.modal-row{display:flex;gap:.75rem}.modal-row .modal-field{flex:1;min-width:0}.modal-field{display:flex;flex-direction:column;gap:.3rem}.modal-field label{font-size:.82rem;color:#a0a0b0}.modal-field input,.modal-field select{background:#0000004d;color:#e8e8e8;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.45rem .65rem;font-size:.9rem;outline:none;width:100%}.modal-field input:focus,.modal-field select:focus{border-color:#e9456099}.modal-input-readonly{opacity:.6;cursor:default}.modal-error{font-size:.85rem;color:#e94560;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.25rem}.modal-btn-cancel{padding:.45rem 1rem;background:#0000004d;color:#e8e8e8;border:1px solid rgba(255,255,255,.15);border-radius:6px;font-size:.9rem;cursor:pointer}.modal-btn-cancel:hover{background:#ffffff14}.modal-btn-submit{padding:.45rem 1.25rem;background:linear-gradient(90deg,#e94560,#c0392b);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer}.modal-btn-submit:disabled{opacity:.6;cursor:not-allowed}.tag-input{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.35rem .5rem;min-height:2.2rem;cursor:text}.tag-input:focus-within{border-color:#e9456099}.tag-input input{flex:1;min-width:6rem;background:none;border:none;outline:none;color:#e8e8e8;font-size:.9rem;padding:0}.tag{display:inline-flex;align-items:center;gap:.25rem;background:#e9456033;border:1px solid rgba(233,69,96,.4);border-radius:4px;padding:.1rem .4rem;font-size:.8rem;color:#f0f0f0;white-space:nowrap}.tag-remove{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:.7rem;padding:0;line-height:1}.tag-remove:hover{color:#e94560}
