/* 마을 전경 화면 — styles-village.css
   기존 styles.css의 색 토큰(--c-*)을 그대로 사용 */

#villageScreen {
  position: fixed; inset: 0; z-index: 200;
  display: none;
  flex-direction: column;
  background:
    radial-gradient(ellipse at 50% 0%, #1a1d24 0%, #0a0b0e 70%);
  color: var(--c-text);
  overflow: hidden;
}
#villageScreen.active { display: flex; }

/* ── 상단 바 ── */
.vh-top {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1.2rem;
  padding: 0.55rem 1.1rem;
  background: linear-gradient(180deg, #20232b, #181a20);
  border-bottom: 1px solid var(--c-border);
}
.vh-top-day { display: flex; align-items: baseline; gap: 0.6rem; }
.vh-top-day #vhDay {
  font-size: 1.5rem; font-weight: 700; letter-spacing: 0.02em;
}
.vh-top-day .vh-sub { font-size: 0.8rem; color: var(--c-text-dim); }
.vh-top-day .vh-sub b { color: var(--c-warn); font-weight: 500; }
.vh-top-day .vh-sub i { font-style: normal; }

.vh-res { display: flex; gap: 0.45rem; flex-wrap: wrap; justify-content: center; }
.vh-pill {
  display: flex; align-items: center; gap: 0.32rem;
  padding: 0.28rem 0.6rem 0.28rem 0.45rem;
  background: #12141a; border: 1px solid var(--c-border);
  border-radius: 20px; font-size: 0.85rem;
}
.vh-pill-ic { width: 16px; height: 16px; display: inline-flex; color: var(--c-text-dim); }
.vh-pill-ic svg { width: 16px; height: 16px; }
.vh-pill-lab { color: var(--c-text-faint); font-size: 0.72rem; }
.vh-pill-val { font-weight: 600; }
.vh-pill.warn { border-color: var(--c-warn); }
.vh-pill.warn .vh-pill-val { color: var(--c-warn); }
.vh-pill.danger { border-color: var(--c-danger); }
.vh-pill.danger .vh-pill-val { color: var(--c-danger); }
.vh-pill.dim .vh-pill-val { color: var(--c-text-dim); }

.vh-cam { display: flex; gap: 0.35rem; align-items: center; }
.vh-cam-btn {
  padding: 0.4rem 0.9rem; border: 1px solid var(--c-border);
  border-radius: 6px; background: var(--c-panel); color: var(--c-text-dim);
  font-size: 0.85rem; transition: all 0.18s;
}
.vh-cam-btn:hover { color: var(--c-text); border-color: var(--c-blue); }
.vh-cam-btn.active {
  background: var(--c-blue); color: #fff; border-color: var(--c-blue);
}
.vh-cam-x {
  margin-left: 0.4rem; padding: 0.4rem 0.7rem; border: 1px solid var(--c-border);
  border-radius: 6px; background: none; color: var(--c-text-faint); font-size: 0.8rem;
}
.vh-cam-x:hover { color: var(--c-danger); border-color: var(--c-danger); }

/* ── 위협 배너 ── */
.vh-alert {
  padding: 0.3rem 1.1rem; font-size: 0.82rem; text-align: center;
  border-bottom: 1px solid var(--c-border); letter-spacing: 0.01em;
}
.vh-alert.calm { background: #15171d; color: var(--c-text-faint); }
.vh-alert.warn { background: #2a2316; color: var(--c-warn); }
.vh-alert.danger { background: #2c1818; color: var(--c-danger); font-weight: 600; }

/* ── 본문 그리드 ── */
.vh-grid {
  flex: 1; min-height: 0;
  display: grid;
  grid-template-columns: 232px 1fr 248px;
  gap: 0.7rem; padding: 0.7rem;
}
.vh-left, .vh-right {
  display: flex; flex-direction: column; gap: 0.6rem;
  min-height: 0; overflow-y: auto;
}
.vh-left-h, .vh-card h4 {
  font-size: 0.74rem; color: var(--c-text-faint);
  letter-spacing: 0.12em; text-transform: uppercase;
  margin: 0 0 0.1rem;
}

/* ── 생존자 명단 ── */
.vh-roster { display: flex; flex-direction: column; gap: 0.3rem; }
.vh-rost {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center;
  gap: 0.5rem; padding: 0.4rem 0.5rem; text-align: left;
  background: #15171d; border: 1px solid #23262e; border-left: 3px solid var(--cc);
  border-radius: 5px; transition: all 0.15s;
}
.vh-rost:hover { background: #1c1f27; }
.vh-rost.selected { background: #232733; border-color: var(--c-blue); }
.vh-rost.dead { opacity: 0.4; }
.vh-rost-dot { width: 8px; height: 8px; border-radius: 50%; }
.vh-rost-name { font-size: 0.9rem; font-weight: 600; display: block; }
.vh-rost-name em { font-style: normal; font-size: 0.72rem; color: var(--c-text-faint); margin-left: 0.35rem; font-weight: 400; }
.vh-rost-bars { display: flex; flex-direction: column; gap: 2px; margin-top: 3px; }
.vh-mini { display: block; height: 3px; background: #000; border-radius: 2px; overflow: hidden; }
.vh-mini i { display: block; height: 100%; }
.vh-rost-state { font-size: 0.7rem; color: var(--c-text-dim); }

/* ── 선택 인물 디테일 ── */
.vh-detail {
  margin-top: auto;
  background: #14161c; border: 1px solid var(--c-border); border-radius: 8px;
  border-left: 3px solid transparent;
  padding: 0.7rem;
  transition: background .2s, box-shadow .2s, border-color .2s;
}
.vh-detail.active {
  background: #1b1e26; border-left-color: var(--c-warn);
  box-shadow: 0 0 0 1px rgba(212, 161, 79, .35), 0 0 22px rgba(212, 161, 79, .16);
}
.vh-detail.pop { animation: vhDetailPop .5s ease; }
@keyframes vhDetailPop {
  0%   { transform: scale(.96); }
  45%  { transform: scale(1.025); box-shadow: 0 0 0 2px rgba(255, 207, 134, .65), 0 0 26px rgba(255, 207, 134, .4); }
  100% { transform: scale(1); }
}
.vh-det-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 6px; vertical-align: middle; box-shadow: 0 0 0 1px rgba(255, 255, 255, .25); }
.vh-det-head { display: flex; gap: 0.6rem; align-items: center; }
.vh-det-port {
  width: 46px; height: 46px; border-radius: 8px; overflow: hidden;
  background: radial-gradient(circle at 50% 30%, #2a2d36, #14161c);
  border: 1px solid var(--c-border); flex-shrink: 0;
}
.vh-det-port svg { width: 100%; height: 100%; display: block; }
.vh-det-name { font-size: 1rem; font-weight: 700; }
.vh-det-name em { font-style: normal; font-size: 0.72rem; color: var(--c-text-dim); margin-left: 0.4rem; font-weight: 400; }
.vh-det-act { font-size: 0.8rem; color: var(--c-warn); margin-top: 1px; }
.vh-det-bio { font-size: 0.78rem; color: var(--c-text-dim); margin: 0.5rem 0; line-height: 1.5; }
.vh-det-row { display: grid; grid-template-columns: 2.4em 1fr auto; align-items: center; gap: 0.4rem; font-size: 0.76rem; margin-bottom: 0.25rem; }
.vh-det-row > span:first-child { color: var(--c-text-faint); }
.vh-detbar { height: 6px; background: #000; border-radius: 3px; overflow: hidden; }
.vh-detbar i { display: block; height: 100%; }
.vh-det-row b { font-weight: 500; font-size: 0.72rem; }
.vh-det-sens { font-size: 0.7rem; color: var(--c-text-faint); margin-top: 0.4rem; border-top: 1px solid #23262e; padding-top: 0.4rem; }

/* ── 중앙 씬 ── */
.vh-center { display: flex; flex-direction: column; gap: 0.6rem; min-height: 0; }
.vh-scene {
  flex: 1; min-height: 0;
  border: 1px solid var(--c-border); border-radius: 10px; overflow: hidden;
  background: #0c0d11;
  box-shadow: inset 0 0 60px #000a;
}
.vh-scene svg { width: 100%; height: 100%; display: block; }

.vh-fig { cursor: pointer; }
.vh-fig:hover { filter: brightness(1.18); }
.vh-fig.sel { filter: drop-shadow(0 0 6px #ffcf8688); }
.vh-nm { font-size: 11px; fill: var(--c-text); font-weight: 600; font-family: 'Noto Sans KR', sans-serif; }
.vh-nm.dim { fill: var(--c-text-faint); }
.vh-zzz { font-size: 13px; fill: #8fa6c4; font-weight: 700; opacity: 0.7; }
.vh-zt { font-size: 12px; fill: #8a8270; font-family: 'Noto Sans KR', sans-serif; letter-spacing: 0.04em; }

/* ── 액션 바 ── */
.vh-actbar {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0.7rem; background: #14161c;
  border: 1px solid var(--c-border); border-radius: 8px;
}
.vh-act {
  padding: 0.45rem 0.9rem; border: 1px solid var(--c-border); border-radius: 6px;
  background: var(--c-panel); color: var(--c-text); font-size: 0.85rem; transition: all 0.15s;
}
.vh-act:hover { background: var(--c-panel-2); border-color: var(--c-blue); }
.vh-hint { margin-left: auto; font-size: 0.74rem; color: var(--c-text-faint); }

/* ── 우측 시스템 카드 ── */
.vh-card {
  background: #14161c; border: 1px solid var(--c-border); border-radius: 8px;
  padding: 0.6rem 0.7rem;
}
.vh-spiral { display: flex; gap: 0.3rem; margin: 0.3rem 0; }
.vh-spiral span {
  flex: 1; text-align: center; padding: 0.25rem 0; font-size: 0.78rem;
  background: #1b1d24; border: 1px solid #262a33; border-radius: 5px; color: var(--c-text-faint);
}
.vh-spiral span.on { background: #233026; border-color: var(--c-spiral); color: #aecbb0; font-weight: 600; }
.vh-line { display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; margin: 0.2rem 0; }
.vh-line span { color: var(--c-text-faint); }
.vh-line b { font-weight: 500; }
.vh-line b.warn { color: var(--c-warn); }
.vh-line b.bad { color: var(--c-danger); }
.vh-bar { height: 6px; background: #000; border-radius: 3px; overflow: hidden; margin-top: 0.35rem; }
.vh-bar i { display: block; height: 100%; }
.vh-sys-empty { font-size: 0.78rem; color: var(--c-text-faint); font-style: italic; }
.vh-prec {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.78rem; padding: 0.3rem 0.4rem; border-radius: 5px; margin-top: 0.2rem;
  background: #1d1718; border-left: 3px solid var(--c-precedent);
}
.vh-prec.pos { background: #18201a; border-left-color: var(--c-precedent-pos); }
.vh-prec-i { color: var(--c-text-dim); font-size: 0.72rem; }

/* ── 마당 실사 배경 모드 (이미지 레이어) ── */
.vh-scene.compound { background: #08090c; display: flex; align-items: center; justify-content: center; }
.vh-stagebox { position: relative; margin: auto; }
.vh-layer { position: absolute; inset: 0; width: 100%; height: 100%; display: block; pointer-events: none; user-select: none; }
.vh-bg { z-index: 0; }
.vh-glow { z-index: 1; opacity: 0; transition: opacity .22s ease, transform .22s ease; will-change: opacity, transform; }
.vh-glow.on { opacity: 1; transform: scale(1.035); }
.vh-campfire { z-index: 2; animation: vhFlick 2.4s ease-in-out infinite; }
@keyframes vhFlick { 0%, 100% { opacity: .86; } 50% { opacity: 1; } }
.vh-actor { position: absolute; transform: translate(-50%, -50%); z-index: 5; pointer-events: none; user-select: none; transition: filter .15s; filter: drop-shadow(0 4px 7px rgba(0, 0, 0, .55)); }
.vh-actor.sel { filter: drop-shadow(0 0 13px rgba(255, 207, 134, .7)); }
.vh-actorfull { z-index: 5; transition: transform .16s ease, filter .15s; }
.vh-actorfull.sel { filter: drop-shadow(0 0 13px rgba(255, 207, 134, .7)); }
.vh-actorfull.hover { transform: scale(1.07); }            /* 호버 시 발끝 기준 확대 (origin은 인라인) */
.vh-actorfull.sel.hover { transform: scale(1.07); }

/* 인물 핫스팟 (형상 위) */
.vh-phot { position: absolute; z-index: 6; background: transparent; border: 0; padding: 0; margin: 0; cursor: pointer; }
.vh-plab {
  position: absolute; left: 50%; bottom: 100%;
  transform: translateX(-50%) translateY(-4px); white-space: nowrap;
  font-size: 0.74rem; font-weight: 600; color: var(--c-text);
  background: #0b0c0fcc; border: 1px solid var(--c-warn); border-radius: 5px;
  padding: 2px 8px; opacity: 0; transition: opacity .15s; pointer-events: none;
}
.vh-phot.hot-on .vh-plab { opacity: 1; }
.vh-hot { position: absolute; z-index: 4; background: transparent; border: 0; padding: 0; margin: 0; cursor: pointer; }
.vh-hotlab {
  position: absolute; left: 50%; bottom: 100%;
  transform: translateX(-50%) translateY(-4px); white-space: nowrap;
  font-size: 0.74rem; color: var(--c-text);
  background: #0b0c0fcc; border: 1px solid var(--c-border); border-radius: 5px;
  padding: 2px 8px; opacity: 0; transition: opacity .18s; pointer-events: none;
}
.vh-hot.hot-on .vh-hotlab { opacity: 1; }

/* ── 반응형 ── */
@media (max-width: 980px) {
  .vh-grid { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .vh-left, .vh-right { flex-direction: row; flex-wrap: wrap; overflow: visible; }
  .vh-scene { min-height: 320px; }
}

/* ═══════════════════════════════════════════════════════
   메탈슬러그 테마 (네오지오 군용 도트) — #villageScreen 스코프
   ═══════════════════════════════════════════════════════ */

/* 픽셀 폰트 전면 적용 */
#villageScreen,
#villageScreen .vh-nm, #villageScreen .vh-zt {
  font-family: 'Galmuri11', 'Galmuri14', 'Apple SD Gothic Neo', monospace;
  letter-spacing: 0;
}

/* 아케이드 하드 섀도우 (검은 1px 그림자) */
#villageScreen .vh-top-day #vhDay,
#villageScreen .vh-pill-val,
#villageScreen .vh-card h4, #villageScreen .vh-left-h,
#villageScreen .vh-rost-name, #villageScreen .vh-det-name,
#villageScreen .vh-line b, #villageScreen .vh-rost-state,
#villageScreen .vh-act, #villageScreen .vh-cam-btn,
#villageScreen .vh-alert, #villageScreen .vh-spiral span {
  text-shadow: 1px 1px 0 #000;
}

/* 금속판 공통 (상단바/카드/디테일) — 리벳 4개 + 베벨 */
#villageScreen .vh-top,
#villageScreen .vh-card,
#villageScreen .vh-detail,
#villageScreen .vh-actbar {
  border-radius: 2px;
  border: 2px solid #14130d;
  background:
    radial-gradient(circle 2.5px at 6px 6px, #74774f, #74774f00 70%),
    radial-gradient(circle 2.5px at calc(100% - 6px) 6px, #74774f, #74774f00 70%),
    radial-gradient(circle 2.5px at 6px calc(100% - 6px), #74774f, #74774f00 70%),
    radial-gradient(circle 2.5px at calc(100% - 6px) calc(100% - 6px), #74774f, #74774f00 70%),
    linear-gradient(180deg, #353829, #23251b);
  box-shadow: inset 0 1px 0 #5a5e43, inset 0 -3px 6px #0007;
}

/* 상단 바 */
#villageScreen .vh-top {
  border-width: 0 0 3px 0; border-radius: 0;
  box-shadow: inset 0 1px 0 #5a5e43, 0 2px 0 #000a;
}
#villageScreen .vh-top-day #vhDay {
  font-family: 'Galmuri14', 'Galmuri11', monospace; color: #ffcf86;
}
#villageScreen .vh-top-day .vh-sub b { color: #d4a14f; }
#villageScreen .vh-top-day .vh-sub { color: #8e8f5e; }

/* 자원 = 탄약 카운터 */
#villageScreen .vh-pill {
  border-radius: 1px; border: 2px solid #14130d;
  background: linear-gradient(180deg, #1b1d15, #0e0f08);
  box-shadow: inset 0 1px 0 #45483366;
}
#villageScreen .vh-pill-val { color: #ffcf86; }
#villageScreen .vh-pill-lab { color: #8e8f5e; }
#villageScreen .vh-pill-ic { color: #c8b06a; }
#villageScreen .vh-pill.warn { border-color: #d4a14f; }
#villageScreen .vh-pill.warn .vh-pill-val { color: #f0c060; }
#villageScreen .vh-pill.danger { border-color: #c25656; }
#villageScreen .vh-pill.danger .vh-pill-val { color: #e07070; }

/* 헤더 = 스텐실 */
#villageScreen .vh-card h4, #villageScreen .vh-left-h {
  color: #d8c882; letter-spacing: 1px;
}
#villageScreen .vh-card h4::before, #villageScreen .vh-left-h::before {
  content: '▌'; color: var(--c-warn); margin-right: 4px;
}

/* 명단 = 군용 태그 */
#villageScreen .vh-rost {
  border-radius: 1px; border: 1px solid #14130d; border-left: 4px solid var(--cc);
  background: linear-gradient(180deg, #2a2c20, #181a12);
  box-shadow: inset 0 1px 0 #4a4d3855;
}
#villageScreen .vh-rost:hover { background: linear-gradient(180deg, #34372a, #1f2116); }
#villageScreen .vh-rost.selected {
  border-left-color: var(--c-warn);
  box-shadow: inset 0 0 0 1px var(--c-warn), inset 0 1px 0 #4a4d3855;
}
#villageScreen .vh-rost-name { color: #e8e5d0; }
#villageScreen .vh-rost-name em, #villageScreen .vh-rost-state { color: #8e8f5e; }

/* 게이지 = 분절 (틱 오버레이) */
#villageScreen .vh-bar, #villageScreen .vh-detbar {
  position: relative; border: 1px solid #14130d; background: #0a0b06; border-radius: 0;
}
#villageScreen .vh-bar::after, #villageScreen .vh-detbar::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1;
  background: repeating-linear-gradient(90deg, #000a 0 1px, transparent 1px 6px);
}
#villageScreen .vh-bar i, #villageScreen .vh-detbar i { border-radius: 0; }

/* 버튼 = 금속 (눌리는 느낌) */
#villageScreen .vh-act, #villageScreen .vh-cam-btn, #villageScreen .vh-cam-x {
  border-radius: 2px; border: 2px solid #14130d; color: #e8e5d0;
  background: linear-gradient(180deg, #3c3f31, #24261b);
  box-shadow: inset 0 1px 0 #5e624799, inset 0 -2px 0 #0009;
}
#villageScreen .vh-act:hover, #villageScreen .vh-cam-btn:hover {
  background: linear-gradient(180deg, #474b39, #2c2e21); border-color: #14130d; color: #fff;
}
#villageScreen .vh-act:active { transform: translateY(1px); box-shadow: inset 0 2px 5px #000a; }
#villageScreen .vh-cam-btn.active {
  background: linear-gradient(180deg, #7a6526, #4a3c14); color: #ffcf86; border-color: #14130d;
}
#villageScreen .vh-cam-x:hover { color: #e07070; border-color: #c25656; }

/* 상승 나선 칩 */
#villageScreen .vh-spiral span {
  border-radius: 1px; border: 1px solid #14130d;
  background: linear-gradient(180deg, #24261b, #16170f); color: #8e8f5e;
}
#villageScreen .vh-spiral span.on {
  background: linear-gradient(180deg, #3a4a2a, #20281a); border-color: var(--c-spiral); color: #bcd6a0;
}

/* 디테일 패널 강조 (메탈+앰버) */
#villageScreen .vh-detail.active {
  background:
    radial-gradient(circle 2.5px at 6px 6px, #8a7a40, #8a7a4000 70%),
    radial-gradient(circle 2.5px at calc(100% - 6px) 6px, #8a7a40, #8a7a4000 70%),
    radial-gradient(circle 2.5px at 6px calc(100% - 6px), #8a7a40, #8a7a4000 70%),
    radial-gradient(circle 2.5px at calc(100% - 6px) calc(100% - 6px), #8a7a40, #8a7a4000 70%),
    linear-gradient(180deg, #3a3520, #241f12);
  border-left: 3px solid var(--c-warn);
  box-shadow: inset 0 1px 0 #6a5e30, 0 0 18px rgba(212, 161, 79, .22);
}
#villageScreen .vh-det-name { color: #ffcf86; }
#villageScreen .vh-det-act { color: #d4a14f; }

/* 위협 배너 = 군용 경고 */
#villageScreen .vh-alert {
  letter-spacing: 1px; border-top: 2px solid #14130d; border-bottom: 2px solid #14130d;
}
#villageScreen .vh-alert.danger { background: #2c1410; }
#villageScreen .vh-alert.warn { background: #2a2110; }

/* 인물/구역 라벨도 픽셀 + 사각 */
#villageScreen .vh-hotlab, #villageScreen .vh-plab { border-radius: 1px; font-weight: normal; }

/* ═══════ 한눈 인지 (1차 패스): 자원 색/실루엣 · 캐릭터 상태 · 경고 핀 ═══════ */

/* 자원 칩 — 아이콘 크게, 색은 인라인(자원 고유색) */
#villageScreen .vh-pill-ic { width: 19px; height: 19px; }
#villageScreen .vh-pill-ic svg { width: 19px; height: 19px; }
#villageScreen .vh-pill-val { font-size: 0.95rem; }
#villageScreen .vh-pill.danger { animation: vhPulse 1.1s ease-in-out infinite; }

/* 명단 — 체력(♥)/사기(★) 아이콘 + 단계 색 바 */
#villageScreen .vh-rost-body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.vh-stat { display: flex; align-items: center; gap: 5px; }
.vh-stat-ic { width: 11px; height: 11px; flex-shrink: 0; display: inline-flex; }
.vh-stat-ic svg { width: 11px; height: 11px; display: block; }
.vh-stat .vh-mini { flex: 1; height: 4px; }
.vh-stat.low .vh-stat-ic { animation: vhPulse 1s ease-in-out infinite; }

/* 위험 캐릭터 행 — 빨강 강조 + 점멸 */
#villageScreen .vh-rost.danger {
  border-left-color: #c25656;
  box-shadow: inset 0 0 0 1px rgba(194, 86, 86, .6), inset 0 1px 0 #4a4d3855;
  animation: vhRowPulse 1.5s ease-in-out infinite;
}
@keyframes vhRowPulse {
  0%, 100% { box-shadow: inset 0 0 0 1px rgba(194, 86, 86, .35), inset 0 1px 0 #4a4d3855; }
  50%      { box-shadow: inset 0 0 0 1px rgba(194, 86, 86, .9), 0 0 10px rgba(194, 86, 86, .35); }
}

/* 씬 경고 핀 — 머리 위 상태 아이콘 */
.vh-pips {
  position: absolute; transform: translate(-50%, -125%);
  display: flex; gap: 2px; z-index: 7; pointer-events: none;
}
.vh-pip {
  width: 23px; height: 23px; padding: 3px;
  background: rgba(8, 9, 12, .85); border: 1.5px solid currentColor; border-radius: 4px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, .7), 0 0 8px currentColor;
  animation: vhPipFloat 1.5s ease-in-out infinite;
}
.vh-pip svg { width: 100%; height: 100%; display: block; }
@keyframes vhPipFloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@keyframes vhPulse { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }

/* ═══════════════════════════════════════════════════════
   레이아웃 오버홀 (2차): 씬 전면 + HUD 오버레이 (디스워이즈마인식)
   ═══════════════════════════════════════════════════════ */

/* 격자 해체 → 씬을 전면 배경으로 */
#villageScreen .vh-grid { position: relative; display: block; padding: 0; gap: 0; }
#villageScreen .vh-center { position: absolute; inset: 0; gap: 0; }
#villageScreen .vh-scene {
  position: absolute; inset: 0; border: 0; border-radius: 0;
  box-shadow: inset 0 0 120px #000c;
}

/* 좌측 명단 = 왼쪽 가장자리 플로팅 (반투명 금속 + 블러) */
#villageScreen .vh-left {
  position: absolute; top: 10px; left: 10px; bottom: 10px;
  width: 198px; z-index: 12; gap: 8px; padding: 0;
  overflow-y: auto; overflow-x: hidden;
}
/* 우측 시스템 = 오른쪽 가장자리 플로팅 */
#villageScreen .vh-right {
  position: absolute; top: 10px; right: 10px;
  width: 210px; z-index: 12; gap: 8px; padding: 0;
  max-height: calc(100% - 78px); overflow-y: auto; overflow-x: hidden;
}

/* 오버레이 카드 = 반투명 금속 + 프로스트 블러 (씬이 은은히 비침) */
#villageScreen .vh-card, #villageScreen .vh-detail {
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  background:
    radial-gradient(circle 2.5px at 6px 6px, #74774f, #74774f00 70%),
    radial-gradient(circle 2.5px at calc(100% - 6px) 6px, #74774f, #74774f00 70%),
    radial-gradient(circle 2.5px at 6px calc(100% - 6px), #74774f, #74774f00 70%),
    radial-gradient(circle 2.5px at calc(100% - 6px) calc(100% - 6px), #74774f, #74774f00 70%),
    linear-gradient(180deg, rgba(53, 56, 41, .84), rgba(30, 32, 23, .9));
}
#villageScreen .vh-rost {
  backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px);
  background: linear-gradient(180deg, rgba(42, 44, 32, .82), rgba(22, 24, 16, .86));
}
#villageScreen .vh-rost:hover { background: linear-gradient(180deg, rgba(54, 57, 40, .9), rgba(28, 30, 20, .9)); }
#villageScreen .vh-left-h {
  background: rgba(10, 11, 8, .66); backdrop-filter: blur(2px);
  padding: 4px 8px; border-radius: 2px; border: 1px solid #14130d;
}

/* 액션바 = 하단 중앙 플로팅 */
#villageScreen .vh-actbar {
  position: absolute; bottom: 12px; left: 218px; right: 230px; z-index: 12;
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  background: linear-gradient(180deg, rgba(42, 44, 32, .86), rgba(24, 26, 18, .9));
}
#villageScreen .vh-hint { color: #9a9a6a; }

/* ═══════ 음향 감지 스코프 (소음 실시간 파형) ═══════ */
#villageScreen #vhSystems { display: flex; flex-direction: column; gap: 8px; }
.vh-scope-card { padding-bottom: 0.5rem; }
.vh-scope {
  display: block; width: 100%; height: 52px;
  border: 1px solid #14130d; border-radius: 2px;
  background: #080b08;
  box-shadow: inset 0 0 10px #000a;
  margin: 2px 0 5px;
}
.vh-scope-read {
  display: flex; align-items: center; gap: 5px;
  font-size: 0.78rem; color: #9a9a6a;
}
.vh-scope-read b { font-size: 0.95rem; text-shadow: 1px 1px 0 #000; }
.vh-scope-dot { width: 9px; height: 9px; border-radius: 50%; background: #5fae8a; flex-shrink: 0; }

/* 호버 시 그 인물 경고 핀 숨김 → 이름 라벨이 안 가려짐 */
.vh-pips { transition: opacity .15s ease; }
.vh-pips-hidden { opacity: 0; }
/* 이름 라벨은 핀보다 위 (만일 동시 노출돼도 안 가리게) */
#villageScreen .vh-plab { z-index: 9; }
