/* viz.css — Istio 문서 Visualizer 공통 스타일 (md-viz skill).
   라이트 기본 / 다크 토글 / 사이드바 접기 / 손수 SVG 다이어그램(테마 자동 대응).
   색은 전부 CSS 변수로 → 라이트·다크 토글 시 SVG까지 자동 재색칠. CDN 의존 0. */
:root{
  --bg:#ffffff; --panel:#f6f8fa; --border:#d0d7de; --fg:#1f2328; --muted:#656d76;
  --accent:#0969da; --green:#1a7f37; --red:#cf222e; --amber:#9a6700; --code:#f6f8fa;
  --hot:#ddf4ff; --shadow:0 1px 3px rgba(0,0,0,.08);
}
body.dark{
  --bg:#0d1117; --panel:#161b22; --border:#30363d; --fg:#e6edf3; --muted:#8b949e;
  --accent:#58a6ff; --green:#3fb950; --red:#f85149; --amber:#d29922; --code:#1f2630;
  --hot:#11335c; --shadow:0 1px 3px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,"Apple SD Gothic Neo","Noto Sans KR",sans-serif;
  line-height:1.65;font-size:16px;transition:background .2s,color .2s}
header{position:sticky;top:0;z-index:20;background:var(--panel);border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:12px;padding:10px 18px;box-shadow:var(--shadow)}
header .title{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
header .badge{font-size:11px;color:var(--amber);border:1px solid var(--amber);border-radius:10px;padding:1px 8px}
.btn{cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--fg);
  border-radius:6px;padding:5px 11px;font-size:13px;text-decoration:none;white-space:nowrap;transition:.15s}
.btn:hover{border-color:var(--accent);color:var(--accent)}
/* 문서 헤더 우측에 합쳐지는 포털 아이콘군(📁 Files / 🔒 Private) — viz.js 주입 또는
   향후 md2viz 템플릿이 정적 실음. header flex + .title{flex:1} 이 이미 우측 정렬을
   제공하므로 정렬은 그대로 두고, 도큐 chrome(📄 MD 원본)과의 경계 구분선(|)만 추가.
   색은 테마 변수 → 라이트/다크 자동 대응. .hbar 아님 → .sn-reopen 오버랩 픽스 유지. */
header .hportal{display:inline-flex;align-items:center;gap:12px;
  padding-left:12px;border-left:1px solid var(--border)}
.wrap{display:grid;grid-template-columns:240px 1fr;gap:0;max-width:1200px;margin:0 auto;transition:max-width .2s}
body.navcollapsed .wrap{grid-template-columns:1fr;max-width:1100px}
body.navcollapsed nav{display:none}
nav{position:sticky;top:53px;align-self:start;height:calc(100vh - 53px);overflow-y:auto;
  padding:22px 14px;border-right:1px solid var(--border);font-size:13.5px}
nav a{display:block;color:var(--muted);text-decoration:none;padding:4px 10px;border-radius:5px;
  border-left:2px solid transparent;transition:.12s}
nav a:hover{color:var(--fg);background:var(--panel)}
nav a.active{color:var(--accent);border-left-color:var(--accent);background:var(--panel)}
nav a.lv3{padding-left:22px;font-size:12.5px}
main{padding:30px 40px 120px;min-width:0}
h1{font-size:26px;margin:.2em 0 .6em;line-height:1.3}
h2{font-size:20px;margin:1.8em 0 .7em;padding-bottom:.3em;border-bottom:1px solid var(--border);scroll-margin-top:64px}
h3{font-size:16px;margin:1.4em 0 .5em;color:var(--accent);scroll-margin-top:64px}
h4{font-size:14.5px;margin:1.2em 0 .4em;scroll-margin-top:64px}
p{margin:.7em 0}
a{color:var(--accent)}
ul,ol{margin:.6em 0;padding-left:1.5em}
li{margin:.25em 0}
blockquote{margin:1em 0;padding:.4em 1em;border-left:3px solid var(--border);color:var(--muted)}
code{background:var(--code);padding:.15em .4em;border-radius:5px;font-size:.88em;
  font-family:"SF Mono",Menlo,Consolas,"Liberation Mono",monospace}
pre{background:var(--code);border:1px solid var(--border);border-radius:8px;padding:14px 16px;
  overflow-x:auto;margin:1em 0;font-size:13px;line-height:1.5}
pre code{background:none;padding:0;font-size:13px}
table{border-collapse:collapse;width:100%;margin:1em 0;font-size:14px}
th,td{border:1px solid var(--border);padding:8px 12px;text-align:left}
th{background:var(--panel);font-weight:600}
tr:nth-child(even) td{background:var(--panel)}
.pill{display:inline-block;min-width:42px;text-align:center;border-radius:11px;padding:1px 9px;font-size:12.5px;font-weight:600}
.ok{background:rgba(63,185,80,.16);color:var(--green);border:1px solid var(--green)}
.bad{background:rgba(248,81,73,.16);color:var(--red);border:1px solid var(--red)}
.warnp{background:rgba(210,153,34,.16);color:var(--amber);border:1px solid var(--amber)}
.tcode{font-family:"SF Mono",Menlo,monospace;color:var(--accent);font-weight:600}
.callout{border:1px solid var(--border);border-left-width:4px;border-radius:8px;padding:12px 16px;margin:1.2em 0;background:var(--panel)}
.callout.warn{border-left-color:var(--amber)} .callout.note{border-left-color:var(--accent)} .callout.key{border-left-color:var(--green)}
.callout.bad{border-left-color:var(--red)} .callout.info{border-left-color:var(--accent)} .callout.tip{border-left-color:var(--green)}
.callout .ct{font-weight:600;margin-bottom:4px;font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.callout.warn .ct{color:var(--amber)} .callout.note .ct{color:var(--accent)} .callout.key .ct{color:var(--green)}
.callout.bad .ct{color:var(--red)} .callout.info .ct{color:var(--accent)} .callout.tip .ct{color:var(--green)}
.callout ul{margin:.3em 0}
.callout p:first-child{margin-top:0} .callout p:last-child{margin-bottom:0}
/* wikilink: 본 폴더에 대상 md가 없을 수 있어 링크 대신 표식만 */
.wikilink{color:var(--muted);background:var(--code);padding:.1em .4em;border-radius:5px;
  font-size:.85em;border:1px dashed var(--border);text-decoration:none}
.wikilink:hover{border-color:var(--accent);color:var(--accent)}
/* frontmatter meta strip */
.meta{font-size:12.5px;color:var(--muted);margin:.2em 0 1.4em;display:flex;flex-wrap:wrap;gap:6px}
.meta .tag{border:1px solid var(--border);border-radius:10px;padding:1px 9px;background:var(--panel)}
/* SVG diagram frame — native scale(=1) so text stays a consistent size across all figures */
figure{margin:1.3em 0;text-align:center}
.dgm{display:inline-block;max-width:100%;height:auto;background:var(--panel);
  border:1px solid var(--border);border-radius:8px;padding:8px}
.dgm .box{fill:var(--bg);stroke:var(--border);stroke-width:1.5}
.dgm .box.hot{fill:var(--hot);stroke:var(--accent);stroke-width:2}
.dgm .box.bad{stroke:var(--red)} .dgm .box.amber{stroke:var(--amber)} .dgm .box.green{stroke:var(--green)}
.dgm .ttl{fill:var(--fg);font:600 13px sans-serif}
.dgm .sub{fill:var(--muted);font:11px sans-serif}
.dgm .mono{font-family:"SF Mono",Menlo,monospace}
.dgm .edge{stroke:var(--muted);stroke-width:1.6;fill:none}
.dgm .edge.dash{stroke-dasharray:5 4}
.dgm .elbl{fill:var(--muted);font:11px "SF Mono",monospace}
.dgm .life{stroke:var(--border);stroke-width:1;stroke-dasharray:3 3}
figcaption{font-size:12.5px;color:var(--muted);text-align:center;margin-top:6px}
.seealso a{color:var(--muted)} .src-link{font-size:12px;color:var(--muted)}
@media(max-width:820px){.wrap{grid-template-columns:1fr}nav{display:none}main{padding:20px}}

/* ───────── 통합 위키 포털 글로벌 사이트내비 (viz.js 주입) ─────────
   body.haswiki = 2컬럼 그리드(sitenav | page). 색은 전부 기존 테마 변수 사용. */
body.haswiki{display:grid;grid-template-columns:var(--sitenav-w,240px) 1fr;min-height:100vh}
/* 접힘: 사이드바 트랙을 완전히 제거(단일 컬럼) → #page 가 col1 을 차지하며 깔끔히 재flow.
   (구버전은 0px 트랙 + #page col2 유지 → 빈 트랙이 남아 정렬이 어긋날 수 있었다) */
body.haswiki.nav-collapsed{grid-template-columns:1fr;--sitenav-w:0px}
body.haswiki.nav-collapsed #sitenav{display:none}
body.haswiki.nav-collapsed #page{grid-column:1}
#page{grid-column:2;min-width:0}
/* 3-pane reconcile: #page 안의 기존 .wrap(원래 nav#toc=왼쪽 240 | main=오른쪽)을
   main(center, fluid) + nav#toc(RIGHT rail)로 재배치 → 글로벌 #sitenav와 좌측 중복 제거.
   전부 body.haswiki 스코프 → JS 미동작(standalone) 시 원래 단일 아카이브 레이아웃 유지. */
body.haswiki .wrap{grid-template-columns:minmax(0,1fr) var(--toc-w,240px);max-width:none;margin:0}
body.haswiki .wrap>main{order:1}
body.haswiki .wrap>nav#toc{order:2;border-right:0;border-left:1px solid var(--border)}
body.haswiki.navcollapsed .wrap{grid-template-columns:minmax(0,1fr)}
body.haswiki.navcollapsed nav#toc{display:none}
body.haswiki #sitenav .sn-tree{display:block}   /* 글로벌 트리는 navcollapsed/좁은화면에서도 유지 */
#sitenav{grid-column:1;position:sticky;top:0;height:100vh;overflow:auto;
  background:var(--panel);border-right:1px solid var(--border);
  font-size:13px;display:flex;flex-direction:column}
#sitenav .sn-head{position:sticky;top:0;z-index:2;background:var(--panel);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:10px 12px;border-bottom:1px solid var(--border)}
#sitenav .sn-brand a{font-weight:700;font-size:14px;color:var(--fg);text-decoration:none;white-space:nowrap}
#sitenav .sn-collapse{cursor:pointer;border:1px solid var(--border);background:var(--bg);color:var(--muted);
  border-radius:6px;padding:2px 9px;font-size:13px;line-height:1.2;transition:.15s}
#sitenav .sn-collapse:hover{border-color:var(--accent);color:var(--accent)}
#sitenav .sn-search{padding:10px 12px 4px}
#sitenav #sn-q{width:100%;padding:6px 10px;border:1px solid var(--border);border-radius:7px;
  background:var(--bg);color:var(--fg);font-size:13px;outline:none;transition:.15s}
#sitenav #sn-q:focus{border-color:var(--accent)}
#sitenav .sn-results{display:none;flex-direction:column;margin-top:6px;
  border:1px solid var(--border);border-radius:7px;overflow:hidden;background:var(--bg)}
#sitenav .sn-results.open{display:flex}
#sitenav .sn-result{display:block;padding:6px 9px;color:var(--fg);text-decoration:none;font-size:12.5px;
  border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#sitenav .sn-result:last-child{border-bottom:0}
#sitenav .sn-result:hover{background:var(--panel)}
#sitenav .sn-rdom{color:var(--muted);font-size:10.5px;border:1px solid var(--border);
  border-radius:8px;padding:0 6px;margin-left:4px}
#sitenav .sn-nohit{color:var(--muted);font-size:12px;padding:7px 9px}
/* content-match 스니펫 (사이드바·포털 공용) */
.sn-snip{display:block;color:var(--muted);font-size:11.5px;margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* 포털 히어로 검색 (#portal-q + #portal-results): 중앙·확대, .sn-results 드롭다운 재사용/확장.
   색은 전부 기존 테마 변수(라이트/다크) 사용, CDN 0. */
.portal-search{position:relative;max-width:none;margin:18px auto 10px;padding:0 12px}
.portal-search #portal-q{width:100%;padding:13px 18px;font-size:16px;border:1px solid var(--border);
  border-radius:12px;background:var(--panel);color:var(--fg);outline:none;box-shadow:var(--shadow);transition:.15s}
.portal-search #portal-q:focus{border-color:var(--accent);background:var(--bg)}
.portal-search #portal-results{display:none;position:absolute;left:12px;right:12px;top:100%;margin-top:6px;z-index:40;
  flex-direction:column;background:var(--bg);border:1px solid var(--border);border-radius:10px;
  overflow:hidden;box-shadow:var(--shadow);max-height:60vh;overflow-y:auto}
.portal-search #portal-results.open{display:flex}
.portal-search .sn-result{display:block;padding:9px 14px;color:var(--fg);text-decoration:none;font-size:14px;
  border-bottom:1px solid var(--border);overflow:hidden}
.portal-search .sn-result:last-child{border-bottom:0}
.portal-search .sn-result:hover{background:var(--panel)}
.portal-search .sn-rdom{color:var(--muted);font-size:11px;border:1px solid var(--border);
  border-radius:8px;padding:0 6px;margin-left:4px}
.portal-search .sn-nohit{color:var(--muted);font-size:13px;padding:10px 14px}
.portal-search .sn-snip{white-space:normal;margin-top:3px}
#sitenav .sn-tree{padding:8px 0 24px;flex:1}
#sitenav ul{list-style:none;margin:0;padding:0}
#sitenav .sn-tier{padding:4px 0}
#sitenav .sn-tier>h3{margin:10px 0 4px;padding:0 12px;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
#sitenav .sn-domain{margin:2px 0}
#sitenav .sn-domlink{display:block;font-weight:700;color:var(--fg);text-decoration:none;padding:5px 12px}
#sitenav .sn-domlink:hover{color:var(--accent)}
#sitenav .sn-ico{margin-right:3px}
#sitenav .sn-toplabel{display:block;padding:4px 12px 1px;color:var(--muted);
  font-size:11px;text-transform:uppercase;letter-spacing:.03em}
#sitenav .sn-doc{display:block;padding:3px 12px 3px 24px;color:var(--muted);text-decoration:none;
  border-left:2px solid transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:.12s}
#sitenav .sn-doc:hover{color:var(--fg);background:var(--bg)}
#sitenav .sn-current{color:var(--accent);border-left-color:var(--accent);background:var(--bg)}
#sitenav .sn-files{border-top:1px solid var(--border);margin-top:8px;padding-top:8px}
#sitenav .sn-files a,#sitenav .sn-lock{display:block;padding:6px 12px;color:var(--fg);text-decoration:none;font-weight:600}
#sitenav .sn-files a:hover,#sitenav .sn-lock:hover{color:var(--accent)}
/* 접힘 상태 재오픈 affordance (떠 있는 버튼) */
.sn-reopen{display:none}
body.haswiki.nav-collapsed .sn-reopen{display:block;position:fixed;top:8px;left:8px;z-index:50;
  cursor:pointer;border:1px solid var(--border);background:var(--panel);color:var(--fg);
  border-radius:7px;padding:5px 11px;font-size:15px;line-height:1;box-shadow:var(--shadow);transition:.15s}
.sn-reopen:hover{border-color:var(--accent);color:var(--accent)}
/* 접힘 시 floating ☰(.sn-reopen, fixed top-left)가 문서 헤더 좌측의 자체 ☰(#navtoggle)·
   🏠목록을 덮는 문제 통일 해결: 문서 헤더(.hbar 없는 md2viz 생성 헤더)의 내용을 ☰ 폭만큼
   우측으로 시프트. 포털 헤더(.hbar 보유)는 PORTAL_CSS가 자체 처리하므로 :not(:has(.hbar))로 제외.
   doc HTML은 손대지 않음 → hand-SVG 강화 istio 문서 포맷 그대로 보존하며 헤더 동작만 통일. */
body.haswiki.nav-collapsed header:not(:has(.hbar)){padding-left:56px}
/* 좁은 화면(<900px): 단일 컬럼, 사이트내비는 오버레이(접힘 시작 권장 — JS가 처리) */
@media(max-width:900px){
  body.haswiki{grid-template-columns:1fr}
  body.haswiki #page{grid-column:1}
  body.haswiki .wrap{grid-template-columns:minmax(0,1fr)}  /* single column: main only */
  body.haswiki .wrap>nav#toc{display:none}                 /* in-page TOC hidden on narrow */
  #sitenav{position:fixed;top:0;left:0;width:var(--sitenav-w,240px);max-width:82vw;z-index:60;
    box-shadow:var(--shadow)}
  body.haswiki.nav-collapsed #sitenav{width:0}
}

/* ═══════════════════ Hugo blog port additions (stage2) ═══════════════════
   Everything below is new vs. the frozen knowledge-base/assets/viz.css this
   file was copied from. Legacy is the reference for markup/id/class names;
   these are additive rules (new classes, or a same-name rule that only
   layers onto behavior that legacy left to a page's own inline <style>,
   e.g. the old catalog index.html). Nothing above this line was edited. */

/* sitenav brand icon (inline <svg> next to the 📚 replacement — small mark so
   every page ships at least one native <svg>, not just pages whose own
   content happens to embed one via goldmark's unsafe HTML passthrough). */
.sn-logo{vertical-align:-3px;margin-right:3px}

/* extra callout variant: legacy's 6 modifier classes (note/warn/key/bad/info/tip)
   didn't include "abstract" (Obsidian summary/tldr-style) — this corpus uses it. */
.callout.abstract{border-left-color:var(--accent)}
.callout.abstract .ct{color:var(--accent)}

/* Hugo's native .TableOfContents renders nested <ul><li><a>, not legacy's flat
   <a> list — nested list reset + an h3-under-h2 indent so it still reads like
   the flat nav's lv3 rows, without needing a custom Fragments-walking partial. */
#toc ul{list-style:none;margin:0;padding:0}
#toc li{margin:0}
#toc ul ul a{padding-left:22px;font-size:12.5px}

/* per-page "Files" download block (bundle files/* + raw markdown link) —
   new in the Hugo port; legacy standalone docs had no page-bundle concept.
   Styled to sit quietly at the foot of a doc, echoing .meta's tag chips. */
.viz-files{margin:2.8em 0 1em;padding-top:1.1em;border-top:1px solid var(--border)}
.viz-files h2{border-bottom:0;margin-bottom:.4em}
.viz-files ul{list-style:none;margin:.4em 0;padding:0}
.viz-files li{display:flex;align-items:baseline;gap:8px;padding:5px 0;font-size:14px}
.viz-files a{font-weight:500}
.viz-files .viz-file-size{font-size:11.5px;color:var(--muted)}

/* header nav menu (Docs/Logs/Legacy) reuses .btn; just needs an active marker. */
header .btn.active{border-color:var(--accent);color:var(--accent)}

/* ── home/list "portal" look, ported from the old catalog index.html's own
   inline <style> block (that page had no shared stylesheet entry for these
   classes — viz.css only ever carried the single-document reader styles).
   Trimmed of the portal hero-search bits (#portal-q etc.) — out of scope. */
.home{max-width:1180px;margin:0 auto;padding:24px 24px 100px}
.home h1{font-size:23px;margin:.1em 0 .15em}
.lead{color:var(--muted);font-size:13.5px;margin:.2em 0 1.4em}
.sec{margin:30px 0 8px;font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}
.sec .cnt{font-size:11.5px;color:var(--muted);border:1px solid var(--border);border-radius:10px;padding:0 7px;font-weight:400}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px;margin-top:6px}
.card{border:1px solid var(--border);border-radius:11px;background:var(--panel);padding:15px 17px}
.card h2{font-size:15.5px;margin:0 0 .15em;border:0;padding:0;display:flex;align-items:center;gap:7px}
.card .cnt{font-size:11.5px;color:var(--muted);border:1px solid var(--border);border-radius:10px;padding:0 7px;font-weight:400}
.card .cdesc{font-size:12px;color:var(--muted);margin:.1em 0 .7em;line-height:1.55}
.card ul{list-style:none;margin:0;padding:0}
a.domcard{display:block;text-decoration:none;color:inherit}
a.domcard:hover{border-color:var(--accent)}
a.domcard:hover h2{color:var(--accent)}
.domcard .icon{font-size:19px}
.dmeta{font-size:11.5px;color:var(--muted);margin:.2em 0 0;display:flex;gap:12px;flex-wrap:wrap}
.row{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-top:1px solid var(--border)}
.row:first-of-type{border-top:0}
a.doc{flex:1;text-decoration:none;color:var(--fg);min-width:0}
.line1{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:14px;font-weight:500}
a.doc:hover .line1{color:var(--accent)}
.sub2{display:block;font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.45;
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.dom{font-size:10.5px;color:var(--muted);border:1px solid var(--border);border-radius:8px;padding:0 6px;font-weight:400;white-space:nowrap}
.when{font-size:11px;color:var(--muted);white-space:nowrap;padding-top:2px}
.empty{color:var(--muted);font-size:13px;margin:.4em 2px}

