.form-control {
  display: block;
  width: 100%;
  padding: .825rem 1.1875rem;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.2;
  color: #27282a;
  background-color: #fff0;
  background-clip: padding-box;
  border: 1px solid rgb(39 40 42 / .3);
  appearance: none;
  border-radius: 4px;
  transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media(prefers-reduced-motion:reduce) {
  .form-control {
    transition: none
  }
}

.form-control[type=file] {
  overflow: hidden
}

.form-control[type=file]:not(:disabled):not([readonly]) {
  cursor: pointer
}

.form-control:focus {
  color: #27282a;
  background-color: #fff0;
  border-color: #cae8a4;
  outline: 0;
  box-shadow: 0 0 0 0 rgb(149 208 73 / .25)
}

.form-control::-webkit-date-and-time-value {
  height: 1.2em
}

.form-control::placeholder {
  color: rgb(39 40 42 / .3);
  opacity: 1
}

.form-control:disabled,
.form-control[readonly] {
  background-color: rgb(39 40 42 / .3);
  opacity: 1
}

.form-control::file-selector-button {
  padding: .825rem 1.1875rem;
  margin: -.825rem -1.1875rem;
  margin-inline-end: 1.1875rem;
  color: #27282a;
  background-color: #fff0;
  pointer-events: none;
  border-color: inherit;
  border-style: solid;
  border-width: 0;
  border-inline-end-width: 1px;
  border-radius: 0;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media(prefers-reduced-motion:reduce) {
  .form-control::file-selector-button {
    transition: none
  }
}

.form-control:hover:not(:disabled):not([readonly])::file-selector-button {
  background-color: rgb(0 0 0 / .05)
}

.form-control::-webkit-file-upload-button {
  padding: .825rem 1.1875rem;
  margin: -.825rem -1.1875rem;
  margin-inline-end: 1.1875rem;
  color: #27282a;
  background-color: #fff0;
  pointer-events: none;
  border-color: inherit;
  border-style: solid;
  border-width: 0;
  border-inline-end-width: 1px;
  border-radius: 0;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

@media(prefers-reduced-motion:reduce) {
  .form-control::-webkit-file-upload-button {
    transition: none
  }
}

.form-control:hover:not(:disabled):not([readonly])::-webkit-file-upload-button {
  background-color: rgb(0 0 0 / .05)
}

.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%
}

.input-group>.form-control,
.input-group>.form-select {
  position: relative;
  flex: 1 1 auto;
  width: 1%;
  min-width: 0
}

.input-group>.form-control:focus,
.input-group>.form-select:focus {
  z-index: 3
}

.input-group .btn {
  position: relative;
  z-index: 2
}

.input-group .btn:focus {
  z-index: 3
}

.input-group-text {
  display: flex;
  align-items: center;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.2;
  color: #27282a;
  text-align: center;
  white-space: nowrap;
  background-color: #fff0;
  border: 1px solid rgb(39 40 42 / .3);
  border-radius: 0px
}

.input-group-lg>.form-control,
.input-group-lg>.form-select,
.input-group-lg>.input-group-text,
.input-group-lg>.btn {
  padding: 1.0625rem 1.4375rem;
  font-size: 1.25rem;
  border-radius: 1.875rem
}

.input-group-sm>.form-control,
.input-group-sm>.form-select,
.input-group-sm>.input-group-text,
.input-group-sm>.btn {
  padding: .5875rem .9375rem;
  font-size: 1rem;
  border-radius: 1.25rem
}

.input-group-lg>.form-select,
.input-group-sm>.form-select {
  padding-right: 4.75rem
}

.input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu),
.input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0
}

.input-group.has-validation>:nth-last-child(n+3):not(.dropdown-toggle):not(.dropdown-menu),
.input-group.has-validation>.dropdown-toggle:nth-last-child(n+4) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0
}

.input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
  margin-left: -1px;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0
}

.radio-number-group {
  display: flex
}


.radio-number,
.radio-text {
  position: relative
}


.radio-text {
  width: 48%
}


.radio-text>input,
.radio-number>input {
  position: absolute;
  top: 50%;
  left: 50%;
  opacity: 0;
  cursor: pointer;
  font-weight: 700
}


.radio-text>label.radio-label,
.radio-number>label.radio-label {
  cursor: pointer;
  text-align: center;
  background: #fff0;
  border: 2px solid #9E9E9E;
  font-weight: 700
}


.radio-number>label.radio-label {
  width: 50px;
  height: 50px;
  display: block;
  border-radius: 50%;
  font-size: 1.5rem;
  line-height: 48px;
  padding: 0
}


.radio-text>label.radio-label {
  width: 100%;
  padding: .825rem 1rem;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.2
}


.radio-text>label.radio-label {
  font-size: .85em;
  overflow: hidden
}


.radio-text>label.disabled {
  color: #d0d0d0;
  border-color: #d0d0d0 !important;
  background: #f8f8f8
}


.radio-number input:checked+label.radio-label,
.radio-text input:checked+label.radio-label {
  background: #023a51;
  color: #fff;
  border-color: rgb(0 0 0 / .3)
}


.radio-number input:checked+label.radio-label>.text-dark-2,
.radio-text input:checked+label.radio-label>.text-dark-2 {
  color: rgb(255 255 255 / .8) !important
}

.w-4 {
  width: 33.333333% !important
}

.fill-dark-3 {
  fill: rgb(39 40 42 / .3);
}

.bg-dark-3 {
  background: rgb(39 40 42 / .1);
}

.input-group.has-error input,
.form-group.has-error input,
.has-error .input-group .input-group-text,
.has-error .radio-group .radio-text .radio-label {
  border-color: var(--bs-red) !important
}

label.error {
  color: #dd3446;
  font-size: 75%;
  width: 100%
}

[type="submit"] .btn-loader {
  display: none
}

.disabled[type="submit"] .btn-label {
  display: none
}

.disabled[type="submit"] .btn-loader {
  display: flex;
  align-items: center;
  justify-content: center;
}


.btn-submit {
  font-weight: 700;
  line-height: 26px;
  text-transform: uppercase;
  background-color: var(--insur-base);
  font-size: 16px;
  padding: 10px;
  letter-spacing: 0.1em;
}

.btn:disabled,.btn.disabled {
    pointer-events: none;
    opacity: .65
}