@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200";.language-switch{display:inline-flex;align-items:center;padding:4px;background:#ffffff0d;border:1px solid var(--color-border);border-radius:var(--radius-full);box-shadow:inset 0 1px #ffffff0a}.language-switch-btn{min-width:46px;padding:.45rem .8rem;border:none;border-radius:var(--radius-full);background:transparent;color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.08em;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.language-switch-btn:hover{color:var(--color-text-primary)}.language-switch-btn.active{background:linear-gradient(135deg,#d4a85338,#e8c97a24);color:var(--color-text-primary);box-shadow:inset 0 0 0 1px var(--color-border-accent)}@media(max-width:768px){.language-switch-btn{min-width:42px;padding:.4rem .65rem}}.landing{min-height:100vh}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-navbar);background:#0f0f1acc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border)}.landing-nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height)}.landing-nav-actions{display:flex;align-items:center;gap:var(--space-3)}.landing-logo{display:flex;align-items:center;gap:var(--space-2)}.logo-icon{font-size:1.5rem}.logo-text{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.logo-accent{color:var(--color-accent-primary)}.hero{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-20) 0;text-align:center;overflow:hidden}.hero-content{position:relative;z-index:2}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:var(--color-bg-glass);border:1px solid var(--color-border-accent);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-accent-secondary);margin-bottom:var(--space-8)}.hero-badge-icon{color:var(--color-accent-primary)}.hero-title{font-size:var(--font-size-5xl);font-weight:800;line-height:1.1;letter-spacing:-.02em;margin-bottom:var(--space-6)}.text-gradient{background:var(--color-accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:540px;margin:0 auto var(--space-10);line-height:1.7;opacity:0}.hero-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-bottom:var(--space-12);opacity:0}.hero-stats{display:flex;align-items:center;justify-content:center;gap:var(--space-8);opacity:0}.stat-group{display:flex;align-items:center;gap:var(--space-8)}.stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-number{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-accent-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.stat-divider{width:1px;height:40px;background:var(--color-border)}.hero-glow{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,var(--color-accent-glow) 0%,transparent 70%);z-index:1;pointer-events:none}.features{padding:var(--space-20) 0}.section-title{font-size:var(--font-size-3xl);font-weight:700;text-align:center;margin-bottom:var(--space-3)}.section-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--space-12);font-size:var(--font-size-lg)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.feature-card{padding:var(--space-8);text-align:center}.feature-icon{margin-bottom:var(--space-4);color:var(--color-accent-primary)}.feature-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-3)}.feature-card p{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6}.cta-section{padding:var(--space-16) 0 var(--space-20)}.cta-card{padding:var(--space-16);text-align:center;background:linear-gradient(135deg,#d4a85314,#1e1e37b3)!important;border-color:var(--color-border-accent)!important}.cta-card h2{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--space-4)}.cta-card p{color:var(--color-text-secondary);font-size:var(--font-size-lg);margin-bottom:var(--space-8)}.landing-footer{border-top:1px solid var(--color-border);padding:var(--space-12) 0}.footer-content{text-align:center}.footer-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-3)}.footer-desc{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.footer-bottom{padding-top:var(--space-6);border-top:1px solid var(--color-border)}.footer-bottom p{color:var(--color-text-muted);font-size:var(--font-size-xs)}@media(max-width:768px){.landing-nav-inner{gap:var(--space-3)}.landing-nav-actions{gap:var(--space-2)}.landing-nav-actions .btn{padding-inline:var(--space-4)}.hero{min-height:auto;padding:calc(var(--navbar-height) + var(--space-12)) 0 var(--space-12)}.hero-actions{flex-direction:column;gap:var(--space-3)}.hero-actions .btn{width:100%}.hero-stats,.stat-group{gap:var(--space-6)}.features-grid{grid-template-columns:1fr;gap:var(--space-4)}.feature-card{padding:var(--space-6)}.cta-card{padding:var(--space-8)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);position:relative;overflow:hidden}.login-glow{position:absolute;top:20%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,var(--color-accent-glow) 0%,transparent 70%);pointer-events:none}.login-container{width:100%;max-width:420px;position:relative;z-index:2}.login-topbar{display:flex;justify-content:flex-end;margin-bottom:var(--space-4)}.login-logo{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-8);text-decoration:none}.login-card{padding:var(--space-8)}.login-card h1{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-2)}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.error-banner{padding:var(--space-3) var(--space-4);background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-sm);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.input-password-wrapper{position:relative;display:flex;align-items:center}.input-password-wrapper .input{width:100%;padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.1rem;padding:0;line-height:1;opacity:.6;transition:opacity var(--transition-fast)}.password-toggle:hover{opacity:1}.login-btn{width:100%;margin-top:var(--space-2)}.login-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-divider span{color:var(--color-text-muted);font-size:var(--font-size-sm)}.google-btn{width:100%}.google-btn .app-icon{flex-shrink:0}.login-tabs{display:flex;gap:0;margin-bottom:var(--space-5);border-radius:var(--radius-md);overflow:hidden;background:#ffffff0a;border:1px solid var(--color-border)}.login-tab{flex:1;padding:var(--space-2) var(--space-3);background:none;color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:500;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.login-tab:hover{background:#ffffff0f;color:var(--color-text-primary)}.login-tab.active{background:linear-gradient(135deg,#d4a8533d,#e8c97a24);color:var(--color-text-primary);font-weight:700;box-shadow:inset 0 0 0 1px var(--color-border-accent)}.navbar{position:fixed;top:0;left:0;right:0;z-index:var(--z-navbar);background:#0f0f1ad9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border)}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:var(--navbar-height)}.navbar-left{display:flex;align-items:center;gap:var(--space-3)}.navbar-right{display:flex;align-items:center;gap:var(--space-4)}.navbar-language-switch{margin-left:var(--space-2)}.nav-link{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--color-text-primary);background:var(--color-bg-glass)}.nav-link.active{color:var(--color-accent-primary)}.navbar-user{display:flex;align-items:center;gap:var(--space-3);padding-left:var(--space-4);border-left:1px solid var(--color-border)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{font-size:var(--font-size-sm);font-weight:600;color:var(--color-accent-primary);text-transform:uppercase}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.mobile-nav-shell{display:none}@media(max-width:768px){.navbar{border-bottom:none;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}.navbar-inner{height:0;min-height:0;padding:0}.navbar-left,.landing-logo,.navbar-right{display:none}.mobile-nav-shell{display:block;position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);left:14px;z-index:calc(var(--z-navbar) + 20)}.mobile-menu-trigger{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:#fffffff0;color:#0f172a;box-shadow:0 12px 28px #0f172a24;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.mobile-menu-trigger .app-icon{font-size:18px}.mobile-menu-trigger-open{background:#0f172a;color:#fff;box-shadow:0 16px 32px #0f172a38}.mobile-menu-panel{position:absolute;top:calc(100% + 10px);left:0;width:168px;display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid rgba(219,226,234,.92);border-radius:18px;background:#fffffffa;box-shadow:0 18px 40px #0f172a29;opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:opacity .18s ease,transform .18s ease}.mobile-menu-panel-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.mobile-menu-language{display:flex;justify-content:center;padding:2px 0 6px}.mobile-menu-item{min-height:44px;display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border:none;border-radius:12px;background:#f8fafc;color:#0f172a;text-decoration:none;font-size:.84rem;font-weight:700;text-align:left;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.mobile-menu-item:active{transform:scale(.98)}.mobile-menu-item-danger{background:#fff1f2;color:#be123c}.mobile-menu-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-menu-icon .app-icon{font-size:18px}}.dashboard-page{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:#f8fafc;font-family:Plus Jakarta Sans,sans-serif}.canvas-container{--canvas-surface: #f8fafc;--canvas-grid-line: #eef2f7;--canvas-dot: #dbe2ea;--canvas-connection-default: #94a3b8;--canvas-connection-spouse: #64748b;--canvas-connection-generic: #a78bfa;--canvas-connection-related: #64748b;--canvas-connection-active: #0f172a;flex:1;position:relative;width:100%;overflow:hidden;cursor:grab;background-color:var(--canvas-surface);background-image:linear-gradient(var(--canvas-grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--canvas-grid-line) 1px,transparent 1px);background-size:28px 28px}.canvas-container:active{cursor:grabbing}.canvas-container-dark{--canvas-surface: #07111f;--canvas-grid-line: rgba(148, 163, 184, .08);--canvas-dot: rgba(148, 163, 184, .22);--canvas-connection-default: #7f8fa6;--canvas-connection-spouse: #cbd5e1;--canvas-connection-generic: #c4b5fd;--canvas-connection-related: #e2e8f0;--canvas-connection-active: #f8fafc}.canvas-content{position:relative;width:3000px;height:3000px;background-color:var(--canvas-surface);background-image:radial-gradient(var(--canvas-dot) 1px,transparent 1px);background-size:20px 20px}.connection-layer,.connection-label-layer{position:absolute;top:0;right:0;bottom:0;left:0}.connection-layer{z-index:1;overflow:visible}.connection-label-layer{z-index:2;pointer-events:none}.connection-hit-area{fill:none;stroke:transparent;stroke-width:16;cursor:pointer;pointer-events:stroke}.connection-path{fill:none;stroke:var(--canvas-connection-default);stroke-width:2.5;transition:stroke .18s ease,stroke-width .18s ease,opacity .18s ease;pointer-events:none}.connection-spouse{stroke:var(--canvas-connection-spouse)}.connection-parentChild{stroke:var(--canvas-connection-default)}.connection-generic{stroke:var(--canvas-connection-generic);opacity:.82}.connection-related{stroke:var(--canvas-connection-related)}.connection-active{stroke:var(--canvas-connection-active);stroke-width:3.5;opacity:1}.connection-chip-wrap{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:8px;pointer-events:auto}.connection-chip{background:#fffffff5;color:#0f172a;border:1px solid #dbe2ea;border-radius:999px;padding:5px 12px;font-family:inherit;font-size:.76rem;font-weight:700;cursor:pointer;box-shadow:0 6px 18px #0f172a14;white-space:nowrap}.connection-chip-active{border-color:#0f172a;box-shadow:0 8px 20px #0f172a29}.connection-delete-btn{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5;border-radius:999px;padding:5px 10px;font-family:inherit;font-size:.72rem;font-weight:700;cursor:pointer}.person-node.shadcn-card{position:absolute;width:220px;height:222px;display:flex;flex-direction:column;border:1px solid #e2e8f0;border-radius:16px;background:#fff;box-shadow:0 14px 30px #0f172a14;color:#0f172a;z-index:10;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.person-node.shadcn-card:hover{box-shadow:0 18px 36px #0f172a1f}.node-selected{border-color:#0f172a!important;box-shadow:0 18px 36px #0f172a29}.node-source{border-color:#2563eb!important;box-shadow:0 0 0 4px #2563eb24,0 18px 36px #0f172a29}.node-targetable{border-color:#bfdbfe!important;animation:targetPulse 1.8s infinite}@keyframes targetPulse{0%{box-shadow:0 0 #3b82f647}70%{box-shadow:0 0 0 14px #3b82f600}to{box-shadow:0 0 #3b82f600}}.drag-handle{position:absolute;top:12px;left:12px;color:#94a3b8;cursor:grab;line-height:0;z-index:2;touch-action:none}.drag-handle:active{cursor:grabbing}.node-controls{position:absolute;top:10px;right:10px;display:flex;gap:4px;z-index:2;align-items:center}.icon-btn-shad{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:7px;background:#ffffffb8;color:#64748b;cursor:pointer;transition:background .18s ease,color .18s ease}.icon-btn-shad:hover{background:#f1f5f9;color:#0f172a}.icon-btn-delete:hover{background:#fee2e2;color:#dc2626}.icon-btn-add{background:#eff6ff;color:#1d4ed8}.icon-btn-add:hover,.icon-btn-add-open{background:#1d4ed8;color:#fff}.card-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;padding:34px 16px 12px;text-align:center}.avatar-wrapper{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.9)}.node-info{display:flex;flex-direction:column;gap:3px;align-items:center}.node-title{font-size:.72rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.08em}.node-order-badge{display:inline-flex;align-items:center;justify-content:center;min-height:22px;padding:0 10px;border-radius:999px;background:#dcfce7;color:#166534;font-size:.74rem;font-weight:800;letter-spacing:.01em}.node-name{font-size:1.02rem;line-height:1.25;font-weight:700;color:#0f172a}.node-age{font-size:.82rem;color:#64748b}.node-action-menu-btn{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid transparent;border-radius:10px;font-family:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s ease}.node-action-menu-btn:hover{transform:translateY(-1px)}.node-action-menu{position:absolute;top:calc(100% + 8px);right:0;display:flex;flex-direction:column;gap:6px;width:152px;padding:0;background:transparent;border:none;box-shadow:none;pointer-events:auto}.node-action-menu-btn{width:100%;justify-content:flex-start;padding:0 12px;box-shadow:0 8px 18px #0f172a14}.node-action-link{background:#f8fafc;border-color:#dbe2ea;color:#0f172a}.node-action-spouse{background:#fdf4ff;border-color:#f3d2ff;color:#a21caf}.node-action-child{background:#f0fdf4;border-color:#bbf7d0;color:#15803d}.node-action-parent{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.canvas-controls{position:absolute;right:24px;bottom:24px;z-index:120;display:flex;gap:8px;padding:8px;background:#fffffff5;border:1px solid #dbe2ea;border-radius:14px;box-shadow:0 12px 28px #0f172a1f}.canvas-menu-shell{position:relative;z-index:1}.canvas-menu-trigger{box-shadow:none}.canvas-menu-trigger-open{background:#0f172a;color:#fff;border-color:#0f172a}.canvas-menu-trigger:hover{background:#f8fafc}.canvas-menu-trigger-open:hover{background:#0f172a}.canvas-menu-panel{position:absolute;right:0;bottom:calc(100% + 12px);width:232px;padding:12px;border:1px solid rgba(219,226,234,.92);border-radius:18px;background:#fffffffa;box-shadow:0 18px 42px #0f172a2e;opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;transition:opacity .18s ease,transform .18s ease}.canvas-menu-panel-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.canvas-menu-header{margin-bottom:10px;color:#475569;font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.canvas-menu-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 12px 12px 14px;border:1px solid #dbe2ea;border-radius:14px;background:#f8fafc;color:#0f172a;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.canvas-menu-option:hover,.canvas-menu-option-active{background:#fefce8;border-color:#d4a85357;box-shadow:inset 0 0 0 1px #d4a85324}.canvas-menu-option-copy{display:flex;flex-direction:column;gap:2px;min-width:0}.canvas-menu-option-title{font-size:.88rem;font-weight:700}.canvas-menu-option-hint{color:#64748b;font-size:.75rem}.canvas-menu-switch{width:42px;height:24px;display:inline-flex;align-items:center;padding:2px;border-radius:999px;background:#cbd5e1;transition:background var(--transition-fast);flex-shrink:0}.canvas-menu-switch-on{background:#0f172a}.canvas-menu-switch-handle{width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0f172a38;transition:transform var(--transition-fast)}.canvas-menu-switch-on .canvas-menu-switch-handle{transform:translate(18px)}.control-btn{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid #dbe2ea;border-radius:10px;background:#fff;color:#0f172a;font-size:1rem;font-weight:700;cursor:pointer}.control-btn:hover{background:#f8fafc}.layout-btn{padding:0 12px}.btn-global-tambah{position:absolute;left:50%;bottom:24px;transform:translate(-50%);z-index:140;display:inline-flex;align-items:center;gap:var(--space-2);background:#0f172a;color:#fff;border:none;border-radius:999px;padding:13px 24px;font-family:inherit;font-size:.98rem;font-weight:800;cursor:pointer;box-shadow:0 16px 28px #0f172a33}.btn-global-tambah:hover{background:#1e293b}.dashboard-page-dark-canvas .btn-global-tambah{background:#fffffffa;color:#0f172a;box-shadow:0 16px 28px #03071257}.dashboard-page-dark-canvas .btn-global-tambah:hover{background:#fff}.linking-banner{position:absolute;top:24px;left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:14px;max-width:min(92vw,720px);padding:14px 18px;background:#eff6fff5;border:1px solid #bfdbfe;border-radius:16px;box-shadow:0 12px 28px #2563eb29;color:#1d4ed8;font-size:.92rem;font-weight:700}.btn-cancel-link{border:none;border-radius:999px;background:#2563eb;color:#fff;padding:8px 14px;font-family:inherit;font-size:.8rem;font-weight:700;cursor:pointer}.dashboard-loading{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#64748b}.spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#0f172a;border-radius:50%;animation:spin .8s linear infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;background:#ffffffd6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:min(100%,440px);max-height:min(88vh,760px);overflow:auto;background:#fff;color:#0f172a;border:1px solid #dbe2ea;border-radius:22px;padding:24px;box-shadow:0 30px 60px #0f172a29}.modal-compact{width:min(100%,460px)}.modal h2{margin:0 0 8px;font-size:1.45rem;font-weight:800}.modal-subtitle{margin:0 0 20px;color:#64748b;line-height:1.5}.modal-error{margin-bottom:16px;padding:10px 12px;border-radius:12px;background:#fef2f2;color:#b91c1c;font-size:.9rem;font-weight:600}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{font-size:.9rem;font-weight:700}.input-field{width:100%;padding:11px 13px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;color:#0f172a;font-family:inherit;font-size:.95rem}.input-field:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.gelaran-chips{display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid #dbe2ea;border-radius:999px;background:#f8fafc;color:#475569;padding:5px 12px;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer}.chip-active{background:#0f172a;border-color:#0f172a;color:#fff}.form-hint{margin:2px 0 0;font-size:.76rem;color:#94a3b8;line-height:1.45}.gender-options{display:flex;gap:16px}.gender-option{display:inline-flex;align-items:center;gap:8px;color:#334155;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.btn-secondary,.btn-primary{border:none;border-radius:12px;padding:10px 16px;font-family:inherit;font-size:.9rem;font-weight:700;cursor:pointer}.btn-secondary{background:#e2e8f0;color:#0f172a}.btn-primary{background:#0f172a;color:#fff}.choice-grid{display:grid;gap:12px}.choice-btn{display:flex;flex-direction:column;gap:6px;align-items:flex-start;padding:16px;border:1px solid #dbe2ea;border-radius:16px;background:#fff;color:#0f172a;text-align:left;font-family:inherit;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.choice-btn:hover{transform:translateY(-1px);border-color:#94a3b8;box-shadow:0 12px 24px #0f172a14}.choice-btn strong{font-size:.95rem}.choice-btn span{color:#64748b;line-height:1.5}.relation-option-list{display:flex;flex-direction:column;gap:10px}.relation-option{display:grid;grid-template-columns:22px 1fr;gap:12px;align-items:start;padding:12px 14px;border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc;cursor:pointer}.relation-option input{margin-top:2px}.relation-option-title{font-size:.92rem;font-weight:700;color:#0f172a}.relation-option-desc{margin-top:4px;font-size:.8rem;color:#64748b;line-height:1.45}@media(max-width:768px){.canvas-menu-shell{display:none}.drag-handle{top:10px;left:10px;color:#94a3b8}.node-controls{top:8px;right:8px;gap:5px}.icon-btn-shad{width:24px;height:24px;border-radius:999px;background:#ffffffeb;color:#64748b;box-shadow:0 6px 16px #0f172a14}.icon-btn-add{background:#0f172a;color:#fff}.icon-btn-add:hover,.icon-btn-add-open{background:#1d4ed8;color:#fff}.card-content{gap:7px;padding:30px 12px 12px}.avatar-wrapper{width:56px;height:56px}.node-title{font-size:.68rem}.node-name{font-size:.96rem}.node-age{font-size:.78rem}.node-action-menu-btn{font-size:.74rem;min-height:32px}.node-action-menu{top:calc(100% + 6px);width:138px;gap:5px}.canvas-controls{left:50%;right:auto;bottom:calc(env(safe-area-inset-bottom,0px) + 8px);transform:translate(-50%);gap:6px;padding:6px 8px;border-radius:999px;background:#fffffff5;box-shadow:0 10px 28px #0f172a29}.control-btn{min-width:32px;height:32px;border-radius:999px;font-size:.92rem}.control-btn-reset{display:none}.layout-btn{padding:0 10px;font-size:.78rem;font-weight:700}.btn-global-tambah{top:14px;right:14px;left:auto;bottom:auto;transform:none;padding:8px 12px;font-size:.78rem;font-weight:700;border-radius:999px;box-shadow:0 12px 24px #0f172a2e}.linking-banner{top:calc(env(safe-area-inset-top,0px) + 62px);width:calc(100% - 24px);align-items:flex-start;flex-direction:column}}.person-form-modal{max-width:560px;max-height:85vh;overflow-y:auto}.person-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.person-form textarea.input{resize:vertical;min-height:80px}@media(max-width:768px){.form-row{grid-template-columns:1fr;gap:var(--space-3)}.person-form-modal{max-height:90vh}}.tree-page{min-height:100vh}.tree-main{padding:calc(var(--navbar-height) + var(--space-6)) 0 var(--space-16)}.tree-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-8);gap:var(--space-4)}.tree-header-left{flex:1}.back-btn{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-2);transition:color var(--transition-fast)}.back-btn:hover{color:var(--color-accent-primary)}.tree-header h1{font-size:var(--font-size-2xl);font-weight:700}.tree-header p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.tree-actions{display:flex;gap:var(--space-3);flex-shrink:0}.tree-container{margin-bottom:var(--space-8)}.tree-visual{overflow-x:auto;padding:var(--space-8) var(--space-4);display:flex;justify-content:center;gap:var(--space-8)}.empty-icon{display:inline-flex;color:var(--color-accent-primary);margin-bottom:var(--space-4)}.tree-branch,.tree-node-wrapper{display:flex;flex-direction:column;align-items:center}.tree-couple{display:flex;align-items:center;gap:var(--space-2)}.spouse-connector{display:inline-flex;color:var(--color-accent-primary);opacity:.85}.person-node{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-4) var(--space-5);cursor:pointer;min-width:120px;text-align:center;position:relative;transition:all var(--transition-base)}.person-node[data-gender=male]{border-top:3px solid var(--color-male)}.person-node[data-gender=female]{border-top:3px solid var(--color-female)}.person-node.selected{border-color:var(--color-accent-primary)!important;box-shadow:var(--shadow-glow);background:#d4a8531a}.person-emoji{display:inline-flex;color:inherit}.person-name{font-size:var(--font-size-sm);font-weight:600;max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.person-dates{font-size:var(--font-size-xs);color:var(--color-text-muted)}.person-deceased{position:absolute;top:var(--space-2);right:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-muted)}.children-connector{width:2px;height:24px;background:var(--color-border);margin:0 auto}.children-row{display:flex;gap:var(--space-4);position:relative;padding-top:var(--space-4)}.children-row:before{content:"";position:absolute;top:0;left:50px;right:50px;height:2px;background:var(--color-border)}.tree-stats{display:flex;justify-content:center;gap:var(--space-10);padding:var(--space-5) var(--space-8);margin-top:var(--space-6)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.stat-item .stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--color-accent-primary)}.stat-item .stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.person-detail{padding:var(--space-8);margin-top:var(--space-6)}.person-detail-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.person-avatar{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-primary)}.person-avatar[data-gender=male]{background:#60a5fa26}.person-avatar[data-gender=female]{background:#f472b626}.person-detail h2{font-size:var(--font-size-xl);font-weight:700}.person-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.person-status{display:inline-flex;align-items:center;gap:6px}.person-status-alive{color:var(--color-success)}.person-status-deceased{color:var(--color-text-muted)}.person-bio{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-3)}.person-info{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-2)}.person-links{display:flex;flex-wrap:wrap;gap:var(--space-6);margin:var(--space-6) 0;padding-top:var(--space-4);border-top:1px solid var(--color-border)}.link-section h4{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.link-tag{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast);margin-right:var(--space-2);margin-bottom:var(--space-2)}.link-tag:hover{background:var(--color-bg-glass-hover);border-color:var(--color-accent-primary)}.person-detail-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border)}@media(max-width:768px){.tree-header{flex-direction:column}.tree-actions{width:100%}.tree-actions .btn{flex:1}.tree-visual{justify-content:flex-start;min-width:max-content}.tree-stats{gap:var(--space-6);padding:var(--space-4) var(--space-5)}.person-detail-actions{flex-wrap:wrap}.person-detail-actions .btn{flex:1;min-width:100px}}.profile-page{min-height:100vh}.profile-main{padding:calc(var(--navbar-height) + var(--space-8)) 0 var(--space-16);max-width:640px;margin:0 auto}.profile-header{margin-bottom:var(--space-8)}.profile-header h1{font-size:var(--font-size-3xl);font-weight:700}.profile-header p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.profile-card{padding:var(--space-8);margin-bottom:var(--space-6)}.profile-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-5)}.profile-avatar-section{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--color-border)}.profile-avatar-large{width:72px;height:72px;border-radius:var(--radius-full);background:var(--color-accent-glow);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-avatar-large span{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-accent-primary);text-transform:uppercase}.profile-avatar-section h2{font-size:var(--font-size-xl);font-weight:600}.profile-avatar-section p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.profile-form{display:flex;flex-direction:column;gap:var(--space-4)}.profile-actions{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-2)}.save-success{color:var(--color-success);font-size:var(--font-size-sm);font-weight:500;animation:fadeIn .3s ease}.account-info{display:flex;flex-direction:column;gap:var(--space-4)}.account-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.account-row:last-child{border-bottom:none}.account-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.account-value{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);max-width:200px;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.profile-main{padding-bottom:var(--space-10)}}:root{--color-bg-primary: #0f0f1a;--color-bg-secondary: #1a1a2e;--color-bg-card: rgba(30, 30, 55, .7);--color-bg-glass: rgba(255, 255, 255, .05);--color-bg-glass-hover: rgba(255, 255, 255, .08);--color-bg-input: rgba(255, 255, 255, .06);--color-accent-primary: #d4a853;--color-accent-secondary: #e8c97a;--color-accent-glow: rgba(212, 168, 83, .3);--color-accent-gradient: linear-gradient(135deg, #d4a853, #e8c97a);--color-text-primary: #f0eee6;--color-text-secondary: #a8a5b8;--color-text-muted: #6b6880;--color-text-inverse: #0f0f1a;--color-success: #4ade80;--color-warning: #fbbf24;--color-danger: #f87171;--color-info: #60a5fa;--color-border: rgba(255, 255, 255, .08);--color-border-accent: rgba(212, 168, 83, .3);--color-male: #60a5fa;--color-female: #f472b6;--font-family: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3.5rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--color-accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--z-dropdown: 100;--z-modal: 200;--z-toast: 300;--z-navbar: 50;--navbar-height: 64px;--bottom-nav-height: 72px;--max-width: 1200px;--sidebar-width: 280px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23d4a853' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}a{color:var(--color-accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-secondary)}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.glass-card{background:var(--color-bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.glass-card:hover{background:var(--color-bg-glass-hover);border-color:var(--color-border-accent);box-shadow:var(--shadow-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-base);position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn-primary{background:var(--color-accent-gradient);color:var(--color-text-inverse);box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-bg-glass);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-glass-hover);border-color:var(--color-border-accent)}.btn-danger{background:#f8717126;color:var(--color-danger);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover{background:#f8717140}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full)}.app-icon{display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:1em;vertical-align:middle;-webkit-user-select:none;user-select:none;flex-shrink:0}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-group label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.input{padding:var(--space-3) var(--space-4);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-fast)}.input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-glow)}.input::placeholder{color:var(--color-text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-slide-up{animation:slideUp .6s ease forwards}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;flex-direction:column;gap:var(--space-4)}.loading-screen p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}@media(max-width:768px){:root{--font-size-5xl: 2.25rem;--font-size-4xl: 1.75rem;--font-size-3xl: 1.5rem}.container{padding:0 var(--space-4)}.hide-mobile{display:none!important}}@media(min-width:769px){.hide-desktop{display:none!important}}
