/*
 * Tema Catalog da area restrita.
 *
 * Este arquivo fica dentro de application para facilitar atualizacoes por pack.
 * Ele e servido como CSS externo pela rota /themes/catalog.css, preservando cache
 * do navegador sem depender do arquivo estatico em assets/themes.
 */
/*!
 * Bootstrap 3.3.7 Theme - "Catálogo"
 * Gerado para combinar com o visual do Catálogo (app.css) e estender para componentes usados no projeto (.tpl)
 * Carregue este arquivo DEPOIS do bootstrap.min.css e DEPOIS dos CSS do admin.
 *
 * Paleta base:
 *  - Accent: #2f7dff
 *  - Accent2: #00b894
 *  - Danger: #e63946
 */

:root {
  --bg: #f5f7fb;
  --panel: #ffffff;
  --card: #ffffff;
  --muted: #5a6a82;
  --text: #1d2430;
  --border: rgba(0, 0, 0, 0.08);
  --accent: #2f7dff;
  --accent2: #00b894;
  --danger: #e63946;
  --shadow: 0 2px 10px rgba(15, 23, 42, 0.08);
  --radius: 14px;
  --font:
    ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial,
    "Noto Sans", "Liberation Sans", sans-serif;

  --title-color: #1f2a3a; /* preto mais suave para títulos */
  --title-weight: 700; /* menos bold */
}

/* Títulos: menos bold + preto menos intenso */
h1,
h2,
h3,
h4,
h5,
h6,
.page-header h1,
.page-header h2,
.panel-title,
.section-title {
  color: var(--title-color) !important;
  font-weight: var(--title-weight) !important;
}

/* =========================================================
   Base (tipografia + fundo) - inspirado no Catálogo
   ========================================================= */

html,
body {
  height: 100%;
}

/* Títulos: usar a mesma "pegada" do título dos painéis */
h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  font-family: var(--font);
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.01em;
}

.page-header h1 {
  margin-top: 0;
  margin-bottom: 10px;
}
body {
  font-family:
    ui-sans-serif,
    system-ui,
    -apple-system,
    Segoe UI,
    Roboto,
    Arial,
    "Noto Sans",
    "Liberation Sans",
    sans-serif;
  font-family: var(--font);
  color: #1d2430;
  color: var(--text);
  background: #f5f7fb;
  background: var(--bg);
  background-image: none;
}

a {
  color: #2f7dff;
  color: var(--accent);
}
a:hover,
a:focus {
  color: #1f63d8;
  text-decoration: none;
}

.text-muted {
  color: #5a6a82;
  color: var(--muted);
}
.main-content {
  padding: 14px 10px;
}
hr {
  border-top: 1px solid rgba(0, 0, 0, 0.08);
  border-top: 1px solid var(--border);
}

/* =========================================================
   Helpers "card"
   ========================================================= */

.card,
.gd-card,
.card-modal {
  background: #ffffff;
  background: var(--panel);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border: 1px solid var(--border);
  border-radius: 14px;
  border-radius: var(--radius);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.08);
  box-shadow: var(--shadow);
}

.card {
  padding: 15px;
  margin-bottom: 15px;
}

.gd-pill,
.pill {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border: 1px solid var(--border);
  background: rgba(47, 125, 255, 0.08);
}

.gd-axis-label {
  color: #5a6a82;
  color: var(--muted);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.02em;
}

/* =========================================================
   Buttons
   ========================================================= */

.btn {
  border-radius: 12px;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.btn:active,
.btn.active {
  box-shadow: inset 0 2px 8px rgba(0, 0, 0, 0.12);
}

.btn-default {
  background: #fff;
  border-color: rgba(0, 0, 0, 0.12);
  border-color: var(--border);
  color: #1d2430;
  color: var(--text);
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  background-repeat: repeat-x;
}
.btn-default:hover,
.btn-default:focus {
  background-color: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.18);
}

.btn-primary {
  background: #2f7dff;
  background: var(--accent);
  border-color: #2f7dff;
  border-color: var(--accent);
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  background-repeat: repeat-x;
}
.btn-primary:hover,
.btn-primary:focus {
  background-color: #1f63d8;
  border-color: #1f63d8;
}

.btn-success {
  background: #00b894;
  background: var(--accent2);
  border-color: #00b894;
  border-color: var(--accent2);
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  background-repeat: repeat-x;
}
.btn-success:hover,
.btn-success:focus {
  background-color: #009e7f;
  border-color: #009e7f;
}

.btn-danger {
  background: #e63946;
  background: var(--danger);
  border-color: #e63946;
  border-color: var(--danger);
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  background-repeat: repeat-x;
}
.btn-danger:hover,
.btn-danger:focus {
  background-color: #cf2d3a;
  border-color: #cf2d3a;
}

.btn-info {
  background: #22a6f2;
  border-color: #22a6f2;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  background-repeat: repeat-x;
}
.btn-warning {
  background: #f4b400;
  border-color: #f4b400;
  color: #1d2430;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  background-repeat: repeat-x;
}

.btn-link {
  font-weight: 700;
  color: #2f7dff;
  color: var(--accent);
}

.btn-md {
  padding: 8px 14px;
  font-size: 14px;
  line-height: 1.42857143;
}

.btn-circle {
  border-radius: 999px;
  padding: 8px 12px;
}
.btn-square {
  border-radius: 6px;
}

.btn-secondary {
  background: rgba(47, 125, 255, 0.1);
  border-color: rgba(47, 125, 255, 0.25);
  color: #2f7dff;
  color: var(--accent);
}
.btn-secondary:hover {
  background: rgba(47, 125, 255, 0.16);
}

.btn-outline,
.btn-default-outline,
.btn-default-outline-alt,
.btn-outline-primary,
.btn-outline-light {
  background: transparent;
  border-color: rgba(47, 125, 255, 0.35);
  color: #2f7dff;
  color: var(--accent);
}
.btn-outline:hover,
.btn-default-outline:hover,
.btn-default-outline-alt:hover,
.btn-outline-primary:hover,
.btn-outline-light:hover {
  background: rgba(47, 125, 255, 0.08);
}

.btn-ghost {
  background: transparent;
  border-color: transparent;
  color: #5a6a82;
  color: var(--muted);
}
.btn-ghost:hover {
  background: rgba(0, 0, 0, 0.04);
  color: #1d2430;
  color: var(--text);
}

.btn-preto {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}

.btn-verde,
.verde {
  background: #00b894;
  background: var(--accent2);
  color: #fff;
}
.btn-verde:hover {
  background: #009e7f;
}

.btn-group .btn + .btn {
  margin-left: 6px;
}
.btn-toolbar .btn + .btn {
  margin-left: 6px;
}

/* =========================================================
   "Botões do sistema" sem .btn (aliases)
   Alguns .tpl usam variantes do Bootstrap sem a classe base .btn
   Ex.: <a class="btn-warning form-control">... (sim, isso existe)
   Este bloco aplica a base do .btn automaticamente, sem quebrar quem já usa .btn.
   ========================================================= */

/* base do .btn para elementos com .btn-variant sem a classe .btn */
a.btn-default:not(.btn),
a.btn-primary:not(.btn),
a.btn-success:not(.btn),
a.btn-info:not(.btn),
a.btn-warning:not(.btn),
a.btn-danger:not(.btn),
button.btn-default:not(.btn),
button.btn-primary:not(.btn),
button.btn-success:not(.btn),
button.btn-info:not(.btn),
button.btn-warning:not(.btn),
button.btn-danger:not(.btn),
input.btn-default:not(.btn),
input.btn-primary:not(.btn),
input.btn-success:not(.btn),
input.btn-info:not(.btn),
input.btn-warning:not(.btn),
input.btn-danger:not(.btn) {
  display: inline-block;
  padding: 6px 12px;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.42857143;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  user-select: none;
  border: 1px solid transparent;
  border-radius: 12px;
  letter-spacing: 0.01em;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  text-decoration: none;
}
a.btn-default:not(.btn):focus,
a.btn-primary:not(.btn):focus,
a.btn-success:not(.btn):focus,
a.btn-info:not(.btn):focus,
a.btn-warning:not(.btn):focus,
a.btn-danger:not(.btn):focus,
button.btn-default:not(.btn):focus,
button.btn-primary:not(.btn):focus,
button.btn-success:not(.btn):focus,
button.btn-info:not(.btn):focus,
button.btn-warning:not(.btn):focus,
button.btn-danger:not(.btn):focus,
input.btn-default:not(.btn):focus,
input.btn-primary:not(.btn):focus,
input.btn-success:not(.btn):focus,
input.btn-info:not(.btn):focus,
input.btn-warning:not(.btn):focus,
input.btn-danger:not(.btn):focus {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(47, 125, 255, 0.2);
  border-color: #2f7dff;
  border-color: var(--accent);
}

/* quando alguém usa <a class="btn-warning form-control"> (sim) */
a.form-control.btn-default:not(.btn),
a.form-control.btn-primary:not(.btn),
a.form-control.btn-success:not(.btn),
a.form-control.btn-info:not(.btn),
a.form-control.btn-warning:not(.btn),
a.form-control.btn-danger:not(.btn) {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* botões utilitários (filtros / menu) vistos nos .tpl */
.btn-toggle-collapse,
.btn-toggle-fullwidth:not(.btn) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  width: 34px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border: 1px solid var(--border);
  background: #fff;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  color: #5a6a82;
  color: var(--muted);
}
.btn-toggle-collapse:hover,
.btn-toggle-fullwidth:not(.btn):hover {
  background-color: rgba(0, 0, 0, 0.03);
  color: #1d2430;
  color: var(--text);
}
.btn-toggle-collapse:focus,
.btn-toggle-fullwidth:not(.btn):focus {
  outline: 0;
  border-color: #2f7dff;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 125, 255, 0.2);
}

/* links "botão" comuns */
.btn-forget {
  font-weight: 700;
  color: #e63946;
  color: var(--danger);
  text-decoration: none;
}
.btn-forget:hover {
  text-decoration: underline;
  color: #cf2d3a;
}

/* botões de quantidade (classes detectadas no projeto) */
.btn-number,
.btn-inc,
.btn-dec {
  border-radius: 10px;
  font-weight: 700;
}
.btn-number:not(.btn),
.btn-inc:not(.btn),
.btn-dec:not(.btn) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  min-width: 34px;
  padding: 0 10px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border: 1px solid var(--border);
  background: #fff;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  );
  color: #1d2430;
  color: var(--text);
}
.btn-number:not(.btn):hover,
.btn-inc:not(.btn):hover,
.btn-dec:not(.btn):hover {
  background-color: rgba(0, 0, 0, 0.03);
}

/* lista de categorias (classe usada em .tpl com list-group-item-action) */
a.btn-categoria.list-group-item-action {
  display: block;
  width: 100%;
  padding: 10px 14px;
  border-radius: 12px;
  color: #1d2430;
  color: var(--text);
  text-decoration: none;
}
a.btn-categoria.list-group-item-action:hover {
  background: rgba(0, 0, 0, 0.03);
}
a.btn-categoria.list-group-item-action.active {
  background: rgba(47, 125, 255, 0.1);
  color: #2f7dff;
  color: var(--accent);
  font-weight: 700;
}

/* =========================================================
   Forms
   ========================================================= */

.form-control {
  border-radius: 12px;
  border-color: rgba(0, 0, 0, 0.12);
  border-color: var(--border);
  box-shadow: none;
}
.form-control:focus {
  border-color: #2f7dff;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 125, 255, 0.2);
}

.input-group-addon {
  border-radius: 12px;
  border-color: rgba(0, 0, 0, 0.12);
  border-color: var(--border);
  background: rgba(0, 0, 0, 0.02);
}

.has-success .form-control {
  border-color: rgba(0, 184, 148, 0.45);
}
.has-warning .form-control {
  border-color: rgba(244, 180, 0, 0.55);
}
.has-error .form-control {
  border-color: rgba(230, 57, 70, 0.55);
}

.help-block {
  color: #5a6a82;
  color: var(--muted);
}
.control-label {
  font-weight: 700;
}

span.field-icon {
  color: #5a6a82;
  color: var(--muted);
}
.toggle-password {
  cursor: pointer;
}

/* Status em selects/inputs que aparecem no projeto */
.form-control.aguardando,
.form-control.waiting {
  border-color: rgba(244, 180, 0, 0.55);
  background: rgba(244, 180, 0, 0.06);
}
.form-control.processando,
.form-control.exam_in_progress {
  border-color: rgba(34, 166, 242, 0.55);
  background: rgba(34, 166, 242, 0.06);
}
.form-control.finalizada,
.form-control.finished {
  border-color: rgba(0, 184, 148, 0.45);
  background: rgba(0, 184, 148, 0.06);
}
.form-control.cancelada,
.form-control.canceled {
  border-color: rgba(230, 57, 70, 0.55);
  background: rgba(230, 57, 70, 0.06);
}
.form-control.criada,
.form-control.created {
  border-color: rgba(47, 125, 255, 0.45);
  background: rgba(47, 125, 255, 0.06);
}

/* =========================================================
   Tables
   ========================================================= */

.table {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
}

.table > thead > tr > th {
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  border-bottom: 1px solid var(--border);
  background: rgba(0, 0, 0, 0.02);
  font-weight: 700;
}

.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: rgba(0, 0, 0, 0.015);
}
.table-hover > tbody > tr:hover {
  background-color: rgba(47, 125, 255, 0.06);
}

tr.nao-integrada {
  background: rgba(230, 57, 70, 0.06) !important;
}
tr.integrada {
  background: rgba(0, 184, 148, 0.06) !important;
}

/* =========================================================
   Panels / Wells / Thumbnails
   ========================================================= */

.panel {
  border-radius: 14px;
  border-radius: var(--radius);
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
}

.panel-heading {
  border-top-left-radius: 14px;
  border-top-left-radius: var(--radius);
  border-top-right-radius: 14px;
  border-top-right-radius: var(--radius);
  background: rgba(0, 0, 0, 0.02);
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
}

.panel-title {
  font-weight: 700;
}

/* List Group */
.list-group {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: none;
}
.list-group-item {
  border-color: var(--border);
  background: #fff;
  background: var(--panel);
}
.list-group-item:hover,
a.list-group-item:hover,
a.list-group-item:focus {
  background: rgba(47, 125, 255, 0.05);
  border-color: var(--border);
}
.list-group-item.active,
.list-group-item.active:hover,
.list-group-item.active:focus {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.list-group-item:first-child {
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);
}
.list-group-item:last-child {
  border-bottom-left-radius: var(--radius);
  border-bottom-right-radius: var(--radius);
}
.well {
  border-radius: 14px;
  border-radius: var(--radius);
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
  box-shadow: none;
}

.thumbnail {
  border-radius: 14px;
  border-radius: var(--radius);
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
}

.jumbotron {
  border-radius: 14px;
  border-radius: var(--radius);
  background: rgba(47, 125, 255, 0.08);
}

/* =========================================================
   Navs / Tabs / Pills / Pagination / Breadcrumb
   ========================================================= */

.nav-pills > li > a {
  border-radius: 999px;
  font-weight: 700;
}
.nav-pills > li.active > a,
.nav-pills > li.active > a:hover,
.nav-pills > li.active > a:focus {
  background: #2f7dff;
  background: var(--accent);
}

.nav-tabs > li > a {
  border-radius: 12px 12px 0 0;
  font-weight: 700;
}

.pagination > li > a,
.pagination > li > span {
  border-radius: 10px;
  margin: 0 3px;
  border-color: rgba(0, 0, 0, 0.1);
  border-color: var(--border);
}

.pagination > .active > a,
.pagination > .active > span,
.pagination > .active > a:hover,
.pagination > .active > span:hover,
.pagination > .active > a:focus,
.pagination > .active > span:focus {
  background: #2f7dff;
  background: var(--accent);
  border-color: #2f7dff;
  border-color: var(--accent);
}

.breadcrumb {
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.03);
}

/* =========================================================
   Alerts / Labels / Badges
   ========================================================= */

.alert {
  border-radius: 14px;
  border-radius: var(--radius);
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
}

.alert-success {
  background: rgba(0, 184, 148, 0.1);
  border-color: rgba(0, 184, 148, 0.25);
  color: #0b3b2f;
}
.alert-info {
  background: rgba(34, 166, 242, 0.1);
  border-color: rgba(34, 166, 242, 0.25);
  color: #0b2a3a;
}
.alert-warning {
  background: rgba(244, 180, 0, 0.12);
  border-color: rgba(244, 180, 0, 0.25);
  color: #3a2a0b;
}
.alert-danger {
  background: rgba(230, 57, 70, 0.1);
  border-color: rgba(230, 57, 70, 0.25);
  color: #3a0b12;
}

.label {
  border-radius: 999px;
  font-weight: 700;
  padding: 0.3em 0.7em;
}
.status.label {
  font-size: 13px;
  padding: 8px 12px;
}

.badge {
  border-radius: 999px;
  font-weight: 700;
}
.badge-success {
  background: #00b894;
  background: var(--accent2);
}
.badge-danger {
  background: #e63946;
  background: var(--danger);
}
.badge-warning {
  background: #f4b400;
  color: #1d2430;
}

/* =========================================================
   Navbar
   ========================================================= */

.navbar {
  border-radius: 0;
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.06);
}
.navbar-default {
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: none;
}
.navbar-default .navbar-nav > li > a {
  font-weight: 700;
}
.navbar-default .navbar-nav > .active > a,
.navbar-default .navbar-nav > .active > a:hover,
.navbar-default .navbar-nav > .active > a:focus {
  background: rgba(47, 125, 255, 0.1);
  color: #2f7dff;
  color: var(--accent);
}

.navbar-inverse {
  background: #0f172a;
  border-color: #0f172a;
}
.navbar-inverse .navbar-nav > li > a {
  font-weight: 700;
}

/* =========================================================
   Modal
   ========================================================= */

.modal-content {
  border-radius: 14px;
  border-radius: var(--radius);
  border-color: rgba(0, 0, 0, 0.08);
  border-color: var(--border);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

.modal-header {
  border-top-left-radius: 14px;
  border-top-left-radius: var(--radius);
  border-top-right-radius: 14px;
  border-top-right-radius: var(--radius);
  background: rgba(0, 0, 0, 0.02);
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  border-bottom: 1px solid var(--border);
}

.modal-title {
  font-weight: 900;
}

.modal-wide .modal-dialog {
  width: 95%;
  max-width: 1200px;
}

.close {
  opacity: 0.5;
}
.close:hover {
  opacity: 0.9;
}

/* =========================================================
   Sidebar (menu_esquerda.tpl - Klorofil)
   ========================================================= */

#sidebar-nav.sidebar,
.sidebar {
  background: rgba(255, 255, 255, 0.92);
  border-right: 1px solid rgba(0, 0, 0, 0.08);
  border-right: 1px solid var(--border);
  box-shadow: 2px 0 8px rgba(15, 23, 42, 0.05);
}

.sidebar .nav > li > a {
  color: #1d2430;
  color: var(--text);
  font-weight: 700;
  border-radius: 12px;
  margin: 2px 10px;
}

.sidebar .nav > li > a:hover {
  background: rgba(47, 125, 255, 0.08);
  color: #2f7dff;
  color: var(--accent);
}

.sidebar .nav > li > a.active {
  background: rgba(47, 125, 255, 0.12);
  color: #2f7dff;
  color: var(--accent);
}

.sidebar .nav a.disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.sidebar .icon-submenu {
  float: right;
  transition: transform 0.15s ease;
  opacity: 0.7;
}

.sidebar a.collapsed .icon-submenu {
  transform: rotate(-90deg);
}

.sidebar .collapse .nav > li > a {
  font-weight: 700;
  color: #5a6a82;
  color: var(--muted);
}
.sidebar .collapse .nav > li > a:hover {
  color: #2f7dff;
  color: var(--accent);
}

/* =========================================================
   "Relatórios" / Cards do Dashboard (panel-relatorio)
   ========================================================= */

.panel-relatorio {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border: 1px solid var(--border);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.07);
  border-radius: 14px;
  border-radius: var(--radius);
  margin-bottom: 20px;
}

.panel-relatorio .panel-heading {
  background: transparent;
  border-bottom: none;
  font-weight: 900;
}

.panel-relatorio .panel-body.like {
  font-size: 42px;
  font-weight: 900;
}

.panel-relatorio .panel-body.success {
  background: #00b894 !important;
  background: var(--accent2) !important;
  color: #fff !important;
}
.panel-relatorio .panel-body.info {
  background: #2f7dff !important;
  background: var(--accent) !important;
  color: #fff !important;
}
.panel-relatorio .panel-body.warning {
  background: #f4b400 !important;
  color: #1d2430 !important;
}
.panel-relatorio .panel-body.danger {
  background: #e63946 !important;
  background: var(--danger) !important;
  color: #fff !important;
}

/* =========================================================
   Modal Versão
============================================================= */
#modal-versao a.btn {
  color: #fff !important;
}

.box-fatura {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 15px;
}

.box-error {
  border: 1px solid rgba(230, 57, 70, 0.25);
  background: rgba(230, 57, 70, 0.08);
  border-radius: var(--radius);
  padding: 12px 14px;
}

.notificationsBox {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px;
}

.notificationTable {
  width: 100%;
}
.notificationTable td,
.notificationTable th {
  padding: 10px;
  border-top: 1px solid var(--border);
}

.panelNotification {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 12px;
  background: rgba(0, 0, 0, 0.02);
}

.box-toggle-notification {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: rgba(47, 125, 255, 0.06);
}

.box-label-toggle {
  font-weight: 900;
}

.loading {
  opacity: 0.65;
  pointer-events: none;
  position: relative;
}
.loading:after {
  content: "";
  position: absolute;
  right: 12px;
  top: 50%;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  border-radius: 999px;
  border: 2px solid rgba(0, 0, 0, 0.15);
  border-top-color: var(--accent);
  animation: spin 0.9s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.icon-checked {
  color: var(--accent2);
}
.icon-unchecked {
  color: var(--muted);
}

/* =========================================================
   Plugins: DataTables / Select2 / Bootstrap-Select / Switch / iCheck
   ========================================================= */

table.dataTable,
table.dataTable.no-footer {
  border-bottom: 1px solid var(--border) !important;
}
table.dataTable thead th {
  background: rgba(0, 0, 0, 0.02) !important;
  border-bottom: 1px solid var(--border) !important;
}

.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
  border-radius: 12px;
  border: 1px solid var(--border);
  padding: 6px 10px;
  outline: none;
}
.dataTables_wrapper .dataTables_filter input:focus,
.dataTables_wrapper .dataTables_length select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(47, 125, 255, 0.2);
}

.dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 10px !important;
  border: 1px solid var(--border) !important;
  background: rgba(255, 255, 255, 0.75) !important;
  margin: 0 2px !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: var(--accent) !important;
  color: #fff !important;
  border-color: var(--accent) !important;
}

.dataTables_wrapper .dt-buttons .dt-button {
  border-radius: 12px !important;
  border: 1px solid var(--border) !important;
  background: rgba(47, 125, 255, 0.08) !important;
  font-weight: 700;
}
.dataTables_wrapper .dt-buttons .dt-button:hover {
  background: rgba(47, 125, 255, 0.12) !important;
}

/* Select2 */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  border-radius: 12px !important;
  border-color: var(--border) !important;
  min-height: 34px;
}
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus
  .select2-selection--multiple {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(47, 125, 255, 0.2) !important;
}
.select2-container--default
  .select2-results__option--highlighted[aria-selected] {
  background: var(--accent) !important;
}

/* Bootstrap Select (selectpicker) */
.bootstrap-select > .dropdown-toggle {
  border-radius: 12px !important;
  border-color: var(--border) !important;
}
.bootstrap-select .dropdown-menu {
  border-radius: 12px;
  border-color: var(--border);
  box-shadow: var(--shadow);
}

/* Bootstrap Switch */
.bootstrap-switch {
  border-radius: 999px !important;
  border-color: var(--border) !important;
  box-shadow: none !important;
  background: rgba(0, 0, 0, 0.03) !important;
}
.bootstrap-switch .bootstrap-switch-container {
  border-radius: 999px !important;
}
.bootstrap-switch .bootstrap-switch-handle-on,
.bootstrap-switch .bootstrap-switch-handle-off,
.bootstrap-switch .bootstrap-switch-label {
  padding: 7px 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em;
}
.bootstrap-switch .bootstrap-switch-label {
  background: rgba(255, 255, 255, 0.92) !important;
  border-left: 1px solid var(--border) !important;
  border-right: 1px solid var(--border) !important;
}
.bootstrap-switch.bootstrap-switch-focused {
  box-shadow: 0 0 0 3px rgba(47, 125, 255, 0.22) !important;
}
.bootstrap-switch .bootstrap-switch-handle-on {
  color: #fff !important;
  background-color: var(--accent2) !important;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.16),
    rgba(0, 0, 0, 0.08)
  ) !important;
}
.bootstrap-switch .bootstrap-switch-handle-off {
  color: #fff !important;
  background-color: var(--danger) !important;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.16),
    rgba(0, 0, 0, 0.08)
  ) !important;
}

/* iCheck - flat-aero (skin do projeto) */
.icheckbox_flat-aero,
.iradio_flat-aero {
  border-radius: 10px !important;
  border: 1px solid var(--border) !important;
  background-color: rgba(255, 255, 255, 0.95) !important;
  box-shadow: none !important;
}
.iradio_flat-aero {
  border-radius: 999px !important;
}
.icheckbox_flat-aero.hover,
.iradio_flat-aero.hover {
  border-color: rgba(47, 125, 255, 0.35) !important;
}
.icheckbox_flat-aero.checked,
.iradio_flat-aero.checked {
  background-color: var(--accent) !important;
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.16),
    rgba(0, 0, 0, 0.08)
  ) !important;
  border-color: var(--accent) !important;
}
.icheckbox_flat-aero.disabled,
.iradio_flat-aero.disabled {
  opacity: 0.55 !important;
}
/* =========================================================
   Plugins: Toastr / SweetAlert v1 / SweetAlert2 / Summernote
   ========================================================= */

#toast-container > div {
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow) !important;
  opacity: 0.98 !important;
}

#toast-container > .toast {
  background-image: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0.14),
    rgba(0, 0, 0, 0.06)
  ) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
}
#toast-container > .toast-success {
  background-color: var(--accent2) !important;
}
#toast-container > .toast-error {
  background-color: var(--danger) !important;
}
#toast-container > .toast-info {
  background-color: var(--accent) !important;
}
#toast-container > .toast-warning {
  background-color: #f4b400 !important;
  color: #1d2430 !important;
}

#toast-container .toast-title {
  font-weight: 900 !important;
  letter-spacing: 0.01em;
}
#toast-container .toast-message {
  font-weight: 600 !important;
}

#toast-container .toast-close-button {
  opacity: 0.9 !important;
  text-shadow: none !important;
}
#toast-container .toast-progress {
  opacity: 0.35 !important;
  background: rgba(0, 0, 0, 0.35) !important;
}
.sweet-alert {
  border-radius: var(--radius) !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25) !important;
}

.swal2-popup {
  border-radius: var(--radius) !important;
}
.swal2-styled {
  border-radius: 12px !important;
  font-weight: 900 !important;
}
.swal2-confirm {
  background: var(--accent) !important;
}
.swal2-cancel {
  background: rgba(0, 0, 0, 0.15) !important;
  color: var(--text) !important;
}

.note-editor.note-frame {
  border-radius: var(--radius) !important;
  border-color: var(--border) !important;
  overflow: hidden;
}
.note-editor.note-frame .note-toolbar {
  background: rgba(0, 0, 0, 0.02) !important;
  border-bottom: 1px solid var(--border) !important;
}
.note-editor.note-frame .note-editing-area .note-editable {
  background: #fff;
}

.tooltip-inner {
  border-radius: 10px;
  font-weight: 700;
}

.btn-info:hover,
.btn-info:focus {
  background-color: #1593da;
  border-color: #1593da;
}
.btn-warning:hover,
.btn-warning:focus {
  background-color: #e3a700;
  border-color: #e3a700;
}

/* =========================================================
   Overrides v5 - Sidebar background + Navbar user dropdown
   ========================================================= */

/* Sidebar (Klorofil) - fundo claro FLAT (sem gradiente) */
:root {
  --sidebar-bg: #f7f9fc;
  --sidebar-border: rgba(15, 23, 42, 0.1);
}
#wrapper #sidebar-nav.sidebar,
body #sidebar-nav.sidebar,
#sidebar-nav.sidebar,
#wrapper .sidebar,
body .sidebar,
.sidebar {
  background: var(--sidebar-bg) !important;
  background-image: none !important;
  border-right: 1px solid var(--sidebar-border) !important;
  box-shadow: 2px 0 8px rgba(15, 23, 42, 0.05) !important;
}
/* Alguns templates colocam o background escuro em .sidebar-scroll */
#sidebar-nav.sidebar .sidebar-scroll,
.sidebar .sidebar-scroll {
  background: transparent !important;
  padding-top: 0 !important;
}

/* Evitar “bloco” escuro atrás da lista */
#sidebar-nav.sidebar nav,
#sidebar-nav.sidebar .nav,
.sidebar nav,
.sidebar .nav {
  background: transparent !important;
}

/* Links do menu lateral (aumenta especificidade pra ganhar do main.css do dash) */
#sidebar-nav.sidebar .nav > li > a,
.sidebar .nav > li > a {
  color: var(--text) !important;
  font-weight: 400 !important;
      padding: 13px 13px !important;
    font-size: 15px!important; 
}
.sidebar .nav i {
    margin-right: 5px !important;
    font-size: 16px;
}
#sidebar-nav.sidebar .nav > li > a:hover,
.sidebar .nav > li > a:hover {
  background: rgba(47, 125, 255, 0.08) !important;
  color: var(--accent) !important;
}
#sidebar-nav.sidebar .nav > li > a.active,
.sidebar .nav > li > a.active {
  background: rgba(47, 125, 255, 0.12) !important;
  color: var(--accent) !important;
}

/* Estado ativo real (Klorofil marca no <li class="active">) */
#sidebar-nav.sidebar .nav > li.active > a,
.sidebar .nav > li.active > a {
  background: rgba(47, 125, 255, 0.12) !important;
  color: var(--accent) !important;
  border-left: 3px solid var(--accent) !important;
  padding-left: 17px !important; /* compensa a borda */
}

/* Ícones e seta do submenu */
#sidebar-nav.sidebar .nav > li > a .icon-submenu,
#sidebar-nav.sidebar .nav > li > a .lnr,
#sidebar-nav.sidebar .nav > li > a .fa,
.sidebar .nav > li > a .icon-submenu,
.sidebar .nav > li > a .lnr,
.sidebar .nav > li > a .fa {
  color: inherit !important;
  opacity: 0.85 !important;
}
#sidebar-nav.sidebar .nav > li > a:hover .icon-submenu,
#sidebar-nav.sidebar .nav > li >a:hover .fa,
.sidebar .nav > li > a:hover .icon-submenu,
.sidebar .nav > li > a:hover .fa {
  color: var(--accent) !important;
  opacity: 1 !important;
}
#sidebar-nav.sidebar .nav > li > a.active .fa,
.sidebar .nav > li > a.active .fa {
  color: var(--accent) !important;
}
/* Submenu (collapse) */
#sidebar-nav.sidebar .collapse .nav > li > a,
.sidebar .collapse .nav > li > a {
  color: var(--muted) !important;
  font-weight: 500 !important;
  padding: 7px 18px 7px 32px !important;
  font-size: 12px !important;
  border-radius: 9px;
  margin: 0 12px 4px;
  letter-spacing: 0.01em;
  transition: background 0.2s ease, color 0.2s ease;
}
#sidebar-nav.sidebar .collapse .nav > li > a:hover,
.sidebar .collapse .nav > li > a:hover,
.sidebar .collapse .nav > li > a:focus {
  color: var(--accent) !important;
  background: rgba(47, 125, 255, 0.08) !important;
}

/* Submenu items styling */
.sidebar .nav .nav > li > a {
  padding-bottom: 6px;
  padding-top: 6px;
  font-weight: 600 !important;
  font-size: 12px;
  padding-left: 34px;
  color: var(--muted);
}

/* Navbar (topo) - dropdown do usuário */
.navbar .navbar-nav.navbar-right > li.dropdown > a.dropdown-toggle {
  border-radius: 12px;
  font-weight: 900;
  letter-spacing: 0.01em;
}
.navbar .navbar-nav.navbar-right > li.dropdown.open > a,
.navbar .navbar-nav.navbar-right > li.dropdown > a:hover,
.navbar .navbar-nav.navbar-right > li.dropdown > a:focus {
  background: rgba(47, 125, 255, 0.1) !important;
  color: var(--accent) !important;
}

/* Menu do dropdown (somente dentro de navbar) */
.navbar .navbar-nav > li > .dropdown-menu {
  border-radius: 14px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  background: rgba(255, 255, 255, 0.98);
  padding: 6px;
  margin-top: 8px;
}

.navbar .navbar-nav > li > .dropdown-menu > li > a {
  border-radius: 10px;
  padding: 9px 12px;
  font-weight: 700;
  color: var(--text);
}
.navbar .navbar-nav > li > .dropdown-menu > li > a:hover,
.navbar .navbar-nav > li > .dropdown-menu > li > a:focus {
  background: rgba(47, 125, 255, 0.08);
  color: var(--accent);
}

.navbar .navbar-nav > li > .dropdown-menu > li > a i,
.navbar .navbar-nav > li > .dropdown-menu > li > a .lnr {
  opacity: 0.75;
  margin-right: 8px;
}

/* caret / ícone do dropdown */
.navbar .navbar-nav.navbar-right .icon-submenu,
.navbar .navbar-nav.navbar-right .caret {
  opacity: 0.7;
  margin-left: 6px;
}

/* Divider do dropdown */
.navbar .dropdown-menu .divider {
  background-color: rgba(0, 0, 0, 0.08);
}

/* Botão "branco" (btn-default / btn-white) - hover mais bonito */
.btn-default,
.btn-white {
  background-color: #ffffff;
  background-image: linear-gradient(to bottom, #ffffff 0%, #f4f6fa 100%);
  border-color: rgba(15, 23, 42, 0.18);
  color: var(--text);
}
.btn-default:hover,
.btn-default:focus,
.btn-white:hover,
.btn-white:focus {
  background-color: #f6f8fc;
  background-image: linear-gradient(to bottom, #f8fafc 0%, #eaeef7 100%);
  border-color: rgba(47, 125, 255, 0.55);
  color: var(--accent);
}
.btn-default:active,
.btn-default.active,
.btn-white:active,
.btn-white.active {
  background-image: none;
  background-color: #eaeef7;
  border-color: rgba(47, 125, 255, 0.55);
  color: var(--accent);
}

/* Login (Klorofil) - compatibilidade com o tema */
body.login,
body.login-page,
body.page-login,
body.auth,
body#login {
  background:
    radial-gradient(
      1200px 700px at 15% -10%,
      rgba(47, 125, 255, 0.18),
      transparent 55%
    ),
    radial-gradient(
      1000px 600px at 110% 10%,
      rgba(0, 184, 148, 0.14),
      transparent 55%
    ),
    #f2f5fb;
  color: var(--text);
}

/* Card do login */
.auth-box,
.login-box,
.card-login {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.10);
  overflow: hidden;
}

/* Layout clássico do Klorofil: .left (form) + .right (banner) */
.auth-box .left {
  padding: 28px 26px;
  background: transparent;
}
.auth-box .right {
  position: relative;
  background: linear-gradient(
    135deg,
    rgba(47, 125, 255, 0.95) 0%,
    rgba(22, 163, 74, 0.65) 100%
  );
  color: #fff;
}
.auth-box .right:before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(
    800px 420px at 20% 0%,
    rgba(255, 255, 255, 0.18),
    transparent 55%
  );
  pointer-events: none;
}
/* Texto/letreiro da direita */
.auth-box .right .overlay,
.auth-box .right .content,
.auth-box .right .text {
  position: relative;
  z-index: 1;
  padding: 28px 26px;
}
.auth-box .right h1,
.auth-box .right h2,
.auth-box .right h3 {
  font-weight: 900;
  letter-spacing: 0.4px;
  color: #fff;
  text-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}
.auth-box .right p,
.auth-box .right small,
.auth-box .right .lead {
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
}

/* Cabeçalho/brand do login */
.auth-box .header,
.auth-box .logo,
.login-header {
  margin-bottom: 18px;
}
.auth-box .header h3,
.auth-box .header h2,
.login-header h3 {
  font-weight: 900;
  margin: 0 0 6px 0;
}
.auth-box .header .lead,
.login-header .lead {
  color: var(--muted);
  margin: 0;
}

/* Campos e botões no login */
.auth-box .form-control {
  border-radius: 12px;
}
.auth-box .btn {
  border-radius: 12px;
}
.auth-box a {
  color: var(--accent);
}
.auth-box a:hover {
  color: rgba(47, 125, 255, 0.85);
}



/* =========================================================
   Performance do tema Catálogo
   =========================================================
   O tema é carregado globalmente quando catalog_theme está ativo.
   Este bloco evita que telas grandes fiquem pesadas por animações de layout,
   sombras longas, filtros e transições amplas herdadas do tema base.
*/
#wrapper .sidebar,
#wrapper .main,
#wrapper .navbar,
.navbar-default {
  -webkit-transition-property: background-color, border-color, color, opacity, transform !important;
  -moz-transition-property: background-color, border-color, color, opacity, transform !important;
  -ms-transition-property: background-color, border-color, color, opacity, transform !important;
  -o-transition-property: background-color, border-color, color, opacity, transform !important;
  transition-property: background-color, border-color, color, opacity, transform !important;
  -webkit-transition-duration: 0.12s !important;
  -moz-transition-duration: 0.12s !important;
  -ms-transition-duration: 0.12s !important;
  -o-transition-duration: 0.12s !important;
  transition-duration: 0.12s !important;
}

/* A transição de width/left do Klorofil força reflow em páginas grandes. */
#wrapper .sidebar,
#wrapper .main {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -ms-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}

.card,
.gd-card,
.card-modal,
.panel,
.panel-relatorio,
.box-fatura {
  box-shadow: 0 1px 6px rgba(15, 23, 42, 0.05) !important;
}

.btn,
a.btn-default:not(.btn),
a.btn-primary:not(.btn),
a.btn-success:not(.btn),
a.btn-info:not(.btn),
a.btn-warning:not(.btn),
a.btn-danger:not(.btn),
button.btn-default:not(.btn),
button.btn-primary:not(.btn),
button.btn-success:not(.btn),
button.btn-info:not(.btn),
button.btn-warning:not(.btn),
button.btn-danger:not(.btn),
input.btn-default:not(.btn),
input.btn-primary:not(.btn),
input.btn-success:not(.btn),
input.btn-info:not(.btn),
input.btn-warning:not(.btn),
input.btn-danger:not(.btn) {
  -webkit-transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease !important;
  -moz-transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease !important;
  -ms-transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease !important;
  -o-transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease !important;
  transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease !important;
}

.table-hover > tbody > tr:hover,
.list-group-item:hover,
a.list-group-item:hover,
a.list-group-item:focus,
.sidebar .nav > li > a:hover,
#sidebar-nav.sidebar .nav > li > a:hover {
  box-shadow: none !important;
}

.navbar-default,
.navbar .navbar-nav > li > .dropdown-menu,
.bootstrap-select .dropdown-menu {
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *:before,
  *:after {
    -webkit-animation-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Sidebar nav adjustments */
.sidebar .nav > li > a {
    padding: 15px 10px;
}

/* =========================================================
   Correções de compatibilidade visual - TopLab 2026-06-02
   - neutraliza regras antigas/demo que deslocavam ícones FontAwesome
   - preserva alinhamento de botões quadrados em listas/dashboard
   ========================================================= */
body.restrita-layout #tabela i.fa,
body.restrita-layout .table i.fa,
body.restrita-layout .btn i.fa,
body.restrita-layout a.icone i.fa,
body.restrita-layout .req-action-btn i.fa,
body.restrita-layout #tabela i.lnr,
body.restrita-layout .table i.lnr,
body.restrita-layout .btn i.lnr,
body.restrita-layout a.icone i.lnr,
body.restrita-layout .req-action-btn i.lnr,
body.restrita-layout #tabela i[class^="icon-"],
body.restrita-layout #tabela i[class*=" icon-"],
body.restrita-layout .table i[class^="icon-"],
body.restrita-layout .table i[class*=" icon-"],
body.restrita-layout .btn i[class^="icon-"],
body.restrita-layout .btn i[class*=" icon-"],
body.restrita-layout a.icone i[class^="icon-"],
body.restrita-layout a.icone i[class*=" icon-"],
body.restrita-layout .req-action-btn i[class^="icon-"],
body.restrita-layout .req-action-btn i[class*=" icon-"],
body.restrita-layout .asaas-icon {
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding: 0 !important;
  line-height: 1 !important;
}
body.restrita-layout a.icone,
body.restrita-layout .req-action-btn,
body.restrita-layout .btn-icon,
body.restrita-layout .tl-actions .btn,
body.restrita-layout .quick-action-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
}
body.restrita-layout .btn i.fa,
body.restrita-layout .btn i.lnr,
body.restrita-layout .btn i[class^="icon-"],
body.restrita-layout .btn i[class*=" icon-"] {
  vertical-align: middle !important;
}

