*{margin:0;padding:0;box-sizing:border-box}body{font-family:Caveat,cursive;background:#fff;color:#000;font-size:20px;line-height:1.3}.app{min-height:100vh;display:flex;flex-direction:column}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.6rem}.navbar{display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #000;padding:8px 24px;background:#fff}.nav-left{display:flex;gap:4px}.nav-link{color:#000;text-decoration:none;padding:6px 14px;font-size:1.3rem;font-weight:500;border:1px solid transparent;transition:border-color .15s}.nav-link:hover{border-color:#000}.nav-right{display:flex;align-items:center;gap:16px}.nav-email{font-size:1rem;color:#555}.nav-logout-btn{background:#fff;color:#000;border:1px solid #000;padding:4px 14px;cursor:pointer;font-family:Caveat,cursive;font-size:1.1rem;transition:background .15s}.nav-logout-btn:hover{background:#000;color:#fff}.main-content{flex:1}.form-group{margin-bottom:14px}.form-group label{display:block;margin-bottom:3px;font-weight:600;font-size:1.15rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:8px 10px;border:1px solid #000;background:#fff;font-family:Caveat,cursive;font-size:1.1rem;color:#000}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:2px solid #000;outline-offset:-2px}.form-group textarea{resize:vertical;min-height:80px}.btn{padding:8px 18px;border:1px solid #000;background:#fff;color:#000;cursor:pointer;font-family:Caveat,cursive;font-size:1.1rem;font-weight:600;transition:all .15s}.btn:hover:not(:disabled){background:#000;color:#fff}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#000;color:#fff}.btn-primary:hover:not(:disabled){background:#333}.btn-secondary{background:#fff;color:#000}.btn-danger{background:#fff;color:#000;border:1px solid #000}.error-msg{color:#000;font-size:1rem;margin-top:6px;font-weight:600;text-decoration:underline}.success-msg{color:#000;font-size:1rem;margin-top:6px;font-style:italic}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:24px;background:#fff}.login-container{width:100%;max-width:440px}.login-card,.contact-card{background:#fff;border:2px solid #000;padding:32px;margin-bottom:20px}.login-card h1{font-size:2.2rem;margin-bottom:20px;text-align:center;font-weight:700;letter-spacing:1px}.contact-card h2{font-size:1.3rem;margin-bottom:6px;font-weight:600}.contact-card p{font-size:1.05rem;margin-bottom:14px}.register-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:24px}.register-card{background:#fff;border:2px solid #000;padding:32px;width:100%;max-width:440px}.register-card h1{font-size:2rem;margin-bottom:6px;text-align:center;font-weight:700}.register-card .subtitle{text-align:center;margin-bottom:20px;font-size:1.05rem}.home-page{max-width:720px;margin:0 auto;padding:48px 24px}.home-hero{border:2px solid #000;padding:48px 40px;text-align:center;background:#fff}.home-hero h1{font-size:2.8rem;margin-bottom:12px;font-weight:700}.home-hero .home-image-placeholder{width:180px;height:180px;border:2px solid #000;margin:20px auto;display:flex;align-items:center;justify-content:center;font-size:1rem}.home-hero p{font-size:1.3rem;line-height:1.4;margin-bottom:20px;max-width:560px;margin-left:auto;margin-right:auto}.home-hero .btn{font-size:1.4rem;padding:12px 36px}.tree-page{padding:24px;overflow-x:auto;background:#fff}.tree-controls{display:flex;justify-content:center;gap:12px;margin-bottom:20px;align-items:center}.tree-controls span{font-size:1.15rem}.tree-container{display:flex;justify-content:center;padding:20px 0}.tree{position:relative}.tree ul{padding-top:24px;position:relative;display:flex;justify-content:center;list-style:none}.tree li{display:flex;flex-direction:column;align-items:center;position:relative;padding:24px 8px 0}.tree li:before,.tree li:after{content:"";position:absolute;top:0;width:50%;height:24px;border-top:1px solid #000}.tree li:before{right:50%;border-right:1px solid #000}.tree li:after{left:50%}.tree li:only-child:before,.tree li:only-child:after{border-top:none}.tree li:only-child:before{border-right:1px solid #000}.tree li:first-child:before{border-top:none;border-right:1px solid #000}.tree li:last-child:after{border-top:none}.tree ul:before{content:"";position:absolute;top:0;left:50%;border-left:1px solid #000;height:24px}.tree>ul:before{display:none}.tree>ul>li:before,.tree>ul>li:after{display:none}.tree-ancestors,.tree-ancestors .person-node{transform:scaleY(-1)}.person-node{border:1px solid #000;padding:6px 14px;cursor:pointer;text-align:center;min-width:110px;position:relative;background:#fff;transition:background .15s}.person-node:hover{background:#f0f0f0}.person-node .person-name{font-weight:700;font-size:1.15rem}.person-node .person-dates{font-size:.95rem;margin-top:1px;font-weight:400}.person-node.is-root{border-width:2px;background:#000;color:#fff}.person-node.is-root:hover{background:#222}.person-node.is-root .person-dates{color:#ccc}.couple-root{display:flex;gap:0;align-items:center;justify-content:center}.couple-root .person-node{margin:0}.couple-connector{width:32px;height:0;border-top:1px solid #000}.couple-root{position:relative}.couple-root:has(+ul):after{content:"";position:absolute;top:50%;left:50%;bottom:-24px;border-left:1px solid #000}.couple-root+ul:before{display:none}.couple-label{font-size:.9rem;text-align:center;margin-top:2px}.hover-card-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000040;display:flex;justify-content:center;align-items:center;z-index:1000}.hover-card{background:#fff;border:2px solid #000;padding:28px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;position:relative}.hover-card h2{margin-bottom:14px;font-size:1.8rem;font-weight:700;border-bottom:1px solid #000;padding-bottom:8px}.hover-card .detail-row{display:flex;margin-bottom:5px;font-size:1.1rem}.hover-card .detail-label{font-weight:700;width:100px;flex-shrink:0}.hover-card .detail-value{color:#000}.hover-card-actions{display:flex;gap:8px;margin:14px 0;flex-wrap:wrap}.hover-card-actions .btn{font-size:1rem;padding:6px 14px}.hover-card .description-list{margin:10px 0;padding-left:0;list-style:none}.hover-card .description-list li{margin-bottom:3px;font-size:1.1rem;padding-left:12px;position:relative}.hover-card .description-list li:before{content:"–";position:absolute;left:0}.hover-card .add-description-form{display:flex;gap:8px;margin-top:8px}.hover-card .add-description-form input{flex:1;padding:6px 10px;border:1px solid #000;font-family:Caveat,cursive;font-size:1.05rem}.hover-card .image-gallery{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.hover-card .image-gallery img{width:110px;height:110px;object-fit:cover;border:1px solid #000}.hover-card .close-btn{position:absolute;top:10px;right:14px;background:none;border:none;font-size:1.6rem;cursor:pointer;color:#000;font-family:Caveat,cursive;font-weight:700}.hover-card .close-btn:hover{text-decoration:underline}.admin-page{max-width:720px;margin:0 auto;padding:32px 24px}.admin-page h1{font-size:2.4rem;margin-bottom:28px;font-weight:700;border-bottom:2px solid #000;padding-bottom:8px}.admin-section{border:1px solid #000;padding:24px;margin-bottom:20px;background:#fff}.admin-section h2{font-size:1.5rem;margin-bottom:14px;padding-bottom:6px;border-bottom:1px solid #000;font-weight:700}.admin-section .btn{margin-top:8px}.tag-input-container{display:flex;gap:8px}.tag-input-container input{flex:1}.tag-input-container .btn{margin-top:0;white-space:nowrap}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{border:1px solid #000;padding:2px 10px;font-size:1rem;display:flex;align-items:center;gap:4px}.tag button{background:none;border:none;cursor:pointer;font-size:1.1rem;color:#000;padding:0 2px;font-family:Caveat,cursive;font-weight:700}.tag button:hover{text-decoration:underline}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#fff}::-webkit-scrollbar-thumb{background:#000}a{color:#000;font-weight:600}a:hover{text-decoration:none}
