/* ─────────────────────────────────────────────────────────────────────────
   Agent edit — "Capacità" section.
   Layout mirrors the Connettori screen: skills are managed like connectors
   (selectable cards/rows, search + tag chips + Tutti/Attive, bulk bar, ctx
   menu). This file holds:
     · a few `mdl-*` rules copied from agent-model.css (toggle + stepper) so the
       Impostazioni card matches without loading that file,
     · the concurrency intent hint,
     · the skills-manager chrome (count bar, tag-chip clear, list tags, skill
       thumb) that layers on top of the shared conn-* classes in styles.css.
   ───────────────────────────────────────────────────────────────────────── */

/* ── Copied from agent-model.css (toggle / stepper / nested / divider) ── */
.mdl-divider { height: 1px; background: var(--border-faint); margin: 2px 0; }

.mdl-toggle { display: flex; flex-direction: column; gap: 7px; }
.mdl-toggle-head {
  display: flex; align-items: center; gap: 11px;
  background: transparent; border: 0; padding: 0; cursor: pointer; text-align: left;
}
.mdl-toggle-head .ttl { font-size: 13.5px; font-weight: 500; color: var(--text-strong); }
.mdl-toggle-head:hover .ttl { color: var(--text); }
.mdl-switch {
  position: relative; width: 38px; height: 22px; flex-shrink: 0;
  border-radius: 999px; background: var(--border-strong);
  transition: background .16s; display: inline-block;
}
.mdl-switch .knob {
  position: absolute; top: 3px; left: 3px; width: 16px; height: 16px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.45); transition: transform .16s;
}
.mdl-switch.on { background: var(--accent); }
.mdl-switch.on .knob { transform: translateX(16px); }
.mdl-toggle-head:focus-visible { outline: 0; }
.mdl-toggle-head:focus-visible .mdl-switch { box-shadow: 0 0 0 3px var(--accent-soft); }

.idn-label.wrap { white-space: normal; line-height: 1.35; }

.mdl-stepper {
  display: flex; align-items: stretch; height: 46px; max-width: 220px;
  background: var(--bg-app); border: 1px solid var(--border); border-radius: 10px;
  overflow: hidden; transition: border-color .12s, box-shadow .12s;
}
.mdl-stepper:hover { border-color: var(--border-strong); }
.mdl-stepper:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.mdl-step-btn {
  width: 50px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 0; color: var(--text-muted); cursor: pointer;
  transition: background .12s, color .12s;
}
.mdl-step-btn:hover:not(:disabled) { background: var(--bg-card-hover); color: var(--text-strong); }
.mdl-step-btn:active:not(:disabled) { background: var(--bg-elev); }
.mdl-step-btn:disabled { opacity: .3; cursor: default; }
.mdl-step-btn:first-child { border-right: 1px solid var(--border-faint); }
.mdl-step-btn:last-child  { border-left: 1px solid var(--border-faint); }
.mdl-step-val {
  flex: 1; min-width: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 0; color: var(--text-strong);
  font-size: 15px; font-weight: 600; cursor: text;
  font-variant-numeric: tabular-nums; text-align: center; letter-spacing: .01em;
}
.mdl-step-val:hover { color: var(--accent); }
.mdl-step-val.edit { outline: 0; width: 100%; font-family: inherit; }
.mdl-step-val.edit:hover { color: var(--text-strong); }

/* ── Concorrenza: stepper row + intent hint ── */
.cap-conc-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.cap-intent {
  display: inline-flex; align-items: center; gap: 7px;
  height: 30px; padding: 0 12px; border-radius: 999px;
  background: var(--bg-elev); border: 1px solid var(--border-faint);
  font-size: 12.5px; color: var(--text-muted); white-space: nowrap;
}
.cap-intent .ic { display: inline-flex; color: var(--text-faint); }
.cap-intent.parallel { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--text-link); }
.cap-intent.parallel .ic { color: var(--accent); }

/* ── Skills-disabled note (inside the Impostazioni card) ── */
.cap-disabled-note {
  display: flex; align-items: center; gap: 10px;
  margin-top: 14px; padding: 13px 15px;
  border: 1px dashed var(--border); border-radius: 11px;
  color: var(--text-muted); font-size: 13px; line-height: 1.45;
  background: var(--bg-app);
}
.cap-disabled-note .ico {
  width: 30px; height: 30px; border-radius: 8px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev); border: 1px solid var(--border-faint); color: var(--text-faint);
}

/* ─────────────────────────────  Skills manager  ──────────────────────────── */
.cap-sec-sub { margin: -8px 0 16px; color: var(--text-muted); font-size: 13.5px; max-width: 760px; line-height: 1.5; }

/* (Collapsible grey panel styles moved to styles.css — shared with Connettori) */

/* Count summary bar */
.cap-skills-bar {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 14px;
}
.cap-count-pill {
  display: inline-flex; align-items: center; gap: 6px;
  height: 30px; padding: 0 13px; border-radius: 999px;
  background: var(--bg-card); border: 1px solid var(--border-faint);
  color: var(--text-muted); font-size: 13px; font-weight: 500; cursor: pointer;
}
.cap-count-pill:hover { border-color: var(--border); color: var(--text); }
.cap-count-pill.on { border-color: var(--accent); background: var(--accent-soft); color: var(--text-strong); }
.cap-count-pill .num { color: var(--success); font-weight: 700; font-variant-numeric: tabular-nums; }
.cap-count-pill.on .num { color: var(--text-link); }
.cap-count-sep { color: var(--text-faint); }
.cap-count-total { color: var(--text-muted); font-size: 13px; }
.cap-count-grow {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--text-faint); font-size: 12px;
}

.cap-toolbar { margin-bottom: 14px; }
/* Aggiungi button matches the search/view-switch height for a clean toolbar row */
.cap-toolbar .btn { height: 38px; }

/* Tag chips row (multi-select) */
.cap-chips { flex-wrap: wrap; row-gap: 8px; }
.cap-chip-clear {
  display: inline-flex; align-items: center; gap: 5px;
  height: 30px; padding: 0 11px; border-radius: 999px;
  background: transparent; border: 1px solid var(--border-faint);
  color: var(--text-muted); font-size: 12.5px; font-weight: 500; cursor: pointer;
}
.cap-chip-clear:hover { color: var(--text); border-color: var(--border-strong); background: var(--bg-elev); }

/* Skill thumb = icon on a tinted tile (overrides conn-thumb's text styling) */
.cap-skill-thumb { /* width/height/background/color set inline */ }

/* Grid card: top-aligned, name + wrapping tag row (active/inactive = bg colour) */
.conn-card.cap-card { align-items: flex-start; }
.cap-card .conn-card-body { display: flex; flex-direction: column; gap: 8px; min-width: 0; }

/* Tag row (shared by grid card + list row) */
.cap-tagrow { display: flex; flex-wrap: wrap; gap: 5px; min-width: 0; align-items: center; }
.cap-tagmini {
  font-size: 11px; font-family: var(--mono);
  padding: 1px 7px; border-radius: 4px;
  background: var(--bg-elev); border: 1px solid var(--border-faint); color: var(--text-muted);
  white-space: nowrap;
}

/* Skill list rows: thumb / name / tags (no status text — bg colour signals state) */
.cap-3col .conn-row { grid-template-columns: 28px minmax(170px, 1fr) 1.6fr; }

/* ─────────────────────────────  Abilità (toggle list)  ───────────────────── */
.cap-ability {
  border: 1px solid var(--border-faint); border-radius: 11px;
  background: var(--bg-card); overflow: hidden; transition: border-color .12s, box-shadow .12s;
  cursor: pointer;
}
.cap-ability:hover { border-color: var(--border); }
.cap-ability.on:hover { border-color: var(--accent-ring); }
.cap-ability.selected { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-ring); }
.cap-ability-cfg { cursor: default; }
.cap-ability + .cap-ability { margin-top: 10px; }
.cap-ability.on { border-color: var(--accent-ring); }
.cap-ability-head { display: flex; align-items: center; gap: 12px; padding: 13px 16px; }
.cap-ability-ico {
  width: 30px; height: 30px; border-radius: 8px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev); border: 1px solid var(--border-faint); color: var(--text-muted);
}
.cap-ability.on .cap-ability-ico { background: var(--accent-soft); color: var(--accent); border-color: var(--accent-ring); }
.cap-ability-name { flex: 1; min-width: 0; font-size: 14px; font-weight: 500; color: var(--text-strong); }
.cap-ability-cfg {
  padding: 14px 16px 16px; border-top: 1px solid var(--border-faint);
  display: flex; flex-direction: column; gap: 14px;
}
.cap-cfg-json {
  margin: 0; font-family: var(--mono); font-size: 12.5px; color: var(--text);
  background: var(--bg-app); border: 1px solid var(--border-faint); border-radius: 9px;
  padding: 11px 13px; overflow-x: auto; white-space: pre; line-height: 1.5;
}
.cap-sources { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.cap-src-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--bg-elev); border: 1px solid var(--border-faint); border-radius: 7px;
  padding: 5px 6px 5px 10px; font-size: 12.5px; color: var(--text);
}
.cap-src-chip button {
  width: 18px; height: 18px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 0; color: var(--text-faint); cursor: pointer; border-radius: 4px;
}
.cap-src-chip button:hover { background: var(--bg-card-hover); color: var(--text); }
.cap-add-link {
  display: inline-flex; align-items: center; gap: 6px;
  background: transparent; border: 0; color: var(--text-link); font-size: 13px; font-weight: 500;
  cursor: pointer; padding: 4px 6px; border-radius: 6px;
}
.cap-add-link:hover { background: var(--bg-card-hover); }

/* Chip input (project ability "Goal Slugs" / channels) */
.cap-chipinput {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center; width: 100%; min-height: 42px;
  background: var(--bg-app); border: 1px solid var(--border); border-radius: 10px; padding: 7px 10px;
  transition: border-color .12s, box-shadow .12s;
}
.cap-chipinput:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.cap-chipinput input { flex: 1; min-width: 120px; background: transparent; border: 0; outline: 0; color: var(--text); font-size: 14px; }
.cap-chipinput input::placeholder { color: var(--text-faint); }

/* Editable JSON textarea (project ability config) */
.cap-json-edit {
  width: 100%; resize: vertical; min-height: 72px;
  background: var(--bg-app); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px;
  color: var(--text); font-family: var(--mono); font-size: 12.5px; line-height: 1.5; outline: 0;
}
.cap-json-edit:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }

/* Inline-config close button (Connettori config header) */
.cap-cfg-close {
  width: 28px; height: 28px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border-faint);
  border-radius: 7px; color: var(--text-muted); cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.cap-cfg-close:hover { background: var(--bg-elev); color: var(--text); border-color: var(--border); }

/* Shared interaction hint — lives inline on the left of the sticky footer */
.cap-foot-hint {
  flex: 1; min-width: 0;
  color: var(--text-faint); font-size: 12px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cap-foot-hint .kbd {
  font-family: var(--mono); background: var(--bg-elev);
  padding: 2px 6px; border-radius: 4px; color: var(--text-muted);
  font-size: 11px; border: 1px solid var(--border-faint);
}

/* Overflow scope chip */
.cap-tagmore { color: var(--text-faint); }

/* ─────────────────────────────  Add-MCP modal  ───────────────────────────── */
.cap-mcp-modal { width: 600px; }
.cap-add-search {
  display: flex; align-items: center; gap: 8px;
  height: 42px; margin: 8px 0 12px;
  background: var(--bg-app); border: 1px solid var(--border); border-radius: 10px;
  padding: 0 10px 0 12px;
}
.cap-add-search:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.cap-add-search svg { color: var(--text-faint); flex-shrink: 0; }
.cap-add-search input { flex: 1; background: transparent; border: 0; outline: 0; color: var(--text); font-size: 14px; }
.cap-add-search input::placeholder { color: var(--text-faint); }

.cap-add-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 0 2px 8px;
}
.cap-add-bar span { font-size: 11.5px; color: var(--text-faint); text-transform: uppercase; letter-spacing: .05em; font-weight: 600; }
.cap-add-selall { background: transparent; border: 0; cursor: pointer; color: var(--text-link); font-size: 12.5px; font-weight: 500; padding: 2px 4px; border-radius: 5px; }
.cap-add-selall:hover { background: var(--bg-card-hover); color: var(--text-strong); }

.cap-add-list {
  display: flex; flex-direction: column; gap: 2px;
  max-height: 360px; overflow-y: auto;
  border: 1px solid var(--border-faint); border-radius: 10px; padding: 5px;
  background: var(--bg-app);
}
.cap-add-opt {
  display: flex; align-items: flex-start; gap: 11px;
  padding: 9px 10px; border-radius: 8px; cursor: pointer;
  background: transparent; border: 0; text-align: left; width: 100%;
}
.cap-add-opt:hover { background: var(--bg-card-hover); }
.cap-add-opt.on { background: var(--accent-soft); }
.cap-add-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cap-add-name { font-size: 13.5px; font-weight: 500; color: var(--text-strong); }
.cap-add-scopes { font-size: 12px; color: var(--text-muted); line-height: 1.4; }
.cap-add-count { font-size: 12.5px; color: var(--text-muted); }
.cap-add-empty {
  display: flex; align-items: center; gap: 10px;
  padding: 22px 14px; color: var(--text-muted); font-size: 13.5px;
  border: 1px dashed var(--border); border-radius: 10px;
}
.cap-add-empty svg { color: var(--success); flex-shrink: 0; }

/* Checkbox (shared: modal list) */
.cap-check {
  width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px;
  border-radius: 5px; border: 1.5px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-card); color: transparent;
  transition: background .1s, border-color .1s;
}
.cap-add-opt.on .cap-check { background: var(--accent); border-color: var(--accent); color: #fff; }
.cap-menu-empty { padding: 18px 12px; text-align: center; color: var(--text-faint); font-size: 13px; }

/* MiniSelect → card compatte (enum brevi nei form Abilità). Single-select:
   bordo accent sull'attiva; stato dato solo da bordo/sfondo (mai una tendina). */
.cap-minicards { display: flex; flex-wrap: wrap; gap: 8px; }
.cap-minicard {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 12px; border-radius: var(--r-md);
  border: 1px solid var(--border-faint); background: var(--bg-card);
  color: var(--text); font-size: 13px; font-weight: 500; cursor: pointer;
  transition: border-color .12s, background .12s, box-shadow .12s;
}
.cap-minicard:hover { border-color: var(--border); background: var(--bg-card-hover); }
.cap-minicard.on { border-color: var(--accent); background: var(--accent-soft); box-shadow: 0 0 0 1px var(--accent-ring); color: var(--text-strong); }
.cap-minicard .cap-minicard-nm { white-space: nowrap; }
.cap-minicard svg { color: var(--accent); }
