@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap";@import "https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&display=swap";:root{--font-display:"Outfit", "Inter", system-ui, -apple-system, sans-serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--heritage-red:#7a0612;--heritage-gold:#bf9e55;--heritage-cream:#fcf9f2;--heritage-cream-card:#fff8ef;--heritage-dark-brown:#1b120c;--heritage-green:#55745f;--heritage-gold-border:#e2cbaf;--color-brand-primary:var(--heritage-red);--color-brand-secondary:var(--heritage-green);--color-brand-accent:var(--heritage-gold);--bg-app:radial-gradient(circle at top left, var(--heritage-cream), #f0e8d9);--bg-card:var(--heritage-cream-card);--bg-card-hover:#fffdf8;--border-card:var(--heritage-gold-border);--text-primary:#2b2118;--text-secondary:#5a4e42;--text-muted:#8e7f72;--bg-input:#fcf9f2;--shadow-sm:0 4px 6px -1px #7a06120d;--shadow-md:0 10px 15px -3px #7a061214;--shadow-lg:0 20px 25px -5px #7a06121f;--bg-nav:var(--heritage-red);--glass-blur:blur(12px);--node-deceased-bg:#eae3d5;--node-deceased-border:#8e7f72;--node-deceased-text:#5a4e42;--node-living-male-bg:#e6f0fa;--node-living-male-border:#4a90e2;--node-living-female-bg:#fae6f0;--node-living-female-border:#e24a90;--color-active:#28a745;--color-deceased:#495057;--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--heritage-red:#b64235;--heritage-gold:#d6a85a;--heritage-cream:#17110c;--heritage-cream-card:#241a12;--bg-app:radial-gradient(circle at top left, var(--heritage-cream), #0f0a07);--bg-card:var(--heritage-cream-card);--bg-card-hover:#2d2017;--border-card:#4b3828;--text-primary:#f5e7d3;--text-secondary:#d4c6b2;--text-muted:#8e7f72;--bg-input:#1c150f;--shadow-sm:0 4px 6px -1px #0006;--shadow-md:0 10px 15px -3px #00000080;--shadow-lg:0 20px 25px -5px #0009;--bg-nav:#4a020a;--node-deceased-bg:#1b120c;--node-deceased-border:#4b3828;--node-deceased-text:#8e7f72;--node-living-male-bg:#4a90e226;--node-living-male-border:#4a90e2;--node-living-female-bg:#e24a9026;--node-living-female-border:#e24a90}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition-normal);overflow:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-primary);font-weight:700;line-height:1.2}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none;outline:none}button{cursor:pointer}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-card);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-brand-primary)}.glass{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-card);box-shadow:var(--shadow-md);transition:background var(--transition-normal), border var(--transition-normal), box-shadow var(--transition-normal)}.glass-hover:hover{background:var(--bg-card-hover);box-shadow:var(--shadow-lg);border-color:var(--color-brand-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-5px)}to{transform:translateY(0)}}.animate-fade{animation:fadeIn var(--transition-normal) forwards}.animate-slide-up{animation:slideInUp var(--transition-normal) forwards}.animate-slide-right{animation:slideInRight var(--transition-normal) forwards}.animate-scale-up{animation:scaleUp var(--transition-normal) forwards}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{color:var(--color-brand-primary);background:#bfa15f26;border:1px solid #bfa15f4d}.badge-success{color:var(--color-active);background:#28a74526;border:1px solid #28a7454d}.badge-secondary{color:var(--text-muted);background:#8d7e6f26;border:1px solid #8d7e6f4d}.tooltip-container{position:relative}.tooltip-text{visibility:hidden;color:#fff;text-align:center;white-space:nowrap;opacity:0;z-index:1000;background-color:#2d261e;border-radius:6px;padding:5px 10px;font-size:.75rem;transition:opacity .2s;position:absolute;bottom:125%;left:50%;transform:translate(-50%)}.tooltip-container:hover .tooltip-text{visibility:visible;opacity:1}.tooltip-container.tooltip-bottom .tooltip-text{top:calc(100% + 8px);bottom:auto}.serif{font-family:Lora,Georgia,Times New Roman,serif}.homepage-container{--home-red:#8b0d0b;--home-red-dark:#620504;--home-gold:#b9822f;--home-gold-soft:#dfc38a;--home-green:#557861;--home-teal:#5b8b88;--home-paper:#f8efdf;--home-ink:#3c2417;--home-muted:#755f49;--home-line:#af7f3f57;--home-panel:#fff9ebc7;--home-shadow:0 14px 28px #66361224;--home-radius:8px;width:100%;height:100%;color:var(--home-ink);background:var(--home-paper);scroll-behavior:smooth;isolation:isolate;padding:clamp(1.25rem,1.55vw,1.52rem) clamp(1.25rem,4vw,4.25rem) 0;position:relative;overflow:hidden auto}.homepage-container:before{content:"";pointer-events:none;background:var(--home-dongson-drum) center 42% / min(90vw, 860px) no-repeat, var(--home-gold-waves-lotus) left -7% bottom 4% / 650px auto no-repeat, var(--home-gold-waves-lotus) right -7% bottom 4% / 650px auto no-repeat;opacity:.12;mix-blend-mode:multiply;z-index:-1;position:fixed;inset:70px 0 0}.homepage-container:after{content:"";pointer-events:none;z-index:-1;background:0 0;display:none;position:fixed;inset:70px 0 0}.home-hero{grid-template-columns:minmax(188px,.15fr) minmax(570px,.42fr) minmax(660px,.5fr);align-items:center;gap:clamp(1rem,1.25vw,1.4rem);min-height:310px;margin-bottom:.86rem;display:grid}.hero-lotus-art{opacity:.96;filter:drop-shadow(0 18px 18px #4c311a21);align-self:end;width:min(18vw,252px);min-width:180px;transform:translate(-22%)translateY(7%)}.home-hero-copy{padding:0 0 .55rem;position:relative;transform:translateY(-.55rem)}.hero-cloud-mark,.panel-cloud,.header-mark{opacity:.76;background-repeat:no-repeat;display:inline-block}.hero-cloud-mark{background-image:var(--home-gold-clouds);background-position:7.5% 8.5%;background-size:760px;width:86px;height:34px}.header-mark{background-image:var(--home-gold-waves-lotus);background-position:33% 83%;background-size:690px;width:28px;height:24px}.hero-title{color:var(--home-red);letter-spacing:-.01em;text-wrap:balance;text-shadow:0 1px #fff8e8d1;margin:.25rem 0 0;font-size:clamp(1.2rem,7.5vw,3rem);font-style:italic;line-height:1.3}.hero-title span{white-space:nowrap;display:block}.hero-divider{background:radial-gradient(circle, var(--home-gold) 0 3px, transparent 4px) center / 26px 26px no-repeat, linear-gradient(45deg, transparent 42%, var(--home-gold) 42% 58%, transparent 58%) center / 28px 28px no-repeat, linear-gradient(-45deg, transparent 42%, var(--home-gold) 42% 58%, transparent 58%) center / 28px 28px no-repeat, linear-gradient(90deg, transparent, var(--home-gold) 18%, var(--home-gold) 43%, transparent 43% 57%, var(--home-gold) 57%, var(--home-gold) 82%, transparent) center / 100% 1px no-repeat;opacity:.68;width:min(350px,58%);height:21px;margin:.62rem 0 .8rem;display:block}.hero-description{color:#57412e;max-width:660px;margin:0;font-size:clamp(.88rem,.92vw,.95rem);line-height:1.52}.hero-cta-buttons{flex-wrap:wrap;gap:1.1rem;margin-top:1rem;display:flex}.heritage-btn{border:1px solid var(--home-line);border-radius:6px;justify-content:center;align-items:center;gap:.75rem;min-width:205px;min-height:46px;font-size:1rem;font-weight:800;transition:transform .18s,box-shadow .18s,background .18s;display:inline-flex;box-shadow:0 8px 16px #5c2c0c29,inset 0 1px #fff9eb8c}.heritage-btn:hover{transform:translateY(-2px);box-shadow:0 12px 22px #5c2c0c38,inset 0 1px #fff9eba6}.heritage-btn:active{transform:translateY(0)scale(.99)}.heritage-btn-primary{color:#fff8df;background:linear-gradient(180deg, #ffffff29, transparent 42%), var(--home-red);border-color:#d6b77b}.heritage-btn-secondary{color:#6c4016;background:#fff9ebc7;border-color:#af7f3f8c}.heritage-icon{flex:none;place-items:center;width:27px;height:27px;display:inline-grid;position:relative}.heritage-icon svg{width:100%;height:100%;display:block}.hero-tree-panel,.stat-card,.feature-card,.home-panel{border:1px solid var(--home-line);border-radius:var(--home-radius);box-shadow:var(--home-shadow);background:#fffaeef0}.hero-tree-panel{align-self:start;min-height:286px;padding:.82rem 1.05rem .58rem;position:relative;overflow:hidden}.hero-tree-panel:before{content:"";background:linear-gradient(180deg, #fffaeead 0 44%, #e4dcc42e 72%, #fffaee2e), var(--home-mountain-bg) center bottom 10% / 108% auto no-repeat;pointer-events:none;opacity:.38;mix-blend-mode:multiply;position:absolute;inset:0}.hero-tree-panel:after{content:"";pointer-events:none;background:0 0;display:none;position:absolute;inset:0}.panel-heading{z-index:5;color:var(--home-ink);justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.45rem;display:flex;position:relative}.panel-heading strong{align-items:center;gap:.45rem;font-size:1rem;display:inline-flex}.panel-heading strong:before{content:"";background:linear-gradient(135deg,#7a9a72,#426a53);border-radius:62% 0;width:13px;height:18px;transform:rotate(24deg);box-shadow:inset 0 1px #ffffff6b}.panel-link{color:#87340c;white-space:nowrap;background:#fff8e6bf;border:1px solid #af7f3f8c;border-radius:4px;align-items:center;gap:.55rem;min-height:35px;padding:0 .8rem;font-weight:700;transition:transform .18s,background .18s;display:inline-flex}.panel-link:hover{background:#fff3da;transform:translate(2px)}.tree-panel-icon-strip{z-index:4;opacity:.76;gap:.5rem;display:flex;position:absolute;top:4.8rem;right:1.4rem}.panel-mini-icon{color:#9b691e;background:#fff9ebb8;border:1px solid #b7822f73;border-radius:50%;width:28px;height:28px;display:inline-block;position:relative;box-shadow:inset 0 0 0 2px #ffffff80,0 3px 7px #502c1014}.panel-mini-icon:before,.panel-mini-icon:after{content:"";position:absolute}.panel-mini-home:before{border:2px solid;border-top:0;width:12px;height:9px;top:12px;left:8px}.panel-mini-home:after{border-top:2px solid;border-left:2px solid;width:13px;height:13px;top:6px;left:7px;transform:rotate(45deg)}.panel-mini-tree:before{background:currentColor;width:2px;height:16px;top:6px;left:13px}.panel-mini-tree:after{border:2px solid;border-bottom:0;border-radius:50% 50% 34% 34%;width:14px;height:11px;top:5px;left:7px}.panel-mini-calendar:before{border:2px solid;border-radius:3px;inset:7px 6px 5px}.panel-mini-calendar:after{background:currentColor;width:3px;height:3px;top:13px;left:11px;box-shadow:5px 0,0 5px,5px 5px}.panel-mini-record:before{border:2px solid;border-radius:2px;width:13px;height:18px;top:5px;left:8px}.panel-mini-record:after{background:currentColor;width:8px;height:2px;top:12px;left:11px;box-shadow:0 5px}.panel-mini-search:before{border:2px solid #8b0d0b;border-radius:50%;width:12px;height:12px;top:5px;left:6px}.panel-mini-search:after{background:#8b0d0b;width:8px;height:2px;bottom:6px;right:6px;transform:rotate(45deg)}.pine-art{opacity:.2;z-index:3;pointer-events:none;filter:drop-shadow(0 8px 12px #3c2a121f);width:min(22vw,240px);min-width:160px;position:absolute;top:auto;bottom:3.75rem;right:-3rem}.panel-cloud{background-image:var(--home-gold-clouds);opacity:.42;z-index:3;background-repeat:no-repeat;background-size:690px;width:92px;height:38px;position:absolute}.panel-cloud-left{background-position:40% 34%;top:33%;left:14%}.panel-cloud-right{background-position:69% 51%;width:118px;height:46px;top:45%;right:26%}.mini-family-tree{z-index:4;grid-template-rows:auto 28px auto auto;place-items:center;min-height:212px;padding:.12rem .35rem 0;display:grid;position:relative}.tree-founder,.tree-child{background:linear-gradient(#fffcf4e6,#fff6e0d1);border:1px solid #9b6c2f6b;border-radius:7px;box-shadow:0 8px 14px #5237181c,inset 0 0 0 1px #ffffff94}.tree-founder{align-items:center;gap:.8rem;min-width:190px;padding:.45rem .72rem;display:flex}.tree-founder img{object-fit:cover;border:2px solid #af7f3f8c;border-radius:50%;width:48px;height:48px}.generated-avatar{letter-spacing:0;text-transform:uppercase;flex:none;place-items:center;font-family:Lora,Georgia,serif;font-weight:850;display:inline-grid}.tree-founder>.generated-avatar{border:2px solid #af7f3f8c;border-radius:50%;width:48px;height:48px;font-size:1rem;box-shadow:inset 0 0 0 2px #fff9e847,0 4px 7px #4e381a1f}.tree-founder div,.tree-child{flex-direction:column;align-items:center;display:flex}.tree-founder span,.tree-founder small,.tree-child small{color:var(--home-muted);font-size:.72rem}.tree-founder strong,.tree-child strong{color:var(--home-ink);white-space:nowrap;font-size:.92rem;line-height:1.2}.tree-lines{width:min(420px,72%);height:28px;position:relative}.tree-lines:before,.tree-lines:after{content:"";background:#5d2c18;position:absolute}.tree-lines:before{height:2px;top:10px;left:12%;right:12%}.tree-lines:after{width:2px;height:30px;top:0;left:50%}.tree-lines span{background:#5d2c18;width:2px;height:19px;position:absolute;top:10px}.tree-lines span:first-child{left:12%}.tree-lines span:nth-child(2){left:50%}.tree-lines span:nth-child(3){right:12%}.tree-children{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;width:min(510px,88%);display:grid}.tree-child{box-sizing:border-box;grid-template-rows:auto auto;grid-template-columns:24px 1fr;place-items:center start;column-gap:.3rem;width:100%;min-width:0;min-height:46px;padding:.25rem .35rem;display:grid}.tree-child-landscape{object-fit:cover;border:1px solid #55786173;border-radius:50%;grid-row:1/span 2;place-items:center;width:24px;height:24px;margin-bottom:0;font-size:.58rem;line-height:1;display:inline-grid;box-shadow:inset 0 0 0 1.5px #fff9e8b8,0 3px 6px #4e381a1a}.tree-child-landscape.generated-avatar{background-image:none}.tree-child strong{text-overflow:ellipsis;white-space:nowrap;align-self:end;max-width:100%;font-size:.65rem;overflow:hidden}.tree-child small{white-space:nowrap;text-overflow:ellipsis;align-self:start;max-width:100%;font-size:.55rem;overflow:hidden}.branch-row{grid-template-columns:repeat(var(--branch-cols,5), minmax(0, 1fr));gap:.25rem;width:100%;margin-top:.34rem;display:grid}.branch-row button{color:#644019;justify-items:center;gap:.1rem;min-width:0;font-size:.66rem;font-weight:700;display:grid}.branch-row .heritage-icon{color:#815215;width:28px;height:28px}.hero-dots{z-index:2;justify-content:center;gap:.9rem;margin-top:.45rem;display:flex;position:relative}.hero-dots span{background:#b3844059;border-radius:50%;width:8px;height:8px}.hero-dots .active{background:var(--home-red)}.mini-family-tree-dynamic{z-index:4;flex-direction:column;align-items:center;width:100%;display:flex;position:relative}.desktop-only-tree{display:flex!important}.mobile-only-tree,.mobile-only-dots{display:none!important}.couple-role-badge,.mobile-couple-connectors{display:none}.mini-tree-root-wrapper{justify-content:center;margin-bottom:0;display:flex}.mini-tree-connectors-wrapper{flex-direction:column;align-items:center;width:100%;height:24px;display:flex;position:relative}.mini-tree-line-down-from-root{background:#5d2c18;width:2px;height:14px;margin-top:-2px}.mini-tree-horizontal-line{background:#5d2c18;height:2px;position:absolute;top:12px}.mini-tree-children-wrapper{grid-template-columns:repeat(var(--tree-child-cols,5), minmax(0, 1fr));gap:.35rem;width:100%;display:grid}.mini-tree-child-column{flex-direction:column;flex:1;align-items:center;min-width:0;display:flex}.mini-tree-line-down-to-child{z-index:2;background:#5d2c18;width:2px;height:16px;margin-bottom:-4px;position:relative}.desktop-only-tree .mini-tree-line-down-to-child{height:28px;margin-top:-12px}.tree-branch-btn{color:#644019;background:0 0;border:none;flex-direction:column;align-items:center;gap:.1rem;width:100%;margin-top:.6rem;padding:0;font-size:.66rem;font-weight:700;display:flex}.tree-branch-btn .heritage-icon{color:#815215;width:28px;height:28px}.homepage-stats-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:1.45rem;margin:0 clamp(0rem,3.4vw,3.65rem) .8rem;display:grid}.stat-card{align-items:center;gap:1.05rem;min-height:78px;padding:.86rem 1.12rem;display:flex}.stat-icon-wrapper{color:#f9efd7;border:2px solid #fff9ebbf;border-radius:50%;flex:none;place-items:center;width:57px;height:57px;font-size:.78rem;font-weight:800;display:grid;box-shadow:inset 0 0 0 1px #502c0c26,0 8px 12px #482b121f}.stat-green .stat-icon-wrapper{background:var(--home-green)}.stat-red .stat-icon-wrapper{background:#ab1715}.stat-gold .stat-icon-wrapper{background:#c28d36}.stat-details{min-width:0}.stat-details>div{align-items:baseline;gap:.75rem;display:flex}.stat-number{color:var(--home-red);font-family:Lora,Georgia,serif;font-size:clamp(1.7rem,2vw,2.2rem);line-height:1}.stat-green .stat-number{color:var(--home-green)}.stat-gold .stat-number{color:#b77816}.stat-label{color:var(--home-ink);white-space:nowrap;font-weight:800}.stat-note{color:var(--home-muted);margin-top:.25rem;font-size:.83rem;display:block}.homepage-features-section{grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin-bottom:.72rem;display:grid}.feature-card{text-align:left;grid-template-columns:83px 1fr;align-items:center;gap:.9rem;min-height:108px;padding:.8rem .95rem;transition:transform .18s,box-shadow .18s,border-color .18s;display:grid}.feature-card:hover{border-color:#8b0d0b6b;transform:translateY(-2px);box-shadow:0 16px 24px #6636122e}.feature-card:active{transform:scale(.995)}.feature-medallion{color:#f9efd7;background:var(--home-green);border-radius:50%;place-items:center;width:73px;height:73px;display:grid;box-shadow:inset 0 0 0 3px #fff9eb8f,0 8px 12px #482b121f}.feature-gold .feature-medallion{background:#c28d36}.feature-red .feature-medallion{background:#c76552}.feature-teal .feature-medallion{background:var(--home-teal)}.feature-medallion .heritage-icon{color:currentColor;width:36px;height:36px}.feature-body{flex-direction:column;gap:.18rem;min-width:0;display:flex}.feature-title{color:var(--home-ink);font-size:1.23rem}.feature-desc{color:#54402c;font-size:.82rem;line-height:1.42}.feature-link{color:#6b3b14;margin-top:.18rem;font-size:.82rem;font-weight:800}.homepage-bottom-grid{grid-template-columns:.97fr .92fr 1.03fr;gap:1rem;margin-bottom:.65rem;display:grid}.home-panel{height:242px;padding:.7rem 1.05rem .78rem;overflow:hidden}.panel-events,.panel-notables{flex-direction:column;min-height:0;display:flex}.column-header-row{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.72rem;display:flex}.column-title{color:var(--home-red);align-items:center;gap:.45rem;font-size:1.12rem;line-height:1.2;display:inline-flex}.header-mark{opacity:.95;width:25px;height:21px}.column-more-link{color:#6c3d18;white-space:nowrap;font-size:.73rem;font-weight:800;transition:color .16s}.column-more-link:hover{color:var(--home-red)}.panel-events .column-header-row{grid-template-columns:minmax(0,auto) minmax(7.5rem,1fr) max-content;align-items:center;gap:clamp(.34rem,1.1vw,.9rem);display:grid}.panel-events .column-title{min-width:0;font-size:clamp(.86rem,1.2vw,1.12rem)}.panel-events .column-more-link{text-align:right;min-width:0;font-size:clamp(.58rem,.78vw,.73rem)}.lunar-today-pill{min-width:0;max-width:100%;color:var(--home-gold);text-align:center;white-space:nowrap;text-overflow:ellipsis;justify-self:center;padding:0;font-size:clamp(.62rem,.82vw,.76rem);font-weight:900;line-height:1.15;overflow:hidden}.notables-list{overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:#af7f3f94 #af7f3f14;grid-template-columns:repeat(4,minmax(0,1fr));gap:.7rem;min-height:0;padding-right:.22rem;display:grid;overflow-y:auto}.panel-notables .notables-list{flex:1}.notables-list::-webkit-scrollbar{width:6px}.notables-list::-webkit-scrollbar-track{background:#af7f3f14;border-radius:999px}.notables-list::-webkit-scrollbar-thumb{background:#af7f3f80;border-radius:999px}.notable-card{text-align:left;background:#fff6e1bd;border:1px solid #af7f3f57;border-radius:7px;flex-direction:column;align-items:stretch;padding:.48rem;transition:transform .16s,border-color .16s;display:flex}.notable-card:hover{border-color:#8b0d0b61;transform:translateY(-2px)}.notable-avatar{aspect-ratio:1/.95;object-fit:cover;box-sizing:border-box;background:#f0dfbd;border:1px solid #af7f3f6b;border-radius:5px;place-items:center;width:100%;margin-bottom:.45rem;font-size:1.25rem;display:grid}.notable-name{color:var(--home-ink);font-size:.86rem;line-height:1.2}.notable-copy{flex-direction:column;min-width:0;display:flex}.notable-title,.notable-years{color:var(--home-muted);font-size:.72rem;line-height:1.25}.notables-empty-state{color:var(--home-muted);grid-column:1/-1;padding:.9rem .2rem .35rem;font-size:.82rem;line-height:1.45}.anniversaries-list{overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:#af7f3f94 #af7f3f14;flex-direction:column;gap:0;min-height:0;padding-right:.22rem;display:flex;overflow-y:auto}.panel-events .anniversaries-list{flex:1}.anniversaries-list::-webkit-scrollbar{width:6px}.anniversaries-list::-webkit-scrollbar-track{background:#af7f3f14;border-radius:999px}.anniversaries-list::-webkit-scrollbar-thumb{background:#af7f3f80;border-radius:999px}.anniversary-item{border-top:1px solid #af7f3f38;grid-template-columns:68px 1fr auto;align-items:center;gap:.7rem;padding:.34rem 0;display:grid}.anniversary-item:first-child{border-top:0}.anniversary-date-box{min-height:49px;color:var(--home-red);text-align:center;border-right:1px solid #af7f3f52;flex-direction:column;justify-content:center;display:flex}.anniversary-date-box strong{font-family:Lora,Georgia,serif;font-size:1.45rem;line-height:1}.anniversary-date-box span{font-size:.78rem;font-weight:800}.anniversary-details{flex-direction:column;gap:.1rem;min-width:0;display:flex}.anniversary-details strong{color:var(--home-red);white-space:nowrap;text-overflow:ellipsis;font-size:.86rem;overflow:hidden}.anniversary-details span,.anniversary-details small{color:var(--home-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.anniversary-empty-state{color:var(--home-muted);padding:.9rem .2rem .35rem;font-size:.82rem;line-height:1.45}.btn-item-action{color:#8b310d;white-space:nowrap;background:#fff7e6b8;border:1px solid #af7f3f6b;border-radius:5px;min-height:30px;padding:0 .66rem;font-size:.72rem;font-weight:800;transition:background .16s,transform .16s}.btn-item-action:hover{background:#fff1d3;transform:translateY(-1px)}.history-timeline{--timeline-year-width:56px;--timeline-rail-width:18px;--timeline-column-gap:.56rem;--timeline-line-x:calc(var(--timeline-year-width) + var(--timeline-column-gap) + (var(--timeline-rail-width) / 2));gap:.43rem;padding:.12rem 0 0;display:grid;position:relative}.history-timeline:before{content:"";left:var(--timeline-line-x);background:#8b0d0b9e;width:1px;position:absolute;top:.58rem;bottom:.64rem;transform:translate(-.5px)}.timeline-node{grid-template-columns:var(--timeline-year-width) var(--timeline-rail-width) minmax(0, 1fr);column-gap:var(--timeline-column-gap);align-items:center;min-height:1.18rem;display:grid;position:relative}.timeline-node:before{content:"";border:2px solid var(--home-red);z-index:1;background:#f9efd7;border-radius:50%;grid-area:1/2;justify-self:center;width:8px;height:8px;box-shadow:0 0 0 2px #fff9ebe6}.timeline-node strong{color:var(--home-red);text-align:left;grid-column:1;font-size:.82rem;line-height:1.08}.timeline-node span{color:#57412e;grid-column:3;min-width:0;font-size:.78rem;line-height:1.35}.traditional-footer{color:#f5dfb7;background:var(--home-gold-waves-lotus) left 2rem bottom -.25rem / 390px auto no-repeat, var(--home-gold-waves-lotus) right 2rem bottom -.25rem / 390px auto no-repeat, radial-gradient(circle at 8% 50%, #b8822f38, transparent 18%), radial-gradient(circle at 92% 50%, #b8822f2e, transparent 18%), linear-gradient(90deg, #1b0d05, #3a1c0b 45%, #1b0d05);border-top:2px solid #b8822f61;place-items:center;min-height:86px;margin:0 calc(-1*clamp(1.25rem,4vw,4.25rem));display:grid;position:relative;overflow:hidden}.traditional-footer:before,.traditional-footer:after{content:"";opacity:.48;background-image:var(--home-gold-borders);background-position:3% 88%;background-repeat:no-repeat;background-size:720px;width:260px;height:70px;position:absolute;bottom:5px}.traditional-footer:before{left:2rem}.traditional-footer:after{right:2rem;transform:scaleX(-1)}.footer-quote{text-align:center;z-index:1;max-width:820px;font-size:clamp(1.05rem,1.3vw,1.28rem);font-style:italic;line-height:1.55;position:relative}.footer-quote span{display:block}@media (width<=1280px){.home-hero{grid-template-columns:165px minmax(320px,.56fr) minmax(410px,.64fr);gap:1.4rem}}@media (width<=1024px){.homepage-container{padding:1rem}.home-hero{grid-template-columns:minmax(0,1fr)}.hero-lotus-art{opacity:.22;width:200px;min-width:0;position:absolute;top:1.8rem;right:.8rem;transform:none}.home-hero-copy{z-index:1;text-align:center;flex-direction:column;align-items:center;padding:0;display:flex;position:relative;transform:none}.hero-divider{margin:.62rem auto .8rem}.hero-cta-buttons{justify-content:center}.hero-tree-panel{z-index:1;position:relative}.homepage-stats-row,.homepage-features-section{grid-template-columns:repeat(2,minmax(0,1fr))}.homepage-bottom-grid{grid-template-columns:1fr 1fr}.panel-history{grid-column:1/-1}.traditional-footer{margin:0 -1rem}}@media (width<=760px){.homepage-container{padding:.85rem}.desktop-only-tree{display:none!important}.mobile-only-tree{flex-direction:column;align-items:center;width:100%;display:flex!important}.mobile-only-dots{display:flex!important}.mobile-root-row{isolation:isolate;flex-direction:column;justify-content:center;gap:.72rem;width:100%;margin-bottom:0;display:flex;position:relative}.mobile-root-row.has-spouse:before{content:"";z-index:1;border-left:2px dashed #5d2c18b8;height:.92rem;position:absolute;top:calc(50% - .46rem);left:50%;transform:translate(-1px)}.mobile-root-row .tree-founder{z-index:2;align-items:flex-start;gap:.58rem;width:100%;min-width:0;padding:.5rem 2.1rem .5rem .55rem;position:relative}.mobile-root-row .tree-founder>div{flex:1;align-items:flex-start;min-width:0}.mobile-root-row .tree-founder img{border-width:1.5px;width:36px;height:36px}.mobile-root-row .tree-founder>.generated-avatar{border-width:1.5px;width:36px;height:36px;font-size:.78rem}.mobile-root-row .tree-founder strong{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.86rem;display:block;overflow:hidden}.mobile-root-row .tree-founder span,.mobile-root-row .tree-founder small{font-size:.65rem}.mobile-root-row .parent-node{background:linear-gradient(#fffaeef0,#ffefd6d6);border-color:#8b0d0b7a}.mobile-root-row .spouse-node{background:linear-gradient(#f9fcf4f0,#e8f4ebd1);border-color:#5b8b8880}.couple-role-badge{background:var(--home-red);border-radius:999px;justify-content:center;align-items:center;min-height:18px;padding:0 .42rem;font-weight:800;line-height:1;display:inline-flex;position:absolute;top:-.45rem;left:auto;right:-.08rem;box-shadow:0 4px 8px #26120833,inset 0 0 0 1px #ffffff38;color:#fff8e8!important;font-size:.56rem!important}.spouse-node .couple-role-badge{background:#4f7f74;left:auto;right:-.08rem}.mobile-couple-connectors{width:100%;height:34px;margin:-.03rem 0 .12rem;display:block;position:relative}.mobile-couple-line{border-left:0;height:0;position:absolute;top:0;left:50%}.mobile-root-row.single-parent+.mobile-couple-connectors .mobile-couple-line{display:none}.mobile-family-drop{border-left:2px solid #5d2c18b8;width:0;height:30px;position:absolute;top:0;left:50%;transform:translate(-1px)}.hero-description{font-size:.92rem}.hero-cta-buttons,.heritage-btn{width:100%}.homepage-stats-row,.homepage-features-section,.homepage-bottom-grid,.tree-children{grid-template-columns:1fr}.home-panel{height:auto}.panel-events{height:min(68vh,330px)}.panel-events .column-header-row{grid-template-columns:minmax(5.6rem,auto) minmax(4.8rem,1fr) max-content;gap:.38rem}.panel-events .column-title{gap:.28rem;font-size:clamp(.78rem,3.4vw,1.02rem)}.panel-events .column-title .header-mark{width:20px;height:17px}.lunar-today-pill{font-size:clamp(.54rem,2.25vw,.68rem)}.panel-events .column-more-link{font-size:clamp(.5rem,2vw,.64rem)}.hero-tree-panel{min-height:auto}.pine-art,.panel-cloud,.tree-panel-icon-strip,.mini-tree-connectors-wrapper{display:none}.mini-tree-children-wrapper{border-top:1px solid #af7f3f3d;flex-direction:column;align-items:stretch;gap:.55rem;margin-top:.2rem;padding-top:.55rem;display:flex;position:relative}.mini-tree-children-wrapper:before{content:"Con cái";color:#704119;background:#fff6e0d1;border:1px solid #af7f3f52;border-radius:999px;align-self:center;align-items:center;min-height:20px;margin:-.18rem 0 .08rem;padding:0 .55rem;font-size:.62rem;font-weight:850;display:inline-flex}.mobile-child-family-card strong{align-items:baseline;gap:.34rem;min-width:0;max-width:100%;display:flex}.mobile-child-family-card .child-name-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.mobile-child-family-card .child-inline-status{color:var(--home-muted);flex:none;font-size:.54rem;font-weight:700}.mobile-child-family-card small{color:#6d4a24;font-weight:700}.mini-tree-child-column{flex-direction:row;justify-content:space-between;align-items:center;gap:.8rem;width:100%;display:flex}.mini-tree-line-down-to-child{display:none}.tree-branch-btn{color:#87340c;border:1px solid var(--home-line);white-space:nowrap;box-sizing:border-box;background:#fff6e073;border-radius:6px;flex-direction:row;flex-shrink:0;align-items:center;gap:.35rem;width:auto;padding:.3rem .55rem;font-size:.72rem;font-weight:700;box-shadow:0 2px 4px #5c2c0c14;margin-top:0!important}.tree-branch-btn .heritage-icon{color:#815215;width:18px!important;height:18px!important}.skeleton-branch-btn{flex-shrink:0;width:90px;height:32px;margin-top:0!important}[data-theme=dark] .tree-branch-btn{box-shadow:0 2px 4px #0000004d;color:#f5c05b!important;background:#0e0e0c99!important;border-color:#f5c05b40!important}[data-theme=dark] .tree-branch-btn .heritage-icon{color:#f5c05b!important}.mini-family-tree{grid-template-rows:auto 28px auto auto;min-height:auto}.tree-lines{width:60%}.tree-children{gap:.55rem}.tree-child{flex:1;grid-template-columns:40px 1fr;align-items:center;column-gap:.6rem;width:auto;min-width:0;display:grid}.tree-child-landscape{width:38px;height:38px}.tree-child strong{font-size:.82rem}.tree-child small{font-size:.72rem}.branch-row{grid-template-columns:repeat(3,minmax(0,1fr))}.feature-card{grid-template-columns:72px 1fr}.notables-list{grid-template-columns:1fr}.notable-card{grid-template-columns:66px minmax(0,1fr);align-items:center;gap:.72rem;padding:.54rem;display:grid}.notable-avatar{aspect-ratio:1;width:66px;margin-bottom:0;font-size:.92rem}.notable-name{font-size:.88rem}.notable-title,.notable-years{font-size:.74rem}.anniversary-item{grid-template-columns:58px 1fr}.btn-item-action{grid-column:2;width:max-content}.traditional-footer{margin:0 -.85rem;padding:1.4rem 1rem}.traditional-footer:before,.traditional-footer:after{display:none}}@media (width<=460px){.panel-heading{flex-direction:column;align-items:flex-start}.panel-link{justify-content:center;width:100%}.tree-founder{width:100%}.notables-list{grid-template-columns:1fr}.notable-card{grid-template-columns:60px minmax(0,1fr)}.notable-avatar{width:60px}.stat-card{align-items:flex-start}}@media (prefers-reduced-motion:reduce){.heritage-btn,.feature-card,.notable-card,.panel-link,.btn-item-action{transition:none}}[data-theme=dark] .homepage-container{--home-red:#ff6b6b;--home-red-dark:#c92a2a;--home-gold:#f5c05b;--home-gold-soft:#ffe066;--home-green:#51cf66;--home-teal:#22b8cf;--home-paper:#0e0e0c;--home-ink:#f8f0e3;--home-muted:#bcaba0;--home-line:#f5c05b26;--home-panel:#0e0e0ca6;--home-shadow:0 16px 36px #000000a6;background:var(--home-paper)}[data-theme=dark] .homepage-container:before{background:var(--home-dongson-drum) center 42% / min(90vw, 860px) no-repeat, var(--home-gold-waves-lotus) left -7% bottom 4% / 650px auto no-repeat, var(--home-gold-waves-lotus) right -7% bottom 4% / 650px auto no-repeat;opacity:.08;filter:invert()hue-rotate(180deg)brightness(.95)contrast(1.1);mix-blend-mode:screen}[data-theme=dark] .homepage-container:after{background:0 0;display:none}[data-theme=dark] .hero-title{text-shadow:0 2px 4px #000c}[data-theme=dark] .hero-description{color:#cbbcb0}[data-theme=dark] .hero-divider{opacity:.35}[data-theme=dark] .heritage-btn-primary{color:#fff8df;background:linear-gradient(#ffffff29,#0000 42%),#8b0d0b;border-color:#d6b77b}[data-theme=dark] .heritage-btn-secondary{color:#f5c05b;-webkit-backdrop-filter:blur(12px);background:#0e0e0ca6;border-color:#f5c05b4d;box-shadow:0 8px 16px #0006,inset 0 1px #ffffff0a}[data-theme=dark] .heritage-btn-secondary:hover{background:#0e0e0cd9;border-color:#f5c05b73}[data-theme=dark] .hero-tree-panel,[data-theme=dark] .stat-card,[data-theme=dark] .feature-card,[data-theme=dark] .home-panel{-webkit-backdrop-filter:blur(24px)saturate(120%)!important;background:#0e0e0c9e!important;border:1px solid #f5c05b29!important;box-shadow:inset 0 1px 1px #ffffff0d,0 12px 32px #0009!important}[data-theme=dark] .hero-tree-panel:before{background:linear-gradient(180deg, #0e0e0c80 0 44%, #0e0e0c33 72%, #0e0e0c1a), var(--home-mountain-bg) center bottom 10% / 108% auto no-repeat;opacity:.25;filter:invert()hue-rotate(180deg)brightness(.9)contrast(1.1);mix-blend-mode:screen}[data-theme=dark] .hero-tree-panel:after{background:0 0;display:none}[data-theme=dark] .panel-link{color:#f5c05b;-webkit-backdrop-filter:blur(8px);background:#0e0e0cbf;border-color:#f5c05b59}[data-theme=dark] .panel-link:hover{color:#ffe066;background:#0e0e0ce6}[data-theme=dark] .panel-mini-icon{color:#f5c05b;background:#0e0e0cb3;border-color:#f5c05b40;box-shadow:inset 0 0 0 2px #ffffff0a,0 3px 7px #0006}[data-theme=dark] .stat-icon-wrapper{border-color:#f5c05b40;box-shadow:inset 0 0 0 1px #0003,0 8px 12px #0006}[data-theme=dark] .stat-green .stat-number{color:#51cf66}[data-theme=dark] .stat-gold .stat-number{color:#f5c05b}[data-theme=dark] .stat-red .stat-number{color:#ff6b6b}[data-theme=dark] .feature-medallion{box-shadow:inset 0 0 0 3px #0e0e0c73,0 8px 12px #0006}[data-theme=dark] .feature-desc{color:#bcaba0}[data-theme=dark] .feature-link{color:#f5c05b}[data-theme=dark] .column-more-link{color:#bcaba0}[data-theme=dark] .column-more-link:hover{color:var(--home-gold)}[data-theme=dark] .notable-card{-webkit-backdrop-filter:blur(12px)!important;background:#0e0e0c80!important;border-color:#f5c05b26!important}[data-theme=dark] .notable-card:hover{background:#0e0e0ca6!important;border-color:#f5c05b59!important}[data-theme=dark] .notable-avatar{background:#0e0e0c;border-color:#f5c05b33}[data-theme=dark] .anniversary-item{border-top-color:#f5c05b1f}[data-theme=dark] .anniversary-date-box{color:#ff6b6b;border-right-color:#f5c05b2e}[data-theme=dark] .btn-item-action{color:#f5c05b;-webkit-backdrop-filter:blur(8px);background:#0e0e0ca6;border-color:#f5c05b40}[data-theme=dark] .btn-item-action:hover{color:#ffe066;background:#0e0e0cd9}[data-theme=dark] .history-timeline:before{background:#f5c05b40}[data-theme=dark] .timeline-node:before{border-color:var(--home-gold);background:#0e0e0c;box-shadow:0 0 0 2px #0e0e0ce6}[data-theme=dark] .timeline-node strong{color:#ff6b6b}[data-theme=dark] .timeline-node span{color:#cbbcb0}[data-theme=dark] .tree-founder,[data-theme=dark] .tree-child{-webkit-backdrop-filter:blur(12px)!important;background:#0e0e0cd9!important;border:1.2px solid #f5c05b47!important;box-shadow:inset 0 1px #ffffff0d,0 8px 16px #00000080!important}[data-theme=dark] .tree-founder img{border-color:#f5c05b73}[data-theme=dark] .tree-child-landscape{background:linear-gradient(#0e0e0cb3, #0e0e0cb3), var(--home-mountain-bg) center 70% / 260px auto no-repeat;border-color:#7ca88a59;box-shadow:inset 0 0 0 2px #fff9e80a,0 4px 7px #0006}[data-theme=dark] .tree-lines:before,[data-theme=dark] .tree-lines:after,[data-theme=dark] .tree-lines span,[data-theme=dark] .mini-tree-line-down-from-root,[data-theme=dark] .mini-tree-horizontal-line,[data-theme=dark] .mini-tree-line-down-to-child{background:#e2b05c}[data-theme=dark] .tree-branch-btn{color:#f5c05b}[data-theme=dark] .tree-branch-btn .heritage-icon{color:#e2b05c}[data-theme=dark] .pine-art{filter:brightness(1.1)contrast(1.05)drop-shadow(0 10px 15px #00000080)}.skeleton-pulse{position:relative;overflow:hidden}.skeleton-pulse:after{content:"";background:linear-gradient(90deg,#fff0 0,#ffffff3d 20%,#ffffff73 60%,#fff0);animation:1.8s infinite shimmer;position:absolute;inset:0;transform:translate(-100%)}[data-theme=dark] .skeleton-pulse:after{background:linear-gradient(90deg,#fff0 0,#ffffff0d 20%,#ffffff1a 60%,#fff0)}@keyframes shimmer{to{transform:translate(100%)}}.skeleton-avatar{background:#af7f3f2e;animation:1.5s infinite alternate pulse-bg}.skeleton-bar{background:#af7f3f26;border-radius:4px;animation:1.5s infinite alternate pulse-bg;display:block}.skeleton-branch-btn{background:#af7f3f1f;border:1px dashed #af7f3f38;border-radius:6px;width:38px;height:38px;margin-top:.6rem;animation:1.5s infinite alternate pulse-bg}@keyframes pulse-bg{0%{opacity:.6}to{opacity:1}}.app-container{flex-direction:column;width:100vw;height:100dvh;display:flex;position:relative}.navbar{z-index:10;color:#fff8ef;border-bottom:2px solid #d7a94d;justify-content:space-between;align-items:center;height:70px;padding:0 clamp(1rem,4vw,4.2rem);display:flex;position:relative;overflow:hidden;box-shadow:0 7px 18px #4412043d;background:radial-gradient(circle at 28% 110%,#f1c05b42,#0000 17%),radial-gradient(circle at 70% -20%,#f1c05b2e,#0000 15%),linear-gradient(45deg,#ffe18e0b 25%,#0000 25% 50%,#ffe18e0b 50% 75%,#0000 75%) 0 0/26px 26px,linear-gradient(#9c130f,#690604)!important}.navbar:before{content:"";pointer-events:none;opacity:.24;mix-blend-mode:screen;background:url(/assets/gold-clouds-cutout-CFzqin99.png) 34% -188px/410px no-repeat,url(/assets/gold-clouds-cutout-CFzqin99.png) right 18% top -180px/370px no-repeat,linear-gradient(#e9c36e,#e9c36e) 10px 8px/52px 2px no-repeat,linear-gradient(#e9c36e,#e9c36e) 10px 8px/2px 48px no-repeat,linear-gradient(#e9c36e,#e9c36e) right 10px top 8px/52px 2px no-repeat,linear-gradient(#e9c36e,#e9c36e) right 10px top 8px/2px 48px no-repeat,linear-gradient(#e9c36e,#e9c36e) left 10px bottom 8px/42px 2px no-repeat,linear-gradient(#e9c36e,#e9c36e) right 10px bottom 8px/42px 2px no-repeat;position:absolute;inset:0}.navbar:after{content:"";pointer-events:none;opacity:.62;background:linear-gradient(90deg,#0000,#ffde8d85,#0000) bottom/72% 1px no-repeat,radial-gradient(circle,#ffdd8ee6 0 2px,#0000 3px) bottom/42px 8px repeat-x;height:18px;position:absolute;inset:auto 0 0}.nav-brand{z-index:1;align-items:center;gap:14px;min-width:max-content;display:flex;position:relative}.logo-icon{color:#f8da8d;background:#5205036b;border:2px solid #d7a94d;border-radius:50%;place-items:center;width:52px;height:52px;font-family:Lora,Georgia,serif;font-size:1.72rem;font-weight:800;display:grid;box-shadow:inset 0 0 0 4px #f7d98c1a}.logo-text{font-family:var(--font-display);letter-spacing:0;background:linear-gradient(135deg,#f9da86,#fff2c2);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:clamp(1.35rem,1.75vw,1.7rem);font-weight:800}.nav-actions{z-index:1;align-items:center;gap:.68rem;display:flex;position:relative}.search-box{width:clamp(250px,18vw,310px);position:relative}.search-input{color:#4b2818;width:100%;min-height:43px;transition:all var(--transition-fast);background:#fff8ec;border:1px solid #edc882a3;border-radius:8px;padding:8px 44px 8px 18px;font-size:.88rem;box-shadow:inset 0 1px #ffffffd1}.search-input::placeholder{color:#56382294}.search-input:focus{background:#fffdf7;border-color:#f0c86d;box-shadow:0 0 0 3px #f0c86d38,inset 0 1px #ffffffd1}.search-icon{pointer-events:none;color:#8b0d0b;width:16px;height:16px;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.navbar .btn-group{background:#50040338;border:1px solid #ffe7a42e;border-radius:8px;padding:4px;display:flex}.navbar .btn-tab{color:#fff8efcc;min-height:42px;transition:all var(--transition-fast);white-space:nowrap;border-radius:6px;justify-content:center;align-items:center;gap:.44rem;padding:8px 12px;font-size:.88rem;font-weight:600;display:inline-flex}.navbar .btn-tab:hover{color:#fff;background:#fff8ef14}.navbar .btn-tab.active{color:#ffeab4;background:#7b0805b8;box-shadow:inset 0 -2px #d7a94d,0 8px 16px #3b090233}.nav-tab-icon{color:currentColor;flex:none;width:18px;height:18px}.btn-bell{color:#fff8ef;border:0;flex:none;place-items:center;width:36px;height:36px;display:inline-grid}.btn-bell svg{width:19px;height:19px}.navbar .btn-icon{color:#fff8ef;width:38px;height:38px;transition:all var(--transition-fast);background:#43050333;border:1px solid #fff8ef52;border-radius:50%;justify-content:center;align-items:center;display:flex}.navbar .btn-icon:hover{background:#fff8ef1a;border-color:#d7a94d;transform:scale(1.05)}.theme-mark{border-radius:50%;width:18px;height:18px;display:block}.theme-light{background:#ffe6a2;box-shadow:0 0 0 4px #ffe6a22e}.theme-dark{border:2px solid #ffe6a2;box-shadow:inset -5px 0 #ffe6a2}.navbar .user-badge{cursor:default;color:#fff8ef;transition:all var(--transition-fast);background:#4305033d;border:1px solid #fff8ef40;border-radius:999px;align-items:center;gap:8px;padding:5px 12px 5px 5px;display:flex}.navbar .btn-logout{color:#fff8efcc;width:36px;height:36px;transition:all var(--transition-fast);background:#0003;border:1px solid #fff8ef40;border-radius:50%;justify-content:center;align-items:center;display:flex}.navbar .btn-logout:hover{color:#ff8585;background:#dc354540;border-color:#ff8585;transform:scale(1.05)}.navbar .user-avatar{color:#5b1209;background:#f0c86d;border:1px solid #ffecb8d1;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.82rem;font-weight:700;display:flex;overflow:hidden}.navbar .user-avatar img{object-fit:cover;width:100%;height:100%;display:block}.navbar .user-role{white-space:nowrap;font-size:.84rem;font-weight:800}.main-content{flex:1;display:flex;position:relative;overflow:hidden}.viewport-container{flex:1;height:100%;position:relative;overflow:hidden}.tree-canvas-wrapper{cursor:grab;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:relative}.tree-canvas-wrapper:active{cursor:grabbing}.tree-svg{width:100%;height:100%;position:absolute;top:0;left:0}.tree-connector{fill:none;stroke:var(--text-muted);stroke-width:2px;stroke-dasharray:none;opacity:.4;transition:stroke var(--transition-normal), opacity var(--transition-normal)}.tree-connector.hovered{stroke:var(--color-brand-primary);stroke-width:3px;opacity:.9}.tree-connector-spouse{fill:none;stroke:var(--color-brand-primary);stroke-width:2px;stroke-dasharray:4 4;opacity:.7}.node-foreign-object{overflow:visible}.member-card{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;align-items:center;gap:10px;width:100%;height:100%;padding:8px 12px;display:flex;position:relative}.member-card.nam{background:var(--node-living-male-bg);border:1.5px solid var(--node-living-male-border)}.member-card.nu{background:var(--node-living-female-bg);border:1.5px solid var(--node-living-female-border)}.member-card.deceased{background:var(--node-deceased-bg);border:1.5px solid var(--node-deceased-border);color:var(--node-deceased-text)}.member-card.selected{transform:scale(1.03);box-shadow:0 0 0 3px var(--color-brand-primary)!important;opacity:1!important}.member-card.blood-card{box-shadow:var(--shadow-sm), 0 0 10px #bf9e5540;opacity:1;border-width:2.2px}.member-card.spouse-card{opacity:.78;box-shadow:var(--shadow-sm);transition:opacity var(--transition-fast), transform var(--transition-fast), border var(--transition-fast);border-width:1.2px}.member-card.spouse-card:hover{opacity:.95}.card-avatar-wrapper{flex-shrink:0;position:relative}.card-avatar{object-fit:cover;width:44px;height:44px;box-shadow:var(--shadow-sm);background-color:var(--color-brand-primary);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;display:flex}.generated-avatar{font-family:var(--font-display), serif;letter-spacing:0;text-transform:uppercase;place-items:center;font-weight:850;display:inline-grid}.member-card.deceased .card-avatar{filter:grayscale();border-color:var(--node-deceased-border)}.deceased-ribbon{z-index:2;background:#000;border:1px solid #fff;width:14px;height:14px;position:absolute;top:-4px;right:-4px;transform:rotate(45deg);box-shadow:0 1px 2px #00000080}.card-details{flex-direction:column;justify-content:center;height:100%;display:flex;overflow:hidden}.card-name{font-family:var(--font-display);white-space:normal;word-break:break-word;font-size:.85rem;font-weight:700;line-height:1.2}.card-meta{color:var(--text-secondary);white-space:normal;word-break:break-word;margin-top:2px;font-size:.7rem;line-height:1.2}.card-gen{opacity:.5;text-transform:uppercase;font-size:.6rem;font-weight:800;position:absolute;bottom:4px;right:8px}.zoom-controls{z-index:5;flex-direction:column;gap:8px;display:flex;position:absolute;bottom:24px;left:24px}.zoom-btn{border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:700;display:flex}.list-view-container{width:100%;height:100%;animation:fadeIn var(--transition-normal) forwards;padding:2rem;overflow-y:auto}.list-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.list-filters{background:var(--bg-card);border:1px solid var(--border-card);border-radius:12px;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:var(--text-secondary);font-size:.75rem;font-weight:600}.filter-select{border:1px solid var(--border-card);background:var(--bg-input);cursor:pointer;border-radius:8px;min-width:140px;padding:8px 12px;font-size:.85rem}.list-table-wrapper{background:var(--bg-card);border:1px solid var(--border-card);box-shadow:var(--shadow-md);border-radius:12px;overflow:hidden}.list-table{border-collapse:collapse;text-align:left;width:100%}.list-table th,.list-table td{border-bottom:1px solid var(--border-card);padding:12px 18px;font-size:.9rem}.list-table th{font-weight:700;font-family:var(--font-display);color:var(--text-primary);background:#bfa15f14}.list-table tbody tr{cursor:pointer;transition:background var(--transition-fast)}.list-table tbody tr:hover{background:#bfa15f0a}.table-avatar{width:30px;height:30px;box-shadow:var(--shadow-sm);vertical-align:middle;object-fit:cover;border:1px solid #ffffff52;border-radius:50%;place-items:center;margin-right:.55rem;font-size:.72rem;display:inline-grid}.sidebar{border-left:1px solid var(--border-card);z-index:100;width:400px;height:100%;animation:slideInRight var(--transition-normal) forwards;flex-direction:column;display:flex;overflow-y:hidden}.sidebar-header{border-bottom:1px solid var(--border-card);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:24px;display:flex}.sidebar-close{color:var(--text-muted);font-size:1.5rem}.sidebar-body{flex-direction:column;flex:1;gap:24px;padding:24px;display:flex;overflow-y:auto}.sidebar-backdrop{display:none}.profile-hero{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.profile-avatar{object-fit:cover;border:4px solid var(--color-brand-primary);width:120px;height:120px;box-shadow:var(--shadow-md);background-color:var(--color-brand-primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:3rem;font-weight:800;display:flex}.profile-avatar.deceased{filter:grayscale();border-color:var(--node-deceased-border)}.profile-name{font-size:1.5rem;font-weight:800}.profile-actions{gap:10px;width:100%;margin-top:8px;display:flex}.btn{transition:all var(--transition-fast);border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:.9rem;font-weight:600;display:flex}.btn-primary{background:var(--color-brand-primary);color:#fff}.btn-primary:hover{background:#a98d4d;transform:translateY(-1px)}.btn-secondary{border:1px solid var(--border-card);background:#bfa15f0d}.btn-secondary:hover{border-color:var(--color-brand-primary);background:#bfa15f1a}.info-section{background:#bfa15f08;border:1px solid #bfa15f1a;border-radius:12px;flex-direction:column;gap:12px;padding:16px;display:flex}.info-section h4{border-bottom:1.5px solid var(--color-brand-primary);margin-bottom:4px;padding-bottom:6px;font-size:.95rem}.info-grid{grid-template-columns:100px 1fr;gap:10px;font-size:.85rem;display:grid}.info-label{color:var(--text-muted);font-weight:600}.info-value{color:var(--text-primary);word-break:break-word}.relation-item{background:var(--bg-card);border:1px solid var(--border-card);cursor:pointer;transition:all var(--transition-fast);border-radius:8px;align-items:center;gap:10px;padding:8px;display:flex}.relation-item:hover{border-color:var(--color-brand-primary);background:var(--bg-card-hover)}.relation-avatar{background-color:var(--color-brand-primary);color:#fff;object-fit:cover;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.relation-avatar.generated-avatar{background-color:unset}.relation-avatar.deceased{filter:grayscale()}.relation-details{flex-direction:column;display:flex;overflow:hidden}.relation-name{white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:700;overflow:hidden}.relation-role{color:var(--text-muted);font-size:.7rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;width:100vw;height:100dvh;animation:fadeIn var(--transition-fast) forwards;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}.modal-content{width:90%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-lg);animation:scaleUp var(--transition-normal) forwards;border-radius:16px;flex-direction:column;display:flex;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-card);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{padding:24px;overflow-y:auto}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid.full-width{grid-template-columns:1fr}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-input,.form-select,.form-textarea{border:1px solid var(--border-card);background:var(--bg-input);transition:border-color var(--transition-fast);border-radius:8px;padding:10px 14px;font-size:.9rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-brand-primary)}.form-checkbox{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;margin-top:24px;font-size:.9rem;font-weight:600;display:flex}.modal-footer{border-top:1px solid var(--border-card);justify-content:flex-end;gap:12px;padding:20px 24px;display:flex}.toast{color:#fff;box-shadow:var(--shadow-lg);z-index:1000;animation:slideInUp var(--transition-fast) forwards;background:#2d261e;border-radius:8px;padding:12px 24px;font-size:.9rem;font-weight:600;position:fixed;bottom:24px;right:24px}.empty-state{width:100%;height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:2rem;display:flex}.empty-icon{color:var(--border-card);font-size:3rem}.lock-screen{background:var(--bg-app);text-align:center;z-index:90;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;display:flex;position:absolute;top:0;left:0}.lock-container{border-radius:16px;flex-direction:column;align-items:center;gap:20px;max-width:400px;padding:3rem;display:flex}.lock-icon{color:var(--color-brand-primary);font-size:3.5rem;animation:4s ease-in-out infinite float}.mobile-nav-toggle{align-items:center;gap:10px;display:none}.hamburger-btn{border:1px solid var(--border-card);background:var(--bg-card);transition:all var(--transition-fast);border-radius:8px;padding:4px 8px;font-size:1.5rem}.mobile-drawer{z-index:150;border-left:1px solid var(--border-card);flex-direction:column;width:290px;height:100dvh;display:flex;position:fixed;top:0;right:0;box-shadow:-10px 0 30px #00000040}.mobile-drawer-header{border-bottom:1px solid var(--border-card);justify-content:space-between;align-items:center;padding:20px;display:flex}.mobile-drawer-body{padding:20px;padding-bottom:calc(80px + env(safe-area-inset-bottom));flex-direction:column;flex:1;gap:16px;display:flex;overflow-y:auto}.mobile-drawer-body .btn{height:44px;flex:none!important}.mobile-card-list{flex-direction:column;gap:12px;margin-top:1rem;display:none}.mobile-member-card{border:1px solid var(--border-card);cursor:pointer;transition:all var(--transition-fast);border-radius:12px;flex-direction:column;gap:8px;padding:14px;display:flex}.mobile-member-card.nam{border-left:5px solid var(--node-living-male-border)}.mobile-member-card.nu{border-left:5px solid var(--node-living-female-border)}.mobile-member-card.deceased{border-left:5px solid var(--node-deceased-border);opacity:.85}.mobile-card-header{justify-content:space-between;align-items:center;display:flex}.mobile-card-name{align-items:center;gap:.55rem;min-width:0;font-size:.95rem;font-weight:700;display:inline-flex}.mobile-list-avatar{width:34px;height:34px;box-shadow:var(--shadow-sm);object-fit:cover;border:1px solid #ffffff42;border-radius:50%;flex:none;place-items:center;font-size:.78rem;display:inline-grid}.mobile-card-gen{opacity:.6;font-size:.75rem;font-weight:800}.mobile-card-body{color:var(--text-secondary);flex-direction:column;gap:4px;font-size:.8rem;display:flex}.mobile-meta-row{justify-content:space-between;display:flex}.mobile-meta-desc{color:var(--text-muted);font-size:.75rem}@keyframes slideUpBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sidebar-handle-bar{background:var(--border-card);border-radius:9999px;width:40px;height:5px;margin:8px auto 0;display:none}@media (width<=1024px){.navbar{height:60px;padding:0 1rem}.navbar .btn-tab{min-width:65px}.logo-text{white-space:nowrap;font-size:1.1rem}.desktop-nav{display:none}.mobile-nav-toggle{display:flex}.main-content{flex-direction:column;position:relative}.sidebar{border-left:none;border-top:1px solid var(--border-card);background:var(--bg-card);z-index:100;border-top-left-radius:24px;border-top-right-radius:24px;width:100%;height:70vh;animation:.3s cubic-bezier(.4,0,.2,1) forwards slideUpBottom;position:absolute;bottom:0;left:0;box-shadow:0 -10px 30px #00000040}.sidebar-body{padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.sidebar-handle-bar{display:block}.sidebar-header{padding:12px 24px 20px}.list-view-container{padding:1rem;padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.list-header{margin-bottom:1rem}.list-table-wrapper{display:none}.mobile-card-list{display:flex}.form-grid{grid-template-columns:1fr}.zoom-controls{bottom:calc(60px + env(safe-area-inset-bottom));left:calc(20px + env(safe-area-inset-left))}.sidebar-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:95;background:#00000073;width:100vw;height:100dvh;display:block;position:fixed;top:0;left:0}}@media (width<=360px){.logo-text{font-size:.95rem}.logo-icon{font-size:1.4rem}.mobile-nav-toggle{gap:6px}.mobile-nav-toggle .btn-tab{border-radius:12px!important;padding:4px 6px!important;font-size:.7rem!important}}@media (height<=500px) and (width<=1024px){.navbar{height:50px}.logo-text{font-size:1rem}.logo-icon{font-size:1.3rem}.sidebar{height:85vh}}@media (width<=480px){.logo-text{display:none}}.navbar .hamburger-btn{color:#fff8ef!important;background:#0003!important;border:1px solid #fff8ef40!important}.navbar .hamburger-btn:hover{border-color:var(--heritage-gold)!important;background:#fff8ef1a!important}.has-tooltip{position:relative}.has-tooltip:after{content:attr(data-tooltip);color:#fff8df;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;z-index:9999;background:#1c1510;border:1px solid #b9822f80;border-radius:6px;padding:.35rem .6rem;font-size:.72rem;font-weight:500;transition:opacity .15s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1);position:absolute;bottom:125%;left:50%;transform:translate(-50%)scale(.9);box-shadow:0 4px 12px #502c0c40}.has-tooltip:hover:after{opacity:1;visibility:visible;transform:translate(-50%)scale(1)}[data-theme=dark] .has-tooltip:after{color:#f5c05b;background:#0e0e0c;border-color:#f5c05b40;box-shadow:0 4px 16px #0009}
