.eak-side__link, .kl-lessonlist__link, .menu-items .menu-item, a:hover {
    text-decoration: none
}

.kl-lessonlist__name, .rt-name, .task-file-uploaded .file span.text {
    white-space: nowrap;
    text-overflow: ellipsis
}

@font-face {
    src: url("/fonts/Rubik-Regular.ttf") format('truetype');
    font-family: Rubik;
    font-style: normal;
    font-weight: 400
}

@font-face {
    src: url("/fonts/Rubik-Medium.ttf") format('truetype');
    font-family: Rubik;
    font-style: normal;
    font-weight: 500
}

@font-face {
    src: url("/fonts/Rubik-SemiBold.ttf") format('truetype');
    font-family: Rubik;
    font-style: normal;
    font-weight: 600
}

@font-face {
    src: url("/fonts/Rubik-Bold.ttf") format('truetype');
    font-family: Rubik;
    font-style: normal;
    font-weight: 700
}

:root {
    --main-color: #2135B3;
    --main-hover-color: #2135B3;
    --main-focus-color: #2135B3;
    --text-color: #202020;
    --title-color: #333333;
    --body-bacground: #FFFFFF;
    --footer-bacground: #1B1B1B;
    --header-bacground: #FAFAFA;
    --border-radius: 12px;
    --color-error: #FA4343;
    --color-success: #14BF2F;
    --color-checking: #A92AD6;
    --color-white: #fff;
    --color-black: #303030;
    --main-bacground: #fff;
    --brand: var(--main-color);
    --ok: #16a34a;
    --muted: #94a3b8;
    --card: #ffffff;
    --ring: #e2e8f0;
    --rt-blue: #2563eb;
    --rt-blue-100: #eef2ff;
    --rt-blue-200: #dbeafe;
    --rt-green: #16a34a;
    --rt-muted: #64748b;
    --rt-ring: #e2e8f0;
    --lesson-chat-primary: #2135B3
}

* {
    word-wrap: break-word;
    scroll-behavior: smooth
}

body {
    font-family: Rubik, sans-serif;
    font-size: 16px;
    font-weight: 400;
    color: var(--text-color);
    background-color: var(--body-bacground);
    overflow-x: hidden;
    margin: 0
}

.content-wrapper, body, html {
    height: 100%
}

.cabinet-text, a, a:hover {
    color: #303030
}

.card-cart, .form-search, .header, .lesson-composer__field, .overlay .vld-icon, .section, .vld-parent, body {
    position: relative
}

.form-control, .input-search {
    caret-color: var(--main-color)
}

.auth-btn:hover, .btn-link:active, .btn-link:focus, .btn-link:hover {
    text-decoration-line: none
}

.eak-side__link .eak-ico.stroke svg [stroke], .eak-side__link .eak-ico:not(.stroke):not(.fill) svg [stroke], .menu-items .menu-item svg [stroke] {
    stroke: currentColor
}

.eak-side__link .eak-ico.fill svg [fill]:not([fill=none]), .eak-side__link .eak-ico:not(.stroke):not(.fill) svg [fill]:not([fill=none]), .menu-items .menu-item svg [fill]:not([fill=none]), .menu-items .menu-item.eak-side__logout svg [fill]:not([fill=none]) {
    fill: currentColor
}

body::-webkit-scrollbar-track {
    background-color: #edffff;
    box-shadow: inset 0 0 5px #d6fffe;
    cursor: pointer
}

body::-webkit-scrollbar-thumb {
    border-radius: 1px;
    background-color: var(--main-color);
    height: 100px;
    cursor: pointer
}

body::-webkit-scrollbar {
    width: 10px;
    cursor: pointer
}

.logo100x {
    width: 180px;
    text-align: center;
    display: block;
    margin: 0 auto
}

.form-log {
    margin: auto
}

.section-login {
    height: 100%;
    display: flex
}

.kiruhhh {
    text-align: left;
    font-weight: 600;
    font-size: 23px;
    color: #102252
}

.auth-btn, .btn, .card-cart-header-text.count, .card-cart-header-text.price, .card-header h3, .card-header h5, .card-header p, .product-count, .product-item .product-label {
    text-align: center
}

.header {
    width: 100%;
    padding: 3px 0;
    background-color: transparent;
    box-shadow: 0 4px 34px rgba(0, 0, 0, .15);
    z-index: 4;
    display: none
}

.menu-items {
    display: flex;
    align-items: center;
    gap: 24px;
    margin: 0 auto
}

.btn, .menu-items .menu-item {
    font-weight: 400;
    font-size: 16px;
    align-items: center
}

.menu-items .menu-item {
    display: flex;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 12px;
    font-weight: 400;
    line-height: 21px;
    color: #697493;
    transition: background .2s, color .2s
}

.comment-reply-show, .form-group input:checked ~ .form-group-content, .menu-items .menu-item svg, .play svg, body.loading .overlay {
    display: block
}

.menu-items .menu-item.is-active, .menu-items .menu-item:hover {
    background: rgba(33, 53, 179, .1);
    color: #2135b3
}

.menu-items .menu-item.eak-side__logout {
    color: #697493
}

.menu-items .menu-item.eak-side__logout:hover {
    color: #eb4d4b
}

.navbar, .navbar-brand, .navbar-toggler {
    padding: 0
}

.auth-mobile-links, .card-mobile, .comment-reply, .content-right-mobile, .dropdown-toggle.dropdown-toggle-mobile:after, .form-row-inline .actions .edit-buttons, .form-row-inline.is-editing .actions .btn-icon, .is-locked .go, .loader, .mobile-login-row, .mobile-logo, .mobile-search, .navbar-collapse-header, .product-item input[type=radio], .swiper-button-next::after, .swiper-button-prev::after, .swiper-pagination, .tab-bar, .teacher-content, .teacher-mobile-card, .time-widget .tw-toggle {
    display: none
}

.btn, .card-expert:hover .card-overlay, .cart-list-left, .form-search-inner, .form-search-row, .overlay.is-active, .platform-info-title, .product-items {
    display: flex
}

.navbar-brand {
    min-width: 250px;
    height: 65px;
    margin-right: 50px;
    background-image: url('/images/desktop-logo.svg');
    background-size: contain;
    background-position: left;
    background-repeat: no-repeat
}

.navbar-toggler-icon {
    min-width: 28px;
    width: 28px;
    height: 28px;
    background-image: url("/images/icons/burger-icon.svg")
}

.btn {
    font-style: normal;
    line-height: 19px;
    justify-content: center;
    border-radius: 10px;
    transition: .3s;
    color: #fff
}

.btn-quantity:focus, .btn:focus, .swal2-close:focus {
    box-shadow: none
}

.btn-form-login {
    box-shadow: 0 24px 34px rgba(102, 102, 204, .25)
}

.btn-login {
    min-width: 120px;
    height: 50px;
    background: var(--main-color);
    border: 1px solid var(--main-color);
    color: var(--color-white);
    margin-left: 30px
}

.auth-button svg, .btn-login > svg, .dropdown-item-svg, .task-file .input-file svg, .task-file-uploaded .file span.left svg {
    margin-right: 10px
}

.btn-default-outline:hover, .btn-default:hover, .btn-login:hover {
    color: #fff;
    background: var(--main-hover-color)
}

.btn-login:hover > svg path {
    stroke: #fff;
    margin-right: 10px
}

.btn-login:focus {
    color: #fff;
    background: var(--main-focus-color)
}

.content-left-title {
    font-style: normal;
    font-weight: 400;
    font-size: 50px;
    color: #fff;
    margin-bottom: 10px;
    margin-top: 15px
}

.content-left-subtitle, .input-search {
    font-weight: 400;
    color: #fff;
    font-style: normal
}

.form-search {
    max-width: 625px;
    width: 100%;
    min-height: 50px;
    height: 50px;
    border-radius: var(--border-radius);
    margin-right: auto;
    background-clip: padding-box;
    box-sizing: border-box;
    z-index: 0;
    margin-bottom: 30px
}

.input-search, .input-search:active, .input-search:focus, .input-search:hover {
    border: none;
    outline: 0
}

.form-search-inner {
    align-items: center;
    justify-content: space-between;
    background: 0 0
}

.input-search {
    background: 0 0;
    padding: 0;
    margin-right: 10px;
    flex: 1 1 100%;
    font-size: 16px;
    line-height: 21px
}

.btn-search, .section-main {
    background-repeat: no-repeat;
    background-position: center
}

.input-search:-webkit-autofill, .input-search:-webkit-autofill:focus, .input-search:-webkit-autofill:hover {
    border: none;
    -webkit-text-fill-color: #000000;
    -webkit-box-shadow: none;
    transition: background-color 5000s
}

.input-search::placeholder {
    font-family: Raleway-300;
    font-style: normal;
    font-weight: 300;
    font-size: 16px;
    line-height: 21px;
    color: #afafaf
}

.btn-search {
    padding: 0;
    background-image: url("/images/icons/search-icon.svg");
    background-size: contain
}

.section-main, .section-platform {
    padding: 80px 0
}

.btn-mobile-search {
    background-image: url("/images/icons/mobile-search-close-icon.svg")
}

.content-left-subtitle {
    font-size: 22px;
    line-height: 28px;
    margin-bottom: 35px
}

.content-left-text {
    font-family: Raleway-300;
    font-style: normal;
    font-weight: 300;
    font-size: 20px;
    line-height: 23px;
    color: #fff;
    opacity: .5
}

.section-platform-header-text, .section-title {
    font-style: normal;
    font-weight: 400;
    color: #fff
}

.section-title {
    font-size: 54px;
    margin-bottom: 25px
}

.section-main {
    background-image: url('/images/section-main/section-main.png');
    background-size: cover
}

.section-courses {
    background: #1c1c1c
}

.section-platform-header {
    background: linear-gradient(180deg, #0e0e0e 0, #370e0e 100%);
    border-radius: 30px;
    padding: 20px 40px
}

.section-platform-header-text {
    font-size: 26px;
    text-align: center
}

.accordion-li a, .card-header h3, .card-header h5, .card-price, .platform-info-title {
    font-weight: 700;
    font-style: normal
}

.section-platform-body {
    margin-bottom: 50px
}

.form-search-row {
    justify-content: space-between
}

.form-search-inner {
    max-width: 500px;
    width: 100%;
    height: 100%;
    padding: 14px 20px 14px 50px;
    align-items: center;
    justify-content: space-between;
    background-color: #101010;
    border-radius: var(--border-radius);
    border: 1px solid var(--main-color);
    background-image: url('/images/icons/search-icon.svg');
    background-repeat: no-repeat;
    background-position: left 15px center;
    -webkit-background-size: 24px;
    background-size: 24px;
    margin-right: 10px;
    color: #fff
}

.form-search-inner::placeholder {
    color: #fff
}

.btn-search {
    border: none;
    min-width: 120px;
    max-width: 120px;
    height: 50px
}

.platform-info-title {
    font-size: 178px;
    line-height: 209px;
    color: #df0809;
    text-shadow: 0 24px 34px rgba(223, 8, 9, .3);
    height: 209px
}

.platform-info-title.platform-info-title-3 {
    font-size: 88px
}

.platform-info-description {
    font-family: Raleway-300;
    font-style: normal;
    font-weight: 300;
    font-size: 30px;
    line-height: 47px;
    color: #fff
}

.platform-info-title-users {
    font-size: 70px;
    line-height: 103px
}

.card {
    cursor: pointer;
    border: none;
    transition: .3s;
    border-radius: var(--border-radius);
    background: var(--main-bacground);
    overflow: hidden;
    filter: none
}

.card-login {
    box-shadow: 0 4px 64px rgba(0, 0, 0, .05)
}

.card:hover {
    fill: none
}

.card-login .card-body {
    padding: 20px 40px 30px
}

.card-login .card-header {
    padding: 20px 40px 0
}

.card-header {
    background-color: transparent;
    border-bottom: none
}

.card-header h3 {
    font-size: 30px;
    line-height: 34px;
    color: #202020;
    margin-bottom: 10px
}

.card-header h5 {
    color: #202020
}

.card-header p {
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 19px;
    color: #202020;
    margin-bottom: 0
}

.card-status {
    background: var(--color-white);
    border-radius: var(--border-radius);
    width: 100%;
    height: 5px
}

.card-status-block {
    margin-bottom: 15px
}

.card-checking-title, .card-error-title, .card-success-title {
    line-height: 145%;
    margin: 0;
    font-style: normal;
    font-size: 14px
}

.card.card-status-block .card-body {
    padding: 1rem
}

.card-status.success {
    background: var(--color-success)
}

.card-success-title {
    font-weight: 500;
    color: var(--color-success)
}

.card-status.checking {
    background: var(--color-checking)
}

.card-checking-title {
    font-weight: 500;
    color: var(--color-checking)
}

.card-status.error, .task-file-uploaded .file span.right:hover {
    background: var(--color-error)
}

.card-error-title {
    font-weight: 400;
    color: var(--color-error)
}

.btn-back {
    max-width: 130px;
    height: 50px;
    background: #eaf1ff;
    color: var(--main-color);
    border: 1px solid #eaf1ff;
    border-radius: 30px;
    padding-left: 25px;
    padding-right: 25px;
    line-height: normal
}

.section-header {
    padding: 30px 0;
    margin-bottom: 30px;
    background-color: #f6f7f9
}

.btn-back:focus, .btn-back:hover {
    color: var(--main-color);
    border-color: var(--main-color)
}

.btn-back svg {
    min-width: 24px;
    width: 24px
}

.product-title {
    font-style: normal;
    font-weight: 700;
    font-size: 26px;
    line-height: 35px;
    color: #000;
    margin-bottom: 20px
}

.product-article {
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 23px;
    color: #676767
}

.product-item .product-label, .product-item-title {
    font-size: 16px;
    line-height: 19px;
    font-weight: 500;
    font-style: normal
}

.card-status-body-product-info span, .product-item-title {
    color: #676767
}

.product-items {
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 20px
}

.product-item .product-label, .product-quantity-wrapper {
    width: max-content;
    display: flex;
    align-items: center;
    min-height: 40px
}

.buttons .btn-link, .form-control-reply, .product-item {
    margin-right: 10px;
    margin-bottom: 10px
}

.product-item .product-label {
    cursor: pointer;
    user-select: none;
    padding: 0 15px;
    color: #303030;
    margin-bottom: 0;
    transition: .3s;
    min-width: 40px;
    max-height: 40px;
    height: 100%;
    justify-content: center;
    background: var(--color-white);
    border: 1px solid #c9c9c9;
    border-radius: var(--border-radius)
}

.product-color-items .product-item .product-label {
    min-width: 100px
}

.product-item input[type=radio]:checked + .product-label {
    background: var(--color-black);
    border: 1px solid var(--color-black);
    border-radius: var(--border-radius);
    color: var(--color-white)
}

input[type=radio]:checked .product-item {
    background: red
}

.product-item .product-label:hover {
    background: var(--color-black);
    color: #fff
}

.product-row-wrapper {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 20px
}

.product-row-item {
    margin-right: 30px;
    margin-bottom: 10px
}

.product-quantity-wrapper {
    min-width: 170px;
    height: 40px;
    border-radius: var(--border-radius);
    border: 1px solid #c9c9c9;
    justify-content: space-between
}

.badge-done, .btn-groups, .cart-list-qty-wrapper, .checking-header, .lesson-sub, .lesson-wrapper .buttons, .lock, .product-count, .section-header-bread {
    display: flex;
    align-items: center
}

.product-count {
    justify-content: center;
    background: #303030;
    border: 1px solid #333;
    border-radius: var(--border-radius);
    font-style: normal;
    font-weight: 500;
    font-size: 20px;
    line-height: 28px;
    color: #fff;
    width: 100%;
    min-width: 100px;
    max-width: 100px;
    height: 40px;
    margin: 0 3px
}

.btn-quantity {
    min-width: 60px;
    width: 60px;
    height: 40px;
    transition: .3s
}

.btn-default, .btn-default-outline {
    width: 100%;
    height: 50px;
    min-height: 50px
}

.btn-quantity:hover {
    background-color: #303030
}

.btn-quantity:hover svg rect, .lesson.is-locked:hover .play svg path {
    stroke: white
}

.product-price {
    font-style: normal;
    font-weight: 700;
    font-size: 28px;
    line-height: 37px;
    color: #000
}

.btn-default, .btn-send-reply, .lesson:hover .play {
    background: var(--main-color)
}

.btn-default-outline:focus, .btn-default:focus {
    color: #fff;
    box-shadow: none;
    background: var(--main-focus-color)
}

.btn-default-outline {
    color: var(--main-color);
    border: 1px solid var(--main-color);
    background-color: transparent;
    box-shadow: none
}

.btn-cart, .btn-order {
    width: 190px
}

.card-body-line {
    border-top-color: #c4c4c4;
    margin: 60px 0 40px
}

.product-details {
    margin-bottom: 30px
}

.product-detail-title {
    font-style: normal;
    font-weight: 500;
    font-size: 22px;
    line-height: 28px;
    margin-bottom: 15px;
    color: #000
}

.auth-button, .product-detail-description {
    font-style: normal;
    font-size: 18px;
    font-weight: 400
}

.product-detail-description {
    line-height: 23px;
    color: #000;
    overflow-x: auto
}

.auth-btn, .auth-button {
    color: #fff;
    cursor: pointer
}

.accordion-item, .avatar-wrap, .cart-list-img, .courses-hero, .dropdown-image, .kl-lessonlist__name, .module-image, .overlay, .progress-line, .rt-name, .vld-shown, body.loading {
    overflow: hidden
}

.product-detail-description::-webkit-scrollbar-track {
    background-color: #edffff;
    box-shadow: inset 0 0 5px #d6fffe;
    cursor: pointer
}

.product-detail-description::-webkit-scrollbar-thumb {
    border-radius: 10px;
    background-color: var(--main-color);
    height: 100px;
    cursor: pointer
}

.product-detail-description::-webkit-scrollbar {
    width: 5px;
    height: 5px;
    cursor: pointer
}

.auth-image {
    display: block;
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    height: 40px;
    object-fit: cover;
    margin-right: 10px;
    border-radius: 100%
}

.auth-buttons {
    display: flex;
    align-items: center;
    justify-content: space-around
}

.auth-button, .comment.comment-user-reply {
    flex-direction: row
}

.auth-button {
    background: #66c;
    border-radius: 2px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: Raleway-Regular;
    line-height: 150%;
    padding: 11px 14px;
    box-sizing: border-box;
    width: 156px
}

.auth-btn, .dropdown-item-title {
    font-weight: 500;
    font-size: 16px;
    font-style: normal
}

.auth-button:hover {
    background: #5454ae
}

.auth-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: Exo2-500
}

.auth-btn svg {
    margin-right: 10px;
    transition: .4s
}

.auth-btn:hover {
    transition: .4s;
    color: #c4c4c4
}

.auth-btn:hover svg path {
    transition: .4s;
    fill: #C4C4C4
}

.dropdown-groups, .task-file-uploaded .file {
    display: flex;
    align-items: center;
    justify-content: space-between
}

.dropdown-cart {
    margin-right: 30px;
    margin-left: 30px
}

.dropdown-cart .cart-result {
    font-style: normal;
    font-weight: 400;
    font-size: 12px;
    line-height: 14px;
    letter-spacing: .02em;
    color: #676767
}

.dropdown-cart-menu {
    min-width: 300px
}

.dropdown-cart-item {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 5px;
    margin-bottom: 5px;
    transition: .3s;
    border-radius: var(--border-radius)
}

.dropdown-cart-item:hover, .dropdown-item:hover {
    background-color: var(--main-hover-color)
}

.btn-send-reply:hover, .comment-reply-title b, .dropdown-cart-item:hover *, .whatsapp-button a {
    color: #fff
}

.dropdown-cart-item-image {
    width: 50px;
    min-width: 50px;
    height: 50px;
    min-height: 50px;
    margin-right: 15px;
    border-radius: var(--border-radius);
    object-fit: cover
}

.dropdown-item-content, .field-input .form-control {
    width: 100%
}

.dropdown-item-title {
    line-height: 19px;
    color: #303030
}

.dropdown-item-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%
}

.dropdown-item-left, .dropdown-item-right {
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 19px;
    color: #303030
}

.dropdown-item-link, .modal-header {
    font-weight: 500;
    font-size: 16px;
    line-height: 19px;
    font-style: normal
}

.dropdown-item-link {
    width: max-content;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 10px auto 5px;
    color: var(--main-color);
    border-bottom: 1px solid transparent;
    transition: .3s
}

.dropdown-item-link:hover {
    color: var(--main-hover-color);
    border-color: var(--main-hover-color)
}

.dropdown-item-link:active, .dropdown-item-link:focus {
    color: var(--main-focus-color);
    border-color: var(--main-focus-color)
}

.dropdown-item, .dropdown-item.active, .dropdown-toggle {
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
    line-height: 19px;
    display: flex;
    align-items: center;
    letter-spacing: .02em;
    cursor: pointer
}

.dropdown-toggle {
    color: #000
}

.dropdown.show .dropdown-toggle::after {
    transition: .4s;
    transform: rotate(180deg)
}

.dropdown-toggle::after {
    all: unset;
    display: inline-block;
    margin-left: .5em;
    vertical-align: center;
    content: "";
    width: 15px;
    height: 8px;
    background-image: url('/images/icons/dropdown-icon.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto;
    transition: .4s;
    padding: 1px
}

.dropdown-menu {
    background: #fff;
    box-shadow: 0 0 130px rgba(0, 0, 0, .2);
    border: none;
    border-radius: var(--border-radius);
    padding: .6rem;
    margin: 1.5rem 0 0
}

.dropdown-item {
    margin-bottom: 5px;
    color: #333;
    padding: .65rem 1.5rem;
    border-radius: 8px;
    transition: .3s
}

.dropdown-item:focus, .dropdown-item:hover {
    color: #fff;
    text-decoration: none
}

.dropdown-item:focus {
    background-color: var(--main-focus-color)
}

.btn-link:hover svg path, .dropdown-item.active .dropdown-item-svg path, .dropdown-item:focus .dropdown-item-svg path, .dropdown-item:hover .dropdown-item-svg path, .task-file-uploaded .file span.right:hover svg path {
    stroke: #fff
}

.dropdown-item.active, .dropdown-item:active {
    color: #fff;
    background-color: var(--main-color)
}

.dropdown-item.dropdown-item-logout:focus, .dropdown-item.dropdown-item-logout:hover {
    background-color: var(--color-error)
}

.dropdown-image {
    min-width: 35px;
    max-width: 35px;
    width: 35px;
    height: 35px;
    margin-right: .5em;
    border-radius: 100%;
    object-fit: cover
}

.dropdown-item-image {
    min-width: 24px;
    max-width: 24px;
    width: 24px;
    height: 24px;
    margin-right: .8em
}

.modal-header {
    color: #000;
    padding: 0;
    margin-bottom: 20px
}

.modal-body-reset-password-text, .modal-body-small-text {
    font-weight: 500;
    line-height: 14px;
    color: #606060
}

.modal-body {
    padding: 21px 30px
}

.modal-content {
    border: none
}

.reset-password, .reset-password:hover {
    border-bottom: 1px solid var(--main-color)
}

.modal-open .modal {
    background: rgba(0, 0, 0, .3)
}

.modal-header .close {
    margin: 0;
    min-width: 24px;
    width: 24px;
    height: 24px;
    background: #b4b4b4;
    border-radius: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    opacity: unset
}

.close:not(:disabled):not(.disabled):focus, .close:not(:disabled):not(.disabled):hover {
    opacity: unset;
    background-color: var(--main-hover-color)
}

.modal-header .close svg {
    min-width: 9px;
    width: 9px;
    min-height: 9px
}

.modal-body-small-text {
    font-style: normal;
    font-size: 12px;
    text-align: center;
    margin: 20px auto
}

.modal-body-reset-password-text, .reset-password {
    font-style: normal;
    font-size: 16px;
    text-align: center
}

.modal-body-reset-password-text {
    margin: 40px auto 5px
}

.reset-password {
    width: max-content;
    font-weight: 400;
    line-height: 19px;
    color: var(--main-color);
    margin: 5px auto 0;
    transition: .3s;
    cursor: pointer
}

.form-control, .form-group label, .invalid-feedback {
    font-style: normal;
    font-weight: 400;
    line-height: 16px
}

.form-group, .payment-info, .payment-title, .task-file {
    margin-bottom: 10px
}

.form-group label {
    font-size: 14px;
    color: #697493
}

.form-control {
    height: 50px;
    background: #fff;
    border-radius: var(--border-radius);
    border: 1px solid #2135b3;
    font-size: 16px !important;
    color: #141414;
    padding: 0 15px;
    transition: .3s
}

.form-control:placeholder-shown {
    font-size: 16px;
    font-weight: 400
}

textarea.form-control {
    padding: 10px 15px
}

.form-control:hover {
    border-color: var(--main-hover-color)
}

.form-control:active, .form-control:focus {
    border-color: var(--main-focus-color);
    background: 0 0;
    box-shadow: none
}

.form-control::placeholder {
    font-style: normal;
    font-weight: 300;
    font-size: 14px;
    line-height: 16px;
    color: #909090
}

.invalid-feedback {
    font-size: 14px;
    color: var(--color-error)
}

.section-header-subtitle, .section-header-title {
    font-weight: 500;
    font-style: normal
}

.form-control.is-invalid, .was-validated .form-control:invalid {
    border-color: var(--color-error)
}

.section-header-title {
    font-size: 30px;
    line-height: 41px;
    color: #102252;
    margin: 0
}

.section-header-desc {
    font-size: 16px;
    color: #697493;
    margin: 0;
    padding: 0
}

.section-header-subtitle {
    font-size: 18px;
    line-height: 21px;
    color: #102252;
    margin-top: 10px
}

.card-body-title {
    font-style: normal;
    font-weight: 700;
    font-size: 20px;
    line-height: 23px;
    color: #303030;
    margin-bottom: 20px
}

.cabinet-subtitle, .cart-list-footer span, .custom-checkbox + label, .custom-checkbox + label > a {
    font-style: normal;
    font-weight: 400
}

.cabinet-subtitle, .cabinet-text {
    font-size: 16px;
    line-height: 21px
}

.card-body-row {
    padding: 6px 0
}

.cabinet-subtitle {
    color: #909090
}

.cabinet-text, .cart-list-text, .cart-list-title, .swal2-title {
    font-style: normal;
    font-weight: 500
}

.form-group-delivery, .form-group-mobile, label {
    margin-bottom: 0
}

.btn-logout {
    margin-top: 15px;
    max-width: 220px
}

.card-cabinet {
    margin-bottom: 20px;
    background: #f8f8f8
}

.custom-checkbox {
    position: absolute;
    z-index: -1;
    opacity: 0
}

.custom-checkbox + label, .custom-checkbox + label > a {
    display: inline-flex;
    align-items: center;
    user-select: none;
    font-family: Raleway-Regular;
    font-size: 15px;
    line-height: 115%;
    color: #66c;
    cursor: pointer;
    transition: none
}

.custom-checkbox + label > a {
    transition: .3s;
    border-bottom: 1px solid transparent
}

.custom-checkbox + label > a:hover {
    border-bottom: 1px solid #66c;
    text-decoration-line: none
}

.custom-checkbox + label::before {
    content: '';
    display: inline-block;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    flex-grow: 0;
    border: 2px solid #66c;
    border-radius: 100%;
    margin-right: .5em;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 50% 50%
}

.custom-checkbox:checked + label::before {
    border-color: #66c;
    background-color: transparent;
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0.75 3.99992L3.58 6.82992L9.25 1.16992' stroke='%236666CC' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A")
}

.custom-checkbox:not(:disabled):not(:checked) + label:hover::before {
    border-color: #66c
}

.custom-checkbox:not(:disabled):active + label::before {
    background-color: transparent;
    border-color: #5454ae
}

.custom-checkbox:focus:not(:checked) + label::before {
    border-color: #3b3b8b
}

.custom-checkbox:disabled + label::before {
    background-color: #e9ecef
}

.svgErrorContainer, .svgSuccessContainer {
    display: block;
    position: relative;
    margin: 0 auto;
    width: 120px;
    min-width: 120px;
    height: 120px
}

.card-cart, .cart-list-footer, .cart-list-text, .cart-list-title {
    margin-bottom: 5px
}

.no-border {
    border: 0 !important
}

.swal2-title {
    font-size: 20px;
    line-height: 28px;
    text-align: center;
    color: #000
}

.swal-modal .swal2-close {
    position: absolute;
    top: 0;
    right: 0;
    width: 1.2em;
    height: 1.2em;
    transition: color .1s ease-out;
    border: none;
    outline: 0;
    background: 0 0;
    color: #ccc;
    font-family: serif;
    font-size: 40px;
    cursor: pointer
}

.swal-modal .swal2-close:hover {
    color: #f27474
}

.product-detail-description table {
    width: 100% !important;
    border: 1px solid #c4c4c4;
    table-layout: auto
}

.product-detail-description tr:first-child td {
    background-color: #303030;
    border: none;
    font-style: normal;
    font-weight: 500;
    font-size: 18px;
    line-height: 23px;
    color: #fff;
    white-space: nowrap
}

.product-detail-description tr:not(:first-child) td {
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 23px;
    color: #000
}

.product-detail-description th, td {
    padding: 16px
}

.cart-list-img {
    max-width: 130px;
    width: 100%;
    height: 150px;
    margin-right: 15px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center
}

.cart-list-img img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.cart-list-content {
    display: flex;
    flex-direction: column;
    width: 100%
}

.cart-list-title {
    font-size: 18px;
    line-height: 21px;
    color: #000;
    transition: .3s
}

.cart-list-footer span, .cart-list-text {
    font-size: 14px;
    line-height: 16px;
    color: #676767
}

.accordion-heading, .card-cart-payment-count, .card-cart-payment-price, .card-cart-payment-price span, .card-status-body-product-info, .cart-list-footer, .cart-list-price, .cart-list-product-count, .payment-info, .payment-title {
    font-weight: 500;
    color: #000;
    font-style: normal
}

.cart-list-title:active, .cart-list-title:focus, .cart-list-title:hover {
    color: var(--main-color)
}

.cart-list-footer-content {
    margin-top: auto
}

.cart-list-footer {
    font-size: 14px;
    line-height: 16px
}

.copyright {
    padding: 20px 0 5px
}

.cart-list-end, .cart-list-middle, .cart-list-right {
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center
}

.btn-cart-qty, .cart-list-remove {
    width: 30px;
    min-width: 30px;
    height: 30px;
    border-radius: 100%;
    transition: .3s
}

.cart-list-price {
    font-size: 22px;
    line-height: 28px;
    text-align: center
}

.cart-list-remove {
    background: #f6f6f6;
    display: flex;
    align-items: center;
    justify-content: center
}

.btn-cart-qty:hover, .cart-list-remove:hover {
    background: #1949a5
}

.accordion-heading.acc-open svg rect, .btn-cart-qty:hover svg rect, .btn-icon.btn-edit:active svg path, .btn-icon.btn-edit:focus svg path, .btn-icon.btn-edit:hover svg path, .cart-list-remove:hover svg rect, .pagination .next:hover svg path, .pagination .prev:hover svg path {
    fill: #fff
}

.btn-cart-qty {
    background: #f7f7f7
}

.btn-cart-qty svg {
    min-width: 24px;
    max-width: 24px;
    width: 24px
}

.cart-list-product-count {
    font-size: 16px;
    line-height: 19px;
    text-align: center;
    margin: 0 15px
}

.card-cart-header-text, .card-cart-payment-count span {
    line-height: 21px;
    font-style: normal;
    font-weight: 500;
    color: #000
}

.card-cart-header-text, .lesson-text {
    font-size: 18px
}

.card-cart-header-line {
    border-top: 1px solid #c4c4c4
}

.card-cart-payment-count {
    font-size: 16px;
    line-height: 19px;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.card-cart-payment-count span {
    font-size: 16px;
    text-align: right
}

.card-cart-payment-price {
    font-size: 16px;
    line-height: 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px
}

.card-cart-payment-price span {
    font-size: 16px;
    line-height: 28px
}

.card-payment .card-body {
    padding: 40px
}

.payment-left, .payment-right, .section-platform-learn-lists {
    display: flex;
    flex-direction: column
}

.payment-card {
    max-width: 380px;
    width: 100%;
    margin-bottom: 20px
}

.payment-info {
    font-size: 24px;
    line-height: 28px
}

.payment-title {
    font-size: 30px;
    line-height: 42px
}

.payment-subtitle {
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 23px;
    color: #676767;
    margin-bottom: 15px
}

.card-status-header-page-link, .card-status-header-title {
    line-height: 145%;
    font-weight: 500;
    font-style: normal
}

.btn-send-check {
    margin-top: 20px
}

.btn-send {
    width: 180px
}

.btn-sends {
    max-width: 260px
}

textarea.form-control:active, textarea.form-control:focus {
    background: #fff
}

.task-file label {
    margin-bottom: unset
}

.task-file .input-file .text {
    font-size: 16px;
    color: var(--main-color)
}

.form-payment {
    max-width: 300px
}

.task-file .input-file {
    background: #eee;
    border: 1px solid #c4c4c4;
    box-sizing: border-box;
    border-radius: var(--border-radius);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0 15px;
    width: 100%;
    height: 50px;
    font-size: 16px;
    color: var(--main-color);
    margin-bottom: unset;
    cursor: pointer
}

.task-file-uploaded {
    padding: 5px 10px 5px 15px;
    margin-bottom: 10px;
    background: #eee;
    border-radius: var(--border-radius);
    display: none
}

.task-file-uploaded .file span:not(.text) {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    font-size: 16px;
    line-height: 130%;
    color: var(--main-color)
}

.task-file-uploaded .file span.text {
    max-width: 170px;
    overflow: hidden;
    display: block
}

.task-file-uploaded .file span.right {
    width: 40px;
    min-width: 40px;
    min-height: 40px;
    height: 40px;
    background: #ffe9e9;
    border-radius: var(--border-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: .3s
}

.task-file-uploaded .file span.right svg {
    cursor: pointer
}

.card-status-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px
}

.svgCheckingContainer {
    display: inline-block;
    position: relative;
    width: 34px;
    min-width: 34px;
    height: 34px
}

.card-status-svg-container {
    display: inline-block;
    position: relative;
    min-width: 24px;
    max-width: 24px;
    width: 24px;
    height: 24px;
    margin-right: 8px
}

.module-image, .pagination .prev {
    margin-right: 20px
}

.card-status-header-title {
    font-size: 14px;
    color: #000;
    display: flex;
    align-items: center
}

.card-status-header-title.checking {
    color: var(--color-checking)
}

.card-status-header-title.error {
    color: var(--color-error)
}

.card-status-header-title.success {
    color: var(--color-success)
}

.card-status-header-page-link {
    font-size: 14px;
    color: var(--main-color)
}

.card-status-header-page-link span {
    border-bottom: 1px solid #fff;
    transition: .3s;
    padding-bottom: 2px
}

.card-status-header-page-link:hover span {
    color: var(--main-hover-color);
    border-bottom: 1px solid var(--main-hover-color)
}

.card-status-header-page-link:focus span {
    color: var(--main-focus-color);
    border-bottom: 1px solid var(--main-focus-color)
}

.card-status-header-page-link svg {
    width: 24px;
    min-width: 24px;
    margin-left: 5px
}

.card-status-body-image {
    width: 100%;
    min-height: 150px;
    max-height: 150px;
    height: 100%;
    -webkit-background-size: cover;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    border-radius: var(--border-radius)
}

.card-status-body-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    width: 100%
}

.card-status-body-product-title {
    font-style: normal;
    font-weight: 500;
    font-size: 18px;
    line-height: 21px;
    color: #000;
    margin-bottom: 5px;
    margin-right: 20px
}

.btn-course, .card-news .date, .card-news .subtitle, .card-news .title, .card-status-body-product-article, .comment-author span, .comment-text, .section-experts, .section-platform-learn-list, .section-platform-learn-title {
    font-weight: 400
}

.card-status-body-product-article {
    font-style: normal;
    font-size: 16px;
    line-height: 19px;
    color: #676767;
    margin-bottom: 5px
}

.accordion-body, .lesson-title {
    font-weight: 400;
    font-style: normal
}

.card-status-body-product-info {
    font-size: 15px;
    line-height: 16px;
    margin-bottom: 5px
}

.card-news .date {
    font-style: normal;
    font-size: 14px;
    line-height: 130%;
    color: #a5a7b0;
    margin-bottom: 10px
}

.card-news .title {
    font-style: normal;
    font-size: 17px;
    line-height: 150%;
    color: #2a64d6;
    margin-bottom: 10px;
    display: inline-block
}

.card-news .subtitle {
    font-style: normal;
    font-size: 14px;
    line-height: 155%;
    color: #65676e;
    margin-bottom: 0
}

.accordion {
    width: 100%;
    padding: 0 0 25px
}

.accordion-item {
    border-radius: 6px;
    margin-bottom: 10px;
    background: #fff;
    border: 1px solid var(--main-color)
}

.accordion-heading {
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 18px;
    background: #fff;
    border-radius: 6px
}

.module-image, label {
    display: inline-block
}

.accordion-heading.acc-open {
    background: #2135b3;
    color: #fff
}

.module-image {
    border-radius: 10px;
    vertical-align: middle;
    width: 150px;
    height: 150px;
    object-fit: cover
}

.accordion-heading svg {
    transform: rotate(0);
    transition: .4s;
    margin-left: auto
}

.accordion-heading.acc-open svg {
    transition: .4s;
    transform: rotate(-180deg)
}

.accordion-body {
    padding: 0;
    font-size: 16px;
    color: #2b2a29;
    background: #fff
}

.accordion-ul {
    margin: 0;
    padding: 0
}

.accordion-li {
    list-style-type: none;
    cursor: pointer;
    border-radius: 6px;
    transition: .3s;
    border-bottom: 1px solid #c3c8cc
}

.accordion-li a {
    padding: 20px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    word-break: break-all;
    font-size: 17px;
    line-height: 155%;
    color: #333;
    margin-right: 10px
}

.accordion-li a img {
    margin-left: 15px
}

.accordion-li:hover {
    background: #e9eef3
}

.course-col, .section-payment-weight {
    margin-bottom: 20px
}

.form-group-delivery label {
    margin-bottom: 0;
    top: -2px;
    position: relative
}

.form-group-delivery input[type=radio] {
    outline: 0
}

.form-control-message {
    resize: none;
    border-radius: 5px
}

.form-group-content {
    display: none;
    margin-left: 17px;
    margin-bottom: 5px
}

.card-news {
    border-radius: var(--border-radius)
}

.card-news .news-image {
    width: 100%;
    height: 190px;
    min-height: 190px;
    max-height: 190px;
    object-fit: cover
}

.card-body iframe, .panel-body iframe {
    width: 100% !important;
    border-radius: var(--border-radius)
}

.card-price {
    font-size: 20px;
    line-height: 115%;
    color: #fff;
    margin-bottom: 20px
}

.whatsapp-button {
    position: fixed;
    right: 13px;
    bottom: 70px;
    transform: translate(-50%, -50%);
    background: #25d366;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    color: #fff;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center
}

.whatsapp-button:after, .whatsapp-button:before {
    content: " ";
    display: block;
    position: absolute;
    border: 1px solid #25d366;
    left: -20px;
    right: -20px;
    top: -20px;
    bottom: -20px;
    border-radius: 50%;
    animation: 1.5s linear infinite animate;
    opacity: 0;
    backface-visibility: hidden
}

.whatsapp-button:after {
    animation-delay: .5s
}

@keyframes animate {
    0% {
        transform: scale(.5);
        opacity: 0
    }
    50% {
        opacity: 1
    }
    100% {
        transform: scale(1.2);
        opacity: 0
    }
}

input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0
}

input[type=number] {
    -moz-appearance: textfield
}

.card-course {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: var(--border-radius)
}

.lesson-title {
    font-size: 16px;
    color: #102252;
    margin-bottom: 5px;
    line-height: normal
}

.card-course-image {
    min-height: 246px;
    max-height: 366px;
    width: 100%;
    object-fit: contain;
    object-position: center;
    border-radius: 25px
}

.card-course-name {
    font-style: normal;
    font-weight: 500;
    font-size: 20px;
    line-height: 115%;
    text-align: center;
    margin-top: 15px;
    margin-bottom: 20px;
    color: #333
}

.btn-course, .expert-description, .expert-name, .section-experts, .section-platform-learn-list {
    font-style: normal;
    color: #fff
}

.course-main {
    background: #f8f8f8;
    padding: 25px;
    border-radius: 10px
}

.breadcrumb, .card-expert {
    background-color: transparent
}

.btn-course {
    font-size: 18px;
    line-height: 150%;
    box-shadow: 0 24px 34px rgba(102, 102, 204, .2);
    margin-bottom: 10px
}

.section-platform-learn-title {
    font-style: normal;
    font-size: 54px;
    line-height: 62px;
    color: #fff;
    margin-bottom: 30px
}

.section-platform-learn-list {
    font-size: 22px;
    line-height: 24px;
    margin-bottom: 5px
}

.section-experts {
    font-size: 54px;
    line-height: 62px
}

.swiper {
    width: 100%;
    height: 100%
}

.expert-image {
    width: 100%;
    height: 366px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain
}

.expert-name {
    font-weight: 700;
    font-size: 20px;
    line-height: 23px;
    text-align: center
}

.expert-description {
    font-family: Raleway-300;
    font-weight: 300;
    font-size: 18px;
    line-height: 21px;
    text-align: center
}

.swiper-button-prev img {
    transform: rotate(180deg)
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: -35px
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: -35px
}

.swiper-button-next, .swiper-button-prev {
    top: 40%
}

.swiper-block {
    position: relative;
    width: 100%;
    height: auto;
    margin-bottom: 50px
}

.breadcrumb {
    padding: 10px 0;
    margin-bottom: 0
}

.breadcrumb-item, .breadcrumb-item.active, .breadcrumb-item > a {
    color: #a0a0a0
}

.btn-reply:hover, .comment-text {
    color: #292929
}

.section-courses-page, .section-experts-page {
    background-color: #0e0e0e
}

.breadcrumb-title {
    margin-bottom: 10px;
    font-weight: 700;
    margin-top: 20px
}

.card-expert {
    position: relative;
    transition: .3s;
    padding-top: 10px;
    border: 1px solid transparent
}

.card-overlay {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    background-color: rgba(0, 0, 0, .7);
    display: none;
    align-items: center;
    justify-content: center
}

.btn-expert-link {
    width: 212px
}

.card-expert:hover {
    border: 1px solid var(--main-color)
}

.comment {
    width: 100%;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #f3f3f3;
    display: flex;
    flex-direction: column
}

.comment:last-child, .lesson-document-download {
    border-bottom: 1px solid transparent
}

.comment-main {
    display: flex;
    flex-direction: row;
    align-items: flex-start
}

.comment-header {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start
}

.comment-image {
    width: 50px;
    min-width: 50px;
    max-width: 50px;
    height: 50px;
    border-radius: 50%;
    margin-right: 10px;
    object-fit: cover
}

.btn-send-reply, .comment-text {
    border-radius: 10px;
    font-style: normal;
    font-size: 16px
}

.comment-author span {
    font-style: normal;
    font-size: 14px;
    color: #909090;
    margin-left: 5px
}

.comment-text {
    margin-top: 5px;
    width: 100%;
    background: #f9f9f9;
    padding: 20px;
    line-height: 23px;
    word-break: break-all
}

.chat-md, .gap-hint {
    word-break: break-word
}

.form-group-reply {
    display: flex;
    align-items: center;
    justify-content: flex-start
}

.btn-send-reply {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 145%;
    text-align: center;
    color: #fff;
    height: 48px;
    margin-bottom: 10px;
    width: 180px
}

.btn-reply, .chat-day, .lesson-chat__close, .lesson-document-li, .rt-row, .time-widget {
    align-items: center;
    display: flex
}

.lesson-text, .text {
    font-style: normal;
    font-weight: 400;
    line-height: 130%;
    color: #303030
}

.text {
    font-size: 20px
}

.btn-reply, .comment-reply-title {
    font-style: normal;
    font-size: 16px;
    line-height: 18px
}

.comment-replies {
    width: 96%;
    padding: 15px 0 0;
    margin-left: auto
}

.comment-reply-title {
    font-weight: 700;
    color: #8b8b8b;
    margin-bottom: 10px
}

.btn-reply {
    font-weight: 400;
    color: #979797;
    justify-content: center;
    transition: .3s
}

.lesson-documents-ul {
    list-style-type: none;
    margin: 15px 0;
    width: 100%;
    padding: 0
}

.lesson-document-li {
    padding: 20px;
    background: #f6f7f9;
    border-radius: var(--border-radius);
    justify-content: space-between;
    margin-bottom: 10px
}

.lesson-items-title {
    font-weight: 500;
    font-size: 20px;
    color: #102252;
    margin-bottom: 5px
}

.lesson-document-download, .lesson-document-name span {
    font-style: normal;
    font-weight: 400;
    font-size: 18px;
    line-height: 130%
}

.gap-task-row, .lesson-document-name {
    display: flex;
    align-items: center;
    gap: 5px
}

.lesson-document-name span {
    color: #102252
}

.lesson-document-download {
    color: var(--main-color);
    transition: .4s
}

.lesson-document-download:hover {
    color: var(--main-color);
    border-bottom: 1px solid var(--main-color)
}

.btn-link {
    width: 220px;
    transition: .3s
}

.auth-logo {
    min-height: 54px;
    width: 350px;
    margin: 0 auto 40px;
    color: #102252;
    display: flex;
    gap: 30px;
    align-items: center;
    font-size: 20px;
    line-height: normal
}

.eak-side {
    position: fixed;
    top: 10px;
    bottom: 10px;
    left: 10px;
    width: 115px;
    z-index: 1000;
    background: #fff;
    border-radius: 26px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, .08);
    padding: 12px 8px;
    flex-direction: column;
    align-items: center
}

.eak-side__link, .eak-side__logo {
    display: flex;
    border-radius: 18px;
    width: 100%
}

.eak-side__logo {
    align-items: center;
    justify-content: center;
    height: 54px;
    margin-bottom: 20px
}

.eak-side__logo img {
    max-height: 34px;
    width: auto
}

.lesson-chat__close svg, .lesson-composer__send svg {
    min-width: 24px;
    max-width: 24px;
    min-height: 24px;
    max-height: 24px
}

.eak-side__nav {
    list-style: none;
    padding: 0;
    margin: 4px 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 10px
}

.eak-side__link {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    color: #697493;
    transition: background .2s, box-shadow .2s, color .2s;
    padding: 15px
}

.btn-icon, .eak-ico {
    border-radius: 12px
}

.eak-side__link:hover {
    background: #f6f7ff;
    color: var(--main-color)
}

.eak-side__link.is-active {
    background: #e6ecff;
    color: var(--main-color)
}

.eak-ico {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    min-height: 28px;
    line-height: 1
}

.field-actions, .field-inline {
    align-items: center;
    display: flex;
    gap: 12px
}

.course-desc, .lesson + .lesson, .progress-wrap {
    margin-top: 10px
}

.course-desc, .eak-side__link .eak-ico, .lesson-count {
    color: #697493
}

.eak-side__link.is-active .eak-ico, .eak-side__link:hover .eak-ico {
    color: #2135b3
}

.eak-side__link .eak-ico svg * {
    transition: fill .2s, stroke .2s
}

.eak-tx {
    text-align: center;
    line-height: 1;
    font-size: 15px
}

.eak-side__footer {
    margin-top: auto;
    width: 100%;
    padding-top: 6px
}

.eak-side__logout {
    color: #555
}

.eak-side__link.eak-side__logout .eak-ico svg [fill]:not([fill=none]), .eak-side__link.eak-side__logout .eak-ico svg [stroke] {
    fill: #697493
}

.eak-side__link.eak-side__logout:hover .eak-ico svg [fill]:not([fill=none]), .eak-side__link.eak-side__logout:hover .eak-ico svg [stroke] {
    fill: var(--color-error)
}

.eak-side__link.eak-side__logout:hover .eak-ico {
    color: inherit
}

.eak-side__logout:hover {
    background: #fff1f1;
    color: var(--color-error)
}

.field-input {
    flex: 1;
    min-width: 0
}

.field-actions {
    white-space: nowrap
}

.btn-icon {
    min-width: 50px;
    padding: 4px;
    display: flex;
    align-items: center
}

.form-row-inline {
    margin-bottom: 18px
}

.form-row-inline .control-wrap {
    display: grid;
    grid-template-columns:1fr auto;
    gap: 12px;
    align-items: center
}

.form-row-inline .actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px
}

.form-row-inline.is-editing .actions .edit-buttons {
    display: flex;
    gap: 12px
}

.btn-cancel, .btn-save {
    padding: 0 15px
}

.profile-aside {
    display: flex;
    flex-direction: column;
    align-items: center
}

.avatar-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 128px;
    height: 128px;
    border-radius: 50%;
    margin: 0 auto;
    background: #f5f7ff;
    cursor: pointer
}

.avatar-wrap img, .courses-hero .slide-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block
}

.header-line {
    display: flex;
    align-items: center;
    gap: 20px
}

.courses-hero {
    border-radius: 16px;
    position: relative;
    z-index: 0
}

.courses-hero .swiper, .courses-hero .swiper-slide, .courses-hero .swiper-wrapper {
    height: 260px
}

.course-card {
    border: 0;
    border-radius: 16px;
    background: #fff;
    transition: box-shadow .2s, transform .2s;
    box-shadow: 0 12px 28px rgba(29, 78, 216, .1);
    position: relative;
    cursor: pointer
}

.course-title {
    transition: color .15s;
    font-size: 16px;
    font-weight: 600;
    margin: 12px 0 8px;
    color: #102252
}

.course-go, .go, .lock, .rt-score {
    margin-left: auto
}

.course-go svg path, .go svg path {
    transition: stroke .15s
}

.course-card:focus-within .course-title, .course-card:hover .course-title {
    color: var(--main-color)
}

.course-card:focus-within .course-go svg path, .course-card:hover .course-go svg path {
    stroke: var(--main-color)
}

.course-go:focus-visible {
    outline: rgba(37, 99, 235, .35) solid 2px;
    outline-offset: 2px
}

.course-card:hover {
    box-shadow: 0 12px 28px rgba(29, 78, 216, .18);
    transform: translateY(-2px)
}

.lesson, .lesson:hover {
    box-shadow: 0 5px 12px 0 rgba(0, 0, 0, .1)
}

.lesson-chat-fab, .time-widget {
    box-shadow: 0 10px 26px rgba(0, 0, 0, .22)
}

.course-cover {
    width: 100%;
    height: 160px;
    border-radius: 12px;
    object-fit: cover;
    display: block
}

.course-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: #697493
}

.course-meta .dot {
    width: 4px;
    height: 4px;
    border-radius: 999px;
    background: #cbd5e1
}

.course-go {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .15s, border-color .15s
}

.lesson, .play, .play svg path {
    transition: .15s
}

.course-go:hover {
    background: #eef2ff;
    border-color: #c7d2fe
}

.progress-line {
    position: relative;
    width: 100%;
    height: 6px;
    border-radius: 999px;
    background: #e5e7eb
}

.progress-bar {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 0%;
    background: linear-gradient(90deg, #4f46e5, #60a5fa)
}

.progress-caption {
    margin-top: 6px;
    font-size: 12px;
    color: #64748b;
    display: flex;
    justify-content: space-between
}

.progress-caption .percent, .rt-name {
    font-weight: 600;
    color: #0f172a
}

.course-head {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 20px;
    justify-content: space-between
}

.course-head img {
    height: 65px;
    border-radius: 20px
}

.course-head h1 {
    font-size: 32px;
    margin: 0;
    color: #102252
}

.lesson-page-title {
    margin-top: 20px;
    font-weight: 500;
    font-size: 26px;
    color: #102252;
    line-height: normal
}

.lesson-sub, .lesson-sub.secondary {
    color: #9dafd0
}

.lessons {
    margin-top: 16px
}

.lesson {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-radius: 20px;
    background: var(--card);
    border: 1px solid #e0e6f4;
    cursor: pointer
}

.go, .play {
    display: grid;
    border-radius: 999px;
    place-items: center
}

.section-content-variant, .section-header-variant {
    padding-top: 20px;
    padding-bottom: 20px
}

.lesson:hover {
    border-color: var(--main-color)
}

.lesson:not(.is-locked):hover .play svg path {
    fill: white
}

.play {
    width: 44px;
    height: 44px;
    background: #e6ecff;
    flex: 0 0 auto
}

.lesson-sub {
    line-height: normal;
    font-size: 14px
}

.badge-done, .lock {
    gap: 6px;
    font-size: 12px;
    white-space: nowrap
}

.kl-lessonlist, .kl-lessonlist__name, .kl-lessonlist__title {
    font-size: 16px
}

.lesson-sub.success {
    color: #03b113
}

.go {
    width: 28px;
    height: 28px;
    flex: 0 0 auto
}

.lesson:hover .go svg path {
    stroke: var(--brand)
}

.badge-done {
    color: var(--ok);
    font-weight: 600
}

.lock {
    color: #64748b
}

.is-locked {
    cursor: not-allowed
}

.section-header-variant {
    background-color: #fff
}

.section-content.variant-left, .section-header-variant.variant-left {
    padding-left: 150px
}

.section-header-bread {
    max-width: 991px;
    gap: 10px;
    color: #697493;
    line-height: normal;
    flex-wrap: wrap
}

.rt-card {
    background: #fff;
    border: 1px solid var(--rt-ring);
    border-radius: 16px;
    padding: 16px
}

.rt-row {
    gap: 12px;
    padding: 10px 12px;
    border-radius: 12px
}

.rt-row + .rt-row {
    margin-top: 6px
}

.rt-rank {
    width: 20px;
    text-align: right;
    font-weight: 700
}

.rt-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    flex: 0 0 32px
}

.rt-namepill {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--rt-blue-100);
    border: 1px solid var(--rt-blue-200);
    border-radius: 10px;
    padding: 8px 10px;
    min-height: 38px
}

.rt-score {
    font-weight: 700;
    color: var(--rt-blue)
}

.rt-star {
    margin-left: 6px;
    color: #f59e0b
}

.rt-bar {
    height: 6px;
    border-radius: 999px;
    background: #e5e7eb;
    position: relative;
    margin-top: 0
}

.rt-bar__fill {
    position: absolute;
    inset: 0 auto 0 0;
    background: var(--rt-green);
    width: 0;
    border-radius: 999px
}

.time-widget {
    position: fixed;
    right: 24px;
    top: 19px;
    z-index: 4;
    gap: 18px;
    padding: 12px 22px;
    color: #fff;
    background: linear-gradient(225deg, #e44146 0, #ea61c2 100%);
    border-radius: 20px;
    cursor: pointer
}

.time-widget .tw-left {
    display: flex;
    align-items: center;
    gap: 16px
}

.time-widget .tw-num {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    line-height: 1;
    font-weight: 800;
    white-space: nowrap
}

.time-widget .tw-num b {
    font-size: 26px;
    font-weight: 500;
    line-height: 1
}

.time-widget .tw-num small {
    font-weight: 500;
    font-size: 14px;
    margin-left: 6px
}

.time-widget .tw-sub {
    font-style: italic;
    opacity: .95;
    max-width: 116px;
    font-size: 13px;
    white-space: normal;
    line-height: 1
}

.pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 15px;
    margin-bottom: 15px
}

.pagination .next, .pagination .page-number, .pagination .prev {
    align-items: center;
    cursor: pointer;
    display: flex;
    height: 40px;
    justify-content: center;
    width: 40px;
    min-width: 40px;
    border-radius: 10px
}

.pagination .next {
    margin-left: 20px
}

.pagination .next:hover, .pagination .prev:hover {
    background: #2a64D6FF
}

.pagination .page-numbers {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap
}

.pagination .page-numbers .active {
    background: #2a64D6FF !important;
    color: #fff !important
}

.pagination .page-numbers .page-number {
    background: 0 0;
    border: 1px solid #2a64D6FF;
    color: #2a64D6FF;
    font-weight: 400;
    font-size: 14px;
    line-height: 1.5;
    margin-right: 8px
}

.pagination .page-numbers .page-number:hover {
    background: #1949A5FF;
    color: #fff
}

.pagination .page-numbers .page-number:last-child {
    margin-right: unset
}

.overlay {
    bottom: 0;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    align-items: center;
    display: none;
    justify-content: center;
    z-index: 9999
}

.overlay.is-full-page {
    z-index: 9999;
    position: fixed
}

.vld-background {
    backdrop-filter: blur(2px)
}

.overlay .vld-background {
    bottom: 0;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    opacity: .5;
    background: rgba(0, 0, 0, .6)
}

.loading {
    display: block !important;
    z-index: 9999999999;
    position: fixed
}

.vld-icon svg {
    width: 100px
}

@media (max-width: 767.98px) {
    .vld-icon svg {
        width: 65px
    }
}

.lesson-subtitle {
    font-size: 16px;
    margin-bottom: 15px;
    color: #697493
}

.kl-lessonlist {
    display: block;
    font-weight: 400;
    color: #697493
}

.kl-lessonlist__title {
    color: #697493;
    margin-bottom: 12px
}

.kl-lessonlist__ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px
}

.kl-lessonlist__li {
    border-radius: 14px;
    background: #f6f7f9;
    border: 1px solid transparent;
    transition: background .2s, border-color .2s, box-shadow .2s
}

.kl-lessonlist__li.is-active {
    background: #0e1c6b;
    box-shadow: 0 6px 20px rgba(0, 0, 0, .1)
}

.kl-lessonlist__li.is-active .kl-lessonlist__icon, .kl-lessonlist__li.is-active .kl-lessonlist__name {
    color: #fff
}

.kl-lessonlist__li.is-active .kl-lessonlist__meta {
    color: #b4c2ff
}

.kl-lessonlist__li:not(.is-active):hover {
    border-color: var(--main-color)
}

.kl-lessonlist__li:hover .kl-lessonlist__icon {
    color: var(--main-color);
    border-color: rgba(33, 53, 179, .25)
}

.kl-lessonlist__link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px
}

.kl-lessonlist__icon {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #2135b3;
    border: none;
    transition: color .2s, border-color .2s, background .2s
}

.kl-lessonlist__content {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0
}

.kl-lessonlist__name {
    line-height: normal;
    color: #102252
}

.kl-lessonlist__meta {
    line-height: normal;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: #97a1bc
}

.kl-lessonlist__check, .kl-lessonlist__li.is-viewed .kl-lessonlist__meta {
    color: #14bf2f
}

.gap-task-card {
    background: #f6f7f9;
    border: 1px solid #f6f7f9;
    border-radius: 12px;
    padding: 16px;
    margin-top: 20px
}

.gap-hint, .gap-solution {
    background: #fff;
    font-style: italic
}

.gap-task-title {
    font-weight: 600;
    color: #0e1b4d
}

.chat-md strong, .gap-task-num {
    font-weight: 700
}

.gap-task-num {
    color: #2135b3;
    min-width: 22px;
    line-height: 1.6
}

.gap-solution {
    flex-basis: 100%;
    border: 1px solid #eceff5;
    border-radius: 8px;
    padding: 8px 10px;
    color: #697493;
    font-size: 14px;
    line-height: normal;
    margin-bottom: 10px
}

.gap-chunk {
    display: inline-block;
    line-height: normal
}

.gap-input {
    border: 1px solid #dde3f0;
    border-radius: 8px;
    padding: 6px 10px;
    min-width: 140px;
    transition: border-color .15s, box-shadow .15s;
    outline: 0 !important
}

.gap-input:focus {
    border-color: #2135b3;
    box-shadow: 0 0 0 3px rgba(33, 53, 179, .12);
    outline: 0 !important
}

.gap-input.is-ok {
    border-color: #26c281;
    background: #f6fffa;
    outline: 0 !important
}

.gap-input.is-bad {
    border-color: #e74c3c;
    background: #fff5f5;
    outline: 0 !important
}

@media (max-width: 576px) {
    .kl-lessonlist {
        display: none
    }

    .gap-task-row {
        align-items: flex-start
    }

    .gap-task-text {
        column-gap: 5px;
        row-gap: 5px
    }

    .gap-input {
        min-width: 180px
    }

    body.chat-open {
        position: fixed;
        width: 100%;
        overflow: hidden
    }
}

.gap-field {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px
}

.gap-hint {
    border: 1px solid #eceff5;
    border-radius: 6px;
    padding: 2px 8px;
    font-size: 13px;
    line-height: 1.3;
    color: #6b7280;
    max-width: 100%
}

.gap-task-text {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    column-gap: 10px;
    row-gap: 8px
}

.gap-task-images {
    gap: 5px;
    display: flex;
}

.gap-figure-img {
    max-height: 240px;
    object-fit: contain;
    background: #f8f9fa;
    cursor: pointer;
    transition: transform 0.2s;
}

.gap-figure-img:hover {
    transform: scale(1.02);
}

.gap-lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .8);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 1050;
}

.gap-lightbox img {
    max-width: 90%;
    max-height: 90%;
    border-radius: 8px;
    box-shadow: 0 0 20px rgba(0, 0, 0, .5);
}

.gap-lightbox-close {
    position: absolute;
    top: 20px;
    right: 30px;
    font-size: 32px;
    color: #fff;
    cursor: pointer;
    z-index: 1060;
    transition: color 0.2s;
}

.gap-lightbox-close:hover {
    color: #ccc;
}

.test-page-title {
    margin: 0 auto 10px;
    line-height: normal;
    max-width: 600px;
    font-weight: 500;
    font-size: 28px;
    color: #102252
}

.test-page-sub {
    font-weight: 400;
    font-size: 16px;
    text-align: center;
    color: #697493;
    line-height: normal
}

.lesson-chat-fab {
    outline: 0;
    position: fixed;
    right: max(16px, env(safe-area-inset-right));
    bottom: max(16px, env(safe-area-inset-bottom));
    width: 56px;
    height: 56px;
    border-radius: 999px;
    border: 0;
    color: #fff;
    background: linear-gradient(225deg, #e44146 0, #ea61c2 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 4
}

.lesson-chat {
    position: fixed;
    right: max(15px, env(safe-area-inset-right));
    bottom: calc(max(15px, env(safe-area-inset-bottom)) + 64px);
    width: 420px;
    max-width: calc(100vw - 32px);
    transform: translateY(calc(100% + 24px));
    opacity: 0;
    pointer-events: none;
    z-index: 4;
    transition: transform .28s, opacity .28s
}

.lesson-chat.is-open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto
}

.lesson-chat__panel {
    position: relative;
    overflow: hidden;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 22px 50px rgba(0, 0, 0, .25)
}

.lesson-chat .card {
    height: 75vh;
    max-height: 760px;
    min-height: 420px;
    display: flex;
    flex-direction: column;
    margin: 0;
    border: 0;
    border-radius: 0
}

.lesson-chat .card-header {
    background: var(--lesson-chat-primary);
    color: #fff;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: space-between
}

.lesson-chat .card-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    background: #fff;
    padding: 10px
}

.lesson-chat__close {
    position: relative;
    width: 32px;
    min-width: 32px;
    max-width: 32px;
    height: 32px;
    min-height: 32px;
    max-height: 32px;
    border-radius: 999px;
    border: 0;
    background: rgba(255, 255, 255, .96);
    color: #111;
    font-size: 20px;
    line-height: 32px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .22);
    cursor: pointer;
    justify-content: center
}

.lesson-chat__close svg {
    width: 24px;
    height: 24px
}

.lesson-chat__close:hover {
    background: #fff
}

.chat-meta {
    margin-top: 6px;
    font-size: 11px;
    color: #8b92a3;
    text-align: right
}

.chat-day {
    justify-content: center;
    margin: 10px 0 14px;
    color: #7b8191;
    font-size: 12px
}

.chat-day span {
    background: #eef1ff;
    color: #2135b3;
    padding: 4px 10px;
    border-radius: 12px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .04)
}

.chat-bubble {
    position: relative;
    max-width: 90%;
    padding: 10px 12px;
    border-radius: 12px;
    font-size: 15px;
    line-height: 1.35;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .05)
}

.chat-bubble-user {
    background: #2135b3;
    color: #fff;
    border-top-right-radius: 4px
}

.chat-bubble-bot {
    background: #f3f5ff;
    color: #111;
    border-top-left-radius: 4px
}

.typing span {
    display: inline-block;
    width: 6px;
    height: 6px;
    margin: 0 2px;
    border-radius: 999px;
    background: #9aa0ae;
    animation: 1.2s ease-in-out infinite blink
}

.typing span:nth-child(2) {
    animation-delay: .15s
}

.typing span:nth-child(3) {
    animation-delay: .3s
}

@keyframes blink {
    0%, 100%, 80% {
        opacity: .2
    }
    40% {
        opacity: 1
    }
}

.lesson-composer {
    position: sticky;
    bottom: 0;
    background: #f6f7fb;
    border-top: 1px solid #e7e7ee;
    padding: 12px
}

.lesson-composer__input {
    width: 100%;
    height: 50px;
    border-radius: 12px;
    border: 1px solid #2135b3;
    padding: 0 105px 0 14px;
    outline: 0;
    font-size: 16px
}

.lesson-composer__send {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    min-width: 38px;
    max-width: 38px;
    height: 38px;
    min-height: 38px;
    border-radius: 999px;
    border: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #bfc7ff;
    color: #fff;
    cursor: not-allowed;
    box-shadow: 0 4px 10px rgba(46, 107, 255, 0);
    transition: background .15s, box-shadow .15s
}

.lesson-composer__send svg {
    width: 24px;
    height: 24px
}

.lesson-composer__send.is-active {
    background: #2135b3;
    cursor: pointer;
    box-shadow: 0 6px 14px rgba(33, 53, 179, .35)
}

.lesson-composer__meta {
    margin-top: 6px;
    font-size: 12px;
    color: #9aa0ae;
    display: flex;
    justify-content: space-between
}

.lesson-chat-root .card-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    padding-bottom: 8px
}

.chat-md {
    font-size: 15px;
    line-height: 1.55
}

.chat-md p {
    margin: 0 0 8px
}

.chat-md ol, .chat-md ul {
    margin: 0 0 8px 20px;
    padding: 0
}

.chat-md li {
    margin-bottom: 4px
}

.chat-md em {
    font-style: italic
}

.chat-md code {
    background: #f6f7fb;
    padding: 2px 4px;
    border-radius: 4px;
    font-family: ui-monospace, Menlo, monospace
}

.chat-md pre {
    background: #0f172a;
    color: #e5e7eb;
    padding: 10px 12px;
    border-radius: 8px;
    overflow: auto;
    margin: 0 0 8px
}

.chat-md blockquote {
    border-left: 3px solid #e4e7ef;
    padding-left: 10px;
    color: #667085;
    margin: 0 0 8px
}

.voice-pill{
    display:flex; align-items:center; gap:8px;
    padding:6px 6px; border:1px solid var(--main-color); border-radius:12px;
    background:#f9fafc;
}
.voice-pill__btn{
    border:0; border-radius:100%; padding:6px 10px; cursor:pointer;
    min-width: 36px;
}

.voice-pill__btn.is-primary{ background:var(--main-color); color:#fff; }
.voice-pill__btn[disabled]{ opacity:.5; cursor:not-allowed; }
.voice-pill__timer{ min-width:48px; font-variant-numeric: tabular-nums; text-align:center; font-size: 14px}
.voice-pill__hint{ margin-top:6px; font-size:12px;     color: #9aa0ae; }
.voice-pill__canvas{
    width:200px; height:36px; display:block;
    background:#fff; border-radius:8px;
    --main-color: var(--main-color, #2135B3);
}
@keyframes vp-fade { from{opacity:0; transform:translateY(2px)} to{opacity:1; transform:none} }

.lesson-composer.is-voice .lesson-composer__input,
.lesson-composer.is-voice .lesson-composer__send,
.lesson-composer.is-voice .lesson-composer__meta { display:none; }

.lesson-composer__mic {
    box-shadow: 0 4px 10px rgba(46, 107, 255, 0);
    position:absolute; right: 52px; top:50%; transform: translateY(-50%);
    width:38px; height:38px; border-radius:999px; border:0; background:#f0f2ff; color:#2135b3;
    display:flex; align-items:center; justify-content:center; cursor:pointer;
}
.lesson-composer__mic:hover{ background:#e6e9ff; }

@media (max-width: 1590px) {
    .card-product .btn-link, .card-product .title, .payment-subtitle, .section-header-subtitle {
        font-size: calc(14px + (4 + 4 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(16px + (5 + 5 * .7) * ((100vw - 360px) / 1590))
    }

    .card-product .text {
        font-size: calc(12px + (4 + 4 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(14px + (7 + 7 * .7) * ((100vw - 360px) / 1590))
    }

    .footer-text {
        font-size: calc(13px + (3 + 3 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(16px + (5 + 5 * .7) * ((100vw - 360px) / 1590))
    }

    .breadcrumb-item {
        font-size: calc(14px + (3 + 3 * .7) * ((100vw - 360px) / 1590))
    }

    .breadcrumb-title {
        font-size: calc(21px + (4 + 4 * .7) * ((100vw - 360px) / 1590))
    }

    .cabinet-username {
        font-size: calc(24px + (12 + 12 * .7) * ((100vw - 360px) / 1590))
    }

    .cabinet-description {
        font-size: calc(16px + (4 + 4 * .7) * ((100vw - 360px) / 1590))
    }

    .cabinet-title {
        font-size: calc(24px + (6 + 6 * .7) * ((100vw - 360px) / 1590))
    }

    .product-article, .product-detail-description {
        font-size: calc(14px + (4 + 4 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(16px + (7 + 7 * .7) * ((100vw - 360px) / 1590))
    }

    .product-title {
        font-size: calc(20px + (6 + 6 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(26px + (9 + 9 * .7) * ((100vw - 360px) / 1590))
    }

    .product-detail-title {
        font-size: calc(16px + (6 + 6 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(19px + (9 + 9 * .7) * ((100vw - 360px) / 1590))
    }

    .section-header-title {
        font-size: calc(22px + (8 + 8 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(24px + (17 + 17 * .7) * ((100vw - 360px) / 1590))
    }

    .payment-info {
        font-size: calc(20px + (4 + 4 * .7) * ((100vw - 360px) / 1590))
    }

    .payment-title {
        font-size: calc(22px + (8 + 8 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(28px + (13 + 13 * .7) * ((100vw - 360px) / 1590))
    }

    .platform-info-description {
        font-size: calc(14px + (16 + 16 * .7) * ((100vw - 360px) / 1590));
        line-height: calc(14px + (33 + 33 * .7) * ((100vw - 360px) / 1590))
    }
}

@media (max-width: 1350px) {
    .section-content, .section-content-variant, .section-header, .section-header-variant {
        padding-left: 150px
    }
}

@media (max-width: 1200px) {
    .platform-info-title {
        font-size: 120px;
        height: 190px
    }

    .platform-info-title.platform-info-title-3 {
        font-size: 64px
    }

    .content-left-title {
        font-size: 45px
    }

    .content-left-subtitle {
        font-size: 20px;
        margin-bottom: 30px
    }

    .content-left-text {
        font-size: 18px
    }

    .section-title {
        font-size: 42px
    }

    .section-platform-header-text {
        font-size: 22px
    }

    .section-platform-learn-title {
        font-size: 42px;
        margin-bottom: 20px
    }

    .section-platform {
        padding-bottom: 50px
    }

    .swiper-button-next, .swiper-rtl .swiper-button-prev {
        right: 10px
    }

    .swiper-button-prev, .swiper-rtl .swiper-button-next {
        left: 10px
    }
}

@media (max-width: 991px) {
    .lesson-chat {
        width: 100vw;
        top: 0;
        right: 0;
        bottom: 0;
        max-width: 100vw;
        transform: translateY(0);
        z-index: 5
    }

    .lesson-chat .card {
        height: 100dvh;
        min-height: 420px;
        max-height: 100dvh
    }

    .lesson-chat .card-header:first-child, .lesson-chat__panel {
        border-radius: 0
    }

    .form-payment, .payment-card {
        max-width: 100%
    }

    .mySwiper img, .tab-bar-menu li a {
        border-radius: var(--border-radius)
    }

    .section-content, .section-content-variant, .section-content.variant-left, .section-header, .section-header-variant, .section-header-variant.variant-left {
        padding-left: 0
    }

    .content-left-title, .product-wrapper, .profile-content {
        margin-top: 30px
    }

    .field-inline {
        flex-direction: column;
        align-items: stretch;
        gap: 10px
    }

    .field-actions {
        width: 100%;
        gap: 10px
    }

    .field-actions .btn {
        flex: 1 1 0
    }

    .form-row-inline .control-wrap {
        flex-direction: column;
        align-items: stretch
    }

    .form-payment, .form-row-inline .actions {
        width: 100%
    }

    .form-row-inline.is-editing .control-wrap {
        grid-template-columns:1fr
    }

    .form-row-inline.is-editing .actions {
        justify-content: flex-start
    }

    .profile-aside .btn.w-100 {
        width: 80% !important;
        margin-left: auto;
        margin-right: auto
    }

    .card-like {
        border-radius: 12px
    }

    .avatar-wrap {
        width: 120px;
        height: 120px
    }

    .eak-side {
        display: none !important
    }

    .content-wrapper.container {
        padding-left: 145px
    }

    .section {
        padding-bottom: 20px
    }

    .platform-info-title {
        font-size: 100px
    }

    .product-price, .time-widget.is-open .tw-num b {
        font-size: 26px
    }

    .card-cart-header, .card-client, .content-right-desktop, .dropdown-groups-desktop, .time-widget .tw-sub, .time-widget.has-hours .tw-mins, .time-widget.is-open.only-mins .tw-hours, .time-widget.only-mins .tw-hours {
        display: none
    }

    .content-right-mobile {
        display: block;
        width: 100%
    }

    .footer-socials {
        align-items: flex-end
    }

    .footer-support {
        align-items: center
    }

    .slides-wrapper {
        flex-direction: column-reverse
    }

    .mySwiper {
        height: 400px
    }

    .swiper-thumbsSlider-wrapper {
        margin-right: 0;
        margin-top: 10px;
        max-width: 100%;
        height: 160px
    }

    .section-header {
        margin-bottom: 20px
    }

    .product-item .product-label {
        font-size: 14px;
        line-height: 16px
    }

    .product-price {
        line-height: 32px
    }

    .cabinet-subtitle {
        margin-bottom: 5px
    }

    .payment-left, .payment-right {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start
    }

    .payment-right {
        margin-top: 20px
    }

    .card-payment .card-body {
        padding: 20px
    }

    .thumbsSlider {
        min-height: max-content
    }

    .col-md-position {
        position: absolute;
        top: 10px;
        right: 0;
        width: min-content
    }

    .navbar-collapse, .tab-bar {
        position: fixed;
        left: 0;
        background: #fff
    }

    .cart-list-end {
        justify-content: flex-end
    }

    .mobile-login-row {
        display: flex;
        align-items: center
    }

    .mobile-login-item, .tab-bar-menu li a {
        display: inline-block
    }

    .tab-bar, .time-widget.is-open .tw-sub {
        display: block
    }

    .mobile-login-item img {
        border-radius: 100%;
        width: 40px;
        height: 40px;
        object-fit: cover
    }

    .tab-bar {
        right: 0;
        bottom: 0;
        z-index: 1;
        border-top: 1px solid #e2e2e2
    }

    .card-mobile, .card-mobile .card-header, .header, .navbar-collapse-header, .tab-bar-menu, .time-widget.is-open.has-hours .tw-mins {
        display: flex
    }

    .tab-bar-menu {
        align-items: center;
        justify-content: center;
        margin: 0;
        padding: 0
    }

    .tab-bar-menu li {
        list-style-type: none;
        position: relative
    }

    .tab-bar-menu li:not(:last-child):after {
        content: '';
        display: block;
        width: 1px;
        height: 30px;
        position: absolute;
        right: 0;
        top: 20px;
        background: #cacaca;
        border-radius: 10px
    }

    .tab-bar-menu li a {
        width: 100%;
        height: 100%;
        padding: 20px 25px
    }

    .tab-bar-menu li a.active svg path {
        stroke: var(--main-color)
    }

    .footer {
        padding-bottom: 80px
    }

    .card-mobile-body .card-price, .card-mobile-body .card-text, .footer-item.footer-support {
        margin-bottom: 0
    }

    .navbar-collapse, .navbar-collapse.collapse {
        padding: 20px 0
    }

    .navbar-collapse.collapse.show {
        padding: 20px 0;
        width: 100%
    }

    .navbar-collapse {
        top: 0;
        width: 75%;
        height: 100%;
        min-height: 100vh;
        z-index: 100;
        overflow-y: auto
    }

    .navbar-collapse.collapsing {
        left: -100%;
        transition: height
    }

    .navbar-collapse.show {
        left: 0;
        transition: left .3s
    }

    .navbar-toggler.collapsed ~ .navbar-collapse {
        transition: left .5s
    }

    .navbar-collapse-header {
        align-items: center;
        justify-content: space-between
    }

    .navbar-brand.logo-link, .navbar-close-mobile {
        margin-left: 1.5rem;
        margin-right: 1.5rem
    }

    .navbar-toggler-icon.navbar-toggler-close {
        background-image: url('/images/icons/burger-close-icon.svg')
    }

    .menu-items {
        flex-direction: column;
        align-items: stretch;
        gap: 5px;
        margin-top: 30px;
        padding: 0 20px
    }

    .menu-items .menu-item {
        width: 100%;
        padding: 12px 14px
    }

    .btn-login {
        width: 85%;
        margin: 40px auto 10px
    }

    .card-mobile {
        box-shadow: none;
        flex-direction: column;
        filter: none;
        background: 0 0
    }

    .card-mobile .card-header {
        all: unset;
        align-items: center
    }

    .card-mobile .card-footer {
        all: unset;
        padding: 10px 0
    }

    .card-mobile-img {
        min-width: 114px;
        height: 139px;
        margin-right: 10px;
        object-fit: contain;
        border-radius: 10px
    }

    .btn-buy {
        margin-top: 10px;
        width: 172px
    }

    .card-mobile-body {
        padding: 0
    }

    .comment-image {
        width: 40px;
        min-width: 40px;
        max-width: 40px;
        height: 40px
    }

    .comment-text {
        padding: 15px
    }

    .auth-logo {
        gap: 10px;
        flex-direction: column
    }

    .navbar-brand {
        min-width: 92px;
        background-position: center;
        background-image: url('/images/logo.svg')
    }

    .content-wrapper {
        padding-bottom: 50px
    }

    .time-widget {
        top: unset;
        bottom: 15px;
        right: 15px;
        padding: 12px 11px;
        border-radius: 16px;
        width: 56px;
        gap: 0;
        overflow: hidden
    }

    .time-widget.page-lesson {
        bottom: 81px
    }

    .time-widget .tw-left {
        justify-content: center
    }

    .time-widget .tw-num {
        flex-direction: column;
        align-items: center;
        justify-content: center
    }

    .time-widget .tw-num b {
        font-size: 18px
    }

    .time-widget .tw-num small {
        font-size: 12px;
        margin: 2px 0 0
    }

    .time-widget.is-open {
        width: auto;
        gap: 12px;
        padding: 15px 16px
    }

    .time-widget.is-open .tw-num {
        flex-direction: row;
        align-items: baseline
    }

    .time-widget.is-open .tw-num small {
        margin: 0 0 0 6px;
        font-size: 14px
    }
}

@media (max-width: 768px) {
    .content-left-title {
        font-size: 38px
    }

    .content-left-subtitle, .section-platform-header-text, .test-page-title {
        font-size: 18px
    }

    .content-left-text {
        font-size: 16px
    }

    .cart-list-left, .footer-item {
        margin-bottom: 20px
    }

    .section-title {
        font-size: 34px
    }

    .section-platform-header {
        padding: 15px 30px;
        border-radius: 10px
    }

    .platform-info-title {
        font-size: 90px;
        height: 144px;
        line-height: 144px
    }

    .platform-info-title.platform-info-title-3 {
        font-size: 50px
    }

    .footer-info {
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 0 auto 6px;
        width: max-content
    }

    .section-platform-learn-title {
        font-size: 30px;
        line-height: 40px
    }

    .section-platform-learn-list {
        font-size: 20px
    }

    .swiper-button-next, .swiper-rtl .swiper-button-prev {
        right: 25px
    }

    .swiper-button-prev, .swiper-rtl .swiper-button-next {
        left: 25px
    }
}

@media (max-width: 576px) {
    .gap-task-text {
        column-gap: 6px;
        row-gap: 10px
    }

    .gap-input {
        min-width: 180px
    }

    .module-image, .swiper-pagination {
        display: block
    }

    .footer-title, .lesson-document-download, .swal2-title {
        font-size: 16px
    }

    .lesson, .lesson-document-li, .rt-card {
        padding: 12px
    }

    .lesson-items-title, .lesson-page-title {
        font-size: 18px
    }

    .course-head h1, .kiruhhh, .profile-content h4 {
        font-size: 20px
    }

    .content-left-title {
        font-size: 30px;
        line-height: 31px
    }

    .content-left-subtitle {
        font-size: 14px;
        line-height: 18px;
        margin-bottom: 20px
    }

    .content-left-text {
        font-size: 13px;
        line-height: 16px
    }

    .section-title {
        font-size: 28px;
        text-align: center
    }

    .section-platform-header-text {
        font-size: 14px;
        line-height: 18px
    }

    .section-platform-learn-title {
        font-size: 22px;
        line-height: 23px
    }

    .section-platform-learn-list {
        font-size: 14px;
        line-height: 20px
    }

    .section-platform-header {
        padding: 10px 15px
    }

    .platform-info {
        overflow: hidden;
        margin-top: 25px
    }

    .btn-search {
        min-width: 100px;
        max-width: 100px
    }

    .platform-info-title {
        font-size: 40px;
        height: 46px;
        line-height: 46px
    }

    .platform-info-title.platform-info-title-3 {
        font-size: 30px
    }

    .card-product {
        margin-right: -10px;
        margin-left: -10px
    }

    .card-product .card-body {
        padding: 10px
    }

    .card-product .product-image {
        height: 165px
    }

    .card-product .btn-link {
        margin-top: 10px
    }

    .footer-company, .footer-socials, .footer-support {
        align-items: flex-start
    }

    .footer-socials {
        margin-bottom: 35px
    }

    .card-body-title, .card-status-body-product-info:last-child, .module-image, .product-detail-title {
        margin-bottom: 10px
    }

    .btn-back span, .footer-text br {
        display: none
    }

    .btn-call {
        min-width: 100%
    }

    .footer-info, .lesson-title, .rt-name, .rt-score {
        font-size: 14px
    }

    .btn, .cabinet-subtitle, .cabinet-text {
        font-size: 14px;
        line-height: 16px
    }

    .product-row-item {
        margin-right: 20px
    }

    .card-body-title {
        font-size: 18px;
        line-height: 21px
    }

    .section-header-subtitle {
        margin-left: 10px
    }

    .card-status-body-image {
        min-height: 100px;
        max-height: 100px
    }

    .card-status-body-product-article {
        font-size: 13px;
        line-height: 14px
    }

    .card-body-line {
        margin-top: 40px
    }

    .cart-list-img {
        max-width: 86px;
        width: 100%;
        height: 100px
    }

    .cart-list-text {
        font-size: 12px
    }

    .accordion-heading {
        font-size: 16px;
        line-height: 150%;
        flex-wrap: wrap
    }

    .module-image {
        margin-right: 0;
        width: 100%;
        height: 100%
    }

    .panel-body {
        font-size: 12px;
        line-height: 130%
    }

    .lesson-document-name, .lesson-document-name span, .lesson-text {
        font-size: 14px;
        line-height: 130%
    }

    .swiper-button-next, .swiper-rtl .swiper-button-prev {
        right: 90px
    }

    .swiper-button-prev, .swiper-rtl .swiper-button-next {
        left: 90px
    }

    .swiper-button-next, .swiper-button-prev {
        top: 106%
    }

    .swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
        bottom: -50px
    }

    .swiper-pagination-bullet {
        width: 14px;
        height: 14px;
        border: 1px solid var(--main-color)
    }

    .swiper-pagination-bullet-active {
        opacity: 1;
        background: var(--main-color)
    }

    .footer-company, .footer-socials, .footer-support {
        align-items: center
    }

    .footer {
        padding-bottom: 20px
    }

    .form-search {
        height: auto;
        min-height: auto
    }

    .card-body-expert {
        padding: 1rem 1rem .8rem
    }

    .lesson-document-li {
        flex-wrap: wrap
    }

    .lesson-document-name {
        margin-bottom: 5px
    }

    .lesson-wrapper {
        background: 0 0;
        border: none;
        padding: 0
    }

    .course-main {
        padding: 25px 10px
    }

    .card-login .card-body {
        padding: 20px 30px 30px
    }

    .card-login .card-header {
        padding-left: 25px;
        padding-right: 25px
    }

    .card-header h3 {
        font-size: 26px;
        line-height: 28px
    }

    .navbar-brand {
        margin: auto 0
    }

    .navbar-toggler-icon {
        min-width: 25px;
        width: 35px;
        height: 45px
    }

    .content-wrapper {
        height: auto
    }

    .footer-logo img {
        width: 100%;
        margin-top: 25px
    }

    .footer-item {
        display: flex;
        flex-direction: column;
        margin-top: 0;
        margin-bottom: 10px
    }

    .course-cover, .courses-hero .swiper, .courses-hero .swiper-slide, .courses-hero .swiper-wrapper {
        height: 140px
    }

    .rt-row {
        padding: 10px 0
    }

    .btn-back {
        width: 40px;
        max-width: 40px;
        min-width: 40px;
        height: 40px;
        border-radius: 100%;
        padding: unset
    }

    .header-line {
        gap: 10px
    }

    .section-header-bread {
        font-size: 14px;
        gap: 5px
    }

    .play {
        width: 32px;
        height: 32px
    }
}

@media (max-width: 400px) {
    .form-search-row {
        flex-wrap: wrap
    }

    .form-search-inner {
        margin-bottom: 5px;
        margin-right: 0
    }

    .btn-search {
        min-width: 100%
    }
}

@media (max-width: 360px) {
    .tab-bar-menu li a {
        padding: 20px
    }
}

@media (min-width: 576px) {
    .modal-dialog {
        max-width: 400px
    }
}