:root {
    --primary-color2: #1a894a;
    --primary-color: #1a894a;
    --skinColor: #1B84FF;
    --whiteColor: #FFF;
    --blackColor: #000;
    --darkColor: #0a1017;
    --grayColor: #4b5675;
    --borderColor: #c3c9da;
    --bg: #f4f3ff;
    --surface: #ffffff;
    --border: #e4e2f5;
    --accent: #6246ea;
    --accent-lt: #ede9fd;
    --accent-glow: rgba(98, 70, 234, .15);
    --text: #1e1a3c;
    --muted: #8e8aaa;
    --red: #e53e3e;
    --red-lt: #fff5f5;
    --green: #0a7c59;
    --green-lt: #e6faf4;
    --radius: 10px;
    --shadow: 0 1px 3px rgba(30, 26, 60, .08), 0 4px 16px rgba(98, 70, 234, .06);
    --primary-gradient: linear-gradient(135deg, #00a651 0%, #00813f 100%);
    --card-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.05), 0 4px 6px -2px rgba(0, 0, 0, 0.02);
    --text-muted: #7f8c8d;
    --primary-green: #5fcf80;
    --primary-white: #fff;
    --primary-blue: #17a2b8;
    --primary-red: #ff0000;
    --primary-black: #000;
    --color-red: #F22C3F;
    --tag-blue: #17a2b8;
    --tag-purple: #8e44ad;
}

.nk-header.is-theme:not([class*=bg-]) {
    background: var(--primary-color2) !important;
    border-color: var(--primary-color2) !important;
}

body {
    color: #333 !important;
    font-family: "Roboto" !important;
}

.table > :not(caption) > * > * {
    color: #333 !important;
}

.nk-app-root {
    color: #333 !important;
}

h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1 {
    font-family: "Roboto" !important
}

::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-thumb {
    background-color: #aaa;
}

::-webkit-scrollbar-track {
    background-color: #f1f1f1;
}

.invalid-feedback {
    display: block !important;
}

.d-flex.svg-illustration.mb-4.gap-2.align-items-center img {
    width: 240px;
}

.btn.waves-light {
    margin-right: 5px;
}

.nk-menu-link:hover, .nk-menu-icon:hover, .nk-menu-sub .active > .nk-menu-link {
    color: var(--primary-color) !important;
}


/*
* demo.css
* File include item demo only specific css only
******************************************************************************/

.light-style .menu .app-brand.demo {
    height: 64px;
}

.dark-style .menu .app-brand.demo {
    height: 64px;
}

.app-brand-logo.demo {
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    display: -ms-flexbox;
    display: flex;
    width: 34px;
    height: 24px;
}

.app-brand-logo.demo svg {
    width: 35px;
    height: 24px;
}

.app-brand-text.demo {
    font-size: 1.375rem;
}

/* ! For .layout-navbar-fixed added fix padding top tpo .layout-page */
.layout-navbar-fixed .layout-wrapper:not(.layout-without-menu) .layout-page {
    padding-top: 64px !important;
}

.layout-navbar-fixed .layout-wrapper:not(.layout-horizontal):not(.layout-without-menu) .layout-page {
    padding-top: 78px !important;
}

/* Navbar page z-index issue solution */
.content-wrapper .navbar {
    z-index: auto;
}

/*
* Content
******************************************************************************/

.demo-blocks > * {
    display: block !important;
}

.demo-inline-spacing > * {
    margin: 1rem 0.375rem 0 0 !important;
}

/* ? .demo-vertical-spacing class is used to have vertical margins between elements. To remove margin-top from the first-child, use .demo-only-element class with .demo-vertical-spacing class. For example, we have used this class in forms-input-groups.html file. */
.demo-vertical-spacing > * {
    margin-top: 1rem !important;
    margin-bottom: 0 !important;
}

.demo-vertical-spacing.demo-only-element > :first-child {
    margin-top: 0 !important;
}

.demo-vertical-spacing-lg > * {
    margin-top: 1.875rem !important;
    margin-bottom: 0 !important;
}

.demo-vertical-spacing-lg.demo-only-element > :first-child {
    margin-top: 0 !important;
}

.demo-vertical-spacing-xl > * {
    margin-top: 5rem !important;
    margin-bottom: 0 !important;
}

.demo-vertical-spacing-xl.demo-only-element > :first-child {
    margin-top: 0 !important;
}

.rtl-only {
    display: none !important;
    text-align: left !important;
    direction: ltr !important;
}

[dir='rtl'] .rtl-only {
    display: block !important;
}

/*
* Layout demo
******************************************************************************/

.layout-demo-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 1rem;
}

.layout-demo-placeholder img {
    width: 900px;
}

.layout-demo-info {
    text-align: center;
    margin-top: 1rem;
}

select#deleteSelect {
    width: unset;
}

.previewThumbnail {
    padding: 5px;
    border: 1px solid #f2f2f2;
    width: 150px !important;
    height: 150px !important;
    position: relative;
    border-radius: 3px !important
}

.previewThumbnail .btn-close {
    border: 0 !important;
    margin: 0 !important;
    background: #ddd;
    border-radius: 50% !important;
    color: #000;
    display: flex;
    font-size: 18px;
    height: 30px;
    position: absolute;
    right: 5px;
    top: 5px;
    padding: 0 !important;
    width: 30px;
    justify-content: center;
}

.btnAddImage {
    display: block;
    padding: 0 !important;
    line-height: 25px;
    font-size: 13px;
    margin: 5px 0 0 !important;
    border: 0 !important
}

.previewThumbnail .btn-close:hover {
    color: #dc3545 !important
}

.previewThumbnail img {
    object-fit: contain !important;
}

.avatar-upload .avatar-preview div#imagePreview, .box-image-table.circle img, .previewThumbnail img, div#imagePreview > img {
    width: 100%;
    height: 100%;
}

.table-title {
    white-space: normal;
    margin: 0px !important;
}

tr.mycheckbox {
    background: #f2f2f2 !important;
}

.offcanvas.showing, .offcanvas.hiding, .offcanvas.show {
    visibility: visible;
    z-index: 99999999999;
}

.category-list {
    min-height: 42px;
    max-height: 200px;
    overflow: auto;
    padding: 0 .9em;
    border: 1px solid #e9ecef;
    background: #e9ecef;
    border-radius: 3px
}

.category-list ul {
    margin: .9em 0 !important;
    padding: 0 !important
}

.category-list ul li {
    list-style: none !important
}

.category-list-table span:last-child {
    display: none !important;
}

td.details-control {
    background: url(../admins/img/details_open.png) no-repeat center center;
    cursor: pointer;
}

tr.dt-hasChild td.details-control {
    background: url(../admins/img/details_close.png) no-repeat center center;
}

/** Nestable**/
.dd {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 13px;
    line-height: 20px;
}

.dd-list {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    list-style: none;
}

.dd-list .dd-list {
    padding-left: 30px;
}

.dd-collapsed .dd-list {
    display: none;
}

.dd-item,
.dd-empty,
.dd-placeholder {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    min-height: 20px;
    font-size: 13px;
    line-height: 20px;
}

.dd-handle {
    display: block;
    height: 30px;
    margin: 5px 0;
    padding: 4px 10px;
    color: #333;
    text-decoration: none;
    font-weight: bold;
    border: 1px solid #ccc;
    background: #F5F6F7;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
}


.dd-item > button {
    display: block;
    position: relative;
    cursor: pointer;
    float: left;
    width: 25px;
    height: 20px;
    margin: 5px 0;
    padding: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    border: 0;
    background: transparent;
    font-size: 12px;
    line-height: 1;
    text-align: center;
    font-weight: bold;
}

.dd-item > button:before {
    content: '+';
    display: block;
    position: absolute;
    width: 100%;
    text-align: center;
    text-indent: 0;
}

.dd-item > button[data-action="collapse"]:before {
    content: '-';
}

.dd-placeholder,
.dd-empty {
    margin: 5px 0;
    padding: 0;
    min-height: 30px;
    background: #f2fbff;
    border: 1px dashed #b6bcbf;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
}

.dd-empty {
    border: 1px dashed #bbb;
    min-height: 100px;
    background-color: #e5e5e5;
    background-image: -webkit-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff),
    -webkit-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff);
    background-image: -moz-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff),
    -moz-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff);
    background-image: linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff),
    linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff);
    background-size: 60px 60px;
    background-position: 0 0, 30px 30px;
}

.dd-dragel {
    position: absolute;
    pointer-events: none;
    z-index: 9999;
}

.dd-dragel > .dd-item .dd-handle {
    margin-top: 0;
}

.dd-dragel .dd-handle {
    -webkit-box-shadow: 2px 4px 6px 0 rgba(0, 0, 0, .1);
    box-shadow: 2px 4px 6px 0 rgba(0, 0, 0, .1);
}

.action_menu .fa:first-child {
    margin-right: 5px;
}

.action_menu {
    text-align: center;
    border-left: 1px solid #ccc;
    float: right;
    width: 80px;
    padding-left: 20px;
}

.action_menu a i {
    margin-top: -5px;
    font-size: 16px;
}

.link_menu {
    border-left: 1px solid #ccc;
    float: right;
    padding: 0 5px 0px 15px;
    white-space: nowrap;
    width: 500px;
    overflow: hidden;
    font-weight: normal;
}

.thVal {
    height: 20px !important;
}

@media (max-width: 768px) {

    .link_menu {
        display: none;
    }
}

/**menu**/
.dd {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    max-width: 100%;
    list-style: none;
    font-size: 13px;
    line-height: 20px;
}

.dd-list {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    list-style: none;
}

.dd-list .dd-list {
    padding-left: 30px;
}

.dd-collapsed .dd-list {
    display: none;
}

.dd-item,
.dd-empty,
.dd-placeholder {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    min-height: 35px;
    font-size: 13px;
    line-height: 35px;
}

li.dd-item p {
    margin: 0px !important;
}

.dd-handle {
    display: flex;
    height: 100%;
    margin: 5px 0;
    padding: 5px 10px;
    color: #333;
    text-decoration: none;
    font-weight: bold;
    background: #fafafa;
    border: 1px solid #f2f2f2;
    -webkit-border-radius: 3px;
    border-radius: 3px;
    box-sizing: border-box;
    position: relative;
    -moz-box-sizing: border-box;
    align-items: center;
}

.dd-handle:hover {
    color: #2ea8e5;
    background: #fff;
}

.dd-handle .custom-control.custom-checkbox {
    padding-top: 5px;
}

.dd-item > button {
    display: block;
    position: relative;
    cursor: pointer;
    float: left;
    width: 25px;
    height: 20px;
    margin: 5px 0;
    padding: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    border: 0;
    background: transparent;
    font-size: 12px;
    line-height: 1;
    text-align: center;
    font-weight: bold;
}

.dd-item > button:before {
    content: '+';
    display: block;
    position: absolute;
    width: 100%;
    text-align: center;
    text-indent: 0;
}

.dd-item > button[data-action="collapse"]:before {
    content: '-';
}

.dd-placeholder,
.dd-empty {
    margin: 5px 0;
    padding: 0;
    height: 100%;
    background: #f2fbff;
    border: 1px dashed #b6bcbf;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
}

.dd-empty {
    border: 1px dashed #bbb;
    min-height: 100px;
    background-color: #e5e5e5;
    background-image: -webkit-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff),
    -webkit-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff);
    background-image: -moz-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff),
    -moz-linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff);
    background-image: linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff),
    linear-gradient(45deg, #fff 25%, transparent 25%, transparent 75%, #fff 75%, #fff);
    background-size: 60px 60px;
    background-position: 0 0, 30px 30px;
}

.dd-item > button {
    position: absolute;
    right: 0px;
    z-index: 999;
    top: 24px;
    transform: translateY(-50%);
    margin: 0px !important;
}

.dd-dragel {
    position: absolute;
    pointer-events: none;
    z-index: 9999;
}

.dd-dragel > .dd-item .dd-handle {
    margin-top: 0;
}

.dd-dragel .dd-handle {
    -webkit-box-shadow: 2px 4px 6px 0 rgba(0, 0, 0, .1);
    box-shadow: 2px 4px 6px 0 rgba(0, 0, 0, .1);
}

/**
 * Nestable Extras
 */

.nestable-lists {
    display: block;
    clear: both;
    padding: 30px 0;
    width: 100%;
    border: 0;
    border-top: 2px solid #ddd;
    border-bottom: 2px solid #ddd;
}

#nestable-menu {
    padding: 0;
    margin: 20px 0;
}

#nestable-output,
#nestable2-output {
    width: 100%;
    height: 7em;
    font-size: 0.75em;
    line-height: 1.333333em;
    font-family: Consolas, monospace;
    padding: 5px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
}


@media only screen and (min-width: 700px) {
    .dd {
        float: left;
        width: 100%;
    }

    .dd + .dd {
        margin-left: 2%;
    }
}

.dd-hover > .dd-handle {
    background: #2ea8e5 !important;
}

/**
 * Nestable Draggable Handles
 */

.dd3-content {
    display: block;
    height: 30px;
    margin: 5px 0;
    padding: 5px 10px 5px 40px;
    color: #333;
    text-decoration: none;
    font-weight: bold;
    border: 1px solid #ccc;
    background: #fafafa;
    background: -webkit-linear-gradient(top, #fafafa 0%, #eee 100%);
    background: -moz-linear-gradient(top, #fafafa 0%, #eee 100%);
    background: linear-gradient(top, #fafafa 0%, #eee 100%);
    -webkit-border-radius: 3px;
    border-radius: 3px;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
}

.dd3-content:hover {
    color: #2ea8e5;
    background: #fff;
}

.dd-dragel > .dd3-item > .dd3-content {
    margin: 0;
}

.dd3-item > button {
    margin-left: 30px;
}

.dd3-handle {
    position: absolute;
    margin: 0;
    left: 0;
    top: 0;
    cursor: pointer;
    width: 30px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    border: 1px solid #aaa;
    background: #ddd;
    background: -webkit-linear-gradient(top, #fafafa 0%, #eee 100%);
    background: -moz-linear-gradient(top, #fafafa 0%, #eee 100%);
    background: linear-gradient(top, #fafafa 0%, #eee 100%);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.dd3-handle:before {
    content: '≡';
    display: block;
    position: absolute;
    left: 0;
    top: 3px;
    width: 100%;
    text-align: center;
    text-indent: 0;
    color: #fff;
    font-size: 20px;
    font-weight: normal;
}

.dd3-handle:hover {
    background: #ddd;
}


.menu-action {
    position: absolute;
    top: 50%;
    right: 10px;
    display: flex;
    transform: translateY(-50%);
    align-items: center;
}

.dd-item > button[data-action="collapse"]:before {
    content: '\ea62' !important;
    font-family: "tabler-icons" !important;
    font-size: 13px;
    color: inherit !important;
}

.dd-item > button:before {
    content: '\ea5f' !important;
    font-family: "tabler-icons" !important;
    font-size: 13px;
    color: inherit !important;
}

.table-responsive {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.action_menu-2 {
    border-left: 1px solid #ccc;
    float: right;
    width: 80px;
    padding-left: 20px;
}

.action_menu-2 a i {
    margin-top: -5px;
    font-size: 16px;
}

span.action_menu-2.d-flex.align-items-center {
    position: absolute;
    right: 0px;
}

.link_menu {
    border-left: 1px solid #ccc;
    float: right;
    padding: 0 5px 0px 15px;
    white-space: nowrap;
    width: 500px;
    overflow: hidden;
    font-weight: normal;
    margin-left: 15px;
}

body *::-webkit-scrollbar {
    width: 6px;
    height: 6px;
    transition: .3s background;
}

body *::-webkit-scrollbar-thumb {
    background: #ced4da;
}

.swal2-modal.swal2-popup .swal2-title {
    margin: 15px 0 !important;
    padding: 0px !important;
}

.swal2-html-container {
    margin-top: 0px !important;
}

.wd-4 {
    width: 25%;
}


/**loading**/
div#loading {
    position: fixed;
    top: 50%;
    left: 50%;
    width: 200px;
    transform: translate(-50%, -50%);
    text-align: center;
    padding: 2px;
    z-index: 999;
}

div#loading > div:last-child {
    position: relative;
    width: 80px;
    height: 15px;
    margin: 1em auto;
}

div#loading > div:last-child > div {
    position: absolute;
    top: 0;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: #0d6efd;
    background: rgb(var(--dt-row-selected));
    animation-timing-function: cubic-bezier(0, 1, 1, 0);
}

div#loading > div:last-child > div:nth-child(1) {
    left: 8px;
    animation: datatables-loader-1 0.6s infinite;
}

div#loading > div:last-child > div:nth-child(2) {
    left: 8px;
    animation: datatables-loader-2 0.6s infinite;
}

div#loading > div:last-child > div:nth-child(3) {
    left: 32px;
    animation: datatables-loader-2 0.6s infinite;
}

div#loading > div:last-child > div:nth-child(4) {
    left: 56px;
    animation: datatables-loader-3 0.6s infinite;
}

span.color-bg {
    width: 25px;
    height: 25px;
    display: inline-block;
    border: 1px solid #f2f2f2;
    margin-right: 5px;
}

.avatar.w45 {
    width: 50px;
    height: 50px;
    padding: 5px;
    border-radius: 5px;
    border: 1px solid #f2f2f2 !important;
}

.avatar img {
    height: 100% !important;
    object-fit: cover !important;
}

.avatar.w45 img {
    object-fit: contain !important;
}

#country-select span.select2-selection.select2-selection--single, #country-select .select2.select2-container.select2-container--default.select2-container--focus {
    width: 500px !important;
}

.hidden {
    display: none !important;
}

.app-brand-logo {
    width: 150px !important;
    height: unset !important;
}

.app-brand-logo img {
    width: 100% !important;
    object-fit: contain !important;
}

div#ckf-modal {
    z-index: 09999999999999999999999999999999999999 !important;
}

div#attributeItem button.accordion-button.collapsed {
    display: flex;
    align-items: center;
}


.user-profile-header-banner img {
    width: 100%;
    object-fit: cover;
    height: 250px;
}

.user-profile-header {
    margin-top: -2rem;
}

.user-profile-header .user-profile-img {
    border: 5px solid;
    width: 120px;
}

.light-style .user-profile-header .user-profile-img {
    border-color: #fff;
}

.dark-style .user-profile-header .user-profile-img {
    border-color: #2f3349;
}

.dataTables_wrapper .card-header .dataTables_filter label {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

@media (max-width: 767.98px) {
    .user-profile-header-banner img {
        height: 150px;
    }

    .user-profile-header .user-profile-img {
        width: 100px;
    }
}

.dot:last-child {
    display: none;
}

#loading {
    width: 100%;
    height: 300px;
    background: #e8e8e847;
    z-index: 9999;
    text-align: center;
    display: none;
}

#loadingBox {
    display: inline-block;
    width: 70px;
    height: 70px;
    background: #fff;
    border-radius: 50%;
    margin-top: 200px;
}

#loadingIcon {
    width: 100%;
    height: 100%;
}

.dropify-wrapper .dropify-preview .dropify-infos .dropify-infos-inner p.dropify-infos-message {
    margin-top: 15px;
    padding-top: 15px;
    font-size: 12px !important;
    position: relative;
    opacity: .5;
}

.dropify-wrapper .dropify-message p {
    font-size: 15px !important;
}

.table-acf .order {
    background: #f4f4f4;
    width: 20px;
    color: #aaa;
    text-shadow: #fff 0 1px 0;
}

.acf-field {
    position: relative;
    padding: 15px 12px;
    border-top: #EEEEEE solid 1px;
}

.acf-field:first-child {
    border: 0;
}

.acf-field:before {
    content: "";
    display: block;
    position: absolute;
    background: #F9F9F9;
    border-color: #E1E1E1;
    border-style: solid;
    border-width: 0 1px 0 0;
    top: 0;
    bottom: 0;
    left: 0;
    width: 25%;
    z-index: 0;
}


.acf-left b {
    color: #ff3333;
}

.acf-left {
    position: relative;
    font-size: 15px;
    color: #000;
    font-weight: 700;
}

td.table-fields.-left {
    padding: 0;
}

.table-acf td {
    border-top: 1px solid #f4f4f4;
}

td.table-fields.-right {
    width: 80px;
}

.table-acf tr:nth-child(even) {
    background: #eae8fd !important;
}


.table-acf tr:nth-child(even) .order {
    background: #eae8fd !important;
}

.table-acf tr:nth-child(even) .acf-field:before {
    background: #eae8fd !important;
}

.title-option {
    background: linear-gradient(72.47deg, #7367f0 22.16%, rgba(115, 103, 240, 0.7) 76.47%);
    box-shadow: 0px 2px 6px 0px rgba(115, 103, 240, 0.48);
    color: #fff !important;
    padding: 10px;
    border-radius: 5px;
}

.dropify-wrapper .dropify-preview .dropify-infos .dropify-infos-inner p.dropify-infos-message {
    margin-top: 15px;
    padding-top: 15px;
    font-size: 12px !important;
    position: relative;
    opacity: .5;
}

.dropify-wrapper .dropify-message p {
    font-size: 15px !important;
}

.question label b, .question label {
    color: var(--bs-body-color) !important;
    font-size: 15px;
}

.cauhoi {
    margin-top: 10px;
}

.cauhoi span label {
    margin-left: 10px !important;
}

.cauhoi span {
    width: 100%;
    display: flex;
    margin: 0 0 10px 0;
}

.cauhoi span input[type='radio'], .cauhoi span input[type='checkbox'] {
    outline: none !important
}

.cauhoi span input[type=radio] {
    border-radius: 50%;
}

.cauhoi span input[type=checkbox], .cauhoi span input[type=radio] {
    -webkit-appearance: none;
    -moz-appearance: none;
    position: relative;
    width: 20px;
    height: 20px;
    border: 3px solid #39414d;
    background: #fff;
}

.cauhoi label {
    width: calc(100% - 26px);
    font-size: 14px !important;
    color: #000;
}

@supports (-webkit-appearance: none) or (-moz-appearance: none) {
    .cauhoi span input[type=radio]:after {
        content: "";
        opacity: 0;
        display: block;
        left: 3px;
        top: 3px;
        position: absolute;
        width: 11px;
        height: 11px;
        border-radius: 50%;
        background: #28303d;
    }

    .cauhoi span input[type=checkbox]:after {
        content: "";
        opacity: 0;
        display: block;
        left: 3px;
        top: 3px;
        position: absolute;
        width: 11px;
        height: 11px;
        border-radius: 50%;
        background: #28303d;
    }
}

.cauhoi span input[type=radio]:after {
    left: 2px;
    top: 0px;
    border-radius: 0;
    background: none;
    border: solid #fff;
    width: 8px;
    height: 10px;
    border-width: 0 4px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.cauhoi span input[type=checkbox]:after {
    left: 2px;
    top: 0px;
    border-radius: 0;
    background: none;
    border: solid #fff;
    width: 8px;
    height: 10px;
    border-width: 0 4px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.cauhoi span input[type=radio]:checked {
    border: 4px solid #ed341d;
    background: #ed341d;
}

.cauhoi span input[type=checkbox]:checked {
    border: 4px solid #ed341d;
    background: transparent;
}

label.form-label {
    width: 100%;
}

span.d-flex.flex-question .form-control {
    display: inline-block;
    border-radius: 0px !important;
    margin: 0 5px !important;
}

@supports (-webkit-appearance: none) or (-moz-appearance: none) {
    .cauhoi span input[type=radio]:checked:after {
        opacity: 1;
    }

    .cauhoi span input[type=checkbox]:checked:after {
        opacity: 1;
        border-color: #ed341d;
    }
}

h3.f-header {
    background: var(--primary-color) !important;
    border-radius: 5px !important;
    padding: 10px;
    color: #fff;
    font-size: 20px;
    line-height: 22px;
    margin: 0 0 15px 0;
}

.input_text {
    border-radius: 0px !important;
}

.form-desc {
    font-size: 15px;
    line-height: 22px;
    background: #f2f2f2;
    padding: 15px;
    margin: 0 0 20px 0 !important;
    display: inline-block;
    width: 100%;
}

.answer-drop, .item-drag {
    text-align: center;
    display: inline-block;
    border: 1px solid #444;
    height: 30px;
}

.answer-drop {
    min-width: 140px;
    margin-bottom: -5px;
}

.answer-drop.input-incorrect {
    border-color: #ed3c0d;
}

.item-drag {
    margin: 5px;
    min-width: 120px;
}

.bottom-drag-container .item-drag {
    line-height: 30px;
    padding-top: 0;
}

.answer-drop .item-drag {
    border: none !important;
    margin: 0;
    padding-top: 0;
}

.float-right {
    float: right !important;
}

.float-right > * {
    width: auto !important;
}

.card .card-widgets {
    height: 16px;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
}

.thinner-card-body {
    padding: 0.8rem;
}

.card .card-widgets > a {
    color: inherit;
    font-size: 15px;
    display: inline-block;
    line-height: 1;
    margin-left: 8px;
}

span.input-group-text.input-group-addon {
    line-height: unset !important;
    padding-top: 0;
}

.bootstrap-timepicker-widget table td input {
    border: 1px solid #007bff;
    font-size: 14px;
    width: 30px !important;
}

.bootstrap-timepicker-widget table td a {
    background: #f2f2f2;
    color: #000;
    padding: 0px !important;
}

span.glyphicon.glyphicon-chevron-up:before {
    content: '\f077';
    font-family: 'Font Awesome 6 Pro';
}

span.glyphicon.glyphicon-chevron-down:before {
    content: '\f078';
    font-family: 'Font Awesome 6 Pro';
}

.is-light a.nk-menu-link {
    color: #222 !important;
    text-transform: unset;
}

/**course**/
{
    width: 100%
;
    background: #fff
;
    border-radius: 10px
;
    padding: 10px
;
    transition: all .5s
;
    box-shadow: 0 1px 3px -2px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24)
;
}

.course-thumbnail {
    width: 100%;
    height: 240px;
    overflow: hidden;
    border-radius: 10px;
    transition: all .5s;
}

.course-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 10px;
    transition: all .5s;
}

.course-item:hover .course-thumbnail img {
    transition: all .5s;
    transform: scale(1.1);
}

.course-content {
    padding: 15px;
}

.course-title a {
    color: #000;
    text-transform: uppercase;
    font-size: 18px;
    line-height: 24px;
    font-weight: 700;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    height: 50px;
}

.course-title a:hover {
    color: #ff3333;
}

.card-thumbnail {
    width: 100%;
    height: 240px;
    border-top-left-radius: 4px !important;
    border-top-right-radius: 4px !important;
}

.card-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-top-left-radius: 4px !important;
    border-top-right-radius: 4px !important;
}

.course-process {
    display: flex;
    flex-flow: wrap;
    align-items: center;
}

.course-process .course-bar {
    width: 85%;
}

.course-process .course-counter {
    width: calc(100% - 85%);
    text-align: center;
}


.course-footer i {
    font-size: 20px;
}

.course-footer {
    display: flex;
    width: 100%;
    justify-content: space-between;
    text-align: center;
    margin: 15px 0 0 0;
    color: #666666;
    font-size: 15px;
}

.course-single {
    background: #fff;
    border-radius: 10px;
    padding: 20px;
    box-shadow: 0 1px 3px -2px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);
}

.course-single .course-header h3 {
    text-align: center;
    text-transform: uppercase;
    font-size: 30px;
    line-height: 38px;
    margin: 0 0 10px 0;
    font-weight: bold;
    color: #000;
}

.course-single .course-description {
    width: 80%;
    margin: auto;
    text-align: center;
    color: #000;
    font-size: 15px;
    line-height: 22px;
}


/**timline shiping**/
.shipping ul.timeline {
    position: relative;
    list-style-type: none;
    padding-left: 180px;
}

.shipping ul.timeline:before {
    position: absolute;
    display: block;
    left: 136px;
    width: 4px;
    height: 100%;
    border-radius: 4px;
    background-color: var(--primary-color);
    content: ' ';
}

.shipping ul.timeline .event {
    position: relative;
    background: #f2f2f2;
    border-radius: 2px;
    box-shadow: 0 1px 3px 0 rgba(0, 0, 0, .2), 0 1px 1px 0 rgba(0, 0, 0, .14), 0 2px 1px -1px rgba(0, 0, 0, .12);
    padding: 16px !important;
    margin-bottom: 30px !important;
    display: flex;
}

.shipping ul.timeline .event:before {
    display: block;
    position: absolute;
    top: 35px;
    left: -52px;
    width: 20px;
    height: 20px;
    background: var(--primary-color);
    border-radius: 50%;
    box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.6);
    content: ' ';
}

.shipping ul.timeline .description {
    margin-left: 80px;
}

.shipping ul.timeline h3 {
    font-size: 16px;
    margin-top: 0;
    margin-bottom: 10px;
}

.shipping ul.timeline .description p {
    font-size: 15px;
    margin: 0;
}

.shipping ul.timeline .time {
    /* position: absolute; */
    /* display: block; */
    width: 120px;
    top: 15px;
    left: -179px;
    font-size: 0.9em;
    text-align: right;
    font-weight: 600;
    color: #000 !important;
    margin-left: -200px;
}

.shipping ul.timeline .time > .glyphicon-time {
    top: 2px;
}

.shipping ul.timeline .left-arrow:before {
    position: absolute;
    top: 30px;
    left: -15px;
    display: inline-block;
    border-top: 15px solid transparent;
    border-right: 15px solid #ddd;
    border-left: 0 solid #ddd;
    border-bottom: 15px solid transparent;
    content: ' ';
}

.shipping ul.timeline .left-arrow:after {
    position: absolute;
    top: 30px;
    left: -14px;
    display: inline-block;
    border-top: 15px solid transparent;
    border-right: 15px solid #f2f2f2;
    border-left: 0 solid #f2f2f2;
    border-bottom: 15px solid transparent;
    content: ' ';
}

.course-step {
    margin: 40px 0 0 0;
}

.shipping > * {
    color: #000;
}

.shipping ul.timeline .time h3 {
    font-size: 23px;
    line-height: 28px;
    color: #000 !important;
}

.description h3 {
    font-size: 23px !important;
    line-height: 28px;
    color: #000 !important;
}

@media only screen and (max-width: 768px) {
    .shipping ul.timeline .description {
        margin-left: 100px;
    }
}

.work-list {
    margin: 20px 0;
}

.work-flex {
    display: flex;
}

.work-item {
    padding: 15px;
    position: relative;
    margin-bottom: 1rem;
    border: 1px solid #badbcc;
    border-radius: .25rem;
    color: #fff;
    background-color: #d1e7dd;
}

.work-item h5 {
    color: #0f5132;
    margin-bottom: 15px;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    line-height: 22px;
    height: 45px;
    font-size: 15px;
}

.work-icon svg {
    width: 50px;
    height: 50px;
    margin: 0 auto 20px;
    display: block;
}

.work-item {
    font-size: 15px;
    text-align: center;
}

.work-item a {
    color: #fff;
}

.work-item i {
    margin: 0 5px 0 0;
}

.document-item {
    padding: 15px;
    position: relative;
    margin-bottom: 1rem;
    border: 1px solid #ffecb5;
    border-radius: .25rem;
    color: #664d03;
    background-color: #fff3cd;
    text-align: center;
}

.document-item h5 {
    color: #664d03;
    font-size: 15px;
    margin-bottom: 15px;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    line-height: 22px;
    height: 45px;
}

.document-item {
    font-size: 15px;
}

.document-item a {
    color: #fff;
}

.document-item i {
    margin: 0 5px 0 0;
}

.document-icon svg {
    width: 50px;
    height: 50px;
    margin: 0 auto 20px;
    display: block;
}

.avatar-xs {
    width: 1.625rem;
    height: 1.625rem;
}

.avatar-xs .avatar-initial {
    font-size: 0.625rem;
}

.avatar-xs.avatar-online:after, .avatar-xs.avatar-offline:after, .avatar-xs.avatar-away:after, .avatar-xs.avatar-busy:after {
    width: 0.325rem;
    height: 0.325rem;
    right: 1px;
}

.avatar-sm {
    width: 2rem;
    height: 2rem;
}

.avatar-sm .avatar-initial {
    font-size: 0.75rem;
}

.avatar-sm.avatar-online:after, .avatar-sm.avatar-offline:after, .avatar-sm.avatar-away:after, .avatar-sm.avatar-busy:after {
    width: 0.4rem;
    height: 0.4rem;
    right: 2px;
}

.avatar-md {
    width: 3rem;
    height: 3rem;
}

.avatar-md .avatar-initial {
    font-size: 1.125rem;
}

.avatar-md.avatar-online:after, .avatar-md.avatar-offline:after, .avatar-md.avatar-away:after, .avatar-md.avatar-busy:after {
    width: 0.6rem;
    height: 0.6rem;
    right: 4px;
}

.avatar-lg {
    width: 4rem;
    height: 4rem;
}

.avatar-lg .avatar-initial {
    font-size: 1.5rem;
}

.avatar-lg.avatar-online:after, .avatar-lg.avatar-offline:after, .avatar-lg.avatar-away:after, .avatar-lg.avatar-busy:after {
    width: 0.8rem;
    height: 0.8rem;
    right: 5px;
}

.avatar-xl {
    width: 4.5rem;
    height: 4.5rem;
}

.avatar-xl .avatar-initial {
    font-size: 1.875rem;
}

.avatar-xl.avatar-online:after, .avatar-xl.avatar-offline:after, .avatar-xl.avatar-away:after, .avatar-xl.avatar-busy:after {
    width: 0.9rem;
    height: 0.9rem;
    right: 6px;
}

.avatar-group .avatar {
    transition: all 0.25s ease;
}

.avatar-group .avatar img,
.avatar-group .avatar .avatar-initial {
    border: 2px solid #fff;
}

.avatar-group .avatar .avatar-initial {
    color: #6f6b7d;
    background-color: #f6f6f7;
}

.avatar-group .avatar:hover {
    z-index: 30;
    transition: all 0.25s ease;
}

.avatar-group .avatar {
    margin-left: -0.8rem;
}

.avatar-group .avatar:first-child {
    margin-left: 0;
}

.avatar-group .avatar-xs {
    margin-left: -0.65rem;
}

.avatar-group .avatar-sm {
    margin-left: -0.75rem;
}

.avatar-group .avatar-md {
    margin-left: -0.9rem;
}

.avatar-group .avatar-lg {
    margin-left: -1.5rem;
}

.avatar-group .avatar-xl {
    margin-left: -1.75rem;
}

[dir=rtl] .avatar-group .avatar {
    margin-right: -0.8rem;
    margin-left: 0;
}

[dir=rtl] .avatar-group .avatar-xs {
    margin-right: -0.65rem;
}

[dir=rtl] .avatar-group .avatar-sm {
    margin-right: -0.75rem;
}

[dir=rtl] .avatar-group .avatar-md {
    margin-right: -0.9rem;
}

[dir=rtl] .avatar-group .avatar-lg {
    margin-right: -1.5rem;
}

[dir=rtl] .avatar-group .avatar-xl {
    margin-right: -1.75rem;
}

/**section2**/
section.sec-2 {
    padding: 100px;
}

/***read aloud***/
#record-btn {
    border: 1px solid;
    color: var(--primary-blue);
}

#record-btn:hover {
    background: var(--primary-blue);
    color: var(--primary-white);
}

#speak-btn {
    border: 1px solid;
    color: var(--primary-blue);
    float: right;
}

#speak-btn:hover {
    background: var(--primary-blue);
    color: var(--primary-white);
}

.read-aloud-content {
    padding: 15px;
    border: 1px solid var(--primary-white);
    margin: 20px 0;
    background-color: rgba(0, 0, 0, 0.05);
}

/***repeat sentence***/
#txtAnswer {
    margin-bottom: 20px;
}

.form-select {
    margin-bottom: 20px;
}

/**tts**/
.bg-light {
    padding: 15px;
}

.body-tts {
    border: 1px dotted #ddd;
    padding: 20px;
    margin-top: 30px;
}

/***fill-in-blank***/
.item-drag {
    padding: 4px 25px;
    border: 1px solid;
    margin: 10px;
}

.mt-5.bottom-drag-container.drop-zone {
    padding: 10px;
    background-color: #d1ecf1;
    display: flex;
    flex-wrap: wrap;
}

/***mcma***/
.start-practice {
    padding: 20px 10px;
    background: rgb(248 249 250);
}

.audio-player {
    border: 1px solid #ddd;
    padding: 10px;
    width: 300px;
}

/***practice***/
.practice-menu a {
    color: var(--primary-black);
    font-weight: normal;
}

.title-practice {
    margin-bottom: 25px;
}

.form-group {
    margin-bottom: 20px !important;
}

td.table-fields.-right button {
    text-align: center !important;
    display: flex;
    justify-content: center;
}

.answer-drop, .item-drag {
    text-align: center;
    display: inline-block;
    border: 1px solid #444;
    height: 30px;
}

.answer-drop {
    min-width: 140px;
    margin-bottom: -5px;
}

.answer-drop.input-incorrect {
    border-color: #ed3c0d;
}

.item-drag {
    margin: 5px;
    min-width: 120px;
}

.bottom-drag-container .item-drag {
    line-height: 30px;
    padding-top: 0;
}

.answer-drop .item-drag {
    border: none !important;
    margin: 0;
    padding-top: 0;
}

.wide-xl .scroll {
    height: 71vh;
    margin-bottom: 0px !important;
    overflow-x: visible;
    overflow-y: scroll;
    padding-right: 20px;
}

.flex-calendar select {
    background: #d9d9d9 !important;
    border-radius: 99px !important;
    padding: 0 15px !important;
    line-height: 25px !important;
    min-height: 25px !important;
}

.flex-calendar {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
}

.fc .fc-toolbar-title {
    text-transform: capitalize;
}

p#preview-event-description span.dot:last-child {
    display: none !important;
}

div.dataTables_wrapper div.dataTables_length select {
    margin-bottom: 0;
}

.nk-menu-main > li > .nk-menu-link {
    text-transform: unset !important;
}

#primary {
    margin: 0px auto !important;
    width: 100%;
}

.um-dropdown ul {
    text-align: left;
}

#thinoi,
.an {
    pointer-events: none;
}

.um-member-directory-search-line .um-button {
    color: #ffffff;
    background: #000d77;
}

.mejs-container,
.mejs-container .mejs-controls,
.mejs-embed,
.mejs-embed body {
    color: #fff;
    text-align: center !important;
    line-height: 2.5;
}

span#duration {
    font-size: 35px;
    background: #fff;
    border-radius: 50%;
    width: 100px;
    height: 100px;
    line-height: 2.7;
    text-align: center;
    margin: 15px auto;
    display: block;
}

p#nmsec {
    color: #001996;
}

#partvoice {
    display: flex;
}

.wrapnoidungsp {
    width: 60%;
}

#bspeak {
    text-align: center
}

input[type=radio]:after {
    left: 2px;
    top: 0px;
    border-radius: 0;
    background: none;
    border: solid #fff;
    width: 8px;
    height: 10px;
    border-width: 0 4px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

form .mejs-button.mejs-playpause-button.mejs-pause {
    display: none;
}

p#bghiam {
    font-size: 25px;
    vertical-align: middle;
    margin-top: 100px;
}

input[type=radio]:checked {
    border: 4px solid #00bb06;
    background: #00bb06;
}

#form .noidungghiam {
    width: 300px;
    float: right;
    padding: 10px;
    height: 300px;
    background: #efefef;
    border-radius: 6px
}

.grpdethi {
    width: calc(100% - 310px);
    float: left;
    margin-bottom: 100px;
}

.um-directory .um-members-wrapper .um-members .um-member {
    border: 0 !important;
}

.um-new-dropdown {
    width: 300px;
    right: 0;
}

.um-directory .um-members-wrapper .um-members img {
    width: 34px;
    display: inline-block;
}

.wp-audio-shortcode .mejs-time-rail {
    pointer-events: none;
}

.mejs-button.mejs-playpause-button.mejs-replay {
    display: none !important;
}

.cauhoi span {
    width: 50%;
    display: flex;
}

.nmcount {
    display: block;
    text-align: right;
    background: #ddd;
    border: 1px solid #5c5b5b;
    border-bottom: 0;
    font-size: 12px;
    padding-right: 5px;
}

.nmheader div {
    width: 33%;
    display: inline-block;
    margin-top: 0px;
}

.nmheader {
    background: #047099;
    color: #fff;
    position: fixed;
    width: 100%;
    padding: 2px 10px;
    left: 0;
    top: 0px;
    font-size: 13px;
    z-index: 10000;
    display: flex;
    vertical-align: middle;
    align-items: center;
}

p#nmtime {

    display: inline-block;
    padding: 0 5px;
    border-radius: 3px;
    color: #ffffff;
    font-size: 18px;
    font-weight: 700;
    margin-top: 0px;
}

p#nmtime span {
    background: #047099;
    padding: 6px 2px;


}

p#nmtime .timeitem {
    background: #ff5722;
    margin: 0px 2px;
    border-radius: 5px;
    padding: 6px 8px;
}

.anPart {
    display: none;
}

.nmheader div:nth-child(2) {
    text-align: center;
}

.nmheader div:nth-child(3) {
    text-align: right;
}

h2.nmtitle {
    margin-top: 40px;
    text-align: center;
}

a#btnsend {
    background: #f00;
    color: #fff;
}

.nmfooter {
    position: fixed;
    bottom: -10px;
    left: 0;
    width: 100%;
    z-index: 100;
    background: #d9d9d9;
    padding: 5px 10px;
    font-size: 13px;
    display: flex;
}

.nmfooter div:nth-child(1) {
    display: inline-block;
    width: 60%;
    text-align: center;
    margin-left: auto;

}

.nmfooter div:nth-child(2) {
    display: inline-block;
    width: 30%;
    vertical-align: top;
}

.nmfooter table tr:first-child td {
    text-transform: uppercase;
}

.nmfooter table tr td a {
    color: #000 !important;
}

.nmfooter table {
    display: inline-block;
    min-width: unset;
    width: unset;
    margin: 0 5px;
}

.nmfooter td {
    padding: 0 10px;
    text-align: center;
    border-color: #fff !important;
    font-size: 14px;
    line-height: 1.5;
    border-width: 1px;
}

.nmfooter td.nmchon, .nmfooter td.nmchon a {
    background: #FF5722;
    color: #fff;
}

.nmfooter td:hover, .nmfooter td:hover a {
    background: #FF5722;
    color: #fff;
}

.nmfooter tr:first-child {
    font-size: 11px;
}

.nmfooter table tr:nth-child(2) {
    background: #747474;
    color: #fff;
}

.nmfooter .nmnut {
    margin-top: 5px;
}

.nmnut {
    padding: 5px;
    margin: 0 5px;
    color: #fff;
    font-size: 13px;
    border-radius: 2px;
    cursor: pointer;
    display: inline-block;
    width: 100px;
    text-align: center;
}

.nmnut.btnnext {
    background: #000272e0;
}

.nmnut.btnsave {
    background: #FF5722;
}

.cauhoi label {
    width: calc(100% - 26px);
    font-size: 14px !important;
    font-family: "Libre Franklin", Sans-serif;
}

.noidung {
    margin: 15px 0 100px;
    line-height: 1.2;
    font-size: 15px;
    max-width: 1240px;
    margin-right: auto !important;
    margin-left: auto !important;
}

form#form {
    line-height: 1.5;
}

.mejs-container,
.cauhoi {
    margin-bottom: 15px;
}

.cauhoi {
    margin-top: 10px;
}

.nmquest {
    display: none
}

.baithi {
    cursor: pointer;
}

.baithi.hien {
    pointer-events: none;
}

#record {
    text-align: center;
    display: block;
    margin: 20px auto;
    border-radius: 50px;
    background: #575848;
    color: #ffffff;
    box-shadow: unset;
    width: 90px;
    height: 90px;
    line-height: 4.5;
    font-size: 20px;
    cursor: pointer;
}

.noidungghiam {
    text-align: center;
    width: 40%;
}

.rpart .qpart,
.rpart .chpart {
    width: 50%;
    margin-bottom: 100px;
    float: left;
    height: 60vh;
    overflow-x: visible;
    overflow-y: scroll;
}

.rpart .qpart, .rpart .chpart {
    height: 71vh;
    margin-bottom: 0px !important;
}

.chpart {
    margin-top: 11px;
}

.qpart {
    padding-right: 15px;
    text-align: justify;
}

.qpart span {
    font-size: 16px;
    font-family: "Libre Franklin", Sans-serif;
    line-height: 1.4;
}

.chpart .cauhoi span {
    width: 100%;
}

.nmcount {
    margin-top: 15px
}

.chpart b {
    font-family: "Libre Franklin", Sans-serif;
}

.mejs-time {
    padding: 10px 0px !important;
    font-weight: bold;
}

.mejs-time span {
    font-size: 14px !important;
    line-height: 1.5;
}

.secinfo {
    display: flex !important;
    vertical-align: middle;
    align-items: center;
    font-weight: bold;
    font-size: 16px;
}

.secinfo img {
    width: 30px;
    border-radius: 50%;
    height: 30px;
    margin-right: 10px;
}

.socau {
    margin-right: 100px;
    background: #0a0a0a78;
    padding: 10px;
    font-weight: bold;
}

.socau strong {
    padding: 2px 5px;
    background: #ff5722;
}

#partreading {
    max-width: 100%;
}

@media all and (max-width: 700px) {
    .baithi.hien {
        display: none;
    }

    .rpart .qpart,
    .rpart .chpart {
        width: 100%;
        overflow: visible;
        height: unset;
        margin-bottom: 10px;
    }

    .nmheader div:first-child {
        display: none;
    }

    .nmfooter div:nth-child(1),
    .nmfooter div:nth-child(2) {
        width: 50%
    }

    .nmheader div:nth-child(3) {
        text-align: right;
        float: right;
        top: 16px;
        margin-top: 3px;
    }

    p#nmtime {
        margin-top: 2px;
    }

    .nmheader div {
        width: unset
    }

    .nmnut {
        padding: 5px 7px;
        font-size: 12px;
        width: 70px;
        margin-top: 2px !important;
    }

    .nmfooter {
        padding: 2px;
        font-size: 11px;
    }

    .nmfooter td {
        padding: 0 2px;
    }

    h2.nmtitle {
        margin-top: 27px;
        font-size: 25px;
    }

    .noidung {
        margin-top: 5px;
    }

    form#form {
        line-height: 1.5;
        display: -webkit-grid;
        display: grid;
    }

    div.spart {
        order: 5;
        display: block;
    }

    .grpdethi {
        float: none !important;
        display: block;
        width: 100%;
    }

    .noidungghiam {
        text-align: center;
        order: 1;
        float: none !important;
        display: flow-root;
        -webkit-order: 1;
    }
}

#gritter-notice-wrapper {
    position: fixed;
    width: auto;
    height: auto;
    right: 20px;
    top: unset !important;
    transform: unset;
    bottom: 73px;
}

.gritter-item-wrapper.gritter-success {
    background: #30ac22 !important;

}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-title {
    display: none !important
}

#gritter-notice-wrapper p {
    text-transform: uppercase;
}

#gritter-notice-wrapper .gritter-item-wrapper {

}

.the-count {
    font-size: 16px;
    text-align: right;
    margin: 10px 0px;
}

.swal-thoigianchuanbi {
    width: auto !important;
}

#saveNoticeAudioWarning {
    background: #d51c1c;
    padding: 10px;
    width: 300px;
    margin: auto;
}

.textWarning {
    text-align: left;
    padding: 40px 0px;
}

#saveNoticeAudioWarning p {
    font-size: 16px;
    color: #fff !important;
    margin: 20px 0px;
}

#audtiocontrols {
    display: none !important;
}

.load-wrapp {
    float: left;
    width: 100%;
    height: 100px;
    margin: 0 10px 10px 0;
    padding: 20px 20px 20px;
    border-radius: 5px;
    text-align: center;
    background-color: #d8d8d800;
}

.load-wrapp p {
    padding: 0 0 20px;
}

.load-wrapp:last-child {
    margin-right: 0;
}

.line {
    display: inline-block;
    width: 15px;
    height: 15px;
    border-radius: 15px;
    background-color: #4b9cdb;
}


.load-3 .line:nth-last-child(1) {
    animation: loadingC 0.6s 0.1s linear infinite;
}

.load-3 .line:nth-last-child(2) {
    animation: loadingC 0.6s 0.2s linear infinite;
}

.load-3 .line:nth-last-child(3) {
    animation: loadingC 0.6s 0.3s linear infinite;
}

#overlay {
    position: fixed;
    top: 0;
    z-index: 100;
    width: 100%;
    height: 100%;
    display: none;
    background: rgba(0, 0, 0, 0.6);
}

.cv-spinner {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.spinner {
    width: 40px;
    height: 40px;
    border: 4px #ddd solid;
    border-top: 4px #2e93e6 solid;
    border-radius: 50%;
    animation: sp-anime 0.8s infinite linear;
}

@keyframes sp-anime {
    100% {
        transform: rotate(360deg);
    }
}

.is-hide {
    display: none;
}


.home .mejs-horizontal-volume-current:after {
    content: "";
    width: 14px;
    height: 14px;
    background: var(--primary-color);
    right: -8px !important;
    display: block;
    border-radius: 50%;
    position: absolute;
    top: -4px;
}

#dangkyform .um-postmessage {
    color: #fff !important
}

.home .mejs-container .mejs-controls {
    background: #2b2b2bbf;
}

.home .mejs-time-handle, .home .mejs-time-handle-content {
    top: -4px;
    border-radius: 50% !important;
    border: 4px solid var(--primary-color);
    width: 14px;
    height: 14px;

    background: var(--primary-color);
}

.home .mejs-time-handle-content {
    opacity: 0 !important
}

.home .mejs-horizontal-volume-total {
    height: 6px;
    top: 18px;
    border-radius: 20px !important
}

.home .mejs-time-buffering, .home .mejs-time-current, .home .mejs-time-float, .home .mejs-time-float-corner, .home .mejs-time-float-current, .home .mejs-time-hovered, .home .mejs-time-loaded, .home .mejs-time-marker, .home .mejs-time-total {
    border-radius: 20px !important;

    height: 6px;
}

.home .mejs-time-rail {
    padding-top: 12px
}

.home .mejs-horizontal-volume-current {
    border-radius: 20px !important
}

.single-de_thi_tieng_anh #wpadminbar {
    display: none !important;
}

.single-de_thi_tieng_anh .site-header {
    display: none !important;
}

.single-de_thi_tieng_anh .site-footer {
    display: none !important;
}

.home #page .elementor-location-header {
    position: fixed;
    z-index: 999999999999
}

.roundcirle {
    border: 3px solid;
    padding: 2px 8px;
    border-radius: 50%;
}

.textpartnghe .roundcirle {
    border: 3px solid #f0983a !important;
    color: #f0983a !important;
}

.textpartluuy .roundcirle {
    border: 3px solid #dce560 !important;
    color: #dce560 !important;
}

#thuamphu {
    cursor: pointer;
}

#nghelaiphu {
    cursor: pointer;
}

.thongtinuser {
    display: flex;
}

.noclick {
    pointer-events: none;
    cursor: default;
    background: #8ab7d0 !important;
}

#gritter-notice-wrapper {
    position: fixed;
    top: 20px;
    right: 20px;
    width: 301px;
    z-index: 9999;
}

#gritter-notice-wrapper.top-left {
    left: 20px;
    right: auto;
}

#gritter-notice-wrapper.bottom-right {
    top: auto;
    left: auto;
    bottom: 20px;
    right: 20px;
}

#gritter-notice-wrapper.bottom-left {
    top: auto;
    right: auto;
    bottom: 20px;
    left: 20px;
}

.gritter-item-wrapper {
    position: relative;
    margin: 0 0 10px 0;

}

.gritter-item {
    display: block;

    color: #eee;
    padding: 2px 11px 8px 11px;
    font-size: 11px;
    font-family: verdana;
}

.hover .gritter-item {
    background-position: right -40px;
}

.gritter-item p {
    padding: 0;
    margin: 0;
    word-wrap: break-word;
}

.gritter-close {
    display: none;
    position: absolute;
    top: 5px;
    left: 3px;
    background: url(../images/gritter.png) no-repeat left top;
    cursor: pointer;
    width: 30px;
    height: 30px;
    text-indent: -9999em;
}

.gritter-title {
    font-size: 14px;
    font-weight: bold;
    padding: 0 0 7px 0;
    display: block;
}

.gritter-image {
    width: 48px;
    height: 48px;
    float: left;
}

.gritter-with-image,
.gritter-without-image {
    padding: 0;
}

.gritter-with-image {
    width: 220px;
    float: right;
}

/* for the light (white) version of the gritter notice */
.gritter-light .gritter-item,
.gritter-light .gritter-bottom,
.gritter-light .gritter-top,
.gritter-light .gritter-close {

    color: #222;
}

.gritter-light .gritter-title {
    text-shadow: none;
}

#gritter-notice-wrapper {
    position: fixed;
    top: 70px;
    right: 20px;
    width: 301px;
    z-index: 99999999999999999;
}

#gritter-notice-wrapper.top-left {
    left: 20px;
    right: auto;
}

#gritter-notice-wrapper.bottom-right {
    top: auto;
    left: auto;
    bottom: 20px;
    right: 20px;
}

#gritter-notice-wrapper.bottom-left {
    top: auto;
    right: auto;
    bottom: 20px;
    left: 20px;
}

#gritter-notice-wrapper .gritter-item-wrapper {
    position: relative;
    margin: 0 0 10px 0;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item {
    display: block;

    border: 1px solid #0bacd3;
    color: #ffffff;
    padding: 10px 11px;
    font-size: 12px;
    border-radius: 3px;
    transition: all;
    transition: all all ease-out;
    transition-duration: 0.4s;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item:hover {
    background: #72849e;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item p {
    padding: 0;
    margin: 0;
    word-wrap: break-word;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-close {
    position: absolute;
    top: 5px;
    right: 7px;
    cursor: pointer;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-close i {
    font-size: 16px;
    color: #ffffff;
    transition: background;
    transition: all background ease-out;
    transition-duration: 0.4s;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-close:hover i {
    color: #f7f7f7;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-image {
    width: 48px;
    height: 48px;
    float: left;
    border-radius: 3px;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-icon {
    margin-top: 0;
    margin-right: 15px;
    float: left;
    font-size: 32px;
    padding-bottom: 10px;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-with-image {
    width: 220px;
    float: right;
    padding: 0;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-without-image {
    padding: 0;
}

#gritter-notice-wrapper .gritter-item-wrapper .gritter-item .gritter-title {
    font-size: 14px;
    font-weight: bold;
    padding: 0;
    display: block;
}

#gritter-notice-wrapper .gritter-item-wrapper.success-notice .gritter-item {
    color: #0a776c;
    background: #b2ede8;
    border: 1px solid #63c8be;
}

#gritter-notice-wrapper .gritter-item-wrapper.success-notice .gritter-item:hover {
    background: #c7f2ee;
}

#gritter-notice-wrapper .gritter-item-wrapper.success-notice .gritter-item .gritter-close i {
    color: #0a776c;
}

#gritter-notice-wrapper .gritter-item-wrapper.success-notice .gritter-item .gritter-close:hover i {
    color: #09695f;
}

#gritter-notice-wrapper .gritter-item-wrapper.info-notice .gritter-item {
    color: #2a6891;
    background: #cfebff;
    border: 1px solid #94bedb;
}

#gritter-notice-wrapper .gritter-item-wrapper.info-notice .gritter-item:hover {
    background: #e9f6ff;
}

#gritter-notice-wrapper .gritter-item-wrapper.info-notice .gritter-item .gritter-close i {
    color: #2a6891;
}

#gritter-notice-wrapper .gritter-item-wrapper.info-notice .gritter-item .gritter-close:hover i {
    color: #275f85;
}

#gritter-notice-wrapper .gritter-item-wrapper.error-notice .gritter-item {
    color: #933230;
    background: #fddede;
    border: 1px solid #cb7c7a;
}

#gritter-notice-wrapper .gritter-item-wrapper.error-notice .gritter-item:hover {
    background: #fef6f6;
}

#gritter-notice-wrapper .gritter-item-wrapper.error-notice .gritter-item .gritter-close i {
    color: #933230;
}

#gritter-notice-wrapper .gritter-item-wrapper.error-notice .gritter-item .gritter-close:hover i {
    color: #872e2c;
}

.gritter-item-wrapper.gritter-error {
    background: rgba(153, 40, 18, 0.92) !important;
}

.gritter-item-wrapper.gritter-success {
    background: #9ed170 !important;
}

.gritter-item p {
    color: white !important
}

.gritter-top {
    background: none !important
}

.gritter-item {
    background: none !important;
    border: 0px !important
}

.swal2-popup {
    width: 50em !important;
}

#swal2-content p {
    font-weight: 500;
    text-transform: uppercase;
    font-size: 16px;
}

.cd-popup-trigger {
    display: block;
    width: 170px;
    height: 50px;
    line-height: 50px;
    margin: 3em auto;
    text-align: center;
    color: #FFF;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    text-transform: uppercase;
    border-radius: 50em;
    background: #35a785;
    box-shadow: 0 3px 0 rgba(0, 0, 0, 0.07);
}

.mejs-horizontal-volume-current {
    background: #595959 !important;
}

@media only screen and (min-width: 1170px) {
    .cd-popup-trigger {
        margin: 6em auto;
    }
}

/* --------------------------------

xpopup

-------------------------------- */
.cd-popup {
    position: fixed;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(94, 110, 141, 0.9);
    opacity: 0;
    visibility: hidden;
    -webkit-transition: opacity 0.3s 0s, visibility 0s 0.3s;
    -moz-transition: opacity 0.3s 0s, visibility 0s 0.3s;
    transition: opacity 0.3s 0s, visibility 0s 0.3s;
    z-index: 9999999
}

.cd-popup.is-visible {
    opacity: 1;
    visibility: visible;
    -webkit-transition: opacity 0.3s 0s, visibility 0s 0s;
    -moz-transition: opacity 0.3s 0s, visibility 0s 0s;
    transition: opacity 0.3s 0s, visibility 0s 0s;
}

.cd-popup-container {
    position: relative;
    width: 90%;
    max-width: 60%;
    margin: 4em auto;
    background: #FFF;
    border-radius: .25em .25em .4em .4em;
    text-align: center;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
    -webkit-transform: translateY(-40px);
    -moz-transform: translateY(-40px);
    -ms-transform: translateY(-40px);
    -o-transform: translateY(-40px);
    transform: translateY(-40px);
    /* Force Hardware Acceleration in WebKit */
    -webkit-backface-visibility: hidden;
    -webkit-transition-property: -webkit-transform;
    -moz-transition-property: -moz-transform;
    transition-property: transform;
    -webkit-transition-duration: 0.3s;
    -moz-transition-duration: 0.3s;
    transition-duration: 0.3s;
}

.cd-popup-container p {
    padding: 3em 1em;
}

.cd-popup-container .cd-buttons:after {
    content: "";
    display: table;
    clear: both;
}

.cd-popup-container .cd-buttons li {
    float: left;
    width: 50%;
    list-style: none;
}

.cd-popup-container .cd-buttons a {
    display: block;
    height: 40px;
    line-height: 40px;
    text-transform: uppercase;
    color: #FFF;
    -webkit-transition: background-color 0.2s;
    -moz-transition: background-color 0.2s;
    transition: background-color 0.2s;
    /* margin: 0px 20px; */
    border-radius: 0px !important;
}

.cd-popup-container .cd-buttons li:first-child a {
    background: #fc7169;
    border-radius: 0 0 0 .25em;
}

.no-touch .cd-popup-container .cd-buttons li:first-child a:hover {
    background-color: #fc8982;
}

.cd-popup-container .cd-buttons li:last-child a {
    background: #b6bece;
    border-radius: 0 0 .25em 0;
}

.no-touch .cd-popup-container .cd-buttons li:last-child a:hover {
    background-color: #c5ccd8;
}

.cd-popup-container .cd-popup-close {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 30px;
    height: 30px;
}

.cd-popup-container .cd-popup-close::before, .cd-popup-container .cd-popup-close::after {
    content: '';
    position: absolute;
    top: 12px;
    width: 14px;
    height: 3px;
    background-color: #8f9cb5;
}

.cd-popup-container .cd-popup-close::before {
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
    left: 8px;
}

.cd-popup-container .cd-popup-close::after {
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    transform: rotate(-45deg);
    right: 8px;
}

.is-visible .cd-popup-container {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -o-transform: translateY(0);
    transform: translateY(0);
}

.cd-buttons {
    width: 80%;
    margin: auto;
    padding: 0px;
}

#saveNoticeAudio {
    background: #42c229;
    height: 300px;
    width: 300px;
    margin: auto;
    display: flex;
    flex-direction: column;
    vertical-align: middle;
    justify-content: center;
    border-radius: 5px;
}

#saveNoticeAudio img {
    height: 60px;
    margin: 0px auto;
}

#saveNoticeAudio h3 {
    color: #fff;
    margin: 0px auto;
    font-size: 20px;
    margin-top: 20px;
}

#msecspeaking {
    font-size: 30px
}

#swal2-content {
    display: block;
    width: 90%;
    margin: auto;
}

#swal2-content img {
    width: 100px;
    margin: auto;
    margin-bottom: 20px;
}

#swal2-content p {
    margin-bottom: 10px !important;
}

#textketthucnopbai {
    font-size: 20px;
    width: 100%;
    margin: 0px auto;
    color: #fff;
    margin-top: 10px;
}

.textgioithieucauhoi {
    font-weight: bold;
    margin-bottom: 20px !important;
    font-size: 16px;
    text-transform: uppercase;
}

.de_thi_tieng_anh-template-default .mejs-container .mejs-controls {
    background: #621a7e;
}

#thongtinuserketqua .hinhanhdaidien {
    width: 15%;
}

#thongtinuserketqua .noidung {
    color: #000;
    display: flex;
    vertical-align: middle;
    align-items: center;
    font-size: 20px !important;
    font-weight: 500;
}

.acauhoi {
    background: #fdfdfd;
    border: 1px solid red;
    padding: 20px;
    margin: 20px 0px;
}

.sectraloiqt {
    background: #89ef3e;
    padding: 10px 20px;
    color: #000;
}

#savediem {
    border-radius: 20px;
    padding: 15px 40px;
    background: #1d9b29;
    text-transform: uppercase;
    font-weight: bold;
}

#sendmaildiem {
    border-radius: 20px;
    padding: 15px 40px;
    background: #25136a;
    text-transform: uppercase;
    font-weight: bold;
}

.wrapbtn {
    text-align: center;
    margin: 40px 0px;
    margin-bottom: 0px;
}

#dangkyform .um-field-label label {
    color: #fff !important
}

#dangkyform .um-right a {
    background: #dc3545;
    color: #fff !important
}

.single-de_thi_tieng_anh .ast-container {
    max-width: 100% !important;
}

#bangdulieuKQ {
    background: #fff;
    width: 60%;
    margin: auto;
    border: 0px;
}

#bangdulieuKQ th {
    text-align: left;
}

#bangdulieuKQ .font-weight-bold {
    font-weight: bold !important
}

#bangdulieuXH {

    width: 60%;
    margin: auto;
    border: 0px;
    border: 1px solid #e5e5e5;
    background: var(--primary-color);
    text-align: center;
    color: #FFf;
}

#bangdulieuXH th {
    text-align: center;
    background: var(--primary-color);
    color: #fff;
}

#bangdulieuXH .font-weight-bold {
    text-align: center;
    font-weight: bold !important
}

#bangdulieuXH tr {
    background: #f5f5f5;
    color: #000;

}

.preventaudio #mep_1 {
    pointer-events: none
}

.dangthuam {
    pointer-events: none
}

.dangthuam .mejs-button {
    display: none
}

.dangthuam .mejs-time-handle {
    display: none
}

.dangthuam .mejs-volume-button {
    display: none
}

.dangthuam .mejs-horizontal-volume-slider {
    display: none !important
}

.home .mejs-container .mejs-controls {
    background: #f1f3f4;
    border-radius: 20px;
}

.home .mejs-container {
    border-radius: 20px;
}

.home .mejs-time {

    color: #000;
    font-weight: 500 !important;
    font-size: 12px;
}

.home .mejs-controls .mejs-time-rail .mejs-time-total {
    background: #595959;
}

.home .mejs-button > button {
    background: transparent url(https://thithu.edulife.com.vn/wp-includes/js/mediaelement/mejs-controls-bl.svg);
}

.home .mejs-replay > button {
    background-position: -160px 0 !important;
}

.home .mejs-mute > button {
    background-position: -60px 0 !important
}

.home .mejs-pause > button {
    background-position: -20px 0 !important
}

.home .mejs-unmute > button {
    background-position: -40px 0 !important
}

.site-below-footer-wrap {
    display: none !important
}

.tatNut {
    pointer-events: none !important;
    background: #b1b1b1 !important;
    text-decoration: none;
}

@media only screen and (min-width: 1170px) {
    .cd-popup-container {
        margin: 8em auto;
    }
}

.qpart {
    padding-left: 20px;
}

p.d-flex.d-course {
    gap: 15px;
}

span.success label {
    color: green !important;
    font-weight: 700;
}

span.success b {
    color: green !important;
}

#filePreviewBox {
    width: 200px;
    height: 200px;
    margin-top: 10px;
    border: 2px dashed #aaa;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-direction: column;
    text-align: center;
}

.table-document tr td {
    padding: 8px !important;
    color: #000 !important;
    vertical-align: middle;
}

.calendar-overview {
    background: #fff;
    padding: 8px;
    border: 1px solid #dbdfea;
    margin: 20px 0;
}


#loadingCus {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 9999;
    text-align: center;
    display: none;
    background: rgba(255, 255, 255, 0.5);
    left: 0;
}

#loadingBox {
    display: inline-block;
    width: 70px;
    height: 70px;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    margin: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

#loadingIcon {
    width: 100%;
    height: 100%;
}


div#loading2 {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: 9999;
    text-align: center;
    display: none;
    background: rgba(255, 255, 255, 0.5);
    left: 0;
    top: 0
}

span.error-label {
    color: #ff3333;
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--primary-color);
    --bs-btn-border-color: var(--primary-color);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--primary-color);
    --bs-btn-hover-border-color: var(--primary-color);
    --bs-btn-focus-shadow-rgb: 124, 139, 255;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--primary-color);
    --bs-btn-active-border-color: var(--primary-color);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(16, 25, 36, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--primary-color);
    --bs-btn-disabled-border-color: var(--primary-color);
}

.btn-success {
    --bs-btn-color: #fff;
    --bs-btn-bg: #733AEA;
    --bs-btn-border-color: #733AEA;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: #6231c7;
    --bs-btn-hover-border-color: #5c2ebb;
    --bs-btn-focus-shadow-rgb: 136, 88, 237;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: #5c2ebb;
    --bs-btn-active-border-color: #562cb0;
    --bs-btn-active-shadow: inset 0 3px 5px rgba(16, 25, 36, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #733AEA;
    --bs-btn-disabled-border-color: #733AEA;
}

.swal2-popup {
    width: 32em !important;
    max-width: 32em !important;
}

.documentStep .card {
    height: 100%;
    border-radius: 20px;
}

.document-step {
    height: 100%;
}

.document-step .document-step-heading {
    margin: 0px 0px 20px 0px;
    padding: 5px 0px 5px 0px;
    background-color: var(--primary-color);
    border-radius: 20px 0px 0px 20px;
    color: #fff;
    font-weight: 700;
    font-size: 20px;
    line-height: 24px;
}

.document-step .document-step-body p {
    margin: 0 0 15px 0;
}

.document-step .document-step-body {
    color: #000;
    font-size: 16px;
    line-height: 24px;
}

.document-step .document-step-body ul {
    margin-left: 30px;
}

.document-step .document-step-body ul li {
    margin-bottom: 15px !important;
    list-style: disc;
}

.document-step .document-step-body p.d-flex {
    justify-content: center;
    gap: 10px;
}

.audio-wrapper {
    width: 100%;
}

/* Container bo tròn, nền xám nhạt */
.audio-wrapper .mejs__container {
    background: #eee !important;
    border-radius: 40px;
    padding: 10px 15px;
    width: 100% !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

/* Controls setup */
.audio-wrapper .mejs__controls {
    background: transparent !important;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Nút Play/Pause - xài SVG CSS */
.audio-wrapper .mejs__play > button,
.audio-wrapper .mejs__pause > button {
    border: 0;
    cursor: pointer;
    display: block;
    font-size: 0;
    height: 20px;
    line-height: 0;
    margin: 10px 6px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    text-decoration: none;
    width: 20px;
}

.audio-wrapper .mejs__button button {
    background: transparent url(../images/mejs-controls-bl.svg) !important;
}

/* Text thời gian */
.audio-wrapper .mejs__time {
    font-size: 14px;
    color: #222;
}

/* Thanh thời gian */
.audio-wrapper .mejs__time-total {
    height: 8px !important;
    border-radius: 10px;
    background-color: #444 !important;
    position: relative;
    overflow: visible !important;
    flex-grow: 1;
}

.audio-wrapper .mejs__time-current {
    background-color: #444 !important;
    border-radius: 10px;
}

/* Nút tròn thời gian */
.audio-wrapper .mejs__time-handle {
    width: 14px;
    height: 14px;
    background-color: green !important;
    border-radius: 50%;
    position: absolute;
    top: -3px;
    margin-left: -7px;
    z-index: 2;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.3);
    cursor: pointer;
}

/* Thanh âm lượng ngang */
.audio-wrapper .mejs__horizontal-volume-total {
    height: 8px !important;
    border-radius: 10px;
    background-color: #ccc !important;
    position: relative;
    overflow: visible;
    flex-basis: 80px;
    flex-grow: 0;
    flex-shrink: 0;
}

.audio-wrapper .mejs__horizontal-volume-current {
    background-color: #444 !important;
    border-radius: 10px;
}

/* Nút tròn âm lượng */
.audio-wrapper .mejs__horizontal-volume-handle {
    display: block !important;
    width: 14px;
    height: 14px;
    background-color: green !important;
    border-radius: 50%;
    position: absolute;
    top: -3px;
    margin-left: -7px;
    z-index: 2;
    box-shadow: 0 0 2px rgba(0, 0, 0, 0.3);
    cursor: pointer;
}

/* Nút volume icon */
.audio-wrapper .mejs__volume-button > button {
    color: green !important;
    background: transparent;
    border: none;
}

.audio-wrapper .mejs__button.mejs__volume-button.mejs__mute button {
    background-position: -60px 0 !important;
}

.audio-wrapper .mejs__button.mejs__volume-button.mejs__unmute button {
    background-position: -40px 0 !important;
}

.audio-wrapper .mejs__controls {
    gap: 5px !important;
    padding: 0 5px;
}

.audio-wrapper .mejs__time {
    padding: 16px 6px 0 !important;
    font-weight: 500 !important;
    font-size: 12px;
    height: 24px;
}

.audio-wrapper .mejs__button.mejs__playpause-button.mejs__pause button {
    background-position: -20px 0 !important;
}

.audio-wrapper .mejs__volume-button {
    margin-right: 5px !important;
}

.audio-wrapper .mejs__horizontal-volume-slider {
    margin-top: -5px;
}

span#duration {
    font-size: 35px;
    background: #fff;
    border-radius: 50%;
    width: 100px;
    height: 100px;
    line-height: 2.7;
    text-align: center;
    margin: 15px auto;
    display: none;
    border: 1px solid var(--primary-color2)
}

#canvas {
    width: 100%;
    height: 80px;
    background: #111;
    display: block;
    margin-top: 20px;
}

.user_author {
    display: flex;
    align-items: center;
    gap: 15px;
}

.user_author .user_avatar {
    width: 100px;
    height: 100px;
    border-radius: 50px;
    border: 1px solid var(--primary-color2);
}

.user_author .user_avatar img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
}

.user_author h4 {
    color: var(--primary-color2);
    text-transform: uppercase;
    font-size: 18px;
    line-height: 24px;
    font-weight: 700;
    margin-bottom: 5px;
}

.user_author p {
    color: #000;
    margin-bottom: 10px;
}

.is-theme .header-desktop .nk-menu > li > .nk-menu-link {
    color: rgba(255, 255, 255, 0.7) !important;
}

.header-desktop .nk-menu .nk-menu-link:hover,
.header-desktop .nk-menu .nk-menu-link:focus,
.header-desktop .nk-menu .nk-menu-item.active > .nk-menu-link,
.header-desktop .nk-menu .nk-menu-item.current-menu > .nk-menu-link,
.header-desktop .nk-menu .nk-menu-item:hover > .nk-menu-link {
    color: #fff !important;
}

.header-desktop .nk-menu > li > .nk-menu-link:before {
    background: #fff !important;
}

.is-theme .user-avatar, .is-theme [class^=user-avatar]:not([class*=-group]) {
    background: #fff !important;
    color: var(--primary-color2) !important;
}

.is-theme .dropdown-menu-s1 {
    border-color: var(--primary-color2) !important;
}

.textPrimary {
    color: var(--primary-color2);
    text-transform: uppercase;
    font-size: 18px;
    line-height: 24px;
    font-weight: 700;
    margin-bottom: 5px;
}

div#countdown {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: center;
    margin-top: 15px;
}

div#countdown > div {
    background: var(--primary-color2);
    width: 100px;
    height: 100px;
    margin: 0 3px;
    padding: 0px 15px;
    color: #fff;
    border-radius: 6px;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

div#countdown .time {
    width: 20px;
}

div#countdown > div label {
    font-weight: 700;
    color: #fff;
    line-height: 10px;
    font-size: 40px;
    display: block !important;
}

div#countdown > div span {
    display: block !important;
    font-size: 18px;
    margin-top: 20px;
    text-transform: uppercase;
}

div#countdown > div span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 8px;
}

div#countdown > div.time {
    background: transparent !important;
    color: #000 !important;
    font-weight: 700 !important;
    font-size: 25px !important;
    padding: 0px !important;
}

.audio .mejs__container {
    width: 100% !important;
    background: #621a7e !important;
}


.audio .mejs__button.mejs__playpause-button.mejs__play button {
    background: transparent url(../images/mejs-controls.svg) !important;
}

.audio .mejs__button.mejs__volume-button.mejs__mute button {
    background: transparent url(../images/mejs-controls.svg) !important;
    background-position: -60px 0 !important;
}

.audio .mejs__button.mejs__volume-button.mejs__unmute button {
    background: transparent url(../images/mejs-controls.svg) !important;
    background-position: -40px 0 !important;
}

a.gritter-close {
    display: none !important;
}

.gritter-bottom, .gritter-top {
    display: none;
}

.acauhoi {
    background: #fdfdfd;
    border: 1px solid red;
    padding: 20px;
    margin: 20px 0px;
}

.sectraloiqt {
    background: #89ef3e;
    padding: 10px 20px;
    color: #000;
}

.form-flex {
    gap: 10px;
    font-weight: 700;
}

.form-flex .form-control {
    width: 200px;
}

.menu-bar-home a.active {
    color: #fff;
    background-color: #364a63;
    border-color: #364a63;
}

@media only screen and (max-width: 768px) {
    .menu-bar-home {
        flex-flow: wrap;
        gap: 7px;
    }

    .menu-bar-home > a {
        width: 49%;
        flex-flow: wrap;
        margin: 0 !important;
    }
}

.form-control:disabled, .form-control[readonly] {
    background-color: #e9ecef;
    opacity: 1;
}

.card {
    color: #333 !important;
}

.dark-mode .card {
    color: #8094ae !important
}

.datepicker, .datepicker2, .datepicker3, .datepicker4 {
    background-color: transparent !important;
}

.nk-header-menu.mobile-menu.nk-sidebar-active {
    transform: translateX(0) !important;
}

.is-theme .nk-menu > li > .nk-menu-link {
    color: #fff !important;
}

.is-theme .nk-menu > li > .nk-menu-link:before {
    background: #fff !important;
}

.view-label {
    background: var(--primary-color);
    font-weight: 700;
    padding: 8px;
    color: #fff;
}

.button-radius {
    border-radius: 50% !important;
    width: unset;
    height: unset;
    padding: 0;
    text-align: center;
    line-height: unset;
    display: inline-block;
    background: transparent;
    border-color: transparent;
    color: var(--primary-color) !important;
    font-size: 17px;
}

.button-radius:hover {
    background: transparent;
    border-color: transparent;
    color: var(--primary-color) !important;
}

.modal-content {
    background: #fff;
}

.chquestion strong, .chquestion b {
    font-weight: 700 !important;
}

.dataTable td .btn {
    padding: 4px 15px !important;
}

.audio-disabled {
    pointer-events: none !important;
    opacity: 0.5;
    filter: grayscale(1);
}

.thingay div#countdown {
    margin-top: 10px;
}

.thingay div#countdown > div {
    padding: 0 !important;
    font-size: 16px !important;
    width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
}

.thingay div#countdown > div:first-child {
    margin-left: 0 !important;
}

.thingay div#countdown > div span {
    font-size: 15px !important;
    margin: 0;
}

.thingay div#countdown > div.time {
    width: 10px;
}

div#formThi h4#vaoTitle {
    background: transparent;
    font-size: 15px;
    margin: 0;
    padding: 0;
    text-align: left;
}

.thingay div#countdown > div label {
    line-height: 10px;
    font-size: 18px;
}

@media only screen and (max-width: 768px) {
    .is-theme .nk-menu > li > .nk-menu-link {
        color: var(--primary-color2) !important;
    }
}

@keyframes progress-bar-stripes {
    from {
        background-position: 40px 0;
    }
    to {
        background-position: 0 0;
    }
}

.hide {
    display: none;
}

button.swal2-cancel.btn.btn-label-danger {
    background: #c23558 !important;
    color: #ffff;
}

.is-light .nk-menu-link:hover, li.nk-menu-item.active.current-page a {
    background-color: var(--primary-color);
    color: white !important;
    box-shadow: 0 4px 12px rgba(46, 204, 113, 0.3);
    border-radius: 1rem;
}

.is-light .nk-menu-link:hover, .is-light .active > .nk-menu-link {
    background-color: var(--primary-color);
    color: white !important;
    box-shadow: 0 4px 12px rgba(46, 204, 113, 0.3);
    border-radius: 1rem;
}

.nk-menu-link:hover .nk-menu-icon .icon, .nk-menu-item.active > .nk-menu-link .nk-menu-icon .icon, .nk-menu-item.current-menu > .nk-menu-link .nk-menu-icon .icon {
    color: #fff !important;
}

.is-light .nk-menu-link:hover .nk-menu-icon .icon {
    color: #fff !important;
}

.current-page .icon {
    color: #fff !important;
}

li.nk-menu-item.has-sub.active.current-page a {
    background-color: var(--primary-color);
    color: white !important;
    box-shadow: 0 4px 12px rgba(46, 204, 113, 0.3);
}

li.nk-menu-item.active.current-page a:after {
    color: #fff !important;
}

li.nk-menu-item.active.current-page ul.nk-menu-sub li a {
    background: transparent !important;
    box-shadow: unset !important;
    color: #222 !important;
}

li.nk-menu-item.active.current-page ul.nk-menu-sub li a .nk-menu-icon {
    color: #222 !important;
}

li.nk-menu-item.active.current-page ul.nk-menu-sub li.active.current-page a {
    color: var(--primary-color2) !important;
}

.card-header {
    border-bottom: 2px solid #f8f9fa;
    padding: 15px !important;
    background: transparent !important;
    font-weight: 700 !important;
    font-size: 1.25rem;
}

.card-body {
    padding: 15px !important;
}

h3.nk-block-title.page-title {
    color: #222 !important;
}

.bg-action {
    background-color: #eae8fd !important;
    color: #7367f0 !important;
    padding: 10px !important;
    border-radius: 8px;
}

.btn-success {
    background: var(--skinColor) !important;
    border-color: var(--skinColor) !important;
}

.card-label {
    background: var(--skinColor);
    width: auto !important;
    display: inline-block;
    position: absolute;
    color: #fff;
    padding: 5px 10px;
    font-size: 11px;
    border-radius: 0 0 8px 0;
}

.bg-success {
    background: var(--primary-color) !important;
    border-color: var(--primary-color);
}

.course-bar {
    border: 1px solid var(--primary-color);
    border-radius: 99px;
    overflow: hidden;
}

.course-bar .progress {
    background: var(--primary-color) !important;
}

.question {
    margin-bottom: 20px;
}

.stars i {
    font-size: 25px;
    color: #ccc;
    cursor: pointer;
    margin-right: 5px;
    transition: color 0.2s;
}

.stars i.active,
.stars i.hover {
    color: #f5b301;
}

.light-style .flatpickr-calendar.open {
    z-index: 99999999999999 !important;
}

.file-row {
    display: flex;
    gap: 7px;
    align-items: center;
}

.inp-path {
    flex: 1;
    min-width: 0;
    background: var(--primary-color) 26 !important;
    border: 1px solid var(--primary-color2);
    padding: 8px 11px;
    font-family: 'Inter', sans-serif;
    font-size: .82rem;
    color: var(--primary-color2);
    outline: none;
    cursor: default;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border-radius: 4px;
    transition: border-color .2s, color .2s, background .2s;
}

.inp-path.filled {
    color: var(--green);
    border-color: #b2f0dc;
    background: var(--green-lt);
    font-weight: 500;
}

/* browse button */
.btn-browse {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 38px;
    line-height: 38px;
    padding: 8px 14px;
    background: var(--primary-color2);
    color: #fff;
    border: none;
    font-family: 'Inter', sans-serif;
    font-size: .78rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    border-radius: 4px;
    transition: background .2s, transform .15s, box-shadow .2s;
    box-shadow: 0 2px 8px var(--accent-glow);
}

.btn-browse:hover {
    background: #5036d5;
    transform: translateY(-1px);
    box-shadow: 0 4px 14px var(--accent-glow);
}

.btn-browse:active {
    transform: translateY(0);
}

.btn-browse svg {
    width: 13px;
    height: 13px;
}

/* clear button */
.btn-clear {
    border-radius: 4px;
    display: none;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    flex-shrink: 0;
    background: var(--red-lt);
    border: 1.5px solid #fecaca;
    color: var(--red);
    cursor: pointer;
    transition: background .2s;
}

.btn-clear.show {
    display: inline-flex;
}

.btn-clear:hover {
    background: #fee2e2;
}

.btn-clear svg {
    width: 11px;
    height: 11px;
}

.section-title {
    font-size: 16px;
    font-weight: bold;
    color: var(--primary-color2);
    border-left: 4px solid var(--primary-color2);
    padding-left: 10px;
    margin: 0px 0 15px 0;
}

.hero-card {
    background: var(--primary-gradient);
    color: white;
    border-radius: 24px;
    padding: 30px;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-shadow: 0 15px 30px rgba(0, 166, 81, 0.2);
    height: 100%;
}

.hero-card h1 {
    font-size: 64px;
    font-weight: 900;
    line-height: 1;
    margin-bottom: 5px;
    color: #fff;
}

.hero-card p {
    font-size: 12px;
    font-weight: 700;
    opacity: 0.8;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.analysis-card {
    background: #fff;
    border-radius: 24px;
    padding: 25px;
    display: flex;
    align-items: center;
    gap: 30px;
    box-shadow: var(--card-shadow);
}

/* Radar Chart Lục Giác Chuẩn 6 Cạnh */
.radar-box {
    position: relative;
    width: 180px;
    height: 180px;
    flex-shrink: 0;
}

.radar-svg {
    width: 100%;
    height: 100%;
}

.radar-label {
    position: absolute;
    font-size: 8px;
    font-weight: 800;
    color: var(--primary-color2);
    background: #f0fdf4;
    padding: 2px 5px;
    border-radius: 4px;
    white-space: nowrap;
}

.metrics-grid {
    flex: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 30px;
}

.m-item {
}

.m-head {
    display: flex;
    justify-content: space-between;
    font-size: 10px;
    font-weight: 700;
    color: #000;
    margin-bottom: 4px;
    text-transform: uppercase;
}

.m-bar {
    height: 6px;
    background: #f1f5f9;
    border-radius: 10px;
    overflow: hidden;
}

.m-fill {
    height: 100%;
    background: var(--primary-color2);
    border-radius: 10px;
}

.review-list .card {
    background: #fff;
    border-radius: 16px;
    padding: 20px;
    margin-bottom: 15px;
    box-shadow: var(--card-shadow);
    border: 1px solid #f1f5f9;
    transition: 0.3s;
}

.review-list .card:hover {
    transform: translateX(5px);
    border-color: var(--primary-color2);
}

.review-list .card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 12px;
    padding: 0 0 15px 0 !important;
}

.review-list .st-name {
    font-size: 16px;
    font-weight: 700;
    color: #0f172a;
}

.review-list .st-meta {
    font-size: 12px;
    color: #000;
    margin-top: 2px;
}

.review-list .st-total {
    background: #f0fdf4;
    color: var(--primary-color2);
    padding: 4px 12px;
    border-radius: 8px;
    font-weight: 800;
    font-size: 16px;
}

.review-list .rating-row {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
    background: #f8fafc;
    padding: 10px;
    border-radius: 12px;
    margin-bottom: 12px;
}

.review-list .r-box {
    text-align: center;
}

.review-list .r-box label {
    display: block;
    font-size: 7.5px;
    font-weight: 800;
    color: #94a3b8;
    text-transform: uppercase;
    margin-bottom: 2px;
    line-height: 1.2;
    height: 18px;
}

.review-list .r-box span {
    font-size: 14px;
    font-weight: 700;
    color: var(--primary-color2);
}

.review-list .comment {
    font-size: 14px;
    color: #475569;
    font-style: italic;
    line-height: 1.5;
    margin-bottom: 15px;
    padding-left: 15px;
    border-left: 2px solid #e2e8f0;
}

/* Mục Hỗ trợ thêm - Highlighted */
.review-list .support-line {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 12px;
    border-top: 1px dashed #e2e8f0;
}

.review-list .support-title {
    font-size: 11px;
    font-weight: 800;
    color: #000;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.review-list .tag-container {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.review-list .tag {
    background: #f1f5f9;
    color: #475569;
    font-size: 10.5px;
    font-weight: 700;
    padding: 3px 12px;
    border-radius: 20px;
    border: 1.5px solid #e2e8f0;
    transition: 0.2s;
}

.review-list .tag:hover {
    border-color: var(--primary-color2);
    background: #f0fdf4;
    color: var(--primary-color2);
}

@media only screen and (max-width: 768px) {
    .analysis-card {
        flex-flow: column;
    }

    .metrics-grid {
        grid-template-columns: 1fr;
        gap: 12px 30px;
        width: 100%;
    }

    .analysis-card {
        margin-top: 30px;
    }
}

.dashboard-item {
    height: 100%;
}

.card-bo {
    border-radius: 28px !important;
    --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.timeline-line::before {
    content: '';
    position: absolute;
    left: 20px;
    top: 10px;
    bottom: 10px;
    width: 1px;
    border-left: 1px dashed #cbd5e1;
    z-index: 0;
}

.active-tab {
    background-color: #10b981;
    color: white !important;
}

/* Animation cho thanh tiến độ */
.progress-fill {
    animation: progressLoad 1.5s ease-out forwards;
}

.form-search-class .select2-container--default .select2-selection--single {
    height: 48px;
    background-color: #f8fafc; /* slate-50 */
    border: none;
    border-radius: 0.75rem; /* rounded-xl */
    padding: 0 1rem 0 1rem;
    display: flex;
    align-items: center;
}

.form-search-class .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 48px;
    font-size: 0.875rem;
    font-weight: 500;
    color: #1e293b;
    padding: 0;
}

.form-search-class .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 48px;
    right: 12px;
}

.form-search-class .select2-container--default.select2-container--focus .select2-selection--single {
    outline: none;
    box-shadow: 0 0 0 2px rgb(16 185 129 / 0.2); /* emerald-500/20 */
}

.form-search-class .select2-container {
    width: 100% !important;
}

.card-tawin {
    border-radius: 28px !important;
    padding: 22px !important;
}

.card {
    border-radius: 28px !important;
    padding: 12px !important;
    border: 1px solid #dbdfea;
}

.height-100 {
    height: 100px;
}

.tab-active {
    background: white;
    color: #1f2937 !important;
    font-weight: 900 !important;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.10);
}

.progress-container {
    height: 6px;
    background: #f3f4f6;
    border-radius: 9999px;
    overflow: hidden;
}

.tag-method {
    font-size: 9px;
    padding: 2px 8px;
    border-radius: 6px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.tag-method.offline {
    background: #f3f4f6;
    color: #6b7280;
    border: 1px solid #e5e7eb;
}

.tag-method.online {
    background: #eff6ff;
    color: #3b82f6;
    border: 1px solid #bfdbfe;
}

.tag-method.status-ongoing {
    background: #f0fdf4;
    color: #16a34a;
    border: 1px solid #bbf7d0;
}

.tag-method.status-completed {
    background: #faf5ff;
    color: #9333ea;
    border: 1px solid #e9d5ff;
}

/* Animation ẩn/hiện item */
.group-item {
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.group-item.hidden-item {
    display: none;
}

/* Stats Cards */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

.stat-card {
    background: white;
    padding: 20px;
    border-radius: 20px;
    box-shadow: var(--shadow);
}

.stat-card p {
    font-size: 11px;
    color: var(--text-muted);
    margin: 0;
    text-transform: uppercase;
    font-weight: 600;
}

.stat-card h3 {
    font-size: 24px;
    margin: 8px 0 0;
    font-weight: 700;
    color: #222 !important;
}

.btn {
    border-radius: 8px !important;
    font-size: 14px;
}

.form-control, .dual-listbox .dual-listbox__search, div.dt-container div.dt-search input, div.dataTables_wrapper div.dataTables_filter input, .select2-container--default .select2-selection--single {
    border-radius: 8px !important;
}

.input-group .form-control {
    border-radius: 8px 0 0 8px !important;
}

.nk-sidebar .nk-menu > li .nk-menu-sub .nk-menu-link {
    padding-left: 32px;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
}

.nk-sidebar .nk-menu > li .nk-menu-sub .nk-menu-sub .nk-menu-link:hover {
    color: var(--primary-color) !important;
    background: transparent !important;
    box-shadow: unset !important;
}

.has-sub.active > .nk-menu-toggle:after {
    color: #fff !important;
}

li.nk-menu-item.active.current-page ul.nk-menu-sub li a:after {
    color: var(--grayColor) !important;
}

li.nk-menu-item.active.current-page ul.nk-menu-sub li.active.current-page .nk-menu-sub li a {
    color: #222 !important;
}

li.nk-menu-item.active.current-page ul.nk-menu-sub li.active.current-page .nk-menu-sub li.active.current-page a {
    color: var(--primary-color) !important;
}

/*PTE*/
.button_style {
    background-color: var(--primary-color);
    color: #fff !important;
    text-align: center;
    padding: 0 30px;
    font-size: 15px;
    display: inline-block;
    position: relative;
    overflow: hidden;
    z-index: 9;
    border-radius: 5px;
    height: 40px;
    line-height: 40px;
}

.button_style:before {
    position: absolute;
    top: 0;
    left: -75%;
    z-index: 2;
    display: block;
    content: '';
    width: 50%;
    height: 100%;
    background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), to(rgba(255, 255, 255, 0.3)));
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
    -webkit-transform: skewX(-25deg);
    transform: skewX(-25deg);
}

.button_style:hover:before {
    -webkit-animation: shine .75s;
    animation: shine .75s;
}

@-webkit-keyframes shine {
    100% {
        left: 125%;
    }
}

@keyframes shine {
    100% {
        left: 125%;
    }
}

/**header**/
#header {
    width: 100%;
    box-shadow: 0px 0 18px rgba(55, 66, 59, .08);
    background: var(--primary-white);
    padding: 8px 0;
}

#header .logo img {
    height: 60px;
}

#header .header-right {
    display: flex;
    justify-content: end;
    align-items: center;
}

#header .header-menu ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    padding: 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0;
}

#header .header-menu ul li {
    list-style: none;
    position: relative;
}

#header .header-menu ul li a {
    font-size: 16px;
    color: #000000;
    text-transform: uppercase;
    font-weight: 700;
    padding: 0 15px;
    display: block;
}

#header .header-menu ul li a:hover, #header .header-menu ul li a.active {
    background: rgba(255, 255, 255, 0.4);
}

#header .header-menu ul li .sub-menu {
    position: absolute;
    top: 45px;
    left: 0;
    background: #fff;
    height: auto !important;
    border-radius: 0 0 4px 4px;
    -webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    -webkit-transition: 0.4s;
    transition: 0.4s;
    width: 250px;
    z-index: 9999;
}

#header .header-menu ul li .sub-menu li a {
    color: #000;
}

#header .header-menu ul li:hover > .sub-menu {
    display: block;
}

#header .header-menu ul li .sub-menu > li {
    height: unset !important;
    display: inline-block;
    width: 100%;
}

#header .header-menu ul li .sub-menu > li a {
    font-size: 15px !important;
}

/**user**/
.wp_user_login ul {
    display: flex;
    align-items: center;
}

.wp_user_login ul li {
    list-style: none;
    position: relative;
    display: flex;
    align-items: center;
}

.wp_user_login ul li.user__login a {
    display: flex !important;
    align-items: center;
    flex-flow: wrap !important;
    color: #fff
}

.wp_user_login ul li.user__login .user_avatar {
    width: 40px;
    height: 40px;
    border-radius: 99px;
}

.wp_user_login ul li.user__login .user_avatar img {
    width: 100%;
    height: 100%;
    border-radius: 99px;
    object-fit: cover;
    object-position: top;
}

.wp_user_login ul li.user__login .user_name {
    color: #232323;
    margin: 0 6.5px;
    font-weight: 700;
    font-size: 18px;
    line-height: 20px;
}

.wp_user_login ul li a.btnMenuBox {
    margin: 0 6.5px;
    width: 28px;
    height: 28px;
    background: #e5e5e5;
    border-radius: 99px;
    position: relative;
    display: block;
}

.wp_user_login ul li a.btn_Dropdown img,
.wp_user_login ul li a.btn_Bar img {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 16px !important;
    height: auto !important;
}

.wp_user_login ul li a.btn_Dropdown img {
    width: 12px !important;
}

.wp_user_login ul li.user__login a {
    display: flex !important;
    align-items: center;
    flex-flow: wrap !important;
}

.wp_user_login ul li.user__login .user_avatar {
    width: 40px;
    height: 40px;
    border-radius: 99px;
}

.wp_user_login ul li.user__login .user_avatar img {
    width: 100%;
    height: 100%;
    border-radius: 99px;
    object-fit: cover;
    object-position: top;
}

.wp_user_login ul li.user__login .user_name {
    color: #232323;
    margin: 0 6.5px;
    font-weight: 700;
    font-size: 18px;
    line-height: 20px;
}

.boxAccount {
    font-weight: 600;
    font-size: 13px;
    line-height: 16px;
    padding: 9.5px 8px;
    border: 1px solid var(--primary-color);
    border-radius: 5px;
    text-decoration: none;
    white-space: nowrap;
    color: var(--primary-color) !important;
    transition: ease-in-out .3s;
    margin-left: 2px;
}

.btn_register {
    background-color: var(--primary-color);
    color: #fff !important;
    margin-right: 8px;
    margin-left: 5px;
}

/**slide**/
body .swiper-button-next, body .swiper-button-prev {
    display: none;
    font-size: 50px;
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background-color: #ac161891;
    color: #000;
    -webkit-transition-property: all;
    transition-property: all;
    -webkit-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    -webkit-transition-duration: 150ms;
    transition-duration: 150ms;
}

body .swiper-button-next:hover, body .swiper-button-prev:hover {
    --tw-bg-opacity: 0.6;
}

body .swiper-button-next::after, body .swiper-button-prev::after {
    font-size: 1rem;
    line-height: 1.5rem;
}

body .swiper-button-prev {
    left: 30px !important;
}

body .swiper-button-next {
    right: 30px !important;
}

.swiper-button-next:after, .swiper-button-prev:after {
    display: none;
}

body .swiper-button-next i, body .swiper-button-prev i {
    color: inherit;
    display: inline-flex;
    place-content: center;
    place-items: center;
    font-size: inherit;
    height: 100%;
    margin: 0;
    padding: 5px;
    position: relative;
    width: 100%;
    z-index: 0;
    -webkit-transition: inherit;
    transition: inherit;
}

body .swiper-button-prev span, body .swiper-button-next span {
    display: flex;
    align-items: center;
}

body .swiper-button-next i svg, body .swiper-button-prev i svg {
    fill: #fff;
}

.swiper-customer .swiper-button-prev {
    display: none;
}

.swiper-customer .swiper-button-next {
    display: none;
}

svg {
    height: 1em;
    width: 1em;
}

/**section2**/
section.sec-2 {
    padding: 100px;
}

/***read aloud***/
#record-btn {
    border: 1px solid;
    color: var(--primary-blue);
}

#record-btn:hover {
    background: var(--primary-blue);
    color: var(--primary-white);
}

#speak-btn {
    border: 1px solid;
    color: var(--primary-blue);
    float: right;
}

#speak-btn:hover {
    background: var(--primary-blue);
    color: var(--primary-white);
}

.read-aloud-content {
    padding: 15px;
    border: 1px solid var(--primary-white);
    margin: 20px 0;
    background-color: rgba(0, 0, 0, 0.05);
}

/***repeat sentence***/
#txtAnswer {
    margin-bottom: 20px;
}

.form-select {
    margin-bottom: 20px;
}

/**tts**/
.bg-light {
    padding: 15px;
}

.body-tts {
    border: 1px dotted #ddd;
    padding: 20px;
    margin-top: 30px;
}

/***fill-in-blank***/
.item-drag {
    padding: 4px 25px;
    border: 1px solid;
    margin: 10px;
}

.mt-5.bottom-drag-container.drop-zone {
    padding: 10px;
    background-color: #d1ecf1;
    display: flex;
    flex-wrap: wrap;
}

/***mcma***/
.start-practice {
    padding: 20px 10px;
    background: rgb(248 249 250);
}

.audio-player {
    border: 1px solid #ddd;
    padding: 10px;
    width: 300px;
}


/***swt***/

/*.form-control {*/
/*    margin-bottom: 20px*/
/*}*/

/***practice***/
.practice-menu a {
    color: var(--primary-black);
    font-weight: normal;
}

.title-practice {
    margin-bottom: 25px;
}


/***forgot***/
/**login**/
.form-login h1 {
    text-align: center;
    font-size: 30px;
    color: #333;
    margin: 0 0 30px 0;
}

.login-form .login-bg {
    background: #fbe9e7;
    padding: 40px;
    border-radius: 10px 0 0 10px;
    display: flex;
    justify-content: center;
    flex-direction: column;
    height: 100%;
}

.login-form .login-bg img {
    margin: 0 auto;
    height: 100%;
    max-width: 100%;
    object-fit: contain;
}

.login-form .form {
    padding: 20px 100px;
    background: #fff;
    border-radius: 0 10px 10px 0;
    height: 100%;
}

.login-form .form .form-group {
    position: relative;
}

.form-position {
    position: relative;
}

.login-form .form h1 {
    font-size: 25px;
    margin: 0 0 20px 0;
}

.login-form .form .external {
    display: flex;
    align-items: center;
    flex-flow: wrap;
}

.login-form .form .external button {
    margin-right: 20px;
    border: 0;
    color: #fff;
    font-weight: bold;
    border-radius: 4px;
    flex-grow: 1;
}

.login-form .form .external button {
    justify-content: flex-start;
    display: flex;
    line-height: 38px;
    padding: 3px;
}

.login-form .form .external .btn-facebook {
    background: #4267b2;
}

.login-form .form .external button:last-child {
    margin-right: 0;
}

.login-form .form .external .btn-google {
    background: #4385f5;
}

.login-form .form .external button:hover {
    background: transparent linear-gradient(180deg, #4385f5 0%, #4267b2 100%) 0% 0% no-repeat padding-box;
}

.login-form .form .external button:hover {
    background: transparent linear-gradient(180deg, #4385f5 0%, #4267b2 100%) 0% 0% no-repeat padding-box;
}

.login-form .form .external button img {
    margin-right: 8px;
}

.login-form .split {
    border-bottom: 2px solid #afafaf;
    position: relative;
    height: 23px;
    margin: 20px 0 20px 0;
    justify-content: center;
    display: flex;
}

.login-form .split p {
    position: absolute;
    background: #fff;
    padding: 0 10px;
    color: #afafaf;
    font-size: 14px;
    margin: 0px !important;
    font-weight: bold;
    top: 10px;
}

.errors.just-center.text-red {
    text-align: center;
    font-size: 14px;
}

.text-red {
    color: #fd475a;
}

.login-form .form form {
    margin: 20px 0 0 0;
}

.login-form .form label {
    font-weight: 700;
    font-size: 15px;
    margin: 0 0 10px 0;
}

.login-form .form label b {
    color: #000;
}

.form-group .input_user, .form-group .select_user {
    background-color: #fff;
    border-radius: 4px !important;
    width: 100%;
    padding: 8px 20px 8px 10px !important;
    font-size: 14px !important;
    color: #111 !important;
    font-weight: 500;
    border: 1px solid #adadad;
    margin: 0;
}

.checkbox-ctn {
    display: block;
    position: relative;
    padding-left: 35px;
    margin-bottom: 12px;
    cursor: pointer;
    font-size: 15px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.checkbox-ctn input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.login-form .form .row input {
    background: #fff;
    border-radius: 4px !important;
    width: 100%;
    padding: 8px 20px 8px 10px !important;
    font-size: 14px !important;
    color: #111 !important;
    font-weight: 500;
    border: 1px solid #adadad;
}

.checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 25px;
    width: 25px;
    background-color: #eee;
}

.checkbox-ctn input:checked ~ .checkmark {
    background-color: var(--primary-color);
}

.checkbox-ctn input:checked ~ .checkmark:after {
    display: block;
}

.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

.checkbox-ctn {
    font-weight: normal !important;
}

.checkbox-ctn .checkmark:after {
    left: 9px;
    top: 5px;
    width: 5px;
    height: 10px;
    border: solid #fff;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.checkbox-ctn input:checked ~ .checkmark:after {
    display: block;
}

.login-form .form .button-group {
    display: flex;
    justify-content: space-around;
}


.login-form .form .button-group button, .login-form .form .button-group .btn {
    margin: 0 20px;
    border: 0;
    font-weight: bold;
    border-radius: 8px !important;
    flex-grow: 1;
    display: block;
    padding: 10px;
    text-align: center;
    text-transform: uppercase;
    border: 2px solid var(--primary-color);
    color: #222;
    font-size: 14px;
    text-decoration: none !important
}

.login-form .form .button-group .btn-submit {
    background: var(--primary-color);
    box-shadow: 0 4px 6px #00000029;
    border-radius: 3px;
    color: #fff;
    border: none;
    padding: 12px;
}

.login-form .form .button-group button:first-child {
    margin-left: 0;
}

.login-form .form .btn-link {
    margin-right: 0px !important;
}

.login-form .form .forgotpass {
    text-align: right;
    font-weight: bold;
}

.login-form .form .forgotpass a {
    color: #222;
    font-size: 14px;
}

.login-form .form .forgotpass a:hover {
    color: var(--color-red)
}

.radius-50 {
    border-radius: 50px !important;
}

.form-register label {
    margin: 0px !important;
}

.form-register .controls {
    display: flex;
    flex-basis: 100%;
    flex-grow: 3;
}

.radio-ctn {
    display: block;
    position: relative;
    padding-left: 35px;
    margin-bottom: 12px;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.form-register .controls .radio-ctn {
    margin-right: 30px;
    margin-top: 5px;
}

.radio-ctn input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

.radio-ctn .checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 20px;
    width: 20px;
    background-color: #fff;
    border-radius: 50%;
    border: 2px solid #aaa;
}

.radio-ctn .checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

.radio-ctn .checkmark:after {
    top: 1.3px;
    left: 1.3px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--primary-color);
}

.radio-ctn input:checked ~ .checkmark:after {
    display: block;
}

.form-register .controls .radio-ctn span strong {
    display: block;
    margin-top: -3px;
    color: #858585;
    font-style: italic;
    margin-right: 40px;
}

.form-register .select_address {
    background-color: #fff !important;
    border-radius: 4px !important;
    width: 100% !important;
    padding: 8px 20px 8px 10px !important;
    font-size: 14px !important;
    color: #111 !important;
    font-weight: 500 !important;
    border: 1px solid #adadad !important;
}

.form-register .item__description {
    font-size: 13px;
    font-style: italic;
    margin: 10px 0 0 0;
    color: #afafaf;
}

/**images**/
.blur-up {
    -webkit-filter: blur(5px);
    filter: blur(5px);
    transition: filter 400ms, -webkit-filter 400ms;
}

.blur-up.lazyloaded {
    -webkit-filter: blur(0);
    filter: blur(0);
}

.is-invalid {
    border-color: #dc3545 !important;
}

img.account-image {
    width: 30px;
    border-radius: 50%;
    object-fit: cover;
}

.toggle-password {
    position: absolute;
    top: 8px;
    right: 8px;
    cursor: pointer;
}

/***---footer---***/
#footer {
    background: #AF1313;
    padding: 40px 0 20px 0;
    font-size: 15px;
}

#footer .footer-top {
    width: 100%;
}

#footer .footer-address p {
    color: #fff;
    margin: 0 0 10px 0;
}

#footer a {
    color: #ffff00
}

#footer .footer-logo {
    margin-bottom: 20px;
}

#footer .footer-logo img {
    width: 200px;
}

#footer .footer-top .footer-link ul li a i {
    color: #fff;
}

#footer .footer-top .footer-link ul li a {
    color: #fff;
    font-size: 15px;
}

#footer .footer-top .footer-title {
    margin: 0 0 20px 0;
}

#footer .footer-top .footer-title h3 {
    font-size: 20px;
    text-transform: uppercase;
    color: #fff;
    margin: 0;
}

.footer-bottom .footer-bottom-icon {
    text-align: right;
}

.footer-bottom .footer-bottom-icon a {
    margin-left: 10px !important;
    font-size: 20px;
}

.footer-bottom .footer-bottom-icon i {
    color: #fff;
}

.footer-bottom {
    background: #AF1313;
    padding: 10px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    color: #fff;
    font-size: 15px;
    text-align: center;
}

.category-entry {
    margin: 40px 0;
}

/**learn**/
.nmheader {
    background: #047099;
    color: #fff;
    width: 100%;
    padding: 5px 10px;
    left: 0;
    top: 0px;
    font-size: 13px;
    z-index: 10000;
    display: flex;
    vertical-align: middle;
    align-items: center;
}

.nmheader .secinfo img {
    width: 30px;
    border-radius: 50%;
    height: 30px;
    margin-right: 10px;
}

.nmheader .secinfo {
    display: flex !important;
    vertical-align: middle;
    align-items: center;
    font-weight: bold;
    font-size: 16px;
}

.nmheader div {
    width: 33%;
    display: inline-block;
    margin-top: 0px;
}

p#nmtime {
    display: inline-block;
    padding: 0 5px;
    border-radius: 3px;
    color: #ffffff;
    font-size: 18px;
    font-weight: 700;
    margin: 0;
}

p#nmtime span {
    background: #fff;
    padding: 6px 2px;
    color: #000;
}

p#nmtime .timeitem {
    background: #ff5722;
    margin: 0px 2px;
    border-radius: 5px;
    color: #fff;
    padding: 6px 8px;
}

.anPart {
    display: none;
}

.nmheader div:nth-child(2) {
    text-align: center;
}

.nmheader div:nth-child(3) {
    text-align: right;
}

h2.nmtitle {
    margin-top: 40px;
    text-align: center;
}

a#btnsend {
    background: #f00;
    color: #fff;
}

.nmnut {
    padding: 5px;
    margin: 0 5px;
    color: #fff;
    font-size: 13px;
    border-radius: 2px;
    cursor: pointer;
    display: inline-block;
    width: 100px;
    text-align: center;
}

.socau {
    margin-right: 100px;
    background: #0a0a0a78;
    padding: 10px;
    font-weight: bold;
}


/**control**/
.controls {
    display: flex;
    flex-flow: wrap;
    align-items: center;
}

.controls button {
    height: 2rem;
    width: 120px;
    border: none;
    border-radius: 0.15rem;
    background: #ed341d;
    margin-left: 2px;
    box-shadow: inset 0 -0.15rem 0 rgba(0, 0, 0, 0.2);
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #ffffff;
    font-weight: bold;
    font-size: 14px;
}

.controls button:hover, .controls button:focus {
    outline: none;
    background: #c72d1c;
}

.controls button::-moz-focus-inner {
    border: 0;
}

.controls button:active {
    box-shadow: inset 0 1px 0 rgba(0, 0, 0, 0.2);
    line-height: 3rem;
}

.controls button:disabled {
    pointer-events: none;
    background: lightgray;
}

.controls button:first-child {
    margin-left: 0;
}

.controls_list audio {
    display: block;
    width: 100%;
    margin-top: 0.2rem;
}

.controls_list li {
    list-style: none;
    margin-bottom: 1rem;
}

.controls_list #formats {
    margin-top: 0.5rem;
    font-size: 80%;
}

.controls_list ol audio {
    margin: 0 0 10px 0;
}

.controls_list ol li {
    font-size: 15px;
    margin: 10px 0 0 !important;
}

.controls_list ol li a {
    color: #ed341d;
    margin-left: 10px !important;
}

#recordingsList {
    max-width: 28em;
    padding: 0 !important;
}

div#wizard-validation {
    box-shadow: 0 0.25rem 1.125rem rgba(75, 70, 92, 0.1);
}

div#wizard-validation .bs-stepper-header {
    display: flex;
    justify-content: space-between;
}

.form-desc {
    font-size: 15px;
    line-height: 22px;
    background: #f2f2f2;
    padding: 15px;
    margin: 0 0 20px 0 !important;
    display: inline-block;
    width: 100%;
}

.active .bs-stepper-circle {
    background: var(--primary-color) !important;
}

.controls_list {
    max-width: 28em;
    font-size: 15px;
}

.controls_list ol {
    padding: 0;
}

.dstepper-block .form-control {
    margin: 0 0 10px 0;
}

.cauhoi {
    margin-top: 10px;
}

.cauhoi span label {
    margin-left: 10px !important;
}

.cauhoi span {
    width: 100%;
    display: flex;
    margin: 0 0 10px 0;
}

.cauhoi span input[type='radio'], .cauhoi span input[type='checkbox'] {
    outline: none !important
}

.cauhoi span input[type=radio] {
    border-radius: 50%;
}

.cauhoi span input[type=checkbox], .cauhoi span input[type=radio] {
    -webkit-appearance: none;
    -moz-appearance: none;
    position: relative;
    width: 20px;
    height: 20px;
    border: 3px solid #39414d;
    background: #fff;
}

.cauhoi label {
    width: calc(100% - 26px);
    font-size: 14px !important;
    color: #000;
}

@supports (-webkit-appearance: none) or (-moz-appearance: none) {
    .cauhoi span input[type=radio]:after {
        content: "";
        opacity: 0;
        display: block;
        left: 3px;
        top: 3px;
        position: absolute;
        width: 11px;
        height: 11px;
        border-radius: 50%;
        background: #28303d;
    }

    .cauhoi span input[type=checkbox]:after {
        content: "";
        opacity: 0;
        display: block;
        left: 3px;
        top: 3px;
        position: absolute;
        width: 11px;
        height: 11px;
        border-radius: 50%;
        background: #28303d;
    }
}

.cauhoi span input[type=radio]:after {
    left: 2px;
    top: 0px;
    border-radius: 0;
    background: none;
    border: solid #fff;
    width: 8px;
    height: 10px;
    border-width: 0 4px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.cauhoi span input[type=checkbox]:after {
    left: 2px;
    top: 0px;
    border-radius: 0;
    background: none;
    border: solid #fff;
    width: 8px;
    height: 10px;
    border-width: 0 4px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.cauhoi span input[type=radio]:checked {
    border: 4px solid #ed341d;
    background: #ed341d;
}

.cauhoi span input[type=checkbox]:checked {
    border: 4px solid #ed341d;
    background: transparent;
}

label.form-label {
    width: 100%;
}

span.d-flex.flex-question .form-control {
    display: inline-block;
    border-radius: 0px !important;
    margin: 0 5px !important;
}

@supports (-webkit-appearance: none) or (-moz-appearance: none) {
    .cauhoi span input[type=radio]:checked:after {
        opacity: 1;
    }

    .cauhoi span input[type=checkbox]:checked:after {
        opacity: 1;
        border-color: #ed341d;
    }
}

h3.f-header {
    background: var(--primary-color) !important;
    border-radius: 5px !important;
    padding: 10px;
    color: #fff;
    font-size: 20px;
    line-height: 22px;
    margin: 0 0 15px 0;
}

.input_text {
    border-radius: 0px !important;
}

.form-desc img {
    height: auto !important;
}

.dstepper-block button.btn {
    display: flex;
}

h2#swal2-title {
    width: 100%;
    max-width: 100% !important;
    padding-top: 0 !important;
}

div#swal2-html-container {
    margin-top: 0 !important;
}

.form-group {
    margin-bottom: 10px;
}

.input-group > .input-group-append > .btn, .input-group > .input-group-append > .input-group-text, .input-group > .input-group-prepend:not(:first-child) > .btn, .input-group > .input-group-prepend:not(:first-child) > .input-group-text, .input-group > .input-group-prepend:first-child > .btn:not(:first-child), .input-group > .input-group-prepend:first-child > .input-group-text:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.input-group > .input-group-prepend > .btn, .input-group > .input-group-prepend > .input-group-text, .input-group:not(.has-validation) > .input-group-append:not(:last-child) > .btn, .input-group:not(.has-validation) > .input-group-append:not(:last-child) > .input-group-text, .input-group.has-validation > .input-group-append:nth-last-child(n + 3) > .btn, .input-group.has-validation > .input-group-append:nth-last-child(n + 3) > .input-group-text, .input-group > .input-group-append:last-child > .btn:not(:last-child):not(.dropdown-toggle), .input-group > .input-group-append:last-child > .input-group-text:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.quiz-question-search label {
    display: inline-block;
    margin-bottom: 0.5rem;
}

.main {
    border: 1px dotted #ddd;
}

.answer-drop, .item-drag {
    text-align: center;
    display: inline-block;
    border: 1px solid #444;
    height: 30px;
}

.answer-drop {
    min-width: 140px;
    margin-bottom: -5px;
}

.answer-drop.input-incorrect {
    border-color: #ed3c0d;
}

.item-drag {
    margin: 5px;
    min-width: 120px;
}

.bottom-drag-container .item-drag {
    line-height: 30px;
    padding-top: 0;
}

.answer-drop .item-drag {
    border: none !important;
    margin: 0;
    padding-top: 0;
}

input.form-control-inline {
    height: 35px;
}

#hiw.show .answer {
    color: #ffb74d;
}

select#selectVoices {
    width: 100%;
}

.hidden {
    display: none;
}

.header-mobile .header-right {
    width: 100%;
}

.header-mobile .header-right ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.header-mobile .header-right ul li {
    list-style: none;
    margin-left: 20px;
}

.header-mobile .header-right ul li a img {
    width: 25px;
}

.header-mobile .header-right ul li a span {
    background: var(--color-red);
    position: absolute;
    color: #fff;
    width: 16px;
    border-radius: 50%;
    font-size: 13px;
    height: 16px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    top: -6px;
    right: -5px;
}

.header-mobile .header-right ul li .cart,
.header-mobile .header-right ul li .like {
    position: relative;
}

.header-mobile .header-right ul li a {
    color: #000;
    font-size: 25px;
}

/**mobile menu**/
#nav-mobile {
    display: none;
}

#nav-mobile .nav-mobile {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 99999999;
}

#nav-mobile .nav-mobile_bg {
    background: rgba(0, 0, 0, 0.7);
    cursor: pointer;
    height: 100%;
    width: 100%;
}

#nav-mobile .nav-mobile_main {
    background: #fff;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 300px;
    flex: 0 0 300px;
    padding: 15px;
}

#nav-mobile .custom-scrollBar_y {
    overflow-y: scroll;
    width: 100%;
}

#nav-mobile .nav-mobile_main__exit {
    color: #678;
    cursor: pointer;
    font-size: 16px;
    padding: 10px 15px;
    position: fixed;
    right: 0;
    text-shadow: 1px 1px 1px #e9ecef;
    top: 0;
}

#nav-mobile .nav-mobile_main > ul {
    margin-left: 0;
    padding-left: 0;
    margin-top: 15px;
}

#nav-mobile .nav-mobile_main > ul li {
    list-style: none;
}

#nav-mobile .nav-mobile_main > ul li ul {
    margin-left: 0px !important;
}

#nav-mobile .nav-mobile_main > ul > li {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    font-size: 15.5px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

#nav-mobile .nav-mobile_main > ul > li:not(:last-child) {
    border-bottom: 1px solid #e9ecef;
}

#nav-mobile .nav-mobile_main > ul > li a, #nav-mobile .nav-mobile_main > ul > li .nav-mobile_main > ul li > div {
    color: #000 !important;
    display: block;
    padding: 10px 0;
    width: calc(100% - 40px);
}

#nav-mobile .nav-mobile_main > ul > li span {
    background: #f8f9fa;
    border-radius: 5px;
    height: 35px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    line-height: 35px;
    text-align: center;
    width: 35px;
}

#nav-mobile .nav-mobile_main > ul > li > ul {
    display: none;
    padding-left: 20px;
    width: 100%;
}

.box-stores {
    background: var(--primary-color);
    border-radius: 5px;
    max-width: 100%;
    color: #111;
    display: block;
    text-align: center;
    font-size: 15px;
    padding: 8px 0;
    font-weight: 700;
}

.dot-attribute:last-child {
    display: none !important;
}

.box-stores_text a {
    color: #111;
}

.header-search.search-mobile {
    margin: 15px 0 0 0;
}

.header-search input.input-s {
    width: 100%;
    border: 0px !important;
    height: 40px;
    font-size: 15px;
    border-radius: 8px;
    padding: 0 25px 0 35px;
}

.header-search button.btn-search {
    background: transparent;
    border: 0px !important;
    height: 40px;
    position: absolute;
    left: 5px;
    top: 0px;
}

.header-search.search-mobile input {
    background: var(--primary-color);
    border: 1px solid var(--primary-color);
}

/**banner**/
.banner_hero img {
    width: 100%;
}

.section {
    margin: 40px 0;
}

.abouts {
    width: 100%;
    height: 280px;
    box-shadow: 0px 0px 30px 0px #84848440;
    border-radius: 10px;
    position: relative;
}

.abouts img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
}

.abouts .abouts-content {
    width: 65%;
    height: 100%;
    position: absolute;
    top: 0px;
    z-index: 999;
    display: flex;
    align-items: center;
    padding: 25px;
}

.abouts .abouts-content p {
    color: #fff;
    font-size: 15px;
}

.abouts .abouts-content h4 {
    color: #fff !important;
    font-size: 35px;
    line-height: 42px;
}

.abouts .abouts-content a {
    margin-top: 15px;
}

.abouts .abouts-content .button_for_yellow {
    color: #000 !important;
    background: #FFC42C;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 15px;
    border-radius: 99px !important;
}

/**title**/
.home-title {
    text-align: center;
    margin: 0 0 20px 0;
}

.home-title h3 {
    text-transform: uppercase;
    font-size: 30px;
    line-height: 40px;
    margin: 0;
}

.over_hidden {
    overflow: hidden;
    padding: 0 20px;
    margin-left: -10px;
    margin-right: -10px;
}

.course-item {
    border-radius: 20px;
    background: #FAFAFA;
    box-shadow: 0px 7px 14px 0px rgba(0, 0, 0, 0.25);
    overflow: hidden;
    margin-bottom: 20px;
    padding: 10px;
}

.course-item .course-thumbnail {
    width: 100%;
    height: 350px;
    border-radius: 15px;
    position: relative;
}

.course-item .course-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 15px;
}

.course-item .course-content {
    width: 100%;
    padding: 15px 0 0 0;
}

.course-item .course-content h4 {
    margin: 0;
}

.course-item .course-content h4 a {
    color: #277FA3;
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    line-height: 30px;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.course-item .course-content .course-overview {
    width: 100%;
    font-size: 15px;
    margin: 10px 0;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    height: 45px;
}

.course-item .course-content .camket {
    width: 100%;
    background: #E92429;
    text-align: center;
    border-radius: 9px;
    color: #fff;
    font-weight: 700;
    padding: 8px 0;
    font-size: 18px;
    line-height: 26px;
}

section.footer__address {
    padding: 20px 0;
    box-shadow: 0px -3px 3px 0px rgba(0, 0, 0, 0.5);
}

section.footer__address .footer-logo {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}

section.footer__address .footer-logo img {
    max-width: 200px;
}

section.footer__address .footer-logo span {
    color: #E92429;
    margin: 0 10px;
    font-size: 28px;
}

section.footer__address .footer-logo h1 {
    font-size: 32px;
    font-weight: 600;
    color: #E92429;
    line-height: 38px;
    margin: 0;
}

section.footer__address .footer_top {
    font-size: 15px;
}

section.footer__address .footer_top h3 {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 15px 0;
}

section.footer__address .footer-menu ul {
    padding: 0;
}

section.footer__address .footer-menu ul li {
    list-style: none;
    margin: 0 0 5px 0 !important;
}

section.footer__address .footer-menu ul li a {
    font-size: 15px;
    color: #000;
    text-decoration: underline;
}

section.footer__address .footer-menu ul li a:hover {
    color: #E92429;
}

section.footer__address p {
    margin: 0 0 5px 0;
}

section.footer__address p i {
    color: #E92429;
}

.box-register {
    width: 100%;
    background: #E92429;
    border-radius: 20px;
    padding: 20px 20px 30px 50px;
}

.box-register h4 {
    margin: 0;
    color: #fff;
    font-size: 35px;
    line-height: 45px;
}

.input_register::placeholder {
    color: #fff;
}

.input_register {
    background: transparent !important;
    color: #fff;
    border: 1px solid #ffff;
    height: 45px;
}

button.button_style.button_for_white {
    background: #fff;
    width: 100%;
    height: 45px;
    border-color: #fff;
    border: 0;
    color: #E92429 !important;
    text-transform: uppercase;
    font-size: 20px;
    font-weight: 700;
}

.input-incorrect {
    border: 1px solid #ff3333 !important;
}

.success {
    border: 1px solid #198754 !important;
}

.chosen {
    background-color: #d1ecf1;
    padding: 2px 5px;
    border: 1px solid #ddd;
    border-radius: 5px;
}

#hiw.show .chosen.wrong {
    background-color: #008b00;
    color: #fff;
}

#hiw.show .chosen {
    background-color: #c62828;
    color: #fff;
}

button.swal2-cancel.btn.btn-label-danger {
    background: #ff3333;
    color: #fff;
}

#commentReview .card {
    background: #ffffff;
    border: 1px solid #e8e8e8;
    border-radius: 12px !important;
    padding: 1rem 1.25rem;
    margin-bottom: 10px;
    transition: border-color 0.15s, box-shadow 0.15s;
}

#commentReview .card:hover {
    border-color: #d0d0d0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.card-top {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.card-top .avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 600;
    flex-shrink: 0;
}

.av1 {
    background: #EEEDFE;
    color: #3C3489;
}

.av2 {
    background: #E1F5EE;
    color: #085041;
}

.av3 {
    background: #FAECE7;
    color: #712B13;
}

.av4 {
    background: #E6F1FB;
    color: #0C447C;
}

.av5 {
    background: #FAEEDA;
    color: #633806;
}

.av6 {
    background: #EAF3DE;
    color: #27500A;
}

.card-top .user-info {
    flex: 1;
    min-width: 0;
}

.card-top .username {
    font-size: 14px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-top.datetime {
    font-size: 12px;
    color: #aaa;
    margin-top: 1px;
}

#commentReview .comment-text {
    font-size: 14px;
    color: #333;
    line-height: 1.65;
    margin-bottom: 12px;
}

.nk-header.nk-header-fluid.is-theme a.nk-menu-link {
    box-shadow: unset !important;
}

.nk-menu > li.nk-menu-item {
    position: relative;
}

.nk-header.nk-header-fluid.is-theme .nk-menu .nk-menu-sub .nk-menu-text {
    color: #000 !important;
    font-size: 15px !important;
    font-weight: 700;
}

.modal-header-custom {
    background: #2d8a4e;
    border: none;
    padding: 1rem 1.25rem;
}

.modal-header-custom .modal-title {
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.5px;
}

.modal-header-custom .btn-close {
    filter: brightness(0) invert(1);
    opacity: 0.85;
}

.step-box-orange {
    border: 1.5px dashed #f0a030;
    border-radius: 8px;
    background: #fffbf2;
    padding: 0.85rem 1rem;
}

.step-box-green {
    border: 1.5px dashed #2d8a4e;
    border-radius: 8px;
    background: #f4fbf6;
    padding: 0.85rem 1rem;
}

.step-box-orange p,
.step-box-green p {
    font-size: 13px;
    color: #333;
    margin: 0;
    line-height: 1.6;
}

.btn-huong-dan {
    display: inline-block;
    background: #f0a030;
    color: #fff;
    font-weight: 600;
    font-size: 14px;
    padding: 0.6rem 1.5rem;
    border-radius: 8px;
    text-decoration: none;
    text-align: center;
    min-width: 240px;
    transition: background 0.2s;
}

.btn-huong-dan:hover {
    background: #d88c20;
    color: #fff;
}

.btn-vao-thi {
    background: #2d8a4e;
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 700;
    padding: 0.75rem;
    width: 100%;
    letter-spacing: 0.5px;
    transition: background 0.2s;
}

.btn-vao-thi:hover {
    background: #236b3d;
    color: #fff;
}

.note-text {
    font-size: 12px;
    color: #888;
    text-align: center;
    margin: 0;
}

.modal-content {
    border: none;
    border-radius: 12px;
    overflow: hidden;
}

.col-classroom, .col-teacher {
    width: 300px !important;
    min-width: 300px;
}

.controls_list {
    background: var(--primary-color);
    padding: 20px;
    margin: 0 0 20px 0;
    color: #fff;
}

.header-admin .user-toggle {
    gap: 10px;
    background: #f1f1f1;
    padding: 8px;
    border-radius: 5px;
}

.header-admin .nk-header-tools {
    padding-top: 5px;
    padding-bottom: 5px;
}

.edu-badge {
    padding: 5px 10px;
    border-radius: 6px;
    font-weight: bold;
    font-size: 12px;
    display: inline-block;
}

.edu-badge.bg-orange {
    background: #fff4e5 !important;
    color: #e67e22;
}

.edu-badge.bg-green {
    background: #e8f8f0 !important;
    color: #27ae60;
}

.count-circle {
    width: 30px;
    height: 30px;
    background: #f1f5f9;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    font-weight: 700;
    font-size: 12px;
    color: #4a5568;
}

.company-badge {
    font-size: 9px;
    padding: 2px 6px;
    border-radius: 4px;
    font-weight: 800;
    margin-left: 5px;
    text-transform: uppercase;
}

.edu {
    border: 1px solid #e67e22;
    color: #e67e22;
}

.pte {
    border: 1px solid #27ae60;
    color: #27ae60;
}

.name-tag {
    background-color: var(--tag-blue);
    color: white;
    padding: 5px 12px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 500;
    display: inline-block;
    white-space: nowrap;
}
.bg-purple {
    background: #f3e5f5 !important;
    color: #8e44ad !important;
}
