/* ==========================================================================
   salescode Design System — design-system.css
   Complementa o Bootstrap 3.3.7 + AdminLTE + Tailwind CDN do epedido.
   Carregado automaticamente pelo scandir() em index.php.
   ========================================================================== */


/* ==========================================================================
   1. CSS CUSTOM PROPERTIES (Design Tokens)
   ========================================================================== */

:root {
  /* Brand colors */
  --salescode-navy:        #042D4D;
  --salescode-navy-hover:  #0E3B62;
  --salescode-lime:        #C9FF64;
  --salescode-bismark:     #5D7989;

  /* Typography colors */
  --salescode-title:       #032036;
  --salescode-subtitle:    #364E61;
  --salescode-body:        #5B6771;

  /* Surface colors */
  --salescode-bg:          #FAFDFF;
  --salescode-card:        #FFFFFF;
  --salescode-muted:       #F7FAFC;

  /* Border */
  --salescode-border:      #E2EAF0;
  --salescode-border-focus:#042D4D;

  /* Sidebar */
  --salescode-sidebar-w:   256px;
  --salescode-topbar-h:    56px;

  /* Shadows */
  --salescode-shadow-sm:   0 1px 3px rgba(4, 45, 77, 0.08);
  --salescode-shadow-md:   0 4px 12px rgba(4, 45, 77, 0.12);
  --salescode-shadow-lg:   0 8px 24px rgba(4, 45, 77, 0.16);

  /* Transitions */
  --salescode-transition:  0.2s ease;

  /* Radius */
  --salescode-radius-sm:   4px;
  --salescode-radius-md:   8px;
  --salescode-radius-lg:   12px;
  --salescode-radius-xl:   16px;

  /* Typography scale */
  --salescode-font:        'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --salescode-text-xs:     11px;
  --salescode-text-sm:     12px;
  --salescode-text-base:   13px;
  --salescode-text-md:     14px;
  --salescode-text-lg:     16px;
  --salescode-text-xl:     18px;
  --salescode-text-2xl:    22px;
}


/* ==========================================================================
   2. BASE — fonte e background globais (sobrescreve Bootstrap defaults)
   ========================================================================== */

html,
body {
  margin: 0;
  padding: 0;
  font-family: var(--salescode-font) !important;
  background-color: var(--salescode-bg);
  color: var(--salescode-body);
}


/* ==========================================================================
   3. APP LAYOUT SHELL
   Estrutura flex principal: sidebar + main (topbar + content).
   Não afeta views Bootstrap puras que rodam dentro de #app-content.
   ========================================================================== */

/* Wrapper raiz do novo layout */
.app-layout {
  display: flex;
  min-height: 100vh;
  background: var(--salescode-bg);
}

/* Sidebar de navegação lateral */
.app-sidebar {
  width: var(--salescode-sidebar-w);
  background: var(--salescode-navy);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  transition: transform var(--salescode-transition);
  position: relative;
  z-index: 200;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Área principal (topbar + conteúdo) */
.app-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-width: 0;
}

/* Barra superior */
.app-topbar {
  height: var(--salescode-topbar-h);
  background: var(--salescode-card);
  border-bottom: 1px solid var(--salescode-border);
  padding: 0 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--salescode-shadow-sm);
}

/* Área de conteúdo scrollável */
.app-content {
  flex: 1;
  overflow-y: auto;
  padding: 24px;
  background: var(--salescode-bg);
}

/* Overlay do sidebar em mobile */
.app-sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 190;
}

.app-sidebar-overlay.visible {
  display: block;
}


/* ==========================================================================
   4. SIDEBAR — navegação e módulos
   ========================================================================== */

/* Logo / cabeçalho do sidebar */
.sc-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}

/* Separador de seção dentro do sidebar */
.sc-sidebar-section-label {
  padding: 16px 16px 4px;
  font-size: var(--salescode-text-xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.35);
}

/* Item de navegação */
.sidebar-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  font-size: var(--salescode-text-base);
  font-weight: 500;
  border-radius: var(--salescode-radius-md);
  margin: 1px 8px;
  transition: background var(--salescode-transition),
              color var(--salescode-transition),
              border-color var(--salescode-transition);
  border-left: 2px solid transparent;
  cursor: pointer;
}

.sidebar-nav-item:hover,
.sidebar-nav-item:focus {
  background: var(--salescode-navy-hover);
  color: #ffffff;
  text-decoration: none;
  outline: none;
}

.sidebar-nav-item.active {
  background: var(--salescode-navy-hover);
  color: #ffffff;
  border-left-color: var(--salescode-lime);
  font-weight: 600;
}

/* Ícone dentro do item de nav */
.sidebar-nav-item .sc-nav-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: 0.75;
}

.sidebar-nav-item:hover .sc-nav-icon,
.sidebar-nav-item.active .sc-nav-icon {
  opacity: 1;
}

/* Aba de módulo no topo do sidebar */
.sidebar-module-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  color: rgba(255, 255, 255, 0.6);
  font-size: var(--salescode-text-sm);
  font-weight: 500;
  border-radius: var(--salescode-radius-md);
  cursor: pointer;
  transition: all var(--salescode-transition);
  text-decoration: none;
}

.sidebar-module-tab:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  text-decoration: none;
}

.sidebar-module-tab.active {
  color: var(--salescode-lime);
  background: rgba(201, 255, 100, 0.1);
}

/* Submenu dentro do sidebar */
.sc-sidebar-submenu {
  list-style: none;
  margin: 0;
  padding: 0 0 0 20px;
}

.sc-sidebar-submenu li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  color: rgba(255, 255, 255, 0.6);
  text-decoration: none;
  font-size: var(--salescode-text-sm);
  border-radius: var(--salescode-radius-md);
  margin: 1px 8px;
  transition: all var(--salescode-transition);
}

.sc-sidebar-submenu li a:hover {
  background: rgba(255, 255, 255, 0.07);
  color: #ffffff;
  text-decoration: none;
}

/* Re-estiliza o menu gerado pelo GeradorMenu (classes AdminLTE/Bootstrap) */
#app-sidebar .module-menu,
#app-sidebar nav .module-menu {
  display: block;
  background: transparent;
  padding: 0;
  border: none;
  box-shadow: none;
}

#app-sidebar .menu-item > a,
#app-sidebar nav .menu-item > a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  font-size: var(--salescode-text-base);
  font-weight: 500;
  border-radius: var(--salescode-radius-md);
  margin: 1px 8px;
  transition: all var(--salescode-transition);
  border-left: 2px solid transparent;
}

#app-sidebar .menu-item > a:hover,
#app-sidebar nav .menu-item > a:hover {
  background: var(--salescode-navy-hover);
  color: #ffffff;
  text-decoration: none;
}

#app-sidebar .menu-item > a.active,
#app-sidebar nav .menu-item > a.active {
  background: var(--salescode-navy-hover);
  color: #ffffff;
  border-left-color: var(--salescode-lime);
}

#app-sidebar .submenu,
#app-sidebar nav .submenu {
  list-style: none;
  margin: 0;
  padding: 0 0 0 20px;
  display: none;
}


#app-sidebar .submenu li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  color: rgba(255, 255, 255, 0.6);
  text-decoration: none;
  font-size: var(--salescode-text-sm);
  border-radius: var(--salescode-radius-md);
  margin: 1px 8px;
  transition: all var(--salescode-transition);
}

#app-sidebar .submenu li a:hover {
  background: rgba(255, 255, 255, 0.07);
  color: #ffffff;
}


/* ==========================================================================
   5. BOTÕES salescode
   ========================================================================== */

/* Base — all btn-salescode-* variants share identical sizing (Fix 3) */
.btn-salescode-primary,
.btn-salescode-secondary,
.btn-salescode-outline,
.btn-salescode-destructive,
.btn-salescode-warning,
.btn-salescode-ghost {
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 600;
    border-radius: 10px;
    line-height: 1.5;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    border: none;
    white-space: nowrap;
}

/* btn-sm modifier */
.btn-salescode-primary.btn-sm,
.btn-salescode-secondary.btn-sm,
.btn-salescode-outline.btn-sm,
.btn-salescode-destructive.btn-sm,
.btn-salescode-warning.btn-sm,
.btn-salescode-ghost.btn-sm {
    padding: 5px 12px;
    font-size: 12px;
    border-radius: 8px;
}

/* btn-lg modifier */
.btn-salescode-primary.btn-lg,
.btn-salescode-secondary.btn-lg,
.btn-salescode-outline.btn-lg,
.btn-salescode-destructive.btn-lg,
.btn-salescode-warning.btn-lg,
.btn-salescode-ghost.btn-lg {
    padding: 12px 24px;
    font-size: 14px;
    border-radius: 12px;
}

/* btn-block compatibility */
.btn-salescode-primary.btn-block,
.btn-salescode-secondary.btn-block,
.btn-salescode-outline.btn-block { width: 100%; justify-content: center; }

/* Botão primário — lime */
.btn-salescode-primary {
  background: var(--salescode-lime);
  color: var(--salescode-navy);
  font-family: var(--salescode-font);
}

.btn-salescode-primary:hover,
.btn-salescode-primary:focus {
  background: #b8f040;
  color: var(--salescode-navy);
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(201, 255, 100, 0.4);
  outline: none;
}

.btn-salescode-primary:active {
  transform: translateY(1px);
  box-shadow: none;
}

.btn-salescode-primary:disabled,
.btn-salescode-primary.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Botão secundário — navy */
.btn-salescode-secondary {
  background: var(--salescode-navy);
  color: #ffffff;
  font-family: var(--salescode-font);
}

.btn-salescode-secondary:hover,
.btn-salescode-secondary:focus {
  background: var(--salescode-navy-hover);
  color: #ffffff;
  text-decoration: none;
  box-shadow: var(--salescode-shadow-md);
  outline: none;
}

.btn-salescode-secondary:active {
  transform: translateY(1px);
  box-shadow: none;
}

.btn-salescode-secondary:disabled,
.btn-salescode-secondary.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* Botão outline — borda navy */
.btn-salescode-outline {
  background: transparent;
  color: var(--salescode-navy);
  font-family: var(--salescode-font);
  border: 1.5px solid var(--salescode-navy);
}

.btn-salescode-outline:hover,
.btn-salescode-outline:focus {
  background: var(--salescode-navy);
  color: #ffffff;
  text-decoration: none;
  outline: none;
}

/* btn-salescode-destructive, btn-salescode-warning, btn-salescode-ghost
   color/background variants — add as needed below */
.btn-salescode-destructive {
  background: #DC2626;
  color: #ffffff;
  font-family: var(--salescode-font);
}

.btn-salescode-destructive:hover,
.btn-salescode-destructive:focus {
  background: #b91c1c;
  color: #ffffff;
  text-decoration: none;
  outline: none;
}

.btn-salescode-warning {
  background: #F59E0B;
  color: #ffffff;
  font-family: var(--salescode-font);
}

.btn-salescode-warning:hover,
.btn-salescode-warning:focus {
  background: #d97706;
  color: #ffffff;
  text-decoration: none;
  outline: none;
}

.btn-salescode-ghost {
  background: transparent;
  color: var(--salescode-navy);
  font-family: var(--salescode-font);
}

.btn-salescode-ghost:hover,
.btn-salescode-ghost:focus {
  background: var(--salescode-muted);
  color: var(--salescode-navy);
  text-decoration: none;
  outline: none;
}


/* ==========================================================================
   6. BADGES / STATUS PILLS
   ========================================================================== */

/* Base */
.sc-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 10px;
  font-size: var(--salescode-text-xs);
  font-weight: 600;
  border-radius: 100px;
  white-space: nowrap;
  line-height: 1.6;
}

.badge-success {
  background: #DCFCE7;
  color: #166534;
}

.badge-warning {
  background: #FEF9C3;
  color: #854D0E;
}

.badge-danger {
  background: #FEE2E2;
  color: #991B1B;
}

.badge-info {
  background: #DBEAFE;
  color: #1E40AF;
}

.badge-neutral {
  background: var(--salescode-muted);
  color: var(--salescode-bismark);
  border: 1px solid var(--salescode-border);
}

.badge-lime {
  background: rgba(201, 255, 100, 0.2);
  color: var(--salescode-navy);
}

/* Dot indicator */
.sc-badge-dot::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}


/* ==========================================================================
   7. CARD salescode
   ========================================================================== */

.card-salescode {
  background: #ffffff;
  border-radius: 16px;
  border: 1px solid #f3f4f6;
  margin-bottom: 20px;
  overflow: visible; /* allow dropdowns to overflow */
  box-shadow: 0 1px 4px rgba(4, 45, 77, 0.06);
  transition: box-shadow var(--salescode-transition);
}

.card-salescode:hover {
  box-shadow: var(--salescode-shadow-md);
}

.card-salescode-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--salescode-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.sc-card-header {
    padding: 14px 24px;
    border-bottom: 1px solid #f3f4f6;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #ffffff;
    border-radius: 16px 16px 0 0;
}

.card-salescode-title {
  font-size: var(--salescode-text-md);
  font-weight: 700;
  color: var(--salescode-title);
  margin: 0;
}

.card-salescode-body {
  padding: 20px;
}

.card-salescode-footer {
  padding: 12px 20px;
  border-top: 1px solid var(--salescode-border);
  background: var(--salescode-muted);
}

/* sc-card-body — Fix 1 */
.sc-card-body { padding: 20px 24px; }
.sc-card-body .form-group { margin-bottom: 16px; }
.sc-card-body .form-group:last-child { margin-bottom: 0; }
.sc-card-body .row { margin-left: -8px; margin-right: -8px; }
.sc-card-body .row [class*="col-"] { padding-left: 8px; padding-right: 8px; }

/* Clearfix: Bootstrap 3 usa float nos col-*, o card precisa conter os filhos flutuantes */
.sc-card-body::after,
.card-salescode::after {
    content: "";
    display: table;
    clear: both;
}

/* Colunas Bootstrap diretamente dentro do sc-card-body (sem .row pai) */
.sc-card-body > [class*="col-"] {
    float: left;
    padding-left: 8px;
    padding-right: 8px;
    box-sizing: border-box;
}

/* sc-card-footer */
.sc-card-footer {
    background: #F7FAFC;
    border-top: 1px solid #e5e7eb;
    padding: 14px 24px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    /* Arredondamento inferior para colar visualmente ao card */
    border-radius: 0 0 16px 16px;
    /* Clearfix para floats Bootstrap */
    clear: both;
}
/* Form dentro do card também precisa limpar floats */
.card-salescode > form::after,
.card-salescode form::after {
    content: "";
    display: table;
    clear: both;
}

/* Card de métrica / KPI */
.sc-metric-card {
  background: var(--salescode-card);
  border: 1px solid var(--salescode-border);
  border-radius: var(--salescode-radius-lg);
  padding: 20px;
  box-shadow: var(--salescode-shadow-sm);
  transition: box-shadow var(--salescode-transition), transform var(--salescode-transition);
}

.sc-metric-card:hover {
  box-shadow: var(--salescode-shadow-md);
  transform: translateY(-1px);
}

.sc-metric-label {
  font-size: var(--salescode-text-sm);
  font-weight: 500;
  color: var(--salescode-bismark);
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.sc-metric-value {
  font-size: var(--salescode-text-2xl);
  font-weight: 700;
  color: var(--salescode-title);
  line-height: 1.2;
}

.sc-metric-sub {
  font-size: var(--salescode-text-xs);
  color: var(--salescode-bismark);
  margin-top: 4px;
}


/* ==========================================================================
   8. TIPOGRAFIA
   ========================================================================== */

.sc-page-title {
  font-size: var(--salescode-text-2xl);
  font-weight: 700;
  color: var(--salescode-title);
  margin: 0 0 4px;
  line-height: 1.3;
}

.sc-page-subtitle {
  font-size: var(--salescode-text-base);
  color: var(--salescode-subtitle);
  margin: 0;
}

.sc-section-title {
    font-size: 14px;
    font-weight: 600;
    color: #032036;
    margin: 0;
}

.sc-label {
  font-size: var(--salescode-text-sm);
  font-weight: 600;
  color: var(--salescode-subtitle);
  letter-spacing: 0.03em;
}

.sc-text-muted {
  color: var(--salescode-bismark);
  font-size: var(--salescode-text-sm);
}

.sc-text-navy {
  color: var(--salescode-navy);
}

.sc-text-lime {
  color: var(--salescode-lime);
}


/* ==========================================================================
   9. FORMULÁRIOS
   ========================================================================== */

.sc-input {
  display: block;
  width: 100%;
  padding: 9px 14px;
  font-family: var(--salescode-font);
  font-size: var(--salescode-text-base);
  color: var(--salescode-title);
  background: var(--salescode-card);
  border: 1.5px solid var(--salescode-border);
  border-radius: var(--salescode-radius-md);
  transition: border-color var(--salescode-transition),
              box-shadow var(--salescode-transition);
  outline: none;
  -webkit-appearance: none;
}

.sc-input:focus {
  border-color: var(--salescode-border-focus);
  box-shadow: 0 0 0 3px rgba(4, 45, 77, 0.08);
}

.sc-input::placeholder {
  color: var(--salescode-bismark);
  opacity: 0.7;
}

.sc-input:disabled {
  background: var(--salescode-muted);
  color: var(--salescode-bismark);
  cursor: not-allowed;
}

.sc-select {
  display: block;
  width: 100%;
  padding: 9px 36px 9px 14px;
  font-family: var(--salescode-font);
  font-size: var(--salescode-text-base);
  color: var(--salescode-title);
  background: var(--salescode-card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235D7989' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 12px center;
  border: 1.5px solid var(--salescode-border);
  border-radius: var(--salescode-radius-md);
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  outline: none;
  transition: border-color var(--salescode-transition), box-shadow var(--salescode-transition);
}

.sc-select:focus {
  border-color: var(--salescode-border-focus);
  box-shadow: 0 0 0 3px rgba(4, 45, 77, 0.08);
}

/* Select chevron indicator — aplicar a TODOS os selects do projeto
   (form-control e/ou sc-input), exceto o select nativo oculto do select2. */
select.sc-input:not(.select2-hidden-accessible),
select.form-control:not(.select2-hidden-accessible) {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235D7989' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 16px 16px;
    padding-right: 36px !important;
    cursor: pointer;
    /* Bootstrap 3 fixa height: 34px no form-control; sobrescrevemos para não clipar o conteúdo */
    height: auto !important;
    /* Forçar 100% de largura para não colapsar com width:auto inline */
    width: 100% !important;
    min-width: 80px;
    /* Garantir que o texto selecionado seja visível */
    color: #364E61;
    background-color: #F7FAFC;
}
select.sc-input:not(.select2-hidden-accessible):focus,
select.form-control:not(.select2-hidden-accessible):focus {
    border-color: #042D4D;
    box-shadow: 0 0 0 3px rgba(4,45,77,0.08);
    background-color: #fff;
    outline: none;
}
/* Restore chevron for select2 (custom dropdown) - don't interfere */
.select2-container select,
.select2-container + select {
    appearance: auto !important;
    -webkit-appearance: auto !important;
}
/* Select2 already hides native select — ensure it doesn't get our styles */
.select2-hidden-accessible {
    appearance: auto !important;
    width: auto !important;
    opacity: 0 !important;
}

.sc-form-label {
  display: block;
  font-size: var(--salescode-text-sm);
  font-weight: 600;
  color: var(--salescode-subtitle);
  margin-bottom: 6px;
}

.sc-form-group {
  margin-bottom: 16px;
}

.sc-form-hint {
  font-size: var(--salescode-text-xs);
  color: var(--salescode-bismark);
  margin-top: 4px;
}

.sc-form-error {
  font-size: var(--salescode-text-xs);
  color: #DC2626;
  margin-top: 4px;
}

.sc-input.is-error {
  border-color: #DC2626;
}

.sc-input.is-error:focus {
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.08);
}


/* ==========================================================================
   10. TABELAS
   ========================================================================== */

.sc-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--salescode-text-base);
  color: var(--salescode-body);
}

.sc-table thead th {
  padding: 10px 14px;
  text-align: left;
  font-size: var(--salescode-text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--salescode-bismark);
  background: var(--salescode-muted);
  border-bottom: 1px solid var(--salescode-border);
  white-space: nowrap;
}

.sc-table tbody td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--salescode-border);
  vertical-align: middle;
}

.sc-table tbody tr:last-child td {
  border-bottom: none;
}

.sc-table tbody tr:hover {
  background: #F0F7FF;
}

.sc-table-container {
  background: var(--salescode-card);
  border: 1px solid var(--salescode-border);
  border-radius: var(--salescode-radius-lg);
  overflow: hidden;
  box-shadow: var(--salescode-shadow-sm);
}


/* ==========================================================================
   11. UTILITÁRIOS DE TRANSIÇÃO / ANIMAÇÃO
   ========================================================================== */

/* Para elementos que não usam Tailwind diretamente */
.sc-transition {
  transition: all var(--salescode-transition);
}

.sc-transition-colors {
  transition: color var(--salescode-transition),
              background-color var(--salescode-transition),
              border-color var(--salescode-transition);
}

.sc-transition-transform {
  transition: transform var(--salescode-transition);
}

/* Fade in */
@keyframes sc-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.sc-fade-in {
  animation: sc-fade-in 0.25s ease forwards;
}

/* Pulse (loading indicator) */
@keyframes sc-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

.sc-pulse {
  animation: sc-pulse 1.4s ease-in-out infinite;
}

/* Spin */
@keyframes sc-spin {
  to { transform: rotate(360deg); }
}

.sc-spin {
  animation: sc-spin 0.7s linear infinite;
}


/* ==========================================================================
   12. LOADING / SKELETON
   ========================================================================== */

.sc-skeleton {
  background: linear-gradient(90deg,
    var(--salescode-muted) 25%,
    #EDF2F7 50%,
    var(--salescode-muted) 75%
  );
  background-size: 200% 100%;
  animation: sc-skeleton-shimmer 1.5s infinite;
  border-radius: var(--salescode-radius-sm);
}

@keyframes sc-skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}


/* ==========================================================================
   13. DIVIDER
   ========================================================================== */

.sc-divider {
  border: none;
  border-top: 1px solid var(--salescode-border);
  margin: 16px 0;
}

.sc-divider-vertical {
  display: inline-block;
  width: 1px;
  height: 1em;
  background: var(--salescode-border);
  margin: 0 8px;
  vertical-align: middle;
}


/* ==========================================================================
   14. AVATAR
   ========================================================================== */

.sc-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-weight: 700;
  color: var(--salescode-navy);
  background: rgba(201, 255, 100, 0.25);
  flex-shrink: 0;
}

.sc-avatar-sm  { width: 28px;  height: 28px;  font-size: var(--salescode-text-xs); }
.sc-avatar-md  { width: 36px;  height: 36px;  font-size: var(--salescode-text-sm); }
.sc-avatar-lg  { width: 48px;  height: 48px;  font-size: var(--salescode-text-md); }
.sc-avatar-xl  { width: 64px;  height: 64px;  font-size: var(--salescode-text-xl); }

.sc-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}


/* ==========================================================================
   15. RESPONSIVIDADE DO NOVO LAYOUT
   ========================================================================== */

@media (max-width: 1023px) {
  /* Sidebar oculta por padrão — abre via JS toggle */
  .app-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    z-index: 200;
    transform: translateX(-100%);
  }

  .app-sidebar.open {
    transform: translateX(0);
  }

  .sc-mobile-menu-btn {
    display: flex !important;
  }

  .app-content {
    padding: 16px;
  }
}

@media (min-width: 1024px) {
  .sc-mobile-menu-btn {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .app-content {
    padding: 12px;
  }

  .card-salescode-body {
    padding: 14px;
  }

  .sc-page-title {
    font-size: var(--salescode-text-xl);
  }
}


/* ==========================================================================
   16. COMPATIBILIDADE Bootstrap 3 + AdminLTE
   Corrige possíveis conflitos entre Tailwind CDN e o legado.
   ========================================================================== */

/* Tailwind CDN define box-sizing: border-box em *, mas o preflight está
   desativado (corePlugins.preflight: false) — sem conflito esperado.
   Garantimos aqui por segurança para elementos novos. */
.app-layout *,
.app-layout *::before,
.app-layout *::after {
  box-sizing: border-box;
}

/* AdminLTE injeta .content-wrapper, .main-header, etc. que colidem com o
   novo shell. Ocultamos apenas quando o novo layout está ativo. */
.app-layout ~ .main-header,
.app-layout ~ .main-sidebar,
.app-layout ~ .main-footer {
  display: none !important;
}

/* Dentro do novo layout, o .content-wrapper do AdminLTE perde sentido */
.app-layout .content-wrapper {
  background: transparent !important;
  min-height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

.app-layout .wrapper {
  min-height: auto !important;
}

/* Garantir que o grid Bootstrap continue funcional dentro de #app-content */
.app-content .row {
  margin-right: -15px;
  margin-left: -15px;
}

.app-content [class*="col-"] {
  padding-right: 15px;
  padding-left: 15px;
}

/* Headings do Bootstrap não devem ser resetados pelo Tailwind */
.app-content h1,
.app-content h2,
.app-content h3,
.app-content h4,
.app-content h5,
.app-content h6 {
  font-family: var(--salescode-font);
  font-weight: 700;
  color: var(--salescode-title);
}


/* ==========================================================================
   COMPAT — .btn (Bootstrap classes usadas em views legadas e util.js)
   ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.5;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  vertical-align: middle;
}
.btn-sm { padding: 4px 10px; font-size: 12px; border-radius: 6px; }
.btn-lg { padding: 10px 20px; font-size: 15px; border-radius: 10px; }
.btn-block { width: 100%; justify-content: center; }

.btn-primary  { background: var(--salescode-navy); color: #fff; border-color: var(--salescode-navy); }
.btn-primary:hover, .btn-primary:focus { background: var(--salescode-navy-hover); color: #fff; text-decoration: none; }

.btn-default  { background: #fff; color: var(--salescode-subtitle); border-color: #d1d5db; }
.btn-default:hover { background: #f3f4f6; color: var(--salescode-subtitle); text-decoration: none; }

.btn-success  { background: #16a34a; color: #fff; border-color: #16a34a; }
.btn-success:hover { background: #15803d; color: #fff; text-decoration: none; }

.btn-danger   { background: #dc2626; color: #fff; border-color: #dc2626; }
.btn-danger:hover { background: #b91c1c; color: #fff; text-decoration: none; }

.btn-warning  { background: #d97706; color: #fff; border-color: #d97706; }
.btn-warning:hover { background: #b45309; color: #fff; text-decoration: none; }

.btn-info     { background: #0284c7; color: #fff; border-color: #0284c7; }
.btn-info:hover { background: #0369a1; color: #fff; text-decoration: none; }

.btn-file     { background: #f3f4f6; color: var(--salescode-subtitle); border-color: #d1d5db; }
.btn-file:hover { background: #e5e7eb; text-decoration: none; }

.btn:disabled, .btn.disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }


/* ==========================================================================
   COMPAT — Bootstrap grid + form (classes usadas em views legadas)
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; }

.row { display: flex; flex-wrap: wrap; margin-left: -8px; margin-right: -8px; }
.row::after { content: ''; display: table; clear: both; }

[class*="col-"] { padding-left: 8px; padding-right: 8px; }
.col-xs-1  { width: 8.333%; }  .col-xs-2  { width: 16.666%; } .col-xs-3  { width: 25%; }
.col-xs-4  { width: 33.333%; } .col-xs-5  { width: 41.666%; } .col-xs-6  { width: 50%; }
.col-xs-7  { width: 58.333%; } .col-xs-8  { width: 66.666%; } .col-xs-9  { width: 75%; }
.col-xs-10 { width: 83.333%; } .col-xs-11 { width: 91.666%; } .col-xs-12 { width: 100%; }

/* BS3 float grid — col-xs fora de .row flex (romaneio, recibo, PDFs legados) */
.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6,
.col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {
  float: left;
  position: relative;
  min-height: 1px;
}

/* Romaneio / recibo de frete — containers legados sem .row */
#ordem,
.ordem-print {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  flex: none !important;
  box-sizing: border-box;
}

#ordem > .col-xs-12,
#ordem > .col-12,
.ordem-print > .col-xs-12,
.ordem-print > .col-12 {
  clear: both;
}

#ordem > .col-12::after,
.ordem-print > .col-12::after,
#ordem .bd::after,
.ordem-print .bd::after {
  content: "";
  display: table;
  clear: both;
}

/* Tabelas dentro do romaneio/recibo — sem grid, padding ou estilos do template */
.ordem-print .tabm [class*="col-"] {
  float: none !important;
  width: auto !important;
  clear: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  min-height: 0 !important;
}

.ordem-print .tabm .box,
.ordem-print .tabm .box-primary,
.ordem-print .tabm .box-body,
.ordem-print .tabm .box-header {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  background: transparent !important;
}

.ordem-print .tabm table {
  width: 100%;
  margin: 0 !important;
  border-collapse: collapse;
}

.ordem-print .tabm .table > :not(caption) > * > * {
  padding: 0 !important;
}

.ordem-print .tabm table td,
.ordem-print .tabm table th {
  white-space: normal !important;
  line-height: 1.1;
}

@media (min-width: 768px) {
  .col-sm-1  { width: 8.333%; }  .col-sm-2  { width: 16.666%; } .col-sm-3  { width: 25%; }
  .col-sm-4  { width: 33.333%; } .col-sm-5  { width: 41.666%; } .col-sm-6  { width: 50%; }
  .col-sm-7  { width: 58.333%; } .col-sm-8  { width: 66.666%; } .col-sm-9  { width: 75%; }
  .col-sm-10 { width: 83.333%; } .col-sm-11 { width: 91.666%; } .col-sm-12 { width: 100%; }
}

@media (min-width: 992px) {
  .col-md-1  { width: 8.333%; }  .col-md-2  { width: 16.666%; } .col-md-3  { width: 25%; }
  .col-md-4  { width: 33.333%; } .col-md-5  { width: 41.666%; } .col-md-6  { width: 50%; }
  .col-md-7  { width: 58.333%; } .col-md-8  { width: 66.666%; } .col-md-9  { width: 75%; }
  .col-md-10 { width: 83.333%; } .col-md-11 { width: 91.666%; } .col-md-12 { width: 100%; }
}

.form-group { margin-bottom: 12px; }
.form-control {
  display: block; width: 100%; padding: 7px 10px;
  font-size: 13px; line-height: 1.5;
  color: var(--salescode-subtitle);
  background: #fff; border: 1px solid #d1d5db;
  border-radius: 8px; transition: border-color 0.15s, box-shadow 0.15s;
}
.form-control:focus {
  outline: none; border-color: var(--salescode-navy);
  box-shadow: 0 0 0 3px rgba(4,45,77,0.08);
}
.form-control.input-sm { padding: 4px 8px; font-size: 12px; border-radius: 6px; }

.input-group { display: flex ; width: 100%; overflow: hidden; }
.input-group .form-control { flex: 1 ; min-width: 0; float: none !important; position: static !important; z-index: auto !important; border-radius: 8px 0 0 8px; }
.input-group-btn { display: flex !important; flex-shrink: 0; position: static !important; }
.input-group-btn .btn { border-radius: 0 8px 8px 0; border-left: none; white-space: nowrap; margin-left: 0 !important; position: static !important; z-index: auto !important; }

label { font-size: 13px; font-weight: 500; color: var(--salescode-subtitle); margin-bottom: 4px; display: inline-block; }

.text-center { text-align: center; }
.text-right  { text-align: right; }
.text-left   { text-align: left; }
.text-muted  { color: #9ca3af; }

.hide, .hidden { display: none !important; }
.show { display: block !important; }
.no-print { }
@media print {
  .no-print,
  #app-sidebar,
  #sidebar-collapse-btn,
  #sidebar-overlay,
  #app-topbar,
  #app-page-header,
  #chat-sidebar,
  #not-panel {
    display: none !important;
  }

  html, body {
    overflow: visible !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #fff !important;
  }

  body {
    display: block !important;
  }

  #salescode-app,
  #app-main,
  #app-content {
    display: block !important;
    position: static !important;
    overflow: visible !important;
    height: auto !important;
    max-height: none !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #fff !important;
    box-shadow: none !important;
  }

  .dataTables_wrapper,
  .box,
  .box-body,
  .box-primary,
  .ordem-print,
  .ordem-print .tabm .box-primary {
    overflow: visible !important;
    max-height: none !important;
  }
}

.clearfix::after { content: ''; display: table; clear: both; }
.pull-left  { float: left; }
.pull-right { float: right; }

.alert { padding: 12px 16px; border-radius: 8px; margin-bottom: 12px; font-size: 13px; }
.alert-info    { background: #dbeafe; color: #1e40af; border: 1px solid #bfdbfe; }
.alert-danger  { background: #fee2e2; color: #991b1b; border: 1px solid #fecaca; }
.alert-warning { background: #fef9c3; color: #854d0e; border: 1px solid #fef08a; }
.alert-success { background: #dcfce7; color: #166534; border: 1px solid #bbf7d0; }

.callout { padding: 12px 16px; border-radius: 8px; border-left: 4px solid; margin-bottom: 12px; font-size: 13px; }
.callout-info    { background: #f0f9ff; border-color: #0284c7; color: #0369a1; }
.callout-danger  { background: #fef2f2; border-color: #dc2626; color: #991b1b; }
.callout-warning { background: #fffbeb; border-color: #d97706; color: #92400e; }
.callout-success { background: #f0fdf4; border-color: #16a34a; color: #15803d; }

.box        { background: #fff; border-radius: 12px; border: 1px solid #f3f4f6; margin-bottom: 16px; box-shadow: 0 1px 4px rgba(4,45,77,0.06); }
.box-header { padding: 12px 16px; border-bottom: 1px solid #f3f4f6; display: flex; align-items: center; justify-content: space-between; }
.box-body   { padding: 16px; overflow-x: auto; }
.box-footer { padding: 12px 16px; border-top: 1px solid #f3f4f6; }
.box-title  { font-size: 14px; font-weight: 600; color: var(--salescode-title); margin: 0; }
.box-primary { border-top: 3px solid var(--salescode-navy); }


/* ==========================================================================
   COMPAT — DataTables salescode skin
   ========================================================================== */

table.dataTable {
  width: 100% !important;
  border-collapse: collapse;
  font-size: 13px;
}

table.dataTable thead th,
table.dataTable thead td {
  padding: 10px 14px;
  background: #f8fafc;
  border-bottom: 2px solid #e2e8f0;
  color: var(--salescode-title);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
}

table.dataTable thead th.sorting::after,
table.dataTable thead th.sorting_asc::after,
table.dataTable thead th.sorting_desc::after {
  float: right; opacity: 0.5; font-size: 11px;
}
table.dataTable thead th.sorting::after      { content: '↕'; }
table.dataTable thead th.sorting_asc::after  { content: '↑'; opacity: 1; color: var(--salescode-navy); }
table.dataTable thead th.sorting_desc::after { content: '↓'; opacity: 1; color: var(--salescode-navy); }

table.dataTable tbody tr { border-bottom: 1px solid #f0f4f8; }
table.dataTable tbody tr:hover { background: #f8fafc; }
table.dataTable tbody tr.odd  { background: #ffffff; }
table.dataTable tbody tr.even { background: #fafbfc; }

table.dataTable tbody td { padding: 9px 14px; color: var(--salescode-body); vertical-align: middle; }

table.dataTable tfoot th,
table.dataTable tfoot td {
  padding: 8px 14px;
  border-top: 2px solid #e2e8f0;
  font-weight: 600;
  font-size: 12px;
  background: #f8fafc;
}

.dataTables_wrapper {
  font-size: 13px;
  color: var(--salescode-body);
}

.dataTables_length,
.dataTables_filter {
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.dataTables_length { float: left; }
.dataTables_filter { float: right; }
.dataTables_filter input {
  padding: 5px 10px; border: 1px solid #d1d5db; border-radius: 8px;
  font-size: 13px; outline: none; transition: border-color 0.15s;
}
.dataTables_filter input:focus { border-color: var(--salescode-navy); box-shadow: 0 0 0 3px rgba(4,45,77,0.08); }
.dataTables_length select {
  padding: 4px 8px; border: 1px solid #d1d5db; border-radius: 6px; font-size: 13px; cursor: pointer;
}

.dataTables_info { font-size: 12px; color: #6b7280; padding-top: 8px; float: left; }

.dataTables_paginate { float: right; padding-top: 4px; }
.dataTables_paginate .paginate_button {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 32px; height: 32px; padding: 0 8px;
  border: 1px solid #e5e7eb; border-radius: 6px;
  margin: 0 2px; font-size: 12px; cursor: pointer;
  background: #fff; color: var(--salescode-subtitle);
  transition: all 0.15s; text-decoration: none;
}
.dataTables_paginate .paginate_button:hover { background: #f3f4f6; color: var(--salescode-navy); }
.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
  background: var(--salescode-navy); color: #fff; border-color: var(--salescode-navy);
}
.dataTables_paginate .paginate_button.disabled,
.dataTables_paginate .paginate_button.disabled:hover { opacity: 0.4; cursor: not-allowed; }

.dataTables_wrapper::after { content: ''; display: table; clear: both; }

/* Paginação Bootstrap legacy (.pagination gerada pelo GeradorTabela server-side) */
.pagination { display: inline-flex; gap: 3px; list-style: none; padding: 0; margin: 0; }
.pagination li a,
.pagination li span {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 32px; height: 32px; padding: 0 8px;
  border: 1px solid #e5e7eb; border-radius: 6px;
  font-size: 12px; cursor: pointer;
  background: #fff; color: var(--salescode-subtitle);
  text-decoration: none; transition: all 0.15s;
}
.pagination li.active a,
.pagination li.active span { background: var(--salescode-navy); color: #fff; border-color: var(--salescode-navy); }
.pagination li.disabled a,
.pagination li.disabled span { opacity: 0.4; cursor: not-allowed; pointer-events: none; }
.pagination li a:hover { background: #f3f4f6; color: var(--salescode-navy); }


/* ==========================================================================
   WIZARD STEPS — estilo moderno de etapas numeradas
   ========================================================================== */

.sc-wizard-steps {
  display: flex;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0 24px;
  border-bottom: 2px solid var(--salescode-border);
  background: #fff;
  flex-wrap: wrap;
  gap: 0;
}

.sc-wizard-steps li.nav-item { flex-shrink: 0; }

.sc-step-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 12px 12px;
  text-decoration: none !important;
  color: var(--salescode-bismark);
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: color 0.2s, border-color 0.2s;
  font-size: var(--salescode-text-base);
  font-weight: 500;
  white-space: nowrap;
}

.sc-step-link:hover { color: var(--salescode-navy); text-decoration: none !important; }

.sc-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #e5e7eb;
  color: #6b7280;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  transition: background 0.2s, color 0.2s;
}

.sc-step-icon { font-size: 13px; }
.sc-step-label { font-weight: 500; }

.sc-step-sep {
  color: var(--salescode-bismark);
  opacity: 0.35;
  font-size: 18px;
  padding: 0 2px;
  user-select: none;
  pointer-events: none;
  list-style: none;
}

/* Estado ativo */
.sc-wizard-steps li.nav-item.active .sc-step-link {
  color: var(--salescode-navy);
  border-bottom-color: var(--salescode-lime);
  font-weight: 600;
}

.sc-wizard-steps li.nav-item.active .sc-step-num {
  background: var(--salescode-lime);
  color: var(--salescode-navy);
}

/* ==========================================================================
   WIZARD PAGER — botões Anterior / Próximo
   ========================================================================== */

ul.pager.wizard {
  list-style: none !important;
  padding: 14px 20px;
  margin: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--salescode-border);
  background: var(--salescode-muted);
  border-radius: 0 0 var(--salescode-radius-lg) var(--salescode-radius-lg);
}

ul.pager.wizard li { list-style: none !important; }

ul.pager.wizard li a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 20px;
  border-radius: var(--salescode-radius-md);
  font-size: var(--salescode-text-base);
  font-weight: 600;
  text-decoration: none !important;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
  border: 1.5px solid transparent;
}

ul.pager.wizard li.previous a,
ul.pager.wizard li.first a {
  background: transparent;
  border-color: var(--salescode-border);
  color: var(--salescode-subtitle);
}
ul.pager.wizard li.previous a:hover,
ul.pager.wizard li.first a:hover {
  border-color: var(--salescode-navy);
  color: var(--salescode-navy);
}

ul.pager.wizard li.next a,
ul.pager.wizard li.last a {
  background: var(--salescode-navy);
  border-color: var(--salescode-navy);
  color: #fff;
}
ul.pager.wizard li.next a:hover,
ul.pager.wizard li.last a:hover {
  background: var(--salescode-navy-hover);
  border-color: var(--salescode-navy-hover);
}

ul.pager.wizard li a.disabled,
ul.pager.wizard li.disabled a {
  opacity: 0.4;
  pointer-events: none;
  cursor: default;
}

/* ==========================================================================
   SEARCH PAGES — correções globais para todos os /search
   ========================================================================== */

/* Colunas col-* direto dentro de <form> (sem .row) — fix de grid para os
   search que ainda não foram migrados para rows explícitos */
.sc-card-body form > [class*="col-"] {
  float: left;
  padding-left: 8px;
  padding-right: 8px;
  box-sizing: border-box;
}
.sc-card-body form::after {
  content: "";
  display: table;
  clear: both;
}

/* Remove width:auto inline em selects dentro de cards (herança do antigo AdminLTE) */
.sc-card-body select[style*="width:auto"],
.sc-card-body select[style*="width: auto"] {
  width: 100% !important;
}

/* Barra de ações dos resultados (print / excel) */
.sc-search-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 0;
  margin-bottom: 8px;
}
.sc-search-count {
  font-size: var(--salescode-text-sm);
  color: var(--salescode-bismark);
  margin-right: auto;
}

/* ==========================================================================
   JQUERY UI DATEPICKER — override para o design salescode
   ========================================================================== */

#ui-datepicker-div,
.ui-datepicker {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(4, 45, 77, 0.12);
  padding: 12px;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 13px;
  color: #042D4D;
  width: 260px;
  z-index: 9999 !important;
}

/* Cabeçalho — mês / navegação */
.ui-datepicker .ui-datepicker-header {
  background: #042D4D;
  border: none;
  border-radius: 8px;
  color: #ffffff;
  padding: 8px 6px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.ui-datepicker .ui-datepicker-title {
  font-weight: 700;
  font-size: 13px;
  color: #ffffff;
  line-height: 1;
  text-align: center;
  flex: 1;
}

/* Botões Prev / Next */
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
  position: static;
  top: auto;
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.ui-datepicker .ui-datepicker-prev:hover,
.ui-datepicker .ui-datepicker-next:hover {
  background: rgba(201, 255, 100, 0.2);
}
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
  display: block;
  overflow: hidden;
  text-indent: -9999px;
  width: 0;
  height: 0;
}
.ui-datepicker .ui-datepicker-prev::after {
  content: '‹';
  color: #C9FF64;
  font-size: 18px;
  font-weight: 700;
  text-indent: 0;
}
.ui-datepicker .ui-datepicker-next::after {
  content: '›';
  color: #C9FF64;
  font-size: 18px;
  font-weight: 700;
  text-indent: 0;
}

/* Tabela de dias */
.ui-datepicker table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}
.ui-datepicker th {
  font-size: 11px;
  font-weight: 700;
  color: #5D7989;
  text-align: center;
  padding: 4px 2px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ui-datepicker td {
  padding: 2px;
}
.ui-datepicker td a,
.ui-datepicker td span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
  color: #042D4D;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  margin: 0 auto;
  cursor: pointer;
}
.ui-datepicker td a:hover {
  background: #f0fdf4;
  color: #042D4D;
}

/* Dia de hoje */
.ui-datepicker td.ui-datepicker-today a,
.ui-datepicker td.ui-datepicker-today span {
  background: #e8fff0;
  color: #042D4D;
  font-weight: 700;
  border: 1.5px solid #C9FF64;
}

/* Dia selecionado */
.ui-datepicker td.ui-datepicker-current-day a,
.ui-datepicker td .ui-state-active,
.ui-datepicker td a.ui-state-active {
  background: #042D4D !important;
  color: #C9FF64 !important;
  font-weight: 700;
  border: none;
}

/* Dias de outros meses */
.ui-datepicker td.ui-datepicker-other-month a {
  color: #c4c9d0;
}

/* Linha de semana destacada (ui-datepicker-week-row) */
.ui-datepicker tr:has(.ui-state-highlight) {
  background: transparent;
}

/* Remove todos os gradientes e bordas do jQuery UI padrão */
.ui-widget-content:not(.ui-autocomplete),
.ui-widget-header,
.ui-state-default:not(.ui-autocomplete *),
.ui-state-hover:not(.ui-autocomplete *),
.ui-state-focus:not(.ui-autocomplete *),
.ui-state-active:not(.ui-autocomplete *),
.ui-state-highlight:not(.ui-autocomplete *) {
  background-image: none !important;
  border: none !important;
}

/* jQuery UI Autocomplete */
.ui-autocomplete {
  position: absolute;
  z-index: 10050 !important;
  max-height: 280px;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 4px 0 !important;
  margin: 2px 0 0;
  background: #fff !important;
  border: 1px solid #d1dbe5 !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 16px rgba(4, 45, 77, 0.14) !important;
  list-style: none !important;
  font-family: "Plus Jakarta Sans", system-ui, sans-serif;
  font-size: 13px;
}

.ui-autocomplete .ui-menu-item {
  list-style: none !important;
  margin: 0;
  padding: 0;
}

.ui-autocomplete .ui-menu-item-wrapper {
  padding: 8px 12px !important;
  border: none !important;
  color: #364E61 !important;
  background: transparent !important;
  cursor: pointer;
  line-height: 1.4;
  white-space: normal;
  word-break: break-word;
}

.ui-autocomplete .ui-state-active,
.ui-autocomplete .ui-state-focus,
.ui-autocomplete .ui-menu-item-wrapper.ui-state-active,
.ui-autocomplete .ui-menu-item-wrapper.ui-state-focus {
  margin: 0 !important;
  border: none !important;
  background: #F0F7FF !important;
  color: #042D4D !important;
  font-weight: 500;
}

/* ==========================================================================
   FIM DO ARQUIVO
   ========================================================================== */
