@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.react-flow{--xy-edge-stroke-default:#b1b1b7;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#555;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#e2e2e2;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:transparent;--xy-background-pattern-dots-color-default:#91919a;--xy-background-pattern-lines-color-default:#eee;--xy-background-pattern-cross-color-default:#e2e2e2;background-color:var(--xy-background-color,var(--xy-background-color-default));--xy-node-color-default:inherit;--xy-node-border-default:1px solid #1a192b;--xy-node-background-color-default:#fff;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--xy-node-boxshadow-selected-default:0 0 0 .5px #1a192b;--xy-node-border-radius-default:3px;--xy-handle-background-color-default:#1a192b;--xy-handle-border-color-default:#fff;--xy-selection-background-color-default:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--xy-controls-button-background-color-default:#fefefe;--xy-controls-button-background-color-hover-default:#f4f4f4;--xy-controls-button-color-default:inherit;--xy-controls-button-color-hover-default:inherit;--xy-controls-button-border-color-default:#eee;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.react-flow.dark{--xy-edge-stroke-default:#3e3e3e;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#727272;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#2b2b2b;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:#141414;--xy-background-pattern-dots-color-default:#777;--xy-background-pattern-lines-color-default:#777;--xy-background-pattern-cross-color-default:#777;--xy-node-color-default:#f8f8f8;--xy-node-border-default:1px solid #3c3c3c;--xy-node-background-color-default:#1e1e1e;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--xy-node-boxshadow-selected-default:0 0 0 .5px #999;--xy-handle-background-color-default:#bebebe;--xy-handle-border-color-default:#1e1e1e;--xy-selection-background-color-default:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--xy-controls-button-background-color-default:#2b2b2b;--xy-controls-button-background-color-hover-default:#3e3e3e;--xy-controls-button-color-default:#f8f8f8;--xy-controls-button-color-hover-default:#fff;--xy-controls-button-border-color-default:#5b5b5b;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#141414;--xy-edge-label-color-default:#f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props,var(--xy-background-color,var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected,var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default;position:absolute}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background-color:var(--xy-handle-background-color,var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color,var(--xy-handle-border-color-default));border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px)translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px)translateY(-50%)}.react-flow__attribution{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__minimap{background:var(--xy-minimap-background-color-props,var(--xy-minimap-background-color,var(--xy-minimap-background-color-default)))}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var(--xy-minimap-mask-background-color-props,var(--xy-minimap-mask-background-color,var(--xy-minimap-mask-background-color-default)));stroke:var(--xy-minimap-mask-stroke-color-props,var(--xy-minimap-mask-stroke-color,var(--xy-minimap-mask-stroke-color-default)));stroke-width:var(--xy-minimap-mask-stroke-width-props,var(--xy-minimap-mask-stroke-width,var(--xy-minimap-mask-stroke-width-default)))}.react-flow__minimap-node{fill:var(--xy-minimap-node-background-color-props,var(--xy-minimap-node-background-color,var(--xy-minimap-node-background-color-default)));stroke:var(--xy-minimap-node-stroke-color-props,var(--xy-minimap-node-stroke-color,var(--xy-minimap-node-stroke-color-default)));stroke-width:var(--xy-minimap-node-stroke-width-props,var(--xy-minimap-node-stroke-width,var(--xy-minimap-node-stroke-width-default)))}.react-flow__background-pattern.dots{fill:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-dots-color-default)))}.react-flow__background-pattern.lines{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-lines-color-default)))}.react-flow__background-pattern.cross{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-cross-color-default)))}.react-flow__controls{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;color:var(--xy-node-color,var(--xy-node-color-default));text-align:center;border:var(--xy-node-border,var(--xy-node-border-default));background-color:var(--xy-node-background-color,var(--xy-node-background-color-default));padding:10px;font-size:12px}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected,var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color,var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color,var(--xy-selection-background-color-default));border:var(--xy-selection-border,var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var(--xy-controls-button-background-color-hover-props,var(--xy-controls-button-background-color-hover,var(--xy-controls-button-background-color-hover-default)));color:var(--xy-controls-button-color-hover-props,var(--xy-controls-button-color-hover,var(--xy-controls-button-color-hover-default)))}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)))}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;translate:-50% -50%}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border-style:solid;border-width:0}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color,var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color,var(--xy-edge-label-color-default))}svg{background:0 0}.graph{border:none}.node{cursor:pointer}.link{fill:none;stroke:#d4cbb3;stroke-width:1.5px}.additional-marriage{stroke-dasharray:2}.detailed text{fill:#2d3436;font-family:Inter,sans-serif}.detailed .name{font-size:14px;font-weight:600}.detailed rect{stroke:#e0d8c8;stroke-width:1.5px;rx:12;ry:12}.detailed .details{fill:#636e72;font-size:11px}.detailed rect.male{fill:#f0f7ff;stroke:#74b9ff}.detailed rect.female{fill:#fff0f6;stroke:#fab1a0}.detailed .selected rect{stroke:#d4a373;stroke-width:3px}circle{fill:#fdfbf7;stroke:#e0d8c8;stroke-width:3px}.circle text{fill:#2d3436;text-anchor:middle;font-family:Inter,sans-serif;font-size:13px}.background{stroke:none;fill:#0000}.branch,.trunk{fill:#d4cbb3;stroke:#d4cbb3}.expander{fill:#f5efe0;stroke:#d4a373;stroke-width:2px;cursor:pointer}.indi.selected circle{stroke:#d4a373;stroke-width:6px}:root{--bg-primary:#fdfbf7;--bg-secondary:#f5efe0;--bg-tertiary:#ece1ca;--bg-card:#fff;--bg-card-hover:#f9f6f0;--bg-input:#fff;--text-primary:#2d3436;--text-secondary:#636e72;--text-muted:#b2bec3;--accent:#d4a373;--accent-hover:#c69362;--accent-glow:#d4a37326;--success:#27ae60;--success-bg:#27ae601a;--error:#e17055;--error-bg:#e170551a;--warning:#fdcb6e;--warning-bg:#fdcb6e1a;--border:#e0d8c8;--border-focus:#d4a373;--radius:12px;--radius-sm:8px;--radius-xs:6px;--shadow-sm:0 1px 4px #0000000a;--shadow-md:0 8px 16px #b5a9911f;--shadow-lg:0 12px 32px #b5a99126;--shadow-glow:0 0 15px var(--accent-glow);--transition:.2s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}a{color:var(--accent);transition:color var(--transition);text-decoration:none}a:hover{color:var(--accent-hover)}.page-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.loading-screen{min-height:60vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.spinner{border:3px solid var(--bg-tertiary);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-secondary);padding:4rem 2rem;font-size:1.1rem}.not-found{text-align:center;padding:6rem 2rem}.not-found h1{background:linear-gradient(135deg, var(--accent), #e17055);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:5rem;font-weight:700}.not-found p{color:var(--text-secondary);margin:1rem 0 2rem;font-size:1.2rem}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-family:inherit;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{background:var(--bg-tertiary);color:var(--text-primary);padding:.35rem .75rem;font-size:.8rem}.btn-sm:hover{background:var(--bg-secondary)}.btn-full{width:100%}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);padding:.6rem .8rem;font-family:inherit;font-size:.9rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-group textarea{resize:vertical;min-height:60px}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-grid .full-width{grid-column:1/-1}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;margin-top:1rem;padding-top:1rem;display:flex}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.5rem}.form-card h3{margin-bottom:1rem;font-size:1.1rem}.form-hint{color:var(--text-muted);margin-top:.5rem;font-size:.8rem}.checkbox-label{cursor:pointer;align-items:center;gap:.5rem;text-transform:none!important;flex-direction:row!important;display:flex!important}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.field-error{color:var(--error);font-size:.78rem}.warning-banner{background:var(--warning-bg);border:1px solid var(--warning);color:var(--warning);border-radius:var(--radius-xs);margin-bottom:1rem;padding:.6rem 1rem;font-size:.85rem}.home-header{text-align:center;padding:3rem 0 2.5rem}.home-header h1{background:linear-gradient(135deg, var(--accent), #e17055);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700}.subtitle{color:var(--text-secondary);margin-top:.5rem;font-size:1.05rem}.project-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);color:inherit;text-decoration:none;overflow:hidden}.project-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.card-cover{height:160px;overflow:hidden}.card-cover-img{object-fit:cover;width:100%;height:100%}.card-cover-placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.card-cover-placeholder span{color:#fffc;text-shadow:0 2px 8px #0000004d;font-size:4rem;font-weight:700}.card-body{padding:1.25rem}.card-title{color:var(--text-primary);margin-bottom:.4rem;font-size:1.15rem;font-weight:600}.card-description{color:var(--text-secondary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;line-height:1.5;display:-webkit-box;overflow:hidden}.card-link{color:var(--accent);margin-top:.75rem;font-size:.85rem;font-weight:500;display:inline-block}.tree-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);align-items:center;gap:1.5rem;padding:1rem 1.5rem;display:flex}.tree-header h1{font-size:1.25rem;font-weight:600}.back-link{color:var(--text-secondary);font-size:.9rem}.tree-container{flex:1;min-height:0}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);max-width:400px;margin:8vh auto 0;padding:2.5rem}.login-card h1{text-align:center;font-size:1.5rem;font-weight:700}.login-card .subtitle{text-align:center;margin-bottom:2rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.error-message{background:var(--error-bg);border:1px solid var(--error);color:var(--error);border-radius:var(--radius-xs);padding:.6rem 1rem;font-size:.85rem}.admin-layout{height:100vh;display:flex}.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;width:250px;min-width:250px;padding:1.5rem 1rem;display:flex}.admin-sidebar h2{background:linear-gradient(135deg, var(--accent), #e17055);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;padding:0 .5rem;font-size:1.1rem;font-weight:700}.admin-sidebar nav{flex-direction:column;gap:.25rem;margin-bottom:1.5rem;display:flex}.sidebar-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all var(--transition);background:0 0;border:none;padding:.6rem 1rem;font-family:inherit;font-size:.9rem;font-weight:500}.sidebar-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-btn.active{background:var(--accent-glow);color:var(--accent)}.sidebar-project-select{flex-direction:column;gap:.4rem;margin-top:auto;margin-bottom:1rem;display:flex}.sidebar-project-select label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-weight:500}.sidebar-project-select select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);padding:.5rem;font-family:inherit;font-size:.85rem}.sidebar-logout{width:100%;margin-top:.5rem}.admin-main{flex:1;padding:2rem;position:relative;overflow-y:auto}.section-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.header-actions{gap:1rem;display:flex}.bulk-textarea{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);resize:vertical;margin:1rem 0;padding:1rem;font-family:monospace;font-size:.9rem}.form-hint{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem}code{background:var(--bg-tertiary);color:var(--accent);border-radius:4px;padding:.2rem .4rem}.section-header h1{font-size:1.5rem;font-weight:600}.data-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.data-table table{border-collapse:collapse;width:100%}.data-table th{text-align:left;background:var(--bg-secondary);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:.85rem 1rem;font-size:.75rem;font-weight:700}.data-table td{border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-secondary)}.data-table .row-selected td{background:var(--accent-glow)}.data-table code{background:var(--bg-primary);border-radius:4px;padding:.15rem .4rem;font-size:.82rem}.data-table .empty-cell{text-align:center;color:var(--text-muted);padding:2rem}.data-table .actions{gap:.4rem;display:flex}.badge{border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-green{background:var(--success-bg);color:var(--success)}.badge-gray{color:var(--text-muted);background:#94a3b81a}.badge-rel-parent{color:#22c55e;background:#22c55e1a}.badge-rel-child{color:#3b82f6;background:#3b82f61a}.badge-rel-spouse{color:#ec4899;background:#ec48991a}.toast{border-radius:var(--radius-sm);z-index:1000;padding:.75rem 1.25rem;font-size:.9rem;font-weight:500;animation:.3s slideIn;position:fixed;top:1.5rem;right:1.5rem}.toast-success{background:var(--success-bg);border:1px solid var(--success);color:var(--success)}.toast-error{background:var(--error-bg);border:1px solid var(--error);color:var(--error)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.dialog-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.dialog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:440px;box-shadow:var(--shadow-lg);padding:2rem}.dialog-card h3{margin-bottom:.75rem;font-size:1.15rem}.dialog-body{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem;line-height:1.6}.dialog-actions{justify-content:flex-end;gap:.75rem;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.person-node{border:1px solid var(--border);text-align:left;min-width:200px;transition:all var(--transition);box-shadow:var(--shadow-sm);background:#fff;border-radius:12px;padding:.8rem 1rem;position:relative}.person-node:hover{border-color:var(--accent);box-shadow:var(--shadow-md);background:#fdfbf7;transform:translateY(-2px)}.node-male{border-left:4px solid #74b9ff}.node-female{border-left:4px solid #fab1a0}.node-unknown{border-left:4px solid #dcdde1}.node-content{flex-direction:column;display:flex}.node-row{align-items:center;gap:.75rem;display:flex}.node-avatar,.node-avatar-placeholder{object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}.node-avatar-placeholder{color:#fff;text-transform:uppercase;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex}.node-avatar-placeholder.male{background:linear-gradient(135deg,#a4c5f9,#74b9ff)}.node-avatar-placeholder.female{background:linear-gradient(135deg,#f9a4d4,#fab1a0)}.node-avatar-placeholder.unknown{background:linear-gradient(135deg,#dcdde1,#b2bec3)}.node-text{flex-direction:column;gap:.15rem;display:flex}.node-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.photo-upload-row{align-items:center;gap:1rem;margin-top:.5rem;display:flex}.photo-preview-sm{object-fit:cover;border:1px solid var(--border);border-radius:50%;width:48px;height:48px}.node-name{color:#2d3436;font-size:.95rem;font-weight:700}.node-years{color:#636e72;font-size:.8rem}.node-handle{opacity:0;transition:opacity .2s;background:var(--accent)!important;border:2px solid #fff!important;width:8px!important;height:8px!important}.person-node:hover .node-handle{opacity:1}.marriage-node{background:0 0;width:10px;height:10px}.marriage-handle{opacity:0!important}.node-tooltip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xs);z-index:100;min-width:220px;max-width:300px;box-shadow:var(--shadow-lg);padding:.75rem;animation:.15s fadeIn;position:absolute;top:calc(100% + 12px);left:0}.react-flow__background{background-color:#fdfbf7}.react-flow__controls{overflow:hidden;border:1px solid var(--border)!important;box-shadow:var(--shadow-md)!important;background:#ffffffe6!important;border-radius:8px!important}.react-flow__controls-button{border-bottom:1px solid var(--border)!important;fill:var(--text-primary)!important;background:0 0!important}.react-flow__controls-button:hover{background:var(--bg-secondary)!important}.react-flow__minimap{background:var(--bg-secondary)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-md)!important;border-radius:8px!important;bottom:20px!important;right:20px!important}.react-flow__minimap-mask{fill:#d4a3730d!important}.react-flow__minimap-node{rx:4;ry:4;fill:var(--accent)!important;stroke:none!important}.tree-page{flex-direction:column;height:100vh;display:flex}.tree-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:1.5rem;padding:.8rem 1.5rem;display:flex}.tree-header h1{white-space:nowrap;font-size:1.2rem;font-weight:600}.back-link{color:var(--text-secondary);white-space:nowrap;font-size:.85rem;text-decoration:none}.back-link:hover{color:var(--text-primary)}.tree-container{background:var(--bg-primary);flex:1;position:relative}.view-selector{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:100px;gap:4px;padding:4px;display:flex;box-shadow:inset 0 2px 4px #0000000d}.view-toggle-btn{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:100px;align-items:center;gap:8px;padding:6px 16px;font-size:.85rem;font-weight:600;display:flex}.view-toggle-btn:hover{color:var(--text-primary)}.view-toggle-btn.active{color:#c69362;background:#fff;transform:scale(1.02);box-shadow:0 2px 10px #b5a99140}.chart-type-select{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23d4a373'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;border-radius:100px;outline:none;padding:8px 36px 8px 16px;font-size:.85rem;font-weight:600}.chart-type-select:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.chart-type-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.tree-search{min-width:220px;position:relative}.header-actions{align-items:center;gap:1rem;margin-left:auto;display:flex}.export-btn{white-space:nowrap}.search-input{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:.5rem .8rem;font-size:.85rem;transition:border-color .2s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.search-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:100;max-height:240px;box-shadow:var(--shadow-lg);margin:0;padding:.25rem;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.search-dropdown li{cursor:pointer;border-radius:4px;justify-content:space-between;align-items:center;padding:.5rem .75rem;transition:background .15s;display:flex}.search-dropdown li:hover{background:var(--accent-glow)}.search-name{color:var(--text-primary);font-size:.85rem}.search-year{color:var(--text-muted);font-size:.75rem}.selected-node .person-node{border-color:var(--accent)!important;box-shadow:0 0 15px var(--accent-glow), 0 0 30px #d4a3731a!important}.detail-panel-overlay{z-index:50;background:#00000080;animation:.2s fadeIn;position:fixed;inset:0}.detail-panel{z-index:51;background:#fdfbf7;border-left:1px solid #e0d8c8;width:380px;max-width:90vw;height:100vh;padding:2rem 1.5rem;animation:.3s slideInRight;position:fixed;top:0;right:0;overflow-y:auto;box-shadow:-4px 0 20px #b5a9911a}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:1.2rem;transition:all .15s;position:absolute;top:1rem;right:1rem}.detail-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.detail-header{text-align:center;margin-bottom:1.5rem}.detail-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;font-size:2rem;font-weight:700;display:flex;overflow:hidden}.detail-avatar.male{background:linear-gradient(135deg,#a4c5f9,#74b9ff)}.detail-avatar.female{background:linear-gradient(135deg,#f9a4d4,#fab1a0)}.detail-avatar.unknown{background:linear-gradient(135deg,#dcdde1,#b2bec3)}.detail-avatar img{object-fit:cover;width:100%;height:100%}.detail-header h2{margin-bottom:.25rem;font-size:1.3rem;font-weight:600}.detail-title{color:var(--text-muted);font-size:.85rem}.detail-info{background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border);flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding:1rem;display:flex}.info-row{justify-content:space-between;align-items:center;display:flex}.info-label{color:var(--text-muted);font-size:.8rem}.info-value{color:var(--text-primary);font-size:.85rem;font-weight:500}.detail-bio{margin-bottom:1.5rem}.detail-bio h3,.detail-relations h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.75rem;font-size:.8rem}.detail-bio p{color:var(--text-secondary);font-size:.85rem;line-height:1.6}.detail-relations ul{flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.detail-relations li{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:.75rem;padding:.6rem .75rem;transition:all .15s;display:flex}.detail-relations li:hover{border-color:var(--accent);background:var(--accent-glow)}.rel-badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:4px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.rel-parent{color:#27ae60;background:#27ae601a}.rel-child{color:#74b9ff;background:#74b9ff26}.rel-spouse{color:#fab1a0;background:#fab1a026}.rel-name{color:var(--text-primary);flex:1;font-size:.85rem}.rel-arrow{color:var(--text-muted);font-size:.8rem}.landing-page{background:var(--bg-primary);color:var(--text-primary);min-height:100vh}.section-container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.home-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;border-bottom:1px solid var(--border);background:#fdfbf7cc;align-items:center;height:80px;display:flex;position:sticky;top:0}.nav-container{justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex}.nav-logo{color:var(--accent);letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.nav-links{gap:2rem;display:flex}.nav-links a{color:var(--text-secondary);font-size:.95rem;font-weight:500;transition:color .2s}.nav-links a:hover{color:var(--accent)}.nav-actions{align-items:center;gap:1rem;display:flex}.btn-text{color:var(--accent);cursor:pointer;background:0 0;border:none;font-weight:600}.mobile-menu-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;display:none}.hero-section{background:radial-gradient(circle at 80% 20%,#d4a3730d 0%,#0000 50%);padding:6rem 0}.section-container.split{align-items:center;gap:4rem;display:flex}.hero-text-content{flex:1}.hero-badge{background:var(--bg-secondary);color:var(--accent);letter-spacing:.05em;border-radius:20px;margin-bottom:1.5rem;padding:.4rem .8rem;font-size:.75rem;font-weight:700;display:inline-block}.hero-text-content h1{color:var(--text-primary);letter-spacing:-.03em;margin-bottom:1.5rem;font-size:4rem;font-weight:800;line-height:1.1}.text-accent{color:var(--accent)}.hero-text-content p{color:var(--text-secondary);max-width:540px;margin-bottom:2.5rem;font-size:1.25rem}.hero-btns{gap:1rem;display:flex}.btn-lg{border-radius:12px;padding:1rem 2rem;font-size:1rem}.btn-outline{border:1.5px solid var(--border);color:var(--text-secondary);background:#fff}.btn-outline:hover{background:var(--bg-primary);border-color:var(--accent)}.hero-visual{flex:1;justify-content:flex-end;display:flex}.hero-image-frame{width:100%;max-width:500px;box-shadow:var(--shadow-lg);background:#fff;border-radius:24px;padding:1.5rem;transform:rotate(2deg)}.hero-image-frame img{border-radius:12px;width:100%;display:block}.features-section{background:var(--bg-primary);padding:8rem 0}.section-header-centered{text-align:center;margin-bottom:4rem}.section-header-centered h2{color:var(--text-primary);margin-bottom:1rem;font-size:2.5rem;font-weight:800}.section-header-centered p{color:var(--text-secondary);font-size:1.1rem}.feature-grid{grid-template-columns:repeat(3,1fr);gap:2rem;display:grid}.feature-card{box-shadow:var(--shadow-md);border:1px solid var(--border);background:#fff;border-radius:20px;padding:3rem 2rem;transition:transform .3s cubic-bezier(.4,0,.2,1)}.feature-card:hover{border-color:var(--accent);transform:translateY(-10px)}.feature-icon-box{border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:1.5rem;display:flex}.feature-icon-box.blue{color:#74b9ff;background:#f0f7ff}.feature-icon-box.green{color:#55efc4;background:#f0fff4}.feature-icon-box.purple{color:#a29bfe;background:#f8f7ff}.feature-card h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.25rem;font-weight:700}.feature-card p{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.projects-section{padding:8rem 0}.section-header-row{justify-content:space-between;align-items:flex-end;margin-bottom:3rem;display:flex}.section-header-row h2{color:var(--text-primary);margin-bottom:.5rem;font-size:2.5rem;font-weight:800}.section-header-row p{color:var(--text-secondary)}.btn-text-icon{color:#4f46e5;align-items:center;gap:.5rem;font-weight:700;text-decoration:none;display:flex}.project-grid-new{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem;display:grid}.project-card-v2{background:var(--bg-card);border:1px solid var(--border);transition:all var(--transition);box-shadow:var(--shadow-sm);border-radius:20px;flex-direction:column;text-decoration:none;display:flex;overflow:hidden}.project-card-v2:not(.starter):hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.card-v2-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.project-avatar-v2{color:#b5a991;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:800;display:flex}.status-badge{border-radius:6px;padding:.3rem .6rem;font-size:.7rem;font-weight:800}.status-badge.active{color:#16a34a;background:#f0fdf4}.card-v2-body h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:800}.card-v2-stats{color:var(--text-secondary);align-items:center;gap:.4rem;margin-bottom:1rem;font-size:.85rem;display:flex}.card-v2-desc{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.card-v2-footer{margin-top:auto}.btn-v2{background:var(--bg-tertiary);color:var(--text-primary);font-weight:700}.btn-v2:hover{background:var(--bg-secondary)}.project-card-v2.starter{border:2px dashed var(--border);background:var(--bg-secondary);text-align:center;color:var(--text-secondary);justify-content:center;align-items:center;padding:3rem}.starter-icon-plus{width:64px;height:64px;box-shadow:var(--shadow-sm);color:var(--text-muted);background:#fff;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.project-card-v2.starter:hover{border-color:var(--accent);color:var(--accent);background:#fff}.project-card-v2.starter:hover .starter-icon-plus{color:var(--accent)}@media (width<=1024px){.section-container.split{text-align:center;flex-direction:column}.hero-text-content h1{font-size:3rem}.hero-text-content p{margin-left:auto;margin-right:auto}.hero-btns{justify-content:center}.hero-visual{justify-content:center;margin-top:4rem}.feature-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.desktop-only{display:none}.mobile-menu-toggle{display:block}.mobile-menu{z-index:999;background:#fff;flex-direction:column;gap:1.5rem;padding:2rem;display:flex;position:absolute;top:80px;left:0;right:0;box-shadow:0 10px 15px -3px #0000001a}.feature-grid{grid-template-columns:1fr}.cta-card{text-align:center;padding:4rem 2rem}.cta-btns{flex-direction:column}.footer-top{flex-direction:column;gap:3rem}.admin-layout{flex-direction:column}.admin-sidebar{gap:.75rem;width:100%;min-width:100%;padding:.75rem 1rem}.admin-sidebar h2{margin-bottom:.5rem;font-size:1rem}.admin-sidebar nav{flex-flow:wrap;gap:.4rem}.sidebar-btn{padding:.4rem .75rem;font-size:.8rem}.sidebar-project-select{width:100%}.admin-main{padding:1rem}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.section-header .header-controls{flex-wrap:wrap;width:100%}.header-controls .btn{flex:1}.data-table{background:var(--bg-primary);border-radius:var(--radius-sm);overflow-x:auto}.data-table table{min-width:600px}.tree-header{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem}.tree-header h1{text-align:center;font-size:1rem}.header-actions{flex-direction:column;align-items:stretch;gap:.75rem;width:100%}.tree-search{width:100%;min-width:0}.detail-panel{border-left:none;border-top:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:100%;height:85vh;padding:2.5rem 1.25rem 1.5rem;animation:.3s slideInUp;top:auto;bottom:0}.detail-panel:before{content:"";background:var(--border);border-radius:2px;width:40px;height:4px;position:absolute;top:12px;left:50%;transform:translate(-50%)}.form-grid{grid-template-columns:1fr}}
