:root{--bg: #f4f1ea;--panel: #ffffff;--ink: #2b2b33;--muted: #8a8a93;--accent: #6b4f2e;--accent-2: #9a7b4f;--border: #e4ddd0;--error: #b3261e;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink)}.app{display:flex;flex-direction:column;height:100vh}.app__bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--panel);border-bottom:1px solid var(--border)}.spacer{flex:1}.app__main{position:relative;flex:1;overflow:hidden}.panzoom{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:var(--bg)}.panzoom__surface{width:100%;height:100%;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.panzoom__surface:active{cursor:grabbing}.panzoom__content{transform-origin:0 0;will-change:transform;display:inline-block}.tree-svg{display:block}.panzoom__controls{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;gap:6px;z-index:6}.panzoom__controls button{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--panel);font-size:1.2rem;line-height:1;box-shadow:0 2px 8px #0000001a}.panzoom__controls button:hover{background:var(--bg)}.person-panel{position:absolute;top:0;right:0;z-index:8;width:360px;max-width:90vw;height:100%;background:var(--panel);border-left:1px solid var(--border);box-shadow:-6px 0 24px #00000014;display:flex;flex-direction:column;overflow-y:auto}.person-panel__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--panel)}.person-panel__header h2{font-size:1.05rem;margin:0}.person-panel__body{padding:16px;display:flex;flex-direction:column;gap:12px}.meta{display:flex;align-items:center;justify-content:space-between}.badge{font-size:.75rem;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:2px 8px}.field{display:flex;flex-direction:column;gap:4px;font-size:.85rem}.field>span{color:var(--muted)}.field-row{display:flex;gap:10px}.field-row .field{flex:1}input,select,textarea{font:inherit;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fff}textarea{resize:vertical}.actions{margin-top:6px}button{cursor:pointer}.primary{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px 16px;font-weight:600}.primary:disabled{opacity:.6;cursor:default}.link-btn{background:none;border:none;color:var(--accent-2);text-decoration:underline;padding:0;font-size:.85rem}.icon-btn{background:none;border:none;font-size:1.4rem;line-height:1;color:var(--muted)}.muted{color:var(--muted)}.hint{font-size:.75rem;color:var(--muted)}.error{color:var(--error)}.banner{position:absolute;z-index:5;top:10px;left:50%;transform:translate(-50%);background:#fff;border:1px solid var(--error);padding:8px 14px;border-radius:8px}.splash,.login{height:100vh;display:grid;place-items:center}.login__card{background:var(--panel);padding:28px;border-radius:14px;border:1px solid var(--border);width:320px;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 40px #00000014}.login__card h1{margin:0;font-size:1.4rem;color:var(--accent)}.tabs{display:flex;gap:4px;margin-left:12px}.tab{background:none;border:1px solid transparent;border-radius:8px;padding:6px 12px;color:var(--muted);font:inherit}.tab.is-active{background:var(--bg);border-color:var(--border);color:var(--ink);font-weight:600}.settings-popover{position:absolute;top:10px;right:10px;z-index:10;width:260px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 32px #00000024;padding:14px;display:flex;flex-direction:column;gap:12px}.settings-popover__head{display:flex;align-items:center;justify-content:space-between}.check{display:flex;align-items:center;gap:8px;font-size:.9rem}.check input{width:16px;height:16px}.people{height:100%;display:flex;flex-direction:column;background:var(--panel)}.people__toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.people__search{flex:1;max-width:520px}.people__tablewrap{flex:1;overflow:auto}.people__table{border-collapse:collapse;width:100%;font-size:.85rem}.people__table thead th{position:sticky;top:0;background:var(--bg);text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);color:var(--muted);font-weight:600;white-space:nowrap}.people__table td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top}.people__table th.c,.people__table td.c{text-align:center}.people__table tr.is-root{background:#faf6ee}.people__table tr:hover{background:var(--bg)}.people__namebtn{background:none;border:none;padding:0;color:var(--accent);font:inherit;font-weight:600;text-align:left;cursor:pointer;text-decoration:underline}.people__id{font-size:.72rem;color:var(--muted)}.tag{margin-left:6px;font-size:.68rem;background:var(--accent-2);color:#fff;border-radius:999px;padding:1px 7px;vertical-align:middle}.pad{padding:16px}
