/* =====================================================================
   TRIDELIVERY — DESIGN SYSTEM (Controle)
   Canonical tokens + components. Include ONCE globally (templates/admin/index.html).
   Screens should consume classes — avoid redefining these rules inline.
   Doc: docs/DESIGN_SYSTEM.md
   ===================================================================== */

:root {
  --primary:     #DC0E2A;  /* Tridelivery red */
  --primary-dk:  #A00B1F;
  --primary-lt:  #FEE2E5;
  --success:     #10B981;
  --success-lt:  #ECFDF5;
  --warning:     #F59E0B;
  --warning-lt:  #FFFBEB;
  --danger:      #EF4444;
  --danger-lt:   #FEF2F2;
  --info:        #3B82F6;
  --info-lt:     #EFF6FF;
  --purple:      #8B5CF6;
  --purple-lt:   #F5F3FF;
  --teal:        #14B8A6;
  --teal-lt:     #F0FDFA;
  --orange:      #F97316;
  --orange-lt:   #FFF7ED;
  --rose:        #F43F5E;
  --rose-lt:     #FFF1F2;

  --bg:          #F1F5F9;
  --bg-soft:     #F8FAFC;
  --card-bg:     #FFFFFF;
  --text:        #1E293B;
  --text-muted:  #64748B;
  --text-soft:   #94A3B8;
  --border:      #E2E8F0;
  --border-dk:   #CBD5E1;

  --shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);
  --shadow:      0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);
  --shadow-lg:   0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);

  --radius:      12px;
  --radius-sm:   8px;
  --radius-xs:   6px;

  --transition:  all .2s cubic-bezier(.4,0,.2,1);
}

/* --- Page canvas ----------------------------------------------------- */
.page-content-wrapper .page-content {
  background: var(--bg);
  padding: 24px !important;
  min-height: 100vh;
}

/* --- Alerts (override legacy) --------------------------------------- */
#twofa-alert.alert-danger,
#erro-api.alert-danger,
#erro-js.alert-danger {
  background: var(--danger-lt);
  border: 1px solid #FECACA;
  border-left: 4px solid var(--danger);
  border-radius: var(--radius-sm);
  color: #991B1B;
  box-shadow: var(--shadow-sm);
  padding: 14px 18px;
  margin-bottom: 20px;
}

/* --- Typography helpers --------------------------------------------- */
.section-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 12px;
}
.section-label i { color: var(--primary); margin-right: 4px; }

/* --- Page header (replaces Metronic page-title/breadcrumb) ---------- */
.page-header-modern {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 18px 24px;
  margin-bottom: 20px;
}
.page-header-modern .ph-title {
  font-size: 20px; font-weight: 700; color: var(--text);
  display: flex; align-items: center; gap: 10px;
  margin: 0;
}
.page-header-modern .ph-title i { color: var(--primary); font-size: 22px; }
.page-header-modern .ph-subtitle {
  font-size: 13px; font-weight: 400; color: var(--text-muted);
  margin-left: 6px;
}
.page-header-modern .ph-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* Breadcrumb modern */
.breadcrumb-modern {
  display: flex; align-items: center; flex-wrap: wrap; gap: 4px;
  list-style: none; padding: 0; margin: 0 0 16px;
  font-size: 12px; color: var(--text-muted);
}
.breadcrumb-modern li { display: inline-flex; align-items: center; gap: 4px; }
.breadcrumb-modern li + li::before {
  content: "/"; color: var(--text-soft); margin: 0 6px; font-weight: 400;
}
.breadcrumb-modern a {
  color: var(--text-muted); text-decoration: none; transition: var(--transition);
}
.breadcrumb-modern a:hover { color: var(--primary); }
.breadcrumb-modern li:last-child { color: var(--text); font-weight: 600; }

/* --- Quick-access icon buttons -------------------------------------- */
.quick-access-wrap { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 24px; }
.icon-btn-modern {
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; min-width: 90px; padding: 16px 18px;
  background: var(--card-bg); border: 1px solid var(--border);
  border-radius: var(--radius-sm); box-shadow: var(--shadow-sm);
  text-decoration: none !important; color: var(--text) !important;
  transition: var(--transition);
}
.icon-btn-modern:hover {
  background: var(--primary); border-color: var(--primary);
  color: #fff !important; box-shadow: var(--shadow); transform: translateY(-2px);
}
.icon-btn-modern i { font-size: 20px; color: var(--primary); transition: var(--transition); }
.icon-btn-modern:hover i { color: #fff; }
.icon-btn-modern span { font-size: 11px; font-weight: 600; letter-spacing: .02em; white-space: nowrap; }

/* --- Filter card (+ legacy alias .lst-filtros) ---------------------- */
.filtros-card,
.lst-filtros {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 20px 24px;
  margin-bottom: 24px;
}
.filtros-card .filtros-title,
.lst-filtros .lst-filtros-title,
.lst-filtros .filtros-title {
  font-size: 13px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .06em;
  margin-bottom: 16px;
  display: flex; align-items: center; gap: 8px;
}
.filtros-card .filtros-title i,
.lst-filtros .lst-filtros-title i { color: var(--primary); }
.filtros-grid { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; }
.filtro-group { display: flex; flex-direction: column; gap: 4px; min-width: 140px; }
.filtro-group label {
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .04em; margin: 0;
}
.filtros-card .form-control,
.lst-filtros .form-control,
.filtro-group .form-control {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xs) !important;
  background: var(--bg-soft) !important;
  color: var(--text) !important;
  font-size: 13px !important;
  padding: 7px 10px !important;
  height: 36px !important;
  box-shadow: none !important;
  transition: var(--transition) !important;
}
.filtros-card .form-control:focus,
.lst-filtros .form-control:focus,
.filtro-group .form-control:focus {
  border-color: var(--primary) !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(220,14,42,.15) !important;
}
.filtros-card .input-group { border-radius: var(--radius-xs); overflow: hidden; }
.filtros-card .input-group-btn .btn.default,
.filtros-card .input-group-btn .btn-default {
  background: #F1F5F9; border: 1px solid var(--border); border-left: none;
  color: var(--text-muted); height: 36px; padding: 0 10px;
  border-radius: 0 var(--radius-xs) var(--radius-xs) 0;
}
.filtros-card .input-group-btn .btn.default:hover,
.filtros-card .input-group-btn .btn-default:hover {
  background: var(--primary); color: #fff; border-color: var(--primary);
}
.filtro-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

/* --- Buttons (modern) ----------------------------------------------- */
.btn-modern-primary {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 18px;
  background: var(--primary); color: #fff !important;
  border: none; border-radius: var(--radius-xs);
  font-size: 13px; font-weight: 600;
  cursor: pointer; transition: var(--transition);
  text-decoration: none; line-height: 1;
}
.btn-modern-primary:hover {
  background: var(--primary-dk); box-shadow: var(--shadow);
  transform: translateY(-1px); color: #fff !important;
}
.btn-modern-outline {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  background: transparent; color: var(--text-muted) !important;
  border: 1px solid var(--border); border-radius: var(--radius-xs);
  font-size: 13px; font-weight: 600;
  cursor: pointer; transition: var(--transition);
  text-decoration: none; line-height: 1;
}
.btn-modern-outline:hover {
  background: var(--bg); border-color: var(--border-dk); color: var(--text) !important;
}
.btn-modern-success { background: var(--success); color: #fff !important; border: none; }
.btn-modern-success:hover { background: #059669; color: #fff !important; }
.btn-modern-danger  { background: var(--danger); color: #fff !important; border: none; }
.btn-modern-danger:hover  { background: #DC2626; color: #fff !important; }
.btn-modern-sm { padding: 5px 12px; font-size: 12px; }
.btn-modern-xs { padding: 3px 8px; font-size: 11px; gap: 4px; }
.btn-modern-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; padding: 0;
  background: transparent; color: var(--text-muted);
  border: 1px solid var(--border); border-radius: var(--radius-xs);
  transition: var(--transition); cursor: pointer;
}
.btn-modern-icon:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-modern-icon.danger:hover { background: var(--danger); border-color: var(--danger); }
.btn-modern-icon.success:hover { background: var(--success); border-color: var(--success); }

/* --- KPI cards ------------------------------------------------------ */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px; margin-bottom: 24px;
}
.kpi-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  display: flex; flex-direction: column; gap: 12px;
  transition: var(--transition);
  position: relative; overflow: hidden;
}
.kpi-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  border-radius: var(--radius) var(--radius) 0 0;
}
.kpi-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.kpi-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; font-size: 18px;
}
.kpi-value { font-size: 22px; font-weight: 700; color: var(--text); line-height: 1.1; letter-spacing: -.5px; }
.kpi-label { font-size: 12px; color: var(--text-muted); font-weight: 500; margin-top: 2px; }

.kpi-blue::before    { background: var(--info); }
.kpi-blue .kpi-icon  { background: var(--info-lt); color: var(--info); }
.kpi-amber::before   { background: var(--warning); }
.kpi-amber .kpi-icon { background: var(--warning-lt); color: var(--warning); }
.kpi-teal::before    { background: var(--teal); }
.kpi-teal .kpi-icon  { background: var(--teal-lt); color: var(--teal); }
.kpi-green::before   { background: var(--success); }
.kpi-green .kpi-icon { background: var(--success-lt); color: var(--success); }
.kpi-orange::before  { background: var(--orange); }
.kpi-orange .kpi-icon{ background: var(--orange-lt); color: var(--orange); }
.kpi-red::before     { background: var(--danger); }
.kpi-red .kpi-icon   { background: var(--danger-lt); color: var(--danger); }
.kpi-purple::before  { background: var(--purple); }
.kpi-purple .kpi-icon{ background: var(--purple-lt); color: var(--purple); }
.kpi-rose::before    { background: var(--rose); }
.kpi-rose .kpi-icon  { background: var(--rose-lt); color: var(--rose); }
.kpi-primary::before { background: var(--primary); }
.kpi-primary .kpi-icon { background: var(--primary-lt); color: var(--primary); }

/* --- Portlet / Section card ---------------------------------------- */
.portlet-modern,
.section-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden; margin-bottom: 24px;
}
.portlet-modern-head,
.section-card-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px; border-bottom: 1px solid var(--border);
  background: #FAFAFA;
}
.portlet-modern-head .ptitle,
.section-card-head .ptitle,
.section-card-head > span:first-child {
  font-size: 13px; font-weight: 700; color: var(--text);
  text-transform: uppercase; letter-spacing: .06em;
  display: flex; align-items: center; gap: 8px;
}
.portlet-modern-head .ptitle i,
.section-card-head .ptitle i { color: var(--primary); font-size: 15px; }
.portlet-modern-body,
.section-card-body { padding: 20px 24px; }
.section-card-body.scroll-320 { max-height: 320px; overflow-y: auto; }

/* --- Modern table --------------------------------------------------- */
.modern-table-wrap {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--card-bg);
  box-shadow: var(--shadow-sm);
  margin-bottom: 24px;
}
.modern-table { width: 100%; border-collapse: collapse; font-size: 13px; margin: 0; }
.modern-table thead tr { background: var(--bg-soft); border-bottom: 2px solid var(--border); }
.modern-table thead th {
  padding: 12px 16px; font-size: 11px; font-weight: 700;
  color: var(--text-muted); text-transform: uppercase;
  letter-spacing: .06em; white-space: nowrap; border: none;
  text-align: left;
}
.modern-table thead th a {
  color: var(--text-muted) !important; text-decoration: none;
  display: inline-flex; align-items: center; gap: 5px; transition: var(--transition);
}
.modern-table thead th a:hover { color: var(--primary) !important; }
.modern-table tbody tr { border-bottom: 1px solid var(--border); transition: var(--transition); }
.modern-table tbody tr:last-child { border-bottom: none; }
.modern-table tbody tr:hover { background: var(--bg-soft); }
.modern-table td { padding: 12px 16px; color: var(--text); border: none; vertical-align: middle; }
.modern-table td.td-id { font-size: 12px; color: var(--text-muted); font-weight: 500; }
.modern-table .td-name { font-weight: 600; }
.modern-table .td-number { font-weight: 600; color: var(--text); text-align: center; }
.modern-table .td-money { font-weight: 700; color: var(--success); }
.modern-table .td-commission { font-weight: 700; color: var(--primary); }
.modern-table .td-actions {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}

/* Filter row inside table (if kept) */
.modern-table thead tr.filter td,
.modern-table thead tr.filter th {
  background: var(--bg-soft); padding: 8px 12px; border-bottom: 1px solid var(--border);
}
.modern-table thead tr.filter .form-control {
  height: 32px !important; padding: 5px 8px !important; font-size: 12px !important;
}

/* --- Badges (status) ----------------------------------------------- */
.badge-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 20px;
  font-size: 11px; font-weight: 600; letter-spacing: .02em;
  text-transform: uppercase;
}
.badge-status::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%; background: currentColor;
}
.badge-status.badge-open,    .badge-status.badge-success { background: var(--success-lt); color: #059669; }
.badge-status.badge-closed,  .badge-status.badge-danger  { background: var(--danger-lt);  color: #DC2626; }
.badge-status.badge-warning, .badge-status.badge-amber   { background: var(--warning-lt); color: #B45309; }
.badge-status.badge-info,    .badge-status.badge-blue    { background: var(--info-lt);    color: #1D4ED8; }
.badge-status.badge-muted                                { background: #F1F5F9;           color: var(--text-muted); }
.badge-status.badge-primary                              { background: var(--primary-lt); color: var(--primary-dk); }

/* --- Pagination ----------------------------------------------------- */
.pagination-modern {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; padding: 16px 24px;
  background: #FAFAFA; border-top: 1px solid var(--border);
}
.pagination-info { font-size: 13px; color: var(--text-muted); }
.pagination-controls { display: flex; align-items: center; gap: 4px; }
.pg-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 32px; height: 32px; padding: 0 10px; border-radius: var(--radius-xs);
  border: 1px solid var(--border); background: var(--card-bg);
  color: var(--text-muted); font-size: 13px; text-decoration: none;
  transition: var(--transition);
}
.pg-btn:hover { background: var(--primary); border-color: var(--primary); color: #fff; }
.pg-btn.active { background: var(--primary); border-color: var(--primary); color: #fff; font-weight: 700; }
.pg-btn.disabled { opacity: .4; pointer-events: none; }
.pg-limit-select { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-muted); }
.pg-limit-select select {
  border: 1px solid var(--border); border-radius: var(--radius-xs);
  background: var(--card-bg); color: var(--text); font-size: 13px;
  padding: 4px 8px; height: 32px; cursor: pointer; outline: none; transition: var(--transition);
}
.pg-limit-select select:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(220,14,42,.15); }

/* --- Form sections (detail/edit screens) ---------------------------- */
.form-section {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  margin-bottom: 20px;
  overflow: hidden;
}
.form-section-head {
  padding: 16px 24px; border-bottom: 1px solid var(--border);
  background: #FAFAFA;
  font-size: 13px; font-weight: 700; color: var(--text);
  text-transform: uppercase; letter-spacing: .06em;
  display: flex; align-items: center; gap: 8px;
}
.form-section-head i { color: var(--primary); }
.form-section-body { padding: 24px; }
.form-section-body .form-group label {
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; display: block;
}
.form-section-body .form-control {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xs) !important;
  background: #fff !important; color: var(--text) !important;
  font-size: 13px !important; padding: 8px 12px !important;
  height: 38px !important; box-shadow: none !important;
  transition: var(--transition) !important;
}
.form-section-body textarea.form-control { height: auto !important; min-height: 80px; }
.form-section-body .form-control:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(220,14,42,.15) !important;
}
.form-actions {
  display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap;
  padding: 16px 24px; background: var(--bg-soft); border-top: 1px solid var(--border);
}

/* Grid de formulário — 12 colunas. Use fg-N para largura. */
.form-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.form-grid .form-group { margin: 0; }
.fg-12 { grid-column: span 12; }
.fg-10 { grid-column: span 10; }
.fg-8  { grid-column: span 8; }
.fg-6  { grid-column: span 6; }
.fg-4  { grid-column: span 4; }
.fg-3  { grid-column: span 3; }
.fg-2  { grid-column: span 2; }
@media (max-width: 768px) {
  .fg-10, .fg-8, .fg-6, .fg-4, .fg-3, .fg-2 { grid-column: span 12; }
}

/* Help inline + label de aviso em formulário */
.help-inline {
  font-size: 12px; color: var(--text-muted);
  margin-top: 4px; display: block;
}
.help-inline a { color: var(--primary); }
.help-inline .label-warn {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  background: var(--warning-lt); color: #B45309;
  font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  margin-right: 6px;
}
.help-inline .label-info {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  background: var(--info-lt); color: #1D4ED8;
  font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  margin-right: 6px;
}

/* Radio/checkbox "pill" — para escolhas curtas (PF/PJ, etc) */
.radio-inline-modern {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border: 1px solid var(--border);
  border-radius: var(--radius-xs); cursor: pointer;
  font-size: 13px; transition: var(--transition);
  margin-right: 8px;
}
.radio-inline-modern:hover { border-color: var(--primary); }
.radio-inline-modern input { margin: 0; }

/* --- Empty state ---------------------------------------------------- */
.empty-state {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 48px 24px; color: var(--text-muted); text-align: center;
}
.empty-state i { font-size: 40px; opacity: .4; }
.empty-state p { font-size: 13px; margin: 0; }
.empty-state .btn-modern-primary { margin-top: 12px; }

/* --- Portlet Metronic (telas não refatoradas como reputacoes) ------ */
.portlet {
  background: var(--card-bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  padding: 0;
  margin-bottom: 20px;
  overflow: hidden;
}
.portlet.light,
.portlet.light.bordered {
  background: var(--card-bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 0 !important;
  margin-bottom: 20px;
}
.portlet.light > .portlet-title,
.portlet.light.bordered > .portlet-title {
  padding: 14px 20px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-soft);
  margin: 0;
  min-height: 0;
  display: flex; align-items: center; justify-content: space-between;
}
.portlet.light > .portlet-title > .caption,
.portlet.light.bordered > .portlet-title > .caption {
  font-size: 13px; font-weight: 700;
  color: var(--text);
  text-transform: uppercase; letter-spacing: .06em;
  padding: 0;
  display: flex; align-items: center; gap: 8px;
}
.portlet.light > .portlet-title > .caption > i,
.portlet.light.bordered > .portlet-title > .caption > i {
  color: var(--primary) !important;
  font-size: 15px !important;
  margin: 0 !important;
}
.portlet.light > .portlet-title > .caption .caption-subject,
.portlet.light.bordered > .portlet-title > .caption .caption-subject {
  color: var(--text) !important;
  font-weight: 700 !important;
}
.portlet.light > .portlet-title > .caption .caption-helper,
.portlet.light.bordered > .portlet-title > .caption .caption-helper {
  color: var(--text-muted) !important;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  font-size: 12px;
  margin-left: 8px;
}
.portlet.light > .portlet-title > .tools,
.portlet.light.bordered > .portlet-title > .tools { padding: 0; margin: 0; }
.portlet.light > .portlet-body,
.portlet.light.bordered > .portlet-body { padding: 18px 20px; }

/* Portlet box variants (outras telas) */
.portlet.box { border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; margin-bottom: 20px; }
.portlet.box.blue-madison,
.portlet.box.blue,
.portlet.box.green,
.portlet.box.red,
.portlet.box.purple,
.portlet.box.grey-gallery { border: 1px solid var(--border) !important; }
.portlet.box.blue-madison > .portlet-title,
.portlet.box.blue > .portlet-title,
.portlet.box.green > .portlet-title,
.portlet.box.red > .portlet-title,
.portlet.box.purple > .portlet-title,
.portlet.box.grey-gallery > .portlet-title {
  background: var(--bg-soft) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 14px 20px !important;
  display: flex; align-items: center; justify-content: space-between;
}
.portlet.box.blue-madison > .portlet-title > .caption,
.portlet.box.blue > .portlet-title > .caption,
.portlet.box.green > .portlet-title > .caption,
.portlet.box.red > .portlet-title > .caption,
.portlet.box.purple > .portlet-title > .caption,
.portlet.box.grey-gallery > .portlet-title > .caption {
  font-size: 13px !important; font-weight: 700 !important;
  color: var(--text) !important;
  text-transform: uppercase !important; letter-spacing: .06em !important;
  padding: 0 !important;
  display: flex; align-items: center; gap: 8px;
}
.portlet.box > .portlet-title > .caption > i {
  color: var(--primary) !important;
}
.portlet.box > .portlet-body { background: var(--card-bg); padding: 18px 20px; }

/* note Metronic (ex.: reputacoes "Como funciona a nota") */
.note { border-radius: var(--radius-sm); padding: 14px 18px; margin-bottom: 16px; border: 1px solid var(--border); }
.note.note-info { background: var(--info-lt); border-color: #BFDBFE; color: #1D4ED8; }
.note.note-success { background: var(--success-lt); border-color: #A7F3D0; color: #065F46; }
.note.note-warning { background: var(--warning-lt); border-color: #FDE68A; color: #92400E; }
.note.note-danger  { background: var(--danger-lt);  border-color: #FECACA; color: #991B1B; }
.note h4 { margin: 0 0 6px; font-size: 14px; color: inherit; font-weight: 700; }
.note p { margin: 0; color: inherit; font-size: 13px; }

/* Labels Metronic (label-success, label-danger etc) */
.label { display: inline-flex; align-items: center; padding: 3px 8px; font-size: 11px; font-weight: 600; border-radius: 4px; letter-spacing: .02em; }
.label-success { background: var(--success-lt); color: #065F46; }
.label-danger  { background: var(--danger-lt);  color: #991B1B; }
.label-warning { background: var(--warning-lt); color: #92400E; }
.label-info    { background: var(--info-lt);    color: #1D4ED8; }
.label-default { background: var(--bg);         color: var(--text-muted); }

/* --- Legacy overrides (Metronic fallbacks) -------------------------- */
.page-content-wrapper .page-title {
  font-size: 20px; font-weight: 700; color: var(--text);
  margin: 0 0 12px; padding: 0; border: none;
}
.page-content-wrapper .page-title small { color: var(--text-muted); font-weight: 400; font-size: 13px; }

/* Soft scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-dk); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: #94A3B8; }

/* --- Utilities ------------------------------------------------------ */
.muted-text { color: var(--text-muted); }
.soft-text  { color: var(--text-soft); }
.mono       { font-variant-numeric: tabular-nums; }
.mb-24      { margin-bottom: 24px !important; }
.mb-16      { margin-bottom: 16px !important; }

/* --- Legacy ".lst-*" compat (pedidos/*, monitoramento) -------------
   Converge as classes legadas azuis (#1565c0) para o token indigo.
   Declarado em cascata — vence por estar incluído depois dos <style>
   inline das telas antigas (que tipicamente vêm no <body>; as inline
   ganhariam se não usássemos seletores especificamente reforçados).
   Onde o inline ainda vencer, a tela deverá ter seu <style> removido
   ao ser refatorada. */
.lst-header {
  background: var(--card-bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 18px 24px !important;
}
.lst-header-title { color: var(--text) !important; }
.lst-header-title small { color: var(--text-muted) !important; }
.lst-header .lst-live { color: var(--success) !important; }
.lst-live-dot { background: var(--success) !important; }

.lst-loader-bar {
  background: linear-gradient(90deg, var(--primary), var(--primary-dk)) !important;
}

.lst-table {
  background: var(--card-bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm) !important;
}
.lst-table thead th {
  background: var(--bg-soft) !important;
  border-bottom: 2px solid var(--border) !important;
  color: var(--text-muted) !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
}
.lst-table tbody td { border-bottom: 1px solid var(--border) !important; }
.lst-table tbody tr:hover { background: var(--bg-soft) !important; }

.lst-id { color: var(--primary) !important; }
.lst-cliente a, .lst-restaurante a { color: var(--text) !important; }
.lst-cliente a:hover, .lst-restaurante a:hover { color: var(--primary) !important; }
.lst-valor { color: var(--success) !important; }
.lst-data  { color: var(--text-muted) !important; }

/* Status chips — re-skin em cima dos tokens semânticos */
.lst-st-1 { background: var(--danger-lt) !important; color: #C62828 !important; }
.lst-st-2 { background: var(--warning-lt) !important; color: #B45309 !important; }
.lst-st-3 { background: var(--primary-lt) !important; color: var(--primary-dk) !important; }
.lst-st-4,
.lst-st-5 { background: var(--success-lt) !important; color: #059669 !important; }
.lst-st-8 { background: #F1F5F9 !important; color: var(--text-muted) !important; }

.lst-badge-fin.fin-zero { background: var(--danger-lt) !important; color: #C62828 !important; }
.lst-badge-fin.fin-ok   { background: var(--success-lt) !important; color: #059669 !important; }

.lst-online-dot.on     { background: var(--success) !important; }
.lst-online-dot.off    { background: var(--danger) !important; }
.lst-online-dot.closed { background: var(--text-soft) !important; border-color: var(--border) !important; }

.lst-pag-1 { background: var(--primary-lt) !important; color: var(--primary-dk) !important; }
.lst-pag-2 { background: var(--success-lt) !important; color: #059669 !important; }
.lst-pag-3 { background: var(--warning-lt) !important; color: #B45309 !important; }
.lst-pag-4 { background: var(--teal-lt) !important; color: #0F766E !important; }

.lst-btn-ver {
  background: var(--primary-lt) !important;
  color: var(--primary-dk) !important;
  border-radius: var(--radius-xs) !important;
  padding: 6px 14px !important;
  transition: var(--transition);
}
.lst-btn-ver:hover {
  background: var(--primary) !important;
  color: #fff !important;
  box-shadow: var(--shadow);
}

.lst-empty { color: var(--text-muted) !important; padding: 48px 24px !important; }
.lst-empty i { color: var(--text-soft) !important; }

/* Força wrapper de filtros legado (override de <style> inline nas telas) */
.lst-filtros {
  background: var(--card-bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm) !important;
  padding: 20px 24px !important;
}
.lst-filtros-title { color: var(--text-muted) !important; }
.lst-filtros-title i { color: var(--primary) !important; }
.lst-filtros .form-control:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(220,14,42,.15) !important;
}
.lst-filtros .btn[type=submit],
.lst-filtros button[type=submit].filter-submit {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
  border-radius: var(--radius-xs) !important;
}
.lst-filtros .btn[type=submit]:hover {
  background: var(--primary-dk) !important;
  border-color: var(--primary-dk) !important;
}
.lst-filtros .filter-cancel { border-radius: var(--radius-xs) !important; }
/* status "em análise" (lst-st-0) do pedidos_all usa laranja — manter como warning */
.lst-st-0 { background: var(--warning-lt) !important; color: #B45309 !important; }
.lst-pago-nao { background: var(--warning-lt) !important; color: #B45309 !important; }

/* =====================================================================
   CHROME OVERRIDE — Sidebar / Navbar / Footer (Metronic shell)
   Sobrescreve templates/admin/layout/css/themes/default.css e layout.css
   sem alterar o HTML do chrome (Metronic JS continua funcionando).
   ===================================================================== */

/* --- Body base ------------------------------------------------------ */
body {
  background-color: var(--bg) !important;
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
    Oxygen, Ubuntu, Cantarell, 'Helvetica Neue', Arial, sans-serif;
}

/* --- Navbar (topo) — vermelho Tridelivery --------------------------- */
/* Mantém altura 46px do Metronic para não quebrar offsets hardcoded no layout.css */
.page-header.navbar {
  background: var(--primary) !important;
  background-color: var(--primary) !important;
  border-bottom: 1px solid var(--primary-dk) !important;
  box-shadow: var(--shadow-sm);
}
.page-header.navbar .page-header-inner { background: transparent !important; }

.page-header.navbar .page-logo {
  background: transparent !important;
  display: flex; align-items: center;
}
.page-header.navbar .page-logo img.logo-default {
  max-height: 32px; width: auto;
  /* logo.png já é branca — aparece direto no fundo vermelho */
}

.page-header.navbar .top-menu {
  background: transparent !important;
  margin-right: 12px;
}
.page-header.navbar .top-menu .navbar-nav { padding-right: 0; }
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-toggle,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user > .dropdown-toggle {
  background: rgba(255,255,255,.15) !important;
  color: #fff !important;
  border-radius: var(--radius-xs) !important;
  padding: 6px 10px !important;
  margin: 7px 6px !important;
  height: auto !important;
  min-height: auto !important;
  border: 1px solid rgba(255,255,255,.2) !important;
  transition: var(--transition);
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-toggle:hover,
.page-header.navbar .top-menu .navbar-nav > li.dropdown.open > .dropdown-toggle,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user > .dropdown-toggle:hover,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user.open > .dropdown-toggle {
  background: rgba(255,255,255,.25) !important;
  border-color: rgba(255,255,255,.35) !important;
  color: #fff !important;
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user .dropdown-toggle .username,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user .dropdown-toggle > i,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user .dropdown-toggle:hover .username,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user.open .dropdown-toggle .username,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user .dropdown-toggle:hover > i,
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user.open .dropdown-toggle > i {
  color: #fff !important;
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user .dropdown-toggle .username {
  font-weight: 600; font-size: 13px;
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown-user .dropdown-toggle img.img-circle {
  border: 1px solid rgba(255,255,255,.35);
}

/* Dropdown menu (user) */
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-menu,
.dropdown-user > .dropdown-menu {
  background: var(--card-bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: var(--shadow-lg) !important;
  padding: 6px !important;
  margin-top: 4px !important;
  min-width: 200px;
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-menu > li > a,
.dropdown-user > .dropdown-menu > li > a {
  color: var(--text) !important;
  padding: 8px 12px !important;
  border-radius: var(--radius-xs) !important;
  font-size: 13px;
  transition: var(--transition);
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-menu > li > a:hover,
.dropdown-user > .dropdown-menu > li > a:hover {
  background: var(--primary-lt) !important;
  color: var(--primary-dk) !important;
}
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-menu > li > a > i,
.dropdown-user > .dropdown-menu > li > a > i { color: var(--text-muted) !important; width: 16px; }
.page-header.navbar .top-menu .navbar-nav > li.dropdown > .dropdown-menu > li.divider,
.dropdown-user > .dropdown-menu > li.divider { background: var(--border) !important; margin: 6px 0 !important; }

/* --- Sidebar --------------------------------------------------------
   Metronic usa seletores como `.page-sidebar .page-sidebar-menu > li > a`
   (especificidade 0,2,1). Para vencer com !important precisamos igualar
   ou superar essa especificidade. Mantemos o prefixo `.page-sidebar` em
   todas as regras e, onde o Metronic tem variantes (ex.: `page-sidebar-
   closed.page-sidebar-fixed .page-sidebar:hover`), adicionamos a variante.
   ------------------------------------------------------------------ */
.page-sidebar-wrapper { background: var(--card-bg); }
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover,
.page-sidebar {
  background: var(--card-bg) !important;
  background-color: var(--card-bg) !important;
  border-right: 1px solid var(--border);
}

/* Sidebar search */
.page-sidebar .sidebar-search-wrapper,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .sidebar-search-wrapper {
  padding: 16px 16px 0 !important;
  background: transparent !important;
}
.page-sidebar .sidebar-search,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .sidebar-search {
  background: var(--bg-soft) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xs) !important;
  padding: 0 !important;
  margin: 0 !important;
  height: 36px !important;
  box-shadow: none !important;
  display: flex; align-items: center;
}
.page-sidebar .sidebar-search .input-group { display: flex; width: 100%; background: transparent !important; }
.page-sidebar .sidebar-search .form-control {
  background: transparent !important;
  border: none !important;
  color: var(--text) !important;
  font-size: 13px !important;
  padding: 8px 12px !important;
  box-shadow: none !important;
  height: 34px !important;
}
.page-sidebar .sidebar-search .form-control::placeholder { color: var(--text-soft); }
.page-sidebar .sidebar-search .input-group-btn .btn.submit {
  background: transparent url(../../img/header_search_icon_default.png) center center no-repeat !important;
  border: none !important;
  width: 34px; height: 34px;
  filter: invert(58%) sepia(11%) saturate(500%) hue-rotate(180deg) brightness(90%);
  cursor: pointer;
}

/* Sidebar menu — nível 1 */
.page-sidebar .page-sidebar-menu,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu {
  padding-top: 8px !important;
  background: transparent !important;
}
.page-sidebar .page-sidebar-menu > li,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li {
  border: none !important;
  background: transparent !important;
}
.page-sidebar .page-sidebar-menu > li > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li > a {
  background: transparent !important;
  color: var(--text) !important;
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
  padding: 10px 20px !important;
  margin: 2px 10px !important;
  border-radius: var(--radius-xs) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  transition: var(--transition) !important;
  text-shadow: none !important;
}
.page-sidebar .page-sidebar-menu > li > a > i,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li > a > i {
  color: var(--text-muted) !important;
  text-shadow: none !important;
  font-size: 15px !important;
  margin-right: 10px !important;
  width: 20px;
}
.page-sidebar .page-sidebar-menu > li > a > .arrow:before,
.page-sidebar .page-sidebar-menu > li > a > .arrow.open:before,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li > a > .arrow:before,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li > a > .arrow.open:before {
  color: var(--text-soft) !important;
  font-size: 14px !important;
  text-shadow: none !important;
}

/* Hover + open (não-ativo) */
.page-sidebar .page-sidebar-menu > li:hover > a,
.page-sidebar .page-sidebar-menu > li.open > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li:hover > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li.open > a {
  background: var(--bg-soft) !important;
  color: var(--text) !important;
}
.page-sidebar .page-sidebar-menu > li:hover > a > i,
.page-sidebar .page-sidebar-menu > li.open > a > i,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li:hover > a > i,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li.open > a > i {
  color: var(--primary) !important;
}

/* Active (inclusive active.open) */
.page-sidebar .page-sidebar-menu > li.active > a,
.page-sidebar .page-sidebar-menu > li.active.open > a,
.page-sidebar .page-sidebar-menu > li.active > a:hover,
.page-sidebar .page-sidebar-menu > li.active.open > a:hover,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li.active > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li.active.open > a {
  background: var(--primary-lt) !important;
  color: var(--primary-dk) !important;
  font-weight: 600 !important;
  border: none !important;
  border-top-color: transparent !important;
}
.page-sidebar .page-sidebar-menu > li.active > a > i,
.page-sidebar .page-sidebar-menu > li.active.open > a > i,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li.active > a > i,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu > li.active.open > a > i {
  color: var(--primary) !important;
}
.page-sidebar .page-sidebar-menu > li.active > a > .arrow:before,
.page-sidebar .page-sidebar-menu > li.active > a > .arrow.open:before,
.page-sidebar .page-sidebar-menu > li.active.open > a > .arrow:before,
.page-sidebar .page-sidebar-menu > li.active.open > a > .arrow.open:before {
  color: var(--primary) !important;
}
/* Esconder o marcador vermelho legado do item ativo */
.page-sidebar .page-sidebar-menu > li.active > a > .selected,
.page-sidebar .page-sidebar-menu > li.active.open > a > .selected { display: none !important; }

/* Borda superior/inferior dos itens (desliga dividers do Metronic) */
.page-sidebar .page-sidebar-menu > li.active + li > a,
.page-sidebar .page-sidebar-menu > li.active.open + li > a,
.page-sidebar .page-sidebar-menu > li:last-child > a {
  border-top-color: transparent !important;
  border-bottom-color: transparent !important;
}

/* Sub-menus (nível 2) */
.page-sidebar .page-sidebar-menu .sub-menu,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu .sub-menu {
  background: transparent !important;
  padding: 2px 0 4px !important;
  margin: 0 10px 4px !important;
}
.page-sidebar .page-sidebar-menu .sub-menu > li,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu .sub-menu > li {
  background: transparent !important;
  border: none !important;
}
.page-sidebar .page-sidebar-menu .sub-menu > li > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu .sub-menu > li > a {
  background: transparent !important;
  color: var(--text-muted) !important;
  padding: 7px 12px 7px 42px !important;
  font-size: 12px !important;
  border: none !important;
  border-radius: var(--radius-xs) !important;
  margin: 1px 0 !important;
  transition: var(--transition) !important;
}
.page-sidebar .page-sidebar-menu .sub-menu > li > a > i {
  color: var(--text-soft) !important;
  font-size: 12px !important;
  margin-right: 8px !important;
}
.page-sidebar .page-sidebar-menu .sub-menu > li:hover > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu .sub-menu > li:hover > a {
  background: var(--bg-soft) !important;
  color: var(--text) !important;
}
.page-sidebar .page-sidebar-menu .sub-menu > li:hover > a > i { color: var(--primary) !important; }
.page-sidebar .page-sidebar-menu .sub-menu > li.active > a,
.page-sidebar .page-sidebar-menu .sub-menu > li.active.open > a,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .page-sidebar-menu .sub-menu > li.active > a {
  background: var(--primary-lt) !important;
  color: var(--primary-dk) !important;
  font-weight: 600 !important;
}
.page-sidebar .page-sidebar-menu .sub-menu > li.active > a > i,
.page-sidebar .page-sidebar-menu .sub-menu > li.active.open > a > i { color: var(--primary) !important; }

/* Sub-menu de 3º nível */
.page-sidebar .page-sidebar-menu .sub-menu .sub-menu > li > a {
  padding-left: 60px !important;
  font-size: 11.5px !important;
}

/* Sidebar toggler wrapper */
.page-sidebar-menu .sidebar-toggler-wrapper {
  background: transparent !important;
  padding: 14px 16px !important;
  border-bottom: 1px solid var(--border) !important;
  margin-bottom: 4px;
}
.page-sidebar-menu .sidebar-brand {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
}
.page-sidebar-menu .sidebar-brand-link {
  display: inline-flex;
  align-items: center;
  text-decoration: none !important;
  flex: 1;
  min-width: 0;
}
.page-sidebar-menu .sidebar-brand-logo {
  max-height: 40px;
  max-width: 100%;
  height: auto;
  display: block;
}
.page-sidebar-menu .sidebar-toggler-wrapper .sidebar-toggler {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 34px !important;
  height: 34px !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  background: var(--bg-soft) !important;
  background-image: none !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius-xs) !important;
  color: var(--text-muted) !important;
  opacity: 1 !important;
  cursor: pointer;
  transition: var(--transition);
}
.page-sidebar-menu .sidebar-toggler-wrapper .sidebar-toggler:hover {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
}
.page-sidebar-menu .sidebar-toggler-wrapper .sidebar-toggler i {
  font-size: 14px;
  line-height: 1;
}
/* Quando sidebar está fechada: esconder marca e centralizar botão */
.page-sidebar-closed .page-sidebar-menu .sidebar-toggler-wrapper,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:not(:hover) .sidebar-toggler-wrapper {
  padding: 10px 0 !important;
  display: flex;
  justify-content: center;
}
.page-sidebar-closed .page-sidebar-menu .sidebar-brand-link,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:not(:hover) .sidebar-brand-link {
  display: none !important;
}
.page-sidebar-closed .page-sidebar-menu .sidebar-brand,
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:not(:hover) .sidebar-brand {
  justify-content: center;
  gap: 0;
}
/* No hover da sidebar fechada: volta ao estado expandido */
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .sidebar-toggler-wrapper {
  padding: 14px 16px !important;
}
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .sidebar-brand-link {
  display: inline-flex !important;
}
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover .sidebar-brand {
  justify-content: space-between;
  gap: 12px;
}

/* Scrollbar do sidebar */
.page-sidebar .slimScrollBar { background: var(--border-dk) !important; border-radius: 2px !important; opacity: .6 !important; }

/* Quando sidebar colapsa: popup submenu */
.page-sidebar-closed.page-sidebar-fixed .page-sidebar:hover {
  background: var(--card-bg) !important;
  box-shadow: var(--shadow-lg);
}

/* ---- Sidebar fechada: popup ao passar o mouse ---- */
/* Item hover vira "card" flutuante com label + submenu */
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover {
  background: var(--card-bg) !important;
  box-shadow: var(--shadow-lg) !important;
  border-radius: 0 var(--radius-xs) var(--radius-xs) 0 !important;
}
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover > a {
  background: transparent !important;
  color: var(--text) !important;
}
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover > a > .title {
  color: var(--text) !important;
  font-weight: 500 !important;
}
/* Submenu em popup */
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover > .sub-menu {
  top: 100% !important;
  left: 0 !important;
  margin: 0 !important;
  padding: 6px 0 !important;
  min-width: 220px;
  background: var(--card-bg) !important;
  border: 1px solid var(--border) !important;
  border-top: none !important;
  border-radius: 0 0 var(--radius-xs) var(--radius-xs) !important;
  box-shadow: var(--shadow-lg) !important;
}
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover > .sub-menu > li > a {
  padding: 8px 16px !important;
  color: var(--text-muted) !important;
  background: transparent !important;
  font-size: 13px !important;
}
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover > .sub-menu > li:hover > a,
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li:hover > .sub-menu > li.active > a {
  background: var(--bg-soft) !important;
  color: var(--primary) !important;
}
/* Esconder search e brand-link enquanto fechada */
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li.sidebar-search-wrapper {
  display: none !important;
}
/* Sem padding lateral nos itens quando colapsada */
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li > a {
  padding: 10px 0 !important;
  margin: 2px 0 !important;
  text-align: center;
  border-radius: 0 !important;
}
.page-sidebar-closed .page-sidebar .page-sidebar-menu.page-sidebar-menu-closed > li > a > i {
  margin: 0 !important;
  width: auto !important;
  display: inline-block;
}

/* --- Page container / conteúdo ------------------------------------- */
.page-container { background: transparent; }
.page-content-wrapper .page-content { border-left: none !important; }

/* --- Footer --------------------------------------------------------- */
.page-footer {
  background: var(--card-bg) !important;
  border-top: 1px solid var(--border) !important;
  padding: 0 !important;
  height: 40px;
  display: flex; align-items: center;
}
.page-footer .page-footer-inner {
  color: var(--text-muted) !important;
  font-size: 12px !important;
  padding: 0 24px;
}
.page-footer .page-footer-tools { padding-right: 16px; }
.page-footer .go-top {
  background: var(--primary) !important;
  color: #fff !important;
  border-radius: var(--radius-xs) !important;
  width: 28px; height: 28px;
  display: inline-flex !important; align-items: center; justify-content: center;
  font-size: 13px;
  transition: var(--transition);
}
.page-footer .go-top:hover { background: var(--primary-dk) !important; }

/* --- Alerta de slider global (loading horizontal) ------------------- */
.slider {
  background: var(--border); height: 3px; border-radius: 2px; overflow: hidden;
}
.slider .line, .slider .subline {
  background: var(--primary);
}

/* (Altura da navbar mantida em 46px — não sobrescrever offsets do Metronic) */

/* --- Breadcrumb legado dentro de telas não migradas ---------------- */
.page-breadcrumb.breadcrumb {
  background: transparent;
  padding: 0;
  margin: 0 0 16px;
  border-radius: 0;
  font-size: 12px;
  color: var(--text-muted);
}
.page-breadcrumb.breadcrumb > li > a { color: var(--text-muted); text-decoration: none; }
.page-breadcrumb.breadcrumb > li > a:hover { color: var(--primary); }
.page-breadcrumb.breadcrumb > li:last-child > a { color: var(--text); font-weight: 600; }

/* --- Responsive ----------------------------------------------------- */
@media (max-width: 992px) {
  .bottom-grid { grid-template-columns: 1fr !important; }
}
@media (max-width: 768px) {
  .page-content-wrapper .page-content { padding: 16px !important; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .filtros-grid { flex-direction: column; }
  .filtro-group { min-width: 100%; }
  .charts-grid { grid-template-columns: 1fr !important; }
  .page-header-modern { flex-direction: column; align-items: flex-start; }
  .page-header-modern .ph-actions { width: 100%; }
  .modern-table-wrap { overflow-x: auto; }
  .modern-table { min-width: 640px; }
}
