/**
 * BelCX — escala visual global (compacta + responsiva).
 * Carregado após app.css. CRM moderno reutiliza os mesmos tokens (--bx-*).
 */

:root {
  /* Tipografia */
  --bx-fs-base: 13px;
  --bx-fs-sm: 11px;
  --bx-fs-xs: 10px;
  --bx-fs-lg: clamp(1.15rem, 1.2vw + 0.9rem, 1.45rem);
  --bx-fs-xl: clamp(1.25rem, 1.5vw + 0.85rem, 1.65rem);
  --bx-line: 1.5;

  /* Espaçamento */
  --bx-gap: 10px;
  --bx-gap-md: 12px;
  --bx-gap-lg: 14px;
  --bx-gap-xl: 18px;
  --bx-card-pad: 12px 14px;
  --bx-content-pad-x: clamp(12px, 1.8vw, 20px);
  --bx-content-pad-y: clamp(10px, 1.2vw, 16px);

  /* Formulários */
  --bx-input-h: 32px;
  --bx-input-pad: 5px 10px;
  --bx-label-fs: var(--bx-fs-sm);

  /* Superfícies */
  --bx-radius: 8px;
  --bx-radius-lg: 10px;
  --bx-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 2px 10px rgba(15, 23, 42, 0.05);

  /* Layout */
  --bx-container-max: 1560px;
  --bx-sidebar-form: clamp(220px, 22vw, 280px);
}

/* —— Base —— */
body {
  font-size: var(--bx-fs-base);
  line-height: var(--bx-line);
}

.content {
  padding: var(--bx-content-pad-y) var(--bx-content-pad-x) !important;
  width: 100% !important;
  max-width: var(--bx-container-max);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.main-content {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* —— Títulos e listagens —— */
.page-title {
  font-size: var(--bx-fs-lg);
}

.page-heading-row {
  gap: var(--bx-gap-md);
  margin-bottom: var(--bx-gap-xl);
}

.page-heading-row__title {
  font-size: var(--bx-fs-xl);
}

.page-heading-row__sub,
.page-heading-row p {
  font-size: var(--bx-fs-base);
}

/* —— Cards —— */
.card {
  border-radius: var(--bx-radius-lg);
  box-shadow: var(--bx-shadow);
}

.card-header {
  padding: var(--bx-card-pad);
}

.card-body {
  padding: var(--bx-card-pad);
}

.card-title {
  font-size: var(--bx-fs-base);
}

.stat-card {
  padding: var(--bx-card-pad);
  border-radius: var(--bx-radius-lg);
}

.stat-label {
  font-size: var(--bx-fs-xs);
  margin-bottom: 6px;
}

.stat-value {
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
}

.stat-sub {
  font-size: var(--bx-fs-sm);
  margin-top: 4px;
}

/* —— Botões —— */
.btn {
  padding: 6px 12px;
  font-size: var(--bx-fs-base);
  border-radius: var(--bx-radius);
  gap: 5px;
}

.btn-sm {
  padding: 4px 9px;
  font-size: var(--bx-fs-sm);
}

.btn-icon {
  padding: 5px 8px;
}

/* —— Formulários globais —— */
label,
.form-group > label {
  font-size: var(--bx-label-fs);
  letter-spacing: 0.04em;
  margin-bottom: 0;
}

.form-group {
  gap: 4px;
}

.form-grid {
  gap: var(--bx-gap-md);
}

input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="file"]),
select,
textarea,
.form-control {
  min-height: var(--bx-input-h);
  padding: var(--bx-input-pad);
  font-size: var(--bx-fs-base);
  border-radius: var(--bx-radius);
}

textarea {
  min-height: 72px;
  padding: 8px 10px;
}

.form-hint,
.td-small {
  font-size: var(--bx-fs-sm);
  line-height: 1.4;
}

/* Tom Select */
.ts-wrapper .ts-control,
.ts-wrapper.single.input-active .ts-control,
.form-group .ts-control,
.opp-cell .ts-control {
  min-height: var(--bx-input-h) !important;
  padding: 3px 8px !important;
  font-size: var(--bx-fs-base) !important;
  border-radius: var(--bx-radius) !important;
}

.ts-dropdown .option,
.ts-dropdown .no-results {
  font-size: var(--bx-fs-sm);
  padding: 6px 9px;
}

/* —— Tabelas —— */
.table-wrap {
  border-radius: var(--bx-radius-lg);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

th {
  padding: 8px 11px;
  font-size: var(--bx-fs-xs);
  letter-spacing: 0.06em;
}

td {
  padding: 9px 11px;
  font-size: var(--bx-fs-base);
}

/* —— Badges / status —— */
.badge,
.status-badge {
  font-size: var(--bx-fs-sm);
  padding: 3px 8px;
}

/* —— Modais —— */
.modal-header,
.modal-footer {
  padding: var(--bx-card-pad);
}

.modal-body {
  padding: var(--bx-card-pad);
}

.modal-title {
  font-size: var(--bx-fs-base);
}

/* —— Prospecção (tabs legadas) —— */
.pros-tabs {
  padding: 4px;
  gap: 4px;
  margin-bottom: var(--bx-gap-md);
  border-radius: var(--bx-radius-lg);
}

.pros-tab {
  padding: 7px 12px;
  font-size: var(--bx-fs-sm);
}

/* —— Navbar —— */
.navbar {
  padding: 0 clamp(12px, 2vw, 20px);
}

.logo-text {
  font-size: clamp(16px, 1.5vw, 18px);
}

.navbar-nav a,
.navbar-nav .nav-link {
  font-size: var(--bx-fs-sm);
  padding: 6px 10px;
}

/* —— CRM moderno: usa tokens globais —— */
.crm-modern {
  --crm-radius: var(--bx-radius);
  --crm-radius-lg: var(--bx-radius-lg);
  --crm-shadow: var(--bx-shadow);
  --crm-fs-base: var(--bx-fs-base);
  --crm-fs-sm: var(--bx-fs-sm);
  --crm-fs-xs: var(--bx-fs-xs);
  --crm-input-h: var(--bx-input-h);
  --crm-input-pad: var(--bx-input-pad);
  --crm-gap: var(--bx-gap);
  --crm-gap-md: var(--bx-gap-md);
  --crm-gap-lg: var(--bx-gap-lg);
  --crm-card-pad: var(--bx-card-pad);
  --crm-action-bar-space: 76px;
}

.crm-modern-layout {
  grid-template-columns: minmax(0, 1fr) minmax(0, var(--bx-sidebar-form));
}

.crm-modern-view-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, var(--bx-sidebar-form));
}

/* —— Notebook (≤1366px) —— */
@media (max-width: 1366px) {
  :root {
    --bx-fs-base: 12.5px;
    --bx-fs-sm: 10.5px;
    --bx-input-h: 30px;
    --bx-input-pad: 4px 9px;
    --bx-gap: 8px;
    --bx-gap-md: 10px;
    --bx-card-pad: 10px 12px;
    --bx-sidebar-form: 228px;
    --bx-container-max: 100%;
  }

  .form-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .stat-value {
    font-size: clamp(1.2rem, 2.2vw, 1.5rem);
  }
}

/* —— Tablet (≤992px) —— */
@media (max-width: 992px) {
  :root {
    --bx-content-pad-x: 12px;
    --bx-sidebar-form: 100%;
  }

  .form-grid-2,
  .form-grid-3 {
    grid-template-columns: 1fr;
  }

  .page-heading-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .crm-modern-layout,
  .crm-modern-view-grid {
    grid-template-columns: 1fr;
  }
}

/* —— Mobile (≤768px) —— */
@media (max-width: 768px) {
  :root {
    --bx-fs-base: 12px;
    --bx-input-h: 36px;
    --bx-input-pad: 8px 10px;
  }

  .btn {
    min-height: 36px;
  }
}

/* —— Telas grandes (≥1440px) —— */
@media (min-width: 1440px) {
  :root {
    --bx-content-pad-x: 20px;
    --bx-container-max: 1600px;
  }
}

@media (min-width: 1680px) {
  :root {
    --bx-content-pad-x: 24px;
    --bx-container-max: 1720px;
    --bx-gap-lg: 16px;
    --bx-gap-xl: 22px;
  }

  .content {
    padding-top: 18px !important;
    padding-bottom: 22px !important;
  }
}

@media (min-width: 1920px) {
  :root {
    --bx-container-max: 1840px;
    --bx-fs-base: 13.5px;
  }
}

/* Evita scroll horizontal acidental no app */
html {
  overflow-x: clip;
}

body {
  overflow-x: clip;
}
