* { box-sizing: border-box; }
body { margin: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }

.page { max-width: 1200px; margin: 0 auto; padding: 16px; }

.topbar { border: 1px solid #ddd; border-radius: 10px; padding: 12px; }
.row1 { display: flex; gap: 12px; align-items: center; justify-content: space-between; }
.title { font-size: 20px; font-weight: 700; }
.controls { display: flex; gap: 8px; }

.row2 { margin-top: 10px; position: relative; }
.search { display: flex; gap: 8px; align-items: center; }
.search input { flex: 1; padding: 10px 12px; border: 1px solid #ccc; border-radius: 8px; }

.btn { padding: 9px 12px; border: 1px solid #bbb; background: #fff; border-radius: 8px; cursor: pointer; }
.btn:hover { border-color: #888; }

.status { margin-top: 10px; color: #444; }

.main { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 16px; margin-top: 16px; }
@media (max-width: 900px) { .main { grid-template-columns: 1fr; } }

.svgHost { border: 1px solid #ddd; border-radius: 10px; padding: 10px; min-height: 240px; }
.loading { color: #666; padding: 12px; }

.source { margin-top: 8px; color: #666; font-size: 13px; }

.panel { border: 1px solid #ddd; border-radius: 10px; padding: 12px; margin-bottom: 16px; }
.panel-title { font-weight: 700; margin-bottom: 8px; }
.panel-body { color: #333; }
.k { color: #666; }
.hint { color: #666; font-size: 13px; margin-bottom: 8px; }

.list { display: flex; flex-direction: column; gap: 8px; }
.item { border: 1px solid #ddd; border-radius: 8px; padding: 10px; cursor: pointer; display:flex; justify-content:space-between; gap:12px; }
.item:hover { border-color: #999; }
.item.active { border-color: #2f7d57; }
.name { font-weight: 600; }
.meta { color: #666; font-size: 13px; white-space: nowrap; }

.suggest {
  position: absolute;
  left: 0; right: 0;
  top: 46px;
  border: 1px solid #ddd;
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  z-index: 20;
}
.suggestItem { padding: 10px 12px; display:flex; justify-content:space-between; gap: 12px; cursor: pointer; }
.suggestItem:hover { background: #f5f5f5; }
.suggestItem .b { color:#666; font-size: 13px; }

svg.feet { width: 100%; height: auto; display: block; }

/* ✅ 默认不填充，避免黑块 */
#Feet path {
  fill: none !important;
  stroke: #555;
  stroke-width: 1;
  cursor: pointer;
}

/* hover */
#Feet path.hovered { stroke-width: 2; }

/* ✅ 选中：淡绿色描边 + 淡绿色填充（只对 selected 开启 fill） */
#Feet path.selected {
  stroke: #2f7d57;
  stroke-width: 3;
  fill: rgba(144, 238, 144, 0.35) !important; /* 淡绿色 */
}

/* 选中标签粗体 */
g.label-selected text { font-weight: 800; }

/* 外轮廓 */
#Feet path.cls-40 { stroke: #888; stroke-width: 1; cursor: default; }


