@import"https://fonts.googleapis.com/css2?family=Questrial&family=Source+Sans+Pro:wght@300;400;600;700&display=swap";#root{width:100%;min-height:100vh}:root{--bg-primary: #F5E8C7;--bg-secondary: #FAF7F0;--bg-alt: #FFFBF5;--primary: #D97706;--primary-dark: #C2410C;--primary-light: #F97316;--success: #4A7C59;--success-light: #10B981;--success-dark: #065F46;--ancestor: #EF4444;--ancestor-dark: #DC2626;--ancestor-light: #F87171;--text-primary: #1F2937;--text-secondary: #4B5563;--text-light: #6B7280;--accent-gold: #F59E0B;--accent-gold-light: #FCD34D;--border: #D1D5DB;--border-light: #E5E7EB;--border-dark: #9CA3AF;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--font-primary: "Questrial", "Source Sans Pro", system-ui, sans-serif;--font-size-h1: 32px;--font-size-h2: 24px;--font-size-h3: 20px;--font-size-body: 16px;--font-size-small: 14px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);font-size:var(--font-size-body);line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary);margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-h1);color:var(--primary-dark)}h2{font-size:var(--font-size-h2);color:var(--primary)}h3{font-size:var(--font-size-h3)}p{margin-bottom:var(--spacing-md);color:var(--text-secondary)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);font-family:var(--font-primary);font-size:var(--font-size-body);font-weight:600;text-align:center;border-radius:var(--radius-md);border:none;cursor:pointer;text-decoration:none;transition:all .2s ease;line-height:1.5}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover{background-color:var(--success-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-ancestor{background-color:var(--ancestor);color:#fff}.btn-ancestor:hover{background-color:var(--ancestor-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background-color:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background-color:var(--primary);color:#fff}.card{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);transition:box-shadow .2s ease}.card:hover{box-shadow:var(--shadow-md)}.form-control{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-family:var(--font-primary);font-size:var(--font-size-body);border:2px solid var(--border);border-radius:var(--radius-md);background-color:#fff;color:var(--text-primary);transition:border-color .2s ease}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #d977061a}.form-control:disabled{background-color:var(--bg-alt);cursor:not-allowed;opacity:.6}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:600;color:var(--text-primary);font-size:var(--font-size-small)}.form-label small{display:block;font-weight:400;color:var(--text-light);font-size:.875rem;margin-top:var(--spacing-xs)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid}.alert-info{background-color:#3b82f61a;border-color:#3b82f64d;color:#1e40af}.alert-danger{background-color:#ef44441a;border-color:#ef44444d;color:#991b1b}.alert-success{background-color:#10b9811a;border-color:#10b9814d;color:#065f46}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.table thead{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff}.table th{padding:var(--spacing-md);text-align:left;font-weight:600;font-size:var(--font-size-small);text-transform:uppercase;letter-spacing:.5px}.table td{padding:var(--spacing-md);border-bottom:1px solid var(--border-light);font-size:var(--font-size-body);vertical-align:middle}.table tbody tr:hover{background-color:#d977060d}.table tbody tr:last-child td{border-bottom:none}.badge-sexe{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-small);font-weight:600;text-transform:uppercase}.badge-sexe.H{background-color:#d9770633;color:var(--primary-dark)}.badge-sexe.F{background-color:#10b98133;color:var(--success-dark)}.mb-3{margin-bottom:var(--spacing-lg)}.text-center{text-align:center}.flex{display:flex}.justify-between{justify-content:space-between}.items-center{align-items:center}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.footer-modern{background:linear-gradient(180deg,#1a1a1a,#2d2d2d);border-top:1px solid rgba(255,255,255,.1);padding:4rem 0 2rem;margin-top:4rem;position:relative;overflow:hidden}.footer-modern:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(217,119,6,.5) 50%,transparent 100%)}.footer-container{max-width:1400px;margin:0 auto;padding:0 2rem;position:relative;z-index:1}.footer-content-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:3rem;margin-bottom:3rem}.footer-section-modern{display:flex;flex-direction:column}.footer-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.footer-brand-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.footer-brand-title{font-size:1.5rem;font-weight:700;color:#fff;margin:0;letter-spacing:-.5px}.footer-brand-tagline{font-size:1rem;font-weight:600;color:#d97706;margin:0 0 .5rem}.footer-brand-description{font-size:.875rem;color:#9ca3af;margin:0;line-height:1.6}.footer-section-title{font-size:1.125rem;font-weight:700;color:#fff;margin:0 0 1.25rem;position:relative;padding-bottom:.75rem}.footer-section-title:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:2px;background:linear-gradient(90deg,#d97706,#c2410c);border-radius:2px}.footer-agency{display:flex;flex-direction:column;gap:.5rem}.footer-agency-name{font-size:1rem;font-weight:600;color:#fff;margin:0}.footer-agency-desc{font-size:.875rem;color:#9ca3af;margin:0}.footer-links-modern{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.footer-link-modern{color:#9ca3af;font-size:.95rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-block;position:relative;padding-left:0}.footer-link-modern:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:0;height:2px;background:linear-gradient(90deg,#d97706,#c2410c);transition:width .3s ease;border-radius:2px}.footer-link-modern:hover{color:#fff;padding-left:12px;transform:translate(4px)}.footer-link-modern:hover:before{width:8px}.footer-tech-modern{display:flex;flex-wrap:wrap;gap:.75rem}.tech-badge-modern{display:inline-block;padding:.5rem 1rem;background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:.875rem;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tech-badge-modern:hover{background:#d9770633;border-color:#d9770680;transform:translateY(-2px);box-shadow:0 4px 12px #d977064d}.footer-bottom-modern{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;margin-top:2rem;text-align:center}.footer-bottom-links{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.footer-bottom-link{color:#9ca3af;font-size:.875rem;text-decoration:none;transition:color .3s ease}.footer-bottom-link:hover{color:#d97706}.footer-bottom-separator{color:#4b5563;font-size:.875rem}.footer-copyright{color:#6b7280;font-size:.875rem;margin:0;line-height:1.6}.footer-copyright-name{color:#d97706;font-weight:600}.footer-main{background-color:var(--bg-secondary);border-top:2px solid var(--border);padding:var(--spacing-2xl) 0 var(--spacing-lg);margin-top:var(--spacing-2xl)}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.footer-section h4{font-size:var(--font-size-h3);font-weight:700;margin-bottom:var(--spacing-md);color:var(--primary-dark)}.footer-links{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:var(--spacing-sm)}.footer-links a{color:var(--text-secondary);font-size:var(--font-size-small);transition:color .2s ease;text-decoration:none}.footer-links a:hover{color:var(--primary);text-decoration:underline}.footer-tech{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.tech-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--bg-primary);color:var(--primary-dark);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-size-small);font-weight:500}.footer-bottom{border-top:1px solid var(--border-light);padding-top:var(--spacing-lg);margin-top:var(--spacing-lg)}.navbar-modern{background:linear-gradient(180deg,#fff,#fafafa);border-bottom:1px solid rgba(0,0,0,.08);padding:0;box-shadow:0 2px 20px #0000000f;position:sticky;top:0;z-index:1000;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.navbar-container{max-width:1400px;margin:0 auto;padding:0 1rem;position:relative}.navbar-content{display:flex;justify-content:space-between;align-items:center;width:100%;position:relative;min-height:72px}.navbar-brand-modern{display:flex;align-items:center;gap:.75rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);padding:.5rem;border-radius:12px;margin-left:-.5rem}.navbar-brand-modern:hover{transform:translateY(-2px);background:#d977060d}.navbar-brand-icon{font-size:2rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform .3s ease}.navbar-brand-modern:hover .navbar-brand-icon{transform:scale(1.1) rotate(5deg)}.navbar-brand-text{display:flex;flex-direction:column;line-height:1.2}.navbar-brand-title{font-size:1.5rem;font-weight:700;color:#1a1a1a;letter-spacing:-.5px}.navbar-brand-subtitle{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.navbar-toggle-modern{display:flex;flex-direction:column;justify-content:space-around;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001;position:relative;transition:all .3s ease}.navbar-toggle-modern:hover{transform:scale(1.1)}.hamburger-line{display:block;height:3px;width:100%;background:linear-gradient(90deg,#d97706,#c2410c);border-radius:3px;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center}.navbar-toggle-modern.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(8px,8px);background:#1a1a1a}.navbar-toggle-modern.active .hamburger-line:nth-child(2){opacity:0;transform:translate(-10px)}.navbar-toggle-modern.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(8px,-8px);background:#1a1a1a}.navbar-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border-top:1px solid rgba(0,0,0,.08);box-shadow:0 8px 32px #0000001f;border-radius:0 0 20px 20px;overflow:hidden;max-height:0;opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1);transform:translateY(-10px);pointer-events:none}.navbar-menu.active{max-height:500px;opacity:1;transform:translateY(0);pointer-events:all}.navbar-nav-modern{list-style:none;margin:0;padding:1rem 0;display:flex;flex-direction:column;gap:.5rem}.navbar-nav-modern li{width:100%}.nav-link-modern{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1.25rem;background:transparent;border:none;color:#1a1a1a;font-weight:500;font-size:.95rem;border-radius:0;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:left;font-family:inherit;position:relative;overflow:hidden}.nav-link-modern:before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:linear-gradient(180deg,#d97706,#c2410c);transform:scaleY(0);transition:transform .3s ease}.nav-link-modern:hover:before,.nav-link-modern:focus:before{transform:scaleY(1)}.nav-link-modern:hover{background:linear-gradient(90deg,#d9770614,#d9770608);color:#d97706;padding-left:1.5rem}.nav-link-icon{font-size:1.25rem;display:inline-block;transition:transform .3s ease}.nav-link-modern:hover .nav-link-icon{transform:scale(1.2)}.nav-link-text{flex:1}.nav-link-modern-primary{background:linear-gradient(135deg,#d97706,#c2410c);color:#fff!important;margin:.5rem 1.25rem;border-radius:12px;box-shadow:0 4px 12px #d977064d;position:relative;z-index:1}.nav-link-modern-primary:before{display:none}.nav-link-modern-primary:hover{background:linear-gradient(135deg,#c2410c,#9a3412);transform:translateY(-2px);box-shadow:0 6px 20px #d9770666;padding-left:1.25rem;color:#fff!important}.nav-link-modern-primary .nav-link-icon{filter:brightness(0) invert(1);position:relative;z-index:2}.nav-link-modern-primary .nav-link-text{position:relative;z-index:2;color:#fff!important}.nav-link-modern-danger{color:#dc2626}.nav-link-modern-danger:hover{background:linear-gradient(90deg,#dc262614,#dc262608);color:#dc2626}@media(min-width:769px){.navbar-modern{padding:0}.navbar-container{padding:0 2rem}.navbar-content{min-height:80px}.navbar-brand-title{font-size:1.75rem}.navbar-brand-subtitle{font-size:.8rem}.navbar-toggle-modern{display:none}.navbar-menu{position:static;max-height:none;opacity:1;transform:none;background:transparent;border:none;box-shadow:none;border-radius:0;pointer-events:all}.navbar-nav-modern{flex-direction:row;padding:0;gap:.5rem;align-items:center}.navbar-nav-modern li{width:auto}.nav-link-modern{width:auto;padding:.625rem 1.25rem;border-radius:10px;text-align:center}.nav-link-modern:before{display:none}.nav-link-modern:hover{background:#d977061a;padding-left:1.25rem;transform:translateY(-2px)}.nav-link-modern-primary{margin:0;padding:.75rem 1.5rem;color:#fff!important}.nav-link-modern-primary:hover{padding-left:1.5rem;padding-right:1.5rem;color:#fff!important;background:linear-gradient(135deg,#c2410c,#9a3412)}.nav-link-modern-primary .nav-link-text{color:#fff!important}.nav-link-modern-primary .nav-link-icon{filter:brightness(0) invert(1)}}@media(max-width:768px){.navbar-brand-title{font-size:1.25rem}.navbar-brand-subtitle{font-size:.7rem}.navbar-brand-icon{font-size:1.75rem}}@media(max-width:768px){.footer-modern{padding:3rem 0 1.5rem}.footer-container{padding:0 1rem}.footer-content-modern{grid-template-columns:1fr;gap:2.5rem;margin-bottom:2rem}.footer-section-modern{text-align:center}.footer-brand{justify-content:center}.footer-section-title:after{left:50%;transform:translate(-50%)}.footer-links-modern{align-items:center}.footer-link-modern:before{display:none}.footer-link-modern:hover{padding-left:0;transform:none}.footer-tech-modern{justify-content:center}.footer-bottom-links{gap:.75rem}.footer-content{grid-template-columns:1fr;gap:var(--spacing-lg)}.footer-section{text-align:center}.footer-tech{justify-content:center}}@media(min-width:1024px){.footer-content-modern{grid-template-columns:repeat(5,1fr)}}.app-main{min-height:calc(100vh - 200px);padding:1rem;background:linear-gradient(180deg,#fafafa,#f5f5f5)}.app-container{max-width:1400px;margin:0 auto;width:100%}.header-compact{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:12px;padding:.75rem 1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000000f;border:1px solid rgba(0,0,0,.05);display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.header-compact-title{display:flex;align-items:center;gap:.5rem;flex:1;min-width:150px}.header-compact-title h1{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0;line-height:1.2}.header-icon{font-size:1.5rem}.selector-compact{flex:1;min-width:200px;max-width:400px}.selector-input-compact{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;background:#fff;color:#1a1a1a;cursor:pointer;transition:all .2s}.selector-input-compact:hover{border-color:#d97706}.selector-input-compact:focus{outline:none;border-color:#d97706;box-shadow:0 0 0 3px #d977061a}.header-actions-compact{display:flex;gap:.5rem}.btn-compact{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;cursor:pointer;transition:all .2s;font-size:1.1rem;box-shadow:0 1px 3px #0000001a}.btn-compact:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.btn-compact-primary{background:linear-gradient(135deg,#d97706,#c2410c);color:#fff}.btn-compact-secondary{background:#f3f4f6;color:#4b5563}.family-info-compact{margin-bottom:1rem;height:80px;display:flex;align-items:center;overflow:hidden}.family-info-compact-placeholder{width:100%;height:80px;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;text-align:center;background:#00000005;border-radius:10px;border:1px dashed rgba(0,0,0,.1);box-sizing:border-box}.family-info-compact-card{width:100%;height:80px;background:linear-gradient(135deg,#d9770614,#c2410c14);border:1px solid rgba(217,119,6,.2);border-radius:10px;padding:.75rem 1rem;display:flex;align-items:center;box-sizing:border-box}.family-info-compact-content{width:100%;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.family-info-compact-main{flex:1;min-width:200px}.family-info-compact-title{font-size:1.1rem;font-weight:700;color:var(--primary-dark, #c2410c);margin:0 0 .5rem;line-height:1.2}.family-info-compact-details{display:flex;gap:.75rem;flex-wrap:wrap}.family-info-badge{font-size:.85rem;color:#4b5563;background:#fff9;padding:.25rem .5rem;border-radius:6px;white-space:nowrap}.family-info-compact-actions{display:flex;gap:.5rem}.btn-compact-icon{width:32px;height:32px;font-size:1rem;background:#fff;border:1px solid #d1d5db;color:#4b5563}.btn-compact-icon:hover{background:#f9fafb;border-color:#d97706;color:#d97706}.btn-compact-danger:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}@media(max-width:768px){.app-main{padding:.5rem}.header-compact{flex-direction:column;align-items:stretch;gap:.5rem;padding:.5rem;margin-bottom:.75rem;border-radius:8px}.header-compact-title{min-width:auto;justify-content:center;gap:.4rem}.header-compact-title h1{font-size:1rem}.header-icon{font-size:1.1rem}.selector-compact{max-width:100%;min-width:auto}.selector-input-compact{font-size:.8rem;padding:.5rem .6rem}.header-actions-compact{justify-content:center;flex-wrap:wrap;gap:.4rem}.btn-compact{width:36px;height:36px;font-size:1rem;border-radius:6px}.family-info-compact{height:60px;margin-bottom:.75rem}.family-info-compact-card{height:60px;padding:.5rem .6rem;border-radius:8px}.family-info-compact-placeholder{height:60px;padding:.5rem .6rem}.family-info-compact-content{flex-direction:column;align-items:stretch;gap:.5rem}.family-info-compact-main{min-width:auto}.family-info-compact-title{font-size:.9rem;margin-bottom:.3rem}.family-info-compact-details{gap:.4rem}.family-info-badge{font-size:.75rem;padding:.15rem .35rem;border-radius:4px}.family-info-compact-actions{justify-content:center;flex-wrap:wrap;width:100%;gap:.4rem}.btn-compact-icon{width:32px;height:32px;font-size:.85rem;border-radius:6px}.family-info-compact-placeholder{padding:.5rem .6rem;font-size:.8rem;border-radius:8px}}@media(max-width:480px){.app-main{padding:.4rem}.header-compact{padding:.4rem;gap:.4rem;margin-bottom:.5rem}.header-compact-title h1{font-size:.9rem}.header-icon{font-size:1rem}.selector-input-compact{font-size:.75rem;padding:.45rem .5rem}.btn-compact{width:32px;height:32px;font-size:.9rem}.family-info-compact{height:55px;margin-bottom:.5rem}.family-info-compact-card,.family-info-compact-placeholder{height:55px;padding:.4rem .5rem}.family-info-compact-title{font-size:.85rem;margin-bottom:.25rem}.family-info-badge{font-size:.7rem;padding:.1rem .3rem}.btn-compact-icon{width:28px;height:28px;font-size:.8rem}.family-info-compact-placeholder{padding:.4rem .5rem;font-size:.75rem}}.btn-modern{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:12px;font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000001a;position:relative;overflow:hidden}.btn-modern:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-modern:hover:before{width:300px;height:300px}.btn-modern-primary{background:linear-gradient(135deg,#d97706,#c2410c);color:#fff}.btn-modern-primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #d9770666}.btn-modern-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-modern-success:hover{transform:translateY(-2px);box-shadow:0 4px 16px #10b98166}.btn-icon{font-size:1.25rem;display:inline-block;position:relative;z-index:1}.btn-modern span:not(.btn-icon){position:relative;z-index:1}.selector-card{background:#fff;border-radius:16px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 12px #00000014;border:1px solid rgba(0,0,0,.05);transition:all .3s ease}.selector-card:hover{box-shadow:0 4px 20px #0000001f}.selector-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.selector-icon{font-size:1.5rem}.selector-label{font-weight:600;color:#1a1a1a;font-size:.95rem}.selector-input{width:100%;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;background:#fff;color:#1a1a1a;transition:all .3s ease;cursor:pointer}.selector-input:focus{outline:none;border-color:#d97706;box-shadow:0 0 0 4px #d977061a}.quick-actions{background:#fff;border-radius:16px;padding:1.5rem;margin-top:1.5rem;box-shadow:0 2px 12px #00000014;border:1px solid rgba(0,0,0,.05)}.quick-actions-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0 0 1.25rem}.quick-actions-icon{font-size:1.5rem}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.25rem 1rem;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);text-align:center;min-height:100px}.action-card:hover{transform:translateY(-4px);border-color:#d97706;background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 8px 24px #d9770633}.action-card:active{transform:translateY(-2px)}.action-card-icon{font-size:2rem;display:block}.action-card-label{font-size:.875rem;font-weight:600;color:#1a1a1a;line-height:1.3}.tree-section{margin-bottom:2rem}.tree-container{width:100%;height:800px;border-radius:20px;background:linear-gradient(135deg,#fff,#f8f9fa);box-shadow:0 8px 32px #0000001f;border:1px solid rgba(0,0,0,.08);overflow:hidden;position:relative}.info-card-modern{display:flex;gap:1rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:16px;padding:1.5rem;margin-bottom:2rem;border:1px solid rgba(59,130,246,.2);box-shadow:0 2px 12px #00000014}.info-card-icon{font-size:2rem;flex-shrink:0}.info-card-content{flex:1}.info-card-title{font-size:1.125rem;font-weight:700;color:#1e40af;margin:0 0 .5rem}.info-card-text{font-size:.95rem;color:#1e3a8a;margin:0;line-height:1.6}#tree-wrapper svg{backface-visibility:hidden;transform:translateZ(0);will-change:transform}.rd3t-link,.custom-parent-link path{shape-rendering:geometricPrecision}.family-section,.content-section,.members-section{margin-top:1.5rem;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;border:1px solid rgba(217,119,6,.2)}.members-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.members-title{margin:0;color:var(--primary-dark, #c2410c);font-size:1.25rem;font-weight:700}.btn-add-member{padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;white-space:nowrap}.members-empty{text-align:center;padding:2rem}.members-cards{display:grid;grid-template-columns:1fr;gap:.6rem}.member-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.6rem;transition:all .2s;box-shadow:0 1px 2px #0000000a;position:relative}.member-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#d977064d,#d977061a);border-radius:8px 8px 0 0}.member-card:hover{box-shadow:0 2px 6px #00000014;transform:translateY(-1px);border-color:#d977064d}.member-card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}.member-card-photo{flex-shrink:0}.member-photo-img,.member-photo-placeholder{width:44px;height:44px;border-radius:50%;object-fit:cover}.member-photo-placeholder{display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1rem}.member-photo-placeholder.male{background:var(--primary, #d97706)}.member-photo-placeholder.female{background:var(--success, #10b981)}.member-card-info{flex:1;min-width:0}.member-card-name{margin:0 0 .2rem;font-size:.9rem;color:#1a1a1a;font-weight:500;line-height:1.3}.member-card-name strong{font-weight:700}.member-card-details{margin-bottom:.5rem;padding-top:.4rem;border-top:1px solid #e2e8f0}.member-detail-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem;font-size:.8rem}.member-detail-item:last-child{margin-bottom:0}.member-detail-label{color:#6b7280;font-weight:500}.member-detail-value{color:#1a1a1a;font-weight:600}.member-card-actions{display:flex;gap:.4rem;flex-wrap:wrap}.btn-member-action{flex:1;min-width:90px;padding:.45rem .6rem;font-size:.8rem;font-weight:600;white-space:nowrap;border-radius:6px}.members-table-container{display:none}.members-table{width:100%;border-collapse:collapse}.members-table thead{background:#f8f9fa}.members-table th{padding:.75rem;text-align:left;font-weight:600;color:#1a1a1a;border-bottom:2px solid #e2e8f0;font-size:.9rem}.members-table td{padding:.75rem;border-bottom:1px solid #e2e8f0;font-size:.9rem}.members-table tbody tr:hover{background:#f8f9fa}.member-table-photo,.member-table-photo-placeholder{width:40px;height:40px;border-radius:50%;object-fit:cover}.member-table-photo-placeholder{display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.9rem}.member-table-photo-placeholder.male{background:var(--primary, #d97706)}.member-table-photo-placeholder.female{background:var(--success, #10b981)}.actions-column{min-width:220px;text-align:center}.member-table-actions{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.member-table-actions .btn{padding:.5rem 1rem;font-size:.875rem;font-weight:600;white-space:nowrap;min-width:100px}@media(min-width:769px){.members-cards{display:none}.members-table-container{display:block}}@media(max-width:768px){.members-section{padding:.75rem;margin-top:1rem}.members-header{margin-bottom:.75rem}.members-title{font-size:1.1rem}.btn-add-member{padding:.5rem 1rem;font-size:.85rem}.members-cards{gap:.5rem}.member-card{padding:.5rem;border-width:1px;border-radius:6px}.member-card:before{height:2px}.member-card-header{gap:.5rem;margin-bottom:.4rem}.member-photo-img,.member-photo-placeholder{width:40px;height:40px;font-size:.9rem}.member-card-name{font-size:.85rem;margin-bottom:.15rem}.member-card-details{margin-bottom:.4rem;padding-top:.35rem}.member-detail-item{font-size:.75rem;margin-bottom:.25rem}.member-card-actions{gap:.35rem}.btn-member-action{font-size:.75rem;padding:.4rem .5rem;min-width:80px}}@media(max-width:480px){.members-section{padding:.5rem}.members-title{font-size:1rem}.btn-add-member{padding:.45rem .85rem;font-size:.8rem}.member-card{padding:.45rem;border-width:1px;border-radius:6px}.member-card:before{height:2px}.member-card-header{gap:.45rem;margin-bottom:.35rem}.member-photo-img,.member-photo-placeholder{width:36px;height:36px;font-size:.85rem}.member-card-name{font-size:.8rem;margin-bottom:.1rem}.member-card-details{margin-bottom:.35rem;padding-top:.3rem}.member-detail-item{font-size:.7rem;margin-bottom:.2rem}.member-card-actions{gap:.3rem}.btn-member-action{font-size:.7rem;padding:.35rem .45rem;min-width:70px}.member-photo-img,.member-photo-placeholder{width:40px;height:40px;font-size:.9rem}.member-card-name{font-size:.85rem}.member-detail-item{font-size:.75rem}.btn-member-action{font-size:.75rem;padding:.4rem .5rem;min-width:80px}}.members-section,.families-section{margin-bottom:2rem}@media(max-width:640px){.hero-section{padding:1.5rem 1rem;border-radius:20px}.hero-title{font-size:1.5rem}.hero-icon{font-size:2rem}.hero-subtitle{font-size:.9rem}.btn-modern{padding:.75rem 1.25rem;font-size:.875rem}.selector-card,.quick-actions{padding:1.25rem;border-radius:16px}.quick-actions-grid{grid-template-columns:1fr;gap:.75rem}.action-card{min-height:90px;padding:1rem}.tree-container{height:600px;border-radius:16px}.info-card-modern{flex-direction:column;text-align:center;padding:1.25rem}}@media(min-width:768px){.app-main{padding:2rem}.hero-section{padding:3rem 2.5rem}.hero-title{font-size:2.5rem}.quick-actions-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.hero-title{font-size:3rem}.tree-container{height:900px}}.loading{text-align:center;padding:3rem;font-size:1.125rem;color:#6b7280}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:.5rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:600px;width:100%;max-height:95vh;overflow-y:auto;position:relative;padding:1rem}.modal-form{max-width:800px;width:90%;max-height:90vh;padding:1.5rem}@media(max-width:640px){.modal-form{width:95%;padding:1rem;max-height:95vh}}.modal-form .form-group{margin-bottom:1.25rem}.modal-form label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:.9rem}.modal-form .form-control{width:100%;padding:.625rem .75rem;border:2px solid #e5e7eb;border-radius:6px;font-size:.95rem;transition:border-color .2s}.modal-form .form-control:focus{outline:none;border-color:#d97706;box-shadow:0 0 0 3px #d977061a}.modal-form .form-control:disabled{background-color:#f3f4f6;cursor:not-allowed}.modal-form .alert{padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.modal-form .alert-danger{background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca}.modal-form .alert-info{background-color:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.modal-form button[type=submit],.modal-form .btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;font-size:.95rem}.modal-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.modal-close{position:absolute;top:.5rem;right:.5rem;background:#f3f4f6;border:none;width:28px;height:28px;border-radius:50%;font-size:1.25rem;cursor:pointer;color:#1f2937;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .2s;z-index:10}.modal-close:hover{background:#d97706;color:#fff;transform:scale(1.1)}.modal-compact{max-width:420px;width:90%;padding:1.25rem;border-radius:16px;box-shadow:0 20px 60px #00000026}@media(max-width:640px){.modal-compact{width:95%;padding:1rem;max-width:100%}}.member-preview-compact{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.member-photo-compact{width:64px;height:64px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 4px 12px #00000026}.member-avatar-compact{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;border:3px solid #fff;box-shadow:0 4px 12px #00000026}.member-name-compact{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0;text-align:center;line-height:1.3}.action-grid-compact{display:grid;grid-template-columns:repeat(2,1fr);gap:.625rem;margin-top:.5rem}@media(max-width:480px){.action-grid-compact{grid-template-columns:1fr;gap:.5rem}}.action-button-compact{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:10px;background:linear-gradient(135deg,#fff,#f9fafb);color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);text-align:left;position:relative;overflow:hidden}.action-button-compact:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.action-button-compact:hover:before{left:100%}.action-button-compact:hover{border-color:#d97706;background:linear-gradient(135deg,#fff7ed,#ffedd5);color:#c2410c;transform:translateY(-2px);box-shadow:0 4px 12px #d9770633}.action-button-compact:active{transform:translateY(0);box-shadow:0 2px 6px #d9770626}.action-button-compact:disabled{opacity:.5;cursor:not-allowed;transform:none}.action-icon-compact{font-size:1.25rem;line-height:1;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.action-label-compact{flex:1;line-height:1.3;font-weight:500}.action-button-compact[style*="background: linear-gradient"]{background:linear-gradient(135deg,#fee2e2,#fecaca)!important;border-color:#dc2626!important;color:#dc2626!important}.action-button-compact[style*="background: linear-gradient"]:hover{background:linear-gradient(135deg,#fecaca,#fca5a5)!important;border-color:#b91c1c!important;color:#991b1b!important;box-shadow:0 4px 12px #dc262640!important}.modal-delete-confirm{text-align:center;padding:.5rem 0}.modal-delete-confirm-icon{font-size:3rem;margin-bottom:1rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.modal-delete-confirm-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .75rem}.modal-delete-confirm-message{font-size:.9rem;color:#6b7280;margin:0 0 1.5rem;line-height:1.5}.modal-delete-confirm-buttons{display:flex;gap:.75rem;justify-content:center}.modal-delete-confirm-button{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.9rem;border:2px solid;cursor:pointer;transition:all .25s}.modal-delete-confirm-button-cancel{background:#fff;border-color:#d1d5db;color:#374151}.modal-delete-confirm-button-cancel:hover{background:#f9fafb;border-color:#9ca3af}.modal-delete-confirm-button-delete{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;color:#fff}.modal-delete-confirm-button-delete:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 4px 12px #dc26264d}.modal-delete-confirm-button:disabled{opacity:.6;cursor:not-allowed}#tree-wrapper{width:100%;height:100%;position:relative}#tree-wrapper svg{width:100%;height:100%;display:block;background:transparent;overflow:visible}#tree-wrapper .rd3t-tree-container{width:100%;height:100%;overflow:visible}#tree-wrapper .rd3t-link{fill:none;stroke:linear-gradient(90deg,#d97706 0%,#c2410c 100%);stroke:#d97706;stroke-width:2.5;stroke-opacity:.6;transition:all .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 1px 2px rgba(217,119,6,.3))}#tree-wrapper .rd3t-link:hover{stroke-width:3;stroke-opacity:1;filter:drop-shadow(0 2px 4px rgba(217,119,6,.5))}.custom-tree-node{cursor:pointer;transition:transform .3s cubic-bezier(.4,0,.2,1)}.custom-tree-node:hover{transform:scale(1.08)}.custom-tree-node circle{transition:all .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 6px rgba(0,0,0,.15))}.custom-tree-node:hover circle{stroke-width:4px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25));transform:scale(1.05)}.custom-tree-node rect{transition:all .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 8px rgba(0,0,0,.12))}.custom-tree-node:hover rect{filter:drop-shadow(0 4px 16px rgba(0,0,0,.2));stroke-width:2.5}.custom-tree-node image{transition:all .3s cubic-bezier(.4,0,.2,1);filter:brightness(1) contrast(1)}.custom-tree-node:hover image{filter:brightness(1.05) contrast(1.05);transform:scale(1.02)}#tree-wrapper text{font-family:system-ui,-apple-system,Segoe UI,sans-serif;-webkit-user-select:none;user-select:none;transition:all .3s ease;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.custom-tree-node:hover text{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.custom-tree-node g[transform*=translate] circle[fill="#fff"]{transition:all .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}.custom-tree-node g[transform*=translate]:hover circle[fill="#fff"]{transform:scale(1.15);filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));stroke-width:2.5}.custom-tree-node g[transform*=translate]:hover text{transform:scale(1.1);font-weight:700}.custom-tree-node line{transition:all .3s cubic-bezier(.4,0,.2,1);stroke-linecap:round;stroke-linejoin:round}.custom-tree-node:hover line{stroke-width:3;opacity:1;filter:drop-shadow(0 1px 2px rgba(217,119,6,.4))}#tree-wrapper g{pointer-events:all}#tree-wrapper svg *{vector-effect:non-scaling-stroke}@keyframes fadeInNode{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.custom-tree-node{animation:fadeInNode .4s cubic-bezier(.4,0,.2,1)}.member-frame{transition:all .3s cubic-bezier(.4,0,.2,1)}.member-frame:hover{stroke-width:3;filter:drop-shadow(0 4px 16px rgba(0,0,0,.25))!important}.member-circle{transition:all .3s cubic-bezier(.4,0,.2,1)}.member-circle:hover{stroke-width:4;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))!important;transform:scale(1.05)}.add-button-group{transition:all .3s cubic-bezier(.4,0,.2,1)}.add-button-group:hover{transform:scale(1.15)}.add-button-circle{transition:all .3s cubic-bezier(.4,0,.2,1)}.add-button-group:hover .add-button-circle{stroke-width:3;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))!important}.add-button-icon{transition:all .3s ease}.add-button-group:hover .add-button-icon{transform:scale(1.2);font-weight:800}
