/** 
* Generic styles
*/
.float-right {
  float: right;
}

@media (min-width: 768px) {
    .half-width-on-large-viewports {
        width: 50%;
    }
}

/**
* Padding
*/
.padding-t25 {
  padding-top: 25px;
}

.padding-b0-important {
  padding-bottom: 0px !important;
}

.padding-b25 {
  padding-bottom: 25px;
}

@media (max-width: 768px) {
    .padding-t45-on-large-viewports {
        padding-top: 45px;
    }
}


/**
* Margin
*/
.margin-t15 {
  margin-top: 15px;
}

/**
* Button
*/
.btn-link {
  color: #0D6EFD;
  text-decoration: underline;
  line-height: 0.5;
}

/**
* Spinner
*/
@keyframes spinner {
  to {transform: rotate(360deg);}
}
 
.spinner:before {
  content: '';
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin-top: -10px;
  margin-left: -10px;
  border-radius: 50%;
  border: 2px solid #ccc;
  border-top-color: #333;
  animation: spinner .6s linear infinite;
}