.font-montserrat-light{
  font-family: 'Montserrat-light';
}
.font-montserrat-bold{
  font-family: 'Montserrat-bold';
}
.dm-sans{
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
}

.btn-primary {
  color: #fff;
  background-color: #332e87;
  border-color: #332e87
}

.btn-primary:hover {
  color: #fff;
  background-color: #23205e;
  border-color: #1e1b5f
}

.btn-check:focus+.btn-primary, .btn-primary:focus {
  color: #fff;
  background-color: #23205e;
  border-color: #1e1b5f;
  box-shadow: 0 0 0 .25rem rgba(30, 27, 95, 0.466)
}

.btn-check:active+.btn-primary, .btn-check:checked+.btn-primary, .btn-primary.active, .btn-primary:active, .show>.btn-primary.dropdown-toggle {
  color: #fff;
  background-color: #1e1b5f;
  border-color: #1e1b5f
}

.btn-check:active+.btn-primary:focus, .btn-check:checked+.btn-primary:focus, .btn-primary.active:focus, .btn-primary:active:focus, .show>.btn-primary.dropdown-toggle:focus {
  box-shadow: 0 0 0 .25rem rgba(30, 27, 95, 0.466)
}

.btn-primary.disabled, .btn-primary:disabled {
  color: #fff;
  background-color: #332e87;
  border-color: #332e87
}

.text-primary {
  color: #332e87 !important
}

.text-opacity-hover:hover {
  opacity: .8;
}

.text-primary-underline-animation {
  cursor: pointer;
  position: relative;
}

.text-primary-underline-animation::after {
  content: "";
  height: 2px;
  width: 0;
  background-color: #332e87;

  text-align: center;
  position: absolute;
  left: 45%;
  bottom: 0;

  transition: all .5s ease;
}

.text-primary-underline-animation:hover {
  opacity: .8;
}

.text-primary-underline-animation:hover::after {
  left: 0;
  width: 100%;
  opacity: .8;
}

.text-grey{
  color: #908c8c !important;
}

.divider-row{
  height: 1px;
  background-color: #ddd;
}

/* width */
::-webkit-scrollbar {
  width: 10px !important;
}

/* Track */
::-webkit-scrollbar-track {
  background: #f1f1f1 !important;
}

/* Handle */
::-webkit-scrollbar-thumb {
  background: #332e87 !important;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #1e1b5f !important;
}

.mat-form-field-subscript-wrapper{
  font-size: 100%!important;
}

input:-internal-autofill-selected {
  background-image: none !important;
  background-color: inherit !important;
  color: inherit !important;
}

@-webkit-keyframes autofill {
  0%,100% {
      color: #666;
      background: transparent;
  }
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active  {
    -webkit-box-shadow: 0 0 0 30px white inset !important;
}

.dashboard-card {
  border: 1px solid lightgray;
  border-radius: 15px;
  padding: 1em;

  transition: .25s all ease-in;
}
.dashboard-card-focus {
  border-color: rgb(0, 132, 255);
  box-shadow: 0px 0px 5px rgb(0, 132, 255);
}
.dashboard-card-hover:hover {
  border-color: rgb(0, 132, 255);
  box-shadow: 0px 0px 5px rgb(0, 132, 255);
}

.title-beauty{
  background-color: #f2f8fe;
  color: #49607a;
  padding: 1rem 1.5rem;
}

.table-dashboard {
  width: 100%;
}
.table-dashboard thead tr th{
  text-align: center;
  border-right: 1px solid black;
  padding: 1rem 0;
}
.table-dashboard thead tr th:last-child{
  text-align: center;
  border-right: none;
  padding: 1rem 0;
}
.table-dashboard thead tr{
  border: 1px solid black;
}
.table-dashboard tbody tr{
  border-bottom: 1px solid black;
  border-left: 1px solid black;
  border-right: 1px solid black;
}
.table-dashboard tbody tr td{
  border-right: 1px solid black;
  padding: 1rem;
}
.table-dashboard tbody tr td:last-child{
  border-right: 1px solid none;
}

.origin-input:disabled{
  background-color: transparent;
}
.origin-input:focus{
  border: none;
  outline: none;
  box-shadow: none;
}
.origin-input{
  background-color: #f2f8fe;
  color: #49607a;
}

.cdk-drag-preview {
  box-sizing: border-box;
  border-radius: 4px;
  box-shadow: 0 5px 5px -3px rgba(0, 0, 0, 0.2),
              0 8px 10px 1px rgba(0, 0, 0, 0.14),
              0 3px 14px 2px rgba(0, 0, 0, 0.12);
}

.cdk-drag-placeholder {
  opacity: 0;
}

.cdk-drag-animating {
  transition: transform 250ms cubic-bezier(0, 0, 0.2, 1);
}

.example-box:last-child {
  border: none;
}

.drag-list.cdk-drop-list-dragging .drag-content:not(.cdk-drag-placeholder) {
  transition: transform 250ms cubic-bezier(0, 0, 0.2, 1);
}

.card-media{
  cursor: pointer;
  transition: all .5s ease;
}
.card-media:hover{
  border-color: #332e87;
  box-shadow: 0px 0px 5px #332e87;
}

.home-content-padding{
  padding-left: 6rem;
  padding-right: 6rem;
}
.home-content-margin{
  margin-left: 6rem;
  margin-right: 6rem;
}

.pontuacao {
  background-color: #4733ff;
  height: auto;
}

.home-review-width{
  width: calc(2rem + 25vw)!important;
}
.introduction-title{
  position: absolute; left: 17%; top: 28%; width: 30%;
}
.introduction-title-text{
  letter-spacing: 2px; font-size: 6rem; line-height: 1;
}
.mobile-show{
  display: none;
}
.tablet-show{
  display: none;
}
.partner-logo{
  height: 35px;
}
.loggin-padding{
  padding: 3rem 5rem;
}
.content-title{
  font-size: 3.5rem; line-height: 1;
}

@media only screen and (max-width: 1507px) {
  .loggin-padding{
    padding: 3rem 4rem;
  }
  .partner-logo{
    height: 27px;
  }
}
@media only screen and (max-width: 1198px) {
  .loggin-padding{
    padding: 3rem 4rem;
  }
  .partner-logo{
    height: 30px;
  }
}
@media only screen and (max-width: 1292px) {
  .introduction-title-text{
    font-size: 5rem;
  }
  .content-title{
    font-size: 2.7rem!important;
  }
}
@media only screen and (max-width: 1083px) {
  .introduction-title-text{
    font-size: 5rem;
  }
  .content-title{
    font-size: 2.3rem!important;
  }
}
@media only screen and (max-width: 1124px) {
  .introduction-title-text{
    font-size: 4.5rem;
  }
}
@media only screen and (max-width: 1124px) {
  .introduction-title-text{
    font-size: 4.2rem;
  }
}
video {
  width: 100% !important;
  height: auto !important;
}
@media only screen and (max-width: 442px) {
  .content-title{
    font-size: 2rem!important;
  }
}
.loading-text{
  width: 100%;
}
.logo-imagem-mobile{
  display: none;
}
@media only screen and (max-width: 637px) {
  .introduction-image-height{
    height: 250px !important;
  }
  .logo-imagem-mobile{
    display: inline-block;
  }
  .logo-imagem{
    display: none;
  }
}
@media only screen and (max-width: 547px) {
  .loading-text-remove{
    display: none;
  }
}
@media only screen and (max-width: 480px) {
  .loggin-padding{
    padding: 3em!important;
  }
}
@media only screen and (max-width: 991px) { /* Tablet */
  .tablet-text-center{
    text-align: center !important;
  }
  .content-title{
    font-size: 3.5rem; line-height: 1;
  }
  .introduction-image-height{
    height: 350px;
  }
  .loggin-padding{
    padding: 3rem 5rem;
  }
  .video-loading-text{
    font-size: 1rem!important;
  }
  .lesson{
    justify-content: center;
    text-align: center;
  }
  .col{
    flex: none;
  }
  .lesson-review{
    justify-content: center;
    text-align: center;
  }
  .home-review-width{
    width: 50% !important;
    margin: auto;
  }
  .lesson-img{
    width: 300px;
  }
  .tablet-hidden{
    display: none;
  }
  .tablet-show{
    display: block;
  }
  .tablet-title-center{
    position: relative;
    left: 0%; top: 0%;
    width: 100%; height: 100%;
    text-align: center;
    display: flex;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
  }
  .home-content-padding{
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .home-content-margin{
    margin-left: 2rem;
    margin-right: 2rem;
  }
  .partner-logo{
    height: 35px;
  }
  .partner-logo{
    margin-right: 15px;
  }
  .partner-logo:nth-last-child(){
    margin-right: 0px;
  }
}
@media only screen and (max-width: 575px) { /* Phone */
  .mobile-hidden{
    display: none;
  }
  .mobile-show{
    display: block;
  }
  .flex-column-mobile{
    flex-direction: column;
  }
  .partner-logo{
    height: 27px;
  }
  .video-loading-img{
    width: 30%;
  }
}
@media only screen and (max-width: 585px) {
  .home-review-width{
    width: 100%!important;
  }
  .video-loading-text{
    font-size: .6rem!important;
  }
  .content-title{
    font-size: 2.6rem!important;
  }
}
