/**
 * Recart + Shreyu — overrides de marca e compatibilidade.
 * Overrides Recart + Shreyu. Assets em public/assets/shreyu/.
 */

:root {
  --bs-primary: #c41e3a;
  --bs-primary-rgb: 196, 30, 58;
  --bs-link-color: #c41e3a;
  --bs-link-hover-color: #9e1830;
}

[data-topbar-color="brand"] .navbar-custom {
  background: linear-gradient(135deg, #c41e3a 0%, #9e1830 100%) !important;
}

.btn-primary {
  --bs-btn-bg: #c41e3a;
  --bs-btn-border-color: #c41e3a;
  --bs-btn-hover-bg: #9e1830;
  --bs-btn-hover-border-color: #9e1830;
  --bs-btn-active-bg: #9e1830;
  --bs-btn-active-border-color: #861528;
  --bs-btn-disabled-bg: #c41e3a;
  --bs-btn-disabled-border-color: #c41e3a;
}

.form-check-input:checked {
  background-color: #c41e3a;
  border-color: #c41e3a;
}

body {
  font-family: "Inter", var(--bs-body-font-family, system-ui, sans-serif);
}

.left-side-menu .side-menu li > a > i.bi,
.left-side-menu .nav-second-level li a i.bi {
  display: inline-block;
  vertical-align: middle;
  width: 18px;
  height: 18px;
  font-size: 1.05rem;
  line-height: 1;
  margin-right: 0;
  text-align: center;
  flex-shrink: 0;
}

.left-side-menu .recart-side-parent-link,
.left-side-menu .recart-side-sub-link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.left-side-menu .recart-side-link-label {
  flex: 1 1 auto;
  min-width: 0;
}

.left-side-menu .recart-side-badge {
  flex-shrink: 0;
  font-size: 0.65rem;
  font-weight: 600;
  line-height: 1.2;
  padding: 0.2em 0.55em;
}

.left-side-menu .recart-side-sub-link .recart-side-badge {
  margin-left: auto;
}

.left-side-menu .recart-side-parent-link .menu-arrow {
  flex-shrink: 0;
  margin-left: auto;
}

.left-side-menu .recart-side-parent-link .recart-side-badge {
  margin-left: 0;
  margin-right: 0.15rem;
}

.left-side-menu .recart-side-parent-link:not([data-bs-toggle]) .recart-side-badge {
  margin-left: auto;
  margin-right: 0;
}

.left-side-menu .nav-second-level li a {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.left-side-menu .side-menu li > a .badge.float-end,
.left-side-menu .nav-second-level li a .badge.float-end {
  margin-left: auto;
}

.recart-row-actions .recart-action-btn {
  min-width: 9.5rem;
  white-space: nowrap;
}

.recart-topbar-avatar {
  width: 32px;
  height: 32px;
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 600;
}

[data-topbar-color="light"] .recart-topbar-avatar {
  background: #c41e3a;
  color: #fff;
}

.noti-icon-badge {
  position: absolute;
  top: 12px;
  right: 4px;
  font-size: 10px;
  min-width: 18px;
  padding: 2px 5px;
}

.content-page .container-fluid {
  padding-top: 1.25rem;
  padding-bottom: 2rem;
}

.content-page .container-fluid.recart-ajustes {
  font-size: 0.95rem;
}
.content-page .container-fluid.recart-ajustes .card {
  font-size: 0.95rem;
}
.content-page .container-fluid.recart-ajustes .table {
  font-size: 0.92rem;
}
.content-page .container-fluid.recart-ajustes .h4 {
  font-size: 1.45rem;
  font-weight: 600;
}


.btn-novo {
  background: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}
.btn-novo:hover {
  background: #9e1830;
  border-color: #9e1830;
  color: #fff;
}

.recart-card {
  box-shadow: var(--bs-card-box-shadow, 0 0.75rem 1.5rem rgba(18, 38, 63, 0.03));
  border-radius: 0.375rem;
}

.recart-confirm-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--recart-warning-bg, #fff5d6);
  color: var(--recart-warning-strong, #8a6708);
}

.recart-loader-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.75rem;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
}
.recart-loader-overlay.recart-loader-visible {
  display: flex;
  opacity: 1;
  visibility: visible;
}
.recart-loader-spinner {
  width: 42px;
  height: 42px;
  border: 3px solid rgba(255, 255, 255, 0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: recart-spin 0.75s linear infinite;
}
.recart-loader-text {
  color: #fff;
  font-weight: 500;
}
@keyframes recart-spin {
  to { transform: rotate(360deg); }
}

.recart-toast {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.12);
}

.authentication-bg .recart-auth-logo {
  max-height: 48px;
  width: auto;
}

.authentication-bg .authentication-form .input-group-text {
  background: var(--bs-light);
}

.recart-auvo .sidebar,
.recart-auvo #sidebar,
.recart-auvo aside.sidebar {
  display: none !important;
}

[data-bs-theme="dark"] .recart-card,
[data-bs-theme="dark"] .card.recart-card {
  background-color: var(--bs-secondary-bg);
}

[data-bs-theme="dark"] .table-light {
  --bs-table-bg: var(--bs-tertiary-bg);
}

/* ---------- Fase 2: componentes de página -------------------------------- */

.recart-page-header-row {
  margin-bottom: 1.25rem;
}

.page-title-box {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.page-title-box .page-title {
  font-weight: 600;
  font-size: 1.35rem;
}

.page-title-box .page-title-left {
  flex: 1 1 auto;
  min-width: 0;
}

.page-title-box .page-title-right {
  flex: 0 0 auto;
}

.recart-breadcrumb-wrap .breadcrumb {
  font-size: 0.8125rem;
}

.recart-breadcrumb-wrap .breadcrumb-item + .breadcrumb-item::before {
  content: "›";
}

/* Cards de lista / tabela */
.card.recart-list-card,
.card.recart-card:not(.recart-filters) {
  border: 0;
  box-shadow: 0 0 35px 0 rgba(154, 161, 171, 0.12);
  margin-bottom: 1.5rem;
}

.card.recart-list-card > .card-header,
.card.recart-card > .card-header.recart-list-card-header {
  background: transparent;
  border-bottom: 1px solid var(--bs-border-color);
  padding: 0.85rem 1.25rem;
}

.card.recart-list-card .table thead th,
.card.recart-card .table-responsive + .table thead th,
.card.recart-card > .table-responsive .table thead th {
  background: var(--bs-tertiary-bg);
  font-weight: 600;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--bs-secondary-color);
  border-bottom-width: 1px;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  white-space: nowrap;
}

.card.recart-card .table-hover > tbody > tr:hover {
  background-color: rgba(var(--bs-primary-rgb), 0.04);
}

/* Filtros */
.recart-filters .form-label {
  color: var(--bs-secondary-color);
}

/* Abas (contrato, etc.) */
.nav-tabs-recart {
  border-bottom: 1px solid var(--bs-border-color);
  gap: 0.25rem;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: thin;
}

.nav-tabs-recart .nav-link {
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--bs-secondary-color);
  font-weight: 500;
  font-size: 0.9rem;
  padding: 0.65rem 1rem;
  white-space: nowrap;
  border-radius: 0;
  transition: color 0.15s ease, border-color 0.15s ease;
}

.nav-tabs-recart .nav-link:hover {
  color: var(--bs-primary);
  border-bottom-color: rgba(var(--bs-primary-rgb), 0.35);
}

.nav-tabs-recart .nav-link.active {
  color: var(--bs-primary);
  background: transparent;
  border-bottom-color: var(--bs-primary);
}

/* Dashboard — stat cards Shreyu */
.recart-dash-section-title {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
  margin: 1.5rem 0 0.75rem;
}

.recart-stat-card {
  border: 0;
  box-shadow: 0 0 35px 0 rgba(154, 161, 171, 0.12);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  height: 100%;
}

a:hover .recart-stat-card,
.recart-stat-card-link:hover .recart-stat-card {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(154, 161, 171, 0.18);
}

.recart-stat-card .recart-stat-icon {
  width: 48px;
  height: 48px;
  border-radius: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  flex-shrink: 0;
}

.recart-stat-card .recart-stat-value {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.1;
}

.recart-stat-card .recart-stat-value-sm {
  font-size: 1.35rem;
}

.recart-stat-card .recart-stat-label {
  font-size: 0.8125rem;
  color: var(--bs-secondary-color);
}

.recart-stat-mini {
  border-radius: 0.5rem;
  padding: 0.85rem 1rem;
  background: var(--bs-tertiary-bg);
  height: 100%;
  transition: background 0.15s ease;
}

a:hover .recart-stat-mini {
  background: rgba(var(--bs-primary-rgb), 0.08);
}

/* Empty state */
.recart-empty-state-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(var(--bs-primary-rgb), 0.08);
  color: var(--bs-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
}

/* Notificações */
.recart-notification-unread {
  background: rgba(var(--bs-primary-rgb), 0.05);
  border-left: 3px solid var(--bs-primary);
}

/* Fechamento show — nav mês */
.fechamento-month-nav {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.fechamento-month-nav__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.375rem;
  border: 1px solid var(--bs-border-color);
  color: var(--bs-body-color);
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease;
}

.fechamento-month-nav__btn:hover {
  background: var(--bs-tertiary-bg);
  border-color: var(--bs-primary);
  color: var(--bs-primary);
}

.fechamento-month-nav__btn--disabled {
  opacity: 0.4;
  pointer-events: none;
}

/* Botões de ação padronizados */
.btn-editar {
  background: transparent;
  border-color: var(--bs-border-color);
  color: var(--bs-body-color);
}
.btn-editar:hover {
  background: var(--bs-tertiary-bg);
  border-color: var(--bs-secondary-color);
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .recart-stat-mini {
  background: var(--bs-secondary-bg);
}

[data-bs-theme="dark"] a:hover .recart-stat-mini {
  background: rgba(var(--bs-primary-rgb), 0.15);
}

/* ---------- Fase 2b: formulários ----------------------------------------- */

.recart-form-page {
  margin-bottom: 0.5rem;
}

.recart-form-page .card-header {
  background: transparent;
}

.recart-form-back {
  border-top: 1px dashed var(--bs-border-color);
}

.recart-permissions-card .recart-permissions-module:last-child {
  border-bottom: none;
}

/* Fechamento show — tabelas densas */
.recart-fechamento-show .card.recart-card {
  margin-bottom: 1.25rem;
}

.recart-fechamento-show .card.recart-card > .card-body {
  padding: 1rem 1.15rem;
}

.fechamento-table-printers .fechamento-th-a3,
.fechamento-table-printers .fechamento-td-a3 {
  padding-right: 1rem !important;
  border-right: 1px solid rgba(0, 0, 0, 0.08);
}

.fechamento-table-printers .fechamento-th-counter {
  line-height: 1.1;
  vertical-align: bottom;
}

.fechamento-table-printers .fechamento-counter-cell {
  line-height: 1.15;
}

.fechamento-table-printers .fechamento-counter-date {
  font-size: 0.72rem;
  color: var(--bs-secondary-color);
  min-height: 1em;
}

.fechamento-table-printers .fechamento-value-cell {
  min-width: 0;
  white-space: nowrap;
}

.fechamento-table-printers .fechamento-value-cell .small {
  font-size: 0.72rem;
  line-height: 1.1;
}

.fechamento-table-fixed .fechamento-fixed-spacer,
.fechamento-table-fixed thead th[aria-hidden="true"] {
  background: transparent;
}

.fechamento-table-printers td,
.fechamento-table-printers th {
  word-break: normal;
  overflow-wrap: anywhere;
}

.fechamento-table-printers .fechamento-serial-cell {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.fechamento-table-printers .fechamento-serial-cell code {
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: bottom;
  white-space: nowrap;
}

.fechamento-bulk-btn--counters:not(:disabled) {
  background-color: var(--bs-body-bg);
  color: var(--bs-danger);
  border-color: var(--bs-danger);
}

.fechamento-bulk-btn--counters:not(:disabled):hover,
.fechamento-bulk-btn--counters:not(:disabled):focus {
  background-color: var(--bs-danger);
  border-color: var(--bs-danger);
  color: #fff;
}

.fechamento-bulk-btn--send:not(:disabled) {
  background-color: var(--bs-body-bg);
  color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.fechamento-bulk-btn--send:not(:disabled):hover,
.fechamento-bulk-btn--send:not(:disabled):focus {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
  color: #fff;
}

.fechamento-status-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

[data-bs-theme="dark"] .fechamento-table-printers .fechamento-td-a3 {
  border-right-color: rgba(255, 255, 255, 0.08);
}

/* ---------- Fase 3: relatórios ------------------------------------------- */

.recart-relatorios .recart-stat-value {
  font-size: 1.75rem;
}

.recart-relatorios #recart-chart-fechamento-trend,
.recart-relatorios #recart-chart-contracts,
.recart-relatorios #recart-chart-clients,
.recart-relatorios #recart-chart-printers {
  width: 100%;
}

.recart-reports-chart {
  min-height: 280px;
  width: 100%;
}

.recart-reports-chart--donut {
  min-height: 240px;
}

/* ---------- Dashboard compacto + KPI tiles -------------------------------- */

.recart-dashboard-compact .recart-dash-section-title {
  margin-top: 1rem;
}

.recart-dashboard-compact .recart-dash-section-title:first-of-type {
  margin-top: 0.25rem;
}

.recart-kpi-tile {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  border-radius: 0.5rem;
  background: var(--bs-body-bg);
  box-shadow: 0 0 24px 0 rgba(154, 161, 171, 0.1);
  border: 1px solid var(--bs-border-color);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

a.recart-kpi-tile:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(154, 161, 171, 0.14);
  border-color: rgba(var(--bs-primary-rgb), 0.25);
}

.recart-kpi-tile--static {
  cursor: default;
}

.recart-kpi-tile__icon {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.recart-kpi-tile__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.recart-kpi-tile__value {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.recart-kpi-tile__label {
  font-size: 0.72rem;
  color: var(--bs-secondary-color);
  line-height: 1.25;
}

.recart-dash-chart-card {
  box-shadow: 0 0 24px 0 rgba(154, 161, 171, 0.1);
}

.recart-dash-mini-chart {
  min-height: 168px;
  width: 100%;
}

[data-bs-theme="dark"] .recart-kpi-tile {
  box-shadow: 0 0 24px 0 rgba(0, 0, 0, 0.2);
}

/* Relatórios — KPIs empilhados com valor e rótulo centralizados */
.recart-relatorios .recart-kpi-tile {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 0.55rem;
  padding: 1rem 0.75rem;
}

.recart-relatorios .recart-kpi-tile__body {
  align-items: center;
  text-align: center;
  width: 100%;
}

.recart-relatorios .recart-kpi-tile__value,
.recart-relatorios .recart-kpi-tile__label {
  display: block;
  width: 100%;
  text-align: center;
  white-space: normal;
}

/* ---------- Fase 4: polimento dark mode ---------------------------------- */

.recart-card > .card-header,
.recart-card > .card-footer {
  background: transparent;
}

.recart-subtle-panel {
  background: var(--bs-tertiary-bg);
}

.cost-tiered-panel {
  background: var(--bs-body-bg);
}

.recart-row-muted {
  background: var(--bs-tertiary-bg);
}

.recart-count-badge {
  background: var(--bs-secondary-bg);
  color: var(--bs-body-color);
  font-weight: 500;
}

[data-bs-theme="dark"] .recart-card .table-light {
  --bs-table-bg: rgba(255, 255, 255, 0.04);
  --bs-table-color: var(--bs-body-color);
  --bs-table-border-color: rgba(255, 255, 255, 0.08);
}

[data-bs-theme="dark"] .recart-subtle-panel code,
[data-bs-theme="dark"] .cost-tiered-panel code {
  color: var(--bs-body-color);
}

/* Menu — 3º nível (Fechamento > Ajustes > …) */
.left-side-menu .recart-nav-third-level {
  padding-left: 0.75rem;
}

.left-side-menu .recart-nav-third-level .recart-side-third-link {
  padding-left: 2.35rem;
  font-size: 0.8125rem;
}

.left-side-menu .recart-side-nested-parent .menu-arrow {
  margin-left: auto;
}
