/* GEDEXWeb overrides and theme */
:root {
  --gw-primary: #0d6efd;
  --gw-bg: #f8f9fa;
  --gw-text: #212529;
  --gw-muted: #6c757d;
  --gw-border: #dee2e6;
  --gw-sidebar-bg: #ffffff;
  --gw-sidebar-fg: var(--gw-text);
  --gw-header-h: 56px;

  /* Grid palette (inspired by provided mockup) */
  --gw-grid-header-bg: #3f6ab3;  /* deep blue */
  --gw-grid-header-fg: #ffffff;
  --gw-grid-header-border: #2d4e86;
  --gw-grid-row-bg: #ffffff;
  --gw-grid-row-alt: #f4f7fb;
  --gw-grid-row-hover: #eaf2ff;
  --gw-grid-border: #d6dee8;
  --gw-accent-success: #2ebe60;
  --gw-accent-danger: #e74c3c;
  --gw-accent-warning: #f2a93b;
  --gw-shadow: 0 8px 24px rgba(30,60,120,.08);
  --gw-radius: 10px;
  --gw-menu-active-bg: #0d6efd;
  --gw-menu-active-fg: #ffffff;
  --gw-menu-hover-bg: rgba(13,110,253,.12);
}

body.bg-light.dark-mode-support.dark-mode {
  --gw-bg: #0f1318;
  --gw-text: #e9ecef;
  --gw-muted: #adb5bd;
  --gw-border: #1f2937;
  --gw-sidebar-bg: #12171d;
  background-color: var(--gw-bg);
  color: var(--gw-text);
}

.bg-light, body { margin: 0; }
html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}
.layout-wrapper, .main-wrapper {
  width: 100%;
  max-width: 100vw;
}
img, svg, video { max-width: 100%; height: auto; }

.layout-wrapper { padding-top: var(--gw-header-h); }

header.navbar { backdrop-filter: saturate(180%) blur(4px); }
body.dark-mode header.navbar { background-color: #131820 !important; border-color: var(--gw-border); }

.sidebar {
  width: 260px;
  background: var(--gw-sidebar-bg) !important;
  border-right: 1px solid var(--gw-border);
  position: fixed;
  top: var(--gw-header-h);
  bottom: 0;
  left: 0;
  padding: 16px 12px;
  overflow-y: auto;
  transition: transform .2s ease, opacity .2s ease;
}
.sidebar.hide { transform: translateX(-100%); opacity: 0; }
.sidebar.show { transform: translateX(0); opacity: 1; z-index: 1040; }

.main-content { padding: 16px 24px 24px; }
.main-content > :first-child { margin-top: 0 !important; }
.main-content .page-header { margin-top: 0 !important; padding-top: 0 !important; }
.main-content .card:first-child { margin-top: 0 !important; }
.with-sidebar .main-content { margin-left: 260px; }

/* Correções de layout para ocupar a largura total e evitar deslocamento à direita */
/* Anula regras do tema base (NiceAdmin) que deslocam o wrapper inteiro */
.main-wrapper.with-sidebar { margin-left: 0 !important; }
.sidebar.hide { left: 0 !important; }

@media (max-width: 767.98px) {
  .with-sidebar .main-content { margin-left: 0; }
  .sidebar { top: 56px; }
}

@media (min-width: 768px) {
  /* Garante que em desktop o wrapper não tenha margem e o conteúdo simule o recuo da sidebar */
  .main-wrapper.with-sidebar { margin-left: 0 !important; }
  .with-sidebar .main-content { margin-left: 260px; }
}

.sidebar .nav-link {
  border-radius: 8px;
  padding: 10px 12px;
  color: var(--gw-text);
}
.sidebar .nav-link:hover { background-color: rgba(13,110,253,.08); color: var(--gw-text); }
.sidebar .nav-link.active { background-color: rgba(13,110,253,.12); font-weight: 600; }

.footer { background-color: var(--gw-bg) !important; border-color: var(--gw-border) !important; }
.footer .text-muted { color: var(--gw-muted) !important; }

.btn#menu-toggle .bi { pointer-events: none; }

.page-header { display: flex; align-items: baseline; gap: 12px; }
.page-header h1 { margin: 0; }
.page-header small { color: var(--gw-muted); }

/* Toast tweaks */
#toast-container { pointer-events: none; }
#toast-container .toast { pointer-events: auto; }

/* Dark mode adjustments */
body.dark-mode .sidebar .nav-link:hover { background-color: rgba(13,110,253,.15); }
body.dark-mode .sidebar .nav-link.active { background-color: rgba(13,110,253,.18); }

/* Grid/Table styling */
.grid-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--gw-grid-row-bg);
  border: 1px solid var(--gw-grid-border);
  border-radius: var(--gw-radius);
  box-shadow: var(--gw-shadow);
  overflow: hidden;
}
.grid-table thead th {
  background: var(--gw-grid-header-bg);
  color: var(--gw-grid-header-fg);
  font-weight: 600;
  padding: 10px 12px;
  border-right: 1px solid rgba(255,255,255,.2);
  white-space: nowrap;
}
.grid-table thead th:first-child { border-top-left-radius: var(--gw-radius); }
.grid-table thead th:last-child { border-top-right-radius: var(--gw-radius); border-right: none; }
.grid-table tbody td,
.grid-table tbody th {
  padding: 8px 10px;
  border-top: 1px solid var(--gw-grid-border);
  border-right: 1px solid var(--gw-grid-border);
  vertical-align: middle;
}
.grid-table tbody td:last-child,
.grid-table tbody th:last-child { border-right: none; }
.grid-table tbody tr:nth-child(even) { background: var(--gw-grid-row-alt); }
.grid-table tbody tr:hover { background: var(--gw-grid-row-hover); }
.grid-table .status-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.grid-table .status-dot.success { background: var(--gw-accent-success); }
.grid-table .status-dot.danger { background: var(--gw-accent-danger); }
.grid-table .status-dot.warning { background: var(--gw-accent-warning); }

/* Controls and Forms */
.section-card {
  background: #fff;
  border: 1px solid var(--gw-grid-border);
  border-radius: var(--gw-radius);
  box-shadow: var(--gw-shadow);
  padding: 16px;
  margin-bottom: 16px;
}
.section-card h2, .section-card .section-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--gw-text);
  margin: 0 0 12px;
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 16px;
}
.form-grid.full { grid-template-columns: 1fr; }
.form-note {
  font-size: .85rem;
  color: var(--gw-muted);
}
label { font-weight: 500; color: var(--gw-text); }
.form-check-label { font-weight: 500; }

.form-control, .form-select {
  border: 1px solid var(--gw-grid-border);
  border-radius: 10px;
  background-color: #fff;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.04);
}
.form-control:focus, .form-select:focus {
  border-color: var(--gw-primary);
  box-shadow: 0 0 0 3px rgba(13,110,253,.15);
}
.form-control::placeholder { color: var(--gw-muted); }

.form-check-input {
  border-color: var(--gw-grid-border);
}
.form-check-input:checked {
  background-color: var(--gw-primary);
  border-color: var(--gw-primary);
}

.btn {
  border-radius: 10px;
}
.btn-primary { background-color: var(--gw-primary); border-color: var(--gw-primary); }
.btn-success { background-color: var(--gw-accent-success); border-color: var(--gw-accent-success); }
.btn-danger { background-color: var(--gw-accent-danger); border-color: var(--gw-accent-danger); }
.btn-outline-secondary { color: var(--gw-muted); border-color: var(--gw-border); }
.btn-outline-secondary:hover { color: var(--gw-text); border-color: var(--gw-muted); }

/* Tom Select styling to match theme */
.ts-wrapper { --ts-border: var(--gw-grid-border); --ts-focus: var(--gw-primary); }
.ts-control {
  border: 1px solid var(--gw-grid-border);
  border-radius: 10px;
  background-color: #fff;
  min-height: 38px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.04);
}
.ts-control.focus {
  border-color: var(--gw-primary);
  box-shadow: 0 0 0 3px rgba(13,110,253,.15);
}
.ts-dropdown { border: 1px solid var(--gw-grid-border); box-shadow: var(--gw-shadow); }
.ts-dropdown .option { padding: 8px 10px; }
.ts-dropdown .active { background-color: var(--gw-grid-row-hover); }
.ts-wrapper .item { background: var(--gw-grid-row-alt); border-radius: 8px; padding: 2px 6px; margin: 2px; }
.ts-wrapper.multi .ts-control > .item { margin-right: 6px; }
.ts-wrapper .clear-button { color: var(--gw-muted); }

/* Tabs, Pills, Breadcrumb, Accordion */
.tab-card {
  background: #fff;
  border: 1px solid var(--gw-grid-border);
  border-radius: var(--gw-radius);
  box-shadow: var(--gw-shadow);
}
.tab-card .nav-tabs {
  border-bottom: 1px solid var(--gw-grid-border);
  padding: 8px 12px;
}
.nav-tabs .nav-link {
  border: none;
  color: var(--gw-text);
  margin-right: 8px;
  border-radius: 8px 8px 0 0;
}
.nav-tabs .nav-link:hover { background-color: var(--gw-grid-row-alt); }
.nav-tabs .nav-link.active {
  background-color: var(--gw-grid-row-hover);
  color: var(--gw-text);
  box-shadow: inset 0 -2px 0 var(--gw-primary);
}
.nav-pills .nav-link { border-radius: 20px; }
.nav-pills .nav-link.active { background-color: var(--gw-primary); }

.breadcrumb { --bs-breadcrumb-divider-color: var(--gw-muted); }
.breadcrumb .breadcrumb-item a { color: var(--gw-text); }
.breadcrumb .breadcrumb-item.active { color: var(--gw-muted); }

.accordion .accordion-item { border: 1px solid var(--gw-grid-border); border-radius: var(--gw-radius); overflow: hidden; }
.accordion .accordion-header { background: var(--gw-grid-row-alt); }
.accordion .accordion-button { background: transparent; }
.accordion .accordion-button:focus { box-shadow: 0 0 0 3px rgba(13,110,253,.15); }
.accordion .accordion-button:not(.collapsed) { color: var(--gw-text); background: var(--gw-grid-row-hover); box-shadow: inset 0 -2px 0 var(--gw-primary); }

.badge-primary { background-color: var(--gw-primary); }
.badge-success { background-color: var(--gw-accent-success); }
.badge-danger { background-color: var(--gw-accent-danger); }
.badge-warning { background-color: var(--gw-accent-warning); }

.sidebar { background-color: var(--gw-sidebar-bg) !important; }
.sidebar .nav-link { color: var(--gw-sidebar-fg) !important; }
.sidebar .nav-link:hover { background-color: var(--gw-menu-hover-bg) !important; }
.sidebar .nav-link.active { background-color: var(--gw-menu-active-bg) !important; color: var(--gw-menu-active-fg) !important; }

/* Theme: Cotes (azul profundo + destaque laranja, fundo claro) */
.theme-cotes {
  --gw-bg: #eef3f8;
  --gw-text: #1f2a3a;
  --gw-muted: #6a7a90;
  --gw-primary: #1e6bd6;          /* azul principal para botões e foco */
  --gw-sidebar-bg: #0f3a5c;       /* azul profundo do menu */
  --gw-sidebar-fg: #ffffff;       /* texto do menu lateral branco */
  --gw-menu-active-bg: #f26522;   /* destaque laranja ativo */
  --gw-menu-active-fg: #ffffff;
  --gw-menu-hover-bg: rgba(255,255,255,.08);
  --gw-grid-header-bg: #2e5fa5;   /* cabeçalho de grids ligeiramente mais escuro */
  --gw-grid-border: #cfd7e3;
}
