@charset "UTF-8";
:root { --dark-grey: #393939; --light-blue: #18aef8; --regular-text: 22px; }

.more-text { display: block; max-height: 0; overflow: hidden; -webkit-transition: max-height 0.5s ease; transition: max-height 0.5s ease; }
.more-text.show { max-height: 1000px; }

.dots.hidden { display: none; }

.swiper__body { display: block; max-height: 0; overflow: hidden; opacity: 0; -webkit-transition: max-height 0.4s ease, opacity 0.3s ease; transition: max-height 0.4s ease, opacity 0.3s ease; }

.swiper__body.open { max-height: -webkit-max-content; max-height: -moz-max-content; max-height: max-content; opacity: 1; }

.footer { display: none; }

.toggle-btn { display: -webkit-inline-box; display: -ms-inline-flexbox; display: inline-flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; gap: 6px; cursor: pointer; margin-top: 10px; text-decoration: none; color: #000; }

body { margin: 0; padding: 0; }

main .container { padding: 0 8px; margin: 0 auto; }

@media (min-width: 575px) { main .container { max-width: 540px; } }
@media (min-width: 721px) { main .container { max-width: 720px; } }
@media (min-width: 993px) { main .container { max-width: 720px; } }
@media (min-width: 1201px) { main .container { max-width: 720px; } }
.out-of-header { background: #222222; color: #fff; font-family: "Nunito", sans-serif; overflow-x: hidden; padding: 114px 0 100px; position: relative; }
.out-of-header::before, .out-of-header::after { content: ""; height: clamp(100px, 20vw, 280px); min-width: 700px; position: absolute; width: 100%; top: 0px; }
.out-of-header::before { background: url(../img/stars.svg) repeat-x; background-size: contain; }
.out-of-header::after { background: -webkit-gradient(linear, left top, left bottom, color-stop(-17.31%, #000), to(rgba(0, 0, 0, 0))); background: linear-gradient(180deg, #000 -17.31%, rgba(0, 0, 0, 0) 100%); background-size: contain; }

main * { -webkit-box-sizing: border-box; box-sizing: border-box; margin: 0; padding: 0; }
main section { margin: 76px 0; }
main ul { margin: 0; padding: 0; display: grid; gap: 8px; }
main ul li { background: var(--dark-grey); list-style-type: none; font-size: 16px; font-style: normal; font-weight: 300; line-height: 110%; margin: 0; padding: 4px 0 5px 22px; position: relative; }
main ul li:first-child::before, main ul li::before { background: var(--light-blue); content: ""; position: absolute; width: 8px; height: 100%; left: 0; top: 0 !important; }
main ul li:first-child, main ol li:first-child { padding: 4px 0 5px 22px; }
main h1 { font-size: 32px; font-style: normal; font-weight: 800; line-height: 120%; text-transform: uppercase; }
main h2 { color: var(--light-blue); font-size: 32px; font-style: normal; font-weight: 700; line-height: 110%; margin: 0 0 22px; text-transform: uppercase; }
main h3 { color: var(--light-blue); font-size: 22px; font-style: normal; font-weight: 700; line-height: 110%; margin: 0 0 22px; }
main h4 { font-size: 16px; font-style: normal; font-weight: 700; line-height: 110%; margin: 32px 0 22px; }
main p { font-size: 16px; font-style: normal; font-weight: 400; line-height: 110%; }
main a { text-decoration: none; }
main .litle { font-size: clamp(12px, 2vw, 16px); width: 95%; text-align: center; margin: 1em 0; }
main .offerta { color: #fff; display: block; font-size: clamp(16px, 2vw, 32px); margin: 0 auto; text-align: center; text-decoration: underline; width: -webkit-max-content; width: -moz-max-content; width: max-content; }
main .landing-btn { background: var(--light-blue); border-radius: 12px; color: #fff; display: block; font-size: 14px; font-style: normal; font-weight: 800; line-height: normal; letter-spacing: 0.28px; padding: 16px; text-align: center; text-transform: uppercase; }
main .transparent-btn { background: transparent; border: 1px solid #fff; margin-top: 6px; }
main .welcome { margin: 0 0 76px; position: relative; }
main .welcome-text { position: relative; z-index: 1; }
main .visual { position: relative; }
main .visual img { -webkit-transform: translateX(-50%); transform: translateX(-50%); margin: -5em 0 0 55%; width: 550px; }
main .company { display: grid; position: relative; margin: 0 -15px; padding: 1px 10px; }
main .company ul { margin: 2em 0; }
main .company ul li::before { background: #fff; border-radius: 50%; height: 8px; top: 9px !important; width: 8px; }
main .company-text { border-radius: 32px 32px 0px 0px; background: var(--dark-grey); padding: 50px 8px 0; grid-area: 1/1; z-index: 1; }
main .company::before { border-radius: 32px 32px 0px 0px; background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(transparent)); background: linear-gradient(180deg, #fff, transparent); content: ""; left: 50%; top: 50%; position: absolute; -webkit-transform: translateX(-50%) translateY(-50%); transform: translateX(-50%) translateY(-50%); height: 100%; width: calc(100% - 15px); z-index: 0; }
main .company-img { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: end; -ms-flex-pack: end; justify-content: end; margin-right: -10px; }
main .company-img img { width: 78vw; }
main .company h2 { color: inherit; margin: 0 0 12px; }
main .about-blocks { display: grid; gap: 8px 4px; grid-template-columns: 1fr 1fr; }
main .about-block { position: relative; }
main .about-block::before { border-radius: 22px; background: -webkit-gradient(linear, left bottom, left top, from(#fff), color-stop(77%, transparent)); background: linear-gradient(0deg, #fff, transparent 77%); content: ""; left: 50%; top: 50%; position: absolute; -webkit-transform: translateX(-50%) translateY(-50%); transform: translateX(-50%) translateY(-50%); height: 100%; width: 100%; z-index: 0; }
main .about-block img { width: 30px; }
main .about-block:first-child { grid-column: 1 / -1; }
main .about-block:first-child img { width: 44px; }
main .about-text { background: var(--dark-grey); border-radius: 22px; display: grid; height: 98%; gap: 44px; margin: 1.5px; padding: 16px; position: relative; z-index: 1; }
main .swiper { padding-bottom: 2em; }
main .swiper img { margin-left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); width: 100%; position: relative; z-index: 2; }
main .swiper-text { position: relative; }
main .swiper-text::before { position: absolute; background: -webkit-gradient(linear, left bottom, left top, from(#fff), color-stop(85%, transparent)); background: linear-gradient(0deg, #fff, transparent 85%); content: ""; top: 50%; left: 50%; -webkit-transform: translateX(-50%) translateY(-50%); transform: translateX(-50%) translateY(-50%); width: calc(100% - 7px); height: 100.6%; z-index: 0; border-radius: 0px 0px 16px 16px; }
main .text-wrapper { background: #222222; border-radius: 0px 0px 16px 16px; padding: 3em 9px 22px; margin: -32px 5px 0; min-height: 300px; position: relative; z-index: 1; }
main .text-wrapper .to-anketa { color: #ffcc00; font-size: inherit; text-decoration: underline; }
main .options .swiper-pagination-bullet { background: #fff; width: 5px; height: 5px; }
main .options .swiper-pagination-bullet-active { border-radius: 12px; width: 15px; }
main .options .options__text { background: transparent; bottom: 1em; -webkit-box-shadow: none; box-shadow: none; color: #ffcc00; cursor: pointer; margin: 16px 0 0; min-height: 24px; padding: 0; position: absolute; -webkit-transition: color 0.5s ease; transition: color 0.5s ease; width: 100%; }
main .options .options__text::after { background: url(../img/show-arrow.svg) no-repeat; background-size: contain; content: ""; height: 20px; right: 22px; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); -webkit-transition: -webkit-transform 0.5s ease; transition: -webkit-transform 0.5s ease; transition: transform 0.5s ease; transition: transform 0.5s ease, -webkit-transform 0.5s ease; position: absolute; width: 20px; }
main .options .options__text.rotated::after { -webkit-transform: translateY(-50%) rotateX(180deg); transform: translateY(-50%) rotateX(180deg); }
main .options .accordion__body { background: transparent; -webkit-box-shadow: none; box-shadow: none; display: none; padding: 1em 0 0; }
main .options .accordion__body ul li { padding-top: 4px; }
main .options .accordion__body * { font-size: 16px; line-height: 110%; }
main .info { background: #fff; border-radius: 16px; padding: 16px 8px; }
main .info h3 { color: #222; font-weight: 800; margin: 0; text-transform: uppercase; }
main .info p { color: #222; margin: 8px 0 22px; }
main .calculate h3 { color: inherit; margin: 0 0 16px; }
main .calculate .mb-3 { margin: 44px 0 32px; }
main .calculate .tab-block { -webkit-box-align: center; -ms-flex-align: center; align-items: center; background: var(--dark-grey); border-radius: 16px; display: -webkit-box; display: -ms-flexbox; display: flex; min-height: 42px; padding: 4px; text-align: center; }
main .calculate .tab-block .btn-outline-primary { -webkit-box-align: center; -ms-flex-align: center; align-items: center; background: transparent; border: none; color: #fff; display: -webkit-box; display: -ms-flexbox; display: flex; font-size: 12px; font-style: normal; font-weight: 400; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; line-height: 110%; min-height: 42px; min-width: 114px; opacity: 0.5; padding: 0px 18px; }
main .calculate .tab-block .btn-outline-primary.active { background: var(--light-blue); border: none; border-radius: 12px; -webkit-box-shadow: none; box-shadow: none; font-weight: 700; opacity: 1; padding: 8px 18px; }
main .calculate .btn-outline-primary:not(:disabled):not(.disabled).active:focus, main .calculate .btn-outline-primary:not(:disabled):not(.disabled):active:focus, main .calculate .show > .btn-outline-primary.dropdown-toggle:focus { -webkit-box-shadow: none; box-shadow: none; }
main .calculate .range-block { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; gap: 16px; }
main .calculate .range-block.mb-4 { gap: 25px; }
main .calculate .range-block + .range-block { margin-top: 32px; }
main .calculate .date-block { display: -webkit-box; display: -ms-flexbox; display: flex; gap: 32px; }
main .calculate .number { color: var(--light-blue); font-weight: 700; }
main .calculate .form-label { font-size: 16px; }
main .calculate .form-range { -webkit-appearance: none; -moz-appearance: none; appearance: none; border: none; border-radius: 3px; cursor: pointer; height: 6px; outline: none; -webkit-transition: background 0.3s ease; transition: background 0.3s ease; width: 100%; }
main .calculate .form-range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; background: white; border-radius: 50%; -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.4); box-shadow: 0 0 4px rgba(0, 0, 0, 0.4); height: 20px; position: relative; width: 20px; z-index: 2; }
main .calculate .form-range::-moz-range-thumb { background: white; border-radius: 50%; box-shadow: 0 0 4px rgba(0, 0, 0, 0.4); cursor: pointer; height: 20px; width: 20px; }
main .calculate .form-range::-moz-range-track { background: #bbb; border-radius: 3px; height: 6px; }
main .calculate .form-range::-moz-range-progress { background: var(--light-blue); border-radius: 3px; height: 6px; }
main .calculate .form-check { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; gap: 6px; }
main .calculate .form-check-input { display: none; }
main .calculate .form-check-label { cursor: pointer; font-size: 16px; padding-left: 26px; position: relative; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; }
main .calculate .form-check-label::before { -webkit-box-sizing: border-box; box-sizing: border-box; content: ""; position: absolute; top: 50%; left: 0; -webkit-transform: translateY(-50%); transform: translateY(-50%); width: 20px; height: 20px; border-radius: 50%; background: #fff; border: 1.5px solid #cdd2d8; -webkit-transition: border 0.2s ease; transition: border 0.2s ease; }
main .calculate .form-check-input:checked + .form-check-label::before { border: 6px solid var(--light-blue); }
main .calculate .income { border: 1px solid transparent; margin: 32px 0 0; position: relative; }
main .calculate .income-text { background: var(--dark-grey); border-radius: 22px; display: grid; gap: 16px; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; justify-items: center; margin: 1px; padding: 16px; position: relative; }
main .calculate .income::before { background: -webkit-gradient(linear, left bottom, left top, from(#fff), color-stop(77%, transparent)); background: linear-gradient(0deg, #fff, transparent 77%); border-radius: 22px; content: ""; height: 100%; position: absolute; left: 50%; top: 50%; -webkit-transform: translateX(-50%) translateY(-50%); transform: translateX(-50%) translateY(-50%); width: 100%; }
main .calculate .alert-success { background: transparent; border: none; color: inherit; font-size: 16px; margin: 0; padding: 0; }
main .calculate .form-check-input[type="radio"] { opacity: 0; position: absolute; width: 0; height: 0; }
main .anketa { display: grid; position: relative; margin: 0 -15px; padding: 1px 10px; /* Универсально отключает внешние украшения */ }
main .anketa h2 { color: #fff; font-size: 32px; }
main .anketa h4 { font-size: 24px; margin: 0; }
main .anketa h5 { color: var(--light-blue); font-size: 18px; font-style: normal; font-weight: 400; line-height: 122%; }
main .anketa-block { border-radius: 32px 32px 0px 0px; background: var(--dark-grey); padding: 50px 16px 88px; grid-area: 1/1; z-index: 1; }
main .anketa::before { border-radius: 32px 32px 0px 0px; background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(transparent)); background: linear-gradient(180deg, #fff, transparent 100%); content: ""; left: 50%; top: 50%; position: absolute; -webkit-transform: translateX(-50%) translateY(-50%); transform: translateX(-50%) translateY(-50%); height: 100%; width: calc(100% - 15px); z-index: 0; }
main .anketa .text { background: #fff; border-radius: 12px; border: 1px solid #222; color: #8a9fc9; font-family: Nunito; font-size: 14px; font-style: normal; line-height: 114%; min-height: 56px; padding: 0 24px; width: 100%; }
main .anketa .text::-webkit-input-placeholder { color: #8a9fc9; font-family: Nunito; font-size: 14px; font-style: normal; font-weight: 600; line-height: 114%; }
main .anketa .text:-ms-input-placeholder { color: #8a9fc9; font-family: Nunito; font-size: 14px; font-style: normal; font-weight: 600; line-height: 114%; }
main .anketa .text::-ms-input-placeholder { color: #8a9fc9; font-family: Nunito; font-size: 14px; font-style: normal; font-weight: 600; line-height: 114%; }
main .anketa .text::placeholder { color: #8a9fc9; font-family: Nunito; font-size: 14px; font-style: normal; font-weight: 600; line-height: 114%; }
main .anketa .text.error, main .anketa .text select.error { border: 1px solid red; }
main .anketa .text .error-msg { color: red; font-size: 13px; margin-top: 4px; display: block; }
main .anketa .input-block { display: grid; gap: 24px; }
main .anketa .input-block__item { display: grid; gap: 8px; }
main .anketa .check-block { -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; display: -webkit-box; display: -ms-flexbox; display: flex; grid-gap: 8px; }
main .anketa .check-block .check { accent-color: #fff; border: 1px solid #c4c5c5; background: #fff; border-radius: 5px; height: 24px; -ms-flex-negative: 0; flex-shrink: 0; width: 24px; }
main .anketa .check-block .check::before { left: 50%; top: 50%; -webkit-transform: translateX(-50%) translateY(-50%) rotate(45deg); transform: translateX(-50%) translateY(-50%) rotate(45deg); }
main .anketa .check-block p { font-size: 14px; line-height: 120%; }
main .anketa .check-block a { color: inherit; font-size: inherit; line-height: inherit; text-decoration: underline; }
main .anketa input[list]::-webkit-calendar-picker-indicator { display: none; opacity: 0; }
main .anketa input[list] { appearance: none; -webkit-appearance: none; -moz-appearance: none; }
main .anketa .input-wrapper { position: relative; }
main .anketa .input-wrapper .text { -webkit-appearance: none; -moz-appearance: none; appearance: none; width: 100%; padding-right: 30px; }
main .anketa .input-wrapper .text::-ms-expand { display: none; }
main .anketa .input-wrapper .text::-webkit-calendar-picker-indicator { display: none; -webkit-appearance: none; }
main .anketa .input-wrapper .arrow { position: absolute; right: 10px; top: 50%; width: 12px; height: 12px; -webkit-transform: translateY(-50%); transform: translateY(-50%); -webkit-transition: -webkit-transform 0.3s ease; transition: -webkit-transform 0.3s ease; transition: transform 0.3s ease; transition: transform 0.3s ease, -webkit-transform 0.3s ease; background: url("../img/input-arrow.svg") no-repeat center; background-size: contain; pointer-events: none; }
main .anketa .input-wrapper.active .arrow { -webkit-transform: translateY(-50%) rotateX(180deg); transform: translateY(-50%) rotateX(180deg); }
main .faq h3 { margin: 0; }
main .faq .accordion { margin: 0 0 8px 0; padding: 0px; position: relative; }
main .faq .accordion__text { background: var(--dark-grey); border: 1px solid #dce2e4; border-radius: 16px; -webkit-box-shadow: 0px 5px 25px rgba(43, 93, 168, 0.15); box-shadow: 0px 5px 25px rgba(43, 93, 168, 0.15); color: #fff; cursor: pointer; font-size: 16px; font-weight: normal; line-height: 100%; margin: 0; padding: 16px 32px 16px 16px; position: relative; z-index: 2; }
main .faq .accordion__text::after { background: url(../img/acc-arrow.svg) no-repeat; background-size: contain; content: ""; position: absolute; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); -webkit-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out; height: 8px; width: 12px; right: 16px; }
main .faq .accordion__text-opened::after { -webkit-transform: translateY(-50%) rotateX(180deg); transform: translateY(-50%) rotateX(180deg); }
main .faq .accordion__body { background: #fff; border-bottom-left-radius: 16px; border-bottom-right-radius: 16px; -webkit-box-shadow: 0px 5px 25px rgba(43, 93, 168, 0.15); box-shadow: 0px 5px 25px rgba(43, 93, 168, 0.15); display: none; padding: 30px 16px 16px; -webkit-transform: translateY(-15px); transform: translateY(-15px); z-index: 1; }
main .faq .accordion__body * { color: #111318; font-size: 14px; font-style: normal; line-height: 125%; }
main .diagramm { background: url(../img/visualDiagram.png) no-repeat; background-size: contain; position: absolute; height: clamp(43px, 20vw, 164px); right: -2.2em; top: 10em; width: clamp(61px, 20vw, 144px); z-index: 1; }

@media (max-width: 1023px) { .page { margin-top: 0; }
  .header__mobile-button path { stroke: #fff; }
  .header__main-link { color: #fff; -webkit-filter: brightness(0) invert(1); filter: brightness(0) invert(1); }
  #announceActive0 { background: transparent; -webkit-filter: brightness(0) invert(1); filter: brightness(0) invert(1); }
  .header__lang-switch { color: #fff; }
  .out-of-header { margin-top: -50px; }
  .out-of-header::before { top: 50px; } }
@media (min-width: 720px) { main h1 { font-size: 56px; }
  main h2 { font-size: 44px; margin: 0 0 44px; }
  main h3 { font-size: 36px; }
  main p { font-size: 32px; }
  main ul { gap: 16px; }
  main ul li { font-size: 32px; }
  main section { margin: 130px 0; }
  main .landing-btn { font-size: 32px; letter-spacing: 0.64px; padding: 32px; }
  main .transparent-btn { margin-top: 16px; }
  main .visual img { width: -webkit-max-content; width: -moz-max-content; width: max-content; }
  main .company h2 { margin: 0 0 24px; }
  main .company-text { padding: 90px 32px 0; }
  main .company-img { margin-right: -2em; }
  main .company-img img { width: 497px; }
  main .company ul li::before { top: 20px !important; }
  main .about-blocks { gap: 16px; }
  main .about-block img { width: 44px; }
  main .about-block:first-child img { width: 66px; }
  main .about-block::before { border-radius: 0 0 44px 44px; }
  main .about-text { border-radius: 44px; margin: 2px; padding: 22px 16px; }
  main .options-swiper .swiper-wrapper { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }
  main .options-swiper .swiper-wrapper .swiper-slide { max-height: -webkit-max-content; max-height: -moz-max-content; max-height: max-content; }
  main .options .options__text:after { height: 30px; width: 30px; }
  main .options .options__body * { font-size: 32px; }
  main .swiper-text::before { border-radius: 44px; }
  main .text-wrapper { border-radius: 44px; padding: 3em 16px 80px; }
  main .info { padding: 32px 16px; }
  main .info p { font-size: var(--regular-text); padding: 24px 0 44px; }
  main .info { border-radius: 32px; }
  main .calculate .tab-block { padding: 6px; }
  main .calculate .tab-block .btn-outline-primary { font-size: var(--regular-text); min-height: 80px; min-width: 216px; padding: 0 37px; }
  main .calculate .tab-block .btn-outline-primary.active { padding: 16px 37px; }
  main .calculate .form-label { font-size: var(--regular-text); }
  main .calculate .form-check { gap: 16px; }
  main .calculate .form-check-label { font-size: var(--regular-text); padding-left: 42px; }
  main .calculate .form-check-label::before { border: 2px solid #cdd2d8; height: 26px; width: 26px; }
  main .calculate .form-check-input:checked + .form-check-label::before { border: 7px solid var(--light-blue); }
  main .calculate .alert-success { font-size: var(--regular-text); }
  main .calculate .date-block { gap: 56px; }
  main .anketa h5 { font-size: var(--regular-text); }
  main .anketa .text { border-radius: 16px; font-size: var(--regular-text); min-height: 76px; }
  main .anketa .text::-webkit-input-placeholder { font-size: var(--regular-text); }
  main .anketa .text:-ms-input-placeholder { font-size: var(--regular-text); }
  main .anketa .text::-ms-input-placeholder { font-size: var(--regular-text); }
  main .anketa .text::placeholder { font-size: var(--regular-text); }
  main .anketa .input-block { gap: 44px; }
  main .anketa .input-block__item { gap: 16px; }
  main .anketa .check-block .check { height: 30px; width: 30px; }
  main .anketa .check-block p { font-size: 16px; }
  main .faq .accordion__text { font-size: 18px; font-weight: 600; line-height: 160%; padding: 22px 16px; }
  main .faq .accordion__body * { font-size: 18px; } }
