/*
 * Syntactig sugar for border radius defintion
 */
/*
 * Media queries for various sizes based on S/M/L value
 */
/*
 * Generates a keyframe entry for all browser based on the given argument and content
 */
/*
 * Generates the standard animation properties based on the given arguments
 */
/*
 * Applies the given tranformation using both standard and browser prefix
 */
/*
 * Generates a float clear after the given element
 */
#missing-fields {
  display: none;
  text-align: center;
  color: var(--palette-8);
}
#missing-fields.active {
  display: block !important;
}
#missing-fields i {
  color: var(--palette-10);
}

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

.form-control:focus {
  border-color: --main-background-color-lighten;
  box-shadow: 0 0 0 0.2rem --main-background-color-lighten3f;
}

label {
  font-size: 0.8rem;
  color: #9e9e9e;
  margin-bottom: 0.25rem;
}

.bebsi-button {
  background-color: var(--main-color) !important;
  border-color: rgba(0, 0, 0, 0) !important;
}
.bebsi-button:hover, .bebsi-button:focus, .bebsi-button:active {
  background: var(--main-color) !important;
  border-color: var(--main-color-darker) !important;
  box-shadow: 0 8px 25px -8px var(--main-color) !important;
}

.form-control, .input-group-text {
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
  border-radius: 0px;
}

.fieldsContainer {
  padding: 0px !important;
}

.recordField {
  height: 75px;
}
.recordField.label-only {
  height: 15px;
}

.checkbox {
  padding-top: 25px;
}
.checkbox label {
  vertical-align: middle;
  color: #444;
  line-height: 1rem;
}

.select2-container--focus {
  border: none !important;
  border-bottom: 1px solid --main-background-color-lighten !important;
  box-shadow: 0 0 0 0.2rem --main-background-color-lighten3f;
  border-radius: 0px !important;
}

.select2-selection {
  border: none !important;
  border-bottom: 1px solid #ced4da !important;
  border-radius: 0px !important;
  height: 34px !important;
}
.select2-selection .select2-selection__rendered {
  line-height: 34px !important;
}
.select2-selection .select2-selection__choice {
  font-size: 0.8rem !important;
  background-color: white !important;
  line-height: 200%;
  margin-top: 3px !important;
  border-color: #e4e4e4 !important;
}

.select2-results__option .coupleEntry {
  margin: 5px 0px;
}

input[type=checkbox]:focus-visible {
  outline: 1px solid var(--main-color-darker) !important;
}

.input-field input, .input-field textarea {
  border: none;
  border-bottom: 1px solid #ced4da !important;
  padding-left: 8px;
}
.input-field textarea.invalid {
  border: 1px solid var(--palette-8) !important;
}

.select2-selection:focus-visible {
  outline: none;
}

.field-invalid .form-control, .field-invalid .select2-selection {
  border-bottom-color: var(--palette-8) !important;
}

.bootstrap-datetimepicker-widget {
  position: fixed;
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: none !important;
  padding-left: 0px !important;
  margin: 0px !important;
  background: rgba(0, 0, 0, 0.4) !important;
}
.bootstrap-datetimepicker-widget::before, .bootstrap-datetimepicker-widget::after {
  display: none !important;
}
.bootstrap-datetimepicker-widget a {
  color: #808080 !important;
}
.bootstrap-datetimepicker-widget table td, .bootstrap-datetimepicker-widget table th {
  border: none !important;
  padding: 0.75rem !important;
}
.bootstrap-datetimepicker-widget table td.today::before, .bootstrap-datetimepicker-widget table th.today::before {
  border-bottom-color: var(--main-background-color) !important;
}
.bootstrap-datetimepicker-widget table td.active, .bootstrap-datetimepicker-widget table th.active {
  background: var(--main-background-color) !important;
}
.bootstrap-datetimepicker-widget table td.active::before, .bootstrap-datetimepicker-widget table th.active::before {
  border-bottom-color: #fff !important;
}
.bootstrap-datetimepicker-widget .list-unstyled {
  width: 90%;
  position: fixed;
  left: 50%;
  top: calc(50% + 25px);
  transform: translateX(-50%) translateY(-50%);
  background: white;
}
@media only screen and (min-width: 768px) {
  .bootstrap-datetimepicker-widget .list-unstyled {
    width: calc(500px - 5rem);
    left: calc(50% + 100px);
    top: 50%;
  }
}
.bootstrap-datetimepicker-widget .list-unstyled::after {
  display: none !important;
}
.bootstrap-datetimepicker-widget .list-unstyled::before {
  width: 100%;
  left: 0px;
  top: -50px;
  height: 50px;
  background: var(--main-background-color);
  content: "";
  position: absolute;
}
@media only screen and (min-width: 768px) {
  .bootstrap-datetimepicker-widget .list-unstyled::before {
    width: 200px;
    left: -200px;
    height: 100%;
    top: 0px;
  }
}
.bootstrap-datetimepicker-widget .list-unstyled .timepicker td {
  padding: 0px !important;
}
.bootstrap-datetimepicker-widget .date-display {
  position: absolute;
  top: -50px;
  left: 10px;
  line-height: 46px;
  color: white;
}
@media only screen and (min-width: 768px) {
  .bootstrap-datetimepicker-widget .date-display {
    top: 20px;
    left: -180px;
    line-height: initial;
  }
}
.bootstrap-datetimepicker-widget .date-display .year-display {
  font-size: 1.8rem;
  display: block;
  float: right;
  padding-left: 5px;
}
@media only screen and (min-width: 768px) {
  .bootstrap-datetimepicker-widget .date-display .year-display {
    float: unset;
    padding-left: initial;
  }
}
.bootstrap-datetimepicker-widget .date-display .day-display {
  font-size: 1.8rem;
}

fieldset .card-title {
  display: inline-block;
}
fieldset .help-icon.group {
  display: inline-block;
  margin-left: 10px;
}
fieldset .help-icon.group img {
  width: 20px;
  cursor: help;
  padding-bottom: 10px;
}

.fieldsContainer.row .recordField.input-field .help-icon {
  position: absolute;
  right: 15px;
  top: 27px;
}
.fieldsContainer.row .recordField.input-field .help-icon img {
  width: 25px;
  cursor: help;
}

.input-group.invalid {
  border: 1px solid var(--palette-8) !important;
}

.input-field.invalid .select2 {
  border: 1px solid var(--palette-8) !important;
}
.input-field.invalid .select2 input {
  border: none !important;
}

.input-field.invalid > input {
  border: 1px solid var(--palette-8) !important;
}

.required label:after {
  content: " *";
}

.select2 input {
  border: none !important;
}

#server-error {
  color: var(--palette-8);
  text-align: center;
  display: none;
}

/*
 * Syntactig sugar for border radius defintion
 */
/*
 * Media queries for various sizes based on S/M/L value
 */
/*
 * Generates a keyframe entry for all browser based on the given argument and content
 */
/*
 * Generates the standard animation properties based on the given arguments
 */
/*
 * Applies the given tranformation using both standard and browser prefix
 */
/*
 * Generates a float clear after the given element
 */
.lds-ellipsis {
  display: inline-block;
  position: relative;
  width: 80px;
  height: 80px;
}
@keyframes lds-ellipsis1 {
  0% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes lds-ellipsis3 {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(0);
  }
}
@keyframes lds-ellipsis2 {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(24px, 0);
  }
}
.lds-ellipsis div {
  position: absolute;
  top: 15px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  animation-timing-function: cubic-bezier(0, 1, 1, 0);
}
.lds-ellipsis div:nth-child(1) {
  left: 8px;
  animation: lds-ellipsis1 0.6s infinite;
}
.lds-ellipsis div:nth-child(2) {
  left: 8px;
  animation: lds-ellipsis2 0.6s infinite;
}
.lds-ellipsis div:nth-child(3) {
  left: 32px;
  animation: lds-ellipsis2 0.6s infinite;
}
.lds-ellipsis div:nth-child(4) {
  left: 56px;
  animation: lds-ellipsis3 0.6s infinite;
}

.fade-in {
  animation-duration: 1s;
  animation-name: fadeIn;
  animation-fill-mode: forwards;
  animation-direction: forwards;
  animation-timing-function: ease;
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-moz-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-ms-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.tada {
  animation-duration: 1s;
  animation-name: tada;
  animation-fill-mode: forwards;
  animation-direction: forwards;
  animation-timing-function: ease;
}

@-webkit-keyframes tada {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
  3%, 7% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }
  10%, 17%, 23%, 30% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }
  13%, 20%, 27% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }
  33% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}
@-moz-keyframes tada {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
  3%, 7% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }
  10%, 17%, 23%, 30% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }
  13%, 20%, 27% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }
  33% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}
@-ms-keyframes tada {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
  3%, 7% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }
  10%, 17%, 23%, 30% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }
  13%, 20%, 27% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }
  33% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}
@keyframes tada {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
  3%, 7% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }
  10%, 17%, 23%, 30% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }
  13%, 20%, 27% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -moz-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }
  33% {
    -webkit-transform: scale3d(1, 1, 1);
    -moz-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}
.bounce-in {
  visibility: visible;
  animation-duration: 0.6s;
  animation-name: cd-bounce-1;
  animation-fill-mode: forwards;
  animation-direction: forwards;
  animation-timing-function: ease;
}

@-webkit-keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
    -moz-transform: scale(0.5);
    -ms-transform: scale(0.5);
    transform: scale(0.5);
  }
  60% {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-moz-keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
    -moz-transform: scale(0.5);
    -ms-transform: scale(0.5);
    transform: scale(0.5);
  }
  60% {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@-ms-keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
    -moz-transform: scale(0.5);
    -ms-transform: scale(0.5);
    transform: scale(0.5);
  }
  60% {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes cd-bounce-1 {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
    -moz-transform: scale(0.5);
    -ms-transform: scale(0.5);
    transform: scale(0.5);
  }
  60% {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}
.flexer, .progress-indicator {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
}

.no-flexer, .progress-indicator.stacked {
  display: block;
}

.no-flexer-element {
  -ms-flex: 0;
  -webkit-flex: 0;
  -moz-flex: 0;
  flex: 0;
}

.flexer-element, .progress-indicator > li {
  -ms-flex: 1;
  -webkit-flex: 1;
  -moz-flex: 1;
  flex: 1;
}

.progress-indicator {
  margin: 0;
  padding: 0;
  font-size: 80%;
  text-transform: uppercase;
  margin-bottom: 1em;
}
.progress-indicator > li {
  list-style: none;
  text-align: center;
  width: auto;
  padding: 0;
  margin: 0;
  position: relative;
  text-overflow: ellipsis;
  color: #bbb;
  display: block;
}
.progress-indicator > li:hover {
  color: rgb(110.5, 110.5, 110.5);
}
.progress-indicator > li .bubble {
  border-radius: 1000px;
  width: 20px;
  height: 20px;
  background-color: #bbb;
  display: block;
  margin: 0 auto 0.5em auto;
  border-bottom: 1px solid #888888;
}
.progress-indicator > li .bubble:before,
.progress-indicator > li .bubble:after {
  display: block;
  position: absolute;
  top: calc(20px / 2 - 1px);
  width: 100%;
  height: 3px;
  content: "";
  background-color: #bbb;
}
.progress-indicator > li .bubble:before {
  left: 0;
}
.progress-indicator > li .bubble:after {
  right: 0;
}
.progress-indicator > li:first-child .bubble:before,
.progress-indicator > li:first-child .bubble:after {
  width: 50%;
  margin-left: 50%;
}
.progress-indicator > li:last-child .bubble:before,
.progress-indicator > li:last-child .bubble:after {
  width: 50%;
  margin-right: 50%;
}
.progress-indicator > li.completed {
  color: #86bc42;
}
.progress-indicator > li.completed .bubble {
  background-color: #86bc42;
  color: #86bc42;
  border-color: rgb(53.2834645669, 74.7559055118, 26.2440944882);
}
.progress-indicator > li.completed .bubble:before, .progress-indicator > li.completed .bubble:after {
  background-color: #86bc42;
  border-color: rgb(53.2834645669, 74.7559055118, 26.2440944882);
}
.progress-indicator > li.active {
  color: rgb(80.188976378, 112.5039370079, 39.4960629921);
}
.progress-indicator > li.active .bubble {
  background-color: rgb(80.188976378, 112.5039370079, 39.4960629921);
  color: rgb(80.188976378, 112.5039370079, 39.4960629921);
  border-color: hsl(86.5573770492, 48.031496063%, -0.1960784314%);
}
.progress-indicator > li.active .bubble:before, .progress-indicator > li.active .bubble:after {
  background-color: rgb(80.188976378, 112.5039370079, 39.4960629921);
  border-color: hsl(86.5573770492, 48.031496063%, -0.1960784314%);
}
.progress-indicator > li a:hover .bubble {
  background-color: #5671d0;
  color: #5671d0;
  border-color: rgb(30.6805555556, 48.3055555556, 110.3194444444);
}
.progress-indicator > li a:hover .bubble:before, .progress-indicator > li a:hover .bubble:after {
  background-color: #5671d0;
  border-color: rgb(30.6805555556, 48.3055555556, 110.3194444444);
}
.progress-indicator > li.danger .bubble {
  background-color: #d3140f;
  color: #d3140f;
  border-color: rgb(68.1548672566, 6.4601769912, 4.8451327434);
}
.progress-indicator > li.danger .bubble:before, .progress-indicator > li.danger .bubble:after {
  background-color: #d3140f;
  border-color: rgb(68.1548672566, 6.4601769912, 4.8451327434);
}
.progress-indicator > li.warning .bubble {
  background-color: #edb10a;
  color: #edb10a;
  border-color: rgb(90.1943319838, 67.3603238866, 3.8056680162);
}
.progress-indicator > li.warning .bubble:before, .progress-indicator > li.warning .bubble:after {
  background-color: #edb10a;
  border-color: rgb(90.1943319838, 67.3603238866, 3.8056680162);
}
.progress-indicator > li.info .bubble {
  background-color: #5b32d6;
  color: #5b32d6;
  border-color: rgb(37, 18.5, 92.5);
}
.progress-indicator > li.info .bubble:before, .progress-indicator > li.info .bubble:after {
  background-color: #5b32d6;
  border-color: rgb(37, 18.5, 92.5);
}
.progress-indicator.stacked > li {
  text-indent: -10px;
  text-align: center;
  display: block;
}
.progress-indicator.stacked > li .bubble:before,
.progress-indicator.stacked > li .bubble:after {
  left: 50%;
  margin-left: calc(3px / -2);
  width: 3px;
  height: 100%;
}
.progress-indicator.stacked .stacked-text {
  position: relative;
  z-index: 10;
  top: 0;
  margin-left: 60% !important;
  width: 45% !important;
  display: inline-block;
  text-align: left;
  line-height: 1.2em;
}
.progress-indicator.stacked > li a {
  border: none;
}
.progress-indicator.stacked.nocenter > li .bubble {
  margin-left: 0;
  margin-right: 0;
}
.progress-indicator.stacked.nocenter > li .bubble:before,
.progress-indicator.stacked.nocenter > li .bubble:after {
  left: calc(20px / 2);
}
.progress-indicator.stacked.nocenter .stacked-text {
  width: auto !important;
  display: block;
  margin-left: 40px !important;
}
.progress-indicator span.number {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  color: white;
  top: 0px;
}

@media screen and (max-width: 400px) {
  .progress-indicator {
    font-size: 60%;
  }
}
/*
 * Syntactig sugar for border radius defintion
 */
/*
 * Media queries for various sizes based on S/M/L value
 */
/*
 * Generates a keyframe entry for all browser based on the given argument and content
 */
/*
 * Generates the standard animation properties based on the given arguments
 */
/*
 * Applies the given tranformation using both standard and browser prefix
 */
/*
 * Generates a float clear after the given element
 */
.family-view .validation-failure {
  color: red;
  margin-left: 50%;
  transform: translateX(-50%);
  text-align: center;
}
.family-view .members-list {
  display: flex;
  justify-content: center;
}
.family-view .members-list .family-member .portrait {
  font-size: 80px;
  width: 160px;
  height: 160px;
  line-height: 160px;
  text-align: center;
  background: #e7e7e7;
  border-radius: 50%;
  margin-left: 50%;
  transform: translateX(-50%);
  color: var(--main-color);
}
.family-view .members-list .family-member .portrait .remove-member {
  position: absolute;
  right: 0;
  top: 0;
  height: 30px;
  width: 30px;
  background-color: red;
  border: 1px solid red;
  border-radius: 15px;
  font-size: 18px;
  font-family: monospace;
  font-style: normal;
  line-height: 30px;
  font-weight: bold;
  color: #ffffff;
  user-select: none;
  cursor: pointer;
}
@media only screen and (min-width: 768px) {
  .family-view .members-list .family-member .portrait .remove-member {
    display: none;
  }
}
.family-view .members-list .family-member .portrait.invalid {
  border: 2px solid red;
}
.family-view .members-list .family-member .member-role {
  text-align: center;
  font-family: LemonMilk;
  font-size: 12px;
  color: #86bc42;
  position: absolute;
  margin-left: 50%;
  transform: translateX(-100%);
  top: 20px;
}
.family-view .members-list .family-member .member-title {
  text-align: center;
  padding: 20px;
  color: var(--main-color);
}
@media only screen and (min-width: 768px) {
  .family-view .members-list .family-member:hover .remove-member {
    display: block;
  }
}

/*
 * Syntactig sugar for border radius defintion
 */
/*
 * Media queries for various sizes based on S/M/L value
 */
/*
 * Generates a keyframe entry for all browser based on the given argument and content
 */
/*
 * Generates the standard animation properties based on the given arguments
 */
/*
 * Applies the given tranformation using both standard and browser prefix
 */
/*
 * Generates a float clear after the given element
 */
.initial-request-list-view .validation-failure {
  color: red;
  margin-left: 50%;
  transform: translateX(-50%);
  text-align: center;
}
.initial-request-list-view .initial-request-list {
  display: flex;
  justify-content: center;
}
.initial-request-list-view .initial-request-list .initial-request .portrait {
  font-size: 80px;
  width: 160px;
  height: 160px;
  line-height: 160px;
  text-align: center;
  background: #e7e7e7;
  border-radius: 50%;
  margin-left: 50%;
  transform: translateX(-50%);
  color: var(--main-color);
}
.initial-request-list-view .initial-request-list .initial-request .portrait .remove-request {
  position: absolute;
  right: 0;
  top: 0;
  height: 30px;
  width: 30px;
  background-color: red;
  border: 1px solid red;
  border-radius: 15px;
  font-size: 18px;
  font-family: monospace;
  font-style: normal;
  line-height: 30px;
  font-weight: bold;
  color: #ffffff;
  user-select: none;
  cursor: pointer;
}
@media only screen and (min-width: 768px) {
  .initial-request-list-view .initial-request-list .initial-request .portrait .remove-request {
    display: none;
  }
}
.initial-request-list-view .initial-request-list .initial-request .request-title {
  text-align: center;
  padding: 20px;
  color: var(--main-color);
}
@media only screen and (min-width: 768px) {
  .initial-request-list-view .initial-request-list .initial-request:hover .remove-request {
    display: block;
  }
}

.subscribe-container, .subscribe-container-footer {
  text-align: initial;
}

.subscribe-container {
  height: 100%;
}
.subscribe-container h2 {
  color: var(--main-background-color);
}
.subscribe-container h2.main-title {
  text-align: center;
}
.subscribe-container .logo {
  width: 250px;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.subscribe-container .next-page-holder {
  height: 100px;
  position: relative;
}
.subscribe-container .next-page-holder .next-btn {
  right: 30px;
}
.subscribe-container .next-page-holder .prev-btn {
  left: 0px;
}
.subscribe-container .next-page-holder .family-back-btn {
  left: 0px;
  display: none;
}
.subscribe-container .next-page-holder .request-back-btn {
  left: 0px;
  display: none;
}
.subscribe-container #subscribe-panel {
  width: 100%;
  height: 100%;
  z-index: 2;
  background-color: var(--portal-card-color);
}
.subscribe-container #subscribe-panel #fixed-logo {
  position: initial;
  width: 200px;
  margin-left: 50%;
  transform: translateX(-50%);
}
.subscribe-container .missing-required {
  color: red;
  padding: 0px 0px 20px 0px;
}
.subscribe-container .sainet-validation-errors {
  color: red;
  padding: 0px 0px 20px 0px;
}

#almost-done-panel {
  padding: 20px;
}
#almost-done-panel .subtitle {
  padding: 20px;
  font-size: 15px;
}
#almost-done-panel .g-recaptcha {
  display: inline-block;
  margin-left: 50%;
  transform: translateX(-50%);
  margin-top: 50px;
}
#almost-done-panel .buttons-holder {
  height: 100px;
  position: relative;
}
#almost-done-panel .buttons-holder .next-btn {
  right: 30px;
}
#almost-done-panel .buttons-holder .prev-btn {
  left: 0px;
}
#almost-done-panel .success-buttons-holder {
  height: 100px;
  margin-top: 100px;
}
#almost-done-panel .success-buttons-holder .next-btn {
  right: 30px;
}
#almost-done-panel .failure {
  font-weight: bold;
  margin: 15px 0;
  color: #FF0000;
}
#almost-done-panel .failure .reason {
  display: block;
}

#welcome-panel {
  padding: 20px;
}
#welcome-panel .subtitle {
  margin-top: 20px;
}
#welcome-panel .creche-selection-label {
  margin-top: 20px;
  margin-bottom: 20px;
}
#welcome-panel .buttons-holder {
  height: 100px;
}
#welcome-panel .buttons-holder .next-btn {
  right: 30px;
}
#welcome-panel .buttons-holder.center {
  text-align: center;
}
#welcome-panel .buttons-holder.center #startSubscription {
  transform: translateX(-50%);
}
#welcome-panel .error-message {
  color: red;
  padding: 20px;
}

label {
  white-space: nowrap;
}
label input[type=checkbox] + span {
  vertical-align: top;
  color: #444;
  line-height: 1rem;
}

h2.main-title, h2.card-title {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

.d-flex {
  align-items: flex-start !important;
}

.btn.btn-primary {
  position: absolute;
}

.submit-output-message {
  padding: 20px;
  font-weight: bold;
}

table.pages-results {
  margin: 0 20px;
}
table.pages-results td {
  padding: 0px 20px 10px 0px;
}

.upload-button {
  position: absolute;
  top: 30px;
  right: 0px;
  font-size: 1.3em;
  background-color: white;
}

.uploaded-files {
  margin-top: 5px;
}
.uploaded-files .uploaded-file-item {
  background-color: var(--main-background-color);
  color: white;
  border-radius: 12px;
  padding: 2px 10px 2px 5px;
  user-select: none;
  display: inline-block;
  margin: 1px;
}
.uploaded-files .uploaded-file-item .fa-times-circle {
  margin-right: 5px;
  cursor: pointer;
}

.upload-error {
  color: red;
  margin: 5px;
  font-weight: bold;
}

.upload-button-label {
  position: absolute;
  left: 10px;
  top: 20px;
  font-size: 14px;
  color: white;
  padding: 5.25px 10px;
  border-radius: 3.5px;
  cursor: pointer;
  border: 1px solid transparent;
  z-index: 2;
}

input[type=file] {
  opacity: 0;
}

.field-loading {
  position: absolute;
  left: 0;
  top: 0%;
  font-size: 25px;
  width: 100%;
  height: 100%;
  z-index: 10;
  background: rgba(0, 0, 0, 0.04);
}
.field-loading .spinner-holder {
  position: relative;
  left: 50%;
  top: 50%;
  width: 25px;
  height: 25px;
  transform: translate(-50%, -50%);
}
.field-loading .spinner-holder i {
  -webkit-animation: spin 2s linear infinite;
  -moz-animation: spin 2s linear infinite;
  animation: spin 2s linear infinite;
}

@-moz-keyframes spin {
  100% {
    -moz-transform: rotate(180deg);
  }
}
@-webkit-keyframes spin {
  100% {
    -webkit-transform: rotate(180deg);
  }
}
@keyframes spin {
  100% {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
}
.backdrop {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.2);
}
.backdrop .loader {
  top: 200px;
  left: 50%;
  position: absolute;
  border: 16px solid #f3f3f3;
  border-top: 16px solid var(--main-color);
  border-radius: 50%;
  width: 120px;
  height: 120px;
  animation: spin 2s linear infinite;
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.form-comment {
  border: 1px solid #e7e7e7;
  border-radius: 5px;
  padding: 5px;
  background-color: #e7e7e7;
}

.panel-comment {
  border: 1px solid #e7e7e7;
  border-radius: 5px;
  padding: 5px;
  background-color: #e7e7e7;
  margin-bottom: 20px;
}

/*# sourceMappingURL=subscribe.css.map */
