*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:18px;line-height:1.5;color:#333;background:#f5f5f5}.app{min-height:100vh;display:flex;flex-direction:column}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:24px}.header{background:#2c5282;color:#fff;padding:16px 20px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px}.header h1{font-size:24px;font-weight:600}.person-count{font-size:14px;font-weight:400;opacity:.8;margin-left:8px}.nav{display:flex;gap:8px}.nav button{padding:10px 20px;font-size:16px;border:2px solid white;border-radius:8px;background:transparent;color:#fff;cursor:pointer;transition:all .2s}.nav button:hover,.nav button.active{background:#fff;color:#2c5282}.nav-separator{width:1px;height:24px;background:#ffffff4d;margin:0 8px}.auth-btn{background:#ffffff1a!important;border-color:#ffffff80!important;font-size:14px!important;padding:8px 16px!important}.auth-btn:hover{background:#fff3!important}.main{flex:1;padding:20px;overflow:auto}button{font-size:18px;padding:12px 24px;border:none;border-radius:8px;cursor:pointer;min-height:48px;transition:all .2s}button:focus{outline:3px solid #4299e1;outline-offset:2px}.btn-primary{background:#2c5282;color:#fff}.btn-primary:hover{background:#1a365d}.btn-secondary{background:#e2e8f0;color:#333}.btn-secondary:hover{background:#cbd5e0}.btn-danger{background:#c53030;color:#fff}.btn-danger:hover{background:#9b2c2c}.family-tree{display:flex;flex-direction:column;gap:20px}.tree-actions{display:flex;gap:12px;flex-wrap:wrap}.tree-container{background:#fff;border-radius:12px;padding:24px;min-height:400px;overflow:auto}.tree-canvas-wrapper{background:#fff;border-radius:12px;padding:24px;overflow:auto;max-height:calc(100vh - 200px)}.tree-canvas{background:linear-gradient(to bottom,#f8fafc,#fff);border-radius:8px}.cytoscape-container{width:100%;height:calc(100vh - 220px);min-height:500px;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.d3-container{width:100%;height:calc(100vh - 180px);min-height:500px;background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.layout-buttons{display:flex;gap:8px;flex-wrap:wrap}.view-toggle{display:flex;gap:4px;background:#e2e8f0;padding:4px;border-radius:8px}.view-toggle button{padding:8px 16px;font-size:14px;min-height:36px;border:none;background:transparent;color:#666;border-radius:6px}.view-toggle button.active{background:#fff;color:#2c5282;box-shadow:0 1px 3px #0000001a}.tree-empty{text-align:center;padding:60px 20px;color:#666}.root-select{padding:10px 16px;font-size:16px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer}.tree-stats{padding:10px 16px;font-size:14px;color:#666}.tree-group{margin-bottom:24px}.tree-group-title{font-size:18px;margin-bottom:12px;color:#2c5282}.generations-view{display:flex;flex-direction:column;gap:24px}.generation{border-bottom:1px solid #e2e8f0;padding-bottom:20px}.generation:last-child{border-bottom:none}.generation-label{font-size:14px;font-weight:600;color:#666;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.generation-persons{display:flex;flex-wrap:wrap;gap:12px}.tree-person{cursor:pointer}.disconnected-section{margin-top:24px;padding:20px;background:#fff;border-radius:12px}.disconnected-section h3{margin-bottom:16px;color:#666}.disconnected-list{display:flex;flex-wrap:wrap;gap:12px}.disconnected-person{cursor:pointer}.tree-scroll{overflow:auto;padding:20px}.tree-scroll>div{position:relative}.tree-scroll svg{position:absolute;top:0;left:0;pointer-events:none;overflow:visible}.tree-scroll svg path{stroke:#2c5282;stroke-width:2;fill:none}.person-card{background:#fff;border:2px solid #e2e8f0;border-radius:10px;padding:10px 12px;min-width:140px;max-width:160px;text-align:center;cursor:pointer;transition:all .2s;font-size:14px}.person-card:hover{border-color:#2c5282;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.person-card.male{border-color:#90cdf4;background:#ebf8ff}.person-card.female{border-color:#fbb6ce;background:#fff5f7}.person-card.deceased{opacity:.7;background:#f7fafc}.person-card.compact{padding:8px 10px;min-width:auto;max-width:none;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center}.person-card.compact .person-name{font-size:13px;line-height:1.2}.person-card.compact .person-dates{font-size:11px}.person-photo{width:50px;height:50px;border-radius:50%;object-fit:cover;margin-bottom:6px;border:2px solid #e2e8f0}.person-name{font-weight:600;font-size:14px;margin-bottom:2px;line-height:1.2}.person-dates{font-size:12px;color:#666}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}.modal{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:22px}.modal-close{background:none;border:none;font-size:28px;padding:4px 12px;min-height:auto;color:#666}.modal-close:hover{color:#333}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{width:100%;padding:12px 16px;font-size:18px;border:2px solid #e2e8f0;border-radius:8px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4299e1}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;gap:12px;flex-wrap:wrap;padding-top:20px;border-top:1px solid #e2e8f0;margin-top:20px}.form-actions button{flex:1;min-width:120px}.dates-list{background:#fff;border-radius:12px;padding:24px}.dates-list h2{font-size:22px;margin-bottom:20px}.dates-empty{text-align:center;padding:40px 20px;color:#666}.date-item{display:flex;align-items:center;gap:16px;padding:16px;border-bottom:1px solid #e2e8f0}.date-item:last-child{border-bottom:none}.date-item.soon{background:#fffaf0}.date-days{background:#2c5282;color:#fff;padding:8px 16px;border-radius:8px;font-weight:600;min-width:100px;text-align:center}.date-days.today{background:#38a169}.date-days.soon{background:#d69e2e}.date-info{flex:1}.date-name{font-weight:600;font-size:18px}.date-date{color:#666;font-size:16px}.form-section{margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.relation-list{margin-bottom:12px}.relation-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f7fafc;border-radius:8px;margin-bottom:8px}.relation-item span{font-size:16px}.relation-add{display:flex;gap:8px;align-items:center}.relation-add select{flex:1}.btn-small{padding:8px 16px;font-size:14px;min-height:36px}.relation-empty{color:#999;font-style:italic}.login-modal{max-width:360px}.login-modal h2{margin-bottom:20px;font-size:24px;text-align:center}.login-modal form{padding:24px}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.form-group input[readonly]{background:#f7fafc;color:#666}.form-group select:disabled{background:#f7fafc;color:#666}.persons-table-container{background:#fff;border-radius:12px;padding:24px;overflow-x:auto}.table-empty{text-align:center;padding:40px 20px;color:#666}.persons-table{width:100%;border-collapse:collapse;font-size:16px}.persons-table th,.persons-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #e2e8f0}.persons-table th{background:#f7fafc;font-weight:600;color:#4a5568;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.persons-table tbody tr{cursor:pointer;transition:background .15s}.persons-table tbody tr:hover{background:#ebf8ff}.persons-table tbody tr:last-child td{border-bottom:none}@media (max-width: 600px){.header{flex-direction:column;align-items:stretch;text-align:center}.nav{justify-content:center}.form-row{grid-template-columns:1fr}.tree-couple{flex-direction:column}.tree-connector{width:4px;height:24px}}
