@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;--home-scroll-thumb:#8b0d0b94;--home-scroll-track:#8b0d0b14;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(5,minmax(0,1fr));gap:clamp(.75rem,1.2vw,1.45rem);margin:0 clamp(0rem,3.4vw,3.65rem) .8rem;display:grid}.stat-card{align-items:center;gap:clamp(.72rem,.9vw,1.05rem);min-height:78px;padding:.86rem clamp(.82rem,.95vw,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-teal .stat-icon-wrapper{background:var(--home-teal)}.stat-details{min-width:0}.stat-details>div{flex-wrap:wrap;align-items:baseline;gap:.6rem;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);font-weight:800;line-height:1.1}.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:var(--home-scroll-thumb) var(--home-scroll-track);grid-template-columns:repeat(2,minmax(0,1fr));gap:.54rem;min-height:0;padding-right:0;display:grid;overflow-y:hidden}.panel-notables .notables-list{flex:1}.notables-list.is-scrollable{max-height:9.8rem;padding-right:.22rem;overflow-y:auto}.notables-list::-webkit-scrollbar{width:6px}.notables-list::-webkit-scrollbar-track{background:var(--home-scroll-track);border-radius:999px}.notables-list::-webkit-scrollbar-thumb{background:var(--home-scroll-thumb);border-radius:999px}.notable-card{text-align:left;background:#fff6e1bd;border:1px solid #af7f3f57;border-radius:7px;grid-template-columns:62px minmax(0,1fr);align-items:center;gap:.58rem;padding:.42rem;transition:border-color .16s,background-color .16s,box-shadow .16s;display:grid}.notable-card:hover{background:#fff6e1e0;border-color:#8b0d0b61;box-shadow:inset 0 0 0 1px #8b0d0b14}.notable-avatar{aspect-ratio:1;object-fit:cover;box-sizing:border-box;background:#f0dfbd;border:1px solid #af7f3f6b;border-radius:5px;place-items:center;width:62px;margin-bottom:0;font-size:1rem;display:grid}.notable-name{color:var(--home-ink);overflow-wrap:anywhere;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:.7rem;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:var(--border-card) transparent;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:0 0;border-radius:999px}.anniversaries-list::-webkit-scrollbar-thumb{background:var(--border-card);border-radius:999px}.anniversaries-list::-webkit-scrollbar-thumb:hover{background:var(--color-brand-primary)}.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{overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--border-card) transparent;grid-template-columns:max-content 20px minmax(0,1fr);gap:0 .72rem;max-height:184px;padding:.12rem .2rem .08rem 0;display:grid;position:relative;overflow-y:auto}.history-timeline::-webkit-scrollbar{width:6px}.history-timeline::-webkit-scrollbar-thumb{background:var(--border-card);border-radius:999px}.history-timeline::-webkit-scrollbar-track{background:0 0}.history-timeline::-webkit-scrollbar-thumb:hover{background:var(--color-brand-primary)}.timeline-node{grid-template-columns:subgrid;grid-column:1/-1;align-items:start;min-height:1.4rem;padding:.08rem 0 .32rem;display:grid;position:relative}.timeline-node:before{content:"";background:#8b0d0b85;grid-area:1/2;place-self:stretch center;width:1px;min-height:calc(100% + .34rem);transform:translateY(.68rem)}.timeline-node:last-child:before{display:none}.timeline-node:after{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;margin-top:.26rem;box-shadow:0 0 0 2px #fff9ebe6}.timeline-node strong{color:var(--home-red);text-align:right;white-space:nowrap;grid-column:1;padding-top:.12rem;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;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:var(--color-brand-primary,var(--home-red));font-weight:800}.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}.notables-list.is-scrollable{max-height:20.4rem}.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{opacity:.34;background-size:560px;width:190px;height:58px;display:block;bottom:0}.traditional-footer:before{left:-1.6rem}.traditional-footer:after{right:-1.6rem}}@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] .timeline-node:before{background:#f5c05b40}[data-theme=dark] .timeline-node:after{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:1200;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:visible;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;min-width:max-content;color:inherit;cursor:pointer;background:0 0;border:0;flex:none;align-items:center;gap:14px;padding:0;display:flex;position:relative}.nav-brand:hover .logo-text-main{filter:drop-shadow(0 0 7px #f9da868c)}.nav-brand:active{transform:translateY(1px)}.logo-icon{color:#f8da8d;background:#5205036b;border:2px solid #d7a94d;border-radius:50%;place-items:center;width:52px;height:52px;display:grid;overflow:hidden;box-shadow:inset 0 0 0 4px #f7d98c1a}.logo-icon img{object-fit:contain;width:100%;height:100%;display:block}.logo-text{min-width:112px;font-family:var(--font-display);letter-spacing:0;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:0;line-height:1;display:flex}.logo-text-kicker{color:#ffefc0e6;text-transform:uppercase;font-size:clamp(.66rem,.78vw,.78rem);font-weight:700}.logo-text-main{background:linear-gradient(135deg,#f9da86,#fff2c2);-webkit-text-fill-color:transparent;text-shadow:0 0 8px #f9da8694,0 0 18px #d7a94d57;filter:drop-shadow(0 0 4px #f9da8657);-webkit-background-clip:text;font-size:clamp(1.15rem,1.45vw,1.42rem);font-weight:900;line-height:1.02}.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%)}.search-clear-btn{color:#8b0d0b;cursor:pointer;pointer-events:auto;background:0 0;border:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.search-clear-btn:hover{color:#8b0d0b;opacity:.82}.global-search-panel{z-index:180;background:var(--bg-card);width:min(430px,86vw);max-height:min(520px,100dvh - 96px);box-shadow:var(--shadow-lg);color:var(--text-primary);border:1px solid #d7a94d61;border-radius:14px;padding:10px;position:absolute;top:calc(100% + 10px);right:0;overflow-y:auto}.global-search-section+.global-search-section{border-top:1px solid var(--border-card);margin-top:8px;padding-top:8px}.global-search-label{color:var(--color-brand-accent);text-transform:uppercase;padding:4px 6px 7px;font-size:.72rem;font-weight:900;display:block}.global-search-item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast), transform var(--transition-fast);background:0 0;border:0;border-radius:12px;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:10px;padding:9px;display:grid}.global-search-item:hover,.global-search-item:focus-visible{background:var(--bg-secondary);outline:none;transform:translateY(-1px)}.global-search-item.compact{grid-template-columns:38px minmax(0,1fr)}.global-search-avatar,.global-search-nav-icon{color:#fff7dc;border:1px solid #d7a94d57;border-radius:50%;place-items:center;width:42px;height:42px;font-size:.78rem;font-weight:900;display:grid;overflow:hidden;box-shadow:inset 0 0 0 1px #fff8ec14}.global-search-nav-icon{width:36px;height:36px;color:var(--color-brand-accent);background:#bfa15f1f}.global-search-avatar img{object-fit:cover;width:100%;height:100%;display:block}.global-search-copy{gap:3px;min-width:0;display:grid}.global-search-copy strong{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.92rem;line-height:1.2;overflow:hidden}.global-search-copy small,.global-search-copy em{min-width:0;color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:5px;font-size:.76rem;font-style:normal;line-height:1.25;display:flex;overflow:hidden}.global-search-copy em{color:var(--text-muted)}.global-search-copy svg{color:var(--color-brand-accent);flex:none}.global-search-empty{color:var(--text-secondary);text-align:center;padding:18px 12px;font-size:.88rem;font-weight:800}.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;width:36px;height:36px;transition:border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);background:#43050333;border:1px solid #fff8ef40;border-radius:50%;flex:none;place-items:center;display:inline-grid;position:relative}.btn-bell:hover,.btn-bell.active{background:#fff8ef1a;border-color:#d7a94d;transform:scale(1.05)}.btn-bell svg{width:19px;height:19px}.notification-wrap{flex:none;align-items:center;display:inline-flex;position:relative}.notification-badge{color:#fff;background:#ff5a64;border:2px solid #7b0805;border-radius:999px;place-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.64rem;font-weight:950;line-height:1;display:grid;position:absolute;top:-4px;right:-5px}.notification-panel{z-index:1350;background:var(--bg-card);width:min(390px,92vw);max-height:min(560px,100dvh - 96px);color:var(--text-primary);box-shadow:var(--shadow-lg);border:1px solid #d7a94d6b;border-radius:16px;grid-template-rows:auto minmax(0,1fr);display:grid;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.notification-head{border-bottom:1px solid var(--border-card);justify-content:space-between;align-items:center;gap:12px;padding:14px;display:flex}.notification-head div{gap:2px;min-width:0;display:grid}.notification-head strong{color:var(--text-primary);font-family:var(--font-heading);font-size:1.02rem}.notification-head span{color:var(--text-muted);font-size:.78rem;font-weight:800}.notification-read-all{background:var(--bg-secondary);min-height:32px;color:var(--color-brand-accent);white-space:nowrap;border:1px solid #d7a94d57;border-radius:8px;align-items:center;gap:6px;padding:7px 10px;font-size:.76rem;font-weight:900;display:inline-flex}.notification-read-all:disabled{opacity:.45;cursor:not-allowed}.notification-list{overscroll-behavior:contain;min-height:0;max-height:460px;padding:8px;overflow-y:auto}.notification-item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:12px;grid-template-columns:40px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;display:grid}.notification-item:hover,.notification-item:focus-visible{background:var(--bg-secondary);border-color:#d7a94d5c;outline:none;transform:translateY(-1px)}.notification-item.is-unread{background:#bfa15f14}.notification-icon{width:38px;height:38px;color:var(--color-brand-accent);background:#bfa15f1f;border:1px solid #d7a94d52;border-radius:50%;place-items:center;display:grid}.notification-critical .notification-icon,.notification-warning .notification-icon{color:#ffcf7d;background:#c0392b2e;border-color:#c0392b6b}.notification-success .notification-icon{color:var(--color-green);background:#3a744e1f;border-color:#3a744e57}.notification-info .notification-icon{color:#6ac7c0;background:#469d971f;border-color:#469d9757}.notification-copy{gap:3px;min-width:0;display:grid}.notification-title-row{align-items:center;gap:7px;min-width:0;display:flex}.notification-title-row strong{min-width:0;color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;line-height:1.25;overflow:hidden}.notification-title-row i{background:#ff5a64;border-radius:50%;flex:none;width:7px;height:7px;box-shadow:0 0 0 3px #ff5a6424}.notification-copy small{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.76rem;line-height:1.35;display:-webkit-box;overflow:hidden}.notification-copy em{color:var(--text-muted);font-size:.71rem;font-style:normal;font-weight:900}.notification-action{color:var(--color-brand-accent);white-space:nowrap;font-size:.72rem;font-weight:950}.notification-empty{color:var(--text-secondary);text-align:center;padding:28px 16px;font-size:.88rem;font-weight:800}.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)}.navbar .sensitive-toggle.active{color:#ffe39a;background:#ffe39a2e;border-color:#ffe39ab8}.navbar .privacy-toggle.active{color:#8ff0a4;background:#3a744e38;border-color:#8ff0a494}.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:pointer;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 .user-menu-trigger:hover,.navbar .user-menu-trigger.active{background:#fff8ef1f;border-color:#d7a94d}.user-menu-wrap{z-index:1300;flex:none;align-items:center;display:flex;position:relative}.user-menu-chevron{color:#fff8efc7;transition:transform var(--transition-fast)}.user-menu-trigger.active .user-menu-chevron{transform:rotate(180deg)}.user-menu-panel{z-index:1300;background:var(--bg-card);width:240px;box-shadow:var(--shadow-card);border:1px solid #d7a94d5c;border-radius:14px;padding:10px;position:absolute;top:calc(100% + 10px);right:0}.user-menu-heading{border-bottom:1px solid var(--border-card);gap:2px;margin-bottom:6px;padding:8px 10px 10px;display:grid}.user-menu-heading strong{color:var(--text-primary);font-size:.95rem}.user-menu-heading span{color:var(--color-brand-accent);font-size:.78rem;font-weight:900}.user-menu-item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:0;border-radius:10px;align-items:center;gap:9px;padding:10px;font-weight:800;display:flex}.user-menu-item svg{color:var(--color-brand-accent);flex:none}.user-menu-item:hover{background:var(--bg-secondary);color:var(--color-brand-primary)}.user-menu-item.danger{color:var(--color-red);margin-top:4px}.user-menu-item.danger svg{color:currentColor}.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}.btn-icon.danger{color:var(--color-red)}.btn-icon:disabled,.btn:disabled{cursor:not-allowed;opacity:.45;transform:none}.main-content{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.viewport-container{flex:1;height:100%;min-height:0;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}.directory-page{background:radial-gradient(circle at 14% 8%, #bfa15f1f, transparent 26%), radial-gradient(circle at 86% 92%, #8b0d0b1f, transparent 24%), var(--bg-main);width:100%;height:100%;animation:fadeIn var(--transition-normal) forwards;padding:clamp(1rem,2.4vw,2rem);position:relative;overflow-y:auto}.directory-page:before{content:"";pointer-events:none;opacity:.08;mix-blend-mode:screen;background:url(/assets/gold-clouds-cutout-CFzqin99.png) right -110px top 18%/430px no-repeat,url(/assets/gold-clouds-cutout-CFzqin99.png) left -160px bottom 14%/360px no-repeat;position:fixed;inset:70px 0 0}.anniversary-directory-page:before{opacity:.12;background:url(/assets/gold-clouds-cutout-CFzqin99.png) right -110px top 18%/430px no-repeat,url(/assets/gold-clouds-cutout-CFzqin99.png) left -160px bottom 14%/360px no-repeat}.directory-hero,.directory-grid,.anniversary-timeline,.directory-empty-state{z-index:1;position:relative}.directory-hero{grid-template-columns:minmax(0,1fr) minmax(220px,300px);align-items:stretch;gap:clamp(1rem,2vw,1.5rem);max-width:1320px;margin:0 auto clamp(1rem,2vw,1.5rem);display:grid}.directory-kicker{color:var(--color-brand-primary);align-items:center;gap:.44rem;margin-bottom:.7rem;font-size:.82rem;font-weight:800;display:inline-flex}.directory-kicker svg{width:18px;height:18px}.directory-hero h1{color:var(--text-primary);font-family:var(--font-display);letter-spacing:0;margin:0;font-size:clamp(2rem,4vw,4.2rem);line-height:.96}.directory-hero p{max-width:680px;color:var(--text-secondary);margin:.8rem 0 0;font-size:clamp(.92rem,1.15vw,1.05rem);line-height:1.65}.directory-summary{background:linear-gradient(135deg, #bfa15f1f, #8b0d0b0a), var(--bg-card);min-height:150px;box-shadow:var(--shadow-md);border:1px solid #bfa15f3d;border-radius:12px;align-content:center;justify-items:start;padding:1.1rem;display:grid}.directory-summary strong{color:var(--color-brand-primary);font-family:var(--font-display);font-size:clamp(2.2rem,5vw,4rem);line-height:.9}.directory-summary span{color:var(--text-primary);margin-top:.55rem;font-size:1rem;font-weight:800}.directory-summary small{color:var(--text-secondary);margin-top:.25rem;font-size:.82rem}.anniversary-summary{place-self:stretch end;width:min(300px,100%)}.anniversary-summary strong{color:var(--color-danger)}.anniversary-summary span,.anniversary-summary small{max-width:17rem}.directory-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.82rem;max-width:1320px;margin:0 auto;display:grid}.directory-card{text-align:left;background:linear-gradient(135deg, #fff8ec0a, transparent), var(--bg-card);min-height:126px;box-shadow:var(--shadow-sm);border:1px solid #bfa15f38;border-radius:12px;grid-template-columns:86px minmax(0,1fr);align-items:center;gap:.9rem;padding:.9rem;transition:border-color .18s,background-color .18s,box-shadow .18s,transform .18s;display:grid;position:relative;overflow:hidden}.directory-card:hover{background-color:var(--bg-card-hover);box-shadow:var(--shadow-md);border-color:#bfa15f80}.directory-card:active{transform:translateY(1px)}.featured-page-avatar{object-fit:cover;border:1px solid #bfa15f47;border-radius:10px;place-items:center;width:86px;height:86px;font-size:1.35rem;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #ffffff0f}.directory-card-main{flex-direction:column;gap:.34rem;min-width:0;display:flex}.directory-card-topline{justify-content:space-between;align-items:flex-start;gap:.8rem;display:flex}.directory-card-topline strong{min-width:0;color:var(--text-primary);font-family:var(--font-display);font-size:clamp(1rem,1.45vw,1.28rem);line-height:1.14}.directory-card-topline em{color:var(--color-brand-primary);border:1px solid #bfa15f3d;border-radius:999px;flex:none;padding:.22rem .46rem;font-size:.72rem;font-style:normal;font-weight:800}.directory-card-meta,.directory-card-place,.directory-card-note{min-width:0;color:var(--text-secondary);align-items:center;gap:.36rem;font-size:.84rem;line-height:1.35;display:inline-flex}.directory-card-note{color:var(--text-primary);font-weight:650;display:block}.directory-card-place{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.directory-card-meta svg,.directory-card-place svg{width:15px;height:15px;color:var(--color-brand-primary);flex:none}.directory-card-mark{color:#bfa15f38;position:absolute;bottom:.65rem;right:.75rem}.directory-card-mark svg{width:34px;height:34px}.directory-empty-state{text-align:center;background:var(--bg-card);max-width:560px;box-shadow:var(--shadow-md);border:1px solid #bfa15f38;border-radius:16px;margin:4rem auto 0;padding:2rem}.directory-empty-state svg{width:42px;height:42px;color:var(--color-brand-primary)}.directory-empty-state h2{color:var(--text-primary);font-family:var(--font-display);margin:.75rem 0 .4rem}.directory-empty-state p{color:var(--text-secondary);margin:0;line-height:1.55}.generations-page .directory-hero,.generation-controls,.generation-groups{z-index:1;position:relative}.generations-summary strong{color:var(--color-brand-accent);font-size:clamp(1.35rem,2.4vw,2.25rem);line-height:1.05}.generation-controls{max-width:1320px;margin:0 auto 1rem}.generation-tabs{scrollbar-color:#bfa15f73 transparent;grid-auto-columns:minmax(108px,1fr);grid-auto-flow:column;gap:.58rem;padding:.2rem 0 .55rem;display:grid;overflow-x:auto}.generation-tab{min-height:62px;color:var(--text-secondary);background:linear-gradient(145deg, #bfa15f1a, #8b0d0b0a), var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #bfa15f3d;border-radius:10px;justify-items:start;gap:.18rem;padding:.68rem .82rem;transition:border-color .18s,background-color .18s,color .18s,transform .18s;display:grid}.generation-tab span{color:var(--text-primary);font-weight:900}.generation-tab small{color:var(--text-muted);font-size:.72rem}.generation-tab:hover{background-color:var(--bg-card-hover);border-color:#bfa15f80}.generation-tab:active{transform:translateY(1px)}.generation-tab.active{color:var(--color-brand-primary);background:linear-gradient(145deg, #8b0d0b80, #bfa15f29), var(--bg-card);border-color:#bfa15fb8}.generation-tab.active span,.generation-tab.active small{color:var(--color-brand-primary)}.generation-select-wrap{background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #bfa15f47;border-radius:10px;align-items:center;gap:.72rem;padding:.72rem .85rem;display:none;position:relative}.generation-select-wrap span{color:var(--text-secondary);white-space:nowrap;font-size:.78rem;font-weight:800}.generation-select-wrap select{appearance:none;width:100%;min-width:0;color:var(--text-primary);font:inherit;background:0 0;border:0;outline:0;font-weight:900}.generation-select-wrap select option{color:var(--text-primary);background:var(--bg-card)}.generation-select-wrap svg{width:18px;height:18px;color:var(--color-brand-primary);pointer-events:none;flex:none}.generation-groups{gap:1rem;max-width:1320px;margin:0 auto;display:grid}.generation-tree-shell{z-index:1;max-width:1320px;height:min(620px,100dvh - 280px);min-height:420px;box-shadow:var(--shadow-md);background:radial-gradient(circle at 50% 8%,#bfa15f1a,#0000 34%),#0a0e0a8f;border:1px solid #bfa15f38;border-radius:14px;margin:0 auto;position:relative;overflow:hidden}.generation-tree-shell .tree-canvas-wrapper{height:100%}.generation-filtered-tree .zoom-controls{bottom:18px;left:18px}.generation-family-group{background:radial-gradient(circle at 100% 0%, #bfa15f1f, transparent 28%), linear-gradient(135deg, #fff8ec0a, transparent), var(--bg-card);box-shadow:var(--shadow-sm);animation:.24s both fadeIn;animation-delay:calc(var(--index,0) * 55ms);border:1px solid #bfa15f38;border-radius:12px;padding:.95rem;position:relative;overflow:hidden}.generation-family-group:before{display:none}.generation-couple-head,.generation-parents-row,.generation-children-tree,.generation-tree-stem{z-index:1;position:relative}.generation-couple-head{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.72rem;width:100%;min-height:54px;display:grid}.generation-couple-toggle-row{appearance:none;color:inherit;cursor:pointer;font:inherit;text-align:left;background:0 0;border:0;padding:0}.generation-couple-toggle-row:focus-visible{outline-offset:5px;border-radius:10px;outline:2px solid #bfa15f7a}.generation-couple-icon{width:42px;height:42px;color:var(--color-brand-primary);background:#bfa15f1a;border:1px solid #bfa15f61;border-radius:50%;place-items:center;display:grid}.generation-couple-icon svg{width:21px;height:21px}.generation-couple-text{flex-direction:column;gap:.12rem;min-width:0;display:flex}.generation-couple-title-line{align-items:center;gap:.62rem;min-width:0;display:flex}.generation-couple-text strong{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:clamp(.98rem,1.5vw,1.16rem);font-weight:900;overflow:hidden}.generation-couple-text small{color:var(--text-muted);font-size:.78rem;font-weight:700}.generation-branch-count{color:var(--color-brand-primary);white-space:nowrap;background:#bfa15f14;border:1px solid #bfa15f42;border-radius:999px;flex:none;align-items:center;gap:.36rem;padding:.38rem .58rem;font-size:.78rem;font-weight:900;line-height:1;transition:border-color .16s,background .16s;display:inline-flex}.generation-couple-toggle-row:hover .generation-branch-count{background:#bfa15f24;border-color:#bfa15f7a}.generation-branch-count svg{width:15px;height:15px}.generation-branch-arrow{width:34px;height:34px;color:var(--color-brand-primary);background:#bfa15f14;border:1px solid #bfa15f38;border-radius:50%;place-items:center;transition:border-color .16s,background .16s,color .16s;display:grid}.generation-couple-toggle-row:hover .generation-branch-arrow{color:var(--color-accent-red);background:#bfa15f24;border-color:#bfa15f75}.generation-branch-arrow svg{width:18px;height:18px}.generation-tree-stem{place-items:center;height:46px;margin:.3rem 0 0;display:grid}.generation-tree-stem span,.generation-tree-stem:before{content:"";background:#bfa15f75;display:block}.generation-tree-stem span{width:1px;height:46px}.generation-tree-stem:before{background:linear-gradient(90deg,#0000,#bfa15f8f 10% 90%,#0000);height:1px;position:absolute;bottom:0;left:min(8%,3rem);right:min(8%,3rem)}.generation-parents-row{justify-content:center;align-items:center;gap:.82rem;padding:.8rem 0 .1rem;display:flex}.generation-parents-row .generation-tree-card{flex:none;width:min(280px,42vw)}.generation-parents-row .generation-tree-card+.generation-tree-card{margin-left:.4rem}.generation-parents-row .generation-tree-card+.generation-tree-card:before{content:"";border-top:1px dashed #db5553bd;width:1.05rem;position:absolute;top:50%;left:-1.05rem}.generation-children-tree{scrollbar-width:thin;scrollbar-color:#bfa15f7a #bfa15f14;align-items:flex-start;gap:1rem;padding:1rem .25rem .15rem;display:flex;position:relative;overflow:auto hidden}.generation-child-unit{flex:none;min-width:280px;padding-top:18px;position:relative}.generation-child-unit:before{content:"";background:#bfa15f8a;width:1px;height:18px;position:absolute;top:0;left:50%}.generation-child-couple{align-items:center;gap:0;display:flex}.generation-spouse-pair{align-items:center;display:inline-flex}.generation-member-card{min-height:100px;color:var(--text-primary);text-align:left;background:linear-gradient(145deg, #bfa15f14, transparent), var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #bfa15f3d;border-left-color:#bfa15f80;border-radius:10px;grid-template-columns:58px minmax(0,1fr);align-items:center;gap:.72rem;padding:.72rem;transition:border-color .18s,background-color .18s,box-shadow .18s,transform .18s;display:grid;position:relative}.generation-member-card:hover{background:linear-gradient(145deg, #bfa15f1a, transparent), var(--bg-card-hover);box-shadow:var(--shadow-md);border-color:#bfa15f8a}.generation-member-card:active{transform:translateY(1px)}.generation-member-card.nam{border-left-color:#41a35c94}.generation-member-card.nu{border-left-color:#d2675794}.generation-member-avatar{object-fit:cover;border:1px solid #bfa15f52;border-radius:50%;place-items:center;width:58px;height:58px;font-size:.95rem;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #ffffff0f}.generation-member-main{flex-direction:column;gap:.24rem;min-width:0;display:flex}.generation-member-topline{justify-content:space-between;align-items:flex-start;gap:.55rem;display:flex}.generation-member-topline strong{min-width:0;color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-weight:900;overflow:hidden}.generation-member-topline em{color:var(--color-brand-primary);flex:none;font-size:.72rem;font-style:normal;font-weight:900}.generation-member-meta,.generation-member-children,.generation-member-place{min-width:0;color:var(--text-secondary);align-items:center;gap:.3rem;font-size:.78rem;display:inline-flex}.generation-member-meta svg,.generation-member-children svg,.generation-member-place svg{flex:none;width:14px;height:14px}.generation-member-spouse{min-width:0;color:var(--color-brand-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;font-weight:800;overflow:hidden}.generation-tree-stem{background:linear-gradient(#bfa15f9e,#bfa15f2e);width:1px;height:20px;margin:.35rem auto 0}.generation-tree-stem:before,.generation-tree-stem span{display:none}.generation-members-grid{z-index:1;border-top:1px solid #bfa15f33;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.72rem;padding-top:.9rem;display:grid;position:relative}.anniversary-timeline{scrollbar-width:thin;scrollbar-color:#bfa15f8c #bfa15f14;grid-auto-columns:minmax(285px,360px);grid-auto-flow:column;gap:1rem;max-width:1320px;margin:0 auto;padding:2.35rem .2rem 1rem;display:grid;position:relative;overflow:auto hidden}.anniversary-timeline:before{content:"";background:linear-gradient(90deg,#0000,#bfa15fb8,#0000);height:2px;display:none;position:absolute;top:1.25rem;left:.2rem;right:.2rem}.anniversary-timeline-item{text-align:left;background:0 0;border:0;grid-template-rows:auto 1fr;justify-items:stretch;display:grid;position:relative}.anniversary-timeline-item:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#bfa15fb8 12%,#bfa15f6b,#0000);height:2px;position:absolute;top:55px;left:0;right:-1rem}.anniversary-timeline-item:last-child:before{display:none}.anniv-timeline-head{z-index:1;align-items:center;gap:.6rem;min-height:42px;margin-bottom:.78rem;display:flex;position:relative}.anniv-timeline-node{background:var(--bg-card);width:42px;height:42px;color:var(--color-brand-primary);box-shadow:var(--shadow-sm);border:1px solid #bfa15f80;border-radius:50%;flex:none;place-items:center;display:grid}.anniv-timeline-node svg{width:20px;height:20px;display:block}.anniv-date-inline{z-index:2;background:var(--bg-main);border-radius:8px;align-content:center;justify-items:start;min-width:0;padding:.1rem .72rem .1rem .02rem;display:grid;position:relative}.anniv-date-inline strong{color:var(--color-danger);font-family:var(--font-display);font-size:1.42rem;line-height:.95}.anniv-date-inline em{color:var(--text-secondary);font-size:.72rem;font-style:normal;font-weight:800;line-height:1.15}.anniv-date-inline small{color:var(--text-muted);white-space:nowrap;font-size:.66rem;font-weight:700;line-height:1.15}.anniv-timeline-card{background:linear-gradient(145deg, #bfa15f1a, #8b0d0b0a), var(--bg-card);width:100%;min-height:188px;box-shadow:var(--shadow-sm);border:1px solid #bfa15f3d;border-radius:14px;grid-template-columns:minmax(0,1fr);gap:.84rem;padding:.9rem;transition:border-color .18s,box-shadow .18s,transform .18s;display:grid}.anniversary-timeline-item:hover .anniv-timeline-card{box-shadow:var(--shadow-md);border-color:#bfa15f8c}.anniversary-timeline-item:active .anniv-timeline-card{transform:translateY(1px)}.anniv-timeline-content{flex-direction:column;gap:.36rem;min-width:0;display:flex}.anniv-timeline-status,.anniv-timeline-place{color:var(--color-brand-primary);align-items:center;gap:.34rem;font-size:.74rem;font-weight:800;display:inline-flex}.anniv-timeline-status svg,.anniv-timeline-place svg{width:15px;height:15px}.anniv-timeline-content strong{color:var(--text-primary);font-family:var(--font-display);font-size:1.02rem;line-height:1.16}.anniv-timeline-content span,.anniv-timeline-content small{color:var(--text-secondary);font-size:.8rem;line-height:1.38}.anniv-timeline-place{color:var(--text-muted);justify-content:flex-start;font-weight:650}.family-history-page:before{opacity:.14}.family-history-hero{align-items:center}.family-history-summary strong{color:var(--color-brand-primary)}.family-history-timeline{z-index:1;gap:0;max-width:1180px;margin:0 auto;padding:.25rem 0 2rem;display:grid;position:relative}.family-history-item{grid-template-columns:minmax(96px,max-content) 42px minmax(0,1fr);gap:.95rem;padding-bottom:1.15rem;display:grid;position:relative}.family-history-item:before{content:"";background:linear-gradient(#bfa15fb3,#bfa15f1f);width:1px;position:absolute;top:42px;bottom:0;left:calc(117px + .95rem)}.family-history-item:last-child:before{display:none}.family-history-date{color:var(--color-danger);font-family:var(--font-display);white-space:nowrap;justify-self:end;padding-top:.54rem;font-size:clamp(.94rem,1.5vw,1.2rem);font-weight:900}.family-history-node{width:42px;height:42px;color:var(--color-brand-primary);background:var(--bg-card);box-shadow:var(--shadow-sm);border:1px solid #bfa15f80;border-radius:50%;place-items:center;display:grid}.family-history-card{background:linear-gradient(145deg, #bfa15f1a, #8b0d0b0a), var(--bg-card);min-width:0;box-shadow:var(--shadow-sm);border:1px solid #bfa15f3d;border-radius:14px;padding:1rem}.family-history-card-head{justify-content:space-between;align-items:flex-start;gap:.8rem;display:flex}.family-history-card h2{color:var(--text-primary);font-family:var(--font-display);margin:0;font-size:clamp(1.05rem,1.8vw,1.35rem);line-height:1.18}.family-history-card-head span{max-width:min(320px,45%);color:var(--color-brand-primary);flex:none;align-items:center;gap:.35rem;font-size:.78rem;font-weight:850;display:inline-flex}.family-history-card-head span svg{flex:none}.family-history-card p{color:var(--text-secondary);white-space:pre-line;margin:.62rem 0 0;line-height:1.62}.family-history-gallery{scrollbar-width:thin;scrollbar-color:#bfa15f7a #bfa15f14;gap:.66rem;margin-top:.9rem;padding-bottom:.15rem;display:flex;overflow-x:auto}.family-history-gallery button{aspect-ratio:4/3;background:var(--bg-secondary);width:126px;box-shadow:var(--shadow-sm);border:1px solid #bfa15f47;border-radius:10px;flex:none;padding:0;overflow:hidden}.family-history-gallery img{object-fit:cover;width:100%;height:100%;transition:transform .18s;display:block}.family-history-gallery button:hover img{transform:scale(1.035)}.history-lightbox{z-index:12000;-webkit-backdrop-filter:blur(8px);cursor:zoom-out;background:#000000c7;place-items:center;padding:clamp(1rem,4vw,2.2rem);display:grid;position:fixed;inset:0}.history-lightbox figure{cursor:default;touch-action:pan-y;-webkit-user-select:none;user-select:none;justify-items:center;gap:.82rem;width:min(1060px,100%);max-height:90dvh;margin:0;display:grid}.history-lightbox figure img{object-fit:contain;background:#090705;border:1px solid #f5c05b52;border-radius:14px;max-width:100%;max-height:calc(90dvh - 78px);box-shadow:0 26px 90px #0000007a}.history-lightbox-stage{place-items:center;width:100%;max-height:calc(90dvh - 78px);display:grid;position:relative}.history-lightbox figcaption{color:#fff8e8;text-align:center;justify-items:center;gap:.32rem;width:min(680px,100%);font-weight:850;display:grid}.history-lightbox figcaption span,.history-lightbox figcaption small{justify-content:center;align-items:center;gap:.4rem;display:inline-flex}.history-lightbox figcaption span{font-size:.98rem;line-height:1.25}.history-lightbox figcaption small{color:#fff8e8b3;font-size:.82rem}.history-lightbox-close,.history-lightbox-nav{color:#fff8e8;width:44px;height:44px;box-shadow:var(--shadow-md);background:#191009b8;border:1px solid #f5c05b4d;border-radius:50%;place-items:center;display:grid}.history-lightbox-close{position:fixed;top:1rem;right:1rem}.history-lightbox-nav{z-index:1;position:absolute;top:50%;transform:translateY(-50%)}.history-lightbox-nav.prev{left:.8rem}.history-lightbox-nav.next{right:.8rem}.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);color:var(--text-primary);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;min-width:0;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}.relation-spouse-role{color:var(--color-brand-primary);font-weight:800}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1500;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{box-sizing:border-box;width:90%;min-width:0;max-width:600px;max-height:min(90vh,100dvh - 32px);box-shadow:var(--shadow-lg);animation:scaleUp var(--transition-normal) forwards;border-radius:16px;flex-direction:column;display:flex;overflow:hidden auto}.modal-header{border-bottom:1px solid var(--border-card);flex:none;justify-content:space-between;align-items:center;gap:14px;padding:20px 24px;display:flex}.member-modal-title{min-width:0;color:var(--text-primary);overflow-wrap:anywhere;margin:0;line-height:1.25}.member-modal-title span,.member-modal-title strong{display:block}.member-modal-title strong{color:var(--color-brand-primary);margin-top:3px}.modal-body{min-width:0;padding:24px;overflow:hidden auto}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid.full-width{grid-template-columns:1fr}.form-group-wide{grid-column:1/-1}.form-group{flex-direction:column;gap:6px;min-width:0;display:flex}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-input,.form-select,.form-textarea{box-sizing:border-box;border:1px solid var(--border-card);background:var(--bg-input);width:100%;min-width:0;max-width:100%;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;white-space:normal;overflow-wrap:anywhere;align-items:center;gap:8px;min-width:0;margin-top:24px;font-size:.9rem;font-weight:600;display:flex}.modal-footer{border-top:1px solid var(--border-card);flex:none;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-back-btn,.mobile-search-btn,.mobile-notification-btn{color:#fff8ef;background:#0003;border:1px solid #fff8ef40;border-radius:50%;flex:none;place-items:center;width:36px;height:36px;display:inline-grid}.mobile-back-btn svg,.mobile-search-btn svg,.mobile-notification-btn svg{width:18px;height:18px}.mobile-search-backdrop{z-index:135;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0c08057a;position:fixed;inset:0}.mobile-search-overlay{z-index:150;top:calc(60px + env(safe-area-inset-top));max-height:calc(100dvh - 80px - env(safe-area-inset-top));background:var(--bg-card);box-shadow:var(--shadow-lg);border:1px solid #d7a94d5c;border-radius:16px;padding:14px;position:fixed;left:10px;right:10px}.mobile-search-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.mobile-search-head strong{color:var(--text-primary);font-family:var(--font-heading);font-size:1.05rem}.mobile-search-close{width:34px!important;height:34px!important;color:var(--text-primary)!important;border-color:var(--border-card)!important;background:var(--bg-secondary)!important}.mobile-search-box{width:100%}.mobile-search-input-wrap{width:100%;position:relative}.mobile-search-input-wrap .search-input{padding-right:44px}.mobile-search-box>.search-icon{top:21.5px}.mobile-search-overlay .global-search-panel{width:100%;max-height:calc(100dvh - 190px - env(safe-area-inset-top));box-shadow:var(--shadow-card);margin-top:10px;position:static}.mobile-drawer{z-index:150;width:100vw;max-width:none;height:100dvh;box-shadow:none;background:var(--bg-card);color:var(--text-primary);overscroll-behavior:contain;touch-action:pan-y;border-left:0;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.mobile-drawer-header{border-bottom:1px solid var(--border-card);flex:none;justify-content:space-between;align-items:center;padding:20px;display:flex}.mobile-drawer-header h3{color:var(--text-primary)}.mobile-drawer .sidebar-close{color:var(--text-secondary)}.mobile-drawer-body{min-height:0;padding:20px;padding-bottom:calc(80px + env(safe-area-inset-bottom));overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:16px;display:flex;overflow-y:auto}.mobile-drawer-body .btn{height:44px;color:var(--text-primary);flex:none!important}.mobile-drawer-body .btn svg{color:currentColor}.mobile-drawer-body .btn-primary{color:#fff}.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;min-width:92px}.logo-text-kicker{font-size:.58rem}.logo-text-main{font-size:1.04rem}.desktop-nav{display:none}.mobile-nav-toggle{display:flex}.mobile-notification-wrap .notification-panel{top:calc(62px + env(safe-area-inset-top));width:auto;max-height:calc(100dvh - 82px - env(safe-area-inset-top));position:fixed;left:10px;right:10px}.notification-list{max-height:calc(100dvh - 180px - env(safe-area-inset-top))}.notification-item{grid-template-columns:38px minmax(0,1fr)}.notification-action{grid-column:2;justify-self:start}.main-content{flex-direction:column;position:relative}.sidebar{width:100%;height:90dvh;max-height:calc(100dvh - env(safe-area-inset-top));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;animation:.3s cubic-bezier(.4,0,.2,1) forwards slideUpBottom;position:absolute;bottom:0;left:0;box-shadow:0 -10px 30px #00000040}.sidebar-body{min-height:0;overflow-x:hidden;padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.sidebar-handle-bar{display:block}.sidebar-header{padding:12px 24px 20px}.modal-overlay{padding:calc(72px + env(safe-area-inset-top)) 12px calc(12px + env(safe-area-inset-bottom));justify-content:center;align-items:flex-start;overflow:hidden}.modal-content{width:100%;max-width:min(600px,100vw - 24px);max-height:calc(100dvh - 84px - env(safe-area-inset-top) - env(safe-area-inset-bottom));border-radius:16px}.modal-header{align-items:flex-start;padding:14px 18px}.member-modal-title{font-size:1rem}.modal-body{padding:18px}.modal-footer{padding:14px 18px calc(14px + env(safe-area-inset-bottom));flex-direction:column-reverse}.modal-footer .btn{justify-content:center;width:100%}.form-grid,.form-grid.full-width{grid-template-columns:minmax(0,1fr)}.form-group-wide{grid-column:auto}.form-checkbox{align-items:flex-start;margin-top:0;line-height:1.35}.list-view-container{padding:1rem;padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}.directory-page{padding:1rem;padding-bottom:calc(80px + env(safe-area-inset-bottom))}.directory-page:before{opacity:.06;background:url(/assets/gold-clouds-cutout-CFzqin99.png) right -170px top 22%/360px no-repeat,url(/assets/gold-clouds-cutout-CFzqin99.png) left -180px bottom 12%/300px no-repeat;inset:60px 0 0}.anniversary-directory-page:before{opacity:.1;background:url(/assets/gold-clouds-cutout-CFzqin99.png) right -170px top 22%/360px no-repeat,url(/assets/gold-clouds-cutout-CFzqin99.png) left -180px bottom 12%/300px no-repeat}.directory-hero{grid-template-columns:1fr}.directory-summary{min-height:112px}.directory-grid{grid-template-columns:1fr}.generation-tabs{display:none}.generation-select-wrap{display:flex}.generation-family-group{padding:.78rem}.generation-tree-shell{border-radius:12px;height:min(560px,100dvh - 250px);min-height:380px}.generation-couple-head{grid-template-columns:auto minmax(0,1fr) auto}.generation-couple-title-line{flex-wrap:wrap;align-items:flex-start;gap:.42rem .55rem}.generation-branch-count{padding:.34rem .5rem;font-size:.72rem}.generation-couple-text strong{white-space:normal}.generation-parents-row{justify-content:flex-start;padding-bottom:.25rem;overflow-x:auto}.generation-parents-row .generation-tree-card{width:245px}.generation-tree-stem,.generation-tree-stem span{height:34px}.generation-tree-stem:before{left:1.25rem;right:1.25rem}.generation-children-tree{gap:.78rem;padding-top:.84rem}.generation-child-unit{min-width:245px}.generation-member-card{grid-template-columns:52px minmax(0,1fr);min-height:92px;padding:.66rem}.generation-members-grid{grid-template-columns:1fr}.generation-member-avatar{width:52px;height:52px}.generation-member-topline strong,.generation-member-spouse{white-space:normal}.directory-card{grid-template-columns:72px minmax(0,1fr);min-height:112px;padding:.72rem}.featured-page-avatar{width:72px;height:72px}.directory-card-topline{flex-direction:column;align-items:flex-start;gap:.34rem}.anniversary-timeline{grid-auto-flow:row;grid-auto-columns:unset;grid-template-columns:1fr;gap:.8rem;padding:0;overflow-x:hidden}.anniversary-timeline:before{display:none}.anniversary-timeline-item{grid-template-columns:1fr;justify-items:stretch;gap:0;margin-left:0}.anniversary-timeline-item:before{background:linear-gradient(#bfa15fb3,#bfa15f57,#0000);width:2px;height:auto;inset:34px auto -.82rem 17px}.anniversary-timeline-item:last-child:before{bottom:0}.anniv-timeline-head{gap:.54rem;min-height:34px;margin-bottom:.48rem}.anniv-timeline-node{width:34px;height:34px}.anniv-timeline-node svg{width:17px;height:17px}.anniv-date-inline{background:var(--bg-main)}.anniv-date-inline strong{font-size:1.3rem}.anniv-date-inline small{font-size:.64rem}.anniv-timeline-card{grid-template-columns:minmax(0,1fr);width:calc(100% - 44px);min-height:0;margin-left:44px;padding:.72rem}.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-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-kicker{font-size:.54rem}.logo-text-main{font-size:.96rem}.logo-icon{font-size:1.3rem}.sidebar{height:85vh}}@media (width<=480px){.logo-text{display:none}}.navbar .hamburger-btn,.navbar .mobile-back-btn,.navbar .mobile-search-btn,.navbar .mobile-notification-btn{color:#fff8ef!important;background:#0003!important;border:1px solid #fff8ef40!important}.navbar .hamburger-btn:hover,.navbar .mobile-back-btn:hover,.navbar .mobile-search-btn:hover,.navbar .mobile-notification-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}.accounts-page{box-sizing:border-box;scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;background:radial-gradient(circle at 78% 18%, #bfa15f1f, transparent 30%), var(--bg-primary);height:100%;min-height:0;padding:28px clamp(16px,4vw,48px) 56px;overflow:hidden auto}.accounts-hero{border-radius:var(--radius-xl);border:1px solid var(--border-card);background:var(--bg-card);box-shadow:var(--shadow-card);justify-content:space-between;align-items:stretch;gap:24px;padding:clamp(20px,4vw,34px);display:flex}.accounts-eyebrow{color:var(--color-brand-accent);align-items:center;gap:8px;margin-bottom:10px;font-size:.88rem;font-weight:900;display:inline-flex}.accounts-hero h1{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:0;margin:0 0 8px;font-size:clamp(2rem,5vw,4rem)}.accounts-hero p{color:var(--text-secondary);max-width:680px;margin:0;line-height:1.55}.accounts-metric{border-radius:var(--radius-lg);border:1px solid var(--border-card);background:var(--bg-secondary);align-content:center;justify-items:start;min-width:180px;padding:20px;display:grid}.accounts-metric strong{color:var(--color-brand-accent);font-size:clamp(2.4rem,5vw,4rem);line-height:.95}.accounts-metric span{color:var(--text-primary);font-weight:900}.accounts-metric small{color:var(--text-muted);margin-top:4px}.accounts-layout{grid-template-columns:minmax(280px,360px) 1fr;gap:18px;margin-top:18px;display:grid}.account-form,.account-password-card,.member-sync-card,.accounts-list{border:1px solid var(--border-card);background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:var(--radius-xl)}.account-form{flex-direction:column;align-self:start;gap:14px;padding:18px;display:flex}.account-password-card,.member-sync-card{gap:14px;margin-top:18px;padding:18px;display:grid}.account-password-card p,.member-sync-card p{color:var(--text-secondary);margin:0;line-height:1.5}.account-password-card strong,.member-sync-card strong{color:var(--text-primary)}.member-sync-actions{flex-wrap:wrap;gap:10px;display:flex}.member-sync-actions .btn{justify-content:center;gap:8px;min-height:42px}.member-sync-import{position:relative;overflow:hidden}.member-sync-import input{opacity:0;cursor:pointer;position:absolute;inset:0}.member-sync-import.disabled{opacity:.58;cursor:not-allowed}.member-sync-preview{border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid #d7a94d57;gap:12px;padding:14px;display:grid}.member-sync-file{gap:3px;min-width:0;display:grid}.member-sync-file strong{overflow-wrap:anywhere}.member-sync-file span{color:var(--text-muted);font-size:.82rem;font-weight:800}.member-sync-stats{grid-template-columns:repeat(4,minmax(120px,1fr));gap:8px;display:grid}.member-sync-stats span{border:1px solid var(--border-card);border-radius:var(--radius-md);background:var(--bg-card);min-width:0;color:var(--text-secondary);gap:2px;padding:10px;font-size:.78rem;font-weight:800;display:grid}.member-sync-stats strong{color:var(--color-brand-accent);font-size:1.25rem;line-height:1}.member-sync-errors{border-radius:var(--radius-md);color:var(--color-red);background:#c0392b1a;border:1px solid #c0392b57;gap:6px;padding:10px;font-size:.8rem;font-weight:800;display:grid}.account-password-grid{grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px;display:grid}.account-form-title,.accounts-list-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.account-form-title{color:var(--color-brand-accent);justify-content:flex-start}.account-form h2,.accounts-list h2{color:var(--text-primary);font-family:var(--font-heading);margin:0;font-size:1.25rem}.account-form label,.account-password-card label{min-width:0;color:var(--text-secondary);gap:7px;font-size:.84rem;font-weight:800;display:grid}.account-form .form-input,.account-form .form-select,.account-form select,.account-password-card .form-input{box-sizing:border-box;text-overflow:ellipsis;white-space:nowrap;width:100%;min-width:0;max-width:100%;overflow:hidden}.account-field-hint{max-width:100%;color:var(--text-muted);overflow-wrap:anywhere;font-size:.75rem;font-weight:700;line-height:1.35;display:block}.account-form select.form-input option{background:var(--bg-primary);color:var(--text-primary)}.account-form-actions{gap:10px;margin-top:4px;display:flex}.account-form-actions .btn{flex:1;justify-content:center}.accounts-list{min-width:0;padding:18px}.accounts-list-header span{color:var(--text-muted);font-size:.86rem}.accounts-grid{grid-template-columns:repeat(2,minmax(260px,1fr));gap:12px;margin-top:14px;display:grid}.account-card{border-radius:var(--radius-lg);border:1px solid var(--border-card);background:var(--bg-secondary);grid-template-columns:58px minmax(0,1fr);align-items:center;gap:12px;padding:14px;display:grid;position:relative;box-shadow:0 10px 26px #00000024}.account-avatar{color:#fff7dc;border:1px solid #eabe6061;border-radius:50%;place-items:center;width:54px;height:54px;font-weight:900;display:grid}.account-info{min-width:0}.account-title-row{justify-content:space-between;align-items:flex-start;gap:10px;min-width:0;margin-bottom:4px;display:flex}.account-title-row h3{min-width:0;color:var(--text-primary);overflow-wrap:anywhere;flex:1;margin:0 0 4px;font-size:1rem;line-height:1.2}.account-info p{color:var(--text-muted);align-items:center;gap:5px;margin:0 0 6px;font-size:.82rem;display:flex}.account-info small{color:var(--text-secondary);margin-top:7px;line-height:1.35;display:block}.account-role{width:fit-content;color:var(--color-brand-accent);background:#bfa15f21;border:1px solid #bfa15f52;border-radius:999px;padding:4px 9px;font-size:.72rem;font-weight:900;display:inline-flex}.account-scope{width:fit-content;max-width:100%;color:var(--text-secondary);background:#3a744e1a;border:1px solid #3a744e38;border-radius:8px;margin-top:6px;padding:4px 8px;font-size:.74rem;font-weight:800;line-height:1.3;display:block}.account-role.role-admin{color:var(--color-red);background:#c0392b1f;border-color:#c0392b5c}.account-role.role-editor{color:var(--color-green);background:#3a744e1f;border-color:#3a744e5c}.account-actions{flex:none;gap:8px;display:flex}.account-actions .btn-icon{border:1px solid var(--border-card);background:var(--bg-card);width:36px;height:36px;color:var(--text-primary);border-radius:50%;place-items:center;display:grid}.history-admin-page{box-sizing:border-box;scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;background:radial-gradient(circle at 76% 20%, #bfa15f1f, transparent 30%), var(--bg-primary);height:100%;min-height:0;padding:28px clamp(16px,4vw,48px) 56px;overflow:hidden auto}.history-admin-layout{grid-template-columns:minmax(280px,390px) 1fr;gap:18px;margin-top:18px;display:grid}.history-admin-hero-actions{flex-wrap:wrap;justify-content:flex-end;align-items:stretch;gap:12px;display:flex}.history-preview-btn{white-space:nowrap;align-self:center;min-height:44px}.history-event-form,.history-events-list{border:1px solid var(--border-card);background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:var(--radius-xl)}.history-event-form{flex-direction:column;align-self:start;gap:14px;padding:18px;display:flex}.history-event-form label{min-width:0;color:var(--text-secondary);gap:7px;font-size:.84rem;font-weight:800;display:grid}.history-event-form .form-input,.history-event-form .form-textarea{box-sizing:border-box;width:100%;min-width:0;max-width:100%}.history-event-form .form-textarea{resize:vertical;white-space:normal;min-height:112px}.history-date-row{grid-template-columns:minmax(0,1fr) 150px;gap:8px;display:grid}.history-date-picker{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;min-width:0}[data-theme=dark] .history-date-picker{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.history-member-search{display:block;position:relative}.history-member-search svg{color:var(--color-brand-accent);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.history-member-search .form-input{padding-left:36px}.history-selected-members{flex-wrap:wrap;gap:7px;display:flex}.history-selected-chip{max-width:100%;color:var(--text-primary);cursor:pointer;background:#bfa15f1f;border:1px solid #d7a94d61;border-radius:999px;align-items:center;gap:6px;padding:6px 9px;font-size:.74rem;font-weight:900;display:inline-flex}.history-member-picker{border:1px solid var(--border-card);border-radius:var(--radius-md);background:var(--bg-secondary);gap:7px;max-height:230px;padding:8px;display:grid;overflow-y:auto}.history-member-option{cursor:pointer;min-height:38px;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:9px;flex-direction:row;align-items:center;padding:8px 10px;color:var(--text-secondary)!important;grid-template-columns:none!important;gap:9px!important;display:flex!important}.history-member-option:hover{background:var(--bg-card);border-color:#d7a94d4d;color:var(--text-primary)!important}.history-member-option.is-selected{background:#d7a94d29;border-color:#d7a94dad;color:var(--text-primary)!important}.history-member-option input{width:17px;height:17px;accent-color:var(--color-brand-primary);flex:none}.history-member-option span{overflow-wrap:anywhere;min-width:0}.history-member-empty{color:var(--text-muted);text-align:center;padding:16px 10px;font-size:.82rem}.history-event-form select.form-input option{background:var(--bg-primary);color:var(--text-primary)}.history-toggle-row{border:1px solid var(--border-card);border-radius:var(--radius-md);background:var(--bg-secondary);flex-direction:row;align-items:center;padding:12px;color:var(--text-primary)!important;grid-template-columns:none!important;gap:10px!important;display:flex!important}.history-toggle-row input{width:18px;height:18px;accent-color:var(--color-brand-primary)}.history-upload-box{border-radius:var(--radius-md);min-height:54px;color:var(--text-primary);background:var(--bg-secondary);cursor:pointer;transition:border-color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast), color var(--transition-fast);border:1px dashed #d7a94d6b;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:9px;padding:12px;display:grid;position:relative;overflow:hidden}.history-upload-box.is-dragging{border-color:var(--color-brand-primary);color:var(--color-brand-accent);background:#bfa15f24;box-shadow:inset 0 0 0 1px #d7a94d57,0 0 0 3px #d7a94d1f}.history-upload-box.is-disabled{cursor:not-allowed;opacity:.58}.history-upload-box input{opacity:0;cursor:pointer;position:absolute;inset:0}.history-upload-box.is-disabled input{cursor:not-allowed}.history-upload-box svg{color:var(--color-brand-primary)}.history-upload-box span{min-width:0;font-size:.84rem;font-weight:900}.history-image-preview-list{gap:8px;display:grid}.history-image-preview{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid #bfa15f38;grid-template-columns:72px minmax(0,1fr) auto;align-items:center;gap:10px;margin:0;padding:8px;display:grid;position:relative}.history-image-preview img{object-fit:cover;border:1px solid #bfa15f33;border-radius:8px;width:72px;height:54px}.history-image-preview figcaption{gap:3px;min-width:0;display:grid}.history-image-preview figcaption span{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;font-weight:900;overflow:hidden}.history-image-preview figcaption small{color:var(--text-muted);font-size:.72rem}.history-image-preview button{width:30px;height:30px;color:var(--color-red);background:#c0392b14;border:1px solid #c0392b59;border-radius:50%;place-items:center;display:grid}.history-events-list{min-width:0;padding:18px}.history-event-grid{gap:12px;margin-top:14px;display:grid}.history-event-card{border:1px solid var(--border-card);border-radius:var(--radius-lg);background:var(--bg-secondary);grid-template-columns:110px minmax(0,1fr) auto;align-items:start;gap:14px;padding:14px;display:grid;box-shadow:0 10px 26px #0000001f}.history-event-date{color:var(--color-brand-accent);justify-items:start;gap:8px;font-weight:900;display:grid}.history-event-date svg{background:#bfa15f1f;border:1px solid #d7a94d61;border-radius:50%;width:34px;height:34px;padding:7px}.history-event-body{gap:7px;min-width:0;display:grid}.history-event-title-row{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.history-event-title-row h3{color:var(--text-primary);overflow-wrap:anywhere;margin:0;font-size:1rem;line-height:1.25}.history-event-body p{color:var(--text-secondary);margin:0;line-height:1.45}.history-event-body small{color:var(--text-muted);font-weight:800}.history-event-thumbs{align-items:center;gap:7px;min-width:0;display:flex;overflow:hidden}.history-event-thumb{background:var(--bg-card);border:1px solid #bfa15f47;border-radius:9px;flex:none;width:56px;height:42px;overflow:hidden;box-shadow:0 8px 18px #00000021}.history-event-thumb img{object-fit:cover;width:100%;height:100%;display:block}.history-event-thumb-more{color:var(--color-brand-primary);background:#bfa15f1f;place-items:center;font-size:.78rem;font-weight:950;display:grid}.history-visibility-pill,.history-related-members span{width:fit-content;color:var(--color-red);white-space:nowrap;background:#c0392b1a;border:1px solid #c0392b47;border-radius:999px;align-items:center;gap:5px;padding:4px 8px;font-size:.72rem;font-weight:900;display:inline-flex}.history-visibility-pill.is-visible{color:var(--color-green);background:#3a744e1c;border-color:#3a744e52}.history-related-members{flex-wrap:wrap;gap:6px;display:flex}.history-related-members span{color:var(--text-secondary);background:#bfa15f1a;border-color:#bfa15f47}.history-event-actions{gap:8px;display:flex}.history-event-actions .btn{white-space:nowrap;flex:none;min-height:34px;padding:8px 12px}.history-event-actions .danger{color:var(--color-red)}.history-admin-footnote{color:var(--text-muted);margin-top:14px;font-size:.8rem;font-weight:800;display:block}@media (width<=900px){.accounts-layout,.history-admin-layout,.accounts-grid,.account-password-grid,.member-sync-stats{grid-template-columns:1fr}.accounts-hero{flex-direction:column}.accounts-metric{width:100%}.history-admin-hero-actions{justify-content:stretch;width:100%}.history-preview-btn{justify-content:center;width:100%}.history-event-card{grid-template-columns:1fr}.history-event-title-row,.history-event-actions{flex-direction:column;align-items:stretch}.history-date-row{grid-template-columns:1fr}.family-history-item{grid-template-columns:1fr;gap:.6rem;padding-left:52px}.family-history-item:before{top:42px;left:20px}.family-history-node{position:absolute;top:0;left:0}.family-history-date{justify-self:start;padding-top:.3rem}.family-history-card-head{flex-direction:column;gap:.45rem}.family-history-card-head span{max-width:100%}}@media (width<=560px){.accounts-page,.history-admin-page{padding:18px 12px 40px}.account-card{grid-template-columns:48px minmax(0,1fr)}.account-avatar{width:46px;height:46px}.history-image-preview{grid-template-columns:62px minmax(0,1fr) auto}.history-image-preview img{width:62px;height:48px}.family-history-gallery button{width:108px}.history-lightbox{padding:.72rem}.history-lightbox figcaption{width:calc(100vw - 1.44rem)}.history-lightbox-nav.prev{left:.72rem}.history-lightbox-nav.next{right:.72rem}}
