html,
body {
  font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: #111827;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

button,
input,
select,
textarea {
  font: inherit
}

h1,
h2,
h3,
h4,
h5,
h6 {
  letter-spacing: -.02em
}

:root {
  --primary: #2563eb;
  --border: #e2e8f0;
  --muted: #64748b;
  --radius: 1rem
}

.page-title {
  font-size: 1.875rem;
  font-weight: 800;
  letter-spacing: -.03em
}

.section-title {
  font-size: 1.125rem;
  font-weight: 800;
  margin-bottom: 1rem
}

.card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem
}

.input {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: .75rem;
  padding: .7rem .85rem;
  background: #fff;
  outline: none
}

.input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .12)
}

.label {
  display: block;
  font-size: .875rem;
  font-weight: 700;
  margin-bottom: .4rem;
  color: #334155
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: .75rem;
  background: var(--primary);
  color: #fff;
  font-weight: 700;
  padding: .65rem 1rem
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: .75rem;
  background: #fff;
  color: #0f172a;
  font-weight: 700;
  padding: .6rem .95rem
}

.nav-link {
  padding: .55rem .8rem;
  border-radius: .7rem;
  color: #334155
}

.nav-link:hover {
  background: #f1f5f9;
  color: #1d4ed8
}

.alert-success {
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #166534;
  border-radius: .9rem;
  padding: .85rem 1rem;
  margin-bottom: 1rem
}

.alert-error {
  border: 1px solid #fecaca;
  background: #fef2f2;
  color: #991b1b;
  border-radius: .9rem;
  padding: .85rem 1rem;
  margin-bottom: 1rem
}

.kanban {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(290px, 1fr);
  gap: 1rem;
  overflow-x: auto;
  padding-bottom: .5rem
}

.kanban-col {
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 1rem;
  padding: 0;
  min-height: 70vh
}

.kanban-list {
  min-height: 62vh;
  display: flex;
  flex-direction: column;
  gap: .75rem
}

.chip {
  border: 1px solid var(--border);
  background: #f8fafc;
  border-radius: 999px;
  padding: .35rem .55rem;
  color: #1d4ed8;
  font-weight: 700
}

.table {
  width: 100%;
  font-size: .9rem
}

.table th {
  text-align: left;
  color: #64748b;
  font-weight: 700;
  padding: .75rem;
  border-bottom: 1px solid var(--border)
}

.table td {
  padding: .75rem;
  border-bottom: 1px solid var(--border)
}

@media(max-width:768px) {
  .page-title {
    font-size: 1.5rem
  }

  .kanban {
    grid-auto-columns: 86vw
  }

  .card {
    padding: 1rem
  }
}

.status-badge {
  display: inline-flex;
  margin-top: .65rem;
  border-radius: 999px;
  padding: .25rem .55rem;
  font-size: .72rem;
  font-weight: 800
}

.status-em_andamento {
  background: #eff6ff;
  color: #1d4ed8
}

.status-perdida {
  background: #fef2f2;
  color: #b91c1c
}

.status-vendida {
  background: #f0fdf4;
  color: #15803d
}

.btn-mini {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: #0f172a;
  font-weight: 800;
  padding: .35rem .6rem
}

.btn-mini.danger {
  border-color: #fecaca;
  color: #b91c1c;
  background: #fff5f5
}

.btn-mini.success {
  border-color: #bbf7d0;
  color: #15803d;
  background: #f0fdf4
}

.log-box {
  border: 1px solid var(--border);
  border-radius: .9rem;
  background: #f8fafc;
  max-height: 320px;
  overflow: auto;
  padding: .75rem
}

.log-item {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: .75rem;
  padding: .75rem;
  margin-bottom: .6rem
}

.log-item:last-child {
  margin-bottom: 0
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  margin-top: .75rem;
  font-size: .78rem
}

.contact-text {
  color: #475569;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .32rem .55rem;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis
}

.icon-btn {
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
  color: #1d4ed8;
  font-weight: 800
}

.icon-btn:hover {
  background: #eff6ff;
  border-color: #bfdbfe
}

.card-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .5rem;
  margin-top: .85rem
}

.detail-contact {
  justify-content: flex-start;
  margin-top: 0
}

.table form {
  margin: 0
}

@media(max-width:768px) {
  .detail-contact {
    justify-content: center
  }

  .contact-text {
    max-width: 72vw
  }
}

.deal-mid-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-top: .75rem
}

.deal-amount {
  font-size: 1.1rem;
  line-height: 1.2;
  font-weight: 900;
  color: #0f172a
}

.card-contact-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-start;
  gap: .35rem;
  margin-top: -.25rem
}

.icon-btn-lg {
  width: 2.25rem;
  height: 2.25rem;
  font-size: 1.05rem
}

.deal-card-footer {
  border-top: 1px solid var(--border);
  margin-top: .75rem;
  padding-top: .65rem;
  color: #64748b;
  font-size: .75rem;
  line-height: 1.35
}

.deal-card-footer p {
  margin: .1rem 0
}

/* v12 - filtros do funil recolhidos por padrao */
.filter-card {
  padding: 1.1rem 1.25rem
}

.filter-panel {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border)
}

.filter-toggle-btn {
  white-space: nowrap
}

.input-search-wide {
  min-height: 3rem
}

@media(max-width:768px) {
  .filter-card>.flex {
    align-items: flex-start;
    flex-direction: column
  }

  .filter-toggle-btn {
    width: 100%
  }

  .filter-panel {
    width: 100%
  }
}


/* v15 - destaque da empresa e contato logo abaixo */
.deal-company {
  font-size: .98rem;
  font-weight: 800;
  color: #0f172a;
  margin-top: .35rem;
  line-height: 1.25
}

.deal-contact-name {
  font-size: .82rem;
  color: #64748b;
  margin-top: .12rem;
  line-height: 1.25
}


/* v16 - ajuste do card: contato menor e detalhes alinhado a direita */
.deal-contact-name {
  font-size: .75rem !important;
  color: #64748b;
  margin-top: .12rem;
  line-height: 1.35
}

.deal-card .flex.justify-between {
  align-items: flex-start;
  padding-right: 0 !important
}

.deal-detail-link {
  margin-left: auto;
  text-align: right;
  color: #1d4ed8;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .02em;
  line-height: 1.2
}

.deal-detail-link:hover {
  text-decoration: underline
}


/* v17 - funil em largura total controlada pelo layout atual */
.pipeline-kanban-full {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
  box-sizing: border-box;
}

.pipeline-kanban-full .kanban {
  width: 100%;
  padding: 0;
}

/* v15 - menu configuracoes e notificacoes */
.nav-icon-link {
  position: relative;
  width: 2.35rem;
  height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: .8rem;
  background: #fff;
  color: #334155;
  font-size: 1.05rem;
  line-height: 1;
  text-decoration: none;
  transition: background .18s ease, border-color .18s ease, color .18s ease
}

.nav-icon-link:hover {
  background: #f1f5f9;
  border-color: #bfdbfe;
  color: #1d4ed8
}

.nav-notification-badge {
  position: absolute;
  right: -.35rem;
  top: -.35rem;
  min-width: 1.15rem;
  height: 1.15rem;
  padding: 0 .28rem;
  border-radius: 999px;
  background: #ef4444;
  color: #fff;
  border: 2px solid #fff;
  font-size: .68rem;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center
}

.nav-settings {
  position: relative;
  display: inline-flex
}

.nav-settings-menu {
  position: absolute;
  right: 0;
  top: calc(100% + .45rem);
  min-width: 13rem;
  padding: .45rem;
  border: 1px solid var(--border);
  border-radius: .95rem;
  background: #fff;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .14);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-.25rem);
  pointer-events: none;
  z-index: 60;
  transition: opacity .2s ease .45s, transform .2s ease .45s, visibility 0s linear .65s
}

.nav-settings:hover .nav-settings-menu,
.nav-settings:focus-within .nav-settings-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
  transition-delay: 0s
}

.nav-settings-menu:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -.65rem;
  height: .65rem
}

.nav-settings-menu a {
  display: block;
  padding: .65rem .75rem;
  border-radius: .7rem;
  color: #334155;
  font-weight: 700;
  white-space: nowrap
}

.nav-settings-menu a:hover {
  background: #f1f5f9;
  color: #1d4ed8
}

/* v15 - timeline de etapas */
.stage-create-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 180px auto;
  align-items: end;
  gap: 1rem
}

.stage-create-actions {
  display: flex;
  align-items: end
}

.stage-timeline {
  display: flex;
  align-items: stretch;
  gap: 1rem;
  overflow-x: auto;
  padding: .35rem .1rem 1rem;
  scroll-snap-type: x proximity
}

.stage-card {
  position: relative;
  flex: 0 0 280px;
  background: #fff;
  border: 1px solid var(--border);
  border-top: 6px solid var(--primary);
  border-radius: 1rem;
  padding: 1rem;
  scroll-snap-align: start;
  box-shadow: 0 1px 2px rgba(15, 23, 42, .04)
}

.stage-order-card {
  cursor: grab
}

.stage-order-card:active {
  cursor: grabbing
}

.stage-card.dragging {
  opacity: .55;
  transform: scale(.985)
}

.stage-card.drag-over {
  border-color: #93c5fd;
  background: #eff6ff
}

.stage-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: 1rem
}

.stage-drag-handle {
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #f8fafc;
  color: #64748b;
  font-weight: 900;
  cursor: grab;
  flex: 0 0 auto
}

.stage-position {
  font-size: .78rem;
  font-weight: 900;
  color: #0f172a;
  text-align: right
}

.stage-deal-count {
  font-size: .72rem;
  color: #64748b;
  text-align: right
}

.stage-color-input {
  height: 2.75rem;
  padding: .35rem
}

.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fecaca;
  background: #fff1f2;
  color: #be123c;
  font-weight: 800;
  border-radius: .75rem;
  padding: .7rem 1rem;
  transition: .15s
}

.btn-danger:hover {
  background: #ffe4e6;
  border-color: #fda4af
}

@media(max-width:768px) {
  .stage-create-form {
    grid-template-columns: 1fr
  }

  .stage-card {
    flex-basis: 82vw
  }

  .nav-settings-menu {
    right: -.5rem
  }
}

/* v18 - totais do funil e usuario logado */
.stage-total-card {
  margin-top: .5rem;
  border: 1px solid var(--border);
  border-radius: .85rem;
  background: #fff;
  padding: .8rem .85rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  min-height: 3.75rem
}

.stage-total-amount {
  font-weight: 900;
  color: #0f172a;
  font-size: 1rem;
  line-height: 1.15;
  white-space: nowrap
}

.stage-total-count {
  font-size: .78rem;
  color: #64748b;
  line-height: 1.2;
  text-align: right;
  white-space: nowrap
}

.logged-user-name {
  font-weight: 600;
  color: #0f172a;
  cursor: help
}

@media(max-width:768px) {
  .stage-total-card {
    align-items: flex-start;
    flex-direction: column;
    gap: .25rem
  }

  .stage-total-count {
    text-align: left
  }
}


/* v19 - etapas minimalistas e formularios compactos */
.stage-create-card,
.stage-list-card {
  max-width: 1180px;
  margin-left: auto;
  margin-right: auto
}

.stage-create-card {
  max-width: 760px
}

.stage-create-form-min {
  grid-template-columns: minmax(260px, 1fr) 110px auto
}

.stage-list-card {
  overflow: hidden
}

.stage-save-status {
  font-size: .78rem;
  font-weight: 800;
  color: #64748b;
  min-height: 1.2rem
}

.stage-line {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 0;
  overflow-x: auto;
  padding: 1.1rem .4rem 1.4rem;
  scroll-snap-type: x proximity
}

.stage-line:before {
  content: "";
  position: absolute;
  left: 1.6rem;
  right: 1.6rem;
  top: 2.05rem;
  height: 3px;
  background: #38bdf8;
  border-radius: 999px
}

.stage-node {
  position: relative;
  flex: 0 0 220px;
  padding-top: 2.05rem;
  scroll-snap-align: start;
  cursor: grab
}

.stage-node:active {
  cursor: grabbing
}

.stage-node.dragging {
  opacity: .62
}

.stage-node.drag-over .stage-node-body {
  border-color: #93c5fd;
  background: #f8fbff
}

.stage-dot {
  position: absolute;
  left: 0;
  top: .62rem;
  width: 2.85rem;
  height: 2.85rem;
  border-radius: 999px;
  background: var(--stage-color, #2563eb);
  border: 5px solid #fff;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, .08);
  z-index: 2
}

.stage-node-body {
  margin-right: 1.2rem;
  border: 1px solid transparent;
  border-radius: .9rem;
  padding: .75rem .7rem .8rem;
  background: #fff;
  transition: .15s
}

.stage-node-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  margin-bottom: .25rem
}

.stage-position {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #94a3b8;
  font-weight: 900;
  text-align: left
}

.stage-delete-btn {
  border: 0;
  background: transparent;
  color: #94a3b8;
  border-radius: .55rem;
  padding: .15rem .25rem;
  font-size: .9rem;
  line-height: 1
}

.stage-delete-btn:hover {
  background: #fff1f2;
  color: #be123c
}

.stage-inline-form {
  display: block;
  margin: 0
}

.stage-name-display {
  display: block;
  width: 100%;
  border: 0;
  background: transparent;
  text-align: left;
  padding: .15rem 0;
  color: #334155;
  font-weight: 900;
  line-height: 1.25;
  min-height: 2.15rem
}

.stage-name-display:hover {
  color: #1d4ed8
}

.stage-name-input {
  display: none;
  width: 100%;
  border: 1px solid #bfdbfe;
  border-radius: .6rem;
  padding: .45rem .5rem;
  font-weight: 800;
  color: #0f172a;
  outline: none
}

.stage-node.editing .stage-name-display {
  display: none
}

.stage-node.editing .stage-name-input {
  display: block
}

.stage-meta {
  font-size: .78rem;
  color: #94a3b8;
  font-weight: 700;
  margin-top: .25rem
}

.stage-color-row {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-top: .75rem;
  color: #64748b;
  font-size: .76rem;
  font-weight: 800
}

.stage-color-mini {
  width: 2.25rem;
  height: 1.55rem;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer
}

.stage-delete-form {
  display: none
}

.form-compact,
form.card.grid {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto
}

.form-compact-narrow {
  max-width: 720px
}

.card form:not(.stage-inline-form):not(.stage-delete-form) {
  max-width: 100%
}

@media(max-width:768px) {
  .stage-create-form-min {
    grid-template-columns: 1fr
  }

  .stage-node {
    flex-basis: 190px
  }

  .stage-line:before {
    left: 1.4rem;
    right: 1.4rem
  }

  .form-compact,
  form.card.grid {
    max-width: 100%
  }
}

/* Ajustes timeline etapas: largura quase total e marcadores menores */
.stage-list-card {
  max-width: none;
  width: calc(100vw - 50px);
  margin-left: calc(50% - 50vw + 25px);
  margin-right: calc(50% - 50vw + 25px);
}

.stage-line {
  padding: 1rem 1.1rem 1.25rem;
}

.stage-line:before {
  left: 2rem;
  right: 2rem;
  top: 1.85rem;
  height: 2px;
}

.stage-node {
  flex: 1 0 190px;
  min-width: 190px;
  padding-top: 1.85rem;
}

.stage-dot {
  left: .18rem;
  top: .72rem;
  width: 2.25rem;
  height: 2.25rem;
  border-width: 4px;
}

.stage-node-body {
  margin-right: 1rem;
  padding: .65rem .55rem .75rem;
}

@media(max-width:768px) {
  .stage-list-card {
    width: calc(100vw - 24px);
    margin-left: calc(50% - 50vw + 12px);
    margin-right: calc(50% - 50vw + 12px);
  }

  .stage-node {
    flex-basis: 180px;
    min-width: 180px
  }
}

/* Ajustes finos timeline etapas: linha completa, bolinhas reposicionadas e cards separados */
.stage-line {
  --stage-node-w: 190px;
  padding: 1.2rem 0 1.35rem;
}

.stage-line:before {
  left: 0;
  right: auto;
  top: 38px;
  width: max(100%, calc(var(--stage-count, 1) * var(--stage-node-w)));
  height: 2px;
}

.stage-node {
  flex: 1 0 var(--stage-node-w);
  min-width: var(--stage-node-w);
  padding-top: 2.1rem;
}

.stage-dot {
  left: 5.85rem;
  top: .4rem;
  width: 2.25rem;
  height: 2.25rem;
  border-width: 4px;
}

.stage-node-body {
  margin: .15rem .6rem 0 .6rem;
  border: 1px solid #e2e8f0;
  border-radius: .85rem;
  padding: .75rem .7rem .8rem;
  background: #fff;
}

.stage-node:hover .stage-node-body {
  border-color: #cbd5e1;
}

@media(max-width:768px) {
  .stage-line {
    --stage-node-w: 180px;
  }

  .stage-dot {
    left: 5.15rem;
  }
}

/* v20 - empresas e autocomplete */
.company-table .table-input {
  min-width: 8rem;
  padding: .5rem .6rem;
  font-size: .82rem
}

.company-table td {
  vertical-align: top
}

.text-uppercase {
  text-transform: uppercase
}

.autocomplete-box {
  position: absolute;
  z-index: 70;
  left: 0;
  right: 0;
  top: 100%;
  margin-top: .35rem;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: .9rem;
  box-shadow: 0 14px 30px rgba(15, 23, 42, .14);
  overflow: hidden
}

.autocomplete-item {
  display: grid;
  grid-template-columns: 6.5rem 1fr auto;
  gap: .75rem;
  width: 100%;
  text-align: left;
  align-items: center;
  padding: .8rem .9rem;
  border: 0;
  background: #fff;
  color: #334155
}

.autocomplete-item:hover {
  background: #eff6ff
}

.autocomplete-item strong {
  font-weight: 900;
  color: #1d4ed8
}

.autocomplete-item span {
  font-weight: 800;
  color: #0f172a
}

.autocomplete-item small {
  color: #64748b
}

.autocomplete-empty {
  padding: .85rem .95rem;
  color: #64748b;
  font-weight: 700
}

.deal-company-field {
  z-index: 10
}

@media(max-width:768px) {
  .autocomplete-item {
    grid-template-columns: 1fr
  }

  .company-table .table-input {
    min-width: 10rem
  }
}

/* ================================
   FASE 3 - Modais SaaS + CRUD compacto
   ================================ */
.crm-page-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px
}

.crm-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px
}

.crm-modal.hidden {
  display: none
}

.crm-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 10, 22, .68);
  backdrop-filter: blur(8px);
  animation: crmFade .16s ease-out
}

.crm-modal-panel {
  position: relative;
  width: min(760px, calc(100vw - 28px));
  max-height: calc(100dvh - 34px);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: var(--panel);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .38);
  overflow: hidden;
  animation: crmPop .18s ease-out
}

.crm-modal-panel.crm-modal-xl {
  width: min(1120px, calc(100vw - 28px))
}

.crm-modal-header {
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255, 255, 255, .05), transparent)
}

.crm-modal-kicker {
  display: block;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted)
}

.crm-modal-header h2 {
  margin: 1px 0 0;
  font-size: 15px;
  font-weight: 800;
  color: var(--text)
}

.crm-modal-close {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  cursor: pointer
}

.crm-modal-close:hover {
  filter: brightness(1.08)
}

.crm-modal-body {
  overflow: auto;
  padding: 16px
}

.crm-modal-body .crm-topbar,
.crm-modal-body .crm-sidebar,
.crm-modal-body .pipeline-toolbar,
.crm-modal-body .crm-alert {
  display: none !important
}

.crm-modal-body .crm-main {
  padding: 0 !important;
  overflow: visible !important
}

.crm-modal-body .page-title {
  font-size: 18px;
  margin-bottom: 8px
}

.crm-modal-body .card {
  box-shadow: none;
  border-color: var(--border);
  background: var(--card)
}

.crm-modal-body .form-grid,
.crm-modal-body form.grid {
  gap: 10px
}

.crm-modal-body textarea.input {
  min-height: 82px
}

.crm-modal-form {
  display: block
}

.crm-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px
}

.crm-span-2 {
  grid-column: span 2/span 2
}

.crm-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--border)
}

.crm-readonly {
  display: flex;
  align-items: center;
  background: var(--input-bg, var(--card));
  opacity: .86
}

.crm-compact-form .input,
.crm-modal-body .input {
  min-height: 34px;
  font-size: 12px
}

.crm-compact-form .label,
.crm-modal-body .label {
  font-size: 10px;
  margin-bottom: 4px
}

.crm-modal-loading {
  display: grid;
  place-items: center;
  min-height: 180px;
  color: var(--muted);
  font-weight: 700
}

.crm-modal-error {
  padding: 14px;
  border: 1px solid rgba(239, 68, 68, .35);
  border-radius: 14px;
  background: rgba(239, 68, 68, .12);
  color: #ef4444
}

.table.company-table {
  font-size: 12px
}

.company-table th,
.company-table td {
  padding: 8px 7px
}

.table-input {
  min-width: 106px;
  height: 32px
}

.deal-detail-link[data-crm-modal] {
  cursor: pointer
}

@keyframes crmFade {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@keyframes crmPop {
  from {
    opacity: 0;
    transform: translateY(10px) scale(.985)
  }

  to {
    opacity: 1;
    transform: none
  }
}

@media(max-width:860px) {
  .crm-modal {
    padding: 8px;
    align-items: flex-end
  }

  .crm-modal-panel,
  .crm-modal-panel.crm-modal-xl {
    width: 100%;
    max-height: calc(100dvh - 16px);
    border-radius: 20px 20px 0 0
  }

  .crm-form-grid {
    grid-template-columns: 1fr
  }

  .crm-span-2 {
    grid-column: auto
  }

  .crm-page-head {
    align-items: stretch;
    flex-direction: column
  }

  .crm-page-head .btn-primary {
    width: 100%
  }
}


/* ================================
   FASE 8 - Dashboard executivo + alertas auto dismiss
   ================================ */
.crm-alert {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 12px 0;
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .08);
  transition: opacity .22s ease, transform .22s ease, max-height .22s ease, margin .22s ease, padding .22s ease;
  max-height: 80px;
  overflow: hidden
}

.crm-alert.is-hiding {
  opacity: 0;
  transform: translateY(-6px);
  max-height: 0;
  margin: 0;
  padding-top: 0;
  padding-bottom: 0
}

.crm-alert-close {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  border: 1px solid currentColor;
  border-radius: 999px;
  background: transparent;
  color: inherit;
  opacity: .65;
  line-height: 1;
  font-size: 16px;
  cursor: pointer
}

.crm-alert-close:hover {
  opacity: 1
}

.crm-modal-body .crm-alert {
  display: none !important
}

.exec-dashboard {
  display: flex;
  flex-direction: column;
  gap: 14px
}

.exec-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(37, 99, 235, .14), rgba(14, 165, 233, .04)), var(--panel, var(--card));
  box-shadow: 0 12px 34px rgba(15, 23, 42, .08)
}

.exec-kicker {
  display: inline-flex;
  margin-bottom: 6px;
  color: var(--primary);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .14em
}

.exec-hero h1 {
  margin: 0;
  font-size: 25px;
  line-height: 1.1;
  color: var(--text, #0f172a);
  font-weight: 900
}

.exec-hero p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 12px
}

.exec-hero-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap
}

.exec-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px
}

.exec-kpi {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--card);
  padding: 14px;
  min-height: 104px;
  display: flex;
  flex-direction: column;
  justify-content: space-between
}

.exec-kpi span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em
}

.exec-kpi strong {
  display: block;
  color: var(--text, #0f172a);
  font-size: 23px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.04em
}

.exec-kpi small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700
}

.exec-kpi.is-blue strong {
  color: #2563eb
}

.exec-kpi.is-green strong {
  color: #16a34a
}

.exec-kpi.is-red strong {
  color: #dc2626
}

.exec-grid {
  display: grid;
  gap: 12px
}

.exec-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr))
}

.exec-grid-2 {
  grid-template-columns: 1fr 1fr
}

.exec-card {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--card);
  padding: 14px;
  min-width: 0
}

.exec-card-large {
  padding: 16px
}

.exec-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px
}

.exec-card-head h2 {
  margin: 0;
  color: var(--text, #0f172a);
  font-size: 14px;
  font-weight: 900
}

.exec-card-head p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 11px
}

.exec-card-head span,
.exec-card-head a {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(37, 99, 235, .08);
  color: var(--primary);
  font-size: 11px;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap
}

.exec-muted {
  color: var(--muted);
  font-size: 12px;
  margin: 0
}

.exec-progress,
.exec-bar {
  height: 9px;
  border-radius: 999px;
  background: rgba(148, 163, 184, .18);
  overflow: hidden
}

.exec-progress i,
.exec-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2563eb, #22c55e)
}

.exec-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px
}

.exec-split div,
.exec-mini-list div {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px;
  background: rgba(148, 163, 184, .06)
}

.exec-split small,
.exec-mini-list span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800
}

.exec-split b,
.exec-mini-list b {
  display: block;
  margin-top: 3px;
  color: var(--text, #0f172a);
  font-size: 15px;
  font-weight: 900
}

.exec-mini-list {
  display: grid;
  gap: 8px
}

.exec-bars {
  display: grid;
  gap: 10px
}

.exec-bar-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 5px;
  font-size: 12px
}

.exec-bar-label span {
  color: var(--muted);
  font-weight: 800
}

.exec-bar-label b {
  color: var(--text, #0f172a);
  font-weight: 900
}

.exec-stage-list,
.exec-return-list {
  display: grid;
  gap: 8px
}

.exec-stage-item,
.exec-return-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px;
  background: rgba(148, 163, 184, .05)
}

.exec-stage-item b,
.exec-return-item b {
  display: block;
  color: var(--text, #0f172a);
  font-size: 12px;
  font-weight: 900
}

.exec-stage-item small,
.exec-return-item small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  margin-top: 2px
}

.exec-stage-item strong,
.exec-return-item span {
  color: var(--text, #0f172a);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap
}

@media(max-width:1180px) {
  .exec-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }

  .exec-grid-3,
  .exec-grid-2 {
    grid-template-columns: 1fr
  }
}

@media(max-width:720px) {
  .exec-hero {
    align-items: stretch;
    flex-direction: column
  }

  .exec-hero-actions .btn-primary,
  .exec-hero-actions .btn-outline {
    width: 100%
  }

  .exec-kpi-grid {
    grid-template-columns: 1fr
  }

  .exec-stage-item,
  .exec-return-item {
    align-items: flex-start;
    flex-direction: column
  }

  .exec-stage-item strong,
  .exec-return-item span {
    white-space: normal
  }

  .exec-hero h1 {
    font-size: 22px
  }
}

[data-theme="dark"] .exec-kpi,
[data-theme="dark"] .exec-card {
  background: var(--card);
  border-color: var(--border)
}

[data-theme="dark"] .exec-hero {
  background: linear-gradient(135deg, rgba(59, 130, 246, .16), rgba(14, 165, 233, .05)), var(--panel)
}

[data-theme="dark"] .exec-split div,
[data-theme="dark"] .exec-mini-list div,
[data-theme="dark"] .exec-stage-item,
[data-theme="dark"] .exec-return-item {
  background: rgba(255, 255, 255, .035)
}

/* ================================
   FASE 9.1 - Agenda completa, tarefas e follow-up
   ================================ */
.kanban-col {
  padding: 0 !important;
  overflow: hidden
}

.kanban-col-header {
  padding: 22px 24px 14px
}

.kanban-list {
  padding: 12px 22px 22px
}

.phase91-head {
  align-items: center
}

.phase91-kicker {
  display: inline-flex;
  margin-bottom: 6px;
  color: var(--primary);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .14em
}

.phase91-kpis {
  grid-template-columns: repeat(4, minmax(0, 1fr))
}

.followup-kpi.is-warning strong {
  color: #f59e0b
}

.phase91-grid {
  display: grid;
  gap: 14px;
  margin-top: 14px
}

.phase91-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr))
}

.phase91-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr))
}

.phase91-panel {
  min-width: 0
}

.phase91-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px
}

.phase91-list {
  display: grid;
  gap: 8px
}

.phase91-list.compact {
  max-height: 330px;
  overflow: auto
}

.phase91-note,
.phase91-card-link,
.phase91-productivity,
.phase91-day {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(148, 163, 184, .06);
  padding: 10px
}

.phase91-note b,
.phase91-card-link b,
.phase91-productivity b {
  display: block;
  color: var(--text);
  font-size: 12px;
  font-weight: 900
}

.phase91-note span,
.phase91-card-link span,
.phase91-productivity span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
  margin-top: 2px
}

.phase91-note small,
.phase91-card-link small {
  display: block;
  color: var(--muted);
  font-size: 10px;
  margin-top: 4px
}

.phase91-card-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px
}

.phase91-card-link a {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 9px;
  text-decoration: none;
  color: var(--primary);
  font-size: 11px;
  font-weight: 900;
  background: rgba(37, 99, 235, .08)
}

.phase91-productivity {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center
}

.phase91-productivity div {
  display: flex;
  gap: 6px;
  flex-wrap: wrap
}

.phase91-productivity div span {
  display: inline-flex;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 7px;
  margin: 0;
  background: var(--card)
}

.phase91-productivity strong {
  font-size: 12px;
  color: #16a34a
}

.phase91-calendar {
  display: grid;
  gap: 8px
}

.phase91-day {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 10px;
  align-items: start
}

.phase91-day strong {
  color: var(--primary);
  font-size: 13px
}

.phase91-day span {
  display: block;
  color: var(--text);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
  padding: 2px 0
}

.deal-activity-strip {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px
}

.deal-activity-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 3px 6px;
  background: rgba(148, 163, 184, .08);
  color: var(--muted);
  font-size: 10px;
  font-weight: 800
}

.deal-activity-pill.is-danger {
  background: rgba(239, 68, 68, .1);
  border-color: rgba(239, 68, 68, .25);
  color: #ef4444
}

.deal-activity-pill.is-primary {
  background: rgba(37, 99, 235, .1);
  border-color: rgba(37, 99, 235, .22);
  color: var(--primary)
}

@media(max-width:1180px) {

  .phase91-grid-3,
  .phase91-grid-2,
  .phase91-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }
}

@media(max-width:720px) {

  .phase91-grid-3,
  .phase91-grid-2,
  .phase91-kpis,
  .phase91-form-row {
    grid-template-columns: 1fr
  }

  .phase91-card-link,
  .phase91-productivity {
    display: block
  }

  .phase91-productivity strong {
    display: block;
    margin-top: 8px
  }

  .phase91-day {
    grid-template-columns: 1fr
  }
}

[data-theme="dark"] .phase91-note,
[data-theme="dark"] .phase91-card-link,
[data-theme="dark"] .phase91-productivity,
[data-theme="dark"] .phase91-day {
  background: rgba(255, 255, 255, .035)
}


/* FASE 10 - WhatsApp CRM */
.whatsapp-screen .whatsapp-hero {
  align-items: center;
  background: linear-gradient(135deg, var(--panel), rgba(37, 99, 235, .08));
}

.whatsapp-disabled {
  border-color: rgba(245, 158, 11, .35);
  background: rgba(245, 158, 11, .08);
  margin-bottom: 1rem;
}

.whatsapp-kpis {
  margin: 1rem 0;
}

.whatsapp-grid {
  gap: 1rem;
  align-items: start;
}

.crm-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.stack-list {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  max-height: 520px;
  overflow: auto;
  padding-right: .25rem;
}

.mini-row,
.template-row {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  align-items: flex-start;
  border: 1px solid var(--border);
  background: var(--muted-panel, var(--panel-soft));
  border-radius: 16px;
  padding: .85rem;
}

.mini-row strong,
.template-row strong {
  display: block;
  color: var(--text);
  font-weight: 800;
  font-size: .92rem;
}

.mini-row small,
.template-row small {
  display: block;
  color: var(--muted);
  font-size: .78rem;
  margin-top: .12rem;
}

.template-row p {
  color: var(--text-soft, var(--muted));
  font-size: .82rem;
  line-height: 1.45;
  margin: .45rem 0 0;
}

.btn-mini {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: rgba(37, 99, 235, .12);
  border: 1px solid rgba(37, 99, 235, .24);
  color: var(--primary);
  font-weight: 800;
  font-size: .78rem;
  white-space: nowrap;
}

.btn-mini.danger {
  color: #dc2626;
  background: rgba(220, 38, 38, .1);
  border-color: rgba(220, 38, 38, .22);
}

.timeline-list {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  max-height: 620px;
  overflow: auto;
  padding-left: .25rem;
}

.timeline-item {
  position: relative;
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: .65rem;
}

.timeline-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, .12);
  margin-top: .35rem;
}

.timeline-item strong {
  font-weight: 800;
  color: var(--text);
}

.timeline-item small {
  display: block;
  color: var(--muted);
  font-size: .78rem;
  margin: .15rem 0 .3rem;
}

.timeline-item p {
  font-size: .86rem;
  color: var(--text-soft, var(--muted));
  line-height: 1.45;
  margin: 0;
}

.inline-check {
  display: flex;
  gap: .5rem;
  align-items: center;
  font-size: .86rem;
  color: var(--text);
  font-weight: 700;
}

.settings-options {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
}

.icon-btn.whatsapp-btn {
  color: #16a34a;
  background: rgba(22, 163, 74, .12);
  border-color: rgba(22, 163, 74, .25);
}

@media(max-width:980px) {
  .crm-grid-2 {
    grid-template-columns: 1fr
  }

  .whatsapp-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ================================
   FASE 10.1 - WhatsApp chat + configuracoes corrigidas
   ================================ */
.phase101-settings,
.phase101-whatsapp {
  display: flex;
  flex-direction: column;
  gap: 14px
}

.settings-hero,
.whatsapp-hero.clean {
  border-radius: 0;
  background: transparent;
  border: 0;
  padding: 0 0 8px 0;
  box-shadow: none
}

.settings-status-card {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--card);
  padding: 10px 12px
}

.settings-status-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800
}

.settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 14px;
  align-items: start
}

.settings-layout .settings-panel {
  grid-column: 1/2
}

.settings-panel {
  padding: 16px;
  border-radius: 18px
}

.settings-section-head.clean {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .06);
  padding: 14px;
  margin-bottom: 14px
}

.settings-option-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px
}

.option-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .05);
  padding: 12px;
  cursor: pointer
}

.option-card input {
  margin-top: 3px
}

.option-card b {
  display: block;
  color: var(--text);
  font-size: 12px;
  font-weight: 900
}

.option-card small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
  margin-top: 3px
}

.settings-actions-bar {
  grid-column: 2/3;
  grid-row: 1/span 3;
  position: sticky;
  top: 76px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--card);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08)
}

.settings-actions-bar strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 900
}

.settings-actions-bar span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  margin-top: 3px
}

.settings-actions-bar .btn-primary {
  width: 100%
}

.whatsapp-hero-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap
}

.wa-notice-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(245, 158, 11, .35);
  border-radius: 18px;
  background: rgba(245, 158, 11, .08);
  padding: 14px 16px
}

.wa-notice-card strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 900
}

.wa-notice-card p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px
}

.wa-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px
}

.wa-kpi {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--card);
  padding: 14px;
  min-height: 98px;
  display: flex;
  flex-direction: column;
  justify-content: space-between
}

.wa-kpi span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .07em
}

.wa-kpi strong {
  color: var(--primary);
  font-size: 24px;
  font-weight: 950;
  letter-spacing: -.04em
}

.wa-kpi small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700
}

.wa-chat-shell {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr) 320px;
  gap: 14px;
  align-items: start
}

.wa-panel,
.wa-card {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: var(--card);
  padding: 16px;
  min-width: 0
}

.wa-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px
}

.wa-panel-head h2 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
  font-weight: 950;
  letter-spacing: -.02em
}

.wa-panel-head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35
}

.wa-panel-head>span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(37, 99, 235, .08);
  color: var(--primary);
  font-size: 11px;
  font-weight: 900;
  padding: 0 8px
}

.wa-list {
  display: grid;
  gap: 9px
}

.wa-list.compact {
  max-height: 375px;
  overflow: auto;
  padding-right: 2px
}

.wa-conversation-card {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .05);
  padding: 10px
}

.wa-conversation-card.is-unassigned {
  border-color: rgba(37, 99, 235, .28);
  background: rgba(37, 99, 235, .06)
}

.wa-avatar {
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #2563eb, #7c3aed);
  color: #fff;
  font-weight: 950
}

.wa-conversation-main {
  min-width: 0
}

.wa-conversation-main strong {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text);
  font-size: 12px;
  font-weight: 950
}

.wa-conversation-main small,
.wa-conversation-main span {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--muted);
  font-size: 10.5px;
  font-weight: 700;
  margin-top: 2px
}

.wa-compose-form {
  gap: 11px
}

.wa-compose-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap
}

.wa-mini-deal {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .05);
  padding: 10px
}

.wa-mini-deal strong {
  display: block;
  color: var(--text);
  font-size: 12px;
  font-weight: 950
}

.wa-mini-deal span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  margin-top: 3px
}

.wa-mini-deal a {
  display: inline-flex;
  margin-top: 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 9px;
  text-decoration: none;
  color: var(--primary);
  font-size: 11px;
  font-weight: 900;
  background: rgba(37, 99, 235, .08)
}

.wa-bottom-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px
}

.wa-table-list,
.wa-template-list {
  display: grid;
  gap: 9px
}

.wa-table-list article,
.wa-template-list article {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .05);
  padding: 10px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px
}

.wa-table-list strong,
.wa-template-list strong {
  display: block;
  color: var(--text);
  font-size: 12px;
  font-weight: 950
}

.wa-table-list small,
.wa-template-list small {
  display: block;
  color: var(--muted);
  font-size: 10.5px;
  margin-top: 2px
}

.wa-table-list p,
.wa-template-list p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35
}

.wa-table-list span {
  display: inline-flex;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(148, 163, 184, .07);
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase
}

.wa-template-form {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .05);
  padding: 12px;
  margin-bottom: 12px
}

.wa-timeline {
  max-height: 480px;
  overflow: auto;
  padding-right: 2px
}

.btn-mini[disabled],
.btn-primary[disabled] {
  opacity: .55;
  cursor: not-allowed
}

body[data-theme="dark"] .settings-section-head.clean,
body[data-theme="dark"] .option-card,
body[data-theme="dark"] .wa-conversation-card,
body[data-theme="dark"] .wa-mini-deal,
body[data-theme="dark"] .wa-table-list article,
body[data-theme="dark"] .wa-template-list article,
body[data-theme="dark"] .wa-template-form {
  background: rgba(255, 255, 255, .035)
}

body[data-theme="dark"] .wa-notice-card {
  background: rgba(245, 158, 11, .09)
}

@media(max-width:1280px) {
  .wa-chat-shell {
    grid-template-columns: 1fr 1fr
  }

  .wa-compose-panel {
    grid-column: 1/-1;
    grid-row: 1
  }

  .wa-bottom-grid {
    grid-template-columns: 1fr
  }

  .settings-layout {
    grid-template-columns: 1fr
  }

  .settings-actions-bar {
    position: static;
    grid-column: 1;
    grid-row: auto
  }
}

@media(max-width:820px) {

  .wa-kpi-grid,
  .settings-option-grid {
    grid-template-columns: 1fr
  }

  .wa-chat-shell {
    grid-template-columns: 1fr
  }

  .wa-conversation-card {
    grid-template-columns: 38px 1fr
  }

  .wa-conversation-card form {
    grid-column: 1/-1
  }

  .wa-panel,
  .wa-card,
  .settings-panel {
    padding: 12px
  }

  .wa-notice-card,
  .whatsapp-hero-actions {
    align-items: stretch;
    flex-direction: column
  }

  .wa-notice-card .btn-mini,
  .whatsapp-hero-actions .btn-outline {
    width: 100%;
    justify-content: center
  }
}

/* FASE 10.2 - Evolution API */
.inline-form {
  display: inline-flex;
  margin: 0
}

.wa-api-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: var(--card);
  padding: 16px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, .05)
}

.wa-api-card h2 {
  margin: 2px 0 4px;
  color: var(--text);
  font-size: 16px;
  font-weight: 950;
  letter-spacing: -.03em
}

.wa-api-card p {
  margin: 0;
  color: var(--muted);
  font-size: 12px
}

.wa-api-card small {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: 11px
}

.wa-api-card code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 2px 6px;
  background: rgba(148, 163, 184, .08);
  color: var(--text)
}

.wa-api-status {
  min-width: 180px;
  border: 1px solid rgba(239, 68, 68, .28);
  border-radius: 16px;
  background: rgba(239, 68, 68, .08);
  padding: 10px 12px;
  text-align: right
}

.wa-api-status strong {
  display: block;
  color: #dc2626;
  font-size: 12px;
  font-weight: 950
}

.wa-api-status span {
  display: block;
  color: var(--muted);
  font-size: 10.5px;
  margin-top: 3px
}

.wa-api-status.is-online {
  border-color: rgba(22, 163, 74, .3);
  background: rgba(22, 163, 74, .08)
}

.wa-api-status.is-online strong {
  color: #16a34a
}

.wa-api-response {
  border: 1px solid rgba(37, 99, 235, .22);
  border-radius: 20px;
  background: rgba(37, 99, 235, .06);
  padding: 14px 16px
}

.wa-api-response strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 950
}

.wa-api-response p {
  margin: 7px 0;
  color: var(--muted);
  font-size: 12px
}

.wa-api-response pre {
  max-height: 240px;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--card);
  padding: 12px;
  font-size: 11px;
  color: var(--text)
}

.wa-qr {
  max-width: 240px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: #fff;
  padding: 10px;
  margin-top: 10px
}

.phase101-whatsapp .page-subtitle,
.phase101-settings .page-subtitle {
  max-width: 760px
}

.whatsapp-hero-actions form button {
  white-space: nowrap
}

@media(max-width:900px) {
  .wa-api-card {
    align-items: stretch;
    flex-direction: column
  }

  .wa-api-status {
    text-align: left;
    min-width: 0
  }

  .whatsapp-hero-actions {
    width: 100%
  }

  .whatsapp-hero-actions .inline-form,
  .whatsapp-hero-actions .inline-form button {
    width: 100%;
    justify-content: center
  }
}

/* RD Conversas v2.0 - timeline e status RD */
.wa-history-item code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 2px 6px;
  background: rgba(148, 163, 184, .08);
  color: var(--text);
  font-size: 10.5px
}

.wa-status-pill.checked,
.wa-status-pill.enviado,
.wa-status-pill.recebido {
  border-color: rgba(22, 163, 74, .28) !important;
  background: rgba(22, 163, 74, .08) !important;
  color: #16a34a !important
}

.wa-status-pill.erro {
  border-color: rgba(239, 68, 68, .28) !important;
  background: rgba(239, 68, 68, .08) !important;
  color: #dc2626 !important
}

.wa-history-item p b {
  color: var(--text)
}


/* RD Conversas v3.0 - chat modal no funil */
.icon-btn.rd-chat-open {
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--primary);
  cursor: pointer;
  text-decoration: none
}

.rd-chat-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  padding: 18px
}

.rd-chat-modal.hidden {
  display: none
}

.rd-chat-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, .42);
  backdrop-filter: blur(3px)
}

.rd-chat-panel {
  position: relative;
  width: min(430px, calc(100vw - 26px));
  height: min(680px, calc(100dvh - 32px));
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: var(--card);
  box-shadow: 0 24px 80px rgba(15, 23, 42, .28);
  overflow: hidden
}

.rd-chat-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(135deg, rgba(37, 99, 235, .12), rgba(14, 165, 233, .04))
}

.rd-chat-head span {
  display: block;
  color: var(--primary);
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .12em
}

.rd-chat-head h2 {
  margin: 2px 0 0;
  color: var(--text);
  font-size: 16px;
  font-weight: 950
}

.rd-chat-head p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.25
}

.rd-chat-close {
  width: 34px;
  height: 34px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--card);
  color: var(--text);
  font-size: 22px;
  cursor: pointer
}

.rd-chat-body {
  flex: 1;
  overflow: auto;
  padding: 14px;
  background: rgba(148, 163, 184, .05);
  display: flex;
  flex-direction: column;
  gap: 10px
}

.rd-chat-empty {
  margin: auto;
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800
}

.rd-chat-bubble {
  display: flex
}

.rd-chat-bubble>div {
  max-width: 86%;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 10px 12px;
  background: var(--card);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .06)
}

.rd-chat-bubble.is-out {
  justify-content: flex-end
}

.rd-chat-bubble.is-out>div {
  background: rgba(37, 99, 235, .10);
  border-color: rgba(37, 99, 235, .22)
}

.rd-chat-bubble p {
  margin: 0;
  color: var(--text);
  font-size: 12px;
  line-height: 1.38;
  white-space: pre-wrap
}

.rd-chat-bubble small {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800
}

.rd-chat-form {
  border-top: 1px solid var(--border);
  padding: 12px;
  background: var(--card)
}

.rd-chat-form textarea.input {
  min-height: 74px;
  resize: vertical
}

.rd-chat-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 9px
}

.rd-chat-actions small {
  color: var(--muted);
  font-size: 10.5px;
  line-height: 1.25
}

.rd-chat-actions .btn-primary {
  white-space: nowrap
}

@media(max-width:640px) {
  .rd-chat-modal {
    padding: 0
  }

  .rd-chat-panel {
    width: 100%;
    height: 100dvh;
    border-radius: 0
  }

  .rd-chat-actions {
    align-items: stretch;
    flex-direction: column
  }

  .rd-chat-actions .btn-primary {
    width: 100%
  }
}

/* v3.2 - erro de mensagem livre exibido dentro do chat */
.rd-chat-bubble.is-error>div {
  border-color: #fecaca;
  background: #fef2f2;
  color: #991b1b;
}

.rd-chat-bubble.is-error small {
  color: #b91c1c;
}

/* v3.8 - Chat do funil: janela 24h e envio inicial por template */
.rd-chat-session-notice {
  border-top: 1px solid var(--border);
  padding: 10px 12px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
  background: var(--card);
  color: var(--muted)
}

.rd-chat-session-notice.hidden {
  display: none
}

.rd-chat-session-notice.is-open {
  background: #ecfdf5;
  color: #047857;
  border-color: #bbf7d0
}

.rd-chat-session-notice.is-closed {
  background: #fff7ed;
  color: #9a3412;
  border-color: #fed7aa
}

.rd-chat-template-form {
  border-top: 0
}

.rd-chat-template-form.hidden,
.rd-chat-form.hidden {
  display: none
}

.rd-chat-template-form .label {
  font-size: 10px;
  margin: 0 0 5px
}

.rd-chat-template-form textarea.input {
  min-height: 54px
}

.rd-chat-template-select {
  min-height: 40px
}

.rd-chat-template-preview {
  margin-top: 8px;
  padding: 10px 12px;
  border: 1px solid #dbe4f0;
  background: #f8fafc;
  border-radius: 12px;
  color: #334155;
  font-size: 12px;
  line-height: 1.35;
  max-height: 96px;
  overflow: auto;
  white-space: pre-wrap
}

.rd-chat-template-form .mt-2 {
  margin-top: 8px;
  display: block
}

/* v4.4 RD Conversas - webhook, auto-refresh e indicador de novas respostas */
.icon-btn.rd-chat-open {
  position: relative;
  overflow: visible
}

.icon-btn.rd-chat-open.has-rd-inbound {
  border-color: #22c55e;
  box-shadow: 0 0 0 2px rgba(34, 197, 94, .18)
}

.rd-chat-count {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 17px;
  height: 17px;
  padding: 0 5px;
  border-radius: 999px;
  background: #22c55e;
  color: #fff;
  font-size: 10px;
  font-weight: 950;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 17px
}

.rd-chat-bubble.is-in {
  justify-content: flex-start
}

.rd-chat-bubble.is-in>div {
  background: rgba(34, 197, 94, .10);
  border-color: rgba(34, 197, 94, .24)
}

.rd-chat-bubble.is-error>div {
  background: rgba(239, 68, 68, .10);
  border-color: rgba(239, 68, 68, .24)
}

/* v4.5 - Funil: filtros sempre visiveis no topo direito */
.pipeline-toolbar.pipeline-toolbar-v45 {
  display: grid;
  grid-template-columns: minmax(230px, 1fr) minmax(720px, auto);
  align-items: start;
  gap: 14px;
  margin-bottom: 14px
}

.pipeline-toolbar-v45 .pipeline-title-wrap {
  min-width: 220px
}

.pipeline-filter-bar {
  display: grid;
  grid-template-columns: 220px 130px minmax(130px, 160px) minmax(145px, 170px) minmax(230px, 1fr) auto;
  gap: 8px;
  align-items: end;
  justify-self: end;
  width: min(1050px, 100%);
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(148, 163, 184, .07);
  box-shadow: 0 10px 24px rgba(15, 23, 42, .05)
}

.pipeline-filter-bar .label {
  font-size: 9px;
  margin-bottom: 4px;
  letter-spacing: .08em;
  white-space: nowrap
}

.pipeline-filter-bar .input {
  min-height: 34px;
  height: 34px;
  font-size: 12px;
  padding: 0 10px;
  border-radius: 12px
}

.pipeline-filter-bar select.input {
  padding-right: 26px
}

.pipeline-filter-search {
  min-width: 210px
}

.pipeline-filter-buttons {
  display: flex;
  gap: 6px;
  align-items: center
}

.pipeline-filter-buttons .btn-primary,
.pipeline-filter-buttons .btn-outline {
  height: 34px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 12px;
  font-size: 11px;
  white-space: nowrap
}

.pipeline-date-range {
  min-width: 210px
}

.date-range-inputs {
    height: 34px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 5px;
    /* border: 1px solid var(--border); */
    /* border-radius: 12px; */
    /* background: var(--input-bg, var(--card)); */
    padding: 0 7px;
}

.date-range-inputs .input {
  border: 0;
  background: transparent;
  padding: 0;
  min-height: 30px;
  height: 30px;
  border-radius: 0
}

.date-range-inputs span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase
}

.pipeline-filter-drawer.hidden {
  display: none !important
}

.pipeline-search-form {
  display: none !important
}

.pipeline-actions {
  display: none !important
}

@media(max-width:1280px) {
  .pipeline-toolbar.pipeline-toolbar-v45 {
    grid-template-columns: 1fr
  }

  .pipeline-filter-bar {
    justify-self: stretch;
    width: 100%;
    grid-template-columns: repeat(3, minmax(0, 1fr))
  }

  .pipeline-filter-search {
    grid-column: span 2
  }

  .pipeline-filter-buttons {
    justify-content: flex-end
  }
}

@media(max-width:760px) {
  .pipeline-filter-bar {
    grid-template-columns: 1fr
  }

  .pipeline-filter-search {
    grid-column: auto
  }

  .pipeline-filter-buttons {
    justify-content: stretch
  }

  .pipeline-filter-buttons .btn-primary,
  .pipeline-filter-buttons .btn-outline {
    flex: 1;
    justify-content: center
  }

  .pipeline-date-range {
    min-width: 0
  }
}

/* v4.5 - diagnóstico visual de webhook no chat */
.rd-chat-webhook-hint {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.25
}

.rd-chat-bubble.is-in>div {
  box-shadow: 0 10px 24px rgba(22, 163, 74, .08)
}

/* v4.7 funil/historico RD - base sem largura forçada por viewport */
.pipeline-toolbar.pipeline-toolbar-v45 {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  align-items: end !important;
  margin: 0 0 10px !important;
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important
}

.pipeline-filter-bar {
  width: 100% !important;
  max-width: none !important;
  justify-self: stretch !important;
  grid-template-columns: minmax(205px, 250px) minmax(120px, 145px) minmax(130px, 155px) minmax(90px, 110px) minmax(135px, 165px) minmax(220px, 1fr) auto !important;
  position: relative !important;
  z-index: 2 !important;
  box-sizing: border-box !important
}

.pipeline-kanban-full {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important
}

.deal-card-phone {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800
}

.rd-chat-head-actions {
  display: flex;
  align-items: center;
  gap: 8px
}

.rd-chat-session-chip {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  white-space: nowrap
}

.rd-chat-session-chip.hidden {
  display: none !important
}

.rd-chat-session-chip.is-on {
  background: #dcfce7;
  color: #047857;
  border: 1px solid #86efac
}

.rd-chat-session-chip.is-off {
  background: #fff7ed;
  color: #9a3412;
  border: 1px solid #fed7aa
}

.rd-chat-session-notice {
  display: none !important
}

@media(max-width:1180px) {
  .pipeline-toolbar.pipeline-toolbar-v45 {
    grid-template-columns: 1fr !important
  }

  .pipeline-filter-bar {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important
  }

  .pipeline-filter-search {
    grid-column: span 2
  }
}

@media(max-width:760px) {
  .pipeline-filter-bar {
    grid-template-columns: 1fr !important
  }

  .pipeline-filter-search {
    grid-column: auto
  }
}

/* v4.9 - botao visivel de sincronizacao RD no topo do chat */
.rd-chat-sync-btn {
  border: 1px solid rgba(37, 99, 235, .25);
  background: rgba(37, 99, 235, .08);
  color: var(--primary);
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .02em;
  cursor: pointer;
  white-space: nowrap
}

.rd-chat-sync-btn:hover {
  background: rgba(37, 99, 235, .14)
}

.rd-chat-sync-btn:disabled {
  opacity: .65;
  cursor: wait
}

@media(max-width:520px) {
  .rd-chat-sync-btn {
    font-size: 0;
    width: 32px;
    height: 32px;
    padding: 0;
    border-radius: 12px
  }

  .rd-chat-sync-btn::before {
    content: '↻';
    font-size: 15px
  }
}

/* V5.5 - Terminal temporario de diagnostico RD Conversas */
.rd-chat-log-btn {
  border: 1px solid rgba(100, 116, 139, .28);
  background: rgba(100, 116, 139, .08);
  color: var(--muted);
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .02em;
  cursor: pointer;
  white-space: nowrap
}

.rd-chat-log-btn:hover {
  background: rgba(100, 116, 139, .14);
  color: var(--text)
}

.rd-chat-debug-panel {
  border-top: 1px solid var(--border);
  background: #0f172a;
  color: #dbeafe;
  max-height: 260px;
  display: flex;
  flex-direction: column
}

.rd-chat-debug-panel.hidden {
  display: none
}

.rd-chat-debug-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-bottom: 1px solid rgba(148, 163, 184, .22);
  background: rgba(15, 23, 42, .96)
}

.rd-chat-debug-head strong {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #93c5fd
}

.rd-chat-debug-action {
  border: 1px solid rgba(147, 197, 253, .35);
  background: rgba(37, 99, 235, .18);
  color: #dbeafe;
  border-radius: 8px;
  padding: 4px 7px;
  font-size: 10px;
  font-weight: 800;
  cursor: pointer
}

.rd-chat-debug-action:hover {
  background: rgba(37, 99, 235, .30)
}

.rd-chat-debug-panel pre {
  margin: 0;
  padding: 10px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 10.5px;
  line-height: 1.4;
  color: #e0f2fe;
  max-height: 205px
}

@media(max-width:520px) {
  .rd-chat-log-btn {
    font-size: 10px;
    padding: 6px 8px
  }

  .rd-chat-debug-panel {
    max-height: 220px
  }

  .rd-chat-debug-panel pre {
    max-height: 170px
  }
}


/* v5.6 - Monitor temporario webhook RD Conversas */
.rd-webhook-monitor {
  padding: 18px
}

.rd-monitor-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap
}

.rd-monitor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 16px 0
}

.rd-monitor-box {
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255, 255, 255, .03)
}

.rd-monitor-box strong {
  display: block;
  margin-bottom: 8px
}

.rd-monitor-box code {
  display: block;
  white-space: normal;
  word-break: break-all;
  color: var(--muted)
}

.rd-monitor-title {
  font-weight: 800;
  margin: 18px 0 10px
}

.rd-monitor-table-wrap {
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 16px
}

.rd-monitor-table pre {
  max-width: 520px;
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 11px;
  color: var(--muted)
}

.rd-terminal {
  min-height: 340px;
  max-height: 620px;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  background: #050914;
  color: #d7e1ff;
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word
}

@media(max-width:800px) {
  .rd-monitor-grid {
    grid-template-columns: 1fr
  }

  .rd-monitor-actions {
    justify-content: flex-start
  }
}

.rd-chat-actions small.is-error {
  color: #dc2626;
  font-weight: 800
}


/* RD Conversas V6.3 - notificações realtime no funil */
.rd-unread-toasts {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1100;
  display: none;
  flex-direction: column;
  gap: 10px;
  width: min(360px, calc(100vw - 28px));
  pointer-events: none
}

.rd-unread-toasts.is-visible {
  display: flex
}

.rd-unread-toast {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid rgba(34, 197, 94, .28);
  border-radius: 18px;
  background: var(--card);
  box-shadow: 0 16px 44px rgba(15, 23, 42, .22);
  overflow: hidden;
  pointer-events: auto
}

.rd-unread-toast-main {
  flex: 1;
  text-align: left;
  border: 0;
  background: linear-gradient(135deg, rgba(34, 197, 94, .13), rgba(37, 99, 235, .06));
  padding: 10px 12px;
  cursor: pointer
}

.rd-unread-toast-main strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 950;
  line-height: 1.2
}

.rd-unread-toast-main span {
  display: block;
  margin-top: 2px;
  color: #047857;
  font-size: 10.5px;
  font-weight: 900
}

.rd-unread-toast-main p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 11.5px;
  line-height: 1.25;
  max-height: 32px;
  overflow: hidden
}

.rd-unread-toast-close {
  width: 34px;
  border: 0;
  border-left: 1px solid var(--border);
  background: rgba(248, 250, 252, .78);
  color: var(--muted);
  font-size: 20px;
  font-weight: 800;
  cursor: pointer
}

.rd-unread-toast-close:hover {
  background: #fee2e2;
  color: #b91c1c
}

@media(max-width:640px) {
  .rd-unread-toasts {
    right: 10px;
    bottom: 10px;
    width: calc(100vw - 20px)
  }
}

/* RD Conversas V6.4 - opção de balões de não lidas */
.rd-config-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(37, 99, 235, .04)
}

.rd-config-option .field-hint {
  margin: .35rem 0 0;
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.35
}

.rd-config-option .crm-switch {
  flex: 0 0 auto
}


/* v7.4 - CSS final e unico para card kanban atual */
.deal-card {
  background: var(--card) !important;
  border: 1px solid var(--border-soft) !important;
  border-radius: 15px !important;
  padding: 10px 10px 0 !important;
  box-shadow: none !important;
  transition: transform .16s, border-color .16s, background .16s !important;
  cursor: grab !important;
  overflow: hidden !important;
  min-height: 182px !important;
  position: relative !important;
}

.deal-card:hover {
  background: var(--card-hover) !important;
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border-soft)) !important;
  transform: translateY(-1px) !important;
  box-shadow: none !important;
}

.deal-card.dragging {
  opacity: .55 !important;
  transform: scale(.985) !important
}

.deal-card::after {
  display: none !important;
  content: none !important
}

.deal-card.deal-status-em_andamento {
  border-color: rgba(37, 99, 235, .28) !important
}

.deal-card.deal-status-vendida {
  border-color: rgba(34, 197, 94, .36) !important
}

.deal-card.deal-status-perdida {
  border-color: rgba(239, 68, 68, .36) !important
}

.deal-card.deal-status-em_andamento:hover {
  border-color: rgba(37, 99, 235, .55) !important
}

.deal-card.deal-status-vendida:hover {
  border-color: rgba(34, 197, 94, .60) !important
}

.deal-card.deal-status-perdida:hover {
  border-color: rgba(239, 68, 68, .60) !important
}

.deal-card-status-head {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-rows: auto auto !important;
  gap: 2px !important;
  align-items: start !important;
  min-height: 0 !important;
  padding: 9px 10px 7px !important;
  border-radius: 13px !important;
  text-decoration: none !important;
  background: #dbeafe !important;
  color: #3454e8 !important;
}

.deal-card.deal-status-vendida .deal-card-status-head {
  background: #bbf7d0 !important;
  color: #059669 !important
}

.deal-card.deal-status-perdida .deal-card-status-head {
  background: #fee2e2 !important;
  color: #ef1111 !important
}

.deal-card-head-text,
.deal-card-head-text:hover {
  grid-column: 1 !important;
  grid-row: 1 !important;
  display: grid !important;
  gap: 2px !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  color: inherit !important;
  text-decoration: none !important;
}

.deal-card-head-text strong,
.deal-card-head-text span,
.deal-card-head-text:hover strong,
.deal-card-head-text:hover span {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}


.deal-card-title-edit {
  appearance: none !important;
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  text-align: left !important;
  color: inherit !important;
  cursor: pointer !important;
  border-radius: 8px !important;
}

.deal-card-title-edit:hover strong {
  text-decoration: underline !important;
  text-decoration-thickness: 1px !important;
}

.deal-card-title-edit.is-saving {
  opacity: .65 !important;
  cursor: wait !important;
}

.deal-card-company-link,
.deal-card-company-link:hover {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  color: inherit !important;
  text-decoration: none !important;
}

.deal-title-inline-input {
  width: 100% !important;
  max-width: 100% !important;
  height: 24px !important;
  border: 1px solid rgba(37, 99, 235, .35) !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #0f172a !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  padding: 2px 6px !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .12) !important;
}

.deal-card-head-text strong {
  font-size: 14px !important;
  font-weight: 950 !important;
  line-height: 1.06 !important;
  color: #172033 !important;
  margin: 0 !important
}

.deal-card-head-text span {
  font-size: 12px !important;
  font-weight: 950 !important;
  line-height: 1.06 !important;
  text-transform: uppercase !important;
  color: currentColor !important;
  margin: 0 !important
}

.deal-card-head-value {
  grid-column: 1 !important;
  grid-row: 2 !important;
  justify-self: end !important;
  align-self: end !important;
  appearance: none !important;
  border: 0 !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 4px !important;
  max-width: 100% !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  color: currentColor !important;
  cursor: pointer !important;
  border-radius: 10px !important;
  text-decoration: none !important;
}

.deal-card-head-value:hover {
  filter: brightness(.94) !important;
  text-decoration: none !important
}

.deal-card-head-value:disabled,
.deal-card-head-value.is-saving {
  opacity: .65 !important;
  cursor: wait !important
}

.deal-card-head-value.is-editing {
  min-width: 96px !important;
  filter: none !important;
  text-decoration: none !important
}

.deal-amount-prefix {
  display: inline-flex !important;
  align-items: center !important;
  line-height: 1 !important
}

.deal-amount-inline-input {
  width: 78px !important;
  max-width: 78px !important;
  height: 24px !important;
  border: 1px solid rgba(37, 99, 235, .35) !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #0f172a !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  padding: 2px 6px !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .12) !important;
}

.deal-card-body-v65 {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 36px !important;
  gap: 8px !important;
  padding: 7px 2px 1px !important;
  min-height: 0 !important;
}

.deal-info-lines {
  min-width: 0 !important;
  display: grid !important;
  align-content: start !important;
  gap: 1px !important;
  padding-right: 0 !important
}

.deal-info-line {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  min-width: 0 !important;
  color: #1f2937 !important;
  font-size: 12px !important;
  line-height: 1.13 !important;
  text-decoration: none !important
}

.deal-info-line span:last-child {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important
}

.deal-info-line:hover {
  color: #1d4ed8 !important
}

.deal-email-link:hover {
  text-decoration: underline !important
}

.deal-info-ico {
  width: 14px !important;
  min-width: 14px !important;
  text-align: center !important;
  color: #111827 !important;
  font-size: 12px !important;
  line-height: 1 !important
}

.deal-card-actions-v65 {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 7px !important;
  padding-top: 1px !important
}

.deal-card-actions-v65 .icon-btn {
  position: relative !important;
  width: 32px !important;
  height: 32px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(15, 23, 42, .22) !important;
  background: #fff !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, .08) !important;
  font-size: 17px !important;
  text-decoration: none !important;
  color: #0f172a !important
}

.deal-card-actions-v65 .icon-btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 8px 18px rgba(15, 23, 42, .14) !important
}

.deal-card-actions-v65 .rd-chat-open {
  color: #00b900 !important
}

.deal-card-actions-v65 .rd-open-official {
  color: #0f2b3d !important;
  font-weight: 950 !important
}

.deal-card-actions-v65 .rd-chat-count {
  position: absolute !important;
  right: -7px !important;
  top: -7px !important;
  min-width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  background: #ef4444 !important;
  color: #fff !important;
  border: 2px solid #fff !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 4px !important;
  line-height: 1 !important
}

.deal-loss-reason {
  margin: 2px 4px 4px !important;
  color: #b91c1c !important;
  font-size: 11px !important;
  font-weight: 800 !important
}

.deal-card-status-footer {
  height: 29px !important;
  min-width: 132px !important;
  margin: 0 auto 0 !important;
  padding: 0 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #3454e8 !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  position: relative !important;
  text-transform: none !important;
}

.deal-card-status-footer::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  bottom: 0 !important;
  transform: translateX(-50%) !important;
  width: 132px !important;
  height: 4px !important;
  border-radius: 999px 999px 0 0 !important;
  background: #3454e8 !important
}

.deal-card-status-footer.status-vendida {
  color: #00a63e !important;
  background: transparent !important
}

.deal-card-status-footer.status-vendida::after {
  background: #00b83f !important
}

.deal-card-status-footer.status-perdida {
  color: #ef1111 !important;
  background: transparent !important
}

.deal-card-status-footer.status-perdida::after {
  background: #ef1111 !important
}

.deal-card-status-footer.status-em_andamento {
  color: #3454e8 !important;
  background: transparent !important
}

.deal-card-status-footer.status-em_andamento::after {
  background: #3454e8 !important
}

#lossModal.loss-modal-top,
#lossModal.loss-modal-top.fixed,
.modal-shell.loss-modal-top {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2500 !important
}

#lossModal.loss-modal-top form,
#lossModal.loss-modal-top .modal-card {
  z-index: 2501 !important;
  position: relative !important
}

@media(max-width:768px) {
  .deal-card-status-head {
    padding: 9px 10px 8px !important
  }

  .deal-card-head-value {
    font-size: 12px !important
  }

  .deal-card-body-v65 {
    grid-template-columns: minmax(0, 1fr) 34px !important
  }
}



/* CRM RD Conversas V7.6 - chat com metadados fora do balao e resposta marcada */
.rd-chat-body {
  gap: 8px !important;
}

.rd-chat-row {
  display: flex;
  flex-direction: column;
  max-width: 88%;
}

.rd-chat-row.is-out {
  align-self: flex-end;
  align-items: flex-end;
}

.rd-chat-row.is-in {
  align-self: flex-start;
  align-items: flex-start;
}

.rd-chat-bubble {
  display: flex !important;
  align-items: center;
  gap: 6px;
  width: 100%;
}

.rd-chat-bubble.is-out {
  justify-content: flex-end !important;
}

.rd-chat-bubble.is-in {
  justify-content: flex-start !important;
}

.rd-chat-bubble>div {
  max-width: 100% !important;
  padding: 9px 11px !important;
  border-radius: 10px !important;
}

.rd-chat-bubble .rd-chat-sender {
  display: block;
  margin: 0 0 4px;
  color: var(--text);
  font-size: 12px;
  font-weight: 950;
  line-height: 1.2;
}

.rd-chat-bubble p {
  font-size: 12px !important;
}

.rd-chat-meta {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
}

.rd-chat-row.is-out .rd-chat-meta {
  text-align: right;
}

.rd-chat-row.is-in .rd-chat-meta {
  text-align: left;
}

.rd-chat-bubble small {
  display: none !important;
}

.rd-chat-reply-btn {
  width: 24px;
  height: 24px;
  border: 0;
  background: transparent;
  color: #64748b;
  font-size: 17px;
  line-height: 1;
  cursor: pointer;
  opacity: .65;
  border-radius: 999px;
}

.rd-chat-reply-btn:hover {
  opacity: 1;
  background: rgba(100, 116, 139, .12);
}

.rd-chat-row.is-out .rd-chat-reply-btn {
  order: -1;
}

.rd-chat-quote {
  margin: 0 0 7px;
  padding: 6px 8px;
  border-left: 3px solid rgba(37, 99, 235, .55);
  border-radius: 8px;
  background: rgba(255, 255, 255, .55);
  color: #475569;
  font-size: 11px;
  line-height: 1.25;
  max-height: 50px;
  overflow: hidden;
}

.rd-chat-quote strong {
  display: block;
  font-weight: 800;
  color: #334155;
  margin-bottom: 2px;
}

.rd-chat-quote span {
  display: block;
  font-weight: 500;
  color: #475569;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rd-chat-quote.quote-in {
  border-left-color: rgba(34, 197, 94, .65);
}

.rd-chat-reply-box {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 8px;
  margin: 0 0 8px;
  padding: 8px 9px;
  border: 1px solid rgba(37, 99, 235, .25);
  border-left: 4px solid var(--primary);
  border-radius: 12px;
  background: rgba(37, 99, 235, .08);
}

.rd-chat-reply-box.hidden {
  display: none !important;
}

.rd-chat-reply-box strong {
  display: block;
  color: var(--text);
  font-size: 11px;
  font-weight: 950;
  margin-bottom: 2px;
}

.rd-chat-reply-box span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.25;
  max-height: 32px;
  overflow: hidden;
}

.rd-chat-reply-box button {
  width: 26px;
  min-width: 26px;
  border: 0;
  border-radius: 9px;
  background: rgba(15, 23, 42, .08);
  color: #334155;
  font-size: 18px;
  font-weight: 900;
  cursor: pointer;
}

.rd-chat-reply-box button:hover {
  background: rgba(239, 68, 68, .13);
  color: #b91c1c;
}


.rd-media-image {
  max-width: 220px;
  border-radius: 12px;
  display: block;
  margin-bottom: 8px
}

.rd-media-video {
  max-width: 240px;
  border-radius: 12px;
  margin-bottom: 8px
}

.rd-media-audio {
  width: 220px;
  margin-bottom: 8px
}

.rd-media-file {
  display: inline-flex;
  gap: 6px;
  padding: 10px 12px;
  background: #1f2937;
  border-radius: 10px;
  margin-bottom: 8px;
  color: #fff;
  text-decoration: none
}

.rd-chat-upload-row {
  margin-top: 8px
}
/* CRM RD Conversas V11.17 - histórico somente com scroll vertical */
.rd-chat-body,
#rdChatMessages {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  max-width: 100% !important;
}
.rd-chat-row,
.rd-chat-bubble,
.rd-chat-bubble > div,
.rd-chat-bubble p,
.rd-chat-text,
.rd-chat-meta {
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  white-space: pre-wrap !important;
}
.rd-chat-row { width: auto !important; }
.rd-chat-row.is-in,
.rd-chat-row.is-out { max-width: 88% !important; }

/* CRM RD Conversas V11.18 - somente scroll vertical no historico do chat */
.rd-chat-body {
    overflow-x: hidden !important;
    overflow-y: auto !important;
}
.rd-chat-row,
.rd-chat-bubble,
.rd-chat-bubble > div,
.rd-chat-bubble p,
.rd-chat-message-text {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    white-space: pre-wrap !important;
}

/* CRM RD Conversas V11.19 - remove definitivamente scroll horizontal no histórico do chat */
.rd-chat-modal,
.rd-chat-panel,
.rd-chat-body,
#rdChatMessages,
.rd-chat-list,
.rd-chat-scroll,
.rd-chat-content {
  max-width: 100% !important;
  overflow-x: hidden !important;
}
#rdChatMessages * {
  max-width: 100% !important;
  box-sizing: border-box !important;
}
.rd-chat-bubble,
.rd-chat-message,
.rd-chat-message-text,
.rd-chat-text {
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  white-space: pre-wrap !important;
}

/* V11.34 - Assistente de renovacao do Token interno Tallos/F12 */
.rd-token-helper {
    border: 1px solid var(--border, #d9e2ef);
    border-radius: 16px;
    background: var(--card, #fff);
    padding: 14px;
    display: grid;
    gap: 10px;
}
.rd-token-helper-main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}
.rd-token-helper strong {
    display: block;
    font-size: 14px;
    color: var(--text, #172033);
    margin: 3px 0;
}
.rd-token-helper span,
.rd-token-helper p,
.rd-token-steps li {
    color: var(--muted, #64748b);
    font-size: 12px;
    line-height: 1.45;
}
.rd-token-helper p { margin: 4px 0 0; }
.rd-token-helper.is-ok { border-color: #9ee6b4; background: rgba(34, 197, 94, .06); }
.rd-token-helper.is-warning { border-color: #fde68a; background: rgba(245, 158, 11, .08); }
.rd-token-helper.is-danger { border-color: #fecaca; background: rgba(239, 68, 68, .07); }
.rd-token-helper.is-empty { border-color: var(--border, #d9e2ef); }
.rd-token-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}
.rd-token-steps {
    border-top: 1px dashed var(--border, #d9e2ef);
    padding-top: 10px;
}
.rd-token-steps summary {
    cursor: pointer;
    font-weight: 700;
    font-size: 13px;
    color: var(--primary, #2563eb);
}
.rd-token-steps ol {
    margin: 8px 0 0 18px;
    padding: 0;
}
.rd-token-steps li + li { margin-top: 4px; }
@media (max-width: 768px) {
    .rd-token-helper-main { flex-direction: column; }
    .rd-token-actions { width: 100%; justify-content: flex-start; }
}
.crm-span-3 { grid-column: span 3 / span 3; }
@media (max-width: 768px) { .crm-span-3 { grid-column: 1 / -1; } }


/* V11_50 - dados cadastrais da empresa em cards/detalhes de negociação */
.deal-company-extra{
  display:block;
  margin-top:2px;
  font-size:10.5px;
  line-height:1.2;
  color:#dc2626;
  font-weight:800;
  letter-spacing:.01em;
}
.deal-company-extra-detail{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:6px;
  font-size:12px;
  color:#dc2626;
  font-weight:700;
}
.deal-company-extra-detail span{
  display:inline-flex;
  align-items:center;
  gap:4px;
  border:1px solid rgba(220,38,38,.18);
  background:rgba(254,242,242,.75);
  border-radius:999px;
  padding:4px 8px;
}
.login-remember{
  display:flex;
  align-items:center;
  gap:8px;
  color:#475569;
  font-size:14px;
  font-weight:700;
}
.login-remember input{
  width:16px;
  height:16px;
  accent-color:#2563eb;
}


/* V11_52 - ajuste apenas nos cards do funil: cod.totvs - cpf/cnpj compacto, 9px e sem quebra */
.deal-card .deal-company-extra-funil{
  display:block !important;
  color:#2563eb;
  font-size:9px !important;
  font-weight:500 !important;
  line-height:1.05 !important;
  margin-top:2px;
  white-space:nowrap !important;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.deal-card .deal-company-extra-funil span{
  display:inline !important;
  font-size:9px !important;
  font-weight:500 !important;
  line-height:1.05 !important;
  white-space:nowrap !important;
}
.deal-card .deal-company-extra-funil span[title]{
  cursor:help;
}

.deal-temperature-line{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  margin-top:4px;
  font-size:11px;
}
.deal-temp-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:20px;
  padding:2px 8px;
  border-radius:999px;
  font-size:11px;
  font-weight:800;
  line-height:1;
  border:1px solid transparent;
}
.deal-temp-days{
  color:var(--muted,#64748b);
  font-size:11px;
}
.deal-temp-badge.temp-quente{background:#dcfce7;color:#166534;border-color:#86efac}
.deal-temp-badge.temp-morno{background:#fef9c3;color:#854d0e;border-color:#fde68a}
.deal-temp-badge.temp-esfriando{background:#ffedd5;color:#9a3412;border-color:#fdba74}
.deal-temp-badge.temp-parado{background:#fee2e2;color:#991b1b;border-color:#fecaca}
.deal-temp-badge.temp-finalizado{background:#e2e8f0;color:#475569;border-color:#cbd5e1}

.report-temperature-help .deal-temperature-line{
  gap:8px;
  margin-top:8px;
}

/* V11.89 - RD Conversas: templates em grade compacta + permissões por operador */
.wa-template-admin-panel {
  grid-column: 1 / -1;
}

.wa-template-permissions {
  display: grid;
  gap: 12px;
}

.wa-template-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .05);
  padding: 10px 12px;
}

.wa-template-toolbar strong {
  color: var(--text);
  font-size: 12px;
  font-weight: 950;
}

.wa-template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-right: 4px;
}

.wa-template-card {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(148, 163, 184, .045);
  padding: 11px;
  display: grid;
  gap: 9px;
  min-height: 136px;
}

.wa-template-card.is-active {
  border-color: rgba(37, 99, 235, .32);
  background: rgba(37, 99, 235, .055);
}

.wa-template-card.is-inactive {
  opacity: .68;
}

.wa-template-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  font-size: 10.5px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
  cursor: pointer;
}

.wa-template-toggle input {
  width: 16px;
  height: 16px;
  accent-color: var(--primary);
}

.wa-template-card-main {
  min-width: 0;
}

.wa-template-card-main strong {
  display: block;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 950;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.wa-template-card-main p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.wa-template-card-main small {
  display: inline-flex;
  margin-top: 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 3px 7px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
}

.wa-template-manual {
  margin-top: 12px;
}

.wa-template-manual summary {
  cursor: pointer;
  color: var(--primary);
  font-size: 12px;
  font-weight: 900;
}

body[data-theme="dark"] .wa-template-toolbar,
body[data-theme="dark"] .wa-template-card {
  background: rgba(255, 255, 255, .035);
}

body[data-theme="dark"] .wa-template-card.is-active {
  background: rgba(37, 99, 235, .13);
}

@media(max-width: 760px) {
  .wa-template-grid {
    grid-template-columns: 1fr;
    max-height: none;
  }

  .wa-template-toolbar {
    align-items: stretch;
    flex-direction: column;
  }
}

/* V11.90 - campo de variavel de teste no envio de template RD */
.rd-chat-template-var-label{margin-top:10px;display:block}
.rd-chat-template-var-input{margin-top:6px;width:100%}

/* V11.92 - RD Conversas: variaveis editaveis por posicao no template */
.rd-chat-template-vars-box{margin-top:10px}
.rd-chat-template-vars-list{display:grid;grid-template-columns:1fr;gap:8px;margin-top:6px}
.rd-chat-template-var-row .label{margin-bottom:4px;font-size:11px}
.rd-chat-template-vars-box small{display:block;margin-top:6px;color:#64748b;font-size:11px;line-height:1.35}


/* v11.100 - classificacao da empresa nos cards com imagem A/B/C */
.deal-company-class-badge {
  grid-column: 1 !important;
  grid-row: 1 !important;
  justify-self: end !important;
  align-self: start !important;
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  text-decoration: none !important;
  pointer-events: none !important;
  z-index: 3 !important;
}

.deal-company-class-badge img {
  width: 26px !important;
  height: 26px !important;
  display: block !important;
  object-fit: contain !important;
}


.deal-card-head-text {
  padding-right: 42px !important;
}

/* V11_103 - Empresas: ações alinhadas e exclusão minimalista */
.crm-head-actions,
.company-row-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.btn-icon-danger {
  width: 18px;
  height: 18px;
  min-width: 18px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  box-shadow: none !important;
  color: #ef4444;
  cursor: pointer;
  font-size: 12px;
  line-height: 1;
  opacity: .78;
  transition: opacity .15s ease, transform .15s ease;
}

.btn-icon-danger:hover {
  background: transparent !important;
  border: 0 !important;
  opacity: 1;
  transform: scale(1.08);
}

.crm-modal-inline-error {
  display: block;
  margin: 0 0 12px 0;
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 800;
}

/* V11_106 - Configuração da empresa - layout revisado */
.phase104-company-config{padding-bottom:28px}.phase104-company-config .company-config-layout{display:grid;gap:18px;width:100%;max-width:1180px;margin:0 auto}.phase104-company-config .card{border:1px solid var(--border);background:var(--card,#fff);box-shadow:none}.company-profile-card,.company-hours-card,.company-closed-dates-card{border-radius:22px;padding:20px}.settings-section-head.compact{padding:0 0 14px}.company-profile-grid{display:grid;grid-template-columns:minmax(300px,1.5fr) repeat(3,minmax(170px,1fr));gap:12px;margin-top:14px}.company-profile-main{display:flex;gap:16px;align-items:center;padding:16px;border:1px solid var(--border);border-radius:18px;background:rgba(148,163,184,.07);min-width:0}.company-avatar{width:58px;height:58px;flex:0 0 58px;border-radius:18px;display:grid;place-items:center;background:#2563eb;color:#fff;font-weight:900;font-size:26px}.company-profile-main span,.company-info-box span{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:900}.company-profile-main strong{display:block;font-size:18px;color:var(--text);line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.company-profile-main small{display:block;margin-top:4px;color:var(--muted);font-weight:800}.company-info-box{padding:16px;border:1px solid var(--border);border-radius:18px;background:rgba(148,163,184,.06);min-height:92px;display:flex;flex-direction:column;justify-content:center}.company-info-box strong{display:block;margin-top:7px;color:var(--text);font-size:16px}.company-config-main-grid{display:grid;grid-template-columns:minmax(420px,560px) minmax(320px,1fr);gap:18px;align-items:start}.company-hours-card{max-width:560px;width:100%}.business-hours-list{border-top:1px solid var(--border);margin-top:0}.business-day{border-bottom:1px solid var(--border)}.business-day-head{width:100%;border:0;background:transparent;color:var(--text);display:grid;grid-template-columns:minmax(130px,1fr) auto 22px;align-items:center;gap:10px;padding:15px 0;text-align:left;cursor:pointer}.business-day-head strong{font-size:15px}.business-day-head em{font-style:normal;color:var(--muted);font-size:18px;transform:rotate(0deg);transition:.18s}.business-day.is-open .business-day-head em{transform:rotate(180deg)}.business-summary{display:inline-flex;align-items:center;justify-content:center;min-width:112px;border-radius:6px;background:#06c9ee;color:#001526;padding:5px 9px;font-size:11px;font-weight:950;white-space:nowrap;text-transform:uppercase}.business-summary.is-closed{background:rgba(148,163,184,.20);color:var(--text)}.business-day-body{display:none;padding:8px 8px 22px}.business-day.is-open .business-day-body{display:block}.business-time-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;max-width:370px}.business-time-grid label span{display:block;margin-bottom:7px;font-size:15px;font-weight:900;color:var(--text)}.business-time-grid input{width:100%;height:42px;border:1px solid var(--border);border-radius:12px;background:var(--input-bg,#fff);color:var(--text);padding:0 12px;font-size:16px;font-weight:800}.business-time-grid label.is-muted input{opacity:.55;background:rgba(148,163,184,.20)}.business-checks{display:grid;gap:10px;margin-top:20px}.business-checks label{display:flex;align-items:center;gap:10px;font-weight:850;color:var(--text);font-size:13px}.business-checks input{width:17px;height:17px;accent-color:#2563eb}.company-hours-actions{position:static;margin-top:18px;border-radius:18px;display:grid;grid-template-columns:1fr auto;gap:14px;align-items:center}.company-hours-actions .btn-primary{min-width:170px}.closed-date-form{display:grid;grid-template-columns:160px minmax(180px,1fr) 130px;gap:12px;align-items:end;margin-top:4px}.closed-date-form label span{display:block;margin-bottom:7px;color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.closed-date-form input{width:100%;height:42px;border:1px solid var(--border);border-radius:13px;background:var(--input-bg,#fff);color:var(--text);padding:0 12px;font-size:13px;font-weight:750}.closed-date-list{display:grid;gap:9px;margin-top:16px}.closed-date-empty{border:1px dashed var(--border);border-radius:16px;padding:14px;color:var(--muted);font-size:13px;font-weight:800;background:rgba(148,163,184,.06)}.closed-date-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--border);border-radius:16px;background:rgba(148,163,184,.06);padding:11px 12px}.closed-date-item strong{display:block;color:var(--text);font-size:14px;font-weight:950}.closed-date-item span{display:block;margin-top:2px;color:var(--muted);font-size:12px;font-weight:700}.closed-date-delete{border:0;background:transparent;color:#ef4444;cursor:pointer;font-size:14px;line-height:1;padding:4px;opacity:.82}.closed-date-delete:hover{opacity:1;transform:scale(1.05)}
@media(max-width:1120px){.company-profile-grid{grid-template-columns:1fr 1fr}.company-config-main-grid{grid-template-columns:1fr}.company-hours-card{max-width:620px}.company-closed-dates-card{max-width:620px}}
@media(max-width:720px){.phase104-company-config .company-config-layout{gap:14px}.company-profile-grid{grid-template-columns:1fr}.company-config-main-grid{gap:14px}.company-hours-card,.company-closed-dates-card{max-width:none}.business-day-head{grid-template-columns:1fr auto 20px}.business-summary{min-width:auto}.business-day-body{padding-left:0;padding-right:0}.closed-date-form{grid-template-columns:1fr}.closed-date-form .btn-primary{width:100%}.company-hours-actions{grid-template-columns:1fr}.company-hours-actions .btn-primary{width:100%}}
@media(max-width:480px){.business-day-head{grid-template-columns:1fr 20px}.business-summary{grid-column:1/2;justify-self:start}.business-time-grid{gap:12px}.company-profile-main{align-items:flex-start}.company-avatar{width:48px;height:48px;flex-basis:48px}}


/* v11.107 - ajuste pagina configuracao da empresa */
.phase104-company-config .company-config-layout{max-width:1280px!important;}
.company-profile-grid{grid-template-columns:minmax(430px,2.2fr) repeat(3,minmax(160px,1fr))!important;}
.company-profile-main strong{font-size:16px!important;white-space:normal!important;overflow:visible!important;text-overflow:clip!important;line-height:1.2!important;}
.company-profile-main{min-height:92px!important;}
@media(max-width:1120px){.company-profile-grid{grid-template-columns:1fr 1fr!important;}.company-profile-main strong{font-size:16px!important;}}
@media(max-width:720px){.company-profile-grid{grid-template-columns:1fr!important;}}

.company-after-hours-card{border-radius:22px;padding:20px;max-width:560px;width:100%}.after-hours-message-form{display:grid;gap:14px}.after-hours-enabled{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:850;color:var(--text)}.after-hours-enabled input{width:17px;height:17px;accent-color:#2563eb}.after-hours-message-form label:not(.after-hours-enabled) span{display:block;margin-bottom:7px;color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.after-hours-message-form textarea{width:100%;min-height:118px;resize:vertical;border:1px solid var(--border);border-radius:15px;background:var(--input-bg,#fff);color:var(--text);padding:12px 14px;font-size:13px;font-weight:750;line-height:1.45}.after-hours-message-form .btn-primary{justify-self:start;min-width:170px}@media(max-width:1120px){.company-after-hours-card{max-width:620px}}@media(max-width:720px){.company-after-hours-card{max-width:none}.after-hours-message-form .btn-primary{width:100%}}

/* V11_114 - Funil: filtros em uma linha com Classe/Ordenar compactos */
body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
body.crm-body.is-pipeline-page .pipeline-filter-bar {
  display: grid !important;
  grid-template-columns: 300px 140px minmax(150px, 170px) 120px 120px minmax(170px, 1fr) auto !important;
  gap: 8px !important;
  align-items: end !important;
  width: 100% !important;
  max-width: none !important;
}

body.crm-body.is-pipeline-page .pipeline-filter-bar > div {
  min-width: 0 !important;
  margin: 0 !important;
}

body.crm-body.is-pipeline-page .pipeline-filter-bar .input {
  width: 100% !important;
  min-width: 0 !important;
}

body.crm-body.is-pipeline-page .pipeline-filter-bar > div:nth-child(4),
body.crm-body.is-pipeline-page .pipeline-filter-bar > div:nth-child(5) {
  width: 120px !important;
  max-width: 120px !important;
}

body.crm-body.is-pipeline-page .pipeline-filter-search {
  min-width: 170px !important;
  grid-column: auto !important;
}

body.crm-body.is-pipeline-page .pipeline-filter-buttons {
  display: flex !important;
  flex-direction: row !important;
  align-items: end !important;
  justify-content: flex-start !important;
  gap: 6px !important;
  align-self: end !important;
  white-space: nowrap !important;
  grid-column: auto !important;
}

body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-primary,
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-outline {
  width: auto !important;
  min-width: 62px !important;
  height: 34px !important;
  min-height: 34px !important;
  padding: 0 12px !important;
}

@media (max-width: 1280px) {
  body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
  body.crm-body.is-pipeline-page .pipeline-filter-bar {
    grid-template-columns: 280px 135px minmax(140px, 160px) 120px 120px minmax(150px, 1fr) auto !important;
  }
}

@media (max-width: 1120px) {
  body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
  body.crm-body.is-pipeline-page .pipeline-filter-bar {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  body.crm-body.is-pipeline-page .pipeline-filter-bar > div:nth-child(4),
  body.crm-body.is-pipeline-page .pipeline-filter-bar > div:nth-child(5) {
    width: auto !important;
    max-width: none !important;
  }
  body.crm-body.is-pipeline-page .pipeline-filter-search,
  body.crm-body.is-pipeline-page .pipeline-filter-buttons {
    grid-column: auto !important;
  }
}

@media (max-width: 760px) {
  body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
  body.crm-body.is-pipeline-page .pipeline-filter-bar {
    grid-template-columns: 1fr !important;
  }
  body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-primary,
  body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-outline {
    flex: 1 1 0 !important;
  }
}

/* V11_115 - Ajuste final dos filtros do funil e limpeza do bloco de empresa */
body.crm-body.is-pipeline-page .pipeline-toolbar.pipeline-toolbar-v45{
  grid-template-columns: 1fr !important;
  gap: 8px !important;
}
body.crm-body.is-pipeline-page .pipeline-toolbar-v45 .pipeline-title-wrap{
  display:none !important;
}
body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
body.crm-body.is-pipeline-page .pipeline-filter-bar{
  display:grid !important;
  grid-template-columns: 286px 140px 170px 120px 120px minmax(150px,1fr) 132px !important;
  column-gap: 10px !important;
  row-gap: 8px !important;
  align-items:end !important;
  width: min(1290px, calc(100vw - 120px)) !important;
  max-width: 1290px !important;
  justify-self:center !important;
  padding: 14px 16px !important;
  border-radius: 20px !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-bar > div,
body.crm-body.is-pipeline-page .pipeline-filter-status,
body.crm-body.is-pipeline-page .pipeline-filter-owner,
body.crm-body.is-pipeline-page .pipeline-filter-class,
body.crm-body.is-pipeline-page .pipeline-filter-order,
body.crm-body.is-pipeline-page .pipeline-filter-search,
body.crm-body.is-pipeline-page .pipeline-filter-buttons{
  min-width:0 !important;
  margin:0 !important;
  grid-column:auto !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-class,
body.crm-body.is-pipeline-page .pipeline-filter-order{
  width:120px !important;
  max-width:120px !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-bar .input{
  width:100% !important;
  height:34px !important;
  min-height:34px !important;
  min-width:0 !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-buttons{
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  align-self:end !important;
  gap:8px !important;
  white-space:nowrap !important;
  width:132px !important;
  max-width:132px !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-primary,
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-outline{
  width:62px !important;
  min-width:62px !important;
  max-width:62px !important;
  height:34px !important;
  min-height:34px !important;
  padding:0 !important;
  text-align:center !important;
}
.phase104-company-config .company-profile-card .company-profile-grid{
  margin-top:0 !important;
}
@media (max-width: 1180px){
  body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
  body.crm-body.is-pipeline-page .pipeline-filter-bar{
    width:calc(100vw - 36px) !important;
    grid-template-columns: repeat(4,minmax(0,1fr)) !important;
  }
  body.crm-body.is-pipeline-page .pipeline-filter-class,
  body.crm-body.is-pipeline-page .pipeline-filter-order,
  body.crm-body.is-pipeline-page .pipeline-filter-buttons{
    width:auto !important;
    max-width:none !important;
  }
}
@media (max-width: 760px){
  body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
  body.crm-body.is-pipeline-page .pipeline-filter-bar{
    grid-template-columns:1fr !important;
  }
  body.crm-body.is-pipeline-page .pipeline-filter-buttons{
    width:100% !important;
    max-width:none !important;
  }
  body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-primary,
  body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-outline{
    flex:1 1 0 !important;
    max-width:none !important;
    width:auto !important;
  }
}

/* V11_116 - Funil: filtros compactos sem espacos e botoes ao lado da busca */
body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
body.crm-body.is-pipeline-page .pipeline-filter-bar{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  gap:8px !important;
  width:max-content !important;
  max-width:calc(100vw - 88px) !important;
  justify-self:center !important;
  padding:14px 16px !important;
  overflow-x:auto !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-bar > div,
body.crm-body.is-pipeline-page .pipeline-filter-date,
body.crm-body.is-pipeline-page .pipeline-date-range,
body.crm-body.is-pipeline-page .pipeline-filter-status,
body.crm-body.is-pipeline-page .pipeline-filter-owner,
body.crm-body.is-pipeline-page .pipeline-filter-class,
body.crm-body.is-pipeline-page .pipeline-filter-order,
body.crm-body.is-pipeline-page .pipeline-filter-search,
body.crm-body.is-pipeline-page .pipeline-filter-buttons{
  flex:0 0 auto !important;
  min-width:0 !important;
  margin:0 !important;
  grid-column:auto !important;
}
body.crm-body.is-pipeline-page .pipeline-date-range{width:300px !important;max-width:300px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-status{width:140px !important;max-width:140px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-owner{width:170px !important;max-width:170px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-class{width:120px !important;max-width:120px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-order{width:120px !important;max-width:120px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-search{width:190px !important;max-width:190px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-buttons{
  width:130px !important;
  max-width:130px !important;
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  gap:8px !important;
  white-space:nowrap !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-bar .label{margin-bottom:6px !important;white-space:nowrap !important;}
body.crm-body.is-pipeline-page .pipeline-filter-bar .input{height:34px !important;min-height:34px !important;width:100% !important;}
body.crm-body.is-pipeline-page .date-range-inputs{display:flex !important;align-items:center !important;gap:7px !important;}
body.crm-body.is-pipeline-page .date-range-inputs input{width:126px !important;min-width:126px !important;}
body.crm-body.is-pipeline-page .date-range-inputs span{font-size:10px !important;font-weight:900 !important;text-transform:uppercase !important;color:var(--muted) !important;}
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-primary,
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-outline{width:62px !important;min-width:62px !important;max-width:62px !important;height:34px !important;min-height:34px !important;padding:0 !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;}
@media (max-width: 900px){
  body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
  body.crm-body.is-pipeline-page .pipeline-filter-bar{width:calc(100vw - 28px) !important;max-width:calc(100vw - 28px) !important;}
}

/* V11_117 - ajuste definitivo filtros funil: layout flex compacto */
body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,
body.crm-body.is-pipeline-page .pipeline-filter-bar{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  gap:8px !important;
  grid-template-columns:none !important;
  width:max-content !important;
  max-width:calc(100vw - 88px) !important;
  min-height:auto !important;
  margin:0 auto !important;
  padding:14px 16px !important;
  overflow-x:auto !important;
  overflow-y:visible !important;
}
body.crm-body.is-pipeline-page .pipeline-filter-bar > div{flex:0 0 auto !important;min-width:0 !important;margin:0 !important;grid-column:auto !important;}
body.crm-body.is-pipeline-page .pipeline-date-range{width:300px !important;max-width:300px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-status{width:140px !important;max-width:140px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-owner{width:170px !important;max-width:170px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-class{width:120px !important;max-width:120px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-order{width:120px !important;max-width:120px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-search{width:220px !important;max-width:220px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-buttons{width:132px !important;max-width:132px !important;display:flex !important;gap:8px !important;align-items:flex-end !important;justify-content:flex-start !important;}
body.crm-body.is-pipeline-page .pipeline-filter-bar .input{width:100% !important;height:34px !important;min-height:34px !important;}
body.crm-body.is-pipeline-page .date-range-inputs{display:flex !important;align-items:center !important;gap:7px !important;}
body.crm-body.is-pipeline-page .date-range-inputs input{width:126px !important;min-width:126px !important;}
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-primary,
body.crm-body.is-pipeline-page .pipeline-filter-buttons .btn-outline{width:62px !important;min-width:62px !important;max-width:62px !important;height:34px !important;min-height:34px !important;padding:0 !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;}
@media(max-width:900px){body.crm-body.is-pipeline-page form#pipelineFilters.pipeline-filter-bar,body.crm-body.is-pipeline-page .pipeline-filter-bar{width:calc(100vw - 28px) !important;max-width:calc(100vw - 28px) !important;}}
