@font-face {
    font-family: "Inter";
    src: url("/assets/fonts/inter-light46a7.woff") format("woff");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("/assets/fonts/inter-regular46a7.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("/assets/fonts/inter-medium46a7.woff") format("woff");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("/assets/fonts/inter-medium46a7.woff") format("woff");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("/assets/fonts/inter-medium46a7.woff") format("woff");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    --glass-bg: rgba(255, 255, 255, 0.05);
    --glass-border: rgba(255, 255, 255, 0.08);
    --glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
    --glass-blur: 16px;
    --gradient-start: #0a0a1a;
    --gradient-mid: #1a1145;
    --gradient-end: #0d0d2b;
    --accent-primary: #7c3aed;
    --accent-secondary: #06b6d4;
    --accent-glow: rgba(124, 58, 237, 0.25);
    --text-primary: #e2e8f0;
    --text-secondary: #94a3b8;
    --card-bg: rgba(20, 16, 56, 0.6);
    --sidebar-bg: rgba(10, 8, 30, 0.9);
    --topbar-bg: rgba(10, 8, 30, 0.8);
    --input-bg: rgba(255, 255, 255, 0.06);
    --input-border: rgba(255, 255, 255, 0.1);
    --input-focus: rgba(124, 58, 237, 0.4);
    --hover-glow: rgba(124, 58, 237, 0.12);
    --success-color: #10b981;
    --danger-color: #ef4444;
    --warning-color: #f59e0b;
    --info-color: #06b6d4;
    --sensitive-mask-bg: rgba(148, 163, 184, 0.12);
    --sensitive-mask-color: var(--text-secondary);
    --sensitive-mask-border: rgba(148, 163, 184, 0.18);
    --sensitive-license-mask-bg: linear-gradient(135deg, rgba(14, 165, 233, 0.78), rgba(124, 58, 237, 0.72));
    --sensitive-license-mask-color: #ffffff;
    --sensitive-license-mask-border: rgba(255, 255, 255, 0.3);
    --option-bg: #1a1145;
    --option-color: #e2e8f0;
    --option-selected-bg: #6d28d9;
    --option-selected-color: #ffffff;
    --scrollbar-track: rgba(255, 255, 255, 0.06);
    --scrollbar-thumb: color-mix(in srgb, var(--accent-primary) 78%, #64748b);
    --scrollbar-thumb-hover: var(--accent-secondary);
    --t: 0.25s;
    color-scheme: dark
}

[data-theme="light"] {
    color-scheme: light;
    --option-bg: #ffffff;
    --option-color: #1e1b4b;
    --option-selected-bg: #ede9fe;
    --option-selected-color: #312e81;
    --glass-bg: rgba(255, 255, 255, 0.55);
    --glass-border: rgba(140, 120, 200, 0.2);
    --glass-shadow: 0 4px 24px rgba(80, 60, 140, 0.08);
    --gradient-start: #f0ecff;
    --gradient-mid: #e8e0ff;
    --gradient-end: #eaefff;
    --text-primary: #1e1b4b;
    --text-secondary: #4a4570;
    --card-bg: rgba(255, 255, 255, 0.72);
    --sidebar-bg: rgba(255, 255, 255, 0.85);
    --topbar-bg: rgba(255, 255, 255, 0.8);
    --input-bg: rgba(255, 255, 255, 0.8);
    --input-border: rgba(124, 58, 237, 0.18);
    --input-focus: rgba(124, 58, 237, 0.25);
    --hover-glow: rgba(124, 58, 237, 0.08);
    --accent-glow: rgba(124, 58, 237, 0.15);
    --sensitive-mask-bg: rgba(124, 58, 237, 0.08);
    --sensitive-mask-color: #3730a3;
    --sensitive-mask-border: rgba(124, 58, 237, 0.18);
    --sensitive-license-mask-bg: linear-gradient(135deg, rgba(219, 234, 254, 0.96), rgba(237, 233, 254, 0.96));
    --sensitive-license-mask-color: #1e1b4b;
    --sensitive-license-mask-border: rgba(124, 58, 237, 0.24);
    --scrollbar-track: rgba(124, 58, 237, 0.08);
    --scrollbar-thumb: color-mix(in srgb, var(--accent-primary) 62%, #c4b5fd);
    --scrollbar-thumb-hover: var(--accent-primary)
}

html,
body {
    scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
    scrollbar-width: thin
}

body,
body.authentication-bg {
    background: linear-gradient(135deg, var(--gradient-start) 0%, var(--gradient-mid) 50%, var(--gradient-end) 100%) !important;
    background-size: 300% 300% !important;
    animation: gradientShift 20s ease infinite;
    color: var(--text-primary);
    font-family: "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, system-ui, sans-serif !important
}

button,
input,
textarea,
select {
    font-family: inherit
}

html[data-theme="dark"] body,
body[data-theme="dark"] {
    color: var(--text-primary) !important
}

html[data-theme="dark"] .card,
html[data-theme="dark"] .card-body,
html[data-theme="dark"] .modal-content,
html[data-theme="dark"] .dropdown-menu,
body[data-theme="dark"] .card,
body[data-theme="dark"] .card-body,
body[data-theme="dark"] .modal-content,
body[data-theme="dark"] .dropdown-menu {
    color: var(--text-primary) !important
}

html[data-theme="dark"] .card-title,
html[data-theme="dark"] .modal-title,
html[data-theme="dark"] .page-title-box h4,
html[data-theme="dark"] .dropdown-header,
body[data-theme="dark"] .card-title,
body[data-theme="dark"] .modal-title,
body[data-theme="dark"] .page-title-box h4,
body[data-theme="dark"] .dropdown-header {
    color: var(--text-primary) !important
}

html[data-theme="dark"] .card p,
html[data-theme="dark"] .modal-content p,
html[data-theme="dark"] .dropdown-menu .dropdown-item,
body[data-theme="dark"] .card p,
body[data-theme="dark"] .modal-content p,
body[data-theme="dark"] .dropdown-menu .dropdown-item {
    color: var(--text-secondary) !important
}

html[data-theme="dark"] .info-box .info-box-label,
body[data-theme="dark"] .info-box .info-box-label {
    color: var(--text-secondary) !important
}

html[data-theme="dark"] .info-box .info-box-value:not([class*="text-"]),
body[data-theme="dark"] .info-box .info-box-value:not([class*="text-"]) {
    color: var(--text-primary) !important
}

@keyframes gradientShift {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    100% {
        background-position: 0% 50%
    }
}

.card {
    background: var(--card-bg) !important;
    backdrop-filter: blur(var(--glass-blur)) !important;
    -webkit-backdrop-filter: blur(var(--glass-blur)) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 16px !important;
    box-shadow: var(--glass-shadow) !important;
    transition: transform var(--t), box-shadow var(--t), border-color var(--t) !important
}

.card:hover {
    border-color: rgba(124, 58, 237, 0.3) !important;
    box-shadow: var(--glass-shadow), 0 0 24px var(--accent-glow) !important;
    transform: translateY(-2px)
}

.card-body {
    padding: 1.25rem !important;
    color: var(--text-primary)
}

#page-topbar {
    background: var(--topbar-bg) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border-bottom: 1px solid var(--glass-border) !important;
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.15) !important
}

.navbar-header {
    background: transparent !important;
    min-height: 70px
}

#page-topbar .navbar-header>.d-flex {
    min-height: 70px
}

#page-topbar .vertical-menu-btn {
    width: 52px;
    min-width: 52px;
    height: 70px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center
}

.header-item {
    color: var(--text-primary) !important;
    transition: color var(--t)
}

.header-item:hover {
    color: var(--accent-primary) !important
}

#page-topbar #theme-toggler,
#page-topbar #privacy-mask-toggler {
    width: 38px;
    min-width: 38px;
    height: 38px;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    align-self: center
}

#page-topbar #theme-toggler i,
#page-topbar #privacy-mask-toggler i,
#page-topbar .vertical-menu-btn i,
#page-topbar .header-balance i {
    width: 1.25rem;
    min-width: 1.25rem;
    height: 1.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1
}

.header-language-dropdown>.header-item {
    min-width: 55px
}

.locale-glyph {
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    color: var(--text-primary);
    font-size: 11px;
    line-height: 1;
    font-weight: 700;
    vertical-align: middle;
}

.user-dropdown>.header-item {
    width: 54px;
    min-width: 54px;
    padding-inline: 9px !important
}

.header-profile-user {
    width: 36px !important;
    min-width: 36px !important;
    height: 36px !important;
    object-fit: cover;
    display: block
}

.privacy-mask-toggle {
    position: relative;
    width: 38px;
    min-width: 38px;
    height: 38px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 11px !important
}

.privacy-mask-toggle.is-active {
    color: var(--warning-color) !important;
    background: rgba(245, 158, 11, 0.12) !important;
    box-shadow: inset 0 0 0 1px rgba(245, 158, 11, 0.28)
}

[data-theme="light"] .privacy-mask-toggle.is-active {
    background: rgba(217, 119, 6, 0.1) !important;
    box-shadow: inset 0 0 0 1px rgba(217, 119, 6, 0.22)
}

.sensitive-value {
    border-radius: 6px;
    transition: background-color var(--t), color var(--t), box-shadow var(--t)
}

.sensitive-value.is-sensitive-masked {
    color: var(--sensitive-mask-color) !important;
    background: var(--sensitive-mask-bg);
    box-shadow: inset 0 0 0 1px var(--sensitive-mask-border);
    padding-inline: 0.35em;
    user-select: none
}

.header-balance .sensitive-value.is-sensitive-masked,
.badge .sensitive-value.is-sensitive-masked {
    color: inherit !important;
    background: transparent !important;
    box-shadow: none !important;
    padding-inline: 0 !important
}

.sensitive-value[data-sensitive-type="license-key"] {
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    letter-spacing: 0.01em
}

.badge.sensitive-value[data-sensitive-type="license-key"] {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    max-width: min(100%, 15rem);
    min-width: 11.5rem;
    min-height: 1.65rem;
    overflow: hidden;
    padding: 0.35rem 0.65rem !important;
    vertical-align: middle
}

html[data-privacy-mask="masked"] [data-sensitive] {
    color: transparent !important;
    position: relative;
    user-select: none;
    -webkit-user-select: none
}

html[data-privacy-mask="masked"] .header-balance [data-sensitive],
html[data-privacy-mask="masked"] .badge [data-sensitive] {
    color: inherit !important
}

html[data-privacy-mask="masked"] [data-sensitive]::after {
    content: attr(data-sensitive-placeholder);
    position: absolute;
    inset: 0;
    color: var(--sensitive-mask-color);
    background: var(--sensitive-mask-bg);
    border-radius: 6px;
    padding-inline: 0.35em;
    box-shadow: inset 0 0 0 1px var(--sensitive-mask-border);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis
}

html[data-privacy-mask="masked"] .badge.sensitive-value[data-sensitive-type="license-key"] {
    background: var(--sensitive-license-mask-bg) !important;
    border: 1px solid var(--sensitive-license-mask-border);
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.22)
}

html[data-privacy-mask="masked"] .badge.sensitive-value[data-sensitive-type="license-key"]::after {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--sensitive-license-mask-color);
    background: transparent;
    border-radius: inherit;
    box-shadow: none;
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.35rem 0.65rem;
    text-align: center;
    text-shadow: none
}

html[data-privacy-mask="masked"] .header-balance [data-sensitive]::after,
html[data-privacy-mask="masked"] .badge [data-sensitive]::after {
    content: none
}

html[data-privacy-mask="visible"] [data-sensitive]::after {
    content: none
}

.vertical-menu {
    background: var(--sidebar-bg) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border-right: 1px solid var(--glass-border) !important
}

.vertical-menu .navbar-brand-box {
    background: transparent !important;
    height: 70px;
    padding: 0 12px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden
}

.vertical-menu .navbar-brand-box .logo {
    width: 100%;
    height: 70px;
    line-height: 1 !important;
    display: flex;
    align-items: center;
    justify-content: center
}

.vertical-menu .navbar-brand-box .logo-dark {
    display: none !important
}

.vertical-menu .navbar-brand-box .logo-light {
    display: flex !important
}

body:not(.vertical-collpsed) .vertical-menu .navbar-brand-box .logo span.logo-lg {
    width: 170px;
    height: 62px;
    display: inline-flex !important;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: hidden
}

body:not(.vertical-collpsed) .vertical-menu .navbar-brand-box .logo span.logo-lg img {
    width: 220px !important;
    height: 220px !important;
    max-width: none !important;
    object-fit: fill !important;
    transform: translate(-28px, -92px);
    display: block
}

.vertical-collpsed .vertical-menu .navbar-brand-box .logo span.logo-sm {
    width: 52px;
    height: 44px;
    display: inline-flex !important;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: hidden
}

.vertical-collpsed .vertical-menu .navbar-brand-box .logo span.logo-sm img {
    width: 130px !important;
    height: 130px !important;
    max-width: none !important;
    object-fit: fill !important;
    transform: translate(-16px, -56px);
    display: block
}

#sidebar-menu ul li a {
    color: var(--text-secondary) !important;
    border-radius: 10px !important;
    margin: 2px 10px !important;
    padding: 10px 15px !important;
    transition: all var(--t) !important;
    white-space: nowrap !important
}

#sidebar-menu>ul>li>a {
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important
}

#sidebar-menu>ul>li>a i {
    order: 1 !important;
    flex: 0 0 auto !important
}

#sidebar-menu>ul>li>a>span:not(.badge) {
    order: 2 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important
}

#sidebar-menu>ul>li>a>.badge {
    order: 3 !important;
    flex: 0 0 auto !important;
    align-self: flex-start !important;
    margin-left: auto !important;
    transform: translateY(-4px) !important
}

#sidebar-menu>ul>li>a.has-arrow:after {
    order: 3 !important;
    flex: 0 0 auto !important;
    float: none !important;
    margin-left: auto !important;
    margin-top: 0 !important;
    line-height: 1 !important
}

#sidebar-menu ul li a:hover {
    color: var(--text-primary) !important;
    background: var(--hover-glow) !important
}

#sidebar-menu ul li a.active,
#sidebar-menu>ul>li.mm-active>a {
    color: #fff !important;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important;
    box-shadow: 0 4px 15px var(--accent-glow) !important
}

#sidebar-menu ul li a.active i,
#sidebar-menu>ul>li.mm-active>a i {
    color: #fff !important
}

#sidebar-menu ul li ul.sub-menu li.mm-active>a,
#sidebar-menu ul li ul.sub-menu li a.active {
    color: var(--accent-primary) !important;
    background: var(--hover-glow) !important;
    box-shadow: none !important
}

.menu-title {
    color: var(--accent-primary) !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    font-size: 11px !important;
    padding: 12px 25px 6px !important
}

#sidebar-menu .badge {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important;
    border: none !important;
    font-weight: 500 !important;
    box-shadow: 0 2px 8px var(--accent-glow) !important;
    line-height: 1 !important
}

.sub-menu li a {
    color: var(--text-secondary) !important
}

.sub-menu li a:hover {
    color: var(--accent-primary) !important
}

#sidebar-menu ul li ul.sub-menu li a::before {
    display: none !important
}

#sidebar-menu ul li ul.sub-menu li a {
    padding-left: 52px !important;
    position: relative
}

#sidebar-menu ul li ul.sub-menu li a::after {
    content: '';
    position: absolute;
    left: 32px;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--text-secondary);
    opacity: 0.4;
    transition: all var(--t)
}

#sidebar-menu ul li ul.sub-menu li a:hover::after,
#sidebar-menu ul li ul.sub-menu li.mm-active>a::after {
    background: var(--accent-primary);
    opacity: 1
}

.main-content,
.page-content {
    background: transparent !important
}

.main-content {
    overflow: clip visible !important
}

.page-title-box h4 {
    color: var(--text-primary) !important;
    font-weight: 700 !important
}

.footer {
    background: var(--topbar-bg) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border-top: 1px solid var(--glass-border) !important;
    color: var(--text-secondary) !important
}

.footer a {
    color: var(--accent-primary) !important
}

.form-control,
.form-select {
    background: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--text-primary) !important;
    border-radius: 10px !important;
    padding: 10px 14px !important;
    transition: all var(--t) !important
}

.form-control:focus,
.form-select:focus {
    border-color: var(--accent-primary) !important;
    box-shadow: 0 0 0 3px var(--input-focus) !important
}

.form-control option,
.form-select option,
select option {
    background-color: var(--option-bg) !important;
    color: var(--option-color) !important
}

.form-control option:checked,
.form-select option:checked,
select option:checked {
    background-color: var(--option-selected-bg) !important;
    color: var(--option-selected-color) !important
}

.form-control::placeholder {
    color: var(--text-secondary) !important;
    opacity: 0.5
}

.form-label,
label {
    color: var(--text-secondary) !important;
    font-weight: 500 !important;
    font-size: 0.875rem !important
}

.form-check-input:checked {
    background-color: var(--accent-primary) !important;
    border-color: var(--accent-primary) !important
}

.btn-primary {
    background: linear-gradient(135deg, var(--accent-primary), #6d28d9) !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 10px 20px !important;
    font-weight: 600 !important;
    box-shadow: 0 4px 15px var(--accent-glow) !important;
    transition: all var(--t) !important;
    color: #fff !important
}

.btn-primary:hover {
    box-shadow: 0 6px 25px var(--accent-glow) !important;
    transform: translateY(-1px)
}

.btn-outline-primary {
    color: var(--accent-primary) !important;
    border-color: var(--accent-primary) !important;
    border-radius: 10px !important;
    background: transparent !important;
    transition: all var(--t) !important
}

.btn-outline-primary:hover {
    background: var(--hover-glow) !important;
    color: #fff !important
}

.btn-danger {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    border: none !important;
    border-radius: 10px !important
}

.btn-success {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    border: none !important;
    border-radius: 10px !important
}

.btn-warning {
    background: linear-gradient(135deg, #f59e0b, #d97706) !important;
    border: none !important;
    border-radius: 10px !important
}

.btn-info {
    background: linear-gradient(135deg, var(--info-color), #0891b2) !important;
    border: none !important;
    border-radius: 10px !important
}

.authentication-bg .card {
    border-radius: 20px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35) !important
}

.authentication-bg .card .card {
    background: var(--glass-bg) !important;
    box-shadow: none !important;
    border-radius: 14px !important
}

.auth-logo.bg-primary {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important;
    position: relative;
    overflow: hidden
}

.auth-logo.bg-primary::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.08) 0%, transparent 60%);
    animation: shimmer 8s ease-in-out infinite
}

@keyframes shimmer {

    0%,
    100% {
        transform: translate(-30%, -30%) rotate(0deg)
    }

    50% {
        transform: translate(10%, 10%) rotate(180deg)
    }
}

.authentication-bg .text-primary {
    color: var(--accent-primary) !important
}

.authentication-bg a.auth-logo:not(.bg-primary) {
    width: 280px;
    height: 96px;
    margin: 0 auto 1.1rem;
    display: inline-flex !important;
    align-items: flex-start;
    justify-content: flex-start;
    overflow: hidden
}

.authentication-bg a.auth-logo:not(.bg-primary) .auth-page-logo {
    width: 355px !important;
    height: 355px !important;
    min-width: 355px;
    max-width: none !important;
    object-fit: fill !important;
    transform: translate(-44px, -148px);
    display: block;
    margin: 0 !important
}

@media (max-width: 575.98px) {
    .authentication-bg a.auth-logo:not(.bg-primary) {
        width: 236px;
        height: 82px;
        margin-bottom: 0.9rem
    }

    .authentication-bg a.auth-logo:not(.bg-primary) .auth-page-logo {
        width: 300px !important;
        height: 300px !important;
        min-width: 300px;
        transform: translate(-37px, -125px)
    }
}

.alert {
    border-radius: 12px !important;
    backdrop-filter: blur(10px) !important;
    border: 1px solid var(--glass-border) !important
}

.alert-success {
    background: rgba(16, 185, 129, 0.12) !important;
    color: var(--success-color) !important;
    border-color: rgba(16, 185, 129, 0.25) !important
}

.alert-danger {
    background: rgba(239, 68, 68, 0.12) !important;
    color: var(--danger-color) !important;
    border-color: rgba(239, 68, 68, 0.25) !important
}

.alert-warning {
    background: rgba(245, 158, 11, 0.12) !important;
    color: var(--warning-color) !important;
    border-color: rgba(245, 158, 11, 0.25) !important
}

.alert-info {
    background: rgba(6, 182, 212, 0.12) !important;
    color: var(--info-color) !important;
    border-color: rgba(6, 182, 212, 0.25) !important
}

.table {
    color: var(--text-primary) !important
}

.table thead th {
    background: var(--glass-bg) !important;
    color: var(--text-secondary) !important;
    border-bottom: 1px solid var(--glass-border) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.05em
}

.table td {
    border-color: var(--glass-border) !important
}

.table-striped>tbody>tr:nth-of-type(odd)>* {
    background: var(--glass-bg) !important
}

.table-hover>tbody>tr:hover>* {
    background: var(--hover-glow) !important
}

.badge {
    border-radius: 8px !important;
    font-weight: 500 !important;
    padding: 5px 10px !important
}

.bg-soft-success,
.badge.bg-success:not(#sidebar-menu .badge) {
    background: rgba(16, 185, 129, 0.15) !important;
    color: #10b981 !important
}

.bg-soft-danger,
.badge.bg-danger:not(#sidebar-menu .badge) {
    background: rgba(239, 68, 68, 0.15) !important;
    color: #ef4444 !important
}

.bg-soft-warning {
    background: rgba(245, 158, 11, 0.15) !important;
    color: #f59e0b !important
}

.bg-soft-primary {
    background: rgba(124, 58, 237, 0.12) !important;
    color: var(--accent-primary) !important
}

.bg-soft-info {
    background: rgba(6, 182, 212, 0.12) !important;
    color: var(--info-color) !important
}

.bg-soft-secondary {
    background: rgba(148, 163, 184, 0.12) !important
}

.dropdown-menu {
    background: var(--card-bg) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3) !important;
    padding: 8px !important
}

.dropdown-item {
    color: var(--text-primary) !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    transition: all var(--t) !important
}

.dropdown-item:hover {
    background: var(--hover-glow) !important;
    color: var(--accent-primary) !important
}

.dropdown-menu-lg {
    border-radius: 16px !important
}

.navbar-header .user-dropdown {
    position: relative !important
}

.navbar-header .user-dropdown .dropdown-menu {
    background: rgba(18, 14, 48, 0.96) !important;
    backdrop-filter: blur(12px) saturate(140%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(140%) !important;
    border: 1px solid rgba(255, 255, 255, 0.16) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(124, 58, 237, 0.12) !important;
    top: calc(100% + 8px) !important;
    right: 0 !important;
    left: auto !important;
    transform: none !important;
    width: min(320px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important
}

.navbar-header .user-dropdown .dropdown-menu,
.navbar-header .user-dropdown .dropdown-menu .text-reset,
.navbar-header .user-dropdown .notification-item,
.navbar-header .user-dropdown .notification-item h6 {
    color: var(--text-primary) !important
}

.navbar-header .user-dropdown .notification-item p {
    color: var(--text-secondary) !important
}

.navbar-header .user-dropdown .notification-item:hover h6 {
    color: var(--accent-secondary) !important
}

[data-theme="light"] .navbar-header .user-dropdown .dropdown-menu {
    background: rgba(255, 255, 255, 0.96) !important;
    border-color: rgba(124, 58, 237, 0.22) !important;
    box-shadow: 0 18px 44px rgba(76, 56, 132, 0.2), 0 0 0 1px rgba(124, 58, 237, 0.08) !important
}

.notification-item {
    border-radius: 10px !important;
    transition: all var(--t) !important
}

.notification-item:hover {
    background: var(--hover-glow) !important
}

.modal-content {
    background: var(--card-bg) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4) !important;
    color: var(--text-primary) !important
}

.modal-header {
    border-bottom: 1px solid var(--glass-border) !important
}

.modal-footer {
    border-top: 1px solid var(--glass-border) !important
}

.swal2-popup {
    background: var(--card-bg) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 20px !important;
    color: var(--text-primary) !important
}

.swal2-title {
    color: var(--text-primary) !important
}

.swal2-html-container {
    color: var(--text-secondary) !important
}

.page-link {
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--text-primary) !important;
    border-radius: 8px !important;
    margin: 0 2px !important
}

.page-link:hover {
    background: var(--hover-glow) !important;
    color: var(--accent-primary) !important
}

.page-item.active .page-link {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important;
    border-color: transparent !important;
    color: #fff !important
}

::-webkit-scrollbar {
    width: 6px;
    height: 6px
}

::-webkit-scrollbar-track {
    background: var(--scrollbar-track)
}

::-webkit-scrollbar-thumb {
    background: var(--scrollbar-thumb);
    border-radius: 3px
}

::-webkit-scrollbar-thumb:hover {
    background: var(--scrollbar-thumb-hover)
}

.simplebar-scrollbar::before {
    background: var(--scrollbar-thumb) !important;
    border-radius: 3px !important
}

#preloader {
    background: var(--gradient-start) !important
}

.loader {
    border-top-color: var(--accent-primary) !important
}

.text-muted {
    color: var(--text-secondary) !important
}

h1,
h2,
h3,
h4,
h5,
h6 {
    color: var(--text-primary)
}

a {
    color: var(--accent-primary);
    transition: color var(--t)
}

a:hover {
    color: var(--accent-secondary)
}

.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    background: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--text-primary) !important;
    border-radius: 8px !important
}

.dataTables_info,
.dataTables_length label,
.dataTables_filter label {
    color: var(--text-secondary) !important
}

.copy-text {
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 10px !important
}

.waves-effect .waves-ripple {
    background: radial-gradient(rgba(124, 58, 237, 0.25) 0, rgba(124, 58, 237, 0.1) 40%, transparent 60%) !important
}

#hoamaitet {
    display: none;
    pointer-events: none;
    z-index: 9999;
    opacity: 0.4
}

@media (max-width:991.98px) {
    .vertical-menu {
        backdrop-filter: blur(24px) !important
    }

    #page-topbar .navbar-header .navbar-brand-box {
        display: none !important
    }

    body.sidebar-enable .vertical-menu {
        width: 250px !important
    }

    .vertical-menu .navbar-brand-box {
        display: flex !important;
        width: 250px;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 2
    }

    .vertical-menu .sidebar-menu-scroll {
        height: calc(100% - 70px) !important;
        margin-top: 70px !important
    }

    .vertical-menu .navbar-brand-box .logo span.logo-sm {
        display: none !important
    }

    body:not(.vertical-collpsed) .vertical-menu .navbar-brand-box .logo span.logo-lg {
        display: inline-flex !important
    }

    .header-balance {
        max-width: 130px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        font-size: 12px !important;
        padding: 0 8px !important
    }

}

@media (max-width:575.98px) {
    .header-balance {
        max-width: 100px !important;
        font-size: 11px !important
    }
}

.stat-icon-wrap {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    transition: all var(--t)
}

.stat-icon-lg {
    width: 52px;
    height: 52px;
    min-width: 52px
}

.card-stats {
    position: relative;
    overflow: hidden
}

.card-stats::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, var(--accent-primary), var(--accent-secondary));
    opacity: 0;
    transition: opacity var(--t)
}

.card-stats:hover::before {
    opacity: 1
}

.welcome-card {
    border-left: 4px solid var(--accent-primary) !important
}

.welcome-info {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.welcome-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.6
}

.welcome-item i {
    color: var(--accent-primary);
    font-size: 18px;
    margin-top: 2px;
    min-width: 20px
}

.admin-stat-card {
    transition: all var(--t) !important
}

.admin-stat-card:hover {
    transform: translateY(-3px);
    border-color: rgba(124, 58, 237, 0.4) !important
}

[data-theme="light"] .vertical-menu {
    box-shadow: 2px 0 20px rgba(100, 80, 160, 0.06) !important
}

[data-theme="light"] #sidebar-menu ul li a {
    color: #4a4570 !important
}

[data-theme="light"] #sidebar-menu ul li a:hover {
    color: var(--accent-primary) !important;
    background: rgba(124, 58, 237, 0.06) !important
}

[data-theme="light"] #sidebar-menu ul li a.active,
[data-theme="light"] #sidebar-menu>ul>li.mm-active>a {
    color: #fff !important;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important
}

[data-theme="light"] #sidebar-menu ul li ul.sub-menu li.mm-active>a,
[data-theme="light"] #sidebar-menu ul li ul.sub-menu li a.active {
    color: var(--accent-primary) !important;
    background: rgba(124, 58, 237, 0.08) !important;
    box-shadow: none !important
}

[data-theme="light"] .menu-title {
    color: var(--accent-primary) !important
}

[data-theme="light"] #page-topbar {
    box-shadow: 0 2px 12px rgba(100, 80, 160, 0.08) !important
}

[data-theme="light"] .header-item {
    color: #3b3566 !important
}

[data-theme="light"] .header-item:hover {
    color: var(--accent-primary) !important
}

[data-theme="light"] .vertical-menu-btn .fa-bars {
    color: #3b3566 !important
}

[data-theme="light"] .card {
    box-shadow: 0 2px 16px rgba(100, 80, 160, 0.06) !important
}

[data-theme="light"] .card:hover {
    box-shadow: 0 4px 24px rgba(100, 80, 160, 0.12) !important
}

[data-theme="light"] .footer {
    box-shadow: 0 -1px 12px rgba(100, 80, 160, 0.04) !important
}

[data-theme="light"] .dropdown-menu {
    box-shadow: 0 8px 30px rgba(100, 80, 160, 0.12) !important
}

.bg-soft-success {
    background: rgba(16, 185, 129, 0.12) !important
}

.bg-soft-primary {
    background: rgba(124, 58, 237, 0.12) !important
}

.bg-soft-danger {
    background: rgba(239, 68, 68, 0.12) !important
}

.bg-soft-warning {
    background: rgba(245, 158, 11, 0.12) !important
}

.bg-soft-info {
    background: rgba(6, 182, 212, 0.12) !important
}

.bg-overlay {
    display: none !important
}

[style*="overlay"] {
    background-image: none !important
}

.row.g-3>[class*="col-"]:last-child:nth-child(3n+2) {}

[data-theme="light"] .text-success {
    color: #059669 !important
}

[data-theme="light"] .text-primary {
    color: #7c3aed !important
}

[data-theme="light"] .text-danger {
    color: #dc2626 !important
}

[data-theme="light"] .text-warning {
    color: #d97706 !important
}

[data-theme="light"] .text-info {
    color: #0891b2 !important
}

.btn-group .btn.btn-sm,
.btn-group form .btn.btn-sm {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    max-width: 36px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    margin: 0 2px !important;
    transition: all var(--t) !important;
    flex-shrink: 0 !important
}

.btn-group .btn.btn-sm i,
.btn-group form .btn.btn-sm i {
    font-size: 14px !important;
    line-height: 1 !important;
    margin: 0 !important
}

.btn-group .btn.btn-sm:hover,
.btn-group form .btn.btn-sm:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important
}

.btn-group form {
    display: inline-flex !important;
    margin: 0 !important;
    padding: 0 !important
}

.btn-group>.btn:not(:first-child),
.btn-group>form:not(:first-child) .btn,
.btn-group>.btn-group:not(:first-child)>.btn {
    border-top-left-radius: 10px !important;
    border-bottom-left-radius: 10px !important
}

.btn-group>.btn:not(:last-child):not(.dropdown-toggle),
.btn-group>form:not(:last-child) .btn,
.btn-group>.btn-group:not(:last-child)>.btn {
    border-top-right-radius: 10px !important;
    border-bottom-right-radius: 10px !important
}

.btn-group[role="group"] {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0 !important;
    flex-wrap: nowrap !important
}

.page-title-box {
    padding: 8px 0 !important
}

.page-title-box h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.02em
}

.info-box {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    padding: 10px 14px;
    transition: all var(--t)
}

.info-box.info-box-flex {
    display: flex;
    align-items: center;
    gap: 12px
}

.info-box.info-box-flex>i {
    flex-shrink: 0
}

.info-box .info-box-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-bottom: 2px;
    line-height: 1.3
}

.info-box .info-box-value {
    font-size: 0.85rem;
    color: var(--text-primary);
    line-height: 1.4
}

.info-box:hover {
    border-color: rgba(124, 58, 237, 0.2)
}

.card code,
.info-box code {
    background: rgba(124, 58, 237, 0.1);
    color: var(--accent-primary);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.85em;
    word-break: break-all
}

[data-theme="light"] .card code,
[data-theme="light"] .info-box code {
    background: rgba(124, 58, 237, 0.08);
    color: #6d28d9
}

.license-overview-stats>[class*="col-"] {
    display: flex
}

.license-status-card {
    width: 100%;
    min-height: 92px;
    padding: 12px 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center
}

.license-status-card .info-box-value {
    margin-bottom: 8px;
    line-height: 1
}

.license-status-card .info-box-label {
    min-height: 2.2em;
    margin-bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center
}

.card .progress {
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border);
    border-radius: 6px !important;
    overflow: hidden
}

.card .progress-bar {
    border-radius: 6px !important;
    transition: width 0.6s ease
}

[data-theme="light"] .card .progress {
    background: rgba(124, 58, 237, 0.06) !important;
    border-color: rgba(124, 58, 237, 0.1)
}

.card.card-stats.text-center a,
a.card.card-stats {
    color: var(--text-primary);
    text-decoration: none !important
}

a.card.card-stats:hover {
    border-color: var(--accent-primary) !important
}

a.card.card-stats small {
    color: var(--text-secondary);
    font-weight: 500
}

.btn-outline-success {
    color: var(--success-color) !important;
    border-color: var(--success-color) !important;
    background: transparent !important;
    border-radius: 10px !important;
    transition: all var(--t) !important
}

.btn-outline-success:hover {
    background: rgba(16, 185, 129, 0.12) !important;
    color: #fff !important
}

.btn-secondary {
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--text-primary) !important;
    border-radius: 10px !important;
    padding: 9px 20px !important;
    font-weight: 600 !important;
    transition: all var(--t) !important
}

.btn-secondary:hover {
    background: var(--hover-glow) !important;
    border-color: var(--accent-primary) !important;
    color: var(--text-primary) !important
}

[data-theme="light"] .btn-secondary {
    background: rgba(124, 58, 237, 0.06) !important;
    border-color: rgba(124, 58, 237, 0.15) !important;
    color: var(--text-primary) !important
}

[data-theme="light"] .btn-secondary:hover {
    background: rgba(124, 58, 237, 0.12) !important
}

.accordion-item {
    background: var(--card-bg) !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--text-primary) !important
}

.accordion-button {
    background: transparent !important;
    color: var(--text-primary) !important;
    box-shadow: none !important
}

.accordion-button::after {
    filter: invert(0.5)
}

[data-theme="light"] .accordion-button::after {
    filter: none
}

.accordion-button:not(.collapsed) {
    color: var(--accent-primary) !important;
    background: var(--hover-glow) !important
}

.accordion-body {
    color: var(--text-secondary) !important;
    background: transparent !important
}

.accordion-collapse {
    background: transparent !important
}

[data-theme="light"] .info-box {
    background: rgba(124, 58, 237, 0.04);
    border-color: rgba(124, 58, 237, 0.12)
}

[data-theme="light"] .info-box:hover {
    border-color: rgba(124, 58, 237, 0.25)
}

.pricing-card .list-text {
    color: var(--text-secondary)
}

@media (max-width:575.98px) {
    .info-box {
        padding: 8px 10px
    }

    .info-box .info-box-label {
        font-size: 0.7rem
    }

    .info-box .info-box-value {
        font-size: 0.8rem
    }

    .license-status-card {
        min-height: 86px;
        padding: 10px 6px
    }

    .license-status-card .info-box-value {
        font-size: 1rem;
        margin-bottom: 7px
    }

    .license-status-card .info-box-label {
        font-size: 0.68rem
    }

    .stat-icon-wrap {
        width: 40px;
        height: 40px;
        min-width: 40px;
        font-size: 18px
    }
}

.list-group-item {
    background: var(--glass-bg) !important;
    border-color: var(--glass-border) !important;
    color: var(--text-primary) !important
}

.list-group-item:hover {
    background: var(--hover-glow) !important
}

.select2-container--default .select2-selection--single {
    background: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    border-radius: 10px !important;
    color: var(--text-primary) !important;
    height: auto !important;
    padding: 6px 10px !important
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text-primary) !important
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 50% !important;
    transform: translateY(-50%)
}

.select2-dropdown {
    background: var(--card-bg) !important;
    border: 1px solid var(--glass-border) !important;
    border-radius: 10px !important;
    backdrop-filter: blur(var(--glass-blur)) !important
}

.select2-container--default .select2-results__option {
    color: var(--text-primary) !important
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
    background: var(--hover-glow) !important;
    color: var(--accent-primary) !important
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    background: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--text-primary) !important;
    border-radius: 8px !important
}

.nav-tabs-custom .nav-link {
    color: var(--text-secondary) !important;
    border: none !important;
    border-radius: 10px !important;
    transition: all var(--t) !important
}

.nav-tabs-custom .nav-link.active {
    color: #fff !important;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important;
    box-shadow: 0 4px 15px var(--accent-glow) !important
}

.nav-tabs-custom .nav-link:hover:not(.active) {
    background: var(--hover-glow) !important;
    color: var(--text-primary) !important
}

.input-group-text {
    background: var(--glass-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--text-secondary) !important
}

.navbar-header>.d-flex {
    align-items: center !important
}

.header-balance {
    font-size: 13px;
    font-weight: 600;
    cursor: default !important;
    min-width: 54px;
    padding: 0 10px !important;
    border-radius: 8px !important;
    background: rgba(16, 185, 129, 0.1) !important;
    border: 1px solid rgba(16, 185, 129, 0.2) !important;
    line-height: 32px !important;
    height: 32px !important;
    color: var(--success-color) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: center !important;
    vertical-align: middle !important;
    gap: 6px;
    transition: all var(--t)
}

.header-balance:hover {
    background: rgba(16, 185, 129, 0.15) !important;
    border-color: rgba(16, 185, 129, 0.3) !important
}

[data-theme="light"] .header-balance {
    background: rgba(16, 185, 129, 0.08) !important;
    border-color: rgba(16, 185, 129, 0.15) !important;
    color: #059669 !important
}

.plan-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--glass-border) !important;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important
}

.plan-card:hover {
    transform: translateY(-6px) !important
}

.plan-card-accent {
    height: 4px;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1
}

.plan-icon-wrap {
    width: 64px;
    height: 64px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    transition: all 0.4s ease
}

.plan-icon-free {
    background: rgba(16, 185, 129, 0.12);
    color: var(--success-color)
}

.plan-icon-premium {
    background: linear-gradient(135deg, rgba(124, 58, 237, 0.2), rgba(6, 182, 212, 0.2));
    color: var(--accent-primary)
}

.plan-icon-nitro {
    background: linear-gradient(135deg, rgba(245, 158, 11, 0.2), rgba(239, 68, 68, 0.2));
    color: var(--warning-color)
}

.plan-card:hover .plan-icon-wrap {
    transform: scale(1.1) rotate(-5deg)
}

.plan-price-wrap {
    min-height: 70px;
    display: flex;
    flex-direction: column;
    justify-content: center
}

.plan-price-amount {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--text-primary);
    line-height: 1;
    letter-spacing: -0.02em
}

.plan-price-boost {
    background: linear-gradient(135deg, #f59e0b, #ef4444);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text
}

.plan-price-period {
    color: var(--text-secondary);
    font-size: 14px;
    font-weight: 500
}

.plan-save-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    background: rgba(16, 185, 129, 0.12);
    color: var(--success-color);
    border: 1px solid rgba(16, 185, 129, 0.2)
}

.plan-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--glass-border), transparent);
    margin: 4px 0 12px
}

.plan-features li {
    padding: 7px 0;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.875rem;
    color: var(--text-secondary)
}

.plan-features li i {
    font-size: 17px;
    flex-shrink: 0
}

.plan-features li.disabled {
    opacity: 0.4
}

.plan-features li.disabled i {
    color: var(--text-secondary) !important
}

.btn-plan {
    padding: 11px 20px !important;
    border-radius: 12px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    transition: all 0.3s ease !important;
    border: none !important;
    position: relative;
    overflow: hidden
}

.btn-plan-free {
    background: rgba(16, 185, 129, 0.1) !important;
    color: var(--success-color) !important;
    border: 1px solid rgba(16, 185, 129, 0.2) !important
}

.btn-plan-current {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important
}

.btn-plan-premium {
    background: linear-gradient(135deg, var(--accent-primary), #6d28d9) !important;
    color: #fff !important;
    box-shadow: 0 4px 20px var(--accent-glow) !important
}

.btn-plan-premium:hover {
    box-shadow: 0 6px 30px rgba(124, 58, 237, 0.4) !important;
    transform: translateY(-2px)
}

.btn-plan-nitro {
    background: linear-gradient(135deg, #f59e0b, #d97706) !important;
    color: #fff !important;
    box-shadow: 0 4px 20px rgba(245, 158, 11, 0.25) !important
}

.btn-plan-nitro:hover {
    box-shadow: 0 6px 30px rgba(245, 158, 11, 0.4) !important;
    transform: translateY(-2px)
}

.plan-card-featured {
    border-color: rgba(124, 58, 237, 0.3) !important;
    box-shadow: var(--glass-shadow), 0 0 40px var(--accent-glow) !important;
    position: relative;
    z-index: 2
}

.plan-card-featured:hover {
    box-shadow: var(--glass-shadow), 0 0 50px rgba(124, 58, 237, 0.35) !important;
    transform: translateY(-8px) !important
}

@media (min-width:1200px) {
    .plan-card-featured {
        transform: scale(1.03)
    }

    .plan-card-featured:hover {
        transform: scale(1.03) translateY(-8px) !important
    }
}

.plan-badge-ribbon {
    position: absolute;
    top: 16px;
    right: 16px;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 5px 14px;
    border-radius: 20px;
    z-index: 3;
    box-shadow: 0 4px 12px var(--accent-glow);
    display: inline-flex;
    align-items: center;
    white-space: nowrap
}

.plan-toggle-wrap {
    user-select: none;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 50px;
    padding: 4px !important;
    display: inline-flex;
    gap: 0
}

.plan-toggle-label {
    padding: 8px 20px;
    border-radius: 50px;
    cursor: pointer;
    font-weight: 600;
    font-size: 13px;
    color: var(--text-secondary);
    transition: all 0.3s ease !important;
    display: inline-flex;
    align-items: center;
    gap: 6px
}

.plan-toggle-label.active {
    background: linear-gradient(135deg, var(--accent-primary), #6d28d9) !important;
    color: #fff !important;
    box-shadow: 0 2px 10px var(--accent-glow)
}

.plan-toggle-label:not(.active):hover {
    color: var(--text-primary);
    background: var(--hover-glow)
}

.plan-save-tag {
    font-size: 10px;
    font-weight: 700;
    background: rgba(16, 185, 129, 0.15);
    color: var(--success-color);
    padding: 2px 6px;
    border-radius: 10px;
    line-height: 1
}

.plan-card-nitro {
    border-color: rgba(245, 158, 11, 0.2) !important
}

.plan-card-nitro:hover {
    border-color: rgba(245, 158, 11, 0.4) !important;
    box-shadow: var(--glass-shadow), 0 0 30px rgba(245, 158, 11, 0.15) !important
}

.plan-card-free:hover {
    border-color: rgba(16, 185, 129, 0.3) !important;
    box-shadow: var(--glass-shadow), 0 0 30px rgba(16, 185, 129, 0.1) !important
}

[data-theme="light"] .plan-card-featured {
    box-shadow: 0 4px 30px rgba(124, 58, 237, 0.12) !important
}

[data-theme="light"] .plan-card-featured:hover {
    box-shadow: 0 8px 40px rgba(124, 58, 237, 0.2) !important
}

[data-theme="light"] .plan-badge-ribbon {
    box-shadow: 0 4px 12px rgba(124, 58, 237, 0.2)
}

[data-theme="light"] .plan-toggle-label.active {
    box-shadow: 0 2px 8px rgba(124, 58, 237, 0.15)
}

@media (max-width:767.98px) {
    .plan-price-amount {
        font-size: 1.8rem
    }

    .plan-icon-wrap {
        width: 52px;
        height: 52px;
        font-size: 24px;
        border-radius: 16px
    }
}

.verify-card {
    max-width: 460px;
    margin: 0 auto
}

.verify-icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    background: linear-gradient(135deg, rgba(124, 58, 237, 0.15), rgba(6, 182, 212, 0.15));
    color: var(--accent-primary);
    transition: all 0.4s ease
}

.verify-card:hover .verify-icon-wrap {
    transform: scale(1.05) rotate(-3deg)
}

.verify-input {
    padding-left: 42px !important;
    font-family: 'Courier New', monospace !important;
    font-size: 15px !important;
    letter-spacing: 0.08em;
    height: 48px !important
}

.verify-input-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 18px;
    color: var(--text-secondary);
    z-index: 2;
    pointer-events: none
}

.verify-action-btn {
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--text-secondary) !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    padding: 6px 12px !important;
    transition: all 0.25s ease !important
}

.verify-action-btn:hover {
    background: var(--hover-glow) !important;
    color: var(--accent-primary) !important;
    border-color: rgba(124, 58, 237, 0.2) !important
}

.verify-action-clear:hover {
    color: var(--danger-color) !important;
    border-color: rgba(239, 68, 68, 0.2) !important;
    background: rgba(239, 68, 68, 0.08) !important
}

.verify-submit-btn {
    height: 48px !important;
    font-size: 14px !important;
    letter-spacing: 0.03em
}

.verify-steps {
    display: flex;
    justify-content: center;
    gap: 24px;
    padding-top: 16px;
    border-top: 1px solid var(--glass-border)
}

.verify-step {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--text-secondary)
}

.verify-step-num {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    background: rgba(124, 58, 237, 0.12);
    color: var(--accent-primary);
    flex-shrink: 0
}

.api-hero {
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    border-radius: 20px;
    padding: 2.5rem;
    margin-bottom: 2rem;
    position: relative;
    overflow: hidden
}

.api-hero::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 400px;
    height: 400px;
    background: rgba(255, 255, 255, .06);
    border-radius: 50%
}

.api-hero h2 {
    color: #fff;
    font-weight: 700;
    font-size: 1.75rem;
    margin-bottom: .5rem
}

.api-hero p {
    color: rgba(255, 255, 255, .85);
    font-size: 1rem;
    margin: 0
}

.api-hero .badge-v {
    background: rgba(255, 255, 255, .2);
    color: #fff;
    padding: 4px 14px;
    border-radius: 20px;
    font-size: .8rem;
    font-weight: 600
}

.api-docs-row {
    position: relative
}

.api-nav-col {
    align-self: flex-start;
    position: sticky;
    top: 90px;
    z-index: 10
}

.api-nav {
    max-height: calc(100vh - 110px);
    overflow-y: auto
}

.api-nav .nav-link {
    color: var(--text-secondary);
    padding: 8px 16px;
    border-radius: 10px;
    font-size: .875rem;
    transition: all .2s;
    border-left: 3px solid transparent;
    margin-bottom: 2px
}

.api-nav .nav-link:hover,
.api-nav .nav-link.active {
    color: var(--accent-primary);
    background: var(--hover-glow);
    border-left-color: var(--accent-primary)
}

.api-nav .nav-link i {
    width: 20px;
    text-align: center;
    margin-right: 8px
}

.ep-card {
    border-radius: 16px !important;
    margin-bottom: 1.5rem;
    overflow: hidden;
    transition: transform .2s, box-shadow .2s
}

.ep-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, .3) !important
}

.ep-header {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap
}

.m-badge {
    padding: 4px 14px;
    border-radius: 8px;
    font-weight: 700;
    font-size: .75rem;
    letter-spacing: .5px;
    text-transform: uppercase;
    flex-shrink: 0
}

.m-get {
    background: rgba(16, 185, 129, .15);
    color: #10b981
}

.m-post {
    background: rgba(59, 130, 246, .15);
    color: #3b82f6
}

.ep-url {
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: .9rem;
    color: var(--text-primary);
    word-break: break-all
}

.p-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0
}

.p-table th {
    background: var(--input-bg);
    color: var(--text-secondary);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--glass-border)
}

.p-table th:first-child {
    border-radius: 10px 0 0 0
}

.p-table th:last-child {
    border-radius: 0 10px 0 0
}

.p-table td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--glass-border);
    font-size: .875rem;
    color: var(--text-primary);
    vertical-align: top
}

.p-name {
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    color: var(--accent-primary);
    font-weight: 600;
    font-size: .85rem
}

.p-req {
    color: var(--danger-color);
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase
}

.p-opt {
    color: var(--text-secondary);
    font-size: .7rem;
    font-weight: 600
}

.p-type {
    background: var(--input-bg);
    padding: 2px 8px;
    border-radius: 6px;
    font-size: .75rem;
    font-family: monospace;
    color: var(--accent-secondary)
}

.lang-tabs {
    display: flex;
    gap: 4px;
    padding: 4px;
    background: var(--input-bg);
    border-radius: 12px;
    margin-bottom: 0;
    flex-wrap: wrap
}

.lang-tab {
    padding: 6px 16px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s;
    display: flex;
    align-items: center;
    gap: 6px
}

.lang-tab:hover {
    color: var(--text-primary);
    background: rgba(255, 255, 255, .05)
}

.lang-tab.active {
    background: var(--accent-primary);
    color: #fff;
    box-shadow: 0 2px 8px var(--accent-glow)
}

.code-wrap {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    margin-top: 8px
}

.code-wrap pre {
    margin: 0 !important;
    border-radius: 12px !important;
    padding: 1.25rem !important;
    font-size: .82rem !important;
    line-height: 1.6 !important;
    max-height: 420px;
    overflow-y: auto
}

.code-wrap pre code {
    padding: 0 !important;
    margin: 0 !important;
    display: block !important;
    background: none !important;
    border: none !important
}

.code-wrap pre::-webkit-scrollbar {
    width: 6px
}

.code-wrap pre::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, .15);
    border-radius: 3px
}

.copy-btn {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .15);
    color: #fff;
    padding: 4px 12px;
    border-radius: 8px;
    font-size: .75rem;
    cursor: pointer;
    transition: all .2s;
    z-index: 5;
    backdrop-filter: blur(8px)
}

.copy-btn:hover {
    background: var(--accent-primary);
    border-color: var(--accent-primary)
}

.copy-btn.copied {
    background: var(--success-color);
    border-color: var(--success-color)
}

.res-block {
    background: var(--input-bg);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    padding: 1rem;
    margin-top: .75rem
}

.res-block pre {
    margin: 0;
    color: var(--text-primary);
    font-size: .82rem;
    line-height: 1.6;
    white-space: pre-wrap;
    word-break: break-word
}

.res-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 8px
}

.res-label.ok {
    color: var(--success-color)
}

.res-label.err {
    color: var(--danger-color)
}

.s-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: .7rem;
    font-weight: 700
}

.s-200 {
    background: rgba(16, 185, 129, .12);
    color: #10b981
}

.s-403 {
    background: rgba(245, 158, 11, .12);
    color: #f59e0b
}

.s-429 {
    background: rgba(245, 158, 11, .12);
    color: #f59e0b
}

.s-500 {
    background: rgba(239, 68, 68, .12);
    color: #ef4444
}

.info-card {
    background: var(--input-bg);
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: 1.25rem;
    height: 100%;
    transition: transform .2s
}

.info-card:hover {
    transform: translateY(-2px)
}

.info-card .ic-w {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    margin-bottom: .75rem
}

.info-card h6 {
    font-weight: 700;
    font-size: .9rem;
    color: var(--text-primary)
}

.info-card p {
    font-size: .82rem;
    color: var(--text-secondary);
    margin: 0
}

.srv-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: var(--input-bg);
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    font-size: .82rem;
    color: var(--text-primary);
    font-weight: 500
}

.srv-chip .dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--success-color)
}

.sec-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 10px
}

.sec-title i {
    color: var(--accent-primary);
    font-size: 1.1rem
}

[id] {
    scroll-margin-top: 100px
}

.try-form {
    background: var(--input-bg);
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: 1.25rem
}

.try-form .form-control,
.try-form .form-select {
    background: var(--card-bg);
    border: 1px solid var(--glass-border);
    color: var(--text-primary);
    border-radius: 10px;
    font-size: .85rem;
    padding: 8px 14px
}

.try-form .form-control:focus,
.try-form .form-select:focus {
    border-color: var(--accent-primary);
    box-shadow: 0 0 0 3px var(--accent-glow)
}

.try-form label {
    color: var(--text-secondary);
    font-size: .78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .3px;
    margin-bottom: 4px
}

.try-result {
    background: #1a1a2e;
    border-radius: 12px;
    padding: 1rem;
    margin-top: 1rem;
    display: none;
    max-height: 300px;
    overflow-y: auto
}

.try-result pre {
    margin: 0;
    color: #e2e8f0;
    font-size: .82rem;
    white-space: pre-wrap
}

.btn-try {
    background: var(--accent-primary);
    color: #fff;
    border: none;
    border-radius: 10px;
    padding: 8px 24px;
    font-weight: 600;
    font-size: .85rem;
    transition: all .2s
}

.btn-try:hover {
    background: #6d28d9;
    color: #fff;
    transform: translateY(-1px)
}

@media(max-width:991.98px) {
    .api-nav-col {
        position: static;
        z-index: auto
    }

    .api-nav {
        position: static;
        max-height: none;
        margin-bottom: 1.5rem
    }

    .api-hero {
        padding: 1.5rem
    }

    .api-hero h2 {
        font-size: 1.35rem
    }

    .ep-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px
    }

    .lang-tabs {
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch
    }

    .lang-tab {
        white-space: nowrap;
        flex-shrink: 0
    }
}

.profile-header-card {
    border-left: 4px solid var(--accent-primary) !important
}

.profile-avatar-wrap {
    position: relative;
    width: 72px;
    height: 72px;
    flex-shrink: 0
}

.profile-avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--glass-border);
    transition: border-color var(--t)
}

.profile-avatar-wrap:hover .profile-avatar {
    border-color: var(--accent-primary)
}

.profile-avatar-placeholder {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    color: #fff
}

.profile-status-dot {
    position: absolute;
    bottom: 4px;
    right: 4px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--card-bg)
}

.profile-status-dot.online {
    background: var(--success-color);
    box-shadow: 0 0 8px rgba(16, 185, 129, 0.5)
}

.profile-status-dot.offline {
    background: var(--text-secondary)
}

.profile-quick-link {
    cursor: pointer;
    transition: all var(--t) !important
}

.profile-quick-link:hover {
    border-color: var(--accent-primary) !important;
    transform: translateY(-1px)
}

.profile-quick-link .info-box-value {
    color: var(--text-primary)
}

@media (max-width:575.98px) {

    .profile-avatar-wrap,
    .profile-avatar,
    .profile-avatar-placeholder {
        width: 56px;
        height: 56px
    }

    .profile-avatar-placeholder {
        font-size: 22px
    }

    .profile-status-dot {
        width: 12px;
        height: 12px;
        bottom: 2px;
        right: 2px
    }

    .profile-header-card .card-body {
        padding: 1rem !important
    }

    .profile-header-card h4 {
        font-size: 1rem
    }

    .profile-header-card .badge {
        font-size: 0.7rem;
        padding: 3px 8px !important
    }
}

/* ═══════════════════════════════════════════════════════════
   SETTINGS PAGE — Glass Morphism
   ═══════════════════════════════════════════════════════════ */

.settings-header-card {
    border-left: 4px solid var(--accent-primary) !important
}

.settings-nav-wrapper {
    background: var(--glass-bg);
    backdrop-filter: blur(var(--glass-blur));
    -webkit-backdrop-filter: blur(var(--glass-blur));
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: 6px;
    overflow-x: auto
}

.settings-nav {
    border: none !important;
    gap: 4px;
    flex-wrap: nowrap;
    min-width: max-content
}

.settings-nav .nav-link {
    background: transparent !important;
    border: none !important;
    color: var(--text-secondary) !important;
    border-radius: 10px !important;
    padding: 10px 18px !important;
    font-weight: 500 !important;
    font-size: 0.875rem;
    white-space: nowrap;
    transition: all var(--t) !important;
    display: flex;
    align-items: center;
    gap: 4px
}

.settings-nav .nav-link:hover {
    color: var(--text-primary) !important;
    background: var(--hover-glow) !important
}

.settings-nav .nav-link.active {
    color: #fff !important;
    background: linear-gradient(135deg, var(--accent-primary), var(--accent-secondary)) !important;
    box-shadow: 0 4px 15px var(--accent-glow) !important
}

.settings-nav .nav-link i {
    font-size: 16px
}

.settings-section {
    border-radius: 16px !important
}

.settings-group-title {
    color: var(--accent-primary) !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--glass-border);
    display: flex;
    align-items: center
}

.settings-group-title i {
    font-size: 16px
}

.settings-field {
    margin-bottom: 4px
}

.settings-field label {
    display: flex;
    align-items: center;
    gap: 4px
}

.settings-field label .ri-information-line {
    color: var(--text-secondary);
    cursor: help;
    font-size: 14px;
    opacity: 0.6;
    transition: opacity var(--t)
}

.settings-field label .ri-information-line:hover {
    opacity: 1;
    color: var(--accent-primary)
}

.settings-currency-note {
    display: flex;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    background: var(--glass-bg);
    color: var(--text-secondary);
}

.settings-currency-note-icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(16, 185, 129, 0.12);
    color: var(--success-color);
    font-size: 18px;
}

.settings-currency-note h6 {
    margin: 0 0 4px;
    color: var(--text-primary);
    font-size: 0.92rem;
    font-weight: 700;
}

.settings-currency-note p {
    margin: 0;
    line-height: 1.55;
}

.captcha-provider-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.captcha-provider-option {
    min-width: 0;
}

.captcha-provider-card {
    min-height: 118px;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    grid-template-areas:
        "icon copy"
        "state state";
    align-items: start;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    background: color-mix(in srgb, var(--card-bg, #10101a) 72%, transparent);
    cursor: pointer;
    transition: border-color var(--t), background var(--t), box-shadow var(--t), transform var(--t);
}

.captcha-provider-card:hover,
.captcha-provider-card.is-active {
    border-color: color-mix(in srgb, var(--accent-primary) 56%, var(--glass-border));
    background: color-mix(in srgb, var(--accent-primary) 8%, var(--card-bg, #10101a));
    box-shadow: 0 10px 24px color-mix(in srgb, var(--accent-primary) 14%, transparent);
}

.captcha-provider-card:hover {
    transform: translateY(-1px);
}

.captcha-provider-icon {
    grid-area: icon;
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    color: var(--accent-primary);
    background: color-mix(in srgb, var(--accent-primary) 14%, transparent);
    font-size: 20px;
}

.captcha-provider-copy {
    grid-area: copy;
    min-width: 0;
}

.captcha-provider-title {
    display: block;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.25;
}

.captcha-provider-desc {
    display: block;
    margin-top: 4px;
    color: var(--text-secondary);
    font-size: 0.82rem;
    line-height: 1.35;
}

.captcha-provider-state {
    grid-area: state;
    width: max-content;
    max-width: 100%;
    padding: 4px 10px;
    border-radius: 999px;
    color: var(--text-secondary);
    background: rgba(148, 163, 184, .13);
    font-size: 0.75rem;
    font-weight: 700;
}

.captcha-provider-card.is-active .captcha-provider-state {
    color: #fff;
    background: linear-gradient(135deg, var(--accent-primary), var(--success-color, #10b981));
}

.captcha-provider-panel[hidden] {
    display: none !important;
}

.captcha-provider-panel {
    padding: 18px;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    background: var(--glass-bg);
}

.captcha-provider-empty {
    min-height: 96px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--text-secondary);
    border: 1px dashed var(--glass-border);
    border-radius: 10px;
    background: rgba(148, 163, 184, .06);
    font-weight: 600;
}

.captcha-provider-empty i {
    font-size: 20px;
    color: var(--accent-primary);
}

.settings-gateway-card {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    padding: 20px;
    transition: border-color var(--t)
}

.settings-gateway-card:hover {
    border-color: rgba(124, 58, 237, 0.2)
}

.input-group-text {
    border-radius: 0 10px 10px 0 !important
}

/* Color picker */
.form-control-color {
    border-radius: 10px !important;
    cursor: pointer;
    padding: 4px !important
}

/* Responsive settings tabs */
@media (max-width: 767.98px) {
    .settings-nav .nav-link {
        padding: 8px 14px !important;
        font-size: 0.8rem
    }

    .settings-nav .nav-link span {
        display: none
    }

    .settings-nav .nav-link i {
        font-size: 18px;
        margin: 0 !important
    }

    .settings-gateway-card {
        padding: 14px
    }
}

[data-theme="light"] .settings-nav-wrapper {
    box-shadow: 0 2px 10px rgba(100, 80, 160, 0.04)
}

[data-theme="light"] .settings-gateway-card {
    background: rgba(255, 255, 255, 0.45);
    border-color: rgba(140, 120, 200, 0.12)
}

[data-theme="light"] .captcha-provider-card {
    background: #fff;
    border-color: rgba(15, 23, 42, .1);
    box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
}

[data-theme="light"] .captcha-provider-card:hover,
[data-theme="light"] .captcha-provider-card.is-active {
    background: color-mix(in srgb, var(--accent-primary) 5%, #fff);
    border-color: color-mix(in srgb, var(--accent-primary) 36%, rgba(15, 23, 42, .1));
    box-shadow: 0 12px 24px rgba(15, 23, 42, .08);
}

[data-theme="light"] .captcha-provider-panel {
    background: rgba(255, 255, 255, .7);
    border-color: rgba(15, 23, 42, .1);
}

[data-theme="light"] .captcha-provider-empty {
    background: rgba(124, 58, 237, .035);
    border-color: rgba(124, 58, 237, .16);
}

[data-theme="light"] .settings-gateway-card:hover {
    border-color: rgba(124, 58, 237, 0.2);
    box-shadow: 0 2px 12px rgba(100, 80, 160, 0.06)
}

@media (max-width: 991.98px) {
    .captcha-provider-grid {
        grid-template-columns: 1fr;
    }

    .captcha-provider-card {
        min-height: 92px;
    }
}

/* Sticky Save Bar */
.settings-save-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1050;
    transform: translateY(100%);
    opacity: 0;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.35s ease;
    pointer-events: none
}

.settings-save-bar.visible {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto
}

.settings-save-bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 32px;
    margin: 0 auto;
    background: rgba(30, 20, 60, 0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-top: 1px solid rgba(124, 58, 237, 0.3);
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.25)
}

.settings-save-bar-info {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #fff;
    font-weight: 500;
    font-size: 0.9rem
}

.settings-save-bar-info i {
    font-size: 20px;
    color: #fbbf24
}

.settings-save-bar-actions {
    display: flex;
    align-items: center;
    gap: 10px
}

.settings-save-bar-actions .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.25);
    color: rgba(255, 255, 255, 0.8);
    border-radius: 10px;
    padding: 8px 18px;
    font-weight: 500;
    transition: all var(--t)
}

.settings-save-bar-actions .btn-outline-light:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.4);
    color: #fff
}

.settings-save-bar-actions .btn-primary {
    border-radius: 10px;
    padding: 8px 24px;
    font-weight: 600;
    box-shadow: 0 4px 15px var(--accent-glow)
}

[data-theme="light"] .settings-save-bar-inner {
    background: rgba(255, 255, 255, 0.92);
    border-top-color: rgba(124, 58, 237, 0.15);
    box-shadow: 0 -8px 32px rgba(100, 80, 160, 0.12)
}

[data-theme="light"] .settings-save-bar-info {
    color: var(--text-primary)
}

[data-theme="light"] .settings-save-bar-actions .btn-outline-light {
    border-color: var(--glass-border);
    color: var(--text-secondary)
}

[data-theme="light"] .settings-save-bar-actions .btn-outline-light:hover {
    background: rgba(124, 58, 237, 0.06);
    border-color: var(--accent-primary);
    color: var(--accent-primary)
}

@media (max-width: 767.98px) {
    .settings-save-bar-inner {
        padding: 12px 16px;
        flex-direction: column;
        gap: 10px
    }
}

/* ── Plan Purchase Modal (SweetAlert2) ── */

@keyframes swalPlanShowAnim {
    from { opacity: 0; transform: translateY(30px) scale(0.96) }
    to { opacity: 1; transform: translateY(0) scale(1) }
}

@keyframes swalPlanHideAnim {
    from { opacity: 1; transform: translateY(0) scale(1) }
    to { opacity: 0; transform: translateY(20px) scale(0.96) }
}

.swal-plan-show {
    animation: swalPlanShowAnim 0.35s cubic-bezier(0.4, 0, 0.2, 1) forwards !important
}

.swal-plan-hide {
    animation: swalPlanHideAnim 0.25s cubic-bezier(0.4, 0, 0.2, 1) forwards !important
}

.swal-plan-popup {
    padding: 0 !important;
    border-radius: 20px !important;
    overflow: hidden;
    max-width: 460px !important;
    width: 95vw !important
}

.swal-plan-popup .swal2-html-container {
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important
}

.swal-plan-popup .swal2-title {
    display: none !important
}

.swal-plan-popup .swal2-icon {
    display: none !important
}

.swal-plan-popup .swal2-actions {
    padding: 0 24px 24px !important;
    margin-top: 0 !important;
    gap: 10px
}

.swal-plan-popup .swal2-validation-message {
    margin: 0 24px 12px !important;
    border-radius: 10px !important;
    background: rgba(239, 68, 68, 0.1) !important;
    color: var(--danger-color) !important;
    border: 1px solid rgba(239, 68, 68, 0.2) !important;
    font-size: 13px
}

/* Header */
.swal-plan-header {
    padding: 24px 24px 18px;
    text-align: center;
    position: relative;
    overflow: hidden
}

.swal-plan-header::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0.08;
    background: radial-gradient(circle at 30% 50%, #fff 0%, transparent 60%)
}

.swal-plan-header-icon {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    margin-bottom: 12px;
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    backdrop-filter: blur(8px);
    animation: swalPlanIconPulse 2.5s ease-in-out infinite;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15)
}

@keyframes swalPlanIconPulse {
    0%, 100% { transform: scale(1); box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) }
    50% { transform: scale(1.06); box-shadow: 0 6px 28px rgba(0, 0, 0, 0.2) }
}

.swal-plan-header-title {
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 2px;
    letter-spacing: 0.02em
}

.swal-plan-header-sub {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
    font-weight: 500
}

/* Body */
.swal-plan-body {
    padding: 20px 24px 20px
}

/* Summary Card */
.swal-plan-summary {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 14px;
    padding: 0;
    overflow: hidden
}

.swal-plan-summary-head {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--glass-border);
    background: rgba(255, 255, 255, 0.02)
}

.swal-plan-summary-head i {
    font-size: 16px;
    color: var(--accent-primary)
}

.swal-plan-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    transition: background 0.2s ease
}

.swal-plan-row:not(:last-child) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.04)
}

.swal-plan-row:hover {
    background: rgba(255, 255, 255, 0.02)
}

.swal-plan-row-label {
    font-size: 13px;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 8px
}

.swal-plan-row-label i {
    font-size: 15px;
    opacity: 0.7
}

.swal-plan-row-value {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary)
}

.swal-plan-row-highlight {
    color: var(--accent-primary) !important
}

.swal-plan-row-success {
    color: var(--success-color) !important
}

.swal-plan-row-danger {
    color: var(--danger-color) !important
}

/* Balance Status */
.swal-plan-status {
    margin-top: 14px;
    padding: 10px 14px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    font-weight: 600;
    animation: swalPlanStatusFade 0.5s ease forwards
}

@keyframes swalPlanStatusFade {
    from { opacity: 0; transform: translateY(6px) }
    to { opacity: 1; transform: translateY(0) }
}

.swal-plan-status-ok {
    background: rgba(16, 185, 129, 0.1);
    border: 1px solid rgba(16, 185, 129, 0.2);
    color: var(--success-color)
}

.swal-plan-status-fail {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    color: var(--danger-color)
}

.swal-plan-status i {
    font-size: 18px;
    flex-shrink: 0
}

/* Discount Section */
.swal-plan-discount {
    margin-top: 16px
}

.swal-plan-discount-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em
}

.swal-plan-discount-label i {
    font-size: 14px;
    color: var(--accent-primary)
}

.swal-plan-discount-input-wrap {
    display: flex;
    gap: 8px;
    align-items: stretch
}

.swal-plan-discount-input-wrap input {
    flex: 1;
    background: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    border-radius: 10px !important;
    color: var(--text-primary) !important;
    padding: 8px 14px !important;
    font-size: 13px;
    transition: all 0.25s ease;
    margin: 0 !important;
    height: auto !important
}

.swal-plan-discount-input-wrap input:focus {
    border-color: var(--accent-primary) !important;
    box-shadow: 0 0 0 3px var(--input-focus) !important;
    outline: none
}

.swal-plan-discount-input-wrap input::placeholder {
    color: var(--text-secondary);
    opacity: 0.5
}

.swal-plan-discount-btn {
    background: linear-gradient(135deg, var(--accent-primary), #6d28d9) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 8px 16px !important;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: all 0.25s ease !important;
    box-shadow: 0 4px 12px var(--accent-glow)
}

.swal-plan-discount-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px var(--accent-glow) !important
}

.swal-plan-discount-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none !important
}

.swal-plan-discount-result {
    margin-top: 10px
}

.swal-plan-discount-detail {
    background: rgba(16, 185, 129, 0.06);
    border: 1px solid rgba(16, 185, 129, 0.15);
    border-radius: 12px;
    padding: 2px 0;
    overflow: hidden
}

.swal-plan-discount-detail .swal-plan-row {
    padding: 8px 14px
}

.swal-plan-discount-detail .swal-plan-row-label,
.swal-plan-discount-detail .swal-plan-row-value {
    font-size: 12.5px
}

/* Action Buttons */
.swal-plan-confirm {
    border-radius: 12px !important;
    padding: 11px 28px !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    border: none !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 20px var(--accent-glow) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    letter-spacing: 0.02em
}

.swal-plan-confirm:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 30px rgba(124, 58, 237, 0.4) !important
}

.swal-plan-confirm:disabled,
.swal-plan-confirm-disabled {
    cursor: not-allowed !important;
    opacity: .55 !important;
    transform: none !important;
    box-shadow: none !important
}

.swal-plan-confirm:disabled:hover,
.swal-plan-confirm-disabled:hover {
    transform: none !important;
    box-shadow: none !important
}

.swal-plan-cancel {
    border-radius: 12px !important;
    padding: 11px 24px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    background: var(--glass-bg) !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--text-secondary) !important;
    transition: all 0.3s ease !important
}

.swal-plan-cancel:hover {
    background: var(--hover-glow) !important;
    border-color: var(--accent-primary) !important;
    color: var(--text-primary) !important;
    transform: translateY(-1px) !important
}

/* Responsive */
@media (max-width: 575.98px) {
    .swal-plan-popup {
        max-width: 96vw !important
    }

    .swal-plan-header {
        padding: 18px 18px 14px
    }

    .swal-plan-body {
        padding: 16px 18px 16px
    }

    .swal-plan-popup .swal2-actions {
        padding: 0 18px 18px !important;
        flex-direction: column-reverse
    }

    .swal-plan-confirm,
    .swal-plan-cancel {
        width: 100% !important;
        justify-content: center !important
    }

    .swal-plan-header-icon {
        width: 48px;
        height: 48px;
        font-size: 22px;
        border-radius: 14px
    }

    .swal-plan-header-title {
        font-size: 16px
    }
}

/* Light theme overrides */
[data-theme="light"] .swal-plan-summary {
    background: rgba(124, 58, 237, 0.03);
    border-color: rgba(124, 58, 237, 0.1)
}

[data-theme="light"] .swal-plan-row:not(:last-child) {
    border-bottom-color: rgba(124, 58, 237, 0.06)
}

[data-theme="light"] .swal-plan-row:hover {
    background: rgba(124, 58, 237, 0.03)
}

[data-theme="light"] .swal-plan-summary-head {
    background: rgba(124, 58, 237, 0.03);
    border-bottom-color: rgba(124, 58, 237, 0.08)
}

[data-theme="light"] .swal-plan-status-ok {
    background: rgba(16, 185, 129, 0.08);
    border-color: rgba(16, 185, 129, 0.15)
}

[data-theme="light"] .swal-plan-status-fail {
    background: rgba(239, 68, 68, 0.06);
    border-color: rgba(239, 68, 68, 0.12)
}

[data-theme="light"] .swal-plan-discount-detail {
    background: rgba(16, 185, 129, 0.04);
    border-color: rgba(16, 185, 129, 0.1)
}

[data-theme="light"] .swal-plan-cancel {
    background: rgba(124, 58, 237, 0.05) !important;
    border-color: rgba(124, 58, 237, 0.12) !important;
    color: var(--text-secondary) !important
}

[data-theme="light"] .swal-plan-cancel:hover {
    background: rgba(124, 58, 237, 0.1) !important;
    color: var(--accent-primary) !important
}

/* ==========================================================
   CUSTOM SWITCHES & CHECKBOXES
   Smooth, modern, themed — overrides Bootstrap defaults
   ========================================================== */
.form-check-input {
    cursor: pointer;
    transition:
        background-color 0.25s ease,
        background-position 0.3s cubic-bezier(0.34, 1.56, 0.64, 1),
        border-color 0.25s ease,
        box-shadow 0.25s ease,
        transform 0.15s ease !important;
}

.form-check-input:hover:not(:disabled):not(:checked) {
    border-color: var(--accent-primary) !important;
}

.form-check-input:active:not(:disabled) {
    transform: scale(0.94);
}

.form-check-input:focus {
    outline: 0;
    box-shadow: 0 0 0 3px var(--accent-glow) !important;
}

.form-check-input:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.form-switch {
    padding-left: 3em;
    display: inline-flex;
    align-items: center;
}

.form-switch .form-check-input {
    width: 2.4em;
    height: 1.35em;
    margin-left: -3em;
    margin-top: 0;
    background-color: rgba(148, 163, 184, 0.22) !important;
    border: 1px solid rgba(148, 163, 184, 0.25) !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23ffffff'/%3e%3c/svg%3e") !important;
    background-position: left center !important;
    background-size: contain;
    background-repeat: no-repeat;
    border-radius: 2em !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.form-switch .form-check-input:hover:not(:disabled):not(:checked) {
    background-color: rgba(148, 163, 184, 0.32) !important;
    border-color: rgba(148, 163, 184, 0.4) !important;
}

.form-switch .form-check-input:focus {
    border-color: var(--accent-primary) !important;
    box-shadow:
        inset 0 2px 4px rgba(0, 0, 0, 0.1),
        0 0 0 3px var(--accent-glow) !important;
}

.form-switch .form-check-input:checked {
    background-color: var(--accent-primary) !important;
    border-color: transparent !important;
    background-position: right center !important;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23ffffff'/%3e%3c/svg%3e") !important;
    box-shadow:
        inset 0 2px 4px rgba(0, 0, 0, 0.15),
        0 2px 10px var(--accent-glow) !important;
}

.form-switch .form-check-input:checked:hover:not(:disabled) {
    filter: brightness(1.08);
    box-shadow:
        inset 0 2px 4px rgba(0, 0, 0, 0.15),
        0 4px 14px var(--accent-glow) !important;
}

[data-theme="light"] .form-switch .form-check-input {
    background-color: rgba(148, 163, 184, 0.28) !important;
    border-color: rgba(148, 163, 184, 0.35) !important;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .form-switch .form-check-input:checked {
    background-color: var(--accent-primary) !important;
    border-color: transparent !important;
    box-shadow:
        inset 0 1px 3px rgba(0, 0, 0, 0.12),
        0 2px 10px var(--accent-glow) !important;
}

.form-check.form-switch label,
.form-check.form-switch .form-check-label {
    cursor: pointer;
    user-select: none;
}

@media (prefers-reduced-motion: reduce) {
    .form-check-input,
    .form-switch .form-check-input {
        transition: none !important;
    }

    .form-check-input:active:not(:disabled) {
        transform: none;
    }
}

/* ═════════════════════════════════════════════════════════
   Auth pages — split-screen layout (Lottie left + form right)
   Moved from resources/views/layouts/auth.blade.php inline
   <style> to avoid duplication. Applies when body.authentication-bg
   wraps <main class="auth-wrap">.
   ═════════════════════════════════════════════════════════ */

/* Body override for full-width split layout (no flex/py-5 needed) */
body.authentication-bg {
    padding: 0 !important;
    display: block !important;
    min-height: 100vh;
}

/* Input-group: gắn liền icon-prefix + input + eye-toggle thành 1 khối */
.input-group > .form-control,
.input-group > .input-group-text,
.input-group > .pwd-toggle,
.input-group > .btn {
    border-radius: 0 !important;
}
.input-group > :first-child {
    border-top-left-radius: 10px !important;
    border-bottom-left-radius: 10px !important;
}
.input-group > :last-child {
    border-top-right-radius: 10px !important;
    border-bottom-right-radius: 10px !important;
}
.input-group > .form-control + .input-group-text,
.input-group > .form-control + .pwd-toggle,
.input-group > .input-group-text + .form-control {
    border-left: 0;
}

.pwd-toggle { cursor: pointer; }
.pwd-toggle:hover { color: var(--accent-primary); }
.pwd-bar { height: 4px; flex: 1; border-radius: 2px; background: var(--glass-border, rgba(148,163,184,.25)); transition: background .3s; }
.pwd-bar.weak { background: #ef4444; }
.pwd-bar.fair { background: #f59e0b; }
.pwd-bar.good { background: #3b82f6; }
.pwd-bar.strong { background: #10b981; }
.auth-card-header { display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem; }
.auth-card-header .stat-icon-wrap { width: 42px; height: 42px; border-radius: 10px; display: inline-flex; align-items: center; justify-content: center; font-size: 20px; box-shadow: 0 0 0 1px rgba(255,255,255,.06), 0 4px 12px rgba(0,0,0,.18); }
body.authentication-bg[data-theme="light"] .auth-card-header .stat-icon-wrap {
    box-shadow: 0 0 0 1px rgba(140,120,200,.12), 0 4px 12px rgba(80,60,140,.10);
}

body.authentication-bg:not([data-theme="light"]) main.auth-wrap,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap .card,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap .card-body {
    color: var(--text-primary) !important;
}

/* Split-screen wrap (full-viewport, 2 cols on lg+) */
.auth-wrap { max-width: 100% !important; }

/* Glass card (dark) */
body.authentication-bg main.auth-wrap .card {
    position: relative;
    background: linear-gradient(145deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.02) 100%),
                color-mix(in srgb, var(--gradient-mid) 35%, transparent) !important;
    backdrop-filter: blur(28px) saturate(160%) !important;
    -webkit-backdrop-filter: blur(28px) saturate(160%) !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    border-radius: 20px !important;
    box-shadow: 0 24px 64px rgba(0,0,0,.45),
                0 0 0 1px rgba(255,255,255,.04) inset,
                0 1px 0 rgba(255,255,255,.10) inset !important;
    overflow: hidden;
}
body.authentication-bg main.auth-wrap .card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.18) 50%, transparent 100%);
    pointer-events: none;
}
body.authentication-bg main.auth-wrap .card:focus-within {
    border-color: rgba(var(--accent-rgb, 124,58,237), .35) !important;
    box-shadow: 0 24px 64px rgba(0,0,0,.50),
                0 0 0 1px rgba(var(--accent-rgb, 124,58,237), .25) inset,
                0 0 32px var(--accent-glow, rgba(124,58,237,.25)) !important;
}

body.authentication-bg:not([data-theme="light"]) main.auth-wrap h1,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap h2,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap h3,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap h4,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap h5,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap h6,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap .auth-card-header .fw-bold,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap .form-check-label {
    color: var(--text-primary) !important;
}

body.authentication-bg:not([data-theme="light"]) main.auth-wrap .text-muted,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap small.text-muted,
body.authentication-bg:not([data-theme="light"]) main.auth-wrap .info-box-label,
body.authentication-bg:not([data-theme="light"]) .auth-footer {
    color: var(--text-secondary) !important;
}

body.authentication-bg:not([data-theme="light"]) main.auth-wrap .input-group .form-control::placeholder {
    color: rgba(148, 163, 184, .88) !important;
}

/* Glass card (light) */
body.authentication-bg[data-theme="light"] main.auth-wrap .card {
    background: linear-gradient(145deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.82) 100%) !important;
    border: 1px solid rgba(140,120,200,.18) !important;
    box-shadow: 0 16px 48px rgba(80,60,140,.12),
                0 0 0 1px rgba(255,255,255,.6) inset !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .card::before {
    background: linear-gradient(90deg, transparent 0%, rgba(124,58,237,.18) 50%, transparent 100%);
}

/* Inputs inside auth-wrap — dark (default) */
body.authentication-bg main.auth-wrap .input-group .form-control,
body.authentication-bg main.auth-wrap .input-group .input-group-text,
body.authentication-bg main.auth-wrap .input-group .pwd-toggle {
    background: rgba(0,0,0,.18) !important;
    border-color: rgba(255,255,255,.10) !important;
    color: var(--text-primary, #fff) !important;
}

/* Inputs — light */
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .form-control,
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .input-group-text,
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .pwd-toggle {
    background: #ffffff !important;
    border: 1px solid #cbd5e1 !important;
    color: #1e1b4b !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .input-group-text i,
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .pwd-toggle i {
    color: #64748b !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .form-control::placeholder {
    color: #94a3b8 !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .input-group .form-control:focus {
    border-color: #7c3aed !important;
    box-shadow: 0 0 0 3px rgba(124,58,237,.12) !important;
}

/* Labels + text — light */
body.authentication-bg[data-theme="light"] main.auth-wrap .card h5,
body.authentication-bg[data-theme="light"] main.auth-wrap .card .info-box-label {
    color: #1e1b4b !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .card small.text-muted,
body.authentication-bg[data-theme="light"] main.auth-wrap .card .text-muted {
    color: #64748b !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .nav-pills .nav-link {
    color: #64748b !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .nav-pills .nav-link.active {
    background: #7c3aed !important;
    color: #ffffff !important;
}
body.authentication-bg[data-theme="light"] main.auth-wrap .form-check-label {
    color: #1e1b4b !important;
}

/* Left illustration column */
.auth-illustration-col {
    align-items: center;
    justify-content: center;
    padding: 3rem 2rem;
    position: relative;
    overflow: hidden;
    background: linear-gradient(145deg,
        color-mix(in srgb, var(--accent-primary) 8%, transparent) 0%,
        color-mix(in srgb, var(--accent-primary) 18%, transparent) 100%);
    border-right: 1px solid rgba(255,255,255,.06);
}
.auth-illustration-col::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 30% 50%, var(--accent-glow, rgba(124,58,237,.25)), transparent 65%);
}
body.authentication-bg[data-theme="light"] .auth-illustration-col {
    background: linear-gradient(145deg, #f5f2ff 0%, #eae3ff 100%);
    border-right: 1px solid rgba(140,120,200,.15);
}
.auth-illustration-inner {
    width: 100%;
    max-width: 560px;
    position: relative;
    z-index: 1;
}
.auth-lottie {
    width: 100%;
    aspect-ratio: 600 / 390;
}
.auth-lottie svg {
    display: block;
    width: 100% !important;
    height: 100% !important;
}

/* Right form column — !important to beat Bootstrap col padding and
   prevent late-applied padding causing CLS on throttled networks. */
.auth-form-col {
    min-height: 100vh;
    padding: 2.5rem 1rem !important;
}
.auth-form-wrap {
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}
.auth-footer {
    color: var(--text-secondary);
    opacity: .82;
}

.auth-footer a {
    color: var(--accent-primary) !important;
    font-weight: 600;
}

.auth-footer a:hover {
    color: var(--accent-secondary) !important;
}

.auth-top-actions {
    z-index: 1050;
}

.auth-top-actions .header-item {
    width: 2.25rem;
    min-width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 999px;
    background: rgba(15, 23, 42, .36);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .18) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.auth-top-actions .header-item:hover,
.auth-top-actions .header-item:focus-visible {
    background: rgba(124, 58, 237, .2);
    transform: translateY(-1px);
}

.auth-top-actions .auth-lang-toggle {
    width: auto;
    min-width: 3.25rem;
    padding: 0 .65rem;
}

body.authentication-bg[data-theme="light"] .auth-top-actions .header-item {
    border-color: rgba(124, 58, 237, .18);
    background: rgba(255, 255, 255, .86);
    box-shadow: 0 10px 24px rgba(33, 37, 41, .1) !important;
}

body.authentication-bg:not([data-theme="light"]) .auth-top-actions .header-item,
body.authentication-bg:not([data-theme="light"]) .auth-top-actions .header-item i,
body.authentication-bg:not([data-theme="light"]) .auth-top-actions .header-item span {
    color: #ffffff !important;
}

/* Desktop (>=lg): vertically center form + larger padding */
@media (min-width: 992px) {
    .auth-form-col {
        justify-content: center;
        padding: 3rem 1.5rem !important;
    }
}

/* Mobile/tablet (<lg): form anchored to top — NO vertical centering,
   so any height change (typing, focus, validation) grows downward
   and doesn't re-center the whole card (fixes CLS). */
@media (max-width: 991.98px) {
    .auth-form-col {
        min-height: auto;
    }
}

@media (max-width: 419.98px) {
    body.authentication-bg .auth-form-wrap > .p-4,
    body.authentication-bg main.auth-wrap .card .card-body.p-4 {
        padding: 1rem !important;
    }
}

/* Reserve space for validation/helper elements that toggle d-none,
   preventing Cumulative Layout Shift when they appear. */
.pwd-match-error { min-height: 1.25rem; display: block !important; visibility: hidden; }
.pwd-match-error:not(.d-none) { visibility: visible; }
/* hCaptcha injects a 303x78 iframe; scale it on narrow auth cards. */
.auth-captcha {
    width: 100%;
}

.geetest-captcha-shell {
    width: min(100%, 320px);
    margin-right: auto;
    margin-left: auto;
}

.geetest-captcha-box {
    width: 100%;
    min-height: 44px;
    display: block;
    border-radius: 10px;
    overflow: visible;
}

.geetest-captcha-box > .geetest_captcha,
.geetest-captcha-box .geetest_holder {
    width: 100% !important;
}

.auth-captcha [class*="geetest_box_logo"] {
    display: none !important;
}

.authentication-bg [class*="geetest_feedback"],
.authentication-bg [class*="geetest_box_feedback"] {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

.geetest-captcha-loading {
    width: 100%;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 10px;
    background: rgba(0, 0, 0, .18);
    color: var(--text-secondary);
    font-size: .85rem;
    font-weight: 600;
}

.geetest-captcha-status {
    min-height: 20px;
    margin-top: 6px;
    color: var(--text-secondary);
    font-size: .78rem;
    line-height: 1.35;
}

.geetest-captcha-status[data-state="success"] {
    color: var(--success-color, #10b981);
}

.geetest-captcha-status[data-state="error"] {
    color: var(--danger-color, #ef4444);
}

body.authentication-bg[data-theme="light"] .geetest-captcha-loading {
    border-color: #cbd5e1;
    background: #fff;
    color: #64748b;
}

body.authentication-bg .h-captcha {
    --hcaptcha-scale: 1;
    width: 303px;
    height: 78px;
    min-height: 78px;
    display: block;
    overflow: hidden;
}
body.authentication-bg .h-captcha iframe {
    display: block;
    max-width: none;
    transform: scale(var(--hcaptcha-scale));
    transform-origin: top left;
}

@media (max-width: 419.98px) {
    body.authentication-bg .h-captcha {
        --hcaptcha-scale: .92;
        width: 279px;
        height: 72px;
        min-height: 72px;
    }
}

@media (max-width: 359.98px) {
    body.authentication-bg .h-captcha {
        --hcaptcha-scale: .78;
        width: 237px;
        height: 61px;
        min-height: 61px;
    }
}

@media (max-width: 329.98px) {
    body.authentication-bg .h-captcha {
        --hcaptcha-scale: .72;
        width: 219px;
        height: 57px;
        min-height: 57px;
    }
}

/* Aurora-style page reveal: fade up content blocks as they enter viewport. */
body:not(.authentication-bg).js-page-reveal .page-reveal {
    opacity: 0;
    transform: translate3d(0, 34px, 0);
    transition:
        opacity .68s cubic-bezier(.22, 1, .36, 1),
        transform .68s cubic-bezier(.22, 1, .36, 1);
    transition-delay: var(--page-reveal-delay, 0ms);
    will-change: opacity, transform;
}

body:not(.authentication-bg).js-page-reveal .page-reveal.is-revealed {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce) {
    body:not(.authentication-bg).js-page-reveal .page-reveal {
        transform: none !important;
        transition: opacity .26s ease-out !important;
    }
}

body:not(.authentication-bg).js-page-reveal:not(.js-page-reveal-ready) .page-reveal {
    transition: none !important;
}
