.user-menu{display:flex;align-items:center;gap:15px}.user-name{display:flex;align-items:center;gap:8px;color:var(--primary-color);font-weight:500}.user-name img{border-radius:50%;width:24px;height:24px}.horizontal-menu .sub-menu{position:absolute;top:100%;left:0;background:#fff;min-width:200px;list-style:none;padding:0;margin:0;box-shadow:0 2px 10px rgba(0,0,0,.1);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s;z-index:1000;border-radius:4px}.horizontal-menu li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}.horizontal-menu .sub-menu li{border-bottom:1px solid #eee}.horizontal-menu .sub-menu li:last-child{border-bottom:none}.horizontal-menu .sub-menu a{padding:.75rem 1rem;color:var(--text-color)}.horizontal-menu .sub-menu a:hover{background:#f5f5f5;color:var(--secondary-color)}.header-bottom.sticky{position:fixed;top:0;left:0;right:0;box-shadow:0 2px 10px rgba(0,0,0,.1);animation:slideDown .3s ease;z-index:999}body.menu-sticky .header-bottom.sticky+.site-main{margin-top:60px}@media (max-width:768px){.mobile-menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.active span:nth-child(2){opacity:0}.mobile-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.main-navigation.active{display:block}.horizontal-menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;background:rgba(0,0,0,.2);padding-left:1rem;box-shadow:none;display:none}.horizontal-menu li.menu-item-has-children>a:after{content:"▼";position:absolute;right:1rem;font-size:.7rem}.horizontal-menu li:hover>.sub-menu{display:block}.main-navigation.active+.mobile-menu-actions{display:flex}.mobile-user-info{display:flex;align-items:center;gap:15px;padding:12px;background:rgba(255,255,255,.1);border-radius:10px}.mobile-user-avatar img{width:45px;height:45px;border-radius:50%;border:2px solid rgba(255,255,255,.3)}.mobile-user-details strong{display:block;color:white;font-size:.95rem;margin-bottom:3px}.mobile-user-details span{font-size:.75rem;color:rgba(255,255,255,.7)}.mobile-add-member-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:linear-gradient(135deg,#4caf50,#45a049);color:white;text-decoration:none;border-radius:8px;font-weight:600;font-size:.95rem}.mobile-logout-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:linear-gradient(135deg,#e74c3c,#c0392b);color:white;text-decoration:none;border-radius:8px;font-weight:600;font-size:.95rem}}.search-suggestions.active,.mobile-search-suggestions.active{display:block}.suggestions-list{padding:8px 0}.suggestion-item{display:flex;align-items:center;gap:12px;padding:10px 15px;text-decoration:none;transition:background .2s;border-bottom:1px solid #f0f0f0;cursor:pointer}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.highlighted{background:#f5f5f5}.suggestion-avatar{width:40px;height:40px;flex-shrink:0}.suggestion-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.default-suggestion-avatar{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:white;font-size:18px;font-weight:700}.default-suggestion-avatar.male{background:linear-gradient(135deg,#3498db 0%,#2980b9 100%)}.default-suggestion-avatar.female{background:linear-gradient(135deg,#e91e63 0%,#c2185b 100%)}.suggestion-info{flex:1}.suggestion-name{color:#2c3e50;font-weight:500;margin-bottom:2px}.suggestion-name mark{background:#fff3cd;padding:0 2px;border-radius:2px}.suggestion-details{font-size:.7rem;color:#7f8c8d}.no-results{padding:15px;text-align:center;color:#999}.family-tree-container{position:relative;overflow:visible;width:100%;max-width:100%;background:#f9f9f9;border-radius:8px;padding:20px;margin:0}.tree-wrapper{position:relative;overflow-x:auto;overflow-y:visible;width:100%;min-height:600px;background:#f9f9f9;border-radius:8px;border:1px solid #eee}.zoom-container{position:relative;width:100%;min-width:max-content;min-height:600px;transition:transform .3s ease;transform-origin:0 0;display:inline-block}.family-tree{display:inline-block;min-width:100%;padding:20px}.tree-controls{position:sticky;top:20px;right:20px;z-index:100;display:flex;gap:10px;background:#fff;padding:8px 12px;border-radius:40px;box-shadow:0 2px 10px rgba(0,0,0,.1);margin-bottom:15px;float:right;clear:both}.tree-controls button{width:36px;height:36px;border:1px solid #ddd;background:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}.tree-controls button:hover{background:#f0f0f0;transform:scale(1.05)}.generation-row{display:flex;flex-direction:column;align-items:center;width:100%;position:relative;margin-bottom:60px}.generation-label{text-align:center;font-weight:700;margin-bottom:25px;color:#2c3e50;color:white;font-size:1rem;padding:6px 18px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:inline-block;border-radius:30px;position:relative;z-index:2;box-shadow:0 2px 10px rgba(0,0,0,.1)}.generation-members{display:flex;justify-content:center;align-items:flex-start;gap:30px;flex-wrap:wrap;position:relative;width:100%;padding:15px 20px}.family-unit{display:flex;flex-direction:column;align-items:center;position:relative;flex-shrink:0}.couple-wrapper{display:flex;align-items:center;justify-content:center;gap:25px;position:relative;background:#fff;padding:15px 20px;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.08);min-width:auto}.member-card-link{text-decoration:none;display:block}.member-card{background:#fff;border-radius:10px;box-shadow:0 2px 6px rgba(0,0,0,.08);padding:12px;min-width:180px;max-width:200px;width:100%;text-align:center;cursor:pointer;transition:all .3s;position:relative;border:2px solid transparent}.member-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px rgba(0,0,0,.12);border-color:#3498db}.member-card.deceased{background:#f5f5f5;border:1px solid #ddd;opacity:.8}.member-card.male{border-top:3px solid var(--male-color)}.member-card.female{border-top:3px solid var(--female-color)}.member-avatar{width:80px;height:80px;margin:0 auto 10px;border-radius:50%;overflow:hidden;border:2px solid #3498db;background:#f0f0f0;display:flex;align-items:center;justify-content:center;position:relative}.default-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:white;font-size:32px;font-weight:700}.default-avatar .initial{font-size:32px;font-weight:700;text-transform:uppercase}.default-avatar.male{background:linear-gradient(135deg,#3498db 0%,#2980b9 100%)}.default-avatar.female{background:linear-gradient(135deg,#e91e63 0%,#c2185b 100%)}.member-name{font-size:.9rem;margin:8px 0 4px;color:#2c3e50;font-weight:600;white-space:normal;word-wrap:break-word;line-height:1.3}.member-age{font-size:.75rem;color:#7f8c8d;margin-bottom:4px}.member-dates{font-size:.7rem;color:#95a5a6;margin:4px 0}.view-profile-link{display:inline-block;margin-top:6px;font-size:.75rem;color:#3498db;text-decoration:none}.member-card:hover .view-profile-link{text-decoration:underline}.gender-icon{position:absolute;top:-8px;right:-8px;background:#fff;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 1px 3px rgba(0,0,0,.1);z-index:10}.horizontal-line{width:50px;height:2px;background:linear-gradient(90deg,#e74c3c,#f39c12);position:relative;margin:0 10px}.horizontal-line::before,.horizontal-line::after{content:"";position:absolute;width:6px;height:6px;background:#e74c3c;border-radius:50%;top:50%;transform:translateY(-50%)}.horizontal-line::before{left:-3px}.horizontal-line::after{right:-3px}.marriage-icon{position:absolute;top:-18px;left:50%;transform:translateX(-50%);font-size:11px;background:#fff;padding:1px 4px;border-radius:12px;white-space:nowrap}.vertical-line{width:2px;height:30px;background:linear-gradient(180deg,#95a5a6,#bdc3c7);margin:0 auto;position:relative}.children-wrapper{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;position:relative;margin-top:15px;padding-top:20px;min-width:max-content}.children-wrapper::before{content:"";position:absolute;top:0;left:5%;right:5%;height:2px;background:linear-gradient(90deg,transparent,#bdc3c7,#bdc3c7,transparent)}.horizontal-tree-layout{display:flex;justify-content:center;align-items:flex-start;gap:40px;flex-wrap:nowrap;overflow-x:auto;padding:20px 30px;min-height:500px;min-width:max-content}.generation-column{flex:0 0 auto;min-width:220px;position:relative;display:flex;flex-direction:column;align-items:center}.vertical-label{font-size:.85rem;padding:5px 12px;margin-bottom:15px}.vertical-members{display:flex;flex-direction:column;gap:25px;align-items:center;width:100%}.member-horizontal .member-card{min-width:170px;max-width:190px}.spouse-badge{font-size:.7rem;padding:2px 8px;margin-top:5px}.site-footer{background:var(--primary-color);color:white;padding:3rem 2rem 1rem;margin-top:3rem}.footer-container{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.footer-widget-area h3{margin-bottom:1rem;font-size:1.2rem}.footer-bottom{text-align:center;padding-top:2rem;margin-top:2rem;border-top:1px solid rgba(255,255,255,.1)}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.hidden{display:none}.clearfix::after{content:"";clear:both;display:table}.search-page-container{max-width:1200px;margin:50px auto;padding:0 20px}.search-page-header{text-align:center;margin-bottom:40px}.search-page-header h1{font-size:2rem;color:#2c3e50;margin-bottom:20px}.search-page-form{max-width:500px;margin:0 auto}.search-page-form form{display:flex}.search-page-form input{flex:1;padding:12px 15px;border:1px solid #ddd;border-radius:4px 0 0 4px;font-size:16px;outline:none}.search-page-form input:focus{border-color:#3498db}.search-page-form button{padding:12px 24px;background:#3498db;color:white;border:none;border-radius:0 4px 4px 0;cursor:pointer;font-size:16px;transition:background .3s}.search-page-form button:hover{background:#2980b9}.results-count{text-align:center;color:#3498db;font-weight:700;margin-bottom:30px;font-size:1rem}.search-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px;margin-bottom:40px}.search-result-card{background:#fff;border-radius:10px;transition:all .3s;box-shadow:0 2px 5px rgba(0,0,0,.05);border:1px solid #eee}.search-result-card:hover{transform:translateY(-3px);box-shadow:0 5px 15px rgba(0,0,0,.1);border-color:#3498db}.result-link{text-decoration:none;display:flex;padding:15px;gap:15px}.result-avatar{flex-shrink:0;width:70px;height:70px}.result-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.default-avatar{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:white;font-size:28px;font-weight:700}.default-avatar.male{background:linear-gradient(135deg,#3498db 0%,#2980b9 100%)}.default-avatar.female{background:linear-gradient(135deg,#e91e63 0%,#c2185b 100%)}.result-info{flex:1}.result-info h3{margin:0 0 5px;font-size:1rem;color:#2c3e50}.result-details{display:flex;gap:12px;font-size:.75rem;color:#7f8c8d;margin-bottom:8px;flex-wrap:wrap}.view-link{color:#3498db;font-size:.75rem;font-weight:500}.result-link:hover .view-link{text-decoration:underline}.no-results{text-align:center;padding:60px 20px;background:#f9f9f9;border-radius:12px}.no-results-content{max-width:400px;margin:0 auto}.search-icon{font-size:64px;display:block;margin-bottom:20px}.no-results h2{margin:0 0 10px;color:#2c3e50;font-size:1.3rem}.no-results p{color:#7f8c8d;margin-bottom:20px}.browse-tree-btn{display:inline-block;padding:10px 25px;background:#3498db;color:white;text-decoration:none;border-radius:6px;transition:background .3s}.browse-tree-btn:hover{background:#2980b9}.pagination{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #eee}.pagination .page-numbers{display:inline-block;padding:6px 12px;margin:0 3px;background:#f5f5f5;color:#666;text-decoration:none;border-radius:4px;transition:all .3s}.pagination .page-numbers.current{background:#3498db;color:white}.pagination .page-numbers:hover:not(.current){background:#e0e0e0}@media (max-width:768px){.search-results-grid{grid-template-columns:1fr}.result-link{flex-direction:column;text-align:center}.result-avatar{margin:0 auto}.search-page-header h1{font-size:1.5rem}.search-page-form input,.search-page-form button{font-size:14px;padding:10px 15px}}.member-profile-container{max-width:900px;margin:50px auto;padding:0 20px}.profile-header{display:flex;gap:30px;margin-bottom:40px;padding-bottom:30px;border-bottom:2px solid #ecf0f1}.profile-avatar{position:relative;flex-shrink:0}.profile-image{width:150px;height:150px;border-radius:50%;object-fit:cover;border:4px solid #fff;box-shadow:0 5px 15px rgba(0,0,0,.1)}.profile-info h1{font-size:2rem;margin:0 0 10px;color:#2c3e50}.profile-section{background:#f9f9f9;padding:25px;margin-bottom:30px;border-radius:12px}.profile-section h2{margin-top:0;margin-bottom:20px;color:#2c3e50}.profile-actions{display:flex;gap:15px;justify-content:center;margin-top:30px}.back-button,.edit-button{padding:10px 20px;border-radius:6px;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.back-button{background:#95a5a6;color:white}.edit-button{background:#3498db;color:white}@media (max-width:768px){.profile-header{flex-direction:column;text-align:center}.profile-avatar{margin:0 auto}.profile-actions{flex-direction:column}}.generation-row{animation:fadeInUp .5s ease-out}.member-card{animation:fadeInUp .3s ease-out}@media print{.family-tree-container{background:#fff;padding:0}.member-card{break-inside:avoid;page-break-inside:avoid}}