*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;background:#f0f2f5}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 12px #00000026;z-index:20;flex-shrink:0}.header-left{display:flex;align-items:center;gap:10px}.app-header h1{font-size:20px;color:#fff}.menu-btn{display:none;background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:20px;width:36px;height:36px;border-radius:6px;cursor:pointer;line-height:1}.filter-bar{display:flex;gap:8px}.filter-btn{padding:6px 16px;border:2px solid rgba(255,255,255,.5);border-radius:20px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;opacity:.6}.filter-btn.active{opacity:1;border-color:#fff}.filter-btn.师徒{background:#e74c3c4d;color:#fff}.filter-btn.结义{background:#3498db4d;color:#fff}.filter-btn.侠缘{background:#e91e634d;color:#fff}.filter-btn:not(.active){background:#ffffff26;color:#fff9;border-color:#ffffff4d}.app-body{display:flex;flex:1;overflow:hidden;position:relative}.sidebar{width:320px;min-width:320px;background:#fff;border-right:1px solid #e8e8e8;display:flex;flex-direction:column;overflow-y:auto;padding:16px;gap:16px;z-index:15}.sidebar-overlay{display:none}.card{background:#fafafa;border:1px solid #eee;border-radius:8px;padding:14px}.card h3{font-size:15px;color:#333;margin-bottom:10px}.form-row{margin-bottom:8px}.form-row label{display:block;font-size:13px;color:#666;margin-bottom:4px}.form-row input,.form-row select{width:100%;padding:8px 10px;border:1px solid #d9d9d9;border-radius:4px;font-size:16px;outline:none}.form-row input:focus,.form-row select:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff26}.btn{display:inline-block;padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:opacity .2s}.btn:hover{opacity:.85}.btn-primary{background:#1890ff;color:#fff}.btn-danger{background:#ff4d4f;color:#fff}.btn-sm{padding:4px 12px;font-size:12px}.error-msg{color:#ff4d4f;font-size:12px;margin-top:4px}.person-list{list-style:none}.person-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f0f0f0}.person-item:last-child{border-bottom:none}.person-name{font-size:14px;color:#333}.graph-area{flex:1;position:relative;overflow:hidden;background:#e8ecf1;background-image:radial-gradient(circle,#d0d5dd 1px,transparent 1px);background-size:20px 20px}.graph-area svg{width:100%;height:100%;display:block}.link{stroke-opacity:.7}.node-circle{stroke-width:2.5;cursor:pointer;transition:stroke-width .15s;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}.node-circle:hover{stroke-width:4}.node-label{text-anchor:middle;dominant-baseline:central;font-size:13px;font-weight:600;fill:#1a1a1a;pointer-events:none;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.app-header{padding:10px 14px;flex-wrap:wrap;gap:8px}.app-header h1{font-size:17px}.menu-btn{display:block}.filter-bar{gap:5px;order:3;width:100%;justify-content:center}.filter-btn{padding:4px 12px;font-size:13px}.sidebar{position:fixed;top:0;left:0;bottom:0;width:85vw;max-width:340px;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 20px #00000026;padding-top:70px}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:14}.card{padding:12px}.card h3{font-size:14px}.form-row input,.form-row select{font-size:16px;padding:10px}.btn{padding:10px 16px;width:100%;font-size:15px}.btn-sm{width:auto;padding:5px 12px}.person-item{padding:10px 0}}
