@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Rubik:wght@400;500;600;700&display=swap");

:root {
    --font: "Rubik", sans-serif;
    --white-color: #fff;
    --white-alpha-1: rgba(255, 255, 255, 0.12);
    --white-alpha-2: rgba(255, 255, 255, 0.3);
    --white-alpha-3: rgba(255, 255, 255, 0.90);
    --sidebar-bg: #b9203f;
    --black-color: #000;
    --black-50: rgba(0, 0, 0, 0.7);
    --body-color: #1b1b1b;
    --primary-color: #fe2c55;
    --warning-color: #ff9700;
    --assest-color: #e9ecef;
    --green-color: #058f00;
    --red-color: #e3000b;
    --dark-color: rgba(0, 0, 0, 0.04);
    --light-gray: #9c9999c0;
    --primary-light: rgba(254, 44, 85, 0.07);
    --header-height: 64px;
    --header-shadow: 0 1px 4px rgba(0, 0, 0, 0.07);
    --text-muted: rgba(27, 27, 27, 0.7);
    --light-green: rgba(86, 163, 86, 0.195);
    --light-red: rgba(172, 81, 81, 0.195);
    --light-warning: rgba(161, 161, 63, 0.195);

    /* Glassmorphic Login Variables */
    --login-card-bg: rgba(18, 11, 16, 0.65);
    --login-card-border: rgba(255, 255, 255, 0.08);
    --login-card-shadow: 0 30px 60px rgba(0, 0, 0, 0.8);
    --login-input-bg: rgba(255, 255, 255, 0.03);
    --login-input-border: rgba(255, 255, 255, 0.1);
    --login-text-secondary: rgba(255, 255, 255, 0.6);
    --login-btn-gradient: linear-gradient(135deg, #fe2c55 0%, #bd1539 100%);
    --login-btn-hover-gradient: linear-gradient(135deg, #ff4165 0%, #d41c45 100%);
    --login-bg-overlay: radial-gradient(circle, rgba(18, 11, 16, 0.85) 0%, rgba(18, 11, 16, 0.75) 45%, rgba(18, 11, 16, 0.4) 65%, rgba(18, 11, 16, 0) 90%);
}

html,
body {
    height: 100%;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--font);
    color: var(--body-color);
    background-color: var(--assest-color);
    font-size: 14px;
    overflow-x: hidden;
}

.body-content {
    padding: 25px;
}

.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font);
}

.defaultfont {
    font-family: var(--font);
}

a {
    text-decoration: none !important;
}

.primary-color {
    color: var(--primary-color);
}

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

.show-bg {
    background-color: var(--green-color) !important;
}

.hide-bg {
    background-color: var(--red-color) !important;
}

.draft-bg {
    background-color: var(--light-gray) !important;
}

.text-gray {
    color: var(--body-color);
    opacity: 0.6;
}

.size-90 {
    height: 90px;
    width: 90px;
}

.size-55 {
    height: 55px;
    width: 55px;
}

.price {
    font-size: 18px;
    font-weight: 600;
}

.user_name {
    font-size: 14px;
    font-weight: 600;
}

.cursor {
    background-color: var(--assest-color);
    border: 1px solid var(--black-color);
    cursor: s-resize;
}

.mt-12 {
    margin-top: 12px;
}

.btn:focus {
    outline: none;
    -webkit-box-shadow: 0 0 0;
    box-shadow: 0 0 0;
}

.user_image {
    position: relative;
}

.action-badge {
    color: var(--white-color) !important;
    font-size: 12px;
    width: 20px;
    height: 20px;
    position: absolute !important;
    bottom: -20px !important;
    right: 0px !important;
    border-radius: 50% !important;
    display: flex;
    justify-content: center;
    align-items: center;
}

.success-badge {
    background-color: var(--primary-color);
}

.review-badge {
    background-color: var(--warning-color);
}

.btn-link {
    color: var(--primary-color) !important;
    font-weight: 600;
    border-bottom: 1px solid var(--primary-color);
    display: inline-block;
    padding: 0 0 0px;
    border-radius: 0;
    font-size: 14px;
}

.custom-checkbox {
    height: 20px;
    width: 20px;
    accent-color: var(--primary-color);
}

.btn-default {
    background: var(--primary-color);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--white-color);
    border: 1px solid transparent;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    padding: 8px 20px;
}

.btn-default:hover {
    color: var(--primary-color);
    background: transparent;
    border-color: var(--primary-color);
}

.mw-120 {
    min-width: 120px;
}

.dropright .dot-icon {
    height: 18px;
}

.dropright .dropdown-menu {
    top: 100% !important;
    right: 0;
    -webkit-transform: none !important;
    transform: none !important;
    left: auto !important;
}

.dropdown-menu {
    -webkit-box-shadow: 0 15px 35px var(--assest-color);
    box-shadow: 0 15px 35px var(--assest-color);
    padding: 4px;
    border: 0;
    border-radius: 12px;
}

.dropdown-menu .dropdown-item {
    font-weight: 500;
    border-bottom: 2px dashed var(--assest-color);
    padding: 7px 11px;
    font-size: 14px;
}

.dropdown-menu .dropdown-item:last-child {
    border-bottom: 0;
}

.side-toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    background: transparent;
    padding: 0;
}

.side-toggle span {
    background: var(--white-color);
    width: 20px;
    height: 2px;
    margin: 2.5px 0;
    border-radius: 50px;
    -webkit-transition: all 0.25s ease;
    transition: all 0.25s ease;
    display: block;
}

.side-toggle span:nth-child(2) {
    width: 13px;
    -ms-flex-item-align: start;
    align-self: flex-start;
}

.custom-control .custom-control-label::before {
    background: transparent;
    border: 2px solid var(--primary-color);
    border-radius: 3px;
}

.custom-control .custom-control-input:checked~.custom-control-label::after {
    border-radius: 3px;
    background-color: var(--primary-color);
}

.custom-control.custom-radio .custom-control-label::before,
.custom-control.custom-radio .custom-control-label:after {
    border-radius: 50% !important;
}

.sidebar {
    background: var(--sidebar-bg);
    padding: 0;
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    height: 100%;
    width: 260px;
    max-width: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-transform: translateX(0px);
    transform: translateX(0px);
    -webkit-transition:
        width 0.3s ease,
        -webkit-transform 0.3s ease;
    transition:
        width 0.3s ease,
        transform 0.3s ease;
    border-right: 1px solid var(--white-alpha-1);
    z-index: 100;
}

.sidebar::-webkit-scrollbar {
    width: 6px;
}

.sidebar::-webkit-scrollbar-thumb {
    background-color: var(--white-color);
}

.sidebar::-webkit-scrollbar-track {
    background: transparent;
}

@media (min-width: 1680px) {
    .sidebar {
        width: 280px;
    }
}

.sidebar.hide-sidebar {
    width: 72px;
    padding: 0;
}

@media (min-width: 1024px) {
    .sidebar.hide-sidebar .side-menu .side-submenu a.dropdown-item {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 10px 0;
        margin: 4px 10px;
        border-left: none;
        border-radius: 10px;
    }

    .hide-sidebar .side-menu .side-submenu a.dropdown-item {
        height: 35px;
        margin-left: 15px !important;
    }

    .sidebar.hide-sidebar .side-menu .partition {
        display: none;
    }

    .sidebar.hide-sidebar .side-head {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 15px 12px;
    }

    .sidebar.hide-sidebar .side-logo,
    .sidebar.hide-sidebar .partition,
    .sidebar.hide-sidebar .side-menu a>span {
        display: none;
    }

    .sidebar.hide-sidebar .side-menu .active a:after {
        content: none;
    }

    .sidebar.hide-sidebar .side-menu a {
        margin: 2px auto;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        padding: 7px;
        height: 44px;
        width: 44px;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        border-left: none !important;
        border-radius: 10px;
    }

    .sidebar.hide-sidebar .side-menu a .menu-icon {
        margin-right: 0;
        width: 30px;
        height: 30px;
        font-size: 14px !important;
    }

    .sidebar.hide-sidebar .side-menu a.dropdown-toggle:after {
        content: none;
    }

    .sidebar.hide-sidebar .side-menu .dropdown-menu {
        margin-left: 0;
        min-width: unset;
        padding: 0;
    }

    .sidebar.hide-sidebar .side-menu .dropdown-menu a {
        padding: 0;
    }

    .sidebar.hide-sidebar .side-menu .dropdown-menu .active {
        padding: 0;
        margin: 0px;
    }

    .sidebar.hide-sidebar .side-menu .dropdown-menu a svg {
        margin-right: 0;
    }

    .sidebar.hide-sidebar .side-menu .side-submenu .submenu-icon {
        margin: 0;
        width: 26px;
        height: 26px;
        font-size: 13px;
    }
}

@media (min-width: 1680px) {
    .sidebar.hide-sidebar .side-head {
        padding: 0 12px;
    }
}

.sidebar .side-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 20px;
    height: 64px;
    border-bottom: 1px solid var(--white-alpha-2);
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    background: var(--sidebar-bg);
    z-index: 10000;
}

.sidebar .side-logo {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.3px;
    width: auto;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--white-color);
}

.sidebar .side-logo:hover {
    color: var(--white-alpha-3);
}

.sidebar .side-menu {
    padding: 8px 0 28px;
    list-style: none;
    margin: 0;
}

.sidebar .side-menu a {
    color: var(--white-alpha-3);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 9px 12px;
    margin: 2px 10px;
    position: relative;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
    font-size: 13.5px;
    font-weight: 500;
    border-left: 3px solid transparent;
    border-radius: 10px;
    -webkit-transition:
        background 0.18s ease,
        color 0.18s ease;
    transition:
        background 0.18s ease,
        color 0.18s ease;
    white-space: nowrap;
}

.sidebar.hide-sidebar .side-menu .side_line.active a:after {
    display: none;
}

.sidebar .side-menu .side_line.active a:after {
    content: none;
}

.sidebar .side-menu a i {
    font-size: 15px !important;
}

.sidebar .side-menu a .menu-icon {
    margin-right: 11px;
    width: 30px;
    height: 30px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 8px;
    background: var(--white-alpha-1);
    -ms-flex-negative: 0;
    flex-shrink: 0;
    color: var(--white-alpha-3);
    -webkit-transition:
        background 0.18s ease,
        color 0.18s ease;
    transition:
        background 0.18s ease,
        color 0.18s ease;
}

.sidebar .side-menu .dropdown-menu a i {
    font-size: 13px !important;
}

.sidebar .side-menu .dropdown-menu a .submenu-icon {
    margin-right: 10px;
    width: 26px;
    height: 26px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 7px;
    background: var(--white-alpha-1);
    -ms-flex-negative: 0;
    flex-shrink: 0;
    color: var(--white-alpha-3);
    -webkit-transition:
        background 0.18s ease,
        color 0.18s ease;
    transition:
        background 0.18s ease,
        color 0.18s ease;
}

.sidebar .side-menu a:hover {
    background: var(--white-alpha-1);
    color: var(--white-color);
}

.sidebar .side-menu a:hover .menu-icon,
.sidebar .side-menu a:hover .submenu-icon {
    background: var(--white-alpha-1);
    color: var(--white-color);
}

.sidebar .side-menu .active a {
    background: var(--white-color);
    color: var(--primary-color);
    border-left: 3px solid transparent;
    font-weight: 600;
}

.sidebar .side-menu .active a .menu-icon {
    -webkit-filter: none;
    filter: none;
    background: var(--primary-light);
    color: var(--primary-color);
}

.sidebar .side-menu .active .dropdown-menu .active .submenu-icon {
    -webkit-filter: none;
    filter: none;
    background: var(--primary-light);
    color: var(--primary-color);
}

.sidebar .side-menu .dropdown-toggle::after {
    position: absolute;
    right: 14px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    margin: 0;
}

.sidebar .side-menu .dropdown-menu {
    position: relative !important;
    -webkit-transform: none !important;
    transform: none !important;
    -webkit-box-shadow: none;
    box-shadow: none;
    float: none;
    background: transparent;
    margin-left: 20px;
    padding: 2px 0;
    border-left: none;
    border-radius: 0;
}

.sidebar .side-menu .dropdown-menu .dropdown-item {
    padding: 7px 12px;
    background: transparent;
    color: var(--white-alpha-3);
    font-size: 13px;
    border-bottom: none;
    border-radius: 8px;
    margin: 1px 10px 1px 4px;
    width: auto;
}

.right-content {
    margin-left: 260px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.sidebar .side-menu .side-submenu a {
    color: var(--white-alpha-3);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 7px 12px;
    position: relative;
    margin: 2px 4px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    border-left: 3px solid transparent;
    border-radius: 8px;
    -webkit-transition:
        background 0.18s ease,
        color 0.18s ease;
    transition:
        background 0.18s ease,
        color 0.18s ease;
}

.sidebar .side-menu .side-submenu .active {
    background: transparent;
    border-radius: 0;
    color: inherit;
}

.sidebar .side-menu .side-submenu a:hover {
    color: var(--white-color);
    background: var(--white-alpha-1);
}

.sidebar .side-menu .side-submenu .active a:hover {
    color: var(--primary-color);
}

.sidebar .side-menu .side-submenu .active a {
    color: var(--primary-color);
    background: var(--white-color);
    font-weight: 600;
    border-left: 3px solid transparent;
    -webkit-box-shadow: 0 1px 6px var(--black-alpha-1);
    box-shadow: 0 1px 6px var(--black-alpha-1);
}

@media (min-width: 1680px) {
    .right-content {
        margin-left: 280px;
    }
}

.right-content.right-content-0 {
    margin-left: 72px;
}

.right-content.right-content-0 .header .title-control .side-toggle {
    display: none;
}

.header {
    position: sticky;
    -webkit-position: -webkit-sticky;
    top: 0;
    background: var(--white-color);
    z-index: 22;
    padding: 0 24px;
    height: var(--header-height);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    border-bottom: 1px solid var(--assest-color);
    -webkit-box-shadow: var(--header-shadow);
    box-shadow: var(--header-shadow);
}

.header .title-control {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 14px;
}

.header .title-control .side-toggle {
    margin-right: 0;
    display: none;
}

.header .page-title {
    font-size: 20px;
    font-weight: 600;
    margin: 0;
    color: var(--body-color);
    letter-spacing: -0.2px;
}

.header .input-group {
    border: 1px solid var(--assest-color);
    border-radius: 100px;
    width: 550px;
    max-width: 100%;
}

.header .input-group .input-group-text,
.header .input-group .form-control {
    background: transparent;
    border: 0;
    -webkit-box-shadow: 0 0 0;
    box-shadow: 0 0 0;
}

.header .input-group .input-group-text img,
.header .input-group .form-control img {
    width: 20px;
    margin: 0 5px;
}

.header .input-group .form-control {
    font-size: 14px;
    padding: 12px 6px;
}

.header .side-logo {
    display: none;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.3px;
}

.header .head-control {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 8px;
}

.header .head-control .head-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 40px;
    width: 40px;
    padding: 0;
    border-radius: 10px;
    overflow: hidden;
    margin-left: 0;
    background: var(--primary-light);
    color: var(--primary-color);
    border: 1px solid var(--assest-color);
    -webkit-box-shadow: none;
    box-shadow: none;
    -webkit-transition:
        background 0.18s ease,
        border-color 0.18s ease;
    transition:
        background 0.18s ease,
        border-color 0.18s ease;
}

.header .head-control .head-btn:hover {
    background: var(--primary-color);
    color: var(--white-color);
}

.avatar-img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}

.box-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--assest-color);
    padding-bottom: 14px;
    margin-top: 0;
    margin-bottom: 16px;
}

.box-title .title {
    font-size: 14px;
    font-weight: 600;
    margin: 4px 0;
    color: var(--body-color);
    letter-spacing: -0.1px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 8px;
}

.avatar-control {
    overflow: hidden;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.avatar-control .avatar-img {
    height: 60px;
    width: 60px;
    border-radius: 8px;
    -o-object-fit: cover;
    object-fit: cover;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-right: 10px;
}

.table-striped tbody tr:nth-of-type(odd) {
    background-color: transparent;
}

.table-striped tbody tr:nth-of-type(even) {
    background-color: var(--assest-color);
}

.table {
    border-color: var(--assest-color);
    min-width: 650px;
}

.table thead th {
    font-size: 14px;
    font-weight: 600;
    border-top: 0;
    border-bottom: 1px solid var(--assest-color);
}

.table td {
    font-size: 14px;
    border-bottom: 1px solid var(--assest-color);
    border-top: 0;
    vertical-align: middle;
}

.table .avatar-img {
    margin-right: 10px;
}

.table .clamp-text {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.table .btn {
    padding: 2px;
    background: transparent;
    margin: 0 3px;
}

.table .btn img {
    width: 16px;
}

.dot {
    height: 8px;
    width: 8px;
    background: var(--red-color);
    border-radius: 50%;
    display: inline-block;
    margin-right: 8px;
}

.summary-table-card .border-card {
    padding: 10px 12px;
    border: 1px solid var(--assest-color);
    border-radius: 8px;
    margin-bottom: 8px;
    font-size: 14px;
    background: var(--white-color);
    -webkit-transition:
        border-color 0.18s ease,
        -webkit-box-shadow 0.18s ease;
    transition:
        border-color 0.18s ease,
        box-shadow 0.18s ease;
}

.summary-table-card .border-card:hover {
    border: 1px solid var(--primary-color);
    -webkit-box-shadow: 0 2px 12px rgba(254, 44, 85, 0.08);
    box-shadow: 0 2px 12px rgba(254, 44, 85, 0.08);
}

.summary-table-card .border-card>.row {
    margin: 0;
}

.summary-table-card .border-card>.row .col,
.summary-table-card .border-card>.row .col-1,
.summary-table-card .border-card>.row .col-2,
.summary-table-card .border-card>.row .col-12 {
    padding: 0;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.summary-table-card .avatar-control {
    min-width: 100px;
    font-weight: 500;
    font-size: 13px;
    gap: 8px;
}

.summary-table-card .avatar-control img {
    margin-right: 0;
}

.summary-table-card .price {
    color: var(--red-color);
    font-weight: 600;
}

.video-box {
    padding: 20px;
    background: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 12px;
    height: 100%;
}

.video-box .f600 {
    font-weight: 600;
}

.video-box .box-border-0 {
    border: 0;
    padding-bottom: 0;
}

/* =============================================================
   VIDEO CARD — Premium SaaS-quality reusable card component
   Shared by: Ads · Feeds · Reels · Story modules
   Design direction: Stripe / Linear / Vercel aesthetic
   ============================================================= */

/* Card shell — overflow:hidden clips media to border-radius so
   card-img-top needs no separate border-radius declaration */
.video-card {
    padding: 0;
    border: 1px solid var(--assest-color);
    border-radius: 16px;
    margin: 12px 0;
    overflow: hidden;
    background-color: var(--white-color);
    -webkit-transition:
        -webkit-box-shadow 0.25s ease,
        -webkit-transform 0.25s ease;
    transition:
        box-shadow 0.25s ease,
        transform 0.25s ease;
    -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
}

/* Subtle lift replaces the heavy assest-color box-shadow */
.video-card:hover {
    -webkit-box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
}

/* Media fills full card width; taller height gives visual dominance */
.video-card .card-img-top {
    border-radius: 0;
    height: 200px;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    display: block;
}

/* Gradient scrim on media bottom — ensures action icons are legible on any media */
.video-card .position-relative::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 55%;
    background: -webkit-gradient(linear,
            left bottom,
            left top,
            from(rgba(0, 0, 0, 0.5)),
            to(transparent));
    background: linear-gradient(to top,
            rgba(0, 0, 0, 0.5) 0%,
            transparent 100%);
    pointer-events: none;
    z-index: 1;
}

/* Play / expand button — centered over media, revealed on hover.
   Moved from top-right corner to dead-center (standard media-card UX). */
.video-card .play-btn-top {
    position: absolute;
    top: 50%;
    left: 50%;
    right: auto;
    -webkit-transform: translate(-50%, -50%) scale(0.85);
    transform: translate(-50%, -50%) scale(0.85);
    background: rgba(0, 0, 0, 0.35);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
    border-radius: 50%;
    padding: 10px 14px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    -webkit-transition:
        opacity 0.2s ease,
        -webkit-transform 0.2s ease;
    transition:
        opacity 0.2s ease,
        transform 0.2s ease;
    z-index: 2;
}

/* Backward compat — if an <img> is used inside play-btn-top */
.video-card .play-btn-top img {
    width: 38px;
}

/* Edit / delete action row — top-right of media, revealed on hover.
   Repositioned from bottom edge to top-right corner for standard SaaS card UX. */
.video-card .overlap-control {
    position: absolute;
    top: 10px;
    right: 10px;
    bottom: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 4px;
    list-style: none;
    margin: 0;
    padding: 0;
    opacity: 0;
    pointer-events: none;
    -webkit-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
    z-index: 3;
}

/* Reveal all hover-state overlays simultaneously */
.video-card:hover .play-btn,
.video-card:hover .overlap-control,
.video-card:hover .play-btn-top {
    opacity: 1;
    pointer-events: auto;
}

/* Scale-in the play button on reveal — adds kinetic feedback */
.video-card:hover .play-btn-top {
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
}

/* Action icon buttons — frosted-glass pill style on dark media */
.video-card .overlap-control .btn {
    background: rgba(255, 255, 255, 0.9);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    padding: 5px 8px;
    border-radius: 8px;
    line-height: 1;
    -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
    -webkit-transition: background 0.15s ease;
    transition: background 0.15s ease;
}

.video-card .overlap-control .btn:hover {
    background: var(--white-color);
}

.video-card .overlap-control .btn .dot-icon {
    height: 16px;
    width: 16px;
    -o-object-fit: contain;
    object-fit: contain;
    color: var(--primary-color) !important;
}

/* Legacy center play-btn — kept for backward compat; uses opacity instead of display */
.video-card .play-btn {
    background: transparent;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    opacity: 0;
    pointer-events: none;
    -webkit-transition: opacity 0.2s ease;
    transition: opacity 0.2s ease;
}

/* Card body — more breathing room than the original 15px 10px */
.video-card .card-body {
    padding: 14px 16px 12px;
    position: relative;
    background-color: var(--white-color);
}

/* Title — tighter font size (was 16px), preserves 2-line clamp */
.video-card .card-body .card-title {
    padding-right: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--body-color);
    line-height: 1.45;
    margin: 0 0 12px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Stat icons — normalize fa-xl (17.5px) down to body text scale */
.video-card .card-body .fa-xl {
    font-size: 13px;
}

/* Stat numbers — strip Bootstrap h5 sizing (20px → 13px) */
.video-card .card-body .d-flex.text-align-center h5 {
    font-size: 13px;
    font-weight: 500;
    margin: 0;
    color: var(--body-color);
}

/* Remove the mt-12 offset from stat icons — was compensating for old fa-xl height delta */
.video-card .card-body .d-flex.text-align-center .mt-12 {
    margin-top: 0;
}

/* Tighten icon–number gap: Bootstrap mr-3 (16px) → compact 5px */
.video-card .card-body .d-flex.text-align-center span i {
    margin-right: 5px !important;
}

/* Scheduled status badge in reels — compact pill */
.video-card .card-body .hide-btn {
    font-size: 12px;
    padding: 4px 12px;
}

/* Dropdown in card body — preserved exactly */
.video-card .card-body .dropdown {
    position: absolute;
    right: 10px;
    top: 10px;
}

.video-card .card-body .dropdown .dropdown-menu {
    top: auto !important;
    bottom: 100%;
}

.video-card .card-body .dropdown .head-btn {
    padding: 5px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.video-card .card-body .dropdown .dropdown-item {
    font-weight: 500;
}

.video-card .card-body .dropdown .dropdown-item img {
    height: 18px;
    width: 18px;
    -o-object-fit: contain;
    object-fit: contain;
    margin-right: 10px;
}

/* Card details section — flex layout preserved */
.video-card .card-body .card-details {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.video-card .card-body .card-details p {
    margin: 0;
    font-weight: 500;
    color: var(--assest-color);
}

.video-card .card-body .card-details p.tag {
    color: var(--body-color);
}

.pagination {
    padding: 5px;
    border: 1px solid var(--assest-color);
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    border-radius: 10px;
    margin: 35px auto 0;
}

.pagination .page-link {
    border: 0;
    height: 30px;
    width: 30px;
    background: var(--assest-color) !important;
    margin: 0 5px;
    border-radius: 50px !important;
    color: var(--body-color);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.pagination .page-link .right-arrow {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}

.pagination .page-link .dots {
    font-weight: 600;
    margin-top: -4px;
}

.pagination .arrow-icon {
    height: 20px;
    width: 20px;
    background-image: url("../../assets/imgs/left-arrow.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 7px;
}

.pagination .arrow-icon .next-arrow {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}

.pagination .active .page-link {
    background: var(--primary-color) !important;
}

.modal .close {
    font-size: 34px;
    color: var(--white-color);
    opacity: 1;
    position: absolute;
    right: 5px;
    top: 0px;
    font-weight: 200;
    z-index: 22;
    outline: none;
}

.custom-border-card {
    border: 1px solid var(--assest-color);
    -webkit-box-shadow: 0 1px 6px var(--dark-color);
    box-shadow: 0 1px 6px var(--dark-color);
    padding: 20px 25px;
    border-radius: 15px;
    margin-bottom: 25px;
}

.custom-border-card .card-header {
    font-size: 18px;
    background: transparent;
    padding: 0;
    font-weight: 700;
    border-bottom: 2px solid var(--assest-color);
    padding-bottom: 15px;
}

.custom-border-card .card-body {
    padding: 18px 0 10px;
}

.form-group label {
    font-weight: 500;
    color: var(--body-color);
    font-size: 14px;
    margin-bottom: 10px;
}

.form-control,
.custom-select {
    border: 1px solid var(--assest-color);
    background: var(--white-color);
    border-radius: 8px;
    padding: 12px 18px;
    font-size: 14px;
    height: auto !important;
}

.form-control:focus,
.custom-select:focus {
    -webkit-box-shadow: 0 0 0;
    box-shadow: 0 0 0;
    border-color: var(--primary-color);
}

.radio-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 20px;
}

.radio-group .custom-control {
    padding-left: 0;
    margin-right: 15px;
}

.radio-group .custom-control-label {
    margin-bottom: 0;
    background: var(--assest-color);
    padding: 6px 23px 6px 33px;
    border-radius: 100px;
    font-size: 16px;
}

.radio-group .custom-control-label::before,
.radio-group .custom-control-label:after {
    border-radius: 50%;
    top: 10px;
    left: 10px;
}

.radio-group .custom-control-label:after {
    display: none;
}

.radio-group .custom-control-label::before {
    background: transparent;
    border: 3px solid var(--body-color);
}

.radio-group .custom-control-input:checked~.custom-control-label {
    background: var(--primary-color);
    color: var(--white-color);
}

.radio-group .custom-control-input:checked~.custom-control-label::before {
    background: var(--primary-color);
    border-color: var(--white-color);
}

.page-title-sm {
    display: none;
}

table.dataTable>thead .sorting:before,
table.dataTable>thead .sorting_asc:before,
table.dataTable>thead .sorting_desc:before,
table.dataTable>thead .sorting_asc_disabled:before,
table.dataTable>thead .sorting_desc_disabled:before {
    content: "↑";
}

table.dataTable>thead .sorting:after,
table.dataTable>thead .sorting_asc:after,
table.dataTable>thead .sorting_desc:after,
table.dataTable>thead .sorting_asc_disabled:after,
table.dataTable>thead .sorting_desc_disabled:after {
    content: "↓";
}

div.dataTables_wrapper div.dataTables_length label,
div.dataTables_wrapper div.dataTables_filter label {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background: var(--assest-color);
    border-radius: 8px;
    padding: 6px 18px;
    font-weight: 600;
}

div.dataTables_wrapper div.dataTables_length label .form-control,
div.dataTables_wrapper div.dataTables_filter label .form-control {
    padding: 6px 12px;
    text-align: center;
    margin: 0 13px;
    background-color: var(--white-color);
}

div.dataTables_wrapper div.dataTables_length label input.form-control,
div.dataTables_wrapper div.dataTables_filter label input.form-control {
    margin-right: 0;
    text-align: left;
}

div.table-responsive>div.dataTables_wrapper>div.row>div[class^="col-"]:first-child,
div.table-responsive>div.dataTables_wrapper>div.row>div[class^="col-"]:last-child {
    overflow: auto;
}

.left-caption {
    height: 100%;
    position: relative;
}

.left-caption .bg-img {
    height: 100%;
    width: 100%;
    -o-object-fit: fit;
    object-fit: fit;
}

.left-caption .caption {
    height: 100%;
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: var(--black-50);
    color: var(--white-color);
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 160px;
}

.left-caption .caption .text {
    margin-top: 20px;
    font-size: 14px;
    line-height: 24px;
}

.login-bg {
    background: var(--assest-color);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    overflow: auto;
    padding-bottom: 20px;
}

@media (max-height: 600px) {
    .login-bg {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: start;
    }
}

.app-logo img {
    width: 180px;
    margin: 15px 0 20px;
}

@media (min-width: 1600px) {
    .counter-row {
        margin-bottom: 20px;
    }

    .table thead th,
    .table td {
        font-size: 16px;
    }

    .custom-tabs .nav-link,
    .summary-table-card .border-card {
        font-size: 16px;
    }

    .video-card .card-img-top {
        height: 250px;
    }

    .video-card .card-body .card-title {
        font-size: 18px;
    }

    .video-card .card-body .card-details p {
        font-size: 16px;
    }

    .video-card .play-btn-top img {
        width: 60px;
    }

    .form-group label {
        font-size: 16px;
    }

    .custom-border-card .card-header {
        font-size: 20px;
    }
}

@media (max-width: 1280px) {
    .header .input-group {
        width: 280px;
    }
}

@media (max-width: 991px) {
    .sidebar {
        left: -260px;
    }

    .sidebar.hide-sidebar {
        -webkit-transform: translateX(0);
        transform: translateX(0);
        left: 0;
        z-index: 99;
        width: 260px;
    }

    .sidebar.hide-sidebar .side-toggle span:first-child {
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    .sidebar.hide-sidebar .side-toggle span:nth-child(2) {
        display: none;
    }

    .sidebar.hide-sidebar .side-toggle span:last-child {
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        margin-top: -7px;
    }

    .right-content {
        margin-left: 0 !important;
    }

    .right-content .page-title {
        display: none;
    }

    .header {
        padding: 0 16px;
        height: var(--header-height);
    }

    .header .title-control .side-toggle {
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
    }

    .header .side-logo {
        display: block;
        width: auto;
    }

    .header .mobile-close-search {
        display: none;
    }

    .counter-row .col-md {
        padding-right: 5px;
        padding-left: 5px;
    }

    .page-title-sm {
        font-size: 24px;
        font-weight: 600;
        margin: -10px 0 20px;
        display: block;
        border-bottom: 1px solid var(--assest-color);
        padding-bottom: 5px;
    }

    .app-logo img {
        margin: 20px 0 10px;
    }
}

@media (max-width: 767px) {
    .btn-default {
        font-size: 14px;
    }

    .header .input-group {
        height: 40px;
        width: 40px;
        border-radius: 10px;
    }

    .header .input-group .input-group-text {
        padding: 7px;
    }

    .header .input-group .form-control {
        display: none;
    }

    .box-title {
        padding-bottom: 8px;
    }

    .box-title .title {
        font-size: 18px;
    }

    .avatar-control .avatar-img {
        height: 30px;
        width: 30px;
    }

    .table th,
    .table td {
        padding: 8px 5px;
    }

    .summary-table-card .border-card {
        padding: 10px 2px;
    }

    .summary-table-card .border-card .row .col {
        text-align: left;
    }

    .summary-table-card .border-card .row .col-12 {
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
    }

    .summary-table-card .avatar-control {
        margin: 0 14px 10px;
    }

    .pagination {
        margin-top: 20px;
    }

    .inline-tabs {
        -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
        overflow: auto;
        margin-top: 0;
    }

    .inline-tabs::-webkit-scrollbar {
        display: none;
    }

    .inline-tabs .nav-link {
        padding: 8px 14px;
    }

    .form-group label {
        font-size: 14px;
    }

    .custom-border-card {
        padding: 16px 20px;
    }

    .custom-border-card .card-header {
        font-size: 18px;
        padding-bottom: 12px;
    }
}

@media (max-width: 567px) {
    .page-search {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin-bottom: 15px;
    }

    .page-search .sorting {
        margin-top: 8px;
    }

    div.dataTables_wrapper div.dataTables_length label,
    div.dataTables_wrapper div.dataTables_filter label {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    div.table-responsive>div.dataTables_wrapper>div.row>div[class^="col-"]:first-child,
    div.table-responsive>div.dataTables_wrapper>div.row>div[class^="col-"]:last-child {
        padding: 0;
        overflow: auto;
    }

    div.dataTables_wrapper div.dataTables_paginate ul.pagination {
        margin-top: 15px;
    }
}

@media (max-width: 340px) {
    .header .side-logo {
        width: 120px;
    }
}

/* Loader */
#dvloader {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    position: fixed;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    /* align to bottom */
    padding-bottom: 100px;
    /* adjust how far from bottom */
    opacity: 0.7;
    background-color: var(--white-color);
    z-index: 9999;
}

#dvloader img {
    max-width: 350px;
    max-height: 350px;
    z-index: 100;
}

/* btn Cancel */
.btn-cancel {
    background: var(--black-color);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--white-color);
    border: 1px solid transparent;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    padding: 8px 20px;
}

.btn-cancel:hover {
    color: var(--black-color);
    background: transparent;
    border-color: var(--black-color);
}

/* Edit-Delete btn */

.edit-delete-btn {
    cursor: pointer;
    outline: none;
    background: var(--primary-light) !important;
    color: var(--primary-color);
    padding: 7px 8px;
    border-radius: 4px;
    border: 1.5px solid transparent;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}

.edit-delete-btn:hover {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: var(--white-color);
}

.edit-delete-btn:focus {
    outline: none;
    box-shadow: none;
}

/* Import File */
.import-file {
    background-color: var(--assest-color);
    color: var(--black-color);
}

.import-file::file-selector-button {
    border-radius: 4px;
    background-color: var(--assest-color);
    border: 1px solid var(--assest-color);
    height: 30px;
    cursor: pointer;
}

.centered {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 20px;
    font-weight: 800;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    width: 100%;
    color: var(--white-color);
    padding-left: 25px;
}

/* Dashboard Hashtag */
.hashtag-card {
    padding: 10px 14px;
    border-left: 3px solid var(--primary-color);
    border-top: 1px solid var(--assest-color);
    border-right: 1px solid var(--assest-color);
    border-bottom: 1px solid var(--assest-color);
    border-radius: 0 8px 8px 0;
    font-size: 14px;
    font-weight: 600;
    background-color: var(--white-color);
    -webkit-transition:
        background-color 0.18s ease,
        -webkit-box-shadow 0.18s ease;
    transition:
        background-color 0.18s ease,
        box-shadow 0.18s ease;
}

.hashtag-card>.row {
    margin: 0;
}

.hashtag-card>.row .col,
.hashtag-card>.row .col-2 .hashtag-card>.row .col-10 {
    padding: 0;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: start;
}

@media (max-width: 1440px) {
    .wallet-image {
        height: 110px;
        border-radius: 15px;
    }
}

@media (max-width: 1260px) {
    .wallet-image {
        height: 50px;
        border-radius: 15px;
    }

    .wallet-image {
        height: 70px;
        border-radius: 10px;
    }
}

@media (max-width: 991px) {
    .wallet-image {
        height: 140px;
        border-radius: 15px;
    }
}

/* Side Menu Partition */
.partition {
    width: 100%;
    border-bottom: none;
    line-height: 1;
    margin: 16px 0 4px;
    padding: 0 12px;
}

.partition span {
    background: transparent;
    margin: 0;
    padding: 0;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--assest-color);
    opacity: .7;
}

/* Demo Mode Box */
.demo-mode-box {
    background: var(--primary-light);
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--primary-color);
    border: 1px solid var(--primary-color);
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
    padding: 8px 14px;
    letter-spacing: 0.02em;
}

.demo-mode-box:hover {
    background: var(--primary-color);
    color: var(--white-color);
    border-color: var(--primary-color);
}

/* Installation */
.list-group-item {
    padding-top: 18px !important;
    padding-bottom: 18px !important;
    background-color: transparent;
}

.dropdown-menu,
.card {
    background-color: var(--white-color);
    border: none;
}

.form-control {
    background-color: var(--white-color);
    color: var(--title-color);
}

.install-bg-img {
    text-align: center;
}

.install-bg-img img {
    max-width: 100%;
    height: auto;
}

.install-title {
    font-size: 42px;
    font-weight: bold;
}

.install_sub_title {
    font-size: 24px;
}

.install_text {
    font-size: 20px;
    margin-bottom: 30px;
    margin-top: 30px;
}

.install-list li {
    font-size: 20px;
    margin-bottom: 10px;
}

.install-list li:hover {
    background-color: var(--white-color);
    color: var(--primary-color);
}

.install-card {
    margin-left: 100px;
    margin-right: 100px;
}

@media (max-width: 1024px) {
    .install-bg-img {
        display: none !important;
    }
}

.install-footer {
    padding: 20px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
    color: var(--black-color);
    background-color: var(--primary-color);
}

.install-footer a {
    color: var(--white-color);
    margin: 0 15px;
    text-decoration: none;
    font-size: 18px;
}

.install-footer a:hover {
    color: var(--black-color);
}

.install-social-icons {
    margin-top: 10px;
}

.install-social-icons a {
    color: var(--white-color);
    font-size: 20px;
    text-decoration: none;
}

.install-social-icons a:hover {
    color: var(--black-color);
}

.install-footer .content {
    position: relative;
    z-index: 1;
}

/* btn Install */
.btn-install {
    background: var(--primary-color);
    border-radius: 5px;
    font-size: 18px;
    font-weight: 600;
    color: var(--white-color);
    border: 1px solid transparent;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    padding: 10px 40px;
}

.btn-install:hover {
    color: var(--primary-color);
    background: transparent;
    border-color: var(--primary-color);
}

/* btn Install Cancel */
.btn-install-cancel {
    background: var(--black-color);
    border-radius: 5px;
    font-size: 18px;
    font-weight: 600;
    color: var(--white-color);
    border: 1px solid transparent;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    padding: 10px 40px;
}

.btn-install-cancel:hover {
    color: var(--black-color);
    background: transparent;
    border-color: var(--black-color);
}

/* Color Picker */
.colorpicker-component {
    display: flex;
    border: 1px solid var(--primary-color);
    border-radius: 5px;
    overflow: hidden;
}

.colorpicker {
    border: none;
    width: 40px;
    height: 40px;
    cursor: pointer;
    padding: 0;
    margin: 0;
}

.hexcolor {
    border: none;
    padding: 10px;
    width: 100px;
    outline: none;
}

/* Hide-Show Btn */
.show-btn,
.hide-btn,
.info-btn,
.draft-btn,
.warning-btn {
    font-weight: bold;
    border: none;
    padding: 6px 18px;
    outline: none;
    border-radius: 50px;
    cursor: pointer;
    font-size: 14px !important;
    border: 2px dashed transparent;
    white-space: nowrap;
}

.show-btn {
    background-color: var(--light-green);
    color: var(--green-color);
}

.hide-btn {
    background-color: var(--light-red);
    color: var(--red-color);
}

.warning-btn {
    background-color: var(--light-warning);
    color: var(--warning-color);
}

.info-btn {
    background-color: var(--primary-light);
    color: var(--primary-color);
}

.draft-btn {
    background-color: var(--assest-color);
    color: var(--light-gray);
}

.show-btn:focus,
.hide-btn:focus,
.info-btn:focus,
.draft-btn:focus,
.warning-btn:focus {
    outline: none;
    box-shadow: none;
}

/* Custom-Card */
.custom-card {
    background-color: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 12px;
    -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
    -webkit-transition: all 0.25s ease;
    transition: all 0.25s ease;
    overflow: hidden;
    margin-bottom: 16px;
}

.custom-card .card-body h3 {
    margin: 0 0 4px;
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: -0.5px;
    line-height: 1.15;
    color: var(--body-color);
}

.custom-card .card-body span {
    font-size: 11px;
    color: var(--light-gray);
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    display: block;
}

.custom-card .card-body {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 20px;
    gap: 12px;
}

.card-icon-primary {
    padding: 0;
    border-radius: 10px;
    color: var(--primary-color);
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: var(--primary-light);
    width: 52px;
    height: 52px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    transition: all 0.2s ease-in-out;
    position: relative;
}

.card-color-primary::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--primary-color);
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    -webkit-transform-origin: left;
    transform-origin: left;
}

.card-icon-primary i {
    font-size: 20px !important;
}

.card-color-primary:hover {
    border-color: var(--primary-color);
    -webkit-box-shadow: 0 4px 20px rgba(254, 44, 85, 0.1);
    box-shadow: 0 4px 20px rgba(254, 44, 85, 0.1);
    -webkit-transform: translateY(-2px);
    transform: translateY(-2px);
}

.card-color-primary:hover:after {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
}

.card-color-primary:hover .card-icon-primary {
    color: var(--white-color);
    background-color: var(--primary-color);
}

.card-color-primary .card-body {
    color: var(--body-color);
}

.profile-picture {
    width: 150px;
    height: 150px;
    border-radius: 10%;
    border: 4px solid var(--white-color);
    object-fit: cover;
    margin-top: -60px;
}

.profile-details p {
    font-size: 16px;
}

/* Earning-Card */
.card-earning {
    background-color: var(--white-color);
    border-radius: 10px;
    padding-top: 10px;
    padding-left: 20px;
    padding-right: 20px;
    align-items: center;
    width: 100%;
}

.card-align {
    display: flex;
    justify-content: space-between;
}

.earning-title {
    font-weight: bold;
    font-size: 16px;
    text-align: center;
}

.earning-amount {
    font-size: 22px;
    font-weight: bold;
    margin: 0;
    color: var(--primary-color);
}

/* Landscape Card */
.landscape-card {
    background-color: var(--assest-color) !important;
    padding: 8px;
    margin: 10px 0;
    border: 3px solid transparent;
}

.landscape-card:hover {
    border: 3px solid var(--primary-color);
}

.wallet-image {
    height: 180px;
    width: 180px;
    border-radius: 10px;
}

.landscape-card-title {
    font-size: 16px;
    font-weight: 600;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.landscape-card-border {
    border-top: 2px dashed var(--primary-color) !important;
    margin: 10px 0px;
}

.story-groups {
    display: flex;
    gap: 30px;
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    outline: none;
    -ms-overflow-style: none;
    scrollbar-width: none;
    padding: 10px;
}

.story-groups::-webkit-scrollbar {
    display: none;
}

.story-group {
    flex: 0 0 auto;
    width: 80px;
    cursor: pointer;
    text-align: center;
    scroll-snap-align: start;
    transition: transform 0.2s ease;
}

.story-group:hover {
    transform: scale(1.05);
}

.story-group .user-img {
    width: 90px;
    height: 90px;
    margin: 0 auto 8px;
    border-radius: 50%;
    border: 3px solid var(--primary-light);
    overflow: hidden;
    position: relative;
    box-shadow: 0 2px 6px var(--black-50);
    transition: all 0.2s ease;
}

.story-group .user-img img,
.story-group .user-img video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Hide scrollbar for all browsers */
.story-groups::-webkit-scrollbar {
    display: none;
}

.reels-wrapper {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    outline: none;
}

.reels-wrapper::-webkit-scrollbar {
    display: none;
}

.reels-container {
    display: flex;
    gap: 20px;
    padding: 10px 5px;
}

.reel {
    position: relative;
    flex: 0 0 auto;
    width: 200px;
    height: 350px;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: var(--header-shadow);
    transition:
        transform 0.4s linear,
        filter 0.4s linear,
        box-shadow 0.4s linear;
    will-change: transform, box-shadow;
}

.reel:hover {
    transform: scale(1.03);
}

.reel video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: inherit;
}

.reel-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: inherit;
    filter: brightness(0.5);
}

.reel:hover .reel-image {
    filter: brightness(1);
}

.reel-overlay {
    position: absolute;
    bottom: 48px;
    right: 12px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    z-index: 2;
}

.reel-actions .action {
    display: flex;
    flex-direction: column;
    align-items: center;
    color: var(--white-color);
    font-size: 23px;
    transition: color 0.3s ease;
}

.reel-actions .action .count {
    font-size: 15px;
    margin-top: 4px;
    color: var(--white-color);
}

.reel-title {
    position: absolute;
    bottom: 8px;
    left: 8px;
    right: 8px;
    padding: 4px 8px;
    color: var(--white-color);
    font-size: 14px;
    font-weight: 500;
    border-radius: 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    z-index: 2;
}

.system-note {
    font-weight: 600;
    font-size: 16px;
    color: var(--black-50);
}

/* Challenge Details Page */
.challenge-details-page {
    border-radius: 20px;
}

.challenge-details-hero,
.challenge-details-panel,
.challenge-details-stat-card,
.challenge-details-reward-card {
    background: var(--white-color);
    border: 1px solid var(--dark-color);
    border-radius: 18px;
    box-shadow: 0 10px 30px var(--dark-color);
}

.challenge-details-hero {
    overflow: hidden;
    margin-bottom: 18px;
}

.challenge-details-banner {
    position: relative;
    min-height: 150px;
    display: flex;
    align-items: flex-end;
    padding: 22px 24px;
}

.challenge-details-banner-image,
.challenge-details-banner-overlay {
    position: absolute;
    inset: 0;
}

.challenge-details-banner-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.challenge-details-banner-overlay {
    background: linear-gradient(135deg, var(--primary-color), var(--black-50));
}

.challenge-details-banner-id {
    position: absolute;
    top: 16px;
    right: 18px;
    padding: 4px 10px;
    border-radius: 999px;
    background: var(--light-gray);
    border: 1px solid var(--white-color);
    font-size: 11px;
    font-weight: 500;
    color: var(--white-color);
}

.challenge-details-banner-title {
    margin: 0;
    max-width: 720px;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--white-color);
    z-index: 1;
}

.challenge-details-hero-body {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 24px;
}

.challenge-details-hero-main {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-width: 0;
}

.challenge-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    width: fit-content;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    color: var(--white-color);
}

.challenge-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: currentColor;
}

.challenge-details-hero-desc {
    margin: 0;
    color: var(--light-gray);
    font-size: 14px;
    line-height: 1.7;
}

.challenge-details-hero-meta {
    color: var(--light-gray);
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
}

.challenge-details-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 18px;
}

.challenge-details-stat-card {
    padding: 18px 20px;
}

.challenge-details-stat-highlight {
    border-left: 3px solid var(--primary-color);
}

.challenge-details-stat-label,
.challenge-details-section-label {
    margin: 0 0 8px;
    color: var(--light-gray);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.challenge-details-stat-value {
    margin: 0;
    color: var(--body-color);
    font-size: 22px;
    font-weight: 600;
    line-height: 1.3;
}

.challenge-details-stat-date {
    font-size: 17px;
}

.challenge-details-stat-sub {
    margin: 6px 0 0;
    color: var(--light-gray);
    font-size: 12px;
}

.challenge-details-audio-card {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 5px 10px;
    gap: 14px;
    border: none;
    border-radius: 14px;
    background: var(--white-color);
    text-align: left;
    transition: all 0.3s;
    border: none;
    outline: none;
    cursor: pointer;
}

.challenge-details-audio-card.is-playing,
.challenge-details-audio-card:hover {
    background: var(--assest-color);
}

.challenge-details-audio-play {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--primary-color);
    color: var(--white-color);
    flex-shrink: 0;
}

.challenge-details-audio-card:focus {
    outline: none;
}

.challenge-details-audio-content {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.challenge-details-audio-title {
    color: var(--body-color);
    font-size: 14px;
    font-weight: 600;
}

.challenge-details-reward-card {
    padding: 18px 20px;
}

@media only screen and (max-width: 1199px) {
    .challenge-details-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media only screen and (max-width: 991px) {
    .challenge-details-page {
        padding: 18px;
    }

    .challenge-details-topbar,
    .challenge-details-hero-body {
        flex-direction: column;
        align-items: flex-start;
    }

    .challenge-details-info-grid {
        grid-template-columns: 1fr;
    }

    .challenge-details-banner-title {
        font-size: 20px;
    }

    .challenge-details-hero-meta {
        white-space: normal;
    }
}

@media only screen and (max-width: 767px) {

    .challenge-details-top-actions,
    .challenge-details-stats-grid {
        width: 100%;
    }

    .challenge-details-top-actions {
        flex-direction: column;
    }

    .challenge-details-action-btn,
    .challenge-details-edit-btn {
        width: 100%;
    }

    .challenge-details-stats-grid {
        grid-template-columns: 1fr;
    }

    .challenge-details-banner {
        min-height: 130px;
        padding: 18px;
    }

    .challenge-details-banner-title {
        font-size: 18px;
    }

    .challenge-details-hero-body,
    .challenge-details-panel,
    .challenge-details-reward-card,
    .challenge-details-stat-card {
        padding: 16px;
    }
}

/* # sourceMappingURL=style.css.map */

/* =============================================
   DASHBOARD — Stat Card Row Spacing
   ============================================= */

.counter-row {
    margin-bottom: 8px;
}

.counter-row [class*="col-"] {
    padding-left: 10px;
    padding-right: 10px;
}

/* =============================================
   DASHBOARD — Chart + Panel Layout
   ============================================= */

.cart-bg {
    padding: 20px;
    background-color: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 12px;
}

.cart-bg .box-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Year / Month toggle buttons in chart header */
.dash-chart-btn {
    padding: 7px 18px;
    border-radius: 8px;
    border: 1.5px solid var(--light-gray);
    background: var(--white-color);
    color: var(--light-gray);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: var(--font);
    outline: none;
}

.dash-chart-btn:hover {
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.dash-chart-btn:focus {
    outline: none;
}

.dash-chart-btn.active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--white-color);
    box-shadow: 0 3px 10px var(--primary-light-color);
}

.dash-follower-name {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
}

.dash-user-name {
    background-color: var(--primary-light);
    color: var(--primary-color);
    display: inline-block !important;
    font-size: 12px;
    width: fit-content;
}

/* =============================================
   DASHBOARD — ApexCharts Theme Integration
   ============================================= */

/* Axis text */
.apexcharts-xaxis-label,
.apexcharts-yaxis-label {
    fill: var(--light-gray) !important;
    font-size: 11px !important;
    font-family: inherit !important;
}

/* Grid lines */
.apexcharts-gridline {
    stroke: var(--assest-color) !important;
    stroke-dasharray: 4 !important;
}

/* No border on plot area */
.apexcharts-plot-series {
    border: none;
}

/* Tooltip */
.apexcharts-tooltip {
    background: var(--white-color) !important;
    border: 1px solid var(--assest-color) !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 16px var(--header-shadow) !important;
    color: var(--body-color) !important;
    font-family: inherit !important;
}

.apexcharts-tooltip-title {
    background: var(--assest-color) !important;
    border-bottom: 1px solid var(--assest-color) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--body-color) !important;
    padding: 6px 12px !important;
}

.apexcharts-tooltip-series-group {
    padding: 6px 12px !important;
}

.apexcharts-tooltip-text-y-value {
    font-weight: 700 !important;
    color: var(--primary-color) !important;
}

/* Legend text */
.apexcharts-legend-text {
    color: var(--body-color) !important;
    font-size: 12px !important;
    font-family: inherit !important;
}

/* Toolbar icons */
.apexcharts-menu-icon,
.apexcharts-reset-icon,
.apexcharts-zoom-icon {
    color: var(--light-gray) !important;
}

/* =============================================
   DASHBOARD — Hashtag Card Improvements
   ============================================= */

.hashtag-card .hashtag-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--primary-light);
    color: var(--primary-color);
    font-size: 14px;
    font-weight: 700;
    flex-shrink: 0;
}

/* =============================================
   DASHBOARD — Video Box Panel
   ============================================= */

.video-box .box-title {
    border-radius: 12px 12px 0 0;
}

.video-box .border-card {
    padding: 10px 14px;
    border-radius: 8px;
    border: 1px solid var(--assest-color) !important;
    background: var(--white-color);
    margin-bottom: 8px;
    transition: all 0.2s ease;
}

.video-box .border-card:last-child {
    margin-bottom: 0;
}

.video-box .border-card:hover {
    border-color: var(--primary-color) !important;
    box-shadow: 0 2px 10px rgba(254, 44, 85, 0.07);
}

/* =============================================
   DASHBOARD — Responsive Adjustments
   ============================================= */

@media only screen and (max-width: 991px) {
    .counter-row [class*="col-"] {
        padding-left: 8px;
        padding-right: 8px;
    }

    .cart-bg,
    .video-box {
        margin-bottom: 16px;
    }
}

@media only screen and (max-width: 575px) {
    .custom-card .card-body h3 {
        font-size: 1.4rem;
    }

    .card-icon-primary {
        width: 44px;
        height: 44px;
    }
}

/* =====================================================
   GLOBAL MODULE UI — Toolbar, Table, Cards, Forms
   ===================================================== */

/* --- Page Header Bar (breadcrumb + CTA row) --- */

.ph {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 12px;
    padding: 13px 16px;
    background: var(--white-color);
    border-radius: 10px;
    border: 1px solid var(--assest-color);
    -webkit-box-shadow: 0 1px 6px var(--dark-color);
    box-shadow: 0 1px 6px var(--dark-color);
}

.ph .breadcrumb {
    margin: 0;
    padding: 0;
    background: transparent;
    font-size: 13px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.action-bar {
    background: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 12px;
    -webkit-box-shadow: 0 1px 4px var(--dark-color);
    box-shadow: 0 1px 4px var(--dark-color);
    overflow: hidden;
    margin-bottom: 16px;
    padding: 14px 16px;
}

.action-row-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

.export-note {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    color: var(--text-body);
}

.export-note>i {
    font-size: 15px;
    color: var(--primary-color);
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.export-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
}

.exp-btn {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    font-size: 12px;
    font-weight: 500;
    border-radius: 7px;
    cursor: pointer;
    -webkit-transition: all 0.15s;
    transition: all 0.15s;
    white-space: nowrap;
    line-height: 1.4;
    background: var(--white-color);
    color: var(--text-body);
    border: 1px solid var(--assest-color);
}

.exp-btn:hover {
    background: var(--bg-light);
    border-color: var(--assest-color);
    color: var(--black-color);
}

.exp-btn>i {
    font-size: 14px;
}

.search-filter-bar {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 12px;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.searchbox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
    background: var(--assest-color);
    border: 1px solid var(--assest-color);
    border-radius: 9px;
    padding: 4px 14px;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    min-width: 200px;
    -webkit-transition:
        border-color 0.18s,
        background 0.18s,
        -webkit-box-shadow 0.18s;
    transition:
        border-color 0.18s,
        background 0.18s,
        box-shadow 0.18s;
}

.searchbox:focus-within {
    border-color: var(--primary-color);
    background: var(--white-color);
    -webkit-box-shadow: 0 0 0 3px var(--primary-light);
    box-shadow: 0 0 0 3px var(--primary-light);
}

.searchbox-icon {
    color: var(--text-muted);
    font-size: 14px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.searchbox .form-control {
    border: none;
    background: transparent;
    padding: 7px 0;
    -webkit-box-shadow: none;
    box-shadow: none;
    font-size: 14px;
    color: var(--black-color);
    height: auto !important;
    line-height: 1.5;
    border-radius: 0;
}

.filter-group {
    display: flex;
}

.filter-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    background: var(--assest-color);
    border-radius: 10px;
    min-width: 180px;
    border: 1.5px solid var(--assest-color);
    -webkit-transition:
        border-color 0.15s,
        -webkit-box-shadow 0.15s;
    transition:
        border-color 0.15s,
        box-shadow 0.15s;
}

.filter-item:focus-within {
    border-color: var(--primary-color);
    -webkit-box-shadow: 0 0 0 3px var(--primary-light);
    box-shadow: 0 0 0 3px var(--primary-light);
}

.sort-label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 8px 0 12px;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-muted);
    white-space: nowrap;
    border-right: 1px solid var(--assest-color);
    height: 100%;
    letter-spacing: 0.04em;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.filter-item .form-control {
    border: none;
    background: transparent;
    -webkit-box-shadow: none;
    box-shadow: none;
    font-size: 14px;
    color: var(--black-color);
    height: auto !important;
    line-height: 1.5;
    cursor: pointer;
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/* --- Select2 inside filter-item --- */
.filter-item .select2-container .select2-selection--single {
    background: var(--assest-color);
    border: none;
}

/* new table design  */
.table-card {
    background: var(--white-color);
    border-radius: 14px;
    border: 1px solid var(--assest-color);
    -webkit-box-shadow: 0 1px 6px var(--dark-color);
    box-shadow: 0 1px 6px var(--dark-color);
    overflow: hidden;
    padding: 10px 16px 16px;
}

.table-card .table-responsive {
    border-radius: 0;
}

.table-card .table {
    margin-bottom: 0;
}

.table-card .table thead th {
    background: var(--assest-color);
    font-size: 11.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.55px;
    color: var(--body-color);
    padding: 13px 16px;
    border-bottom: 2px solid var(--assest-color);
    border-top: 0;
    white-space: nowrap;
    vertical-align: middle;
}

.table-card .table td {
    padding: 12px 16px;
    vertical-align: middle;
    border-bottom: 1px solid var(--assest-color);
    border-top: 0;
    font-size: 13.5px;
}

.table-card tbody tr:last-child td {
    border-bottom: none;
}

.table-card tbody tr:hover td {
    background: var(--primary-light);
}

.table-card .dataTables_wrapper {
    padding: 0;
}

.table-card .dataTables_wrapper>.row {
    margin: 0;
    padding: 12px 20px 0px 20px;
    border-top: 1px solid var(--assest-color);
    background: var(--white-color);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.table-card .dataTables_info {
    font-size: 12px;
    color: var(--text-muted);
    padding: 0;
}

.table-card .dataTables_length {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.table-card .dataTables_length label {
    margin: 0;
    font-size: 12px;
    color: var(--text-muted);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
}

.table-card .dataTables_length select.form-control {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: var(--bg-light);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 10 6'%3E%3Cpath fill='%236b7280' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    border: 1px solid var(--assest-color);
    border-radius: 6px;
    padding: 4px 24px 4px 8px;
    font-size: 12px;
    color: var(--black-color);
    height: auto;
    margin: 0;
    cursor: pointer;
    min-width: 56px;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.table-card .dataTables_length select.form-control:focus {
    border-color: var(--primary-color);
    -webkit-box-shadow: 0 0 0 2px var(--primary-light);
    box-shadow: 0 0 0 2px var(--primary-light);
    outline: none;
}

.table-card .dataTables_paginate {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.table-card .pagination {
    margin: 0;
    border-radius: 10px;
    background: transparent;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 3px;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding: 5px;
    border: 1px solid var(--assest-color);
}

.table-card .pagination .page-item {
    display: flex;
    justify-content: center;
    align-items: center;
}

.table-card .pagination .page-item .page-link {
    border: 1px solid var(--assest-color);
    border-radius: 50%;
    font-size: 12px;
    padding: 5px 10px;
    color: var(--text-body, var(--black-color));
    background: var(--white-color);
    font-weight: 500;
    -webkit-transition: all 0.15s;
    transition: all 0.15s;
    height: 30px;
    width: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.table-card .pagination .page-item.active .page-link {
    background: var(--primary-color) !important;
    border-color: var(--primary-color);
    color: var(--white-color);
    -webkit-box-shadow: 0 2px 6px var(--primary-light);
    box-shadow: 0 2px 6px var(--primary-light);
}

.table-card .pagination .page-item .page-link:hover {
    background: var(--primary-light);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

.table-card .pagination .page-item.active .page-link:hover {
    background: var(--primary-color) !important;
    color: var(--white-color);
}

.table-card .pagination .page-item.disabled .page-link {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

/* START: IMAGE UPLOAD COMPONENT */
.image-upload-wrapper {
    max-width: 220px;
}

.image-upload-wrapper.small {
    max-width: 100px;
    display: flex;
    align-items: center;
}

.image-upload-wrapper input[type="file"] {
    display: none;
}

.drop-area {
    position: relative;
    width: 85%;
    height: 170px;
    border: 2px dashed var(--assest-color);
    border-radius: 10px;
    cursor: pointer;
    overflow: hidden;
    transition: 0.25s;
}

.image-upload-wrapper.small .drop-area {
    width: 100px;
    height: 100px;
    border-radius: 10px;
}

.drop-area img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
    opacity: 0;
    transition: 0.3s;
}

.drop-prompt,
.drop-change-hint {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    text-align: center;
}

.drop-icon {
    width: 46px;
    height: 46px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-light);
    color: var(--primary-color);
    border-radius: 6px;
    font-size: 20px;
    margin-bottom: 8px;
    transition: 0.25s;
}

.image-upload-wrapper.small .drop-icon {
    width: 30px;
    height: 30px;
}

.drop-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-dark);
    margin: 0 !important;
}

.drop-change-hint {
    bottom: 0;
    top: auto;
    height: auto;
    padding: 8px;
    flex-direction: row;
    gap: 6px;
    background: var(--primary-color);
    color: var(--white-color);
    font-size: 12px;
    font-weight: 600;
    opacity: 0;
    transition: 0.25s;
}

.image-upload-wrapper.small .drop-change-hint {
    font-size: 9px;
    padding: 4px;
}

.drop-area:hover {
    border-color: var(--primary-color);
    background: var(--primary-light);
}

.drop-area:hover .drop-icon {
    background: var(--primary-color);
    color: var(--white-color);
    transform: translateY(-2px);
}

.drop-area.dragover {
    border-color: var(--primary-color);
    background: var(--primary-light);
    box-shadow: 0 0 0 3px var(--primary-light);
}

.image-upload-wrapper.has-preview img {
    opacity: 1;
}

.image-upload-wrapper.has-preview .drop-prompt {
    opacity: 0;
    pointer-events: none;
}

.image-upload-wrapper.has-preview .drop-area:hover .drop-change-hint {
    opacity: 1;
}

/* ============================================================
   TOGGLE — Enhanced Premium Switch
   ============================================================ */
.switch {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 7px;
    position: relative;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.switch label {
    position: relative;
    width: 38px;
    height: 21px;
    border-radius: 21px;
    background: var(--red-color);
    cursor: pointer;
    margin: 0;
    -webkit-flex-shrink: 0;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -webkit-box-shadow:
        inset 0 1px 3px rgba(0, 0, 0, 0.22),
        0 1px 2px rgba(0, 0, 0, 0.08);
    box-shadow:
        inset 0 1px 3px rgba(0, 0, 0, 0.22),
        0 1px 2px rgba(0, 0, 0, 0.08);
    -webkit-transition:
        background 0.28s cubic-bezier(0.4, 0, 0.2, 1),
        box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    transition:
        background 0.28s cubic-bezier(0.4, 0, 0.2, 1),
        box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

.switch:hover label {
    background: var(--red-color);
}

.switch label:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 3px;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    background: var(--white-color);
    -webkit-box-shadow:
        0 1px 4px rgba(0, 0, 0, 0.26),
        0 0 0 0.5px rgba(0, 0, 0, 0.04);
    box-shadow:
        0 1px 4px rgba(0, 0, 0, 0.26),
        0 0 0 0.5px rgba(0, 0, 0, 0.04);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition:
        -webkit-transform 0.28s cubic-bezier(0.4, 0, 0.2, 1),
        width 0.12s ease;
    transition:
        transform 0.28s cubic-bezier(0.4, 0, 0.2, 1),
        width 0.12s ease;
    will-change: transform;
}

.switch label:active:after {
    width: 18px;
}

.switch input[type="checkbox"]:checked+label {
    background: var(--green-color);
    -webkit-box-shadow:
        inset 0 1px 3px rgba(0, 0, 0, 0.16),
        0 0 0 3px rgba(5, 143, 0, 0.12);
    box-shadow:
        inset 0 1px 3px rgba(0, 0, 0, 0.16),
        0 0 0 3px rgba(5, 143, 0, 0.12);
}

.switch:hover input[type="checkbox"]:checked+label {
    background: var(--green-color);
}

.switch input[type="checkbox"]:checked+label:after {
    -webkit-transform: translateY(-50%) translateX(17px);
    transform: translateY(-50%) translateX(17px);
}

.status-checkbox {
    display: none;
}

.switch input:not(:checked)~.toggle-text::after {
    content: attr(data-off);
    color: var(--red-color);
}

.switch input:checked~.toggle-text::after {
    content: attr(data-on);
    color: var(--green-color);
}

.toggle-text {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.25px;
    line-height: 1;
}

.video_box .vup-card {
    background: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 12px;
    -webkit-box-shadow: var(--shadow-sm);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    -webkit-transition:
        -webkit-box-shadow 0.22s ease,
        border-color 0.22s ease;
    transition:
        box-shadow 0.22s ease,
        border-color 0.22s ease;
}

/* ── Header strip ────────────────────────────────── */
.video_box .vup-card-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 12px 18px;
    background: var(--bg-light);
    border-bottom: 1px solid var(--assest-color);
}

.video_box .vup-card-header-left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
}

.video_box .vup-icon-badge {
    width: 32px;
    height: 32px;
    border-radius: 7px;
    background: var(--primary-light);
    color: var(--primary-color);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 13px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.video_box .vup-header-text {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.video_box .vup-header-primary {
    font-size: 13px;
    font-weight: 600;
    color: var(--body-color);
    line-height: 1.3;
}

.video_box .vup-format-tag {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.8px;
    color: var(--primary-color);
    background: var(--primary-light);
    padding: 3px 9px;
    border-radius: 4px;
    text-transform: uppercase;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

/* ── File select + upload row ────────────────────── */
.video_box .vup-file-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
}

.video_box .vup-file-input-wrap {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    min-width: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background: var(--bg-light);
    border: 1px solid var(--assest-color);
    border-radius: 8px;
    overflow: hidden;
    -webkit-transition:
        border-color 0.2s ease,
        background 0.2s ease;
    transition:
        border-color 0.2s ease,
        background 0.2s ease;
}

.video_box .vup-file-input-wrap:hover,
.video_box .vup-file-input-wrap:focus-within {
    border-color: var(--primary-color);
    background: var(--primary-light);
    outline: none;
}

.video_box .vup-file-icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0 4px 0 13px;
    color: var(--text-muted);
    font-size: 14px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    pointer-events: none;
}

.video_box .vup-file-input {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    min-width: 0;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
    padding: 9px 12px !important;
    font-size: 13px;
    color: var(--text-body);
    cursor: pointer;
    outline: none !important;
}

.video_box .vup-file-input:focus {
    outline: none;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}

.video_box .vup-file-input::-webkit-file-upload-button {
    background: var(--primary-color);
    color: var(--white-color);
    border: none;
    padding: 5px 12px;
    border-radius: 5px;
    font-size: 11px;
    font-weight: 600;
    font-family: "Poppins", sans-serif;
    cursor: pointer;
    margin-right: 8px;
    -webkit-transition: opacity 0.15s ease;
    transition: opacity 0.15s ease;
}

.video_box .vup-file-input::file-selector-button {
    background: var(--primary-color);
    color: var(--white-color);
    border: none;
    padding: 5px 12px;
    border-radius: 5px;
    font-size: 11px;
    font-weight: 600;
    font-family: "Poppins", sans-serif;
    cursor: pointer;
    margin-right: 8px;
    -webkit-transition: opacity 0.15s ease;
    transition: opacity 0.15s ease;
}

.video_box .vup-file-input::-webkit-file-upload-button:hover,
.video_box .vup-file-input::file-selector-button:hover {
    opacity: 0.88;
}

/* ── Upload trigger button ───────────────────────── */
.video_box .vup-upload-trigger {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    font-size: 13px;
    font-weight: 600;
    border-radius: 8px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    white-space: nowrap;
    letter-spacing: 0.1px;
    -webkit-transition:
        opacity 0.2s ease,
        -webkit-transform 0.15s ease,
        -webkit-box-shadow 0.2s ease;
    transition:
        opacity 0.2s ease,
        transform 0.15s ease,
        box-shadow 0.2s ease;
}

.video_box .vup-upload-trigger:hover {
    opacity: 0.9;
    -webkit-transform: translateY(-1px);
    transform: translateY(-1px);
    color: var(--white-color) !important;
    -webkit-box-shadow: var(--shadow-md);
    box-shadow: var(--shadow-md);
}

.video_box .vup-upload-trigger i {
    font-size: 14px;
}

/* ── Progress / filelist area ────────────────────── */
.video_box .vup-progress-area {
    font-size: 13px;
    color: var(--text-body);
    min-height: 0;
}

.video_box .vup-progress-area:not(:empty) {
    padding: 12px 18px;
    border-top: 1px solid var(--assest-color);
    background: var(--bg-light);
}

.video_box .vup-progress-area>div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    background: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 8px;
    margin-bottom: 4px;
    word-break: break-all;
}

.video_box .vup-progress-area>div:last-child {
    margin-bottom: 0;
}

.video_box .vup-progress-area>div b {
    color: var(--primary-color);
    font-weight: 700;
    margin-left: auto;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.video_box .vup-progress-area>div b span {
    display: inline-block;
    min-width: 40px;
    text-align: right;
}

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 576px) {
    .video_box .vup-file-row {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: stretch;
        -ms-flex-align: stretch;
        align-items: stretch;
    }

    .video_box .vup-upload-trigger {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
}

/* user login type badge  */
.type-badge {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    border: 1.5px solid var(--assest-color);
    background: var(--white-color);
    color: var(--text-body);
    white-space: nowrap;
    line-height: 1.5;
}

.type-badge-normal {
    color: var(--text-muted);
    border-color: var(--assest-color);
}

.type-badge-otp {
    color: var(--primary-color);
    border-color: var(--primary-color);
    background: var(--primary-light);
}

.type-badge-google {
    color: var(--green-color);
    border-color: var(--green-color);
}

.type-badge-apple {
    color: var(--body-color);
    border-color: var(--body-color);
}

/* ==============================
   User / Company Dashboard
   Premium Dashboard Redesign
============================== */

/* --- Hero Profile Card --- */
.dash-hero-card {
    background: var(--primary-light);
    border-radius: 20px;
    border: 1px solid var(--assest-color);
    overflow: hidden;
    box-shadow: 0 2px 20px var(--dark-color);
    margin-bottom: 28px;
}

.dash-hero-banner {
    height: 130px;
    background: linear-gradient(135deg,
            var(--primary-color) 0%,
            var(--red-color) 100%);
    position: relative;
    overflow: hidden;
}

.dash-hero-content {
    padding: 0 28px 28px;
}

.dash-hero-identity {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: flex-end;
    -ms-flex-align: flex-end;
    align-items: flex-end;
    gap: 18px;
    margin-bottom: 24px;
    padding-top: 8px;
}

.dash-avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    border: 4px solid var(--white-color);
    object-fit: cover;
    margin-top: -52px;
    box-shadow: 0 2px 10px var(--black-50);
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -webkit-transition:
        -webkit-transform 0.3s ease,
        -webkit-box-shadow 0.3s ease;
    transition:
        transform 0.3s ease,
        box-shadow 0.3s ease;
    display: block;
    position: relative;
    z-index: 1;
}

.dash-avatar:hover {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    box-shadow: 0 3px 15px var(--black-50);
}

.dash-identity-info {
    padding-bottom: 10px;
}

.dash-fullname {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--body-color);
    margin: 0 0 4px;
    line-height: 1.2;
}

.dash-username {
    font-size: 12px;
    font-weight: 500;
    color: var(--white-color);
    background-color: var(--primary-color);
    border-radius: 50px;
    padding: 4px 10px;
    box-shadow: var(--header-shadow);
}

/* --- Section Divider Labels --- */
.dash-section {
    margin-top: 28px;
}

.dash-section-label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
}

.dash-section-label-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--primary-color);
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.dash-section-label-text {
    font-size: 12px;
    font-weight: 700;
    color: var(--body-color);
    letter-spacing: 0.07em;
    text-transform: uppercase;
    white-space: nowrap;
}

.dash-section-label-line {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    height: 1px;
    background: var(--assest-color);
}

/* --- Responsive: Medium screens (tablet landscape) --- */
@media (max-width: 1100px) {
    .dash-stats-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 12px;
    }
}

/* --- Responsive: Tablet --- */
@media (max-width: 768px) {
    .dash-hero-content {
        padding: 0 20px 24px;
    }

    .dash-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    .dash-stat-value {
        font-size: 1.3rem;
    }
}

/* --- Responsive: Mobile --- */
@media (max-width: 576px) {
    .dash-hero-banner {
        height: 100px;
    }

    .dash-avatar {
        width: 80px;
        height: 80px;
        margin-top: -40px;
    }

    .dash-hero-content {
        padding: 0 14px 20px;
    }

    .dash-hero-identity {
        gap: 12px;
        margin-bottom: 18px;
    }

    .dash-fullname {
        font-size: 1.05rem;
    }

    .dash-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .dash-stat-card {
        padding: 12px;
        gap: 10px;
    }

    .dash-stat-icon-wrap {
        width: 36px;
        height: 36px;
        font-size: 15px;
        border-radius: 10px;
    }

    .dash-stat-value {
        font-size: 1.15rem;
    }

    .dash-stat-label {
        font-size: 9.5px;
    }

    .dash-section {
        margin-top: 20px;
    }
}

/* --------------------------------------------------------------------------
   Sortable list items — drag-and-drop reorder rows
   -------------------------------------------------------------------------- */

/* Row item replacing inline style="background-color…" */
.sort-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 12px;
    background: var(--bg-light);
    border: 1px solid var(--assest-color);
    border-radius: 8px;
    padding: 10px 16px;
    cursor: -webkit-grab;
    cursor: grab;
    -webkit-transition:
        -webkit-box-shadow 0.15s ease,
        background 0.15s ease;
    transition:
        box-shadow 0.15s ease,
        background 0.15s ease;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.sort-item:hover {
    background: var(--white-color);
    -webkit-box-shadow: 0 4px 12px var(--dark-color);
    box-shadow: 0 4px 12px var(--dark-color);
}

.sort-item:active {
    cursor: -webkit-grabbing;
    cursor: grabbing;
    -webkit-box-shadow: 0 4px 12px var(--dark-color);
    box-shadow: 0 4px 12px var(--dark-color);
}

/* Grip icon — visual drag affordance */
.sort-handle {
    color: var(--text-muted);
    font-size: 13px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -webkit-transition: color 0.15s ease;
    transition: color 0.15s ease;
}

.sort-item:hover .sort-handle {
    color: var(--primary-color);
}

/* ==========================================================================
   APP SETTINGS — Premium SaaS Settings Page Layout
   ========================================================================== */

/* Two-column page wrapper: sidebar nav + content area */
.settings-page-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 24px;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
}

/* ── Left Sidebar Navigation ─────────────────────────────────────────────── */

.settings-sidenav {
    width: 220px;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    position: -webkit-sticky;
    position: sticky;
    top: 84px;
}

.settings-sidenav-inner {
    background: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 14px;
    -webkit-box-shadow: var(--header-shadow);
    box-shadow: var(--header-shadow);
    overflow: hidden;
}

.settings-nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.settings-nav-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 9px 12px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--primary-color) !important;
}

.settings-nav-item {
    width: 100%;
    border-bottom: 1px solid var(--assest-color);
}

.settings-nav-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
    padding: 9px 12px;
    border-left: 3px solid transparent;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--text-muted);
    cursor: pointer;
    -webkit-transition:
        background 0.16s ease,
        color 0.16s ease;
    transition:
        background 0.16s ease,
        color 0.16s ease;
}

.settings-nav-link i {
    font-size: 13px;
    width: 16px;
    text-align: center;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.settings-nav-link:hover {
    background: var(--primary-light);
    color: var(--primary-color);
}

.settings-nav-link.active {
    background: var(--primary-light);
    color: var(--primary-color);
    font-weight: 600;
    border-left: 3px solid var(--primary-color);
}

/* ── Main Content Area ───────────────────────────────────────────────────── */

.settings-content {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    min-width: 0;
}

/* ── Settings Section (grouped block with header) ───────────────────────── */

.settings-section {
    margin-bottom: 40px;
}

/* Section header: icon bubble + title + description */
.settings-section-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: flex-start;
    -ms-flex-align: flex-start;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 18px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--assest-color);
}

.settings-section-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--primary-light);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.settings-section-icon i {
    font-size: 15px;
    color: var(--primary-color);
}

.settings-section-info {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

.settings-section-title {
    font-size: 17px;
    font-weight: 700;
    color: var(--body-color);
    margin: 0 0 4px;
    line-height: 1.3;
}

.settings-section-desc {
    font-size: 13px;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.5;
}

/* ── Panel (white card container inside a section) ───────────────────────── */

.settings-panel {
    background: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 14px;
    -webkit-box-shadow: 0 1px 6px var(--dark-color);
    box-shadow: 0 1px 6px var(--dark-color);
    padding: 18px 20px;
    margin-bottom: 16px;
}

/* Inner sub-header within a panel (icon + label) */
.settings-panel-inner-header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 8px;
    font-size: 18px;
    font-weight: 700;
    color: var(--body-color);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--assest-color);
}

.settings-panel-inner-header i {
    font-size: 13px;
    color: var(--primary-color);
}

/* Footer row inside a panel — right-aligned save button */
.settings-panel-footer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding-top: 16px;
    margin-top: 8px;
}

/* ── Field group sub-section titles ─────────────────────────────────────── */

.settings-field-group {
    margin-bottom: 24px;
}

.settings-field-group:last-child {
    margin-bottom: 0;
}

.settings-field-group-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--light-gray);
    margin-bottom: 14px;
}

/* Hint text beneath an input */
.settings-field-hint {
    font-size: 12px;
    color: var(--text-muted);
    margin: 4px 0 8px;
    line-height: 1.45;
}

/* Inline text link (settings context) */
.settings-link {
    color: var(--primary-color);
    font-weight: 500;
}

.settings-link:hover {
    text-decoration: underline !important;
}

/* ── API Path copy row ───────────────────────────────────────────────────── */

.settings-copy-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 10px;
}

.settings-copy-btn {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 42px;
    height: 46px;
    border: 1px solid var(--assest-color);
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px;
    background: var(--white-color);
    color: var(--body-color);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    -webkit-transition:
        background 0.16s,
        border-color 0.16s,
        color 0.16s;
    transition:
        background 0.16s,
        border-color 0.16s,
        color 0.16s;
}

.settings-copy-btn:hover {
    background: var(--primary-light);
    border-color: var(--primary-color);
    color: var(--primary-color);
}

/* ── Stacked logo upload group ───────────────────────────────────────────── */

.settings-logo-stack {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 16px;
}

/* ── Repeater rows (social links / onboarding screens) ───────────────────── */

.settings-repeater-row {
    padding: 10px 0;
    border-bottom: 1px solid var(--assest-color);
}

/* New-entry row sits above existing rows without top padding */
.settings-repeater-row-new {
    padding-top: 0;
}

/* Add / Remove buttons for repeater rows */
.settings-add-btn {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    padding: 9px 16px;
    font-size: 13px;
}

.settings-remove-btn {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    padding: 9px 14px;
}

/* ==========================================================================
   APP SETTINGS — Responsive Overrides
   ========================================================================== */

@media (max-width: 991px) {

    /* Stack to single column on tablets/mobile */
    .settings-page-wrapper {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
    }

    .settings-sidenav {
        width: 100%;
        position: static;
    }

    /* Horizontal scrolling nav strip on small screens */
    .settings-sidenav-inner {
        padding: 8px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        gap: 4px;
    }

    .settings-nav-list {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        gap: 4px;
    }

    .settings-nav-item {
        margin-bottom: 0;
    }

    .settings-nav-link {
        padding: 7px 12px;
        font-size: 13px;
    }
}

/* new content upload design  */

.repeater-item {
    background-color: var(--white-color);
    border: 1px solid var(--assest-color);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
    transition: box-shadow 0.2s ease;
    margin-bottom: 12px;
}

.repeater-item:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.repeater-item-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background-color: var(--assest-color);
    border-bottom: 1px solid var(--assest-color);
}

.repeater-item-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--primary-color);
    color: var(--white-color);
    font-size: 12px;
    font-weight: 700;
    flex-shrink: 0;
}

.repeater-item-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--body-color);
    flex: 1;
}

.repeater-item-body {
    padding: 16px;
}

.repeater-item-body .form-group {
    margin-bottom: 0;
}

.repeater-add-row {
    display: flex;
    align-items: center;
    padding-top: 6px;
}

.btn-repeater-add {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 20px;
    background: var(--primary-color);
    color: var(--white-color);
    border: none;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition:
        opacity 0.2s ease,
        transform 0.1s ease;
    box-shadow: 0 3px 10px var(--primary-light);
    font-family: var(--font);
}

.btn-repeater-add:hover {
    opacity: 0.9;
    transform: translateY(-1px);
    color: var(--white-color);
}

.btn-repeater-add:active {
    transform: translateY(0);
    opacity: 1;
}

.btn-repeater-add:focus,
.btn-repeater-remove:focus {
    outline: none;
    box-shadow: none;
}

.btn-repeater-add i {
    font-size: 11px;
}

.btn-repeater-remove {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border: 1.5px solid var(--red-color);
    background: transparent;
    color: var(--red-color);
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    transition:
        background 0.2s ease,
        color 0.2s ease;
    margin-left: auto;
    flex-shrink: 0;
    padding: 0;
}

.btn-repeater-remove:hover {
    background: var(--red-color);
    color: var(--white-color);
}

@media (max-width: 767px) {
    .repeater-item-body .form-row>[class*="col-"] {
        margin-bottom: 12px;
    }

    .repeater-item-body .form-row>[class*="col-"]:last-child {
        margin-bottom: 0;
    }
}

/* ===== Video Card UI (Feed Module) ===== */
.video-card {
    position: relative;
    border-radius: 14px;
    overflow: hidden;
    margin-bottom: 20px;
    background: var(--white-color);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    border: 1px solid var(--assest-color);
    transition:
        transform 0.25s ease,
        box-shadow 0.25s ease;
}

.video-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.11);
}

/* Media */
.vc-media {
    position: relative;
    height: 220px;
    overflow: hidden;
}

.vc-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
    display: block;
}

.video-card:hover .vc-img {
    transform: scale(1.05);
}

.vc-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom,
            rgba(0, 0, 0, 0.08) 0%,
            transparent 32%,
            rgba(0, 0, 0, 0.64) 100%);
    pointer-events: none;
}

/* Play button */
.vc-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.85);
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.18);
    border: 2px solid rgba(255, 255, 255, 0.55);
    color: var(--white-color);
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition:
        opacity 0.2s ease,
        transform 0.2s ease;
    padding: 0;
}

.video-card:hover .vc-play {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

/* Type badge */
.vc-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 5;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    padding: 4px 11px;
    border-radius: 20px;
    color: var(--white-color);
    font-family: var(--font);
    border: 1px solid rgba(255, 255, 255, 0.22);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
    -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22);
    line-height: 1.4;
    pointer-events: none;
    opacity: 1;
}

.vc-badge-normal {
    background: var(--primary-color);
}

.vc-badge-subscription {
    background: var(--warning-color);
}

/* Action buttons (top-right, reveal on hover) */
.vc-actions {
    position: absolute;
    top: 12px;
    right: 12px;
    display: flex;
    gap: 6px;
    opacity: 0;
    transform: translateY(-5px);
    transition:
        opacity 0.2s ease,
        transform 0.2s ease;
}

.video-card:hover .vc-actions {
    opacity: 1;
    transform: translateY(0);
}

.vc-action-btn {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    transition:
        background 0.2s ease,
        color 0.2s ease;
    cursor: pointer;
    border: none;
    background-color: var(--white-color);
    color: var(--primary-color);
}

.vc-action-btn:hover {
    background-color: var(--primary-color);
    color: var(--white-color);
}

/* Caption overlaid on image */
.vc-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 12px 14px;
}

.vc-title {
    font-size: 13px;
    font-weight: 700;
    color: var(--white-color);
    margin: 0 0 4px;
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Footer bar */
.vc-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    border-top: 1px solid var(--assest-color);
}

.vc-stats {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 12px;
    font-weight: 600;
    color: var(--black-50);
}

.vc-stats i {
    color: var(--primary-color);
    margin-right: 3px;
}

/* ===== Video Card UI End ===== */

/* ===== Glassmorphic Login Redesign ===== */
.login-wrapper {
    height: 100vh;
    width: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: clamp(12px, 3.5vh, 32px) clamp(16px, 3.5vw, 24px);
    font-family: var(--login-font-family);
    box-sizing: border-box;
    overflow: hidden;
    position: relative;
}

.login-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--login-bg-overlay);
    z-index: 1;
}

.login-container {
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(12px, 3vh, 24px);
    box-sizing: border-box;
    position: relative;
    z-index: 2;
}

.login-card {
    width: 100%;
    background: var(--login-card-bg);
    border: 1px solid var(--login-card-border);
    border-radius: clamp(16px, 4vh, 28px);
    box-shadow: var(--login-card-shadow);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    padding: clamp(24px, 6vh, 48px) clamp(20px, 6vw, 44px);
    display: flex;
    flex-direction: column;
    gap: clamp(16px, 4vh, 28px);
    box-sizing: border-box;
}

.login-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: clamp(12px, 2vh, 18px);
}

.login-logo-container {
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-logo-img {
    height: clamp(28px, 5vh, 38px);
    width: auto;
    object-fit: contain;
}

.login-logo-text-dt {
    font-size: clamp(26px, 4vh, 32px);
    font-weight: 700;
    color: var(--white-color);
    letter-spacing: -0.5px;
}

.login-logo-text-trends {
    font-size: clamp(26px, 4vh, 32px);
    font-weight: 700;
    color: var(--primary-color);
    letter-spacing: -0.5px;
}

.login-badge {
    background: var(--login-input-bg);
    border: 1px solid var(--login-input-border);
    border-radius: 50px;
    padding: clamp(4px, 1vh, 8px) clamp(12px, 2.5vw, 20px);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.login-badge-icon {
    font-size: clamp(10px, 1.4vh, 12px);
    color: var(--primary-color);
}

.login-badge-text {
    font-size: clamp(10px, 1.4vh, 12px);
    font-weight: 700;
    color: var(--primary-color);
    letter-spacing: 1px;
}

.login-title {
    font-size: clamp(24px, 4.5vh, 34px);
    font-weight: 700;
    color: var(--white-color);
    margin: 4px 0 0 0;
    letter-spacing: -0.5px;
}

.text-primary-accent {
    color: var(--primary-color);
}

.login-subtitle {
    font-size: clamp(13px, 2vh, 15px);
    color: var(--login-text-secondary);
    margin: 0;
    line-height: 1.6;
    max-width: 420px;
}

.login-form {
    display: flex;
    flex-direction: column;
    gap: clamp(16px, 3vh, 22px);
    width: 100%;
}

.login-input-group {
    position: relative;
    width: 100%;
}

.login-input-icon {
    position: absolute;
    left: clamp(16px, 3vw, 20px);
    top: 50%;
    transform: translateY(-50%);
    color: var(--login-text-secondary);
    font-size: clamp(15px, 2vh, 18px);
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-input {
    width: 100%;
    background: var(--login-input-bg);
    border: 1px solid var(--login-input-border);
    border-radius: clamp(10px, 2vh, 14px);
    padding: clamp(14px, 2.2vh, 18px) clamp(20px, 3vw, 24px) clamp(14px, 2.2vh, 18px) clamp(44px, 7vw, 56px);
    font-size: clamp(14px, 2vh, 16px);
    color: var(--white-color);
    outline: none;
    transition: all 0.25s ease;
    box-sizing: border-box;
}

.login-input::placeholder {
    color: var(--login-text-secondary);
    opacity: 0.6;
}

.login-input:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px var(--login-input-border);
    background: var(--login-card-bg);
}

/* Chrome Autofill Fix */
.login-input:-webkit-autofill,
.login-input:-webkit-autofill:hover,
.login-input:-webkit-autofill:focus,
.login-input:-webkit-autofill:active {
    -webkit-text-fill-color: var(--white-color) !important;
    caret-color: var(--white-color);
    background-color: var(--login-input-bg) !important;
    background-clip: content-box !important;
    transition: background-color 999999s ease-in-out 0s;
}
.login-input-toggle {
    position: absolute;
    right: clamp(16px, 3vw, 20px);
    top: 50%;
    transform: translateY(-50%);
    color: var(--login-text-secondary);
    font-size: clamp(15px, 2vh, 18px);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s ease;
}

.login-input-toggle:hover {
    color: var(--primary-color);
}

.login-btn {
    width: 100%;
    background: var(--login-btn-gradient);
    border: none;
    border-radius: clamp(10px, 2vh, 14px);
    padding: clamp(14px, 2.2vh, 18px) clamp(24px, 4vw, 32px);
    color: var(--white-color);
    font-size: clamp(14px, 2.2vh, 16px);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(10px, 2vh, 14px);
    position: relative;
}

.login-btn:hover {
    background: var(--login-btn-hover-gradient);
    transform: translateY(-1px);
}

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

.login-btn-icon-wrapper {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease;
}

.login-btn:hover .login-btn-icon-wrapper {
    transform: translateX(4px);
}

.login-btn-icon {
    font-size: clamp(13px, 2.2vh, 16px);
}

.login-note {
    background: rgba(254, 44, 85, 0.07);
    border: 1px solid rgba(254, 44, 85, 0.18);
    border-left: 3px solid var(--primary-color);
    border-radius: clamp(8px, 1.5vh, 12px);
    padding: clamp(10px, 1.8vh, 14px) clamp(14px, 2.5vw, 18px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-top: -4px;
}

.login-note h6 {
    font-size: clamp(12px, 1.7vh, 13px);
    color: var(--login-text-secondary);
    line-height: 1.55;
    font-weight: 400;
}

.login-note h6 a {
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 600;
    transition: opacity 0.2s ease;
}

.login-note h6 a:hover {
    opacity: 0.8;
    text-decoration: underline;
}

.login-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(8px, 2vw, 16px);
    width: 100%;
    margin-top: clamp(12px, 2.5vh, 20px);
    flex-wrap: wrap;
}

.login-footer-copyright,
.login-footer-trusted {
    font-size: clamp(11px, 1.8vh, 13px);
    color: var(--login-text-secondary);
}

.login-footer-divider {
    color: var(--login-text-secondary);
    opacity: 0.5;
    font-size: clamp(11px, 1.8vh, 13px);
}

.login-footer-icon {
    font-size: clamp(10px, 1.6vh, 12px);
    color: var(--login-text-secondary);
    opacity: 0.5;
    margin-right: 4px;
}

@media (max-width: 576px) {
    .login-card {
        padding: clamp(20px, 5vh, 36px) clamp(16px, 5vw, 28px);
        gap: clamp(16px, 4vh, 24px);
    }

    .login-footer {
        flex-direction: column;
        gap: 6px;
    }

    .login-footer-divider {
        display: none;
    }
}

/* Proportional scaling for very short viewports to prevent any clipping */
@media (max-height: 750px) {
    .login-container {
        transform: scale(0.9);
        transform-origin: center center;
    }
}

@media (max-height: 650px) {
    .login-container {
        transform: scale(0.8);
        transform-origin: center center;
    }
}

@media (max-height: 560px) {
    .login-container {
        transform: scale(0.7);
        transform-origin: center center;
    }
}

@media (max-height: 480px) {
    .login-container {
        transform: scale(0.58);
        transform-origin: center center;
    }
}

@media (max-height: 400px) {
    .login-container {
        transform: scale(0.48);
        transform-origin: center center;
    }
}

@media (max-height: 330px) {
    .login-container {
        transform: scale(0.38);
        transform-origin: center center;
    }
}