/* ══════════════════════════════════════════════
   VMware Field Guide — style.css
   Dark GitHub-style design system
   ══════════════════════════════════════════════ */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0f1117;--bg2:#161b22;--bg3:#21262d;--bg4:#2d333b;
  --border:#30363d;--border2:#444c56;
  --text:#e6edf3;--text2:#8b949e;--text3:#6e7681;
  --blue:#58a6ff;--blue-bg:#1f3a5f;--blue-border:#1f6feb;
  --green:#3fb950;--green-bg:#1a3828;--green-border:#238636;
  --yellow:#d29922;--yellow-bg:#2f2007;--yellow-border:#9e6a03;
  --red:#f85149;--red-bg:#3d1a18;--red-border:#6e1c1c;
  --purple:#a371f7;--purple-bg:#2a1f4f;--purple-border:#553098;
  --orange:#f0883e;--orange-bg:#2a1500;--orange-border:#a04e00;
  --mono:ui-monospace,SFMono-Regular,'SF Mono',Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;
}

body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;min-height:100vh}

/* ── PORTFOLIO BAR ── */
#pbar{background:#080c11;border-bottom:1px solid #1a1f27;padding:5px 16px;font-size:12px;color:var(--text3);display:flex;gap:8px;align-items:center}
#pbar a{color:var(--text2);text-decoration:none;transition:color .15s}
#pbar a:hover{color:var(--blue)}
.sep{color:#2a2f38}

/* ── HEADER ── */
#hdr{background:var(--bg2);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
#hdr h1{font-size:16px;font-weight:600;color:var(--text);letter-spacing:-.2px}
.bdg{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500;border:1px solid}
.bdg-blue{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}
.bdg-green{background:var(--green-bg);color:var(--green);border-color:var(--green-border)}
.bdg-orange{background:var(--orange-bg);color:var(--orange);border-color:var(--orange-border)}
.bdg-purple{background:var(--purple-bg);color:var(--purple);border-color:var(--purple-border)}
#hdr-right{margin-left:auto;display:flex;align-items:center;gap:8px}
#prog-text{font-size:12px;color:var(--text3)}
#prog-wrap{width:80px;height:4px;background:var(--bg4);border-radius:4px;overflow:hidden}
#prog-fill{height:100%;background:var(--green);border-radius:4px;transition:width .4s}

/* ── MODE SWITCHER ── */
#modes{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 16px;display:flex;gap:0}
.mode-btn{padding:10px 20px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;display:flex;align-items:center;gap:7px;transition:all .15s;border-right:1px solid var(--border);user-select:none}
.mode-btn:last-child{border-right:none}
.mode-btn:hover{color:var(--text);background:var(--bg3)}
.mode-btn.active{color:var(--blue);border-bottom-color:var(--blue);background:transparent}
.mode-btn.active#mb-operate{color:var(--orange);border-bottom-color:var(--orange)}
.mode-btn.active#mb-ref{color:var(--purple);border-bottom-color:var(--purple)}
.mode-icon{font-size:14px}

/* ── PHASE BAR ── */
#phase-bar{background:#0c1017;border-bottom:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;gap:4px;overflow-x:auto}
.ph-node{display:flex;align-items:center;gap:4px}
.ph-dot{width:22px;height:22px;border-radius:50%;border:1px solid var(--border2);cursor:pointer;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:all .2s;flex-shrink:0}
.ph-dot.done{background:var(--green-bg);border-color:var(--green-border);color:var(--green)}
.ph-dot.active{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue)}
.ph-line{width:18px;height:1px;background:var(--border);flex-shrink:0}

/* ── SUB-NAV ── */
#subnav{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 16px;display:flex;gap:2px;overflow-x:auto}
.snav{padding:9px 13px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:5px}
.snav:hover{color:var(--text)}
.snav.active{color:var(--blue);border-bottom-color:var(--blue)}
.snav-num{font-size:9px;background:var(--bg3);border-radius:8px;padding:1px 4px;color:var(--text3)}
.snav.active .snav-num{background:#1a3260;color:#7ab4ff}

/* ── CONCEPT TABS ── */
#ctabs{padding:14px 20px 0;display:flex;flex-wrap:wrap;gap:6px}
.ctab{padding:5px 11px;font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:20px;cursor:pointer;color:var(--text2);background:var(--bg2);transition:all .15s;display:flex;align-items:center;gap:5px}
.ctab:hover{color:var(--text);border-color:var(--border2)}
.ctab.active{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-border)}
.ctab-n{font-size:10px;background:var(--bg3);border-radius:8px;padding:1px 5px;color:var(--text3)}
.ctab.active .ctab-n{background:#1a3260;color:#7ab4ff}
.ctab.reviewed .ctab-n{color:var(--green)}

/* ── SEARCH INPUT ── */
#search-input:focus{border-color:var(--blue-border);box-shadow:0 0 0 2px rgba(88,166,255,.15)}
.search-result{padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text2)}
.search-result strong{color:var(--blue)}

/* ── MAIN ── */
#main{padding:18px 20px;max-width:1080px;margin:0 auto}
.pane{display:none}.pane.active{display:block}

/* ── FILE SOURCE INDICATOR ── */
.file-src{font-size:10px;font-family:var(--mono);color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:2px 6px;margin-left:auto}
.src-line{font-size:11px;color:var(--text3);font-family:var(--mono);margin-bottom:10px;display:flex;align-items:center;gap:6px}

/* ── CARDS ── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:13px}
.card-hd{font-size:15px;font-weight:600;margin-bottom:12px;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cnum{font-size:11px;background:var(--bg3);border:1px solid var(--border2);border-radius:5px;padding:2px 7px;color:var(--text3);font-family:var(--mono)}
.card h3{font-size:13px;font-weight:600;margin:14px 0 6px;color:var(--blue)}
.card h3.orange{color:var(--orange)}
.card h3.purple{color:var(--purple)}
.card p,.card li{font-size:13px;color:var(--text2);line-height:1.75}
.card ul,.card ol{padding-left:20px;margin:5px 0}
.card li{margin:3px 0}

/* ── PREFORMATTED / CODE ── */
pre{background:var(--bg3);border:1px solid var(--border);border-left:3px solid var(--blue-border);border-radius:6px;padding:10px 14px;font-family:var(--mono);font-size:12px;color:#a5d6ff;overflow-x:auto;margin:8px 0;white-space:pre;line-height:1.6}
code{font-family:var(--mono);font-size:12px;background:var(--bg3);padding:1px 5px;border-radius:4px;color:#a5d6ff}

/* ── CALLOUT BOXES ── */
.box{border-radius:6px;padding:11px 14px;margin:9px 0;font-size:13px;color:var(--text2);line-height:1.75}
.box-info{background:var(--blue-bg);border:1px solid var(--blue-border)}
.box-warn{background:var(--yellow-bg);border:1px solid var(--yellow-border);border-left:3px solid var(--yellow)}
.box-success{background:var(--green-bg);border:1px solid var(--green-border)}
.box-vmw{background:var(--orange-bg);border:1px solid var(--orange-border);border-left:3px solid var(--orange)}
.box-vmw strong,.box-vmw b{color:var(--orange)}
.box-op{background:#1a0d00;border:1px solid #5a2a00;border-left:3px solid var(--orange)}
.box-purple{background:var(--purple-bg);border:1px solid var(--purple-border);border-left:3px solid var(--purple)}
.box strong,.box b{font-weight:600}

/* ── UNDER THE HOOD ── */
.hood-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-size:12px;background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-border);border-radius:6px;cursor:pointer;transition:all .15s;user-select:none;margin:4px 0}
.hood-btn:hover{background:#341f66}
.hood-arr{display:inline-block;transition:transform .2s;font-size:11px}
.hood-body{display:none;background:var(--bg3);border:1px solid var(--purple-border);border-radius:6px;padding:13px;margin:4px 0 10px;font-size:13px;color:var(--text2);line-height:1.75}
.hood-body h4{font-size:12px;font-weight:600;color:var(--purple);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px}
.hood-body p{margin-bottom:6px}
.hood-body.open{display:block}

/* ── TABLES ── */
table{width:100%;border-collapse:collapse;font-size:13px;margin:8px 0}
th{background:var(--bg3);color:var(--text);font-weight:600;padding:8px 12px;text-align:left;border:1px solid var(--border)}
td{padding:7px 12px;border:1px solid var(--border);color:var(--text2)}
tr:hover td{background:#191e26}

/* ── PORT TAGS ── */
.ptag{display:inline-block;font-family:var(--mono);font-size:11px;padding:2px 7px;border-radius:4px;margin:1px}
.ptag-tcp{background:#1a2d50;color:#7ab4ff;border:1px solid #254070}
.ptag-udp{background:#2a2005;color:#d29922;border:1px solid #6a4800}

/* ── REVIEWED ROW ── */
.rev-row{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);flex-wrap:wrap;gap:8px}
.rev-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-size:12px;border:1px solid var(--border2);border-radius:6px;cursor:pointer;color:var(--text2);background:transparent;font-family:var(--sans);transition:all .15s;user-select:none}
.rev-btn:hover{border-color:var(--green-border);color:var(--green)}
.rev-btn.done{background:var(--green-bg);border-color:var(--green-border);color:var(--green)}
.rev-meta{font-size:12px;color:var(--text3)}

/* ── TROUBLESHOOT TREES (operate) ── */
.tree-node{margin:3px 0}
.tni{display:flex;align-items:flex-start;gap:8px;cursor:pointer;padding:7px 10px;border-radius:6px;border:1px solid transparent;transition:background .1s;user-select:none}
.tni:hover{background:var(--bg4)}
.tni.root{background:var(--blue-bg);border-color:var(--blue-border)}
.tni.root .tlbl{color:var(--blue);font-weight:600}
.tni.q{background:#1a2810;border-color:#2d5a2d}
.tni.q .tlbl{color:#56d364}
.tni.cause{background:var(--yellow-bg);border-color:var(--yellow-border)}
.tni.cause .tlbl{color:var(--yellow)}
.tni.fix{background:var(--green-bg);border-color:var(--green-border)}
.tni.fix .tlbl{color:var(--green)}
.tni.cmd{background:var(--bg3);border-color:var(--border)}
.tni.cmd .tlbl{font-family:var(--mono);font-size:12px;color:#a5d6ff}
.tni.warn{background:var(--red-bg);border-color:var(--red-border)}
.tni.warn .tlbl{color:var(--red)}
.tlbl{font-size:13px;color:var(--text);line-height:1.4;flex:1}
.tico{font-size:11px;color:var(--text3);flex-shrink:0;width:14px;text-align:center;margin-top:2px}
.tch{margin-left:20px;border-left:1px solid var(--border2);padding-left:10px;margin-top:3px}
.tch.hidden{display:none}

/* ── LEGEND ── */
.leg{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.leg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text2)}
.leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ── QUICK REF GRIDS ── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ── COMING SOON ── */
.coming-soon{text-align:center;padding:48px 24px;color:var(--text3)}
.coming-soon h2{font-size:18px;color:var(--text2);margin-bottom:8px}
.coming-soon p{font-size:13px}

/* ── OPERATE SUB-NAV ── */
.op-tabs{display:flex;gap:2px;padding:0 16px;background:var(--bg2);border-bottom:1px solid var(--border);overflow-x:auto}
.op-tab{padding:9px 14px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s}
.op-tab:hover{color:var(--text)}
.op-tab.active{color:var(--orange);border-bottom-color:var(--orange)}

/* ── RESPONSIVE ── */
@media(max-width:700px){
  .g2{grid-template-columns:1fr}
  #ctabs{padding:10px 14px 0}
  #main{padding:12px 14px}
  .mode-btn{padding:9px 12px;font-size:12px}
  #hdr h1{font-size:15px}
}
