:root {
  --color-primary: #001531;
  --color-primary-rgb: 161, 19, 27;
  --color-primary-contrast: #ffffff;
  --color-primary-contrast-rgb: 255, 255, 255;
  --color-primary-shade: #8e1118;
  --color-primary-tint: #aa2b32;
  --color-secondary: #fed530;
  --color-secondary-rgb: 161, 19, 27;
  --color-secondary-contrast: #ffffff;
  --color-secondary-contrast-rgb: 255, 255, 255;
  --color-secondary-shade: #8e1118;
  --color-secondary-tint: #aa2b32;
}

body {
  font-family: Helvetica !important;
}

.min-h-100vh {
  min-height: 100vh !important;
}

.invalid-form,
.invalid-image {
  border: 1px solid #ff0000;
}

.bg-filtrando {
  background-color: rgba(28, 200, 138, 0.4);
  background-image: linear-gradient(180deg, rgba(28, 200, 138, 0.3) 10%, rgba(19, 133, 92, 0.3) 100%);
  background-size: cover;
}

#pager {
  display: flex;
  width: 100%;
  justify-content: flex-end;
  margin-top: 32px;
  padding-right: 16px;
  margin-bottom: 24px;
}

/* LOGIN START */
.bg-login-image {
  background-image: url("/img/alphacode_quadrado.jpg");
  cursor: pointer;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.bg-password-image {
  background-image: url("/img/alphacode_quadrado.jpg");
}

.footer-login p {
  color: #ffffff;
  font-size: small;
}

.footer-login img {
  height: 23px;
}

#olho-senha {
  width: 25px;
  border: none;
  cursor: pointer;
  position: absolute;
  top: 324px;
  right: 44%;
  color: #555;
  transform: translateY(-50%);
}

.dropdown-item:focus,
.dropdown-item:hover {
  color: #eaebf0;
  text-decoration: none;
  background-color: #4e73df;
  border-radius: 4px;
}

@media (max-width: 300px) {
  #olho-senha {
    right: 22%;
  }
}

::-webkit-calendar-picker-indicator {
  border-radius: 50%;
  margin-left: 0.1rem;
  width: 14px;
  height: 14px;
  cursor: pointer;
}

::-webkit-calendar-picker-indicator:hover {
  -webkit-box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04);
  box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04);
}

.form-control-user {
  width: 280px !important;
  padding: 1.3rem 1rem !important;
}

.background {
  position: relative;
  background-image: url("/img/fundo_alphacode.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}

.background::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgb(0 0 0 / 5%);
  z-index: -1;
}

.login-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-bottom: 100px;
  margin-right: 50px;
}

@media (min-width: 576px) {
  .modal-dialog {
    max-width: 520px;
    margin: 1.75rem auto;
  }
}
/* LOGIN END */

/* MENU START */
.item-nav-link {
  color: white !important;
  width: 100% !important;
  font-size: 18px !important;
  font-weight: 500;
}

.name_usuario {
  color: #27292f !important;
  font-weight: 700;
  font-size: 14px;
}

.item-menu {
  margin: 0px !important;
  width: 100% !important;
  height: 2.5rem !important;
  margin: 0 !important;
  margin-left: 0px !important;
  display: flex !important;
  align-items: center !important;
}

.item-menu:hover {
  margin-left: 0px !important;
  background-color: white !important;
  border-top-width: 1px !important;
  border-right-width: 0px !important;
  border-bottom-width: 1px !important;
  border-left-width: 0px !important;
  border-radius: 0px 2px 2px 0px !important;
  border-style: solid !important;
  border-color: #fff !important;
  display: flex !important;
  align-items: center !important;
}

.menu-active {
  margin-left: 0px !important;
  background: white !important;
  border-top-width: 1px !important;
  border-right-width: 0px !important;
  border-bottom-width: 1px !important;
  border-left-width: 0px !important;
  border-radius: 0px 2px 2px 0px !important;
  border-style: solid !important;
  border-color: #fff !important;
  display: flex !important;
  align-items: center !important;
}

.sidebar {
  width: 20rem !important;
}

.nav-link i {
  color: white !important;
}

.nav-link .fa-solid,
.fas {
  font-weight: 900;
  font-size: 18px !important;
}

.item-menu > a:hover > span {
  color: black !important;
}

.item-menu > a:hover > i {
  color: black !important;
}

.menu-active > a > span {
  color: black !important;
}

.menu-active > a > i {
  color: black !important;
}

.dropdown-menu {
  padding: 0 !important;
}
/* MENU END */

/* GERADOR START */

.stepper-active {
  background-color: #1a8fce !important;
  color: white !important;
  padding: 8px !important;
  box-shadow: 0px 3px 6px #00000029 !important;
}

#pager .stepper-before {
  color: #878787 !important;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
}

#pager .stepper-next {
  border-top-right-radius: 4px;
  color: #1a8fce;
  border-bottom-right-radius: 4px;
}

#pager .stepper {
  display: inline-block;
  font-weight: 600;
  margin: 0px !important;
  text-align: center;
  padding: 8px !important;
  font-size: 0.89rem;
  line-height: 1.5;
  transition:
    color 0.15s ease-in-out,
    background-color 0.15s ease-in-out,
    border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
  color: #1a8fce;
  border: 1px solid #878787 !important;
  cursor: pointer;
}

.text-titulo {
  font-size: 28px;
  font-weight: 700;
  color: #000 !important;
}

.titulo-info {
  font-size: 18px;
  font-weight: 400;
  color: #000 !important;
  opacity: 0.8;
  margin: 15px 0px 10px 0px;
}

.card-header {
  background-color: #f8f9fc !important;
  padding: 4px 0px 4px 16px;
}

.card-header div {
  font-size: 12px;
  color: #ffffff !important;
}

.botao- {
  border-radius: 1.35rem !important;
}

.voltar {
  color: #000 !important;
  font-size: 1.875em !important;
}

.table td,
.table th {
  border-top: 0 !important;
}

.table {
  margin-bottom: 5px !important;
  color: #001531 !important;
  font-size: 0.9rem !important;
}

.body-table {
  padding: 0 !important;
}

.card:not(.o-hidden) {
  background-color: #2a02fc00;
}

.card-table {
  border-radius: 12px 12px 0 0 !important;
}

.tabela-listagem thead tr td:first-child {
  border-radius: calc(0.35rem - 1px) 0 0 0 !important;
}

.tabela-listagem thead tr td:last-child {
  border-radius: 0 calc(0.35rem - 1px) 0 0 !important;
}

.tabela-listagem thead:nth-of-type(1) {
  background-color: white !important;
  font-weight: 700 !important;
  color: black !important;
  line-height: 0.9 !important;
  font-size: 0.8rem !important;
}

.tabela-listagem-avaliacoes thead:nth-of-type(1) {
  background-color: #ffffff !important;
  font-weight: 700 !important;
  color: #001531 !important;
  line-height: 0.9 !important;
  font-size: 1rem !important;
  text-align: center !important;
}

.tabela-listagem th,
.tabela-listagem td {
  text-align: center;
  vertical-align: middle;
}

.btn {
  font-size: 0.8rem;
  border-radius: 0.55rem;
  white-space: nowrap !important;
}

.btn-sm {
  padding: 0.25rem 0.8rem !important;
}

.btn:focus {
  outline: none;
  box-shadow: none;
}

.form-control {
  border-radius: 0.35rem !important;
  color: #424242 !important;
  font-size: 14px;
  border: 1px solid #888787 !important;
}

.form-control::placeholder {
  color: #888787;
  opacity: 1;
}

.form-control:disabled,
.form-control[readonly] {
  border: 1px solid black !important;
}

.form-control:focus {
  box-shadow: 0 0 0 0.2rem rgba(5, 56, 207, 0.25) !important;
}

.card-body {
  padding: 1.25rem !important;
  background-color: white;
}

.label-geral {
  color: #838383c0;
  margin-left: 10px;
  font-size: 15px;
}

.disabled {
  cursor: not-allowed !important;
}

select {
  cursor: pointer;
}
/* GERADOR END */

/* DASHBOARD START */
.titulo-contador {
  font-size: 14px;
  color: #838383a3;
  font-weight: 600 !important;
}

.container-left-icon {
  background-color: #1a8fce;
  height: 40px;
  width: 70px;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.container-fluid a {
  text-decoration: none !important;
}

a > .container-left-icon > i {
  font-size: 15px !important;
  color: white !important;
}

.main .page-header {
  color: black;
  font-size: 30px;
  font-family: "Inter-Regular", Helvetica;
  user-select: none;
  border-bottom: 0px;
  font-weight: 600;
}

.qtd-contador {
  color: #00031b;
  margin-top: 13px;
  font-size: 24px;
}

.link-contador:hover {
  text-decoration: none;
}

.card-hover {
  background: #ffffff !important;
  transition: background-color 2s ease-out 400ms;
  min-height: 140px !important;
}

:not(.aumento).card-hover:hover {
  background-color: #ff009005 !important;
  color: #ffffff !important;
  box-shadow:
    rgb(0 0 0 / 6%) 0px -23px 25px 0px inset,
    rgb(0 0 0 / 0%) 0px -36px 30px 0px inset,
    rgb(0 0 0 / 0%) 0px -79px 40px 0px inset,
    rgb(0 0 0 / -4%) 0px 2px 1px,
    rgb(0 0 0 / 9%) 0px 4px 2px,
    rgb(0 0 0 / 9%) 0px 8px 4px,
    rgb(0 0 0 / 0%) 0px 16px 8px,
    rgb(0 0 0 / 0%) 0px 32px 16px !important;
}

.hidden {
  display: none;
}

.frame {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 8px;
  position: relative;
  margin-left: 10px;
}

.frame .text-wrapper {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  opacity: 0.5;
  font-family: "Inter-Regular", Helvetica;
  font-weight: 400;
  color: #000000;
  font-size: 20px;
  letter-spacing: 0;
  line-height: normal;
  white-space: nowrap;
}

.frame .div {
  position: relative;
  width: fit-content;
  font-family: "Inter-SemiBold", Helvetica;
  font-weight: 600;
  color: #000000;
  font-size: 35px;
  letter-spacing: 0;
  line-height: normal;
  white-space: nowrap;
}

.frame .group {
  position: relative;
  width: 125px;
  height: 20px;
}

.frame .element-nesse-m-s {
  position: absolute;
  top: 2px;
  left: 23px;
  font-family: "Inter-Bold", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 14px;
  letter-spacing: -0.12px;
  line-height: normal;
  width: 150px;
}

.frame .span {
  font-weight: 700;
  color: #00ac4f;
}

.frame .text-wrapper-2 {
  font-family: "Inter-Regular", Helvetica;
  color: #292d32;
}

.frame .arrow-up {
  position: absolute;
  width: 20px;
  height: 20px;
  top: 0;
  left: 0;
}

.icone_aumento {
  background-color: #7099e7;
  display: flex;
  justify-content: center;
  flex-direction: row;
  width: 60px;
  height: 60px;
  align-items: center;
  border-radius: 50%;
}

.vermelho {
  color: red !important;
}

/* DASHBOARD END */

/* USUARIOS START */
.img-avatar {
  position: relative;
  top: 0;
  left: 10px;
  width: 180px !important;
  height: 180px !important;
  border-radius: 50%;
  margin: 0px !important;
  cursor: pointer;
  object-fit: cover;
  margin-bottom: 30px !important;
}

.nav-tabs {
  border-bottom: 0px;
  margin-bottom: -1px;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-link.active:hover {
  margin-bottom: 0px;
  border-color: #a0a3ad !important;
}

.nav-tabs .nav-link {
  border: 0;
}

.header-aba {
  border-radius: 0px calc(0.35rem - 1px) 0px 0px !important;
}

.aba-selecionada:active,
.active.aba-selecionada {
  background-color: #1a8fce !important;
  color: white !important;
}

.aba-selecionada {
  background-color: white !important;
  font-size: 14px;
  border: 0.5px solid #1a8fce !important;
  color: #1a8fce !important;
}

.pointer {
  cursor: pointer !important;
}

.custom-checkbox .custom-control-input:checked ~ .custom-control-label:after {
  border-radius: 4px !important;
}

input:disabled {
  background-color: transparent !important;
}

input::placeholder {
  color: #424242 !important;
}

select:disabled {
  background-color: transparent !important;
}

.container-button-filter {
  display: flex;
  justify-content: right;
  height: 100%;
  align-items: center;
  margin-top: -5px;
}

.btn-filter {
  background-color: #1a8fce;
  border-radius: 4px !important;
  font-size: 14px;
}

.btn-clean-filter {
  background-color: #1a8fce;
  border-radius: 4px !important;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

.btn-new {
  color: white;
  background-color: #0f405b;
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  gap: 8px;
  border-radius: 4px;
}

.btn-new:hover {
  text-decoration: none;
  color: white;
}

.form-group label {
  color: #424242;
  font-weight: 600;
}

/* USUARIOS END */

/* TABLE START*/

.btn-table {
  background-color: #091524;
  font-weight: 600;
  color: white;
}

.btn-table:hover {
  color: white !important;
}

.btn-success-table {
  background-color: #11933f;
  font-weight: 600;
  border: none;
  color: white;
}

.btn-danger-table {
  background-color: #ed0000;
  border: none;
  font-weight: 600;
  color: white;
}

.title-table-permissions {
  font-weight: 600;
  color: black !important;
  font-size: 20px;
}

.table-striped-permission tbody tr:hover {
  color: #858796;
  background-color: rgba(0, 0, 0, 0.075);
}

.custom-control-input:checked ~ .custom-control-label::before {
  background-color: black !important;
  border-color: black;
}

.custom-control-label::before {
  width: 20px;
  height: 20px;
}

.custom-control-label::after {
  width: 20px;
  height: 20px;
}

#lista-permissoes tbody tr {
  border-bottom: 1px solid #ccc;
}

#lista-permissoes thead tr {
  border-bottom: none;
}

#lista-permissoes td {
  font-size: 18px;
  color: #666666;
}

/* CLIENTES START*/

.btn-generate-report {
  border-color: #091524 !important;
  color: #091524;
  font-weight: 600;
  background-color: white;
  font-size: 14px;
  border-radius: 4px;
  width: 220px !important;
}

.btn-generate-report:hover {
  color: #091524 !important;
}

.btn-update {
  color: white;
  font-weight: 600;
  height: 100%;
  background-color: #091524;
  border: none;
  font-size: 14px;
  border-radius: 4px;
  width: 220px !important;
}

.btn-save {
  color: white;
  font-weight: 600;
  height: 100%;
  background-color: #1a8fce;
  border: none;
  font-size: 14px;
  border-radius: 4px;
  width: 220px !important;
}

.container-bottons {
  display: flex;
  width: 100%;
  height: 35px;
  margin-top: 40px;
  justify-content: right;
  padding-right: 10px;
  gap: 8px;
}

/* CLIENTES END*/

/* RELATORIOS START */

.container-total-report {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: end;
  width: 100%;
  padding-right: 10px;
  margin-bottom: 24px;
  padding-right: 16px;
}

.container-total-report > .container-qtd {
  border: 1px solid black;
  border-radius: 5px;
  width: 227px;
  height: 75px;
  color: black;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 30px;
}

.container-total-report > .container-title {
  width: 227px;
  font-size: 24px;
  text-align: left;
  color: black;
}

/* RELATORIOS END */
