.form .form-notify {
  display: none;
  margin-top: 0.15rem;
}
.form [data-rikit-class].error .form-notify,
.form [data-rikit-class].success .form-notify {
  display: block;
}
.form [data-rikit-class].error .form-notify {
  color: #e42d37;
}
.form .form-section-title {
  font-size: 0.18rem;
  margin-bottom: 0.23rem;
}
.form .form-section-list > *:not(last-child) {
  margin-bottom: 0.2rem;
}
.form fieldset {
  border: 0;
}
.form fieldset legend {
  font-size: 0.18rem;
  margin-bottom: 0.23rem;
}
.button {
  padding: 0.12rem 0.24rem;
  border-radius: 0.08rem;
  font-size: 0.15rem;
  text-decoration: none;
  cursor: pointer;
  -webkit-user-select: none;
          user-select: none;
  transition: background 0.2s, color 0.2s;
  border: none;
  background: #e3e3e3;
  color: #000;
  -webkit-tap-highlight-color: transparent;
}
@media (hover: hover) {
  .button:hover {
    background: #d3d1d1;
  }
}
.button:active {
  background: #c4c4c4;
}
.button:focus {
  background: #e3e3e3;
  outline: 0.03rem solid rgba(227, 227, 227, 0.3);
}
.button[disabled], .button.disabled {
  opacity: 0.3;
  pointer-events: none;
}
.button--big {
  padding: 0.16rem 0.32rem;
  font-size: 0.18rem;
}
.button--outline {
  background: none;
  border: 0.01rem solid #e3e3e3;
  color: #000;
}
.button--link {
  background: none;
  text-decoration: underline;
  padding: 0;
  border: none;
}
.button--link:active, .button--link:focus {
  background: none;
  outline: none;
}
@media (hover: hover) {
  .button--link:hover {
    background: none;
    text-decoration: none;
  }
}
.input label {
  display: block;
  font-size: 0.18rem;
  margin-bottom: 0.1rem;
}
.input label .required {
  color: red;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0; 
}
.input input[type=text],
.input input[type=email],
.input input[type=number],
.input input[type=password] {
  height: 0.48rem;
  min-width: 4.2rem;
  padding: 0 0.16rem;
  font-size: 0.16rem;
  border-radius: 0.04rem;
  border: 0.01rem solid #a7a7aa;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.input input[type=text]::placeholder,
.input input[type=email]::placeholder,
.input input[type=number]::placeholder,
.input input[type=password]::placeholder {
  color: #a7a7aa;
}
@media (hover: hover) {
  .input input[type=text]:hover,
  .input input[type=email]:hover,
  .input input[type=number]:hover,
  .input input[type=password]:hover {
    border-color: #0161d9;
  }
}
.input input[type=text]:focus,
.input input[type=email]:focus,
.input input[type=number]:focus,
.input input[type=password]:focus {
  outline: 0;
  box-shadow: 0 0 0 0.03rem rgba(1, 97, 217, 0.3);
  border-color: #a9a9a9;
}
.input input[type=checkbox],
.input input[type=radio] {
  display: none;
}
.input input[type=checkbox] + label,
.input input[type=radio] + label {
  display: flex;
  align-items: center;
  -moz-column-gap: 0.08rem;
       column-gap: 0.08rem;
  font-size: 0.15rem;
  margin-bottom: 0;
  -webkit-user-select: none;
          user-select: none;
}
.input input[type=checkbox] + label:before,
.input input[type=radio] + label:before {
  content: "";
  display: block;
  flex: none;
  height: 0.2rem;
  width: 0.2rem;
  border: 0.01rem solid #979797;
}
.input input[type=checkbox]:checked + label,
.input input[type=radio]:checked + label {
  font-weight: bold;
}
.input input[type=checkbox]:checked + label:before,
.input input[type=radio]:checked + label:before {
  border-color: #0161d9;
}
.input input[type=checkbox] + label:before {
  border-radius: 0.04rem;
}
.input input[type=checkbox]:checked + label:before {
  background-color: #0161d9;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzYgMzYiIHhtbDpzcGFjZT0icHJlc2VydmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgMzYgMzYiPjxnIGlkPSJpY29ucyI+PHBhdGggZD0ibTEyLjggMjguNy05LjUtOS41Yy0uNC0uNC0uNC0xLjEgMC0xLjZsMS41LTEuNWMuNC0uNCAxLjEtLjQgMS42IDBsNy4yIDcuMiAxNi0xNmMuNC0uNCAxLjEtLjQgMS42IDBsMS41IDEuNWMuNC40LjQgMS4xIDAgMS42TDE0LjQgMjguN2MtLjUuNC0xLjIuNC0xLjYgMHoiIGlkPSJjaGVja194NUZfbWFya18xXyIgZmlsbD0iI2ZmZmZmZiIgY2xhc3M9ImZpbGwtMjIyYTMwIj48L3BhdGg+PC9nPjwvc3ZnPg==);
  background-size: 80%;
  background-repeat: no-repeat;
  background-position: center;
}
.input input[type=radio] + label:before {
  border-radius: 50%;
}
.input input[type=radio]:checked + label:before {
  background: radial-gradient(circle closest-side, #0161d9 0.05rem, white 0.05rem);
}
.input .form-notify {
  margin-top: 0.1rem;
  font-size: 0.16rem;
  display: none;
}
.input.error label,
.input.error .form-notify {
  color: #e42d37;
}
.input.error input::placeholder {
  color: #eaa0a4;
}
.input.error input {
  border: 0.01rem solid #e42d37 !important;
}
.input.error .form-notify {
  display: block;
}

@media screen and (max-width: 719px) {
  .input input[type=text],
  .input input[type=email],
  .input input[type=number],
  .input input[type=password] {
    min-width: auto;
    width: 100%;
  }
}
.select.error label,
.select.error .form-notify {
  color: #e42d37;
}
.select.error select::placeholder {
  color: #eaa0a4;
}
.select.error select {
  border-color: #e42d37 !important;
  border: 0.01rem solid #e42d37 !important;

}
.select.error .form-notify {
  display: block;
}
.select label {
  display: block;
  font-size: 0.18rem;
  margin-bottom: 0.1rem;
}
.select label .required {
  color: red;
}
.select select {
  height: 0.48rem;
  min-width: 4.2rem;
  padding: 0px 0.16rem;
  font-size: 0.16rem;
  border-radius: 0.04rem;
  border: 0.01rem solid #a7a7aa;
  transition: border-color 0.2s, box-shadow 0.2s;
  background-color: #fff;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzIgMzIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTE2IDIxYTEgMSAwIDAgMS0uNzEtLjI5bC04LThhMSAxIDAgMSAxIDEuNDItMS40Mmw3LjI5IDcuMyA3LjI5LTcuM2ExIDEgMCAwIDEgMS40MiAxLjQybC04IDhBMSAxIDAgMCAxIDE2IDIxWiIgZGF0YS1uYW1lPSJMYXllciAyIiBmaWxsPSIjYTdhN2FhIiBjbGFzcz0iZmlsbC0wMDAwMDAiPjwvcGF0aD48cGF0aCBkPSJNMCAwaDMydjMySDB6IiBmaWxsPSJub25lIj48L3BhdGg+PC9zdmc+);
  background-repeat: no-repeat;
  background-position: right 0.05rem center;
  background-size: 0.3rem;
  -webkit-appearance: none;
          appearance: none;
  cursor: pointer;
  color: #000;
}
.select select::placeholder {
  color: #a7a7aa;
}
@media (hover: hover) {
  .select select:hover {
    border-color: #0161d9;
  }
}
.select select:focus {
  outline: 0;
  box-shadow: 0 0 0 0.03rem rgba(1, 97, 217, 0.3);
  border-color: #a9a9a9;
}
.select .form-notify {
  margin-top: 0.1rem;
  font-size: 0.16rem;
  display: none;
}

@media screen and (max-width: 719px) {
  .select select {
    min-width: auto;
    width: 100%;
  }
}
.textarea.error label,
.textarea.error .form-notify {
  color: #e42d37;
}
.textarea.error textarea::placeholder {
  color: #eaa0a4;
}
.textarea.error textarea {
  border-color: #e42d37;
}
.textarea.error .form-notify {
  display: block;
}
.textarea label {
  display: block;
  font-size: 0.18rem;
  margin-bottom: 0.1rem;
}
.textarea label .required {
  color: red;
}
.textarea textarea {
  min-height: 1.44rem;
  min-width: 4.2rem;
  padding: 0.16rem;
  font-size: 0.16rem;
  line-height: 1.45em;
  border-radius: 0.04rem;
  border: 0.01rem solid #a7a7aa;
  transition: border-color 0.2s, box-shadow 0.2s;
  resize: vertical;
}
.textarea textarea::placeholder {
  color: #a7a7aa;
}
@media (hover: hover) {
  .textarea textarea:hover {
    border-color: #0161d9;
  }
}
.textarea textarea:focus {
  outline: 0;
  box-shadow: 0 0 0 0.03rem rgba(1, 97, 217, 0.3);
  border-color: #a9a9a9;
}
.textarea .form-notify {
  margin-top: 0.1rem;
  font-size: 0.16rem;
  display: none;
}

@media screen and (max-width: 719px) {
  .textarea textarea {
    min-width: auto;
    width: 100%;
  }
}
.switch {
  display: flex;
  -moz-column-gap: 0.12rem;
       column-gap: 0.12rem;
}
.switch input {
  width: 0.5rem;
  height: 0.26rem;
  border-radius: 0.2rem;
  -webkit-appearance: none;
          appearance: none;
  background-color: #f5f5f7;
  position: relative;
  transition: background 0.2s;
}
.switch input:before {
  content: "";
  display: block;
  height: 0.2rem;
  width: 0.2rem;
  background: #0161d9;
  border-radius: 50%;
  position: absolute;
  left: 0.03rem;
  top: 0.03rem;
  transition: background 0.2s, left 0.2s;
}
.switch input:checked {
  background: #0161d9;
}
.switch input:checked:before {
  left: 27px;
  background: #f5f5f7;
}
.switch input:focus {
  outline: 0;
  box-shadow: 0 0 0 0.03rem rgba(1, 97, 217, 0.3);
}
.switch input[disabled] {
  pointer-events: none;
  opacity: 0.5;
}
.switch label {
  -webkit-user-select: none;
          user-select: none;
  margin-top: 0.03rem;
}
.switch label span {
  display: block;
  margin-top: 0.05rem;
}

.switch--text {
  max-width: -moz-fit-content;
  max-width: fit-content;
}
.switch--text input {
  -webkit-appearance: none;
          appearance: none;
  opacity: 0;
  outline: 0;
}
.switch--text input:checked + label:before {
  background: none;
  color: #000;
}
.switch--text input:checked + label:after {
  background: #0161d9;
  color: #fff;
}
.switch--text input[disabled] + label {
  pointer-events: none;
  opacity: 0.5;
}
.switch--text label {
  display: flex;
  height: 0.4rem;
  padding: 0.03rem;
  background: #f5f5f7;
  border-radius: 0.2rem;
}
.switch--text label:before, .switch--text label:after {
  content: "";
  display: block;
  padding: 0.06rem 0.12rem;
  font-size: 0.14rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.2rem;
  transition: background 0.2s, color 0.2s;
}
.switch--text label:before {
  content: attr(data-text-title-1) " " attr(data-text-1);
  background: #0161d9;
  color: #fff;
}
.switch--text label:after {
  content: attr(data-text-title-2) " " attr(data-text-2);
}
[anim-effect=top] {
  transform: translate(0, -1.2rem);
  opacity: 0;
  transition: transform ease 0.5s, opacity ease 0.5s;
}
[anim-effect=top].anim-reveal {
  transform: translate(0, 0);
  opacity: 1;
}

[anim-effect=bottom] {
  transform: translate(0, 1.2rem);
  opacity: 0;
  transition: transform ease 0.5s, opacity ease 0.5s;
}
[anim-effect=bottom].anim-reveal {
  transform: translate(0, 0);
  opacity: 1;
}

[anim-effect=right] {
  transform: translate(100%, 0);
  opacity: 0;
  transition: 0.5s transform ease, opacity ease 0.5s;
}
[anim-effect=right].anim-reveal {
  transform: translate(0, 0);
  opacity: 1;
}

[anim-effect=left] {
  transform: translate(-100%, 0);
  opacity: 0;
  transition: 0.5s transform ease, opacity ease 0.5s;
}
[anim-effect=left].anim-reveal {
  transform: translate(0, 0);
  opacity: 1;
}

[anim-effect=fade] {
  opacity: 0;
  transition: 1s all ease 0.3s;
}
[anim-effect=fade].anim-reveal {
  opacity: 1;
}

.cookies {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #F7F7F7;
  margin: 0;
  padding: 0;
  z-index: 10;
}
.cookies.show {
  display: block;
}
.cookies-block {
  width: 100%;
  max-width: 1200px;
  padding: 20px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  min-height: 80px;
}
.cookies-info-hide.hide {
  display: none;
}
.cookies-buttons {
  display: flex;
  gap: 20px;
}
