:root{--family-primary:#667eea;--family-secondary:#764ba2;--family-accent:#f59e0b;--family-warm:#fef3c7;--family-text:#1f2937;--family-text-light:#6b7280;--family-bg:#fefbf6;--family-card:#ffffff;--family-border:#e5e7eb}.family-showcase-wrapper{background:linear-gradient(180deg,var(--family-bg) 0,#fff 100%);font-family:Nunito,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh}.family-hero{background:linear-gradient(135deg,var(--family-primary) 0,var(--family-secondary) 100%);padding:60px 24px 80px;position:relative;overflow:hidden}.family-hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.5}.family-hero-content{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.family-hero-avatar{width:180px;height:180px;border-radius:50%;object-fit:cover;border:6px solid #fff;box-shadow:0 8px 32px rgba(0,0,0,.2);margin-bottom:24px}.family-hero-avatar-placeholder{width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.2);border:6px solid #fff;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#fff;margin-bottom:24px}.family-hero-name{font-size:2.5rem;font-weight:800;color:#fff;margin:0 0 8px;text-align:center;text-shadow:0 2px 8px rgba(0,0,0,.2)}.family-hero-relationship{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:rgba(255,255,255,.2);border-radius:30px;color:#fff;font-size:1.1rem;font-weight:600;margin-bottom:16px;backdrop-filter:blur(8px)}.family-hero-dates{display:flex;align-items:center;gap:16px;color:rgba(255,255,255,.9);font-size:1rem;margin-bottom:20px}.family-hero-dates i{margin-right:6px}.family-hero-description{color:rgba(255,255,255,.95);font-size:1.1rem;line-height:1.7;text-align:center;max-width:700px;margin:0}.family-quick-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;max-width:900px;margin:-40px auto 0;padding:0 24px;position:relative;z-index:2}.family-info-card{background:#fff;border-radius:16px;padding:20px;text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid var(--family-border);transition:.2s}.family-info-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(102,126,234,.15)}.family-info-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:1.2rem;color:#fff}.family-info-label{font-size:.8rem;color:var(--family-text-light);margin-bottom:4px}.family-info-value{font-size:1rem;font-weight:700;color:var(--family-text)}.family-section{max-width:900px;margin:40px auto;padding:0 24px}.family-section-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.family-section-header h2{font-size:1.4rem;font-weight:700;color:var(--family-text);margin:0}.family-section-header i{color:var(--family-primary);font-size:1.2rem}.family-bio-card{background:#fff;border-radius:20px;padding:28px;box-shadow:0 4px 20px rgba(0,0,0,.06);border:1px solid var(--family-border)}.family-bio-text{color:var(--family-text);font-size:1.05rem;line-height:1.8;margin:0}.family-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.family-detail-item{background:#fff;border-radius:14px;padding:16px;border:1px solid var(--family-border);transition:.2s}.family-detail-item:hover{border-color:var(--family-primary);box-shadow:0 4px 12px rgba(102,126,234,.1)}.family-detail-label{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--family-text-light);margin-bottom:6px}.family-detail-label i{color:var(--family-primary);width:16px}.family-detail-value{font-size:1rem;font-weight:600;color:var(--family-text)}.family-tags-section{display:flex;flex-wrap:wrap;gap:10px}.family-tag{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#667eea20,#764ba220);border-radius:20px;font-size:.9rem;color:var(--family-primary);font-weight:500;border:1px solid #667eea30;transition:.2s}.family-tag:hover{background:var(--family-primary);color:#fff}.family-tag i{font-size:.85rem}.family-members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.family-member-card{background:#fff;border-radius:16px;padding:16px;text-align:center;border:1px solid var(--family-border);transition:.2s}.family-member-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(102,126,234,.15)}.family-member-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;margin-bottom:10px;border:3px solid var(--family-primary)}.family-member-name{font-weight:600;color:var(--family-text);font-size:.95rem;margin-bottom:4px}.family-member-relation{font-size:.8rem;color:var(--family-text-light)}.family-timeline{position:relative;padding-left:40px}.family-timeline::before{content:'';position:absolute;left:16px;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--family-primary),var(--family-secondary),var(--family-accent));border-radius:3px}.family-timeline-item{position:relative;margin-bottom:20px;cursor:pointer;transition:.2s}.family-timeline-item:hover{transform:translateX(4px)}.family-timeline-marker{position:absolute;left:-40px;top:4px;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;box-shadow:0 3px 10px rgba(0,0,0,.15);z-index:2}.family-timeline-content{background:#fff;border-radius:16px;padding:18px 22px;border:1px solid var(--family-border);transition:.2s}.family-timeline-item:hover .family-timeline-content{border-color:var(--family-primary);box-shadow:0 6px 20px rgba(102,126,234,.12)}.family-timeline-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.family-event-badge{padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.family-timeline-date{font-size:.85rem;color:var(--family-text-light)}.family-timeline-title{font-weight:600;color:var(--family-text);font-size:1.05rem;margin-bottom:6px}.family-timeline-desc{font-size:.9rem;color:var(--family-text-light);line-height:1.5}.family-event-more{color:var(--family-text-light);font-size:.85rem;margin-top:10px;opacity:0;transition:.2s}.family-timeline-item:hover .family-event-more{opacity:1;color:var(--family-primary)}.family-event-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px;animation:.2s familyModalFadeIn}@keyframes familyModalFadeIn{from{opacity:0}to{opacity:1}}.family-event-modal{background:#fff;border-radius:24px;max-width:550px;width:100%;max-height:85vh;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.25);animation:.3s familyModalSlideUp}@keyframes familyModalSlideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.family-event-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;color:#fff}.family-event-modal-badge{padding:8px 16px;border-radius:10px;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:rgba(255,255,255,.2);color:#fff}.family-event-modal-close{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.2);border:none;color:#fff;font-size:1.1rem;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center}.family-event-modal-close:hover{background:rgba(255,255,255,.3)}.family-event-modal-body{padding:28px;overflow-y:auto;max-height:calc(85vh - 80px)}.family-event-modal-title{font-size:1.5rem;font-weight:700;color:var(--family-text);margin:0 0 12px;line-height:1.3}.family-event-modal-date{display:flex;align-items:center;gap:8px;color:var(--family-primary);font-size:.95rem;margin-bottom:16px}.family-event-modal-desc{color:var(--family-text-light);font-size:1rem;line-height:1.7;margin:0 0 20px;padding-bottom:16px;border-bottom:1px solid var(--family-border)}.family-event-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.family-event-detail-item{background:var(--family-warm);border-radius:12px;padding:14px}.family-event-detail-label{font-size:.75rem;color:var(--family-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:600}.family-event-detail-value{color:var(--family-text);font-size:.95rem;font-weight:500;line-height:1.5}body[data-category=family] .fab-button{background:linear-gradient(135deg,#667eea 0,#764ba2 100%);box-shadow:0 4px 12px rgba(102,126,234,.4)}body[data-category=family] .fab-button:hover{box-shadow:0 6px 20px rgba(102,126,234,.6)}body[data-category=family] .fab-menu{border-color:rgba(102,126,234,.2)}body[data-category=family] .fab-entity-item.active{background:rgba(102,126,234,.1);border-color:rgba(102,126,234,.3)}body[data-category=family] .fab-entity-item:hover{background:rgba(102,126,234,.08)}.family-tree-section{background:linear-gradient(135deg,#667eea10,#764ba210);border-radius:20px;padding:24px}.family-tree-container{overflow-x:auto;padding:16px 0}.family-tree-members{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.family-tree-member{display:flex;flex-direction:column;align-items:center;padding:16px;background:#fff;border-radius:16px;border:2px solid transparent;cursor:pointer;transition:.3s;min-width:120px;max-width:140px}.family-tree-member:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(102,126,234,.2);border-color:var(--family-primary)}.family-tree-member.current{border-color:var(--family-primary);background:linear-gradient(135deg,#667eea10,#764ba210);box-shadow:0 4px 16px rgba(102,126,234,.25)}.family-tree-member-avatar{position:relative;width:70px;height:70px;border-radius:50%;overflow:hidden;margin-bottom:12px;border:3px solid var(--family-primary);background:var(--family-primary);display:flex;align-items:center;justify-content:center}.family-tree-member-avatar img{width:100%;height:100%;object-fit:cover}.family-tree-member-avatar i{font-size:2rem;color:#fff}.deceased-badge{position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;background:#64748b;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff;border:2px solid #fff}.family-tree-member-info{text-align:center}.family-tree-member-name{font-weight:600;color:var(--family-text);font-size:.9rem;margin-bottom:4px;line-height:1.3}.family-tree-member-relation{font-size:.75rem;color:var(--family-primary);font-weight:500;text-transform:uppercase;letter-spacing:.3px}.family-tree-generation{display:flex;justify-content:center;gap:24px;margin-bottom:24px;position:relative}.family-tree-generation::after{content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:2px;height:12px;background:var(--family-primary)}.family-tree-generation:last-child::after{display:none}.family-tree-full{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:20px;padding:20px}.family-tree-full .family-tree-member{max-width:none}@media (max-width:768px){.family-hero{padding:40px 20px 60px}.family-hero-avatar,.family-hero-avatar-placeholder{width:140px;height:140px}.family-hero-name{font-size:1.8rem}.family-quick-info{grid-template-columns:repeat(2,1fr);margin-top:-30px}.family-details-grid{grid-template-columns:1fr 1fr}.family-timeline{padding-left:32px}.family-timeline::before{left:12px}.family-timeline-marker{left:-32px;width:28px;height:28px;font-size:.75rem}.family-event-detail-grid{grid-template-columns:1fr}}@media (max-width:480px){.family-quick-info{grid-template-columns:1fr 1fr}.family-details-grid{grid-template-columns:1fr}.family-members-grid{grid-template-columns:repeat(2,1fr)}}