/* =========================================================================
   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;

    /* --- 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: "Geist Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --vc-font-mono: "Geist Mono", "SF Mono", "Fira Code", "Cascadia Code", Consolas, monospace;
}

/* -------------------------------------------------------------------------
   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-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.dark .wrapper,
body.vercel-client.color-dark .wrapper,
html.color-dark body.vercel-client .wrapper,
.color-dark body.vercel-client .wrapper,
body.vercel-client[data-theme="dark"] .wrapper {
    background: var(--vc-bg-200);
}

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

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

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

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

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

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

body.vercel-client.dark .card .card-header .card-title,
body.vercel-client.color-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,
body.vercel-client[data-theme="dark"] .card .card-header .card-title {
    color: var(--vc-text-primary);
}

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

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

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

body.vercel-client.dark .table-striped tbody tr:nth-of-type(odd),
body.vercel-client.color-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),
body.vercel-client[data-theme="dark"] .table-striped tbody tr:nth-of-type(odd) {
    background: var(--vc-gray-a-100);
}

body.vercel-client.dark .table-hover tbody tr:hover,
body.vercel-client.color-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,
body.vercel-client[data-theme="dark"] .table-hover tbody tr:hover {
    background: var(--vc-gray-a-200);
}

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

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

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

body.vercel-client.dark .dropdown-menu,
body.vercel-client.color-dark .dropdown-menu,
html.color-dark body.vercel-client .dropdown-menu,
.color-dark body.vercel-client .dropdown-menu,
body.vercel-client[data-theme="dark"] .dropdown-menu,
body.vercel-client.dark .iq-sub-dropdown .dropdown-menu,
body.vercel-client.color-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,
body.vercel-client[data-theme="dark"] .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.dark .modal-content,
body.vercel-client.color-dark .modal-content,
html.color-dark body.vercel-client .modal-content,
.color-dark body.vercel-client .modal-content,
body.vercel-client[data-theme="dark"] .modal-content {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-300);
    color: var(--vc-text-primary);
}

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

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

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

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

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

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

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

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

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

body.vercel-client.dark .blur-shadow,
body.vercel-client.dark .basic-drop-shadow,
body.vercel-client.color-dark .blur-shadow,
body.vercel-client.color-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,
body.vercel-client[data-theme="dark"] .blur-shadow,
body.vercel-client[data-theme="dark"] .basic-drop-shadow {
    background: var(--vc-bg-100);
    border-color: var(--vc-gray-a-300);
}

/* -------------------------------------------------------------------------
   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: var(--vc-font-sans);
    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
   ========================================================================= */

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

body.vercel-client .iq-navbar-custom .navbar {
    padding: 0 var(--vc-space-4);
    height: 56px;
}

body.vercel-client .iq-top-navbar .badge2 {
    border-radius: var(--vc-radius-full);
    padding: 4px 12px;
    font-size: 12px;
    font-weight: 500;
    line-height: 16px;
    border: 1px solid var(--vc-border) !important;
    background: var(--vc-surface);
}

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;
}

/* Dark mode toggle */
body.vercel-client .change-mode .custom-control-label {
    cursor: pointer;
}

/* =========================================================================
   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;
}

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 {
    opacity: 0.9;
}

/* 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 {
    opacity: 0.9;
}

/* 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;
}

/* =========================================================================
   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);
}

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);
}

/* List group (bank info in recharge) */
body.vercel-client .list-group {
    border-radius: var(--vc-radius-md);
    overflow: hidden;
}

body.vercel-client .list-group-item {
    background: var(--vc-surface);
    border: 1px solid var(--vc-border);
    border-bottom: 1px solid var(--vc-border);
    padding: var(--vc-space-3) var(--vc-space-4);
    font-size: 14px;
    color: var(--vc-text-primary);
}

body.vercel-client .list-group-item:first-child {
    border-top-left-radius: var(--vc-radius-md);
    border-top-right-radius: var(--vc-radius-md);
}

body.vercel-client .list-group-item:last-child {
    border-bottom-left-radius: var(--vc-radius-md);
    border-bottom-right-radius: var(--vc-radius-md);
}

/* =========================================================================
   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.dark .wallet-balance,
body.vercel-client.color-dark .wallet-balance,
html.color-dark body.vercel-client .wallet-balance,
.color-dark body.vercel-client .wallet-balance,
body.vercel-client[data-theme="dark"] .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.dark .discount-rate,
body.vercel-client.color-dark .discount-rate,
html.color-dark body.vercel-client .discount-rate,
.color-dark body.vercel-client .discount-rate,
body.vercel-client[data-theme="dark"] .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.dark .status-success,
body.vercel-client.color-dark .status-success,
html.color-dark body.vercel-client .status-success,
.color-dark body.vercel-client .status-success,
body.vercel-client[data-theme="dark"] .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.dark .status-danger,
body.vercel-client.color-dark .status-danger,
html.color-dark body.vercel-client .status-danger,
.color-dark body.vercel-client .status-danger,
body.vercel-client[data-theme="dark"] .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.dark .status-warning,
body.vercel-client.color-dark .status-warning,
html.color-dark body.vercel-client .status-warning,
.color-dark body.vercel-client .status-warning,
body.vercel-client[data-theme="dark"] .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.dark .status-info,
body.vercel-client.color-dark .status-info,
html.color-dark body.vercel-client .status-info,
.color-dark body.vercel-client .status-info,
body.vercel-client[data-theme="dark"] .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.dark .text-dark,
body.vercel-client.color-dark .text-dark,
html.color-dark body.vercel-client .text-dark,
.color-dark body.vercel-client .text-dark,
body.vercel-client[data-theme="dark"] .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.dark .bg-light,
body.vercel-client.color-dark .bg-light,
html.color-dark body.vercel-client .bg-light,
.color-dark body.vercel-client .bg-light,
body.vercel-client[data-theme="dark"] .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.dark .card-footer,
body.vercel-client.color-dark .card-footer,
html.color-dark body.vercel-client .card-footer,
.color-dark body.vercel-client .card-footer,
body.vercel-client[data-theme="dark"] .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.dark .table-bordered,
body.vercel-client.dark .table-bordered td,
body.vercel-client.dark .table-bordered th,
body.vercel-client.color-dark .table-bordered,
body.vercel-client.color-dark .table-bordered td,
body.vercel-client.color-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,
body.vercel-client[data-theme="dark"] .table-bordered,
body.vercel-client[data-theme="dark"] .table-bordered td,
body.vercel-client[data-theme="dark"] .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.dark .alert.bg-warning,
body.vercel-client.color-dark .alert.bg-warning,
html.color-dark body.vercel-client .alert.bg-warning,
.color-dark body.vercel-client .alert.bg-warning,
body.vercel-client[data-theme="dark"] .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.dark .badge-secondary,
body.vercel-client.color-dark .badge-secondary,
html.color-dark body.vercel-client .badge-secondary,
.color-dark body.vercel-client .badge-secondary,
body.vercel-client[data-theme="dark"] .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;
    }
}