.nodes-tab { padding: 0; height: 100%; display: flex; flex-direction: column; }

.nodes-toolbar {
  display: flex; gap: .7rem; align-items: center;
  padding: .55rem .9rem;
  background: rgba(24, 24, 27, .22);
  border-bottom: 1px solid rgba(255, 255, 255, .1);
  flex-wrap: wrap;
  backdrop-filter: blur(24px) saturate(180%);
}
.nodes-toolbar label { font-size: .82rem; color: #d4d4d8; display: flex; align-items: center; gap: .3rem; }
.nodes-toolbar select,
.nodes-toolbar input:not([type="checkbox"]):not([type="radio"]),
.nodes-toolbar button {
  background: rgba(39, 39, 42, .45); color: #e2e8f0;
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 6px; padding: .22rem .55rem; font-size: .82rem;
}
.nodes-toolbar input[type="search"] { min-width: 220px; font-family: inherit; }
.nodes-toolbar button.t-btn.danger { background: rgba(239, 68, 68, .12); border-color: rgba(var(--v2-rgb), .4); color: #fecaca; }
.nodes-toolbar button.t-btn.danger:hover:not(:disabled) { background: rgba(239, 68, 68, .22); }
.nodes-toolbar .nodes-stats {
  margin-left: auto;
  font-family: 'Menlo','Consolas',monospace;
  font-size: .8rem; font-weight: 600;
  display: flex; gap: .4rem;
}
.nodes-toolbar .nodes-stats .stat { padding: .1rem .45rem; border-radius: 3px; border: 1px solid; }
.nodes-toolbar .nodes-stats .stat.up   { color: var(--v4); border-color: var(--v4); background: rgba(var(--v4-rgb),.1); }
.nodes-toolbar .nodes-stats .stat.down { color: var(--v2); border-color: var(--v2); background: rgba(var(--v2-rgb),.12); }
.nodes-toolbar .nodes-stats .stat.unk  { color: #94a3b8; border-color: #64748b; background: rgba(100,116,139,.1); }

/* ===== Layout ===== */
.nodes-layout { display: grid; grid-template-columns: 280px 1fr; flex: 1; min-height: 0; transition: grid-template-columns .2s; }
.nodes-layout.sidebar-hidden { grid-template-columns: 0 1fr; }
.nodes-layout.sidebar-hidden #nodes-sidebar { visibility: hidden; border-right: none; }

#nodes-sidebar {
  background: rgba(20, 20, 23, .25);
  border-right: 1px solid rgba(255, 255, 255, .1);
  overflow-y: auto;
  backdrop-filter: blur(24px) saturate(180%);
}
#nodes-tree { list-style: none; margin: 0; padding: .3rem 0; }
#nodes-tree .vlan-group { margin: 0; padding: 0; }
#nodes-tree .vlan-header {
  display: flex; align-items: center; gap: .4rem;
  width: 100%; padding: .45rem .85rem;
  background: transparent; border: none; cursor: pointer; text-align: left;
  font-family: 'Menlo','Consolas',monospace; font-weight: 600;
  font-size: .72rem; text-transform: uppercase; letter-spacing: .08em;
  border-bottom: 1px solid rgba(255, 255, 255, .05);
  transition: background .12s;
}
#nodes-tree .vlan-header:hover { background: rgba(255, 255, 255, .04); }
#nodes-tree .vlan-header .vh-chevron { width: 10px; font-size: .68rem; transition: transform .15s; }
#nodes-tree .vlan-group.collapsed .vh-chevron { transform: rotate(-90deg); }
#nodes-tree .vlan-header .vh-name { flex: 1; }
#nodes-tree .vlan-header .vh-count { color: #64748b; font-size: .64rem; font-weight: normal; }

/* Couleur par VLAN sur le label */
#nodes-tree .vlan-header.v0 .vh-name { color: #c084fc; } /* DMZ/box */
#nodes-tree .vlan-header.v1 .vh-name { color: var(--v1); }
#nodes-tree .vlan-header.v2 .vh-name { color: var(--v2); }
#nodes-tree .vlan-header.v3 .vh-name { color: var(--v3); }
#nodes-tree .vlan-header.v4 .vh-name { color: var(--v4); }
#nodes-tree .vlan-header.v5 .vh-name { color: var(--v5); }
#nodes-tree .vlan-header.v6 .vh-name { color: var(--v6); }
#nodes-tree .vlan-header.vt .vh-name { color: var(--vt); }

#nodes-tree .node-item {
  padding: .35rem .85rem .35rem 1.5rem;
  cursor: pointer;
  display: flex; align-items: center; gap: .5rem;
  border-bottom: 1px solid rgba(255, 255, 255, .03);
  transition: background .12s;
  font-size: .8rem;
}
#nodes-tree .node-item:hover { background: rgba(255, 255, 255, .04); }
#nodes-tree .node-item.active {
  background: rgba(var(--p-glow-rgb), .15);
  box-shadow: inset 2px 0 0 var(--p-base);
}
#nodes-tree .node-item.active .ni-name { color: var(--p-base); font-weight: 500; }
#nodes-tree .node-item .ni-led {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0;
}
#nodes-tree .node-item .ni-led.up      { background: var(--v4); box-shadow: 0 0 4px var(--v4); }
#nodes-tree .node-item .ni-led.down    { background: var(--v2); box-shadow: 0 0 4px var(--v2); }
#nodes-tree .node-item .ni-led.unknown { background: #64748b; }
#nodes-tree .node-item .ni-name { color: #e4e4e7; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
#nodes-tree .node-item .ni-ip { color: #64748b; font-family: 'Menlo','Consolas',monospace; font-size: .68rem; flex-shrink: 0; }
#nodes-tree .node-item .ni-ssh {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
  background: rgba(255,255,255,.1);
}
#nodes-tree .node-item .ni-ssh.active { background: var(--p-base); box-shadow: 0 0 3px var(--p-base); }
#nodes-tree .node-item .ni-ssh.had    { background: #fb923c; }
#nodes-tree .vlan-group.collapsed .vlan-items { display: none; }

/* ===== Main ===== */
#nodes-main { display: flex; flex-direction: column; background: transparent; position: relative; overflow: hidden; min-height: 0; }
#nodes-main .sidebar-handle {
  position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 12px; height: 64px;
  background: rgba(39, 39, 42, .55);
  border: 1px solid rgba(255, 255, 255, .08); border-left: none;
  border-radius: 0 6px 6px 0;
  color: var(--p-light);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: .9rem; line-height: 1; padding: 0; z-index: 10;
  backdrop-filter: blur(15px);
}
#nodes-main .sidebar-handle:hover { background: rgba(var(--p-base-rgb), .18); color: var(--p-base); }

.nodes-picker-bar {
  display: flex; align-items: center; gap: .6rem;
  padding: .5rem .9rem;
  background: rgba(24, 24, 27, .25);
  border-bottom: 1px solid rgba(255, 255, 255, .07);
}
.nodes-picker-bar label { font-size: .78rem; color: #94a3b8; display: flex; align-items: center; gap: .35rem; }
.nodes-picker-bar select {
  min-width: 280px;
  background: rgba(39, 39, 42, .55); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 5px; padding: .25rem .5rem; font-size: .82rem;
}
.nodes-picker-bar .picker-info { color: #64748b; font-size: .75rem; font-family: 'Menlo','Consolas',monospace; margin-left: auto; }

.nodes-empty { flex: 1; display: flex; align-items: center; justify-content: center; color: #64748b; font-style: italic; padding: 2rem; }
#nodes-empty[hidden], #nodes-detail[hidden] { display: none !important; }

#nodes-detail { flex: 1; overflow-y: auto; padding: 1.2rem 1.6rem 2rem; max-width: 1100px; margin: 0 auto; width: 100%; }

/* ===== Header riche du detail — chrome .card-pri (ref Vincent 2026-04-29)
   Card principale du node, --p-base plein. Les sub-panels audit gardent
   leurs scores sémantiques internes (.nca-score.score-*). ===== */
.nd-header {
  --card-rgb: var(--p-base-rgb);
  padding: 1rem 1.2rem;
  margin-bottom: 1.2rem;
  border-radius: 8px;
  border-top:    1px solid rgba(var(--card-rgb), .4);
  border-right:  1px solid rgba(var(--card-rgb), .4);
  border-bottom: 1px solid rgba(var(--card-rgb), .4);
  border-left:   2px solid rgba(var(--card-rgb), .9);
  background:
    radial-gradient(circle at top right, rgba(var(--card-rgb), .14), transparent 60%),
    linear-gradient(135deg, rgba(var(--card-rgb), .1) 0%, rgba(var(--card-rgb), .03) 50%, rgba(24, 24, 27, .55) 100%);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  box-shadow: inset 8px 0 14px -8px rgba(var(--card-rgb), .55), inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 18px rgba(0, 0, 0, .28);
}
.nd-h-top { display: flex; gap: 1rem; align-items: center; margin-bottom: .6rem; }
.nd-led {
  width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0;
  box-shadow: 0 0 8px currentColor;
}
.nd-led.up { background: var(--v4); color: var(--v4); }
.nd-led.down { background: var(--v2); color: var(--v2); animation: nd-pulse 1.4s ease-in-out infinite; }
.nd-led.unknown { background: #64748b; color: transparent; box-shadow: none; }
@keyframes nd-pulse { 0%,100%{opacity:1;} 50%{opacity:.4;} }

.nd-h-info { flex: 1; min-width: 0; }
.nd-h-name { font-size: 1.7rem; color: var(--p-base); font-weight: 700; margin: 0 0 .15rem; display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; line-height: 1.15; letter-spacing: -.01em; }
.nd-h-name .nd-h-text { display: inline-flex; align-items: baseline; gap: .55rem; }
.nd-h-name .nd-h-fname { color: #e4e4e7; font-weight: 400; font-size: .85rem; opacity: .75; }
.nd-h-iconbtn {
  background: transparent;
  border: none;
  color: var(--p-base);
  padding: .15rem;
  cursor: pointer;
  transition: color .12s, background .12s, transform .12s;
  line-height: 0;
  border-radius: 3px;
  display: inline-flex; align-items: center; justify-content: center;
}
.nd-h-iconbtn svg { display: block; }
.nd-h-iconbtn:hover:not(:disabled) {
  color: var(--p-glow);
  background: rgba(var(--p-base-rgb), .1);
  transform: scale(1.1);
}
.nd-h-iconbtn:active:not(:disabled) { transform: scale(.95); }
.nd-h-iconbtn:disabled,
.nd-h-iconbtn.is-off { color: #4b5563; cursor: not-allowed; opacity: .55; }
.nd-h-iconbtn.is-off:hover { background: transparent; transform: none; color: #4b5563; }

/* Score = bouton cliquable maintenant */
.nd-score { font-family: inherit; cursor: pointer; transition: box-shadow .12s; }
.nd-score:hover { box-shadow: 0 0 10px currentColor; }

/* Popup décomposition score */
.nd-score-pop {
  position: fixed; z-index: 1000;
  min-width: 320px; max-width: 460px;
  padding: .7rem .85rem;
  background: rgba(24, 24, 27, .96);
  border: 1px solid rgba(var(--p-base-rgb), .4);
  border-radius: 6px;
  backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 12px 40px rgba(0, 0, 0, .55);
  color: #e4e4e7;
  animation: ndsp-in .18s ease-out;
}
@keyframes ndsp-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.nsp-title { color: var(--p-base); font-weight: 600; font-size: .85rem; margin-bottom: .5rem; }
.nsp-tbl { width: 100%; border-collapse: collapse; font-size: .78rem; font-family: 'Menlo','Consolas',monospace; }
.nsp-tbl th { text-align: left; color: #94a3b8; font-weight: 600; padding: .2rem .35rem; border-bottom: 1px solid rgba(255,255,255,.1); font-size: .68rem; text-transform: uppercase; letter-spacing: .04em; }
.nsp-tbl td { padding: .25rem .35rem; border-bottom: 1px solid rgba(255,255,255,.04); color: #d4d4d8; }
.nsp-tbl td.nsp-delta { color: var(--p-light); text-align: right; font-weight: 600; }
.nsp-tbl td.nsp-total { color: var(--p-base); text-align: right; font-weight: 700; }
.nsp-final { margin-top: .55rem; padding-top: .45rem; border-top: 1px solid rgba(var(--p-base-rgb), .25); font-size: .82rem; }
.nd-h-meta { display: flex; gap: .55rem; align-items: center; flex-wrap: wrap; font-family: 'Menlo','Consolas',monospace; font-size: .73rem; color: #94a3b8; }
.nd-h-meta .nd-h-vlan { padding: .12rem .45rem; border-radius: 3px; border: 1px solid; font-weight: 600; }
.nd-h-meta .nd-h-vlan.v0 { color: #c084fc; border-color: #c084fc; }
.nd-h-meta .nd-h-vlan.v1 { color: var(--v1); border-color: var(--v1); }
.nd-h-meta .nd-h-vlan.v2 { color: var(--v2); border-color: var(--v2); }
.nd-h-meta .nd-h-vlan.v3 { color: var(--v3); border-color: var(--v3); }
.nd-h-meta .nd-h-vlan.v4 { color: var(--v4); border-color: var(--v4); }
.nd-h-meta .nd-h-vlan.v5 { color: var(--v5); border-color: var(--v5); }
.nd-h-meta .nd-h-vlan.v6 { color: var(--v6); border-color: var(--v6); }
.nd-h-meta .nd-h-type { color: var(--p-light); }
.nd-h-meta .nd-h-ip   { color: #d4d4d8; }
.nd-h-meta .nd-h-ssh  { padding: .1rem .4rem; border-radius: 3px; border: 1px solid; font-size: .65rem; font-weight: 600; }
.nd-h-meta .nd-h-ssh.active { color: var(--p-base); border-color: var(--p-base); background: rgba(var(--p-base-rgb), .1); }
.nd-h-meta .nd-h-ssh.had    { color: #fb923c; border-color: #fb923c; }
.nd-h-meta .nd-h-ssh.never  { color: #64748b; border-color: #64748b; }

/* Score gauge à droite du header */
.nd-score {
  flex-shrink: 0;
  display: flex; flex-direction: column; align-items: center; gap: .15rem;
  padding: .4rem .7rem;
  border-radius: 8px;
  border: 1px solid;
}
.nd-score .nd-score-num { font-size: 1.5rem; font-weight: 700; line-height: 1; font-family: 'Menlo','Consolas',monospace; }
.nd-score .nd-score-lbl { font-size: .6rem; text-transform: uppercase; letter-spacing: .08em; color: #94a3b8; }
.nd-score.s-excellent { color: var(--v4); border-color: var(--v4); background: rgba(var(--v4-rgb), .08); }
.nd-score.s-good      { color: #84cc16; border-color: #84cc16; background: rgba(132, 204, 22, .08); }
.nd-score.s-medium    { color: #eab308; border-color: #eab308; background: rgba(234, 179, 8, .08); }
.nd-score.s-poor      { color: #fb923c; border-color: #fb923c; background: rgba(251, 146, 60, .08); }
.nd-score.s-bad       { color: var(--v2); border-color: var(--v2); background: rgba(var(--v2-rgb), .08); }
.nd-score.s-unknown   { color: #64748b; border-color: #64748b; background: rgba(100, 116, 139, .08); }

.nd-h-actions { display: flex; gap: .4rem; flex-wrap: wrap; }
.nd-h-actions .t-btn {
  background: rgba(39, 39, 42, .5); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1); border-radius: 5px;
  padding: .35rem .7rem; font-size: .78rem; cursor: pointer;
}
.nd-h-actions .t-btn:hover:not(:disabled) { background: rgba(63, 63, 70, .65); border-color: rgba(var(--p-base-rgb), .3); }
.nd-h-actions .t-btn:disabled { opacity: .4; cursor: not-allowed; }
.nd-h-actions .t-btn.primary {
  background: linear-gradient(135deg, rgba(var(--p-base-rgb), .85), rgba(var(--p-glow-rgb), .75));
  color: var(--p-text-on); border-color: rgba(var(--p-soft-rgb), .8); font-weight: 600;
  box-shadow: 0 0 12px rgba(var(--p-glow-rgb), .3);
}
.nd-h-actions .t-btn.primary:hover:not(:disabled) { box-shadow: 0 0 18px rgba(var(--p-glow-rgb), .5); }
.nd-h-actions .t-btn.danger { color: #fecaca; border-color: rgba(var(--v2-rgb), .4); }
.nd-h-actions .t-btn.is-off {
  opacity: .35; cursor: not-allowed;
  background: rgba(39, 39, 42, .25);
  border-style: dashed;
}

/* Dropdown rescan */
.nd-rescan-menu { position: relative; display: inline-block; }
.nd-rescan-menu summary { list-style: none; }
.nd-rescan-menu summary::-webkit-details-marker { display: none; }
.nd-rescan-menu summary {
  display: inline-flex; align-items: center; gap: .25rem;
  background: rgba(39, 39, 42, .5); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1); border-radius: 5px;
  padding: .35rem .7rem; font-size: .78rem; cursor: pointer;
  transition: background .12s, border-color .12s;
}
.nd-rescan-menu summary:hover { background: rgba(63, 63, 70, .65); border-color: rgba(var(--p-base-rgb), .3); }
.nd-rescan-menu .nd-rescan-popup {
  position: absolute; top: 100%; left: 0; margin-top: .25rem; z-index: 100;
  min-width: 280px;
  background: rgba(24, 24, 27, .95);
  border: 1px solid rgba(var(--p-base-rgb), .35);
  border-radius: 6px;
  backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 10px 30px rgba(0, 0, 0, .5);
  padding: .3rem; display: flex; flex-direction: column; gap: .2rem;
}
.nd-rescan-menu .rescan-opt {
  display: flex; flex-direction: column; gap: .15rem;
  text-align: left;
  background: transparent; color: #e4e4e7;
  border: 1px solid transparent; border-radius: 4px;
  padding: .45rem .6rem; cursor: pointer;
  font-size: .78rem;
  transition: background .12s, border-color .12s;
}
.nd-rescan-menu .rescan-opt:hover:not(:disabled) {
  background: rgba(var(--p-base-rgb), .1);
  border-color: rgba(var(--p-base-rgb), .35);
}
.nd-rescan-menu .rescan-opt:disabled { opacity: .4; cursor: not-allowed; }
.nd-rescan-menu .rescan-opt .ro-title { font-weight: 600; color: var(--p-base); font-size: .82rem; }
.nd-rescan-menu .rescan-opt .ro-desc { color: #94a3b8; font-size: .68rem; }

/* Danger zone (Archive + Delete en bas du panel) */
/* Actions dangereuses / avancées — chrome .card-pri avec couleur alarm (ref Vincent 2026-04-29) */
.nd-danger-zone {
  --card-rgb: var(--c-state-alarm-rgb);
  padding: .6rem .85rem;
  margin-top: 2rem;
  border-radius: 8px;
  border-top:    1px dashed rgba(var(--card-rgb), .4);
  border-right:  1px dashed rgba(var(--card-rgb), .4);
  border-bottom: 1px dashed rgba(var(--card-rgb), .4);
  border-left:   2px solid rgba(var(--card-rgb), .9);
  background:
    radial-gradient(circle at top right, rgba(var(--card-rgb), .14), transparent 60%),
    linear-gradient(135deg, rgba(var(--card-rgb), .1) 0%, rgba(var(--card-rgb), .03) 50%, rgba(24, 24, 27, .55) 100%);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  box-shadow: inset 8px 0 14px -8px rgba(var(--card-rgb), .55), inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 18px rgba(0, 0, 0, .28);
}
.nd-danger-zone summary {
  cursor: pointer; user-select: none; list-style: none;
  display: flex; align-items: center; gap: .4rem;
}
.nd-danger-zone summary::-webkit-details-marker { display: none; }
.nd-danger-zone summary::before {
  content: '▸'; color: var(--v2); opacity: .7;
  transition: transform .15s;
}
.nd-danger-zone[open] summary::before { transform: rotate(90deg); }
.nd-danger-zone summary h3 { margin: 0; color: #fecaca; font-size: .8rem; }
.nd-danger-body { padding-top: .7rem; display: flex; flex-direction: column; gap: .55rem; }
.nd-danger-row {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: .55rem .7rem;
  background: rgba(0, 0, 0, .2);
  border-radius: 4px;
  border-left: 2px solid rgba(var(--v2-rgb), .35);
}
.nd-danger-row .ndr-info { flex: 1; min-width: 0; font-size: .78rem; color: #d4d4d8; }
.nd-danger-row .ndr-info strong { font-size: .82rem; }
.nd-danger-row .ndr-info span { color: #94a3b8; font-size: .72rem; }
.nd-danger-row .t-btn { flex-shrink: 0; }

/* ===== Face avant ports physiques (switch, router) ===== */
.sw-facade {
  background: linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(24, 24, 27, .25));
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 6px;
  padding: .8rem .9rem;
  display: flex; flex-direction: column; gap: .35rem;
}
.sw-row-label { font-size: .65rem; color: #94a3b8; text-transform: uppercase; letter-spacing: .07em; font-family: 'Menlo','Consolas',monospace; }
/* Grid 24 colonnes (switch) — force 1 ligne quoi qu'il arrive */
.sw-row { display: grid; grid-template-columns: repeat(24, minmax(0, 1fr)); gap: 2px; }
.sw-row.sw-sfp-row { grid-template-columns: repeat(4, minmax(80px, 120px)); justify-content: center; gap: .35rem; }
/* Routeur : 9 ports */
.rt-facade .sw-row { grid-template-columns: repeat(9, minmax(0, 1fr)); gap: 4px; }
.sw-port {
  width: auto; min-width: 0; min-height: 38px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: .15rem .15rem; gap: 1px;
  border-radius: 3px;
  border: 1.5px solid;
  background: rgba(0, 0, 0, .3);
  font-size: .62rem; font-family: 'Menlo','Consolas',monospace;
  cursor: help;
  transition: transform .12s;
  overflow: hidden;
}
.sw-port:hover { transform: scale(1.06); z-index: 5; }
.sw-port .p-num { font-weight: 700; line-height: 1; font-size: .65rem; }
.sw-port .p-dev { font-size: .54rem; opacity: .85; line-height: 1; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rt-facade .sw-port { min-height: 50px; padding: .25rem; }
.rt-facade .sw-port .p-num { font-size: .78rem; }
.rt-facade .sw-port .p-dev { font-size: .62rem; }
.sw-port.off { background: rgba(20, 20, 23, .5); border-color: rgba(100, 116, 139, .3); color: #475569; }
.sw-port.poe::after { content: ''; position: absolute; }
.sw-port.poe { box-shadow: inset 0 -2px 0 rgba(132, 204, 22, .5); }
.sw-port.trunk { background-image: repeating-linear-gradient(45deg, transparent, transparent 4px, rgba(255, 255, 255, .05) 4px, rgba(255, 255, 255, .05) 8px); }
.sw-port.v0 { color: #c084fc; border-color: #c084fc; background: rgba(192, 132, 252, .12); }
.sw-port.v1 { color: var(--v1); border-color: var(--v1); background: rgba(var(--v1-rgb), .12); }
.sw-port.v2 { color: var(--v2); border-color: var(--v2); background: rgba(var(--v2-rgb), .12); }
.sw-port.v3 { color: var(--v3); border-color: var(--v3); background: rgba(var(--v3-rgb), .12); }
.sw-port.v4 { color: var(--v4); border-color: var(--v4); background: rgba(var(--v4-rgb), .12); }
.sw-port.v5 { color: var(--v5); border-color: var(--v5); background: rgba(var(--v5-rgb), .12); }
.sw-port.v6 { color: var(--v6); border-color: var(--v6); background: rgba(var(--v6-rgb), .12); }
.sw-port.vt { color: var(--vt); border-color: var(--vt); background: rgba(var(--vt-rgb), .15); }
.sw-port.sw-sfp { background: rgba(56, 189, 248, .08); color: var(--v3); border-color: var(--v3); border-style: dashed; }
.sw-sfp-row { gap: .35rem; }

.sw-legend {
  margin-top: .6rem;
  display: flex; flex-wrap: wrap; gap: .55rem; align-items: center;
  font-size: .68rem; color: #94a3b8;
}
.sw-legend > span { display: inline-flex; align-items: center; gap: .25rem; }
.sw-legend .lg { display: inline-block; width: 10px; height: 10px; border-radius: 2px; border: 1px solid; }
.sw-legend .lg.v0 { color: #c084fc; background: rgba(192, 132, 252, .25); border-color: #c084fc; }
.sw-legend .lg.v1 { background: rgba(var(--v1-rgb), .25); border-color: var(--v1); }
.sw-legend .lg.v2 { background: rgba(var(--v2-rgb), .25); border-color: var(--v2); }
.sw-legend .lg.v3 { background: rgba(var(--v3-rgb), .25); border-color: var(--v3); }
.sw-legend .lg.v4 { background: rgba(var(--v4-rgb), .25); border-color: var(--v4); }
.sw-legend .lg.v5 { background: rgba(var(--v5-rgb), .25); border-color: var(--v5); }
.sw-legend .lg.v6 { background: rgba(var(--v6-rgb), .25); border-color: var(--v6); }
.sw-legend .lg.vt { background: rgba(var(--vt-rgb), .25); border-color: var(--vt); }
.sw-legend .lg.poe { background: linear-gradient(180deg, transparent 60%, rgba(132, 204, 22, .8)); border-color: rgba(132, 204, 22, .5); }
.sw-legend .lg.off { background: rgba(20, 20, 23, .5); border-color: rgba(100, 116, 139, .3); }

/* ===== Sections ===== */
.nd-section { margin-bottom: 1.4rem; }
.nd-section h3 { margin: 0 0 .5rem; font-size: .8rem; color: var(--p-light); text-transform: uppercase; letter-spacing: .08em; font-weight: 600; }
.nd-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: .3rem .9rem; font-size: .8rem; font-family: 'Menlo','Consolas',monospace; }
.nd-grid > div { padding: .25rem .35rem; }
.nd-grid .k { color: #64748b; }
.nd-grid .v { color: #d4d4d8; }
.nd-grid .v.mono { color: var(--p-light); }

/* ===== Champs expandables (5W) ===== */
.nd-field {
  background: rgba(0, 0, 0, .12);
  border-radius: 4px;
  border: 1px solid transparent;
  transition: border-color .15s, background .15s;
}
.nd-field:hover { border-color: rgba(var(--p-base-rgb), .15); }
.nd-field[open] {
  background: rgba(var(--p-base-rgb), .04);
  border-color: rgba(var(--p-base-rgb), .25);
  grid-column: 1 / -1; /* prend toute la largeur quand ouvert */
}
.nd-field summary {
  cursor: pointer;
  list-style: none;
  padding: .3rem .55rem;
  display: flex; gap: .5rem; align-items: baseline;
  font-family: 'Menlo','Consolas',monospace;
  user-select: none;
}
.nd-field summary::-webkit-details-marker { display: none; }
.nd-field summary::before {
  content: '▸';
  color: var(--p-light); opacity: .6;
  font-size: .75rem;
  transition: transform .15s;
}
.nd-field[open] summary::before { transform: rotate(90deg); }
.nd-field summary:hover { background: rgba(var(--p-base-rgb), .05); border-radius: 4px; }
.nd-field summary .k { flex-shrink: 0; min-width: 110px; }
.nd-field summary .v { flex: 1; word-break: break-all; }

.nd-field-body {
  padding: .55rem .85rem .65rem 1.4rem;
  border-top: 1px dashed rgba(255, 255, 255, .07);
  margin-top: .15rem;
  display: flex; flex-direction: column; gap: .4rem;
  font-family: system-ui, -apple-system, 'Segoe UI', sans-serif;
}
.nd-field-body .ndf-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: .5rem;
  font-size: .8rem;
  line-height: 1.45;
}
.nd-field-body .ndf-w {
  color: var(--p-light);
  font-weight: 600; font-size: .68rem;
  text-transform: uppercase; letter-spacing: .06em;
  padding-top: .12rem;
  font-family: 'Menlo','Consolas',monospace;
}
.nd-field-body .ndf-t { color: #d4d4d8; }
.nd-field-body .ndf-empty { color: #94a3b8; font-style: italic; font-size: .78rem; }
.nd-field-body .ndf-actions {
  display: flex; gap: .4rem; padding-top: .35rem;
  border-top: 1px dashed rgba(255, 255, 255, .05);
  margin-top: .25rem;
}
.nd-field-body .ndf-claude {
  background: rgba(39, 39, 42, .55);
  color: #e4e4e7;
  border: 1px solid rgba(var(--p-base-rgb), .35);
  border-radius: 4px;
  padding: .25rem .55rem;
  font-size: .72rem; cursor: pointer;
  transition: background .12s, box-shadow .12s;
}
.nd-field-body .ndf-claude:hover {
  background: rgba(var(--p-base-rgb), .15);
  box-shadow: 0 0 8px rgba(var(--p-glow-rgb), .3);
}

.nd-monitors { display: grid; grid-template-columns: 1fr; gap: .25rem; font-family: 'Menlo','Consolas',monospace; font-size: .76rem; }
.nd-monitor {
  display: grid; grid-template-columns: 14px auto auto 1fr auto;
  gap: .55rem; padding: .3rem .55rem; border-radius: 4px;
  background: rgba(0, 0, 0, .15);
  border-left: 2px solid transparent;
  align-items: center;
}
.nd-monitor.s-ok   { border-left-color: var(--v4); }
.nd-monitor.s-warn { border-left-color: #fb923c; }
.nd-monitor.s-crit { border-left-color: var(--v2); }
.nd-monitor .m-bullet { width: 10px; height: 10px; border-radius: 50%; }
.nd-monitor.s-ok   .m-bullet { background: var(--v4); }
.nd-monitor.s-warn .m-bullet { background: #fb923c; }
.nd-monitor.s-crit .m-bullet { background: var(--v2); }
.nd-monitor .m-ref { color: #64748b; font-size: .68rem; }
.nd-monitor .m-name { color: #e4e4e7; }
.nd-monitor .m-val { color: var(--p-light); text-align: right; }
.nd-monitor .m-cat { color: #94a3b8; font-size: .68rem; padding: .05rem .3rem; border: 1px solid rgba(255,255,255,.08); border-radius: 3px; }

.nd-history { display: flex; flex-direction: column; gap: .2rem; font-family: 'Menlo','Consolas',monospace; font-size: .73rem; max-height: 220px; overflow-y: auto; }

/* ===== Audit Claude (persisté) ===== */
/* Audit Claude — chrome .card-pri (sous-card du node, --p-base plein, ref Vincent 2026-04-29) */
.nd-claude-audit {
  --card-rgb: var(--p-base-rgb);
  display: flex; flex-direction: column; gap: .55rem;
  padding: .8rem 1rem;
  border-radius: 8px;
  border-top:    1px solid rgba(var(--card-rgb), .4);
  border-right:  1px solid rgba(var(--card-rgb), .4);
  border-bottom: 1px solid rgba(var(--card-rgb), .4);
  border-left:   2px solid rgba(var(--card-rgb), .9);
  background:
    radial-gradient(circle at top right, rgba(var(--card-rgb), .14), transparent 60%),
    linear-gradient(135deg, rgba(var(--card-rgb), .1) 0%, rgba(var(--card-rgb), .03) 50%, rgba(24, 24, 27, .55) 100%);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  box-shadow: inset 8px 0 14px -8px rgba(var(--card-rgb), .55), inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 18px rgba(0, 0, 0, .28);
}
.nd-claude-audit.empty p { margin: .15rem 0; }
.nca-head { display: flex; gap: .8rem; align-items: center; padding: .35rem .5rem; }
.nca-score {
  font-family: 'Menlo','Consolas',monospace; font-weight: 700;
  padding: .25rem .55rem; border-radius: 4px; border: 1px solid;
  font-size: .9rem; min-width: 75px; text-align: center;
}
.nca-score.score-excellent { color: var(--v4); border-color: var(--v4); background: rgba(var(--v4-rgb), .1); }
.nca-score.score-good      { color: #84cc16; border-color: #84cc16; background: rgba(132, 204, 22, .1); }
.nca-score.score-medium    { color: #eab308; border-color: #eab308; background: rgba(234, 179, 8, .1); }
.nca-score.score-poor      { color: #fb923c; border-color: #fb923c; background: rgba(251, 146, 60, .1); }
.nca-score.score-bad       { color: var(--v2); border-color: var(--v2); background: rgba(var(--v2-rgb), .1); }
.nca-meta { color: #94a3b8; font-size: .72rem; font-family: 'Menlo','Consolas',monospace; }
/* nca-summary : texte de synthèse Claude — sub-element à l'intérieur de .nd-claude-audit
   (pas une card autonome). Background/border retirés pour ne pas polluer le chrome parent. */
.nca-summary { color: #d4d4d8; font-size: .9rem; line-height: 1.55; padding: .5rem .25rem; }
.nca-axe { margin-top: .65rem; }
.nca-axe-h { margin: 0 0 .3rem; font-size: .85rem; color: var(--p-light); font-weight: 600; }
.nca-axe-h .nca-axe-count { font-size: .65rem; color: #64748b; font-weight: normal; padding: .05rem .35rem; border: 1px solid #64748b; border-radius: 3px; margin-left: .35rem; }

/* Finding (expandable) — chrome .card-pri (ref Vincent 2026-04-29).
   Sous-cards de l'audit interne, couleur par level (f-critical/f-high/f-medium/f-low). */
.nd-finding {
  --card-rgb: var(--v3-rgb);   /* fallback = info cyan */
  border-radius: 8px;
  margin-bottom: .35rem;
  border-top:    1px solid rgba(var(--card-rgb), .4);
  border-right:  1px solid rgba(var(--card-rgb), .4);
  border-bottom: 1px solid rgba(var(--card-rgb), .4);
  border-left:   2px solid rgba(var(--card-rgb), .9);
  background:
    radial-gradient(circle at top right, rgba(var(--card-rgb), .14), transparent 60%),
    linear-gradient(135deg, rgba(var(--card-rgb), .1) 0%, rgba(var(--card-rgb), .03) 50%, rgba(24, 24, 27, .55) 100%);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  box-shadow: inset 8px 0 14px -8px rgba(var(--card-rgb), .55), inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 18px rgba(0, 0, 0, .28);
  transition: opacity .2s, border-color .2s, box-shadow .2s;
}
.nd-finding.f-critical { --card-rgb: var(--c-state-critical-rgb); animation: state-critical-blink 1s steps(2, start) infinite; }
.nd-finding.f-high     { --card-rgb: var(--c-state-alert-rgb); }
.nd-finding.f-medium   { --card-rgb: 234, 179, 8; }   /* jaune medium */
.nd-finding.f-low      { --card-rgb: var(--v3-rgb); }
.nd-finding[open] {
  border-top-color:    rgba(var(--card-rgb), .65);
  border-right-color:  rgba(var(--card-rgb), .65);
  border-bottom-color: rgba(var(--card-rgb), .65);
  border-left-color:   rgba(var(--card-rgb), 1);
  box-shadow: inset 8px 0 16px -8px rgba(var(--card-rgb), .7), inset 0 1px 0 rgba(255, 255, 255, .1), 0 0 24px rgba(var(--card-rgb), .25), 0 4px 18px rgba(0, 0, 0, .3);
}
.nd-finding summary {
  cursor: pointer; user-select: none; list-style: none;
  display: flex; gap: .55rem; align-items: center;
  padding: .5rem .7rem; padding-right: 1.6rem;
  position: relative;
}
.nd-finding summary::-webkit-details-marker { display: none; }
.nd-finding summary::after { content: '▸'; position: absolute; right: .65rem; top: .55rem; color: var(--p-light); opacity: .5; transition: transform .15s; }
.nd-finding[open] summary::after { transform: rotate(90deg); }
.nd-finding summary:hover { background: rgba(var(--p-base-rgb), .04); border-radius: 4px; }
.nd-finding .nf-level {
  font-size: .62rem; font-family: 'Menlo','Consolas',monospace; font-weight: 700;
  padding: .1rem .4rem; border-radius: 3px;
  letter-spacing: .04em; flex-shrink: 0; min-width: 56px; text-align: center;
}
.nd-finding.f-critical .nf-level { color: var(--v2); border: 1px solid var(--v2); background: rgba(var(--v2-rgb), .12); }
.nd-finding.f-high     .nf-level { color: #fb923c; border: 1px solid #fb923c; background: rgba(251, 146, 60, .12); }
.nd-finding.f-medium   .nf-level { color: #eab308; border: 1px solid #eab308; background: rgba(234, 179, 8, .12); }
.nd-finding.f-low      .nf-level { color: var(--v3); border: 1px solid var(--v3); background: rgba(var(--v3-rgb), .12); }
.nd-finding .nf-title { color: #e4e4e7; font-weight: 600; font-size: .85rem; flex: 1; }
.nf-body { padding: .55rem .85rem .65rem 1.6rem; border-top: 1px dashed rgba(255,255,255,.07); margin-top: .15rem; display: flex; flex-direction: column; gap: .5rem; }
.nf-row { display: grid; grid-template-columns: 80px 1fr; gap: .5rem; font-size: .8rem; line-height: 1.5; }
.nf-w { color: var(--p-light); font-weight: 600; font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; padding-top: .12rem; font-family: 'Menlo','Consolas',monospace; }
.nf-t { color: #d4d4d8; }
.nf-actions-wrap { display: flex; flex-direction: column; gap: .35rem; }
.nf-action {
  background: rgba(0, 0, 0, .25);
  border-radius: 4px;
  padding: .4rem .55rem;
  border: 1px solid rgba(255, 255, 255, .05);
}
.nf-act-head { display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; margin-bottom: .25rem; }
.nf-act-label { color: #e4e4e7; font-size: .82rem; font-weight: 500; flex: 1; }
.nf-act-risk {
  font-size: .6rem; padding: .05rem .35rem; border-radius: 3px;
  text-transform: uppercase; letter-spacing: .04em; font-weight: 600;
  font-family: 'Menlo','Consolas',monospace;
}
.nf-act-risk.r-safe        { color: var(--v4); border: 1px solid var(--v4); background: rgba(var(--v4-rgb), .1); }
.nf-act-risk.r-medium      { color: #fb923c; border: 1px solid #fb923c; background: rgba(251, 146, 60, .12); }
.nf-act-risk.r-destructive { color: var(--v2); border: 1px solid var(--v2); background: rgba(var(--v2-rgb), .12); }
.nf-act-rev { color: #94a3b8; font-size: .65rem; font-family: 'Menlo','Consolas',monospace; }
.nf-act-cmd {
  margin: .15rem 0 0; padding: .4rem .55rem;
  background: rgba(0, 0, 0, .4); border: 1px solid rgba(255, 255, 255, .06);
  color: #cbd5e1; font-family: 'Menlo','Consolas',monospace; font-size: .76rem;
  border-radius: 3px; white-space: pre-wrap; word-break: break-all;
}
.nf-todo-flag { color: var(--p-base); font-size: .75rem; font-style: italic; padding-top: .25rem; }

/* Bouton Exécuter inline dans une action */
.nf-act-exec {
  background: linear-gradient(135deg, rgba(var(--p-base-rgb), .8), rgba(var(--p-glow-rgb), .65));
  color: var(--p-text-on); border: 1px solid rgba(var(--p-soft-rgb), .8);
  border-radius: 4px; padding: .15rem .55rem;
  font-size: .7rem; font-weight: 600; cursor: pointer; flex-shrink: 0;
  margin-left: auto;
}
.nf-act-exec:hover:not(:disabled) { box-shadow: 0 0 8px rgba(var(--p-glow-rgb), .5); }
.nf-act-exec:disabled { opacity: .5; cursor: not-allowed; }

/* Badge dernier statut d'exec sur une action */
.nf-act-laststatus {
  font-size: .6rem; padding: .05rem .35rem; border-radius: 3px;
  font-family: 'Menlo','Consolas',monospace; font-weight: 600;
  letter-spacing: .03em; text-transform: uppercase;
}
.nf-act-laststatus.s-ok      { color: var(--v4); border: 1px solid var(--v4); background: rgba(var(--v4-rgb), .1); }
.nf-act-laststatus.s-error   { color: var(--v2); border: 1px solid var(--v2); background: rgba(var(--v2-rgb), .12); }
.nf-act-laststatus.s-timeout { color: #fb923c; border: 1px solid #fb923c; background: rgba(251, 146, 60, .12); }

/* Sortie du dernier exec (collapsable) */
.nf-exec-output { margin-top: .35rem; }
.nf-exec-output summary { cursor: pointer; color: var(--p-light); font-size: .72rem; padding: .15rem 0; user-select: none; }
.nf-exec-output summary::-webkit-details-marker { color: var(--p-base); }
.nf-exec-output pre {
  margin: .2rem 0 0; padding: .4rem .55rem;
  background: rgba(0, 0, 0, .45);
  border: 1px solid rgba(255, 255, 255, .06);
  color: #cbd5e1; font-family: 'Menlo','Consolas',monospace; font-size: .72rem;
  border-radius: 3px; max-height: 220px; overflow: auto; white-space: pre-wrap; word-break: break-all;
}

/* Bouton Accepter / Retirer acceptation */
.nf-state-actions {
  margin-top: .6rem; padding-top: .5rem;
  border-top: 1px dashed rgba(255, 255, 255, .07);
  display: flex; justify-content: flex-end;
}
.nf-state-actions .nf-accept,
.nf-state-actions .nf-unaccept {
  background: rgba(39, 39, 42, .55); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1); border-radius: 4px;
  padding: .25rem .65rem; font-size: .75rem; cursor: pointer;
}
.nf-state-actions .nf-accept:hover { background: rgba(var(--v4-rgb), .15); border-color: var(--v4); color: var(--v4); }
.nf-state-actions .nf-unaccept:hover { background: rgba(var(--v2-rgb), .12); border-color: var(--v2); color: #fecaca; }

/* Finding accepté : style atténué + badge */
.nd-finding.is-accepted { opacity: .55; background: rgba(var(--v4-rgb), .03); }
.nd-finding.is-accepted summary:hover { opacity: .85; }
.nf-accepted-badge {
  font-size: .6rem; padding: .1rem .4rem; border-radius: 3px;
  color: var(--v4); border: 1px solid var(--v4); background: rgba(var(--v4-rgb), .1);
  font-family: 'Menlo','Consolas',monospace; font-weight: 700; letter-spacing: .04em;
  margin-left: auto;
}

/* ===== Mini chat node sous l'entête ===== */
.nd-chat {
  margin-bottom: 1.2rem;
  background: rgba(0, 0, 0, .15);
  border: 1px solid rgba(var(--p-base-rgb), .15);
  border-radius: 6px;
}
.nd-chat summary {
  cursor: pointer; user-select: none; list-style: none;
  padding: .5rem .8rem;
  display: flex; align-items: center; gap: .5rem;
  font-size: .82rem; color: var(--p-light); font-weight: 600;
}
.nd-chat summary::-webkit-details-marker { display: none; }
.nd-chat summary::before { content: '▸'; opacity: .6; transition: transform .15s; }
.nd-chat[open] summary::before { transform: rotate(90deg); }
.nd-chat summary:hover { background: rgba(var(--p-base-rgb), .04); }
.nd-chat .nc-meta { margin-left: auto; color: #64748b; font-size: .68rem; font-weight: normal; font-family: 'Menlo','Consolas',monospace; }
.nd-chat-body { padding: .6rem .8rem .7rem; border-top: 1px dashed rgba(255,255,255,.07); }
.nd-chat-msgs {
  max-height: 280px; overflow-y: auto;
  display: flex; flex-direction: column; gap: .35rem;
  margin-bottom: .55rem;
  padding: .35rem .15rem;
}
.nd-chat-msgs:empty::before { content: 'Pose une question sur ce node — Claude voit le contexte (IP, VLAN, type, score, monitors)…'; color: #64748b; font-style: italic; font-size: .8rem; }
.nc-msg { padding: .4rem .6rem; border-radius: 5px; font-size: .82rem; line-height: 1.45; max-width: 85%; }
.nc-msg.user      { align-self: flex-end; background: rgba(var(--p-base-rgb), .15); color: #e4e4e7; border: 1px solid rgba(var(--p-base-rgb), .35); }
.nc-msg.claude    { align-self: flex-start; background: rgba(0, 0, 0, .35); color: #cbd5e1; border: 1px solid rgba(255, 255, 255, .08); white-space: pre-wrap; }
.nc-msg.pending   { color: #94a3b8; font-style: italic; }
.nc-msg.error     { background: rgba(var(--v2-rgb), .1); border-color: var(--v2); color: #fecaca; }
.nd-chat-form { display: flex; gap: .4rem; align-items: flex-end; }
.nd-chat-form textarea {
  flex: 1; resize: vertical; min-height: 36px; max-height: 120px;
  background: rgba(39, 39, 42, .55); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1); border-radius: 4px;
  padding: .35rem .55rem; font-size: .82rem; font-family: inherit; line-height: 1.4;
}
.nd-chat-form textarea:focus { outline: none; border-color: var(--p-base); box-shadow: 0 0 0 2px rgba(var(--p-base-rgb), .18); }
.nd-chat-form button {
  background: linear-gradient(135deg, rgba(var(--p-base-rgb), .85), rgba(var(--p-glow-rgb), .75));
  color: var(--p-text-on); border: 1px solid rgba(var(--p-soft-rgb), .8);
  border-radius: 4px; padding: .35rem .9rem; font-size: .82rem; font-weight: 600; cursor: pointer;
  flex-shrink: 0;
}
.nd-chat-form button:hover:not(:disabled) { box-shadow: 0 0 12px rgba(var(--p-glow-rgb), .4); }
.nd-chat-form button:disabled { opacity: .5; cursor: not-allowed; }
.nd-chat-clear { background: transparent; border: none; color: #64748b; font-size: .72rem; cursor: pointer; padding: 0; margin-top: .35rem; }
.nd-chat-clear:hover { color: var(--v2); }

/* ===== KPI badges (header) ===== */
.nd-kpis { display: flex; gap: .3rem; flex-wrap: wrap; align-items: center; flex-shrink: 0; }
.nd-kpis .kpi-badge {
  font-size: .65rem; font-weight: 700; font-family: 'Menlo','Consolas',monospace;
  padding: .15rem .45rem; border-radius: 3px; border: 1px solid;
  text-transform: uppercase; letter-spacing: .04em;
  min-width: 50px; text-align: center;
}
.nd-kpis .kpi-badge.critical { color: var(--v2); border-color: var(--v2); background: rgba(var(--v2-rgb), .12); }
.nd-kpis .kpi-badge.warning  { color: #fb923c; border-color: #fb923c; background: rgba(251, 146, 60, .12); }
.nd-kpis .kpi-badge.ok       { color: var(--v4); border-color: var(--v4); background: rgba(var(--v4-rgb), .1); }
.nd-kpis .kpi-badge.info     { color: var(--v3); border-color: var(--v3); background: rgba(var(--v3-rgb), .1); }
.nd-kpis .kpi-badge.recos    { color: var(--p-light); border-color: rgba(var(--p-light-rgb), .5); background: rgba(var(--p-base-rgb), .06); }

/* ===== Audits (checks) ===== */
.nd-checks { display: flex; flex-direction: column; gap: .5rem; }
/* Audits internes — chrome .card-pri (ref Vincent 2026-04-29).
   Couleur par status, c-critical clignote (déclenché). LED bullet supprimée. */
.nd-check {
  --card-rgb: var(--v3-rgb);   /* fallback = cyan info */
  border-radius: 8px;
  border-top:    1px solid rgba(var(--card-rgb), .4);
  border-right:  1px solid rgba(var(--card-rgb), .4);
  border-bottom: 1px solid rgba(var(--card-rgb), .4);
  border-left:   2px solid rgba(var(--card-rgb), .9);
  background:
    radial-gradient(circle at top right, rgba(var(--card-rgb), .14), transparent 60%),
    linear-gradient(135deg, rgba(var(--card-rgb), .1) 0%, rgba(var(--card-rgb), .03) 50%, rgba(24, 24, 27, .55) 100%);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  box-shadow: inset 8px 0 14px -8px rgba(var(--card-rgb), .55), inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 18px rgba(0, 0, 0, .28);
  transition: opacity .2s, border-color .2s, box-shadow .2s;
}
.nd-check.c-ok       { --card-rgb: var(--c-state-notif-rgb); }
.nd-check.c-warning  { --card-rgb: var(--c-state-alert-rgb); }
.nd-check.c-critical { --card-rgb: var(--c-state-critical-rgb); animation: state-critical-blink 1s steps(2, start) infinite; }
.nd-check.c-info     { --card-rgb: var(--v3-rgb); }
.nd-check[open] {
  border-top-color:    rgba(var(--card-rgb), .65);
  border-right-color:  rgba(var(--card-rgb), .65);
  border-bottom-color: rgba(var(--card-rgb), .65);
  border-left-color:   rgba(var(--card-rgb), 1);
  box-shadow: inset 8px 0 16px -8px rgba(var(--card-rgb), .7), inset 0 1px 0 rgba(255, 255, 255, .1), 0 0 24px rgba(var(--card-rgb), .25), 0 4px 18px rgba(0, 0, 0, .3);
}
.nd-check summary {
  display: block;
  padding: .65rem .85rem;
  cursor: pointer; user-select: none; list-style: none;
  position: relative;
}
.nd-check summary::-webkit-details-marker { display: none; }
.nd-check summary::after {
  content: '▸';
  position: absolute; right: .8rem; top: .75rem;
  color: var(--p-light); opacity: .5;
  transition: transform .15s;
}
.nd-check[open] summary::after { transform: rotate(90deg); }
/* LED .ck-bullet supprimée — la couleur de carte + clignotement la remplacent (ref Vincent 2026-04-29) */
.nd-check .ck-bullet { display: none; }
.nd-check .ck-status { color: rgb(var(--card-rgb)); }   /* badge "OK/WARNING/CRITICAL" hérite la couleur card */
.nd-check .ck-body { display: flex; flex-direction: column; gap: .2rem; min-width: 0; }
.nd-check .ck-head { display: flex; gap: .5rem; align-items: baseline; justify-content: space-between; }
.nd-check .ck-label { color: #e4e4e7; font-weight: 600; font-size: .85rem; }
.nd-check .ck-status { font-family: 'Menlo','Consolas',monospace; font-size: .65rem; font-weight: 700; letter-spacing: .04em; }
.nd-check.c-ok       .ck-status { color: var(--v4); }
.nd-check.c-warning  .ck-status { color: #fb923c; }
.nd-check.c-critical .ck-status { color: var(--v2); }
.nd-check.c-info     .ck-status { color: var(--v3); }
.nd-check .ck-desc { color: #d4d4d8; font-size: .8rem; line-height: 1.45; }
.nd-check .ck-evidence { color: #94a3b8; font-size: .72rem; font-family: 'Menlo','Consolas',monospace; margin-top: .15rem; }

/* Détail expandé des checks */
.ck-detail {
  padding: .6rem .85rem .65rem 2.05rem;
  border-top: 1px dashed rgba(255, 255, 255, .07);
  margin-top: .15rem;
}
.ck-detail-grid { display: flex; flex-direction: column; gap: .35rem; margin-bottom: .6rem; }
.ck-detail-grid .ckd-row { display: grid; grid-template-columns: 80px 1fr; gap: .5rem; font-size: .8rem; line-height: 1.45; }
.ck-detail-grid .ckd-w { color: var(--p-light); font-weight: 600; font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; padding-top: .12rem; font-family: 'Menlo','Consolas',monospace; }
.ck-detail-grid .ckd-t { color: #d4d4d8; }
.ck-detail-grid .ckd-t.mono { font-family: 'Menlo','Consolas',monospace; font-size: .76rem; color: #94a3b8; }
.ck-detail-actions { display: flex; gap: .4rem; padding-top: .35rem; border-top: 1px dashed rgba(255, 255, 255, .05); }
.ck-detail-actions .ck-claude {
  background: rgba(39, 39, 42, .55); color: #e4e4e7;
  border: 1px solid rgba(var(--p-base-rgb), .35);
  border-radius: 4px; padding: .3rem .65rem;
  font-size: .76rem; cursor: pointer;
  transition: background .12s, box-shadow .12s;
}
.ck-detail-actions .ck-claude:hover { background: rgba(var(--p-base-rgb), .15); box-shadow: 0 0 8px rgba(var(--p-glow-rgb), .3); }

/* ===== Recommandations (expandable + textarea + Faire faire à Claude) ===== */
.nd-recos { display: flex; flex-direction: column; gap: .5rem; }
/* Recommandations Claude — chrome .card-pri (ref Vincent 2026-04-29).
   Couleur par priorité : critical rouge clignotant / warning orange / info cyan */
.nd-reco {
  --card-rgb: var(--v3-rgb);   /* fallback = cyan info */
  border-radius: 8px;
  border-top:    1px solid rgba(var(--card-rgb), .4);
  border-right:  1px solid rgba(var(--card-rgb), .4);
  border-bottom: 1px solid rgba(var(--card-rgb), .4);
  border-left:   2px solid rgba(var(--card-rgb), .9);
  background:
    radial-gradient(circle at top right, rgba(var(--card-rgb), .14), transparent 60%),
    linear-gradient(135deg, rgba(var(--card-rgb), .1) 0%, rgba(var(--card-rgb), .03) 50%, rgba(24, 24, 27, .55) 100%);
  backdrop-filter: blur(28px) saturate(200%);
  -webkit-backdrop-filter: blur(28px) saturate(200%);
  box-shadow: inset 8px 0 14px -8px rgba(var(--card-rgb), .55), inset 0 1px 0 rgba(255, 255, 255, .08), 0 4px 18px rgba(0, 0, 0, .28);
  transition: opacity .2s, border-color .2s, box-shadow .2s;
}
.nd-reco.r-critical { --card-rgb: var(--c-state-critical-rgb); animation: state-critical-blink 1s steps(2, start) infinite; }
.nd-reco.r-warning  { --card-rgb: var(--c-state-alert-rgb);    }
.nd-reco.r-info     { --card-rgb: var(--v3-rgb);               }
.nd-reco[open] {
  border-top-color:    rgba(var(--card-rgb), .65);
  border-right-color:  rgba(var(--card-rgb), .65);
  border-bottom-color: rgba(var(--card-rgb), .65);
  border-left-color:   rgba(var(--card-rgb), 1);
  box-shadow: inset 8px 0 16px -8px rgba(var(--card-rgb), .7), inset 0 1px 0 rgba(255, 255, 255, .1), 0 0 24px rgba(var(--card-rgb), .25), 0 4px 18px rgba(0, 0, 0, .3);
}
.nd-reco summary {
  cursor: pointer; user-select: none; list-style: none;
  padding: .6rem .85rem; padding-right: 2rem;
  position: relative;
}
.nd-reco summary::-webkit-details-marker { display: none; }
.nd-reco summary::after {
  content: '▸';
  position: absolute; right: .8rem; top: .7rem;
  color: var(--p-light); opacity: .5;
  transition: transform .15s;
}
.nd-reco[open] summary::after { transform: rotate(90deg); }
.nd-reco summary:hover { background: rgba(var(--p-base-rgb), .04); border-radius: 4px; }
.nd-reco .rc-head { display: flex; gap: .55rem; align-items: center; margin-bottom: .25rem; }
.nd-reco .rc-prio {
  font-size: .62rem; font-family: 'Menlo','Consolas',monospace; font-weight: 700;
  padding: .1rem .4rem; border-radius: 3px; letter-spacing: .04em;
}
.nd-reco.r-critical .rc-prio { color: var(--v2); border: 1px solid var(--v2); background: rgba(var(--v2-rgb), .12); }
.nd-reco.r-warning  .rc-prio { color: #fb923c; border: 1px solid #fb923c; background: rgba(251, 146, 60, .12); }
.nd-reco.r-info     .rc-prio { color: var(--v3); border: 1px solid var(--v3); background: rgba(var(--v3-rgb), .1); }
.nd-reco .rc-title { color: #e4e4e7; font-weight: 600; font-size: .87rem; flex: 1; }
.nd-reco .rc-desc { color: #d4d4d8; font-size: .78rem; line-height: 1.45; }

/* Détail expandé d'une reco */
.rc-detail {
  padding: .6rem .85rem .7rem;
  border-top: 1px dashed rgba(255, 255, 255, .07);
  margin: .15rem .35rem 0;
}
.rc-detail .rcd-row { display: grid; grid-template-columns: 80px 1fr; gap: .5rem; font-size: .8rem; line-height: 1.45; margin-bottom: .55rem; }
.rc-detail .rcd-w { color: var(--p-light); font-weight: 600; font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; padding-top: .12rem; font-family: 'Menlo','Consolas',monospace; }
.rc-detail .rcd-t { color: #d4d4d8; }
.rc-detail .rcd-extra-label {
  display: block; color: #94a3b8; font-size: .7rem;
  text-transform: uppercase; letter-spacing: .04em;
  margin: .35rem 0 .25rem;
  font-family: 'Menlo','Consolas',monospace;
}
.rc-detail textarea.rc-extra {
  width: 100%; box-sizing: border-box;
  background: rgba(39, 39, 42, .55); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 5px;
  padding: .35rem .55rem;
  font-size: .8rem; font-family: inherit; line-height: 1.45;
  resize: vertical; min-height: 50px;
}
.rc-detail textarea.rc-extra:focus { outline: none; border-color: var(--p-base); box-shadow: 0 0 0 2px rgba(var(--p-base-rgb), .18); }
.rc-detail-actions {
  display: flex; gap: .4rem; flex-wrap: wrap;
  padding-top: .55rem; margin-top: .45rem;
  border-top: 1px dashed rgba(255, 255, 255, .06);
}
.rc-detail-actions .t-btn {
  background: rgba(39, 39, 42, .55); color: #e4e4e7;
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 4px; padding: .35rem .7rem;
  font-size: .76rem; cursor: pointer;
  transition: background .12s, box-shadow .12s;
}
.rc-detail-actions .t-btn:hover { background: rgba(63, 63, 70, .65); border-color: rgba(var(--p-base-rgb), .3); }
.rc-detail-actions .t-btn.primary {
  background: linear-gradient(135deg, rgba(var(--p-base-rgb), .85), rgba(var(--p-glow-rgb), .75));
  color: var(--p-text-on); border-color: rgba(var(--p-soft-rgb), .8); font-weight: 600;
  box-shadow: 0 0 12px rgba(var(--p-glow-rgb), .3);
}
.rc-detail-actions .t-btn.primary:hover { box-shadow: 0 0 18px rgba(var(--p-glow-rgb), .5); }
.nd-history .ev { display: grid; grid-template-columns: auto auto 1fr; gap: .5rem; padding: .15rem .4rem; border-left: 2px solid rgba(255,255,255,.08); }
.nd-history .ev .ev-ts { color: #64748b; }
.nd-history .ev .ev-tag { color: var(--p-light); font-size: .66rem; padding: 0 .3rem; border: 1px solid rgba(255,255,255,.1); border-radius: 3px; }
.nd-history .ev .ev-msg { color: #d4d4d8; }

/* ===== A3a Responsive Mobile (ciblé chirurgical) =====
   Le seul point cassé sur mobile = le header de la fiche node (.nd-h-top) qui force
   le titre à wrap en colonne ultra-étroite. On le passe en flex-wrap + titre full-width. */
@media (max-width: 768px) {
  .nodes-toolbar { flex-wrap: wrap !important; }

  /* Header fiche : titre sur sa propre ligne pleine largeur + score/icones dessous */
  .nd-h-top {
    flex-wrap: wrap !important;
    align-items: flex-start !important;
  }
  .nd-h-info {
    flex: 1 1 100% !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .nd-h-name {
    font-size: 1.25rem !important;
    flex-wrap: wrap;
    line-height: 1.2;
  }
  .nd-score { margin-left: auto !important; }
  .nd-score .nd-score-num { font-size: 1.4rem; }
}

/* ============================================================================
   STANDARD TOOLBAR — uniforme reference Biometrie sante (Vincent 2026-05-10)
   Principle DB #102 — zone figee + controls coherents inter-tabs et inter-VMs.
   ============================================================================ */
.nodes-toolbar {
  min-height: 3.15rem !important;
  box-sizing: border-box !important;
}
.nodes-toolbar input[type="search"],
.nodes-toolbar input[type="text"],
.nodes-toolbar input[type="date"],
.nodes-toolbar input[type="number"],
.nodes-toolbar select,
.nodes-toolbar button.t-btn {
  background: rgba(39, 39, 42, .45);
  color: #e2e8f0;
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 6px;
  padding: .22rem .55rem;
  font-size: .82rem;
  font-family: 'Menlo','Consolas',monospace;
  height: 28px;
  box-sizing: border-box;
  line-height: 1.2;
}
.nodes-toolbar button.t-btn:hover:not(:disabled) {
  background: rgba(var(--p-base-rgb), .18);
  color: var(--p-base);
  border-color: rgba(var(--p-base-rgb), .35);
}
.nodes-toolbar label {
  font-size: .82rem;
  color: #d4d4d8;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  line-height: 1.2;
}
