/* BVK7 forensic repair layer: additive shell only. Station bodies remain sovereign. */
:root {
  --fr-bg: rgba(5, 7, 12, .86);
  --fr-panel: rgba(16, 18, 28, .92);
  --fr-panel-2: rgba(23, 26, 38, .94);
  --fr-line: rgba(255, 255, 255, .11);
  --fr-ink: #f2eee7;
  --fr-muted: #9c968c;
  --fr-good: #46d672;
  --fr-warn: #e8b53a;
}

.gate-card.consoleos-gate {
  width: min(460px, 92vw);
  padding: 30px;
  border-color: color-mix(in srgb, var(--acc) 62%, var(--line2));
  background:
    radial-gradient(circle at 20% 0%, var(--acc-glow), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .012)),
    var(--panel);
}

.fr-gate-status {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 18px 0 16px;
}

.fr-status-pill {
  border: 1px solid var(--fr-line);
  border-radius: 9px;
  padding: 9px 10px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .11em;
  color: var(--fr-muted);
  text-transform: uppercase;
  background: rgba(255, 255, 255, .025);
}

.fr-status-pill strong {
  display: block;
  margin-top: 4px;
  font-size: 10px;
  color: var(--fr-ink);
}

.fr-pin-display {
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--acc) 58%, var(--line2));
  border-radius: 12px;
  background: rgba(0, 0, 0, .32);
  box-shadow: inset 0 0 22px rgba(0, 0, 0, .3);
}

.fr-pin-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid var(--line3);
  background: rgba(255, 255, 255, .04);
}

.fr-pin-dot.on {
  border-color: var(--acc);
  background: var(--acc-hi);
  box-shadow: 0 0 14px var(--acc-glow);
}

.fr-pad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
  margin-top: 14px;
}

.fr-key {
  height: 48px;
  border: 1px solid var(--line2);
  border-radius: 11px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .018));
  color: var(--fr-ink);
  font-family: var(--mono);
  font-size: 16px;
  letter-spacing: .08em;
}

.fr-key:hover {
  border-color: var(--acc);
  color: var(--acc-hi);
}

.fr-key.action {
  font-size: 10px;
  text-transform: uppercase;
  color: var(--fr-muted);
}

.fr-console-deck {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--acc) 38%, var(--line));
  border-radius: 18px;
  background:
    radial-gradient(circle at 8% 8%, var(--acc-glow), transparent 34%),
    radial-gradient(circle at 92% 16%, rgba(57, 198, 214, .11), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, .055), rgba(255, 255, 255, .018)),
    var(--fr-bg);
  margin: 0 0 22px;
  box-shadow: 0 28px 90px rgba(0, 0, 0, .32);
}

.fr-console-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  padding: 18px;
  border-bottom: 1px solid var(--fr-line);
}

.fr-kicker {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--acc);
}

.fr-console-title {
  margin-top: 8px;
  font-family: var(--disp);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 38px);
  line-height: 1.02;
}

.fr-console-copy {
  max-width: 780px;
  margin-top: 9px;
  color: var(--fr-muted);
  font-size: 13px;
  line-height: 1.55;
}

.fr-live-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(128px, 1fr));
  gap: 10px;
  min-width: 520px;
}

.fr-live-card {
  border: 1px solid var(--fr-line);
  border-radius: 12px;
  padding: 12px;
  background: rgba(0, 0, 0, .2);
}

.fr-live-value {
  font-family: var(--disp);
  font-size: 24px;
  font-weight: 700;
  color: var(--acc-hi);
}

.fr-live-label {
  margin-top: 4px;
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--fr-muted);
}

.fr-station-rail {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 16px 18px 18px;
}

.fr-station-rail::-webkit-scrollbar {
  height: 7px;
}

.fr-station-rail::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--acc) 46%, var(--line2));
  border-radius: 999px;
}

.fr-node {
  scroll-snap-align: start;
  flex: 0 0 245px;
  min-height: 168px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border: 1px solid var(--fr-line);
  border-radius: 15px;
  padding: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .045), rgba(255, 255, 255, .016)),
    var(--fr-panel);
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.fr-node:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--acc) 70%, white 10%);
  background: var(--fr-panel-2);
}

.fr-node-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.fr-node-kind {
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: .16em;
  color: var(--acc);
  text-transform: uppercase;
}

.fr-node-status {
  border-radius: 999px;
  padding: 4px 7px;
  font-family: var(--mono);
  font-size: 8px;
  letter-spacing: .08em;
  color: var(--fr-good);
  background: rgba(70, 214, 114, .12);
}

.fr-node-status.blocked {
  color: var(--fr-warn);
  background: rgba(232, 181, 58, .13);
}

.fr-node-title {
  font-family: var(--disp);
  font-size: 17px;
  line-height: 1.1;
  font-weight: 700;
}

.fr-node-text {
  color: var(--fr-muted);
  font-size: 12px;
  line-height: 1.45;
  flex: 1;
}

.fr-node-action {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--acc-hi);
}

.fr-command-dock {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 0 18px 18px;
}

.fr-command-dock input {
  min-height: 44px;
}

.fr-command-output {
  grid-column: 1 / -1;
  max-height: 220px;
  overflow: auto;
  border: 1px solid var(--fr-line);
  border-radius: 12px;
  background: rgba(0, 0, 0, .22);
  color: var(--fr-muted);
  font-family: var(--mono);
  font-size: 11px;
  line-height: 1.55;
  padding: 12px;
  white-space: pre-wrap;
}

.fr-body-mark {
  outline: 1px solid rgba(70, 214, 114, .18);
}

@media (max-width: 980px) {
  .fr-console-head {
    grid-template-columns: 1fr;
  }
  .fr-live-grid {
    min-width: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .fr-command-dock {
    grid-template-columns: 1fr;
  }
}
