body {
  font-family: "PlusJakartaSans", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

.cursor-pointer {
  cursor: pointer;
}

.fw-medium {
  font-weight: 500 !important;
}

.fw-semi-bold {
  font-weight: 600 !important;
}

.fw-extra-bold {
  font-weight: 800 !important;
}

.solo-title {
  margin-top: 6px;
}

.text-primary {
  color: var(--primary-color) !important;
}

.text-secondary {
  color: var(--secondary-color) !important;
}

.text-tertiary {
  color: var(--tertiary-color) !important;
}

.text-info {
  color: var(--info-color) !important;
}

.text-danger {
  color: var(--danger-color) !important;
}

.bg-primary {
  background-color: var(--primary-color) !important;
}

.bg-secondary {
  background-color: var(--secondary-color) !important;
}

.bg-info {
  background-color: var(--info-color) !important;
}

.bg-danger {
  background-color: var(--danger-color) !important;
}

.btn-primary {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff !important;
}

.btn-warning {
  background-color: var(--warning-color);
  border-color: var(--warning-color);
  color: #fff !important;
}
.btn-warning:hover {
  background-color: var(--warning-color);
  border-color: var(--warning-color);
  color: #fff !important;
}

.btn-info {
  background-color: var(--info-color);
  border-color: var(--info-color);
  color: #fff !important;
}
.btn-info:hover {
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
}

.btn-secondary {
  background-color: var(--secondary-color);
  border-color: var(--secondary-color);
  color: #fff !important;
}

.btn-danger {
  background-color: var(--danger-color);
  border-color: var(--danger-color);
  color: #fff !important;
}

.fs-5 {
  font-size: 0.875rem !important;
}

.fs-6 {
  font-size: 0.75rem !important;
}

.img-white {
  filter: brightness(0) invert(1);
}

hr {
  margin: 1rem 0;
  height: 1px;
  border: 0;
  background-color: #fff;
  opacity: 1;
  width: 100%;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: "P22MackinacPro", sans-serif !important;
  font-weight: 700 !important;
}
h1.main-font, h2.main-font, h3.main-font, h4.main-font, h5.main-font, h6.main-font,
.h1.main-font, .h2.main-font, .h3.main-font, .h4.main-font, .h5.main-font, .h6.main-font {
  font-family: "PlusJakartaSans", sans-serif !important;
}

.iti {
  width: 100%;
}

h2 {
  line-height: 1 !important;
}

#service_contact-buttons {
  bottom: 2rem;
  right: 2rem;
}
#service_contact-buttons a {
  width: 4rem;
  height: 4rem;
  font-size: 1.5rem;
}
#service_contact-buttons a + a {
  margin-top: 0.75rem;
}

.form-label {
  font-weight: 700;
  color: var(--info-color);
  font-size: 0.75rem;
}

.form-control {
  font-size: 0.75rem;
  color: var(--secondary-color);
  box-shadow: none !important;
  border-color: var(--secondary-color);
  min-height: 2.375rem;
}
.form-control:focus {
  border-color: var(--info-color);
}
.form-control[type=file] {
  min-height: auto !important;
}

.form-switch {
  min-height: 2.375rem;
}

.form-select,
.select2-container--bootstrap-5 .select2-selection {
  border-color: var(--secondary-color);
}

.input-group .input-group-text {
  -webkit-border-radius: 0.625rem;
  -moz-border-radius: 0.625rem;
  border-radius: 0.625rem;
  border-color: var(--secondary-color);
}
.input-group .form-control {
  -webkit-border-radius: 0.625rem;
  -moz-border-radius: 0.625rem;
  border-radius: 0.625rem;
}
.input-group > .input-group-text {
  background-color: transparent;
  border-right: 0;
}
.input-group .input-group-text + .form-control {
  border-left: 0;
}

.select2-hidden-accessible + .select2-container--bootstrap-5 {
  width: 100% !important;
}

select[name$=_day] {
  width: 20%;
}

select[name$=_month] {
  width: 45%;
  margin-left: 2.5%;
  margin-right: 2.5%;
}

select[name$=_year] {
  width: 30%;
}

.form-control.is-invalid,
.form-control.is-invalid:focus,
.was-validated .form-control:invalid,
.was-validated .form-control:invalid:focus {
  border-color: var(--danger-color);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23e6367a'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23e6367a' stroke='none'/%3e%3c/svg%3e");
}

.formset-add-row {
  cursor: pointer;
}
.formset-add-row td {
  color: #fff;
  background-color: var(--tertiary-color);
  font-weight: 700;
}
.formset-add-row td:first-child {
  -webkit-border-top-left-radius: 0.5625rem;
  -webkit-border-bottom-left-radius: 0.5625rem;
  -moz-border-radius-topleft: 0.5625rem;
  -moz-border-radius-bottomleft: 0.5625rem;
  border-top-left-radius: 0.5625rem;
  border-bottom-left-radius: 0.5625rem;
}
.formset-add-row td:last-child {
  -webkit-border-top-right-radius: 0.5625rem;
  -webkit-border-bottom-right-radius: 0.5625rem;
  -moz-border-radius-topright: 0.5625rem;
  -moz-border-radius-bottomright: 0.5625rem;
  border-top-right-radius: 0.5625rem;
  border-bottom-right-radius: 0.5625rem;
}

@media (max-width: 796px) {
  .form-control {
    font-size: 0.625rem;
  }
}
.select-container {
  overflow: hidden !important;
}

.btn {
  font-size: 0.75rem;
  font-weight: 700;
  padding-top: 0.6875rem;
  padding-bottom: 0.8125rem;
  -webkit-border-radius: 0.625rem;
  -moz-border-radius: 0.625rem;
  border-radius: 0.625rem;
}
.btn .fa-file-excel {
  font-size: 1.1rem;
  line-height: 1;
}

@media (max-width: 796px) {
  .btn {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }
}
.badge.rounded-pill {
  padding-bottom: 0.25rem;
}

section#dashboard .pie-chart {
  height: 7rem;
  width: 100%;
}

.navbar {
  transition: all 0.5s;
  z-index: 1020;
}
.navbar hr {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
.navbar .text-description {
  white-space: nowrap;
  transition: all 0.5s;
  overflow: hidden;
  text-align: left;
}
.navbar .nav-link {
  color: #fff !important;
  -webkit-border-radius: 0.5625rem;
  -moz-border-radius: 0.5625rem;
  border-radius: 0.5625rem;
}
.navbar .nav-link.active {
  background-color: var(--tertiary-color);
}
.navbar .navbar-brand #logo, .navbar .navbar-brand #isotype {
  max-width: 100%;
  max-height: 100%;
}
.navbar .navbar-toggler {
  color: #fff;
  font-size: 1.625rem;
  padding: 0.75rem;
  border: 0;
}
.navbar #toggle-navbar {
  margin-left: 0;
}
.navbar #toggle-navbar i {
  transition: all 0.5s;
}
.navbar .submenu {
  background-color: var(--primary-color);
  -webkit-border-radius: 0.5625rem;
  -moz-border-radius: 0.5625rem;
  border-radius: 0.5625rem;
  padding: 0 1rem !important;
}
.navbar .submenu a {
  padding: 0.5rem 0 !important;
  display: block;
  color: #fff;
  text-decoration: none;
  font-size: 0.875rem;
}
.navbar .submenu a.active {
  color: var(--info-color);
}

@media screen and (min-width: 992px) {
  body {
    display: flex;
  }
  .navbar .container-fluid,
  .navbar-expand-lg .navbar-collapse,
  .navbar-expand-lg .navbar-nav {
    flex-direction: column;
  }
  main.container-fluid {
    width: 90%;
    margin: 0;
    padding-top: 3.25rem;
    padding-bottom: 2rem;
  }
  .navbar {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    padding: 2rem;
    width: 10.25rem;
    height: 100vh;
    align-items: flex-start;
  }
  .navbar .collapse {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
  }
  .navbar #main-menu-container {
    max-height: calc(100vh - 16.125rem);
    overflow-y: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .navbar #main-menu-container::-webkit-scrollbar {
    display: none;
  }
  .navbar #toggle-navbar {
    width: 2.75rem;
    height: 2.75rem;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center !important;
  }
  .navbar #toggle-navbar i {
    transform: rotate(90deg);
  }
  .navbar .container-fluid {
    -webkit-border-radius: 0.625rem;
    -moz-border-radius: 0.625rem;
    border-radius: 0.625rem;
    height: calc(100vh - 4rem);
    padding: 2rem 1.5rem 1rem;
    background: var(--info-color);
  }
  .navbar .navbar-brand {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    display: flex;
    align-items: center;
    height: 3rem;
  }
  .navbar .navbar-brand #logo {
    display: none;
  }
  .navbar .navbar-brand #isotype {
    display: block;
  }
  .navbar .nav-link {
    justify-content: center !important;
  }
  .navbar .text-description {
    width: 0rem;
    flex: 0 !important;
    padding-left: 0 !important;
  }
  .navbar ul {
    margin-left: auto;
    margin-right: auto;
  }
  .navbar i {
    width: 1.25rem;
    text-align: center;
  }
  .navbar.expanded {
    width: 25%;
  }
  .navbar.expanded ul {
    margin-left: 0;
  }
  .navbar.expanded #toggle-navbar {
    margin-left: 0;
  }
  .navbar.expanded #toggle-navbar i {
    transform: rotate(0deg);
  }
  .navbar.expanded .navbar-brand {
    padding-left: 0;
    padding-right: 0;
  }
  .navbar.expanded .navbar-brand #logo {
    display: block;
  }
  .navbar.expanded .navbar-brand #isotype {
    display: none;
  }
  .navbar.expanded .text-description {
    width: 100%;
    flex: 1 1 auto !important;
    padding-left: 0.5rem !important;
  }
  .navbar.expanded + main {
    width: calc(100% - 10.25rem);
  }
}
@media screen and (min-width: 1400px) {
  .navbar.expanded {
    width: 20%;
  }
  .navbar.expanded + main {
    width: 80%;
  }
}
@media screen and (max-width: 991px) {
  body {
    padding-top: 4.375rem;
  }
  main {
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }
  .navbar {
    background: var(--info-color);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
  }
  .navbar #logo {
    display: none !important;
  }
  .navbar #isotype {
    display: block !important;
    height: 2.75rem;
  }
  .navbar .nav-link {
    padding: 0.5rem;
  }
}
.dropdown .dropdown-menu .dropdown-item {
  font-size: 0.75rem;
  color: var(--secondary-color);
}
.dropdown .dropdown-menu .dropdown-item.active, .dropdown .dropdown-menu .dropdown-item:active {
  background-color: var(--tertiary-color);
  color: #fff;
}
.dropdown .dropdown-menu .dropdown-item .form-check-input {
  box-shadow: none !important;
}
.dropdown .dropdown-menu .dropdown-item .form-check-label {
  margin: 0;
}

.modal-content {
  -webkit-border-radius: 1.25rem;
  -moz-border-radius: 1.25rem;
  border-radius: 1.25rem;
  border: 0;
}
.modal-content .modal-title {
  color: var(--primary-color);
}
.modal-content .modal-body {
  color: var(--secondary-color);
}

.modal-title h5 {
  margin-bottom: 0;
  font-size: calc(1.3rem + 0.6vw);
  line-height: var(--bs-modal-title-line-height);
}

.modal-body .message {
  text-align: left !important;
}

#table-search {
  padding-top: 0.6875rem;
  padding-bottom: 0.8125rem;
  padding-left: 0;
  padding-right: 0.75rem;
  font-size: 0.75rem;
}
#table-search:focus {
  border-color: var(--secondary-color);
}

.list-counter {
  color: var(--secondary-color);
}
.list-counter::before {
  content: "|";
  margin-left: 1rem;
  margin-right: 1rem;
}

table.custom-table {
  width: 100% !important;
  border-collapse: separate;
  border-spacing: 0px 8px;
  margin: 2rem 0 0;
}
table.custom-table tr[data-url] {
  cursor: pointer;
}
table.custom-table thead td:first-child, table.custom-table thead th:first-child, table.custom-table tbody td:first-child, table.custom-table tbody th:first-child {
  padding-left: 1.375rem;
  -webkit-border-top-left-radius: 0.625rem;
  -webkit-border-bottom-left-radius: 0.625rem;
  -moz-border-radius-topleft: 0.625rem;
  -moz-border-radius-bottomleft: 0.625rem;
  border-top-left-radius: 0.625rem;
  border-bottom-left-radius: 0.625rem;
}
table.custom-table thead td:last-child, table.custom-table thead th:last-child, table.custom-table tbody td:last-child, table.custom-table tbody th:last-child {
  padding-right: 1.375rem;
  -webkit-border-top-right-radius: 0.625rem;
  -webkit-border-bottom-right-radius: 0.625rem;
  -moz-border-radius-topright: 0.625rem;
  -moz-border-radius-bottomright: 0.625rem;
  border-top-right-radius: 0.625rem;
  border-bottom-right-radius: 0.625rem;
}
table.custom-table thead td:last-child i, table.custom-table thead th:last-child i, table.custom-table tbody td:last-child i, table.custom-table tbody th:last-child i {
  min-width: 1.25rem;
}
table.custom-table thead {
  color: var(--primary-color) !important;
  font-size: 0.75rem;
}
table.custom-table thead th {
  font-weight: 600;
  vertical-align: middle;
  height: 2rem !important;
  line-height: 1.2;
}
table.custom-table tbody tr:hover td, table.custom-table tbody tr:active td, table.custom-table tbody tr.table-primary td {
  background-color: var(--tertiary-color);
  color: #fff;
}
table.custom-table tbody td {
  font-size: 0.75rem;
  padding: 8px 0px;
  vertical-align: middle;
  background-color: #f9f9fc;
  color: var(--secondary-color);
  height: 4.25rem !important;
}

.dtfh-floatingparent {
  background: #fff !important;
}

.datatable-actions .btn {
  padding: 0.25rem !important;
  padding-bottom: 0.375rem !important;
}

table.formset-table thead th {
  font-weight: 700;
  color: var(--info-color);
  font-size: 0.75rem;
}

@media screen and (max-width: 991px) {
  .datatable-search-container {
    width: 100%;
  }
  .datatable-actions {
    padding-right: 0.4rem !important;
    text-align: right;
  }
  .datatable-actions .btn {
    padding: 0.2rem !important;
    padding-bottom: 0.37rem !important;
  }
}
.banner #back-btn {
  margin: 0px 1rem;
  text-decoration: none;
  color: var(--secondary-color);
}

.nav.inner-nav {
  background-color: #f9f9fc;
  -webkit-border-radius: 0.625rem;
  -moz-border-radius: 0.625rem;
  border-radius: 0.625rem;
  padding: 0 2rem;
}
.nav.inner-nav .nav-link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3.125rem;
  font-weight: 600;
  color: var(--secondary-color);
  font-size: 0.875rem;
  position: relative;
}
.nav.inner-nav .nav-link.active {
  color: var(--tertiary-color);
}
.nav.inner-nav .nav-link.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.15625rem;
  height: 0.3125rem;
  background-color: var(--tertiary-color);
  -webkit-border-radius: 0.15625rem;
  -moz-border-radius: 0.15625rem;
  border-radius: 0.15625rem;
}

@media screen and (max-width: 768px) {
  .nav.inner-nav {
    padding: 0 1rem;
  }
  .nav.inner-nav .nav-item {
    width: 50%;
  }
}
.detail-label {
  font-size: 0.75rem;
  letter-spacing: -0.015rem;
  font-weight: 700;
  color: var(--secondary-color);
}

.detail-text {
  font-size: 0.875rem;
  letter-spacing: -0.0175rem;
  color: var(--secondary-color);
}

hr.content-separator {
  opacity: 1;
  height: 0.03125rem;
  background-color: #e8e9f3;
}

.whatsapp-color {
  color: #25D366 !important;
}

.whatsapp-bg {
  background-color: #25D366 !important;
}

.bg-blue {
  background-color: #4bace9;
}

.axa-color {
  color: #003187;
}

.axa-bg {
  background-color: #003187 !important;
}

.solo-title {
  min-height: 2.75rem;
  margin-bottom: 2rem;
}

.video-js .vjs-big-play-button {
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%);
}

.video-js .vjs-play-progress {
  background-color: var(--primary-color);
}

.video-js .vjs-load-progress div {
  background: rgba(var(--primary-color), 0.3);
}

@media screen and (max-width: 768px) {
  .client-banner .client-info {
    font-size: 0.75rem;
  }
}
.course-container .img-container {
  position: relative;
}
.course-container .img-container .course-category {
  position: absolute;
  top: 0;
  right: 0;
  color: #fff;
  background-color: var(--primary-color);
  font-family: "PlusJakartaSans", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
  -webkit-border-top-right-radius: 0.3125rem;
  -moz-border-radius-topright: 0.3125rem;
  border-top-right-radius: 0.3125rem;
  -webkit-border-bottom-left-radius: 0.3125rem;
  -moz-border-radius-bottomleft: 0.3125rem;
  border-bottom-left-radius: 0.3125rem;
}
.course-container .card.sticky-top {
  top: 2rem;
}
.course-container .module-lessons .badge {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.course-card {
  position: relative;
}
.course-card .course-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 12.5rem;
}
.course-card .course-category {
  position: absolute;
  top: 0;
  right: 0;
  color: #fff;
  background-color: var(--primary-color);
  font-family: "PlusJakartaSans", sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
  -webkit-border-top-right-radius: 0.3125rem;
  -moz-border-radius-topright: 0.3125rem;
  border-top-right-radius: 0.3125rem;
  -webkit-border-bottom-left-radius: 0.3125rem;
  -moz-border-radius-bottomleft: 0.3125rem;
  border-bottom-left-radius: 0.3125rem;
}

.profile-pic {
  width: 6.25rem;
  height: 6.25rem;
  background-color: var(--tertiary-color);
  color: #fff;
  -webkit-border-radius: 0.625rem;
  -moz-border-radius: 0.625rem;
  border-radius: 0.625rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin-right: 2rem;
}

.comment-container .profile-pic {
  width: 3.125rem;
  height: 3.125rem;
  font-size: 1rem;
  margin-right: 1rem;
}
.comment-container .comment-text {
  font-size: 0.85rem;
}
