*,:after,:before{box-sizing:border-box}html{font-size:16px;overflow-y:scroll}body{background:#f5f6fa;font-family:Titillium Web,sans-serif;padding:0}.form{background:#fff;padding:32px 28px;width:420px}.form h1{color:#2d3e50;font-size:1.9rem;font-weight:700;margin-bottom:6px;text-align:center}.form h2{color:#6b7b8a;font-size:1.1rem;font-weight:400;margin-bottom:24px;text-align:center}.tab-group{border-radius:6px;display:flex;list-style:none;margin:0 0 25px;overflow:hidden;padding:0}.tab-group li{flex:1 1}.tab-group li a{background:#e6ebf2;color:#6b7b8a;cursor:pointer;display:block;font-weight:600;padding:12px 0;text-align:center;transition:background .25s ease}.tab-group li a:hover{background:#d7deea}.tab-group .active a{background:#4a90e2;color:#fff}.field-wrap{margin-bottom:20px}.field-wrap label{color:#2d3e50;display:block;font-size:14px;font-weight:600;margin-bottom:6px}input,textarea{background:#fff;border:1px solid #cfd8e3;border-radius:6px;font-size:15px;padding:10px 12px;transition:.25s;width:100%}input:focus,textarea:focus{border-color:#4a90e2;box-shadow:0 0 0 3px #4a90e233;outline:none}textarea{min-height:80px;resize:vertical}.button{background:#4a90e2;border:0;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;letter-spacing:.03em;padding:12px 0;transition:.25s ease}.button:focus,.button:hover{background:#357acb}.button-block{width:100%}.forgot{color:#4a90e2;font-size:.9rem;margin-top:-10px;text-align:right}.forgot:hover{text-decoration:underline}body,html{height:100%;margin:0}.layout{display:flex;gap:16px;height:100vh;overflow:hidden;padding:16px}.block{background:#fff;border-radius:24px;flex:1 1;overflow-y:auto;padding:24px}.block-login{align-items:center;display:flex;justify-content:center}@media (max-width:768px){.layout{flex-direction:column;height:auto}.block-info,.block-login{height:auto;width:100%}.form{margin:20px auto;max-width:500px;padding:20px 16px}.form h1{font-size:1.6rem}.form h2{font-size:1rem}}.tree-wrapper{background:linear-gradient(180deg,#f0f3ff,#eef3ff);border-radius:12px;height:calc(100vh - 180px);overflow:auto;padding:20px;width:100%}.custom-node{background:#fff;border-radius:8px;box-shadow:0 2px 6px #00000026;cursor:pointer;font-size:13px;padding:6px 12px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border .15s ease}.custom-node:hover{box-shadow:0 4px 12px #0000002e}.custom-node.selected{background:#e5f1ff;border:2px solid #4a90e2}.tree-controls{z-index:999}.family-tree-container{cursor:grab;height:100%;overflow:hidden;position:relative;width:100%}.family-tree-container:active{cursor:grabbing}.family-tree-svg{display:block;height:auto;overflow:visible;width:100%;z-index:1}.home-root{background:#f5f6fa;display:flex;flex-direction:column;min-height:100vh}.top-bar{align-items:center;background:#fff;box-shadow:0 2px 10px #00000014;display:grid;grid-template-columns:1fr auto 1fr;padding:12px 24px;width:100%;z-index:10}.top-left{color:#333;font-size:16px;justify-self:start}.top-center{font-size:20px;font-weight:600;justify-self:center}.logout-btn{background:#4a90e2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;justify-self:end;padding:8px 16px;transition:.2s}.logout-btn:hover{background:#357acb}.home-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:200px 1fr;margin-top:20px;padding:0 24px}.side-panel,.tree-panel{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:20px}.side-title{font-size:18px;font-weight:600;margin-bottom:12px}.selected-name{font-size:16px;font-weight:500;margin-bottom:16px}.button-stack{display:flex;flex-direction:column;gap:10px}.button-stack button,.side-panel button{background:#4a90e2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px;transition:.2s;width:100%}.button-stack button:hover{background:#357acb}.danger-btn{background:#ff5c5c!important}.danger-btn:hover{background:#ff3232!important}.tree-controls{display:flex;gap:8px;margin-bottom:10px}.tree-controls button{background:#4a90e2;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:18px;font-weight:700;height:38px;transition:.15s;width:38px}.tree-controls button:hover{background:#357acb}@media (max-width:900px){.home-content{grid-template-columns:1fr;padding:0 12px}.top-bar{grid-template-columns:1fr 1fr 1fr}}.overlay{align-items:center;background:#00000059;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.modal{background:#fff;border-radius:10px;max-height:80vh;overflow-y:auto;padding:20px}.modal button{margin:6px 0;width:100%}.btn-icon{font-size:18px;margin-right:10px;vertical-align:middle}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:20}.modal-card{animation:pop .2s ease;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001f;padding:20px;width:320px}@keyframes pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-card input{background:#fff;border:1px solid #ccc;border-radius:6px;color:#000;margin:10px 0 15px;padding:8px;width:100%}.modal-buttons{display:flex;gap:10px}.modal-buttons button{border:none;border-radius:6px;cursor:pointer;flex:1 1;padding:8px 10px}.cancel-btn{background:#ddd}body{background:#f5f6fa!important}.member-container{background:#fff;border-radius:14px;box-shadow:0 4px 16px #00000014;margin:40px auto;max-width:900px;padding:40px}.member-name{color:#2d3e50;font-size:34px;font-weight:700;margin-bottom:28px;text-align:center}.memory-submit-btn{background:#4a90e2;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:10px;padding:12px;width:40%}.memory-submit-btn:hover{background:#357acb}.add-memory-form{background:#fafcff;border:1px solid #e3e8ef;border-radius:12px;margin-top:20px;padding:20px}.add-memory-form input,.add-memory-form textarea{border:1px solid #cfd8e3;border-radius:8px;font-size:15px;margin-bottom:14px;padding:12px;width:100%}.add-memory-form textarea{min-height:120px}.add-memory-form button{background:#4a90e2;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 18px;width:100%}.add-memory-form button:hover{background:#357acb}.memory-section{margin-top:40px}.memory-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-top:20px}.memory-item{background:#f5f8fc;border:1px solid #dbe3ef;border-radius:10px;padding:16px;transition:.2s ease}.memory-item:hover{background:#eaf1fb}.memory-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.memory-actions{display:flex;gap:10px}.delete-icon,.edit-icon{cursor:pointer;font-size:18px}.delete-icon:hover{color:red}.edit-icon:hover{opacity:.7}.edit-modal{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;position:fixed;z-index:99999}.edit-box{background:#fff;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:24px;width:360px}.edit-box input,.edit-box textarea{border:1px solid #d0d6df;border-radius:8px;padding:10px;width:100%}.edit-box textarea{min-height:120px}.save-edit-btn{background:#4a90e2;color:#fff}.cancel-edit-btn,.save-edit-btn{border:none;border-radius:8px;cursor:pointer;padding:10px}.cancel-edit-btn{background:#ccc;color:#000}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.4c708202.css.map*/