:root{--primary-color: #0f172a;--secondary-color: #1e293b;--accent-color: #d4af37;--text-primary: #f8fafc;--text-secondary: #94a3b8;--bg-gradient: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);--card-bg: rgba(30, 41, 59, .7);--glass-border: 1px solid rgba(255, 255, 255, .1);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--font-main: "Outfit", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background:var(--bg-gradient);color:var(--text-primary);min-height:100vh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:700;color:var(--accent-color);letter-spacing:-.025em}a{color:var(--accent-color);text-decoration:none}button{cursor:pointer;border:none;font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--secondary-color)}::-webkit-scrollbar-thumb{background:var(--accent-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#b5952f}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}.modal-content{background:#1e293bf2;padding:2.5rem;border-radius:20px;width:500px;max-width:90%;max-height:90vh;overflow-y:auto;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 50px #00000080,0 0 0 1px #ffffff1a inset;color:var(--text-primary);position:relative;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem}.modal-header h2{margin:0;font-size:1.8rem;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:700;letter-spacing:-.5px}.modal-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:1rem;background:#ffffff0d;padding:10px;border-radius:8px;border:1px dashed rgba(255,255,255,.1)}.modal-subtitle strong{color:var(--accent-color);font-weight:600}.close-btn{background:transparent;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;transition:all .2s;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}.close-btn:hover{color:#ef4444;background:#ef44441a;transform:rotate(90deg)}.form-group{margin-bottom:1.2rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0003;color:#fff;font-size:1rem;transition:all .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color);background:#0006;box-shadow:0 0 0 3px #d4af3726}.form-group input::placeholder,.form-group textarea::placeholder{color:#ffffff4d}.highlight-group{background:linear-gradient(to right,rgba(212,175,55,.1),transparent);padding:15px;border-radius:12px;border-left:3px solid var(--accent-color);margin-bottom:1.5rem}.highlight-select{border-color:var(--accent-color)!important;background:#d4af370d!important}.form-row{display:flex;gap:1.5rem}.form-row .form-group{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.cancel-btn{background:transparent;color:var(--text-secondary);border:1px solid rgba(255,255,255,.2);padding:12px 24px;border-radius:12px;cursor:pointer;font-weight:500;transition:all .2s}.cancel-btn:hover{background:#ffffff0d;color:#fff;border-color:#fff6}.save-btn{background:linear-gradient(135deg,var(--accent-color) 0%,#b4932a 100%);color:#1a1a1a;border:none;padding:12px 32px;border-radius:12px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #d4af374d}.save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4af3766;filter:brightness(1.1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:#0000001a}.modal-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.modal-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.login-modal-content{background:#1e293bf2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080;padding:3rem 2rem;max-width:400px;width:90%;border-radius:20px;position:relative;overflow:hidden}.login-modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,var(--accent-color),transparent)}.close-btn-icon{position:absolute;top:15px;right:15px;background:transparent;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;transition:all .2s;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}.close-btn-icon:hover{background:#ffffff1a;color:#fff}.login-header{text-align:center;margin-bottom:2rem}.login-icon{font-size:3rem;margin-bottom:1rem;display:inline-block;filter:drop-shadow(0 0 10px rgba(212,175,55,.3))}.login-header h2{color:var(--text-primary);font-size:1.8rem;margin-bottom:.5rem;font-weight:700}.login-header p{color:var(--text-secondary);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.2rem}.input-group{position:relative}.input-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-size:1.1rem;opacity:.7;pointer-events:none}.input-group input{width:100%;padding:12px 15px 12px 45px;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1rem;transition:all .3s;box-sizing:border-box}.input-group input:focus{outline:none;border-color:var(--accent-color);background:#0000004d;box-shadow:0 0 0 4px #d4af371a}.input-group input::placeholder{color:#ffffff4d}.login-submit-btn{background:linear-gradient(135deg,#d4af37,#fcd34d);color:#0f172a;border:none;padding:14px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s;margin-top:1rem;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 15px #d4af374d}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #d4af3766}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#f87171;padding:10px;border-radius:8px;font-size:.9rem;text-align:center;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.loader{width:20px;height:20px;border:3px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:#0f172a;display:inline-block;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-container{height:100vh;display:flex;flex-direction:column;align-items:center;padding:0;overflow:hidden}.navbar{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem 1.2rem;background:linear-gradient(135deg,#0f172af2,#1e293bf2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(212,175,55,.15);flex-shrink:0;z-index:20;gap:12px}.navbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.navbar-logo{font-size:1.6rem;filter:drop-shadow(0 2px 4px rgba(212,175,55,.3))}.navbar-title h1{font-size:1.15rem;text-transform:uppercase;letter-spacing:.08em;margin:0;line-height:1.2;background:linear-gradient(135deg,#d4af37,#f0d060);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.navbar-title p{color:var(--text-secondary);font-size:.7rem;margin:0;opacity:.7}.navbar-center{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;flex:1;min-width:0}.navbar-divider{width:1px;height:24px;background:#ffffff1f;flex-shrink:0}.navbar-auth{flex-shrink:0}.auth-btn{padding:6px 14px;border-radius:20px;font-weight:600;cursor:pointer;border:none;transition:all .2s;font-size:.8rem;white-space:nowrap}.auth-btn.login{background:var(--accent-color);color:var(--primary-color)}.auth-btn.login:hover{background:#fcd34d;box-shadow:0 0 10px #d4af3766}.user-info{display:flex;align-items:center;gap:8px;background:#1e293b99;padding:4px 12px;border-radius:30px;border:1px solid rgba(255,255,255,.1)}.user-avatar{font-size:.9rem}.user-name{font-size:.8rem;color:var(--text-secondary)}.auth-btn.logout{background:transparent;color:#ef4444;border:1px solid #ef4444;padding:4px 10px;font-size:.75rem}.auth-btn.logout:hover{background:#ef4444;color:#fff}.export-group{display:flex;gap:6px;align-items:center}.tab-switcher{display:flex;gap:2px;background:#00000059;border-radius:10px;padding:3px}.tab-btn{padding:6px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:.8rem;border-radius:8px;cursor:pointer;transition:all .25s;font-weight:500;display:flex;align-items:center;gap:5px}.tab-icon{font-size:.85rem}.tab-label{white-space:nowrap}.tab-btn.active{background:var(--accent-color);color:#1a1a2e;font-weight:700;box-shadow:0 2px 8px #d4af374d}.tab-btn:hover:not(.active){background:#ffffff14;color:#fff}.member-list-container{padding:1rem;max-width:1200px;margin:0 auto;width:100%}.member-list-stats{display:flex;gap:20px;justify-content:center;padding:10px;background:#ffffff0a;border-radius:10px;margin-bottom:12px;font-size:.85rem;color:var(--text-secondary)}.member-list-filters{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:8px 14px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0d;color:#fff;font-size:.85rem;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--accent-color)}.search-input::placeholder{color:#ffffff59}.filter-select{padding:8px 12px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0d;color:#fff;font-size:.85rem;cursor:pointer;outline:none}.filter-select option{background:#1e293b;color:#fff}.member-list-table{border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.member-list-header{display:grid;grid-template-columns:60px 1fr 80px 130px 1fr 70px;padding:10px 14px;background:#d4af371f;font-weight:700;font-size:.75rem;color:var(--accent-color);text-transform:uppercase;letter-spacing:.5px}.member-list-row{display:grid;grid-template-columns:60px 1fr 80px 130px 1fr 70px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.04);align-items:center;font-size:.85rem;cursor:pointer;transition:background .2s}.member-list-row:hover{background:#ffffff0f}.member-list-row:last-child{border-bottom:none}.col-gen{text-align:center}.gen-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,#d4af37,#b8860b);color:#1a1a2e;border-radius:50%;font-weight:700;font-size:.8rem}.col-name{display:flex;align-items:center;gap:10px}.list-avatar{width:32px;height:32px;border-radius:50%;border:2px solid rgba(212,175,55,.3);flex-shrink:0}.col-name span{display:flex;flex-direction:column}.member-title-tag{font-size:.7rem;color:var(--accent-color);font-style:italic}.mother-tag{font-size:.7rem;color:#fbbf24;opacity:.7}.col-gender,.col-dates,.col-spouse,.col-children{color:var(--text-secondary)}.col-children{text-align:center}.member-list-empty{padding:40px;text-align:center;color:var(--text-secondary);font-style:italic}.rel-section{margin-top:8px;padding-top:15px;border-top:1px solid rgba(255,255,255,.08)}.rel-title{font-size:1rem;margin-bottom:12px;color:var(--accent-color)}.rel-group{margin-bottom:12px}.rel-group-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.rel-cards{display:flex;flex-wrap:wrap;gap:6px}.rel-mini-card{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:8px;transition:background .2s;min-width:140px}.rel-mini-card:hover{background:#ffffff1a}.rel-avatar{width:30px;height:30px;border-radius:50%;border:2px solid rgba(212,175,55,.3);flex-shrink:0}.rel-info{display:flex;flex-direction:column;font-size:.8rem}.rel-info strong{color:#fff;font-size:.8rem}.rel-label{color:var(--text-secondary);font-size:.65rem}.rel-spouse{color:#fbbf24;font-size:.65rem;opacity:.8}.navbar .tree-controls{margin-top:0}.searchable-select{position:relative;min-width:200px;max-width:260px}.ss-display{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:8px;background:#ffffff0f;color:#fff;font-size:.8rem;cursor:pointer;gap:8px}.ss-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ss-arrow{font-size:.6rem;opacity:.5}.ss-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#1e293b;border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:100;overflow:hidden}.ss-search{width:100%;padding:8px 12px;border:none;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#fff;font-size:.8rem;outline:none;box-sizing:border-box}.ss-search::placeholder{color:#ffffff59}.ss-options{max-height:250px;overflow-y:auto}.ss-option{padding:7px 12px;font-size:.8rem;cursor:pointer;transition:background .15s;color:var(--text-secondary)}.ss-option:hover{background:#ffffff14;color:#fff}.ss-option.selected{background:#d4af3726;color:var(--accent-color);font-weight:600}.ss-no-result{padding:12px;text-align:center;color:var(--text-secondary);font-size:.8rem;font-style:italic}.tree-container{display:block;padding-top:.5rem;width:100%;overflow:auto;flex:1}.tree-wrapper{position:relative;padding:10px 0;width:fit-content;margin:0 auto}.tree ul{padding-top:20px;position:relative;transition:all .5s;display:flex;justify-content:center}.tree li{float:left;text-align:center;list-style-type:none;position:relative;padding:15px 1px 0;transition:all .5s}.tree li:before,.tree li:after{content:"";position:absolute;top:0;right:50%;border-top:1px solid var(--text-secondary);width:50%;height:20px}.tree li:after{right:auto;left:50%;border-left:1px solid var(--text-secondary)}.tree li:only-child:after,.tree li:only-child:before{display:none}.tree li:only-child{padding-top:0}.tree li:first-child:before,.tree li:last-child:after{border:0 none}.tree li:last-child:before{border-right:1px solid var(--text-secondary);border-radius:0 5px 0 0}.tree li:first-child:after{border-radius:5px 0 0}.tree ul ul:before{content:"";position:absolute;top:0;left:50%;border-left:1px solid var(--text-secondary);width:0;height:20px}.member-card{border:var(--glass-border);background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.6rem;border-radius:10px;display:inline-block;min-width:130px;transition:all .3s ease;cursor:pointer;box-shadow:var(--shadow);position:relative;z-index:5}.generation-badge{background:linear-gradient(135deg,#d4af37,#b8860b);color:#1a1a2e;font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:10px;text-align:center;margin-bottom:4px;letter-spacing:.5px}.member-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0003;border-color:var(--accent-color)}.member-avatar{width:45px;height:45px;border-radius:50%;border:2px solid var(--accent-color);margin:0 auto .4rem;overflow:hidden;background:var(--secondary-color)}.member-avatar img{width:100%;height:100%;object-fit:cover}.member-info h3{font-size:.85rem;color:var(--text-primary);margin-bottom:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.member-info p{font-size:.7rem;color:var(--text-secondary);margin-bottom:1px}.member-generation{display:inline-block;background:#d4af3726;color:var(--accent-color);padding:2px 8px;border-radius:12px;font-size:.7rem;margin-top:.5rem;font-weight:600}.export-pdf-btn{padding:8px 18px;border-radius:10px;font-weight:600;cursor:pointer;border:none;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;transition:all .25s ease;display:flex;align-items:center;gap:8px;font-size:.82rem;white-space:nowrap;box-shadow:0 2px 8px #e74c3c40;position:relative;overflow:hidden}.export-pdf-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .4s ease}.export-pdf-btn:hover:not(:disabled):before{left:100%}.export-pdf-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #e74c3c66;background:linear-gradient(135deg,#ff5744,#e74c3c)}.export-pdf-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #e74c3c4d}.export-pdf-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.export-word-btn{display:flex;align-items:center;gap:8px;padding:8px 18px;background:linear-gradient(135deg,#2b579a,#1e3f73);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .25s ease;font-size:.82rem;white-space:nowrap;box-shadow:0 2px 8px #2b579a40;position:relative;overflow:hidden}.export-word-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .4s ease}.export-word-btn:hover:not(:disabled):before{left:100%}.export-word-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #2b579a66;background:linear-gradient(135deg,#3568b8,#2b579a)}.export-word-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #2b579a4d}.export-word-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.tree-controls{display:flex;gap:6px;margin-top:0}.control-btn{padding:6px 12px;border-radius:20px;font-weight:500;cursor:pointer;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;gap:5px;font-size:.8rem;white-space:nowrap}.control-btn:hover{background:#ffffff1a;color:var(--text-primary);border-color:#fff6}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:100;animation:fadeIn .3s ease}.modal-content{background:#1e293b;border:1px solid var(--accent-color);border-radius:16px;width:90%;max-width:500px;padding:2rem;position:relative;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideIn .3s ease}.close-btn{position:absolute;top:1rem;right:1rem;background:transparent;color:var(--text-secondary);font-size:1.5rem;transition:color .2s}.close-btn:hover{color:var(--accent-color)}.modal-header{text-align:center;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem}.modal-avatar{width:100px;height:100px;border-radius:50%;border:3px solid var(--accent-color);margin:0 auto 1rem;overflow:hidden}.modal-avatar img{width:100%;height:100%;object-fit:cover}.modal-body .detail-row{display:flex;justify-content:space-between;margin-bottom:.8rem;border-bottom:1px dashed rgba(255,255,255,.1);padding-bottom:.5rem}.modal-body .label{color:var(--text-secondary)}.modal-body .value{color:var(--text-primary);font-weight:600}.bio-section{margin-top:1.5rem;background:#0003;padding:1rem;border-radius:8px}.bio-section h4{font-size:.9rem;margin-bottom:.5rem;color:var(--accent-color)}.bio-section p{font-size:.9rem;color:var(--text-secondary);line-height:1.5}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.app-container{padding:.5rem}.navbar{flex-wrap:wrap;padding:.4rem .8rem;gap:8px}.navbar-brand{width:100%;justify-content:center}.navbar-title h1{font-size:1rem}.navbar-title p{font-size:.6rem}.navbar-center{gap:6px}.navbar-divider{display:none}.navbar-auth{position:absolute;top:8px;right:10px}.auth-btn{padding:4px 10px;font-size:.7rem}.tab-btn{padding:5px 10px;font-size:.75rem}.tab-label{display:none}.export-pdf-btn,.export-word-btn{padding:5px 10px;font-size:.7rem;border-radius:15px}.control-btn{padding:4px 10px;font-size:.7rem}.tree-container{padding-top:.3rem}.member-card{min-width:110px;padding:.4rem}.member-avatar{width:35px;height:35px;margin-bottom:.2rem}.member-info h3{font-size:.75rem;max-width:100px}.member-info p{font-size:.6rem}.add-btn{padding:2px 6px;font-size:.6rem}.tree li{padding:10px 0 0}.tree ul{padding-top:15px}.tree li:before,.tree li:after{height:15px}.tree ul ul:before{height:15px}.expand-toggle{width:20px;height:20px;font-size:1rem;bottom:-10px}.admin-controls{position:fixed;bottom:15px;right:15px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end}.admin-toggle{background:#1e293be6;color:var(--text-secondary);border:1px solid rgba(255,255,255,.1);padding:8px 12px;border-radius:30px;font-size:.8rem;transition:all .2s;box-shadow:0 4px 6px #0003}.admin-toggle:hover{background:var(--secondary-color);color:var(--text-primary)}.admin-menu{margin-bottom:10px;background:#1e293b;border:1px solid var(--glass-border);padding:12px;border-radius:12px;box-shadow:0 10px 25px #00000080;animation:slideUp .3s ease;min-width:200px}.danger-btn{background:#ef4444;color:#fff;width:100%;padding:8px;border-radius:6px;font-weight:600}.danger-btn:hover{background:#dc2626}.note{font-size:.7rem;color:var(--text-secondary);margin-top:6px;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-group{margin-bottom:.8rem}.form-group label{display:block;margin-bottom:.4rem;color:var(--text-secondary)}.form-group input,.form-group select{width:100%;padding:.6rem;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-color)}.submit-btn{width:100%;padding:.8rem;background:var(--accent-color);color:#0f172a;font-weight:700;border-radius:8px;margin-top:.8rem;transition:all .2s}.submit-btn:hover{background:#f0c430;transform:translateY(-2px)}.spouse-tag{display:block;font-size:.65rem;color:#e2e8f0;margin-top:2px}.modal-content{width:95%;padding:1.2rem}.modal-avatar{width:70px;height:70px}}@media(max-width:480px){.app-container{padding:.3rem}.navbar{padding:.3rem .5rem;gap:6px}.navbar-title h1{font-size:.9rem}.navbar-logo{font-size:1.2rem}.navbar-center{gap:4px}.export-pdf-btn,.export-word-btn{padding:4px 8px;font-size:.65rem;gap:3px}.control-btn{padding:3px 8px;font-size:.65rem}.member-card{min-width:90px;padding:.3rem}.member-avatar{width:28px;height:28px;margin-bottom:.1rem}.member-info h3{font-size:.65rem;max-width:80px}.member-info p{font-size:.55rem}.member-generation{font-size:.6rem;padding:1px 5px}.add-btn{padding:2px 4px;font-size:.55rem;margin-top:.3rem}.user-info{padding:3px 8px;gap:5px;font-size:.75rem}.user-info span{display:none}}.add-btn{margin-top:.5rem;background:linear-gradient(135deg,#d4af371a,#d4af370d);border:1px solid rgba(212,175,55,.4);color:var(--accent-color);padding:4px 8px;border-radius:15px;font-size:.65rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0000001a}.add-btn:hover{background:linear-gradient(135deg,var(--accent-color) 0%,#b4932a 100%);color:#1a1a1a;border-color:transparent;transform:translateY(-2px);box-shadow:0 4px 10px #d4af374d}.add-btn:active{transform:translateY(0)}.spouse-tag{display:block;font-size:.75rem;color:#e2e8f0;margin-top:2px}.node-wrapper{display:flex;flex-direction:column;align-items:center;position:relative}.expand-toggle{width:24px;height:24px;border-radius:50%;background:var(--secondary-color);color:var(--accent-color);border:1px solid var(--accent-color);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;cursor:pointer;position:absolute;bottom:-12px;left:50%;transform:translate(-50%);z-index:10;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 2px 8px #0000004d}.expand-toggle:hover{background:var(--accent-color);color:var(--primary-color);transform:translate(-50%) scale(1.15);box-shadow:0 0 12px #d4af3780}.expand-toggle.expanded{background:var(--primary-color);transform:translate(-50%) rotate(180deg)}.expand-toggle.expanded:hover{background:#ef4444;border-color:#ef4444;color:#fff;transform:translate(-50%) rotate(180deg) scale(1.15)}.tree li.collapsed:before,.tree li.collapsed:after,.tree li.collapsed ul:before{display:none}.detail-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px;align-items:center}.label{color:#cbd5e1;font-weight:500}.value{color:#fff;font-weight:600}.action-btn{border:none;padding:12px 20px;border-radius:12px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;font-size:1rem;text-transform:uppercase;letter-spacing:.5px}.action-btn:hover{transform:translateY(-2px);filter:brightness(1.2)}.action-btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#fbbf24,#d97706);color:#0f172a;border:2px solid #fcd34d;box-shadow:0 4px 15px #fbbf2466;flex:2}.btn-primary:hover{background:linear-gradient(135deg,#fcd34d,#b45309);box-shadow:0 6px 20px #fbbf2499;border-color:#fff}.btn-secondary{background:#ffffff1a;border:2px solid rgba(255,255,255,.5);color:#fff;flex:1}.btn-secondary:hover{background:#fff3;border-color:#fff}.btn-danger{background:#ef444433;border:2px solid #ef4444;color:#fca5a5;flex:1}.btn-danger:hover{background:#ef4444;color:#fff;box-shadow:0 4px 12px #ef444466}.edit-spouse-btn{background:#fbbf24;border:1px solid #d97706;color:#0f172a;border-radius:6px;padding:4px 8px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s;margin-left:10px;box-shadow:0 2px 4px #0003;display:inline-flex;align-items:center;gap:4px}.edit-spouse-btn:hover{background:#fcd34d;transform:scale(1.05);box-shadow:0 4px 8px #fbbf2466}.detail-section strong{color:#fbbf24;font-size:1.1rem;display:block;margin-bottom:8px;border-bottom:1px solid rgba(251,191,36,.3);padding-bottom:4px}.detail-section p{color:#e2e8f0}.exporting-pdf .add-btn,.exporting-pdf .expand-toggle,.exporting-pdf .admin-controls,.exporting-pdf .tree-controls,.exporting-pdf .navbar-auth{display:none!important}.exporting-pdf{padding:60px!important;background-color:#0f172a!important;width:fit-content!important;height:fit-content!important;overflow:visible!important}
