:root{
  --bg:#f7f4ed;
  --surface:#ffffff;
  --surface-soft:#fbf8f1;
  --surface-strong:#f0eadf;
  --ink:#1f2933;
  --muted:#667085;
  --line:#e5e1d8;
  --line-strong:#b8ad9d;
  --primary:#2f6b4f;
  --primary-dark:#244f3b;
  --primary-soft:#e8f2ec;
  --gold:#c89b3c;
  --gold-soft:#fbf0d8;
  --danger:#b91c1c;
  --unknown:#eef0f2;
  --shadow:0 22px 60px rgba(31,41,51,.13);
  --shadow-sm:0 10px 25px rgba(31,41,51,.08);
  --radius:24px;
  --mobile-nav-height:70px;
}

*,*::before,*::after{box-sizing:border-box}
html{height:100%;scroll-behavior:smooth}
body{height:100%;margin:0;overscroll-behavior:none;color:var(--ink);line-height:1.45;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,rgba(200,155,60,.22),transparent 30rem),radial-gradient(circle at bottom right,rgba(47,107,79,.16),transparent 34rem),linear-gradient(135deg,#f8f4ea 0%,#edf5ee 100%)}
button,input,a,select,textarea{font:inherit}
a{text-decoration:none;color:inherit}
button{color:inherit}

.app-shell{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:292px minmax(0,1fr);gap:18px;padding:18px}
.sidebar{position:sticky;top:18px;align-self:start;min-height:calc(100vh - 36px);display:flex;flex-direction:column;gap:18px;padding:22px;border:1px solid rgba(255,255,255,.30);border-radius:30px;background:linear-gradient(180deg,var(--primary-dark),#173528);color:#fff;box-shadow:var(--shadow)}
.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:17px;background:linear-gradient(135deg,var(--gold),#eed18c);color:#243227;font-size:23px;font-weight:900;box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}.brand-text{display:flex;flex-direction:column}.brand-text strong{font-size:23px;letter-spacing:.2px}.brand-text span{font-size:12px;color:rgba(255,255,255,.72)}
.side-menu{display:grid;gap:8px}.side-link{display:flex;align-items:center;min-height:43px;padding:10px 12px;border-radius:15px;color:rgba(255,255,255,.78);transition:.18s ease}.side-link:hover,.side-link.active{background:rgba(255,255,255,.12);color:#fff}.side-link.active{box-shadow:inset 3px 0 0 var(--gold)}
.side-card{display:grid;gap:4px;padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:20px;background:rgba(255,255,255,.10)}.side-card-label{font-size:12px;color:rgba(255,255,255,.72)}.side-card strong{font-size:40px;line-height:1;color:#fff}.side-card p{margin:0;font-size:12px;color:rgba(255,255,255,.72)}
.side-mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.side-mini-grid div{display:grid;gap:2px;padding:12px;border-radius:16px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.13)}.side-mini-grid b{font-size:18px;color:#fff}.side-mini-grid span{font-size:11px;color:rgba(255,255,255,.68)}
.side-note{display:grid;gap:8px;padding:14px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(255,255,255,.09);margin-top:auto}.side-note strong{font-size:13px}.side-note span{font-size:12px;color:rgba(255,255,255,.72)}.admin-panel-card{display:grid;gap:8px;padding:14px;border-radius:18px;background:rgba(200,155,60,.18);border:1px solid rgba(200,155,60,.42)}.admin-panel-card span{font-size:12px;color:rgba(255,255,255,.78)}.admin-panel-card a{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:var(--gold);color:#241b08;font-weight:800;padding:9px 12px}

.workspace{min-width:0;display:flex;flex-direction:column;gap:14px}.topbar{display:grid;grid-template-columns:minmax(240px,360px) minmax(260px,1fr) auto;gap:12px;align-items:center;padding:14px;border:1px solid rgba(255,255,255,.74);border-radius:28px;background:rgba(255,255,255,.80);backdrop-filter:blur(14px);box-shadow:var(--shadow-sm);z-index:5}.page-title{min-width:0}.eyebrow{margin:0 0 2px;color:var(--primary);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.page-title h1{margin:0;font-size:26px;line-height:1.1}.subtitle{margin:6px 0 0;color:var(--muted);font-size:13px;max-width:52ch}
.search-box{position:relative;min-width:0}.search-box input{width:100%;min-height:48px;border:1px solid var(--line);border-radius:17px;background:#fff;padding:11px 15px;outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}.search-box input:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(47,107,79,.13)}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;max-height:330px;overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow);z-index:30}.search-item{display:flex;align-items:center;gap:11px;width:100%;border:0;background:#fff;text-align:left;padding:11px 12px;cursor:pointer}.search-item:hover{background:var(--surface-soft)}.search-item img,.search-avatar-fallback{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);object-fit:cover}.search-avatar-fallback{display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-size:12px;font-weight:800}.search-item-name{font-weight:760}.search-item-meta,.search-empty{font-size:12px;color:var(--muted)}.search-empty{padding:12px}
.toolbar{display:flex;align-items:center;gap:8px;justify-content:flex-end;white-space:nowrap}.toolbar button,.add-button{min-height:42px;border:1px solid var(--line);border-radius:14px;background:#fff;padding:8px 12px;cursor:pointer;color:var(--ink);box-shadow:0 3px 10px rgba(31,41,51,.04)}.toolbar button:hover{background:var(--surface-soft);border-color:var(--line-strong)}.add-button{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:800}.add-button:hover{background:#275d44}.scale{min-width:52px;text-align:center;color:var(--muted);font-variant-numeric:tabular-nums}

.stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.stat-card{padding:14px 16px;border:1px solid rgba(255,255,255,.7);border-radius:20px;background:rgba(255,255,255,.68);box-shadow:0 8px 20px rgba(31,41,51,.055)}.stat-card span{display:block;color:var(--muted);font-size:12px;margin-bottom:4px}.stat-card strong{display:block;font-size:24px;color:var(--primary-dark);line-height:1.1}.stat-card small{display:block;margin-top:5px;color:var(--muted);font-size:11px}
.info-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.info-strip article{padding:16px;border:1px solid rgba(255,255,255,.72);border-radius:22px;background:rgba(255,255,255,.66);box-shadow:0 8px 20px rgba(31,41,51,.045)}.info-strip b{display:block;margin-bottom:6px;color:var(--primary-dark)}.info-strip span{display:block;color:var(--muted);font-size:13px}
.tree-card{display:flex;flex-direction:column;gap:10px;min-height:0;flex:1}.tree-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:22px;background:rgba(255,255,255,.62);border:1px solid rgba(255,255,255,.72)}.tree-card-head h2{margin:0;font-size:18px}.tree-card-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.touch-help{white-space:nowrap;border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 11px;color:var(--primary);font-weight:800;font-size:12px}

.pz-outer{position:relative;flex:1;min-height:520px;width:100%;overflow:hidden;border:1px solid rgba(255,255,255,.82);border-radius:30px;background:radial-gradient(circle at 1px 1px,rgba(47,107,79,.16) 1.1px,transparent 0) 0 0/28px 28px,linear-gradient(180deg,#fffdf7,#f6f1e7);touch-action:none;overscroll-behavior:none;user-select:none;cursor:grab;box-shadow:var(--shadow-sm)}.pz-outer.grabbing{cursor:grabbing}.pz-inner{position:absolute;inset:0;transform-origin:0 0;touch-action:none;will-change:transform}.tree{display:inline-block;width:max-content;min-width:920px;padding:54px;white-space:nowrap}.tree ul{position:relative;margin:0;padding:34px 0 0 0}.tree li{position:relative;float:left;list-style:none;text-align:center;padding:34px 12px 0 12px}.tree li::before,.tree li::after{content:"";position:absolute;top:0;right:50%;width:50%;height:34px;border-top:2px solid var(--line-strong)}.tree li::after{right:auto;left:50%;border-left:2px solid var(--line-strong)}.tree li:only-child::before,.tree li:only-child::after{display:none}.tree li:only-child{padding-top:0}.tree li:first-child::before,.tree li:last-child::after{border:0}.tree li:last-child::before{border-right:2px solid var(--line-strong);border-radius:0 12px 0 0}.tree li:first-child::after{border-radius:12px 0 0 0}.tree ul ul::before{content:"";position:absolute;top:0;left:50%;width:0;height:34px;border-left:2px solid var(--line-strong)}.tree::after,.tree ul::after{content:"";display:block;clear:both}
.union{display:inline-flex;gap:10px;align-items:stretch;padding:8px;border:1px solid rgba(255,255,255,.84);border-radius:20px;background:rgba(255,255,255,.78);box-shadow:0 14px 30px rgba(31,41,51,.09);position:relative}.union::before{content:"";position:absolute;left:50%;top:50%;width:26px;height:2px;background:var(--gold);transform:translate(-50%,-50%);z-index:0}.union.single{padding:0;border:0;background:transparent;box-shadow:none}.union.single::before{display:none}.person{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:150px;min-height:86px;padding:12px 14px;border:1px solid var(--line);border-radius:17px;color:var(--ink);cursor:pointer;touch-action:manipulation;background:#fff;box-shadow:0 6px 16px rgba(31,41,51,.055)}.person.male{background:linear-gradient(180deg,#fff,var(--primary-soft));border-color:rgba(47,107,79,.22)}.person.female{background:linear-gradient(180deg,#fff,var(--gold-soft));border-color:rgba(200,155,60,.30)}.person.unknown{background:linear-gradient(180deg,#fff,var(--unknown))}.person:hover,.person:focus-visible{border-color:var(--primary);outline:4px solid rgba(47,107,79,.14);outline-offset:2px}.avatar-mini{display:grid;place-items:center;width:30px;height:30px;margin-bottom:6px;border-radius:50%;background:rgba(255,255,255,.86);color:var(--primary);font-weight:900}.name{font-weight:850;font-size:13px;max-width:180px;overflow:hidden;text-overflow:ellipsis}.meta{font-size:11px;color:var(--muted)}.deceased .name{text-decoration:line-through;text-decoration-thickness:2px;text-decoration-color:rgba(31,41,51,.45)}.union:hover + ul li .person{border-color:var(--primary)}.union:hover + ul li::before,.union:hover + ul li::after,.union:hover + ul::before,.union:hover + ul ul::before{border-color:var(--primary)}.empty-state{display:inline-block;padding:24px 28px;border:1px dashed var(--line-strong);border-radius:18px;background:#fff;color:var(--muted)}
.modal-backdrop{position:fixed;inset:0;display:none;background:rgba(20,29,26,.55);z-index:50;padding:18px;overflow:auto}.modal-backdrop.open{display:block}.modal{position:relative;width:min(940px,100%);max-height:calc(100dvh - 36px);overflow:auto;margin:0 auto;background:#fff;border-radius:26px;padding:26px;box-shadow:var(--shadow)}.form-modal{width:min(760px,100%)}.modal-close{position:sticky;top:0;float:right;width:40px;height:40px;border:1px solid var(--line);border-radius:50%;background:#fff;cursor:pointer;font-size:25px;line-height:1}.modal h2{margin:0 0 4px;font-size:26px}.modal h3{margin:22px 0 10px;font-size:16px;color:var(--primary-dark)}.muted{color:var(--muted)}.chip{display:inline-flex;align-items:center;gap:4px;margin:0 6px 7px 0;padding:5px 10px;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--ink);font-size:12px}.chip[data-person]{cursor:pointer}.profile-head{display:flex;flex-wrap:wrap;align-items:flex-start;gap:18px;margin:14px 0}.profile-facts{min-width:220px;max-width:620px}.bio-text{white-space:pre-wrap}.profile-actions{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}.action-btn{border:1px solid var(--line);border-radius:12px;background:#fff;padding:8px 11px;cursor:pointer}.action-btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.gallery figure{margin:0}.spinner{width:36px;height:36px;margin:32px auto;border:3px solid #e5e7eb;border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.field{display:grid;gap:6px}.field.full{grid-column:1/-1}.field label{font-size:12px;color:var(--muted);font-weight:700}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:10px 12px;outline:none;background:#fff}.field textarea{min-height:110px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(47,107,79,.12)}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.form-actions button{border:1px solid var(--line);border-radius:13px;background:#fff;padding:10px 14px;cursor:pointer}.form-actions button[type=submit]{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:760}.message{padding:10px 12px;border-radius:12px;margin:10px 0}.message.error{background:#fef2f2;color:var(--danger)}.message.ok{background:var(--primary-soft);color:var(--primary-dark)}
.photo-button{position:relative;display:block;border:0;background:transparent;padding:0;margin:0;cursor:zoom-in;border-radius:16px;overflow:hidden}.photo-button img{display:block;width:100%;height:100%;object-fit:cover;border:1px solid var(--line);border-radius:16px}.profile-photo-button,.profile-photo-placeholder{width:184px;height:184px;flex:0 0 auto}.profile-photo-placeholder{display:grid;place-items:center;border:1px dashed var(--line-strong);border-radius:16px;background:var(--surface-soft);color:var(--muted)}.gallery-photo-button{width:100%;height:126px}.photo-zoom-hint{position:absolute;right:8px;bottom:8px;padding:4px 8px;border-radius:999px;background:rgba(31,41,51,.72);color:#fff;font-size:11px;opacity:0;transform:translateY(4px);transition:opacity .18s ease,transform .18s ease}.photo-button:hover .photo-zoom-hint,.photo-button:focus-visible .photo-zoom-hint{opacity:1;transform:translateY(0)}.photo-button:focus-visible{outline:3px solid rgba(47,107,79,.28);outline-offset:3px}
.image-lightbox-backdrop{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(2,6,23,.84);z-index:90;padding:16px;overscroll-behavior:contain}.image-lightbox-backdrop.open{display:flex}.image-lightbox{position:relative;width:min(1100px,100%);max-height:calc(100dvh - 32px);display:flex;flex-direction:column;align-items:center;gap:10px}.image-lightbox-img{max-width:100%;max-height:calc(100dvh - 130px);object-fit:contain;border-radius:18px;box-shadow:0 20px 55px rgba(0,0,0,.45);background:#fff}.image-lightbox-close{position:absolute;top:10px;right:10px;z-index:2;width:44px;height:44px;border:1px solid rgba(255,255,255,.35);border-radius:50%;background:rgba(15,23,42,.72);color:#fff;font-size:30px;line-height:1;cursor:pointer}.image-lightbox-close:hover{background:rgba(15,23,42,.94)}.image-lightbox-footer{width:min(900px,100%);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid rgba(255,255,255,.18);border-radius:14px;background:rgba(15,23,42,.72);color:#fff}.image-lightbox-caption{margin:0;color:#e5e7eb}.image-lightbox-link{color:#bfdbfe;text-decoration:none;font-weight:650;white-space:nowrap}.image-lightbox-link:hover{text-decoration:underline}
.mobile-tabs{display:none}

@media (max-width:1280px){.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.topbar{grid-template-columns:1fr}.toolbar{justify-content:flex-start;overflow-x:auto;padding-bottom:2px}}
@media (max-width:1020px){body{padding-bottom:var(--mobile-nav-height)}.app-shell{grid-template-columns:1fr;padding:10px;gap:10px}.sidebar{position:relative;top:auto;min-height:auto;display:grid;grid-template-columns:1fr;gap:12px;border-radius:24px;padding:16px}.side-menu{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.side-link{justify-content:center;text-align:center;font-size:12px;min-height:38px;padding:8px}.side-card,.side-mini-grid,.side-note,.admin-panel-card{display:none}.workspace{gap:10px}.info-strip{grid-template-columns:1fr}.pz-outer{min-height:560px}.mobile-tabs{position:fixed;left:10px;right:10px;bottom:10px;z-index:45;display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:7px;border:1px solid rgba(255,255,255,.74);border-radius:20px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);box-shadow:0 12px 35px rgba(31,41,51,.18)}.mobile-tabs a{display:grid;place-items:center;min-height:42px;border-radius:14px;background:var(--surface-soft);color:var(--primary-dark);font-size:12px;font-weight:800}}
@media (max-width:640px){.app-shell{padding:8px;gap:8px}.sidebar{border-radius:20px}.brand-mark{width:40px;height:40px;border-radius:14px}.brand-text strong{font-size:20px}.side-menu{overflow-x:auto;display:flex}.side-link{min-width:max-content;padding-left:11px;padding-right:11px}.topbar{padding:10px;border-radius:20px}.page-title h1{font-size:22px}.subtitle{font-size:12px}.toolbar button,.add-button{min-height:38px;padding:6px 10px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.stat-card{padding:12px}.info-strip{gap:8px}.tree-card-head{align-items:flex-start;flex-direction:column;border-radius:18px}.touch-help{white-space:normal}.pz-outer{min-height:62vh;border-radius:20px}.tree{min-width:720px;padding:28px}.person{min-width:112px;min-height:74px;padding:9px 10px}.avatar-mini{width:26px;height:26px}.name{font-size:12px;max-width:132px}.union{gap:6px;padding:6px}.tree li{padding-left:6px;padding-right:6px}.modal-backdrop{padding:8px}.modal{max-height:calc(100dvh - 16px);padding:16px;border-radius:18px}.modal h2{font-size:21px}.form-grid{grid-template-columns:1fr}.profile-photo-button,.profile-photo-placeholder{width:140px;height:140px}.gallery-photo-button{height:112px}.image-lightbox-backdrop{padding:8px}.image-lightbox-img{max-height:calc(100dvh - 118px);border-radius:12px}.image-lightbox-footer{align-items:flex-start;flex-direction:column}.image-lightbox-close{top:8px;right:8px}.mobile-tabs{left:8px;right:8px;bottom:8px}.mobile-tabs a{min-height:40px;font-size:11px}}
@media (max-width:420px){.stats-grid{grid-template-columns:1fr}.toolbar{gap:6px}.toolbar button{padding:6px 9px}.search-box input{min-height:44px}.mobile-tabs a{font-size:10px}.pz-outer{min-height:60vh}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}

.tree-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.fullscreen-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--primary-dark);padding:9px 12px;font-weight:760;cursor:pointer;white-space:nowrap}
.fullscreen-btn:hover{border-color:var(--primary);box-shadow:0 0 0 4px rgba(47,107,79,.10)}
.toolbar-fullscreen{background:var(--primary);color:#fff;border-color:var(--primary)}
.toolbar-fullscreen:hover{box-shadow:0 0 0 4px rgba(47,107,79,.16);filter:brightness(.98)}
.tree-card:fullscreen,#tree-map:fullscreen{background:#f7f4ec;padding:16px;overflow:auto}
.tree-card:fullscreen .pz-outer,#tree-map:fullscreen .pz-outer{height:calc(100vh - 112px);min-height:calc(100vh - 112px)}
body.tree-fullscreen-native,body.tree-fullscreen-fallback{overflow:hidden}
body.tree-fullscreen-native #tree-map,body.tree-fullscreen-fallback #tree-map{position:fixed;inset:0;z-index:1000;margin:0;border-radius:0;background:#f7f4ec;padding:14px;box-shadow:none}
body.tree-fullscreen-native #tree-map .pz-outer,body.tree-fullscreen-fallback #tree-map .pz-outer{height:calc(100vh - 112px);min-height:calc(100vh - 112px);border-radius:20px}
body.tree-fullscreen-native .mobile-tabs,body.tree-fullscreen-fallback .mobile-tabs{display:none}
body.tree-fullscreen-native .modal-backdrop,body.tree-fullscreen-fallback .modal-backdrop{z-index:5000}
body.tree-fullscreen-native .image-lightbox-backdrop,body.tree-fullscreen-fallback .image-lightbox-backdrop{z-index:6000}
body.tree-fullscreen-native .search-results,body.tree-fullscreen-fallback .search-results{z-index:5200}
body.tree-fullscreen-native .modal,body.tree-fullscreen-fallback .modal{margin-top:18px;margin-bottom:18px}
@media (max-width:640px){.toolbar-fullscreen{width:100%;}.tree-card:fullscreen .pz-outer,#tree-map:fullscreen .pz-outer,body.tree-fullscreen-native #tree-map .pz-outer,body.tree-fullscreen-fallback #tree-map .pz-outer{height:calc(100vh - 122px);min-height:calc(100vh - 122px)}body.tree-fullscreen-native .modal,body.tree-fullscreen-fallback .modal{margin-top:8px;margin-bottom:8px}}
