/* ==============================
   Variaveis globais
   Define fonte, raios, sombras e transicoes base do sistema.
   ============================== */

:root {
  --crmt-font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --crmt-radius-sm: 12px;
  --crmt-radius-md: 18px;
  --crmt-radius-lg: 26px;
  --crmt-shadow: 0 20px 45px rgba(15, 23, 42, 0.18);
  --crmt-shadow-soft: 0 12px 28px rgba(15, 23, 42, 0.1);
  --crmt-transition: .22s ease;
}

/* ==============================
   Base do app
   Define box model, wrapper principal e temas globais.
   ============================== */

.crmt-wrap,
.crmt-wrap * { box-sizing: border-box; }

.crmt-wrap {
  font-family: var(--crmt-font);
  color: var(--crmt-text);
  position: relative;
}

.crmt-wrap[data-mode="dark"],
.crmt-shell[data-mode="dark"],
.crmt-auth-wrap[data-mode="dark"] {
  --crmt-bg: #0f172a;
  --crmt-bg-soft: #111c33;
  --crmt-panel: rgba(15, 23, 42, 0.82);
  --crmt-panel-solid: #14213d;
  --crmt-panel-muted: #1d2a4c;
  --crmt-border: rgba(148, 163, 184, 0.18);
  --crmt-border-strong: rgba(96, 165, 250, 0.28);
  --crmt-text: #e5eefc;
  --crmt-text-soft: #a8b8d8;
  --crmt-text-muted: #7f90b6;
  --crmt-brand: #3b82f6;
  --crmt-brand-soft: rgba(59, 130, 246, 0.16);
  --crmt-brand-2: #8b5cf6;
  --crmt-success: #16a34a;
  --crmt-success-soft: rgba(34, 197, 94, 0.14);
  --crmt-warning: #f59e0b;
  --crmt-warning-soft: rgba(245, 158, 11, 0.15);
  --crmt-danger: #f97316;
  --crmt-danger-soft: rgba(249, 115, 22, 0.16);
  --crmt-input: rgba(12, 19, 35, 0.72);
  --crmt-page: linear-gradient(135deg, #081120 0%, #0f172a 42%, #172554 100%);
}

.crmt-wrap[data-mode="light"],
.crmt-shell[data-mode="light"],
.crmt-auth-wrap[data-mode="light"] {
  --crmt-bg: #eff4fb;
  --crmt-bg-soft: #e7eef8;
  --crmt-panel: rgba(255, 255, 255, 0.88);
  --crmt-panel-solid: #ffffff;
  --crmt-panel-muted: #f4f7fb;
  --crmt-border: rgba(148, 163, 184, 0.3);
  --crmt-border-strong: rgba(59, 130, 246, 0.28);
  --crmt-text: #15223d;
  --crmt-text-soft: #4b607f;
  --crmt-text-muted: #6e7f9e;
  --crmt-brand: #2563eb;
  --crmt-brand-soft: rgba(37, 99, 235, 0.12);
  --crmt-brand-2: #7c3aed;
  --crmt-success: #15803d;
  --crmt-success-soft: rgba(34, 197, 94, 0.12);
  --crmt-warning: #b45309;
  --crmt-warning-soft: rgba(245, 158, 11, 0.15);
  --crmt-danger: #ea580c;
  --crmt-danger-soft: rgba(249, 115, 22, 0.12);
  --crmt-input: #ffffff;
  --crmt-page: linear-gradient(145deg, #edf3fb 0%, #f7faff 55%, #dde9fb 100%);
}

.crmt-wrap { background: var(--crmt-page); padding: 24px; border-radius: 30px; overflow: hidden; }

/* ==============================
   Integracao com o body e tema da pagina
   Ajusta fundo externo do site quando o app esta ativo.
   ============================== */

body.crmt-has-app {
  transition: background-color var(--crmt-transition), background-image var(--crmt-transition), color var(--crmt-transition);
}

body.crmt-has-app.crmt-theme-dark,
body.crmt-has-app.crmt-theme-dark #page,
body.crmt-has-app.crmt-theme-dark .site,
body.crmt-has-app.crmt-theme-dark .site-content,
body.crmt-has-app.crmt-theme-dark main,
body.crmt-has-app.crmt-theme-dark article {
  background: #0b1220 !important;
  color: #e5eefc;
}

body.crmt-has-app.crmt-theme-light,
body.crmt-has-app.crmt-theme-light #page,
body.crmt-has-app.crmt-theme-light .site,
body.crmt-has-app.crmt-theme-light .site-content,
body.crmt-has-app.crmt-theme-light main,
body.crmt-has-app.crmt-theme-light article {
  background: #eef4fb !important;
  color: #15223d;
}

body.crmt-has-app.crmt-theme-dark .crmt-wrap,
body.crmt-has-app.crmt-theme-light .crmt-wrap {
  min-height: calc(100vh - 48px);
  transition: background-image var(--crmt-transition), background-color var(--crmt-transition);
}

/* ==============================
   Tela de autenticacao
   Estrutura a area visual e o card de login.
   ============================== */

.crmt-auth-wrap { min-height: 720px; }
.crmt-auth-shell {
  display: grid;
  grid-template-columns: minmax(320px, 1.1fr) minmax(360px, 0.9fr);
  gap: 26px;
  align-items: stretch;
}
.crmt-auth-side,
.crmt-auth-card {
  background: var(--crmt-panel);
  backdrop-filter: blur(18px);
  border: 1px solid var(--crmt-border);
  box-shadow: var(--crmt-shadow);
}
.crmt-auth-side {
  border-radius: var(--crmt-radius-lg);
  padding: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 620px;
  position: relative;
  overflow: hidden;
}
.crmt-auth-side:before,
.crmt-auth-side:after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(10px);
  opacity: .82;
}
.crmt-auth-side:before {
  width: 240px;
  height: 240px;
  right: -50px;
  top: -50px;
  background: linear-gradient(135deg, rgba(59,130,246,.58), rgba(139,92,246,.22));
}
.crmt-auth-side:after {
  width: 200px;
  height: 200px;
  left: -45px;
  bottom: -45px;
  background: linear-gradient(135deg, rgba(14,165,233,.22), rgba(34,197,94,.25));
}
.crmt-auth-identity {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 26px;
  width: 100%;
  text-align: center;
}
.crmt-auth-mark {
  width: min(360px, 72%);
  max-width: 360px;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.crmt-auth-mark img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.crmt-auth-mark-fallback {
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(59,130,246,.9), rgba(139,92,246,.82));
  color: #fff;
  font-size: 128px;
  font-weight: 800;
  letter-spacing: -.04em;
  box-shadow: 0 30px 80px rgba(59,130,246,.2);
}
.crmt-auth-brand-line {
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--crmt-text);
  white-space: nowrap;
}
.crmt-login-shell.crmt-auth-card {
  max-width: none;
  margin: 0;
  border-radius: var(--crmt-radius-lg);
  padding: 36px;
  min-height: 620px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.crmt-login-kicker {
  display: inline-flex;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--crmt-brand-soft);
  color: var(--crmt-brand);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 700;
  margin-bottom: 18px;
}
.crmt-login-title { font-size: 34px; line-height: 1.08; font-weight: 800; margin: 0 0 10px; color: var(--crmt-text); }
.crmt-login-sub { color: var(--crmt-text-soft); margin-bottom: 22px; font-size: 15px; line-height: 1.6; }

/* ==============================
   Estrutura principal do app
   Controla shell, sidebar e variacoes de layout.
   ============================== */

.crmt-shell {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 24px;
  min-height: 860px;
  position: relative;
  align-items: start;
}
.crmt-shell[data-sidebar-size="sm"] { grid-template-columns: 106px minmax(0, 1fr); }
.crmt-shell[data-layout="horizontal"] { grid-template-columns: minmax(0, 1fr); }

/* ==============================
   Blocos visuais compartilhados
   Aplica painel, borda e sombra aos componentes principais.
   ============================== */

.crmt-sidebar,
.crmt-header,
.crmt-topnav,
.crmt-content,
/* ==============================
   Listagens e tabelas
   Define linhas, colunas, cabecalhos e celulas de acoes.
   ============================== */

.crmt-recent-list,
.crmt-results-table,
.crmt-card,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-perm-list,
.crmt-modal-card,
.crmt-settings-grid > div,
.crmt-stat,
.crmt-type-card,
.crmt-report-tile,
/* ==============================
   Customizador de interface
   Controla painel lateral de preferencias visuais.
   ============================== */

.crmt-customizer {
  background: var(--crmt-panel);
  backdrop-filter: blur(16px);
  border: 1px solid var(--crmt-border);
  box-shadow: var(--crmt-shadow-soft);
}

/* ==============================
   Sidebar
   Controla marca, navegacao lateral e rodape da barra lateral.
   ============================== */

.crmt-sidebar {
  border-radius: 28px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  min-height: calc(100vh - 120px);
  position: sticky;
  top: 24px;
}
.crmt-shell[data-layout="horizontal"] .crmt-sidebar { display: none; }
.crmt-sidebar-brand { display: flex; align-items: center; gap: 14px; }
.crmt-sidebar-logo {
  width: 52px; height: 52px; border-radius: 18px;
  background: linear-gradient(135deg, var(--crmt-brand), var(--crmt-brand-2));
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; letter-spacing: .06em;
  box-shadow: 0 12px 28px rgba(59,130,246,.28);
}
.crmt-sidebar-title { font-size: 18px; font-weight: 800; }
.crmt-sidebar-subtitle,
.crmt-sidebar-hint { font-size: 13px; color: var(--crmt-text-soft); line-height: 1.6; }
.crmt-sidebar-section-title,
.crmt-section-title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--crmt-text-muted);
  font-weight: 700;
  margin-bottom: 0;
}

/* ==============================
   Navegacao
   Estiliza tabs laterais, horizontais e modo compacto.
   ============================== */

.crmt-nav { display: flex; gap: 10px; }
.crmt-nav-sidebar { flex-direction: column; }
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-text,
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab .badge { display: none; }
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-title,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-subtitle,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-section-title,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-hint,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-footer .crmt-btn { display: none; }
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-brand { justify-content: center; }
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab {
  justify-content: center;
  padding: 0;
  width: 56px;
  min-height: 56px;
  margin-inline: auto;
  border-radius: 18px;
}
.crmt-shell[data-layout="horizontal"] .crmt-topnav { display: block; }
.crmt-shell[data-layout="vertical"] .crmt-topnav { display: none; }
.crmt-nav-top { flex-wrap: wrap; }

.crmt-tab {
  border-radius: 16px;
  padding: 13px 16px;
  color: var(--crmt-text-soft);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 10px;
  border: 1px solid transparent;
  transition: transform var(--crmt-transition), background var(--crmt-transition), color var(--crmt-transition), border-color var(--crmt-transition);
  font-size: 14px;
}
.crmt-tab:hover { color: var(--crmt-text); background: rgba(255,255,255,.05); transform: translateY(-1px); }
.crmt-shell[data-mode="light"] .crmt-tab:hover { background: rgba(37,99,235,.06); }
.crmt-tab.active {
  color: var(--crmt-text);
  background: linear-gradient(135deg, var(--crmt-brand-soft), rgba(255,255,255,.06));
  border-color: var(--crmt-border-strong);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.crmt-tab-icon {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 20px;
  background: transparent !important;
  border-radius: 0 !important;
  color: currentColor;
  font-size: 0;
  line-height: 1;
}

.crmt-tab-icon svg {
  width: 20px;
  height: 20px;
  display: block;
}

.crmt-shell[data-mode="light"] .crmt-tab-icon,
.crmt-tab.active .crmt-tab-icon,
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon {
  background: transparent !important;
  border-radius: 0 !important;
}
.crmt-shell[data-mode="light"] .crmt-tab-icon { background: rgba(37,99,235,.08); }
.crmt-tab.active .crmt-tab-icon {
  background: rgba(99,102,241,.18);
  color: var(--crmt-text);
}
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon {
  width: 30px;
  height: 30px;
  border-radius: 12px;
}
.crmt-tab .badge {
  margin-left: auto;
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: var(--crmt-text-soft);
}
.crmt-shell[data-mode="light"] .crmt-tab .badge { background: rgba(37,99,235,.08); color: var(--crmt-text-soft); }
.crmt-tab .badge-admin { background: rgba(245,158,11,.14); color: var(--crmt-warning); }
.crmt-sidebar-footer { margin-top: auto; display: grid; gap: 14px; }

/* ==============================
   Header e area principal
   Define cabecalho, acoes do topo e area central do app.
   ============================== */

.crmt-main-shell { display: grid; gap: 18px; }
.crmt-header,
.crmt-topnav { border-radius: 24px; padding: 18px 22px; }
.crmt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.crmt-header-left,
.crmt-header-actions,
.crmt-user-area { display: flex; align-items: center; gap: 14px; }
.crmt-header-kicker {
  font-size: 11px; text-transform: uppercase; letter-spacing: .16em; color: var(--crmt-text-muted); font-weight: 700; margin-bottom: 4px;
}
.crmt-header-title { font-size: 28px; line-height: 1.1; font-weight: 800; }
.crmt-header-chip,
.crmt-header-icon,
.crmt-btn,
.crmt-wrap .icon-btn,
.crmt-type-pill,
.crmt-option-card {
  border: 1px solid var(--crmt-border);
  background: rgba(255,255,255,.04);
  color: var(--crmt-text);
  border-radius: 14px;
  transition: all var(--crmt-transition);
}
.crmt-shell[data-mode="light"] .crmt-header-chip,
.crmt-shell[data-mode="light"] .crmt-header-icon,
.crmt-shell[data-mode="light"] .crmt-btn,
.crmt-shell[data-mode="light"] .icon-btn,
.crmt-shell[data-mode="light"] .crmt-type-pill,
.crmt-shell[data-mode="light"] .crmt-option-card,
.crmt-auth-wrap[data-mode="light"] .crmt-btn { background: rgba(37,99,235,.04); }
.crmt-header-chip,
.crmt-btn,
.crmt-wrap .icon-btn,
.crmt-type-pill { padding: 11px 15px; font-size: 14px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; text-decoration: none; }
.crmt-header-icon { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; font-size: 22px; cursor: pointer; }
.crmt-header-chip:hover,
.crmt-header-icon:hover,
.crmt-btn:hover,
.crmt-wrap .icon-btn:hover,
.crmt-type-pill:hover,
.crmt-option-card:hover { border-color: var(--crmt-border-strong); transform: translateY(-1px); }
.crmt-mobile-nav-toggle { display: none; }
.crmt-user-meta { display: grid; gap: 2px; }
.crmt-avatar {
  width: 42px; height: 42px; border-radius: 14px;
  background: linear-gradient(135deg, var(--crmt-brand), var(--crmt-brand-2));
  color: #fff; display:flex; align-items:center; justify-content:center; font-weight:800;
}
.crmt-user-name { font-size: 14px; font-weight: 700; color: var(--crmt-text); }
.crmt-user-role { font-size: 12px; color: var(--crmt-text-soft); }
.crmt-logout { color: var(--crmt-text-soft); text-decoration: none; font-size: 14px; padding: 11px 14px; border-radius: 14px; border: 1px solid var(--crmt-border); }
.crmt-logout:hover { color: var(--crmt-text); border-color: var(--crmt-border-strong); }

/* ==============================
   Conteudo e avisos
   Organiza a area de paginas internas e mensagens globais.
   ============================== */

.crmt-page-area { display: grid; gap: 18px; }
.crmt-content { border-radius: 26px; padding: 28px; }
.crmt-hidden { display: none !important; }

#crmt-global-notice {
  position: sticky;
  top: 12px;
  z-index: 25;
  margin-bottom: 16px;
}
.crmt-notice { padding: 15px 18px; border-radius: 18px; font-size: 14px; border: 1px solid transparent; }
.crmt-notice.ok { background: var(--crmt-success-soft); color: var(--crmt-success); border-color: rgba(34,197,94,.16); }
.crmt-notice.error { background: var(--crmt-warning-soft); color: var(--crmt-warning); border-color: rgba(245,158,11,.18); }

.crmt-alert-box {
  background: var(--crmt-warning-soft);
  border: 1px solid rgba(245,158,11,.24);
  border-radius: 20px;
  padding: 16px 18px;
  font-size: 16px;
  color: var(--crmt-warning);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.crmt-alert-dot { width: 10px; height: 10px; border-radius: 50%; background: currentColor; flex-shrink: 0; }
.crmt-alert-link { appearance:none; border:0; background:transparent; color:inherit; font:inherit; font-weight:700; cursor:pointer; padding:0; }
.crmt-alert-link:hover { text-decoration: underline; }

/* ==============================
   Grids utilitarias
   Estrutura linhas, cards e composicoes reutilizaveis.
   ============================== */

.crmt-stats-row,
.crmt-type-grid,
.crmt-settings-grid,
.crmt-user-grid,
.crmt-tiles,
.crmt-filters-row,
.crmt-doc-form-grid,
.crmt-form-grid,
.crmt-report-filters-grid,
.crmt-report-preview-grid,
.crmt-checkbox-grid,
.crmt-kv,
.crmt-option-grid { display: grid; gap: 16px; }
.crmt-stats-row { grid-template-columns: repeat(6, minmax(0, 1fr)); margin-bottom: 24px; }
.crmt-stat { border-radius: 22px; padding: 22px; position: relative; overflow: hidden; }
.crmt-stat:before { content:""; position:absolute; inset:auto -30px -70px auto; width:140px; height:140px; border-radius:999px; background:linear-gradient(135deg, rgba(59,130,246,.12), rgba(139,92,246,.08)); }
.crmt-stat-label { font-size: 14px; color: var(--crmt-text-soft); margin-bottom: 12px; position: relative; z-index:1; }
.crmt-stat-value { font-size: clamp(34px, 5vw, 44px); line-height: 1; font-weight: 800; position: relative; z-index:1; }
.crmt-stat-sub { font-size: 13px; color: var(--crmt-text-muted); margin-top: 10px; position: relative; z-index:1; display:flex; flex-direction:column; gap:4px; }
.crmt-stat-sub-line { line-height: 1.35; }

.crmt-recent-list,
.crmt-results-table,
.crmt-card,
.crmt-user-form,
.crmt-perm-list,
.crmt-report-filters-shell,
.crmt-report-summary { border-radius: 22px; overflow: hidden; }
.crmt-recent-row,
.crmt-trow {
  display: grid;
  gap: 14px;
  padding: 16px 18px;
  align-items: center;
  border-bottom: 1px solid var(--crmt-border);
}
.crmt-recent-row:last-child,
.crmt-trow:last-child,
.crmt-perm-row:last-child { border-bottom: none; }
.crmt-recent-row { grid-template-columns: 2fr 1fr 1fr 120px; }
.crmt-trow { grid-template-columns: minmax(250px, 2fr) minmax(160px, 180px) minmax(180px, 1fr) 130px 210px; }
.crmt-recent-row.header,
.crmt-trow.th {
  background: rgba(255,255,255,.04);
  font-size: 11px;
  color: var(--crmt-text-muted);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 700;
}
.crmt-shell[data-mode="light"] .crmt-recent-row.header,
.crmt-shell[data-mode="light"] .crmt-trow.th { background: rgba(37,99,235,.04); }
.crmt-doc-title { font-weight: 800; font-size: 17px; color: var(--crmt-text); }
.crmt-doc-title-link {
  appearance: none;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  text-align: left;
  cursor: pointer;
}
.crmt-doc-title-link:hover {
  text-decoration: underline;
}
.crmt-recent-list-scroll {
  max-height: 780px;
  overflow-y: auto;
}
.crmt-recent-list-scroll .crmt-recent-row.header {
  position: static;
  top: auto;
  z-index: auto;
}
.crmt-doc-sub { font-size: 13px; color: var(--crmt-text-soft); margin-top: 4px; }
.crmt-actions-cell { display:flex; gap:8px; justify-content:flex-start; align-items:center; }
.crmt-actions-cell .icon-btn { min-width: 0; padding: 10px 14px; white-space: nowrap; }
.crmt-results-meta,
.crmt-admin-note,
.crmt-field-help,
.crmt-logo-preview span,
.crmt-small { font-size: 13px; color: var(--crmt-text-soft); }

/* ==============================
   Pills e estados visuais
   Identifica tipos de documento e status operacionais.
   ============================== */

.crmt-pill,
.crmt-pill-doc-type {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1.2;
  padding: 7px 12px;
  font-weight: 700;
}
.pill-pi { background: rgba(59,130,246,.14); color: #93c5fd; }
.pill-emp { background: rgba(34,197,94,.14); color: #86efac; }
.pill-pat { background: rgba(139,92,246,.16); color: #c4b5fd; }
.pill-avulso { background: rgba(245,158,11,.16); color: #fcd34d; }
.pill-nf { background: rgba(249,115,22,.14); color: #fdba74; }
.pill-ok { background: rgba(34,197,94,.14); color: #86efac; }
.pill-pend { background: rgba(245,158,11,.16); color: #fbbf24; }
.crmt-shell[data-mode="light"] .pill-pi { color: #1d4ed8; }
.crmt-shell[data-mode="light"] .pill-emp { color: #15803d; }
.crmt-shell[data-mode="light"] .pill-pat { color: #6d28d9; }
.crmt-shell[data-mode="light"] .pill-avulso { color: #b45309; }
.crmt-shell[data-mode="light"] .pill-nf { color: #c2410c; }
.crmt-shell[data-mode="light"] .pill-ok { color: #15803d; }
.crmt-shell[data-mode="light"] .pill-pend { color: #b45309; }

/* ==============================
   Cards de tipo
   Estiliza os cards de selecao de tipo de cadastro.
   ============================== */

.crmt-type-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-bottom: 24px; }
.crmt-type-card { border-radius: 22px; padding: 22px; text-align: left; cursor: pointer; position: relative; overflow:hidden; }
.crmt-type-card:before { content:""; position:absolute; inset:auto -24px -60px auto; width:120px; height:120px; border-radius:999px; background: rgba(255,255,255,.05); }
.crmt-type-card.selected { border-color: var(--crmt-border-strong); background: linear-gradient(135deg, var(--crmt-brand-soft), rgba(255,255,255,.04)); }
.crmt-type-icon { width: 52px; height: 52px; border-radius: 16px; margin: 0 0 14px; display:flex; align-items:center; justify-content:center; font-size: 22px; color:#fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,.08); }
.crmt-type-label { font-size: 18px; font-weight: 800; color: var(--crmt-text); position: relative; z-index:1; }
.crmt-type-sub { font-size: 14px; color: var(--crmt-text-soft); margin-top: 6px; position: relative; z-index:1; }

.crmt-projcom-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-bottom: 24px; }
.crmt-projcom-card { border: 1px solid var(--crmt-border); border-radius: 22px; padding: 22px; text-align: left; position: relative; overflow:hidden; background: var(--crmt-surface); }
.crmt-projcom-card:before { content:""; position:absolute; inset:auto -24px -60px auto; width:120px; height:120px; border-radius:999px; background: rgba(255,255,255,.05); }
.crmt-projcom-icon { width: 52px; height: 52px; border-radius: 16px; margin: 0 0 14px; display:flex; align-items:center; justify-content:center; font-size: 22px; color:#fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,.08); }
.crmt-projcom-label { font-size: 18px; font-weight: 800; color: var(--crmt-text); position: relative; z-index:1; }
.crmt-projcom-sub { font-size: 14px; color: var(--crmt-text-soft); margin-top: 6px; position: relative; z-index:1; }

/* ==============================
   Formularios
   Define grid, campos, inputs, textareas e variacoes de layout.
   ============================== */

.crmt-doc-form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.crmt-inline-two { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; overflow: hidden; }
.crmt-inline-two input,
.crmt-inline-two select { width: 100%; min-width: 0; max-width: 100%; box-sizing: border-box; }
.crmt-inline-two input[type="date"] { width: 100% !important; min-width: 0 !important; }
.crmt-field { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.crmt-field label { font-size: 13px; font-weight: 700; color: var(--crmt-text-soft); text-transform: uppercase; letter-spacing: .08em; }
.crmt-field input,
.crmt-field select,
.crmt-field textarea,
.crmt-search-bar input {
  min-height: 50px;
  width: 100%;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid var(--crmt-border);
  background: var(--crmt-input);
  color: var(--crmt-text);
  outline: none;
  transition: border-color var(--crmt-transition), box-shadow var(--crmt-transition), background var(--crmt-transition);
  font-size: 15px;
  box-sizing: border-box;
}
.crmt-field textarea { min-height: 130px; padding: 16px; resize: vertical; }
.crmt-field textarea[name="notes_text"] { min-height: 130px; }
.crmt-field textarea.crmt-textarea-inline,
.crmt-field textarea.crmt-textarea-inline[name="notes_text"] { min-height: 50px !important; height: 50px !important; max-height: 50px; padding: 14px 16px; resize: none; overflow: hidden; }
.crmt-field input:focus,
.crmt-field select:focus,
.crmt-field textarea:focus,
.crmt-search-bar input:focus {
  border-color: var(--crmt-border-strong);
  box-shadow: 0 0 0 4px rgba(59,130,246,.10);
}
.crmt-field-full { grid-column: 1 / -1; }
.crmt-doc-form-grid.crmt-layout-notas_fiscais { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.crmt-doc-form-grid.crmt-layout-notas_fiscais .crmt-field-half { grid-column: span 3; }
.crmt-doc-form-grid.crmt-layout-notas_fiscais .crmt-field-third { grid-column: span 2; }

/* ==============================
   Upload de arquivos
   Organiza a area de arrastar, soltar e selecionar arquivo.
   ============================== */

.crmt-upload-area {
  position: relative;
  border-radius: 22px;
  border: 1px dashed var(--crmt-border-strong);
  background: linear-gradient(135deg, rgba(59,130,246,.09), rgba(139,92,246,.08));
  padding: 34px 24px;
  text-align: center;
  cursor: pointer;
  transition: all var(--crmt-transition);
}
.crmt-upload-area:hover,
.crmt-upload-area.dragover { transform: translateY(-1px); border-color: rgba(96,165,250,.6); box-shadow: 0 0 0 4px rgba(59,130,246,.10); }
.crmt-upload-area.has-file { border-style: solid; background: linear-gradient(135deg, rgba(34,197,94,.14), rgba(59,130,246,.08)); }
.crmt-upload-title { font-size: 24px; font-weight: 800; margin-bottom: 6px; }
.crmt-upload-subtitle { font-size: 14px; color: var(--crmt-text-soft); }
.crmt-upload-file { font-size: 13px; margin-top: 10px; color: var(--crmt-text-soft); }
.crmt-upload-area input[type=file] { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }

/* ==============================
   Botoes e acoes
   Define variacoes principal, secundaria e agrupamentos de botoes.
   ============================== */

.crmt-btn-primary {
  background: linear-gradient(135deg, var(--crmt-brand), var(--crmt-brand-2));
  color: #fff;
  border-color: transparent;
  box-shadow: 0 14px 28px rgba(59,130,246,.22);
}
.crmt-btn-secondary,
.crmt-btn-ghost { background: rgba(255,255,255,.04); }
.crmt-btn-row { display: flex; gap: 12px; justify-content: flex-end; margin-top: 20px; flex-wrap: wrap; }

/* ==============================
   Busca, filtros e relatorios
   Controla barras de busca, filtros e tiles de relatorio.
   ============================== */

.crmt-search-bar { display:flex; gap:12px; margin-bottom: 18px; }
.crmt-search-bar input { flex: 1; }
.crmt-filters-row { grid-template-columns: repeat(5, minmax(0,1fr)); margin-bottom: 18px; }
.crmt-filters-row select { min-height: 48px; }

.crmt-tiles { grid-template-columns: repeat(3, minmax(0, 1fr)); margin-bottom: 20px; }
.crmt-report-tiles { grid-template-columns: repeat(5, minmax(0,1fr)); }
.crmt-report-help { font-size: 14px; color: var(--crmt-text-soft); margin-bottom: 14px; }
.crmt-report-tile { position: relative; text-align: left; width: 100%; appearance: none; cursor: pointer; border-radius: 22px; padding: 20px; }
.crmt-report-tile.active { border-color: var(--crmt-border-strong); background: linear-gradient(135deg, var(--crmt-brand-soft), rgba(255,255,255,.04)); }
.crmt-report-highlight { border-color: rgba(245,158,11,.28); }
.crmt-report-count { font-size: 24px; font-weight: 800; margin-bottom: 8px; }
.crmt-wrap[data-mode="dark"] .crmt-report-count,
.crmt-shell[data-mode="dark"] .crmt-report-count,
.crmt-auth-wrap[data-mode="dark"] .crmt-report-count { color: var(--crmt-text) !important; }
.crmt-report-filters-shell,
.crmt-report-summary { border-radius: 22px; padding: 20px; }
.crmt-report-filters-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.crmt-report-preview-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.crmt-report-preview-card .crmt-stat-value { font-size: 28px; }
.crmt-report-preview-card .crmt-stat-sub { display: none; }
.crmt-report-type-quick { margin-top: 12px; }
.crmt-type-pill-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }
.crmt-type-pill.active { border-color: var(--crmt-border-strong); background: var(--crmt-brand-soft); color: var(--crmt-text); }

/* ==============================
   Configuracoes e usuarios
   Estrutura telas administrativas, permissoes e formularios auxiliares.
   ============================== */

.crmt-settings-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.crmt-settings-grid > div { border-radius: 22px; padding: 20px; }
.crmt-logo-preview { display:flex; align-items:center; gap:12px; margin-top: 12px; padding: 12px; border-radius: 16px; border: 1px solid var(--crmt-border); background: rgba(255,255,255,.03); }
.crmt-logo-preview img { max-height: 48px; max-width: 140px; object-fit: contain; display:block; }

.crmt-user-grid { grid-template-columns: 1.4fr 1fr; }
.crmt-user-form { border-radius: 22px; padding: 20px; }
.crmt-checkbox-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.crmt-checkbox-grid label,
.crmt-perm-row { font-size: 14px; color: var(--crmt-text-soft); }
.crmt-checkbox-grid label { display:flex; gap:10px; align-items:flex-start; }
.crmt-perm-list { border-radius: 22px; padding: 18px; }
.crmt-perm-row { display:flex; justify-content:space-between; gap:16px; padding: 11px 0; border-bottom: 1px solid var(--crmt-border); }

/* ==============================
   Modal e apoio ao login
   Regras para janelas modais e links de autenticacao.
   ============================== */

.crmt-modal { position:fixed; inset:0; background:rgba(3,7,18,.64); display:none; align-items:center; justify-content:center; padding:20px; z-index:99999; }
.crmt-modal.open { display:flex; }
.crmt-modal-card { width:min(820px,100%); border-radius: 26px; padding: 24px; }
.crmt-modal-head { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom: 18px; }
.crmt-kv { grid-template-columns: repeat(2, minmax(0,1fr)); gap:12px; margin: 18px 0; }
.crmt-kv div { padding: 12px 14px; border-radius: 16px; border: 1px solid var(--crmt-border); background: rgba(255,255,255,.04); }
.crmt-kv b { display:block; font-size:11px; text-transform: uppercase; letter-spacing: .12em; color: var(--crmt-text-muted); margin-bottom: 8px; }

.crmt-login-links { display:flex; justify-content:flex-end; margin-top:6px; margin-bottom:4px; }
.crmt-login-links a { color: var(--crmt-brand); text-decoration:none; font-size:14px; }
.crmt-login-links a:hover { text-decoration: underline; }

.crmt-customizer {
  position: fixed;
  top: 20px;
  right: 20px;
  bottom: 20px;
  width: min(360px, calc(100vw - 32px));
  border-radius: 28px;
  padding: 22px;
  z-index: 60;
  transform: translateX(calc(100% + 24px));
  opacity: 0;
  pointer-events: none;
  transition: transform var(--crmt-transition), opacity var(--crmt-transition);
}
.crmt-shell.customizer-open .crmt-customizer { transform: translateX(0); opacity: 1; pointer-events: auto; }
.crmt-customizer-backdrop {
  position: fixed; inset: 0; background: rgba(2,6,23,.45); z-index: 50; opacity: 0; pointer-events: none; transition: opacity var(--crmt-transition);
}
.crmt-shell.customizer-open .crmt-customizer-backdrop { opacity: 1; pointer-events: auto; }
.crmt-customizer-head { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom: 18px; }
.crmt-customizer-title { font-size: 22px; font-weight: 800; }
.crmt-customizer-sub { font-size: 14px; color: var(--crmt-text-soft); margin-top: 6px; }
.crmt-customizer-group { margin-bottom: 20px; }
.crmt-customizer-label { font-size: 12px; text-transform: uppercase; letter-spacing: .14em; color: var(--crmt-text-muted); font-weight: 700; margin-bottom: 12px; }
.crmt-option-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.crmt-option-card {
  padding: 16px;
  cursor: pointer;
  text-align: left;
  display: grid;
  gap: 6px;
}
.crmt-option-card span { font-weight: 700; }
.crmt-option-card small { color: var(--crmt-text-soft); font-size: 13px; }
.crmt-option-card.active { border-color: var(--crmt-border-strong); background: var(--crmt-brand-soft); }

/* ==============================
   Responsividade base
   Ajusta grids e composicoes em larguras menores.
   ============================== */

@media (max-width: 1320px) {
  .crmt-stats-row,
  .crmt-report-preview-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .crmt-report-tiles,
  .crmt-report-filters-grid,
  .crmt-tiles { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 1100px) {
  .crmt-wrap { padding: 18px; border-radius: 22px; }
  .crmt-shell,
  .crmt-shell[data-sidebar-size="sm"] { grid-template-columns: minmax(0,1fr); }
  .crmt-sidebar {
    position: fixed;
    left: 16px;
    top: 16px;
    bottom: 16px;
    width: min(310px, calc(100vw - 32px));
    min-height: 0;
    z-index: 70;
    transform: translateX(calc(-100% - 26px));
    transition: transform var(--crmt-transition);
  }
  .crmt-shell.sidebar-open .crmt-sidebar { transform: translateX(0); }
  .crmt-shell[data-layout="horizontal"] .crmt-sidebar { display: none; }
  .crmt-mobile-nav-toggle { display: inline-flex; }
  .crmt-topnav { display: block !important; }
  .crmt-settings-grid,
  .crmt-user-grid,
  .crmt-doc-form-grid,
  .crmt-filters-row,
  .crmt-form-grid,
  .crmt-report-filters-grid,
  .crmt-report-preview-grid,
  .crmt-checkbox-grid,
  .crmt-kv,
  .crmt-stats-row,
  .crmt-type-grid,
  .crmt-auth-shell { grid-template-columns: 1fr; }
  .crmt-recent-row { grid-template-columns: 1.2fr .8fr .8fr 120px; }
  .crmt-trow { grid-template-columns: 1.2fr 1fr 1fr 130px 190px; }
}
@media (max-width: 760px) {
  .crmt-header,
  .crmt-header-actions,
  .crmt-user-area,
  .crmt-search-bar,
  .crmt-btn-row { flex-direction: column; align-items: stretch; }
  .crmt-header { padding: 18px; }
  .crmt-header-actions { width: 100%; }
  .crmt-header-chip,
  .crmt-logout,
  .crmt-btn,
  .crmt-wrap .icon-btn,
  .crmt-type-pill { width: 100%; }
  .crmt-user-area { align-items: flex-start; }
  .crmt-content { padding: 20px; }
  .crmt-recent-row,
  .crmt-trow { grid-template-columns: 1fr; }
  .crmt-inline-two,
  .crmt-option-grid { grid-template-columns: 1fr; }
  .crmt-auth-side,
  .crmt-login-shell.crmt-auth-card { min-height: auto; padding: 28px; }
  .crmt-customizer { top: 10px; right: 10px; bottom: 10px; width: calc(100vw - 20px); }
}

:root {
  --crmt-radius-sm: 8px;
  --crmt-radius-md: 12px;
  --crmt-radius-lg: 16px;
  --crmt-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  --crmt-shadow-soft: 0 1px 3px rgba(15, 23, 42, 0.06);
}

.crmt-wrap[data-mode="dark"],
.crmt-shell[data-mode="dark"],
.crmt-auth-wrap[data-mode="dark"] {
  --crmt-bg: #111827;
  --crmt-bg-soft: #0f172a;
  --crmt-panel: #172033;
  --crmt-panel-solid: #172033;
  --crmt-panel-muted: #1b2841;
  --crmt-border: rgba(148, 163, 184, 0.14);
  --crmt-border-strong: rgba(96, 165, 250, 0.30);
  --crmt-text: #e5eefc;
  --crmt-text-soft: #9aa8c4;
  --crmt-text-muted: #72819d;
  --crmt-brand: #3b82f6;
  --crmt-brand-soft: rgba(59, 130, 246, 0.12);
  --crmt-brand-2: #8b5cf6;
  --crmt-input: #0f172a;
  --crmt-page: #0f172a;
}

.crmt-wrap[data-mode="light"],
.crmt-shell[data-mode="light"],
.crmt-auth-wrap[data-mode="light"] {
  --crmt-bg: #f3f5f9;
  --crmt-bg-soft: #eef2f7;
  --crmt-panel: #ffffff;
  --crmt-panel-solid: #ffffff;
  --crmt-panel-muted: #f8fafc;
  --crmt-border: #e5eaf2;
  --crmt-border-strong: rgba(37, 99, 235, 0.22);
  --crmt-text: #1f2937;
  --crmt-text-soft: #64748b;
  --crmt-text-muted: #94a3b8;
  --crmt-brand: #2563eb;
  --crmt-brand-soft: rgba(37, 99, 235, 0.08);
  --crmt-brand-2: #7c3aed;
  --crmt-input: #ffffff;
  --crmt-page: #f3f5f9;
}

.crmt-wrap {
  background: transparent;
  padding: 0;
  border-radius: 0;
  overflow: visible;
}

body.crmt-has-app.crmt-theme-dark,
body.crmt-has-app.crmt-theme-dark #page,
body.crmt-has-app.crmt-theme-dark .site,
body.crmt-has-app.crmt-theme-dark .site-content,
body.crmt-has-app.crmt-theme-dark main,
body.crmt-has-app.crmt-theme-dark article {
  background: #0f172a !important;
}

body.crmt-has-app.crmt-theme-light,
body.crmt-has-app.crmt-theme-light #page,
body.crmt-has-app.crmt-theme-light .site,
body.crmt-has-app.crmt-theme-light .site-content,
body.crmt-has-app.crmt-theme-light main,
body.crmt-has-app.crmt-theme-light article {
  background: #f3f5f9 !important;
}

/* ==============================
   Refinos de layout consolidados
   Mantem os ajustes posteriores que sobrescrevem a base original.
   ============================== */

body.crmt-has-app .entry-content > .crmt-wrap,
body.crmt-has-app .crmt-wrap {
  min-height: 100vh;
}

.crmt-shell {
  gap: 0;
  grid-template-columns: 250px minmax(0, 1fr);
  min-height: 100vh;
  align-items: stretch;
}

.crmt-shell[data-sidebar-size="sm"] {
  grid-template-columns: 78px minmax(0, 1fr);
}

.crmt-sidebar,
.crmt-header,
.crmt-topnav,
.crmt-content,
.crmt-recent-list,
.crmt-results-table,
.crmt-card,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-perm-list,
.crmt-modal-card,
.crmt-settings-grid > div,
.crmt-stat,
.crmt-type-card,
.crmt-report-tile,
.crmt-customizer {
  background: var(--crmt-panel-solid);
  backdrop-filter: none;
  box-shadow: var(--crmt-shadow-soft);
}

.crmt-sidebar {
  border-radius: 0;
  border-top: 0;
  border-bottom: 0;
  border-left: 0;
  border-right: 1px solid var(--crmt-border);
  padding: 18px 14px;
  gap: 16px;
  min-height: 100vh;
  top: 0;
}

.crmt-sidebar-brand {
  gap: 10px;
  padding: 0 8px 6px;
}

.crmt-sidebar-logo {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  box-shadow: none;
}

.crmt-sidebar-title { font-size: 20px; }
.crmt-sidebar-subtitle { display: none; }

.crmt-sidebar-section-title,
.crmt-section-title {
  font-size: 11px;
  letter-spacing: .12em;
  padding: 4px 8px 0;
}

.crmt-nav { gap: 4px; }

.crmt-tab {
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 14px;
}

.crmt-nav-sidebar .crmt-tab {
  justify-content: flex-start;
}

.crmt-tab:hover {
  transform: none;
  background: rgba(37, 99, 235, 0.05);
}

.crmt-wrap[data-mode="dark"] .crmt-tab:hover {
  background: rgba(255,255,255,.04);
}

.crmt-tab.active {
  background: var(--crmt-brand-soft);
  border-color: transparent;
  box-shadow: none;
}

.crmt-tab-icon {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  border-radius: 0;
  background: transparent;
  color: var(--crmt-text-soft);
  overflow: visible;
}

.crmt-tab.active .crmt-tab-icon,
.crmt-tab.active .crmt-tab-text {
  color: var(--crmt-brand);
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-brand { justify-content: center; padding-inline: 0; }
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab {
  width: 44px;
  min-height: 44px;
  border-radius: 10px;
}
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
}

.crmt-main-shell {
  gap: 0;
  background: var(--crmt-page);
}

.crmt-header {
  border-radius: 0;
  padding: 14px 20px;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  border-bottom: 1px solid var(--crmt-border);
  box-shadow: none;
  gap: 18px;
}

.crmt-header-left,
.crmt-header-actions {
  gap: 12px;
}

.crmt-header-center {
  flex: 1 1 auto;
  min-width: 260px;
}

.crmt-header-search {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  max-width: 340px;
  padding: 0 12px;
  border: 1px solid var(--crmt-border);
  border-radius: 8px;
  background: var(--crmt-bg-soft);
}

.crmt-header-search-icon {
  color: var(--crmt-text-muted);
  font-size: 14px;
  line-height: 1;
}

.crmt-header-search input {
  flex: 1 1 auto;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--crmt-text);
  font-size: 14px;
  min-height: 38px;
  padding: 0;
}

.crmt-header-search input::placeholder { color: var(--crmt-text-muted); }

.crmt-header-title {
  font-size: 26px;
}

.crmt-header-kicker {
  margin-bottom: 2px;
}

.crmt-header-chip,
.crmt-header-icon,
.crmt-btn,
.crmt-wrap .icon-btn,
.crmt-type-pill,
.crmt-option-card,
.crmt-logout {
  border-radius: 8px;
}

.crmt-header-chip,
.crmt-logout {
  min-height: 40px;
  padding: 0 14px;
}

.crmt-avatar {
  width: 38px;
  height: 38px;
  border-radius: 10px;
}

.crmt-topnav {
  border-radius: 0;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  box-shadow: none;
  padding: 12px 20px;
}

.crmt-page-area {
  gap: 16px;
  padding: 20px;
}

.crmt-content {
  border-radius: 12px;
  padding: 20px;
}

.crmt-alert-box,
.crmt-recent-list,
.crmt-results-table,
.crmt-card,
.crmt-user-form,
.crmt-perm-list,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-stat,
.crmt-type-card,
.crmt-report-tile,
.crmt-settings-grid > div,
.crmt-modal-card {
  border-radius: 12px;
}

.crmt-alert-box {
  margin-bottom: 16px;
  padding: 14px 16px;
}

.crmt-stat:before,
.crmt-type-card:before {
  display: none;
}

.crmt-stats-row {
  margin-bottom: 18px;
  gap: 14px;
}

.crmt-stat {
  padding: 18px;
}

.crmt-stat-value {
  font-size: clamp(28px, 4vw, 40px);
}

.crmt-results-table,
.crmt-recent-list {
  border: 1px solid var(--crmt-border);
}

.crmt-recent-row,
.crmt-trow {
  padding: 14px 16px;
}

.crmt-recent-row.header,
.crmt-trow.th {
  background: var(--crmt-bg-soft);
}

.crmt-field input,
.crmt-field select,
.crmt-field textarea,
.crmt-search-bar input,
.crmt-header-search {
  border-radius: 8px;
}

.crmt-field input,
.crmt-field select,
.crmt-field textarea,
.crmt-search-bar input {
  min-height: 46px;
}

.crmt-upload-area {
  border-radius: 12px;
}

.crmt-customizer {
  border-radius: 16px;
}

.crmt-customizer-head {
  margin-bottom: 14px;
}

@media (max-width: 1100px) {
  .crmt-shell,
  .crmt-shell[data-sidebar-size="sm"] {
    grid-template-columns: minmax(0, 1fr);
  }
  .crmt-sidebar {
    border-radius: 12px;
    border: 1px solid var(--crmt-border);
    left: 12px;
    top: 12px;
    bottom: 12px;
    width: min(260px, calc(100vw - 24px));
    min-height: auto;
  }
  .crmt-header,
  .crmt-topnav { border-radius: 12px; border: 1px solid var(--crmt-border); }
  .crmt-page-area { padding: 16px; }
}

@media (max-width: 760px) {
  .crmt-header-center {
    width: 100%;
    min-width: 0;
  }
  .crmt-header-search {
    max-width: none;
    width: 100%;
  }
}

.crmt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.crmt-header-left {
  min-width: 0;
}

.crmt-header-title {
  font-size: 14px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--crmt-text);
  white-space: nowrap;
}

.crmt-header-kicker,
.crmt-header-center,
.crmt-header-search {
  display: none !important;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab {
  width: 56px;
  min-height: 56px;
  border-radius: 12px;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  font-size: 0;
  line-height: 1;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-text,
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .badge {
  display: none !important;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar {
  width: 88px;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-brand {
  padding-inline: 0;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-section-title,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-footer,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-title,
.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-subtitle {
  display: none !important;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-logo {
  width: 44px;
  height: 44px;
  font-size: 20px;
}

@media (max-width: 760px) {
  .crmt-header-title {
    font-size: 13px;
    letter-spacing: .12em;
  }
}

.crmt-shell[data-layout="horizontal"] {
  grid-template-columns: minmax(0, 1fr) !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-sidebar {
  display: none !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-main-shell {
  min-width: 0;
}

.crmt-shell[data-layout="horizontal"] .crmt-topnav {
  display: block;
}

.crmt-shell[data-layout="horizontal"] .crmt-sidebar-size-group {
  opacity: .45;
}

.crmt-shell[data-layout="horizontal"] .crmt-sidebar-size-group .crmt-option-card {
  pointer-events: none;
}

.crmt-header {
  min-height: 84px;
}

.crmt-topnav {
  min-height: 72px;
  display: flex;
  align-items: center;
}

.crmt-header,
.crmt-topnav,
.crmt-content,
.crmt-recent-list,
.crmt-results-table,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-modal-card,
.crmt-settings-grid > div,
.crmt-stat,
.crmt-type-card,
.crmt-report-tile {
  border-radius: 12px;
}

.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  padding-top: 16px;
}

@media (max-width: 900px) {
  .crmt-header {
    min-height: 72px;
  }
  .crmt-topnav {
    min-height: 64px;
  }
}

:root {
  --crmt-shell-max: 1540px;
  --crmt-content-max: 1540px;
  --crmt-header-h: 72px;
  --crmt-topnav-h: 58px;
}

.crmt-wrap {
  padding: 16px;
  border-radius: 0;
}

.crmt-shell {
  width: 100%;
  max-width: var(--crmt-shell-max);
  margin: 0 auto;
}

.crmt-main-shell {
  min-width: 0;
}

.crmt-header {
  min-height: var(--crmt-header-h);
  padding: 12px 18px;
  gap: 16px;
}

.crmt-topnav {
  min-height: var(--crmt-topnav-h);
  padding: 8px 18px;
}

.crmt-header-left,
.crmt-header-actions,
.crmt-user-area {
  min-width: 0;
}

.crmt-header-title {
  font-size: 13px;
  letter-spacing: .18em;
}

.crmt-header-actions {
  margin-left: auto;
  flex-wrap: nowrap;
}

.crmt-nav-top {
  flex-wrap: wrap;
  overflow: hidden;
}

.crmt-nav-top .crmt-tab {
  flex: 0 0 auto;
}

.crmt-page-area {
  gap: 14px;
  padding: 18px;
}

.crmt-content,
.crmt-recent-list,
.crmt-results-table,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-settings-grid > div,
.crmt-modal-card,
.crmt-stat,
.crmt-type-card,
.crmt-report-tile {
  border-radius: 10px;
}

.crmt-shell[data-layout="horizontal"] {
  max-width: none;
}

.crmt-shell[data-layout="horizontal"] .crmt-main-shell,
.crmt-shell[data-layout="horizontal"] .crmt-header,
.crmt-shell[data-layout="horizontal"] .crmt-topnav,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  width: 100%;
  max-width: var(--crmt-content-max);
  margin-left: auto;
  margin-right: auto;
}

.crmt-shell[data-layout="horizontal"] .crmt-header {
  min-height: var(--crmt-header-h);
}

.crmt-shell[data-layout="horizontal"] .crmt-topnav {
  min-height: var(--crmt-topnav-h);
}

.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  padding-top: 14px;
}

.crmt-shell[data-layout="horizontal"] .crmt-header-actions {
  flex: 0 0 auto;
}

.crmt-shell[data-layout="horizontal"] .crmt-user-area {
  flex: 0 0 auto;
}

@media (min-width: 1680px) {
  .crmt-shell[data-layout="horizontal"] .crmt-main-shell,
  .crmt-shell[data-layout="horizontal"] .crmt-header,
  .crmt-shell[data-layout="horizontal"] .crmt-topnav,
  .crmt-shell[data-layout="horizontal"] .crmt-page-area {
    max-width: var(--crmt-content-max);
  }
}

@media (max-width: 1200px) {
  .crmt-shell,
  .crmt-shell[data-layout="horizontal"] .crmt-main-shell,
  .crmt-shell[data-layout="horizontal"] .crmt-header,
  .crmt-shell[data-layout="horizontal"] .crmt-topnav,
  .crmt-shell[data-layout="horizontal"] .crmt-page-area {
    max-width: none;
  }
}

@media (max-width: 900px) {
  .crmt-header,
  .crmt-shell[data-layout="horizontal"] .crmt-header {
    min-height: 64px;
    padding: 10px 14px;
  }

  .crmt-topnav,
  .crmt-shell[data-layout="horizontal"] .crmt-topnav {
    min-height: 54px;
    padding: 8px 14px;
  }

  .crmt-page-area {
    padding: 14px;
  }
}

:root {
  --crmt-header-fixed-h: 72px;
  --crmt-topnav-fixed-h: 58px;
}

.crmt-wrap {
  padding: 16px !important;
  border-radius: 0 !important;
}

.crmt-shell,
.crmt-shell[data-layout="horizontal"] {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

.crmt-main-shell {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  min-width: 0 !important;
}

.crmt-header,
.crmt-topnav {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  align-items: center !important;
  box-sizing: border-box !important;
  border-radius: 12px !important;
  box-shadow: var(--crmt-shadow-soft) !important;
  border: 1px solid var(--crmt-border) !important;
}

.crmt-header,
.crmt-shell[data-layout="horizontal"] .crmt-header {
  min-height: var(--crmt-header-fixed-h) !important;
  padding: 14px 22px !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-topnav {
  min-height: var(--crmt-topnav-fixed-h) !important;
  padding: 10px 22px !important;
  display: flex !important;
  align-items: center !important;
}

.crmt-shell[data-layout="vertical"] .crmt-topnav {
  display: none !important;
}

.crmt-header-left {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.crmt-header-actions {
  flex: 0 0 auto !important;
  margin-left: auto !important;
  flex-wrap: nowrap !important;
  justify-content: flex-end !important;
}

.crmt-header-title {
  font-size: 14px !important;
  line-height: 1 !important;
  letter-spacing: .18em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.crmt-nav-top {
  width: 100% !important;
  flex-wrap: wrap !important;
  overflow: hidden !important;
  gap: 8px !important;
  align-items: center !important;
}

.crmt-nav-top .crmt-tab {
  flex: 0 0 auto !important;
}

.crmt-page-area,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 16px !important;
}

.crmt-content,
.crmt-recent-list,
.crmt-results-table,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-settings-grid > div,
.crmt-modal-card,
.crmt-stat,
.crmt-type-card,
.crmt-report-tile {
  border-radius: 12px !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-sidebar-size-group,
.crmt-shell[data-layout="horizontal"] [data-ui-sidebar-size] {
  pointer-events: none !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary,
.crmt-shell[data-mode="light"] .crmt-btn-primary,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary {
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 10px 24px rgba(37, 99, 235, .18) !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn[disabled],
.crmt-shell[data-mode="light"] .crmt-btn:disabled,
.crmt-shell[data-mode="light"] .crmt-btn[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn[disabled],
.crmt-wrap[data-mode="light"] button:disabled,
.crmt-shell[data-mode="light"] button:disabled,
.crmt-auth-wrap[data-mode="light"] button:disabled {
  background: #dfe8f5 !important;
  color: #7c8eac !important;
  border-color: #d1dced !important;
  opacity: 1 !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}

.crmt-wrap[data-mode="light"] .crmt-header-chip,
.crmt-wrap[data-mode="light"] .crmt-logout,
.crmt-shell[data-mode="light"] .crmt-header-chip,
.crmt-shell[data-mode="light"] .crmt-logout {
  color: #30425f !important;
}

@media (max-width: 1200px) {
  .crmt-header,
  .crmt-shell[data-layout="horizontal"] .crmt-header {
    padding: 14px 18px !important;
  }

  .crmt-topnav,
  .crmt-shell[data-layout="horizontal"] .crmt-topnav {
    padding: 10px 18px !important;
  }
}

@media (max-width: 760px) {
  .crmt-header,
  .crmt-shell[data-layout="horizontal"] .crmt-header {
    min-height: 64px !important;
    padding: 12px 14px !important;
  }

  .crmt-topnav,
  .crmt-shell[data-layout="horizontal"] .crmt-topnav {
    min-height: 54px !important;
    padding: 8px 14px !important;
  }
}

.crmt-wrap[data-mode="light"] .crmt-actions-cell .icon-btn,
.crmt-shell[data-mode="light"] .crmt-actions-cell .icon-btn {
  background: #ffffff !important;
  color: #24344f !important;
  border-color: rgba(37, 99, 235, 0.18) !important;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04) !important;
}

.crmt-wrap[data-mode="light"] .crmt-actions-cell .icon-btn:hover,
.crmt-shell[data-mode="light"] .crmt-actions-cell .icon-btn:hover {
  background: #f3f7ff !important;
  color: #17305d !important;
  border-color: rgba(37, 99, 235, 0.32) !important;
}

.crmt-wrap[data-mode="light"] .crmt-actions-cell .icon-btn:focus-visible,
.crmt-shell[data-mode="light"] .crmt-actions-cell .icon-btn:focus-visible,
.crmt-wrap[data-mode="light"] .crmt-actions-cell .icon-btn:active,
.crmt-shell[data-mode="light"] .crmt-actions-cell .icon-btn:active {
  outline: none !important;
  background: #eaf1ff !important;
  color: #15284b !important;
  border-color: rgba(37, 99, 235, 0.42) !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn[disabled],
.crmt-shell[data-mode="light"] .crmt-btn:disabled,
.crmt-shell[data-mode="light"] .crmt-btn[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn[disabled],
.crmt-wrap[data-mode="light"] button:disabled,
.crmt-shell[data-mode="light"] button:disabled,
.crmt-auth-wrap[data-mode="light"] button:disabled {
  background: #d9e5f7 !important;
  color: #516a8f !important;
  border-color: #c6d5ee !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary,
.crmt-shell[data-mode="light"] .crmt-btn-primary,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary {
  background: linear-gradient(135deg, #2563eb, #4f46e5) !important;
  color: #ffffff !important;
  border-color: #1d4ed8 !important;
  text-shadow: none !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary:hover,
.crmt-shell[data-mode="light"] .crmt-btn-primary:hover,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary:hover {
  background: linear-gradient(135deg, #1d4ed8, #4338ca) !important;
  color: #ffffff !important;
  border-color: #1e40af !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary:focus-visible,
.crmt-shell[data-mode="light"] .crmt-btn-primary:focus-visible,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary:focus-visible,
.crmt-wrap[data-mode="light"] .crmt-btn-primary:active,
.crmt-shell[data-mode="light"] .crmt-btn-primary:active,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary:active {
  background: linear-gradient(135deg, #1e40af, #3730a3) !important;
  color: #ffffff !important;
  border-color: #1e3a8a !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-primary[disabled],
.crmt-shell[data-mode="light"] .crmt-btn-primary:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-primary[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary[disabled] {
  background: #d8e3f6 !important;
  color: #4d6285 !important;
  border-color: #c3d2ea !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-secondary:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-secondary[disabled],
.crmt-wrap[data-mode="light"] .crmt-btn-ghost:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-ghost[disabled],
.crmt-shell[data-mode="light"] .crmt-btn-secondary:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-secondary[disabled],
.crmt-shell[data-mode="light"] .crmt-btn-ghost:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-ghost[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn-secondary:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-secondary[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn-ghost:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-ghost[disabled] {
  background: #eef3fb !important;
  color: #5f7496 !important;
  border-color: #d3deef !important;
  box-shadow: none !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary,
.crmt-shell[data-mode="light"] .crmt-btn-primary,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary {
  background: linear-gradient(135deg, #2563eb, #5b5cf0) !important;
  color: #ffffff !important;
  border-color: #1d4ed8 !important;
  box-shadow: 0 10px 20px rgba(37, 99, 235, 0.18) !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-primary:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-primary[disabled],
.crmt-shell[data-mode="light"] .crmt-btn-primary:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-primary[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary[disabled],
.crmt-wrap[data-mode="light"] .crmt-btn-primary.is-disabled,
.crmt-shell[data-mode="light"] .crmt-btn-primary.is-disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-primary.is-disabled {
  background: #bcd2ff !important;
  color: #18345d !important;
  border-color: #9ab8f1 !important;
  box-shadow: none !important;
  opacity: 1 !important;
  text-shadow: none !important;
  filter: none !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-secondary,
.crmt-wrap[data-mode="light"] .crmt-btn-ghost,
.crmt-shell[data-mode="light"] .crmt-btn-secondary,
.crmt-shell[data-mode="light"] .crmt-btn-ghost,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-secondary,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-ghost {
  background: #ffffff !important;
  color: #24344f !important;
  border-color: #cfdcf2 !important;
}

.crmt-wrap[data-mode="light"] .crmt-btn-secondary:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-secondary[disabled],
.crmt-wrap[data-mode="light"] .crmt-btn-ghost:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-ghost[disabled],
.crmt-shell[data-mode="light"] .crmt-btn-secondary:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-secondary[disabled],
.crmt-shell[data-mode="light"] .crmt-btn-ghost:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-ghost[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn-secondary:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-secondary[disabled],
.crmt-auth-wrap[data-mode="light"] .crmt-btn-ghost:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-ghost[disabled],
.crmt-wrap[data-mode="light"] button:disabled,
.crmt-shell[data-mode="light"] button:disabled,
.crmt-auth-wrap[data-mode="light"] button:disabled {
  background: #e6edf9 !important;
  color: #334765 !important;
  border-color: #c7d4e9 !important;
  opacity: 1 !important;
  box-shadow: none !important;
  filter: none !important;
}

@media (max-width: 980px) {
  .crmt-auth-side {
    min-height: 300px;
    padding: 32px 24px;
  }
  .crmt-auth-mark {
    width: min(260px, 62vw);
  }
  .crmt-auth-mark-fallback {
    font-size: 96px;
  }
  .crmt-auth-brand-line {
    white-space: normal;
    letter-spacing: .12em;
  }
}

.crmt-wrap[data-mode="light"] .crmt-search-bar .crmt-btn:disabled,
.crmt-wrap[data-mode="light"] .crmt-btn-row .crmt-btn:disabled,
.crmt-shell[data-mode="light"] .crmt-search-bar .crmt-btn:disabled,
.crmt-shell[data-mode="light"] .crmt-btn-row .crmt-btn:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn-row .crmt-btn:disabled,
.crmt-auth-wrap[data-mode="light"] .crmt-btn:disabled {
  color: #223a63 !important;
  background: #dbe7ff !important;
  border-color: #b8caef !important;
  opacity: 1 !important;
  -webkit-text-fill-color: #223a63 !important;
}

.crmt-sidebar-brand {
  justify-content: center;
  padding: 6px 0 2px;
}

.crmt-sidebar-brand-image {
  display: block;
  width: min(180px, 100%);
  max-height: 92px;
  object-fit: contain;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-brand-image {
  width: 44px;
  max-height: 44px;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-sidebar-brand {
  justify-content: center;
}

.crmt-topnav {
  display: flex;
  align-items: center;
  gap: 18px;
}

.crmt-topnav-brand {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 86px;
  padding-right: 6px;
}

.crmt-topnav-brand-image {
  display: block;
  height: 40px;
  width: auto;
  object-fit: contain;
}

.crmt-topnav-brand-fallback {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--crmt-text);
}

.crmt-shell[data-layout="horizontal"] .crmt-topnav {
  display: flex !important;
  align-items: center !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-nav-top {
  flex: 1 1 auto !important;
}

@media (max-width: 980px) {
  .crmt-topnav-brand {
    min-width: 64px;
  }

  .crmt-topnav-brand-image {
    height: 32px;
  }
}

.crmt-shell[data-layout="horizontal"] .crmt-nav-top {
  min-width: 0 !important;
  flex: 1 1 auto !important;
}

.crmt-header-brand {
  display: none;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.crmt-header-brand-image {
  display: block;
  width: auto;
  max-width: 160px;
  max-height: 42px;
  object-fit: contain;
}

.crmt-header-brand-fallback {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #4a7cff, #7c5cff);
  color: #fff;
  font-weight: 800;
  letter-spacing: .08em;
}

.crmt-shell[data-layout="vertical"] .crmt-header-brand {
  display: none !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-header-left {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-header-brand {
  display: inline-flex !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-mobile-nav-toggle {
  display: none !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-header-title {
  display: block !important;
  min-width: 0 !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-topnav {
  gap: 0 !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-topnav-brand,
.crmt-shell[data-layout="horizontal"] .crmt-topnav-brand-image {
  display: none !important;
}

@media (max-width: 980px) {
  .crmt-shell[data-layout="horizontal"] .crmt-header-brand-image {
    max-width: 120px;
    max-height: 34px;
  }
}

.crmt-shell[data-layout="horizontal"] .crmt-main-shell,
.crmt-shell[data-layout="horizontal"] .crmt-header,
.crmt-shell[data-layout="horizontal"] .crmt-topnav,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  max-width: var(--crmt-shell-max) !important;
}

.crmt-type-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin-bottom: 20px !important;
}

.crmt-type-card {
  min-height: 118px !important;
  padding: 16px !important;
  border-radius: 18px !important;
}

.crmt-type-icon {
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
  margin-bottom: 10px !important;
  font-size: 18px !important;
}

.crmt-type-label {
  font-size: 14px !important;
  line-height: 1.2 !important;
}

.crmt-type-sub {
  font-size: 11px !important;
  line-height: 1.3 !important;
}

@media (max-width: 1280px) {
  .crmt-type-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 860px) {
  .crmt-type-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  .crmt-type-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ==============================
   Select pesquisavel
   Estiliza campo com menu e busca embutida.
   ============================== */

.crmt-search-select { position: relative; display: flex; align-items: center; }
.crmt-search-select .crmt-search-select-input { padding-right: 44px; }
.crmt-search-select-toggle {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  border: 0 !important; background: transparent !important; box-shadow: none !important; color: #6f7f95 !important; font-size: 18px; cursor: pointer;
  width: 28px; height: 28px; line-height: 1; padding: 0; border-radius: 8px; appearance: none; -webkit-appearance: none;
}
.crmt-search-select-menu {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 30;
  background: #fff; border: 1px solid #d7dfeb; border-radius: 12px; box-shadow: 0 10px 28px rgba(21, 40, 79, 0.12);
  max-height: 260px; overflow: auto; padding: 6px;
}
.crmt-search-select-option {
  width: 100%; text-align: left; border: 0; background: transparent; padding: 10px 12px; border-radius: 10px; cursor: pointer;
}
.crmt-search-select-option:hover, .crmt-search-select-option:focus { background: #eef4ff; outline: none; }
.crmt-search-select-empty { padding: 10px 12px; color: #6f7f95; }

.crmt-report-filters-shell [data-report-scope].crmt-hidden{display:none!important;}

.crmt-sidebar,
.crmt-header,
.crmt-topnav,
.crmt-content,
.crmt-recent-list,
.crmt-results-table,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-settings-grid > div,
.crmt-modal-card {
  border-radius: 0 !important;
}

.crmt-main-shell {
  gap: 0 !important;
}

.crmt-page-area,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  padding-top: 0 !important;
  gap: 0 !important;
}

.crmt-header,
.crmt-shell[data-layout="horizontal"] .crmt-header {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
}

.crmt-topnav,
.crmt-shell[data-layout="horizontal"] .crmt-topnav {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
  box-shadow: none !important;
}

.crmt-content,
.crmt-recent-list,
.crmt-results-table,
.crmt-user-form,
.crmt-report-filters-shell,
.crmt-report-summary,
.crmt-settings-grid > div {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
  border-top: 0 !important;
  box-shadow: none !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-page-area > :first-child,
.crmt-main-shell > .crmt-content:first-of-type {
  margin-top: 0 !important;
}

/* ==============================
   Aba Clientes e auto preenchimento
   Organiza lista, formulario e seletor de cliente nos documentos.
   ============================== */

.crmt-clientes-layout {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 24px;
  align-items: start;
}

.crmt-clientes-list-panel { min-width: 0; }
.crmt-clientes-form-panel {
  border-radius: 22px;
  overflow: hidden;
  padding: 24px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--crmt-border);
}

.crmt-clientes-list-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.crmt-clientes-search-bar {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}
.crmt-clientes-search-bar input {
  flex: 1;
  min-width: 0;
}

.crmt-clientes-table.crmt-recent-list { border-radius: 16px; }

.crmt-client-row { cursor: default; transition: background .15s; }
.crmt-client-row:hover { background: rgba(255,255,255,.03); }
.crmt-shell[data-mode="light"] .crmt-client-row:hover { background: rgba(37,99,235,.03); }

.crmt-client-autofill-wrap {
  grid-column: 1 / -1;
  order: -1 !important;
  padding: 14px 16px;
  border-radius: 14px;
  background: rgba(99,102,241,.06);
  border: 1px solid rgba(99,102,241,.18);
  margin-bottom: 4px;
}
.crmt-shell[data-mode="light"] .crmt-client-autofill-wrap {
  background: rgba(37,99,235,.05);
  border-color: rgba(37,99,235,.18);
}

.crmt-client-autofill-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.crmt-client-autofill-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .10em;
  color: var(--crmt-text-muted);
  white-space: nowrap;
}

.crmt-client-autofill-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 0;
  width: 100%;
  border: 1px solid var(--crmt-border);
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}

.crmt-client-search-box,
.crmt-client-results-box {
  min-width: 0;
}

.crmt-client-search-box {
  border-right: 1px solid var(--crmt-border);
}

.crmt-client-search-box .crmt-search-select-input {
  width: 100%;
  border: 0;
  border-radius: 0;
  min-height: 44px;
  box-shadow: none;
}

.crmt-client-results {
  width: 100%;
  min-height: 44px;
  height: 44px;
  border: 0;
  border-radius: 0;
  background: #fff;
  padding: 8px 12px;
  font: inherit;
  color: var(--crmt-text);
  outline: none;
  box-shadow: none;
  appearance: auto;
}

.crmt-client-results:focus {
  outline: none;
}

.crmt-client-results option {
  padding: 8px 6px;
}
.crmt-shell[data-mode="dark"] .crmt-client-results,
.crmt-wrap[data-mode="dark"] .crmt-client-results {
  color: #111827 !important;
}

.crmt-shell[data-mode="dark"] .crmt-client-results option,
.crmt-wrap[data-mode="dark"] .crmt-client-results option {
  color: #111827;
}

.crmt-client-autofill-hint {
  font-size: 12px;
  color: var(--crmt-text-muted);
  margin-top: 7px;
}

@media (max-width: 900px) {
  .crmt-clientes-layout {
    grid-template-columns: 1fr;
  }
  .crmt-client-autofill-bar {
    flex-direction: column;
    align-items: stretch;
  }
  .crmt-client-autofill-split {
    grid-template-columns: 1fr;
  }
  .crmt-client-search-box {
    border-right: 0;
    border-bottom: 1px solid var(--crmt-border);
  }
}

/* ==============================
   Ajustes de inputs de data
   Melhora a leitura dos icones de calendario no tema escuro.
   ============================== */

body.crmt-has-app.crmt-theme-dark input[type="date"]::-webkit-calendar-picker-indicator,
.crmt-wrap[data-mode="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
.crmt-shell[data-mode="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
.crmt-auth-wrap[data-mode="dark"] input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(100%);
  opacity: 1;
}

/* ==============================
   Busca com painel lateral
   Estrutura resultados, preview, acoes e variacoes do modo busca.
   ============================== */

.crmt-search-shell { display: grid; gap: 14px; }
.crmt-search-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(600px, .95fr);
  gap: 12px;
  align-items: start;
}
.crmt-search-results-panel,
.crmt-search-panel-card {
  border: 1px solid var(--crmt-border);
  border-radius: 8px;
  background: rgba(8, 17, 45, .68);
  overflow: hidden;
}
.crmt-search-results-panel { min-height: 840px; display: grid; grid-template-rows: auto auto; }
.crmt-search-results-table { border-radius: 8px; overflow: hidden; }
.crmt-search-results-table .crmt-trow {
  grid-template-columns: minmax(230px, 2fr) minmax(168px, 184px) minmax(120px, .9fr) 126px 164px;
  gap: 14px;
  padding: 15px 16px;
}
.crmt-search-results-table .crmt-trow.th {
  background: rgba(2, 10, 33, .9);
  min-height: 44px;
}
.crmt-search-results-table #crmt-search-results { min-height: 738px; }
.crmt-search-row {
  cursor: pointer;
  transition: background .16s ease;
}
.crmt-search-row:hover { background: rgba(33, 56, 106, .24); }
.crmt-search-row.is-active { background: rgba(47, 73, 130, .48); }
.crmt-search-row .crmt-doc-title { font-size: 18px; line-height: 1.15; }
.crmt-search-row .crmt-doc-sub,
.crmt-search-company-cell { font-size: 13px; color: var(--crmt-text-soft); }
.crmt-search-results-footer {
  border-top: 1px solid var(--crmt-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
}
.crmt-search-pagination { display: none; }
.crmt-search-page-btn {
  width: 30px;
  height: 22px;
  border-radius: 6px;
  border: 1px solid var(--crmt-border);
  background: rgba(255,255,255,.02);
  color: var(--crmt-text-soft);
  cursor: default;
}
.crmt-search-side-panel {
  min-height: 840px;
  display: grid;
  gap: 12px;
  align-content: start;
  background: transparent;
  border: 0;
  overflow: visible;
}
.crmt-search-panel-card { position: relative; }
.crmt-search-panel-head-card { padding: 22px 20px 16px; }
.crmt-search-panel-title {
  font-size: 24px;
  line-height: 1.18;
  font-weight: 800;
  padding-right: 46px;
  letter-spacing: -.01em;
}
.crmt-search-panel-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 28px;
  height: 28px;
  border: 0;
  background: transparent;
  color: var(--crmt-text-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
}
.crmt-search-panel-close svg,
.crmt-search-section-chevron svg,
.crmt-search-row-icon svg,
.crmt-search-section-icon svg,
.crmt-search-tool-btn svg,
.crmt-search-action-btn svg,
.crmt-search-icon-mini-btn svg,
.crmt-search-panel-empty-icon svg { width: 16px; height: 16px; display: block; }
.crmt-search-panel-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 26px;
  padding-top: 14px;
  margin-top: 14px;
  border-top: 1px solid var(--crmt-border);
}
.crmt-search-summary-item {
  display: flex;
  gap: 8px;
  align-items: baseline;
  flex-wrap: wrap;
  min-width: 0;
}
.crmt-search-summary-label { font-size: 14px; color: var(--crmt-text-soft); min-width: 72px; }
.crmt-search-summary-value { font-size: 14px; color: var(--crmt-text); font-weight: 600; min-width: 0; }
.crmt-search-panel-section-head {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 15px 16px;
  border: 0;
  border-bottom: 1px solid var(--crmt-border);
  background: linear-gradient(90deg, rgba(7, 14, 40, .96), rgba(4, 12, 34, .9));
  color: var(--crmt-text);
  cursor: pointer;
}
.crmt-search-panel-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 700;
}
.crmt-search-section-icon,
.crmt-search-row-icon,
.crmt-search-panel-empty-icon {
  width: 18px;
  height: 18px;
  border: 1px solid rgba(112, 147, 232, .42);
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #84aaff;
  flex-shrink: 0;
}
.crmt-search-section-chevron {
  color: var(--crmt-text-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .16s ease;
}
.crmt-search-panel-section.is-collapsed .crmt-search-section-chevron { transform: rotate(180deg); }
.crmt-search-panel-section.is-collapsed .crmt-search-panel-section-body { display: none; }
.crmt-search-panel-section-body { padding: 0; }
.crmt-search-related-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--crmt-border);
  transition: background .16s ease;
}
.crmt-search-related-row:last-child { border-bottom: 0; }
.crmt-search-related-row:hover,
.crmt-search-related-row.is-active { background: rgba(32, 52, 98, .28); }
.crmt-search-related-main {
  display: grid;
  grid-template-columns: auto minmax(120px, 1.25fr) auto minmax(90px, .86fr) minmax(96px, .86fr);
  align-items: center;
  gap: 12px;
  min-width: 0;
  flex: 1;
}
.crmt-search-related-title,
.crmt-search-related-company,
.crmt-search-related-user {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.crmt-search-related-title { font-size: 15px; }
.crmt-search-related-company,
.crmt-search-related-user { font-size: 13px; color: var(--crmt-text); }
.crmt-search-related-actions { display: flex; gap: 8px; flex-shrink: 0; }
.crmt-search-preview-toolbar-right { display: none; }
.crmt-search-mini-btn,
.crmt-search-icon-mini-btn,
.crmt-search-tool-btn,
.crmt-search-action-btn {
  border: 1px solid var(--crmt-border);
  background: rgba(255,255,255,.03);
  color: var(--crmt-text);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
}
.crmt-search-mini-btn {
  min-width: 48px;
  height: 38px;
  padding: 0 14px;
  border-radius: 8px;
  font-size: 14px;
}
.crmt-search-icon-mini-btn {
  width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 8px;
}
.crmt-search-preview-empty,
.crmt-search-related-empty,
.crmt-search-panel-loading {
  padding: 18px 16px;
  color: var(--crmt-text-soft);
  font-size: 14px;
}
.crmt-search-preview-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 16px 12px;
  border-bottom: 1px solid rgba(255,255,255,.03);
}
.crmt-search-preview-title {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  font-size: 15px;
  font-weight: 700;
}
.crmt-search-preview-title span:last-child {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.crmt-search-preview-badge {
  min-width: 48px;
  height: 30px;
  padding: 0 10px;
  border: 1px solid var(--crmt-border);
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  color: var(--crmt-text-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.crmt-search-preview-box { padding: 0 16px 14px; }
.crmt-search-preview-toolbar {
  height: 44px;
  border: 1px solid var(--crmt-border);
  border-bottom: 0;
  background: linear-gradient(180deg, rgba(19,28,52,.96), rgba(14,23,46,.92));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 10px;
}
.crmt-search-preview-toolbar-left,
.crmt-search-preview-toolbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.crmt-search-tool-btn {
  width: 34px;
  height: 30px;
  padding: 0;
  border-radius: 6px;
}
.crmt-search-preview-zoom-wrap {
  min-width: 80px;
  height: 30px;
  border: 1px solid var(--crmt-border);
  border-radius: 6px;
  background: rgba(255,255,255,.03);
  overflow: hidden;
}
.crmt-search-preview-zoom-select {
  width: 100%;
  height: 100%;
  border: 0;
  background: transparent;
  color: var(--crmt-text);
  padding: 0 10px;
  outline: none;
}
.crmt-search-preview-viewport {
  width: 100%;
  min-height: 430px;
  border: 1px solid var(--crmt-border);
  background: rgba(4, 10, 31, .98);
}
.crmt-search-preview-frame {
  width: 100%;
  height: 430px;
  display: block;
  border: 0;
  background: #0b1229;
}
.crmt-search-preview-image-wrap {
  width: 100%;
  min-height: 430px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  overflow: auto;
  padding: 14px;
}
.crmt-search-preview-image {
  display: block;
  max-width: none;
  transform-origin: top center;
  transition: transform .16s ease;
}
.crmt-search-preview-actions {
  display: flex;
  gap: 12px;
  padding: 0 16px 18px;
  flex-wrap: wrap;
}
.crmt-search-action-btn {
  min-width: 120px;
  height: 38px;
  padding: 0 14px;
  border-radius: 8px;
}
.crmt-search-panel-empty {
  min-height: 840px;
  display: grid;
  place-items: center;
  text-align: center;
  gap: 10px;
  border: 1px solid var(--crmt-border);
  border-radius: 8px;
  padding: 24px;
  background: rgba(8, 17, 45, .48);
}
.crmt-search-panel-empty-title { font-size: 18px; font-weight: 700; }
.crmt-search-panel-empty-text { font-size: 14px; color: var(--crmt-text-soft); max-width: 320px; }
.crmt-search-results-panel .crmt-delete-doc { display: inline-flex; }
.crmt-search-results-panel .crmt-actions-cell { gap: 8px; }
.crmt-search-results-panel .crmt-actions-cell .icon-btn {
  min-width: 46px;
  padding: 9px 14px;
  border-radius: 8px;
}
.crmt-search-results-panel .crmt-row-file-btn { min-width: 52px; }

@media (max-width: 1360px) {
  .crmt-search-layout { grid-template-columns: minmax(0, 1fr); }
  .crmt-search-results-panel,
  .crmt-search-side-panel,
  .crmt-search-panel-empty { min-height: auto; }
}

@media (max-width: 1024px) {
  .crmt-search-results-table .crmt-trow,
  .crmt-search-results-table .crmt-trow.th { grid-template-columns: 1fr; }
  .crmt-search-panel-summary,
  .crmt-search-related-main { grid-template-columns: 1fr; }
  .crmt-search-related-row { align-items: flex-start; flex-direction: column; }
  .crmt-search-related-actions { width: 100%; }
  .crmt-search-mini-btn,
  .crmt-search-icon-mini-btn,
  .crmt-search-action-btn { flex: 1; width: auto; }
  .crmt-search-preview-toolbar { flex-wrap: wrap; height: auto; padding: 8px 10px; }
}

.crmt-wrap[data-mode="light"] .crmt-search-shell,
.crmt-shell[data-mode="light"] .crmt-search-shell {
  --crmt-search-light-panel: #ffffff;
  --crmt-search-light-panel-alt: #f7faff;
  --crmt-search-light-panel-soft: #eef4fd;
  --crmt-search-light-border: rgba(148, 163, 184, 0.24);
  --crmt-search-light-border-strong: rgba(59, 130, 246, 0.18);
  --crmt-search-light-shadow: 0 18px 34px rgba(15, 23, 42, 0.08);
}

.crmt-wrap[data-mode="light"] .crmt-search-bar input,
.crmt-wrap[data-mode="light"] .crmt-filters-row select,
.crmt-shell[data-mode="light"] .crmt-search-bar input,
.crmt-shell[data-mode="light"] .crmt-filters-row select {
  background: #fff;
  border-color: rgba(148, 163, 184, 0.32);
  box-shadow: 0 1px 0 rgba(255,255,255,.9), 0 8px 20px rgba(15, 23, 42, 0.04);
}

.crmt-wrap[data-mode="light"] .crmt-search-results-panel,
.crmt-wrap[data-mode="light"] .crmt-search-panel-card,
.crmt-wrap[data-mode="light"] .crmt-search-panel-empty,
.crmt-shell[data-mode="light"] .crmt-search-results-panel,
.crmt-shell[data-mode="light"] .crmt-search-panel-card,
.crmt-shell[data-mode="light"] .crmt-search-panel-empty {
  background: linear-gradient(180deg, var(--crmt-search-light-panel) 0%, #fbfdff 100%);
  border-color: var(--crmt-search-light-border);
  box-shadow: var(--crmt-search-light-shadow);
}

.crmt-wrap[data-mode="light"] .crmt-search-results-panel,
.crmt-wrap[data-mode="light"] .crmt-search-panel-card,
.crmt-wrap[data-mode="light"] .crmt-search-panel-empty,
.crmt-wrap[data-mode="light"] .crmt-search-results-table,
.crmt-shell[data-mode="light"] .crmt-search-results-panel,
.crmt-shell[data-mode="light"] .crmt-search-panel-card,
.crmt-shell[data-mode="light"] .crmt-search-panel-empty,
.crmt-shell[data-mode="light"] .crmt-search-results-table {
  border-radius: 10px;
}

.crmt-wrap[data-mode="light"] .crmt-search-results-table .crmt-trow.th,
.crmt-shell[data-mode="light"] .crmt-search-results-table .crmt-trow.th {
  background: linear-gradient(180deg, #f9fbff 0%, #edf3fc 100%);
  border-bottom: 1px solid rgba(148, 163, 184, 0.24);
}

.crmt-wrap[data-mode="light"] .crmt-search-results-table #crmt-search-results,
.crmt-shell[data-mode="light"] .crmt-search-results-table #crmt-search-results {
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.crmt-wrap[data-mode="light"] .crmt-search-row,
.crmt-shell[data-mode="light"] .crmt-search-row {
  border-bottom-color: rgba(148, 163, 184, 0.18);
}

.crmt-wrap[data-mode="light"] .crmt-search-row:hover,
.crmt-shell[data-mode="light"] .crmt-search-row:hover {
  background: #f6f9ff;
}

.crmt-wrap[data-mode="light"] .crmt-search-row.is-active,
.crmt-shell[data-mode="light"] .crmt-search-row.is-active {
  background: linear-gradient(180deg, #ecf3ff 0%, #e6efff 100%);
}

.crmt-wrap[data-mode="light"] .crmt-search-row .crmt-doc-title,
.crmt-shell[data-mode="light"] .crmt-search-row .crmt-doc-title {
  color: #162643;
}

.crmt-wrap[data-mode="light"] .crmt-search-row .crmt-doc-sub,
.crmt-wrap[data-mode="light"] .crmt-search-company-cell,
.crmt-shell[data-mode="light"] .crmt-search-row .crmt-doc-sub,
.crmt-shell[data-mode="light"] .crmt-search-company-cell {
  color: #5a6c88;
}

.crmt-wrap[data-mode="light"] .crmt-search-results-footer,
.crmt-shell[data-mode="light"] .crmt-search-results-footer {
  background: linear-gradient(180deg, #fbfdff 0%, #f5f9ff 100%);
  border-top-color: rgba(148, 163, 184, 0.24);
}

.crmt-wrap[data-mode="light"] .crmt-search-page-btn,
.crmt-shell[data-mode="light"] .crmt-search-page-btn {
  background: #fff;
  border-color: rgba(148, 163, 184, 0.28);
  color: #5a6c88;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-head-card,
.crmt-shell[data-mode="light"] .crmt-search-panel-head-card {
  padding: 22px 20px 18px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-title,
.crmt-shell[data-mode="light"] .crmt-search-panel-title {
  color: #122441;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-close,
.crmt-shell[data-mode="light"] .crmt-search-panel-close {
  color: #6a7c98;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-summary,
.crmt-shell[data-mode="light"] .crmt-search-panel-summary {
  border-top-color: rgba(148, 163, 184, 0.22);
}

.crmt-wrap[data-mode="light"] .crmt-search-summary-label,
.crmt-shell[data-mode="light"] .crmt-search-summary-label {
  color: #6a7c98;
}

.crmt-wrap[data-mode="light"] .crmt-search-summary-value,
.crmt-shell[data-mode="light"] .crmt-search-summary-value {
  color: #1c3157;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-section-head,
.crmt-shell[data-mode="light"] .crmt-search-panel-section-head {
  background: linear-gradient(90deg, #f9fbff 0%, #eef4fd 100%);
  border-bottom-color: rgba(148, 163, 184, 0.22);
  color: #183050;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-section-title,
.crmt-shell[data-mode="light"] .crmt-search-panel-section-title {
  color: #183050;
}

.crmt-wrap[data-mode="light"] .crmt-search-section-icon,
.crmt-wrap[data-mode="light"] .crmt-search-row-icon,
.crmt-wrap[data-mode="light"] .crmt-search-panel-empty-icon,
.crmt-shell[data-mode="light"] .crmt-search-section-icon,
.crmt-shell[data-mode="light"] .crmt-search-row-icon,
.crmt-shell[data-mode="light"] .crmt-search-panel-empty-icon {
  background: #fff;
  border-color: rgba(59, 130, 246, 0.22);
  color: #2563eb;
}

.crmt-wrap[data-mode="light"] .crmt-search-section-chevron,
.crmt-shell[data-mode="light"] .crmt-search-section-chevron {
  color: #6a7c98;
}

.crmt-wrap[data-mode="light"] .crmt-search-related-row,
.crmt-shell[data-mode="light"] .crmt-search-related-row {
  background: rgba(255,255,255,.72);
  border-bottom-color: rgba(148, 163, 184, 0.18);
}

.crmt-wrap[data-mode="light"] .crmt-search-related-row:hover,
.crmt-wrap[data-mode="light"] .crmt-search-related-row.is-active,
.crmt-shell[data-mode="light"] .crmt-search-related-row:hover,
.crmt-shell[data-mode="light"] .crmt-search-related-row.is-active {
  background: #f4f8ff;
}

.crmt-wrap[data-mode="light"] .crmt-search-related-title,
.crmt-shell[data-mode="light"] .crmt-search-related-title {
  color: #183050;
}

.crmt-wrap[data-mode="light"] .crmt-search-related-company,
.crmt-wrap[data-mode="light"] .crmt-search-related-user,
.crmt-shell[data-mode="light"] .crmt-search-related-company,
.crmt-shell[data-mode="light"] .crmt-search-related-user {
  color: #50647f;
}

.crmt-wrap[data-mode="light"] .crmt-search-mini-btn,
.crmt-wrap[data-mode="light"] .crmt-search-icon-mini-btn,
.crmt-wrap[data-mode="light"] .crmt-search-tool-btn,
.crmt-wrap[data-mode="light"] .crmt-search-action-btn,
.crmt-shell[data-mode="light"] .crmt-search-mini-btn,
.crmt-shell[data-mode="light"] .crmt-search-icon-mini-btn,
.crmt-shell[data-mode="light"] .crmt-search-tool-btn,
.crmt-shell[data-mode="light"] .crmt-search-action-btn {
  background: #fff;
  border-color: rgba(148, 163, 184, 0.26);
  color: #1b3158;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.05);
}

.crmt-wrap[data-mode="light"] .crmt-search-mini-btn:hover,
.crmt-wrap[data-mode="light"] .crmt-search-icon-mini-btn:hover,
.crmt-wrap[data-mode="light"] .crmt-search-tool-btn:hover,
.crmt-wrap[data-mode="light"] .crmt-search-action-btn:hover,
.crmt-shell[data-mode="light"] .crmt-search-mini-btn:hover,
.crmt-shell[data-mode="light"] .crmt-search-icon-mini-btn:hover,
.crmt-shell[data-mode="light"] .crmt-search-tool-btn:hover,
.crmt-shell[data-mode="light"] .crmt-search-action-btn:hover {
  background: #eff5ff;
  border-color: rgba(59, 130, 246, 0.22);
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-title-row,
.crmt-shell[data-mode="light"] .crmt-search-preview-title-row {
  border-bottom-color: rgba(148, 163, 184, 0.18);
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-title,
.crmt-shell[data-mode="light"] .crmt-search-preview-title {
  color: #183050;
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-badge,
.crmt-shell[data-mode="light"] .crmt-search-preview-badge {
  background: #f3f7ff;
  border-color: rgba(148, 163, 184, 0.22);
  color: #5a6c88;
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-toolbar,
.crmt-shell[data-mode="light"] .crmt-search-preview-toolbar {
  background: linear-gradient(180deg, #fbfdff 0%, #eff5ff 100%);
  border-color: rgba(148, 163, 184, 0.22);
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-zoom-wrap,
.crmt-shell[data-mode="light"] .crmt-search-preview-zoom-wrap {
  background: #fff;
  border-color: rgba(148, 163, 184, 0.22);
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-zoom-select,
.crmt-shell[data-mode="light"] .crmt-search-preview-zoom-select {
  color: #1b3158;
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-viewport,
.crmt-shell[data-mode="light"] .crmt-search-preview-viewport {
  background: #edf2f8;
  border-color: rgba(148, 163, 184, 0.22);
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-frame,
.crmt-shell[data-mode="light"] .crmt-search-preview-frame {
  background: #ffffff;
}

.crmt-wrap[data-mode="light"] .crmt-search-preview-image-wrap,
.crmt-shell[data-mode="light"] .crmt-search-preview-image-wrap {
  background: #edf2f8;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-empty-title,
.crmt-shell[data-mode="light"] .crmt-search-panel-empty-title {
  color: #183050;
}

.crmt-wrap[data-mode="light"] .crmt-search-panel-empty-text,
.crmt-wrap[data-mode="light"] .crmt-search-preview-empty,
.crmt-wrap[data-mode="light"] .crmt-search-related-empty,
.crmt-wrap[data-mode="light"] .crmt-search-panel-loading,
.crmt-shell[data-mode="light"] .crmt-search-panel-empty-text,
.crmt-shell[data-mode="light"] .crmt-search-preview-empty,
.crmt-shell[data-mode="light"] .crmt-search-related-empty,
.crmt-shell[data-mode="light"] .crmt-search-panel-loading {
  color: #5a6c88;
}

.crmt-wrap[data-mode="light"] .crmt-search-results-panel .crmt-actions-cell .icon-btn,
.crmt-shell[data-mode="light"] .crmt-search-results-panel .crmt-actions-cell .icon-btn {
  background: #fff;
  color: #1c3157;
  border-color: rgba(148, 163, 184, 0.26);
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.05);
}

.crmt-wrap[data-mode="light"] .crmt-search-results-panel .crmt-actions-cell .icon-btn:hover,
.crmt-shell[data-mode="light"] .crmt-search-results-panel .crmt-actions-cell .icon-btn:hover {
  background: #eff5ff;
  border-color: rgba(59, 130, 246, 0.22);
}

.crmt-shell[data-layout="horizontal"] .crmt-main-shell,
.crmt-shell[data-layout="horizontal"] .crmt-header,
.crmt-shell[data-layout="horizontal"] .crmt-topnav,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  max-width: none !important;
  width: 100% !important;
}

.crmt-shell[data-layout="horizontal"] .crmt-header,
.crmt-shell[data-layout="horizontal"] .crmt-topnav,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.crmt-doc-form-grid{column-gap:16px;row-gap:16px;}
.crmt-doc-form-grid .crmt-field[data-span-pi="full"],.crmt-doc-form-grid .crmt-field[data-span-contrato_empresa="full"],.crmt-doc-form-grid .crmt-field[data-span-contrato_patrocinador="full"],.crmt-doc-form-grid .crmt-field[data-span-contrato_avulso="full"],.crmt-doc-form-grid .crmt-field[data-span-notas_fiscais="full"],.crmt-doc-form-grid .crmt-doc-field[data-span-pi="full"],.crmt-doc-form-grid .crmt-doc-field[data-span-contrato_empresa="full"],.crmt-doc-form-grid .crmt-doc-field[data-span-contrato_patrocinador="full"],.crmt-doc-form-grid .crmt-doc-field[data-span-contrato_avulso="full"],.crmt-doc-form-grid .crmt-doc-field[data-span-notas_fiscais="full"]{grid-column:1 / -1;}
.crmt-doc-form-grid textarea{min-height:128px;}

/* ==============================
   Painel de detalhes da busca
   Controla lista com detalhe lateral e preview de arquivo.
   ============================== */

.crmt-busca-shell {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: start;
}
.crmt-busca-shell.detail-open {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
}

.crmt-busca-list-panel {
  min-width: 0;
  overflow: hidden;
}

.crmt-busca-shell.detail-open .crmt-results-table {
  overflow-x: auto;
}
.crmt-busca-shell.detail-open .crmt-trow {
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.2fr) minmax(0, 1fr) 90px 110px;
  font-size: 13px;
}
.crmt-busca-shell.detail-open .crmt-doc-title { font-size: 14px; }
.crmt-busca-shell.detail-open .crmt-doc-sub { font-size: 11px; }
.crmt-busca-shell.detail-open .crmt-actions-cell .icon-btn { padding: 8px 10px; font-size: 12px; }

.crmt-busca-detail-panel {
  position: sticky;
  top: 20px;
  border-radius: 22px;
  background: var(--crmt-panel);
  border: 1px solid var(--crmt-border);
  box-shadow: var(--crmt-shadow-soft);
  overflow: visible;
  min-width: 0;
}

.crmt-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 20px 22px 16px;
  border-bottom: 1px solid var(--crmt-border);
}
.crmt-detail-title {
  font-size: 18px;
  font-weight: 800;
  color: var(--crmt-text);
  line-height: 1.3;
  margin-top: 4px;
}
.crmt-detail-close {
  flex-shrink: 0;
  font-size: 20px;
  padding: 4px 10px;
  line-height: 1;
  background: transparent;
  border: 1px solid var(--crmt-border);
  border-radius: 10px;
  color: var(--crmt-text-muted);
  cursor: pointer;
}
.crmt-detail-close:hover {
  background: rgba(255,255,255,.06);
  color: var(--crmt-text);
}

#crmt-detail-body {
  padding: 0 0 8px;
  max-height: none;
  overflow: visible;
}

.crmt-detail-section {
  padding: 14px 22px;
  border-bottom: 1px solid var(--crmt-border);
}
.crmt-detail-section:last-child {
  border-bottom: none;
}
.crmt-detail-section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--crmt-text-muted);
  margin-bottom: 10px;
}

.crmt-detail-kv {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.crmt-detail-kv-item {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--crmt-border);
  background: rgba(255,255,255,.03);
}
.crmt-detail-kv-item b {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--crmt-text-muted);
  font-weight: 700;
  margin-bottom: 5px;
}
.crmt-detail-kv-item span {
  font-size: 13px;
  color: var(--crmt-text);
  font-weight: 600;
}
.crmt-detail-kv-full {
  grid-column: 1 / -1;
}

.crmt-linked-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--crmt-border);
}
.crmt-linked-row:last-child {
  border-bottom: none;
}
.crmt-linked-row-info {
  flex: 1;
  min-width: 0;
}
.crmt-linked-row-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--crmt-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.crmt-linked-row-sub {
  font-size: 12px;
  color: var(--crmt-text-soft);
  margin-top: 2px;
}
.crmt-linked-row-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.crmt-detail-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding: 14px 22px 18px;
}

.crmt-detail-loading {
  padding: 30px 22px;
  text-align: center;
  color: var(--crmt-text-muted);
  font-size: 14px;
}

.crmt-trow.selected {
  background: rgba(59,130,246,.08);
}

@media (max-width: 900px) {
  .crmt-busca-shell.detail-open {
    grid-template-columns: 1fr;
  }
  .crmt-busca-detail-panel {
    position: static;
  }
}

.crmt-detail-file-name {
  font-size: 12px;
  color: var(--crmt-text-soft);
  margin-bottom: 10px;
  word-break: break-all;
}
.crmt-detail-preview {
  border-radius: 12px;
  overflow: visible;
  border: 1px solid var(--crmt-border);
  background: rgba(0,0,0,.08);
}
.crmt-detail-preview-pdf iframe {
  display: block;
  width: 100%;
  min-height: 520px;
  height: 72vh;
  max-height: 900px;
  border: none;
}
.crmt-detail-preview-img img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 72vh;
}

.crmt-doc-form-grid .crmt-textarea-inline {
  min-height: 50px !important;
  height: 50px !important;
  resize: none;
  overflow: hidden;
  padding-top: 14px;
  padding-bottom: 14px;
}

/* ==============================
   Estrutura oficial do app em tela cheia
   Trava a viewport e controla a altura total do sistema.
   ============================== */

html,
body.crmt-has-app {
  height: 100%;
}

body.crmt-has-app {
  --crmt-admin-bar-h: 0px;
  overflow: hidden !important;
}

body.admin-bar.crmt-has-app {
  --crmt-admin-bar-h: 32px;
}

@media (max-width: 782px) {
  body.admin-bar.crmt-has-app {
    --crmt-admin-bar-h: 46px;
  }
}

body.crmt-has-app #page,
body.crmt-has-app .site,
body.crmt-has-app .site-content,
body.crmt-has-app main,
body.crmt-has-app article,
body.crmt-has-app .entry-content,
body.crmt-has-app .entry-content > .crmt-wrap,
body.crmt-has-app .crmt-wrap {
  height: calc(100dvh - var(--crmt-admin-bar-h)) !important;
  min-height: calc(100dvh - var(--crmt-admin-bar-h)) !important;
  max-height: calc(100dvh - var(--crmt-admin-bar-h)) !important;
  overflow: hidden !important;
}

@supports not (height: 100dvh) {
  body.crmt-has-app #page,
  body.crmt-has-app .site,
  body.crmt-has-app .site-content,
  body.crmt-has-app main,
  body.crmt-has-app article,
  body.crmt-has-app .entry-content,
  body.crmt-has-app .entry-content > .crmt-wrap,
  body.crmt-has-app .crmt-wrap {
    height: calc(100vh - var(--crmt-admin-bar-h)) !important;
    min-height: calc(100vh - var(--crmt-admin-bar-h)) !important;
    max-height: calc(100vh - var(--crmt-admin-bar-h)) !important;
  }
}

body.crmt-has-app .entry-content {
  margin: 0 !important;
  padding: 0 !important;
}

body.crmt-has-app .crmt-wrap {
  overflow: hidden !important;
}

.crmt-shell,
.crmt-shell[data-layout="horizontal"] {
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
  align-items: stretch !important;
  grid-template-rows: 1fr !important;
}

.crmt-sidebar {
  align-self: stretch !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
  position: relative !important;
  top: auto !important;
}

.crmt-main-shell,
.crmt-shell[data-layout="horizontal"] .crmt-main-shell {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  height: 100% !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
}

.crmt-page-area,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  flex: 1 1 auto !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 24px !important;
  padding-right: 6px !important;
  box-sizing: border-box !important;
  scrollbar-width: thin;
  scrollbar-color: rgba(37, 99, 235, 0.42) transparent;
}

.crmt-page-area::-webkit-scrollbar,
.crmt-shell[data-layout="horizontal"] .crmt-page-area::-webkit-scrollbar {
  width: 10px;
}

.crmt-page-area::-webkit-scrollbar-track,
.crmt-shell[data-layout="horizontal"] .crmt-page-area::-webkit-scrollbar-track {
  background: transparent;
}

.crmt-page-area::-webkit-scrollbar-thumb,
.crmt-shell[data-layout="horizontal"] .crmt-page-area::-webkit-scrollbar-thumb {
  background: rgba(37, 99, 235, 0.24);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}

.crmt-page-area::-webkit-scrollbar-thumb:hover,
.crmt-shell[data-layout="horizontal"] .crmt-page-area::-webkit-scrollbar-thumb:hover {
  background: rgba(37, 99, 235, 0.42);
  background-clip: padding-box;
}

.crmt-recent-list-scroll {
  max-height: none !important;
  overflow: visible !important;
}

@media (max-width: 900px) {
  .crmt-page-area,
  .crmt-shell[data-layout="horizontal"] .crmt-page-area {
    padding-bottom: 18px !important;
  }
}

/* ==============================
   Rolagem interna por aba
   Faz cada secao renderizada controlar sua propria rolagem.
   ============================== */

.crmt-page-area,
.crmt-shell[data-layout="horizontal"] .crmt-page-area {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: 0 !important;
  max-height: 100% !important;
  overflow: hidden !important;
  padding-right: 0 !important;
}

.crmt-content[data-tab-content] {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: 100% !important;
  max-height: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding-right: 6px !important;
  padding-bottom: 24px !important;
  box-sizing: border-box !important;
  scrollbar-width: thin;
  scrollbar-color: rgba(37, 99, 235, 0.42) transparent;
}

.crmt-content[data-tab-content]::-webkit-scrollbar {
  width: 10px;
}

.crmt-content[data-tab-content]::-webkit-scrollbar-track {
  background: transparent;
}

.crmt-content[data-tab-content]::-webkit-scrollbar-thumb {
  background: rgba(37, 99, 235, 0.24);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}

.crmt-content[data-tab-content]::-webkit-scrollbar-thumb:hover {
  background: rgba(37, 99, 235, 0.42);
  background-clip: padding-box;
}

@media (max-width: 900px) {
  .crmt-content[data-tab-content] {
    padding-bottom: 18px !important;
  }
}

/* ==============================
   Folga final da rolagem por seção
   Ajuste individualmente cada aba conforme a necessidade.
   ============================== */

.crmt-content[data-tab-content="dashboard"] {
  padding-bottom: 150px !important;
  scroll-padding-bottom: 150px;
}

.crmt-content[data-tab-content="cadastrar"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="projetos_comercial"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="clientes"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="busca"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="lixeira"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="usuarios"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="relatorios"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}

.crmt-content[data-tab-content="config"] {
  padding-bottom: 120px !important;
  scroll-padding-bottom: 120px;
}



/* ==============================
   Salvaguarda final dos icones do menu
   Neutraliza sobrescritas antigas e evita corte dos SVGs.
   ============================== */

.crmt-nav-sidebar .crmt-tab-icon,
.crmt-nav-sidebar .crmt-tab-icon svg {
  overflow: visible !important;
}

.crmt-nav-sidebar .crmt-tab-icon {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
  flex: 0 0 22px !important;
  background: transparent !important;
  border-radius: 0 !important;
}

.crmt-nav-sidebar .crmt-tab-icon svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon,
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon svg {
  width: 22px !important;
  height: 22px !important;
  min-width: 22px !important;
  min-height: 22px !important;
}


/* ==============================
   Ajuste final dos ícones do menu lateral
   Mantém todos os SVGs do menu filled, sem fundo no container e sem corte.
   Este bloco fica por último para sobrescrever regras antigas conflitantes.
   ============================== */

.crmt-nav-sidebar .crmt-tab {
  gap: 12px !important;
}

.crmt-nav-sidebar .crmt-tab-icon {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 18px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  font-size: 0 !important;
  line-height: 1 !important;
  color: currentColor !important;
}

.crmt-nav-sidebar .crmt-tab-icon svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  display: block !important;
  overflow: visible !important;
  flex-shrink: 0 !important;
}

.crmt-shell[data-mode="light"] .crmt-nav-sidebar .crmt-tab-icon,
.crmt-nav-sidebar .crmt-tab.active .crmt-tab-icon,
.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon {
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.crmt-nav-sidebar .crmt-tab.active .crmt-tab-icon,
.crmt-nav-sidebar .crmt-tab.active .crmt-tab-text {
  color: var(--crmt-brand) !important;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  flex: 0 0 18px !important;
}

.crmt-shell[data-sidebar-size="sm"] .crmt-nav-sidebar .crmt-tab-icon svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
}

@media (max-width: 900px) {
  .crmt-projcom-grid { grid-template-columns: 1fr; }
}

.crmt-projcom-card { cursor: pointer; }
.crmt-projcom-card:hover { border-color: rgba(59,130,246,.28); box-shadow: 0 10px 24px rgba(15,23,42,.08); }
.crmt-projcom-form-wrap { width: 100%; }
.crmt-projcom-form-grid { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
.crmt-projcom-form .crmt-doc-form-grid .crmt-field[data-span-projcom="title"],
.crmt-projcom-form .crmt-doc-form-grid .crmt-doc-field[data-span-projcom="title"] { grid-column: span 2; }
.crmt-projcom-form .crmt-doc-form-grid .crmt-field[data-span-projcom="half"],
.crmt-projcom-form .crmt-doc-form-grid .crmt-doc-field[data-span-projcom="half"] { grid-column: span 2; }
.crmt-projcom-form .crmt-field textarea.crmt-projcom-textarea { min-height: 128px !important; height: 128px !important; max-height: 240px; resize: vertical; }
.crmt-projcom-form .crmt-field[data-span-projcom="half"] .crmt-upload-area,
.crmt-projcom-form .crmt-doc-field[data-span-projcom="half"] .crmt-upload-area { min-height: 188px; height: 188px; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; gap: 10px; padding: 24px 32px; box-sizing: border-box; }
.crmt-projcom-form .crmt-upload-title,
.crmt-projcom-form .crmt-upload-subtitle,
.crmt-projcom-form .crmt-upload-file { margin: 0; width: auto; text-align: center; }
.crmt-projcom-note { margin-top: 8px; }
@media (max-width: 900px) {
  .crmt-projcom-form-grid { grid-template-columns: 1fr !important; }
  .crmt-projcom-form .crmt-doc-form-grid .crmt-field[data-span-projcom="title"],
  .crmt-projcom-form .crmt-doc-form-grid .crmt-doc-field[data-span-projcom="title"],
  .crmt-projcom-form .crmt-doc-form-grid .crmt-field[data-span-projcom="half"],
  .crmt-projcom-form .crmt-doc-form-grid .crmt-doc-field[data-span-projcom="half"] { grid-column: 1 / -1; }
}

.crmt-projcom-taxonomy-shell {
  margin-top: 24px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  padding: 18px;
}

.crmt-projcom-taxonomy-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.crmt-projcom-taxonomy-card {
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 14px;
  background: #fbfcfe;
}

.crmt-projcom-taxonomy-head,
.crmt-projcom-parent-head,
.crmt-projcom-child-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.crmt-projcom-taxonomy-head {
  justify-content: space-between;
  margin-bottom: 12px;
}

.crmt-projcom-taxonomy-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.crmt-projcom-parent-col {
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 12px;
  background: #fff;
}

.crmt-projcom-parent-head {
  margin-bottom: 10px;
}

.crmt-projcom-parent-head input,
.crmt-projcom-child-row input {
  flex: 1;
}

.crmt-projcom-children {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 10px;
}

@media (max-width: 980px) {
  .crmt-projcom-taxonomy-grid {
    grid-template-columns: 1fr;
  }
}


.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell {
  background: #162033;
  border-color: rgba(148, 163, 184, 0.18);
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-card,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-card {
  background: #1a253a;
  border-color: rgba(148, 163, 184, 0.16);
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-parent-col,
.crmt-shell[data-mode="dark"] .crmt-projcom-parent-col {
  background: #111a2b;
  border-color: rgba(148, 163, 184, 0.18);
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-section-title,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-section-title,
.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell p,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell p,
.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-head strong,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-head strong,
.crmt-wrap[data-mode="dark"] .crmt-projcom-parent-head strong,
.crmt-shell[data-mode="dark"] .crmt-projcom-parent-head strong {
  color: #dbe7ff;
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-muted,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-muted {
  color: #a9bad8;
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell input[type="text"],
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell input[type="text"] {
  background: #0d1524;
  color: #e5eefc;
  border-color: rgba(148, 163, 184, 0.24);
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell input[type="text"]::placeholder,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell input[type="text"]::placeholder {
  color: #8ea1c2;
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-btn-secondary,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-btn-secondary {
  background: #1c2a43;
  color: #dbe7ff;
  border-color: rgba(148, 163, 184, 0.22);
}

.crmt-wrap[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-btn-secondary:hover,
.crmt-shell[data-mode="dark"] .crmt-projcom-taxonomy-shell .crmt-btn-secondary:hover {
  background: #253552;
  border-color: rgba(96, 165, 250, 0.30);
}

.crmt-detail-preview-video video {
  display: block;
  width: 100%;
  min-height: 360px;
  max-height: 72vh;
  background: #000;
}
.crmt-detail-preview-office iframe {
  display: block;
  width: 100%;
  min-height: 520px;
  height: 72vh;
  max-height: 900px;
  border: none;
}
