:root {
    --flex-accent: #0665d0;
    --flex-ink: #152238;
    --flex-muted: #687385;
    --flex-line: #e6ebf2;
    --flex-soft: #f5f8fc;
    --flex-deep: #102a4c;
    --flex-copy-size: 1rem;
    --flex-copy-line: 1.72;
    --flex-lead-size: 1.08rem;
    --flex-title-weight: 820;
    --flex-heading-weight: 780;
}

body {
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--flex-ink);
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

#main-container .container-fluid,
#main-container .erp-table-section > .container-fluid {
    max-width: 1600px;
}

#page-container:not(.main-content-boxed):not(.main-content-narrow) #main-container .content {
    width: 100%;
    max-width: none;
    padding: 1.25rem;
}

@media (min-width: 1200px) {
    #page-container:not(.main-content-boxed):not(.main-content-narrow) #main-container .content {
        padding-right: 1.5rem;
        padding-left: 1.5rem;
    }
}

.erp-table-section {
    padding: 0;
}

.erp-table-section > .container-fluid,
.section-container > .container-fluid {
    padding-right: 0;
    padding-left: 0;
}

.card,
.cards,
.new-card,
.couter-box,
.feature-items,
.testimonial-item,
.product-card,
.payment-list-table {
    border: 0 !important;
    border-radius: .5rem !important;
    box-shadow: 0 .125rem .375rem rgba(0, 0, 0, .04), 0 .5rem 1.25rem rgba(0, 0, 0, .05) !important;
    background: var(--bs-body-bg, #fff);
}

.card-bodys,
.cards .card-body,
.new-card .card-body {
    padding: 1.25rem;
}

.table-header,
.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--bs-border-color, #e9ecef);
    background: transparent;
}

.erp-table-section .card {
    overflow: hidden;
    border: 1px solid rgba(223, 227, 234, .95) !important;
    border-radius: .5rem !important;
    box-shadow: 0 .25rem .875rem rgba(15, 32, 56, .05) !important;
}

.erp-table-section .card-bodys {
    padding: 0;
}

.erp-table-section .table-header {
    min-height: 58px;
    padding: .9rem 1rem;
    background: #f8fafc;
}

.erp-table-section .table-top-form {
    padding: .85rem 1rem;
    border-bottom: 1px solid var(--flex-line);
}

.erp-table-section .table-search {
    max-width: 320px;
}

.erp-table-section .responsive-table,
.erp-table-section .table-responsive {
    padding: 0;
    background: #fff;
}

.erp-table-section .table,
.erp-table-section table.dataTable,
.erp-table-section .flex-data-table,
.block .flex-data-table {
    width: 100% !important;
    margin: 0 !important;
    border-color: var(--flex-line) !important;
}

.erp-table-section .table thead th,
.erp-table-section table.dataTable thead th,
.erp-table-section .flex-data-table thead th,
.block .flex-data-table thead th {
    padding: .8rem .9rem;
    border-bottom: 1px solid var(--flex-line) !important;
    background: #f8fafc;
    color: #526070;
    font-size: .74rem;
    font-weight: 750;
    text-transform: uppercase;
}

.erp-table-section .table tbody td,
.erp-table-section table.dataTable tbody td,
.erp-table-section .flex-data-table tbody td,
.block .flex-data-table tbody td {
    padding: .78rem .9rem;
    border-color: #eef2f7 !important;
    color: #26364a;
}

.erp-table-section .table tbody tr:hover,
.erp-table-section table.dataTable tbody tr:hover,
.erp-table-section .flex-data-table tbody tr:hover,
.block .flex-data-table tbody tr:hover {
    background: #f8fbff;
}

.dataTables_wrapper {
    padding: 1rem;
}

.dataTables_wrapper .row {
    align-items: center;
    row-gap: .75rem;
}

.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
    min-height: 2.45rem;
    border: 1px solid var(--flex-line);
    border-radius: .5rem;
    background: #fff;
    box-shadow: none;
}

.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
    margin: 0;
}

.dataTables_wrapper .dataTables_filter {
    text-align: right;
}

.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    margin: 0;
    color: #526070;
    font-size: .95rem;
    font-weight: 500;
}

.dataTables_wrapper .dataTables_filter input {
    min-width: 240px;
    margin-left: 0 !important;
}

.dataTables_wrapper .dataTables_info {
    color: var(--flex-muted);
    font-size: .93rem;
    padding-top: 0 !important;
}

.dataTables_wrapper .pagination {
    margin-bottom: 0;
    justify-content: flex-end;
    gap: .35rem;
}

.dataTables_wrapper .page-item {
    margin: 0;
}

.dataTables_wrapper .page-link {
    min-width: 2rem;
    border-radius: .4rem;
    border: 1px solid var(--flex-line);
    color: #40516a;
    text-align: center;
    font-weight: 600;
    box-shadow: none !important;
}

.dataTables_wrapper .page-item.active .page-link {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    color: #fff;
}

.dataTables_wrapper .page-item.disabled .page-link {
    color: #94a3b8;
    background: #fff;
}

.erp-table-section .card > nav {
    padding: .85rem 1rem;
    border-top: 1px solid var(--flex-line);
    background: #fff;
}

.erp-table-section .flex-pagination {
    padding: .85rem 1rem;
    border-top: 1px solid var(--flex-line);
    background: #fff;
}

.erp-table-section nav .pagination,
.erp-table-section .flex-pagination .pagination,
.erp-table-section .card > div > .pagination {
    justify-content: flex-end;
    gap: .25rem;
    margin: 0;
}

.erp-table-section nav .page-item,
.erp-table-section .flex-pagination .page-item,
.erp-table-section .card > div > .pagination .page-item {
    margin: 0;
}

.erp-table-section nav .page-link,
.erp-table-section .flex-pagination .page-link,
.erp-table-section .card > div > .pagination .page-link {
    min-width: 2rem;
    border-radius: .25rem;
    color: #40516a;
    text-align: center;
}

.erp-table-section nav .page-item.active .page-link,
.erp-table-section .flex-pagination .page-item.active .page-link,
.erp-table-section .card > div > .pagination .page-item.active .page-link {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    color: #fff;
}

.table-header h4,
.card-header h4,
.card-header h5 {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
}

.table-top-form {
    padding: 0 1.25rem 1rem;
}

.table-search {
    max-width: 360px;
}

.responsive-table,
.responsibe-table {
    width: 100%;
    overflow-x: auto;
}

.flex-dashboard-page {
    width: 100%;
}

.flex-dashboard-page .block {
    border: 1px solid rgba(230, 235, 242, .9);
    box-shadow: 0 .35rem 1.25rem rgba(15, 32, 56, .05);
}

.flex-dashboard-stat {
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.flex-dashboard-page .row.row-cols-1 .col:nth-child(6n+1) .flex-dashboard-stat {
    background: var(--bs-primary);
}

.flex-dashboard-page .row.row-cols-1 .col:nth-child(6n+2) .flex-dashboard-stat {
    background: var(--bs-warning);
}

.flex-dashboard-page .row.row-cols-1 .col:nth-child(6n+3) .flex-dashboard-stat {
    background: #3c426b;
}

.flex-dashboard-page .row.row-cols-1 .col:nth-child(6n+4) .flex-dashboard-stat {
    background: var(--bs-success);
}

.flex-dashboard-page .row.row-cols-1 .col:nth-child(6n+5) .flex-dashboard-stat {
    background: #34445a;
}

.flex-dashboard-page .row.row-cols-1 .col:nth-child(6n) .flex-dashboard-stat {
    background: var(--bs-info);
}

.flex-dashboard-stat .text-muted,
.flex-dashboard-stat .text-dark {
    color: #fff !important;
}

.flex-dashboard-stat .text-muted {
    opacity: .86;
}

.flex-dashboard-stat .block-content {
    min-height: 118px;
    display: flex;
    align-items: center;
}

.flex-dashboard-stat .block-content > .d-flex {
    width: 100%;
}

.flex-dashboard-stat .flex-stat-icon {
    background: rgba(255, 255, 255, .95) !important;
    color: var(--bs-primary) !important;
}

.flex-dashboard-stat:hover {
    transform: translateY(-2px);
    border-color: rgba(6, 101, 208, .22);
    box-shadow: 0 .65rem 1.75rem rgba(15, 32, 56, .09);
}

.flex-stat-icon {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .75rem;
    font-size: 1.25rem;
}

.flex-dashboard-block .block-header {
    min-height: auto;
    padding: 1rem 1.25rem;
}

.flex-year-select {
    width: 104px;
    flex: 0 0 104px;
}

.flex-dashboard-chart {
    position: relative;
    min-height: 280px;
}

.flex-dashboard-chart-sm {
    min-height: 260px;
}

.flex-dashboard-canvas {
    width: 100% !important;
    min-height: 240px;
}

#ShareProfit.flex-dashboard-canvas {
    max-height: 240px;
}

#new-users-table,
#recent-messages-table {
    margin-bottom: 0 !important;
}

#new-users-table tbody tr,
#new-users-table.table-striped > tbody > tr:nth-of-type(odd),
#new-users-table.table-striped > tbody > tr:nth-of-type(even),
#recent-messages-table tbody tr,
#recent-messages-table.table-striped > tbody > tr:nth-of-type(odd),
#recent-messages-table.table-striped > tbody > tr:nth-of-type(even) {
    background-color: #fff !important;
}

#new-users-table tbody tr > *,
#recent-messages-table tbody tr > * {
    box-shadow: none !important;
}

#new-users-table .img-avatar {
    object-fit: cover;
}

#new-users-table_wrapper .row:first-child,
#new-users-table_wrapper .row:last-child,
#recent-messages-table_wrapper .row:first-child,
#recent-messages-table_wrapper .row:last-child {
    align-items: center;
    row-gap: .75rem;
}

#new-users-table_filter input,
#recent-messages-table_filter input {
    min-width: 240px;
    border-radius: .375rem;
}

.flex-overview-chip {
    height: 100%;
    padding: .75rem .85rem;
    border: 1px solid var(--flex-line);
    border-radius: .65rem;
    background: #fff;
}

.flex-overview-chip small {
    display: block;
    color: var(--flex-muted);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.flex-overview-chip strong {
    display: block;
    margin-top: .2rem;
    color: var(--flex-ink);
    font-size: 1.05rem;
    font-weight: 800;
}

.flex-plan-cell {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .45rem;
}

.flex-plan-badge {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    padding: .35rem .6rem;
    border-radius: 999px;
    background: rgba(6, 101, 208, .12);
    color: var(--flex-accent);
    font-size: .78rem;
    font-weight: 700;
    line-height: 1.3;
    white-space: normal;
}

.flex-plan-duration {
    color: var(--flex-muted);
    font-size: .84rem;
    font-weight: 600;
    line-height: 1.35;
}

.flex-plan-empty {
    color: var(--flex-muted);
    font-size: .84rem;
    font-weight: 600;
}

.user-btn {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem;
}

.flex-table-top-btn {
    min-height: 2rem;
    padding: .35rem .7rem;
    font-size: .84rem;
    line-height: 1.3;
}

#recent-messages-table_wrapper .dataTables_paginate {
    margin-top: 0;
}

#recent-messages-table_wrapper .pagination {
    justify-content: flex-end;
    gap: .25rem;
}

#recent-messages-table_wrapper .page-item {
    margin: 0;
}

#recent-messages-table_wrapper .page-link {
    min-width: 2rem;
    border-radius: .25rem;
    color: #40516a;
    text-align: center;
    box-shadow: none !important;
}

#recent-messages-table_wrapper .page-item.active .page-link {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    color: #fff;
}

#recent-messages-table_wrapper .page-item.disabled .page-link {
    color: #94a3b8;
    background: #fff;
}

@media (max-width: 767.98px) {
    #page-container:not(.main-content-boxed):not(.main-content-narrow) #main-container .content {
        padding: 1rem;
    }

    .flex-dashboard-block .block-header {
        align-items: flex-start !important;
        flex-direction: column;
        gap: .75rem;
    }

    .flex-year-select,
    #new-users-table_filter input,
    #recent-messages-table_filter input,
    .dataTables_wrapper .dataTables_filter input {
        width: 100%;
        min-width: 0;
    }

    .dataTables_wrapper .dataTables_filter,
    .dataTables_wrapper .dataTables_length,
    .dataTables_wrapper .dataTables_info,
    .dataTables_wrapper .dataTables_paginate {
        text-align: left;
    }

    .dataTables_wrapper .pagination {
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

.table {
    margin-bottom: 0;
    vertical-align: middle;
}

.table thead th {
    white-space: nowrap;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: 0;
    color: #6c757d;
    background: var(--bs-body-bg, #fff);
}

.table-img,
.img-avatar,
.profile-info img {
    object-fit: cover;
}

.table-img {
    width: 42px;
    height: 42px;
    border-radius: .35rem;
}

.theme-btn,
.login-btn,
.submit-btn:not(.btn),
.reset-btn:not(.btn) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    min-height: 2.25rem;
    padding: .45rem .9rem;
    border: 1px solid transparent;
    border-radius: .25rem;
    background: var(--flex-accent);
    color: #fff !important;
    font-weight: 600;
    text-decoration: none;
}

.border-btn,
.reset-btn:not(.btn) {
    background: transparent;
    border-color: var(--bs-border-color, #dfe3ea);
    color: var(--bs-body-color, #343a40) !important;
}

.form-control,
.form-select,
.table-select,
.select-dropdown {
    border-radius: .25rem;
}

.gpt-dashboard-card {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 1rem;
}

.gpt-dashboard-card.grid-5 {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.couter-box {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-height: 104px;
    padding: 1.25rem;
}

.couter-box .icons {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .5rem;
    background: rgba(6, 101, 208, .1);
}

.couter-box .icons img {
    max-width: 24px;
    max-height: 24px;
}

.couter-box h5 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
}

.couter-box p {
    margin: .2rem 0 0;
    color: #6c757d;
    font-size: .875rem;
}

.gpt-dashboard-chart {
    row-gap: 1rem;
}

.chart-css {
    min-height: 280px;
}

.dropdown.table-action .dropdown-menu {
    border: 0;
    box-shadow: 0 .5rem 1.5rem rgba(0, 0, 0, .08);
}

.flex-row-actions {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    flex-wrap: wrap;
}

.flex-row-action {
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--flex-line);
    border-radius: .45rem;
    background: #fff;
    text-decoration: none;
    box-shadow: none;
    transition: transform .16s ease, border-color .16s ease, background-color .16s ease, color .16s ease;
}

.flex-row-action i {
    margin: 0 !important;
    font-size: .9rem;
}

.flex-row-action:hover,
.flex-row-action:focus {
    transform: translateY(-1px);
    text-decoration: none;
}

.flex-row-action--primary {
    border-color: rgba(6, 101, 208, .18);
    color: var(--flex-accent);
    background: rgba(6, 101, 208, .06);
}

.flex-row-action--primary:hover,
.flex-row-action--primary:focus {
    border-color: rgba(6, 101, 208, .32);
    background: rgba(6, 101, 208, .12);
    color: #0551a8;
}

.flex-row-action--danger {
    border-color: rgba(220, 53, 69, .18);
    color: #dc3545;
    background: rgba(220, 53, 69, .06);
}

.flex-row-action--danger:hover,
.flex-row-action--danger:focus {
    border-color: rgba(220, 53, 69, .32);
    background: rgba(220, 53, 69, .12);
    color: #b42333;
}

.flex-row-action--info {
    border-color: rgba(13, 202, 240, .2);
    color: #0ea5c6;
    background: rgba(13, 202, 240, .08);
}

.flex-row-action--info:hover,
.flex-row-action--info:focus {
    border-color: rgba(13, 202, 240, .34);
    background: rgba(13, 202, 240, .14);
    color: #0b8ea9;
}

.flex-row-action--success {
    border-color: rgba(25, 135, 84, .2);
    color: #198754;
    background: rgba(25, 135, 84, .08);
}

.flex-row-action--success:hover,
.flex-row-action--success:focus {
    border-color: rgba(25, 135, 84, .34);
    background: rgba(25, 135, 84, .14);
    color: #146c43;
}

.flex-row-action--secondary {
    border-color: rgba(108, 117, 125, .18);
    color: #5f6b7a;
    background: rgba(108, 117, 125, .06);
}

.flex-row-action--secondary:hover,
.flex-row-action--secondary:focus {
    border-color: rgba(108, 117, 125, .3);
    background: rgba(108, 117, 125, .12);
    color: #44515f;
}

.mybazar-login-section {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 480px);
    background: #f5f6f8;
}

.mybazar-login-avatar {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(2rem, 5vw, 5rem);
    background: linear-gradient(135deg, #0b3b75, #0665d0);
}

.mybazar-login-avatar img {
    max-width: min(420px, 100%);
}

.mybazar-login-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.login-wrapper {
    width: 100%;
    max-width: 420px;
}

.login-body {
    padding: 2rem;
    border-radius: .5rem;
    background: #fff;
    box-shadow: 0 .5rem 2rem rgba(0, 0, 0, .08);
}

.login-body .input-group {
    margin-bottom: 1rem;
}

.login-body .input-group > span:first-child {
    display: none;
}

.hide-pass {
    position: absolute;
    right: .75rem;
    top: 50%;
    z-index: 5;
    transform: translateY(-50%);
    cursor: pointer;
}

.hide-pass img {
    width: 18px;
}

.banner-section,
.envato-section,
.our-feature-section,
.service-provide-section,
.premium-product-section,
.faqs-section,
.testimonial-section {
    padding: 4rem 0;
}

.banner-section {
    background: #f5f6f8;
    background-size: cover;
    background-position: center;
}

.banner-content h1,
.section-title h2 {
    font-weight: var(--flex-title-weight);
    letter-spacing: 0;
}

.header-section {
    position: sticky;
    top: 0;
    z-index: 1020;
    background: #fff;
    box-shadow: 0 .125rem .375rem rgba(0, 0, 0, .05);
}

.header-wrapper,
.header-main-menu-wrapper ul,
.header-button-group {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.header-wrapper {
    min-height: 72px;
    justify-content: space-between;
}

.header-main-menu-wrapper ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.header-logo img {
    max-height: 44px;
}

.sidebar-btn,
.sidebar-close-btn {
    border: 0;
    background: transparent;
}

@media (max-width: 991.98px) {
    .mybazar-login-section {
        grid-template-columns: 1fr;
    }

    .mybazar-login-avatar {
        display: none;
    }

    .header-main-menu-wrapper {
        display: none;
    }

    .table-header {
        align-items: flex-start;
        flex-direction: column;
    }
}

html {
    scrollbar-width: thin;
    scrollbar-color: #2f7fe8 #eef3f9;
}

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

::-webkit-scrollbar-track {
    background: #eef3f9;
}

::-webkit-scrollbar-thumb {
    background: #2f7fe8;
    border: 2px solid #eef3f9;
    border-radius: 999px;
}

body {
    color: var(--flex-ink);
}

.flex-public-header {
    position: sticky;
    top: 0;
    z-index: 1020;
    background: rgba(255, 255, 255, .94);
    border-bottom: 1px solid rgba(230, 235, 242, .9);
    backdrop-filter: blur(16px);
}

.flex-public-header .navbar {
    min-height: 78px;
}

.flex-public-header .navbar-brand img {
    max-width: 180px;
    max-height: 42px;
    object-fit: contain;
}

.flex-public-header .nav-link {
    color: #40516a;
    font-size: .97rem;
    font-weight: 650;
    line-height: 1.4;
    padding: .6rem .85rem;
}

.flex-public-header .nav-link.active,
.flex-public-header .nav-link:hover {
    color: var(--flex-accent);
}

.flex-public-footer {
    padding: 4.5rem 0 1.5rem;
    color: #d6e2ef;
    background: #0f2038;
}

.flex-public-footer h6 {
    color: #fff;
    margin-bottom: 1rem;
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: -.01em;
}

.flex-public-footer p {
    color: #aebdd0;
    font-size: .97rem;
    line-height: 1.72;
}

.footer-brand img {
    max-width: 190px;
    max-height: 48px;
    object-fit: contain;
    filter: brightness(0) invert(1);
}

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links li + li {
    margin-top: .65rem;
}

.footer-links a,
.flex-public-footer a {
    color: #d6e2ef;
    text-decoration: none;
}

.footer-links a,
.footer-bottom {
    font-size: .95rem;
    line-height: 1.7;
}

.footer-links a:hover,
.flex-public-footer a:hover {
    color: #fff;
}

.footer-social {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: .35rem;
    background: rgba(255, 255, 255, .08);
}

.footer-social img {
    width: 18px;
    height: 18px;
    object-fit: contain;
}

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 3rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, .12);
    color: #91a3ba;
    font-size: .875rem;
}

.banner-section {
    min-height: calc(100vh - 78px);
    display: flex;
    align-items: center;
    background: linear-gradient(135deg, #f4f8ff 0%, #fff 55%, #eef7ff 100%) !important;
}

.banner-section,
.envato-section,
.our-feature-section,
.service-provide-section,
.premium-product-section,
.faqs-section,
.testimonial-section,
.flex-section {
    padding: 5rem 0;
}

.banner-content h1 {
    max-width: 720px;
    font-size: clamp(2.4rem, 5vw, 4.9rem);
    line-height: 1.04;
    color: var(--flex-ink);
    font-weight: var(--flex-title-weight);
}

.banner-content p {
    max-width: 620px;
    margin-top: 1.25rem;
    color: var(--flex-muted);
    font-size: 1.08rem;
    line-height: 1.72;
}

.banner-img,
.service-banner-img,
.faq-right-img {
    display: flex;
    justify-content: center;
}

.banner-img img,
.service-banner-img img,
.faq-right-img img {
    width: 100%;
    max-width: 560px;
    max-height: 520px;
    object-fit: contain;
}

.section-title {
    max-width: 760px;
    margin: 0 auto 2.5rem;
}

.section-title h2,
.flex-section h2 {
    color: var(--flex-ink);
    font-size: clamp(1.8rem, 3vw, 2.9rem);
    font-weight: var(--flex-title-weight);
    line-height: 1.14;
    letter-spacing: 0;
}

.section-title p,
.flex-section p {
    font-size: var(--flex-copy-size);
    line-height: var(--flex-copy-line);
    color: var(--flex-muted);
}

.flex-section .lead,
.flex-article .lead,
.flex-form-card .text-muted,
.flex-contact-visual .alert,
.banner-content .lead {
    font-size: var(--flex-lead-size);
    line-height: 1.74;
}

.flex-page-hero {
    padding: 6rem 0 4rem;
    text-align: center;
    background: linear-gradient(135deg, #f4f8ff 0%, #fff 55%, #edf6ff 100%);
}

.flex-page-hero-compact {
    padding: 4.5rem 0 3rem;
}

.flex-page-hero h1 {
    max-width: 860px;
    margin: 1rem auto;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 1.08;
    font-weight: var(--flex-title-weight);
    letter-spacing: 0;
}

.flex-page-hero p {
    max-width: 760px;
    margin: 0 auto;
    color: var(--flex-muted);
    font-size: 1.06rem;
    line-height: 1.72;
}

.flex-eyebrow {
    display: inline-block;
    margin-bottom: .75rem;
    color: var(--flex-accent);
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .07em;
}

.flex-feature-image,
.flex-card-image,
.flex-blog-image,
.flex-article-image,
.flex-contact-visual img {
    width: 100%;
    object-fit: cover;
    background: var(--flex-soft);
}

.flex-feature-image {
    aspect-ratio: 4 / 3;
    border-radius: .75rem;
    box-shadow: 0 1rem 3rem rgba(15, 32, 56, .12);
}

.flex-card-image {
    aspect-ratio: 16 / 9;
    border-radius: .5rem .5rem 0 0;
}

.flex-info-card,
.flex-blog-card,
.flex-article,
.flex-sidebar-card,
.flex-form-card,
.flex-policy-card,
.flex-price-card,
.flex-contact-visual {
    border: 1px solid var(--flex-line);
    border-radius: .75rem;
    background: #fff;
    box-shadow: 0 .5rem 2rem rgba(15, 32, 56, .06);
}

.flex-blog-card {
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease;
}

.flex-blog-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 1rem 2.5rem rgba(15, 32, 56, .12);
}

.flex-blog-image {
    aspect-ratio: 16 / 10;
}

.flex-blog-card h3 {
    margin: .65rem 0;
    font-size: 1.18rem;
    font-weight: var(--flex-heading-weight);
    line-height: 1.4;
}

.flex-blog-card h3 a,
.flex-recent-post {
    color: var(--flex-ink);
    text-decoration: none;
}

.flex-blog-card p,
.flex-policy-card p {
    color: var(--flex-muted);
}

.flex-meta {
    color: var(--flex-muted);
    font-size: .92rem;
    font-weight: 650;
}

.flex-article {
    overflow: hidden;
}

.flex-article-image {
    aspect-ratio: 16 / 8;
    max-height: 520px;
}

.flex-comment {
    display: flex;
    gap: 1rem;
    padding: 1rem 0;
    border-top: 1px solid var(--flex-line);
}

.flex-comment-avatar {
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #e8f1ff;
    color: var(--flex-accent);
    font-weight: 800;
}

.flex-comment-form {
    padding: 1.5rem;
    border-radius: .5rem;
    background: var(--flex-soft);
}

.flex-sidebar-card {
    position: sticky;
    top: 100px;
    padding: 1.25rem;
}

.flex-sidebar-card h5 {
    font-size: 1.08rem;
    font-weight: var(--flex-heading-weight);
    line-height: 1.35;
}

.flex-recent-post {
    display: grid;
    grid-template-columns: 86px 1fr;
    gap: .85rem;
    align-items: center;
    padding: .85rem 0;
    border-top: 1px solid var(--flex-line);
    font-size: .95rem;
    font-weight: 700;
    line-height: 1.55;
}

.flex-recent-post img {
    width: 86px;
    height: 64px;
    border-radius: .4rem;
    object-fit: cover;
}

.flex-form-card,
.flex-policy-card,
.flex-price-card {
    padding: clamp(1.25rem, 3vw, 2rem);
}

.flex-price-card {
    min-height: 100%;
    display: flex;
    flex-direction: column;
}

.flex-price-card h3 {
    font-size: 1.18rem;
    font-weight: var(--flex-heading-weight);
    line-height: 1.35;
}

.flex-price {
    margin: 1rem 0;
    color: var(--flex-ink);
    font-size: 1.9rem;
    font-weight: var(--flex-title-weight);
    line-height: 1.1;
}

.flex-price span {
    color: var(--flex-muted);
    font-size: .95rem;
    font-weight: 600;
}

.flex-feature-list {
    padding: 0;
    margin: 0 0 1.5rem;
    list-style: none;
}

.flex-feature-list li {
    display: flex;
    align-items: flex-start;
    gap: .6rem;
    margin-bottom: .75rem;
    color: #44546a;
    font-size: .98rem;
    line-height: 1.65;
}

.flex-contact-visual {
    padding: 1rem;
}

.flex-contact-visual img {
    aspect-ratio: 4 / 3;
    border-radius: .5rem;
}

.flex-icon-image {
    width: 48px;
    height: 48px;
    border-radius: .5rem;
    object-fit: cover;
}

.flex-map {
    overflow: hidden;
    border-radius: .75rem;
    border: 1px solid var(--flex-line);
}

.flex-map iframe {
    width: 100% !important;
    min-height: 360px;
    display: block;
}

.flex-policy-card {
    max-width: 920px;
    margin: 0 auto;
    font-size: 1.02rem;
    line-height: 1.8;
}

.flex-policy-card h2,
.flex-form-card h2,
.flex-info-card h3 {
    color: var(--flex-ink);
    font-size: clamp(1.45rem, 2.2vw, 1.9rem);
    font-weight: var(--flex-title-weight);
    line-height: 1.22;
    letter-spacing: -.01em;
}

.flex-info-card h5,
.flex-info-card h6,
.flex-article h4 {
    color: var(--flex-ink);
    font-weight: var(--flex-heading-weight);
    line-height: 1.35;
}

.envato-wrp,
.feature-items,
.testimonial-item,
.product-card {
    border: 1px solid var(--flex-line) !important;
}

.envato-wrp {
    padding: 1.25rem;
    border-radius: .75rem;
    background: #fff;
    box-shadow: 0 .5rem 2rem rgba(15, 32, 56, .06);
}

.envato-section img,
.feature-items img {
    width: 52px;
    height: 52px;
    object-fit: contain;
}

.feature-items,
.product-card,
.testimonial-item {
    height: 100%;
    padding: 1.5rem;
}

.product-card img {
    width: 100%;
    height: 160px;
    object-fit: contain;
}

.accordion-item {
    border: 1px solid var(--flex-line) !important;
    border-radius: .5rem !important;
    overflow: hidden;
    margin-bottom: .85rem;
}

.accordion-button {
    font-size: 1rem;
    font-weight: 750;
    line-height: 1.5;
}

.alert {
    border-radius: .5rem;
}

.flex-auth-page {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(420px, 560px);
    background: #f4f7fb;
}

.flex-auth-centered {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.flex-auth-visual {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 100vh;
    padding: clamp(2rem, 5vw, 5rem);
    background: linear-gradient(145deg, #0f2038 0%, #143d70 58%, #0665d0 100%);
    color: #fff;
}

.flex-auth-visual::after {
    content: "";
    position: absolute;
    right: 8%;
    bottom: 10%;
    width: 340px;
    height: 340px;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 50%;
}

.flex-auth-logo {
    position: relative;
    z-index: 1;
    display: inline-flex;
}

.flex-auth-logo img {
    max-width: 190px;
    max-height: 48px;
    object-fit: contain;
    filter: brightness(0) invert(1);
}

.flex-auth-logo-inline img {
    filter: none;
}

.flex-auth-copy {
    position: relative;
    z-index: 1;
    max-width: 660px;
}

.flex-auth-copy h1 {
    font-size: clamp(2.4rem, 5vw, 4.5rem);
    line-height: 1.05;
    font-weight: 850;
    letter-spacing: 0;
}

.flex-auth-copy p {
    max-width: 560px;
    color: rgba(255,255,255,.78);
    font-size: 1.08rem;
}

.flex-auth-panel {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.flex-auth-card {
    width: 100%;
    max-width: 460px;
    padding: clamp(1.5rem, 4vw, 2.25rem);
    border: 1px solid var(--flex-line);
    border-radius: .75rem;
    background: #fff;
    box-shadow: 0 1rem 3rem rgba(15, 32, 56, .1);
}

.flex-auth-card-wide {
    max-width: 620px;
}

.flex-auth-card h2 {
    font-weight: 850;
    letter-spacing: 0;
}

.flex-auth-card .input-group-text {
    background: #f7f9fc;
}

.mybazar-login-section {
    display: none;
}

@media (max-width: 991.98px) {
    .flex-public-header .navbar-collapse {
        padding: 1rem 0;
    }

    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
    }

    .flex-auth-page {
        grid-template-columns: 1fr;
    }

    .flex-auth-visual {
        display: none;
    }

    .flex-auth-panel {
        min-height: 100vh;
    }

    .banner-section {
        min-height: auto;
        padding: 4rem 0;
    }
}

/* Final public website refinements */
.flex-home-hero {
    min-height: calc(100vh - 78px);
    padding: clamp(3rem, 7vw, 5.25rem) 0 !important;
}

.flex-home-hero .container {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.flex-home-hero h1 {
    font-size: clamp(2.55rem, 5.2vw, 4.6rem);
}

.flex-home-hero h1 span {
    display: inline;
    padding: 0 .18em;
    color: #fff;
    background: var(--flex-ink);
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.flex-hero-media {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 360px;
}

.flex-hero-media::before {
    content: "";
    position: absolute;
    inset: 12% 2%;
    border-radius: 2rem;
    background: radial-gradient(circle at center, rgba(6, 101, 208, .12), rgba(6, 101, 208, 0) 70%);
}

.flex-hero-media img {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 560px;
    max-height: 410px;
    object-fit: contain;
}

.flex-tight-section,
.pricing-plan-section.flex-section {
    padding: clamp(2.75rem, 5vw, 4rem) 0 !important;
}

.section-title {
    margin-bottom: 1.75rem;
}

.section-title h2,
.flex-section h2 {
    font-size: clamp(1.65rem, 2.5vw, 2.35rem);
}

.section-title p {
    margin-bottom: 0;
}

.flex-mini-feature {
    height: 100%;
    display: flex;
    gap: .9rem;
    align-items: flex-start;
    padding: 1rem;
    border: 1px solid var(--flex-line);
    border-radius: .65rem;
    background: #fff;
    box-shadow: 0 .35rem 1.25rem rgba(15, 32, 56, .04);
    transition: transform .18s ease, border-color .18s ease;
}

.flex-mini-feature:hover,
.flex-workflow-card:hover,
.flex-service-card:hover,
.flex-price-card:hover,
.flex-testimonial-card:hover {
    transform: translateY(-3px);
    border-color: rgba(6, 101, 208, .28) !important;
}

.flex-mini-feature img {
    width: 42px;
    height: 42px;
    object-fit: contain;
}

.flex-mini-feature h4 {
    margin-bottom: .25rem;
    font-size: 1rem;
    font-weight: var(--flex-heading-weight);
    line-height: 1.4;
}

.flex-mini-feature p,
.flex-workflow-card p,
.flex-service-card p {
    margin-bottom: 0;
    color: var(--flex-muted);
    font-size: .98rem;
    line-height: 1.68;
}

.flex-workflow-card {
    min-height: 190px;
    transition: transform .18s ease, border-color .18s ease;
}

.flex-workflow-card img {
    margin-bottom: 1rem;
}

.flex-workflow-card h4 {
    font-size: 1.12rem;
    font-weight: var(--flex-heading-weight);
    line-height: 1.4;
}

.flex-feature-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 320px;
    padding: 1.25rem;
    border: 1px solid var(--flex-line);
    border-radius: .85rem;
    background: #fff;
    box-shadow: 0 .5rem 2rem rgba(15, 32, 56, .06);
}

.flex-feature-panel img {
    width: 100%;
    max-height: 330px;
    object-fit: contain;
}

.flex-service-card {
    height: 100%;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    padding: 1.15rem;
    border: 1px solid var(--flex-line);
    border-radius: .75rem;
    background: #fff;
    color: var(--flex-ink);
    text-decoration: none;
    box-shadow: 0 .35rem 1.5rem rgba(15, 32, 56, .05);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.flex-service-card:hover {
    color: var(--flex-ink);
    box-shadow: 0 .8rem 2rem rgba(15, 32, 56, .1);
}

.flex-service-card img {
    width: 100%;
    height: 92px;
    margin-bottom: .9rem;
    object-fit: contain;
}

.flex-service-card h5 {
    font-size: 1.1rem;
    font-weight: var(--flex-heading-weight);
    line-height: 1.4;
    min-height: 3.1rem;
}

.flex-service-card span {
    margin-top: auto;
    color: var(--flex-accent);
    font-weight: 750;
    font-size: .95rem;
}

.flex-service-card p {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.pricing-plan-section .text-center.mb-5 {
    margin-bottom: 1.75rem !important;
}

.flex-price-card {
    min-height: 190px;
    padding: .95rem;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.flex-price-card:hover {
    box-shadow: 0 .8rem 2rem rgba(15, 32, 56, .1);
}

.flex-price-card h3 {
    margin-bottom: .2rem;
    font-size: 1.02rem;
}

.flex-feature-icon {
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.flex-price {
    margin: .45rem 0 .35rem;
    font-size: 1.28rem;
}

.flex-feature-list-compact {
    margin-bottom: 1rem;
}

.flex-feature-list-compact li {
    margin-bottom: .4rem;
    font-size: .95rem;
}

.flex-price-summary {
    margin-bottom: 1rem;
    color: var(--flex-muted);
    font-size: .92rem;
    line-height: 1.5;
}

.flex-testimonial-card {
    min-height: 245px;
    display: flex;
    flex-direction: column;
    transition: transform .18s ease, border-color .18s ease;
}

.flex-testimonial-card .flex-stars {
    color: #f5a623;
    margin-bottom: .8rem;
}

.flex-testimonial-card .testimonial {
    color: #40516a;
    font-size: 1rem;
    line-height: 1.65;
}

.flex-testimonial-card img {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    object-fit: cover;
}

.flex-auth-page {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.flex-auth-panel {
    padding: clamp(1.5rem, 4vw, 3rem);
}

.flex-auth-card {
    max-width: 500px;
}

.flex-auth-card-wide {
    max-width: 620px;
}

@media (max-width: 1199.98px) {
    .flex-home-hero {
        min-height: auto;
    }
}

@media (max-width: 991.98px) {
    .flex-auth-page {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 1.5rem;
    }

    .flex-auth-panel {
        width: 100%;
        min-height: auto;
        padding: 0;
    }

    .flex-home-hero h1 {
        font-size: clamp(2.25rem, 10vw, 3.4rem);
    }
}

.flex-balance-badge {
    max-width: min(44vw, 280px);
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    background: var(--bs-primary) !important;
    color: #fff !important;
    white-space: nowrap;
    line-height: 1.1;
    text-align: left;
    padding: .25rem .55rem !important;
    font-size: .78rem;
    border-radius: .35rem !important;
}

.flex-balance-label {
    flex: 0 0 auto;
    font-size: .75rem;
    font-weight: 600;
}

.flex-balance-amount {
    min-width: 0;
    font-size: .88rem;
    font-weight: 800;
    line-height: 1.05;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.header-info-badge {
    font-size: .75rem !important;
    font-weight: 600 !important;
    padding: .25rem .55rem !important;
    border-radius: .35rem !important;
    white-space: nowrap;
}

.header-info-group {
    gap: .35rem !important;
}

@media (max-width: 991.98px) {
    .header-info-group {
        gap: .25rem !important;
    }
    .header-info-badge {
        font-size: .7rem !important;
        padding: .2rem .4rem !important;
    }
}

@media (max-width: 575.98px) {
    .flex-balance-badge {
        max-width: 46vw;
        align-items: flex-start;
        flex-direction: column;
        gap: .05rem;
        padding: .2rem .45rem !important;
    }
    .flex-balance-amount {
        font-size: .82rem;
    }
    .flex-balance-label {
        font-size: .7rem;
    }
}

.flex-profile-page .block {
    border: 1px solid rgba(223, 227, 234, .95);
    box-shadow: 0 .35rem 1.25rem rgba(15, 32, 56, .06);
}

.flex-profile-cover {
    height: 132px;
    background:
        linear-gradient(135deg, rgba(6, 101, 208, .95), rgba(19, 154, 82, .78)),
        linear-gradient(45deg, #0f2038, #0665d0);
}

.flex-profile-avatar {
    width: 112px;
    height: 112px;
    margin-top: -56px;
    border: 5px solid #fff;
    border-radius: 50%;
    background: #fff;
    object-fit: cover;
    box-shadow: 0 .5rem 1.5rem rgba(15, 32, 56, .16);
}

.flex-profile-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem 1rem;
    border: 1px solid var(--flex-line);
    border-radius: .5rem;
    background: #f8fafc;
}

.flex-profile-info span {
    color: #687385;
    font-size: .82rem;
    font-weight: 650;
}

.flex-profile-info strong {
    min-width: 0;
    color: #152238;
    font-size: .9rem;
    text-align: right;
    overflow-wrap: anywhere;
}

.flex-notification-dropdown {
    width: min(420px, calc(100vw - 2rem));
    border: 1px solid var(--flex-line);
    border-radius: .75rem;
    overflow: hidden;
    box-shadow: 0 1rem 2.5rem rgba(15, 32, 56, .12);
}

.flex-notification-list {
    display: grid;
    gap: .5rem;
    background: #fff;
}

.flex-notification-item {
    padding: .85rem .95rem;
    border: 1px solid transparent;
    border-radius: .65rem;
    white-space: normal;
    transition: background-color .18s ease, border-color .18s ease;
}

.flex-notification-item:hover,
.flex-notification-item:focus {
    background: #f8fbff;
    border-color: rgba(6, 101, 208, .16);
}

.flex-notification-item-unread {
    background: #f8fbff;
    border-color: rgba(6, 101, 208, .1);
}

.flex-notification-item .fw-semibold {
    line-height: 1.45;
    margin-bottom: .2rem;
}

.flex-notification-footer {
    padding-top: .7rem;
    padding-bottom: .7rem;
    font-weight: 600;
}
