:root {
    --color-gray-600: #535862;
    --color-gray-300: #D5D7DA;
    --color-gray-700: #414651;
    --color-gray-900: #181D27;
    --color-gray-500: #717680;
    --color-main: #CD408E;
    --color-main-2: #3956A5;
    --color-error-600: #D92D20;
    --color-black: #000000;
    --color-error-50: #FEF3F2;
    --color-brand-50: #F9F5FF;
}

img.avatar.avatar-48.photo {
    border-radius: 99px;
    width: 40px;
}

.titan-user-dashboard {
    margin: 30px auto;
    background: rgb(231 231 231);
    border-radius: 12px;
    padding: 28px 24px 40px 24px;
    font-family: "Inter", sans-serif;
}

.display-name-h {
    font-size: 14px;
    font-weight: 600;
    font-family: "Inter", sans-serif;
    color: var(--color-gray-600);
}

.display-rannk-h {
    font-size: 14px;
    font-weight: 400;
    font-family: "Inter", sans-serif;
    color: var(--color-gray-600);
}

.titan-user-header {
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: 24px;
    margin-bottom: 32px;
    background: #fff;
    border-radius: 10px;
    padding: 24px 24px 16px 24px;
    flex-wrap: wrap;
}

.titan-user-header-left {
    flex: 2;
}

.titan-user-rank {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
    font-size: 18px;
    font-weight: 600;
    color: #868686;
}

.titan-rank-icon {
    width: 32px;
    height: 32px;
    background: url('https://cdn-icons-png.flaticon.com/512/992/992700.png') no-repeat center/cover;
    display: inline-block;
    margin-right: 8px;
}

.titan-user-welcome {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 12px;
    color: #2D2D2D;
}

.titan-rank-progress {
    margin-bottom: 12px;
}

.titan-rank-desc {
    font-size: 15px;
    color: #868686;
}

.titan-rank-next-point {
    color: #F13399;
    font-weight: 600;
}

.titan-rank-next {
    color: #F9A825;
    font-weight: 600;
}

.titan-progress-bar {
    display: flex;
    align-items: center;
    margin: 12px 0 8px 0;
}

.titan-progress-item {
    background: #eee;
    border-radius: 14px;
    padding: 6px 16px;
    min-width: 70px;
    text-align: center;
    font-size: 13px;
    color: #bbb;
    font-weight: 600;
    position: relative;
    z-index: 1;
}

.titan-progress-item.active,
.titan-progress-item.titan-rank-bac.active {
    color: #757575;
    background: #E8EBF3;
}

.titan-progress-item.titan-rank-titan.active {
    color: #5F6DF9;
}

.titan-progress-item.titan-rank-vang.active {
    color: #F9A825;
}

.titan-progress-item.titan-rank-bachkim.active {
    color: #868686;
}

.titan-progress-item.titan-rank-trieudiem.active {
    color: #F13399;
}

.titan-progress-separator {
    flex: 1;
    height: 2px;
    background: #e1e1e1;
    margin: 0 2px;
    border-radius: 1px;
}

.titan-rank-note {
    color: #868686;
    font-size: 13px;
    margin-bottom: 4px;
}

button.appt-btn-close-modal {
    padding: 0px 35px !important;
    display: block;
    width: 100%;
    border: 1px solid #D5D7DA;
    font-weight: 600;
    font-size: 16px;
    text-transform: none;
    max-width: 300px;
    margin: 0px auto;
    color: var(--color-gray-700);
}

.titan-user-benefit-btn {
    display: inline-block;
    background: #fff;
    border: 1px solid #F13399;
    color: #F13399;
    border-radius: 24px;
    padding: 8px 22px;
    font-weight: 600;
    font-size: 15px;
    text-decoration: none;
    margin-top: 8px;
    transition: all 0.2s;
}

.titan-user-benefit-btn:hover {
    background: #F13399;
    color: #fff;
}

.titan-user-header-right {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
}

.titan-user-point-box {
    background: #F6F7FF;
    border-radius: 10px;
    padding: 16px 20px;
    text-align: right;
    min-width: 180px;
}

.titan-user-point-label {
    color: #888;
    font-size: 13px;
}

.titan-user-point {
    font-size: 28px;
    font-weight: bold;
    color: #5F6DF9;
}

.titan-user-mcoin {
    color: #888;
    font-size: 14px;
}

.titan-user-exchange-btn {
    display: inline-block;
    background: #fff;
    border: 1px solid #5F6DF9;
    color: #5F6DF9;
    border-radius: 24px;
    padding: 5px 16px;
    font-size: 14px;
    margin-top: 6px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s;
}

.titan-user-exchange-btn:hover {
    background: #5F6DF9;
    color: #fff;
}

.titan-user-ref-btn {
    display: inline-block;
    margin-top: 12px;
    background: linear-gradient(90deg, #3956A5 0%, #CD408E 100%);
    color: #fff;
    border-radius: 8px;
    padding: 12px 40px;
    font-weight: 600;
    font-size: 16px;
    text-decoration: none;
    box-shadow: 0 2px 12px 0 #F1339912;
    transition: filter 0.2s;
}

.titan-user-ref-btn:hover {
    filter: brightness(1.1);
}

.titan-user-main {
    display: flex;
    gap: 28px;
}

.titan-user-sidebar {
    width: 280px;
}



.titan-logout-btn {
    display: block;
    background: none;
    border: none;
    color: #F13399;
    font-weight: 600;
    font-size: 15px;
    padding: 12px 10px 0 10px;
    text-align: left;
    cursor: pointer;
    text-decoration: none;
}

.titan-user-content {
    flex: 1;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 4px #00000006;
    padding: 26px 32px 34px 32px;
}

.titan-user-section {
    margin-bottom: 36px;
}

.titan-user-section h3 {
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 18px;
    color: #000;
    font-family: "Roboto", sans-serif;
}

.titan-user-info-form,
.titan-user-login-form {
    margin-bottom: 0;
}

.titan-form-row {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

.titan-form-group {
    flex: 1;
    min-width: 170px;
    display: flex;
    flex-direction: column;
}

.titan-form-wide {
    flex: 2;
    min-width: 320px;
}

.titan-form-group label {
    margin-bottom: 5px;
    color: var(--color-gray-700);
    font-size: 12px;
    font-weight: 400;
    font-family: "Inter", sans-serif;
}

.titan-form-group input,
.titan-form-group select {
    padding: 9px 12px !important;
    font-size: 15px !important;
    border: 1px solid #D6D5D5 !important;
    border-radius: 7px !important;

    color: #262626 !important;
    transition: border-color 0.2s !important;
    font-family: "Inter", sans-serif;
    box-shadow: unset !important;
}

.titan-form-group input:focus,
.titan-form-group select:focus {
    border-color: #5F6DF9;
    background: #fff;
    outline: none;
}

.required {
    color: #F13399;
}

.titan-btn {
    background: linear-gradient(90deg, #5F6DF9 0%, #F13399 100%);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 12px 36px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    margin-top: 18px;
    transition: filter 0.18s;
    box-shadow: 0 1px 6px 0 #F1339924;
}

.titan-btn:hover {
    filter: brightness(1.08);
}

.titan-user-header-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 18px;
    margin-top: 6px;
}

.titan-user-point-top {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 15px;
    color: #888;
}

.titan-user-point-highlight {
    color: #F13399;
    font-weight: 600;
}

.titan-user-exchange-btn {
    display: inline-flex;
    align-items: center;
    background: #fff;
    border: 1.5px solid #F13399;
    color: #F13399;
    border-radius: 20px;
    padding: 6px 20px;
    font-size: 15px;
    font-weight: 600;
    margin-left: 8px;
    text-decoration: none;
    transition: all 0.15s;
}

.titan-user-exchange-btn i {
    margin-left: 6px;
    font-size: 16px;
}

.titan-user-exchange-btn:hover {
    background: #F13399;
    color: #fff;
}

/* Nút giới thiệu bạn bè */
.titan-user-ref-btn {
    margin-top: 8px;
    width: 320px;
    min-height: 70px;
    background: linear-gradient(90deg, #5F6DF9 0%, #F13399 100%);
    color: #fff;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 14px 28px 14px 20px;
    font-weight: 600;
    font-size: 19px;
    box-shadow: 0 4px 16px 0 #F1339942;
    position: relative;
    text-decoration: none;
    overflow: hidden;
    gap: 18px;
}

.titan-user-ref-icon {
    position: relative;
    display: flex;
    align-items: center;
    font-size: 34px;
    margin-right: 14px;
    min-width: 44px;
}

.titan-user-ref-icon .fa-user {
    color: #fff;
    font-size: 29px;
    margin-right: 3px;
}

.titan-user-ref-icon .fa-plus {
    color: #49B1F7;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    top: -6px;
    left: 18px;
    padding: 2px 2.5px;
    font-size: 13px;
    box-shadow: 0 1px 3px #00000011;
}

.titan-user-ref-icon .fa-heart {
    color: #fff;
    font-size: 22px;
    margin-left: -7px;
    margin-bottom: -2px;
}

.titan-user-ref-content span {
    font-size: 18px;
    font-weight: 600;
    line-height: 22px;
    color: #fff;
}

.titan-user-ref-arrow {
    margin-left: auto;
    font-size: 23px;
    color: #fff;
    opacity: 0.9;
    background: none;
}

.titan-user-ref-btn:hover {
    filter: brightness(1.09);
}


.titan-progress-block {
    max-width: 1700px;
    margin: 0 auto 32px auto;
    padding: 30px 16px 0 16px;
    font-family: 'Inter', Arial, sans-serif;
}

.titan-header-row {
    margin-bottom: 10px;
}

.titan-progress-hello {
    font-size: 40px;
    font-weight: 700;
    color: #231f20;
    margin-top: 0;
}

.titan-progress-labels img {
    width: 76px;
}

.titan-progress-rank {
    display: flex;
    align-items: flex-start;
    margin-bottom: 16px;
    flex-direction: column;
    justify-content: center;
}

.rank-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 32px;
    font-weight: 700;
    color: #bbb;
}

.rank-item.active {
    color: #232323;
}


.rank-item .rank-icon i {
    font-size: 32px;
    border: 2.2px solid #b6b6b6;
    border-radius: 8px;
    padding: 2px 6px 2px 6px;
}

.rank-item.active .rank-icon i {
    border-color: #232323;
    color: #232323;
}

.rank-next-info {
    font-size: 16px;
    color: #222;
    font-weight: 400;
}

.rank-next-info .next-point {
    color: #F13399;
    font-weight: 700;
}

.rank-next-info .next-rank {
    color: #9D988A;
    font-weight: 700;
}

.titan-progress-bar-wrap {
    width: 100%;
    position: relative;
    margin: 22px 0 8px 0;
}

.titan-progress-bar {
    width: 99.5%;
    height: 8px;
    background: #e0e0e0;
    border-radius: 8px;
    position: relative;
    margin: 0 auto;
}

.titan-progress-bar-inner {
    position: absolute;
    height: 8px;
    left: 0;
    top: 0;
    background: linear-gradient(90deg, #F13399 40%, #F9A825 100%);
    border-radius: 8px;
    z-index: 2;
}

.progress-dot {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    background: #e0e0e0;
    border-radius: 50%;
    z-index: 3;
    border: 3px solid #fff;
    box-sizing: border-box;
    transition: background 0.2s;
}

.progress-dot.active {
    background: #F13399;
    border: 3px solid #fff;
}

.titan-progress-labels {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-top: 20px;
    position: relative;
    padding: 0 2px;
}

.progress-label {
    min-width: 180px;
    justify-content: center;
    gap: 7px;

}

.progress-label i {
    font-size: 21px;
    border: 2px solid #dedede;
    border-radius: 7px;
    padding: 1px 5px;
    margin-left: 4px;
    color: #bbb;
    background: #fff;
}

.progress-label.active {
    background: #fff;
    color: #232323;
}



.progress-label.titan.active {
    color: #9D988A;
}

span.progress-label.bkim img {
    width: 115px;
}




.progress-label.trieudiem {
    background: #F13399;
    color: #fff;
    padding: 3px 6px;
    border-radius: 5px;
    text-align: center;
}

span.progress-label.trieudiem img {
    width: 25px;
}

.titan-rank-note {
    color: #868686;
    font-size: 16px;
    margin: 16px 0 24px 0;
}

.titan-user-benefit-btn {
    display: inline-flex;
    align-items: center;
    background: #fff;
    border: 1px solid #F13399;
    color: #F13399;
    border-radius: 16px;
    padding: 10px 25px 10px 25px;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    margin-top: 18px;
    transition: all 0.18s;
    gap: 10px;
}

.titan-user-benefit-btn i {
    font-size: 20px;
    margin-left: 6px;
}

.titan-user-benefit-btn:hover {
    background: #F13399;
    color: #fff;
}

/* menu */
.titan-user-menu {
    list-style: none;
    margin: 0 0 16px 0;
    padding: 0;
    background: none;
}

.titan-user-menu li {
    margin-bottom: 10px;
}

.titan-user-menu li.menu-divider {
    border: none;
    border-top: 2px solid rgba(213, 215, 218, 1);
    background: none;
    margin: 16px 0 14px 0;
    height: 0;
    padding: 0;
}

.titan-user-menu li a {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: 10px;
    padding: 7px 5px 7px 10px;
    font-size: 16px;
    font-weight: 600;
    color: var(--color-gray-500);
    text-decoration: none;
    transition: background .15s, color .15s;
    gap: 14px;
    position: relative;
    border: none;
}

.titan-user-menu li.active a,
.titan-user-menu li a:hover {
    background: var(--color-main-2);
    color: #fff;
}

.titan-user-menu li.active a i,
.titan-user-menu li a:hover i {
    color: #fff;
}

.titan-user-menu i {
    font-size: 20px;
    min-width: 26px;
    text-align: center;
    color: #646974;
    transition: color .15s;
}

.titan-user-menu .menu-arrow {
    margin-left: auto;
    color: #646974;
    font-size: 18px;
    display: flex;
    align-items: center;
    transition: color .15s;
}

.titan-user-menu li.active .menu-arrow,
.titan-user-menu li a:hover .menu-arrow {
    color: #fff;
}

.titan-logout-btn {
    width: 100%;
    display: block;
    background: #fff;
    border: none;
    border-radius: 10px;
    color: #ED212B;
    font-weight: 700;
    font-size: 14px;
    padding: 7px 10px 5px 15px;
    margin-top: 7px;
    cursor: pointer;
    transition: background .13s;
    box-shadow: none;
}

.titan-logout-btn:hover {
    background: #ffe6e6;
}

/* dask account */
.titan-user-content {
    background: #fff;
    border-radius: 12px;
    padding: 38px 38px 28px 38px;
    margin-top: 0;
    font-family: "Inter", Arial, sans-serif;
}

.titan-user-section {
    margin-bottom: 35px;
}

.titan-form-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 22px;
}



.titan-btn {
    background: #F13399;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 0px 18px 0px 18px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    width: 164px;
    transition: background .15s, color .15s;
    box-shadow: none;
    text-transform: none;
}

a.titan-btn {
    padding: 10px 20px;
}

.titan-btn:disabled {
    background: #FCCEEE;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 0px 18px 0px 18px;
    font-size: 16px;
    font-weight: 600;
    cursor: not-allowed !important;
    width: 164px;
    transition: background .15s, color .15s;
    box-shadow: none;
    text-transform: none;
}

.titan-btn:hover {
    background: #F13399;
    color: #fff;
}

.titan-form-row {
    display: flex;
    gap: 26px;
    margin-bottom: 24px;
    flex-wrap: nowrap;
}

.titan-form-group {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.titan-form-wide {
    flex: 2 1 0;
}



.titan-form-group input:focus,
.titan-form-group select:focus {
    border-color: #D6D5D5;
    background: #fff;
    outline: none;
}

.titan-form-group input.readonly,
.titan-form-group input[readonly] {
    background: #D9D9D9;
    color: #000;
    border-color: #D6D5D5;
    cursor: not-allowed;
}

.required {
    color: #F13399;
}

.password-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.password-input-wrap input {
    width: 100%;
    padding-right: 35px;
}

.show-hide-eye {
    position: absolute;
    right: 12px;
    top: 35%;
    transform: translateY(-50%);
    color: #000000;
    cursor: pointer;
    font-size: 19px;
}

.custom-flex {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

button.swal2-cancel.titan-modal-btn.titan-modal-btn-pink.swal2-styled {
    padding: 0px 20px;
    background: #CD408E;
    border-radius: 8px;
    font-weight: 400;
    text-transform: none;
}

button.swal2-confirm.titan-modal-btn.titan-modal-btn-gray.swal2-styled {
    padding: 0px 18px;
    border-radius: 8px;
    text-transform: none;
    font-weight: 400;
    background: #fff;
    border: solid 1px #D5D7DA;
    color: #000;
}

button.swal2-cancel.titan-modal-btn.titan-modal-btn-red.swal2-styled {
    font-weight: 400;
    background: #D92D20;
    padding: 0px 18px;
    border-radius: 8px;
    text-transform: none;
}

table.custom_table tr td {
    border: unset;
    height: 40px;
}

h2#swal2-title {
    text-align: left;
    font-size: 18px;
    color: #181D27;
    text-indent: 15px;
}

table.custom_table td {
    color: #535862;
}

p.custom-text-1 {
    text-transform: uppercase;
    color: #CD408E;
    font-size: 26px;
    font-weight: 700;
}

ul.custom-ul-1 li {
    color: #CD408E;
    font-size: 20px;
    font-weight: 700;
    list-style: none;
    position: relative;
    padding-left: 32px;
    /* chừa chỗ cho icon */
}

ul.custom-ul-1 li::before {
    content: '';
    background-image: url('images/charm_circle-tick.png');
    background-size: contain;
    background-repeat: no-repeat;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.icon-48 {
    width: 48px;
    height: auto;
}

.lightbox-content {
    background-color: #fff;
    box-shadow: 3px 3px 20px 0 rgba(0, 0, 0, .15);
    margin: 0 auto;
    max-width: 875px;
    position: relative;
    border-radius: 12px;
}

.titan-appt-title {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 30px;
    line-height: 28px;
    font-family: "Inter", sans-serif;
}

.titan-appt-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 18px;
    flex-wrap: wrap;
    gap: 8px;
}

.appt-toolbar-left {
    display: flex;
    align-items: center;
    gap: 14px;
}

.appt-toolbar-left input[type="date"],
.appt-toolbar-left select {
    border: 1.5px solid #E0E0E0;
    border-radius: 7px;
    padding: 8px 13px;
    font-size: 15px;
    color: #444;
    width: 136px;
    box-shadow: unset;
}

.appt-toolbar-dash {
    margin: 0 0px;
    font-size: 17px;
    color: #000000;
    position: relative;
    top: -9px;
}

.appt-toolbar-left select {
    min-width: 130px;
    color: #717680;
}

.appt-toolbar-right {
    display: flex;
    align-items: baseline;
    gap: 13px;
}

.appt-toolbar-search {
    background: #fff;
    border: 1.5px solid var(--color-gray-300);
    border-radius: 8px;
    display: flex;
    align-items: center;
    padding: 0px 15px;
    font-size: 17px;
    color: #a6a6a6;
}

#appt-search {
    border: none;
    outline: none;
    background: #fff;
    font-size: 15px;
    color: #333;
    box-shadow: unset;
    padding-top: 15px;
    padding: 7px !important;
    margin-bottom: 0px;
}

.btn-appt-create {
    background: var(--color-main);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background .15s;
    text-transform: none;
    margin-bottom: 0px;
    max-width: 180px;
    text-align: center;
    justify-content: center;
    font-family: "Inter", sans-serif;
}

a#appt-create {
    padding: 7px 20px;
}

a#appt-create:hover {
    color: #fff;
}

.btn-appt-create:hover {
    filter: brightness(1.07);
}

.titan-appt-table-scroll {
    overflow-x: auto;
    background: #fff;
    margin-bottom: 20px;
}

.titan-appt-table {
    border-collapse: collapse;
    width: 100%;
    min-width: 1050px;
    background: #fff;
}

.titan-appt-table th {
    font-family: "Inter", sans-serif;
    font-size: 12px;
    font-weight: 700;
    color: var(--color-gray-600);
    padding: 15px 0px;

}

.titan-appt-table td {
    height: 70px;
    text-align: left;
    font-size: 14px;
    font-weight: 400;
    font-family: "Inter", sans-serif;
    line-height: 20px;
    color: var(--color-gray-600);
}


.titan-appt-table thead th {
    color: #535862;
    font-weight: 700;
    border-bottom: 1px solid #f2f2f2;
    background: #FAFAFA;
    text-transform: none;
}

.titan-appt-table tbody tr {
    border-bottom: 1.5px solid #f4f4f4;
    background: #fff;
    transition: background .13s;
}

.titan-appt-table tbody tr:hover {
    background: #f7f7f9;
}



.appt-status {
    display: inline-block;
    padding: 4px 17px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    background: #e7f4ff;
    color: #1383e4;
}

.appt-status.done {
    background: #ECFDF3;
    color: #027A48;
}

.appt-status.cancel {
    background: #fbe9ef;
    color: #dc3e6e;
}

.appt-status.success {
    background: #e7f4ff;
    color: #1383e4;
}

.appt-btn {
    display: inline-flex;
    align-items: center;
    font-size: 14px;
    font-weight: 600;
    border: none;
    border-radius: 8px;
    padding: 0px 16px;
    margin-right: 7px;
    background: #F8EAFE;
    color: #E24AAB;
    cursor: pointer;
    gap: 6px;
    outline: none;
    text-transform: capitalize;
    transition: background .15s, color .15s;
    margin-bottom: 0px;
}

.appt-btn:last-child {
    margin-right: 0;
}

.appt-btn.view {
    background: var(--color-brand-50);
    color: var(--color-main);
}

.appt-btn.cancel {
    background: #fff0f0;
    color: #ee2032;
    border: 1.4px solid #ffeaea;
}

.appt-btn.cancel:hover {
    background: #ffeaea;
}

.appt-btn.view:hover {
    background: #F13399;
    color: #fff;
}

/* Pagination */
.titan-appt-pagination {
    text-align: right;
    margin-top: 12px;
}

.appt-pagination-list {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.appt-pagination-btn {
    border: none;
    background: #fff;
    color: #CD408E;
    font-size: 14px;
    font-weight: 600;
    padding: 0px 18px;
    border-radius: 8px;
    cursor: pointer;
    transition: background .14s, color .14s;
    margin-right: 2px;
    text-transform: none;
    font-family: "Inter", sans-serif;
}

.appt-pagination-btn.active,
.appt-pagination-btn:hover {
    background: #f3e1f5;
    color: #E24AAB;
}

.appt-pagination-btn.disabled {
    background: #f7f7f7;
    color: #bbb;
    cursor: not-allowed;
}

.modal-error .modal-ok {
    background: #D92D20;
}

.modal-header-x {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.no-border {
    border: unset !important;
}

.custom-center {
    display: flex;
    margin: 0px auto;
    width: 100%;
    justify-content: center;
    margin-bottom: 30px;
}

table.appt-table td {
    height: 70px;
    font-size: 14px;
    color: var(--color-gray-600);
}

table.appt-table th {
    background: #FAFAFA;
    font-size: 12px;
    font-weight: 700;
    text-transform: math-auto;
    padding: 12px 0px;
    font-family: "Inter", sans-serif;
    color: var(--color-gray-600);
    line-height: 18px;
}

.divine_x {
    width: 1px;
    background: var(--color-gray-300);
    height: 40px;
    color: var(--color-gray-300);

}


.head-icon {
    margin-bottom: 15px;
}

.mirari-modal__title {
    font-size: 26px;
    color: var(--color-gray-900);
    font-weight: 700;
    font-family: "Roboto", sans-serif;
}

.flex_custom {
    display: flex;
    align-content: center;
    align-items: baseline;
    justify-content: space-around;
}

.main-button {
    background: var(--color-main);
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    border-radius: 8px;
    padding: 0px 18px;
    text-transform: math-auto;
    width: 100%;
    font-family: "Inter", sans-serif;
    margin: 0px;
}

.button-border {
    background: #fff;
    color: var(--color-gray-700);
    font-size: 16px;
    font-weight: 600;
    border-radius: 8px;
    padding: 0px 18px;
    text-transform: math-auto;
    border: 1px solid var(--color-gray-300);
    width: 100%;
    font-family: "Inter", sans-serif;
}

.titan-form-group label span {
    color: var(--color-error-600);
}

.appt-modal {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 9;
    background: rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
}

.appt-modal-content {
    background: #fff;
    border-radius: 18px;
    padding: 32px 16px 16px 16px;
    min-width: 60vw;
    min-height: 60vh;
    position: relative;
    box-shadow: 0 8px 32px #0002;
    max-width: 1100px;
    width: 90vw;
}

.appt-modal-tabs {
    display: flex;
    align-items: stretch;
    justify-content: center;
    border: solid 1px #D5D7DA;
    border-radius: 8px;
}

h2#appt-modal-title {
    text-align: center;
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 30px;
}

.appt-modal-tabs button {
    border: none;
    padding: 0px 20px;
    font-weight: 600;
    cursor: pointer;
    border-radius: 0;
    transition: .2s;
    margin-bottom: 0px;
    margin-right: 0px;
    font-size: 14px;
    text-transform: math-auto;
    margin-top: 0px;
    color: var(--color-black);
    font-family: "Inter", sans-serif;
}

.appt-modal-tabs button.active {
    background: var(--color-main);
    color: #fff;
}

.appt-tab-content {
    display: none;
    min-height: 300px;
}

.appt-tab-content.active {
    display: block;
}

.appt-modal-close {
    font-size: 16px;
    background: none;
    cursor: pointer;
    font-weight: 600;
    border: solid 1px #D5D7DA;
    border-radius: 8px;
    box-shadow: 0px 1px 2px 0px #0A0D120D;
    font-family: "Inter", sans-serif;
    text-transform: none;
    line-height: 24px;
    display: flex;
    align-content: center;
    align-items: center;
    gap: 10px;
}

button.btn-del-thanhvien {
    width: 85px;
    height: 36px;
    border-radius: 8px;
    color: var(--color-error-600);
    box-shadow: 0px 1px 2px 0px #0A0D120D;
    font-family: "Inter", sans-serif;
    font-weight: 600;
    line-height: 20px;
    background-color: var(--color-error-50);
    display: flex;
    align-items: center;
    font-size: 14px;
    gap: 2px;
    text-transform: capitalize;
    margin-bottom: 0px;
}

.appt-modal-tabs button.active:first-child {
    border-radius: 8px 0px 0px 8px;
}

.appt-modal-tabs button.active:last-child {
    border-radius: 0px 8px 8px 0px;
}

.modal-popup-title {
    font-size: 18px;
    font-weight: 500;
    line-height: 28px;
    height: 50px;
    color: var(--color-gray-900);
    font-family: "Inter", sans-serif;
}

.mirari-bell-noti-row.unread {
    background: #f7f7fa !important;
}

.custom-right {
    float: right;
    min-width: 600px;
    width: 600px;
}

.decoration-underline {
    text-decoration: underline;
}

li.html.custom.html_nav_position_text_top {
    display: flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    gap: 25px;
}

#mirari-bell-icon {
    position: relative;
    cursor: pointer;
    transition: box-shadow .2s;
}

#mirari-bell-icon:hover {
    box-shadow: 0 2px 16px #fbe6f4;
}

#mirari-bell-count {
    position: absolute;
    top: -6px;
    right: -6px;
    background: #fff;
    color: #E3519A;
    font-weight: 700;
    font-size: 14px;
    border-radius: 99px;
    padding: 2px 7px;
    border: 2px solid #E3519A;
}

#mirari-bell-modal-bg {
    position: fixed;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(40, 40, 40, 0.5);
    z-index: 99999;
}

#mirari-bell-modal {
    position: fixed;
    right: 0px;
    top: 156px;
    max-width: 500px;
    width: 95vw;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 8px 50px 0 rgba(40, 34, 109, .16);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    animation: bellModalFadeIn .23s;
}

div#mirari-bell-icon img {
    width: 35px;
    height: auto;
}

.alert-90 {
    font-family: "Roboto", sans-serif;
    font-weight: 400;
    font-size: 16px;
    color: var(--color-gray-900);
}

@keyframes bellModalFadeIn {
    from {
        transform: translateY(40px);
        opacity: .6
    }

    to {
        transform: none;
        opacity: 1
    }
}

.mirari-bell-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0px 20px 0 20px;
    font-size: 26px;
    font-weight: 700;
    color: #24293E;
}

.mirari-bell-modal-header .mirari-bell-close {
    background: none;
    border: none;
    font-size: 30px;
    line-height: 1;
    color: #828282;
    cursor: pointer;
    padding: 0px;
    margin: 0px;
}

.mirari-bell-modal-body {
    max-height: 420px;
    overflow-y: auto;
    padding: 10px 18px 0 18px;
}

.mirari-bell-noti-row {
    display: flex;
    align-items: flex-start;
    gap: 13px;
    background: #F7F8FA;
    border-radius: 10px;
    margin-bottom: 10px;
    padding: 13px 15px;
    position: relative;
}

.mirari-bell-noti-row:last-child {
    margin-bottom: 0;
}

.mirari-bell-noti-icon {
    min-width: 38px;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mirari-bell-noti-content {
    flex: 1;
}

.mirari-bell-noti-title {
    font-weight: 700;
    font-size: 20px;
    color: #333333;
    font-family: "Roboto", sans-serif;
}

.mirari-bell-noti-desc {
    color: #6A6C81;
    font-size: 16px;
    font-weight: 400;
    font-family: "Roboto", sans-serif;
}

.mirari-bell-noti-time {
    position: absolute;
    top: 16px;
    right: 15px;
    font-size: 13px;
    color: #B9B9C3;
}

.mirari-bell-noti-dot {
    position: absolute;
    right: 7px;
    bottom: 13px;
    width: 9px;
    height: 9px;
    background: #32e373;
    border-radius: 99px;
}

.mirari-bell-markread {
    display: flex;
    width: 226px;
    margin: 18px auto 20px auto;
    background: #fbe6f4;
    border: none;
    color: #000000;
    font-size: 16px;
    font-weight: 400;
    border-radius: 100px;
    padding: 8px 3px;
    cursor: pointer;
    transition: background 0.2s;
    height: 43px;
    text-transform: none;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.mirari-bell-modal-footer {
    margin-bottom: 30px;
}

.mirari-bell-markread:hover {
    background: #e6d8ed;
}

.mirari-statistics {
    display: flex;
    gap: 20px;
    margin-bottom: 16px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}

.mirari-stat-card.card-master {
    border: solid 1px #CD408E;
}

.mirari-stat-card {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 4px 14px 0 rgba(56, 43, 83, 0.04);
    border: 1.5px solid #ececec;
    min-width: 310px;
    padding: 16px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 10px;
}

.mirari-stat-card .mirari-label {
    font-size: 1.0rem;
    color: #777;
    margin-bottom: 8px;
    text-align: center;
}

.mirari-stat-card .mirari-value {
    font-size: 20px;
    font-weight: 700;
    color: #FF1493;
    margin-bottom: 0;
    letter-spacing: 1px;
    text-align: center;
}

.mirari-code-box {
    position: relative;
    border: 1.5px solid #FF69BC;
    border-radius: 10px;
    padding: 0px 10px;
    min-width: 160px;
    text-align: center;
    box-shadow: 0 2px 8px 0 rgba(255, 105, 188, 0.08);
    margin-bottom: 6px;
}

.mirari-code {
    font-size: 20px;
    font-weight: 700;
    color: #FF1493;
    display: block;
}

.mirari-copy-btn {
    background: #fff;
    color: #535862;
    font-size: 14px;
    cursor: pointer;
    margin-left: 0;
    font-weight: 500;
    transition: all .15s;
    margin-bottom: 0px;

}



/* Bộ lọc ngày và tìm kiếm */
.mirari-filter-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin: 10px 0 18px 0;
    flex-wrap: wrap;
}

.mirari-dates {
    display: flex;
    align-items: center;
    gap: 7px;
}

.mirari-date-input {
    padding: 7px 14px;
    border: 1px solid #e3e3ea;
    border-radius: 7px;
    font-size: 1rem;
    min-width: 155px;
    background: #fafafd;
    color: #888;
}

.mirari-search {
    margin-left: auto;
    position: relative;
}

.mirari-search input[type="search"] {
    border-radius: 8px;
    border: 1px solid #d8d8e0;
    background: #fafafd;
    padding: 9px 12px 9px 38px;
    font-size: 1.04rem;
    width: 220px;
    outline: none;
    transition: border .16s;
}

.mirari-search:before {
    content: '';
    position: absolute;
    top: 9px;
    left: 12px;
    width: 18px;
    height: 18px;
    background: url('images/icon-search.png') no-repeat center/cover;
    opacity: 0.30;
}

/* Bảng DataTables */
table.dataTable {
    border-radius: 11px;
    overflow: hidden;
    background: #fff;
    width: 100% !important;
}

table.dataTable thead th {
    background: #fafafd;
    color: #6B7280;
    font-weight: 600;
    font-size: 1.02rem;
    border-bottom: 1.5px solid #ececec;
    padding: 10px 8px;
}

table.dataTable tbody td {
    color: #24243e;
    font-size: 1.03rem;
    padding: 11px 8px;
    background: #fff;
}

table.dataTable tr {
    border-bottom: 1px solid #f1f1f5;
}

table.dataTable tr:last-child {
    border-bottom: none;
}

table.dataTable thead th,
table.dataTable tbody td {
    text-align: left;
}

table.dataTable tfoot th,
table.dataTable tfoot td {
    background: #fafafd;
}

.dataTables_paginate {
    margin-top: 16px;
    text-align: center !important;
    font-size: 1.05rem;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 7px;
}

.dataTables_paginate .paginate_button {
    border: none !important;
    background: none !important;
    color: #8C52FF !important;
    border-radius: 7px !important;
    min-width: 34px;
    height: 34px;
    margin: 0 2px;
    transition: background .15s;
    font-weight: 500;
}

.dataTables_paginate .paginate_button.current,
.dataTables_paginate .paginate_button.current:hover {
    background: #f9f1ff !important;
    color: #8C52FF !important;
    font-weight: 700;
    border: 1.5px solid #ebe5fb !important;
}

.dataTables_paginate .paginate_button:hover {
    background: #fde4f7 !important;
    color: #FF69BC !important;
}

.mirari-paging-btn {
    padding: 8px 18px;
    border-radius: 8px;
    border: 1.5px solid #ececec;
    background: #fff;
    color: #444;
    font-weight: 500;
    margin: 0 9px;
    cursor: pointer;
    font-size: 1rem;
    transition: background .13s;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.mirari-paging-btn:hover {
    background: #FF69BC;
    color: #fff;
    border: 1.5px solid #FF69BC;
}

.mirari-code-box {
    display: flex;
    gap: 10px;
    border: solid 1px #D5D7DA;
}

.daisu-divider {
    display: inline-block;
    width: 1px;
    height: auto;
    background: #E6E6E6;
    margin: 0 4px 0 0;
    border-radius: 2px;
}

form#history-modal-form .titan-form-group {
    flex: 0 0 48%;
    box-sizing: border-box;
}

form#history-modal-form {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.icon-head {
    text-align: center;
    margin-bottom: 20px;
}

.icon-head img {
    width: 64px;
}

div#modal-chuyen-nhuong h2 {
    font-size: 18px;
    text-align: center;
    color: var(--color-gray-900);
    font-weight: 600;
    line-height: 28px;
}

div#modal-chuyen-nhuong p {
    font-size: 14px;
    text-align: center;
    color: var(--color-gray-600);
    font-weight: 400;
    line-height: 20px;
}

div#modal-chuyen-nhuong button.titan-btn {
    width: 100% !important;
    display: block;
    max-width: 100%;
}

.description-dashboard {
    font-size: 16px;
    color: var(--color-gray-900);
    font-family: "Roboto", sans-serif;
    font-weight: 400;
}

.flex-2col {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.flex-2col span {
    width: 60%;
    font-weight: 400;
    font-size: 16px;
    font-family: "Roboto", sans-serif;
    color: var(--color-gray-600);
}

.flex-2col strong {
    font-weight: 700;
    font-size: 16px;
    font-family: "Roboto", sans-serif;
    color: var(--color-gray-600);
}

button.appt-btn-copy {
    border: solid 1px #D5D7DA;
    text-transform: none;
    display: flex;
    align-content: center;
    align-items: center;
    gap: 10px;
    margin: 0px auto;
    border-radius: 8px;
    padding: 0px 25px;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-gray-600);
}

.text-copy-p {
    font-size: 16px;
    font-weight: 400;
    line-height: 26px;
    margin-top: 15px;
    color: var(--color-gray-600);
}

.h2-goilieutrinh {
    text-align: center;
    padding: 20px 0px;
    font-size: 26px;
    font-weight: 700;
    font-family: "Roboto", sans-serif;
}

.grid-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

.item-card {
    display: flex;
    background: #fff;
    border-radius: 8px;
    padding: 10px 10px;
    align-items: center;
    min-height: 180px;
    border: solid 1px #A4A7AE;
}

.item-img {
    width: 180px;
    min-width: 180px;
    margin-right: 28px;
}

.item-content {
    flex: 1;
}

.item-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.item-mcoin {
    font-weight: 700;
    font-size: 14.4px;
    font-family: "Roboto", sans-serif;
    color: var(--color-main);
}

.font-roboto {
    font-family: "Roboto", sans-serif !important;
    color: var(--color-gray-600);
    font-weight: 400;
    font-size: 16px;
}

.item-content .item-title {
    font-size: 16px;
    font-weight: 600;
    line-height: 28px;
    font-family: "Roboto", sans-serif;
}

.item-content .item-desc {
    font-size: 14.4px;
    font-weight: 400;
    color: var(--color-gray-600);
}

button.btn-doithuong.titan-btn {
    width: 115px;
    font-size: 14px;
}

ul.card-ulli li {
    font-size: 16px;
    font-weight: 400;
    line-height: 25px;
    color: var(--color-gray-500);
}

.mirari-stat-card.custom-card {
    background: #FDF2FA;

}

ul.card-ulli {
    margin: 0px;
    padding: 0px;
}


.member-benefit-box {
    border: 2px solid #d7338e;
    border-radius: 12px;
    padding: 16px 10px 18px 10px;
    margin: 10px 0;
    overflow-x: auto;
    background: #fff;
}

.member-benefit-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 18px;
}

.member-benefit-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #232323;
    display: flex;
    align-items: center;
    gap: 6px;
    justify-content: center;
}

.member-benefit-title.silver {
    color: #757575;
}

.member-benefit-title.titan {
    color: #7e7e7e;
}

.member-benefit-title.gold {
    color: #ffb800;
}

.member-benefit-title.platinum {
    color: #bbb;
}

.member-benefit-title.vip {
    color: #d7338e;
}

.member-benefit-list {
    padding-left: 18px;
    margin: 0;
    font-size: 15px;
    color: #232323;
}

.member-benefit-list li {
    margin-bottom: 6px;
}

.member-benefit-title .icon {
    display: inline-block;
    width: 22px;
    height: 22px;
    vertical-align: middle;
}

.mirari-times-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px;
    margin-bottom: 30px;
}

.mirari-time-btn {
    border: 1.5px solid var(--color-main-2);
    border-radius: 8px;
    background: #fff;
    color: #2952CC;
    font-size: 15px;
    font-weight: 600;
    transition: background 0.18s, color 0.18s, border 0.18s;
    cursor: pointer;
    margin: 0px;
}

.mirari-time-btn.active,
.mirari-time-btn:hover:not([disabled]) {
    background: var(--color-main-2);
    color: #fff;
    border: 1.5px solid var(--color-main-2);
}

.mirari-time-btn:disabled {
    background: #f2f2f2;
    color: #bbb;
    cursor: not-allowed;
    border: 1.5px solid #eee;
}

/* Đặt chiều rộng flatpickr bằng modal của bạn (ví dụ 100% hoặc giá trị cụ thể) */
/* Toàn bộ popup calendar */
.flatpickr-calendar {
    width: 100% !important;
    /* Luôn chiếm hết chiều ngang cha */
    min-width: 0 !important;
    max-width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 auto !important;
    border-radius: 20px !important;
    box-sizing: border-box;
    padding-bottom: 16px !important;
}

/* Bên trong calendar */
.flatpickr-innerContainer,
.flatpickr-rContainer,
.flatpickr-days {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box;
}

/* Dàn ngang các ngày full chiều ngang */
.dayContainer {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 2px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    justify-items: center !important;
    align-items: center !important;
}

/* Tuỳ chỉnh chiều rộng/cao ô ngày cho đều */
.flatpickr-day,
.flatpickr-day.today,
.flatpickr-day.selected {
    width: 38px !important;
    height: 38px !important;
    line-height: 38px !important;
    margin: 0 auto !important;
    padding: 0 !important;
    border-radius: 50% !important;
    justify-self: center !important;
    align-self: center !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    transition: background .18s, color .18s;
    text-align: center;
}

/* Fix tuần header weekdays full width */
.flatpickr-weekdays {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    width: 100% !important;
    margin-bottom: 0 !important;
}

span.flatpickr-weekday {
    text-align: center;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #ED4E92 !important;
    min-width: 55px;
}

/* Nếu muốn full width luôn cả container cha modal: */
.booking-modal .flatpickr-calendar {
    width: 100% !important;
    max-width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    box-shadow: unset;
}

.flatpickr-month {
    margin-bottom: 15px;
}

.flatpickr-current-month input.cur-year {
    box-shadow: unset;

}

.flatpickr-current-month {
    display: flex;
    align-content: center;
    justify-content: center;
    gap: 10px;
}

.flatpickr-current-month {
    display: flex !important;
    align-content: center;
    align-items: baseline;
}

.flatpickr-day.today {
    border-color: unset;
    background-color: #CD408E;
    color: #fff;
    line-height: 35px !important;
}

.flatpickr-day.selected {
    background: #cd408e;
    border: unset;
    line-height: 38px !important;
}

.confirm-info {
    margin-bottom: 20px;
    margin-top: 20px;
}

form#titan-login-form {
    max-width: 400px;
    display: block;
    margin: 0px auto;
}

form#titan-login-form a {
    text-decoration: underline;
}

.head-modal-icon img {
    text-align: center;
    display: block;
    margin: 0px auto;
    width: 64px;
}

.custom_btn_flex button {
    width: 100% !important;
    margin-bottom: 0px;
}

.custom_btn_flex {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.titan-related-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    max-width: 1700px;
    margin: auto;
}

.titan-related-card {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 6px 24px 0 rgba(28, 39, 75, .08);
    overflow: hidden;
    transition: box-shadow .3s;
}

.titan-related-card:hover {
    box-shadow: 0 10px 30px 0 rgba(28, 39, 75, .18);
}

.titan-related-thumb img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
}

.titan-related-content a {
    font-weight: 700;
    font-size: 22px;
    color: #181D27;
    text-decoration: none;
    line-height: 1.28;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.titan-related-content a {
    font-size: 16px;
    color: #0A0A0A;
}

.titan-related-content {
    padding: 20px;
}

.titan-related-section.product-related-m h2 {
    font-size: 30px;
    text-align: center;
    font-weight: 700;
    color: #0A0A0A;
    padding-bottom: 30px;
}

.titan-related-section.product-related-m {
    margin-bottom: 30px;
}

a.btn-appt-create.btn-appt-header {
    background: #3956A5;
    color: #fff;
    font-family: "Inter", sans-serif;
    display: flex;
    align-content: center;
    align-items: flex-end;
}

.line-x {
    height: 33px;
    width: 1px;
    background: #f50;
    color: #f50;
    border: solid 1px #E9EAEB;
    margin: 0px -15px;
}

@media (max-width: 1024px) {
    .titan-related-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 600px) {
    .titan-related-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1024px) {
    .member-benefit-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .titan-appt-table-page {
        padding: 10px 2vw;
    }

    .titan-appt-title {
        font-size: 20px;
    }

    .titan-appt-table th,
    .titan-appt-table td {
        font-size: 13px;
    }

    .appt-toolbar-left input,
    .appt-toolbar-left select {
        width: 95px;
    }

    .mirari-wrapper {
        padding: 10px;
    }

    .mirari-statistics {
        flex-direction: column;
    }

    .mirari-stat-card {
        min-width: 160px;
    }

    .mirari-filter-row {
        flex-direction: column;
    }

    .mirari-search {
        width: 100%;
    }

    .mirari-search input {
        width: 100%;
    }
}

@media (max-width: 900px) {
    .titan-progress-hello {
        font-size: 30px;
    }

    .progress-label {
        font-size: 13px;
        padding: 3px 8px;
        min-width: 40px;
    }
}

@media (max-width: 1024px) {
    .titan-user-header {
        flex-direction: column;
    }

    .titan-user-main {
        flex-direction: column;
    }

    .titan-user-sidebar {
        width: 100%;
        margin-bottom: 18px;
    }

    .titan-user-content {
        padding: 16px 3vw;
    }

    .titan-form-row {
        flex-direction: column;
        gap: 0;
    }
}

@media (max-width: 700px) {
    .titan-user-dashboard {
        padding: 8px;
    }

    .titan-user-header {
        padding: 12px;
    }

    .titan-user-header-right .titan-user-ref-btn {
        width: 100%;
    }

    .titan-user-content {
        padding: 14px 6px 16px 6px;
    }

    #mirari-bell-wrap {
        right: 9px;
        bottom: 9px;
    }

    #mirari-bell-modal {
        right: 2vw;
        max-width: 99vw;
    }
}