@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap");:root{--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--gray-950:#020617;--accent-50:#eef2ff;--accent-100:#e0e7ff;--accent-200:#c7d2fe;--accent-400:#818cf8;--accent-500:#6366f1;--accent-600:#4f46e5;--accent-700:#4338ca;--brand-500:#10b981;--brand-600:#059669;--success-50:#ecfdf5;--success-400:#34d399;--success-500:#10b981;--success-600:#059669;--danger-50:#fff1f2;--danger-400:#fb7185;--danger-500:#f43f5e;--danger-600:#e11d48;--warning-50:#fffbeb;--warning-400:#fbbf24;--warning-500:#f59e0b;--info-50:#eff6ff;--info-400:#60a5fa;--info-500:#3b82f6;--bg-base:var(--gray-50);--bg-surface:#fff;--bg-surface-hover:var(--gray-100);--bg-elevated:#fff;--bg-inset:var(--gray-100);--bg-overlay:rgba(15,23,42,.45);--glass-bg:hsla(0,0%,100%,.72);--glass-border:hsla(0,0%,100%,.35);--glass-blur:20px;--text-primary:var(--gray-900);--text-secondary:var(--gray-500);--text-tertiary:var(--gray-400);--text-on-accent:#fff;--border-default:var(--gray-200);--border-subtle:var(--gray-100);--border-accent:var(--accent-200);--shadow-xs:0 1px 2px rgba(0,0,0,.04);--shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.06),0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.06),0 4px 6px -4px rgba(0,0,0,.04);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.08),0 8px 10px -6px rgba(0,0,0,.04);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1);--nav-height:64px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}[data-theme=dark]{--bg-base:var(--gray-950);--bg-surface:var(--gray-900);--bg-surface-hover:var(--gray-800);--bg-elevated:var(--gray-800);--bg-inset:var(--gray-800);--bg-overlay:rgba(0,0,0,.6);--glass-bg:rgba(15,23,42,.72);--glass-border:rgba(51,65,85,.5);--text-primary:var(--gray-50);--text-secondary:var(--gray-400);--text-tertiary:var(--gray-500);--border-default:var(--gray-700);--border-subtle:var(--gray-800);--border-accent:var(--accent-700);--shadow-xs:0 1px 2px rgba(0,0,0,.2);--shadow-sm:0 1px 3px rgba(0,0,0,.25),0 1px 2px rgba(0,0,0,.2);--shadow-md:0 4px 6px -1px rgba(0,0,0,.25),0 2px 4px -2px rgba(0,0,0,.2);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.3),0 4px 6px -4px rgba(0,0,0,.2);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.35),0 8px 10px -6px rgba(0,0,0,.2)}*,:after,:before{margin:0;padding:0;box-sizing:border-box}*{scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}[data-theme=dark] *{scrollbar-color:var(--gray-600) transparent}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--gray-600)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--bg-base);color:var(--text-primary);min-height:100vh;display:flex;flex-direction:column;line-height:1.6;font-size:.9375rem;overflow-x:hidden}main{flex:1 1;padding:2rem 0}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;color:var(--text-primary);letter-spacing:-.01em}h1{font-size:2rem}h2{font-size:1.375rem}h3{font-size:1.125rem}p{color:var(--text-secondary)}a{color:var(--accent-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-600)}.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.gnav{position:-webkit-sticky;position:sticky;top:0;z-index:100;height:var(--nav-height);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.gnav,.gnav-inner{display:flex;align-items:center}.gnav-inner{justify-content:space-between;width:100%;gap:1.5rem}.brand{font-size:1.35rem;font-weight:800;margin:0;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem;text-decoration:none}.brand,.brand:hover{color:var(--text-primary)}.brand-logo{color:var(--accent-500);flex-shrink:0}[data-theme=dark] .brand-logo{color:var(--accent-300);filter:invert(1) sepia(1) saturate(2) hue-rotate(200deg) brightness(1.1)}.brand-text{font-family:"Space Grotesk",var(--font-sans);font-weight:700;font-size:1.25rem;letter-spacing:-.03em}.brand-accent{color:var(--brand-500)}[data-theme=dark] .brand-accent{color:var(--success-400)}.gnav-links{display:flex;list-style:none;gap:.15rem;align-items:center}.gnav-item{position:relative}.gnav-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary);text-decoration:none;padding:.45rem .75rem;border-radius:var(--radius-sm);font-size:.84rem;font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;font-family:inherit;white-space:nowrap}.gnav-link:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.gnav-link--active{color:var(--accent-600);background:var(--accent-50)}[data-theme=dark] .gnav-link--active{color:var(--accent-200);background:rgba(99,102,241,.12)}.gnav-link-icon{display:flex;align-items:center;flex-shrink:0;opacity:.7}.gnav-link--active .gnav-link-icon{opacity:1}.gnav-dropdown,.gnav-dropdown-trigger{position:relative}.gnav-dropdown-chevron{display:flex;transition:transform var(--transition-fast);margin-left:.1rem}.gnav-dropdown-chevron--open{transform:rotate(180deg)}.gnav-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:210px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.35rem;list-style:none;z-index:120;animation:gnav-dropdown-in var(--transition-fast) forwards}@keyframes gnav-dropdown-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.gnav-dropdown-item{display:flex;align-items:center;gap:.55rem;padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.84rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast)}.gnav-dropdown-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.gnav-dropdown-item--active{color:var(--accent-600);background:var(--accent-50)}[data-theme=dark] .gnav-dropdown-item--active{color:var(--accent-200);background:rgba(99,102,241,.12)}.gnav-dropdown-item-icon{display:flex;align-items:center;opacity:.65}.gnav-dropdown-item--active .gnav-dropdown-item-icon{opacity:1}.gnav-right,.gnav-user{display:flex;align-items:center;gap:.5rem}.gnav-user-name{font-size:.8rem;font-weight:600;color:var(--text-secondary);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gnav-signout-btn,.gnav-theme-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.gnav-signout-btn:hover,.gnav-theme-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.gnav-signout-btn:hover{border-color:var(--danger-400);color:var(--danger-500)}.gnav-hamburger{display:none;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.gnav-hamburger:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.gnav-mobile-overlay{position:fixed;inset:0;z-index:200;background:var(--bg-overlay);animation:gnav-fade-in var(--transition-fast) forwards}@keyframes gnav-fade-in{0%{opacity:0}to{opacity:1}}.gnav-mobile-panel{position:absolute;top:0;right:0;width:300px;max-width:85vw;height:100%;background:var(--bg-surface);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;animation:gnav-slide-in var(--transition-base) forwards}@keyframes gnav-slide-in{0%{transform:translateX(100%)}to{transform:translateX(0)}}.gnav-mobile-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-default)}.gnav-mobile-title{font-family:"Space Grotesk",var(--font-sans);font-size:1rem;font-weight:700;color:var(--text-primary)}.gnav-mobile-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.gnav-mobile-close:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.gnav-mobile-list{list-style:none;padding:.5rem .75rem;flex:1 1;overflow-y:auto}.gnav-mobile-link{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--text-secondary);text-decoration:none;cursor:pointer;border:none;background:none;width:100%;font-family:inherit;transition:all var(--transition-fast)}.gnav-mobile-link:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.gnav-mobile-link--active{color:var(--accent-600);background:var(--accent-50)}[data-theme=dark] .gnav-mobile-link--active{color:var(--accent-200);background:rgba(99,102,241,.12)}.gnav-mobile-link-icon{display:flex;align-items:center;opacity:.7}.gnav-mobile-link--active .gnav-mobile-link-icon{opacity:1}.gnav-mobile-group-trigger{position:relative}.gnav-mobile-chevron{display:flex;margin-left:auto;transition:transform var(--transition-fast)}.gnav-mobile-chevron--open{transform:rotate(180deg)}.gnav-mobile-sublist{list-style:none;padding:.15rem 0 .15rem 1rem;border-left:2px solid var(--border-default);margin-left:1.5rem}.gnav-mobile-sublink{font-size:.85rem}.tree-context{margin-top:0;margin-bottom:1.5rem}.tree-context-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:.75rem 1.25rem;box-shadow:var(--shadow-xs)}.tree-context-title{color:var(--text-secondary);font-size:.875rem}.tree-context-title strong{color:var(--text-primary);font-weight:600}.tree-context-actions{display:flex;align-items:center;gap:.75rem}.tree-context-actions select{min-width:240px;padding:.5rem .75rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary);font-size:.875rem;font-family:var(--font-sans);transition:border-color var(--transition-fast)}.tree-context-actions select:focus{outline:none;border-color:var(--accent-400);box-shadow:0 0 0 3px rgba(99,102,241,.12)}.footer{border-top:1px solid var(--border-subtle);color:var(--text-tertiary);text-align:center;margin-top:3rem;font-size:.8125rem}.card,.footer{background:var(--bg-surface);padding:1.5rem}.card{border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);margin-bottom:1.5rem;transition:box-shadow var(--transition-base),border-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card h2{margin-top:0;margin-bottom:.75rem;font-size:1.125rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1.125rem;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;font-weight:500;font-family:var(--font-sans);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap;line-height:1.5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-500);color:var(--text-on-accent);border-color:var(--accent-500)}.btn-primary:hover:not(:disabled){background:var(--accent-600);border-color:var(--accent-600);box-shadow:0 2px 8px rgba(99,102,241,.3)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--gray-300)}.btn-danger{color:var(--text-on-accent);border-color:var(--danger-500)}.btn-danger:hover:not(:disabled){background:var(--danger-600);border-color:var(--danger-600);box-shadow:0 2px 8px rgba(244,63,94,.3)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--text-primary)}.btn-group{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-fast);font-size:.875rem}.btn-icon:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--gray-300)}.btn-icon.danger:hover{background:var(--danger-50);color:var(--danger-500);border-color:var(--danger-400)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.375rem;font-weight:500;font-size:.8125rem;color:var(--text-secondary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-surface);transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-400);box-shadow:0 0 0 3px rgba(99,102,241,.12)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-tertiary)}.table{width:100%;border-collapse:collapse;background:var(--bg-surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-default)}.table thead{background:var(--bg-inset)}.table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-default)}.table td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-subtle)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-surface-hover)}.table tbody tr:last-child td{border-bottom:none}.grid{display:grid;grid-gap:1.25rem;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.export-grid{align-items:stretch;grid-template-columns:repeat(2,1fr)}.export-card{display:flex;flex-direction:column;height:100%}.export-card-action{margin-top:auto;padding-top:1rem}.export-page h1{margin-bottom:.5rem}.export-cards-section{margin-top:1rem;margin-bottom:2rem}@media (max-width:600px){.export-grid{grid-template-columns:1fr}}.export-summary-section{margin-top:.5rem}.share-admin-notice{background:var(--warning-50);border:1px solid var(--warning-400);border-radius:var(--radius-sm);padding:.5rem .75rem;margin:.5rem 0;font-size:.8125rem;color:var(--gray-700)}[data-theme=dark] .share-admin-notice{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.3);color:var(--warning-400)}.share-links-list{margin-top:.75rem;display:grid;grid-gap:.375rem;gap:.375rem}.share-links-heading{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.25rem}.share-link-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.375rem .5rem;background:var(--bg-inset);border-radius:var(--radius-sm);font-size:.8125rem}.share-link-info{display:flex;align-items:center;gap:.375rem;min-width:0}.share-link-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.share-link-dot.active{background:var(--success-500)}.share-link-dot.revoked{background:var(--danger-400)}.share-link-label{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-link-truncate{font-family:monospace;font-size:.75rem}.share-link-actions{display:flex;gap:.25rem;flex-shrink:0}.share-links-revoked{opacity:.7}.btn-xs{padding:.2rem .5rem;font-size:.6875rem;border-radius:var(--radius-sm)}.btn-danger{background:var(--danger-500);color:#fff;border:none;cursor:pointer}.btn-danger:hover{background:var(--danger-600)}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:1.25rem;gap:1.25rem}.alert{padding:.875rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem}.alert-success{background:var(--success-50);color:var(--success-600);border:1px solid rgba(16,185,129,.2)}.alert-error{background:var(--danger-50);color:var(--danger-600);border:1px solid rgba(244,63,94,.2)}.alert-info{background:var(--info-50);color:var(--info-500);border:1px solid rgba(59,130,246,.2)}.stat-card{position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:1.5rem;background:var(--bg-surface);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-accent)}.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1rem}.stat-card-value{font-size:2.25rem;font-weight:800;letter-spacing:-.02em;line-height:1;margin-bottom:.25rem}.stat-card-label{font-size:.8125rem;color:var(--text-secondary);margin-bottom:1rem}.dashboard-detail-grid{display:grid;grid-template-columns:100px 1fr;grid-gap:.5rem 1rem;gap:.5rem 1rem;font-size:.9375rem}.dashboard-detail-label{color:var(--text-tertiary);font-weight:500;font-size:.8125rem}.dashboard-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1rem;gap:1rem}@media (max-width:640px){.dashboard-actions-grid{grid-template-columns:1fr}}.dashboard-action-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;transition:all var(--transition-base)}.dashboard-action-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-accent);transform:translateY(-2px);color:inherit}.dashboard-action-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-action-body{flex:1 1;min-width:0}.dashboard-action-title{font-weight:600;font-size:.875rem;color:var(--text-primary);margin-bottom:.125rem}.dashboard-action-stat{font-size:1.75rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;color:var(--text-primary)}.dashboard-action-desc{font-size:.8125rem;color:var(--text-tertiary);margin-top:.25rem}.people-overview-grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:1fr;align-items:stretch;grid-auto-rows:1fr}@media (min-width:640px){.people-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:960px){.people-overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1200px){.people-overview-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.people-card{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);padding:1rem 1.125rem;display:flex;flex-direction:column;gap:.75rem;position:relative;transition:all var(--transition-base)}.people-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-accent)}.people-card-icon-stack{position:absolute;top:10px;right:10px;display:flex;gap:.3rem;z-index:1}.people-card-delete{border:1px solid var(--border-default);background:var(--bg-surface);border-radius:var(--radius-sm);padding:.25rem .4rem;cursor:pointer;line-height:1;color:var(--text-tertiary);transition:all var(--transition-fast);font-size:.8rem}.people-card-delete:hover{background:var(--danger-50);border-color:var(--danger-400);color:var(--danger-500)}.people-card-edit-icon{border:1px solid var(--border-default);background:var(--bg-surface);border-radius:var(--radius-sm);padding:.25rem .4rem;cursor:pointer;line-height:1;color:var(--text-tertiary);transition:all var(--transition-fast);font-size:.8rem}.people-card-edit-icon:hover{background:var(--accent-50);border-color:var(--accent-400);color:var(--accent-500)}.people-card-header{display:flex;align-items:center;gap:.875rem}.people-card-avatar{width:52px;height:52px;border-radius:var(--radius-full);overflow:hidden;flex:0 0 52px;background:var(--bg-inset)}.people-card-avatar-img{width:100%;height:100%;object-fit:cover}.people-card-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.15rem}.people-card-title{flex:1 1;min-width:0}.people-card-name{font-weight:700;color:var(--text-primary);font-size:.9375rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.people-card-subtitle{margin-top:.25rem;font-size:.8125rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.people-card-dot,.people-card-muted{color:var(--text-tertiary)}.people-card-tags{display:flex;flex-wrap:wrap;gap:.4rem;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.people-tag{font-size:.75rem;padding:.25rem .5rem;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.people-chip,.people-tag{border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-inset);color:var(--text-secondary)}.people-chip{font-size:.6875rem;padding:.15rem .4rem;text-transform:capitalize;font-weight:500}.people-chip-married{border-color:rgba(99,102,241,.3);background:rgba(99,102,241,.08);color:var(--accent-600)}.people-chip-coparent{border-color:rgba(148,163,184,.4);background:rgba(148,163,184,.08)}.people-chip-single{border-color:rgba(100,116,139,.2);background:rgba(100,116,139,.06)}.people-chip-alive{border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.08);color:var(--success-600)}.people-chip-deceased{border-color:rgba(244,63,94,.3);background:rgba(244,63,94,.08);color:var(--danger-500)}.people-chip-unknown{border-color:rgba(148,163,184,.4);background:rgba(148,163,184,.08)}.people-card-details{border-top:1px solid var(--border-subtle);padding-top:.625rem;display:flex;flex-direction:column;gap:.35rem}.people-card-detail-row{display:grid;grid-template-columns:72px 1fr;grid-gap:.5rem;gap:.5rem;font-size:.8125rem}.people-card-detail-label{color:var(--text-tertiary);font-weight:600}.people-card-detail-value{color:var(--text-primary)}.people-card-actions{display:flex;gap:.5rem;margin-top:auto}.people-overview-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.people-overview-toolbar{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1rem 1.25rem;border:1px solid var(--border-default);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.people-overview-toolbar-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.people-overview-search{flex:1 1}.people-overview-search-input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-surface);transition:all var(--transition-fast)}.people-overview-search-input::placeholder{color:var(--text-tertiary)}.people-overview-search-input:focus{outline:none;border-color:var(--accent-400);box-shadow:0 0 0 3px rgba(99,102,241,.12)}.people-overview-summary{font-weight:600;font-size:.8125rem;color:var(--text-secondary);padding:.375rem .75rem;background:var(--bg-inset);border-radius:var(--radius-full);border:1px solid var(--border-default);white-space:nowrap}.people-overview-filters{display:grid;grid-template-columns:1fr;grid-gap:.75rem;gap:.75rem}@media (min-width:640px){.people-overview-filters{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:960px){.people-overview-filters{grid-template-columns:repeat(5,minmax(0,1fr))}}.people-overview-filter{display:flex;flex-direction:column;gap:.25rem;font-size:.8125rem;color:var(--text-secondary)}.people-overview-filter select{width:100%;padding:.5rem .75rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--text-primary);font-size:.8125rem;font-family:var(--font-sans);transition:all var(--transition-fast)}.people-overview-filter select:focus{outline:none;border-color:var(--accent-400);box-shadow:0 0 0 3px rgba(99,102,241,.12)}.people-list{display:flex;flex-direction:column;gap:1rem}.person-row{gap:1rem}.person-row,.person-row-avatar{display:flex;align-items:center}.person-row-avatar{width:56px;height:56px;border-radius:var(--radius-full);overflow:hidden;flex:0 0 56px;background:var(--bg-inset);justify-content:center}.person-row-avatar-img{width:100%;height:100%;object-fit:cover}.person-row-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.3rem}.person-row-details{flex:1 1;min-width:0}.person-row-name{font-weight:700;color:var(--text-primary)}.person-row-meta{margin-top:.15rem;font-size:.8125rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.people-tree,.person-row-actions{display:flex;gap:.5rem}.people-tree{flex-direction:column}.people-tree-node{border-radius:var(--radius-sm)}.people-tree-summary{list-style:none;display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-surface);box-shadow:var(--shadow-xs);cursor:pointer;transition:all var(--transition-fast)}.people-tree-summary:hover{background:var(--bg-surface-hover)}.people-tree-summary::-webkit-details-marker{display:none}.people-tree-avatar{width:40px;height:40px;border-radius:var(--radius-full);overflow:hidden;flex:0 0 40px;background:var(--bg-inset);display:flex;align-items:center;justify-content:center}.people-tree-avatar-img{width:100%;height:100%;object-fit:cover}.people-tree-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800}.people-tree-title{font-weight:700;color:var(--text-primary);flex:1 1;min-width:0;font-size:.875rem}.people-tree-actions{display:flex;gap:.35rem}.people-tree-children{margin-top:.35rem}.people-card{cursor:pointer;height:320px}.people-card-mini-summary{font-size:.75rem;color:var(--text-secondary);display:flex;flex-direction:column;gap:.15rem;line-height:1.4}.people-card-mini-row{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.people-card-mini-label{font-weight:600;color:var(--text-tertiary);margin-right:.25rem}.people-tag-badge{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.1);color:#b45309}.people-tag-warn{border-color:rgba(244,63,94,.3);background:rgba(244,63,94,.08);color:var(--danger-500)}.people-tag-info{border-color:rgba(59,130,246,.3);background:rgba(59,130,246,.08);color:#2563eb}.people-card-quick-actions{display:flex;flex-wrap:wrap;gap:.3rem}.btn-quick{font-size:.6875rem;padding:.2rem .45rem;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;font-family:var(--font-sans);font-weight:500;transition:all var(--transition-fast);line-height:1.3}.btn-quick:hover{background:var(--accent-50);border-color:var(--accent-400);color:var(--accent-600)}.people-card-avatar{position:relative}.people-card-photo-popout{position:absolute;top:-110px;left:50%;transform:translateX(-50%);z-index:50;width:160px;height:160px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid var(--border-accent);pointer-events:none;animation:fadeIn .15s ease-out}.people-card-photo-popout img{width:100%;height:100%;object-fit:cover}.person-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:300;display:flex;justify-content:flex-end;animation:fadeIn .15s ease-out}.person-drawer{width:min(420px,90vw);height:100vh;background:var(--bg-surface);border-left:1px solid var(--border-default);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideInRight .2s ease-out}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.person-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-default)}.person-drawer-title{font-size:1rem;font-weight:700;margin:0;color:var(--text-primary)}.person-drawer-close{background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--text-tertiary);padding:.25rem;line-height:1}.person-drawer-close:hover{color:var(--text-primary)}.person-drawer-body{flex:1 1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.person-drawer-identity{text-align:center}.person-drawer-avatar{width:80px;height:80px;border-radius:var(--radius-full);overflow:hidden;margin:0 auto .75rem}.person-drawer-avatar-img{width:100%;height:100%;object-fit:cover}.person-drawer-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.5rem}.person-drawer-identity h3{font-size:1.125rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary)}.person-drawer-chips{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center}.person-drawer-section h4{font-size:.8125rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .5rem}.person-drawer-dl{display:grid;grid-template-columns:auto 1fr;grid-gap:.25rem .75rem;gap:.25rem .75rem;font-size:.8125rem}.person-drawer-dl dt{font-weight:600;color:var(--text-tertiary)}.person-drawer-dl dd,.person-drawer-list{margin:0;color:var(--text-primary)}.person-drawer-list{list-style:none;padding:0;font-size:.8125rem;display:flex;flex-direction:column;gap:.25rem}.person-drawer-list li{padding:.25rem 0}.person-drawer-detail,.person-drawer-sublabel{color:var(--text-tertiary);font-size:.75rem}.person-drawer-sublabel{font-weight:600;margin:.5rem 0 .25rem}.person-drawer-footer{display:flex;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--border-default)}.tree-highlight-ring,.tree-person-highlight{animation:treeHighlightPulse .5s ease-in-out 6}@keyframes treeHighlightPulse{0%,to{opacity:1}50%{opacity:.3}}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:200;animation:fadeIn .15s ease-out}.modal-panel{width:min(1000px,100%);max-height:calc(100vh - 2rem);overflow:auto;animation:slideUp .2s ease-out}.modal-panel .card{margin-bottom:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.tree-container{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1rem;border:1px solid var(--border-default);box-shadow:var(--shadow-sm);overflow:auto;margin-bottom:1.5rem}.tree-container>svg{display:block;margin:0 auto}.tree-pan{cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.tree-pan.is-panning{cursor:-webkit-grabbing;cursor:grabbing}.tree-toolbar{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.tree-zoom-label{min-width:56px;text-align:center;font-weight:600;font-size:.8125rem;color:var(--text-secondary)}.tree-svg{min-width:100%;width:auto}.page-header{margin-bottom:1.5rem}.page-header h1{margin-bottom:.25rem}.page-header p{font-size:.9375rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-secondary)}.empty-state-icon{font-size:2.5rem;margin-bottom:.75rem}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.hidden{display:none}.modal-content{background:var(--bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:min(520px,100%);max-height:calc(100vh - 2rem);overflow:hidden;display:flex;flex-direction:column;animation:slideUp .2s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-default)}.modal-header h2{font-size:1.125rem;margin:0}.modal-close{font-size:1.25rem;padding:.25rem}.modal-body{padding:1.25rem 1.5rem;overflow-y:auto;flex:1 1}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--border-default)}.export-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.export-error{background:var(--danger-50);color:var(--danger-600);border-radius:var(--radius-md);padding:.625rem .875rem;font-size:.8125rem;margin-bottom:1rem}.export-mode-selector{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-bottom:1rem}.export-mode-option{display:flex;align-items:flex-start;gap:.75rem;background:var(--bg-surface);border:2px solid var(--border-default);border-radius:var(--radius-md);padding:1rem;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.export-mode-option:hover{border-color:var(--accent-400);background:var(--accent-50)}.export-mode-option.active{border-color:var(--accent-500);background:var(--accent-50)}.export-mode-icon{font-size:1.5rem;flex-shrink:0}.export-mode-label{display:flex;flex-direction:column;gap:.125rem}.export-mode-label strong{font-size:.875rem}.export-mode-label small{font-size:.75rem;color:var(--text-tertiary)}.export-branch-section{border-top:1px solid var(--border-subtle);padding-top:1rem;margin-top:.25rem}.export-branch-section h3{font-size:.875rem;font-weight:600;margin-bottom:.625rem}.root-child-picker{list-style:none;padding:0;margin:0;display:grid;grid-gap:.375rem;gap:.375rem;max-height:240px;overflow-y:auto}.root-child-picker li{margin:0}.root-child-item{display:flex;align-items:center;gap:.625rem;width:100%;padding:.625rem .875rem;background:var(--bg-surface);border:1.5px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s,background .15s;font-size:.875rem;text-align:left}.root-child-item:hover{border-color:var(--accent-400);background:var(--bg-surface-hover)}.root-child-item.selected{border-color:var(--accent-500);background:var(--accent-50)}.root-child-icon{font-size:1.125rem}.root-child-name{flex:1 1;font-weight:500}.root-child-check{color:var(--accent-500);font-weight:700}.root-child-picker-empty,.root-child-picker-loading{font-size:.8125rem;color:var(--text-tertiary);text-align:center;padding:1rem}@media (max-width:768px){.gnav-links{display:none}.gnav-hamburger{display:flex}.gnav-user-name{display:none}.grid{grid-template-columns:1fr}.gnav .container{position:relative}.tree-context-inner{flex-direction:column;align-items:flex-start}.tree-context-actions{width:100%;flex-direction:column;align-items:stretch}.tree-context-actions select{min-width:0;width:100%}.table{font-size:.8125rem}.table td,.table th{padding:.625rem .75rem}.people-overview-header{flex-direction:column;align-items:flex-start}}.auth-page{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:2rem 1rem}.auth-card{width:100%;max-width:420px;padding:2rem}.auth-card h2{margin-bottom:.25rem;text-align:center}.auth-subtitle{margin-bottom:1.5rem}.auth-footer,.auth-subtitle{text-align:center;color:var(--text-secondary)}.auth-footer{margin-top:1.25rem;font-size:.875rem}.auth-footer a{color:var(--accent-500);text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.btn-block{width:100%}.role-badge{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.role-owner{background:var(--accent-100);color:var(--accent-700)}.role-admin{background:var(--warning-50,#fffbeb);color:var(--warning-600,#d97706)}.role-editor{background:var(--success-50);color:var(--success-600,#16a34a)}.role-viewer{background:var(--gray-100);color:var(--gray-600)}.members-table{width:100%;border-collapse:collapse;margin-top:.75rem}.members-table td,.members-table th{text-align:left;padding:.625rem .75rem;border-bottom:1px solid var(--border-default)}.members-table th{font-weight:600;font-size:.8125rem;color:var(--text-secondary)}.members-table select{padding:.25rem .5rem;font-size:.8125rem}.invite-form{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.invite-form .form-group{flex:1 1;min-width:180px;margin-bottom:0}.invite-form .btn{margin-bottom:0;white-space:nowrap;height:42px}.rel-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap}.rel-page-title{font-size:1.75rem;font-weight:700;font-family:"Space Grotesk",var(--font-family);margin:0 0 .25rem}.rel-page-subtitle{color:var(--text-secondary);font-size:.92rem;margin:0}.rel-top-actions{display:flex;gap:.75rem;flex-wrap:wrap}.rel-action-btn{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.88rem;padding:.5rem 1rem;border-radius:8px}.rel-action-btn-alt{background:var(--primary-light,#e0e7ff);color:var(--primary);border:1.5px solid var(--primary)}.rel-action-btn-alt:hover{background:var(--primary);color:#fff}.rel-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1.5rem;gap:1.5rem;align-items:start}@media (max-width:900px){.rel-grid{grid-template-columns:1fr}}.rel-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 1px 4px rgba(0,0,0,.04);overflow:hidden}.rel-card-header{padding:1.25rem 1.25rem .75rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem}.rel-card-title{display:flex;align-items:center;gap:.5rem}.rel-card-title h3{margin:0;font-size:1.08rem;font-weight:700;font-family:"Space Grotesk",var(--font-family)}.rel-card-count{background:var(--bg-secondary,#f1f5f9);color:var(--text-secondary);font-size:.78rem;font-weight:600;padding:.15rem .55rem;border-radius:99px}.rel-card-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;flex-shrink:0}.rel-card-icon-marriage{background:#fce7f3;color:#db2777}.rel-card-icon-parentchild{background:#e0e7ff;color:var(--primary,#4f46e5)}.rel-card-controls{display:flex;gap:.5rem;flex-wrap:wrap}.rel-card-body{padding:.5rem 0;max-height:600px;overflow-y:auto}.rel-search-bar{position:relative;flex:1 1;min-width:160px}.rel-search-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--text-secondary);display:flex}.rel-search-input{width:100%;padding:.45rem .6rem .45rem 2rem;border:1px solid var(--border);border-radius:8px;font-size:.85rem;background:var(--bg);color:var(--text);transition:border-color .15s}.rel-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(79,70,229,.12)}.rel-filter-bar{display:flex;align-items:center;gap:.35rem;color:var(--text-secondary)}.rel-filter-icon{display:flex}.rel-filter-select{padding:.4rem .6rem;border:1px solid var(--border);border-radius:8px;font-size:.82rem;background:var(--bg);color:var(--text);cursor:pointer}.rel-chip-row{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-bottom:1px solid var(--border);flex-wrap:wrap;transition:background .12s}.rel-chip-row:last-child{border-bottom:none}.rel-chip-row:hover{background:var(--bg-secondary,#f8fafc)}.rel-chip{display:inline-flex;align-items:center;gap:.5rem;flex:1 1;min-width:0;cursor:pointer}.rel-chip-person{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.rel-chip-connector{color:#db2777;font-size:1rem;flex-shrink:0}.rel-chip-arrow{color:var(--primary,#4f46e5);font-weight:700;font-size:1rem;flex-shrink:0}.rel-chip-date{color:var(--text-secondary);font-size:.78rem;margin-left:auto;white-space:nowrap}.rel-chip-expand{display:flex;transition:transform .2s;color:var(--text-secondary)}.rel-chip-expand.open{transform:rotate(180deg)}.rel-chip-parent{color:var(--primary,#4f46e5)}.rel-chip-child{color:#6366f1}.rel-chip-person-1{color:#be185d}.rel-chip-person-2{color:#db2777}.rel-type-badge{font-size:.72rem;font-weight:600;padding:.12rem .5rem;border-radius:99px;text-transform:capitalize;flex-shrink:0}.rel-type-mother{background:#fce7f3;color:#be185d}.rel-type-father{background:#e0e7ff;color:#4338ca}.rel-type-parent{background:#ecfdf5;color:#059669}.rel-type-biological{background:#fef3c7;color:#b45309}.rel-chip-actions{display:flex;gap:.35rem;flex-shrink:0}.rel-btn-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-secondary);cursor:pointer;transition:all .12s}.rel-btn-icon:hover{background:var(--primary-light,#e0e7ff);color:var(--primary);border-color:var(--primary)}.rel-btn-icon-danger:hover{background:#fef2f2;color:#dc2626;border-color:#dc2626}.rel-preview{width:100%;padding:.75rem 1rem;margin-top:.25rem;background:var(--bg-secondary,#f8fafc);border-radius:8px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.82rem;line-height:1.6}.rel-preview-couple{font-weight:600;color:#db2777;margin-bottom:.15rem}.rel-preview-tree{padding-left:1rem;border-left:2px solid var(--border)}.rel-preview-child{color:var(--primary,#4f46e5)}.rel-empty{padding:2rem 1.25rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.rel-empty-state{text-align:center;padding:5rem 2rem}.rel-empty-state h2{font-family:"Space Grotesk",var(--font-family);margin-bottom:.5rem}.rel-loading{text-align:center;padding:4rem 1rem;color:var(--text-secondary);font-size:.95rem}.rel-dialog-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.rel-dialog{background:var(--card-bg);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.18);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.rel-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem 1rem;border-bottom:1px solid var(--border)}.rel-dialog-title{display:flex;align-items:center;gap:.5rem}.rel-dialog-title h3{margin:0;font-size:1.05rem;font-weight:700;font-family:"Space Grotesk",var(--font-family)}.rel-dialog-body{padding:1.25rem 1.5rem}.rel-dialog-step-label{font-size:.82rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 1rem}.rel-dialog-preview{display:flex;align-items:center;gap:.75rem;justify-content:center;padding:1rem;background:var(--bg-secondary,#f8fafc);border-radius:10px;margin-bottom:1.25rem;font-weight:600;font-size:.95rem}.rel-dialog-fields{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-bottom:1.25rem}.rel-field-full{grid-column:1/-1}.rel-dialog-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.rel-dialog-error{padding:.65rem 1.5rem;background:#fef2f2;color:#dc2626;font-size:.85rem;border-bottom:1px solid #fecaca}.rel-field{display:flex;flex-direction:column;gap:.3rem}.rel-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.rel-input{padding:.5rem .7rem;border:1px solid var(--border);border-radius:8px;font-size:.88rem;background:var(--bg);color:var(--text);font-family:inherit}.rel-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(79,70,229,.12)}.rel-person-select{position:relative;margin-bottom:.75rem}.rel-person-select-trigger{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:.88rem;background:var(--bg);color:var(--text);transition:border-color .15s}.rel-person-select-trigger:hover{border-color:var(--primary)}.rel-placeholder{color:var(--text-secondary)}.rel-person-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 6px 24px rgba(0,0,0,.12);z-index:50;overflow:hidden}.rel-person-select-search{width:100%;padding:.55rem .75rem;border:none;border-bottom:1px solid var(--border);font-size:.85rem;background:transparent;color:var(--text)}.rel-person-select-search:focus{outline:none}.rel-person-select-list{list-style:none;margin:0;padding:0;max-height:200px;overflow-y:auto}.rel-person-select-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;cursor:pointer;font-size:.88rem;transition:background .1s}.rel-person-select-item:hover{background:var(--bg-secondary,#f8fafc)}.rel-person-select-item.selected{background:var(--primary-light,#e0e7ff);font-weight:600}.rel-person-select-empty{padding:1rem;text-align:center;color:var(--text-secondary);font-size:.85rem}.rel-gender-badge{font-size:.75rem;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700}.rel-gender-female{background:#fce7f3;color:#be185d}.rel-gender-male{background:#e0e7ff;color:#4338ca}.rel-gender-other{background:#f1f5f9;color:#64748b}[data-theme=dark] .rel-card-icon-marriage{background:#831843;color:#f9a8d4}[data-theme=dark] .rel-card-icon-parentchild{background:#312e81;color:#a5b4fc}[data-theme=dark] .rel-type-mother{background:#831843;color:#f9a8d4}[data-theme=dark] .rel-type-father{background:#312e81;color:#a5b4fc}[data-theme=dark] .rel-type-parent{background:#064e3b;color:#6ee7b7}[data-theme=dark] .rel-type-biological{background:#78350f;color:#fde68a}[data-theme=dark] .rel-chip-row:hover{background:hsla(0,0%,100%,.03)}[data-theme=dark] .rel-dialog-preview,[data-theme=dark] .rel-preview{background:hsla(0,0%,100%,.04)}[data-theme=dark] .rel-dialog-error{background:#450a0a;color:#fca5a5;border-color:#7f1d1d}[data-theme=dark] .rel-gender-female{background:#831843;color:#f9a8d4}[data-theme=dark] .rel-gender-male{background:#312e81;color:#a5b4fc}[data-theme=dark] .rel-gender-other{background:#1e293b;color:#94a3b8}[data-theme=dark] .rel-action-btn-alt{background:#312e81;color:#a5b4fc;border-color:#4f46e5}[data-theme=dark] .rel-action-btn-alt:hover{background:#4f46e5;color:#fff}[data-theme=dark] .rel-person-select-item:hover{background:hsla(0,0%,100%,.05)}[data-theme=dark] .rel-person-select-item.selected{background:rgba(79,70,229,.2)}.admin-shell{width:100vw;max-width:100vw;margin-left:calc(-50vw + 50%);min-height:calc(100vh - var(--nav-height) - 80px)}.admin-nav{background:var(--bg-surface);border-bottom:1px solid var(--border-default);box-shadow:var(--shadow-xs)}.admin-nav-inner{display:flex;align-items:center;gap:1.5rem;height:48px}.admin-nav-title{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.875rem;color:var(--text-primary);white-space:nowrap;padding-right:1rem;border-right:1px solid var(--border-default)}.admin-nav-links{display:flex;align-items:center;gap:.25rem;overflow-x:auto}.admin-nav-link{display:flex;align-items:center;gap:.4rem;padding:.375rem .75rem;font-size:.8125rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-sm);white-space:nowrap;transition:all var(--transition-fast)}.admin-nav-link:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.admin-nav-link.active{color:var(--accent-500);background:var(--accent-50)}[data-theme=dark] .admin-nav-link.active{background:rgba(99,102,241,.1)}.admin-main{padding:2rem 0}.admin-page-header{margin-bottom:1.5rem}.admin-page-header h1{font-size:1.5rem;margin-bottom:.25rem}.admin-page-header p{color:var(--text-secondary);font-size:.875rem}.admin-loading{display:flex;justify-content:center;padding:3rem 0}.admin-loading-spinner{width:32px;height:32px;border:3px solid var(--border-default);border-top-color:var(--accent-500);border-radius:50%;animation:admin-spin .6s linear infinite}@keyframes admin-spin{to{transform:rotate(1turn)}}.admin-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1rem;gap:1rem;margin-bottom:2rem}.admin-stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-fast)}.admin-stat-card:hover{box-shadow:var(--shadow-md)}.admin-stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-inset);flex-shrink:0}.admin-stat-info{display:flex;flex-direction:column}.admin-stat-value{font-size:1.5rem;font-weight:700;line-height:1.2;color:var(--text-primary)}.admin-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.admin-charts-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.admin-chart-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:1.25rem;box-shadow:var(--shadow-xs)}.admin-chart-card h3{font-size:.9375rem;margin-bottom:1rem}.admin-bar-chart{display:flex;flex-direction:column;gap:.625rem}.admin-bar-row{display:flex;align-items:center;gap:.75rem}.admin-bar-label{width:70px;font-size:.8125rem;color:var(--text-secondary);text-align:right;flex-shrink:0}.admin-bar-track{flex:1 1;height:8px;background:var(--bg-inset);border-radius:var(--radius-full);overflow:hidden}.admin-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease;min-width:2px}.admin-bar-value{width:32px;font-size:.8125rem;font-weight:600;color:var(--text-primary)}.admin-toolbar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.admin-search{padding:.5rem .75rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.875rem;background:var(--bg-surface);color:var(--text-primary);min-width:260px}.admin-search:focus{outline:none;border-color:var(--accent-400);box-shadow:0 0 0 3px rgba(99,102,241,.15)}.admin-table-wrap{overflow-x:auto;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-xs)}.admin-table{width:100%;border-collapse:collapse;font-size:.8125rem}.admin-table th{text-align:left;padding:.75rem 1rem;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);border-bottom:1px solid var(--border-default);background:var(--bg-inset);white-space:nowrap}.admin-table td{padding:.625rem 1rem;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:var(--bg-surface-hover)}.admin-row-banned{opacity:.6}.admin-td-name{font-weight:600;color:var(--text-primary)}.admin-td-date{font-size:.8125rem}.admin-td-date,.admin-td-detail{white-space:nowrap;color:var(--text-secondary)}.admin-td-detail{max-width:400px;overflow:hidden;text-overflow:ellipsis}.admin-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.admin-badge-admin{background:var(--accent-50);color:var(--accent-600)}.admin-badge-user{background:var(--gray-100);color:var(--gray-600)}.admin-badge-active{background:var(--success-50);color:var(--success-600)}.admin-badge-banned{background:var(--danger-50);color:var(--danger-600)}[data-theme=dark] .admin-badge-admin{background:rgba(99,102,241,.15);color:var(--accent-400)}[data-theme=dark] .admin-badge-user{background:hsla(0,0%,100%,.06);color:var(--gray-400)}[data-theme=dark] .admin-badge-active{background:rgba(16,185,129,.12);color:var(--success-400)}[data-theme=dark] .admin-badge-banned{background:rgba(244,63,94,.12);color:var(--danger-400)}.admin-audit-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-full);font-size:.6875rem;font-weight:600;color:#fff;text-transform:uppercase}.admin-tree-chips{display:flex;flex-wrap:wrap;gap:.25rem}.admin-tree-chip{display:inline-block;padding:.1rem .4rem;background:var(--bg-inset);border-radius:var(--radius-sm);font-size:.75rem;color:var(--text-secondary)}.admin-tree-chip small{opacity:.7}.admin-muted{color:var(--text-tertiary);font-size:.8125rem}.admin-actions{display:flex;gap:.375rem;flex-wrap:wrap;align-items:center}.admin-btn{padding:.25rem .625rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;cursor:pointer;background:var(--bg-surface);color:var(--text-primary);transition:all var(--transition-fast)}.admin-btn:hover{background:var(--bg-surface-hover)}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn-accent{background:var(--accent-500);color:#fff;border-color:var(--accent-500)}.admin-btn-accent:hover{background:var(--accent-600)}.admin-btn-success{background:var(--success-500);color:#fff;border-color:var(--success-500)}.admin-btn-success:hover{background:var(--success-600)}.admin-btn-warn{background:var(--warning-500);color:#fff;border-color:var(--warning-500)}.admin-btn-warn:hover{background:var(--warning-400)}.admin-btn-danger{background:var(--danger-500);color:#fff;border-color:var(--danger-500)}.admin-btn-danger:hover{background:var(--danger-600)}.admin-btn-outline{background:transparent;color:var(--accent-500);border-color:var(--accent-200)}.admin-btn-outline:hover{background:var(--accent-50)}[data-theme=dark] .admin-btn-outline:hover{background:rgba(99,102,241,.1)}.admin-transfer-row{display:flex;gap:.375rem;align-items:center}.admin-select-sm{padding:.25rem .5rem;border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.75rem;background:var(--bg-surface);color:var(--text-primary);max-width:180px}@media (max-width:768px){.admin-nav-title{display:none}.admin-nav-inner{gap:0}.admin-main{padding:1rem 0}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-charts-row{grid-template-columns:1fr}}.lang-switcher{position:relative}.lang-switcher-trigger{display:inline-flex;align-items:center;gap:.3rem;height:34px;padding:0 .55rem;border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-secondary);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.lang-switcher-trigger:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.lang-flag{width:16px;height:16px;border-radius:2px;object-fit:cover;flex-shrink:0}.lang-code{font-size:.75rem;letter-spacing:.03em}.lang-chevron{width:10px;height:10px;opacity:.6;transition:transform var(--transition-fast)}.lang-switcher-trigger[aria-expanded=true] .lang-chevron{transform:rotate(180deg)}.lang-switcher-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:100;list-style:none;margin:0;padding:4px;min-width:100%;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);box-shadow:0 4px 16px rgba(0,0,0,.12)}.lang-switcher-option{display:flex;align-items:center;gap:.4rem;width:100%;padding:.35rem .55rem;border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.lang-switcher-option:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.lang-switcher-option.active{background:var(--accent-50);color:var(--accent-600);font-weight:600}[data-theme=dark] .lang-switcher-option.active{background:rgba(99,102,241,.15);color:var(--accent-400)}.share-viewer{max-width:1400px;margin:0 auto;padding:1.5rem 1rem}.share-header{text-align:center;margin-bottom:1.5rem}.share-header-top{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.25rem}.share-tree-name{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.share-subtitle{font-size:.875rem;color:var(--text-tertiary);margin-bottom:.75rem}.share-stats{display:flex;justify-content:center;gap:1.5rem;font-size:.8125rem;color:var(--text-secondary)}.share-tabs{display:flex;gap:.5rem;margin-bottom:1rem;border-bottom:1px solid var(--border-default);padding-bottom:0}.share-tab{padding:.5rem 1.25rem;background:none;font-size:.9375rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast)}.share-tab:hover{color:var(--text-primary)}.share-tab-active{color:var(--accent-600);border-bottom-color:var(--accent-500)}[data-theme=dark] .share-tab-active{color:var(--accent-400);border-bottom-color:var(--accent-400)}.share-tree-container{position:relative}.share-tree-toolbar{display:flex;gap:.5rem;margin-bottom:.5rem}.share-people-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:1rem;gap:1rem}.share-person-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;cursor:pointer;transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.share-person-card:hover{border-color:var(--accent-200);box-shadow:var(--shadow-md)}.share-filter-bar{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem;padding:1rem;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg)}.share-filter-row{display:flex;align-items:center;gap:.75rem}.share-filter-search{flex:1 1;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-inset);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast)}.share-filter-search:focus{border-color:var(--accent-400);box-shadow:0 0 0 2px rgba(99,102,241,.15)}.share-filter-count{font-size:.75rem;color:var(--text-tertiary);white-space:nowrap;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.share-filter-selects{display:flex;flex-wrap:wrap;gap:.5rem}.share-filter-label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;color:var(--text-tertiary);min-width:0}.share-filter-label span{font-weight:600;text-transform:uppercase;letter-spacing:.03em}.share-filter-label select{padding:.35rem .5rem;font-size:.8125rem;border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-inset);color:var(--text-primary);cursor:pointer}.share-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:300;display:flex;justify-content:flex-end;animation:fadeIn .15s ease-out}.share-drawer{width:min(420px,90vw);height:100vh;background:var(--bg-surface);border-left:1px solid var(--border-default);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideInRight .2s ease-out}.share-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-default)}.share-drawer-header h2{font-size:1rem;font-weight:700;margin:0;color:var(--text-primary)}.share-drawer-close{background:none;border:none;cursor:pointer;font-size:1.25rem;color:var(--text-tertiary);padding:.25rem;line-height:1}.share-drawer-close:hover{color:var(--text-primary)}.share-drawer-body{flex:1 1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.share-drawer-identity{text-align:center}.share-drawer-identity h3{font-size:1.125rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary)}.share-drawer-avatar{width:80px;height:80px;border-radius:var(--radius-full);overflow:hidden;margin:0 auto .75rem}.share-drawer-avatar-img{width:100%;height:100%;object-fit:cover}.share-drawer-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.5rem}.share-drawer-chips{display:flex;flex-wrap:wrap;gap:.35rem;justify-content:center}.share-drawer-section h4{font-size:.8125rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .5rem}.share-drawer-dl{display:grid;grid-template-columns:auto 1fr;grid-gap:.25rem .75rem;gap:.25rem .75rem;font-size:.8125rem}.share-drawer-dl dt{font-weight:600;color:var(--text-tertiary)}.share-drawer-dl dd,.share-drawer-list{margin:0;color:var(--text-primary)}.share-drawer-list{list-style:none;padding:0;font-size:.8125rem;display:flex;flex-direction:column;gap:.25rem}.share-drawer-list li{padding:.25rem 0}.share-drawer-detail{color:var(--text-tertiary);font-size:.75rem}.share-person-photo{flex-shrink:0;width:48px;height:48px;border-radius:50%;overflow:hidden}.share-person-img{width:100%;height:100%;object-fit:cover}.share-person-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.125rem}.share-person-info{min-width:0}.share-person-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-deceased-marker{color:var(--text-tertiary)}.share-person-detail{font-size:.75rem;color:var(--text-secondary);margin-top:.125rem}.share-footer{text-align:center;padding:2rem 0 1rem;font-size:.75rem;color:var(--text-tertiary)}@media (max-width:640px){.share-viewer{padding:1rem .5rem}.share-header-top{flex-direction:column;gap:.5rem}.share-tree-name{font-size:1.25rem}.share-stats{flex-wrap:wrap;gap:.75rem}.share-tabs{gap:0}.share-tab{flex:1 1;text-align:center;padding:.5rem;font-size:.8125rem}.share-filter-bar{padding:.75rem}.share-filter-selects{flex-direction:column}.share-filter-label{flex-direction:row;align-items:center;gap:.5rem}.share-filter-label select{flex:1 1}.share-people-grid{grid-template-columns:1fr;gap:.5rem}.share-drawer{width:100vw}.share-tree-toolbar{justify-content:center}}