﻿/* ============================================================
   VynexTrading â€“ Design System
   Gold / Amber on Deep Dark Theme
   Fonts: Orbitron (headings) Â· Inter (body) Â· JetBrains Mono (numbers)
   ============================================================ */

/* â”€â”€â”€ Design Tokens â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
:root {
    /* Primary Gold */
    --primary:          #FFD700;
    --primary-hover:    #FFC107;
    --primary-muted:    rgba(255, 215, 0, 0.12);
    --primary-border:   rgba(255, 215, 0, 0.25);
    --primary-glow:     rgba(255, 215, 0, 0.15);
    --grad-primary:     linear-gradient(135deg, #FFD700 0%, #FFA500 100%);
    --grad-primary-text:linear-gradient(90deg, #FFD700, #FFA500);

    /* Backgrounds */
    --bg:               #0B0E11;
    --surface:          #1E2329;
    --surface-2:        #2B3139;
    --surface-3:        #14181E;

    /* Borders */
    --border:           #2B3139;
    --border-light:     rgba(255, 215, 0, 0.15);

    /* Text */
    --text-primary:     #EAECEF;
    --text-secondary:   #848E9C;
    --text-muted:       #5E6673;
    --text-inverse:     #0B0E11;

    /* Semantic */
    --success:          #0ECB81;
    --danger:           #F6465D;
    --info:             #3B82F6;
    --warning:          #FFD700;

    /* Layout */
    --sidebar-width:    256px;
    --topnav-height:    64px;
    --radius:           0.75rem;
    --radius-lg:        1rem;
    --radius-sm:        0.5rem;

    /* Shadows */
    --shadow-card:      0 4px 24px rgba(0,0,0,0.4);
    --shadow-gold:      0 0 20px rgba(255,215,0,0.2);
}

/* â”€â”€â”€ Reset & Base â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    background-color: var(--bg);
    background-image:
        radial-gradient(ellipse at 20% 0%,   rgba(255,215,0,0.04) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 100%,  rgba(255,165,0,0.03) 0%, transparent 55%);
    color: var(--text-primary);
    font-family: 'Inter', 'Segoe UI', sans-serif;
    font-size: 0.9rem;
    line-height: 1.6;
    min-height: 100vh;
}

/* Typography */
h1, h2, h3, h4, h5, h6,
.heading, .stat-value, .auth-title {
    font-family: 'Orbitron', 'Inter', sans-serif;
    font-weight: 700;
    letter-spacing: 0.03em;
}

/* Monospace for prices / numbers */
.mono, .price, .amount, .address,
.font-mono, .badge-amount, code {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 0.9em;
    letter-spacing: 0.02em;
}

a { color: var(--primary); text-decoration: none; transition: color 0.15s; }
a:hover { color: var(--primary-hover); }

/* â”€â”€â”€ Scrollbar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface-2); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--primary); }

/* â”€â”€â”€ Sidebar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.sidebar {
    position: fixed;
    top: 0; left: 0;
    width: var(--sidebar-width);
    height: 100vh;
    background: var(--surface);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    z-index: 1040;
    transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
}

.sidebar-brand {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 1.5rem 1.25rem;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
    position: relative;
}

.sidebar-logo { height: 52px; width: auto; object-fit: contain; transition: transform 0.2s; flex-shrink: 0; }
.sidebar-logo:hover { transform: scale(1.05); }

/* Brand text "VYNEX" beside logo */
.sidebar-brand-text {
    font-family: 'Orbitron', 'Segoe UI', sans-serif;
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    line-height: 1.1;
    display: flex;
    flex-direction: column;
    background: var(--grad-primary-text, linear-gradient(135deg,#f59e0b,#ef4444));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    white-space: nowrap;
}
.sidebar-brand-text small {
    font-size: 0.6rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    opacity: 0.75;
    background: none;
    -webkit-text-fill-color: var(--text-secondary, #9ca3af);
    color: var(--text-secondary, #9ca3af);
    text-transform: uppercase;
}
/* Keep brand link horizontal */
.sidebar-brand a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    gap: 0.65rem;
    text-decoration: none;
}

.sidebar-close-btn {
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: 1.1rem;
    cursor: pointer;
    padding: 0.25rem;
    border-radius: 0.375rem;
    transition: color 0.15s;
}
.sidebar-close-btn:hover { color: var(--text-primary); }

.sidebar-nav {
    flex: 1;
    padding: 1rem 0.875rem;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Group label separator */
.sidebar-section-label {
    font-family: 'Orbitron', sans-serif;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-muted);
    padding: 1rem 0.85rem 0.35rem;
    margin-top: 0.25rem;
}

.sidebar-link,
.sidebar-group-btn {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: 0.75rem;
    color: var(--text-secondary);
    font-size: 0.95rem;
    font-weight: 500;
    transition: background 0.15s, color 0.15s;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    line-height: 1.3;
}

.sidebar-link span,
.sidebar-group-btn > span:first-of-type {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.sidebar-link i,
.sidebar-group-btn i { font-size: 1.1rem; flex-shrink: 0; }

.sidebar-link:hover,
.sidebar-group-btn:hover {
    background: rgba(255,255,255,0.04);
    color: #F59E0B;
}

.sidebar-link.active {
    background: linear-gradient(90deg, #FBBF24 0%, #F59E0B 100%);
    color: #000 !important;
    font-weight: 700;
    border-left: none;
    padding-left: 1rem;
    box-shadow: 0 4px 18px rgba(251,191,36,0.35);
    transform: scale(1.02);
}

.sidebar-group { margin-bottom: 4px; }

.sidebar-group-btn {
    justify-content: space-between;
    margin-bottom: 1px;
}

.sidebar-group-btn:not(.collapsed) { color: #F59E0B; }

.sidebar-chevron {
    transition: transform 0.25s ease, color 0.2s;
    font-size: 0.6rem;
    margin-left: auto;
    color: rgba(255,255,255,0.3);
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    background: rgba(255,255,255,0.05);
}
.sidebar-group-btn:hover .sidebar-chevron {
    background: rgba(245,158,11,0.15);
    color: #F59E0B;
}
.sidebar-group-btn:not(.collapsed) .sidebar-chevron {
    transform: rotate(180deg);
    color: #FBBF24;
    background: rgba(251,191,36,0.12);
}

.sidebar-sub-nav {
    padding-left: 0.75rem;
    padding-top: 4px;
    padding-bottom: 4px;
    border-left: 2px solid rgba(100,100,120,0.4);
    margin-left: 1.5rem;
    margin-bottom: 4px;
}

.sidebar-sub-link {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.55rem 0.8rem;
    border-radius: 0.5rem;
    color: var(--text-secondary);
    font-size: 0.88rem;
    font-weight: 500;
    transition: background 0.15s, color 0.15s, transform 0.15s;
}

.sidebar-sub-link i { font-size: 0.88rem; flex-shrink: 0; }
.sidebar-sub-link span {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}

.sidebar-sub-link:hover {
    background: rgba(255,215,0,0.06);
    color: #F59E0B;
    transform: translateX(3px);
}

.sidebar-sub-link.active {
    background: linear-gradient(90deg, #FBBF24 0%, #F59E0B 100%);
    color: #000 !important;
    font-weight: 700;
    box-shadow: 0 2px 10px rgba(251,191,36,0.28);
}

.sidebar-footer {
    padding: 0.75rem;
    border-top: 1px solid var(--border);
    flex-shrink: 0;
}
.sidebar-footer .sidebar-link {
    background: linear-gradient(135deg, #EF4444 0%, #DC2626 100%) !important;
    color: #fff !important;
    border-radius: 0.75rem;
    font-weight: 700;
    justify-content: center;
    gap: 0.6rem;
    box-shadow: 0 4px 12px rgba(220,38,38,0.35);
    transition: box-shadow 0.2s, opacity 0.2s;
}
.sidebar-footer .sidebar-link:hover {
    background: linear-gradient(135deg, #DC2626 0%, #B91C1C 100%) !important;
    color: #fff !important;
    box-shadow: 0 6px 20px rgba(220,38,38,0.45);
}
.sidebar-footer .sidebar-link {
    background: linear-gradient(135deg, #EF4444 0%, #DC2626 100%);
    color: #fff !important;
    border-radius: 0.75rem;
    font-weight: 700;
    justify-content: center;
    gap: 0.6rem;
    box-shadow: 0 4px 12px rgba(220,38,38,0.35);
    transition: box-shadow 0.2s, opacity 0.2s;
}
.sidebar-footer .sidebar-link:hover {
    background: linear-gradient(135deg, #DC2626 0%, #B91C1C 100%);
    color: #fff !important;
    box-shadow: 0 6px 20px rgba(220,38,38,0.45);
    opacity: 0.95;
}

/* Mobile overlay */
.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    backdrop-filter: blur(2px);
    z-index: 1039;
}

/* â”€â”€â”€ Top Navigation â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.topnav {
    position: fixed;
    top: 0;
    left: var(--sidebar-width);
    right: 0;
    height: var(--topnav-height);
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    padding: 0 1.25rem;
    z-index: 1030;
    gap: 1rem;
}

.topnav-hamburger {
    background: none;
    border: none;
    color: var(--text-primary);
    font-size: 1.4rem;
    cursor: pointer;
    line-height: 1;
    padding: 0.25rem;
    border-radius: var(--radius-sm);
    transition: color 0.15s;
}
.topnav-hamburger:hover { color: var(--primary); }

.topnav-user-btn {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    padding: 0.4rem 0.9rem 0.4rem 0.5rem;
    transition: border-color 0.15s, background 0.15s;
    cursor: pointer;
}
.topnav-user-btn:hover { border-color: rgba(245,158,11,0.5); background: rgba(255,215,0,0.05); color: var(--text-primary); }
.topnav-user-btn::after { display: none !important; }  /* hide bs dropdown arrow */

.user-avatar {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #F59E0B 0%, #EA580C 100%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: #fff;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(234,88,12,0.4);
}

.topnav-dropdown {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
    min-width: 220px;
    overflow: hidden;
}

.topnav-dropdown .dropdown-item {
    color: var(--text-secondary);
    font-size: 0.875rem;
    padding: 0.6rem 1.1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    transition: background 0.12s, color 0.12s;
}
.topnav-dropdown .dropdown-item:hover { background: var(--primary-muted); color: var(--primary); }
.topnav-dropdown .dropdown-item.text-danger:hover { background: rgba(246,70,93,0.1); color: #F6465D; }
.topnav-dropdown .dropdown-divider { border-color: var(--border); margin: 0.25rem 0; }

/* â”€â”€â”€ Main Layout â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.main-content {
    flex: 1;
    min-width: 0;
    margin-left: var(--sidebar-width);
    padding-top: var(--topnav-height);
    min-height: 100vh;
}

.page-body {
    padding: 1.75rem;
    min-height: calc(100vh - var(--topnav-height));
}

/* â”€â”€â”€ Page Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.page-header {
    margin-bottom: 1.75rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.page-header h4 {
    font-family: 'Orbitron', sans-serif;
    font-weight: 700;
    font-size: 1.15rem;
    color: var(--text-primary);
    margin: 0;
    letter-spacing: 0.05em;
}

.page-header .breadcrumb { margin: 0; }
.page-header .breadcrumb-item { font-size: 0.78rem; }
.page-header .breadcrumb-item a { color: var(--text-secondary); }
.page-header .breadcrumb-item a:hover { color: var(--primary); }
.page-header .breadcrumb-item.active { color: var(--primary); }
.page-header .breadcrumb-item + .breadcrumb-item::before { color: var(--text-muted); }

/* â”€â”€â”€ Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.card-dark {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    transition: border-color 0.2s;
}

.card-dark:hover { border-color: var(--border-light); }

.card-header-dark {
    background: rgba(255,255,255,0.02);
    border-bottom: 1px solid var(--border);
    padding: 0.9rem 1.25rem;
    font-family: 'Orbitron', sans-serif;
    font-weight: 600;
    font-size: 0.8rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

.card-dark .card-body { padding: 1.25rem; }
.card-dark .card-header { 
    background: rgba(255,255,255,0.02);
    border-bottom: 1px solid var(--border);
    padding: 0.9rem 1.25rem;
    font-weight: 600;
}

/* Gold accent card */
.card-gold {
    background: linear-gradient(135deg, rgba(255,215,0,0.08) 0%, rgba(255,165,0,0.04) 100%);
    border: 1px solid var(--primary-border);
    border-radius: var(--radius);
}

/* â”€â”€â”€ Stat Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    position: relative;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--grad-primary);
    opacity: 0;
    transition: opacity 0.2s;
}

.stat-card:hover {
    border-color: var(--primary-border);
    box-shadow: 0 8px 32px rgba(255,215,0,0.08);
    transform: translateY(-2px);
}

.stat-card:hover::before { opacity: 1; }

.stat-card .stat-icon {
    width: 44px; height: 44px;
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem;
    flex-shrink: 0;
}

.stat-card .stat-value {
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.2;
    margin-top: 0.5rem;
    letter-spacing: 0.02em;
}

.stat-card .stat-label {
    font-size: 0.75rem;
    color: var(--text-secondary);
    margin-top: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* â”€â”€â”€ Tables â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.table-dark-custom {
    --bs-table-bg: transparent;
    --bs-table-border-color: var(--border);
    --bs-table-color: var(--text-primary);
    --bs-table-striped-bg: rgba(255,255,255,0.02);
    --bs-table-hover-bg: rgba(255,215,0,0.04);
    font-size: 0.84rem;
}

.table-dark-custom thead th {
    background: var(--surface-2);
    color: var(--text-secondary);
    font-family: 'Orbitron', sans-serif;
    font-weight: 600;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
    border-bottom: 1px solid var(--primary-border);
    padding: 0.55rem 0.85rem;
}

.table-dark-custom td {
    vertical-align: middle;
    border-color: var(--border);
    padding: 0.5rem 0.85rem;
    color: var(--text-primary);
    white-space: nowrap;
}

/* ── Admin .table-hover compact ─────────────────────────────────────────── */
.table.table-hover > thead > tr > th {
    white-space: nowrap;
    padding: 0.55rem 0.85rem;
    font-size: 0.75rem;
    vertical-align: middle;
}
.table.table-hover > tbody > tr > td {
    padding: 0.5rem 0.85rem;
    vertical-align: middle;
    font-size: 0.82rem;
}

.table-dark-custom tbody tr:hover { background: rgba(255,215,0,0.03); }

/* Numeric cells */
.table-dark-custom td.amount,
.table-dark-custom td.price,
.table-dark-custom td.mono {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.82rem;
}

/* â”€â”€â”€ Forms â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-control-dark,
.form-select-dark,
.form-select.form-control-dark {
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.form-control-dark:focus,
.form-select-dark:focus {
    background: var(--surface-2);
    border-color: var(--primary);
    color: var(--text-primary);
    box-shadow: 0 0 0 3px rgba(255,215,0,0.12);
    outline: none;
}

.form-control-dark::placeholder { color: var(--text-muted); }

.form-label { 
    color: var(--text-secondary); 
    font-size: 0.8rem; 
    font-weight: 500; 
    margin-bottom: 0.4rem;
    letter-spacing: 0.02em;
}

.form-text { color: var(--text-muted); font-size: 0.75rem; }

.input-group-text {
    background: var(--surface-2);
    border-color: var(--border);
    color: var(--text-secondary);
}

/* â”€â”€â”€ Buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn-accent,
.btn-gold {
    background: var(--grad-primary);
    border: none;
    color: var(--text-inverse);
    font-family: 'Orbitron', sans-serif;
    font-weight: 700;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    border-radius: var(--radius-sm);
    padding: 0.55rem 1.25rem;
    transition: filter 0.15s, transform 0.1s, box-shadow 0.15s;
    cursor: pointer;
}

.btn-accent:hover,
.btn-gold:hover {
    filter: brightness(1.1);
    box-shadow: 0 4px 16px rgba(255,215,0,0.3);
    color: var(--text-inverse);
    transform: translateY(-1px);
}

.btn-accent:active,
.btn-gold:active { transform: translateY(0); filter: brightness(0.95); }

/* Outline gold */
.btn-outline-accent,
.btn-outline-gold {
    border: 1px solid var(--primary);
    color: var(--primary);
    background: transparent;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.84rem;
    transition: background 0.15s, box-shadow 0.15s;
}
.btn-outline-accent:hover,
.btn-outline-gold:hover {
    background: var(--primary-muted);
    color: var(--primary);
    box-shadow: 0 0 12px rgba(255,215,0,0.15);
    border-color: var(--primary);
}

/* â”€â”€â”€ Badges â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge { font-weight: 500; letter-spacing: 0.03em; font-size: 0.72rem; }

.badge-success { background: rgba(14,203,129,0.12); color: #0ECB81; border: 1px solid rgba(14,203,129,0.25); }
.badge-danger  { background: rgba(246,70,93,0.12);  color: #F6465D; border: 1px solid rgba(246,70,93,0.25); }
.badge-warning { background: rgba(255,215,0,0.12);  color: var(--primary); border: 1px solid var(--primary-border); }
.badge-info    { background: rgba(59,130,246,0.12); color: #3B82F6; border: 1px solid rgba(59,130,246,0.25); }

/* Override Bootstrap bg- badges */
.bg-success { background-color: rgba(14,203,129,0.85) !important; }
.bg-danger  { background-color: rgba(246,70,93,0.85)  !important; }
.bg-warning { background-color: rgba(255,215,0,0.85)  !important; color: #0B0E11 !important; }
.bg-info    { background-color: rgba(59,130,246,0.85) !important; }
.bg-secondary { background-color: rgba(132,142,156,0.25) !important; color: #848E9C !important; }

/* Gold badge */
.badge-gold {
    background: var(--grad-primary);
    color: var(--text-inverse);
    font-family: 'Orbitron', sans-serif;
    font-size: 0.65rem;
    letter-spacing: 0.08em;
    padding: 0.3rem 0.65rem;
    border-radius: 2rem;
}

/* â”€â”€â”€ Auth Pages â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.auth-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg);
    padding: 1.5rem;
    position: relative;
    overflow: hidden;
}

.auth-wrapper::before {
    content: '';
    position: absolute;
    top: -30%;
    left: 50%;
    transform: translateX(-50%);
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(255,215,0,0.06) 0%, transparent 65%);
    pointer-events: none;
}

.auth-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    width: 100%;
    max-width: 460px;
    padding: 2.5rem 2rem;
    box-shadow: 0 24px 64px rgba(0,0,0,0.5), 0 0 40px rgba(255,215,0,0.05);
    position: relative;
    z-index: 1;
}

.auth-logo { height: 50px; width: auto; }

.auth-title {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.3rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    background: var(--grad-primary-text);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* â”€â”€â”€ Referral Box â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.referral-box {
    background: rgba(255,215,0,0.05);
    border: 1px dashed var(--primary-border);
    border-radius: var(--radius-sm);
    padding: 0.85rem 1rem;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.8rem;
    word-break: break-all;
    color: var(--text-secondary);
}

/* â”€â”€â”€ Filter Panel â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.filter-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
    margin-bottom: 1rem;
}

/* â”€â”€â”€ Pagination â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pagination .page-link {
    background: var(--surface-2);
    border-color: var(--border);
    color: var(--text-secondary);
    font-size: 0.82rem;
    transition: background 0.15s, color 0.15s;
}

.pagination .page-link:hover { background: var(--primary-muted); color: var(--primary); border-color: var(--primary-border); }
.pagination .page-item.active .page-link { background: var(--grad-primary); border-color: var(--primary); color: var(--text-inverse); font-weight: 600; }
.pagination .page-item.disabled .page-link { background: transparent; color: var(--text-muted); opacity: 0.5; }

/* â”€â”€â”€ Alerts â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.alert { border-radius: var(--radius-sm); border: none; font-size: 0.875rem; }
.alert-success { background: rgba(14,203,129,0.1);  color: #0ECB81; border: 1px solid rgba(14,203,129,0.2); }
.alert-danger  { background: rgba(246,70,93,0.1);   color: #F6465D; border: 1px solid rgba(246,70,93,0.2); }
.alert-warning { background: rgba(255,215,0,0.08);  color: var(--primary); border: 1px solid var(--primary-border); }
.alert-info    { background: rgba(59,130,246,0.1);  color: #3B82F6; border: 1px solid rgba(59,130,246,0.2); }

/* â”€â”€â”€ Utility â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.text-gold    { color: var(--primary) !important; }
.text-success { color: var(--success) !important; }
.text-danger  { color: var(--danger)  !important; }
.text-info    { color: var(--info)    !important; }
.text-muted   { color: var(--text-secondary) !important; }
.text-dimmed  { color: var(--text-muted) !important; }

.bg-surface   { background: var(--surface)   !important; }
.bg-surface-2 { background: var(--surface-2) !important; }

.border-gold  { border-color: var(--primary-border) !important; }

/* Gold gradient text helper */
.gradient-text {
    background: var(--grad-primary-text);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Spinner */
.spinner-accent { color: var(--primary); }

/* ── VNX Toast Notifications ── */
.vnx-toast-container {
    position: fixed;
    top: 1.25rem;
    right: 1.25rem;
    z-index: 99999;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    pointer-events: none;
    max-width: 360px;
    width: calc(100% - 2.5rem);
}
.vnx-toast {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.85rem 1rem;
    border-radius: 0.75rem;
    border: 1.5px solid transparent;
    background: var(--surface);
    box-shadow: 0 8px 28px rgba(0,0,0,0.35), 0 2px 8px rgba(0,0,0,0.2);
    pointer-events: all;
    animation: vnxToastIn 0.32s cubic-bezier(.21,1.02,.73,1) forwards;
    font-size: 0.86rem;
    font-weight: 500;
    color: var(--text-primary);
    position: relative;
    overflow: hidden;
}
.vnx-toast::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    width: 100%;
    transform-origin: left;
    animation: vnxToastBar var(--toast-dur, 4s) linear forwards;
}
.vnx-toast.toast-success { border-color: rgba(14,203,129,0.3); }
.vnx-toast.toast-success .vnx-toast-icon { color: #0ECB81; }
.vnx-toast.toast-success::after { background: #0ECB81; }
.vnx-toast.toast-danger,
.vnx-toast.toast-error  { border-color: rgba(246,70,93,0.3); }
.vnx-toast.toast-danger .vnx-toast-icon,
.vnx-toast.toast-error  .vnx-toast-icon { color: #F6465D; }
.vnx-toast.toast-danger::after,
.vnx-toast.toast-error::after  { background: #F6465D; }
.vnx-toast.toast-warning { border-color: rgba(255,193,7,0.3); }
.vnx-toast.toast-warning .vnx-toast-icon { color: #FFC107; }
.vnx-toast.toast-warning::after { background: #FFC107; }
.vnx-toast.toast-info { border-color: rgba(13,202,240,0.3); }
.vnx-toast.toast-info .vnx-toast-icon { color: #0DCAF0; }
.vnx-toast.toast-info::after { background: #0DCAF0; }
.vnx-toast-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: 1px; }
.vnx-toast-body { flex: 1; line-height: 1.4; }
.vnx-toast-close {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0;
    font-size: 0.85rem;
    flex-shrink: 0;
    line-height: 1;
    transition: color 0.2s;
}
.vnx-toast-close:hover { color: var(--text-primary); }
.vnx-toast.toast-hiding {
    animation: vnxToastOut 0.28s ease forwards;
}
@keyframes vnxToastIn {
    from { opacity: 0; transform: translateX(60px) scale(0.92); }
    to   { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes vnxToastOut {
    from { opacity: 1; transform: translateX(0) scale(1); }
    to   { opacity: 0; transform: translateX(60px) scale(0.9); }
}
@keyframes vnxToastBar {
    from { transform: scaleX(1); }
    to   { transform: scaleX(0); }
}

/* â”€â”€â”€ Tree Container â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tree-container {
    overflow: auto;
    min-height: 400px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem;
}

/* â”€â”€â”€ Section Divider â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.section-title {
    font-family: 'Orbitron', sans-serif;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.section-title::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}

/* â”€â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 991.98px) {
    .sidebar { transform: translateX(-100%); }
    .sidebar.open { transform: translateX(0); }
    .sidebar-overlay.open { display: block; }
    .topnav { left: 0; }
    .main-content { margin-left: 0; }
}

@media (max-width: 767.98px) {
    .page-body { padding: 1rem; }
    .stat-card { padding: 1rem; }
    .stat-card .stat-value { font-size: 1.1rem; }
}

@media (max-width: 575.98px) {
    .auth-card { padding: 1.75rem 1.25rem; }
    .page-header h4 { font-size: 1rem; }
}


/* ═══════════════════════════════════════════════════════════════
   LIGHT THEME OVERRIDES
   ═══════════════════════════════════════════════════════════════ */
[data-theme="light"] {
    --bg:               #F0F3FA;
    --surface:          #FFFFFF;
    --surface-2:        #F2F4F8;
    --surface-3:        #E8EBF2;
    --border:           #DDE2EE;
    --border-light:     rgba(200,168,0,0.35);
    --text-primary:     #1A202C;
    --text-secondary:   #4A5568;
    --text-muted:       #9CA3AF;
    --text-inverse:     #FFFFFF;
    --primary:          #C8A000;
    --primary-hover:    #B89000;
    --primary-muted:    rgba(200,160,0,0.1);
    --primary-border:   rgba(200,160,0,0.3);
    --primary-glow:     rgba(200,160,0,0.12);
    --grad-primary:     linear-gradient(135deg,#C8A000 0%,#A07800 100%);
    --grad-primary-text:linear-gradient(90deg,#C8A000,#A07800);
    --shadow-card:      0 4px 24px rgba(0,0,0,0.08);
}

[data-theme="light"] body {
    background-color: var(--bg);
    background-image:
        radial-gradient(ellipse at 20% 0%,  rgba(200,160,0,0.06) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 100%, rgba(180,140,0,0.04) 0%, transparent 55%);
}

[data-theme="light"] .card-dark { box-shadow: 0 1px 8px rgba(0,0,0,0.06); }
[data-theme="light"] .table-dark-custom { border-color: var(--border); }
[data-theme="light"] .table-dark-custom thead th { background: var(--surface-2); }
[data-theme="light"] .sidebar { box-shadow: 2px 0 20px rgba(0,0,0,0.08); }
[data-theme="light"] .topnav  { box-shadow: 0 1px 10px rgba(0,0,0,0.06); }

/* Sidebar chevron – invisible on light bg fix */
[data-theme="light"] .sidebar-chevron {
    color: var(--text-secondary);
    background: rgba(0,0,0,0.06);
}
[data-theme="light"] .sidebar-group-btn:hover .sidebar-chevron {
    color: #F59E0B;
    background: rgba(245,158,11,0.15);
}
[data-theme="light"] .sidebar-group-btn:not(.collapsed) .sidebar-chevron {
    color: #D97706;
    background: rgba(251,191,36,0.15);
}

/* rpt-table – dark-bg colours fix for light mode */
[data-theme="light"] .rpt-table thead tr {
    border-bottom-color: var(--border);
    background: var(--surface-2);
}
[data-theme="light"] .rpt-table tbody tr {
    border-bottom-color: var(--border);
}
[data-theme="light"] .rpt-table tbody tr:hover { background: rgba(0,0,0,0.03); }
[data-theme="light"] .rpt-pagination-bar { border-top-color: var(--border); }
[data-theme="light"] .rpt-input option   { background: var(--surface-1); }

/* ── Light theme: hex dark background values ── */
[data-theme="light"] [style*="background:#1f2937"],
[data-theme="light"] [style*="background: #1f2937"] {
    background-color: var(--surface) !important;
    background-image: none !important;
    color: var(--text-primary) !important;
    border-color: var(--border) !important;
}
[data-theme="light"] [style*="background:#111827"],
[data-theme="light"] [style*="background: #111827"],
[data-theme="light"] [style*="background:#0B0E11"],
[data-theme="light"] [style*="background:#0b0e11"] {
    background-color: var(--surface) !important;
    background-image: none !important;
}
[data-theme="light"] [style*="background:#0d0f14"],
[data-theme="light"] [style*="background:#131720"] {
    background-color: var(--surface-2) !important;
    background-image: none !important;
}
/* Dark border hex overrides */
[data-theme="light"] [style*="border:1px solid #374151"],
[data-theme="light"] [style*="border: 1px solid #374151"],
[data-theme="light"] [style*="border-color:#374151"],
[data-theme="light"] [style*="border-color: #374151"] {
    border-color: var(--border) !important;
}

/* ── Light theme: Bootstrap class overrides ── */
[data-theme="light"] .text-white { color: var(--text-primary) !important; }
[data-theme="light"] .text-white-50 { color: var(--text-secondary) !important; }
[data-theme="light"] .bg-dark { background-color: var(--surface-2) !important; }
[data-theme="light"] .border-dark { border-color: var(--border) !important; }
[data-theme="light"] .border-secondary { border-color: var(--border) !important; }

/* ── Light theme: form elements ── */
[data-theme="light"] .form-control.bg-dark,
[data-theme="light"] .form-select.bg-dark,
[data-theme="light"] .form-control[style*="background:#1"],
[data-theme="light"] .form-control[style*="background: #1"] {
    background-color: var(--surface) !important;
    border-color: var(--border) !important;
    color: var(--text-primary) !important;
}
[data-theme="light"] .input-group-text.bg-dark {
    background-color: var(--surface-2) !important;
    color: var(--text-secondary) !important;
    border-color: var(--border) !important;
}

/* ── Light theme: page headings with inline style="color:#fff" ── */
[data-theme="light"] .page-body > div > h4[style*="color:#fff"],
[data-theme="light"] .page-body > div > h5[style*="color:#fff"],
[data-theme="light"] h1[style*="color:#fff"], [data-theme="light"] h2[style*="color:#fff"],
[data-theme="light"] h3[style*="color:#fff"], [data-theme="light"] h4[style*="color:#fff"],
[data-theme="light"] h5[style*="color:#fff"], [data-theme="light"] h6[style*="color:#fff"] {
    color: var(--text-primary) !important;
}

/* ── Light theme: card-dark border override ── */
[data-theme="light"] .card-dark[style*="border-color:rgba(255,255,255"] {
    border-color: var(--border) !important;
}

/* ── Light theme: common dark sub-card backgrounds ── */
[data-theme="light"] [style*="background:rgba(31,41,55"],
[data-theme="light"] [style*="background: rgba(31,41,55"],
[data-theme="light"] [style*="background:rgba(17,24,39"],
[data-theme="light"] [style*="background: rgba(17,24,39"],
[data-theme="light"] [style*="background:rgba(55,65,81"],
[data-theme="light"] [style*="background: rgba(55,65,81"] {
    background-color: var(--surface-2) !important;
    background-image: none !important;
}

/* ── Light theme: white text on neutral light cards ── */
[data-theme="light"] .card-dark [style*="color:#fff"],
[data-theme="light"] .card-dark [style*="color: #fff"],
[data-theme="light"] .card-dark [style*="color:#d1d5db"],
[data-theme="light"] .card-dark [style*="color:#e5e7eb"],
[data-theme="light"] .card-dark [style*="color:#f3f4f6"] {
    color: var(--text-primary) !important;
}
[data-theme="light"] .card-dark [style*="color:#6b7280"],
[data-theme="light"] .card-dark [style*="color:#9ca3af"],
[data-theme="light"] .card-dark [style*="color:#4b5563"] {
    color: var(--text-secondary) !important;
}

/* ── Light theme: page borders using white alpha ── */
[data-theme="light"] [style*="border:1px solid rgba(255,255,255"],
[data-theme="light"] [style*="border: 1px solid rgba(255,255,255"] {
    border-color: var(--border) !important;
}
[data-theme="light"] [style*="border-bottom:1px solid rgba(255,255,255"],
[data-theme="light"] [style*="border-top:1px solid rgba(255,255,255"] {
    border-color: var(--border) !important;
}

/* ── Light theme: scrollbars ── */
[data-theme="light"] ::-webkit-scrollbar-track { background: var(--surface-2); }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: var(--border); }

/* Transition for theme switch */
body, .sidebar, .topnav, .card-dark, .stat-card, .auth-card,
.form-control-dark, .form-select-dark, .table-dark-custom thead th,
.table-dark-custom td, .btn-accent, .badge, .alert,
.topnav-dropdown, .referral-box {
    transition: background-color 0.25s ease, border-color 0.25s ease,
                color 0.2s ease, box-shadow 0.25s ease;
}

/* ═══════════════════════════════════════════════════════════════
   AUTH PAGES – FULL REDESIGN (Split Layout, 3D Card, OTP Boxes)
   ═══════════════════════════════════════════════════════════════ */

/* Remove old .auth-wrapper / .auth-card from above and use these */
.auth-page {
    display: flex;
    min-height: 100vh;
    overflow: hidden;
}

/* ── Brand Panel (left) ── */
.auth-brand {
    flex: 0 0 42%;
    position: relative;
    background: #08090C;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 3rem 3.5rem;
    overflow: hidden;
}

/* Glowing orbs */
.auth-brand::before {
    content: '';
    position: absolute;
    width: 500px; height: 500px;
    top: -150px; right: -150px;
    background: radial-gradient(circle, rgba(255,215,0,0.12) 0%, transparent 65%);
    border-radius: 50%;
    animation: orb-pulse 6s ease-in-out infinite alternate;
}
.auth-brand::after {
    content: '';
    position: absolute;
    width: 350px; height: 350px;
    bottom: -80px; left: -80px;
    background: radial-gradient(circle, rgba(255,165,0,0.08) 0%, transparent 65%);
    border-radius: 50%;
    animation: orb-pulse 8s ease-in-out infinite alternate-reverse;
}
@keyframes orb-pulse {
    from { transform: scale(1) rotate(0deg); opacity: 0.7; }
    to   { transform: scale(1.3) rotate(15deg); opacity: 1; }
}

.brand-content { position: relative; z-index: 2; }

.brand-logo-wrap {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin-bottom: 2.5rem;
}
.brand-logo { height: 72px; }
.brand-name {
    font-family: 'Orbitron', sans-serif;
    font-size: 2.2rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    background: linear-gradient(90deg, #FFD700, #FFA500);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1;
}

.brand-title {
    font-family: 'Orbitron', sans-serif;
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    line-height: 1.2;
    color: #EAECEF;
    margin-bottom: 0.75rem;
}

.brand-title span {
    background: linear-gradient(90deg, #FFD700, #FFA500);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.brand-subtitle {
    color: #848E9C;
    font-size: 0.95rem;
    margin-bottom: 2.5rem;
    line-height: 1.6;
}

.brand-features { list-style: none; padding: 0; margin: 0 0 2.5rem; }
.brand-features li {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    color: #EAECEF;
    font-size: 0.9rem;
    transition: padding-left 0.25s ease;
    cursor: default;
}
.brand-features li:last-child { border-bottom: none; }
.brand-features li:hover { padding-left: 0.4rem; }
.brand-features .feat-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(255,215,0,0.1);
    border: 1px solid rgba(255,215,0,0.2);
    display: flex; align-items: center; justify-content: center;
    color: #FFD700;
    font-size: 1rem;
    flex-shrink: 0;
    transition: background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
.brand-features li:hover .feat-icon {
    background: rgba(255,215,0,0.22);
    border-color: rgba(255,215,0,0.5);
    box-shadow: 0 0 16px rgba(255,215,0,0.28);
}

.brand-stats {
    display: flex;
    gap: 2rem;
    margin-top: 1rem;
}
.brand-stat .brand-stat-val {
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.3rem;
    font-weight: 700;
    color: #FFD700;
}
.brand-stat .brand-stat-lbl {
    font-size: 0.72rem;
    color: #848E9C;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-top: 2px;
}

/* Floating crypto symbols */
.brand-floats {
    position: absolute;
    inset: 0;
    z-index: 1;
    overflow: hidden;
    pointer-events: none;
}

.bf {
    position: absolute;
    font-size: 1.2rem;
    color: rgba(255,215,0,0.08);
    animation: float-up linear infinite;
    user-select: none;
}
.bf-1 { left: 10%; animation-duration: 12s; animation-delay: 0s; }
.bf-2 { left: 30%; animation-duration: 18s; animation-delay: 3s; }
.bf-3 { left: 55%; animation-duration: 14s; animation-delay: 6s; }
.bf-4 { left: 75%; animation-duration: 20s; animation-delay: 1s; }
.bf-5 { left: 88%; animation-duration: 16s; animation-delay: 9s; }

@keyframes float-up {
    0%   { transform: translateY(110vh) rotate(0deg);   opacity: 0; }
    5%   { opacity: 0.15; }
    95%  { opacity: 0.08; }
    100% { transform: translateY(-10vh) rotate(360deg); opacity: 0; }
}

/* ── Form Panel (right) ── */
.auth-form-panel {
    flex: 1;
    background: var(--bg);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.5rem;
    position: relative;
    overflow-y: auto;
    min-width: 0;
}

.auth-topbar {
    position: absolute;
    top: 1.25rem;
    right: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    z-index: 10;
}

.theme-toggle-btn {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
    font-size: 1rem;
}
.theme-toggle-btn:hover { color: var(--primary); border-color: var(--primary-border); }

/* ── New Auth Card ── */
.auth-card-wrap {
    width: 100%;
    max-width: 460px;
    position: relative;
}

/* Ambient gold aura that blooms on hover */
.auth-card-wrap::before {
    content: '';
    position: absolute;
    inset: 12px;
    border-radius: 1.5rem;
    background: radial-gradient(ellipse at 50% 60%, rgba(255,215,0,0.22) 0%, transparent 68%);
    filter: blur(28px);
    opacity: 0;
    transition: opacity 0.55s ease;
    z-index: -1;
    pointer-events: none;
}
.auth-card-wrap:hover::before { opacity: 1; }

.auth-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 1.25rem;
    padding: 2.5rem 2rem;
    width: 100%;
    box-shadow: var(--shadow-card), 0 0 40px rgba(255,215,0,0.04);
    position: relative;
    overflow: hidden;
    transition: border-color 0.4s ease, box-shadow 0.45s ease;
}
.auth-card:hover {
    border-color: rgba(255,215,0,0.26);
    box-shadow: var(--shadow-card),
                0 0 0 1px rgba(255,215,0,0.07),
                0 0 55px rgba(255,215,0,0.10),
                0 20px 50px rgba(0,0,0,0.22);
}

/* Gold top accent line — expands on hover */
.auth-card::before {
    content: '';
    position: absolute;
    top: 0; left: 2.5rem; right: 2.5rem;
    height: 2px;
    background: linear-gradient(90deg, transparent, #FFD700, #FFA500, transparent);
    border-radius: 0 0 2px 2px;
    transition: left 0.45s ease, right 0.45s ease;
    z-index: 3;
}
.auth-card:hover::before {
    left: 0.75rem;
    right: 0.75rem;
}

/* Diagonal scan sweep on hover */
.auth-card::after {
    content: '';
    position: absolute;
    top: 0; left: -130%;
    width: 58%; height: 100%;
    background: linear-gradient(
        108deg,
        transparent 0%,
        rgba(255,215,0,0.018) 38%,
        rgba(255,215,0,0.052) 50%,
        rgba(255,215,0,0.018) 62%,
        transparent 100%
    );
    pointer-events: none;
    transition: left 0.85s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    z-index: 1;
}
.auth-card:hover::after { left: 180%; }

.auth-card-logo {
    height: 42px; width: auto;
    transition: filter 0.3s ease;
}
.auth-card-logo:hover {
    filter: drop-shadow(0 0 8px rgba(255,215,0,0.45));
}

.auth-card-title {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: var(--text-primary);
    margin: 0;
}

.auth-card-sub {
    font-size: 0.82rem;
    color: var(--text-secondary);
    margin-top: 0.2rem;
}

/* ── Login Type Tabs ── */
.login-type-tabs {
    display: flex;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: 0.65rem;
    padding: 3px;
    gap: 2px;
    margin-bottom: 1.25rem;
}

.login-type-tabs label {
    flex: 1;
    text-align: center;
    padding: 0.45rem 0.5rem;
    border-radius: 0.5rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary);
    cursor: pointer;
    transition: background 0.18s, color 0.18s;
    user-select: none;
    letter-spacing: 0.02em;
}

.login-type-tabs input[type="radio"] { display: none; }
.login-type-tabs input[type="radio"]:checked + label {
    background: var(--surface);
    color: var(--primary);
    box-shadow: 0 1px 4px rgba(0,0,0,0.25);
}

/* ── Static Label Inputs ── */
.field-float {
    position: relative;
    margin-bottom: 1.1rem;
}

/* Label — static, above the input */
.field-float > label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--primary);
    margin-bottom: 0.42rem;
    letter-spacing: 0.015em;
    pointer-events: none;
    white-space: nowrap;
    transition: color 0.2s ease;
}

/* Label turns gold when field is focused */
.field-float:focus-within > label {
    color: var(--primary);
}

.field-float input,
.field-float select,
.field-float textarea {
    width: 100%;
    padding: 0.72rem 1rem;
    background: var(--surface-2);
    border: 1.5px solid var(--border);
    border-radius: 0.75rem;
    color: var(--text-primary);
    font-size: 0.9rem;
    font-weight: 500;
    outline: none;
    transition: border-color 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
    appearance: none;
    -webkit-appearance: none;
}

/* Hover — warm gold border tint */
.field-float input:hover:not(:focus),
.field-float select:hover:not(:focus),
.field-float textarea:hover:not(:focus) {
    border-color: rgba(255,215,0,0.32);
    background: var(--surface);
}

/* Focus — neon gold ring + subtle glow */
.field-float input:focus,
.field-float select:focus,
.field-float textarea:focus {
    border-color: var(--primary);
    background: var(--surface);
    box-shadow:
        0 0 0 3.5px rgba(255,215,0,0.13),
        0 4px 20px rgba(255,215,0,0.07);
}

/* Placeholder — visible, muted */
.field-float input::placeholder,
.field-float textarea::placeholder { color: var(--text-muted); opacity: 1; }

/* Field icon — resting state */
.field-float .field-icon {
    position: absolute;
    right: 0.85rem;
    bottom: 0;
    height: calc(0.72rem * 2 + 1.35rem);
    display: flex;
    align-items: center;
    color: var(--text-muted);
    font-size: 1rem;
    cursor: pointer;
    z-index: 2;
    background: none;
    border: none;
    padding: 0;
    line-height: 1;
    transition: color 0.2s ease;
}
.field-float .field-icon:hover { color: var(--primary); }

/* Static icons glow gold when field is focused */
.field-float:focus-within .field-icon:not(button) { color: var(--primary); }

/* For select - chevron */
.field-float select ~ .field-chevron {
    position: absolute;
    right: 0.9rem;
    bottom: 0;
    height: calc(0.72rem * 2 + 1.35rem);
    display: flex;
    align-items: center;
    pointer-events: none;
    color: var(--text-secondary);
    font-size: 0.8rem;
}

/* Input / select with icon on right */
.field-float.has-icon input  { padding-right: 2.8rem; }
.field-float.has-icon select { padding-right: 2.8rem; }

/* Sponsor / referral hint line (lives OUTSIDE .field-float to avoid pushing icon) */
.sponsor-hint {
    display: block;
    font-size: 0.78rem;
    font-weight: 500;
    min-height: 0;
    line-height: 1.3;
    padding: 0;
}
.sponsor-hint:empty { margin: 0 !important; }

/* ── OTP Input Boxes ── */
.otp-wrap {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    margin-bottom: 0.5rem;
}

.otp-box {
    width: 48px;
    height: 52px;
    background: var(--surface-2);
    border: 1.5px solid var(--border);
    border-radius: 0.75rem;
    text-align: center;
    font-size: 1.2rem;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    color: var(--text-primary);
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease,
                transform 0.15s ease, background 0.2s ease;
    caret-color: var(--primary);
}
.otp-box:hover:not(:focus) {
    border-color: rgba(255,215,0,0.32);
    background: var(--surface);
}
.otp-box:focus {
    border-color: var(--primary);
    background: var(--surface);
    box-shadow: 0 0 0 3.5px rgba(255,215,0,0.14), 0 0 20px rgba(255,215,0,0.18);
    transform: scale(1.08);
}
.otp-box.filled {
    border-color: var(--primary);
    color: var(--primary);
    background: rgba(255,215,0,0.08);
    box-shadow: 0 0 10px rgba(255,215,0,0.12);
}

/* ── Step Indicator ── */
.step-indicator {
    display: flex;
    align-items: center;
    gap: 0;
    margin-bottom: 1.5rem;
}

.step-dot {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--surface-2);
    border: 2px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--text-muted);
    font-family: 'Orbitron', sans-serif;
    flex-shrink: 0;
    transition: all 0.3s;
}

.step-dot.active {
    background: var(--primary);
    border-color: var(--primary);
    color: #000;
    box-shadow: 0 0 12px var(--primary-glow);
}

.step-dot.done {
    background: var(--success);
    border-color: var(--success);
    color: #000;
}

.step-line {
    flex: 1;
    height: 2px;
    background: var(--border);
    transition: background 0.3s;
    margin: 0 4px;
}

.step-line.done { background: var(--success); }

.step-label {
    font-size: 0.68rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-top: 4px;
    text-align: center;
}

.step-label.active { color: var(--primary); }

/* ── Auth Submit Button ── */
.btn-auth {
    width: 100%;
    padding: 0.85rem;
    background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%);
    border: none;
    border-radius: 0.75rem;
    color: #0B0E11;
    font-family: 'Orbitron', sans-serif;
    font-weight: 800;
    font-size: 0.82rem;
    letter-spacing: 0.1em;
    cursor: pointer;
    transition: filter 0.15s, transform 0.1s, box-shadow 0.15s;
    position: relative;
    overflow: hidden;
}

.btn-auth::after {
    content: '';
    position: absolute;
    top: -50%; left: -75%;
    width: 50%; height: 200%;
    background: rgba(255,255,255,0.15);
    transform: skewX(-20deg);
    transition: left 0.4s;
}

.btn-auth:hover {
    filter: brightness(1.1);
    box-shadow: 0 8px 36px rgba(255,215,0,0.42), 0 2px 10px rgba(0,0,0,0.2);
    transform: translateY(-2px);
}
.btn-auth:hover::after { left: 125%; }
.btn-auth:active { transform: translateY(0); filter: brightness(0.95); box-shadow: 0 2px 8px rgba(255,215,0,0.2); }

/* OTP sent info box */
.otp-info-box {
    background: rgba(14,203,129,0.08);
    border: 1px solid rgba(14,203,129,0.2);
    border-radius: 0.65rem;
    padding: 0.75rem 1rem;
    font-size: 0.82rem;
    color: var(--success);
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 1.25rem;
}

/* Divider */
.auth-divider {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 1rem 0;
    color: var(--text-muted);
    font-size: 0.73rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}
.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}

/* Timer */
.resend-timer {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.82rem;
    color: var(--text-secondary);
}
.resend-timer .timer-num { color: var(--primary); font-weight: 700; }

/* ── Responsive ── */
@media (max-width: 991.98px) {
    .auth-brand { display: none; }
    .auth-form-panel { flex: 1; padding: 1.5rem 1rem; }
}

@media (max-width: 575.98px) {
    .auth-card { padding: 1.75rem 1.25rem; }
    .otp-box { width: 42px; height: 48px; font-size: 1.1rem; }
    .brand-title { font-size: 1.5rem; }
}

/* ── Phone Field ── */
.phone-field-wrap {
    display: flex;
    align-items: stretch;
    border: 1.5px solid var(--border);
    border-radius: 0.75rem;
    background: var(--surface-2);
    overflow: hidden;
    transition: border-color 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}
.phone-field-wrap:hover:not(:focus-within) {
    border-color: rgba(255,215,0,0.32);
    background: var(--surface);
}
.phone-field-wrap:focus-within {
    border-color: var(--primary);
    background: var(--surface);
    box-shadow: 0 0 0 3.5px rgba(255,215,0,0.13), 0 4px 20px rgba(255,215,0,0.07);
}
.phone-dial-badge {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 0.78rem 0.6rem 0.78rem 0.9rem;
    background: transparent;
    font-size: 0.84rem;
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    border-right: 1px solid var(--border);
    min-width: 88px;
    letter-spacing: 0.02em;
    cursor: default;
    user-select: none;
}
.phone-number-input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    padding: 0.78rem 0.9rem;
    color: var(--text-primary);
    font-size: 0.9rem;
    font-family: 'JetBrains Mono', monospace;
}
.phone-number-input::placeholder { color: var(--text-muted); }

/* ── Email OTP Group ── */
.email-otp-group {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
.email-otp-group .field-float { margin-bottom: 0; }
.btn-send-otp {
    flex-shrink: 0;
    min-height: 54px;
    padding: 0 1rem;
    background: var(--grad-primary);
    border: none;
    border-radius: 10px;
    color: #000;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: filter 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, opacity 0.2s ease;
    display: flex;
    align-items: center;
    gap: 4px;
}
.btn-send-otp:hover:not(:disabled) {
    filter: brightness(1.1);
    box-shadow: 0 4px 18px rgba(255,215,0,0.35);
    transform: translateY(-1px);
}
.btn-send-otp:active:not(:disabled) { transform: translateY(0); filter: brightness(0.95); }
.btn-send-otp:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-send-otp.sent {
    background: transparent;
    color: var(--success);
    border: 1px solid var(--success);
}

/* ── Auth Form Panel — subtle dot-grid atmosphere ── */
.auth-form-panel {
    background-image: radial-gradient(rgba(255,215,0,0.045) 1px, transparent 1px);
    background-size: 28px 28px;
}

/* ── Custom checkbox in auth ── */
.auth-page .form-check-input {
    width: 17px;
    height: 17px;
    background-color: var(--surface-2);
    border: 1.5px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
    flex-shrink: 0;
    margin-top: 2px;
}
.auth-page .form-check-input:hover {
    border-color: rgba(255,215,0,0.5);
}
.auth-page .form-check-input:checked {
    background-color: var(--primary);
    border-color: var(--primary);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
    box-shadow: 0 0 8px rgba(255,215,0,0.35);
}
.auth-page .form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(255,215,0,0.15);
    border-color: var(--primary);
}

/* ── Alert polish in auth ── */
.auth-card .alert-danger {
    background: rgba(246,70,93,0.08);
    border-color: rgba(246,70,93,0.2);
    border-radius: 0.65rem;
    color: var(--danger);
}

/* ── Theme toggle ripple ── */
.theme-toggle-btn {
    transition: color 0.2s, border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.theme-toggle-btn:hover {
    color: var(--primary);
    border-color: var(--primary-border);
    box-shadow: 0 0 12px rgba(255,215,0,0.2);
}

/* ── Auth link hover ── */
.text-gold {
    color: var(--primary);
    text-decoration: none;
    transition: color 0.18s ease, text-shadow 0.18s ease;
}
.text-gold:hover {
    color: var(--primary-hover);
    text-shadow: 0 0 12px rgba(255,215,0,0.4);
}

/* ── Forgot password / back links ── */
.auth-card a.text-secondary {
    transition: color 0.18s ease;
}
.auth-card a.text-secondary:hover { color: var(--primary) !important; }

/* ── OTP info box ── */
.otp-info-box {
    border-radius: 0.75rem;
}

/* Consistent border-radius for send OTP button */
.btn-send-otp { border-radius: 0.75rem; }

/* ── Section labels above phone / OTP blocks ── */
.field-section-label {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 6px;
    cursor: default;
}
.field-section-label i { font-size: 0.78rem; }

/* ══════════════════════════════════════════════════════════════
   COIN PRELOADER
   ══════════════════════════════════════════════════════════════ */
#vnx-preloader {
    position: fixed;
    inset: 0;
    z-index: 999999;
    background: var(--bg);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.5rem;
    transition: opacity 0.5s ease, visibility 0.5s ease;
}
#vnx-preloader.hide {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}
.preloader-coin {
    position: relative;
    width: 90px;
    height: 90px;
}
.preloader-coin img {
    width: 90px;
    height: 90px;
    object-fit: contain;
    animation: logoPulse 2s ease-in-out infinite;
    filter: drop-shadow(0 0 16px rgba(255,215,0,0.5));
}
@keyframes logoPulse {
    0%,100% { filter: drop-shadow(0 0 10px rgba(255,215,0,0.35)); }
    50%      { filter: drop-shadow(0 0 26px rgba(255,215,0,0.75)); }
}
.preloader-ring {
    position: absolute;
    inset: -10px;
    border-radius: 50%;
    border: 2px solid transparent;
    border-top-color: var(--primary);
    border-right-color: rgba(255,215,0,0.35);
    animation: ringRotate 1.2s linear infinite;
}
.preloader-dots {
    display: flex;
    gap: 6px;
}
.preloader-dots span {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--primary);
    animation: dotBounce 1.2s ease-in-out infinite;
    opacity: 0.3;
}
.preloader-dots span:nth-child(1) { animation-delay: 0s; }
.preloader-dots span:nth-child(2) { animation-delay: 0.2s; }
.preloader-dots span:nth-child(3) { animation-delay: 0.4s; }
.preloader-text {
    font-family: 'Orbitron', sans-serif;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    color: var(--text-muted);
    text-transform: uppercase;
    margin-top: -0.5rem;
}
@keyframes coinSpin {
    0%   { transform: rotateY(0deg); }
    50%  { transform: rotateY(180deg); }
    100% { transform: rotateY(360deg); }
}
@keyframes ringRotate {
    to { transform: rotate(360deg); }
}
@keyframes dotBounce {
    0%, 80%, 100% { opacity: 0.2; transform: scale(0.8); }
    40%           { opacity: 1;   transform: scale(1.2); }
}

/* ══════════════════════════════════════════════════════════════
   ENHANCED SIDEBAR BRAND
   ══════════════════════════════════════════════════════════════ */
.sidebar-brand {
    background: linear-gradient(135deg, rgba(255,215,0,0.06) 0%, rgba(255,165,0,0.03) 100%);
}
.sidebar-user-info {
    padding: 0.9rem 1rem;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
    background: rgba(255,215,0,0.02);
}
.sidebar-user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--grad-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Orbitron', sans-serif;
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--text-inverse);
    flex-shrink: 0;
    border: 2px solid rgba(255,215,0,0.3);
}
.sidebar-user-name {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sidebar-user-id {
    font-size: 0.72rem;
    color: var(--text-muted);
    font-family: 'JetBrains Mono', monospace;
}

/* ══════════════════════════════════════════════════════════════
   ENHANCED STAT CARDS
   ══════════════════════════════════════════════════════════════ */
.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    position: relative;
    overflow: hidden;
    transition: border-color 0.25s, box-shadow 0.25s, transform 0.25s;
}
.stat-card::after {
    content: '';
    position: absolute;
    bottom: -30px; right: -20px;
    width: 80px; height: 80px;
    border-radius: 50%;
    background: var(--icon-color, rgba(255,215,0,0.06));
    pointer-events: none;
    transition: transform 0.3s ease;
}
.stat-card:hover::after { transform: scale(1.4); }
.stat-card:hover {
    border-color: var(--primary-border);
    box-shadow: 0 8px 32px rgba(255,215,0,0.1), 0 2px 8px rgba(0,0,0,0.3);
    transform: translateY(-3px);
}
.stat-card:hover::before { opacity: 1; }

/* ══════════════════════════════════════════════════════════════
   TOPNAV ENHANCEMENTS
   ══════════════════════════════════════════════════════════════ */
.topnav-icon-btn {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 1rem;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
    flex-shrink: 0;
    text-decoration: none;
}
.topnav-icon-btn:hover {
    color: var(--primary);
    border-color: var(--primary-border);
    background: var(--primary-muted);
}
.topnav-page-title {
    font-family: 'Orbitron', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--text-primary);
}

/* ══════════════════════════════════════════════════════════════
   MOBILE BOTTOM NAVIGATION
   ══════════════════════════════════════════════════════════════ */
.bottom-nav {
    display: none;
}
@media (max-width: 991.98px) {
    .bottom-nav {
        display: flex;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        height: 62px;
        background: var(--surface);
        border-top: 1px solid var(--border);
        z-index: 1050;
        align-items: stretch;
        padding: 0;
        box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
    }
    .bottom-nav-item {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 3px;
        text-decoration: none;
        color: var(--text-muted);
        font-size: 0.6rem;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        transition: color 0.15s, background 0.15s;
        border-radius: 0;
        position: relative;
        -webkit-tap-highlight-color: transparent;
    }
    .bottom-nav-item i {
        font-size: 1.2rem;
        transition: transform 0.2s ease, color 0.2s ease;
    }
    .bottom-nav-item:hover { color: var(--text-secondary); background: rgba(255,255,255,0.03); }
    .bottom-nav-item.active {
        color: var(--primary);
    }
    .bottom-nav-item.active i { transform: translateY(-2px); }
    .bottom-nav-item.active::before {
        content: '';
        position: absolute;
        top: 0; left: 20%; right: 20%;
        height: 2.5px;
        background: var(--grad-primary);
        border-radius: 0 0 4px 4px;
    }
    /* Shift active item icon up with gold glow */
    .bottom-nav-item.active i {
        filter: drop-shadow(0 0 6px rgba(255,215,0,0.6));
    }
    /* Page body needs padding at bottom */
    .page-body {
        padding-bottom: calc(1.75rem + 62px);
    }
}

/* ══════════════════════════════════════════════════════════════
   IMPROVED RESPONSIVE LAYOUT
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 575.98px) {
    .page-body { padding: 1rem 0.9rem; padding-bottom: calc(1rem + 62px); }
    .stat-card { padding: 1rem; }
    .stat-card .stat-value { font-size: 1.1rem; }
    .page-header h4 { font-size: 1rem; }
    .topnav { padding: 0 0.9rem; }
}

/* ══════════════════════════════════════════════════════════════
   DASHBOARD PAGE HEADER GRADIENT STRIP
   ══════════════════════════════════════════════════════════════ */
.page-header-gradient {
    background: linear-gradient(135deg,
        rgba(255,215,0,0.06) 0%,
        rgba(255,165,0,0.03) 50%,
        transparent 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.5rem;
    position: relative;
    overflow: hidden;
}
.page-header-gradient::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--grad-primary);
}

/* Quick action cards */
/* ══════════════════════════════════════════════════════════════
   PROFESSIONAL FILTER BAR
   ══════════════════════════════════════════════════════════════ */
.vnx-filter-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 0.75rem;
    overflow: hidden;
}
.vnx-filter-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.6rem 1.25rem;
    background: rgba(255,215,0,0.03);
    border-bottom: 1px solid var(--border);
}
.vnx-filter-head-title {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.vnx-filter-head-title i { color: var(--primary); font-size: 0.75rem; }
.vnx-filter-body {
    padding: 1rem 1.25rem 1.2rem;
}
.vnx-filter-label {
    display: block;
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.3rem;
}
/* Shared input/select style */
.vnx-fi {
    background: var(--surface-2) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-primary) !important;
    font-size: 0.84rem !important;
    transition: border-color 0.15s, box-shadow 0.15s !important;
}
.vnx-fi:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(255,215,0,0.1) !important;
    background: var(--surface-2) !important;
    color: var(--text-primary) !important;
    outline: none !important;
}
/* Input group addon */
.vnx-ig-addon {
    background: var(--surface-2) !important;
    border-color: var(--border) !important;
    color: var(--text-secondary) !important;
    border-right: none !important;
}
/* Clear X button at end of search group */
.vnx-fi-clear {
    background: var(--surface-2) !important;
    border: 1px solid var(--border) !important;
    border-left: none !important;
    color: var(--text-secondary) !important;
    padding: 0 0.6rem !important;
    cursor: pointer;
    transition: color 0.15s !important;
}
.vnx-fi-clear:hover { color: #F6465D !important; }
/* Clear all button in header */
.vnx-clear-all-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 0.4rem;
    padding: 0.22rem 0.7rem;
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    white-space: nowrap;
}
.vnx-clear-all-btn:hover {
    background: rgba(246,70,93,0.1);
    border-color: #F6465D;
    color: #F6465D;
}

/* Ensure Bootstrap dropdowns always render above the sidebar (z-index: 1040) */
.dropdown-menu {
    z-index: 1050 !important;
}
@media (max-width: 575.98px) {
    .vnx-filter-body  { padding: 0.75rem; }
    .vnx-filter-head  { padding: 0.5rem 0.75rem; }
}

/* Quick action cards */
.quick-action-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 1.25rem 0.75rem;
    text-decoration: none;
    text-align: center;
    min-height: 90px;
    position: relative;
    overflow: hidden;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.quick-action-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--qa-color, var(--grad-primary));
    transform: scaleX(0);
    transition: transform 0.25s ease;
    transform-origin: left;
}
.quick-action-card:hover {
    border-color: var(--qa-border, var(--primary-border));
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
.quick-action-card:hover::before { transform: scaleX(1); }
.quick-action-card .qa-icon {
    width: 40px; height: 40px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem;
    background: var(--qa-bg, rgba(255,215,0,0.1));
    color: var(--qa-color, var(--primary));
    transition: transform 0.2s ease;
}
.quick-action-card:hover .qa-icon { transform: scale(1.1) rotate(-5deg); }
.quick-action-card .qa-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    letter-spacing: 0.03em;
}
.quick-action-card:hover .qa-label { color: var(--text-primary); }

/* ══════════════════════════════════════════════════════════════
   DASHBOARD HOME PAGE — Earnings, Account Details, Stats
   ══════════════════════════════════════════════════════════════ */

/* Welcome + Income Wallet row */
.income-wallet-box {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    background: linear-gradient(135deg, rgba(245,158,11,0.15) 0%, rgba(234,88,12,0.12) 100%);
    border: 1px solid rgba(245,158,11,0.35);
    border-radius: var(--radius);
    padding: 0.85rem 1.25rem;
    transition: background 0.2s, box-shadow 0.2s;
    color: var(--text-primary);
    min-width: 220px;
}
.income-wallet-box:hover {
    background: linear-gradient(135deg, rgba(245,158,11,0.22) 0%, rgba(234,88,12,0.18) 100%);
    box-shadow: 0 6px 24px rgba(245,158,11,0.18);
}
.income-wallet-label {
    font-size: 0.875rem;
    font-weight: 600;
    color: #F59E0B;
    margin-bottom: 2px;
}
.income-wallet-value {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--text-primary);
    letter-spacing: 0em;
}

/* Income limit alert */
.income-alert-warn {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1rem 1.25rem;
    border-radius: var(--radius);
    background: rgba(245,158,11,0.08);
    border: 1px solid rgba(245,158,11,0.35);
    font-size: 0.875rem;
    color: var(--text-primary);
}
.income-alert-warn > i {
    color: #F59E0B;
    font-size: 1.25rem;
    margin-top: 1px;
    flex-shrink: 0;
}

/* Dashboard section title (amber, bold) */
.dash-section-title {
    font-size: 1.1rem;
    font-weight: 700;
    color: #F59E0B;
    margin: 0;
}

/* Income payout cards (dark bg tiles) */
.income-payout-card {
    background: rgba(0,0,0,0.25);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 0.625rem;
    padding: 1rem 1.1rem;
    transition: border-color 0.2s, background 0.2s;
}
.income-payout-card:hover {
    background: rgba(255,215,0,0.04);
    border-color: rgba(255,215,0,0.15);
}
.income-payout-label {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 0.35rem;
    font-weight: 500;
}
.income-payout-value {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: 0em;
}
/* Today's total — full-width golden */
.income-payout-total {
    background: linear-gradient(135deg, rgba(245,158,11,0.12) 0%, rgba(234,88,12,0.1) 100%);
    border-color: rgba(245,158,11,0.3);
}
.income-payout-total .income-payout-value { color: #F59E0B; }

/* Account details & performance stats rows */
.dash-detail-list { display: flex; flex-direction: column; gap: 0; }
.dash-detail-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.65rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.055);
    font-size: 0.875rem;
    gap: 0.5rem;
}
.dash-detail-item:last-child { border-bottom: none; }
.dash-detail-label {
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    flex-shrink: 0;
}
.dash-detail-label i { opacity: 0.7; }
.dash-detail-value {
    font-weight: 600;
    color: var(--text-primary);
    text-align: right;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* Social share buttons (Grow Your Network) */
.social-share-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 0.5rem;
    color: #fff !important;
    font-size: 1.05rem;
    transition: opacity 0.15s, transform 0.15s;
    text-decoration: none;
}
.social-share-btn:hover { opacity: 0.85; transform: scale(1.08); }

/* ────────────────────────────────────────────────
   Report / table pages  (report_template_v2.php)
   ──────────────────────────────────────────────── */

/* Back button */
.btn-icon-back {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 0.5rem;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--text-secondary);
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

/* ═══════════════════════════════════════════════════════════════
   COMPREHENSIVE LIGHT THEME — GLOBAL OVERRIDES
   Covers pages with hardcoded inline dark styles
   ═══════════════════════════════════════════════════════════════ */

/* ── Form Controls (override inline dark styles) ── */
[data-theme="light"] input[type="text"],
[data-theme="light"] input[type="number"],
[data-theme="light"] input[type="date"],
[data-theme="light"] input[type="email"],
[data-theme="light"] input[type="password"],
[data-theme="light"] input[type="search"],
[data-theme="light"] input[type="tel"],
[data-theme="light"] input[type="url"],
[data-theme="light"] select,
[data-theme="light"] textarea,
[data-theme="light"] .form-control,
[data-theme="light"] .form-select {
    background-color: #fff !important;
    background: #fff !important;
    border-color: #cbd5e1 !important;
    color: #1a202c !important;
}
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder { color: #94a3b8 !important; }

[data-theme="light"] select option {
    background: #fff !important;
    color: #1a202c !important;
}

/* ── Tables ── */
[data-theme="light"] .table,
[data-theme="light"] table {
    --bs-table-color: #1a202c;
    --bs-table-bg: transparent;
    --bs-table-border-color: #e2e8f0;
    --bs-table-hover-bg: rgba(0,0,0,0.03);
    color: #1a202c;
}
[data-theme="light"] .table th,
[data-theme="light"] table th {
    color: #4a5568 !important;
    background-color: #f1f5f9 !important;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .table td,
[data-theme="light"] table td {
    border-color: #e2e8f0 !important;
    color: #1a202c !important;
}
[data-theme="light"] .table tbody tr:hover,
[data-theme="light"] table tbody tr:hover { background: rgba(0,0,0,0.025) !important; }

/* ── Page body text (covers hardcoded white text) ── */
[data-theme="light"] .page-body { color: var(--text-primary); }

/* ── Card/Container backgrounds (soft light overrides) ── */
[data-theme="light"] .card-dark { background: #fff !important; }

/* ── Inline dark backgrounds — broad coverage ── */
/* Most pages use div[style*="background:rgba(31,41,55"] or similar hardcoded */
/* We can't target inline styles precisely, so target page-body scope */
[data-theme="light"] .page-body h4,
[data-theme="light"] .page-body h5,
[data-theme="light"] .page-body h6 { color: var(--text-primary) !important; }

/* White text in spans/divs with inline style — can't override, but provide readable defaults */
[data-theme="light"] .page-body .fw-bold,
[data-theme="light"] .page-body .fw-semibold { color: var(--text-primary); }

/* ── Buttons (outline/ghost style) ── */
[data-theme="light"] .btn-icon-back,
[data-theme="light"] .topnav-icon-btn {
    background: rgba(0,0,0,0.04) !important;
    border-color: rgba(0,0,0,0.1) !important;
    color: var(--text-secondary) !important;
}
[data-theme="light"] .btn-icon-back:hover { background: rgba(0,0,0,0.08) !important; color: var(--primary) !important; }

/* ── Dropdown menus (Bootstrap) ── */
[data-theme="light"] .dropdown-menu {
    background: #fff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 8px 25px rgba(0,0,0,0.1) !important;
}
[data-theme="light"] .dropdown-item { color: #4a5568 !important; }
[data-theme="light"] .dropdown-item:hover { background: #f1f5f9 !important; color: #1a202c !important; }

/* ── Alert overrides remain readable in light ── */
[data-theme="light"] .alert-success { background: rgba(14,203,129,0.1) !important; color: #047857 !important; }
[data-theme="light"] .alert-danger  { background: rgba(220,38,38,0.08) !important; color: #dc2626 !important; }
[data-theme="light"] .alert-warning { background: rgba(217,119,6,0.1)  !important; color: #92400e !important; }
[data-theme="light"] .alert-info    { background: rgba(37,99,235,0.08) !important; color: #1e40af !important; }

/* ── Bootstrap dark classes override ── */
[data-theme="light"] .bg-dark { background-color: #f1f5f9 !important; }
[data-theme="light"] .text-white { color: var(--text-primary) !important; }
[data-theme="light"] .text-light { color: var(--text-secondary) !important; }
[data-theme="light"] .border-secondary { border-color: #cbd5e1 !important; }
[data-theme="light"] .border-dark { border-color: #94a3b8 !important; }

/* ── Stat cards ── */
[data-theme="light"] .stat-card { background: #fff !important; box-shadow: 0 2px 8px rgba(0,0,0,0.07); }

/* ── Code / mono elements ── */
[data-theme="light"] code { background: #f1f5f9; color: #be185d; padding: 0.1em 0.35em; border-radius: 4px; }

/* ── Topnav dropdown ── */
[data-theme="light"] .topnav-dropdown { background: #fff; border-color: #e2e8f0; }
[data-theme="light"] .topnav-user-btn { background: #f8fafc; border-color: #e2e8f0; color: #1a202c; }

/* ── Input group ── */
[data-theme="light"] .input-group-text { background: #f1f5f9 !important; border-color: #cbd5e1 !important; color: #4a5568 !important; }

/* ── Sidebar active state stays gold in light mode ── */
[data-theme="light"] .sidebar-link.active,
[data-theme="light"] .sidebar-sub-link.active { background: linear-gradient(90deg,#FBBF24,#F59E0B); color: #000 !important; }

/* ── Sidebar links in light mode ── */
[data-theme="light"] .sidebar-link,
[data-theme="light"] .sidebar-group-btn { color: #4a5568; }
[data-theme="light"] .sidebar-link:hover,
[data-theme="light"] .sidebar-group-btn:hover { background: rgba(245,158,11,0.08); color: #d97706; }
[data-theme="light"] .sidebar-sub-link { color: #4a5568; }
[data-theme="light"] .sidebar-sub-link:hover { background: rgba(245,158,11,0.08); color: #d97706; }
[data-theme="light"] .sidebar-section-label { color: #94a3b8; }

/* ── VNX Toast in light mode ── */
[data-theme="light"] .vnx-toast { background: #fff; box-shadow: 0 8px 28px rgba(0,0,0,0.12); color: #1a202c; }

/* ── rr-modal (rank-rewards modal) ── */
[data-theme="light"] .rr-modal { background: #fff; border-color: rgba(0,0,0,0.1); }
[data-theme="light"] .rr-input { background: #f1f5f9 !important; border-color: #cbd5e1 !important; color: #1a202c !important; }
[data-theme="light"] .rr-option-card { border-color: #e2e8f0; }
[data-theme="light"] .rr-option-card:hover { border-color: #94a3b8; }
[data-theme="light"] .rr-stat-divider { border-color: rgba(0,0,0,0.1); }

/* ── Profile page cards ── */
[data-theme="light"] .referral-box { background: rgba(200,160,0,0.06); color: var(--text-secondary); }

/* ── Tree nodes / SVG in light ── */
[data-theme="light"] #treeContainer { background: #f8fafc !important; border-color: #e2e8f0 !important; }
.btn-icon-back:hover { background: rgba(251,191,36,0.12); color: #FBBF24; }

/* Stat cards — React-style: label top-left, big value bottom-left, icon top-right */
.rpt-stat-card {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1.1rem 1.2rem;
    border-radius: 0.85rem;
    border: 1px solid;
    transition: box-shadow 0.2s, transform 0.15s;
}
.rpt-stat-card:hover { box-shadow: 0 4px 24px rgba(0,0,0,0.22); transform: translateY(-1px); }
.rpt-stat-icon { font-size: 1.25rem; line-height: 1; margin-top: 0.05rem; flex-shrink: 0; }
.rpt-stat-value { font-size: 1.5rem; font-weight: 700; line-height: 1.15; margin-top: 0.3rem; }
.rpt-stat-label { font-size: 0.75rem; color: var(--text-muted); font-weight: 500; }

/* Toolbar */
.rpt-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* Toolbar buttons */
.rpt-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.4rem 0.75rem;
    border-radius: 0.45rem;
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: opacity 0.15s, box-shadow 0.15s;
    white-space: nowrap;
    position: relative;
}
.rpt-btn:hover { opacity: 0.88; }
.rpt-btn-green  { background: linear-gradient(135deg,#16A34A,#15803D); color:#fff; }
.rpt-btn-blue   { background: linear-gradient(135deg,#2563EB,#1D4ED8); color:#fff; }
.rpt-btn-purple { background: linear-gradient(135deg,#7C3AED,#6D28D9); color:#fff; }
.rpt-btn-amber  { background: linear-gradient(135deg,#FBBF24,#F59E0B); color:#000; font-weight:700; }
.rpt-btn-ghost  { background: rgba(255,255,255,0.06); color: var(--text-secondary); border: 1px solid rgba(255,255,255,0.1); }
.rpt-btn-ghost:hover { color: var(--text-primary); background: rgba(255,255,255,0.1); }
.rpt-btn-active { box-shadow: 0 0 0 2px rgba(251,191,36,0.4); }
.rpt-filter-dot {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #FBBF24;
}

/* Per-page select */
.rpt-select {
    padding: 0.35rem 0.55rem;
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 0.4rem;
    color: var(--text-primary);
    font-size: 0.82rem;
    cursor: pointer;
    outline: none;
}
.rpt-select:focus { border-color: rgba(251,191,36,0.4); }

/* Filter panel */
.rpt-filter-panel {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    background: rgba(0,0,0,0.15);
    border-bottom: 1px solid transparent;
}
.rpt-filter-panel.open {
    max-height: 600px;
    padding: 1rem 1.25rem;
    border-bottom-color: rgba(255,255,255,0.06);
}
.rpt-label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-bottom: 4px;
    font-weight: 500;
}
.rpt-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    background: rgba(0,0,0,0.3);
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: 0.5rem;
    color: var(--text-primary);
    font-size: 0.85rem;
    outline: none;
    transition: border-color 0.15s;
}
.rpt-input:focus { border-color: rgba(251,191,36,0.4); }
.rpt-input::placeholder { color: var(--text-muted); }
.rpt-input option { background: #1E2329; }

/* Table */
.rpt-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}
.rpt-table thead tr {
    border-bottom: 1px solid rgba(255,255,255,0.07);
    background: rgba(0,0,0,0.2);
}
.rpt-table thead th {
    padding: 0.75rem 1rem;
    color: var(--text-muted);
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
}
.rpt-table tbody tr {
    border-bottom: 1px solid rgba(255,255,255,0.04);
    transition: background 0.12s;
}
.rpt-table tbody tr:last-child { border-bottom: none; }
.rpt-table tbody tr:hover { background: rgba(255,255,255,0.025); }
.rpt-table tbody td {
    padding: 0.5rem 0.85rem;
    color: var(--text-secondary);
    vertical-align: middle;
    white-space: nowrap;
}
.rpt-table thead th {
    padding: 0.55rem 0.85rem;
    white-space: nowrap;
}
.rpt-table .rpt-num { color: var(--text-muted); font-size: 0.8rem; white-space: nowrap; }
.rpt-empty-row {
    text-align: center;
    padding: 3.5rem 1rem !important;
    color: var(--text-muted);
}

/* Pagination bar */
.rpt-pagination-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 0.85rem 1.25rem;
    border-top: 1px solid rgba(255,255,255,0.06);
}
.rpt-pag-info { font-size: 0.78rem; color: var(--text-muted); }
.rpt-pag-btns { display: flex; align-items: center; gap: 3px; }
.rpt-pag-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 0.4rem;
    border-radius: 0.4rem;
    font-size: 0.8rem;
    font-weight: 500;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.07);
    color: var(--text-secondary);
    text-decoration: none;
    transition: background 0.12s, color 0.12s;
}
.rpt-pag-btn:hover:not(.disabled):not(.active) {
    background: rgba(251,191,36,0.1);
    color: #FBBF24;
    border-color: rgba(251,191,36,0.3);
}
.rpt-pag-btn.active {
    background: linear-gradient(135deg,#FBBF24,#F59E0B);
    color: #000;
    font-weight: 700;
    border-color: transparent;
}
.rpt-pag-btn.disabled {
    opacity: 0.35;
    pointer-events: none;
}
.rpt-pag-ellipsis {
    display: inline-flex;
    align-items: center;
    padding: 0 0.25rem;
    color: var(--text-muted);
    font-size: 0.8rem;
}

/* ═══════════════════════════════════════════════════════════════
   COIN-TO-WALLET PAGE — Semantic theme classes
   ═══════════════════════════════════════════════════════════════ */

/* Convert card container */
.ctw-convert-card {
    background: linear-gradient(135deg,rgba(34,211,238,0.08),rgba(59,130,246,0.08));
    border: 1px solid rgba(34,211,238,0.25);
    border-radius: 1rem;
    padding: 1.5rem;
}
/* Balance row */
.ctw-balance-row {
    background: rgba(255,255,255,0.04);
    border-radius: 0.75rem;
}
.ctw-balance-value {
    font-size: 1.6rem;
    color: #22d3ee;
}
/* Input */
.ctw-input {
    background: var(--surface-2) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-primary) !important;
    border-radius: 0.7rem;
    padding: 0.75rem 1rem;
}
/* Labels / muted text */
.ctw-label  { color: var(--text-secondary); }
.ctw-muted  { color: var(--text-muted); }
.ctw-text   { color: var(--text-primary); }
.ctw-danger { color: var(--danger); }
.ctw-heading { color: var(--text-primary); }

/* Preview box */
.ctw-preview-box {
    background: rgba(34,211,238,0.08);
    border: 1px solid rgba(34,211,238,0.25);
    border-radius: 0.7rem;
    padding: 1rem;
}
.ctw-preview-value { color: var(--text-primary); }
.ctw-preview-sub   { color: var(--text-secondary); }
.ctw-preview-divider { border-color: var(--border) !important; }

/* Rules box */
.ctw-rules-box {
    background: rgba(34,211,238,0.06);
    border: 1px solid rgba(34,211,238,0.2);
    border-radius: 0.7rem;
    padding: 1rem;
}
.ctw-rules-title { color: #67e8f9; }
.ctw-rules-list  { color: #a5f3fc; line-height: 1.8; }

/* History card */
.ctw-hist-card {
    background: linear-gradient(135deg,rgba(31,41,55,0.7),rgba(17,24,39,0.7));
    border: 1px solid rgba(75,85,99,0.4);
    border-radius: 1rem;
    overflow: hidden;
}
/* Toolbar */
.ctw-toolbar { border-bottom: 1px solid rgba(75,85,99,0.4); }

/* Per-page select */
.ctw-select {
    background: var(--surface-2) !important;
    border: 1px solid var(--border) !important;
    color: var(--text-primary) !important;
}

/* Filter bar */
.ctw-filter-bar {
    background: rgba(17,24,39,0.5);
    border-bottom: 1px solid rgba(75,85,99,0.3);
}
.ctw-btn-filter {
    background: rgba(168,85,247,0.2);
    border: 1px solid rgba(168,85,247,0.4);
    color: #c084fc;
}
.ctw-btn-reset {
    background: rgba(75,85,99,0.2);
    border: 1px solid rgba(75,85,99,0.4);
    color: var(--text-secondary);
}

/* Table */
.ctw-table {
    color: var(--text-secondary);
    white-space: nowrap;
    font-size: 0.85rem;
    width: 100%;
}
.ctw-thead { background: rgba(31,41,55,0.5); }
.ctw-th {
    color: var(--text-muted);
    font-weight: 500;
    border: none;
    white-space: nowrap;
}
.ctw-td { border-top: 1px solid var(--border) !important; white-space: nowrap; }
.ctw-row { transition: background 0.12s; }
.ctw-row:hover { background: rgba(75,85,99,0.18); }

/* Pagination footer */
.ctw-pag-footer { border-top: 1px solid rgba(75,85,99,0.4); }

/* ── Light Theme Overrides ── */
[data-theme="light"] .ctw-convert-card {
    background: linear-gradient(135deg,rgba(34,211,238,0.06),rgba(59,130,246,0.06));
    border-color: rgba(34,211,238,0.3);
}
[data-theme="light"] .ctw-balance-row {
    background: rgba(0,0,0,0.03);
    border: 1px solid rgba(34,211,238,0.15);
}
[data-theme="light"] .ctw-hist-card {
    background: #fff;
    border-color: #e2e8f0;
}
[data-theme="light"] .ctw-toolbar { border-bottom-color: #e2e8f0; }
[data-theme="light"] .ctw-filter-bar {
    background: #f8fafc;
    border-bottom-color: #e2e8f0;
}
[data-theme="light"] .ctw-thead { background: #f1f5f9; }
[data-theme="light"] .ctw-th { color: #4a5568 !important; border-bottom: 1px solid #e2e8f0 !important; }
[data-theme="light"] .ctw-td { border-top-color: #e2e8f0 !important; }
[data-theme="light"] .ctw-row:hover { background: rgba(0,0,0,0.025); }
[data-theme="light"] .ctw-pag-footer { border-top-color: #e2e8f0; }
[data-theme="light"] .ctw-rules-title { color: #0891b2; }
[data-theme="light"] .ctw-rules-list  { color: #0e7490; }
[data-theme="light"] .ctw-preview-box {
    background: rgba(8,145,178,0.05);
    border-color: rgba(8,145,178,0.2);
}
[data-theme="light"] .ctw-rules-box {
    background: rgba(8,145,178,0.04);
    border-color: rgba(8,145,178,0.15);
}
[data-theme="light"] .ctw-btn-reset { color: #4a5568; }
[data-theme="light"] .ctw-table { color: #374151; }


/* ═══════════════════════════════════════════════════════════════
   GLOBAL LIGHT THEME — Page-wide inline style overrides
   Fixes pages that use hardcoded dark colors in inline styles
   ═══════════════════════════════════════════════════════════════ */

/* ── Back button (page header back arrows) ── */
[data-theme="light"] .page-body .btn-icon-back,
[data-theme="light"] .btn-icon-back {
    background: rgba(0,0,0,0.05) !important;
    border: 1px solid rgba(0,0,0,0.12) !important;
    color: var(--text-secondary) !important;
}

/* ── Generic card/panel containers (common pattern across all pages) ── */
/* History cards, section panels with dark gradient bg */
[data-theme="light"] #histCard,
[data-theme="light"] .hist-card,
[data-theme="light"] .page-section-card {
    background: #fff !important;
    border-color: #e2e8f0 !important;
}

/* ── All h6 headings inside page cards that have color:#f9fafb ── */
[data-theme="light"] .page-body h6 { color: var(--text-primary) !important; }

/* ── Generic select dropdowns with dark bg ── */
[data-theme="light"] .page-body select { color-scheme: light; }

/* ── Spinner empty state cells ── */
[data-theme="light"] .page-body td[style*="color:#6b7280"],
[data-theme="light"] .page-body td[style*="color: #6b7280"] { color: var(--text-muted) !important; }
[data-theme="light"] .page-body td[style*="color:#9ca3af"],
[data-theme="light"] .page-body td[style*="color: #9ca3af"] { color: var(--text-secondary) !important; }
[data-theme="light"] .page-body td[style*="color:#d1d5db"],
[data-theme="light"] .page-body td[style*="color: #d1d5db"] { color: var(--text-primary) !important; }
[data-theme="light"] .page-body td[style*="color:#f9fafb"],
[data-theme="light"] .page-body td[style*="color: #f9fafb"] { color: var(--text-primary) !important; }

/* ── Hardcoded dark bg panels in page-body ── */
[data-theme="light"] .page-body div[style*="background:rgba(31,41,55"],
[data-theme="light"] .page-body div[style*="background: rgba(31,41,55"],
[data-theme="light"] .page-body div[style*="background:linear-gradient(135deg,rgba(31,41,55"],
[data-theme="light"] .page-body div[style*="background:rgba(17,24,39"],
[data-theme="light"] .page-body div[style*="background: rgba(17,24,39"] {
    background: #fff !important;
    border-color: #e2e8f0 !important;
}

/* ── Inner dark surface panels ── */
[data-theme="light"] .page-body div[style*="background:rgba(255,255,255,0.04)"],
[data-theme="light"] .page-body div[style*="background: rgba(255,255,255,0.04)"],
[data-theme="light"] .page-body div[style*="background:rgba(255,255,255,0.03)"],
[data-theme="light"] .page-body div[style*="background:rgba(0,0,0,0.2)"],
[data-theme="light"] .page-body div[style*="background:rgba(0,0,0,0.15)"] {
    background: rgba(0,0,0,0.025) !important;
}

/* ── Table thead with dark inline bg ── */
[data-theme="light"] .page-body thead[style*="background:rgba(31,41,55"],
[data-theme="light"] .page-body thead[style*="background: rgba(31,41,55"],
[data-theme="light"] .page-body thead[style*="background:rgba(0,0,0"] {
    background: #f1f5f9 !important;
}

/* ── Hardcoded text colors — label text ── */
[data-theme="light"] .page-body .small[style*="color:#9ca3af"],
[data-theme="light"] .page-body small[style*="color:#9ca3af"],
[data-theme="light"] .page-body label[style*="color:#9ca3af"],
[data-theme="light"] .page-body span[style*="color:#9ca3af"] { color: #4a5568 !important; }

[data-theme="light"] .page-body .small[style*="color:#6b7280"],
[data-theme="light"] .page-body small[style*="color:#6b7280"],
[data-theme="light"] .page-body span[style*="color:#6b7280"] { color: #6b7280 !important; }

[data-theme="light"] .page-body span[style*="color:#f9fafb"],
[data-theme="light"] .page-body h6[style*="color:#f9fafb"],
[data-theme="light"] .page-body div[style*="color:#f9fafb"] { color: var(--text-primary) !important; }

[data-theme="light"] .page-body span[style*="color:#d1d5db"],
[data-theme="light"] .page-body div[style*="color:#d1d5db"] { color: var(--text-primary) !important; }

[data-theme="light"] .page-body div[style*="color:#e5e7eb"],
[data-theme="light"] .page-body span[style*="color:#e5e7eb"] { color: #374151 !important; }

/* ── White text on dark bg ── */
[data-theme="light"] .page-body span[style*="color:#fff;"],
[data-theme="light"] .page-body div[style*="color:#fff;"],
[data-theme="light"] .page-body p[style*="color:#fff;"] { color: var(--text-primary) !important; }

/* ── Cyan/accent text (labels) keep their color in light mode ── */
[data-theme="light"] .page-body span[style*="color:#22d3ee"],
[data-theme="light"] .page-body div[style*="color:#22d3ee"] { color: #0891b2 !important; }

[data-theme="light"] .page-body span[style*="color:#67e8f9"],
[data-theme="light"] .page-body span[style*="color:#a5f3fc"] { color: #0e7490 !important; }

/* ── Hardcoded dark inputs ── */
[data-theme="light"] .page-body input[style*="background:#1f2937"],
[data-theme="light"] .page-body input[style*="background: #1f2937"],
[data-theme="light"] .page-body select[style*="background:#1f2937"],
[data-theme="light"] .page-body select[style*="background: #1f2937"],
[data-theme="light"] .page-body textarea[style*="background:#1f2937"] {
    background: #fff !important;
    border-color: #cbd5e1 !important;
    color: #1a202c !important;
}

/* ── Pagination buttons dark bg ── */
[data-theme="light"] .page-body a[style*="background:rgba(31,41,55"],
[data-theme="light"] .page-body button[style*="background:rgba(31,41,55"] {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
    color: #374151 !important;
}

/* ── History/filter toolbar border ── */
[data-theme="light"] .page-body div[style*="border-bottom:1px solid rgba(75,85,99"],
[data-theme="light"] .page-body div[style*="border-bottom: 1px solid rgba(75,85,99"] {
    border-bottom-color: #e2e8f0 !important;
}
[data-theme="light"] .page-body div[style*="border-top:1px solid rgba(75,85,99"],
[data-theme="light"] .page-body div[style*="border-top: 1px solid rgba(75,85,99"] {
    border-top-color: #e2e8f0 !important;
}

/* ── Stat info boxes (light tinted panels) ── */
[data-theme="light"] .page-body div[style*="background:rgba(34,211,238,0.08)"],
[data-theme="light"] .page-body div[style*="background:rgba(34,211,238,0.06)"] {
    background: rgba(8,145,178,0.05) !important;
    border-color: rgba(8,145,178,0.2) !important;
}
[data-theme="light"] .page-body div[style*="background:rgba(59,130,246,0.08)"] {
    background: rgba(37,99,235,0.05) !important;
}
[data-theme="light"] .page-body div[style*="background:rgba(168,85,247,0.15)"],
[data-theme="light"] .page-body div[style*="background:rgba(139,92,246,0.15)"] {
    background: rgba(124,58,237,0.06) !important;
}

/* ── Dark filter bar background ── */
[data-theme="light"] .page-body div[style*="background:rgba(17,24,39,0.5)"] {
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
}

/* Color-scheme for native date inputs in light ── */
[data-theme="light"] input[type="date"],
[data-theme="light"] input[type="datetime-local"],
[data-theme="light"] input[type="month"],
[data-theme="light"] input[type="time"] {
    color-scheme: light;
}

/* ═══════════════════════════════════════════════════════════════════════════
   GLOBAL LIGHT THEME — Extended overrides v2
   (claim-income · staking · genealogy-tree and all similar pages)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Ghost back-buttons (bg≈transparent-white, color:#fff) ── */
[data-theme="light"] .page-body a[style*="background:rgba(255,255,255,0.07)"],
[data-theme="light"] .page-body button[style*="background:rgba(255,255,255,0.07)"] {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
    color: #374151 !important;
}

/* ── button tags with background:#1f2937 (tree controls, etc.) ── */
[data-theme="light"] .page-body button[style*="background:#1f2937"],
[data-theme="light"] .page-body button[style*="background: #1f2937"] {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
    color: #374151 !important;
}

/* ── label elements with dark bg (payment source cards, etc.) ── */
[data-theme="light"] .page-body label[style*="background:rgba(17,24,39"],
[data-theme="light"] .page-body label[style*="background:rgba(31,41,55"] {
    background: #f8fafc !important;
    border-color: #cbd5e1 !important;
}

/* ── Mode-toggle bar (rgba(55,65,81)) ── */
[data-theme="light"] .page-body div[style*="background:rgba(55,65,81"] {
    background: #e5e7eb !important;
}

/* ── button / inline toggle with color:#9ca3af ── */
[data-theme="light"] .page-body button[style*="color:#9ca3af"] { color: #4a5568 !important; }

/* ── div labels with color:#9ca3af (e.g. "Payment Source", "Amount") ── */
[data-theme="light"] .page-body div[style*="color:#9ca3af"] { color: #4a5568 !important; }

/* ── Inputs / textareas with transparent bg but white text ── */
[data-theme="light"] .page-body input[style*="color:#fff"],
[data-theme="light"] .page-body input[style*="color: #fff"] {
    color: #1a202c !important;
}

/* ── Gold/amber text (rules lists, labels) – invisible gold-on-white ── */
[data-theme="light"] .page-body ul[style*="color:#fde68a"],
[data-theme="light"] .page-body span[style*="color:#fde68a"],
[data-theme="light"] .page-body li[style*="color:#fde68a"]  { color: #92400e !important; }
[data-theme="light"] .page-body span[style*="color:#fcd34d"],
[data-theme="light"] .page-body div[style*="color:#fcd34d"]  { color: #b45309 !important; }

/* ── h5 headings inside page cards ── */
[data-theme="light"] .page-body h5[style*="color:#f9fafb"] { color: var(--text-primary) !important; }

/* ── Table-level text color (common: style="color:#d1d5db") ── */
[data-theme="light"] .page-body table[style*="color:#d1d5db"],
[data-theme="light"] .page-body table[style*="color: #d1d5db"] { color: var(--text-primary) !important; }

/* ── th / td header labels ── */
[data-theme="light"] .page-body th[style*="color:#9ca3af"],
[data-theme="light"] .page-body th[style*="color: #9ca3af"] { color: #4a5568 !important; }
[data-theme="light"] .page-body th[style*="color:#d1d5db"],
[data-theme="light"] .page-body th[style*="color: #d1d5db"] { color: var(--text-primary) !important; }

/* ── div with ONLY color:#fff (card labels like "369 Coin") ── */
[data-theme="light"] .page-body div[style="color:#fff"] { color: var(--text-primary) !important; }
[data-theme="light"] .page-body div[style^="color:#fff;"] { color: var(--text-primary) !important; }
[data-theme="light"] .page-body div[style$=";color:#fff"] { color: var(--text-primary) !important; }
[data-theme="light"] .page-body div[style*=";color:#fff;"] { color: var(--text-primary) !important; }

/* ── span with ONLY color:#fff (fee breakdown values, etc.) ── */
[data-theme="light"] .page-body span[style="color:#fff"] { color: var(--text-primary) !important; }

/* ── strong tags with hardcoded light-text colors (JS-generated detRow etc.) ── */
[data-theme="light"] .page-body strong[style*="color:#f9fafb"],
[data-theme="light"] .page-body strong[style*="color:#fff"] { color: var(--text-primary) !important; }

/* ── Pagination anchor links with hardcoded dark bg ── */
[data-theme="light"] .page-body a.page-link[style*="background:#1f2937"],
[data-theme="light"] .page-body a[style*="background:#1f2937"] {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
    color: #374151 !important;
}

/* ── Staking 369-coin source card amber bg – keep bg, fix text ── */
[data-theme="light"] .page-body label[style*="background:rgba(217,119,6"] {
    background: rgba(217,119,6,0.07) !important;
    border-color: rgba(217,119,6,0.4) !important;
}

/* ── Row hover override inline: make transparent for light mode ── */
[data-theme="light"] .page-body tr[onmouseover]:hover { background: rgba(0,0,0,0.035) !important; }

/* ── success/close overlay buttons (rgba(75,85,99)) ── */
[data-theme="light"] .page-body button[style*="background:rgba(75,85,99"] {
    background: #f1f5f9 !important;
    border-color: #cbd5e1 !important;
    color: #374151 !important;
}

/* ════════════════════════════════════════════════════
   GENEALOGY TREE — Stats cards & tree canvas
   ════════════════════════════════════════════════════ */

/* Stats section value text is Bootstrap text-white → override in light */
[data-theme="light"] #statsSection .text-white,
[data-theme="light"] #statsSection .fw-bold { color: var(--text-primary) !important; }

/* Stats cards with colourful semi-transparent gradient bg */
[data-theme="light"] #statsSection .rounded-3[style*="linear-gradient"] {
    background: #fff !important;
    border-color: #e2e8f0 !important;
}

/* Tree canvas background */
[data-theme="light"] #treeContainer {
    background: #f0f4f8 !important;
    border-color: #e2e8f0 !important;
}

/* ── Node Hover Tooltip ── */
[data-theme="light"] #nodeTooltip > div {
    background: #fff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.12) !important;
    color: #374151 !important;
}
[data-theme="light"] #nodeTooltip #tipName  { color: #1a202c !important; }
[data-theme="light"] #nodeTooltip #tipUserId { color: #6b7280 !important; }
[data-theme="light"] #nodeTooltip div[style*="border-bottom:1px solid #374151"],
[data-theme="light"] #nodeTooltip div[style*="border-bottom:1px solid #1f2937"] { border-bottom-color: #e2e8f0 !important; }
[data-theme="light"] #nodeTooltip #tipDetails span[style*="color:#9ca3af"] { color: #6b7280 !important; }

/* ── Node Popup (mobile click) ── */
[data-theme="light"] #nodePopup > div,
[data-theme="light"] #nodePopup [style*="background:#111827"] {
    background: #fff !important;
    border-color: #22d3ee !important;
}
[data-theme="light"] #nodePopup div[style*="linear-gradient(135deg,#1f2937"] {
    background: #f0f9ff !important;
    border-bottom-color: #e0f2fe !important;
}
[data-theme="light"] #nodePopup #popName  { color: #1a202c !important; }
[data-theme="light"] #nodePopup #popDetails { color: #374151 !important; }
[data-theme="light"] #nodePopup div[style*="border-bottom:1px solid #1f2937"] { border-bottom-color: #e2e8f0 !important; }
[data-theme="light"] #nodePopup div[style*="border-top:1px solid #1f2937"] { border-top-color: #e2e8f0 !important; }
[data-theme="light"] #nodePopup #popDetails span[style*="color:#9ca3af"] { color: #6b7280 !important; }
[data-theme="light"] #nodePopup button[style*="background:#374151"] {
    background: #e5e7eb !important;
    color: #374151 !important;
}

/* ════════════════════════════════════════════════════
   STAKING — Success overlay
   ════════════════════════════════════════════════════ */
[data-theme="light"] #successOverlay > div {
    background: #fff !important;
    border-color: #e2e8f0 !important;
    color: #374151 !important;
}
[data-theme="light"] #successOverlay h5 { color: #1a202c !important; }
[data-theme="light"] #successOverlay #successDetails { color: #4a5568 !important; }

/* ═══════════════════════════════════════════════════════════════════════════
   GLOBAL LIGHT THEME — Hex-based dark backgrounds
   (used in my-rank, rank-rewards, and similar pages with #111827 / #1a1d21)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Panels with #111827 (near-black hex) ── */
[data-theme="light"] .page-body div[style*="background:#111827"],
[data-theme="light"] .page-body div[style*="background: #111827"] {
    background: #fff !important;
    border-color: #e2e8f0 !important;
}

/* ── Rank card body #1a1d21 ── */
[data-theme="light"] .page-body div[style*="background:#1a1d21"],
[data-theme="light"] .page-body div[style*="background: #1a1d21"] {
    background: #f8fafc !important;
}

/* ── Not-achieved rank header (gray gradient) ── */
[data-theme="light"] .page-body div[style*="linear-gradient(135deg,#374151,#4b5563)"] {
    background: #e5e7eb !important;
}

/* ── Progress bar track #374151 (inside dark panels) ── */
[data-theme="light"] .page-body div[style*="background:#374151;border-radius:4px"] {
    background: #e2e8f0 !important;
}

/* ── Dividers: border-right and border-top with #374151 / #2d3748 ── */
[data-theme="light"] .page-body div[style*="border-right:1px solid #374151"] {
    border-right-color: #e2e8f0 !important;
}
[data-theme="light"] .page-body div[style*="border-top:1px solid #2d3748"] {
    border-top-color: #e2e8f0 !important;
}
[data-theme="light"] .page-body div[style*="border:1px solid #1f2937"] {
    border-color: #e2e8f0 !important;
}

/* ── Headings using Bootstrap text-white in dark panels ── */
[data-theme="light"] .page-body h4.text-white,
[data-theme="light"] .page-body h5.text-white,
[data-theme="light"] .page-body h6.text-white { color: var(--text-primary) !important; }

/* ── div[style*="background:#1a1d21"] inner text-white (progress %) ── */
[data-theme="light"] .page-body div[style*="background:#1a1d21"] .text-white,
[data-theme="light"] .page-body div[style*="background: #1a1d21"] .text-white {
    color: #374151 !important;
}

/* ── Rank card hover dividers (1px solid #1f2937) ── */
[data-theme="light"] .page-body div[style*="border:1px solid #1f2937"] {
    border-color: #e2e8f0 !important;
}

