*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a1a;background:#f5f7fa;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.auth-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;height:100vh;display:flex}.auth-card{background:#fff;border-radius:12px;width:380px;padding:40px;box-shadow:0 20px 60px rgba(0,0,0,.2)}.auth-card h1{color:#4a5568;margin-bottom:4px;font-size:1.5rem}.auth-card h2{color:#718096;margin-bottom:24px;font-size:1.1rem;font-weight:500}.switch-auth{text-align:center;color:#718096;margin-top:16px;font-size:.9rem}.switch-auth a{color:#667eea;font-weight:500;text-decoration:none}.demo-login{text-align:center;color:#a0aec0;border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px;font-size:.85rem}.btn-demo{color:#4a5568;background:#f7fafc;border:1px dashed #cbd5e0;border-radius:6px;margin-top:6px;padding:8px 20px;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-block}.btn-demo:hover{background:#edf2f7;border-color:#a0aec0}.app-layout{flex-direction:column;height:100vh;display:flex}.tree-page{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.top-nav{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 20px;display:flex;box-shadow:0 1px 3px rgba(0,0,0,.06)}.nav-brand{color:#2d3748;font-size:1.1rem;font-weight:700}.nav-right{align-items:center;gap:16px;display:flex}.nav-user{color:#718096;font-size:.9rem}.toolbar{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;align-items:center;gap:12px;padding:8px 16px;display:flex}.toolbar-zoom{gap:4px;display:flex}button{cursor:pointer;border:none;border-radius:6px;padding:7px 14px;font-size:.9rem;transition:all .15s}.btn-primary{color:#fff;background:#4a90d9;font-weight:600}.btn-primary:hover{background:#2563eb}.btn-ghost{color:#4a5568;background:0 0;border:1px solid #e2e8f0}.btn-ghost:hover{background:#f7fafc}.btn-danger{color:#fff;background:#fc8181}.btn-danger:hover{background:#e53e3e}.btn-icon{color:#4a5568;background:#f7fafc;border:1px solid #e2e8f0;padding:6px 12px;font-size:1.1rem}.btn-icon:hover{background:#edf2f7}.btn-ghost.active{color:#2563eb;background:#ebf4ff;border-color:#93c5fd}.field{flex-direction:column;flex:1;gap:4px;display:flex}.field label{color:#4a5568;font-size:.85rem;font-weight:500}.field input,.field select,.field textarea{border:1px solid #cbd5e0;border-radius:6px;width:100%;padding:8px 10px;font-size:.9rem}.field input:focus,.field select:focus,.field textarea:focus{border-color:#4a90d9;outline:none;box-shadow:0 0 0 3px rgba(74,144,217,.15)}.field textarea{resize:vertical;font-family:inherit}.field-row{gap:12px;display:flex}.modal-backdrop{z-index:100;background:rgba(0,0,0,.4);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:480px;max-width:95vw;padding:28px;box-shadow:0 25px 50px rgba(0,0,0,.25)}.modal h2{color:#2d3748;margin-bottom:20px;font-size:1.2rem}.modal form{flex-direction:column;gap:14px;display:flex}.modal-actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.tree-canvas{-webkit-user-select:none;user-select:none;background:#f5f7fa radial-gradient(circle,rgba(0,0,0,.08) 1px,transparent 1px) 0 0/28px 28px;flex:1;display:block}.timeline-labels text{font-variant-numeric:tabular-nums;pointer-events:none}.timeline-labels line{pointer-events:none}.person-node rect{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:filter .15s}.person-node rect:hover{filter:drop-shadow(0 4px 8px rgba(0,0,0,.18))}.empty-hint{fill:#a0aec0;pointer-events:none;font-size:16px}.rel-panel{padding:20px 16px}.rel-panel h3{color:#2d3748;border-bottom:1px solid #e2e8f0;margin-bottom:16px;padding-bottom:12px;font-size:1rem;font-weight:700}.rel-section{margin-bottom:18px}.rel-section h4{text-transform:uppercase;letter-spacing:.05em;color:#718096;margin-bottom:8px;font-size:.8rem;font-weight:600}.rel-section form{flex-direction:column;gap:10px;display:flex}.rel-item{background:#f7fafc;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:6px 8px;font-size:.9rem;display:flex}.btn-sm{padding:4px 10px;font-size:.8rem}.loading{color:#718096;justify-content:center;align-items:center;height:100vh;display:flex}.error{color:#e53e3e;background:#fff5f5;border:1px solid #fc8181;border-radius:6px;padding:8px 12px;font-size:.875rem}.muted{color:#a0aec0;font-size:.9rem}.tree-main{flex-direction:row;flex:1;display:flex;position:relative;overflow:hidden}.tree-main .tree-canvas{flex:1}.side-panel{background:#fff;border-left:1px solid #e2e8f0;flex-shrink:0;width:320px;min-width:260px;max-width:360px;overflow-y:auto}.nav-left{align-items:center;gap:8px;display:flex}.nav-separator{color:#cbd5e0;font-size:1.2rem}.nav-tree-name{color:#4a5568;font-size:.95rem;font-weight:500}.tree-list-page{max-width:700px;height:100%;margin:0 auto;padding:32px 48px;overflow-y:auto}.tree-list-header{margin-bottom:24px}.tree-list-header h1{color:#2d3748;font-size:1.6rem}.tree-cards{flex-direction:column;gap:12px;margin-bottom:32px;display:flex}.tree-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px 20px;transition:box-shadow .15s;box-shadow:0 1px 3px rgba(0,0,0,.05)}.tree-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.09)}.tree-card-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.tree-card-name{color:#2d3748;cursor:pointer;flex:1;font-size:1.05rem;font-weight:600}.tree-card-name:hover{color:#4a90d9}.tree-card-actions,.tree-card-edit{align-items:center;gap:8px;display:flex}.tree-card-edit input{border:1px solid #cbd5e0;border-radius:6px;flex:1;padding:6px 10px;font-size:1rem}.new-tree-form{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:20px 24px}.new-tree-form h2{color:#4a5568;margin-bottom:12px;font-size:1.05rem}.new-tree-row{gap:10px;display:flex}.new-tree-row input{border:1px solid #cbd5e0;border-radius:6px;flex:1;padding:8px 12px;font-size:.95rem}.new-tree-row input:focus{border-color:transparent;outline:2px solid #4a90d9}.changelog-panel{padding:16px}.changelog-panel h3{color:#2d3748;margin-bottom:12px;font-size:1rem;font-weight:600}.changelog-list{flex-direction:column;gap:10px;list-style:none;display:flex}.changelog-entry{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px}.cl-meta{align-items:center;gap:8px;margin-bottom:6px;display:flex}.cl-action{white-space:nowrap;border-radius:12px;padding:2px 7px;font-size:.75rem;font-weight:700}.cl-action.cl-create{color:#065f46;background:#d1fae5}.cl-action.cl-update{color:#1e40af;background:#dbeafe}.cl-action.cl-delete{color:#991b1b;background:#fee2e2}.cl-desc{color:#4a5568;flex:1;font-size:.88rem}.cl-footer{color:#a0aec0;align-items:center;gap:8px;font-size:.8rem;display:flex}.cl-actor{color:#718096;font-weight:500}.cl-ts{flex:1;font-family:monospace}.share-panel{padding:16px}.share-panel h3{color:#2d3748;margin-bottom:12px;font-size:1rem;font-weight:600}.share-panel h4{color:#718096;text-transform:uppercase;letter-spacing:.04em;margin:14px 0 8px;font-size:.85rem;font-weight:600}.members-list{flex-direction:column;gap:6px;list-style:none;display:flex}.member-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:8px;padding:8px 10px;display:flex}.member-name{color:#2d3748;flex:1;font-size:.9rem}.member-role{border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600}.member-role.role-owner{color:#92400e;background:#fef3c7}.member-role.role-editor{color:#1e40af;background:#dbeafe}.member-role.role-viewer{color:#166534;background:#f0fdf4}.share-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.share-form input{border:1px solid #cbd5e0;border-radius:6px;flex:1;min-width:160px;padding:7px 10px;font-size:.9rem}.share-form select{border:1px solid #cbd5e0;border-radius:6px;padding:7px 10px;font-size:.9rem}