@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--glass-bg-primary: rgba(255, 255, 255, .72);--glass-bg-secondary: rgba(255, 255, 255, .45);--glass-border: rgba(255, 255, 255, .65);--glass-border-light: rgba(255, 255, 255, .35);--glass-shadow: 0 1px 3px rgba(0, 0, 0, .04), 0 6px 20px rgba(0, 0, 0, .05), inset 0 1px 0 rgba(255,255,255,.8);--glass-shadow-hover: 0 4px 10px rgba(0, 0, 0, .07), 0 16px 32px rgba(0, 0, 0, .07), inset 0 1px 0 rgba(255,255,255,.9);--glass-blur: blur(28px) saturate(180%);--glass-blur-sm: blur(14px) saturate(150%);--theme-bg-gradient: radial-gradient(at 0% 0%, hsla(248, 80%, 94%, 1) 0, transparent 55%), radial-gradient(at 100% 0%, hsla(280, 65%, 95%, 1) 0, transparent 55%), radial-gradient(at 50% 30%, hsla(220, 60%, 97%, 1) 0, transparent 45%), radial-gradient(at 0% 100%, hsla(210, 50%, 95%, 1) 0, transparent 50%), radial-gradient(at 100% 100%, hsla(259, 55%, 96%, 1) 0, transparent 50%), #f4f6ff}@media(prefers-color-scheme:dark){:root{--glass-bg-primary: rgba(17, 24, 45, .72);--glass-bg-secondary: rgba(28, 36, 64, .52);--glass-border: rgba(255, 255, 255, .1);--glass-border-light: rgba(255, 255, 255, .05);--glass-shadow: 0 8px 32px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.06);--glass-shadow-hover: 0 16px 48px rgba(0,0,0,.65), 0 0 0 1px rgba(99,102,241,.2);--theme-bg-gradient: radial-gradient(at 0% 0%, hsla(253, 65%, 13%, 1) 0, transparent 55%), radial-gradient(at 100% 0%, hsla(280, 60%, 11%, 1) 0, transparent 55%), radial-gradient(at 50% 40%, hsla(230, 55%, 10%, 1) 0, transparent 45%), radial-gradient(at 0% 100%, hsla(200, 45%, 09%, 1) 0, transparent 50%), radial-gradient(at 100% 100%, hsla(260, 60%, 08%, 1) 0, transparent 50%), #03030c}}body{background:var(--theme-bg-gradient);background-attachment:fixed;background-size:cover;transition:background var(--ease-md)}@media(max-width:768px){body{background-attachment:scroll;background-size:auto}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#6366f12e;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#6366f161}*{scrollbar-width:thin;scrollbar-color:rgba(99,102,241,.2) transparent}.glass-panel{background:var(--glass-bg-primary);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-xl)}@keyframes glass-shine{0%{background-position:200% center}to{background-position:-200% center}}:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: rgba(99, 102, 241, .1);--secondary: #ec4899;--secondary-hover: #db2777;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--danger-light: rgba(239, 68, 68, .1);--hover-neutral: rgba(0, 0, 0, .055);--hover-neutral-dark: rgba(0, 0, 0, .09);--bg: #f8fafc;--bg-card: #ffffff;--surface: #ffffff;--surface-raised: #f1f5f9;--text: #0f172a;--text-muted: #475569;--border: #e2e8f0;--font: "Inter", system-ui, -apple-system, sans-serif;--max-width: 1200px;--nav-height: 68px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--ease: .15s ease-in-out;--ease-md: .3s ease-in-out}@media(prefers-color-scheme:dark){:root{--bg: #0f172a;--bg-card: #1e293b;--surface: #1e293b;--surface-raised: #334155;--text: #f8fafc;--text-muted: #cbd5e1;--border: #334155}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}body{font-family:inherit;color:inherit;line-height:inherit;overflow-x:clip;max-width:100vw}a{text-decoration:none;color:inherit}ul{list-style:none}button{cursor:pointer;font-family:inherit;border:none;background:none}img{max-width:100%;border-radius:var(--radius-md);height:auto;display:block}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1.25rem}main{min-height:calc(100vh - var(--nav-height));padding-top:var(--nav-height);animation:page-enter .38s cubic-bezier(.16,1,.3,1) both}.page-loading{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--nav-height));font-size:1.1rem;color:var(--text-muted)}.dashboard-header{display:flex;align-items:center;gap:1rem;padding:2rem 0 1rem}.dashboard-header h1{font-size:1.8rem;font-weight:800}.dashboard-header p{color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;padding-bottom:3rem}@media(min-width:768px){.dashboard-grid.two-cols{grid-template-columns:repeat(2,1fr)}.dashboard-grid.three-cols{grid-template-columns:repeat(3,1fr)}}@media(min-width:1100px){.dashboard-grid.sidebar-layout{grid-template-columns:340px 1fr}}.expandable-list{display:flex;flex-direction:column;gap:.75rem}.list-item{border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);transition:all var(--ease);overflow:hidden}.list-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.list-item.expanded{border-color:var(--primary)}.list-item-header{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1.1rem;cursor:pointer;gap:.75rem}.list-item-header:hover{background:var(--primary-light)}.list-item-body{padding:1rem 1.1rem 1.1rem;border-top:1px solid var(--border);background:#00000005}.stat-card{background:var(--glass-bg-primary);backdrop-filter:var(--glass-blur-sm);-webkit-backdrop-filter:var(--glass-blur-sm);border-radius:var(--radius-xl);padding:1.5rem;border:1px solid var(--glass-border);display:flex;flex-direction:column;justify-content:space-between;gap:.5rem;height:100%;box-shadow:var(--glass-shadow);transition:transform var(--ease-md),box-shadow var(--ease-md)}.stat-card:hover{box-shadow:var(--glass-shadow-hover);transform:translateY(-2px)}.stat-card .stat-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-card .stat-value{font-size:2rem;font-weight:800;color:var(--text)}.stat-card .stat-sub{font-size:.85rem;color:var(--text-muted)}@media(max-width:640px){.card,.modal-card{padding:1.25rem}.btn{padding:.6rem 1rem;font-size:.875rem}.dashboard-header h1{font-size:1.4rem}.dashboard-header{flex-wrap:wrap;gap:.5rem;padding:1.25rem 0 .75rem;align-items:flex-start}.dashboard-header>svg:first-child{display:none}.dashboard-header>div:first-of-type{flex:1 1 100%}.dashboard-header>div:last-of-type{margin-left:0;flex:1 1 auto;display:flex;justify-content:flex-end;gap:.4rem}.hide-on-mobile{display:none!important}.dashboard-grid.three-cols{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:.5rem}.dashboard-grid.three-cols .stat-card{padding:.75rem .5rem;height:auto;min-height:80px}.dashboard-grid.three-cols .stat-card .stat-label{font-size:.65rem}.dashboard-grid.three-cols .stat-card .stat-value{font-size:1.25rem}.dashboard-grid.three-cols .stat-card .stat-sub{font-size:.65rem}.kpi-row{grid-template-columns:repeat(2,1fr)!important}.list-item-header{padding:.75rem .875rem}.list-item-header>div:first-child{min-width:0;flex:1 1 0%}.list-item-header>div:last-child{flex-shrink:0}.member-filter-bar{flex-direction:column;align-items:stretch}.member-filter-bar>div:first-child{width:100%;flex:none}.member-filter-bar-buttons{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.list-item-body .member-detail-grid{grid-template-columns:repeat(2,1fr)!important;gap:.5rem 1rem}.modal-body{padding:1rem 1.25rem 1.5rem}.modal-card>form{padding:1rem 1.25rem 1.5rem}.modal-header{padding:1rem 1.25rem}}@media(max-width:480px){.dashboard-grid.three-cols{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:.4rem}.dashboard-grid.three-cols .stat-card{padding:.6rem .4rem}.dashboard-grid.three-cols .stat-card .stat-label{font-size:.6rem;letter-spacing:0}.dashboard-grid.three-cols .stat-card .stat-value{font-size:1.15rem}.kpi-overview-card{padding:.875rem!important}.kpi-overview-card span[style*="1.6rem"]{font-size:1.2rem!important}}details{border-radius:var(--radius-md);transition:all var(--ease-md)}details summary{transition:all var(--ease);padding:.5rem;border-radius:var(--radius-md);-webkit-user-select:none;user-select:none}details summary:hover{background:var(--surface-raised);color:var(--primary)}details[open] summary{margin-bottom:.5rem;color:var(--primary)}details[open] summary span:first-child{transform:rotate(90deg);transition:transform var(--ease)}details summary span:first-child{display:inline-block;transition:transform var(--ease)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton{background:var(--border);border-radius:var(--radius-sm);animation:pulse 1.5s cubic-bezier(.4,0,.6,1) infinite}.skeleton-text{height:1.25rem;margin-bottom:.5rem}.skeleton-title{height:2rem;width:40%;margin-bottom:.5rem}.skeleton-avatar{border-radius:50%;width:3rem;height:3rem}.skeleton-card{border-radius:var(--radius-xl);height:15rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-weight:600;font-size:.925rem;transition:all .22s cubic-bezier(.4,0,.2,1);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;box-shadow:0 1px 3px #6366f159,0 1px 2px #00000012,inset 0 1px #ffffff26;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);transition:left .5s ease;pointer-events:none}.btn-primary:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 6px 20px #6366f17a,0 1px 3px #00000014;transform:translateY(-1px)}.btn-primary:hover:before{left:155%}.btn-primary:active:not(:disabled){transform:scale(.97)!important;box-shadow:0 2px 8px #6366f159!important}.btn-secondary{background:#6366f112;color:var(--primary);border:1.5px solid rgba(99,102,241,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-secondary:hover{background:#6366f124;border-color:#6366f180;box-shadow:0 0 16px #6366f129;color:var(--primary-hover);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover{filter:brightness(.9);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--surface-raised);color:var(--text)}.btn-sm{padding:.38rem .85rem;font-size:.83rem}.btn-lg{padding:.85rem 2rem;font-size:1.05rem}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;filter:none!important}.btn:active:not(:disabled){transform:scale(.97) translateY(0)!important;transition-duration:.08s!important}.btn:focus{outline:none}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:3px;box-shadow:0 0 0 4px #6366f12e}.btn-sm{min-width:fit-content}.btn{text-overflow:ellipsis;overflow:hidden}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}label{font-weight:500;font-size:.875rem;color:var(--text-muted)}.form-input,select.form-input{padding:.7rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--glass-bg-secondary, rgba(255,255,255,.6));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text);font-size:.95rem;font-family:inherit;transition:border-color var(--ease),box-shadow var(--ease),background var(--ease);width:100%}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f12e,0 1px 3px #0000000f;background:var(--surface)}.form-input:hover:not(:focus):not([readonly]){border-color:#6366f166}.card{background:var(--glass-bg-primary);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow);padding:1.75rem;border:1px solid var(--glass-border);transition:transform .28s cubic-bezier(.34,1.46,.64,1),box-shadow .28s ease,border-color .2s ease;position:relative}.card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-xl);background:linear-gradient(180deg,rgba(255,255,255,.55) 0%,transparent 40%);pointer-events:none;opacity:.6}.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}@keyframes kpi-card-in{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.kpi-overview-card{--card-accent: var(--primary);animation:kpi-card-in .42s cubic-bezier(.16,1,.3,1) both;transition:transform .3s cubic-bezier(.34,1.46,.64,1),box-shadow .3s cubic-bezier(.34,1.46,.64,1),border-color .25s ease;position:relative;overflow:hidden;cursor:pointer;border-bottom:2px solid transparent}.kpi-overview-card:nth-child(1){animation-delay:.03s}.kpi-overview-card:nth-child(2){animation-delay:.07s}.kpi-overview-card:nth-child(3){animation-delay:.11s}.kpi-overview-card:nth-child(4){animation-delay:.15s}.kpi-overview-card:nth-child(5){animation-delay:.19s}.kpi-overview-card:nth-child(6){animation-delay:.23s}.kpi-overview-card:hover{transform:translateY(-6px) scale(1.015);box-shadow:0 20px 44px #0000001c,0 0 0 1.5px color-mix(in srgb,var(--card-accent) 38%,transparent);border-bottom-color:var(--card-accent)}.kpi-overview-card:after{content:"";position:absolute;top:0;left:-120%;width:55%;height:2px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--card-accent) 70%,white),transparent);transition:left .55s cubic-bezier(.4,0,.2,1);pointer-events:none}.kpi-overview-card:hover:after{left:165%}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.card-header h2{font-size:1.1rem;font-weight:700;flex:1 1 auto}.card-header>div{flex-shrink:0}@media(max-width:640px){.card-header{flex-wrap:wrap;gap:.5rem}.card-header h2{flex:1 1 100%;margin-bottom:0}.card-header>div,.card-header>button,.card-header>select{flex:0 0 auto;margin-left:auto}}.auth-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--nav-height));padding:2rem 1rem}.auth-card{width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;color:var(--primary);margin-bottom:.4rem}.auth-header p{color:var(--text-muted)}.auth-error{background:var(--danger-light);color:var(--danger);padding:.9rem 1rem;border-radius:var(--radius-md);margin-bottom:1.25rem;font-size:.875rem;text-align:center}.auth-success{background:#10b9811a;color:var(--success);padding:.9rem 1rem;border-radius:var(--radius-md);margin-bottom:1.25rem;font-size:.875rem;text-align:center}.auth-footer{margin-top:1.5rem;text-align:center;color:var(--text-muted);font-size:.875rem}.auth-footer a{color:var(--primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.badge{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-success{background:#10b9811a;color:#065f46}.badge-warning{background:#f59e0b1a;color:#92400e}.badge-danger{background:#ef44441a;color:#991b1b}.badge-neutral{background:var(--surface-raised);color:var(--text-muted)}.status-active,.status-approved{background:#10b9811a;color:#065f46}.status-pending{background:#f59e0b1a;color:#92400e}.status-suspended,.status-inactive{background:#ef44441a;color:#991b1b}.role-admin{background:#ede9fe;color:#5b21b6}.role-secretary{background:#dbeafe;color:#1e40af}.role-trustee{background:#fef3c7;color:#92400e}.role-vicar{background:#d1fae5;color:#065f46}.role-member{background:var(--surface-raised);color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172aa6;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.modal-card{width:100%;max-width:520px;background:var(--surface);border-radius:var(--radius-xl);box-shadow:0 24px 60px #0000002e,0 8px 20px #00000014;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem 1.25rem;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.modal-header h3{font-size:1.1rem;font-weight:700}.modal-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem 2rem 2rem;scroll-behavior:smooth;overscroll-behavior:contain}.modal-body::-webkit-scrollbar{width:5px}.modal-body::-webkit-scrollbar-track{background:transparent}.modal-body::-webkit-scrollbar-thumb{background:#6366f126;border-radius:99px}.modal-body::-webkit-scrollbar-thumb:hover{background:#6366f14d}.modal-card>form,.modal-card>.modal-card-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem 2rem 2rem;overscroll-behavior:contain}.modal-card>form::-webkit-scrollbar{width:5px}.modal-card>form::-webkit-scrollbar-thumb{background:#6366f126;border-radius:99px}@keyframes page-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1}}.member-section-nav{margin:0 0 1.5rem;padding:.6rem .85rem;background:linear-gradient(135deg,#fff6,#f8fafc33);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border:1px solid rgba(255,255,255,.6);border-radius:16px;box-shadow:0 4px 16px #0000000d,inset 0 1px #fffc;display:flex;align-items:center;gap:.5rem;overflow-x:auto;scrollbar-width:none;position:relative}.member-section-nav:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:16px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 40%,rgba(255,255,255,.4) 50%,rgba(255,255,255,.2) 60%,transparent 100%);background-size:200% 100%;animation:nav-shimmer 6s linear infinite;pointer-events:none}@keyframes nav-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.member-section-nav::-webkit-scrollbar{display:none}@media(max-width:640px){.member-section-nav{margin:0 -1.25rem 1.5rem;border-radius:0;border-left:none;border-right:none}}@media(prefers-color-scheme:dark){.member-section-nav{background:linear-gradient(135deg,#1e293b99,#0f172a66);border-color:#ffffff1a}}.member-section-nav-link{flex-shrink:0;display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1.25rem;font-size:.85rem;font-weight:600;color:var(--text-muted);letter-spacing:-.01em;border:1px solid transparent;border-radius:12px;transition:all .3s cubic-bezier(.16,1,.3,1);cursor:pointer;white-space:nowrap;background:transparent;font-family:inherit;text-decoration:none;position:relative}.member-section-nav-link:hover{color:var(--text);background:#ffffff80;box-shadow:0 2px 8px #0000000a,inset 0 1px #fff9;transform:translateY(-2px)}.member-section-nav-link.snav-active{color:#fff;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,#8b5cf6 100%);border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 14px #6366f14d,inset 0 1px #fff3,inset 0 -2px #0000001a;text-shadow:0 1px 2px rgba(0,0,0,.1);transform:translateY(-2px)}.section-nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.05rem;height:1.05rem;padding:0 .18rem;border-radius:var(--radius-full);background:#ef4444;color:#fff;font-size:.58rem;font-weight:800;line-height:1;margin-left:.15rem;border:1.5px solid var(--surface, #fff)}.tab-panel-enter{animation:page-enter .3s cubic-bezier(.16,1,.3,1) both}.fg-tree-scroll{overflow:visible;padding:1.5rem 1rem .75rem}.fg-tree-wrap{display:flex;flex-direction:column;align-items:center;gap:0;min-width:max-content}.fg-row{display:flex;align-items:flex-start;gap:2.5rem}.fg-middle-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:0}.fg-siblings-col{display:flex;align-items:flex-start;justify-content:flex-end;gap:1.5rem}.fg-couple-wrap{display:flex;align-items:center;gap:0}.fg-vline{width:2px;height:48px;background:#cbd5e1;flex-shrink:0}.fg-hline{width:32px;height:2px;background:#cbd5e1;flex-shrink:0;align-self:flex-start;margin-top:35px}.fg-marriage-line{width:32px;height:2px;background:#a78bfa;flex-shrink:0}.fg-node{display:flex;flex-direction:column;align-items:center;gap:.3rem;position:relative;width:88px;cursor:pointer;animation:fg-node-in .3s cubic-bezier(.16,1,.3,1) both}@keyframes fg-node-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1}}.fg-avatar-wrap{position:relative;display:inline-flex;flex-shrink:0}.fg-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:800;letter-spacing:-.02em;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.fg-node:hover .fg-avatar{transform:scale(1.05);filter:drop-shadow(0 0 8px rgba(99,102,241,.2))}.fg-name{font-size:.72rem;font-weight:600;text-align:center;line-height:1.25;color:var(--text, #0f172a);width:84px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.2rem}.fg-badge{font-size:.58rem;font-weight:700;text-transform:capitalize;letter-spacing:.04em;padding:.1rem .4rem;border-radius:99px;white-space:nowrap;margin-top:.1rem}.fg-actions{position:absolute;top:-.35rem;right:-.9rem;display:flex;flex-direction:column;gap:.2rem;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:10}.fg-btn{width:1.5rem;height:1.5rem;border-radius:50%;border:1px solid rgba(0,0,0,.1);background:var(--surface, #fff);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted, #64748b);transition:background .15s,color .15s,transform .15s;box-shadow:0 2px 8px #0000001f;padding:0}.fg-btn:hover{background:var(--bg-light, #f1f5f9);color:var(--primary, #6366f1);transform:scale(1.15)}.fg-btn.fg-btn-danger:hover{color:var(--danger, #ef4444);background:#ef444414}.fg-household-dot{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:#fff;border:1px solid #E5E7EB;box-shadow:0 1px 4px #0000001f;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2;flex-shrink:0}.fg-overview-grid{display:grid;grid-template-columns:290px 1fr;gap:1.25rem;align-items:stretch}.fg-overview-grid>.card{box-sizing:border-box;overflow:visible}@media(max-width:800px){.fg-overview-grid{grid-template-columns:1fr}}@media(max-width:640px){.fg-overview-grid>.card{overflow:hidden;min-width:0;max-width:100%}.fg-overview-grid .card-header{flex-wrap:wrap;gap:.25rem}.fg-tree-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem;max-width:100%}}.fg-legend{display:flex;gap:1.25rem;flex-wrap:wrap;font-size:.8rem;font-weight:500;color:var(--text-muted);padding-bottom:.25rem;align-items:center}.fg-legend-item{display:flex;align-items:center;gap:.45rem}.fg-legend-dot{width:20px;height:20px;border-radius:50%;background:#fff;border:1px solid #E5E7EB;box-shadow:0 1px 4px #0000001a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fg-node-selected .fg-name{color:var(--primary, #6366f1);font-weight:700}.fg-detail-panel{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 2.25rem .75rem .85rem;background:var(--bg-light, #f8fafc);border:1.5px solid var(--border, #e2e8f0);border-radius:12px;position:relative;animation:page-enter .22s cubic-bezier(.16,1,.3,1) both}.fg-detail-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:800;flex-shrink:0;letter-spacing:-.02em}.fg-detail-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.35rem}.fg-detail-name{font-weight:700;font-size:.88rem;color:var(--text, #0f172a)}.fg-detail-chips{display:flex;flex-wrap:wrap;gap:.3rem}.fg-chip{font-size:.7rem;font-weight:600;padding:.15rem .55rem;border-radius:99px;background:var(--bg-light, #f1f5f9);color:var(--text-muted, #64748b);border:1px solid var(--border, #e2e8f0);white-space:nowrap}.fg-detail-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.35rem}.fg-action-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:600;padding:.35rem .65rem;border-radius:8px;border:1px solid transparent;transition:all .2s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 4px #0000000a,inset 0 1px #fff6}.fg-action-edit{background:linear-gradient(180deg,#fff,#f1f5f9);color:var(--primary, #6366f1);border-color:#cbd5e1}.fg-action-edit:hover{background:linear-gradient(180deg,#f8fafc,#e2e8f0);transform:translateY(-1px);box-shadow:0 4px 8px #0000000f,inset 0 1px #fffc}.fg-action-danger,.fg-action-warn{background:linear-gradient(180deg,#fef2f2,#fee2e2);color:#ef4444;border-color:#fca5a5}.fg-action-danger:hover,.fg-action-warn:hover{background:linear-gradient(180deg,#fee2e2,#fecaca);transform:translateY(-1px);box-shadow:0 4px 8px #ef444426,inset 0 1px #fffc}.fg-detail-close{position:absolute;top:.5rem;right:.5rem;width:1.6rem;height:1.6rem;border-radius:50%;border:1px solid var(--border, #e2e8f0);background:var(--surface, #fff);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-muted, #64748b);padding:0;transition:background .15s,color .15s}.fg-detail-close:hover{background:#ef444414;color:var(--danger, #ef4444);border-color:#ef44444d}.form-accordion{border:1px solid var(--border, #e2e8f0);border-radius:14px;margin-bottom:.6rem;background:var(--glass-bg-secondary, rgba(255,255,255,.38));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 2px 8px #0000000a,inset 0 1px #ffffff8c;transition:box-shadow .25s ease,border-color .25s ease;overflow:hidden}.form-accordion:focus-within{border-color:#6366f14d;box-shadow:0 0 0 3px #6366f114,0 4px 16px #0000000f}.form-accordion-summary{display:flex;align-items:center;width:100%;padding:.9rem 1.1rem;gap:.85rem;cursor:pointer;background:transparent;border:none;border-radius:14px;text-align:left;-webkit-user-select:none;user-select:none;transition:background .2s ease}.form-accordion-summary:hover{background:#6366f10e}.fa-step-num{flex-shrink:0;width:1.75rem;height:1.75rem;border-radius:50%;border:2px solid var(--border, #e2e8f0);background:var(--surface, #fff);color:var(--text-muted, #64748b);font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center;transition:border-color .22s ease,background .22s ease,color .22s ease,box-shadow .22s ease}.form-accordion-summary:hover .fa-step-num{border-color:var(--primary, #6366f1);color:var(--primary, #6366f1);box-shadow:0 0 0 3px #6366f11f}.fa-step-text{flex:1;min-width:0}.fa-step-title{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:700;color:var(--text, #0f172a);line-height:1.3}.fa-step-badge{font-size:.62rem;font-weight:600;padding:.1rem .45rem;border-radius:99px;background:var(--primary-light, rgba(99,102,241,.1));color:var(--primary, #6366f1);letter-spacing:.02em;text-transform:uppercase}.fa-step-sub{font-size:.73rem;color:var(--text-muted, #64748b);margin-top:.08rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.form-accordion-arrow{flex-shrink:0;color:var(--text-muted, #94a3b8);transition:transform .28s cubic-bezier(.4,0,.2,1),color .2s;display:block}.form-accordion-summary:hover .form-accordion-arrow{color:var(--primary, #6366f1)}.form-accordion-open>.form-accordion-summary{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px 14px 0 0}.form-accordion-open>.form-accordion-summary .fa-step-num{border-color:#ffffff80;background:#ffffff2e;color:#fff;box-shadow:none}.form-accordion-open>.form-accordion-summary .fa-step-title,.form-accordion-open>.form-accordion-summary .fa-step-sub{color:#fff}.form-accordion-open>.form-accordion-summary .fa-step-badge{background:#ffffff38;color:#fff}.form-accordion-open>.form-accordion-summary .form-accordion-arrow{transform:rotate(180deg);color:#ffffffd9}.form-accordion-open>.form-accordion-summary:hover{background:linear-gradient(135deg,#5558e8,#7c3aed)}.form-accordion-open{border-color:#6366f140;box-shadow:0 4px 20px #6366f11a,inset 0 1px #fff6}.form-accordion-body{display:flex;flex-direction:column;gap:.85rem;max-height:0;overflow:hidden;padding:0 1.25rem;background:var(--surface, #fff);border-top:0 solid transparent;transition:max-height .4s cubic-bezier(.16,1,.3,1),padding .38s cubic-bezier(.16,1,.3,1)}.form-accordion-open .form-accordion-body{max-height:1500px;padding:1.25rem}@media(prefers-color-scheme:dark){.form-accordion{background:#11182d8c;box-shadow:0 2px 8px #00000040,inset 0 1px #ffffff0f}.form-accordion-body,.fa-step-num{background:var(--bg-card, #1e293b)}}@media(max-width:640px){.form-accordion-body>div[style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}.form-accordion-summary{padding:.75rem .875rem;gap:.65rem}.form-accordion-open .form-accordion-body{padding:1rem}}.fg-popover{display:none!important}.carousel-arrow-sm{width:28px!important;height:28px!important;min-width:28px!important;min-height:28px!important;aspect-ratio:1!important;border-radius:50%!important;flex-shrink:0!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important}.event-carousel-compact{gap:.65rem;padding-bottom:.5rem;padding-left:0}.event-carousel-card-compact{min-width:155px;max-width:175px;border-radius:var(--radius-md, 10px);box-shadow:0 2px 6px #0000000f}.fg-popover{position:absolute;top:calc(100% + .4rem);left:50%;transform:translate(-50%);z-index:100;width:190px;background:var(--surface, #fff);border:1px solid rgba(99,102,241,.18);border-radius:10px;box-shadow:0 8px 32px #00000024,0 2px 8px #6366f11a;padding:.65rem .75rem .5rem;animation:page-enter .18s cubic-bezier(.16,1,.3,1) both}.fg-popover-name{font-weight:700;font-size:.85rem;color:var(--text, #0f172a);margin-bottom:.5rem;border-bottom:1px solid var(--border, #e2e8f0);padding-bottom:.4rem}.fg-popover-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;font-size:.75rem;padding:.2rem 0;color:var(--text-muted, #64748b)}.fg-popover-row span:first-child{flex-shrink:0}.fg-popover-actions{display:flex;gap:.4rem;margin-top:.6rem;padding-top:.5rem;border-top:1px solid var(--border, #e2e8f0)}.fg-pop-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.3rem .5rem;border-radius:6px;border:1px solid var(--border, #e2e8f0);background:var(--bg-light, #f8fafc);font-size:.72rem;font-weight:600;cursor:pointer;color:var(--text, #0f172a);transition:background .15s,color .15s}.fg-pop-btn:hover{background:#6366f114;color:var(--primary, #6366f1);border-color:#6366f14d}.fg-pop-btn.fg-pop-btn-danger:hover{background:#ef444414;color:var(--danger, #ef4444);border-color:#ef44444d}
