:root{--primary:#0f172a;--primary-hover:#1e293b;--accent:#2563eb;--accent-light:#eff6ff;--success:#10b981;--success-hover:#059669;--bg-color:#f8fafc;--surface:#fff;--text-main:#0f172a;--text-muted:#64748b;--text-inverse:#fff;--border:#e2e8f0;--border-focus:#bfdbfe;--shadow-sm:0 2px 4px #0f172a0a;--shadow-md:0 4px 12px #0f172a0f, 0 1px 3px #0f172a0a;--shadow-lg:0 12px 32px #0f172a14, 0 4px 8px #0f172a0a;--shadow-glow:0 0 0 4px #2563eb26;--radius-sm:0px;--radius-md:0px;--radius-lg:0px;--radius-xl:0px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(circle at 100% 0,#2563eb08,#0000 40%),radial-gradient(circle at 0 100%,#10b98108,#0000 40%);background-attachment:fixed;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6}.glass-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s cubic-bezier(.4,0,.2,1)}.glass-card:hover{box-shadow:var(--shadow-lg);border-color:#cbd5e1;transform:translateY(-3px)}h1,h2,h3,h4{color:var(--primary);letter-spacing:-.03em;font-weight:700}.text-muted{color:var(--text-muted);font-weight:500}input,textarea{border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-main);background-color:var(--surface);padding:.875rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:500;transition:all .2s;box-shadow:inset 0 1px 2px #00000005}input:focus,textarea:focus{border-color:var(--accent);box-shadow:var(--shadow-glow);background-color:var(--surface);outline:none}input::placeholder,textarea::placeholder{color:#94a3b8;font-weight:400}button{border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;border:none;justify-content:center;align-items:center;padding:.875rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}button:active{transform:scale(.97)}button.primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);color:var(--text-inverse);box-shadow:0 4px 6px #0f172a26}button.primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 12px #0f172a33}button.primary:disabled{cursor:not-allowed;box-shadow:none;background:#94a3b8;transform:none}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.text-center{text-align:center}.text-lg{font-size:1.125rem}.font-bold{font-weight:700}.container{max-width:1024px;margin:0 auto;padding:0 1rem}@media (width>=768px){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.5s cubic-bezier(.4,0,.2,1) forwards fadeIn}.spinner{border:2px solid #fff3;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tree-container{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);-webkit-overflow-scrolling:touch;padding:1.5rem;overflow-x:auto;box-shadow:inset 0 2px 4px #00000005}.custom-scrollbar::-webkit-scrollbar{width:8px;height:8px}.custom-scrollbar::-webkit-scrollbar-track{background:0 0}.custom-scrollbar::-webkit-scrollbar-thumb{border:2px solid var(--surface);background:#cbd5e1;border-radius:999px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media (width<=768px){.mobile-padding{padding:1.25rem!important}.mobile-right-align{text-align:left!important}h2{font-size:1.25rem!important}}.tree-node[data-v-b70b09ad]{align-items:center;margin:.5rem 0;display:flex}.node-data[data-v-b70b09ad],.empty-node[data-v-b70b09ad]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);min-width:180px;max-width:220px;box-shadow:var(--shadow-sm);z-index:2;flex-direction:column;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.node-data[data-v-b70b09ad]:hover{box-shadow:var(--shadow-md);border-color:#cbd5e1;transform:translateY(-2px)}.node-tag[data-v-b70b09ad]{text-transform:uppercase;letter-spacing:.05em;color:#fff;padding:.25rem .75rem;font-size:.7rem;font-weight:700}.type-root .node-tag[data-v-b70b09ad]{background:linear-gradient(90deg, var(--primary), var(--secondary))}.type-male .node-tag[data-v-b70b09ad]{background:linear-gradient(90deg,#2563eb,#3b82f6)}.type-female .node-tag[data-v-b70b09ad]{background:linear-gradient(90deg,#db2777,#ec4899)}.type-root[data-v-b70b09ad]{border-left:3px solid var(--primary)}.type-male[data-v-b70b09ad]{border-left:3px solid #3b82f6}.type-female[data-v-b70b09ad]{border-left:3px solid #ec4899}.node-content[data-v-b70b09ad]{padding:.5rem .75rem;font-size:.85rem}.empty-node .node-content[data-v-b70b09ad]{background:#f8fafc;font-size:.8rem;font-style:italic}.registro[data-v-b70b09ad]{color:var(--text-muted);font-size:.75rem;font-weight:600;display:block}.nome[data-v-b70b09ad]{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;margin-top:.15rem;font-weight:700;overflow:hidden}.node-parents[data-v-b70b09ad]{flex-direction:column;justify-content:space-around;margin-left:2.5rem;display:flex;position:relative}.node-parents[data-v-b70b09ad]:before{content:"";background-color:#cbd5e1;border-radius:2px;width:1.25rem;height:2px;position:absolute;top:50%;left:-1.25rem}.node-parents[data-v-b70b09ad]:after{content:"";background-color:#cbd5e1;border-radius:2px;width:2px;position:absolute;top:calc(25% + .5rem);bottom:calc(25% + .5rem);left:-1.25rem}.tree-node .tree-node[data-v-b70b09ad]:before{content:"";background-color:#cbd5e1;border-radius:2px;width:1.25rem;height:2px;position:absolute;top:50%;left:-1.25rem}
