/* =========================================================================
   vercel-client.css — Geist design system theme layer for client UI
   Scoped to body.vercel-client so it never leaks into admin/ctv views.
   Loaded after backend.css and customize.css, so overrides win by source
   order without needing !important in most cases.
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. Design tokens (CSS custom properties)
   Light theme is the default; dark theme activates under the existing
   Datum dark-mode toggle (body.color-dark / .dark-mode).
   ------------------------------------------------------------------------- */

body.vercel-client {
    /* --- Surfaces --- */
    --vc-bg-100: #ffffff;
    --vc-bg-200: #fafafa;
    --vc-bg-300: #f2f2f2;

    /* --- Gray scale (solid) --- */
    --vc-gray-100: #f2f2f2;
    --vc-gray-200: #ebebeb;
    --vc-gray-300: #e6e6e6;
    --vc-gray-400: #eaeaea;
    --vc-gray-500: #c9c9c9;
    --vc-gray-600: #a8a8a8;
    --vc-gray-700: #8f8f8f;
    --vc-gray-800: #7d7d7d;
    --vc-gray-900: #4d4d4d;
    --vc-gray-1000: #171717;

    /* --- Gray scale (alpha) --- */
    --vc-gray-a-100: rgba(0, 0, 0, 0.05);
    --vc-gray-a-200: rgba(0, 0, 0, 0.08);
    --vc-gray-a-300: rgba(0, 0, 0, 0.10);
    --vc-gray-a-400: rgba(0, 0, 0, 0.08);
    --vc-gray-a-500: rgba(0, 0, 0, 0.21);
    --vc-gray-a-600: rgba(0, 0, 0, 0.24);
    --vc-gray-a-700: rgba(0, 0, 0, 0.44);
    --vc-gray-a-800: rgba(0, 0, 0, 0.51);
    --vc-gray-a-900: rgba(0, 0, 0, 0.70);
    --vc-gray-a-1000: rgba(0, 0, 0, 0.91);

    /* --- Accent: blue --- */
    --vc-blue-100: #f0f7ff;
    --vc-blue-400: #cae7ff;
    --vc-blue-600: #48aeff;
    --vc-blue-700: #006bff;
    --vc-blue-800: #0059ec;
    --vc-blue-900: #005ff2;
    --vc-blue-1000: #002359;
    --vc-sky-700: #0ea5e9;

    /* --- Accent: red --- */
    --vc-red-100: #ffeeef;
    --vc-red-400: #ffd7d6;
    --vc-red-600: #ff676d;
    --vc-red-700: #fc0035;
    --vc-red-800: #ea001d;
    --vc-red-1000: #47000c;

    /* --- Accent: amber --- */
    --vc-amber-100: #fff6de;
    --vc-amber-400: #ffdc73;
    --vc-amber-600: #ffa600;
    --vc-amber-700: #ffae00;
    --vc-amber-1000: #561900;

    /* --- Accent: green --- */
    --vc-green-100: #ecfdec;
    --vc-green-400: #b9f5bc;
    --vc-green-600: #4ce15e;
    --vc-green-700: #28a948;
    --vc-green-1000: #003a00;

    /* --- Semantic aliases --- */
    --vc-text-primary: var(--vc-gray-1000);
    --vc-text-secondary: var(--vc-gray-900);
    --vc-text-muted: var(--vc-gray-700);
    --vc-text-disabled: var(--vc-gray-600);

    --vc-border: var(--vc-gray-a-300);
    --vc-border-strong: var(--vc-gray-a-500);

    --vc-surface: var(--vc-bg-100);
    --vc-surface-raised: var(--vc-bg-100);
    --vc-surface-subtle: var(--vc-bg-200);

    --vc-accent: var(--vc-blue-700);
    --vc-accent-hover: var(--vc-blue-800);
    --vc-accent-contrast: #ffffff;

    --vc-danger: var(--vc-red-700);
    --vc-danger-hover: var(--vc-red-800);
    --vc-danger-contrast: #ffffff;

    --vc-success: var(--vc-green-700);
    --vc-warning: var(--vc-amber-700);

    /* --- Radii --- */
    --vc-radius-sm: 6px;
    --vc-radius-md: 12px;
    --vc-radius-lg: 16px;
    --vc-radius-full: 9999px;

    /* --- Spacing (4px base scale) --- */
    --vc-space-1: 4px;
    --vc-space-2: 8px;
    --vc-space-3: 12px;
    --vc-space-4: 16px;
    --vc-space-6: 24px;
    --vc-space-8: 32px;
    --vc-space-10: 40px;
    --vc-space-16: 64px;

    /* --- Shadows --- */
    --vc-shadow-card: 0 2px 2px rgba(0, 0, 0, 0.04);
    --vc-shadow-popover: 0 1px 1px rgba(0, 0, 0, 0.02), 0 4px 8px -4px rgba(0, 0, 0, 0.04), 0 16px 24px -8px rgba(0, 0, 0, 0.06);
    --vc-shadow-modal: 0 1px 1px rgba(0, 0, 0, 0.02), 0 8px 16px -4px rgba(0, 0, 0, 0.04), 0 24px 32px -8px rgba(0, 0, 0, 0.06);

    /* --- Focus ring --- */
    --vc-focus-ring: 0 0 0 2px var(--vc-bg-100), 0 0 0 4px var(--vc-blue-700);

    /* --- Typography --- */
    --vc-font-sans: inherit;
}

/* -------------------------------------------------------------------------
   2. Dark theme token overrides
   Datum's customizer.js adds class .dark to <body> when dark mode is on.
   We also cover .color-dark and [data-theme="dark"] for robustness.
   All selectors are scoped under body.vercel-client so light mode is unaffected.
   ------------------------------------------------------------------------- */

/* Primary selector — Datum uses body.dark */
body.vercel-client.dark,
/* Fallbacks for other possible toggle patterns */
body.vercel-client.color-dark,
html.color-dark body.vercel-client,
.color-dark body.vercel-client,
body.vercel-client[data-theme="dark"] {
    --vc-bg-100: #000000;
    --vc-bg-200: #000000;
    --vc-bg-300: #1a1a1a;

    --vc-gray-100: #1a1a1a;
    --vc-gray-200: #1f1f1f;
    --vc-gray-300: #292929;
    --vc-gray-400: #2e2e2e;
    --vc-gray-500: #454545;
    --vc-gray-600: #878787;
    --vc-gray-700: #8f8f8f;
    --vc-gray-800: #7d7d7d;
    --vc-gray-900: #a0a0a0;
    --vc-gray-1000: #ededed;

    --vc-gray-a-100: rgba(255, 255, 255, 0.07);
    --vc-gray-a-200: rgba(255, 255, 255, 0.09);
    --vc-gray-a-300: rgba(255, 255, 255, 0.13);
    --vc-gray-a-400: rgba(255, 255, 255, 0.14);
    --vc-gray-a-500: rgba(255, 255, 255, 0.24);
    --vc-gray-a-600: rgba(255, 255, 255, 0.51);
    --vc-gray-a-700: rgba(255, 255, 255, 0.54);
    --vc-gray-a-800: rgba(255, 255, 255, 0.47);
    --vc-gray-a-900: rgba(255, 255, 255, 0.61);
    --vc-gray-a-1000: rgba(255, 255, 255, 0.92);

    --vc-blue-700: #006efe;
    --vc-blue-800: #005be7;
    --vc-blue-900: #47a8ff;
    --vc-sky-700: #0ea5e9;

    --vc-red-700: #f13242;
    --vc-red-800: #e2162a;

    --vc-amber-700: #ffae00;

    --vc-green-700: #00ac3a;

    --vc-focus-ring: 0 0 0 2px var(--vc-bg-100), 0 0 0 4px var(--vc-blue-900);

    --vc-shadow-card: 0 1px 2px rgba(0, 0, 0, 0.16);
}

/* -------------------------------------------------------------------------
   2b. Dark-mode surface overrides
   Ensures key areas go dark even if Datum's own dark CSS doesn't cover them.
   ------------------------------------------------------------------------- */

body.vercel-client.dark,
body.vercel-client.color-dark,
html.color-dark body.vercel-client,
.color-dark body.vercel-client,
body.vercel-client[data-theme="dark"] {
    background-color: var(--vc-bg-200);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .wrapper,
html.color-dark body.vercel-client .wrapper,
.color-dark body.vercel-client .wrapper {
    background: var(--vc-bg-200);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .content-page,
html.color-dark body.vercel-client .content-page,
.color-dark body.vercel-client .content-page {
    background: transparent;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .content-page > .container-fluid,
html.color-dark body.vercel-client .content-page > .container-fluid,
.color-dark body.vercel-client .content-page > .container-fluid {
    background: transparent;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .iq-top-navbar,
html.color-dark body.vercel-client .iq-top-navbar,
.color-dark body.vercel-client .iq-top-navbar {
    background: var(--vc-bg-100);
    border-bottom-color: var(--vc-gray-a-300);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .iq-sidebar,
html.color-dark body.vercel-client .iq-sidebar,
.color-dark body.vercel-client .iq-sidebar {
    background: var(--vc-bg-100) !important;
    border-right-color: var(--vc-gray-a-300);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .card,
html.color-dark body.vercel-client .card,
.color-dark body.vercel-client .card {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-300);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .card .card-header,
html.color-dark body.vercel-client .card .card-header,
.color-dark body.vercel-client .card .card-header {
    background: var(--vc-bg-100);
    border-bottom-color: var(--vc-gray-a-300);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .card .card-header .card-title,
html.color-dark body.vercel-client .card .card-header .card-title,
.color-dark body.vercel-client .card .card-header .card-title {
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table,
html.color-dark body.vercel-client .table,
.color-dark body.vercel-client .table {
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table td,
html.color-dark body.vercel-client .table td,
.color-dark body.vercel-client .table td {
    border-top-color: var(--vc-gray-a-200);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table thead th,
html.color-dark body.vercel-client .table thead th,
.color-dark body.vercel-client .table thead th,
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table .table-color-heading th,
html.color-dark body.vercel-client .table .table-color-heading th,
.color-dark body.vercel-client .table .table-color-heading th {
    color: var(--vc-text-muted);
    border-bottom-color: var(--vc-gray-a-300);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table-striped tbody tr:nth-of-type(odd),
html.color-dark body.vercel-client .table-striped tbody tr:nth-of-type(odd),
.color-dark body.vercel-client .table-striped tbody tr:nth-of-type(odd) {
    background: var(--vc-gray-a-100);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table-hover tbody tr:hover,
html.color-dark body.vercel-client .table-hover tbody tr:hover,
.color-dark body.vercel-client .table-hover tbody tr:hover {
    background: var(--vc-gray-a-200);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .form-control,
html.color-dark body.vercel-client .form-control,
.color-dark body.vercel-client .form-control {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-400);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .form-control:focus,
html.color-dark body.vercel-client .form-control:focus,
.color-dark body.vercel-client .form-control:focus {
    background: var(--vc-bg-100);
    border-color: var(--vc-blue-900);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .form-control::placeholder,
html.color-dark body.vercel-client .form-control::placeholder,
.color-dark body.vercel-client .form-control::placeholder {
    color: var(--vc-text-muted);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .dropdown-menu,
html.color-dark body.vercel-client .dropdown-menu,
.color-dark body.vercel-client .dropdown-menu,
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .iq-sub-dropdown .dropdown-menu,
html.color-dark body.vercel-client .iq-sub-dropdown .dropdown-menu,
.color-dark body.vercel-client .iq-sub-dropdown .dropdown-menu {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-300);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .modal-content,
html.color-dark body.vercel-client .modal-content,
.color-dark body.vercel-client .modal-content {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-300);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .modal-header,
html.color-dark body.vercel-client .modal-header,
.color-dark body.vercel-client .modal-header {
    background: var(--vc-bg-100);
    border-bottom-color: var(--vc-gray-a-300);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .modal-body,
html.color-dark body.vercel-client .modal-body,
.color-dark body.vercel-client .modal-body {
    background: var(--vc-bg-100);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .modal-footer,
html.color-dark body.vercel-client .modal-footer,
.color-dark body.vercel-client .modal-footer {
    background: var(--vc-bg-200);
    border-top-color: var(--vc-gray-a-300);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .iq-footer,
html.color-dark body.vercel-client .iq-footer,
.color-dark body.vercel-client .iq-footer {
    background: var(--vc-bg-100);
    border-top-color: var(--vc-gray-a-300);
    color: var(--vc-text-muted);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .iq-footer a,
html.color-dark body.vercel-client .iq-footer a,
.color-dark body.vercel-client .iq-footer a {
    color: var(--vc-text-secondary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .alert.bg-white,
html.color-dark body.vercel-client .alert.bg-white,
.color-dark body.vercel-client .alert.bg-white {
    background: var(--vc-bg-100) !important;
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .bg-white,
html.color-dark body.vercel-client .bg-white,
.color-dark body.vercel-client .bg-white {
    background: var(--vc-bg-100) !important;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) #loading,
html.color-dark body.vercel-client #loading,
.color-dark body.vercel-client #loading {
    background: var(--vc-bg-200);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .list-group-item,
html.color-dark body.vercel-client .list-group-item,
.color-dark body.vercel-client .list-group-item {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-200);
    color: var(--vc-text-primary);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .blur-shadow,
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .basic-drop-shadow,
html.color-dark body.vercel-client .blur-shadow,
html.color-dark body.vercel-client .basic-drop-shadow,
.color-dark body.vercel-client .blur-shadow,
.color-dark body.vercel-client .basic-drop-shadow {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-300);
}

/* --- Fix màu chữ muted cho Card Content ở giao diện Dark Mode --- */
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .product-template2-wrapper p,
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .product-template2-wrapper p i,
html.color-dark body.vercel-client .product-template2-wrapper p,
html.color-dark body.vercel-client .product-template2-wrapper p i,
.color-dark body.vercel-client .product-template2-wrapper p,
.color-dark body.vercel-client .product-template2-wrapper p i {
    color: var(--vc-gray-600) !important;
}

/* -------------------------------------------------------------------------
   3. Base body-level overrides
   Only the most fundamental surface + text color changes here.
   Component-level restyling follows in subsequent incremental steps.
   ------------------------------------------------------------------------- */

body.vercel-client {
    font-family: inherit;
    background-color: var(--vc-surface-subtle);
    color: var(--vc-text-primary);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Keep links readable */
body.vercel-client a {
    color: var(--vc-accent);
    text-decoration: none;
    transition: color 0ms;
}

body.vercel-client a:hover {
    color: var(--vc-accent-hover);
}

/* Focus ring for interactive elements */
body.vercel-client a:focus-visible,
body.vercel-client button:focus-visible,
body.vercel-client input:focus-visible,
body.vercel-client select:focus-visible,
body.vercel-client textarea:focus-visible {
    outline: none;
    box-shadow: var(--vc-focus-ring);
}

/* =========================================================================
   4. Layout — content-page, container spacing, wrapper
   ========================================================================= */

body.vercel-client .content-page {
    padding: var(--vc-space-6) var(--vc-space-6) var(--vc-space-16);
    background: transparent;
}

body.vercel-client .content-page > .container-fluid {
    max-width: 1400px;
    padding-left: var(--vc-space-4);
    padding-right: var(--vc-space-4);
}

body.vercel-client .wrapper {
    background: var(--vc-surface-subtle);
}

/* =========================================================================
   5. Sidebar
   ========================================================================= */

body.vercel-client .iq-sidebar {
    background: var(--vc-surface) !important;
    border-right: 1px solid var(--vc-border);
    box-shadow: none;
}

body.vercel-client .iq-sidebar-logo {
    padding: var(--vc-space-4) var(--vc-space-6);
    border-bottom: 1px solid var(--vc-border);
}

body.vercel-client .iq-sidebar-menu .side-menu > li.sidebar-layout > a.svg-icon {
    padding: var(--vc-space-2) var(--vc-space-4);
    border-radius: var(--vc-radius-sm);
    color: var(--vc-text-secondary);
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
    margin: 1px var(--vc-space-2);
    transition: background 0ms, color 0ms;
}

body.vercel-client .iq-sidebar-menu .side-menu > li.sidebar-layout > a.svg-icon:hover {
    background: var(--vc-gray-a-100);
    color: var(--vc-text-primary);
}

body.vercel-client .iq-sidebar-menu .side-menu > li.sidebar-layout.active > a.svg-icon,
body.vercel-client .iq-sidebar-menu .side-menu > li.active > a.svg-icon {
    background: var(--vc-gray-a-200);
    color: var(--vc-text-primary);
    font-weight: 600;
}

body.vercel-client .iq-sidebar-menu .submenu {
    margin: 0 var(--vc-space-2);
    padding-left: var(--vc-space-4);
}

body.vercel-client .iq-sidebar-menu .submenu > li.sidebar-layout > a.svg-icon {
    padding: var(--vc-space-2) var(--vc-space-3);
    border-radius: var(--vc-radius-sm);
    color: var(--vc-text-muted);
    font-size: 13px;
}

body.vercel-client .iq-sidebar-menu .submenu > li.sidebar-layout > a.svg-icon:hover {
    background: var(--vc-gray-a-100);
    color: var(--vc-text-primary);
}

body.vercel-client .iq-sidebar-menu .submenu > li.active > a.svg-icon {
    background: var(--vc-gray-a-200);
    color: var(--vc-text-primary);
}

/* Sidebar section labels (balance, "Nạp Tiền", "Khác") */
body.vercel-client .iq-sidebar-menu .side-menu > li.px-3 > span {
    color: var(--vc-text-muted);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

/* =========================================================================
   6. Top navbar (Chuẩn style Vercel - Đã fix lỗi tụt đáy layout)
   ========================================================================= */

/* Ép tất cả các lớp bọc thanh điều hướng có cùng chiều cao 56px, triệt tiêu padding thừa */
body.vercel-client .iq-top-navbar,
body.vercel-client .iq-navbar-custom,
body.vercel-client .iq-navbar-custom .navbar {
    height: 56px !important;
    min-height: 56px !important;
    background: var(--vc-surface);
    margin: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

body.vercel-client .iq-top-navbar {
    border-bottom: 1px solid var(--vc-border);
    box-shadow: none;
}

/* Biến khung navbar thành trục Flexbox chuẩn để căn giữa */
body.vercel-client .iq-navbar-custom .navbar {
    padding-left: var(--vc-space-4) !important;
    padding-right: var(--vc-space-4) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
}

/* --- CỤM BÊN TRÁI (Icon menu + Các nút Ví/Admin) --- */
body.vercel-client .side-menu-bt-sidebar {
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
    gap: 8px;
    margin: 0 !important;
    padding: 0 !important;
}

/* Giữ icon menu luôn ở giữa, không lệch */
body.vercel-client .side-menu-bt-sidebar .wrapper-menu {
    margin: 0 !important;
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
}

/* --- ĐỒNG BỘ CÁC NÚT BADGE2 (Ví, Đăng nhập, Admin Panel) --- */
body.vercel-client .iq-top-navbar .badge2 {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 32px !important; /* Chiều cao cố định để thọt lỏm giữa khung 56px */
    padding: 0 12px !important;
    font-size: 12px;
    font-weight: 500;
    line-height: 1 !important; /* Tránh line-height cao quá đẩy chữ xuống đáy */
    border: 1px solid var(--vc-border) !important;
    background: var(--vc-surface);
    border-radius: var(--vc-radius-sm) !important; /* Bo góc vừa phải */
    margin: 0 !important;
}

body.vercel-client .iq-top-navbar .badge2.text-primary {
    color: var(--vc-accent) !important;
    border-color: var(--vc-blue-400) !important;
}

body.vercel-client .iq-top-navbar .badge2.text-danger {
    color: var(--vc-danger) !important;
    border-color: var(--vc-red-400) !important;
}

/* Fix nút bật tắt Dark/Light Mode */
body.vercel-client .change-mode {
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
    margin-right: var(--vc-space-3);
}

body.vercel-client .change-mode .custom-control {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
}

body.vercel-client .change-mode .custom-control-label {
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
}

/* Khống chế hàng menu bên phải luôn căn giữa */
body.vercel-client .navbar-nav {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
}

body.vercel-client .navbar-nav .nav-item {
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
}

/* Navbar icon button */
body.vercel-client .iq-top-navbar .search-toggle {
    height: 36px;
    min-width: 36px;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--vc-muted);
    border-radius: var(--vc-radius-sm);
    text-decoration: none !important;
}

body.vercel-client .iq-top-navbar .search-toggle:hover {
    background: var(--vc-surface-hover);
    color: var(--vc-text);
}

/* Dropdown menu */
body.vercel-client .iq-top-navbar .dropdown-menu {
    border: 1px solid var(--vc-border) !important;
    border-radius: var(--vc-radius-md) !important;
    box-shadow: var(--vc-shadow-md);
    background: var(--vc-surface);
    padding: 6px !important;
    margin-top: 8px !important;
}

body.vercel-client .iq-top-navbar .dropdown-item {
    min-height: 36px;
    display: flex !important;
    align-items: center !important;
    gap: 10px;
    padding: 8px 10px !important;
    border-radius: var(--vc-radius-sm);
    color: var(--vc-text);
}

body.vercel-client .iq-top-navbar .dropdown-item:hover {
    background: var(--vc-surface-hover);
}

body.vercel-client .iq-top-navbar .dropdown-item a {
    color: inherit !important;
    text-decoration: none !important;
    font-size: 13px;
    font-weight: 500;
}

body.vercel-client .iq-top-navbar .dropdown-item .svg-icon {
    flex: 0 0 auto;
}

/* Legacy dropdowns used by client sidebar quick actions */
body.vercel-client .iq-sub-dropdown {
    width: 320px;
    padding: 0 !important;
}

body.vercel-client .iq-sub-dropdown .card {
    background: var(--vc-surface);
    border: 0 !important;
    box-shadow: none !important;
}

body.vercel-client .card-header-border {
    border-bottom: 1px solid var(--vc-border);
}

body.vercel-client .dropdown-item-1 {
    border-bottom: 1px solid var(--vc-border);
}

body.vercel-client .dropdown-item-1:last-child {
    border-bottom: 0;
}

/* Client navbar layout: left badges + right theme/menu controls */
body.vercel-client .iq-navbar-custom .navbar {
    flex-wrap: nowrap !important;
    gap: var(--vc-space-3);
    width: 100%;
}

body.vercel-client .side-menu-bt-sidebar,
body.vercel-client .iq-navbar-custom .navbar > .d-flex.align-items-center,
body.vercel-client .vc-navbar-actions {
    display: flex !important;
    align-items: center !important;
    min-width: 0;
}

body.vercel-client .side-menu-bt-sidebar {
    justify-content: flex-start;
    flex: 1 1 auto !important;
    gap: var(--vc-space-2) !important;
}

body.vercel-client .side-menu-bt-sidebar .badge2 {
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.vercel-client .side-menu-bt-sidebar .badge2 b {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.vercel-client .iq-navbar-custom .navbar > .d-flex.align-items-center {
    justify-content: flex-end;
    flex: 0 0 auto;
    gap: var(--vc-space-3);
    height: 100% !important;
    margin-left: auto !important;
    padding: 0 !important;
}

body.vercel-client .vc-navbar-actions {
    gap: var(--vc-space-2);
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-wrap: nowrap;
}

body.vercel-client .vc-navbar-actions .nav-item {
    position: relative;
    flex: 0 0 auto;
}

body.vercel-client .vc-navbar-menu .vc-menu-toggle {
    position: relative;
    width: 36px;
    height: 36px;
    min-width: 36px;
    padding: 0 !important;
}

body.vercel-client .vc-menu-dropdown {
    width: min(280px, calc(100vw - 16px));
    max-height: calc(100vh - 72px);
    overflow-y: auto;
    left: auto !important;
    right: 0 !important;
}

body.vercel-client .vc-menu-dropdown > .dropdown-item {
    margin: 0 var(--vc-space-2);
    flex-wrap: nowrap !important;
    white-space: nowrap;
    overflow: hidden;
}

body.vercel-client .vc-menu-dropdown > .dropdown-item .svg-icon {
    width: 20px !important;
    min-width: 20px;
    flex: 0 0 20px;
}

body.vercel-client .vc-menu-dropdown > .dropdown-item a {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.vercel-client .change-mode {
    transform: translateX(-10px);
}

/* Mobile */
@media (max-width: 991px) {
    body.vercel-client .iq-navbar-custom .navbar {
        gap: var(--vc-space-2);
        padding-left: 6px !important;
        padding-right: 6px !important;
    }

    body.vercel-client .side-menu-bt-sidebar {
        gap: var(--vc-space-1) !important;
    }

    body.vercel-client .iq-navbar-custom .navbar > .d-flex.align-items-center,
    body.vercel-client .vc-navbar-actions {
        gap: var(--vc-space-1);
    }

    body.vercel-client .side-menu-bt-sidebar .wrapper-menu {
        width: 28px !important;
        min-width: 28px !important;
    }

    body.vercel-client .side-menu-bt-sidebar .badge2 {
        min-width: 0;
        max-width: calc(100vw - 165px) !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    body.vercel-client .vc-menu-dropdown {
        right: 0 !important;
        width: min(280px, calc(100vw - 16px)) !important;
    }
}

@media (max-width: 575px) {
    body.vercel-client .iq-navbar-custom .navbar {
        padding-left: 4px !important;
        padding-right: 4px !important;
    }

    body.vercel-client .side-menu-bt-sidebar .badge2 {
        max-width: calc(100vw - 150px) !important;
        padding-left: var(--vc-space-2) !important;
        padding-right: var(--vc-space-2) !important;
    }

    body.vercel-client .iq-navbar-custom .navbar > .d-flex.align-items-center,
    body.vercel-client .vc-navbar-actions {
        gap: 2px;
    }

    body.vercel-client .change-mode {
        transform: translateX(-10px) scale(0.9);
        transform-origin: center;
    }
}

/* =========================================================================
   7. Cards
   ========================================================================= */

body.vercel-client .card {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-md);
    box-shadow: var(--vc-shadow-card);
    margin-bottom: var(--vc-space-6);
}

body.vercel-client .card .card-header {
    background: var(--vc-surface);
    border-bottom: 1px solid var(--vc-border);
    padding: var(--vc-space-4) var(--vc-space-6);
    border-radius: var(--vc-radius-md) var(--vc-radius-md) 0 0;
}

body.vercel-client .card .card-header .card-title,
body.vercel-client .card .card-header h4,
body.vercel-client .card .card-header h5 {
    color: var(--vc-text-primary);
    font-size: 16px;
    font-weight: 600;
    line-height: 24px;
    letter-spacing: -0.32px;
    margin: 0;
}

body.vercel-client .card .card-body {
    padding: var(--vc-space-6);
}

body.vercel-client .card .card-body.p-0 {
    padding: 0;
}

body.vercel-client .card .card-body.p-2 {
    padding: var(--vc-space-4);
}

/* Product card header gradient override — keep the gradient but modernize */
body.vercel-client .card .card-header.card-product {
    border-radius: var(--vc-radius-md) var(--vc-radius-md) 0 0;
}

body.vercel-client .card .card-header.card-product .card-title {
    color: #ffffff !important;
}

/* =========================================================================
   8. Buttons
   ========================================================================= */

body.vercel-client .btn {
    border-radius: var(--vc-radius-sm);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.25;
    padding: 6px 10px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    white-space: normal;
    text-align: center;
    vertical-align: middle;
    transition: background 0ms, border-color 0ms, color 0ms;
}

/* FIX ICON GIỎ HÀNG TỰ ĐỘNG ĐỔI MÀU THEO CHỮ (THÊM VÀO ĐÂY) */
body.vercel-client .btn i {
    color: inherit !important;
}

body.vercel-client .btn.btn-sm {
    min-height: 32px;
    padding: 4px 6px;
    font-size: 14px;
    line-height: 1.25;
}

body.vercel-client .btn.btn-lg {
    min-height: 48px;
    padding: 8px 14px;
    font-size: 16px;
    line-height: 1.25;
}

body.vercel-client .btn.btn-block {
    width: 100%;
}

/* Primary — solid dark fill (Geist primary) */
body.vercel-client .btn-primary {
    background: var(--vc-gray-1000);
    border-color: var(--vc-gray-1000);
    color: var(--vc-bg-100);
}

body.vercel-client .btn-primary:hover {
    background: var(--vc-gray-900);
    border-color: var(--vc-gray-900);
    color: var(--vc-bg-100);
}

body.vercel-client .btn-primary:focus-visible {
    box-shadow: var(--vc-focus-ring);
}

/* Secondary — surface fill with border */
body.vercel-client .btn-secondary {
    background: var(--vc-surface);
    border-color: var(--vc-border-strong);
    color: var(--vc-text-primary);
}

body.vercel-client .btn-secondary:hover {
    background: var(--vc-gray-a-100);
    border-color: var(--vc-gray-a-500);
    color: var(--vc-text-primary);
}

/* Danger — solid red */
body.vercel-client .btn-danger {
    background: var(--vc-danger);
    border-color: var(--vc-danger);
    color: var(--vc-danger-contrast);
}

body.vercel-client .btn-danger:hover {
    background: var(--vc-danger-hover);
    border-color: var(--vc-danger-hover);
    color: var(--vc-danger-contrast);
}

/* Warning — amber */
body.vercel-client .btn-warning {
    background: var(--vc-warning);
    border-color: var(--vc-warning);
    color: #ffffff;
}

body.vercel-client .btn-warning:hover {
    filter: brightness(1.1);
}

/* Info — blue accent */
body.vercel-client .btn-info {
    background: var(--vc-accent);
    border-color: var(--vc-accent);
    color: var(--vc-accent-contrast);
}

body.vercel-client .btn-info:hover {
    background: var(--vc-accent-hover);
    border-color: var(--vc-accent-hover);
}

/* Success — green */
body.vercel-client .btn-success {
    background: var(--vc-success);
    border-color: var(--vc-success);
    color: #ffffff;
}

body.vercel-client .btn-success:hover {
    filter: brightness(1.1);
}

/* Outline variants */
body.vercel-client .btn-outline-primary {
    border-color: var(--vc-blue-400);
    color: var(--vc-accent);
    background: transparent;
}

body.vercel-client .btn-outline-primary:hover {
    background: var(--vc-blue-100);
    border-color: var(--vc-accent);
    color: var(--vc-accent);
}

body.vercel-client .btn-outline-danger {
    border-color: var(--vc-red-400);
    color: var(--vc-danger);
    background: transparent;
}

body.vercel-client .btn-outline-danger:hover {
    background: var(--vc-red-100);
    border-color: var(--vc-danger);
    color: var(--vc-danger);
}

body.vercel-client .btn-outline-info {
    border-color: var(--vc-blue-400);
    color: var(--vc-accent);
    background: transparent;
}

body.vercel-client .btn-outline-info:hover {
    background: var(--vc-blue-100);
    color: var(--vc-accent);
}

body.vercel-client .btn-outline-success {
    border-color: var(--vc-green-400);
    color: var(--vc-success);
    background: transparent;
}

body.vercel-client .btn-outline-success:hover {
    background: var(--vc-green-100);
    color: var(--vc-success);
}

body.vercel-client .btn-outline-warning {
    border-color: var(--vc-amber-400);
    color: var(--vc-warning);
    background: transparent;
}

body.vercel-client .btn-outline-warning:hover {
    background: var(--vc-amber-100);
    color: var(--vc-warning);
}

body.vercel-client .btn-outline-secondary {
    border-color: var(--vc-border-strong);
    color: var(--vc-text-secondary);
    background: transparent;
}

body.vercel-client .btn-outline-secondary:hover {
    background: var(--vc-gray-a-100);
    color: var(--vc-text-primary);
}

/* Disabled */
body.vercel-client .btn:disabled,
body.vercel-client .btn.disabled {
    background: var(--vc-gray-100);
    border-color: var(--vc-gray-200);
    color: var(--vc-text-disabled);
    cursor: not-allowed;
}

/* -------------------------------------------------------------------------
   8b. Dark mode button improvements
   ------------------------------------------------------------------------- */

/* Primary — in dark mode the base is #ededed; hover was falling to #a0a0a0
   which is too dark. Brighten to pure white on hover instead. */
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .btn-primary:hover,
html.color-dark body.vercel-client .btn-primary:hover,
.color-dark body.vercel-client .btn-primary:hover {
    background: #ffffff;
    border-color: #ffffff;
    color: #000000;
}

/* Secondary — hover background in dark mode was nearly invisible
   (rgba 255,255,255,0.07). Use a solid subtle gray instead. */
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .btn-secondary:hover,
html.color-dark body.vercel-client .btn-secondary:hover,
.color-dark body.vercel-client .btn-secondary:hover {
    background: var(--vc-gray-100);
    border-color: var(--vc-gray-a-500);
    color: var(--vc-text-primary);
}

/* Outline secondary — hover background was too subtle in dark mode. */
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .btn-outline-secondary:hover,
html.color-dark body.vercel-client .btn-outline-secondary:hover,
.color-dark body.vercel-client .btn-outline-secondary:hover {
    background: var(--vc-gray-a-200);
    color: var(--vc-text-primary);
}

/* =========================================================================
   9. Forms and inputs
   ========================================================================= */

body.vercel-client .form-control {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border-strong);
    border-radius: var(--vc-radius-sm);
    color: var(--vc-text-primary);
    font-size: 14px;
    line-height: 20px;
    padding: 0 12px;
    height: 40px;
    transition: border-color 0ms, box-shadow 0ms;
}

body.vercel-client .form-control:focus {
    border-color: var(--vc-accent);
    box-shadow: var(--vc-focus-ring);
    background: var(--vc-surface);
    color: var(--vc-text-primary);
}

body.vercel-client .form-control::placeholder {
    color: var(--vc-text-muted);
}

body.vercel-client .form-control-solid {
    background: var(--vc-gray-a-100);
    border-color: var(--vc-border);
}

body.vercel-client .form-control-solid:focus {
    background: var(--vc-surface);
    border-color: var(--vc-accent);
}

body.vercel-client textarea.form-control {
    height: auto;
    min-height: 40px;
    padding: var(--vc-space-3) var(--vc-space-4);
    line-height: 24px;
}

body.vercel-client .form-group label {
    font-size: 14px;
    font-weight: 500;
    color: var(--vc-text-secondary);
    margin-bottom: var(--vc-space-2);
}

body.vercel-client select.form-control {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%238f8f8f' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
}

/* =========================================================================
   10. Tables
   ========================================================================= */

body.vercel-client .table {
    color: var(--vc-text-primary);
    margin-bottom: 0;
    font-size: 14px;
    line-height: 20px;
    border-collapse: separate;
    border-spacing: 0;
}

/* Vercel-style data-table header */
body.vercel-client .table thead th,
body.vercel-client .table .table-color-heading th {
    color: var(--vc-text-muted);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--vc-border-strong);
    border-top: none;
    padding: var(--vc-space-3) var(--vc-space-4);
    background: var(--vc-surface-subtle);
    position: sticky;
    top: 0;
    z-index: 1;
    white-space: nowrap;
}

body.vercel-client .table .thead-dark th {
    background: var(--vc-surface-subtle);
    color: var(--vc-text-secondary);
    border-bottom: 1px solid var(--vc-border-strong);
}

body.vercel-client .table td {
    padding: var(--vc-space-3) var(--vc-space-4);
    border-top: 1px solid var(--vc-border);
    color: var(--vc-text-primary);
    vertical-align: middle;
}

body.vercel-client .table tbody tr:last-child td {
    border-bottom: none;
}

body.vercel-client .table-striped tbody tr:nth-of-type(odd) {
    background: var(--vc-gray-a-100);
}

body.vercel-client .table-hover tbody tr:hover {
    background: var(--vc-gray-a-200);
}

body.vercel-client .table-responsive {
    border-radius: var(--vc-radius-md);
    border: 1px solid var(--vc-border);
}

/* Rental renew history: keep one outer Vercel card, not a nested table frame */
body.vercel-client .rental-renew-history-page .card-body > .table-responsive {
    border: 0;
    border-radius: 0;
}

body.vercel-client .rental-renew-history-page .card-body > .table-responsive .table thead th:first-child {
    border-top-left-radius: 0;
}

body.vercel-client .rental-renew-history-page .card-body > .table-responsive .table thead th:last-child {
    border-top-right-radius: 0;
}

/* Crypto page: one clean Vercel card per section */
body.vercel-client .crypto-page .crypto-deposit-card,
body.vercel-client .crypto-page .crypto-history-card {
    overflow: hidden;
}

body.vercel-client .crypto-page .crypto-hero {
    padding: var(--vc-space-4);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-md);
    background: var(--vc-surface-subtle);
}

body.vercel-client .crypto-page .crypto-hero img {
    display: block;
    width: 100%;
    max-width: 420px;
    height: auto;
    margin: 0 auto;
}

body.vercel-client .crypto-page .crypto-actions {
    padding-top: var(--vc-space-4);
    margin-top: var(--vc-space-4);
    border-top: 1px solid var(--vc-border);
}

body.vercel-client .crypto-page .crypto-filter-form {
    padding: var(--vc-space-4) var(--vc-space-4) 0;
    margin: 0;
}

body.vercel-client .crypto-page .crypto-filter-form .form-control {
    margin-bottom: var(--vc-space-2) !important;
}

body.vercel-client .crypto-page .crypto-history-card .table-responsive {
    border: 0;
    border-radius: 0;
}

body.vercel-client .crypto-page .crypto-history-card .row:last-child {
    padding: var(--vc-space-4);
    margin: 0;
    border-top: 1px solid var(--vc-border);
}

body.vercel-client .crypto-page .crypto-amount {
    color: var(--vc-danger);
}

body.vercel-client .crypto-page .crypto-currency {
    color: var(--vc-success);
}

body.vercel-client .border-top-table {
    border-top: 1px solid var(--vc-border);
}

/* Data-table variant — tighter rows, monospace for numbers */
body.vercel-client .table.data-table thead th {
    font-size: 11px;
    letter-spacing: 0.05em;
}

body.vercel-client .table.data-table td {
    padding: var(--vc-space-2) var(--vc-space-4);
    font-size: 13px;
}

/* =========================================================================
   11. Alerts
   ========================================================================= */

body.vercel-client .alert {
    border-radius: var(--vc-radius-md);
    border: 1px solid var(--vc-border);
    padding: var(--vc-space-4) var(--vc-space-6);
    margin-bottom: var(--vc-space-6);
    display: flex;
    align-items: flex-start;
    gap: var(--vc-space-3);
}

body.vercel-client .alert.bg-white {
    background: var(--vc-surface) !important;
}

body.vercel-client .alert.alert-primary {
    background: var(--vc-blue-100);
    border-color: var(--vc-blue-400);
    color: var(--vc-blue-1000);
}

body.vercel-client .alert.alert-danger {
    background: var(--vc-red-100);
    border-color: var(--vc-red-400);
    color: var(--vc-red-1000);
}

body.vercel-client .alert.alert-success {
    background: var(--vc-green-100);
    border-color: var(--vc-green-400);
    color: var(--vc-green-1000);
}

body.vercel-client .alert.alert-warning {
    background: var(--vc-amber-100);
    border-color: var(--vc-amber-400);
    color: var(--vc-amber-1000);
}

body.vercel-client .iq-alert-icon {
    font-size: 18px;
    line-height: 20px;
    flex-shrink: 0;
}

body.vercel-client .iq-alert-text {
    font-size: 14px;
    line-height: 20px;
    color: inherit;
}

/* =========================================================================
   12. Badges
   ========================================================================= */

body.vercel-client .badge {
    border-radius: var(--vc-radius-full);
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 500;
    line-height: 16px;
}

body.vercel-client .badge-primary {
    background: var(--vc-accent);
    color: var(--vc-accent-contrast);
}

body.vercel-client .badge-danger {
    background: var(--vc-danger);
    color: var(--vc-danger-contrast);
}

body.vercel-client .badge-success {
    background: var(--vc-success);
    color: #ffffff;
}

body.vercel-client .badge-warning {
    background: var(--vc-warning);
    color: #ffffff;
}

body.vercel-client .badge-info {
    background: var(--vc-accent);
    color: var(--vc-accent-contrast);
}

/* =========================================================================
   13. Dropdowns
   ========================================================================= */

body.vercel-client .dropdown-menu,
body.vercel-client .iq-sub-dropdown .dropdown-menu {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-md);
    box-shadow: var(--vc-shadow-popover);
    padding: var(--vc-space-2);
}

body.vercel-client .dropdown-item,
body.vercel-client .iq-sub-dropdown .dropdown-item-1 {
    border-radius: var(--vc-radius-sm);
    padding: var(--vc-space-2) var(--vc-space-3);
    font-size: 14px;
    color: var(--vc-text-secondary);
    transition: background 0ms;
}

body.vercel-client .dropdown-item:hover,
body.vercel-client .iq-sub-dropdown .dropdown-item-1:hover {
    background: var(--vc-gray-a-100);
    color: var(--vc-text-primary);
}

body.vercel-client .iq-sub-dropdown .card {
    border: none;
    box-shadow: none;
    margin: 0;
}

body.vercel-client .iq-sub-dropdown .card-header-border {
    border-bottom: 1px solid var(--vc-border);
    padding: var(--vc-space-3) var(--vc-space-4);
}

/* =========================================================================
   14. Nav pills (category tabs)
   ========================================================================= */

body.vercel-client .nav-pills .nav-link {
    border-radius: var(--vc-radius-full);
    padding: var(--vc-space-2) var(--vc-space-4);
    font-size: 13px;
    font-weight: 500;
    color: var(--vc-text-secondary);
    background: transparent;
    border: 1px solid transparent;
    transition: background 0ms, color 0ms, border-color 0ms;
}

body.vercel-client .nav-pills .nav-link:hover {
    background: var(--vc-gray-a-100);
    color: var(--vc-text-primary);
}

body.vercel-client .nav-pills .nav-link.active {
    background: var(--vc-gray-1000);
    color: var(--vc-bg-100);
    border-color: var(--vc-gray-1000);
}

/* =========================================================================
   15. Product / order blocks
   ========================================================================= */

body.vercel-client .blur-shadow,
body.vercel-client .basic-drop-shadow {
    border-radius: var(--vc-radius-md);
    border: 1px solid var(--vc-border);
    box-shadow: var(--vc-shadow-card);
    background: var(--vc-surface);
    transition: box-shadow 0ms;
}

body.vercel-client .blur-shadow:hover,
body.vercel-client .basic-drop-shadow:hover {
    box-shadow: var(--vc-shadow-popover);
}

body.vercel-client .shadow-showcase {
    border-radius: var(--vc-radius-md);
}

body.vercel-client .shop-product-section {
    overflow: hidden;
}

body.vercel-client .shop-category-header {
    display: flex;
    align-items: center;
    gap: var(--vc-space-2);
    padding: var(--vc-space-4) var(--vc-space-6);
    border-bottom: 1px solid var(--vc-border);
    color: var(--vc-text-primary);
    font-size: 14px;
    font-weight: 600;
}

body.vercel-client .shop-category-header img {
    width: 30px;
    height: 30px;
    object-fit: contain;
    flex: 0 0 30px;
}

body.vercel-client .shop-product-grid {
    margin: calc(var(--vc-space-2) * -1);
}

body.vercel-client .shop-product-card-col {
    padding: var(--vc-space-2);
}

body.vercel-client .shop-product-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: var(--vc-space-3);
    padding: var(--vc-space-4);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-md);
    background: var(--vc-surface);
    box-shadow: var(--vc-shadow-card);
}

body.vercel-client .shop-product-card:hover {
    box-shadow: var(--vc-shadow-popover);
}

body.vercel-client .shop-product-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--vc-space-3);
}

body.vercel-client .shop-product-title-wrap {
    min-width: 0;
    display: flex;
    align-items: flex-start;
    gap: var(--vc-space-2);
}

body.vercel-client .shop-product-icon {
    width: 25px;
    height: 25px;
    object-fit: contain;
    flex: 0 0 25px;
}

body.vercel-client .shop-product-copy {
    min-width: 0;
}

body.vercel-client .shop-product-copy h6 {
    margin: 0;
    color: var(--vc-text-primary);
    font-size: 14px;
    font-weight: 600;
    line-height: 20px;
}

body.vercel-client .shop-product-copy p {
    margin: var(--vc-space-1) 0 0;
    color: var(--vc-text-muted) !important;
    font-size: 12px;
    line-height: 18px;
}

body.vercel-client .shop-product-rating {
    flex: 0 0 auto;
    white-space: nowrap;
    line-height: 20px;
}

body.vercel-client .shop-product-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--vc-space-2);
}

body.vercel-client .shop-product-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--vc-space-1);
    min-height: 28px;
    padding: 0 var(--vc-space-2);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-sm);
    color: var(--vc-text-secondary);
    background: var(--vc-surface-subtle);
    font-size: 12px;
    line-height: 1;
}

body.vercel-client .shop-product-pill-price {
    color: var(--vc-danger);
    border-color: var(--vc-red-400);
}

body.vercel-client .shop-product-pill-stock {
    color: var(--vc-accent);
    border-color: var(--vc-blue-400);
}

body.vercel-client .shop-product-pill-sold,
body.vercel-client .shop-product-pill-preview {
    color: var(--vc-success);
    border-color: var(--vc-green-400);
}

body.vercel-client .shop-product-pill-country {
    color: var(--vc-warning);
    border-color: var(--vc-amber-400);
}

body.vercel-client .shop-product-actions {
    margin-top: auto;
}

body.vercel-client .shop-product-actions .btn {
    width: 100%;
}

/* Template 2 LIST/BOX responsive wrapper */
body.vercel-client .product-template2-wrapper p {
    color: var(--vc-text-secondary) !important; /* Dùng !important để đè chết mấy cái màu kế thừa cũ */
}

/* Desktop table wrapper: trong suốt, không tự tạo card riêng */
body.vercel-client .product-template2-table-wrap {
    border: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}

/* Table base */
body.vercel-client .product-template2-table {
    width: 100%;
    margin: 0 !important;
    border-collapse: separate;
    border-spacing: 0;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* Xóa mọi nền/border bootstrap table */
body.vercel-client .product-template2-table,
body.vercel-client .product-template2-table thead,
body.vercel-client .product-template2-table tbody,
body.vercel-client .product-template2-table tr,
body.vercel-client .product-template2-table th,
body.vercel-client .product-template2-table td {
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
}

/* Header table */
body.vercel-client .product-template2-table-head th {
    background: transparent !important;
    color: var(--vc-text-primary) !important;
    border-top: 0 !important;
    border-bottom: 1px solid transparent !important;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
    vertical-align: middle;
}

/* Body cell - Cập nhật chuẩn Vercel Style (Thanh mảnh & Sắc nét) */
body.vercel-client .product-template2-table tbody td {
    background: transparent !important;
    color: var(--vc-text-secondary) !important; /* Đảm bảo đè màu thành công */
    border-top: 0 !important;
    border-bottom: 1px solid var(--vc-gray-200, #eaeaea) !important; /* Tạo đường gạch chân mỏng để phân hàng */
    vertical-align: middle !important;
    
    /* CHÌA KHÓA FIX LỖI: Ép font chữ mảnh lại, xóa bỏ mọi thuộc tính dày thô cũ */
    font-weight: 400 !important; 
    font-size: 14px !important;   /* Tầm 0.875rem đến 14px là kích thước chữ tiêu chuẩn */
    letter-spacing: -0.1px !important; /* Hơi co khoảng cách chữ lại một chút kiểu UI hiện đại */
}

/* Last row */
body.vercel-client .product-template2-table tbody tr:last-child td {
    border-bottom: 0 !important;
}

/* Hover vẫn nhẹ kiểu Vercel, nhưng không tạo nền table dày */
body.vercel-client .product-template2-table tbody tr:hover td {
    background: rgba(0, 0, 0, 0.025) !important;
}

/* Nếu không thích hover thì đổi block trên thành transparent */

/* Chặn Bootstrap .table td/th border-top */
body.vercel-client .table.product-template2-table td,
body.vercel-client .table.product-template2-table th {
    border-top: 0 !important;
}

/* Giữ table không tràn card */
body.vercel-client .table-responsive.product-template2-table-wrap {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: auto;
}

/* Mobile card giữ như cũ */
@media (max-width: 767.98px) and (hover: none) {
    body.vercel-client .product-template2-wrapper .basic-drop-shadow {
        transition:
            transform .15s ease,
            box-shadow .15s ease;
    }

    body.vercel-client .product-template2-wrapper .basic-drop-shadow:active {
        transform: scale(.985);
        box-shadow: var(--vc-shadow-card);
    }
}

body.vercel-client .product-template2-mobile-title {
    display: flex;
    align-items: center;
    margin: 0 15px 12px;
    padding: 12px 14px;
    border: 1px solid var(--vc-border);
    border-radius: 12px;
    background: var(--vc-surface);
    color: var(--vc-text-primary);
    font-size: 14px;
    font-weight: 600;
}

@media (min-width: 768px) {
    body.vercel-client .product-template2-mobile-title {
        display: none;
    }
}
/* =========================================================================
   16. Modals
   ========================================================================= */

body.vercel-client .modal-content {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-lg);
    box-shadow: var(--vc-shadow-modal);
}

body.vercel-client .modal-header {
    border-bottom: 1px solid var(--vc-border);
    padding: var(--vc-space-4) var(--vc-space-6);
}

body.vercel-client .modal-header .modal-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--vc-text-primary);
}

body.vercel-client .modal-body {
    padding: var(--vc-space-6);
    color: var(--vc-text-primary);
}

body.vercel-client .modal-footer {
    border-top: 1px solid var(--vc-border);
    padding: var(--vc-space-4) var(--vc-space-6);
    background: var(--vc-surface-subtle);
    border-bottom-left-radius: var(--vc-radius-lg);
    border-bottom-right-radius: var(--vc-radius-lg);
}

/* =========================================================================
   17. Footer
   ========================================================================= */

body.vercel-client .iq-footer {
    background: var(--vc-surface);
    border-top: 1px solid var(--vc-border);
    padding: var(--vc-space-3) var(--vc-space-6);
    color: var(--vc-text-muted);
    font-size: 13px;
}

body.vercel-client .iq-footer a {
    color: var(--vc-text-secondary);
}

body.vercel-client .iq-footer a:hover {
    color: var(--vc-text-primary);
}

/* =========================================================================
   18. Misc — loading, text helpers, marquee
   ========================================================================= */

body.vercel-client #loading {
    background: var(--vc-surface-subtle);
}

body.vercel-client .text-secondary {
    color: var(--vc-text-secondary) !important;
}

body.vercel-client .text-muted {
    color: var(--vc-text-muted) !important;
}

body.vercel-client .text-primary {
    color: var(--vc-accent) !important;
}

body.vercel-client .text-danger {
    color: var(--vc-danger) !important;
}

body.vercel-client .text-success {
    color: var(--vc-success) !important;
}

body.vercel-client .text-warning {
    color: var(--vc-warning) !important;
}

body.vercel-client .bg-primary {
    background: var(--vc-accent) !important;
    color: var(--vc-accent-contrast) !important;
}

body.vercel-client .bg-white {
    background: var(--vc-surface) !important;
}

/* =========================================================================
   19. Responsive — mobile spacing
   ========================================================================= */

@media (max-width: 600px) {
    body.vercel-client .content-page {
        padding: var(--vc-space-3) var(--vc-space-3) var(--vc-space-10);
    }

    body.vercel-client .content-page > .container-fluid {
        padding-left: var(--vc-space-2);
        padding-right: var(--vc-space-2);
    }

    body.vercel-client .card {
        margin-bottom: var(--vc-space-4);
    }

    body.vercel-client .card .card-body {
        padding: var(--vc-space-4);
    }

    body.vercel-client .card .card-header {
        padding: var(--vc-space-3) var(--vc-space-4);
    }

    body.vercel-client .alert {
        padding: var(--vc-space-3) var(--vc-space-4);
    }

    body.vercel-client .modal-header,
    body.vercel-client .modal-body,
    body.vercel-client .modal-footer {
        padding: var(--vc-space-4);
    }

    body.vercel-client .table thead th,
    body.vercel-client .table td {
        padding: var(--vc-space-2) var(--vc-space-3);
        font-size: 13px;
    }
}

/* =========================================================================
   20. Semantic utility classes
   Replace hardcoded inline colors with reusable, theme-aware classes.
   Work in both light and dark mode via CSS variables.
   ========================================================================= */

/* Wallet balance — highlighted monetary value (sidebar, nav) */
body.vercel-client .wallet-balance {
    color: var(--vc-amber-700);
    font-weight: 600;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .wallet-balance,
html.color-dark body.vercel-client .wallet-balance,
.color-dark body.vercel-client .wallet-balance {
    color: var(--vc-amber-700);
}

/* Discount rate — percentage label (sidebar) */
body.vercel-client .discount-rate {
    color: var(--vc-danger);
    font-weight: 600;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .discount-rate,
html.color-dark body.vercel-client .discount-rate,
.color-dark body.vercel-client .discount-rate {
    color: var(--vc-red-700);
}

/* Status: success — green (completed, confirmed, positive amounts) */
body.vercel-client .status-success {
    color: var(--vc-success);
    font-weight: 600;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .status-success,
html.color-dark body.vercel-client .status-success,
.color-dark body.vercel-client .status-success {
    color: var(--vc-green-700);
}

/* Status: danger — red (cancelled, failed, prices, negative amounts) */
body.vercel-client .status-danger {
    color: var(--vc-danger);
    font-weight: 600;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .status-danger,
html.color-dark body.vercel-client .status-danger,
.color-dark body.vercel-client .status-danger {
    color: var(--vc-red-700);
}

/* Status: warning — amber/yellow (pending, waiting) */
body.vercel-client .status-warning {
    color: var(--vc-warning);
    font-weight: 600;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .status-warning,
html.color-dark body.vercel-client .status-warning,
.color-dark body.vercel-client .status-warning {
    color: var(--vc-amber-700);
}

/* Status: info — blue (transaction IDs, neutral amounts) */
body.vercel-client .status-info {
    color: var(--vc-accent);
    font-weight: 600;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .status-info,
html.color-dark body.vercel-client .status-info,
.color-dark body.vercel-client .status-info {
    color: var(--vc-blue-900);
}

/* Card title on gradient header — white text on colored backgrounds */
body.vercel-client .card-title-on-gradient {
    color: #ffffff !important;
}

/* =========================================================================
   21. QA fixes — visual consistency for edge cases
   ========================================================================= */

/* --- Bootstrap text utilities that need dark-mode awareness --- */

body.vercel-client .text-dark {
    color: var(--vc-text-primary) !important;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .text-dark,
html.color-dark body.vercel-client .text-dark,
.color-dark body.vercel-client .text-dark {
    color: var(--vc-text-primary) !important;
}

body.vercel-client .text-white {
    color: #ffffff;
}

/* --- Bootstrap bg-light needs dark-mode override --- */

body.vercel-client .bg-light {
    background: var(--vc-surface-subtle) !important;
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .bg-light,
html.color-dark body.vercel-client .bg-light,
.color-dark body.vercel-client .bg-light {
    background: var(--vc-gray-100) !important;
}

/* --- Card footer --- */

body.vercel-client .card-footer {
    background: var(--vc-surface-subtle);
    border-top: 1px solid var(--vc-border);
    padding: var(--vc-space-4) var(--vc-space-6);
    border-radius: 0 0 var(--vc-radius-md) var(--vc-radius-md);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .card-footer,
html.color-dark body.vercel-client .card-footer,
.color-dark body.vercel-client .card-footer {
    background: var(--vc-bg-200);
    border-top-color: var(--vc-gray-a-300);
}

/* --- Table-bordered variant --- */

body.vercel-client .table-bordered,
body.vercel-client .table-bordered td,
body.vercel-client .table-bordered th {
    border: 1px solid var(--vc-border);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table-bordered,
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table-bordered td,
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .table-bordered th,
html.color-dark body.vercel-client .table-bordered,
html.color-dark body.vercel-client .table-bordered td,
html.color-dark body.vercel-client .table-bordered th,
.color-dark body.vercel-client .table-bordered,
.color-dark body.vercel-client .table-bordered td,
.color-dark body.vercel-client .table-bordered th {
    border-color: var(--vc-gray-a-200);
}

/* --- Profile page components --- */

body.vercel-client .profile-box {
    background: var(--vc-surface);
    border-radius: var(--vc-radius-md);
}

body.vercel-client .profile-card {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-md);
    padding: var(--vc-space-6);
}

body.vercel-client .pro-content {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border);
    border-radius: var(--vc-radius-md);
    padding: var(--vc-space-6);
}

body.vercel-client .profile-box .p-icon {
    color: var(--vc-accent);
}

body.vercel-client .profile-box .eml {
    color: var(--vc-text-secondary);
}

/* --- Nav pills horizontal scroll on mobile --- */

body.vercel-client .nav-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}

body.vercel-client .nav-pills .nav-item {
    flex-shrink: 0;
}

/* --- Alert with bg-warning/bg-primary text-white --- */

body.vercel-client .alert.bg-warning {
    background: var(--vc-amber-100) !important;
    border-color: var(--vc-amber-400) !important;
    color: var(--vc-amber-1000) !important;
}

body.vercel-client .alert.bg-warning .iq-alert-text,
body.vercel-client .alert.bg-warning {
    color: var(--vc-amber-1000);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .alert.bg-warning,
html.color-dark body.vercel-client .alert.bg-warning,
.color-dark body.vercel-client .alert.bg-warning {
    background: rgba(255, 174, 0, 0.1) !important;
    border-color: var(--vc-amber-700) !important;
    color: var(--vc-amber-700) !important;
}

body.vercel-client .alert.text-white.bg-primary {
    background: var(--vc-accent) !important;
    color: var(--vc-accent-contrast) !important;
    border-color: var(--vc-accent) !important;
}

/* --- Marquee alert text color --- */

body.vercel-client .alert.text-white.bg-primary marquee,
body.vercel-client .alert.text-white.bg-primary * {
    color: #ffffff;
}

/* --- Rental-renew page: container outside content-page --- */

body.vercel-client .container {
    max-width: 760px;
    padding-top: var(--vc-space-8);
    padding-bottom: var(--vc-space-16);
}

body.vercel-client .container > .card {
    margin-bottom: 0;
}

body.vercel-client .container > .card.shadow-sm {
    box-shadow: var(--vc-shadow-card);
}

body.vercel-client .container > .card.border-0 {
    border: 1px solid var(--vc-border) !important;
}

body.vercel-client .container > .card .card-header.border-bottom {
    border-bottom: 1px solid var(--vc-border);
}

body.vercel-client .container > .card .card-header.border-0 {
    border-bottom: 1px solid var(--vc-border) !important;
}

/* --- Form-control-lg sizing --- */

body.vercel-client .form-control-lg {
    min-height: 48px;
    font-size: 16px;
    padding: 8px 12px;
    border-radius: var(--vc-radius-sm);
}

/* --- Shadow-sm override (used in rental-renew) --- */

body.vercel-client .shadow-sm {
    box-shadow: var(--vc-shadow-card) !important;
}

/* --- HR styling --- */

body.vercel-client hr {
    border: none;
    border-top: 1px solid var(--vc-border);
    margin: var(--vc-space-6) 0;
}

body.vercel-client .card-body hr,
body.vercel-client .card-body .hr {
    border: none;
    border-top: 1px solid var(--vc-border);
    margin: var(--vc-space-4) 0;
}

/* --- Border-left accent (rental-renew info section) --- */

body.vercel-client .border-left {
    border-left: 1px solid var(--vc-border) !important;
}

body.vercel-client .border-primary {
    border-color: var(--vc-accent) !important;
}

/* --- Badge secondary (rental-renew product name) --- */

body.vercel-client .badge-secondary {
    background: var(--vc-gray-a-200);
    color: var(--vc-text-secondary);
    border: 1px solid var(--vc-border);
}

body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .badge-secondary,
html.color-dark body.vercel-client .badge-secondary,
.color-dark body.vercel-client .badge-secondary {
    background: var(--vc-gray-a-200);
    color: var(--vc-text-secondary);
    border-color: var(--vc-gray-a-300);
}

/* --- Badge with padding (px-2 py-1) --- */

body.vercel-client .badge.px-2,
body.vercel-client .badge.py-1 {
    border-radius: var(--vc-radius-sm);
}

/* --- Close button in modals --- */

body.vercel-client .close {
    color: var(--vc-text-muted);
    opacity: 0.7;
    text-shadow: none;
}

body.vercel-client .close:hover {
    color: var(--vc-text-primary);
    opacity: 1;
}

/* --- Small text helper --- */

body.vercel-client small,
body.vercel-client .small {
    color: var(--vc-text-muted);
}

/* --- Font-weight helpers --- */

body.vercel-client .font-weight-bold,
body.vercel-client .fw-bold {
    font-weight: 600;
}

/* --- Responsive: 375px mobile fixes --- */

@media (max-width: 400px) {
    body.vercel-client .content-page {
        padding: var(--vc-space-2) var(--vc-space-2) var(--vc-space-8);
    }

    body.vercel-client .content-page > .container-fluid {
        padding-left: var(--vc-space-1);
        padding-right: var(--vc-space-1);
    }

    body.vercel-client .card {
        margin-bottom: var(--vc-space-3);
        border-radius: var(--vc-radius-sm);
    }

    body.vercel-client .card .card-body {
        padding: var(--vc-space-3);
    }

    body.vercel-client .card .card-header {
        padding: var(--vc-space-2) var(--vc-space-3);
    }

    body.vercel-client .card .card-header .card-title,
    body.vercel-client .card .card-header h4,
    body.vercel-client .card .card-header h5 {
        font-size: 14px;
    }

    body.vercel-client .alert {
        padding: var(--vc-space-2) var(--vc-space-3);
        margin-bottom: var(--vc-space-3);
        font-size: 13px;
    }

    body.vercel-client .btn {
        min-height: 36px;
        font-size: 13px;
        padding: 4px 8px;
    }

    body.vercel-client .btn.btn-sm {
        min-height: 30px;
        font-size: 12px;
    }

    body.vercel-client .btn.btn-lg {
        min-height: 42px;
        font-size: 14px;
        padding: 6px 10px;
    }

    body.vercel-client .table thead th,
    body.vercel-client .table td {
        padding: var(--vc-space-1) var(--vc-space-2);
        font-size: 12px;
    }

    body.vercel-client .nav-pills .nav-link {
        padding: var(--vc-space-1) var(--vc-space-3);
        font-size: 12px;
    }

    body.vercel-client > .container {
        padding-left: var(--vc-space-2);
        padding-right: var(--vc-space-2);
    }

    body.vercel-client .profile-card {
        padding: var(--vc-space-4);
    }

    body.vercel-client .pro-content {
        padding: var(--vc-space-4);
    }
}

/* --- Desktop 1440px: widen container --- */

@media (min-width: 1400px) {
    body.vercel-client .content-page > .container-fluid {
        max-width: 1400px;
    }
}
@media (min-width: 768px) {
    body.vercel-client .product-template2-wrapper {
        margin-left: 15px;
        margin-right: 15px;
    }
}
/* =========================================================================
   GRID & CARDS - ABSOLUTE CENTER ALIGNMENT FIX
   ========================================================================= */

/* Container bám sát và đồng bộ hoàn hảo với padding của main layout */
body.vercel-client .vc-grid-container {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
    gap: 12px !important; 
    width: 100% !important; 
    max-width: 100% !important; 
    margin: 0 auto 20px auto !important;
    box-sizing: border-box !important;
    
    /* FIX: Thêm padding 2 bên trái/phải đúng 16px để đồng bộ với các wrapper khác */
    padding: 0 16px !important; 
}

/* Style nền tảng cho mỗi Card Button */
body.vercel-client .vc-card-btn {
    display: flex !important;
    align-items: center !important;
    /* FIX: Ép toàn bộ cụm icon + text phải canh giữa theo chiều ngang của nút */
    justify-content: center !important; 
    height: 84px !important; 
    padding: 0 16px !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    position: relative !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    width: 100% !important; 
    border: 1px solid var(--vc-gray-400) !important; 
    transition: transform 0.2s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.2s ease !important;
}

/* Khối trắng chứa Icon - Giữ nguyên kích thước và chống bóp méo */
body.vercel-client .vc-card-btn .vc-icon-wrapper {
    background-color: #ffffff !important;
    width: 46px !important; 
    height: 46px !important;
    border-radius: 10px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-right: 12px !important; /* Khoảng cách vừa phải với text bên phải */
    flex-shrink: 0 !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1) !important;
    box-sizing: border-box !important;
}

/* Giới hạn nghiêm ngặt kích thước ảnh img và svg con */
body.vercel-client .vc-card-btn .vc-icon-wrapper img,
body.vercel-client .vc-card-btn .vc-icon-wrapper svg {
    width: 26px !important;
    height: 26px !important;
    max-width: 26px !important;
    max-height: 26px !important;
    object-fit: contain !important;
    display: block !important;
    flex-shrink: 0 !important;
}

/* Khối text bên trong */
body.vercel-client .vc-card-btn .vc-text-wrapper {
    display: flex !important;
    flex-direction: column !important;
    /* FIX: Đảm bảo các dòng chữ được căn gióng đều theo trục dọc */
    justify-content: center !important; 
    align-items: flex-start !important; /* Giữ chữ thẳng hàng bên trái so với khối text */
    color: #ffffff !important; 
    min-width: 0 !important; 
    /* Bỏ flex-grow: 1 để khối text ôm sát chữ, giúp tổ hợp (Icon + Chữ) nhảy vào tâm nút */
    flex-grow: 0 !important; 
}

body.vercel-client .vc-card-btn .vc-text-wrapper .vc-title {
    font-size: 14px !important; 
    font-weight: 700 !important;
    margin: 0 0 2px 0 !important;
    padding: 0 !important;
    letter-spacing: -0.2px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important; 
    white-space: nowrap !important;
    line-height: 1.2 !important;
}

body.vercel-client .vc-card-btn .vc-text-wrapper .vc-subtitle {
    font-size: 11px !important;
    opacity: 0.85 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
}

/* Hover nhấc nhẹ */
body.vercel-client .vc-card-btn:hover {
    transform: translateY(-3px) !important;
}

/* --- HỆ THỐNG GRADIENT BACKGROUND --- */
body.vercel-client .vc-card-green { background: linear-gradient(135deg, #009640 0%, #005a5b 100%) !important; }
body.vercel-client .vc-card-orange { background: linear-gradient(135deg, #bd651a 0%, #707b00 100%) !important; }
body.vercel-client .vc-card-blue { background: linear-gradient(135deg, #4d83ff 0%, #154294 100%) !important; }
body.vercel-client .vc-card-purple { background: linear-gradient(135deg, #a855f7 0%, #4c1d95 100%) !important; }

/* Dark theme */
body.vercel-client:is(.dark, .color-dark, [data-theme="dark"]) .vc-card-btn,
html.color-dark body.vercel-client .vc-card-btn,
.color-dark body.vercel-client .vc-card-btn {
    border-color: transparent !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4) !important;
}
/* =========================================================================
   21. TempMail — scoped under .tm-page (Vercel Style Standardized)
   ========================================================================= */
body.vercel-client .tm-page .tm-notice {
    background: var(--vc-bg-100);
    border: 1px solid var(--vc-gray-300);
    border-left: 4px solid var(--vc-link);
    border-radius: var(--vc-radius-md);
    padding: 16px 20px;
    margin-bottom: 24px;
    box-shadow: var(--vc-shadow-card);
}
body.vercel-client .tm-page .tm-notice h5 {
    color: var(--vc-text-primary);
    margin-bottom: 8px;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: -0.2px;
}
body.vercel-client .tm-page .tm-notice .tm-price-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    font-size: 14px;
}
body.vercel-client .tm-page .tm-notice .tm-price-row span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--vc-text-secondary);
}
body.vercel-client .tm-page .tm-notice .tm-price-row .badge-price {
    background: var(--vc-accent);
    color: var(--vc-accent-contrast);
    padding: 2px 8px;
    border-radius: var(--vc-radius-sm);
    font-weight: 500;
    font-size: 12px;
}
body.vercel-client .tm-page .tm-notice .tm-warn {
    color: var(--vc-error);
    font-weight: 500;
    margin-top: 8px;
    font-size: 13px;
}
body.vercel-client .tm-page .tm-sidebar {
    background: var(--vc-bg-100);
    border: 1px solid var(--vc-gray-300);
    border-radius: var(--vc-radius-md);
    padding: 12px;
    margin-bottom: 16px;
}
body.vercel-client .tm-page .tm-top-actions {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}
body.vercel-client .tm-page .tm-top-actions button {
    flex: 1;
    padding: 8px 12px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-gray-400);
    background: var(--vc-bg-100);
    color: var(--vc-text-secondary);
    font-weight: 500;
    font-size: 14px;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
body.vercel-client .tm-page .tm-top-actions button:hover {
    background: var(--vc-bg-200);
    color: var(--vc-text-primary);
    border-color: var(--vc-gray-500);
}
body.vercel-client .tm-page .tm-top-actions button.btn-create {
    background: var(--vc-accent);
    color: var(--vc-accent-contrast);
    border-color: var(--vc-accent);
    font-weight: 500;
}
body.vercel-client .tm-page .tm-top-actions button.btn-create:hover {
    background: var(--vc-accent-hover);
    border-color: var(--vc-accent-hover);
}
body.vercel-client .tm-page .tm-limit {
    text-align: center;
    margin-bottom: 12px;
    font-size: 13px;
    color: var(--vc-text-muted);
}
body.vercel-client .tm-page .tm-email-card {
    cursor: pointer;
    padding: 10px 12px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-gray-200);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    transition: background 0.15s ease, border-color 0.15s ease;
    margin-bottom: 6px;
    background: var(--vc-bg-100);
}
body.vercel-client .tm-page .tm-email-card:hover {
    background: var(--vc-bg-200);
    border-color: var(--vc-gray-400);
}
body.vercel-client .tm-page .tm-email-card.active {
    background: var(--vc-gray-100);
    border-color: var(--vc-gray-1000);
}
body.vercel-client .tm-page .tm-card-address {
    font-weight: 600;
    font-size: 14px;
    margin: 6px 0;
    word-break: break-all;
    color: var(--vc-text-primary);
}
body.vercel-client .tm-page .tm-card-meta {
    font-size: 12px;
    color: var(--vc-text-muted);
}
body.vercel-client .tm-page .tm-badge {
    font-size: 11px;
    padding: 2px 6px;
    border-radius: var(--vc-radius-sm);
    background: var(--vc-gray-200);
    color: var(--vc-text-secondary);
    font-weight: 600;
    border: 1px solid var(--vc-gray-300);
}
body.vercel-client .tm-page .tm-badge-muted {
    background: var(--vc-gray-200);
    color: var(--vc-text-muted);
    font-weight: 500;
}
body.vercel-client .tm-page .tm-empty-state {
    text-align: center;
    padding: 32px 16px;
    color: var(--vc-text-muted);
}
body.vercel-client .tm-page .tm-empty-state i {
    font-size: 32px;
    margin-bottom: 8px;
    display: block;
    color: var(--vc-gray-500);
}
body.vercel-client .tm-page .tm-inbox-wrap {
    background: var(--vc-bg-100);
    border: 1px solid var(--vc-gray-300);
    border-radius: var(--vc-radius-md);
    padding: 16px;
}
body.vercel-client .tm-page .tm-inbox-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--vc-gray-300);
}
body.vercel-client .tm-page .tm-selected-info {
    display: flex;
    align-items: center;
    gap: 12px;
}
body.vercel-client .tm-page .tm-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--vc-accent);
    color: var(--vc-accent-contrast);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 14px;
}
body.vercel-client .tm-page .tm-online {
    font-size: 12px;
    color: var(--vc-link);
    font-weight: 600;
}
body.vercel-client .tm-page .tm-selected-address {
    font-weight: 600;
    font-size: 15px;
    word-break: break-all;
    color: var(--vc-text-primary);
}
body.vercel-client .tm-page .tm-header-actions {
    display: flex;
    gap: 6px;
}
body.vercel-client .tm-page .tm-header-actions button {
    width: 34px;
    height: 34px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-gray-400);
    background: var(--vc-bg-100);
    color: var(--vc-text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
}
body.vercel-client .tm-page .tm-header-actions button:hover {
    background: var(--vc-bg-200);
    color: var(--vc-text-primary);
    border-color: var(--vc-gray-500);
}
body.vercel-client .tm-page .tm-msg-item {
    cursor: pointer;
    padding: 10px 12px;
    border-bottom: 1px solid var(--vc-gray-200);
    transition: background 0.15s ease;
}
body.vercel-client .tm-page .tm-msg-item:hover {
    background: var(--vc-bg-200);
}
body.vercel-client .tm-page .tm-msg-from {
    font-weight: 600;
    font-size: 14px;
    color: var(--vc-text-primary);
}
body.vercel-client .tm-page .tm-msg-subject {
    font-size: 13px;
    color: var(--vc-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
body.vercel-client .tm-page .tm-msg-time {
    font-size: 12px;
    color: var(--vc-text-muted);
    white-space: nowrap;
}
body.vercel-client .tm-page .tm-msg-body iframe,
body.vercel-client .tm-page .tm-msg-body img {
    max-width: 100%;
}

body.vercel-client .tm-page .tm-guide-group {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
}

/* Provider badges (Chuyển sang dải màu token xám phẳng chuẩn Vercel) */
body.vercel-client .tm-page .tm-badge-gmail { background: var(--vc-accent); color: var(--vc-accent-contrast); border: none; }
body.vercel-client .tm-page .tm-badge-outlook { background: var(--vc-gray-900); color: var(--vc-bg-100); border: none; }
body.vercel-client .tm-page .tm-badge-domain { background: var(--vc-gray-200); color: var(--vc-gray-1000); }
body.vercel-client .tm-page .tm-badge-active { background: var(--vc-gray-1000); color: var(--vc-bg-100); border: none; }

/* TempMail pagination: sidebar + history */
body.vercel-client .tm-sidebar-pagination,
body.vercel-client .tm-history-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 4px;
    margin-top: 8px;
    border-top: 1px solid var(--vc-gray-300);
}

body.vercel-client .tm-sidebar-pagination button,
body.vercel-client .tm-history-pagination button {
    padding: 6px 10px !important;
    border-radius: var(--vc-radius-sm) !important;
    border: 1px solid var(--vc-gray-400) !important;
    background: var(--vc-bg-100) !important;
    color: var(--vc-text-secondary) !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    cursor: pointer;
    transition: all 0.15s ease;
    box-shadow: none !important;
}

body.vercel-client .tm-sidebar-pagination button:hover:not(:disabled),
body.vercel-client .tm-history-pagination button:hover:not(:disabled) {
    background: var(--vc-bg-200) !important;
    color: var(--vc-text-primary) !important;
    border-color: var(--vc-gray-500) !important;
}

body.vercel-client .tm-sidebar-pagination button:disabled,
body.vercel-client .tm-history-pagination button:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

body.vercel-client .tm-sidebar-pagination span,
body.vercel-client .tm-history-pagination span {
    font-size: 13px;
    color: var(--vc-text-secondary);
    font-weight: 500;
}

/* Selected email improvements (Sử dụng độ tương phản cao đơn sắc thay thế màu xanh thô) */
body.vercel-client .tm-page .tm-email-card.active {
    background: var(--vc-bg-200);
    border-color: var(--vc-gray-900);
    box-shadow: 0 0 0 1px var(--vc-gray-900);
}
body.vercel-client .tm-page .tm-email-card.active .tm-card-address {
    color: var(--vc-text-primary);
}

/* Empty states */
body.vercel-client .tm-page .tm-empty-state p {
    margin: 8px 0 0;
    font-size: 14px;
}

/* Local loading */
body.vercel-client .tm-local-loading {
    text-align: center;
    padding: 24px 16px;
    color: var(--vc-text-muted);
}
body.vercel-client .tm-local-loading i {
    margin-bottom: 8px;
    display: block;
}

/* Custom create modal overlay */
body.vercel-client .tm-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(2px);
    z-index: 1050;
    align-items: center;
    justify-content: center;
    padding: 16px;
}
body.vercel-client .tm-modal-overlay.open {
    display: flex;
}
body.vercel-client .tm-create-modal {
    background: var(--vc-bg-100);
    border: 1px solid var(--vc-gray-300);
    border-radius: var(--vc-radius-lg);
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--vc-shadow-modal);
}
body.vercel-client .tm-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--vc-gray-300);
}
body.vercel-client .tm-modal-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: -0.3px;
    color: var(--vc-text-primary);
}
body.vercel-client .tm-modal-close {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    color: var(--vc-text-muted);
    transition: color 0.1s ease;
}
body.vercel-client .tm-modal-close:hover {
    color: var(--vc-text-primary);
}
body.vercel-client .tm-field {
    padding: 12px 20px;
}
body.vercel-client .tm-label-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}
body.vercel-client .tm-field-label {
    display: block;
    font-weight: 500;
    font-size: 14px;
    color: var(--vc-text-primary);
}
body.vercel-client .tm-field input[type="text"],
body.vercel-client .tm-field input[type="number"],
body.vercel-client .tm-field select {
    width: 100%;
    padding: 8px 12px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-gray-400);
    background: var(--vc-bg-100);
    color: var(--vc-text-primary);
    font-size: 14px;
    box-sizing: border-box;
    transition: border-color 0.15s ease;
}
body.vercel-client .tm-field input:focus,
body.vercel-client .tm-field select:focus {
    outline: none;
    border-color: var(--vc-gray-600);
}
body.vercel-client .tm-clear-btn {
    background: none;
    border: none;
    color: var(--vc-link);
    font-weight: 500;
    cursor: pointer;
    font-size: 13px;
}
body.vercel-client .tm-option-grid {
    display: grid;
    gap: 8px;
}
body.vercel-client .tm-option-grid.col2 { grid-template-columns: 1fr 1fr; }
body.vercel-client .tm-option-grid.col3 { grid-template-columns: 1fr 1fr 1fr; }
body.vercel-client .tm-option-btn {
    padding: 10px 12px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-gray-400);
    background: var(--vc-bg-100);
    color: var(--vc-text-secondary);
    cursor: pointer;
    text-align: left;
    font-size: 14px;
    transition: all 0.15s ease;
}
body.vercel-client .tm-option-btn:hover {
    background: var(--vc-bg-200);
    border-color: var(--vc-gray-500);
}
body.vercel-client .tm-option-btn.active {
    border-color: var(--vc-gray-1000);
    background: var(--vc-bg-200);
    color: var(--vc-text-primary);
}
body.vercel-client .tm-option-btn .tag {
    display: inline-block;
    font-size: 11px;
    padding: 1px 5px;
    border-radius: var(--vc-radius-sm);
    background: var(--vc-gray-200);
    color: var(--vc-text-secondary);
    font-weight: 600;
    margin-top: 4px;
    border: 1px solid var(--vc-gray-300);
}
body.vercel-client .tm-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    padding: 16px 20px;
    border-top: 1px solid var(--vc-gray-300);
}
body.vercel-client .tm-modal-footer .btn-cancel {
    padding: 8px 14px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-gray-400);
    background: var(--vc-bg-100);
    color: var(--vc-text-secondary);
    cursor: pointer;
    font-weight: 500;
    font-size: 14px;
    transition: all 0.15s ease;
}
body.vercel-client .tm-modal-footer .btn-cancel:hover {
    background: var(--vc-bg-200);
    color: var(--vc-text-primary);
}
body.vercel-client .tm-modal-footer .btn-generate {
    padding: 8px 14px;
    border-radius: var(--vc-radius-sm);
    border: 1px solid var(--vc-accent);
    background: var(--vc-accent);
    color: var(--vc-accent-contrast);
    cursor: pointer;
    font-weight: 500;
    font-size: 14px;
    transition: background 0.15s ease;
}
body.vercel-client .tm-modal-footer .btn-generate:hover {
    background: var(--vc-accent-hover);
}
/* =========================================================================
   TRANSPARENT MODAL TABLE - VERCEL CLIENT STYLE
   ========================================================================= */

/* Ép toàn bộ table, hàng và ô về nền trong suốt */
body.vercel-client .modal-content .table,
body.vercel-client .modal-content .table th,
body.vercel-client .modal-content .table td {
    background-color: transparent !important;
    background: transparent !important;
    color: var(--vc-text-primary) !important; /* Đảm bảo chữ vẫn rõ nét */
}

/* Tùy chỉnh hiệu ứng hover (khi di chuột qua hàng) thành một lớp xám mờ trong suốt cực đẹp */
body.vercel-client .modal-content .table-hover tbody tr:hover {
    background-color: var(--vc-bg-200) !important; /* Hoặc dùng rgba(0, 0, 0, 0.03) nếu không có biến */
}

/* Tinh chỉnh lại các đường viền (border) cho mỏng nhẹ theo chuẩn Vercel */
body.vercel-client .modal-content .table-bordered,
body.vercel-client .modal-content .table-bordered th,
body.vercel-client .modal-content .table-bordered td {
    border-color: var(--vc-gray-300) !important;
}
body.vercel-client .tm-page .tm-empty-state .tm-empty-step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: 30px;
    line-height: 1;
    vertical-align: middle;
    padding: 4px 8px;
    border: 1px solid var(--vc-border);
    border-radius: 8px;
    background: var(--vc-surface);
    color: var(--vc-text-secondary);
    font-size: 13px;
    font-weight: 600;
}

body.vercel-client .tm-page .tm-empty-state .tm-empty-arrow {
    display: inline-flex;
    align-items: center;
    margin: 0 6px;
    color: var(--vc-text-muted);
    font-weight: 700;
}

body.vercel-client .tm-page .tm-empty-state .tm-empty-step i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    line-height: 1;
    font-size: 13px;
    margin: 0;
}

body.vercel-client .tm-page {
    --tm-gap: 16px;
}

body.vercel-client .tm-page .container-fluid {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

body.vercel-client .tm-page .row {
    margin-left: calc(var(--tm-gap) / -2);
    margin-right: calc(var(--tm-gap) / -2);
}

body.vercel-client .tm-page .row > [class*="col-"] {
    padding-left: calc(var(--tm-gap) / 2);
    padding-right: calc(var(--tm-gap) / 2);
    margin-bottom: var(--tm-gap) !important;
}

body.vercel-client .tm-page .tm-notice,
body.vercel-client .tm-page .tm-sidebar,
body.vercel-client .tm-page .tm-inbox-wrap {
    margin: 0 !important;
}

@media (max-width: 767px) {
    body.vercel-client .tm-page {
        --tm-gap: 12px;
    }
}

/* ==========================================================================
   Vercel Style Table - FIX LINE MẢNH & TRONG SUỐT BORDER OUTSIDE
   ========================================================================== */

/* Khung bọc ngoài cùng nếu có thẻ p */
body.vercel-client .vercel-table-wrapper p {
    color: var(--vc-text-secondary) !important;
}

/* CHÌA KHÓA KÍCH HOẠT LƯỚT NGANG: Phá bỏ giới hạn khóa cứng của các layout cũ */
body.vercel-client .vercel-table-responsive {
    width: 100% !important;
    overflow-x: auto !important; /* Kích hoạt cuộn ngang trên mobile */
    display: block !important;
    -webkit-overflow-scrolling: touch !important; /* Vuốt mượt trên iPhone/Safari */
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}

/* Cấu hình Table Base */
body.vercel-client .vercel-table {
    width: 100% !important;
    min-width: 750px !important; /* Ép bảng rộng tối thiểu 750px trên mobile */
    margin: 0 !important;
    border-collapse: collapse !important; /* 💡 ĐỔI THÀNH collapse để line mỏng không bị răng cưa */
    background: transparent !important;
    border: 0 !important;
}

/* 💡 LÀM TRONG SUỐT TOÀN BỘ BORDER MẶC ĐỊNH */
body.vercel-client .vercel-table,
body.vercel-client .vercel-table thead,
body.vercel-client .vercel-table tbody,
body.vercel-client .vercel-table tr,
body.vercel-client .vercel-table th,
body.vercel-client .vercel-table td {
    background: transparent !important;
    border: none !important; /* Triệt tiêu sạch border cũ */
    box-shadow: none !important;
}

/* Thẻ th trên Header (Chữ in hoa, nhỏ, sắc nét) */
body.vercel-client .vercel-table thead th {
    background: transparent !important;
    color: var(--vc-text-primary) !important;
    /* 💡 ĐÚNG 1 LINE MẢNH dưới chân header */
    border-bottom: 1px solid var(--vc-gray-200, #eaeaea) !important; 
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
    vertical-align: middle;
    padding: 12px 8px !important;
}

/* Thẻ td dưới Body (Style chữ thanh mảnh kiểu Vercel) */
body.vercel-client .vercel-table tbody td {
    background: transparent !important;
    color: var(--vc-text-secondary) !important;
    /* 💡 ĐÚNG 1 LINE MẢNH để phân chia các hàng */
    border-bottom: 1px solid var(--vc-gray-200, #eaeaea) !important; 
    vertical-align: middle !important;
    white-space: nowrap;
    font-weight: 400 !important; 
    font-size: 14px !important;   
    letter-spacing: -0.1px !important;
    padding: 12px 8px !important;
}

/* Cột nào cần xuống dòng (ví dụ: Tên sản phẩm, Nội dung dài) */
body.vercel-client .vercel-table tbody td.wrap-text {
    white-space: normal !important;
    min-width: 180px;
}

/* Dòng cuối cùng của bảng xóa gạch chân cho sạch chuẩn Vercel */
body.vercel-client .vercel-table tbody tr:last-child td {
    border-bottom: none !important;
}

/* Hiệu ứng hover nhẹ khi rê chuột */
body.vercel-client .vercel-table tbody tr:hover td {
    background: rgba(0, 0, 0, 0.02) !important;
}

/* 💡 TRIỆT TIÊU TRIỆT ĐỂ BORDER TRÊN/DƯỚI CỦA THEME VÀ BOOTSTRAP */
body.vercel-client .table.vercel-table td,
body.vercel-client .table.vercel-table th,
body.vercel-client .table.data-table td,
body.vercel-client .table.data-table th {
    border: none !important;
    border-bottom: 1px solid var(--vc-gray-200, #eaeaea) !important; /* Ép chỉ nhận line này */
}
body.vercel-client .table.data-table tbody tr:last-child td {
    border-bottom: none !important;
}
