:root{--stat-green:#2d5a3d;--stat-gold:#c9a961;--stat-teal:#4a7d9a;--stat-orange:#e07b39}.tree-toolbar{z-index:50;background:linear-gradient(#334155 0%,#1e293b 100%);border-bottom:2px solid #ffffff1a;flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 1rem;display:flex;position:relative}.toolbar-brand{align-items:center;gap:.75rem;display:flex}.toolbar-logo{background:#ffffff14;border:1px solid #c9a96133;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.toolbar-title-group{flex-direction:column;line-height:1.15;display:flex}.toolbar-title{color:#faf7f0;letter-spacing:.02em;font-size:1.35rem;font-weight:700}.toolbar-subtitle{text-transform:uppercase;letter-spacing:.12em;color:#fff;font-size:.68rem;font-weight:600}.toolbar-data-actions{align-items:center;gap:.5rem;display:flex}.toolbar-upload{position:relative}.toolbar-upload-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute;overflow:hidden}.toolbar-upload-btn{color:#faf7f0;font-size:.75rem;font-weight:700;font-family:var(--font-manrope),sans-serif;cursor:pointer;background:#c9a9611f;border:1.5px solid #c9a96166;border-radius:10px;align-items:center;gap:.4rem;padding:.45rem .9rem;transition:all .2s;display:flex}.toolbar-upload-btn:hover{background:#c9a96138;border-color:#c9a96199}.toolbar-clear-btn{background:#c8233326;border-color:#c8233359}.toolbar-clear-btn:hover{background:#c8233340;border-color:#c8233380}.toolbar-controls{scrollbar-width:none;flex:1;justify-content:flex-start;align-items:center;gap:1rem;min-width:0;display:flex;overflow-x:auto}.toolbar-controls::-webkit-scrollbar{display:none}.control-group{align-items:center;gap:.5rem;display:flex}.control-label{text-transform:uppercase;letter-spacing:.08em;color:#fff;font-size:.68rem;font-weight:700}.control-buttons{background:#00000040;border-radius:10px;flex-flow:row;gap:4px;min-width:fit-content;padding:4px;display:inline-flex}.ctrl-btn{color:#fff;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;min-width:max-content;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:700;transition:all .2s;display:flex}.ctrl-btn:hover{color:#faf7f0;background:#ffffff12}.ctrl-btn.active{color:#fff;background:#c9a96140;border:1px solid #c9a961cc;box-shadow:0 0 10px #c9a96133}.stats-toggle{color:#fff;font-size:.75rem;font-weight:700;font-family:var(--font-manrope),sans-serif;cursor:pointer;background:#ffffff0d;border:1.5px solid #c9a9614d;border-radius:10px;align-items:center;gap:.4rem;padding:.45rem .85rem;transition:all .2s;display:flex}.stats-toggle:hover{color:#fff;background:#c9a9611f;border-color:#c9a96180}.stats-toggle-text{display:inline}.parse-error-banner{color:#c82333;font-size:.85rem;font-weight:600;font-family:var(--font-manrope),sans-serif;background:#c823331f;border-bottom:1px solid #c823334d;justify-content:space-between;align-items:center;padding:.6rem 1rem;display:flex}.parse-error-banner button{color:inherit;cursor:pointer;background:0 0;border:none;padding:0 .5rem;font-size:1.2rem;line-height:1}.parse-error-banner button:hover{opacity:.8}.tree-empty-state{background:radial-gradient(at 20% 80%,#d4af370a 0%,#0000 50%),radial-gradient(at 80% 20%,#2d5a3d08 0%,#0000 50%),#faf7f0;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.tree-empty-content{text-align:center;max-width:360px;padding:2rem}.tree-empty-content h2{color:#1a3a2e;font-size:1.4rem;font-weight:700;font-family:var(--font-cormorant),serif;margin-bottom:.5rem}.tree-empty-content p{color:#555;font-size:.95rem;font-family:var(--font-manrope),sans-serif;margin-bottom:.5rem}.tree-empty-hint{color:#888!important;margin-top:1rem!important;font-size:.82rem!important}.tree-visualization-wrapper{width:100%;min-width:0;height:100%;display:flex}.tree-visualization-wrapper .tree-container{flex:1;min-width:0}.person-detail-sidebar{background:#fffdf5;border-left:1px solid #c9a9614d;flex-direction:column;flex-shrink:0;width:420px;display:flex;overflow-y:auto}.person-detail-sidebar .person-detail-panel{border:none;border-bottom:1px solid #c9a96133;border-radius:0;flex:1;min-height:0;animation:none;position:relative}.tree-container{background:radial-gradient(at 20% 80%,#d4af370a 0%,#0000 50%),radial-gradient(at 80% 20%,#2d5a3d08 0%,#0000 50%),#faf7f0;width:100%;height:100%;position:relative;overflow:hidden}.tree-container svg{width:100%;height:100%;display:block}.link-direct,.link-indirect{fill:none;stroke:#2d5a3d;stroke-width:2px;opacity:.55}.link-spouse{fill:none;stroke:#c9a961;stroke-width:2.5px;stroke-dasharray:5 4;opacity:.8}.link-direct,.link-indirect{stroke-linejoin:miter;stroke-linecap:square}.family-box{fill:#c9a96109;stroke:#c9a961;stroke-width:1.5px;stroke-dasharray:6 4;pointer-events:none}.node-card{stroke-width:2px;filter:drop-shadow(0 2px 8px #00000017);transition:filter .2s,stroke-width .2s}.node-card.male{fill:#f4f9fc;stroke:#4a7d9a}.node-card.female{fill:#fef5f7;stroke:#b86a7f}.node-card.neutral{fill:#fdf9f3;stroke:#9a8060}.tree-node:hover .node-card{filter:drop-shadow(0 5px 20px #0003);stroke-width:3px}.tree-node--selected .node-card{filter:drop-shadow(0 0 12px #c9a96199)drop-shadow(0 4px 20px #c9a96166);stroke:#c9a961!important;stroke-width:4px!important;stroke-dasharray:none!important}.node-name,.node-info,.node-detail{pointer-events:none;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.avatar{pointer-events:none}.tree-node:hover .avatar circle,.tree-node:hover .avatar path{opacity:1!important}.tree-legend{z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff0;border:1.5px solid #d4af3740;border-radius:12px;flex-direction:column;gap:.45rem;padding:.7rem 1rem;display:flex;position:absolute;top:1rem;left:1rem;box-shadow:0 2px 14px #00000012}.legend-item{font-family:var(--font-manrope),sans-serif;color:#444;align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;display:flex}.ll{border-radius:2px;width:32px;height:3px;display:inline-block}.ll.direct,.ll.indirect{background:#2d5a3d;height:2.5px}.ll.spouse{background:repeating-linear-gradient(90deg,#c9a961 0 5px,#0000 5px 9px);height:2.5px}.export-controls{z-index:20;flex-direction:column;gap:.5rem;display:flex;position:absolute;bottom:1.5rem;right:1.5rem}.export-btn{cursor:pointer;color:#fff;font-family:var(--font-manrope),sans-serif;border:none;border-radius:10px;align-items:center;gap:.4rem;padding:.6rem .9rem;font-size:.78rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 3px 10px #00000026}.export-png{background:linear-gradient(135deg,#8b6f47,#d4af37)}.export-svg{background:linear-gradient(135deg,#2d5a3d,#5a8a6f)}.export-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px #0003}.tree-tooltip{z-index:9999;pointer-events:none;max-width:290px;font-family:var(--font-manrope),sans-serif;background:#fffdf5;border:1.5px solid #d4af3759;border-radius:14px;padding:.9rem 1.2rem;animation:.2s ease-out tooltipIn;position:fixed;box-shadow:0 8px 32px #00000021}@keyframes tooltipIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.person-detail-panel{z-index:500;background:#fffdf5;border:2px solid #c9960a;border-radius:14px;flex-direction:column;animation:.3s ease-out panelSlide;display:flex;position:fixed;overflow:hidden;box-shadow:0 12px 48px #00000038,0 2px 8px #0000001f}@keyframes panelSlide{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.pdp-header{background:linear-gradient(135deg,#1a3a2e,#2d5a3d);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:.5rem;padding:.7rem .85rem;display:flex}.pdp-title{flex-direction:column;gap:.25rem;min-width:0;display:flex}.pdp-name{color:#faf7f0;font-size:1.2rem;font-weight:800;line-height:1.2;font-family:var(--font-manrope),sans-serif}.pdp-badge{color:#faf7f0e6;width:fit-content;font-size:.72rem;font-weight:600;font-family:var(--font-manrope),sans-serif;background:#c9a96140;border-radius:20px;padding:.15rem .65rem}.pdp-close{color:#faf7f0;cursor:pointer;background:#ffffff1f;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.1rem;transition:background .2s;display:flex}.pdp-close:hover{background:#ffffff40}.pdp-tabs{scrollbar-width:none;background:#f0ead4;border-bottom:2px solid #c9a9614d;flex-shrink:0;display:flex;overflow-x:auto}.pdp-tabs::-webkit-scrollbar{display:none}.pdp-tab{font-size:.7rem;font-weight:700;font-family:var(--font-manrope),sans-serif;color:#8a6820;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:3px solid #0000;flex-shrink:0;margin-bottom:-2px;padding:.45rem .75rem;transition:color .15s,background .15s}.pdp-tab:hover{color:#2d5a3d;background:#2d5a3d0d}.pdp-tab--active{color:#2d5a3d;background:#2d5a3d0d;border-bottom-color:#2d5a3d}.pdp-body{flex:1;padding:.7rem .85rem .85rem;overflow-y:auto}.pdp-grid{grid-template-columns:1fr 1fr;gap:.45rem;display:grid}.pdp-field{background:#2d5a3d0a;border:1px solid #2d5a3d1a;border-radius:8px;padding:.4rem .55rem}.pdp-field-label{text-transform:uppercase;letter-spacing:.4px;color:#2d5a3d;font-size:.62rem;font-weight:700;font-family:var(--font-manrope),sans-serif;margin-bottom:.12rem}.pdp-field-value{color:#1a1a1a;font-size:.88rem;font-weight:600;font-family:var(--font-manrope),sans-serif;word-break:break-word;line-height:1.25}.pdp-event-row{border-bottom:1px dashed #2d5a3d26;margin-bottom:.5rem;padding-bottom:.5rem}.pdp-event-row:last-child{border-bottom:none;margin-bottom:0}.pdp-empty{color:#aaa;text-align:center;font-size:.85rem;font-style:italic;font-family:var(--font-manrope),sans-serif;padding:2rem 1rem}.statistics-panel{scrollbar-width:thin;scrollbar-color:#c9a9614d transparent;background:linear-gradient(#334155 0%,#1e293b 100%);border-left:2px solid #ffffff1a;flex-shrink:0;width:320px;height:100%;padding:1.5rem 1.25rem;overflow-y:auto}.stats-header{margin-bottom:1.25rem}.stats-title{color:#faf7f0;font-size:1.15rem;font-weight:700;font-family:var(--font-cormorant),serif;letter-spacing:.02em}.stats-subtitle{color:#c9a961b3;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600;font-family:var(--font-manrope),sans-serif;margin-top:.25rem}.stats-grid{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem;display:grid}.stat-card{text-align:center;background:#ffffff0d;border:1px solid #ffffff14;border-radius:12px;padding:.85rem .7rem;transition:background .2s}.stat-card:hover{background:#ffffff14}.stat-icon{color:var(--stat-accent);justify-content:center;margin-bottom:.35rem;display:flex}.stat-value{color:#faf7f0;font-size:1.5rem;font-weight:800;font-family:var(--font-manrope),sans-serif;line-height:1.1}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:#faf7f080;font-size:.62rem;font-weight:700;font-family:var(--font-manrope),sans-serif;margin-top:.2rem}.stats-divider{background:#c9a96126;height:1px;margin:1rem 0}.stats-breakdown{margin-bottom:.25rem}.stats-section-title{text-transform:uppercase;letter-spacing:.08em;color:#c9a961b3;font-size:.68rem;font-weight:700;font-family:var(--font-manrope),sans-serif;margin-bottom:.65rem}.stats-bar-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.stats-bar-label{color:#faf7f0b3;width:52px;font-size:.72rem;font-weight:600;font-family:var(--font-manrope),sans-serif;flex-shrink:0}.stats-bar-track{background:#ffffff14;border-radius:3px;flex:1;height:6px;overflow:hidden}.stats-bar-fill{border-radius:3px;height:100%;transition:width .5s}.stats-bar-fill.male{background:linear-gradient(90deg,#4a7d9a,#7aaabf)}.stats-bar-fill.female{background:linear-gradient(90deg,#b86a7f,#cc8fa0)}.stats-bar-fill.direct,.stats-bar-fill.indirect{background:linear-gradient(90deg,#2d5a3d,#5a8a6f)}.stats-bar-count{color:#faf7f0;text-align:right;width:24px;font-size:.75rem;font-weight:800;font-family:var(--font-manrope),sans-serif}.stats-tags{flex-wrap:wrap;gap:.35rem;display:flex}.stats-tag{color:#faf7f0cc;font-size:.68rem;font-weight:600;font-family:var(--font-manrope),sans-serif;background:#2d5a3d26;border:1px solid #2d5a3d40;border-radius:20px;padding:.25rem .6rem}.stats-tag.caste{color:#c9a961;background:#c9a96126;border-color:#c9a9614d}.stats-tag.gotra{color:#7aaabf;background:#4a7d9a26;border-color:#4a7d9a4d}@media (max-width:768px){.tree-toolbar{height:52px;padding:0 .75rem}.toolbar-title{font-size:1.1rem}.control-label,.ctrl-btn span,.stats-toggle-text{display:none}.statistics-panel{width:260px;padding:1rem}.stats-grid{grid-template-columns:1fr 1fr}}.node-action-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffffa;border:1.5px solid #c9a9614d;border-radius:12px;min-width:200px;animation:.2s ease-out menuSlideIn;overflow:hidden;box-shadow:0 8px 32px #00000026}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-8px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.node-action-menu-header{background:linear-gradient(135deg,#1a3a2e,#2d5a3d);border-bottom:1px solid #c9a96133;padding:.75rem 1rem}.node-action-menu-title{color:#faf7f0;font-size:.95rem;font-weight:700;font-family:var(--font-manrope),sans-serif;margin-bottom:.15rem}.node-action-menu-subtitle{color:#c9a961cc;font-size:.7rem;font-family:var(--font-manrope),sans-serif}.node-action-menu-divider{background:#c9a96126;height:1px}.node-action-menu-items{padding:.4rem}.node-action-menu-item{width:100%;font-size:.85rem;font-weight:600;font-family:var(--font-manrope),sans-serif;color:#1a1a1a;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.65rem;padding:.65rem .85rem;transition:background .15s;display:flex}.node-action-menu-item:hover{background:#2d5a3d14}.node-action-menu-item:active{background:#2d5a3d1f}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;animation:.2s ease-out overlayFadeIn;display:flex;position:fixed;inset:0}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fffdf5;border:2px solid #c9a9614d;border-radius:16px;flex-direction:column;width:100%;max-width:600px;max-height:90vh;animation:.3s ease-out modalSlideIn;display:flex;box-shadow:0 20px 60px #0000004d}.modal-content-sm{max-width:450px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{background:linear-gradient(135deg,#1a3a2e,#2d5a3d);border-bottom:2px solid #c9a9614d;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-title{color:#faf7f0;font-size:1.25rem;font-weight:700;font-family:var(--font-manrope),sans-serif;margin:0}.modal-close{color:#faf7f0;cursor:pointer;background:#ffffff1f;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .2s;display:flex}.modal-close:hover{background:#ffffff40}.modal-form{flex-direction:column;flex:1;min-height:0;display:flex}.modal-body{flex:1;padding:1.25rem;overflow-y:auto}.modal-footer{background:#f0ead4;border-top:1px solid #c9a96133;flex-shrink:0;justify-content:flex-end;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.form-section{margin-bottom:1.5rem}.form-section:last-child{margin-bottom:0}.form-section-title{text-transform:uppercase;letter-spacing:.05em;color:#2d5a3d;font-size:.85rem;font-weight:700;font-family:var(--font-manrope),sans-serif;border-bottom:2px solid #2d5a3d26;margin-bottom:.75rem;padding-bottom:.4rem}.form-field{margin-bottom:1rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}.form-label{color:#1a3a2e;font-size:.8rem;font-weight:600;font-family:var(--font-manrope),sans-serif;margin-bottom:.4rem;display:block}.form-required{color:#c82333;margin-left:.2rem}.form-input{width:100%;font-size:.9rem;font-family:var(--font-manrope),sans-serif;color:#1a1a1a;background:#fff;border:1.5px solid #2d5a3d33;border-radius:8px;padding:.65rem .85rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:#2d5a3d;outline:none;box-shadow:0 0 0 3px #2d5a3d1a}.form-input-error{border-color:#c82333}.form-input-error:focus{box-shadow:0 0 0 3px #c823331a}.form-error{color:#c82333;font-size:.75rem;font-family:var(--font-manrope),sans-serif;margin-top:.3rem}.form-hint{color:#888;font-size:.75rem;font-family:var(--font-manrope),sans-serif;margin-top:.3rem;font-style:italic}.btn{font-size:.9rem;font-weight:700;font-family:var(--font-manrope),sans-serif;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.5rem;padding:.65rem 1.25rem;transition:all .2s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#2d5a3d,#3a7a4f);box-shadow:0 2px 8px #2d5a3d4d}.btn-primary:hover{background:linear-gradient(135deg,#3a7a4f,#2d5a3d);transform:translateY(-1px);box-shadow:0 4px 12px #2d5a3d66}.btn-secondary{color:#1a3a2e;background:#f0ead4;border:1.5px solid #2d5a3d33}.btn-secondary:hover{background:#e8e0c4;border-color:#2d5a3d4d}.btn-danger{color:#fff;background:linear-gradient(135deg,#c82333,#dc3545);box-shadow:0 2px 8px #c823334d}.btn-danger:hover{background:linear-gradient(135deg,#dc3545,#c82333);transform:translateY(-1px);box-shadow:0 4px 12px #c8233366}.delete-confirm-content{padding:.5rem 0}.delete-confirm-message{color:#1a1a1a;font-size:1rem;font-family:var(--font-manrope),sans-serif;margin-bottom:1rem;line-height:1.5}.delete-confirm-details{background:#2d5a3d0d;border-radius:8px;margin-bottom:1rem;padding:.75rem}.delete-confirm-detail{font-family:var(--font-manrope),sans-serif;justify-content:space-between;padding:.4rem 0;display:flex}.delete-confirm-label{color:#2d5a3d;font-size:.85rem;font-weight:600}.delete-confirm-value{color:#1a1a1a;font-size:.85rem;font-weight:500}.delete-confirm-warning{color:#c82333;font-size:.85rem;font-family:var(--font-manrope),sans-serif;background:#c8233314;border-left:3px solid #c82333;border-radius:6px;align-items:flex-start;gap:.5rem;padding:.75rem;line-height:1.4;display:flex}.node-action-menu{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform-origin:0 0;background:#fffffff5;border:1px solid #d4af374d;border-radius:14px;min-width:190px;padding:6px 0;animation:.2s cubic-bezier(.16,1,.3,1) menuIn;box-shadow:0 16px 48px #0000002e,0 2px 8px #00000014}@keyframes menuIn{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.node-action-menu-header{background:#2d5a3d0a;padding:.8rem 1.1rem}.node-action-menu-title{color:#1a3a2e;font-size:.95rem;font-weight:800;font-family:var(--font-manrope),sans-serif;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.node-action-menu-subtitle{color:#8b6f47;text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:600;font-family:var(--font-manrope),sans-serif}.node-action-menu-divider{background:#d4af3726;height:1px;margin:4px 0}.node-action-menu-items{flex-direction:column;display:flex}.node-action-menu-item{text-align:left;color:#333;cursor:pointer;width:100%;font-size:.88rem;font-weight:600;font-family:var(--font-manrope),sans-serif;background:0 0;border:none;align-items:center;gap:.8rem;padding:.75rem 1.1rem;transition:all .2s;display:flex}.node-action-menu-item:hover{color:#1a3a2e;background:#2d5a3d14;padding-left:1.35rem}.node-action-menu-item svg{transition:transform .2s}.node-action-menu-item:hover svg{transform:scale(1.15)}@media (max-width:640px){.modal-content{border-radius:0;max-width:100%;max-height:100vh}.form-row{grid-template-columns:1fr}}
