@font-face {
    font-family: 'Roboto';
    src: url("../../fonts/roboto/roboto-regular-webfont.woff2") format("woff2"),
    url("../../fonts/roboto/roboto-regular-webfont.woff") format("woff"),
    url("../../fonts/roboto/Roboto-Regular.ttf") format("truetype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto';
    src: url("../../fonts/roboto/roboto-italic-webfont.woff2") format("woff2"),
    url("../../fonts/roboto/roboto-italic-webfont.woff") format("woff"),
    url("../../fonts/roboto/Roboto-Italic.ttf") format("truetype");
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto';
    src: url("../../fonts/roboto/roboto-bold-webfont.woff2") format("woff2"),
    url("../../fonts/roboto/roboto-bold-webfont.woff") format("woff"),
    url("../../fonts/roboto/Roboto-Bold.ttf") format("truetype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto';
    src: url("../../fonts/roboto/roboto-light-webfont.woff2") format("woff2"),
    url("../../fonts/roboto/roboto-light-webfont.woff") format("woff"),
    url("../../fonts/roboto/Roboto-Light.ttf") format("truetype");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

/* Button styles */
.elm_btn, .elm_btn--blue, .elm_btn--green {
    -webkit-appearance: none;
    display: inline-block;
    padding: 10px 20px;
    border: none;
    color: #fff;
    font-size: 15px;
    font-weight: lighter;
    border-radius: 5px;
    text-decoration: none;
    transition: background-color .2s ease-out;
    cursor: pointer;
}

.elm_btn { background-color: #0070f1; border-color: #0070f1; }
.elm_btn:hover { background-color: #0096d1; border-color: #0096d1; }
.elm_btn--blue { background-color: #1071e3; border-color: #1071e3; }
.elm_btn--blue:hover { background-color: #0d5bb5; border-color: #0d5bb5; }
.elm_btn--green { background-color: #2bbf57; border-color: #2bbf57; }
.elm_btn--green:hover { background-color: #24a148; border-color: #24a148; }

.elm_btn .fa, .elm_btn .fab, .elm_btn--blue .fa, .elm_btn--blue .fab {
    font-size: 20px;
    margin-right: 10px;
    vertical-align: middle;
}



.btn-login-sign-up {
    display: inline-block;
    padding: 10px 20px;
    font-weight: 500;
    font-size: 1.2em;
    line-height: 1.2;
}

/* General styles */
.nobr { white-space: nowrap; }

svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
}

html {
    height: 100%;
    font-family: Roboto, sans-serif;
    font-size: 13px;
    line-height: 1.5;
}
html:has(.signUpStep) {
    line-height: 1.5;
    font-size: 12px;
    font-weight: 400;
}

body {
    min-height: 100%;
    margin: 0;
    padding: 0;

}
body:not(.signUpStep) {
    font-size: 14px;
    color: #1D252C;
    background-color: #fff;
}


input { font-family: "Roboto", sans-serif; }

a {
    color: #1071e3;
    text-decoration: none;
    outline: 0;
}

h2 {
    font-size: 35px;
    font-weight: lighter;
    line-height: 1.3;
    margin: 0 0 20px;
}

h5 {
    font-weight: lighter;
    font-size: 18px;
    line-height: 1.8;
    margin-top: 0;
    color: #8d9ba8;
}

ul {
    padding: 0;
    margin: 0;
    list-style: none;
}

/* Login and company list */
.cp_company__list, .cp_login {
    overflow: hidden;
    margin: 0 auto;
    width: 400px;
    background-color: #fff;
    border-radius: 8px 8px 0 0;
    border: 1px solid #e8e8e8;
}

.cp_login {
    max-width: 400px;
}
/*http://localhost:8080/auth/invalidIP.html*/
.cp_login--c {
    text-align: center;
}
.cp_login--c .cp_login__subtitle {
    padding-left: 3.46rem;
    padding-right: 3.46rem;
}

.cp_login--error {
    background-color: #fffcfc;
    border-color: #ffe1e1;
}

.cp_signup__caption, .cp_login__title, .cp_login__main, .cp_login__footer {
    padding: 0 3.46rem;
}

.cp_login__textbox {
    padding: 15px 21px;
}

.cp_login__textbox > p:first-child { margin-top: 0; }
.cp_login__textbox > p:last-child { margin-bottom: 0; }

.cp_login__main { padding-bottom: 2.30rem; }

.cp_login__title {
    margin: 30px 0;
    font-size: 25px;
    font-weight: 400;
    line-height: 1.2;
}

.cp_login--step-3 .cp_login__title, .cp_login--step-2 .cp_login__title {
    font-size: 20px;
}

.cp_login--step-3 .cp_login__main p {
    line-height: 1.6;
    font-size: 0.85em;
}

.cp_login--step-3 .cp_login__main p strong:first-child {
    display: inline-block;
    margin-bottom: 15px;
}

.cp_login--step-3 .cp_login__main p strong:first-child + span { opacity: .9; }

.cp_login--step-3 .cp_login__main p b, .cp_login--step-3 .cp_login__main p a {
    font-weight: 500;
    color: #000;
}

.cp_login__field:first-child { margin-bottom: 20px; }

.cp_login__form-item {
    display: flex;
    flex-direction: column;
}

.pass-padding { padding-right: 85px !important; }

.form-group--line {
    display: flex;
    justify-content: center;
    align-items: center;
}

.form-group--line .form-group__label { padding-right: 10px; }

.form-group--line select {
    border: none;
    border-bottom: 1px solid #e8e8e8;
    border-radius: 0;
}

.cp_login__field {
    position: relative;
    margin-bottom: 2.30rem;
}

.cp_login .select2-container--default .select2-selection--single,
.cp_login__field input[type=password], .cp_login__field input[type=text],
.cp_login__field input[type=email], .cp_login__field input[type=tel] {
    box-sizing: border-box;
    border: none;
    border-bottom: 1px solid #e8e8e8;
    line-height: 45px;
    height: 45px;
    width: 100%;
    padding: 0 0 1px;
    background: transparent;
    border-radius: 0;
    outline: 0;
    font-size: 14px;
    color: #536677;
}
/*intl-tel-input*/
:root {
    --iti-spacer-horizontal: 8px;
}
.cp_login__field input.iti__search-input {
    padding-left: var(--iti-spacer-horizontal);
}
.signUp-phone .iti {
    display: block;
    width: 100%;
}
.signUp-phone .iti--inline-dropdown .iti__dropdown-content {
    margin-top: 0;
}

.cp_login .select2-container--default .select2-selection--single {
    line-height: 45px;
    height: 45px;
}

.cp_login .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 0;
    line-height: inherit;
}

.cp_login .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: inherit;
}

.cp_login .select2-container--default .select2-selection--single .select2-selection__arrow b {
    margin-top: -3px;
}

.select2-selection.select2-selection--single {
    display: flex !important;
    align-items: center;
}

.select2-selection.select2-selection--single .select2-selection__rendered {
    display: flex !important;
}

#select2-signUpFree_country-container > span:not(.select2-selection__placeholder) {
    position: relative;
}

#select2-signUpFree_country-container > span:not(.select2-selection__placeholder) img {
    display: block;
}

#select2-signUpFree_country-container > span:not(.select2-selection__placeholder):after {
    content: '';
    position: absolute;
    inset: 0;
    border: 1px solid #fff;
}

.cp_login__field-underline {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: #1071e3;
    transition: width .5s cubic-bezier(.03, .76, .98, .98);
}

.cp_login__field input:focus + .cp_login__field-underline {
    width: 100%;
}

.cp_login__field input:focus.cp_login__field-invalid + .cp_login__field-underline {
    width: 100%;
    background: #db4242;
}

.cp_login__field input[type=password]:-webkit-autofill,
.cp_login__field input[type=text]:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #fff inset;
}

.cp_login--error .cp_login__field input[type=password]:-webkit-autofill,
.cp_login--error .cp_login__field input[type=text]:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #fffcfc inset;
}

.cp_login__pass-forgot {
    text-align: center;
    margin-top: 30px;
    line-height: 1;
}

.cp_login__pass-forgot a {
    /*display: inline-flex;*/
    /*align-items: center;*/
    /*text-decoration: none;*/
    /*font-size: 13px;*/
}

.cp_login__pass-forgot a > * {
    /*display: inline-block;*/
    /*vertical-align: middle;*/
}

.elm_btn--back {
    display: inline-flex;
    align-items: center;
}

.elm_btn--forward i { font-size: 13px; }

.cp_login__footer {
    display: flex;
    justify-content: center;
    border-top: 1px solid #e8e8e8;
    border-radius: 0 0 8px 8px;
    padding: 30px 0 20px;
    background: #fcfcfc;
}

.cp_login__footer dl {
    margin: 0;
    text-align: center;
}

.cp_login__footer dt { line-height: 1; }
.cp_login__footer dd { margin: 4px 0 0; }

.cp_login__options {
    display: flex;
    justify-content: center;
    margin-top: 30px;
}

.cp_login__option:not(:first-child) { margin-left: 10px; }

.cp_login__option a {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 40px;
    line-height: 40px;
    /*min-width: 40px;*/
    width: 40px;
    text-align: center;
    font-size: 16px;
    color: #c2c7cd;
    border-radius: 5px;
    background-color: #f3f3f3;
    transition: background-color .2s ease-out;
}
.cp_login__option svg {
    fill: currentColor;
    height: 16px;
    width: auto;
    /* Optional: to make the hover effect smoother */
    transition: fill .2s ease-in-out;
}
.cp_login__option--google svg {
    transform: scale(1.06);
}
.cp_login__option--facebook a:hover { background-color: #4267b2; color: #fff; }
.cp_login__option--google a:hover { background-color: #d62d20; color: #fff; }
.cp_login__option--linkedin a:hover { background-color: #007bb5; color: #fff; }
.cp_login__option--office365 a:hover { background-color: #d83b01; color: #fff; }

.cp_forgotpass {
    width: 300px;
    background-color: #fff;
    border-radius: 5px;
}

.cp_forgotpass:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}

/* Animation keyframes */
@keyframes spinX {
    0% { transform: perspective(78px) rotateY(0); }
    50% { transform: perspective(78px) rotateY(270deg); }
    100% { transform: perspective(78px) rotateY(360deg); }
}

/* Company list page */
.pg_company-list .pg_landing__container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.pg_company-list .pg_landing__start-btn { padding: 30px 0; }

.pg_company-list .pg_landing__main {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.cp_company__header { text-align: center; }

.cp_company__header-user {
    font-size: 25px;
    font-weight: 500;
}

.cp_company__list-title {
    font-size: 15px;
    line-height: 2.1;
    margin-bottom: 13px;
    color: #8d9ba8;
}

.cp_company__list-content::-webkit-scrollbar {
    width: 6px;
}

.cp_company__list-content::-webkit-scrollbar-thumb {
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .15);
}

.cp_company__list-content::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .1);
}

.cp_company__list-item + li { border-top: 1px solid #e8e8e8; }

.cp_company__list-item a {
    display: flex;
    align-items: center;
    color: #1D252C;
    padding: 12px 18px 12px 0;
    transition: background-color .2s ease-out;
    position: relative;
}

.company-status--active a > span:first-child svg { color: #2bbf57; }
.company-status--free a > span:first-child svg { color: #fba800; }
.company-status--expired a > span:first-child svg { color: #de2f2f; }

.cp_company__list-item a > span:first-child {
    padding: 0 20px;
    flex: 0 0 32px;
}

.cp_company__list-item a > span:last-child {
    align-self: center;
    height: 18px;
}

.cp_company__list-item figure { margin: 0; }
.cp_company__list-item figcaption { font-size: 10px; }

.cp_company__list-item dl {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin: 0;
}

.cp_company__list-item dt {
    margin-bottom: 5px;
    line-height: 1.4;
}

.cp_company__list-item dd {
    margin: 0;
    font-size: 0.8em;
    color: #8f9ba6;
}

.cp_company__list-item .icon--company {
    width: 32px;
    height: 32px;
}

.cp_company__list-item .icon--chevronRight {
    position: relative;
    right: 0;
    opacity: 0.4;
    transition: right .2s ease;
}

.cp_company__list-item a:hover .icon--chevronRight {
    right: -6px;
    opacity: 1;
}

.cp_company__list-item a:hover {
    background-color: #f6f7f9;
}

/* Landing page */
.pg_landing {
    min-height: 630px;
    position: relative;
    z-index: 1;
    height: 100%;
}

.pg_landing__container {
    max-width: 1170px;
    margin: 0 auto;
    padding: 0 15px 2rem; /* Используем rem для гибких отступов */
    box-sizing: border-box; /* Добавляем для корректного расчета размеров */
    position: relative;
    min-height: 100vh; /* Контейнер всегда не ниже высоты экрана */

    /* Включаем Flexbox для центрирования */
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.pg_landing__header {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    margin: 0;
}

.pg_landing__header figcaption {
    margin: 0 0 2rem;
    font-size: 24px;
    text-align: center;
}

.pg_landing__logo {
    margin: 2rem 0;
}

.pg_landing__logo img {
    width: 65px !important;
}

.pg_landing__start-btn .elm_btn {
    margin-left: 20px;
}

.pg_landing__content {
    width: 600px;
    float: left;
}

.box-bg--1 {
    background-color: #eceff3;
}

.box-bg--1 .cp_slider__frame use {
    fill: #eceff3;
}

/* Additional styles */
.ficon--more-horiz {
    font-size: 30px;
    font-weight: 800;
    line-height: 1.8;
}

.slick-slide a, .slick-slide:focus { outline: 0 !important; }

.cp_login__message {
    margin: 20px 0;
}

.cp_login__message--error {
    color: #ce0056;
    padding: 8px 10px;
    text-align: center;
    background-color: #fff5f5;
    border-bottom: 1px solid #ffe1e1;
}

.cp_login__submit { cursor: pointer; }

.cp_colorpanel__title {
    font-size: 35px;
    font-weight: 700;
    margin: 20px 0;
    color: #fff;
}

.cp_colorpanel__text {
    margin: 10px 20px 10px 0;
    font-size: 20px;
    font-weight: lighter;
    color: #fff;
}

.cp_login__subtitle {
    padding-bottom: 30px;
    font-size: 0.9em;
    opacity: 0.8;
}

.cp_login__subtitle a { color: #0070f1; }

.cp_login__field-title { margin-bottom: 15px; }

select {
    border: 1px solid #e8e8e8;
    width: 100%;
    border-radius: 5px;
    height: 40px;
    padding: 0 10px;
    background: #fff;
    color: #536677;
}

select:focus {
    outline: none;
    border: 1px solid #526677;
}

.cp_login--field .select-dropdown {
    background-color: #e7ebee;
    padding-left: 15px;
}

/* Password validation */
.pass-validation {
    display: flex;
    justify-content: space-between;
    margin-top: 4px;
    line-height: 1;
}

.pass-validation__text {
    font-size: 12px;
    color: #b7bbbd;
}

.pass-validation__view {
    display: flex;
    width: 70%;
    flex-shrink: 0;
    padding-top: 4px;
}

.pass-validation__view > * {
    position: relative;
    margin-right: 5px;
    width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
    border-radius: 50%;
    background-color: #f3f4f9;
    color: #b5abab;
}

.pass-validation__view > *:after {
    content: "\f023";
    font: normal normal normal 14px/1 FontAwesome;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.pass-validation--state-1 .pass-validation__view > *:not(.pass-validation__view__step-1):after,
.pass-validation--state-2 .pass-validation__view > *:not(.pass-validation__view__step-1):not(.pass-validation__view__step-2):after {
    content: "\f13e";
}

.pass-validation--state-3 .pass-validation__view__step-1,
.pass-validation--state-2 .pass-validation__view__step-1,
.pass-validation--state-1 .pass-validation__view__step-1 {
    color: #ff8180;
}

.pass-validation--state-3 .pass-validation__view__step-2,
.pass-validation--state-2 .pass-validation__view__step-2 {
    color: #f9c575;
}

.pass-validation--state-3 .pass-validation__view__step-3 {
    color: #6fc7a4;
}

.pass-validation__text > * {
    display: none;
    line-height: 20px;
    padding-top: 4px;
}

.pass-validation__text > .active,
.pass-validation--state-1 .pass-validation__text .pass-validation__text__step-1,
.pass-validation--state-2 .pass-validation__text .pass-validation__text__step-2,
.pass-validation--state-3 .pass-validation__text .pass-validation__text__step-3 {
    display: block;
}

.cp_login__field--pass {
    position: relative;
}

.cp_login__field--pass input {
    padding-right: 100px;
    box-sizing: border-box;
}

.cp_login__field--pass .pass-validation__view {
    position: absolute;
    width: auto;
    top: 12px;
    right: 0;
}

.cp_login__field--pass .pass-validation {
    justify-content: flex-end;
}

.password-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.password-wrapper input {
    width: 100%;
    padding-right: 40px;
    height: 40px;
    box-sizing: border-box;
}

.toggle-password {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    color: #333;
    font-size: 16px;
}

/* Wizard page */
.pg_landing--wizard * { box-sizing: content-box; }

.pg_landing--wizard .cp_login__title { font-size: 18px; }
.pg_landing--wizard .cp_login__field { margin-bottom: 15px; }
.pg_landing--wizard select { background-color: #e7ebee; }
.pg_landing--wizard input[type="text"]::placeholder { color: #929ca5; }
.pg_landing--wizard .pg_landing__main { top: 20%; }
.pg_landing--wizard .cp_login__footer { border-top: 0; }

.pg_landing--wizard .cp_colorpanel__items-container {
    background: #e7ebee url("../../images/img-2314578.png") no-repeat right 100px center;
    background-size: contain;
}

/* Modules switcher */
.cp_modules-switch {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 10px -5px;
    padding-bottom: 110px;
    position: relative;
    overflow: hidden;
}

.cp_modules-switch__notes {
    position: absolute;
    background: #fff;
    border-radius: 5px 5px 0 0;
    padding: 30px;
    height: 100px;
    left: 5px;
    right: 5px;
    top: 230px;
    opacity: 0;
    text-align: left;
    transition: all 0.5s ease-out;
    display: flex;
    align-items: center;
    line-height: 1.8;
}

.cp_modules-switch__notes--original { opacity: 1; }

.cp_modules-switch__item:hover .cp_modules-switch__notes { opacity: 1; }
.cp_modules-switch__item:hover ~ .cp_modules-switch__notes--original { opacity: 0; }

.cp_modules-switch__item {
    flex-shrink: 0;
    text-align: center;
    width: 120px;
    height: 190px;
    border-radius: 5px;
    background-color: #F7F9FA;
    margin: 15px 5px;
}

.cp_modules-switch__item-content {
    overflow: hidden;
    padding: 28px 10px;
    transition: all 0.2s ease-out;
    position: relative;
}

.cp_modules-switch__item-content:after {
    content: '';
    display: block;
    width: 280px;
    height: 50px;
    background-color: #fff;
    position: absolute;
    transform: rotate(45deg);
    top: -50px;
    right: -150px;
}

.cp_modules-switch__item:hover {
    box-shadow: 0 7px 28px #CFD7E3;
}

.cp_modules-switch__item--active {
    background-color: #fff;
}

.cp_modules-switch__item:not(.cp_modules-switch__item--active) .switch label .lever {
    background-color: #8d9ba8;
}

.cp_modules-switch__logo {
    display: inline-block;
    color: #fff;
    width: 44px;
    height: 54px;
    line-height: 54px;
    text-align: center;
    font-size: 20px;
    margin-bottom: 10px;
    position: relative;
}

.cp_modules-switch__logo [class*="ficon--"]:after {
    content: "";
    position: absolute;
    top: 0;
    -webkit-mask-image: url(../../images/mask-trapeze.svg);
    mask: url(../../images/mask-trapeze.svg);
    width: 44px;
    height: 54px;
    background-color: #8d9ba8;
}

.cp_modules-switch__logo [class*="ficon--"]:before {
    position: relative;
    z-index: 2;
}

.cp_modules-switch__item--active .cp_modules-switch__logo {
    animation: .7s linear spinX;
}

.cp_modules-switch__title {
    font-size: 12px;
    margin-bottom: 20px;
}

.cp_modules-switch__item--active .cp_modules-switch__item-content:after {
    top: 180px;
    right: 35px;
    transition: all 0.3s ease-out;
}

.cp_login__text--medium {
    font-size: 1rem;
    margin-bottom: 1.7rem;
}

.cp_modules-switch__subtitle { font-weight: bold; }
.cp_modules-switch__subtitle--red { color: #db4343; }
.cp_modules-switch__subtitle--green { color: #85CA40; }

/* Wizard page */
.wizard-page {
    background-color: #ECEFF3;
    color: #8D9BA8;
    font-size: 13px;
}

.wizard-page--blur .wizard-page__container {
    filter: blur(10px);
    opacity: 0.6;
}

.wizard-page__container {
    width: 970px;
    margin: 0 auto;
    padding: 0 15px;
    position: relative;
}

.wizard-page__upper {
    max-width: 450px;
    margin: 0 auto;
    text-align: center;
    padding-top: 3rem;
    margin-bottom: 3rem;
}

.wizard-page__upper p {
    max-width: 320px;
    margin: 0 auto;
}

.wizard-page__logo {
    margin-bottom: 2.5rem;
    display: block;
}

.wizard-page__logo img {
    width: 80px;
}

.wizard-page h3 {
    font-size: 1.6rem;
    font-weight: 300;
    margin: 0 0 2.4rem;
    color: #536677;
}

.wizard-page .quote {
    background-color: #fff;
    border-radius: 5px 5px 0 0;
    padding: 30px;
}

.wizard-page__buttons {
    margin-top: 25px;
    text-align: center;
}

.wizard-page .pg_landing__start-btn {
    position: fixed;
    right: 70px;
    top: 70px;
    z-index: 2;
}

.elm__textfield {
    margin-bottom: 10px;
    position: relative;
}

.elm__textfield input[type="text"] {
    padding: 27px 24px 5px;
    border: none;
    border-radius: 8px;
    width: 100%;
    box-sizing: border-box;
    line-height: 1.9rem !important;
    height: auto !important;
    font-size: 13px;
}

.elm__textfield label {
    position: absolute;
    top: 10px;
    left: 24px;
    right: 24px;
    color: #000;
    font-size: 11px;
}

.elm__dropdown {
    background-color: #fff;
    border-radius: 8px;
    margin-bottom: 10px;
}

.elm__dropdown > label {
    padding: 8px 24px 0;
    display: block;
    color: #000;
    font-size: 11px;
}

.elm__dropdown input.select-dropdown {
    border: none !important;
    padding-left: 24px !important;
    font-size: 15px !important;
    border-radius: 0 0 8px 8px !important;
}

.elm__dropdown .caret {
    top: -18px !important;
    right: 10px !important;
}

.wizard-page--org .wizard-page__content {
    width: 640px;
    margin: 0 auto;
}

.modal-form {
    background-color: #fff;
    width: 476px;
    padding: 40px 70px;
    text-align: center;
    border: 1px solid #DDE1E5;
    border-radius: 8px;
}

.modal-form input[type='text'], .modal-form input[type='password'] {
    border: 1px solid #DDE1E5 !important;
    padding-left: 20px !important;
    font-size: 13px !important;
    height: 60px !important;
}

.modal-form .pass-validation__view--mod {
    top: 16px !important;
    right: 20px !important;
}

.modal-form .cp_login__title { font-size: 18px; }

.modal-form .elm_btn {
    width: 100%;
    text-transform: none !important;
    height: 60px;
}

.wizard-page__overlay {
    position: fixed;
    inset: 0;
    z-index: 2;
    display: flex;
    justify-content: center;
    align-items: center;
}

.wizard-page--apps .wizard-page__content { position: relative; }

#cp_modules-switch__error {
    color: red;
    position: absolute;
    top: -10px;
}

/* Small screens adaptation */
@media screen and (max-height: 800px) {
    .wizard-page__fields {
        height: 355px;
        overflow-y: auto;
        padding-right: 15px;
    }
}

@media screen and (max-height: 768px) {
    .pg_landing__logo img { width: 50px !important; }
    .cp_company__list, .cp_login { width: 360px; }
    .cp_login .select2-container--default .select2-selection--single,
    .cp_login__field input[type=password], .cp_login__field input[type=text] {
        line-height: 35px;
        height: 35px;
    }
    .pg_landing__logo { margin: 20px 0; }
    .pg_landing__header figcaption { font-size: 16px; }
    .cp_login__title { margin: 20px 0; }
    .cp_login--error .cp_login__title { margin: 15px 0 5px; }
    .pg_landing__header figcaption, .cp_login__field { margin-bottom: 20px; line-height: 1.4; }
    .cp_login__field:first-child { margin-bottom: 15px; }
    .cp_login__main { padding-bottom: 20px; }
    .cp_login__pass-forgot, .cp_login__options { margin-top: 20px; }
    .cp_login__footer { padding: 20px 0 15px; }
    .cp_login--error .cp_login__field:first-child { margin-bottom: 10px; }
    .cp_login--error .cp_login__footer { padding: 15px 0 10px; }
}


/* ---- Custom Checkbox Component ---- */

/* 1. BASE BLOCK (.control) */
.control {
    display: flex;
    align-items: center;
    position: relative;
    cursor: pointer;
    user-select: none;
}

/* Spacing for stacked controls (legacy compatibility) */
.controls-stack .control + .control {
    margin-top: 10px;
}

/* Hide the native browser input */
.control input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

/* The visible canvas for our custom control */
.control__indicator {
    position: relative;
    flex-shrink: 0;
    width: 1.1rem;
    height: 1.1rem;
    margin-top: 0.15rem;
}

/* Shared structure for the indicator's pseudo-elements (:before & :after) */
.control__indicator:before, .control__indicator:after {
    content: " ";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 0.25rem;
    box-sizing: border-box;
}

/* Styles for the visible box */
.control__indicator:before {
    background: #fff;
    border: 1px solid #a6a6a6;
    transition: all 0.2s ease-in-out;
    border-radius: 0.25rem;
}

/* Base styles for the inner symbol (the checkmark) */
.control__indicator:after {
    opacity: 0;
    transition: opacity 0.2s ease-in-out;
}

/* Text label */
.control__description {
    padding-left: 0.75rem;
    font-size: 0.70em;
    line-height: 1;
    margin-top: .2em; /*// for centering the text vertically*/
}


/* COMPONENT STATES (:hover, :focus, :checked, :disabled) */
.control:hover .control__indicator:before {
    border-color: #ecad3b;
}

.control input:focus ~ .control__indicator:before {
    border-color: #ecad3b;
    box-shadow: 0 0 0 2px rgba(236, 173, 59, 0.3);
}

.control input:checked ~ .control__indicator:before {
    background: #ecad3b;
    border-color: #ecad3b;
}

.control input:checked ~ .control__indicator:after {
    opacity: 1;
}

.control input:disabled ~ .control__indicator:before {
    opacity: .6;
    pointer-events: none;
    background: #e6e6e6;
}

.control input:disabled ~ .control__description {
    opacity: .6;
}

.control input:disabled:checked ~ .control__indicator:before {
    background: #ecad3b;
}

.control input:disabled ~ .control__indicator:after {
    opacity: .4;
}


/* 2. MODIFIER (.control--checkbox) */
/* Defines the checkmark icon for the checkbox variant */
.control--checkbox .control__indicator:after {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23fff' d='M6.564.75l-3.59 3.6-1.5-1.5L0 4.26l2.974 2.99L8 2.16z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 69%;
}
/* ---- End Custom Checkbox Component ---- */

/*//ToDo: remove old styles for select2 tel input*/
.signUp-phone {}
.iti__tel-input::placeholder {
    /*color: #929ca5;*/
    color: #b8c4cf;
}

/* Signup page */
.cp_signup__caption {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.cp_signup__caption h3 {
    font-size: 18px;
    font-weight: 400;
}

.cp_signup__caption > * {
    margin: 2.30rem 0;
}

.pg_sign-up .cp_login {
    /*margin-top: 0.76rem;*/
}

.signUp-phone {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #e8e8e8;
}

.cp_login .signUp-phone .select2-container--default .select2-selection--single,
.signUp-phone input[type=text] {
    border-bottom: none;
}

.signUp-phone__prefix { flex: 0 0 58px; }
.signUp-phone__prefix .select2.select2-container { width: 100% !important; }
.signUp-phone__phone { flex: 1 0 auto; padding-left: 10px; }

body > .select2-container .select2-dropdown { width: 270px !important; }
body > .select2-container .select2-results__option { font-size: .9em; }

.select2-container .select2-results__option .flag { display: none; }

/* Error page */
.pg_404 {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.b-404 { font-size: 1vw; }
.b-404 dt { font-weight: bold; font-size: 6.5em; }
.b-404 dd { margin: 0; }
.b-404_dsc { font-weight: 500; font-size: 2.6em; line-height: 1.2; }
.b-404_lnk { line-height: 4.2; }

/* Loader */
.cs-loader {
    display: flex;
    align-items: center;
    justify-content: center;
}

.cs-loader-inner {
    width: 80%;
    transform: translateY(-50%);
    text-align: center;
}

.cs-loader-inner i {
    display: inline-block;
    font-style: normal;
    font-size: 20px;
    color: #2D3A45;
    opacity: 0;
}

.cs-loader-inner i + i { margin-left: .2vw; }

@keyframes lol {
    0% { opacity: 0; transform: translateX(-300px); }
    33% { opacity: 1; transform: translateX(0); }
    66% { opacity: 1; transform: translateX(0); }
    100% { opacity: 0; transform: translateX(300px); }
}

.cs-loader-inner i:nth-child(6) { animation: lol 3s infinite ease-in-out; }
.cs-loader-inner i:nth-child(5) { animation: lol 3s 100ms infinite ease-in-out; }
.cs-loader-inner i:nth-child(4) { animation: lol 3s 200ms infinite ease-in-out; }
.cs-loader-inner i:nth-child(3) { animation: lol 3s 300ms infinite ease-in-out; }
.cs-loader-inner i:nth-child(2) { animation: lol 3s 400ms infinite ease-in-out; }
.cs-loader-inner i:nth-child(1) { animation: lol 3s 500ms infinite ease-in-out; }

/* start MODAL for Welcome Page */
body.signUpStep {
    background-color: #eceff3;
    color: #1d252c;
}

.lean-overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    will-change: opacity;
    background-color: #8d9ba8;
    height: 100%;
    filter: blur(6.4px);
    background: url(../../images/bg-signUpSteps--16x9.png) no-repeat 0 0 / cover;
}

@media screen and (max-width: 1440px) {
    .signUpStep .lean-overlay {
        background-image: url(../../images/bg-signUpSteps--1.6x1.png);
    }
}

@media screen and (max-width: 1280px) {
    .signUpStep .lean-overlay {
        background-image: url(../../images/bg-signUpSteps--1.25x1.png);
    }
}

.modal-holder.active {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.5;
    font-size: 12px;
    font-family: Roboto, sans-serif;
    font-weight: 400;
    color: #1d252c;
}

.modal {
    z-index: 1004;
    min-width: 300px;
    max-width: 75%;
    max-height: 90%;
    background-color: #fff;
    border: 1px solid rgba(206, 213, 219, 0.2);
    border-radius: 10px;
    will-change: top, opacity;
    box-shadow: 0 5px 11px 0 rgba(0, 0, 0, 0.05), 0 4px 15px 0 rgba(0, 0, 0, 0.03);
}

.sign-up-step--1 {
    text-align: center;
}

.sign-up-step {
    max-width: 883px;
}

.modal--md {
    max-width: 85%;
}

@media only screen and (max-width: 992px) {
    .modal {
        width: 80%;
    }
}

.modal h1, .modal h2 {
    font-weight: 400;
}

.modal-wrapper {
    display: flex !important;
    flex-direction: column;
    height: 100%;
}

.modal-content, .modal-footer, .modal-header {
    background-color: #fff;
}

.modal-footer, .modal-header {
    padding-left: 40px;
    padding-right: 40px;
}

.modal-header {
    position: relative;
    flex-shrink: 0;
    font-size: 20px;
    text-align: center;
    font-weight: 700;
    color: #425364;
    padding-top: 33px;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

.sign-up-step--1 .modal-header figure {
    margin: 0;
}

.sign-up-step--1 .modal-header figcaption {
    margin-top: 30px;
}

.sign-up-step .modal-header .visual img {
    max-height: 200px;
}

.fs-4 {
    font-size: 23.73px;
}

.sign-up-step .modal-header h1 {
    margin: 0;
}

.sign-up-step .modal-header h1 strong {
    font-weight: 700;
}

.fs-3 {
    font-size: 22.67px;
}

.sign-up-step .sub-title {
    font-weight: 500;
    margin: 11.33px 0 9.07px 0;
}

.modal-content {
    overflow-y: auto;
    padding: 33.33px 40px;
}

.modal>.modal-wrapper>.modal-content {
    border-radius: 10px;
}

.modal .modal-content:not(:last-child) {
    padding-bottom: 0;
}

.sign-up-step .modal-content {
    background-color: transparent;
}

.sign-up-step--1 .modal-content p {
    font-size: 18.67px;
}

.simple-text {
    line-height: 1.8;
}

.sign-up-step--1 .modal-content a[href^=mailto] {
    color: #1d252c;
}

.modal-footer {
    border-bottom-right-radius: 10px;
    border-bottom-left-radius: 10px;
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    flex-shrink: 0;
    padding-top: 20px;
    padding-bottom: 20px;
    border-top: 1px solid #d8d8d8;
    background-color: #fff;
}

.modal .modal-footer {
    border-top: 0;
}

.modal-holder.active .modal-footer {
    padding: 16px;
}

.sign-up-step .modal-footer {
    flex-wrap: wrap;
    border-top: none;
}
/* end MODAL for Welcome Page */


/*.stripePayment .lean-overlay,*/
.signUpStep .lean-overlay {
    top: 0 !important;
    bottom: 0 !important;
    height: 100%;
    filter: blur(6.4px);
    background: url(../../images/bg-signUpSteps--16x9.png) no-repeat 0 0 / cover;
}
@media screen and (max-width: 1440px) {
 /*.stripePayment .lean-overlay,*/
    .signUpStep .lean-overlay {
        background-image: url(../../images/bg-signUpSteps--1.6x1.png);
    }
}
@media screen and (max-width: 1280px) {
    /*.stripePayment .lean-overlay,*/
    .signUpStep .lean-overlay {
        background-image: url(../../images/bg-signUpSteps--1.25x1.png);
    }
}



.modal-holder.active {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    line-height: 1.5;
    font-size: 12px;
    font-family: Roboto, sans-serif;
    font-weight: 400;
    color: #1d252c;
}
.modal {
    z-index: 1004; /* Ensure modal is above .lean-overlay */
    min-width: 300px;
    max-width: 75%;
    max-height: 90%;
    background-color: #fff;
    border: 1px solid rgba(206, 213, 219, .2);
    border-radius: 10px;
    will-change: top, opacity;
    box-shadow: 0 5px 11px 0 rgba(0, 0, 0, .05), 0 4px 15px 0 rgba(0, 0, 0, .03);
}
.sign-up-step--1 {
    text-align: center;
}
.sign-up-step {
    max-width: 883px;
}
.modal--md {
    max-width: 85%;
}
@media only screen and (max-width: 992px) {
    .modal {
        width: 80%;
    }
}
.modal h1, .modal h2 {
    font-weight: 400;
}

.modal-wrapper {
    display: flex !important;
    flex-direction: column;
    height: 100%;
}

.modal-content, .modal-footer, .modal-header {
    background-color: #fff;
}
.modal-footer, .modal-header {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
}

.modal-header {
    position: relative;
    flex-shrink: 0;
    font-size: 20px;
    text-align: center;
    font-weight: 700;
    color: #425364;
    padding-top: 2.08333rem;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}
.modal-holder.active .modal-header {
    /*padding: 24px;
    border-bottom: 1px solid #e0e0e0; no need for signup modal*/
}

.sign-up-step--1 .modal-header figure {
    margin: 0;
}
.sign-up-step--1 .modal-header figcaption {
    margin-top: 30px;
}
.sign-up-step .modal-header .visual img {
    max-height: 200px;
}
.fs-4 {
    font-size: 1.4833rem;
}
.sign-up-step .modal-header h1 {
    margin: 0;
}
.sign-up-step .modal-header h1 strong {
    font-weight: 700;
}
.fs-3 {
    font-size: 1.4166rem;
}
.sign-up-step .sub-title {
    font-weight: 500;
    margin: .7083rem 0 .56664rem 0;
}

.modal-content {
    overflow-y: auto;
    padding: 2.08333rem 2.5rem;
}
.modal>.modal-wrapper>.modal-content {
    border-radius: 10px;
}
.modal .modal-content:not(:last-child) {
    padding-bottom: 0;
}
.sign-up-step .modal-content {
    background-color: transparent;
}
.sign-up-step--1 .modal-content p {
    font-size: 1.16667rem;
}
.simple-text {
    line-height: 1.8;}
.sign-up-step--1 .modal-content a[href^=mailto] {
    color: #1d252c;
}



.modal-footer {
    border-bottom-right-radius: 10px;
    border-bottom-left-radius: 10px;
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    flex-shrink: 0;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    border-top: 1px solid #d8d8d8;
    background-color: #fff;
}
.modal .modal-footer {
    border-top: 0;
}
.modal-holder.active .modal-footer {
    padding: 16px;
    /*text-align: right;
    border-top: 1px solid #e0e0e0; no need for signup modal */
}
.sign-up-step .modal-footer {
    flex-wrap: wrap;
    border-top: none;
}
/* end MODAL for Welcome Page */



/* === Progress Panel Styles (Improved & Refactored) === */

.modal-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.6);
    z-index: 999;
}

.progress-panel {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 600px;
    height: 400px;
    background-color: white;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
    z-index: 1000;
    border-radius: 12px;
    padding: 20px 30px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
}

.progress-panel__header {
    font-size: 1.5rem;
    font-weight: 300;
    text-align: center;
    color: #1D252C;
    flex-shrink: 0;
    padding: 20px 0;
}

.progress-panel__center-content {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 30px;
}

.progress-panel__steps {
    display: flex;
    justify-content: center;
}

.progress-panel__step {
    text-align: center;
    min-width: 155px;
    position: relative;
    color: #a0a9b2;
    transition: color 0.4s ease;
}

/* UPDATED: Renamed --active to --cur for clarity */
.progress-panel__step--cur {
    color: #1D252C;
    font-weight: 500;
}

.progress-panel__step-circle {
    align-items: center;
    background-color: #e1e4e8;
    border-radius: 50%;
    justify-content: center;
    height: 40px;
    width: 40px;
    display: inline-flex;
    margin-bottom: 15px;
    transition: background-color 0.4s ease;
}

.progress-panel__step--success .progress-panel__step-circle {
    background-color: #2bbf57;
}

/* UPDATED: Renamed --active to --cur for clarity */
.progress-panel__step--cur .progress-panel__step-circle {
    background-color: #1D252C;
}

.progress-panel__step-icon {
    opacity: 0;
    color: #fff;
    font-size: 1.8rem;
}

.progress-panel__current-desc {
    position: relative;
    height: 1.5em;
    color: #8d9ba8;
    text-align: center;
    font-size: 1.5rem;
    font-weight: lighter;
}

.progress-panel .cs-loader {
    flex-shrink: 0;
    padding: 20px 0 0;
}

/* === ANIMATIONS (Refactored) === */

@keyframes step-success-animation {
    from { opacity: 0; transform: scale(0.3); }
    to { opacity: 1; transform: scale(1); }
}

@keyframes text-fade-in-smooth {
    from { opacity: 0; transform: translateY(15px); }
    to { opacity: 1; transform: translateY(0); }
}

.progress-panel__step.progress-panel__step--success .progress-panel__step-icon {
    animation: step-success-animation 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

/* REFACTORED: Selecting direct div children, no need for a long class name */
.progress-panel__current-desc > div {
    opacity: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    text-align: center;
    /* ADDED: Smooth fade-out for the text */
    transition: opacity 0.4s ease-out;
}

/* REFACTORED: Using simpler '.cur' class for the active description */
.progress-panel__current-desc > div.cur {
    animation: text-fade-in-smooth 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
/* === End progress panel styles === */

/* ---- Responsive reCAPTCHA Component ---- */

/* 1. Center the reCAPTCHA widget within its container */
.cp_login__field .g-recaptcha {
    display: flex;
    justify-content: center;
}

/* 2. Scale the widget down on very narrow screens */
/* The widget's default width is 304px, so we apply scaling on any screen narrower than that */
@media (max-width: 304px) {
    .g-recaptcha {
        /* Scale down to 90% of its size */
        transform: scale(0.9);
        -webkit-transform: scale(0.9);

        /* Ensure scaling happens from the center */
        transform-origin: center;
        -webkit-transform-origin: center;
    }
}

/* ---- End Responsive reCAPTCHA Component ---- */

/* ==========================================================================
   Mobile Responsive Styles /
   ========================================================================== */
/* Media queries */
@media (min-width: 1024px) {
    .pg_landing .pg_landing__header { }
}
@media (max-width: 1023px) {
    .cp_slider, .cp_colorpanel, .pg_landing__content, .pg_landing__start-txt {
        display: none;
    }
    .pg_landing { min-height: auto; }
    .pg_landing__logo img { width: 50px !important; }
    .elm_404-mobile, .pg_landing__logo--mobile-only { display: block; }
}
@media (max-width: 1200px) {
    .pg_landing__container { max-width: none; }
    .cp_colorpanel__items-innerbox { width: 100%; left: 4.34783%; }
}
@media (max-width: 640px) {
    /*.cp_company, .cp_company__list, .cp_login { width: 400px; }*/
    .cp_company__header-user { font-size: 20px; margin-bottom: 20px; }

    /* ---- Responsive reCAPTCHA Fix ---- */
    /* Контейнер, в котором лежит reCAPTCHA, делаем его flex-контейнером для центрирования */
    .cp_login__field .g-recaptcha {
        display: flex;
        justify-content: center;
    }
}
@media (max-width: 600px) {
    /* 1. Remove unnecessary margins and make the form flexible */
    .cp_login {
        width: auto; /* Replace fixed width with automatic */
        max-width: 100%; /* Ensure the block doesn't overflow the screen */
        margin-top: 15px;
        border-left: none; /* Remove side borders to save space */
        border-right: none;
        border-radius: 0;
    }

    /* 2. Reduce internal padding to fit content */
    .cp_signup__caption,
    .cp_login__title,
    .cp_login__main,
    .cp_login__footer {
        padding-left: 20px;
        padding-right: 20px;
    }

    /* 3. Reduce header margins */
    .pg_landing__header figcaption {
        font-size: 18px; /* Reduce caption font size */
        margin-bottom: 20px;
    }
    .pg_landing__logo {
        margin: 20px 0;
    }
}


/*existingUser assets*/
.form-group {
    margin-bottom: 1.8rem;
}

.btn, .btn-large, .btn-medium, .btn-small {
    background: transparent;
}
.btn, .btn--circle, .btn--icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 2.5rem;
    line-height: 1.7;
    white-space: nowrap;
    border: 0.08333rem solid transparent;
    padding-left: 1.333rem;
    padding-right: 1.333rem;
    border-radius: 3px;
    font-style: normal;
    font-size: 1rem;
    letter-spacing: .5px;
    text-decoration: none;
    outline: none;
    color: #1D252C;
    transition: background-color .1s ease;
}
.btn:not(.sign-btn), .btn-large:not(.sign-btn), .btn-medium:not(.sign-btn), .btn-small:not(.sign-btn) {
    cursor: pointer;
}
.btn--primary {
    background-color: #1071e3;
    border-color: #1071e3;
}
.btn--primary:where(:not(.btn--outline)) {
    color: #fff !important;
}

/*SignUp Steps Backgrounds*/
.stripePayment .lean-overlay,
.signUpStep .lean-overlay {
    top: 0 !important;
    bottom: 0 !important;
    height: 100%;
    filter: blur(6.4px);
    background: url("../../images/bg-signUpSteps--16x9.png") no-repeat 0 0/cover; }
@media screen and (max-width: 1440px) {
    .stripePayment .lean-overlay,
    .signUpStep .lean-overlay {
        background-image: url("../../images/bg-signUpSteps--1.6x1.png"); } }
@media screen and (max-width: 1280px) {
    .stripePayment .lean-overlay,
    .signUpStep .lean-overlay {
        background-image: url("../../images/bg-signUpSteps--1.25x1.png"); } }
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) {
    .stripePayment .lean-overlay,
    .signUpStep .lean-overlay {
        background-image: url("../../images/bg-signUpSteps--4x3.png"); } }

.sign-up-step {
    max-width: 883px; }
.sign-up-step .modal-header h1 {
    margin: 0; }
.sign-up-step .modal-header .visual img {
    max-height: 200px; }
@media only screen and (min-width: 993px) {
    .sign-up-step .modal-wrapper > *:first-child {
        padding-top: 3.33333rem; }
    .sign-up-step .modal-wrapper > *:last-child {
        padding-bottom: 3.33333rem; } }
.sign-up-step .modal-content {
    background-color: transparent; }
.sign-up-step--1 {
    text-align: center; }
.sign-up-step--1 .modal-header figure {
    margin: 0; }
.sign-up-step--1 .modal-header figcaption {
    margin-top: 30px; }
.sign-up-step--1 .modal-content p {
    font-size: 1.16667rem; }
.sign-up-step--1 .modal-content a[href^=mailto] {
    color: #1D252C; }
.sign-up-step--2 .modal-wrapper {
    background-image: url("../../icons/sign-up-step-password.svg");
    background-size: auto 54%;
    background-repeat: no-repeat; }
@media only screen and (min-width: 993px) {
    .sign-up-step--2 .modal-wrapper {
        min-width: 600px;
        padding-right: 161px;
        background-position: right 20px bottom 30px; } }
@media only screen and (max-width: 992px) {
    .sign-up-step--2 .modal-wrapper {
        padding-bottom: 350px;
        background-position: center bottom 15px; } }
.sign-up-step--2 .modal-header {
    text-align: left; }
@media only screen and (min-width: 993px) {
    .sign-up-step--3 .modal-header, .sign-up-step--4 .modal-header {
        padding-bottom: 32px; } }
.sign-up-step--3 .modal-content {
    position: relative;
    background: url("../../icons/sign-up-step-org.svg") right 30px bottom -10px/auto 90% no-repeat; }
@media only screen and (min-width: 993px) {
    .sign-up-step--3 .modal-content {
        padding-right: 200px; } }
@media only screen and (max-width: 992px) {
    .sign-up-step--3 .modal-content {
        padding-top: 1.04167rem; } }
.sign-up-step--4:after {
    top: auto;
    bottom: 0;
    height: 0;
    right: 2.5rem;
    left: 2.5rem;
    border-bottom: 1px solid #eceff4; }
.sign-up-step .sub-title {
    font-weight: 500; }
.sign-up-step .modal-footer {
    flex-wrap: wrap;
    border-top: none; }
.sign-up-step .modal-footer .footnote {
    flex: 100% 0 0;
    padding-top: 20px; }
.sign-up-step .cp_modules-switch {
    flex-wrap: nowrap; }
@media only screen and (min-width: 993px) {
    .sign-up-step__password {
        padding-right: 60px; } }
.sign-up-step__password .form-group__content {
    position: relative; }
.sign-up-step__password .form-control {
    padding-right: 74px; }
.sign-up-step__password .pass-validation {
    position: absolute;
    left: 100%;
    top: 0;
    margin: 0 0 0 -74px;
    justify-content: flex-start;
    white-space: nowrap; }