.form-control,
.form-select {
  border: 1px solid #6c757d !important;
}

/* Compactação visual de filtros no sistema (somente formulários GET) */
.main-content form[method="GET"] .form-label {
  font-size: 0.82rem;
  margin-bottom: 0.2rem;
}

/* Fallback robusto para filtros com auto-submit (evita divergencias entre ambientes) */
.main-content form[data-auto-filter="true"] .form-label {
  font-size: 0.82rem;
  margin-bottom: 0.2rem;
}

.main-content form[method="GET"] .form-control,
.main-content form[method="GET"] .form-select {
  font-size: 0.88rem;
  padding: 0.28rem 0.52rem;
  min-height: calc(1.7em + 0.56rem + 2px);
}

.main-content form[data-auto-filter="true"] .form-control,
.main-content form[data-auto-filter="true"] .form-select {
  font-size: 0.88rem;
  padding: 0.28rem 0.52rem;
  min-height: calc(1.7em + 0.56rem + 2px);
}

.main-content form[method="GET"] .btn {
  font-size: 0.82rem;
  padding: 0.25rem 0.55rem;
}

.main-content form[data-auto-filter="true"] .btn {
  font-size: 0.82rem;
  padding: 0.25rem 0.55rem;
}

/* Botao de acao principal nas paginas com filtros compactos */
.main-content .btn-main-action {
  font-size: 0.95rem !important;
  padding: 0.4rem 0.75rem !important;
  font-weight: 600;
}

/* Filtros JS do gerenciamento (inputs com ids f-*) */
.main-content .card .row.g-2.align-items-end .form-label {
  font-size: 0.82rem;
  margin-bottom: 0.2rem !important;
  line-height: 1.1;
}

.main-content .card .row.g-2.align-items-end .form-control,
.main-content .card .row.g-2.align-items-end .form-select {
  font-size: 0.88rem;
  padding: 0.28rem 0.52rem;
  min-height: calc(1.7em + 0.56rem + 2px);
}

.main-content .card .row.g-2.align-items-end .btn {
  font-size: 0.82rem;
  padding: 0.25rem 0.55rem;
}

/* Botões de abrir filtros no mobile (padrão neutro) */
.main-content button[data-bs-target^="#filtrosMobile"] {
  color: #495057 !important;
  border-color: #6c757d !important;
  background-color: transparent !important;
}

.main-content form[method="GET"] {
  margin-bottom: 0.35rem;
}

.main-content .card:has(form[method="GET"]) {
  margin-bottom: 0.75rem !important;
}

.main-content .card:has(form[method="GET"]) .card-body {
  padding-top: 0.7rem;
  padding-bottom: 0.7rem;
}

.main-content form[method="GET"].row {
  row-gap: 0.45rem !important;
}

.main-content form[method="GET"] .form-label {
  line-height: 1.1;
}

/* =====================
   RESPONSIVIDADE MOBILE
   ===================== */

/* Evitar scroll horizontal indesejado */
body {
  overflow-x: hidden;
}

/* Topbar visível apenas no mobile (hambúrguer) */
#mobile-topbar {
  display: none;
  position: sticky;
  top: 0;
  z-index: 1040;
  background-color: #f8f9fa;
  border-bottom: 1px solid #dee2e6;
  padding: 0.5rem 1rem;
  align-items: center;
}

/* No mobile, mostrar topbar e ajustar layout */
@media (max-width: 991.98px) {
  #mobile-topbar {
    display: flex !important; /* sobrescreve d-md-none do Bootstrap (usa !important internamente) */
  }

  /* Sidebar desktop: ocultar no mobile (será offcanvas) */
  #sidebar {
    display: none !important;
  }

  /* Conteúdo principal ocupa 100% no mobile */
  .main-content {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  /* Evitar tabelas quebrarem o layout */
  .table-responsive {
    font-size: 0.85rem;
  }

  /* Filtros sticky: não usar sticky no mobile para não cobrir conteúdo */
  .sticky-top {
    position: relative !important;
  }

  /* Ajustar cabeçalhos com botões para empilhar no mobile */
  .mobile-flex-wrap {
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .main-content form[method="GET"] .form-label {
    font-size: 0.78rem;
  }

  .main-content form[data-auto-filter="true"] .form-label {
    font-size: 0.78rem;
  }

  .main-content form[method="GET"] .form-control,
  .main-content form[method="GET"] .form-select {
    font-size: 0.84rem;
    min-height: calc(1.6em + 0.5rem + 2px);
  }

  .main-content form[data-auto-filter="true"] .form-control,
  .main-content form[data-auto-filter="true"] .form-select {
    font-size: 0.84rem;
    min-height: calc(1.6em + 0.5rem + 2px);
  }

  .main-content form[method="GET"] {
    margin-bottom: 0.25rem;
  }

  .main-content .card:has(form[method="GET"]) {
    margin-bottom: 0.5rem !important;
  }

  .main-content .card:has(form[method="GET"]) .card-body {
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
  }

  .main-content form[method="GET"].row {
    row-gap: 0.35rem !important;
  }

  .main-content .card .row.g-2.align-items-end .form-label {
    font-size: 0.78rem;
  }

  .main-content .card .row.g-2.align-items-end .form-control,
  .main-content .card .row.g-2.align-items-end .form-select {
    font-size: 0.84rem;
    min-height: calc(1.6em + 0.5rem + 2px);
  }

  .main-content .card .row.g-2.align-items-end .btn {
    font-size: 0.8rem;
    padding: 0.2rem 0.5rem;
  }

  .main-content .btn-main-action {
    font-size: 0.9rem !important;
    padding: 0.35rem 0.65rem !important;
  }
}

/* Sidebar offcanvas: ajustes de estilo */
#offcanvas-sidebar .nav-link {
  padding: 0.5rem 0.75rem;
}

#offcanvas-sidebar .nav-link.active {
  background-color: #0d6efd;
  color: #fff;
  border-radius: 0.375rem;
}

/* Table-to-Cards Mobile Responsive */
@media (max-width: 767.98px) {
  .table-cards-mobile,
  .table-cards-mobile thead,
  .table-cards-mobile tbody,
  .table-cards-mobile th,
  .table-cards-mobile td,
  .table-cards-mobile tr {
    display: block;
  }
  .table-cards-mobile thead tr {
    position: absolute;
    top: -9999px;
    left: -9999px;
  }
  .table-cards-mobile tr {
    margin-bottom: 1rem;
    border: 1px solid #dee2e6;
    border-radius: 0.5rem;
    background: #fff;
    padding: 0.5rem;
    position: relative;
  }
  .table-cards-mobile tr.table-separator {
    border: none;
    background: transparent;
    margin-bottom: 0.5rem;
  }
  .table-cards-mobile tr.table-separator td {
    border: none;
    height: 1px !important;
    background: #ccc;
    padding: 0 !important;
    min-height: 1px;
  }
  .table-cards-mobile tr.table-separator td::before {
    content: none !important;
  }

  .table-cards-mobile td {
    border: none;
    border-bottom: 1px solid #eee;
    position: relative;
    padding-left: 45% !important;
    text-align: right;
    min-height: 2.5rem;
  }
  .table-cards-mobile td:last-child {
    border-bottom: 0;
  }
  .table-cards-mobile td::before {
    position: absolute;
    top: 0.9rem;
    left: 10px;
    width: 40%;
    padding-right: 10px;
    white-space: pre-wrap;
    content: attr(data-label);
    font-weight: 600;
    text-align: left;
    color: #495057;
  }
}
