@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&display=swap";:root{--bg-primary: #fbf9f4;--bg-secondary: #ffffff;--bg-tertiary: #f0ede4;--text-primary: #2c2924;--text-secondary: #605951;--text-muted: #958c82;--gold-primary: #b8860b;--gold-light: #d4af37;--gold-dark: #8b6508;--gold-glow: rgba(184, 134, 11, .12);--accent-red: #8b0000;--accent-red-light: #c0392b;--color-male: #2980b9;--color-male-bg: rgba(41, 128, 185, .07);--color-male-border: rgba(41, 128, 185, .22);--color-female: #d81b60;--color-female-bg: rgba(216, 27, 96, .07);--color-female-border: rgba(216, 27, 96, .22);--color-deceased: #7f8c8d;--color-deceased-bg: rgba(127, 140, 141, .05);--color-deceased-border: rgba(127, 140, 141, .18);--glass-bg: rgba(255, 255, 255, .88);--glass-border: rgba(184, 134, 11, .18);--glass-shadow: rgba(44, 41, 36, .06);--font-serif: "Playfair Display", Georgia, serif;--font-sans: "Montserrat", Helvetica, Arial, sans-serif;--transition-fast: .2s ease;--transition-normal: .3s ease;--border-radius-sm: 6px;--border-radius-md: 12px;--border-radius-lg: 20px}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);overflow-x:hidden;line-height:1.6}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--border-radius-sm);border:1px solid var(--glass-border)}::-webkit-scrollbar-thumb:hover{background:var(--gold-primary)}.app-container{display:flex;min-height:100vh;position:relative}.main-content{flex:1;padding:24px;min-height:100vh;margin-left:260px;transition:padding var(--transition-normal)}.sidebar{width:260px;background-color:var(--bg-secondary);border-right:1px solid var(--glass-border);height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;padding:32px 16px;z-index:100;box-shadow:4px 0 24px #0006}.logo-container{display:flex;align-items:center;gap:12px;margin-bottom:48px;padding:0 8px}.logo-icon{color:var(--gold-primary);width:32px;height:32px;filter:drop-shadow(0 0 8px var(--gold-primary))}.logo-text{font-family:var(--font-serif);font-size:1.4rem;font-weight:700;color:var(--gold-primary);letter-spacing:1px}.logo-subtitle{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:2px;margin-top:-4px}.nav-links{display:flex;flex-direction:column;gap:8px}.nav-link{display:flex;align-items:center;gap:16px;padding:14px 18px;color:var(--text-secondary);text-decoration:none;font-size:.95rem;font-weight:500;border-radius:var(--border-radius-md);transition:all var(--transition-fast);cursor:pointer;border:1px solid transparent}.nav-link:hover{color:var(--text-primary);background-color:var(--bg-tertiary);transform:translate(4px)}.nav-link.active{color:var(--bg-primary);background-color:var(--gold-primary);font-weight:600;box-shadow:0 4px 14px var(--gold-glow);border:1px solid var(--gold-light)}.nav-link-icon{width:20px;height:20px}.sidebar-footer{margin-top:auto;text-align:center;font-size:.75rem;color:var(--text-muted);border-top:1px solid var(--bg-tertiary);padding-top:24px;line-height:1.4}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background-color:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--glass-border);display:none;justify-content:space-around;align-items:center;z-index:1000;box-shadow:0 -8px 24px #0006}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-secondary);text-decoration:none;font-size:.7rem;font-weight:500;cursor:pointer;flex:1;padding:8px 0;transition:color var(--transition-fast)}.bottom-nav-item:hover{color:var(--text-primary)}.bottom-nav-item.active{color:var(--gold-primary);font-weight:600}.bottom-nav-icon{width:22px;height:22px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px}.stats-card{background-color:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 4px 20px #00000026;transition:transform var(--transition-fast)}.stats-card:hover{transform:translateY(-4px);border-color:var(--glass-border)}.stats-icon-wrapper{padding:16px;border-radius:var(--border-radius-md);background-color:var(--bg-tertiary);color:var(--gold-primary)}.stats-info h3{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.stats-info p{font-size:1.8rem;font-weight:700;color:var(--text-primary)}.section-title{font-family:var(--font-serif);font-size:1.6rem;color:var(--gold-primary);margin-bottom:24px;display:flex;align-items:center;gap:12px}.anniversaries-container{background-color:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:24px;margin-bottom:32px;box-shadow:0 4px 20px #00000026}.anniversary-item{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--bg-tertiary);transition:background-color var(--transition-fast)}.anniversary-item:last-child{border-bottom:none}.anniversary-item:hover{background-color:var(--bg-tertiary);border-radius:var(--border-radius-sm)}.anniversary-person{display:flex;align-items:center;gap:16px}.anniversary-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--color-deceased);background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-weight:700}.anniversary-name{font-weight:600;font-size:1.05rem;color:var(--text-primary)}.anniversary-title{font-size:.8rem;color:var(--text-secondary)}.anniversary-days-left{text-align:right}.days-badge{background-color:var(--accent-red);color:#fff;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600;box-shadow:0 2px 8px #9e2a2b66}.days-badge.far{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--bg-tertiary);box-shadow:none}.anniversary-date{font-size:.8rem;color:var(--text-secondary);margin-top:4px}.search-filter-bar{background-color:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:20px;margin-bottom:24px;display:flex;flex-wrap:wrap;gap:16px;align-items:center}.search-input-wrapper{position:relative;flex:1;min-width:250px}.search-input{width:100%;background-color:var(--bg-tertiary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:14px 18px 14px 46px;color:var(--text-primary);font-family:var(--font-sans);font-size:.95rem;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--gold-primary);box-shadow:0 0 10px #d4af3726}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-secondary);width:20px;height:20px}.filter-group{display:flex;gap:12px;flex-wrap:wrap}.select-filter{background-color:var(--bg-tertiary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:14px 20px;color:var(--text-primary);font-family:var(--font-sans);font-size:.9rem;outline:none;cursor:pointer;transition:border-color var(--transition-fast)}.select-filter:focus{border-color:var(--gold-primary)}.btn{display:inline-flex;align-items:center;gap:8px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:14px 24px;font-family:var(--font-sans);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn:hover{background-color:var(--bg-secondary);border-color:var(--text-muted)}.btn-primary{background-color:var(--gold-primary);color:var(--bg-primary);border-color:var(--gold-light);font-weight:600}.btn-primary:hover{background-color:var(--gold-light);transform:translateY(-2px);box-shadow:0 4px 14px var(--gold-glow)}.btn-danger{background-color:var(--accent-red);color:#fff;border-color:var(--accent-red)}.btn-danger:hover{background-color:#bd3a42;box-shadow:0 4px 14px #9e2a2b4d}.directory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.member-card{background-color:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:20px;display:flex;gap:16px;cursor:pointer;position:relative;transition:all var(--transition-normal);box-shadow:0 4px 15px #0000001a;overflow:hidden}.member-card:after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--text-muted)}.member-card.male:after{background-color:var(--color-male)}.member-card.female:after{background-color:var(--color-female)}.member-card.deceased:after{background-color:var(--color-deceased)}.member-card:hover{transform:translateY(-4px);border-color:var(--gold-primary);box-shadow:0 8px 24px #d4af371a}.card-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid var(--bg-tertiary);background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-weight:700;font-size:1.2rem}.member-card.male .card-avatar{border-color:var(--color-male)}.member-card.female .card-avatar{border-color:var(--color-female)}.member-card.deceased .card-avatar{border-color:var(--color-deceased);filter:grayscale(1)}.card-info{flex:1;display:flex;flex-direction:column;justify-content:center}.card-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.card-title{font-size:.8rem;color:var(--gold-primary);font-weight:500;margin-bottom:4px}.card-generation{font-size:.75rem;color:var(--text-secondary)}.card-life-span{font-size:.75rem;color:var(--text-muted);margin-top:2px}.tree-view-container{height:calc(100vh - 100px);background-color:#f3f0e6;border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-lg);overflow:hidden;position:relative;box-shadow:inset 0 0 24px #2c29240f}.tree-instructions{position:absolute;top:16px;left:16px;background-color:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);padding:10px 16px;border-radius:var(--border-radius-md);font-size:.8rem;color:var(--text-secondary);z-index:10;pointer-events:none;box-shadow:0 2px 10px #0000000d}.tree-controls{position:absolute;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:10}.tree-control-btn{width:44px;height:44px;border-radius:50%;background-color:var(--bg-secondary);border:1px solid var(--glass-border);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #2c292414;transition:all var(--transition-fast)}.tree-control-btn:hover{background-color:var(--gold-primary);color:var(--bg-secondary);transform:scale(1.05)}.tree-viewport{width:100%;height:100%;cursor:grab;position:relative;background-image:radial-gradient(rgba(184,134,11,.12) 1.5px,transparent 1.5px);background-size:28px 28px}.tree-viewport:active{cursor:grabbing}.tree-canvas{position:absolute;transform-origin:0 0;-webkit-user-select:none;user-select:none}.tree-connector-lines{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.connector-line{fill:none;stroke:#b8860b38;stroke-width:2.5;stroke-linecap:round;transition:stroke var(--transition-normal)}.connector-line.highlighted{stroke:var(--gold-primary);stroke-width:3.5}.tree-node-wrapper{position:absolute;transform:translate(-50%,-50%);z-index:5}.tree-node{background-color:var(--bg-secondary);border:1.5px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:12px 16px;width:200px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 15px #2c292414;transition:all var(--transition-fast);cursor:pointer}.tree-node:hover{border-color:var(--gold-primary);box-shadow:0 6px 18px #b8860b33;transform:translateY(-2px)}.tree-node.male{border-left:4px solid var(--color-male)}.tree-node.female{border-left:4px solid var(--color-female)}.tree-node.deceased{border-left:4px solid var(--color-deceased);opacity:.85}.tree-node-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-weight:700;font-size:.9rem}.tree-node-info{flex:1;overflow:hidden}.tree-node-name{font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node-title{font-size:.7rem;color:var(--gold-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node-lifespan{font-size:.65rem;color:var(--text-muted)}.spouse-connection-line{fill:none;stroke:var(--color-female-border);stroke-width:2;stroke-dasharray:4 4}.focus-view-container{display:flex;flex-direction:column;gap:24px;align-items:center;padding:12px 0}.focus-view-instructions{text-align:center;font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.focus-level{display:flex;justify-content:center;gap:16px;width:100%;flex-wrap:wrap}.focus-level-label{width:100%;text-align:center;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:-8px}.focus-node-card{background-color:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:16px 20px;width:260px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 15px #0003}.focus-node-card:hover{border-color:var(--gold-primary);transform:translateY(-2px)}.focus-node-card.center{border:2px solid var(--gold-primary);background-color:var(--bg-tertiary);box-shadow:0 0 20px var(--gold-glow);width:280px}.focus-node-card.male{border-left:4px solid var(--color-male)}.focus-node-card.female{border-left:4px solid var(--color-female)}.focus-node-card.deceased{border-left:4px solid var(--color-deceased);opacity:.85}.focus-arrow{display:flex;justify-content:center;align-items:center;color:var(--gold-primary);height:20px}.focus-arrow-icon{width:24px;height:24px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;justify-content:center;align-items:center;padding:20px;animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--border-radius-lg);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0009;position:relative;animation:slideUp var(--transition-normal)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close-btn{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);z-index:10}.modal-close-btn:hover{color:var(--text-primary)}.detail-header{position:relative;padding:40px 32px 32px;background:linear-gradient(180deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border-bottom:1px solid var(--bg-tertiary);display:flex;flex-direction:column;align-items:center;text-align:center}.detail-avatar-wrapper{position:relative;margin-bottom:16px}.detail-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--gold-primary);box-shadow:0 4px 15px #0000004d}.detail-avatar.male{border-color:var(--color-male)}.detail-avatar.female{border-color:var(--color-female)}.detail-avatar.deceased{border-color:var(--color-deceased);filter:grayscale(1)}.detail-gender-badge{position:absolute;bottom:0;right:8px;background-color:var(--bg-tertiary);padding:6px;border-radius:50%;border:1px solid var(--bg-tertiary)}.detail-name{font-family:var(--font-serif);font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.detail-title-badge{background-color:var(--gold-primary);color:var(--bg-primary);padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;margin-bottom:8px}.detail-generation-text{font-size:.85rem;color:var(--text-secondary)}.detail-body{padding:32px}.detail-section{margin-bottom:28px}.detail-section-title{font-size:.9rem;color:var(--gold-primary);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;border-bottom:1px solid var(--bg-tertiary);padding-bottom:6px;font-weight:600}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column}.detail-label{font-size:.75rem;color:var(--text-muted);margin-bottom:2px}.detail-value{font-size:.95rem;color:var(--text-primary);font-weight:500}.biography-text{font-size:.95rem;color:var(--text-secondary);line-height:1.7;white-space:pre-line}.relations-list{display:flex;flex-direction:column;gap:10px}.relation-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background-color:var(--bg-tertiary);border-radius:var(--border-radius-md);border:1px solid transparent;transition:border-color var(--transition-fast)}.relation-row:hover{border-color:var(--gold-primary)}.relation-label{font-size:.8rem;color:var(--text-secondary)}.relation-name{font-size:.9rem;font-weight:600;color:var(--gold-primary);cursor:pointer}.relation-name:hover{text-decoration:underline;color:var(--gold-light)}.form-container{display:flex;flex-direction:column;gap:20px;padding:24px}.form-title{font-family:var(--font-serif);font-size:1.5rem;color:var(--gold-primary);border-bottom:1px solid var(--bg-tertiary);padding-bottom:12px;margin-bottom:8px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:1 / -1}.form-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea{background-color:var(--bg-tertiary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:12px 16px;color:var(--text-primary);font-family:var(--font-sans);font-size:.9rem;outline:none;transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold-primary)}.form-textarea{min-height:120px;resize:vertical}.form-checkbox-group{flex-direction:row;align-items:center;gap:10px;padding:12px 0}.form-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--gold-primary)}.avatar-upload-wrapper{display:flex;align-items:center;gap:20px;padding:10px 0}.avatar-preview{width:70px;height:70px;border-radius:50%;object-fit:cover;border:2px solid var(--bg-tertiary);background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:1.2rem}.file-input-btn{position:relative;overflow:hidden}.file-input-btn input[type=file]{position:absolute;top:0;right:0;min-width:100%;min-height:100%;font-size:100px;text-align:right;filter:alpha(opacity=0);opacity:0;outline:none;cursor:pointer;display:block}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;border-top:1px solid var(--bg-tertiary);padding-top:20px}.settings-panel{background-color:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--border-radius-md);padding:24px;margin-bottom:24px;box-shadow:0 4px 20px #00000026}.settings-description{font-size:.9rem;color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.settings-actions{display:flex;gap:16px;flex-wrap:wrap}@media (max-width: 768px){.sidebar{display:none}.bottom-nav{display:flex}.main-content{margin-left:0;padding:16px 16px 90px}.search-filter-bar{flex-direction:column;align-items:stretch}.filter-group{flex-direction:column}.select-filter,.btn{width:100%}.modal-content{max-height:95vh}.detail-body{padding:20px}.detail-name{font-size:1.5rem}}.tree-search-container{position:absolute;top:16px;right:16px;z-index:100;width:280px}.tree-search-input-wrapper{position:relative;display:flex;align-items:center}.tree-search-input{width:100%;background-color:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1.5px solid var(--glass-border);border-radius:var(--border-radius-md);padding:10px 16px 10px 38px;color:var(--text-primary);font-family:var(--font-sans);font-size:.85rem;outline:none;transition:all var(--transition-fast);box-shadow:0 4px 15px var(--glass-shadow)}.tree-search-input:focus{border-color:var(--gold-primary);box-shadow:0 4px 18px #b8860b26;background-color:var(--bg-secondary)}.tree-search-icon{position:absolute;left:12px;color:var(--text-secondary);width:16px;height:16px;pointer-events:none}.tree-search-clear{position:absolute;right:12px;color:var(--text-muted);width:16px;height:16px;cursor:pointer;transition:color var(--transition-fast)}.tree-search-clear:hover{color:var(--accent-red-light)}.tree-search-results{position:absolute;top:108%;left:0;right:0;background-color:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1.5px solid var(--glass-border);border-radius:var(--border-radius-md);max-height:280px;overflow-y:auto;box-shadow:0 8px 24px #2c292414;display:flex;flex-direction:column;padding:6px 0;z-index:110}.tree-search-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background-color var(--transition-fast)}.tree-search-item:hover{background-color:var(--bg-tertiary)}.tree-search-item-info{display:flex;flex-direction:column;overflow:hidden}.tree-search-item-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-search-item-gen{font-size:.7rem;color:var(--text-secondary)}
