:root {
    /* Modern Enterprise Palette */
    --primary: #cf962b;
    --primary-dark: #b07d1e;
    --primary-light: #fcefd6;
    --success: #10b981;
    --danger: #ef4444;
    --warning: #f59e0b;
    --info: #3b82f6;
    --text-main: #1e293b;
    /* Slate 800 */
    --text-muted: #64748b;
    /* Slate 500 */
    --bg-main: #f8fafc;
    /* Slate 50 */
    --border-color: #e2e8f0;
    /* Slate 200 */
    --surface: #ffffff;
    --card-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --card-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

html.dark {
    --primary-light: rgba(207, 150, 43, 0.18);
    --text-main: #f1f5f9;
    /* Slate 100 */
    --text-muted: #94a3b8;
    /* Slate 400 */
    --bg-main: #0f172a;
    /* Slate 900 */
    --border-color: #334155;
    /* Slate 700 */
    --surface: #1e293b;
    /* Slate 800 */
    --card-shadow: 0 4px 10px -2px rgba(0, 0, 0, 0.45);
    --card-shadow-lg: 0 18px 30px -12px rgba(0, 0, 0, 0.55);
}

/* ==================================================
   PURPLE THEME: Meditative Violet Overrides
   Targets body.purple (added by Alpine.js theme store)
   ================================================== */
body.purple {
    /* Override CSS variables for Meditative Violet palette */
    --primary: #9F8EC7;
    /* Soft amethyst accent */
    --primary-dark: #8270B4;
    /* Deeper amethyst hover */
    --primary-light: rgba(159, 142, 199, 0.15);
    --text-main: #E6DFF3;
    /* Soft lavender-white text */
    --text-muted: #9B83CB;
    /* Muted lavender */
    --bg-main: #1A1829;
    /* Very deep muted amethyst */
    --border-color: #393657;
    /* Soft violet border */
    --surface: #2B2845;
    /* Card surfaces: soft dark violet */
    --card-shadow: 0 4px 12px -2px rgba(0, 0, 0, 0.5);
    --card-shadow-lg: 0 18px 30px -12px rgba(0, 0, 0, 0.65);
}

:where(body.auth-container) {
    background-color: var(--bg-main) !important;
}

:where(body.auth-container, body.tnt-dashboard) {
    font-family: 'Noto Sans', sans-serif !important;
    color: var(--text-main) !important;
    line-height: 1.5;
}

[x-cloak] {
    display: none !important;
}

:where(body.auth-container, body.tnt-dashboard) .text-black {
    color: var(--text-main) !important;
}

:where(body.auth-container, body.tnt-dashboard) .text-body {
    color: var(--text-muted) !important;
}

/* Auth Layout */
.auth-container {
    background:
        radial-gradient(900px 700px at 18% 20%, rgba(34, 197, 94, 0.10), transparent 62%),
        radial-gradient(1000px 800px at 82% 28%, rgba(56, 189, 248, 0.10), transparent 64%),
        radial-gradient(900px 800px at 55% 90%, rgba(168, 85, 247, 0.08), transparent 62%),
        radial-gradient(1200px 900px at 60% 30%, #0b1026 0%, #020617 62%, #01030a 100%);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

body.tnt-dashboard {
    background-image: radial-gradient(circle at top right, #fcefd6 0%, #f9fafb 45%, #f9fafb 100%);
    min-height: 100vh;
}

body.tnt-dashboard.dark {
    background-image: none !important;
}

body.tnt-dashboard header,
body.tnt-dashboard aside {
    background-color: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(226, 232, 240, 0.7);
}

body.tnt-dashboard.dark header,
body.tnt-dashboard.dark aside {
    background-color: rgba(30, 41, 59, 0.85) !important;
    /* Slate 800 */
    border-color: rgba(51, 65, 85, 0.6) !important;
}

body.tnt-dashboard .shadow-default {
    box-shadow: var(--card-shadow-lg);
    border-radius: 16px !important;
    background-color: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(8px);
}

body.tnt-dashboard .border-stroke {
    border-color: var(--border-color) !important;
}

body.tnt-dashboard.dark .dark\\:border-strokedark {
    border-color: #334155 !important;
    /* Slate 700 */
}

body.tnt-dashboard.dark .shadow-default {
    background-color: rgba(30, 41, 59, 0.7) !important;
    /* Slate 800 */
    backdrop-filter: blur(8px);
}

/* Ensure glass effect inside AJAX popup content even without body class */
.ajax-popup-root .shadow-default {
    box-shadow: var(--card-shadow-lg);
    border-radius: 16px !important;
    background-color: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(8px);
}

.ajax-popup-root .border-stroke {
    border-color: var(--border-color) !important;
}

.ajax-popup-root {
    background-image: radial-gradient(circle at top right, #fcefd6 0%, #f9fafb 45%, #f9fafb 100%);
    padding: 12px;
}

html.dark .ajax-popup-root {
    background-image: none !important;
}

/* TailAdmin header and sidebar fine-tuning */
body.tnt-dashboard .sidebar {
    background-color: rgba(255, 255, 255, 0.90) !important;
    backdrop-filter: blur(10px);
    border-right: 1px solid rgba(226, 232, 240, 0.7) !important;
}

html.dark body.tnt-dashboard .sidebar {
    background-color: rgba(30, 41, 59, 0.80) !important;
    border-right-color: rgba(51, 65, 85, 0.6) !important;
}

body.tnt-dashboard .sticky.top-0 {
    background-color: rgba(255, 255, 255, 0.88) !important;
    backdrop-filter: blur(10px);
}

html.dark body.tnt-dashboard .sticky.top-0 {
    background-color: rgba(30, 41, 59, 0.80) !important;
}

/* Override Tailwind Utilities */
body.tnt-dashboard.dark .bg-boxdark {
    background-color: #1e293b !important;
    /* Slate 800 */
}

body.tnt-dashboard.dark .bg-gray-900 {
    background-color: #0f172a !important;
    /* Slate 900 */
}

body.tnt-dashboard.dark .bg-gray-800 {
    background-color: #1e293b !important;
    /* Slate 800 */
}

body.tnt-dashboard.dark .text-white {
    color: #f1f5f9 !important;
    /* Slate 100 */
}

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

body.tnt-dashboard .text-primary {
    color: var(--primary) !important;
}

body.tnt-dashboard .border-primary {
    border-color: var(--primary) !important;
}

body.tnt-dashboard .hover\\:text-primary:hover {
    color: var(--primary) !important;
}

body.tnt-dashboard .hover\\:bg-primary:hover {
    background-color: var(--primary-dark) !important;
}

body.tnt-dashboard .tnt-branding .auth-logo {
    margin: 0 0 0.5rem;
}

body.tnt-dashboard .tnt-branding .auth-subtitle {
    font-size: 0.75rem;
}

body.tnt-dashboard .tnt-branding .auth-subtitle-secondary {
    font-size: 0.75rem;
    margin-top: 0.1rem;
}

.auth-card {
    background: var(--surface) !important;
    border: 1px solid var(--border-color);
    border-radius: 24px;
    padding: 3rem;
    box-shadow: var(--card-shadow-lg);
    width: 100%;
    max-width: 480px;
    position: relative;
    z-index: 2;
}

.auth-universe {
    position: fixed;
    inset: -10%;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(1400px 900px at 65% 110%, rgba(2, 132, 199, 0.20), transparent 62%),
        radial-gradient(1200px 800px at 10% 15%, rgba(34, 197, 94, 0.18), transparent 60%),
        radial-gradient(1100px 800px at 90% 20%, rgba(168, 85, 247, 0.16), transparent 60%),
        radial-gradient(1200px 900px at 60% 30%, #0b1026 0%, #020617 62%, #01030a 100%);
    filter: saturate(1.15) contrast(1.03);
    will-change: transform;
    transform: translate3d(0, 0, 0);
    animation: authUniverseFloat 16s ease-in-out infinite alternate;
}

.auth-universe::before {
    content: "";
    position: absolute;
    inset: -20%;
    background:
        linear-gradient(115deg,
            rgba(34, 197, 94, 0) 0%,
            rgba(34, 197, 94, 0.38) 12%,
            rgba(34, 197, 94, 0) 26%,
            rgba(56, 189, 248, 0.36) 40%,
            rgba(56, 189, 248, 0) 54%,
            rgba(168, 85, 247, 0.34) 68%,
            rgba(168, 85, 247, 0) 82%,
            rgba(34, 197, 94, 0.22) 92%,
            rgba(34, 197, 94, 0) 100%),
        linear-gradient(65deg,
            rgba(16, 185, 129, 0) 0%,
            rgba(16, 185, 129, 0.26) 18%,
            rgba(16, 185, 129, 0) 34%,
            rgba(14, 165, 233, 0.26) 50%,
            rgba(14, 165, 233, 0) 66%,
            rgba(147, 51, 234, 0.22) 82%,
            rgba(147, 51, 234, 0) 100%);
    background-size: 180% 180%;
    background-position: 10% 30%;
    mix-blend-mode: screen;
    filter: blur(18px) saturate(1.35);
    transform: translate3d(0, 0, 0);
    animation: authAuroraWaves 10s ease-in-out infinite, authAuroraShift 22s ease-in-out infinite;
    opacity: 0.88;
}

.auth-universe::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(1px 1px at 10% 15%, rgba(255, 255, 255, 0.70) 50%, transparent 52%),
        radial-gradient(1px 1px at 25% 40%, rgba(255, 255, 255, 0.55) 50%, transparent 52%),
        radial-gradient(1px 1px at 40% 25%, rgba(255, 255, 255, 0.65) 50%, transparent 52%),
        radial-gradient(1px 1px at 55% 60%, rgba(255, 255, 255, 0.50) 50%, transparent 52%),
        radial-gradient(1px 1px at 70% 35%, rgba(255, 255, 255, 0.70) 50%, transparent 52%),
        radial-gradient(1px 1px at 85% 70%, rgba(255, 255, 255, 0.55) 50%, transparent 52%),
        radial-gradient(1px 1px at 18% 78%, rgba(255, 255, 255, 0.60) 50%, transparent 52%),
        radial-gradient(2px 2px at 62% 18%, rgba(255, 255, 255, 0.35) 50%, transparent 52%);
    background-size: 340px 340px;
    opacity: 0.35;
    animation: authStarDrift 26s linear infinite, authStarTwinkle 4.6s ease-in-out infinite;
    transform: translate3d(0, 0, 0);
}

.auth-version {
    position: fixed;
    left: 16px;
    bottom: 16px;
    z-index: 3;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: rgba(30, 41, 59, 0.72);
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(226, 232, 240, 0.85);
    border-radius: 999px;
    padding: 6px 10px;
    backdrop-filter: blur(10px);
}

html.dark .auth-version {
    color: rgba(241, 245, 249, 0.78);
    background: rgba(15, 23, 42, 0.35);
    border-color: rgba(51, 65, 85, 0.85);
}

@keyframes authUniverseFloat {
    0% {
        transform: translate3d(-0.8%, -0.6%, 0) scale(1.02) rotate(-0.25deg);
    }

    100% {
        transform: translate3d(0.8%, 0.6%, 0) scale(1.05) rotate(0.25deg);
    }
}

@keyframes authAuroraWaves {
    0% {
        transform: translate3d(-2%, -1%, 0) rotate(-2deg) scale(1.02);
    }

    50% {
        transform: translate3d(1.5%, 0.5%, 0) rotate(1deg) scale(1.06);
    }

    100% {
        transform: translate3d(-1%, 1.2%, 0) rotate(2deg) scale(1.03);
    }
}

@keyframes authAuroraShift {
    0% {
        background-position: 10% 30%;
        filter: blur(18px) saturate(1.35) hue-rotate(0deg);
    }

    50% {
        background-position: 80% 60%;
        filter: blur(20px) saturate(1.45) hue-rotate(22deg);
    }

    100% {
        background-position: 20% 40%;
        filter: blur(18px) saturate(1.35) hue-rotate(0deg);
    }
}

@keyframes authStarDrift {
    0% {
        background-position: 0 0;
    }

    100% {
        background-position: 340px 680px;
    }
}

@keyframes authStarTwinkle {

    0%,
    100% {
        opacity: 0.35;
        filter: brightness(1);
    }

    50% {
        opacity: 0.78;
        filter: brightness(1.15);
    }
}

@media (prefers-reduced-motion: reduce) {
    .auth-universe {
        animation: none;
    }

    .auth-universe::before,
    .auth-universe::after {
        animation: none;
    }
}

.auth-header {
    text-align: center;
    margin-bottom: 2.5rem;
}

.auth-logo {
    height: 72px;
    width: auto;
    max-width: 340px;
    display: block;
    margin: 0 auto 0.75rem;
}

.auth-title {
    font-size: 1.875rem;
    font-weight: 700;
    color: var(--text-main);
    letter-spacing: -0.025em;
    margin-bottom: 0.5rem;
}

.auth-subtitle {
    font-size: 1rem;
    color: var(--text-muted);
}

.auth-subtitle-secondary {
    font-size: 0.95rem;
    margin-top: 0.25rem;
}

/* Modern Form Controls */
.form-group {
    margin-bottom: 1.5rem;
}

.form-group label {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-main);
    margin-bottom: 0.5rem;
}

.input-icon-group {
    position: relative;
    display: flex;
    align-items: center;
}

.input-icon-group i {
    position: absolute;
    left: 1rem;
    color: var(--text-muted);
    font-size: 1rem;
    pointer-events: none;
}

.form-control {
    width: 100%;
    padding: 0.75rem 1rem 0.75rem 2.75rem !important;
    background: var(--surface) !important;
    border: 1.5px solid var(--border-color) !important;
    border-radius: 12px !important;
    font-size: 0.95rem !important;
    color: var(--text-main) !important;
    transition: all 0.2s ease;
}

.form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 4px var(--primary-light) !important;
    outline: none;
}

.form-control.is-invalid {
    border-color: var(--danger) !important;
}

/* Modern Buttons */
.btn-auth {
    background: var(--primary) !important;
    color: white !important;
    width: 100%;
    padding: 0.875rem !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    border-radius: 12px !important;
    border: none !important;
    cursor: pointer;
    transition: all 0.2s ease;
    margin-top: 1.5rem;
}

.btn-auth:hover {
    background: var(--primary-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(207, 150, 43, 0.25);
}

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

/* Checkbox & Links */
.auth-footer-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 1rem;
}

.custom-checkbox {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--text-muted);
    cursor: pointer;
}

.custom-checkbox input {
    width: 1.125rem;
    height: 1.125rem;
    border-radius: 4px;
    border: 1.5px solid var(--border-color);
    accent-color: var(--primary);
}

.auth-link {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
}

.auth-link:hover {
    text-decoration: underline;
}

.auth-footer-center {
    margin-top: 1rem;
    text-align: center;
}

.auth-alert {
    border: 1px solid var(--border-color);
    background: var(--surface);
    border-radius: 12px;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
    color: var(--text-main);
    margin-bottom: 1rem;
}

.auth-alert-success {
    border-color: rgba(16, 185, 129, 0.35);
    background: rgba(16, 185, 129, 0.08);
}

.auth-alert-error {
    border-color: rgba(239, 68, 68, 0.35);
    background: rgba(239, 68, 68, 0.08);
}

/* Stat Cards - Modern Enterprise Style */
.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1.5rem;
    padding: 1rem 0;
}

.stat-card {
    background: var(--surface);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: all 0.2s ease;
    text-decoration: none !important;
}

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--card-shadow-lg);
    border-color: var(--primary);
}

.stat-icon-wrapper {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    font-size: 1.25rem;
}

.stat-card.primary .stat-icon-wrapper {
    background: #eff6ff;
    color: var(--info);
}

.stat-card.success .stat-icon-wrapper {
    background: #ecfdf5;
    color: var(--success);
}

.stat-card.danger .stat-icon-wrapper {
    background: #fef2f2;
    color: var(--danger);
}

.stat-card.warning .stat-icon-wrapper {
    background: #fffbeb;
    color: var(--warning);
}

.stat-card.info .stat-icon-wrapper {
    background: var(--primary-light);
    color: var(--primary);
}

.stat-label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-muted);
    margin-bottom: 0.25rem;
}

.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-main);
}

.stat-footer {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-color);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--primary);
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* Navigation - Modern Enterprise Style */
.navbar {
    background: var(--surface) !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding: 0.75rem 0;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.navbar-brand {
    display: flex;
    flex-direction: column;
    padding: 0;
}

.navbar-brand img {
    height: 56px;
    width: auto;
    object-fit: contain;
}

.brand-tagline {
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}

.top--links {
    gap: 0.5rem;
}

.top--links>li>a {
    color: var(--text-main) !important;
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.625rem 1rem !important;
    border-radius: 8px;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.top--links>li>a:hover {
    background: var(--bg-main) !important;
    color: var(--primary) !important;
}

.top--links .dropdown-menu {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: var(--card-shadow-lg);
    padding: 0.5rem;
    margin-top: 0.5rem;
}

.top--links .dropdown-item {
    border-radius: 6px;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: var(--text-main);
    transition: all 0.2s ease;
}

.top--links .dropdown-item:hover {
    background: var(--primary-light);
    color: var(--primary);
}

/* Glass Utility (legacy support) */
.glass-effect {
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 16px;
}

body.tnt-dashboard .menu-item {
    border-radius: 12px;
    transition: all 0.2s ease;
}

body.tnt-dashboard .menu-item-active {
    background-color: rgba(255, 255, 255, 0.9) !important;
    color: var(--primary) !important;
    border: 1px solid rgba(226, 232, 240, 0.7) !important;
    backdrop-filter: blur(8px);
    box-shadow: var(--card-shadow);
}

html.dark body.tnt-dashboard .menu-item-active {
    background-color: rgba(30, 41, 59, 0.8) !important;
    border-color: rgba(51, 65, 85, 0.6) !important;
}

body.tnt-dashboard .menu-item-inactive:hover {
    background-color: rgba(255, 255, 255, 0.75) !important;
    backdrop-filter: blur(6px);
}

body.tnt-dashboard .menu-dropdown-item {
    border-radius: 10px;
    transition: all 0.2s ease;
}

body.tnt-dashboard .menu-dropdown-item-active {
    background-color: rgba(255, 255, 255, 0.9) !important;
    color: var(--primary) !important;
    border: 1px solid rgba(226, 232, 240, 0.7) !important;
    backdrop-filter: blur(8px);
    box-shadow: var(--card-shadow);
}

html.dark body.tnt-dashboard .menu-dropdown-item-active {
    background-color: rgba(30, 41, 59, 0.8) !important;
    border-color: rgba(51, 65, 85, 0.6) !important;
}

body.tnt-dashboard .menu-dropdown-item-inactive:hover {
    background-color: rgba(255, 255, 255, 0.75) !important;
}

body.tnt-dashboard .rounded-lg.shadow-sm.border {
    background-color: rgba(255, 255, 255, 0.92) !important;
    backdrop-filter: blur(8px);
    border-color: var(--border-color) !important;
    box-shadow: var(--card-shadow-lg) !important;
}

html.dark body.tnt-dashboard .rounded-lg.shadow-sm.border {
    background-color: rgba(30, 41, 59, 0.75) !important;
    border-color: rgba(51, 65, 85, 0.6) !important;
}

/* ==================================================
   PURPLE THEME: All Inner Page Component Overrides
   ================================================== */

/* Background */
body.tnt-dashboard.purple {
    background-color: #1A1829;
}

/* Sidebar */
body.tnt-dashboard.purple .sidebar {
    background-color: rgba(29, 26, 48, 0.90) !important;
    border-right-color: rgba(57, 54, 87, 0.7) !important;
}

/* Sticky Header */
body.tnt-dashboard.purple .sticky.top-0 {
    background-color: rgba(27, 24, 41, 0.88) !important;
    backdrop-filter: blur(10px);
}

/* Cards / Panels with .shadow-default */
body.tnt-dashboard.purple .shadow-default {
    background-color: rgba(43, 40, 69, 0.85) !important;
    backdrop-filter: blur(8px);
    box-shadow: 0 18px 30px -12px rgba(0, 0, 0, 0.65);
}

/* Cards / Panels with .bg-boxdark */
body.tnt-dashboard.purple .dark\:bg-boxdark {
    background-color: #2B2845 !important;
}

/* Header/Aside border */
body.tnt-dashboard.purple header,
body.tnt-dashboard.purple aside {
    background-color: rgba(29, 26, 48, 0.9) !important;
    border-color: rgba(57, 54, 87, 0.6) !important;
}

/* Borders */
body.tnt-dashboard.purple .dark\:border-strokedark {
    border-color: #393657 !important;
}

body.tnt-dashboard.purple .border-stroke,
body.tnt-dashboard.purple .border-strokedark {
    border-color: #393657 !important;
}

/* DataTables header rows (meta-4) */
body.tnt-dashboard.purple .dark\:bg-meta-4 {
    background-color: #25223D !important;
}

/* Form controls and inputs */
body.tnt-dashboard.purple input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]):not([type="button"]),
body.tnt-dashboard.purple select,
body.tnt-dashboard.purple textarea {
    background-color: #201D33 !important;
    border-color: #393657 !important;
    color: #E6DFF3 !important;
}

body.tnt-dashboard.purple input::placeholder,
body.tnt-dashboard.purple textarea::placeholder {
    color: #9B83CB !important;
}

/* Primary background-colored elements in purple theme */
body.tnt-dashboard.purple .bg-primary {
    background-color: var(--primary) !important;
}

body.tnt-dashboard.purple .text-primary {
    color: var(--primary) !important;
}

body.tnt-dashboard.purple .border-primary {
    border-color: var(--primary) !important;
}

body.tnt-dashboard.purple .hover\:text-primary:hover {
    color: var(--primary) !important;
}

body.tnt-dashboard.purple .hover\:bg-primary:hover {
    background-color: var(--primary-dark) !important;
}

/* Text */
body.tnt-dashboard.purple .dark\:text-white {
    color: #E6DFF3 !important;
}

body.tnt-dashboard.purple .text-white {
    color: #E6DFF3 !important;
}

body.tnt-dashboard.purple .dark\:text-bodydark {
    color: #B7A4DA !important;
}

/* Active menu item */
body.tnt-dashboard.purple .menu-item-active {
    background-color: rgba(57, 54, 87, 0.7) !important;
    color: var(--primary) !important;
    border-color: rgba(57, 54, 87, 0.8) !important;
}

body.tnt-dashboard.purple .menu-item-inactive:hover {
    background-color: rgba(57, 54, 87, 0.4) !important;
}

body.tnt-dashboard.purple .menu-dropdown-item-active {
    background-color: rgba(57, 54, 87, 0.7) !important;
    color: var(--primary) !important;
    border-color: rgba(57, 54, 87, 0.8) !important;
}

body.tnt-dashboard.purple .menu-dropdown-item-inactive:hover {
    background-color: rgba(57, 54, 87, 0.35) !important;
}

/* Rounded/bordered cards */
body.tnt-dashboard.purple .rounded-lg.shadow-sm.border {
    background-color: rgba(43, 40, 69, 0.8) !important;
    border-color: rgba(57, 54, 87, 0.6) !important;
}

/* AJAX popup forms */
body.purple .ajax-popup-root .shadow-default {
    background-color: rgba(43, 40, 69, 0.92) !important;
}

body.purple .ajax-popup-root {
    background-color: #1A1829 !important;
    background-image: none !important;
}

/* bg-gray-900 and boxdark overrides */
body.tnt-dashboard.purple .dark\:bg-gray-900 {
    background-color: #221F36 !important;
}

body.tnt-dashboard.purple .bg-gray-2,
body.tnt-dashboard.purple .dark\:bg-boxdark-2 {
    background-color: #201D33 !important;
}