* {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    box-sizing: border-box;
    font-family: "Inter", sans-serif;
}

:root {
    --title-neutral-07-color: #1a1d1f;
    --title-neutral-06-color: #272b30;
    --title-neutral-04-color: #7f868d;
    --title-neutral-02-color: #f4f4f4;
    --primary-color-blue: #067ff3;
}

/* width */
::-webkit-scrollbar {
    width: 6px;
}

/* Track */
::-webkit-scrollbar-track {
    background: #f1f1f1;
    margin-bottom: 14px;
}

/* Handle */
::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 99px;
}

    /* Handle on hover */
    ::-webkit-scrollbar-thumb:hover {
        background: #555;
    }

svg:not(#other-icon) > path {
    fill: currentColor;
}

p {
    margin: 0;
}

.title1-bold {
    font-size: 24px;
    font-weight: 700;
    line-height: 32px;
    letter-spacing: -0.02em;
    color: #1a1d1f;
}

.title2-semibold {
    font-size: 20px;
    font-weight: 600;
    line-height: 32px;
    text-align: left;
    color: #1a1d1f;
}

.body1-semibold, .tree-nav__item-title, .course-card-title, .class-sub-title, .noti_item_title, .nav_button {
    font-size: 16px;
    font-weight: 600;
    line-height: 24px;
    text-align: left;
    color: #1a1d1f;
}

.body1-medium {
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
    text-align: left;
    color: #1a1d1f;
}

.body1-regular {
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    text-align: left;
    color: #1a1d1f;
}

.body2-semibold, .tag-course-progress, .tag-course-progress-done, .tag-course-progress-active, .news-modal-tag, #news-in-home .uk-subnav-pill > .uk-active > a, .noti_item_desc_block_content {
    font-size: 14px;
    font-weight: 600;
    line-height: 20px;
    text-align: left;
    color: #1a1d1f;
}

.body2-medium, .noti_item_desc, .noti_item_time {
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
    text-align: left;
    color: #1a1d1f;
}

.body2-regular, .course-card-desc, .chat-message-content, .news-switcher-tag {
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    text-align: left;
    color: #1a1d1f;
}

.caption-semibold, .news-card-tag {
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
    text-align: left;
    color: #1a1d1f;
}

.caption-medium, .noti_item_desc_block_title {
    font-size: 12px;
    font-weight: 500;
    line-height: 16px;
    text-align: left;
    color: #1a1d1f;
}

.caption-regular {
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
    text-align: left;
    color: #1a1d1f;
}

.button1, .btn-primary-custom, .button-primary, .button-secondary, .button-secondary-disabled, .button-primary-disabled {
    font-size: 16px;
    font-weight: 600;
    line-height: 24px;
    color: #1a1d1f;
}

.button2 {
    font-size: 14px;
    font-weight: 600;
    line-height: 24px;
    color: #1a1d1f;
}

.button-link {
    font-size: 14px;
    font-weight: 500;
    line-height: 24px;
    color: #1a1d1f;
}

.button-primary, .button-secondary, .button-secondary-disabled, .button-primary-disabled {
    height: 44px;
    padding: 0 16px;
    border-radius: 10px;
    color: #ffffff;
    background-color: #067ff3;
    display: flex;
    justify-content: center;
    align-items: center;
}

    .button-primary:hover, .button-secondary:hover, .button-secondary-disabled:hover, .button-primary-disabled:hover {
        opacity: 0.9;
        color: #ffffff;
        text-decoration: none;
    }

.button-primary-disabled {
    background-color: rgba(6, 127, 243, 0.5019607843);
    color: rgba(255, 255, 255, 0.7490196078);
    cursor: not-allowed;
}

    .button-primary-disabled:hover {
        opacity: 1;
        background-color: rgba(6, 127, 243, 0.5019607843);
        color: rgba(255, 255, 255, 0.7490196078);
    }

.button-secondary, .button-secondary-disabled {
    background-color: #f9f9f9;
    color: #272b30;
    border: 2px solid #efefef;
    cursor: pointer;
}

    .button-secondary:hover, .button-secondary-disabled:hover {
        opacity: 0.8;
        color: #272b30;
        border: 2px solid #efefef;
    }

.button-secondary-disabled {
    background-color: rgba(249, 249, 249, 0.5019607843);
    color: rgba(39, 43, 48, 0.7490196078);
    cursor: not-allowed;
}

    .button-secondary-disabled:hover {
        opacity: 1;
        background-color: rgba(249, 249, 249, 0.5019607843);
        color: rgba(39, 43, 48, 0.7490196078);
        border: 2px solid rgba(231, 232, 234, 0.5019607843);
    }

.shadow {
    box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.1);
}

/* Header */
.header {
    box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.07);
    display: flex;
    justify-content: space-between;
    padding: 8px 24px;
}

.nav_button_active {
    padding: 0 12px;
    border-radius: 12px;
    background-color: #efefef;
    height: 48px;
    width: 100%;
    cursor: pointer;
    color: #1a1d1f;
    font-weight: 600;
}

    .nav_button_active > a {
        padding: 12px 0;
        width: 100%;
        height: 48px;
        text-align: left;
    }

.nav_button {
    padding: 0 12px;
    border-radius: 12px;
    height: 48px;
    width: 100%;
    color: #535557;
    cursor: pointer;
    transition: 0.3ms;
    display: flex;
    align-items: center;
    transition: 0.3s;
}

    .nav_button > a {
        padding: 12px 0;
        width: 100%;
        height: 48px;
        text-align: left;
    }

    .nav_button:hover {
        background-color: #efefef;
    }

    .nav_button:active {
        color: #535557;
    }

.label-form {
    display: flex;
    text-align: left;
    font-weight: 600;
    color: black;
    padding-bottom: 10px;
    line-height: 24px;
    font-size: 14px;
}

.input-form, .login-input, .login-input-error {
    height: 48px;
    border-radius: 12px;
    color: black;
}

#modal-profile .uk-modal-body {
    max-height: 510px !important;
}

.btn-icon {
    background-color: transparent;
    transition: 0.3s;
}

    .btn-icon:focus, .btn-icon:hover {
        background-color: #efefef;
    }

/* Header notification */
.noti_item {
    display: flex;
    width: 100%;
    height: 100%;
}

.noti_item_icon {
    width: 48px;
    height: 48px;
    border-radius: 100%;
    text-align: center;
    display: flex;
    justify-content: center;
    flex: none;
}

.noti_item_content {
    margin-left: 12px;
    width: 100%;
}

.noti-active {
    position: absolute;
    left: 54.17%;
    right: 25%;
    top: 25%;
    bottom: 54.17%;
    width: 12px;
    height: 12px;
    background: #ff6a55;
    border: 2px solid #fcfcfc;
    border-radius: 12px;
}

.noti_item_title {
    text-align: left;
    display: flex;
    padding-bottom: 4px;
    justify-content: space-between;
}

.noti_item_desc_block {
    padding: 12px;
    border-radius: 8px;
    background-color: var(--title-neutral-02-color);
    margin-top: 4px;
    text-align: left;
}

.noti_item_desc_block_content {
    margin-top: 4px;
}

.noti_item_time {
    color: #7f868d;
    display: flex;
    justify-content: center;
    align-items: center;
}

.noti_item_active {
    content: "";
    width: 10px;
    height: 10px;
    display: flex;
    flex: none;
    border-radius: 100%;
    margin-left: 8px;
    background-color: var(--primary-color-blue);
    color: var(--primary-color-blue);
}

.noti_item_desc {
    color: #272b30;
}

.divider-vertical {
    width: 2px;
    height: 20px;
    background-color: #7f868d;
}

.modal-content-title {
    padding: 12px;
    border-radius: 8px;
    background-color: #f9f9f9;
    border: 1px solid #efefef;
    text-align: left;
}

.modal-content-video {
    max-height: 306px;
    width: 100%;
    height: 100%;
    border-radius: 8px;
}

.modal-content-video-button {
    position: absolute;
    top: 50%;
    right: 50%;
    transform: translate(50%, -50%);
    cursor: pointer;
}

.btn-teacher {
    cursor: pointer;
    padding: 8px;
    border-radius: 6px;
}

    .btn-teacher:hover {
        background-color: #f4f4f4;
    }

.tag-progress-already {
    height: 24px;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
    color: #ffffff;
    background-color: #07b682;
}

.tag-progress-cancel {
    height: 24px;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
    color: #ffffff;
    background-color: #f74a4a;
}

.tag-progress-not {
    height: 24px;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
    color: #ffffff;
    background-color: #efefef;
    color: #272b30;
}

.tag-progress-missing {
    height: 24px;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
    color: #ffffff;
    background-color: #7f868d;
}

#news-in-home .uk-subnav-pill > .uk-active > a {
    color: #ffffff;
    background-color: #535557;
    border: 1px solid #efefef;
}

.news-switcher-tag {
    border-radius: 20px;
    margin-right: 8px;
    padding: 8px 16px !important;
    text-transform: none !important;
    color: #535557;
    background-color: #f9f9f9;
    border: 1px solid #efefef;
}

.news-card {
    border: 1px solid #efefef;
    border-radius: 12px;
}

.news-card-image {
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    height: 160px;
    width: 100%;
    object-fit: cover;
}

.news-card-tag {
    padding: 4px 8px;
    height: 24px;
    border-radius: 20px;
    background-color: #efefef;
}

.news-modal-tag {
    padding: 4px 8px;
    height: 28px;
    border-radius: 20px;
    background-color: #efefef;
}

.class {
    height: calc(100vh - 80px);
    display: flex;
    align-items: center;
    width: 100%;
}

.student-card {
    width: 100%;
    border-radius: 16px;
    position: relative;
}

.student-card-image {
    border-radius: 16px;
    width: 100%;
    height: calc((100vh - 80px - 128px - 16px) / 2);
    object-fit: cover;
}

.student-card-desc {
    position: absolute;
    padding: 0 16px 16px 16px;
    bottom: 25px;
    left: 0;
    display: flex;
    justify-content: space-between;
    width: 250px;
    background-image: linear-gradient(to bottom, rgba(255, 0, 0, 0), rgba(0, 0, 0, 0.8));
    border-radius: 16px;
}

.student-card-small {
    width: 90%;
    height: calc((100vh - 112px - 64px) / 5);
    border-radius: 16px;
    position: relative;
    flex: 1;
}

.student-card-small-image {
    border-radius: 16px;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.student-card-small-desc {
    position: absolute;
    padding: 0 8px 8px 8px;
    bottom: -9px;
    left: 0;
    display: flex;
    justify-content: space-between;
    width: 100%;
    background-image: linear-gradient(to bottom, rgba(255, 0, 0, 0), rgba(0, 0, 0, 0.8));
    border-bottom-left-radius: 16px;
    border-bottom-right-radius: 16px;
}

.chat {
    display: none;
}

.chat-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 16px;
    width: 100%;
    height: 56px;
    border-bottom: 1px solid #efefef;
}

.chat-body {
    max-height: calc(100vh - 216px);
    height: 100%;
    overflow: auto;
}

.chat-footer {
    height: 80px;
    display: flex;
    width: 100%;
    padding: 12px 16px;
    border-top: 1px solid #efefef;
}

.chat-message-content {
    border-radius: 20px;
    padding: 10px 12px;
    margin-left: 15px;
    margin-right: 7px;
    width: 245px;
    background-color: #f4f4f4;
    position: relative;
}

.chat-message-content-arrow {
    position: absolute;
    bottom: 0;
    left: -7px;
}

.chat-message-content-arrow-me {
    position: absolute;
    bottom: 0;
    right: -7px;
}

.chat-message-content-time {
    color: #535557;
    font-size: 10px;
    text-align: end;
    line-height: 10px;
}

.btn-primary-custom {
    height: 44px;
    width: 100%;
    border-radius: 10px;
    padding-left: 16px;
    padding-top: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    background-color: red;
    cursor: pointer;
    transition: 0.3s;
}

    .btn-primary-custom:hover {
        opacity: 0.9;
    }

.uk-width-expand > :not(:last-child) {
    margin-bottom: 8px;
}

.practice-card {
    padding: 8px;
    border-radius: 20px;
    background-color: #ffffff;
    justify-content: start;
}

.tag-practice {
    height: 24px;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 600;
    line-height: 16px;
    color: #ffffff;
    background-color: #067ff3;
    margin-right: 4px;
}

.login-input, .login-input-error {
    height: 56px;
}

.login-input-error {
    border: 2px solid #f74a4a;
}

.class-sub-title {
    color: #7f868d;
}

.class-card {
    border: 1px solid #efefef;
    border-radius: 12px;
}

.class-card-header, .class-card-header-in-schedule {
    height: 48px;
    border-radius: 8px 8px 0 0;
    padding: 12px 24px;
    display: flex;
    justify-content: space-between;
}

.class-card-header-in-schedule {
    border-top-right-radius: 10px;
    border-top-left-radius: 10px;
    border-bottom: 1px solid #efefef;
}

.class-card-content {
    padding: 24px;
}

.course-card {
    border: 1px solid #efefef;
    border-radius: 12px;
}

.course-card-big {
    border: 1px solid #efefef;
    border-radius: 12px;
}

.course-card-big-image {
    border-top-left-radius: 12px;
    border-bottom-left-radius: 12px;
    max-height: 178px;
    object-fit: cover;
}

.course-card-big-content {
    padding: 16px;
}

.course-card-title {
    cursor: pointer;
    color: #1a1d1f !important;
}

    .course-card-title:hover {
        text-decoration: none;
    }

.course-card-desc {
    margin-top: 4px;
    margin-bottom: 12px;
    max-height: 40px;
    height: 100%;
    color: #535557;
}

.course-card-image {
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    height: 160px;
    width: 100%;
    object-fit: cover;
}

.tag-course-progress, .tag-course-progress-done, .tag-course-progress-active {
    height: 28px;
    padding-left: 12px;
    padding-right: 12px;
    border-radius: 16px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.tag-course-progress-active {
    color: #067ff3;
    background-color: #cde6fe;
}

.tag-course-progress-done {
    color: #07b682;
    background-color: #cefdef;
}

.uk-nav-sub {
    display: none; /* Hide submenu by default */
}

.uk-parent:hover .uk-nav-sub,
.uk-parent.uk-open .uk-nav-sub {
    display: block; /* Show submenu when parent item is hovered or opened */
}

/*
 For cross browser compatible styling hide Firefox's marker by setting summary { display: block }
 and Chrome and Safari's marker by setting ::-webkit-details-marker {display: none;}
*/
summary {
    display: block;
    cursor: pointer;
    outline: 0;
}

    summary::-webkit-details-marker {
        display: none;
    }

.tree-nav__item {
    display: block;
    white-space: nowrap;
    position: relative;
}

    .tree-nav__item.is-expandable:before {
        border-left: 2px solid #efefef;
        content: "";
        height: 100%;
        left: 12px;
        position: absolute;
        top: 22px;
        height: calc(100% - 22px);
    }

    .tree-nav__item.last-item.is-expandable:before {
        display: none;
    }

    .tree-nav__item .tree-nav__item {
        margin-left: 24px;
    }

    .tree-nav__item.is-expandable[open] > .tree-nav__item-title::before {
        font-family: "ionicons";
        transform: rotate(90deg);
    }

    .tree-nav__item.is-expandable[open] > summary.tree-nav__item-title::after {
        display: inline-block;
    }

    .tree-nav__item.is-expandable > .tree-nav__item-title {
        padding-left: 2.4rem;
    }

        .tree-nav__item.is-expandable > .tree-nav__item-title::before {
            position: absolute;
            will-change: transform;
            transition: transform 300ms ease;
            content: "";
            left: 0;
            display: inline-block;
            width: 1.6rem;
            height: 1.6rem;
            background-image: url("/Content/src/image/new-theme/chevron-right.svg");
        }

        .tree-nav__item.is-expandable > .tree-nav__item-title:last-child:after {
            position: absolute;
            content: "";
            width: 12px;
            height: 24px;
            left: 12px;
            top: 26px;
            border: 2px solid #efefef;
            border-bottom-left-radius: 4px;
            border-right: none;
            border-top: none;
            display: none;
            will-change: transform;
            transition: transform 300ms ease;
        }

.tree-nav__item-title {
    cursor: pointer;
    display: block;
    outline: 0;
}

    .tree-nav__item-title .icon {
        display: inline;
        padding-left: 1.6rem;
        margin-right: 0.8rem;
        color: red;
        font-size: 1.4rem;
        position: relative;
    }

        .tree-nav__item-title .icon::before {
            top: 0;
            position: absolute;
            left: 0;
            display: inline-block;
            width: 1.6rem;
            text-align: center;
        }

    .tree-nav__item-title::-webkit-details-marker {
        display: none;
    }

.uk-list > * > ul,
.uk-list > :nth-child(n+2) {
    margin-top: 0;
}

.uk-child-width-1-3_1 > *:not(:last-child) {
    width: 32.2580645161%;
}

.uk-child-width-1-3_1 > :last-child {
    width: calc(32.2580645161% + 32px);
    padding-right: 32px;
}

.single-chart {
    justify-content: space-around;
}

.circular-chart {
    display: block;
}

.circle-bg {
    fill: none;
    stroke: rgba(255, 255, 255, 0.3);
    stroke-width: 7;
}

.circle {
    fill: none;
    stroke-width: 7;
    stroke-linecap: round;
    animation: progress 1s ease-out forwards;
}

@keyframes progress {
    0% {
        stroke-dasharray: 0 100;
    }
}

.circular-chart .circle {
    stroke: #ffffff;
}

/*# sourceMappingURL=style.css.map */
