/* Base di conoscenza — pagine di modifica. Solo token (--…), dark + light. */

/* Terna in testa: Nome · Slug · Priorità (come MCP/Model/Memoria) */
.kb-grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 22px; }
@media (max-width: 900px) { .kb-grid3 { grid-template-columns: 1fr; } }

/* Selettore a CARD single-select — stessa UX/UI del "Trasporto" MCP
   (conn-card cap-card + kebab + menu contestuale). La griglia eredita da
   .conn-grid (4/riga, auto-fill); qui solo i ritocchi specifici. */
/* Densità: i selettori vivono spesso in campi a metà larghezza (Collezione,
   Tipo store affiancati) → minmax più stretto del .conn-grid full-width così
   restano ≥2 per riga; in campi a tutta larghezza ne entrano di più. */
/* Max 4 per riga su sezione full-width, responsive: la larghezza minima della
   colonna = max(200px, 1/4 della riga) → mai più di 4; nei campi a metà
   larghezza il floor 200px fa scendere a 2. */
.kb-pickgrid { grid-template-columns: repeat(auto-fill, minmax(max(200px, calc((100% - 30px) / 4)), 1fr)); gap: 10px; }
.kb-pickgrid.error .conn-card:not(.selected) { border-color: rgba(231,96,96,.4); }
.kb-pickthumb { border-radius: 9px; }
/* Senza descrizione: il nome va centrato verticalmente (cap-card allinea in
   alto per le card con sottotitolo; qui non c'è, quindi si centra). */
.kb-pickcard:not(:has(.cap-card-sub)) { align-items: center; }
.kb-pickcard:not(:has(.cap-card-sub)) .conn-card-body { justify-content: center; }
.kb-pickcard .conn-card-nm.mono { font-family: "Geist Mono", ui-monospace, monospace; letter-spacing: .02em; }
.kb-pick-ini { font-size: 15px; font-weight: 700; line-height: 1; }
/* Sottotitolo descrittivo della card (non stilizzato a livello globale) */
.kb-pickcard .cap-card-sub {
  color: var(--text-muted); font-size: 12.5px; line-height: 1.45;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
/* Nota nel menu contestuale (campo obbligatorio: nessuna azione di deselezione) */
.ctx-note { padding: 8px 12px 10px; font-size: 12px; color: var(--text-faint); max-width: 220px; line-height: 1.4; }

/* Toggle-card singola */
.kb-togglegrid { grid-template-columns: 1fr; }
.kb-togglecard:not(.on) .ty-card-thumb,
.kb-togglecard:not(.on) .ty-card-name,
.kb-togglecard:not(.on) .ty-card-desc { opacity: .55; }

/* Textarea generica */
textarea.kb-textarea { resize: vertical; min-height: 110px; line-height: 1.55; font-family: var(--font); font-size: 13.5px; }

/* Nota informativa di sezione */
.kb-note { display: flex; align-items: flex-start; gap: 7px; margin: 2px 0 0; font-size: 12px; color: var(--text-faint); line-height: 1.5; }
.kb-note svg { flex-shrink: 0; margin-top: 1px; }

/* Chip input (Filter Urls) */
.kb-chipsbox {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px; min-height: 42px; padding: 6px 8px;
  background: var(--bg-content); border: 1px solid var(--border); border-radius: var(--r-md);
}
.kb-chipsbox:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.kb-chip { display: inline-flex; align-items: center; gap: 5px; padding: 2px 6px 2px 9px; font-size: 12px; font-family: var(--mono); color: var(--text); background: var(--bg-elev); border: 1px solid var(--border); border-radius: 999px; }
.kb-chip button { display: flex; background: none; border: 0; color: var(--text-faint); cursor: pointer; padding: 0; }
.kb-chip button:hover { color: var(--danger); }
.kb-chip-input { flex: 1; min-width: 120px; background: none; border: 0; outline: none; color: var(--text); font-size: 13px; font-family: var(--mono); }

/* Chain builder (Transformer) */
.kb-chain { display: flex; align-items: center; gap: 0; flex-wrap: wrap; padding: 18px 6px; }
.kb-chain-node { display: flex; flex-direction: column; align-items: center; gap: 5px; text-align: center; min-width: 120px; position: relative; }
.kb-node-thumb { width: 40px; height: 40px; border-radius: 11px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--border-faint); }
.kb-node-kind { font-size: 10px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--text-faint); }
.kb-node-name { font-size: 12px; color: var(--text); max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kb-node-x { position: absolute; top: -6px; right: 18px; width: 16px; height: 16px; border-radius: 50%; border: 1px solid var(--border); background: var(--bg-elev); color: var(--text-muted); display: flex; align-items: center; justify-content: center; cursor: pointer; }
.kb-node-x:hover { color: var(--danger); border-color: var(--danger); }
.kb-chain-link { flex: 1; min-width: 28px; height: 2px; background: var(--border-strong); border-radius: 2px; }
.kb-chain-add { display: flex; flex-direction: column; align-items: center; gap: 5px; background: none; border: 0; cursor: pointer; min-width: 120px; }
.kb-add-circle { width: 40px; height: 40px; border-radius: 50%; border: 1.5px dashed var(--border-strong); color: var(--text-muted); display: flex; align-items: center; justify-content: center; transition: border-color .14s, color .14s; }
.kb-chain-add:hover .kb-add-circle { border-color: var(--accent); color: var(--accent); }

/* Tabella esecuzioni */
.kb-runs .list-row { grid-template-columns: minmax(220px, 1.6fr) 140px 180px 100px 110px; }
.kb-run-badge { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; padding: 2px 9px 2px 8px; border-radius: 999px; border: 1px solid; }
.kb-run-badge .dot { width: 6px; height: 6px; border-radius: 50%; }
