.form-group {
  display: block;
  margin-bottom: 25px;
  position: relative; }
  .form-group label {
    color: #000;
    font-weight: 600; }
  .form-group .form-control {
    background: #fff;
    border: 1px solid #cccccc;
    border-radius: 5px;
    box-shadow: none;
    color: #000;
    padding: 8px 15px;
    position: relative;
    text-align: left;
    text-decoration: none;
    vertical-align: middle;
    width: 100%; }
    .form-group .form-control::-webkit-input-placeholder {
      -webkit-transition: opacity 0.2s ease-in-out;
      transition: opacity 0.2s ease-in-out;
      color: #000;
      opacity: 0.5; }
      .prefers-reduced-motion .form-group .form-control::-webkit-input-placeholder {
        -webkit-transition: none;
        transition: none; }
    .form-group .form-control:-moz-placeholder {
      -moz-transition: opacity 0.2s ease-in-out;
      transition: opacity 0.2s ease-in-out;
      color: #000;
      opacity: 0.5; }
      .prefers-reduced-motion .form-group .form-control:-moz-placeholder {
        -moz-transition: none;
        transition: none; }
    .form-group .form-control::-moz-placeholder {
      -moz-transition: opacity 0.2s ease-in-out;
      transition: opacity 0.2s ease-in-out;
      color: #000;
      opacity: 0.5; }
      .prefers-reduced-motion .form-group .form-control::-moz-placeholder {
        -moz-transition: none;
        transition: none; }
    .form-group .form-control:-ms-input-placeholder {
      -ms-transition: opacity 0.2s ease-in-out;
      transition: opacity 0.2s ease-in-out;
      color: #000;
      opacity: 0.5; }
      .prefers-reduced-motion .form-group .form-control:-ms-input-placeholder {
        -ms-transition: none;
        transition: none; }
    .form-group .form-control:focus {
      border-color: #b3b3b3; }
    .form-group .form-control:disabled {
      background-color: #cccccc;
      cursor: default;
      opacity: 0.5; }
      .form-group .form-control:disabled::-moz-placeholder {
        opacity: 0.5; }
      .form-group .form-control:disabled::placeholder {
        opacity: 0.5; }
  .form-group .password-toggle .toggle-icon {
    transition: none;
    background-color: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
    padding: 0;
    margin: 0;
    line-height: 1; }
    .prefers-reduced-motion .form-group .password-toggle .toggle-icon {
      transition: none; }
    .form-group .password-toggle .toggle-icon:hover, .form-group .password-toggle .toggle-icon:focus {
      background-color: transparent; }
    .form-group .password-toggle .toggle-icon:before {
      content: "\f144";
      font-family: "icons" !important;
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      display: inline-block;
      vertical-align: middle;
      line-height: 1;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale; }
  .form-group .password-toggle.show .toggle-icon:before {
    content: "\f143";
    font-family: "icons" !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }
  .form-group textarea.form-control {
    min-height: 90px; }
  .form-group .select-container {
    position: relative; }
    .form-group .select-container select {
      -webkit-appearance: none;
         -moz-appearance: none;
              appearance: none; }
      .form-group .select-container select::-ms-expand {
        display: none; }
      .form-group .select-container select:disabled {
        cursor: default;
        color: rgba(0, 0, 0, 0.5); }
      .form-group .select-container select option {
        font-family: Arial, "Helvetica Neue", Helvetica, sans-serif;
        color: #000; }
    .form-group .select-container .form-control {
      padding-right: 45px; }
    .form-group .select-container:after {
      content: "\f10f";
      font-family: "icons" !important;
      font-style: normal;
      font-weight: normal;
      font-variant: normal;
      text-transform: none;
      display: inline-block;
      vertical-align: middle;
      line-height: 1;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      right: 15px;
      pointer-events: none; }
      .form-group .select-container:after {
        font-size: 10px; }
  .form-group.error input[type="text"],
  .form-group.error input[type="email"],
  .form-group.error input[type="tel"],
  .form-group.error input[type="password"],
  .form-group.error textarea,
  .form-group.error select {
    border-color: #f00; }
    .form-group.error input[type="text"]:focus,
    .form-group.error input[type="email"]:focus,
    .form-group.error input[type="tel"]:focus,
    .form-group.error input[type="password"]:focus,
    .form-group.error textarea:focus,
    .form-group.error select:focus {
      border-color: #f00; }
  .form-group.error label {
    color: #f00; }
  .form-group.error .invalid-feedback {
    display: block; }
  .form-group.error .choices-inner {
    border-color: #f00; }
  .form-group.error .choices-dropdown input[type="text"] {
    border-color: inherit; }
  .form-group .help-text {
    color: #333333;
    display: block;
    font-size: 12px;
    margin-top: 10px; }
  .form-group .invalid-feedback {
    display: none;
    color: #f00;
    font-size: 12px;
    margin-top: 2px; }

.form-check input[type="radio"],
.form-check input[type="checkbox"] {
  cursor: pointer;
  position: relative;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none; }
  .form-check input[type="radio"]::-ms-check,
  .form-check input[type="checkbox"]::-ms-check {
    display: none; }
  .form-check input[type="radio"] + label,
  .form-check input[type="checkbox"] + label {
    position: relative;
    display: inline-block;
    padding-left: 20px; }
    body.editing-layout .form-check input[type="radio"] + label, body.editing-layout
    .form-check input[type="checkbox"] + label {
      padding-left: 0; }
  .form-check input[type="radio"] + label:before,
  .form-check input[type="radio"]:checked + label:after,
  .form-check input[type="checkbox"] + label:before,
  .form-check input[type="checkbox"]:checked + label:after {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0; }
    .form-check input[type="radio"] + label:before,
    .form-check input[type="radio"]:checked + label:after,
    .form-check input[type="checkbox"] + label:before,
    .form-check input[type="checkbox"]:checked + label:after {
      font-size: 16px; }
  .form-check input[type="radio"]:focus,
  .form-check input[type="checkbox"]:focus {
    box-shadow: none; }
  .is-tabbing .form-check input[type="radio"]:focus + label:before, .is-tabbing
  .form-check input[type="radio"]:checked:focus + label:before, .is-tabbing
  .form-check input[type="checkbox"]:focus + label:before, .is-tabbing
  .form-check input[type="checkbox"]:checked:focus + label:before {
    box-shadow: 0 0 0 0.2rem #5e9ed6;
    outline: 0 !important;
    transition: box-shadow 0.25s ease-in-out; }
    .prefers-reduced-motion .is-tabbing .form-check input[type="radio"]:focus + label:before, .prefers-reduced-motion .is-tabbing
    .form-check input[type="radio"]:checked:focus + label:before, .prefers-reduced-motion .is-tabbing
    .form-check input[type="checkbox"]:focus + label:before, .prefers-reduced-motion .is-tabbing
    .form-check input[type="checkbox"]:checked:focus + label:before {
      transition: none; }
  .form-check input[type="radio"][type="checkbox"]:not(:checked) + label:before,
  .form-check input[type="checkbox"][type="checkbox"]:not(:checked) + label:before {
    content: "\f114";
    font-family: "icons" !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }
  .form-check input[type="radio"][type="checkbox"]:checked + label:after,
  .form-check input[type="checkbox"][type="checkbox"]:checked + label:after {
    color: #000;
    content: "\f113";
    font-family: "icons" !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }
  body.editing-layout .form-check input[type="radio"][type="checkbox"]:not(:checked) + label:before, body.editing-layout
  .form-check input[type="checkbox"][type="checkbox"]:not(:checked) + label:before {
    content: ""; }
  body.editing-layout .form-check input[type="radio"][type="checkbox"]:checked + label:after, body.editing-layout
  .form-check input[type="checkbox"][type="checkbox"]:checked + label:after {
    content: ""; }
  .form-check input[type="radio"][type="radio"]:not(:checked) + label:before,
  .form-check input[type="checkbox"][type="radio"]:not(:checked) + label:before {
    content: "\f12b";
    font-family: "icons" !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }
  .form-check input[type="radio"][type="radio"]:checked + label:after,
  .form-check input[type="checkbox"][type="radio"]:checked + label:after {
    color: #000;
    content: "\f12a";
    font-family: "icons" !important;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }
  .form-check input[type="radio"]:disabled,
  .form-check input[type="checkbox"]:disabled {
    cursor: default; }
    .form-check input[type="radio"]:disabled + label,
    .form-check input[type="checkbox"]:disabled + label {
      opacity: 0.5; }

.form-check.error input[type="radio"],
.form-check.error input[type="checkbox"] {
  border-color: #f00; }
  .form-check.error input[type="radio"]:checked + label:after,
  .form-check.error input[type="checkbox"]:checked + label:after {
    color: #f00; }

.form-check.error label {
  color: #f00; }

.input-group {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  position: relative;
  width: 100%; }
  .input-group .form-control {
    flex: 1 1 auto;
    margin-bottom: 0;
    position: relative;
    width: 1%; }
    .input-group .form-control:not(:first-child) {
      border-bottom-left-radius: 0;
      border-top-left-radius: 0; }
    .input-group .form-control:not(:last-child) {
      border-bottom-right-radius: 0;
      border-top-right-radius: 0; }
  .input-group-text {
    /* empty */ }
  .input-group-prepend, .input-group-append {
    align-items: center;
    background-color: #f2f2f2;
    border: 1px solid #cccccc;
    display: flex;
    justify-content: center;
    padding: 0 10px; }
  .input-group-prepend {
    border-radius: 5px 0 0 5px;
    border-right: 0; }
  .input-group-append {
    border-left: 0;
    border-radius: 0 5px 5px 0; }

[data-toggle="buttons"] {
  position: relative;
  display: inline-flex;
  vertical-align: middle; }
  [data-toggle="buttons"] > label {
    margin: 0;
    position: relative;
    font-weight: 400; }
    [data-toggle="buttons"] > label input[type="radio"],
    [data-toggle="buttons"] > label input[type="checkbox"] {
      position: absolute;
      clip: rect(0, 0, 0, 0);
      pointer-events: none; }
    [data-toggle="buttons"] > label:not(:first-child) {
      border-top-left-radius: 0;
      border-bottom-left-radius: 0;
      margin-left: -1px; }
    [data-toggle="buttons"] > label:not(:last-child) {
      border-top-right-radius: 0;
      border-bottom-right-radius: 0; }

.search-form {
  background-color: #1e2028;
  color: #fff;
  margin-bottom: 25px; }
  .search-form .container-fluid, .search-form .container {
    position: relative; }
  .search-form .hero-banner-heading {
    color: #fff; }
  .search-form input[name='keys'] {
    border: none;
    height: 60px;
    padding: 20px 25px;
    border-radius: 38px;
    background-color: #ededed; }
  .search-form > .container {
    display: grid;
    grid-template-columns: 1fr auto; }
    .search-form > .container fieldset {
      grid-column-start: 1;
      grid-column-end: -1;
      grid-row-start: 1;
      grid-row-end: 1; }
    .search-form > .container #edit-actions, .search-form > .container #edit-submit-search, .search-form > .container #edit-actions .btn {
      grid-column-start: 2;
      grid-column-end: -1;
      grid-row-start: 1;
      grid-row-end: 1;
      z-index: 1;
      align-self: center;
      margin-left: -10px;
      border-radius: 50% 50%; }
    .search-form > .container #edit-actions .btn {
      height: 48px;
      width: 48px;
      border-radius: 50%;
      margin: 0;
      position: relative;
      left: -10px; }
      .search-form > .container #edit-actions .btn:after {
        content: "\f12d";
        font-family: "icons" !important;
        font-style: normal;
        font-weight: normal;
        font-variant: normal;
        text-transform: none;
        display: inline-block;
        vertical-align: middle;
        line-height: 1;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
    .search-form > .container #edit-submit-search {
      background-color: #1e2028;
      color: #fff; }
