/* 40-cabling.css — the cross-connect bench: two facing rack panels, armable
 * endpoint rows, and the live cable list carrying the 5 install gates.
 */

.cabling-bar {
  display: flex; align-items: flex-end; gap: 14px; flex-wrap: wrap;
  padding: 12px 14px; margin-bottom: 16px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
}
.cabling-bar .field { min-width: 200px; }
.cabling-bar .arm-hint { font-size: 12px; margin-left: auto; align-self: center; }

/* ---- facing panels --------------------------------------------------- */
.facing-panels {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start;
}
.facing-panel {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r); overflow: hidden;
}
.facing-a { border-top: 3px solid var(--accent); }
.facing-b { border-top: 3px solid var(--accent-2); }
.facing-head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 8px;
  padding: 10px 14px; border-bottom: 1px solid var(--line); background: var(--surface-2);
}
.facing-name { font-weight: 700; font-size: 14px; }
.facing-sub { font-size: 12px; }

.ep-list { display: flex; flex-direction: column; padding: 6px; gap: 3px; max-height: 460px; overflow: auto; }
.ep-row {
  display: flex; align-items: center; gap: 9px;
  padding: 7px 10px; border-radius: var(--r-sm);
  border: 1px solid transparent; background: var(--surface-2);
}
.ep-row.clickable { cursor: pointer; }
.ep-row.clickable:hover { border-color: var(--accent); }
.ep-row.occupied { opacity: .6; background: transparent; }
.ep-row.armed {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 20%, var(--surface-2));
  box-shadow: inset 0 0 0 1px var(--accent);
}
.ep-label { font-family: var(--mono); font-size: 12.5px; font-weight: 600; flex: 1; }
.ep-state {
  font-size: 11px; text-transform: uppercase; letter-spacing: .03em;
}
.ep-row.occupied .ep-state { color: var(--ok); }
.ep-row.armed .ep-state { color: var(--accent); }

/* ---- cable list ------------------------------------------------------ */
.cable-list { margin-top: 4px; display: flex; flex-direction: column; }
.cable-row {
  display: grid; gap: 12px; align-items: center;
  grid-template-columns: minmax(160px, 1fr) auto auto;
  padding: 11px 14px; margin-bottom: 8px;
  background: var(--surface); border: 1px solid var(--line);
  border-left: 3px solid var(--ok); border-radius: var(--r);
}
.cable-row.blocked { border-left-color: var(--bad); }
.cable-ends { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cable-pair { font-family: var(--mono); font-size: 13px; font-weight: 600; }
.cable-type { display: flex; align-items: center; gap: 6px; font-size: 12px; }
.cable-gates { display: flex; gap: 5px; flex-wrap: wrap; }
.cable-actions { display: flex; align-items: center; gap: 8px; justify-content: flex-end; }

@media (max-width: 760px) {
  .facing-panels { grid-template-columns: 1fr; }
  .cable-row { grid-template-columns: 1fr; }
  .cable-actions { justify-content: flex-start; }
}
