.background-overlay {
  background-color: #343a40;
  height: 100%;
  width: 100%;
  position: absolute;
}

.dark-bg {
  background-color: #343a40;
}

.white-bg {
  background-color: white;
}
/* #main.login {
  background-image: url(/images/tlbg.jpg);
  overflow-y: hidden;
  background-size: cover;
} */

#main {
  flex: 1 1 0%;
  overflow-y: auto;
  position: relative;
  flex-direction: column;
}

.modal {
  height: auto !important;
  overflow: visible !important;
}

.modal button {
  margin-left: 0.25em;
  margin-right: 0.25em;
}

.table-button-form {
  display: flex;
  justify-content: center;
}

/* The Close Button */
.close {
  color: #aaa;
  float: right;
  font-size: 28px;
  font-weight: bold;
}

.close:hover,
.close:focus {
  color: black;
  text-decoration: none;
  cursor: pointer;
}

.dataTables_wrapper {
  width: 100%;
  padding: 10px 5px;
}

.data-table {
  width: 100%;
  height: 100%;
}

.data-table td {
  border: 1px solid white;
}
.data-table thead {
  background-color: rgb(33, 37, 41);
  color: white;
}
.data-table tbody {
  background-color: white;
  color: black;
}
table.dataTable > thead > tr > th,
table.dataTable > thead > tr > td {
  padding-top: 4px !important;
  padding-bottom: 4px !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.dt-top,
.dt-bottom {
  display: flex;
  justify-content: space-between;
}

.dt-input {
  color: black !important;
  -webkit-box-shadow: inset 5px 5px 50px 29px rgba(255, 255, 255, 0.95) !important;
  box-shadow: inset 5px 5px 50px 29px rgba(255, 255, 255, 0.95) !important;
  background-color: white !important;
}

html,
body,
#main,
.full-height {
  height: 100%;
  background-color: #343a40;
}

.full-width {
  width: 100% !important;
}

.navbar {
  background-color: #212529;
}

.navbar a {
  color: #fff;
}

.no-border {
  border: none !important;
}

.align-items-center {
  -ms-flex-align: center !important;
  align-items: center !important;
}

.justify-content-center {
  -ms-flex-pack: center !important;
  justify-content: center;
}

.d-flex {
  display: -ms-flexbox !important;
  display: flex !important;
}

.card {
  padding: 0 !important;
  border: none !important;
  background-color: #292d32 !important;
  border-radius: 0.5rem;
  box-shadow: 0px 0px 15px 1px rgba(0, 0, 0, 0.8);
}

.card {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  min-width: 420px;
  word-wrap: break-word;
  background-clip: border-box;
  border: 1px solid rgba(0, 0, 0, 0.125);
  color: white;
}

.card-large {
  min-width: none !important;
  max-width: none !important;
  width: auto !important;
}
.card-large p {
  margin: 1em !important;
}

.card-body {
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  min-height: 1px;
  padding: 1.25rem;
}

form .form-group {
  margin-bottom: 0.25rem !important;
}

.mb-3,
.my-3 {
  margin-bottom: 1rem !important;
}

.form-group {
  margin-bottom: 1rem;
}

.login-logo {
  width: 50%;
  max-width: 320px;
  margin: auto;
  margin-top: 2em;
}

img {
  vertical-align: middle;
  border-style: none;
  border: 0;
}

.grecaptcha-badge {
  display: none;
}

@media (min-width: 768px) {
  .col-md-3 {
    max-width: 25%;
    flex: 0 0 0 !important;
    min-width: 420px !important;
  }
  /* .col-md-3.card-large {
    max-width: 50%;
    flex: 0 0 0 !important;
}
.col-md-3.card-large img {
  max-width: 25%;
} */
}
.form-control {
  display: block;
  width: 100%;
  height: calc(1.5em + 0.75rem + 2px);
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #495057;
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  border-radius: 0.25rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.btn:not(:disabled):not(.disabled) {
  cursor: pointer;
}

.btn-nohover:hover {
  cursor: default !important;
}

.btn-primary {
  background-color: #bb86fc !important;
  border-color: #ad6dfb !important;
}

.btn-themecolor {
  background-color: #bb86fc !important;
  border-color: #ad6dfb !important;
}

.btn-outline-themecolor {
  color: #bb86fc;
  border-color: #bb86fc;
  background-color: white;
}

.btn-outline-themecolor:hover {
  color: #bb86fc !important;
  border-color: #bb86fc !important;
  background-color: white !important;
}

.btn-outline-secondary-no-hover {
  color: #6c757d;
  border-color: #6c757d;
}

.btn-outline-secondary-no-hover:hover {
  color: #6c757d !important;
  border-color: #6c757d !important;
  background-color: white !important;
}

.bg-white,
button.dt-button,
.dataTables_length select,
.dataTables_wrapper input {
  background-color: black !important;
  color: white !important;
}

.text-white,
.dataTables_wrapper .dataTables_filter label {
  color: white !important;
}

div.dataTables_wrapper .dataTables_paginate .paginate_button {
  color: #aaa !important;
}

footer.default-footer {
  height: 48px !important;
  color: #aaa !important;
  background-color: #212529;
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  width: 100%;
  bottom: 0;
  left: 0;
  z-index: 1000;
}

.bold {
  font-weight: bold;
}

.unordered-list {
  list-style-type: none;
  padding-left: 0;
}

.grayed-list-item {
  color: #999;
}

.fulfilled {
  color: #4caf50;
}

.unfulfilled {
  color: #d24747;
}

.text-bubble {
  display: none;
  position: absolute;
  background-color: #212529;
  color: #fff;
  margin: 0 !important;
  padding: 10px;
  border-radius: 5px;
  border-color: #212529;
  z-index: 1;
}

.text-bubble:before {
  content: "";
  position: absolute;
  border-style: solid;
  margin: 0 !important;
  border-width: 0 10px 10px 10px;
  border-color: transparent transparent #212529 transparent;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
}

a.dropdown-item {
  white-space: pre-wrap;
  word-wrap: anywhere;
  word-break: normal;
  white-space: normal;
  display: block;
}

.modal {
  top: 20% !important;
}

.responsive .data-table {
  width: 100% !important;
  margin: auto;
}
.responsive .dataTables_scrollHeadInner {
  width: 100% !important;
}

.hidden {
  display: none !important;
}

.hidden-height {
  height: 0px !important;
  overflow: hidden;
}

a.link-primary {
  color: #bb86fc !important;
  text-decoration: underline !important;
  font-weight: bold;
}

.loader {
  border: 8px solid #f3f3f3;
  border-top-width: 8px;
  border-top-style: solid;
  border-top-color: rgb(243, 243, 243);
  border-top: 8px solid #3498db;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  animation: spin 2s linear infinite;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.tab-content {
  padding-top: 4em;
  width: 100%;
}

.subscriptionTabs a.nav-link {
  color: #c5bfcc !important;
}

.subscriptionTabs a.nav-link.active {
  color: white !important;
}

.flex-direction-column {
  flex-direction: column !important;
}

.no-hover {
  pointer-events: none;
}

.flex-grow {
  flex: 1 1 0;
}

.no-wrap {
  flex-wrap: nowrap;
}

.bg-light {
  background-color: #56606a;
}
.br-4 {
  border-radius: 4px;
}

.info-table td:first-child {
  font-weight: bold;
}
.info-table tr,
.info-table td {
  padding: 0.25em 1em;
  font-size: 18px;
}

.sub-item {
  background-color: rgba(0, 0, 0, 0.3) !important;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 4px;
  min-width: 240px;
}
.chosen-css .chosen-container-multi .chosen-choices {
  width: 100% !important;
  padding: 0.375rem 1.75rem 0.375rem 0.75rem !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #495057 !important;
  vertical-align: middle !important;

  background-color: #fff !important;
  border: 1px solid #ced4da !important;
  border-radius: 0.25rem !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}
.chosen-css .chosen-container {
  width: 100% !important;
}

/* .responsive .dt-scroll-headInner {
  width: 100% !important;
  margin: auto;
} */

.dashboard-table .dt-scroll-body {
  min-height: 160px !important;
  max-height: 165px !important;
  overflow-y: auto !important;
}

.modal {
 
}
.modal.drawer {
  display: flex !important;
  pointer-events: none;
  top: 0 !important;
    height: 100vh !important;
}
.modal.drawer * {
  pointer-events: none;
}
.modal.drawer .modal-dialog {
  margin: 0px;
  display: flex;
  flex: auto;
  transform: translate(25%, 0);
}
.modal.drawer .modal-dialog .modal-content {
  border: none;
  border-radius: 0px;
}
.modal.drawer .modal-dialog .modal-content .modal-body {
  overflow: auto;
}
.modal.drawer.show {
  pointer-events: auto;
}
.modal.drawer.show * {
  pointer-events: auto;
}
.modal.drawer.show .modal-dialog {
  transform: translate(0, 0);
}
.modal.drawer.right-align {
  flex-direction: row-reverse;
}
.modal.drawer.left-align:not(.show) .modal-dialog {
  transform: translate(-25%, 0);
}
.dt-length label{
  margin-left: 8px;
}
div.dt-container .dt-paging .dt-paging-button.current, div.dt-container .dt-paging .dt-paging-button.current:hover {
  color: inherit !important;
  border: 1px solid rgba(0, 0, 0, 0.3);
  background-color: rgba(0, 0, 0, 0.05);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(230, 230, 230, 0.05)), color-stop(100%, rgba(0, 0, 0, 0.05)));
  background: -webkit-linear-gradient(top, rgba(230, 230, 230, 0.05) 0%, rgba(0, 0, 0, 0.05) 100%);
  background: -moz-linear-gradient(top, rgba(230, 230, 230, 0.05) 0%, rgba(0, 0, 0, 0.05) 100%);
  background: -ms-linear-gradient(top, rgba(230, 230, 230, 0.05) 0%, rgba(0, 0, 0, 0.05) 100%);
  background: -o-linear-gradient(top, rgba(230, 230, 230, 0.05) 0%, rgba(0, 0, 0, 0.05) 100%);
  background: #bb86fc !important;
}
/* .dt-scroll-headInner{
  width: 100%!important;
} */