/* ════════════════════════════════════════════════════════════════════════
   PANOPTÈS · M10 · pages-m10.css
   Agents · Registry · Logs · Connect Modal
   ════════════════════════════════════════════════════════════════════════ */

/* ── shared page chrome ─────────────────────────────────────────────── */
.page-content {
  max-width: 1540px;
  margin: 0 auto;
  padding: 0 var(--pad) 80px;
}

/* ── shared section separator ───────────────────────────────────────── */
.section-rule {
  width: 100%;
  height: 14px;
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════════
   PAGE AGENTS
   ═══════════════════════════════════════════════════════════════════════ */

.agents-header {
  padding: 28px var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
  display: flex;
  align-items: baseline;
  gap: 20px;
}
.agents-header__greek {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--fg), transparent 38%);
}
.agents-header__title {
  font-family: var(--ff-serif);
  font-size: 28px;
  font-weight: normal;
  margin: 0;
  color: var(--fg);
}
.agents-header__count {
  margin-left: auto;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .14em;
  color: color-mix(in oklab, var(--fg), transparent 38%);
}

.agents-grid {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 20px var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
}

/* ── Agent panel ──────────────────────────────────────────────────────── */
.agent-panel {
  background: var(--fg);
  color: var(--cr);
  border-radius: var(--r-2);
  padding: 0;
  position: relative;
  overflow: hidden;
  transition: box-shadow .2s ease;
}
.agent-panel:hover {
  box-shadow: 0 8px 32px -8px rgba(26,18,8,.55);
}

.agent-panel__head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 12px;
  padding: 22px 24px 0;
}
.agent-panel__id {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.agent-panel__greek {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cr), transparent 40%);
}
.agent-panel__dot {
  flex: 0 0 10px;
  width: 10px; height: 10px;
  border-radius: 50%;
}
.agent-panel__service {
  font-family: var(--ff-serif);
  font-size: 20px;
  color: var(--cr);
  letter-spacing: .01em;
}
.agent-panel__tag {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 3px;
  border: 1px solid;
}
.agent-panel__tag--warn  { color: var(--s3); border-color: var(--s3); }
.agent-panel__tag--ok    { color: var(--s1); border-color: var(--s1); }
.agent-panel__tag--proxy { color: var(--am); border-color: var(--am); }

.agent-panel__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.agent-panel__body {
  display: grid;
  grid-template-columns: 1fr 500px;
  gap: 0;
}
@media (max-width: 1100px) {
  .agent-panel__body { grid-template-columns: 1fr; }
}

.agent-panel__left {
  padding: 16px 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.agent-panel__desc {
  font-family: var(--ff-sans);
  font-size: 13px;
  line-height: 1.55;
  color: color-mix(in oklab, var(--cr), transparent 22%);
  margin: 0;
  max-width: 600px;
}

.agent-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 20px;
}
.agent-metric {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
  min-width: 72px;
}
.agent-metric__k {
  font-family: var(--ff-mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cr), transparent 50%);
}
.agent-metric__v {
  font-family: var(--ff-mono);
  font-size: 15px;
  font-weight: 600;
  color: var(--cr);
}
.agent-metric__v--warn  { color: var(--s2); }
.agent-metric__v--danger{ color: var(--s3); }
.agent-metric__v--good  { color: var(--s1); }
.agent-metric__v--amber { color: var(--am); }

/* ── Sparkline side ───────────────────────────────────────────────────── */
.agent-panel__right {
  border-left: 1px solid color-mix(in oklab, var(--cr), transparent 86%);
  padding: 16px 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.agent-panel__spark-label {
  font-family: var(--ff-mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cr), transparent 50%);
  display: flex;
  justify-content: space-between;
}
.agent-panel__spark-label span:last-child { color: color-mix(in oklab, var(--cr), transparent 28%); }

.agent-sparkline {
  width: 100%;
  height: 80px;
  display: block;
}

/* Progress bar for quota-style metrics */
.agent-quota-bar {
  height: 4px;
  background: color-mix(in oklab, var(--cr), transparent 82%);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 4px;
}
.agent-quota-bar__fill {
  height: 100%;
  border-radius: 2px;
  background: var(--s1);
  transition: width .6s ease;
}
.agent-quota-bar__fill--warn   { background: var(--s2); }
.agent-quota-bar__fill--danger { background: var(--s3); }

/* ── Corner flancs ───────────────────────────────────────────────────── */
.agent-panel .flanc {
  position: absolute;
  width: 20px; height: 20px;
  border-color: var(--am);
  pointer-events: none;
}

/* Status top strip */
.agent-panel__strip {
  height: 3px;
  width: 100%;
}
.agent-panel__strip[data-status="s1"] { background: var(--s1); }
.agent-panel__strip[data-status="s2"] { background: var(--s2); }
.agent-panel__strip[data-status="s3"] { background: var(--s3); }
.agent-panel__strip[data-status="s4"] { background: var(--s4); }


/* ═══════════════════════════════════════════════════════════════════════
   PAGE REGISTRY
   ═══════════════════════════════════════════════════════════════════════ */

.registry-top {
  padding: 28px var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
}

.reg-header-row {
  display: flex;
  align-items: baseline;
  gap: 20px;
  margin-bottom: 20px;
}
.reg-header-row__greek {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--fg), transparent 38%);
}
.reg-header-row__title {
  font-family: var(--ff-serif);
  font-size: 28px;
  font-weight: normal;
  margin: 0;
  color: var(--fg);
}

/* Counters */
.reg-counters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.reg-counter {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--fg);
  color: var(--cr);
  border-radius: var(--r-1);
  padding: 8px 14px;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .1em;
  min-width: 100px;
}
.reg-counter__n {
  font-size: 22px;
  font-weight: 600;
  line-height: 1;
}
.reg-counter__k {
  display: flex;
  flex-direction: column;
  gap: 1px;
  line-height: 1.1;
}
.reg-counter__label {
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cr), transparent 45%);
}
.reg-counter--pending .reg-counter__n { color: var(--s2); }
.reg-counter--done    .reg-counter__n { color: var(--s1); }
.reg-counter--failed  .reg-counter__n { color: var(--s3); }

/* Filters */
.reg-filter-row {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  align-items: center;
}
.reg-filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
}
.reg-filter-group__label {
  font-family: var(--ff-mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--fg), transparent 45%);
}
.reg-chips {
  display: flex;
  gap: 4px;
}
.reg-chip {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .08em;
  padding: 5px 12px;
  border: 1px solid color-mix(in oklab, var(--fg), transparent 62%);
  border-radius: 999px;
  background: transparent;
  color: color-mix(in oklab, var(--fg), transparent 32%);
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.reg-chip:hover { border-color: var(--fg); color: var(--fg); }
.reg-chip.is-active {
  background: var(--fg);
  color: var(--cr);
  border-color: var(--fg);
}

/* Table */
.registry-wrap {
  padding: 0 var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
}
.reg-table-scroll {
  overflow-x: auto;
  border-radius: var(--r-2);
  background: var(--fg);
}
#registry-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--ff-mono);
  font-size: 12px;
}
#registry-table thead tr {
  border-bottom: 1px solid color-mix(in oklab, var(--cr), transparent 82%);
}
#registry-table th {
  padding: 12px 16px;
  text-align: left;
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cr), transparent 48%);
  font-weight: 500;
  white-space: nowrap;
}
.reg-row {
  border-bottom: 1px solid color-mix(in oklab, var(--cr), transparent 90%);
  transition: background .12s ease;
}
.reg-row:hover { background: color-mix(in oklab, var(--cr), transparent 92%); }
.reg-row:nth-child(4n+3) { background: color-mix(in oklab, var(--cr), transparent 96%); }
.reg-row:nth-child(4n+3):hover { background: color-mix(in oklab, var(--cr), transparent 90%); }
.reg-row.is-open { background: color-mix(in oklab, var(--am), transparent 88%); }

.reg-cell {
  padding: 10px 16px;
  color: color-mix(in oklab, var(--cr), transparent 10%);
  vertical-align: middle;
  white-space: nowrap;
}
.reg-cell--id {
  color: var(--am);
  letter-spacing: .06em;
}
.reg-cell--ts {
  color: color-mix(in oklab, var(--cr), transparent 38%);
  font-size: 11px;
}
.reg-cell--dur {
  color: color-mix(in oklab, var(--cr), transparent 28%);
  text-align: right;
}
.reg-cell--exp {
  width: 32px;
  padding: 10px 8px 10px 16px;
}
.reg-exp {
  background: none;
  border: none;
  color: color-mix(in oklab, var(--cr), transparent 55%);
  font-family: var(--ff-mono);
  font-size: 11px;
  padding: 2px 6px;
  cursor: pointer;
  transition: color .12s ease;
  border-radius: 3px;
}
.reg-exp:hover { color: var(--am); background: color-mix(in oklab, var(--am), transparent 88%); }

/* Status badges */
.reg-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .08em;
  padding: 3px 8px;
  border-radius: 3px;
}
.reg-status i {
  width: 6px; height: 6px;
  border-radius: 50%;
  display: inline-block;
  flex: 0 0 6px;
}
.reg-status--done       { color: var(--s1); background: color-mix(in oklab, var(--s1), transparent 86%); }
.reg-status--done i     { background: var(--s1); }
.reg-status--pending    { color: color-mix(in oklab, var(--cr), transparent 28%); background: color-mix(in oklab, var(--cr), transparent 92%); }
.reg-status--pending i  { background: color-mix(in oklab, var(--cr), transparent 50%); }
.reg-status--processing { color: var(--am); background: color-mix(in oklab, var(--am), transparent 85%); }
.reg-status--processing i { background: var(--am); animation: pulse 1.4s ease-out infinite; }
.reg-status--failed     { color: var(--s3); background: color-mix(in oklab, var(--s3), transparent 86%); }
.reg-status--failed i   { background: var(--s3); }

/* Type badges */
.reg-type {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 3px;
  border: 1px solid;
}
.reg-type--html { color: var(--am);   border-color: color-mix(in oklab, var(--am), transparent 65%); }
.reg-type--json { color: var(--pur);  border-color: color-mix(in oklab, var(--pur), transparent 65%); }
.reg-type--text { color: color-mix(in oklab, var(--cr), transparent 30%); border-color: color-mix(in oklab, var(--cr), transparent 75%); }

/* Expandable payload row */
.reg-payload {
  display: none;
  background: var(--cd);
}
.reg-payload.is-open { display: table-row; }
.reg-payload pre {
  margin: 0;
  padding: 12px 16px;
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--am);
  letter-spacing: .04em;
  white-space: pre-wrap;
  word-break: break-all;
}

/* Empty state */
#registry-empty {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 80px 24px;
  gap: 16px;
  color: color-mix(in oklab, var(--cr), transparent 55%);
}
#registry-empty__glyph {
  font-family: var(--ff-mono);
  font-size: 32px;
  letter-spacing: .28em;
  color: color-mix(in oklab, var(--cr), transparent 70%);
}
#registry-empty p {
  font-family: var(--ff-mono);
  font-size: 12px;
  letter-spacing: .12em;
  margin: 0;
}


/* ═══════════════════════════════════════════════════════════════════════
   PAGE LOGS
   ═══════════════════════════════════════════════════════════════════════ */

.logs-header {
  padding: 28px var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.logs-header__title-group {
  display: flex;
  align-items: baseline;
  gap: 16px;
  flex: 1;
}
.logs-header__greek {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--fg), transparent 38%);
}
.logs-header__title {
  font-family: var(--ff-serif);
  font-size: 28px;
  font-weight: normal;
  margin: 0;
  color: var(--fg);
}
.logs-header__controls {
  display: flex;
  gap: 8px;
  align-items: center;
}

/* Agent selector */
.logs-agents {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  padding: 14px var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
}
.logs-agents__label {
  font-family: var(--ff-mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--fg), transparent 48%);
  align-self: center;
  margin-right: 8px;
}
.logs-agent-btn {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .1em;
  padding: 6px 14px;
  background: transparent;
  border: 1px solid color-mix(in oklab, var(--fg), transparent 68%);
  border-radius: 3px;
  color: color-mix(in oklab, var(--fg), transparent 36%);
  cursor: pointer;
  transition: all .15s ease;
  display: flex;
  align-items: center;
  gap: 6px;
}
.logs-agent-btn .dot { width: 7px; height: 7px; flex: 0 0 7px; }
.logs-agent-btn:hover { border-color: var(--fg); color: var(--fg); }
.logs-agent-btn.is-active {
  background: var(--fg);
  color: var(--cr);
  border-color: var(--fg);
}

/* Terminal body */
.logs-body {
  padding: 14px var(--pad) 0;
  max-width: 1540px;
  margin: 0 auto;
}
#logs-terminal {
  background: var(--cd);
  border-radius: var(--r-2) var(--r-2) 0 0;
  min-height: 420px;
  max-height: 520px;
  overflow-y: auto;
  padding: 16px 18px;
  font-family: var(--ff-mono);
  font-size: 12px;
  line-height: 1.7;
  scroll-behavior: smooth;
}
#logs-terminal::-webkit-scrollbar { width: 6px; }
#logs-terminal::-webkit-scrollbar-track { background: var(--cd); }
#logs-terminal::-webkit-scrollbar-thumb { background: color-mix(in oklab, var(--cr), transparent 72%); border-radius: 3px; }

/* Log lines */
.log {
  display: flex;
  gap: 0;
  white-space: pre-wrap;
  word-break: break-all;
}
.log__t {
  color: var(--am);
  margin-right: 12px;
  flex: 0 0 auto;
  opacity: .85;
}
.log__lvl {
  flex: 0 0 56px;
  font-weight: 500;
  letter-spacing: .08em;
}
.log__msg { color: var(--cr); flex: 1; }

.log--info  .log__lvl { color: color-mix(in oklab, var(--cr), transparent 18%); }
.log--warn  .log__lvl { color: var(--s2); }
.log--error .log__lvl { color: var(--s3); }
.log--debug .log__lvl { color: color-mix(in oklab, var(--cr), transparent 55%); }
.log--debug .log__msg { opacity: .6; }
.log--error .log__msg { color: color-mix(in oklab, var(--s3), transparent 18%); }
.log--warn  .log__msg { color: color-mix(in oklab, var(--s2), transparent 20%); }

/* Terminal footer */
.logs-footer {
  background: var(--fg);
  border-radius: 0 0 var(--r-2) var(--r-2);
  padding: 10px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  border-top: 1px solid color-mix(in oklab, var(--cr), transparent 88%);
}
.logs-footer__agent {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: color-mix(in oklab, var(--cr), transparent 40%);
}
.logs-footer__agent span {
  color: var(--am);
}
#logs-count {
  font-family: var(--ff-mono);
  font-size: 11px;
  color: color-mix(in oklab, var(--cr), transparent 45%);
  letter-spacing: .08em;
}
.logs-footer__sep { margin-left: auto; }
.logs-btn {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .08em;
  padding: 5px 12px;
  background: transparent;
  border: 1px solid color-mix(in oklab, var(--cr), transparent 72%);
  border-radius: 3px;
  color: color-mix(in oklab, var(--cr), transparent 28%);
  cursor: pointer;
  transition: all .15s ease;
}
.logs-btn:hover { border-color: var(--cr); color: var(--cr); }
#logs-pause[data-paused="true"] { color: var(--s1); border-color: var(--s1); }


/* ═══════════════════════════════════════════════════════════════════════
   MODAL CONNECT
   ═══════════════════════════════════════════════════════════════════════ */

#modal-connect {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity .22s ease;
}
#modal-connect[data-open="true"] {
  pointer-events: all;
  opacity: 1;
}

#modal-connect-overlay {
  position: absolute;
  inset: 0;
  background: rgba(13,10,7,.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.modal-card {
  position: relative;
  z-index: 1;
  background: var(--fg);
  color: var(--cr);
  border-radius: var(--r-3);
  width: min(640px, calc(100vw - 48px));
  max-height: calc(100vh - 80px);
  overflow-y: auto;
  box-shadow: 0 40px 100px -20px rgba(0,0,0,.8);
}
.modal-card::-webkit-scrollbar { width: 5px; }
.modal-card::-webkit-scrollbar-track { background: var(--fg); }
.modal-card::-webkit-scrollbar-thumb { background: color-mix(in oklab, var(--cr), transparent 72%); border-radius: 3px; }

.modal-card__meander {
  width: 100%; height: 14px;
  display: block;
  border-radius: var(--r-3) var(--r-3) 0 0;
  overflow: hidden;
}

.modal-head {
  padding: 22px 28px 18px;
  border-bottom: 1px solid color-mix(in oklab, var(--cr), transparent 88%);
  display: flex;
  align-items: center;
  gap: 12px;
}
.modal-head__greek {
  font-family: var(--ff-mono);
  font-size: 9px;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cr), transparent 52%);
}
.modal-head__title {
  font-family: var(--ff-serif);
  font-size: 20px;
  font-weight: normal;
  margin: 0;
  flex: 1;
}
.modal-head__close {
  background: none;
  border: none;
  color: color-mix(in oklab, var(--cr), transparent 45%);
  font-size: 18px;
  cursor: pointer;
  line-height: 1;
  padding: 4px 8px;
  border-radius: 3px;
  transition: color .15s ease, background .15s ease;
}
.modal-head__close:hover { color: var(--cr); background: color-mix(in oklab, var(--cr), transparent 88%); }

.modal-section {
  padding: 20px 28px;
  border-bottom: 1px solid color-mix(in oklab, var(--cr), transparent 90%);
}
.modal-section:last-of-type { border-bottom: none; }
.modal-section__label {
  font-family: var(--ff-mono);
  font-size: 9px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--am);
  display: block;
  margin-bottom: 14px;
}

.modal-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 12px;
}
.modal-field:last-child { margin-bottom: 0; }
.modal-field__label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .16em;
  color: color-mix(in oklab, var(--cr), transparent 40%);
}
.modal-field__input {
  background: var(--cd);
  border: 1px solid color-mix(in oklab, var(--cr), transparent 82%);
  border-radius: var(--r-1);
  padding: 8px 12px;
  font-family: var(--ff-mono);
  font-size: 12px;
  color: var(--cr);
  letter-spacing: .04em;
  outline: none;
  transition: border-color .15s ease;
  width: 100%;
}
.modal-field__input:focus {
  border-color: var(--am);
}
.modal-field__input::placeholder {
  color: color-mix(in oklab, var(--cr), transparent 60%);
}
.modal-field__input[type="password"] {
  letter-spacing: .2em;
}

/* Slider field */
.modal-slider-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.modal-slider-row:last-child { margin-bottom: 0; }
.modal-slider-row__label {
  font-family: var(--ff-mono);
  font-size: 10px;
  letter-spacing: .12em;
  color: color-mix(in oklab, var(--cr), transparent 32%);
  flex: 0 0 140px;
}
.modal-slider {
  flex: 1;
  -webkit-appearance: none;
  appearance: none;
  height: 4px;
  background: color-mix(in oklab, var(--cr), transparent 80%);
  border-radius: 2px;
  outline: none;
}
.modal-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--am);
  cursor: pointer;
  transition: transform .12s ease;
}
.modal-slider::-webkit-slider-thumb:hover { transform: scale(1.2); }
.modal-slider__val {
  font-family: var(--ff-mono);
  font-size: 12px;
  color: var(--am);
  flex: 0 0 38px;
  text-align: right;
  letter-spacing: .04em;
}

/* Modal footer */
.modal-foot {
  padding: 18px 28px 24px;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  align-items: center;
}
.modal-foot__reset {
  margin-right: auto;
  background: none;
  border: none;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: color-mix(in oklab, var(--cr), transparent 55%);
  cursor: pointer;
  padding: 8px 12px;
  border-radius: 3px;
  transition: color .15s ease;
}
.modal-foot__reset:hover { color: color-mix(in oklab, var(--cr), transparent 18%); }

/* Save button */
#modal-connect-save {
  background: var(--am);
  border: none;
  color: var(--fg);
  font-family: var(--ff-mono);
  font-size: 12px;
  letter-spacing: .1em;
  padding: 10px 24px;
  border-radius: 999px;
  cursor: pointer;
  transition: background .15s ease, transform .12s ease;
  font-weight: 600;
}
#modal-connect-save:hover { background: color-mix(in oklab, var(--am), var(--cr) 15%); transform: translateY(-1px); }

/* ── agent panel action button coloring ─────────────────────────────── */
.agent-panel[data-status="s1"] .action { color: var(--s1); }
.agent-panel[data-status="s2"] .action { color: var(--s2); }
.agent-panel[data-status="s3"] .action { color: var(--s3); }
.agent-panel[data-status="s1"] .action:hover { background: var(--s1); color: var(--cd); }
.agent-panel[data-status="s2"] .action:hover { background: var(--s2); color: var(--cd); }
.agent-panel[data-status="s3"] .action:hover { background: var(--s3); color: var(--cd); }

