:root{--bg:#0f1116;--bg-soft:#141824;--text:#f0efe7;--text-soft:#c6c2b6;--muted:#9a9385;--panel:#1b2030;--panel-alt:#22283a;--panel-border:#ffffff14;--accent:#f4cf4b;--accent-strong:#ff9f45;--shadow:0 24px 44px #03050c73;--shadow-soft:0 16px 30px #070a1259;--mono:"Courier New", Courier, monospace;--body:"Trebuchet MS", "Verdana", sans-serif;--heading:"Georgia", "Iowan Old Style", serif;color:var(--text);background:var(--bg);font-size:16px;font-family:var(--body);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{background:var(--bg);min-height:100svh;color:var(--text);margin:0;position:relative;overflow-x:hidden}body:before,body:after{content:"";filter:blur(120px);opacity:.35;z-index:-1;border-radius:50%;width:520px;height:520px;position:fixed;inset:auto}body:before{background:radial-gradient(circle,#ff9f45 0%,#0000 70%);top:-120px;left:-120px}body:after{background:radial-gradient(circle,#5ad0ff 0%,#0000 70%);bottom:-160px;right:-120px}#root{min-height:100svh}h1,h2,h3,h4{font-family:var(--heading);font-weight:600}p{margin:0}button,input,select,textarea{font-family:var(--body)}.app{flex-direction:column;padding:32px clamp(20px,4vw,48px) 40px;display:flex}.grid{grid-template-columns:minmax(0,1.6fr) minmax(0,.7fr);align-items:start;gap:24px;display:grid}.panel{background:var(--panel);box-shadow:var(--shadow);border:1px solid var(--panel-border);border-radius:24px;flex-direction:column;gap:16px;padding:24px;animation:.6s both fadeUp;display:flex}.panel-title{justify-content:space-between;align-items:center;gap:12px;display:flex}.panel-title h2{margin:0;font-size:20px}.map{min-height:420px;position:relative;overflow:hidden}.map-canvas{background:#0f131c;border:1px solid #ffffff14;border-radius:18px;padding:20px;position:relative;overflow:auto}.map-content{box-sizing:border-box;flex-direction:column;gap:20px;width:100%;max-width:100%;min-height:100%;margin:0 auto;display:flex;position:relative}.root-node{box-sizing:border-box;background:#ffffff08;border:1px solid #ffffff14;border-radius:16px;justify-items:center;gap:10px;width:100%;padding:12px;display:grid}.root-node span{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:12px}.group-grid{box-sizing:border-box;column-gap:18px;width:100%}.group-box{box-sizing:border-box;break-inside:avoid;background:#141824cc;border:1px solid #ffffff1a;border-radius:18px;gap:12px;min-width:0;max-width:100%;height:auto;margin-bottom:18px;padding:14px;display:grid;overflow:hidden}.group-box.depth-1{border-style:dashed}.group-box.depth-2{border-style:dotted}.group-title{color:var(--text);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;min-width:0;font-size:12px;display:flex}.group-title span:first-child{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;overflow:hidden}.group-title.static{cursor:default}.group-toggle{color:var(--muted);text-transform:none;letter-spacing:0;white-space:nowrap;font-size:11px}.group-content{gap:12px;min-width:0;display:grid}.group-children,.member-list{gap:10px;min-width:0;display:grid}.person-card{width:100%;height:84px;color:var(--text);box-shadow:var(--shadow-soft);text-align:left;cursor:pointer;box-sizing:border-box;background:#181c26f2;border:1px solid #ffffff14;border-radius:18px;align-items:center;gap:12px;max-width:100%;padding:12px;display:flex}.person-card.active{border-color:#f4cf4b99;box-shadow:0 20px 36px #00000059}.person-card .meta{gap:4px;min-width:0;display:grid}.person-card strong{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.person-card span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.avatar{background:linear-gradient(140deg, var(--accent), var(--accent-strong));color:#0a0a0e;border-radius:16px;place-items:center;width:46px;height:46px;font-weight:700;display:grid;overflow:hidden}.avatar.large{border-radius:22px;width:100%;height:auto}.avatar img{object-fit:cover;width:100%;height:100%}.detail{position:sticky;top:24px}.detail-card{gap:16px;display:grid}.detail-header{align-items:left;flex-direction:column;gap:16px;display:flex}.detail-header h3{margin:0 0 6px}.detail-body{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.detail-body span,.relations span{text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-bottom:6px;font-size:12px;display:block}.detail-body strong,.relations strong{color:var(--text);font-size:14px}.bio{color:var(--text-soft);margin:0;line-height:1.6}.relations{gap:12px;display:grid}.relations h4{margin:0;font-size:16px}.relations div{background:var(--panel-alt);border-radius:14px;padding:12px}.muted{color:var(--muted);margin:0}.empty{background:var(--panel-alt);text-align:center;color:var(--muted);border-radius:16px;padding:24px}@keyframes floatIn{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes nodePop{0%{opacity:0;transform:translate(-50%,-40%)scale(.96)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}@media (width<=1200px){.grid{grid-template-columns:minmax(0,1fr)}.detail{position:static}}@media (width<=900px){.grid{grid-template-columns:minmax(0,1fr)}.group-grid{column-count:1}}@media (width>900px){.group-grid{column-count:2}}
