.app{min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:20px}.header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1rem 2rem}.header h1{font-size:1.5rem}.header-right{align-items:center;display:flex;gap:1rem}.btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5568d3}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.btn-success{background:#27ae60;color:#fff}.btn-success:hover{background:#219150}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d}.card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.card h2{border-bottom:2px solid #667eea;color:#333;padding-bottom:.5rem}.card h2,.form-group{margin-bottom:1rem}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.table{border-collapse:collapse;width:100%}.table td,.table th{border-bottom:1px solid #eee;padding:.75rem;text-align:left}.table th{color:#333;font-weight:600}.table th,.table tr:hover{background:#f8f9fa}.nav-tabs{border-bottom:2px solid #eee;display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:0}.nav-tab{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:1rem;margin-bottom:-2px;padding:.75rem 1.5rem}.nav-tab.active{border-bottom-color:#667eea;color:#667eea}.nav-tab:hover{color:#667eea}.family-tree{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem}.tree-node{background:#fff;border:2px solid #667eea;border-radius:8px;box-shadow:0 2px 8px #0000001a;min-width:150px;padding:1rem;text-align:center}.tree-node.male{border-color:#3498db}.tree-node.female{border-color:#e91e63}.tree-node h3{color:#333;margin-bottom:.5rem}.tree-node p{color:#666;font-size:.85rem;margin:.25rem 0}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:400px;padding:2.5rem;width:100%}.login-card h1{color:#333;margin-bottom:2rem;text-align:center}.error{background:#fee;color:#e74c3c}.error,.success{border-radius:6px;margin-bottom:1rem;padding:.75rem}.success{background:#efe;color:#27ae60}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:100%}.modal h2{color:#333;margin-bottom:1.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}
/*# sourceMappingURL=main.2f610e42.css.map*/