.family-directory-page{background:linear-gradient(to bottom,var(--bg-cream),var(--bg-primary));min-height:100vh;padding:2rem 0 4rem}.page-header{text-align:center;margin-bottom:3rem;padding:2rem 0}.cross-symbol{color:var(--primary-gold);margin-bottom:1rem;font-size:3.5rem;animation:.8s ease-out fadeIn}.page-title{color:var(--primary-burgundy);margin-bottom:1rem;font-size:3rem;font-weight:700;animation:.8s ease-out .2s both fadeIn}.page-subtitle{color:var(--text-secondary);max-width:700px;margin:0 auto;font-size:1.2rem;animation:.8s ease-out .4s both fadeIn}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.stat-card{border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);text-align:center;border-top:4px solid var(--primary-gold);background:#fff;padding:2rem;transition:all .3s;animation:.6s ease-out both slideUp}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.stat-icon{margin-bottom:.75rem;font-size:3rem}.stat-value{color:var(--primary-burgundy);margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.95rem}.controls-section{border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);background:#fff;margin-bottom:2rem;padding:2rem}.search-box{margin-bottom:1.5rem;position:relative}.search-input{border:2px solid var(--bg-secondary);border-radius:var(--border-radius-md);width:100%;padding:1rem 1rem 1rem 3.5rem;font-size:1rem;transition:all .3s}.search-input:focus{border-color:var(--primary-gold);outline:none;box-shadow:0 0 0 3px #d4af371a}.search-icon{pointer-events:none;font-size:1.2rem;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.auth-actions{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:2rem;animation:.8s ease-out .6s both fadeIn;display:flex}.btn-register,.btn-login{cursor:pointer;text-transform:uppercase;letter-spacing:1px;border-radius:30px;padding:.875rem 2rem;font-size:1rem;font-weight:600;transition:all .3s}.btn-register{background:linear-gradient(135deg,var(--primary-burgundy),var(--secondary-brown));color:#fff;border:none;box-shadow:0 4px 15px #8000204d}.btn-register:hover{transform:translateY(-2px);box-shadow:0 6px 20px #80002066}.btn-login{color:var(--primary-burgundy);border:2px solid var(--primary-burgundy);background:#fff}.btn-login:hover{background:var(--bg-light-gold);transform:translateY(-2px)}.results-info{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.results-info strong{color:var(--primary-burgundy);font-weight:700}.families-list{flex-direction:column;gap:1.5rem;display:flex}.family-card{border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);border-left:5px solid var(--primary-gold);background:#fff;transition:all .3s;animation:.5s ease-out both fadeInUp;overflow:hidden}.family-card:hover{box-shadow:var(--shadow-lg)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.family-header{cursor:pointer;background:linear-gradient(to right,white,var(--bg-primary));border-bottom:2px solid var(--bg-secondary);justify-content:space-between;align-items:center;padding:1.5rem;transition:all .3s;display:flex}.family-header:hover{background:linear-gradient(to right,var(--bg-light-gold),var(--bg-primary))}.family-main-info{flex:1}.family-name{color:var(--primary-burgundy);margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.head-of-family{color:var(--text-secondary);margin:0;font-size:1rem}.head-of-family strong{color:var(--primary-burgundy)}.family-meta{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.parish-badge{background:linear-gradient(135deg,var(--primary-burgundy),var(--secondary-brown));color:#fff;border-radius:20px;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.member-count{color:var(--text-light);background:var(--bg-secondary);border-radius:15px;padding:.375rem .875rem;font-size:.9rem;font-weight:600}.toggle-btn{border:2px solid var(--primary-burgundy);width:35px;height:35px;color:var(--primary-burgundy);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;transition:all .3s;display:flex}.toggle-btn:hover{background:var(--primary-burgundy);color:#fff}.family-quick-info{background:var(--bg-primary);border-bottom:1px solid var(--bg-secondary);flex-wrap:wrap;gap:2rem;padding:1rem 1.5rem;display:flex}.info-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.95rem;display:flex}.info-icon{font-size:1.2rem}.members-section{background:var(--bg-primary);border-top:2px solid var(--primary-gold);padding:2rem 1.5rem;animation:.4s ease-out slideDown}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.members-section h4{color:var(--primary-burgundy);margin-bottom:1.5rem;font-size:1.3rem;font-weight:700}.members-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;display:grid}.member-card{border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);background:#fff;border:2px solid #0000;gap:1rem;padding:1.5rem;transition:all .3s;display:flex}.member-card:hover{border-color:var(--primary-gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}.member-avatar{flex-shrink:0;font-size:3rem}.member-info{flex:1}.member-name{color:var(--primary-burgundy);margin-bottom:.25rem;font-size:1.1rem;font-weight:700}.member-relationship{color:var(--primary-gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem;font-size:.85rem;font-weight:600}.member-details{flex-wrap:wrap;gap:1rem;margin-bottom:.75rem;display:flex}.detail-item{color:var(--text-secondary);background:var(--bg-secondary);border-radius:var(--border-radius-sm);padding:.25rem .625rem;font-size:.85rem}.member-contact{color:var(--text-light);margin:.25rem 0 0;font-size:.85rem}.empty-state{text-align:center;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);background:#fff;margin-top:2rem;padding:6rem 2rem}.empty-state p{color:var(--text-secondary);font-size:1.3rem}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:50vh;display:flex}.spinner{border:6px solid var(--bg-secondary);border-top-color:var(--primary-burgundy);border-radius:50%;width:60px;height:60px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{color:var(--text-secondary);font-size:1.2rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:968px){.stats-grid{grid-template-columns:repeat(2,1fr)}.family-header{flex-direction:column;align-items:flex-start;gap:1rem}.family-meta{justify-content:space-between;width:100%}.members-grid{grid-template-columns:1fr}}@media (max-width:768px){.family-directory-page{padding:1rem 0 3rem}.page-title{font-size:2.2rem}.cross-symbol{font-size:2.5rem}.stats-grid{gap:1rem}.stat-card{padding:1.5rem 1rem}.stat-icon{font-size:2.5rem}.stat-value{font-size:2rem}.controls-section{padding:1.5rem}.search-input{padding:.875rem .875rem .875rem 3.25rem;font-size:.95rem}.auth-actions{flex-direction:column;gap:1rem;padding:0 1rem}.btn-register,.btn-login{width:100%}.family-header{padding:1.25rem}.family-name{font-size:1.3rem}.family-quick-info{flex-direction:column;gap:1rem}.members-section{padding:1.5rem 1rem}.member-card{text-align:center;flex-direction:column;align-items:center}.member-avatar{font-size:4rem}}@media (max-width:480px){.page-title{font-size:1.8rem}.stats-grid{grid-template-columns:1fr}.search-input{padding:.875rem .875rem .875rem 3.25rem;font-size:.95rem}.parish-btn{flex:1;min-width:calc(50% - .5rem)}.family-meta{flex-direction:column;align-items:flex-start;width:100%}.member-details{flex-direction:column;gap:.5rem}}
