body {
  background-color: #F8F8F8 !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  border: 1px solid #cbcbcb
}

  table caption {
    color: #000;
    font: italic 85%/1 arial, sans-serif;
    padding: 1em 0;
    text-align: center
  }

  table td,
  table th {
    border-left: 1px solid #cbcbcb;
    border-width: 0 0 0 1px;
    font-size: inherit;
    margin: 0;
    overflow: visible;
    padding: .5em 1em
  }

  table thead {
    background-color: #e0e0e0;
    color: #000;
    text-align: left;
    vertical-align: bottom
  }

  table td {
    background-color: #FFFFFF;
  }


  table tr:nth-child(2n-1) td {
    background-color: #f2f2f2
  }

  table td {
    border-bottom: 1px solid #cbcbcb
  }

  table tbody > tr:last-child > td {
    border-bottom-width: 0
  }

  table td,
  table th {
    border-width: 0 0 1px 0;
    border-bottom: 1px solid #cbcbcb
  }

  table tbody > tr:last-child > td {
    border-bottom-width: 0
  }

.attiva-body {
  width: calc(100% - 48px) !important;
  max-width: 2000px;
  margin: auto !important;
  height: calc(100vh - 74px);
  min-height: calc(100vh - 74px);
  max-height: calc(100vh - 74px);
}

.attiva-footer {
  height: 24px;
  min-height: 24px;
  max-height: 24px;
  padding-top: 3px;
  padding-left: 16px;
  padding-right: 16px;
  background-color: #1b8ce3;
  color: #FFFFFF;
  line-height: 24px;
}

.attiva-datagrid {
}

.attiva-home-app-container {
  margin-top: 24px !important;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
  width: 100%;
  max-width: 900px;
  display: flex;
  flex-wrap: wrap;
}

.attiva-login {
  position: relative;
  height: calc(100vh - 100px);
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.attiva-mainlayout {
  margin-left: 0px;
}

.attiva-mainlayout-header {
  background-color: #FFFFFF !important;
  color: #000000 !important;
  width: 100% !important;
  min-width: 100% !important;
  width: 100%;
  border-bottom: 1px solid #eaeaea;
  margin-left: 0px;
  padding-left: 0px;
}

.attiva-mainlayout-menu-container {
  background-color: #f2f2f2;
  color: #000000 !important;
  width: 250px !important;
  min-width: 250px !important;
  width: 250px;
  border-bottom: 1px solid #eaeaea;
  border-right: 1px solid #eaeaea;
  min-height: 100% !important;
  height: calc(100vh - 24px);
}

.attiva-mainlayout-menu-title {
  background-color: #ffffff;
  border-bottom: 1px solid #eaeaea;
  height: 50px;
  width: 250px;
  max-width: 250px;
  padding-left: 16px;
  font-size: 16px;
  font-weight: 600 !important;
  line-height: 48px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #1b8ce3;
}

.attiva-mainlayout-company {
  height: 48px;
  width: 250px;
  max-width: 250px;
  padding-left: 16px;
  font-size: 16px;
  font-weight: 600 !important;
  line-height: 48px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #424242;
}

.attiva-mb-12 {
  margin-bottom: 12px !important;
}

.attiva-mb-16 {
  margin-bottom: 16px !important;
}

.attiva-mb-4 {
  margin-bottom: 4px !important;
}

.attiva-mb-8 {
  margin-bottom: 8px !important;
}

.attiva-ml-12 {
  margin-left: 12px !important;
}

.attiva-ml-16 {
  margin-left: 16px !important;
}

.attiva-ml-4 {
  margin-left: 4px !important;
}

.attiva-ml-8 {
  margin-left: 8px !important;
}

.attiva-mr-12 {
  margin-right: 12px !important;
}

.attiva-mr-16 {
  margin-right: 16px !important;
}

.attiva-mr-4 {
  margin-right: 4px !important;
}

.attiva-mr-8 {
  margin-right: 8px !important;
}

.attiva-mt-12 {
  margin-top: 12px !important;
}

.attiva-mt-16 {
  margin-top: 16px !important;
}

.attiva-mt-4 {
  margin-top: 4px !important;
}

.attiva-mt-8 {
  margin-top: 8px !important;
}

.attiva-row {
  min-height: 52px;
  width: 100%;
}

.attiva-toolbar-divider {
  min-height: 24px;
  height: 24px;
}

.attiva-user-roles-grid {
  min-height: calc(100vh - 70vh) !important;
  max-height: calc(100vh - 70vh) !important;
  overflow: auto;
}

.attiva-user-roles-modal-grid {
  max-height: 200px;
  min-height: 200px;
  overflow: auto;
}

.fluent-nav-menu {
}

.fluent-presence-badge {
  font-weight: normal !important;
  font-size: 18px;
}

/*.main-layout-build-version {
  line-height: 20px;
}

.main-layout-home {
  background-color: transparent !important;
  border: 0px;
}

.main-layout-home-button {
  background-color: #f5f5f5 !important;
  color: black;
}*/
.header-gutters {
  margin-left: 0px !important;
}

.attiva-ai-request {
  display: inline-block;
  background-color: #f0f0f0;
  border-start-start-radius: 0px;
  border-start-end-radius: 16px;
  border-end-start-radius: 16px;
  border-end-end-radius: 16px;
  margin-top: 16px;
  margin-bottom: 16px;
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 16px;
  padding-right: 16px;
  border: 1px solid #FFFFFF;
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.attiva-ai-response {
  margin-top:8px;
  margin-bottom:24px;
}

.d-flex {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}

.d-inline-flex {
  display: -webkit-inline-box !important;
  display: -ms-inline-flexbox !important;
  display: inline-flex !important;
}

.flex-column {
  -webkit-box-orient: vertical !important;
  -webkit-box-direction: normal !important;
  -ms-flex-direction: column !important;
  flex-direction: column !important;
}

.flex-row {
  -webkit-box-orient: horizontal !important;
  -webkit-box-direction: normal !important;
  -ms-flex-direction : row !important;
  flex-direction: row !important;
}

.align-items-start {
  -webkit-box-align: start !important;
  -ms-flex-align: start !important;
  align-items: flex-start !important;
}

.align-items-end {
  -webkit-box-align: end !important;
  -ms-flex-align: end !important;
  align-items: flex-end !important;
}

.align-items-center {
  -webkit-box-align: center !important;
  -ms-flex-align: center !important;
  align-items: center !important;
}

.align-items-stretch {
  -webkit-box-align: stretch !important;
  -ms-flex-align: stretch !important;
  align-items: stretch !important;
}