/* ============================================================
   integracoes.css — estilos do módulo Integrações + Origens
   Namespaces: .origem-*, .webhook-*
   ============================================================ */

/* ---------- form base ---------- */
.origem-form { display:flex; flex-direction:column; gap:16px; }
.origem-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.origem-grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
@media (max-width:720px) {
  .origem-grid-2, .origem-grid-3 { grid-template-columns:1fr; }
}

.origem-label {
  display:flex; flex-direction:column; gap:6px;
  font-size:13px; font-weight:500; color:var(--cf-text-2, #475569);
}
.origem-input {
  width:100%; padding:10px 12px; border:1px solid var(--cf-border, #e2e8f0);
  border-radius:8px; font-size:14px; background:var(--cf-bg, #fff);
  color:var(--cf-text, #0f172a); transition: border-color .15s;
}
.origem-input:focus { outline:none; border-color: var(--cf-brand, #1E5BAA); box-shadow: 0 0 0 3px rgba(30,91,170,.12); }
.origem-input-sm { padding:6px 10px; font-size:13px; border:1px solid var(--cf-border, #e2e8f0); border-radius:6px; background:#fff; }
.origem-textarea { resize:vertical; min-height:60px; font-family:inherit; }
.origem-color { padding:2px; height:36px; cursor:pointer; }
.origem-req { color:#dc2626; }
.origem-hint { font-size:12px; color:var(--cf-text-3, #64748b); font-weight:400; }

.origem-toggle { display:inline-flex; align-items:center; gap:8px; cursor:pointer; font-weight:400; }
.origem-toggle input[type="checkbox"] { width:16px; height:16px; cursor:pointer; }
.origem-toggle-row { padding:8px 0; }

.origem-color-row { display:flex; gap:8px; align-items:center; }
.origem-color-presets { display:flex; gap:4px; flex-wrap:wrap; }
.origem-color-pick { width:24px; height:24px; border-radius:50%; border:2px solid #fff; box-shadow:0 0 0 1px var(--cf-border, #e2e8f0); cursor:pointer; padding:0; }
.origem-color-pick:hover { transform:scale(1.1); }

.origem-meta-row {
  display:flex; gap:16px; padding:12px; background:#f8fafc; border-radius:8px;
  font-size:13px; color:var(--cf-text-3, #64748b);
}

/* ---------- empty / loading / error ---------- */
.origem-loading, .origem-empty, .origem-error {
  padding:48px 16px; text-align:center; color:var(--cf-text-3, #64748b); font-size:14px;
}
.origem-error { color:#dc2626; }

/* ---------- tabs container ---------- */
.origem-tab { display:flex; flex-direction:column; gap:20px; padding:8px 0; }

/* ---------- aba ETAPAS (kanban interno) ---------- */
.origem-tab-etapas { gap:16px; }
.origem-etapas-head {
  display:flex; justify-content:space-between; align-items:flex-start; gap:16px;
  padding-bottom:8px; border-bottom:1px solid var(--cf-border, #e2e8f0);
}
.origem-etapas-head strong { font-size:15px; color:var(--cf-text, #0f172a); display:block; margin-bottom:4px; }
.origem-etapas-head .origem-hint { margin:0; }

.origem-kanban {
  display:flex; gap:14px; overflow-x:auto; padding-bottom:12px;
  scroll-snap-type: x mandatory;
}

.origem-col {
  flex: 0 0 260px; background:#f8fafc; border:1px solid var(--cf-border, #e2e8f0);
  border-radius:10px; padding:10px; display:flex; flex-direction:column; gap:8px;
  scroll-snap-align: start;
}
.origem-col-head {
  display:flex; justify-content:space-between; align-items:center;
  padding:6px 8px; background:#fff; border-radius:8px; border-bottom:3px solid;
}
.origem-col-title { display:flex; align-items:center; gap:8px; font-size:13px; }
.origem-col-dot { width:10px; height:10px; border-radius:50%; }
.origem-col-edit {
  background:transparent; border:none; cursor:pointer; padding:4px 8px; border-radius:4px;
  color:var(--cf-text-3, #64748b);
}
.origem-col-edit:hover { background:#f1f5f9; color:var(--cf-text, #0f172a); }

.origem-stage-kind {
  font-size:10px; font-weight:600; padding:2px 6px; border-radius:10px;
  text-transform:uppercase; letter-spacing:0.5px;
}
.origem-stage-kind-initial { background:#dcfce7; color:#166534; }
.origem-stage-kind-won { background:#dcfce7; color:#166534; }
.origem-stage-kind-lost { background:#fee2e2; color:#991b1b; }
.origem-stage-kind-closed { background:#fee2e2; color:#991b1b; }

.origem-col-body { display:flex; flex-direction:column; gap:6px; min-height:60px; padding:4px 0; }
.origem-col-empty {
  text-align:center; font-size:12px; color:var(--cf-text-3, #94a3b8);
  padding:16px 8px; font-style:italic;
}

.origem-at-card {
  display:flex; gap:10px; align-items:flex-start; padding:8px 10px;
  background:#fff; border:1px solid var(--cf-border, #e2e8f0); border-radius:8px;
  cursor:pointer; text-align:left; width:100%;
  transition: border-color .15s, transform .1s;
}
.origem-at-card:hover { border-color:var(--cf-brand, #1E5BAA); transform: translateY(-1px); }
.origem-at-icon { font-size:16px; line-height:1; padding-top:2px; }
.origem-at-body { display:flex; flex-direction:column; gap:2px; flex:1; min-width:0; }
.origem-at-label { font-size:13px; font-weight:500; color:var(--cf-text, #0f172a); line-height:1.3; }
.origem-at-meta { font-size:11px; color:var(--cf-text-3, #64748b); }

.origem-add-at-btn {
  background:transparent; border:1px dashed var(--cf-border, #cbd5e1);
  color:var(--cf-brand, #1E5BAA); padding:8px; border-radius:6px;
  cursor:pointer; font-size:12px; font-weight:500;
}
.origem-add-at-btn:hover { background:#fff; border-style:solid; }

.origem-col-add {
  flex: 0 0 200px; border:2px dashed var(--cf-border, #cbd5e1);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  min-height:120px; cursor:pointer;
}
.origem-col-add:hover { border-color: var(--cf-brand, #1E5BAA); background:#f1f5f9; }
.origem-add-stage-btn {
  background:transparent; border:none; color:var(--cf-text-3, #64748b);
  font-size:13px; padding:16px; cursor:pointer; font-weight:500;
}

/* ---------- buttons ---------- */
.origem-btn-primary {
  background:var(--cf-brand, #1E5BAA); color:#fff; border:none;
  padding:8px 14px; border-radius:6px; font-size:13px; font-weight:500;
  cursor:pointer;
}
.origem-btn-primary:hover { background:#164785; }

.origem-btn-ghost {
  background:transparent; color:var(--cf-text-2, #475569);
  border:1px solid var(--cf-border, #e2e8f0);
  padding:6px 12px; border-radius:6px; font-size:13px; cursor:pointer;
}
.origem-btn-ghost:hover { background:#f1f5f9; }

.origem-btn-ghost-sm {
  background:transparent; color:var(--cf-text-2, #475569);
  border:1px solid var(--cf-border, #e2e8f0);
  padding:4px 10px; border-radius:4px; font-size:12px; cursor:pointer;
}
.origem-btn-ghost-sm:disabled { opacity:.4; cursor:not-allowed; }

.origem-btn-link {
  background:transparent; border:none; color:var(--cf-brand, #1E5BAA);
  font-size:13px; cursor:pointer; padding:0; font-weight:500;
}
.origem-btn-link:hover { text-decoration:underline; }

/* ---------- pills ---------- */
.origem-pill { display:inline-block; padding:2px 8px; border-radius:12px; font-size:11px; font-weight:500; }
.origem-pill-green { background:#dcfce7; color:#166534; }
.origem-pill-red { background:#fee2e2; color:#991b1b; }
.origem-pill-amber { background:#fef3c7; color:#92400e; }
.origem-pill-blue { background:#dbeafe; color:#1e3a8a; }
.origem-pill-purple { background:#ede9fe; color:#5b21b6; }
.origem-pill-gray { background:#f1f5f9; color:#475569; }
.origem-pill-warn { background:#fef3c7; color:#92400e; }

/* ---------- aba INTEGRAÇÕES ---------- */
.origem-subtabs {
  display:flex; gap:4px; border-bottom:1px solid var(--cf-border, #e2e8f0);
  padding-bottom:0;
}
.origem-subtab {
  background:transparent; border:none; padding:10px 16px; cursor:pointer;
  font-size:13px; font-weight:500; color:var(--cf-text-3, #64748b);
  border-bottom:2px solid transparent;
}
.origem-subtab.active { color:var(--cf-brand, #1E5BAA); border-bottom-color:var(--cf-brand, #1E5BAA); }
.origem-subtab:hover:not(.active) { color:var(--cf-text-2, #475569); }
.origem-subtab-content { padding-top:16px; }

.origem-apps-head {
  display:flex; justify-content:space-between; gap:12px; margin-bottom:16px;
  flex-wrap:wrap;
}
.origem-apps-filters { display:flex; gap:8px; flex-wrap:wrap; }
.origem-apps-list { display:flex; flex-direction:column; gap:8px; }

.origem-app-card {
  display:grid; grid-template-columns: 40px 1fr 24px;
  gap:12px; padding:12px; background:#fff;
  border:1px solid var(--cf-border, #e2e8f0); border-radius:8px;
  align-items:center;
}
.origem-app-icon { font-size:24px; text-align:center; }
.origem-app-body { min-width:0; }
.origem-app-eyebrow {
  font-size:10px; font-weight:600; color:var(--cf-text-3, #64748b);
  text-transform:uppercase; letter-spacing:0.5px; margin-bottom:2px;
}
.origem-app-name { font-size:14px; font-weight:500; color:var(--cf-text, #0f172a); margin-bottom:4px; }
.origem-app-action { font-size:12px; }
.origem-app-menu {
  background:transparent; border:none; cursor:pointer; padding:6px;
  color:var(--cf-text-3, #64748b); font-size:18px; line-height:1;
}
.origem-app-menu:hover { background:#f1f5f9; border-radius:4px; }

.origem-apps-empty {
  text-align:center; padding:48px 16px; background:#f8fafc; border-radius:10px;
  border:2px dashed var(--cf-border, #e2e8f0);
}
.origem-empty-icon { font-size:36px; margin-bottom:8px; }
.origem-empty-title { font-size:15px; font-weight:600; color:var(--cf-text, #0f172a); margin-bottom:4px; }
.origem-empty-msg { font-size:13px; color:var(--cf-text-3, #64748b); }

.origem-apps-foot {
  display:flex; justify-content:flex-end; padding:12px 0;
  font-size:12px; color:var(--cf-text-3, #64748b);
}

/* ---------- aba LOGS ---------- */
.origem-logs { display:flex; flex-direction:column; gap:12px; }
.origem-logs-head {
  display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap;
}
.origem-logs-filters { display:flex; gap:8px; flex-wrap:wrap; }
.origem-logs-stats { font-size:13px; color:var(--cf-text-2, #475569); }

.origem-logs-table { display:flex; flex-direction:column; }
.origem-logs-row {
  display:grid; grid-template-columns: 160px 130px 1fr 100px 110px;
  gap:8px; padding:10px 12px; border-bottom:1px solid var(--cf-border, #e2e8f0);
  font-size:13px; align-items:center;
}
.origem-logs-head-row {
  font-size:11px; font-weight:600; color:var(--cf-text-3, #64748b);
  text-transform:uppercase; letter-spacing:0.5px; background:#f8fafc;
}
.origem-logs-row:hover:not(.origem-logs-head-row) { background:#f8fafc; }
.origem-logs-empty { padding:32px; text-align:center; color:var(--cf-text-3, #64748b); }

.origem-logs-foot {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 0; flex-wrap:wrap; gap:8px;
}
.origem-pagination { display:flex; gap:8px; align-items:center; font-size:13px; }

/* ---------- modal de templates ---------- */
.origem-tpl-list { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:720px) { .origem-tpl-list { grid-template-columns:1fr; } }
.origem-tpl-card {
  text-align:left; padding:14px; background:#fff;
  border:1px solid var(--cf-border, #e2e8f0); border-radius:8px; cursor:pointer;
  display:flex; flex-direction:column; gap:6px;
  transition: border-color .15s;
}
.origem-tpl-card:hover { border-color:var(--cf-brand, #1E5BAA); }
.origem-tpl-name { font-size:14px; font-weight:600; color:var(--cf-text, #0f172a); }
.origem-tpl-desc { font-size:12px; color:var(--cf-text-3, #64748b); }
.origem-tpl-stats { font-size:11px; color:var(--cf-text-3, #94a3b8); }
.origem-tpl-sys { color:var(--cf-brand, #1E5BAA); font-weight:600; }

/* ============================================================
   PÁGINA DE LISTAGEM DE ORIGENS (tab-origens)
   ============================================================ */

.origens-page { display:flex; flex-direction:column; gap:16px; padding:8px 0; }

.origens-page-head {
  display:flex; justify-content:space-between; gap:12px; align-items:center;
  padding-bottom:12px; border-bottom:1px solid var(--cf-border, #e2e8f0);
  flex-wrap:wrap;
}
.origens-toolbar { display:flex; gap:8px; align-items:center; flex-wrap:wrap; flex:1; min-width:0; }
.origens-search {
  flex:1; min-width:200px; max-width:340px;
  padding:8px 12px; border:1px solid var(--cf-border, #e2e8f0); border-radius:8px;
  background:#fff; font-size:13px;
}
.origens-actions { display:flex; gap:8px; }

.origens-stats {
  display:grid; grid-template-columns:repeat(4, 1fr); gap:12px;
}
@media (max-width:720px) { .origens-stats { grid-template-columns:repeat(2, 1fr); } }
.origens-stat {
  display:flex; flex-direction:column; gap:4px; padding:14px 16px;
  background:#fff; border:1px solid var(--cf-border, #e2e8f0); border-radius:10px;
}
.origens-stat strong { font-size:24px; font-weight:600; color:var(--cf-text, #0f172a); font-family: 'IBM Plex Sans', sans-serif; }
.origens-stat span { font-size:12px; color:var(--cf-text-3, #64748b); }

.origens-list { display:flex; flex-direction:column; gap:16px; }
.origens-empty {
  padding:48px; text-align:center; background:#f8fafc; border-radius:10px;
  border:2px dashed var(--cf-border, #e2e8f0);
  display:flex; flex-direction:column; gap:12px; align-items:center;
}

.origens-group {
  background:#fff; border:1px solid var(--cf-border, #e2e8f0); border-radius:10px;
  overflow:hidden;
}
.origens-group-head {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px; background:#f8fafc;
  border-bottom:1px solid var(--cf-border, #e2e8f0);
  font-size:11px; font-weight:600; color:var(--cf-text-3, #64748b);
  text-transform:uppercase; letter-spacing:0.5px;
}
.origens-group-count {
  background:#e2e8f0; color:var(--cf-text-2, #475569);
  padding:2px 8px; border-radius:10px; font-size:11px;
}
.origens-group-body { display:flex; flex-direction:column; }

.origens-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px;
  border-bottom:1px solid #f1f5f9;
  gap:12px;
}
.origens-row:last-child { border-bottom:none; }
.origens-row:hover { background:#f8fafc; }
.origens-row-left { display:flex; gap:12px; align-items:center; flex:1; min-width:0; }
.origens-row-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.origens-row-info { display:flex; flex-direction:column; gap:2px; min-width:0; }
.origens-row-name {
  background:transparent; border:none; padding:0; cursor:pointer;
  font-size:14px; font-weight:500; color:var(--cf-text, #0f172a);
  text-align:left;
}
.origens-row-name:hover { color:var(--cf-brand, #1E5BAA); text-decoration:underline; }
.origens-row-meta {
  font-size:11px; color:var(--cf-text-3, #64748b);
  display:flex; gap:6px; align-items:center; flex-wrap:wrap;
}
.origens-row-right { display:flex; gap:6px; align-items:center; }
.origens-row-add {
  background:transparent; border:1px solid var(--cf-border, #e2e8f0);
  color:var(--cf-text-3, #64748b);
  padding:4px 10px; border-radius:4px; font-size:11px; cursor:pointer;
}
.origens-row-add:hover { border-color:var(--cf-brand, #1E5BAA); color:var(--cf-brand, #1E5BAA); }
.origens-row-menu {
  background:transparent; border:none; cursor:pointer; padding:4px 10px;
  color:var(--cf-text-3, #64748b); font-size:18px; line-height:1;
  border-radius:4px;
}
.origens-row-menu:hover { background:#e2e8f0; }

/* ---------- modal de detalhe webhook ---------- */
.webhook-detail { display:flex; flex-direction:column; gap:18px; }
.webhook-section { display:flex; flex-direction:column; gap:6px; }
.webhook-section-title {
  font-size:11px; font-weight:600; color:var(--cf-text-3, #64748b);
  text-transform:uppercase; letter-spacing:0.5px;
  cursor:pointer;
}
.webhook-status { display:flex; align-items:center; gap:8px; font-size:13px; }
.webhook-reason { color:var(--cf-text-3, #64748b); font-style:italic; }
.webhook-error, .webhook-actions, .webhook-json {
  background:#0f172a; color:#cbd5e1; padding:12px; border-radius:6px;
  font-family: 'IBM Plex Mono', monospace; font-size:12px;
  overflow-x:auto; max-height:400px; overflow-y:auto;
  white-space:pre-wrap; word-break:break-all;
}
.webhook-error { background:#7f1d1d; color:#fee2e2; }
