/* ================================================================
   GamBit Membership — Design System v2.0
   Brand Kit: Navy #0D1B3D | Royal Blue #12316D | Gold #D4AF37
   Font: Inter | Radius: 12px cards | Shadow: subtle elevation
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ── CSS Variables ── */
:root {
    /* Brand Palette */
    --navy:          #0D1B3D;
    --royal-blue:    #12316D;
    --gold:          #D4AF37;
    --gold-light:    #E8C84A;
    --gold-dark:     #B8922A;
    --white:         #FFFFFF;
    --light-gray:    #F5F7FA;
    --success:       #16A34A;
    --amber:         #F59E0B;
    --danger:        #EF4444;
    --info:          #3B82F6;

    /* Dark Theme Aliases */
    --primary-navy:  #061A2E;
    --deep-navy:     #02101F;
    --card-navy:     #0B2238;
    --card-navy-alt: #122554;
    --border-navy:   #1E3A56;
    --border-light:  #243F75;
    --gambit-gold:   #F5B21A;
    --gold-hover:    #FFC542;
    --white-text:    #FFFFFF;
    --muted-text:    #AEB8C4;
    --light-text:    #C5D3E8;
    --success-green: #22C55E;
    --warning-amber: #F59E0B;
    --danger-red:    #EF4444;

    /* Tier Colors */
    --tier-silver-color:   #B8C5D6;
    --tier-gold-color:     #D4AF37;
    --tier-platinum-color: #A8C4DC;
    --tier-diamond-color:  #7EC8E3;

    /* Spacing */
    --radius-xs: 6px;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-2xl: 24px;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-xs: 0 1px 4px rgba(0,0,0,0.25);
    --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
    --shadow-md: 0 4px 16px rgba(0,0,0,0.35);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.45);
    --shadow-gold: 0 4px 20px rgba(212,175,55,0.22);
    --glow-gold: 0 0 24px rgba(212,175,55,0.18);

    /* Transitions */
    --transition-fast: 0.15s ease;
    --transition-base: 0.22s ease;
    --transition-slow: 0.35s ease;
}

.font-bold{
    font-weight: 700;
}

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    background-color: var(--deep-navy);
    color: var(--white-text);
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
    font-size: 14px;
    line-height: 1.6;
    padding-bottom: 80px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--deep-navy); }
::-webkit-scrollbar-thumb { background: var(--border-navy); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--border-light); }

/* ── Typography ── */
h1, h2, h3, h4, h5, h6 { font-weight: 700; line-height: 1.25; }
.fw-500 { font-weight: 500; }
.fw-600 { font-weight: 600; }
.fw-700 { font-weight: 700; }
.fw-800 { font-weight: 800; }
.fw-900 { font-weight: 900; }
.text-gold         { color: var(--gambit-gold) !important; }
.text-muted-gambit { color: var(--muted-text) !important; }
.text-light-gambit { color: var(--light-text) !important; }
.bg-gold           { background-color: var(--gambit-gold) !important; }
.border-gold       { border-color: var(--gambit-gold) !important; }

/* ── Navbar (desktop) ── */
.gambit-navbar {
    background: var(--primary-navy) !important;
    border-bottom: 1px solid var(--border-navy);
    padding: 0;
    height: 64px;
}
.gambit-navbar .container {
    height: 100%;
    display: flex;
    align-items: center;
}
.navbar-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--white-text) !important;
    font-weight: 800;
    font-size: 1.05rem;
    letter-spacing: 1.5px;
    text-decoration: none;
}
.navbar-brand .brand-icon {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, var(--gambit-gold), var(--gold-dark));
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: var(--primary-navy);
    font-weight: 900;
    box-shadow: var(--shadow-gold);
    flex-shrink: 0;
}
.navbar-brand .brand-wordmark { color: var(--white-text); }
.navbar-brand .brand-sub { color: var(--muted-text); font-size: 0.65rem; font-weight: 500; letter-spacing: 2px; margin-top: 1px; }
.nav-link { color: var(--muted-text) !important; font-size: 0.875rem; font-weight: 500; transition: color var(--transition-fast); }
.nav-link:hover, .nav-link.active { color: var(--white-text) !important; }
.nav-link.active { color: var(--gambit-gold) !important; }
.dropdown-menu {
    background: var(--card-navy) !important;
    border: 1px solid var(--border-navy) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    padding: 8px !important;
    min-width: 200px;
}
.dropdown-item {
    color: var(--light-text) !important;
    border-radius: var(--radius-sm) !important;
    font-size: 0.875rem;
    padding: 8px 12px !important;
    transition: all var(--transition-fast);
}
.dropdown-item:hover { background: var(--border-navy) !important; color: var(--white-text) !important; }
.dropdown-divider { border-color: var(--border-navy) !important; }

/* Notification icon */
.nav-notif {
    position: relative;
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.05);
    border-radius: var(--radius-sm);
    color: var(--muted-text);
    font-size: 1rem;
    text-decoration: none;
    transition: all var(--transition-fast);
}
.nav-notif:hover { background: rgba(255,255,255,0.1); color: var(--white-text); }
.nav-notif .badge-dot {
    position: absolute;
    top: 5px; right: 5px;
    width: 8px; height: 8px;
    background: var(--danger-red);
    border-radius: 50%;
    border: 1.5px solid var(--primary-navy);
}

/* User avatar */
.nav-avatar {
    width: 34px; height: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(212,175,55,0.25), rgba(212,175,55,0.1));
    border: 1.5px solid var(--gambit-gold);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.8rem; font-weight: 700;
    color: var(--gambit-gold);
    cursor: pointer;
    transition: all var(--transition-fast);
}
.nav-avatar:hover { border-color: var(--gold-light); box-shadow: var(--shadow-gold); }

/* ── Mobile Top Bar ── */
.mobile-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    height: 60px;
    background: var(--primary-navy);
    border-bottom: 1px solid var(--border-navy);
    position: sticky;
    top: 0;
    z-index: 100;
}
.mobile-brand {
    display: flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
}
.mobile-brand-icon {
    width: 30px; height: 30px;
    background: linear-gradient(135deg, var(--gambit-gold), var(--gold-dark));
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: var(--primary-navy);
    font-size: 0.85rem;
    font-weight: 900;
}
.mobile-brand-text {
    font-size: 1rem;
    font-weight: 800;
    color: var(--white-text);
    letter-spacing: 1.5px;
}
.mobile-topbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}
.mobile-notif-btn {
    position: relative;
    width: 34px; height: 34px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.06);
    border-radius: var(--radius-sm);
    color: var(--muted-text);
    font-size: 1rem;
    text-decoration: none;
    transition: all var(--transition-fast);
}
.mobile-notif-btn:hover { color: var(--white-text); }
.mobile-notif-btn .notif-count {
    position: absolute;
    top: 4px; right: 4px;
    min-width: 16px; height: 16px;
    background: var(--danger-red);
    border-radius: var(--radius-full);
    border: 1.5px solid var(--primary-navy);
    font-size: 0.55rem;
    font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    padding: 0 3px;
}

/* ── Bottom Navigation ── */
.bottom-nav {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--primary-navy);
    border-top: 1px solid var(--border-navy);
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: 6px 0 max(10px, env(safe-area-inset-bottom));
    z-index: 1000;
    box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
}
.bottom-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    text-decoration: none;
    color: var(--muted-text);
    font-size: 0.6rem;
    font-weight: 500;
    letter-spacing: 0.3px;
    min-width: 52px;
    padding: 4px 0;
    border-radius: var(--radius-sm);
    transition: color var(--transition-fast);
    position: relative;
}
.bottom-nav-item i {
    font-size: 1.25rem;
    line-height: 1;
    transition: transform var(--transition-fast);
}
.bottom-nav-item.active { color: var(--gambit-gold); }
.bottom-nav-item.active i { transform: translateY(-1px); }
.bottom-nav-item:hover { color: var(--gambit-gold); }
.bottom-nav-item .nav-label { font-size: 0.6rem; }

/* Active indicator dot */
.bottom-nav-item.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%; transform: translateX(-50%);
    width: 4px; height: 4px;
    background: var(--gambit-gold);
    border-radius: 50%;
}

/* ── Page Wrapper ── */
.page-wrapper {
    max-width: 480px;
    margin: 0 auto;
    padding: 0 16px 16px;
}
@media (min-width: 992px) {
    .page-wrapper { max-width: 100%; padding: 0 28px 28px; }
    body { padding-bottom: 0; }
    .bottom-nav { display: none !important; }
    .mobile-topbar { display: none !important; }
}

/* ── Cards ── */
.gambit-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.gambit-card:hover {
    border-color: rgba(212,175,55,0.2);
    box-shadow: var(--shadow-md);
}

/* Summary Info Card (brand kit item) */
.summary-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-lg);
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all var(--transition-fast);
}
.summary-card-icon {
    width: 42px; height: 42px;
    border-radius: var(--radius-md);
    background: rgba(212,175,55,0.12);
    border: 1px solid rgba(212,175,55,0.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    color: var(--gambit-gold);
    flex-shrink: 0;
}
.summary-card-content { flex: 1; min-width: 0; }
.summary-card-label  { font-size: 0.7rem; color: var(--muted-text); text-transform: uppercase; letter-spacing: 0.5px; }
.summary-card-value  { font-size: 0.95rem; font-weight: 700; color: var(--white-text); }
.summary-card-sub    { font-size: 0.72rem; color: var(--muted-text); }
.summary-card-arrow  { color: var(--muted-text); font-size: 0.85rem; }

/* Hero/gradient card */
.hero-card {
    background: linear-gradient(145deg, #112660 0%, #0D1B3D 60%, #070F22 100%);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-xl);
    padding: 24px;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-md);
}
.hero-card::before {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(212,175,55,0.1) 0%, transparent 65%);
    border-radius: 50%;
    pointer-events: none;
}
.hero-card::after {
    content: '';
    position: absolute;
    bottom: -40px; left: -20px;
    width: 140px; height: 140px;
    background: radial-gradient(circle, rgba(18,49,109,0.5) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

/* Featured benefit card */
.benefit-card {
    background: linear-gradient(135deg, var(--royal-blue) 0%, var(--primary-navy) 100%);
    border: 1px solid rgba(212,175,55,0.2);
    border-radius: var(--radius-lg);
    padding: 20px;
    position: relative;
    overflow: hidden;
}
.benefit-card::before {
    content: 'G';
    position: absolute;
    right: -20px; bottom: -20px;
    font-size: 8rem;
    font-weight: 900;
    color: rgba(255,255,255,0.04);
    line-height: 1;
    pointer-events: none;
    font-family: 'Inter', sans-serif;
}

/* Content teaser card */
.content-teaser-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    gap: 0;
    transition: all var(--transition-base);
}
.content-teaser-card:hover { border-color: rgba(212,175,55,0.3); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.content-teaser-img {
    width: 90px; min-width: 90px;
    background: linear-gradient(135deg, var(--royal-blue), var(--primary-navy));
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    flex-shrink: 0;
}
.content-teaser-body { padding: 12px 14px; flex: 1; min-width: 0; }
.content-teaser-tag  { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: var(--gambit-gold); }
.content-teaser-title { font-size: 0.875rem; font-weight: 600; color: var(--white-text); margin: 3px 0 4px; line-height: 1.35; }
.content-teaser-meta  { font-size: 0.72rem; color: var(--muted-text); }

/* CTA Promo card */
.promo-card {
    background: linear-gradient(145deg, var(--royal-blue) 0%, #0A1E50 100%);
    border: 1px solid rgba(212,175,55,0.25);
    border-radius: var(--radius-lg);
    padding: 20px;
    position: relative;
    overflow: hidden;
}

/* Empty state card */
.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    text-align: center;
}
.empty-state-icon {
    width: 64px; height: 64px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-xl);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    color: var(--muted-text);
    margin-bottom: 16px;
}
.empty-state-title { font-size: 0.95rem; font-weight: 600; color: #E8EDF5; margin-bottom: 6px; }
.empty-state-sub   { font-size: 0.82rem; color: #C5D3E8; }

/* Tier cards */
.tier-card-silver {
    background: linear-gradient(135deg, #1A2A40 0%, #111D33 100%);
    border: 1px solid rgba(184,197,214,0.3);
    border-radius: var(--radius-lg);
    padding: 20px;
}
.tier-card-gold {
    background: linear-gradient(135deg, #2A2000 0%, #1A1400 100%);
    border: 1px solid rgba(212,175,55,0.35);
    border-radius: var(--radius-lg);
    padding: 20px;
}
.tier-card-platinum {
    background: linear-gradient(135deg, #162040 0%, #0E1630 100%);
    border: 1px solid rgba(168,196,220,0.35);
    border-radius: var(--radius-lg);
    padding: 20px;
}
.tier-card-diamond {
    background: linear-gradient(135deg, #0E2240 0%, #081630 100%);
    border: 1px solid rgba(126,200,227,0.4);
    border-radius: var(--radius-lg);
    padding: 20px;
}

/* Stat cards */
.stat-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}
.stat-number { font-size: 1.75rem; font-weight: 800; margin-bottom: 0; line-height: 1.2; }

/* ── Points Display ── */
.points-display {
    font-size: 2.4rem;
    font-weight: 800;
    color: var(--gambit-gold)!important;
    line-height: 1;
    letter-spacing: -0.5px;
}
.points-small {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--gambit-gold)!important;
    letter-spacing: -0.3px;
}

/* Reward Points Pill (brand kit component) */
.points-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(212,175,55,0.12);
    border: 1px solid rgba(212,175,55,0.3);
    border-radius: var(--radius-full);
    padding: 8px 16px 8px 10px;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-decoration: none;
    box-shadow: var(--shadow-xs);
}
.points-pill:hover { background: rgba(212,175,55,0.2); border-color: rgba(212,175,55,0.5); box-shadow: var(--shadow-gold); }
.points-pill-icon {
    width: 30px; height: 30px;
    background: linear-gradient(135deg, var(--gambit-gold), var(--gold-dark));
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--primary-navy);
    font-size: 0.85rem;
    flex-shrink: 0;
}
.points-pill-value { font-size: 0.9rem; font-weight: 700; color: var(--white-text); }
.points-pill-label { font-size: 0.72rem; color: var(--muted-text); }
.points-pill-arrow { color: var(--muted-text); font-size: 0.75rem; margin-left: 2px; }

/* ── Buttons ── */
.btn-gold {
    background: linear-gradient(135deg, var(--gambit-gold) 0%, var(--gold-dark) 100%);
    color: var(--primary-navy);
    font-weight: 700;
    font-size: 0.875rem;
    border: none;
    border-radius: var(--radius-md);
    padding: 10px 22px;
    transition: all var(--transition-fast);
    box-shadow: 0 2px 8px rgba(212,175,55,0.3);
    letter-spacing: 0.2px;
}
.btn-gold:hover {
    background: linear-gradient(135deg, var(--gold-light) 0%, var(--gambit-gold) 100%);
    color: var(--primary-navy);
    box-shadow: 0 4px 16px rgba(212,175,55,0.4);
    transform: translateY(-1px);
}
.btn-gold:active { transform: translateY(0); box-shadow: 0 2px 8px rgba(212,175,55,0.3); }

.btn-outline-gold {
    border: 1.5px solid rgba(212,175,55,0.6);
    color: var(--gambit-gold);
    background: transparent;
    /* border-radius: var(--radius-md); */
    font-weight: 600;
    font-size: 0.875rem;
    /* padding: 9px 20px; */
    transition: all var(--transition-fast);
}
.btn-outline-gold:hover {
    background: rgba(212,175,55,0.1);
    border-color: var(--gambit-gold);
    color: var(--gambit-gold);
    box-shadow: 0 2px 10px rgba(212,175,55,0.15);
}

.btn-navy {
    background: var(--card-navy);
    color: var(--light-text);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-md);
    font-weight: 500;
    font-size: 0.875rem;
    padding: 9px 20px;
    transition: all var(--transition-fast);
}
.btn-navy:hover { border-color: var(--border-light); color: var(--white-text); background: var(--card-navy-alt); }

.btn-royal {
    background: var(--royal-blue);
    color: var(--white-text);
    border: none;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 0.875rem;
    padding: 10px 22px;
    transition: all var(--transition-fast);
}
.btn-royal:hover { background: #163d85; color: var(--white-text); }

/* ── Quick Action Grid ── */
.quick-action {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: var(--white-text);
    transition: transform var(--transition-fast);
}
.quick-action:hover { transform: translateY(-2px); }
.quick-action-icon {
    width: 56px; height: 56px;
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem;
    color: var(--gambit-gold);
    transition: all var(--transition-fast);
    box-shadow: var(--shadow-xs);
}
.quick-action:hover .quick-action-icon {
    background: rgba(212,175,55,0.1);
    border-color: rgba(212,175,55,0.4);
    box-shadow: var(--shadow-gold);
}
.quick-action .nav-label {
    font-size: 0.68rem;
    font-weight: 600;
    color: #C5D3E8;
    text-align: center;
}
body.member-theme .quick-action .nav-label { color: var(--primary-navy);}

/* ── Forms ── */
.gambit-input {
    background: rgba(13,27,61,0.8) !important;
    border: 1.5px solid var(--border-navy) !important;
    color: var(--white-text) !important;
    border-radius: var(--radius-md) !important;
    padding: 11px 14px !important;
    font-size: 0.875rem !important;
    font-family: inherit !important;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
}
.gambit-input:focus {
    border-color: var(--gambit-gold) !important;
    box-shadow: 0 0 0 3px rgba(212,175,55,0.12) !important;
    /* background: rgba(18,37,84,0.9) !important; */
    outline: none !important;
}
.gambit-input::placeholder { color: var(--muted-text) !important; }
.gambit-input option { background: var(--card-navy); color: var(--white-text); }
.form-label { color: #C5D3E8; font-size: 0.8rem; font-weight: 500; margin-bottom: 6px; }
.form-text  { color: #9FB3CC; font-size: 0.75rem; }
body.member-theme .form-label { color: #C5D3E8; }

/* Search bar (brand kit style) */
.search-bar-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.search-bar-wrap .search-icon {
    position: absolute;
    left: 12px;
    color: var(--muted-text);
    font-size: 0.9rem;
    pointer-events: none;
}
.search-bar-wrap .gambit-input {
    padding-left: 36px !important;
}
.search-bar-wrap .search-filter-btn {
    position: absolute;
    right: 10px;
    background: none;
    border: none;
    color: var(--muted-text);
    font-size: 0.9rem;
    cursor: pointer;
    padding: 4px;
    transition: color var(--transition-fast);
}
.search-bar-wrap .search-filter-btn:hover { color: var(--gambit-gold); }

/* ── Tables ── */
.gambit-table { color: var(--white-text); border-collapse: separate; border-spacing: 0; }
.gambit-table thead th {
    background: rgba(13,27,61,0.8);
    color: var(--gambit-gold);
    border-bottom: 1px solid var(--border-navy);
    border-top: none;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    padding: 10px 14px;
    white-space: nowrap;
}
.gambit-table tbody td {
    border-bottom: 1px solid rgba(30,58,110,0.6);
    vertical-align: middle;
    padding: 12px 14px;
    font-size: 0.875rem;
}
.gambit-table tbody tr:last-child td { border-bottom: none; }
.gambit-table tbody tr { transition: background var(--transition-fast); }
.gambit-table tbody tr:hover { background: rgba(212,175,55,0.03); }

/* ── Tier Badges — brightened for readability on dark navy ── */
.tier-badge-bronze {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(212,161,65,0.18); color: #E5A94D;
    border: 1px solid rgba(212,161,65,0.45);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 700; white-space: nowrap;
}
.tier-badge-silver {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(197,211,232,0.18); color: var(--primary-navy);
    border: 1px solid rgba(197,211,232,0.45);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 700; white-space: nowrap;
}
.tier-badge-gold {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(212,175,55,0.2); color: #F0C040;
    border: 1px solid rgba(212,175,55,0.5);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 700; white-space: nowrap;
}
.tier-badge-platinum {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(180,210,235,0.18); color: #C8E0F4;
    border: 1px solid rgba(180,210,235,0.45);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 700; white-space: nowrap;
}
.tier-badge-diamond {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(126,200,227,0.2); color: #A8E4F5;
    border: 1px solid rgba(126,200,227,0.45);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 700; white-space: nowrap;
}

/* ── Status Chips (brand kit) ── */
.chip-published, .chip-active {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(22,163,74,0.12); color: #22C55E;
    border: 1px solid rgba(22,163,74,0.3);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 600;
}
.chip-published::before, .chip-active::before {
    content: ''; width: 6px; height: 6px;
    background: #22C55E; border-radius: 50%;
}
.chip-draft, .chip-pending {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(245,158,11,0.12); color: #F59E0B;
    border: 1px solid rgba(245,158,11,0.3);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 600;
}
.chip-draft::before, .chip-pending::before {
    content: ''; width: 6px; height: 6px;
    background: #F59E0B; border-radius: 50%;
}
.chip-scheduled, .chip-info {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(59,130,246,0.12); color: #60A5FA;
    border: 1px solid rgba(59,130,246,0.3);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 600;
}
.chip-expired, .chip-danger, .chip-rejected {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(239,68,68,0.12); color: #EF4444;
    border: 1px solid rgba(239,68,68,0.3);
    padding: 3px 10px; border-radius: var(--radius-full);
    font-size: 0.72rem; font-weight: 600;
}

/* ── Segmented Tabs (brand kit) ── */
.segmented-tabs {
    display: inline-flex;
    background: rgba(13,27,61,0.8);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-md);
    padding: 3px;
    gap: 2px;
}
.segmented-tabs .seg-tab {
    padding: 6px 16px;
    border-radius: var(--radius-sm);
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--muted-text);
    cursor: pointer;
    transition: all var(--transition-fast);
    border: none;
    background: none;
    white-space: nowrap;
    text-decoration: none;
    display: inline-block;
}
.segmented-tabs .seg-tab.active,
.segmented-tabs .seg-tab:hover.active {
    background: var(--royal-blue);
    color: var(--white-text);
    font-weight: 600;
}
.segmented-tabs .seg-tab:hover:not(.active) { color: var(--light-text); }

/* ── Filter Chips (brand kit) ── */
.filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}
.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-navy);
    background: transparent;
    color: var(--muted-text);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    white-space: nowrap;
    text-decoration: none;
}
.filter-chip:hover { border-color: var(--border-light); color: var(--light-text); }
.filter-chip.active {
    background: var(--royal-blue);
    border-color: var(--royal-blue);
    color: var(--white-text);
    font-weight: 600;
}
.filter-chip.active i { font-size: 0.75rem; }
.filter-chip-more {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 14px;
    border-radius: var(--radius-full);
    border: 1px dashed var(--border-navy);
    background: transparent;
    color: var(--muted-text);
    font-size: 0.82rem;
    cursor: pointer;
}

/* ── Gambit Tabs (category style) ── */
.gambit-tabs {
    border-bottom: 1px solid var(--border-navy);
    margin-bottom: 20px;
    display: flex;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
}
.gambit-tabs::-webkit-scrollbar { display: none; }
.gambit-tabs .nav-link {
    color: var(--muted-text);
    border: none;
    border-bottom: 2px solid transparent;
    background: none;
    padding: 10px 18px;
    font-size: 0.875rem;
    font-weight: 500;
    white-space: nowrap;
    transition: all var(--transition-fast);
}
.gambit-tabs .nav-link.active {
    color: var(--gambit-gold);
    border-bottom-color: var(--gambit-gold);
    background: none;
    font-weight: 600;
}
.gambit-tabs .nav-link:hover:not(.active) { color: var(--light-text); }

/* ── Progress Bars ── */
.progress {
    background: rgba(30,58,110,0.5);
    border-radius: var(--radius-full);
    overflow: hidden;
}
.progress-bar { border-radius: var(--radius-full); transition: width 0.6s ease; }
.progress-bar.bg-gold { background: linear-gradient(90deg, var(--gambit-gold), var(--gold-light)) !important; }
.progress-bar.bg-silver { background: linear-gradient(90deg, #8FA3C0, #B8C5D6) !important; }

/* ── Transaction Rows ── */
.transaction-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 13px 0;
    border-bottom: 1px solid rgba(30,58,110,0.5);
}
.transaction-row:last-child { border-bottom: none; }
.transaction-icon {
    width: 42px; height: 42px;
    border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.05rem;
    flex-shrink: 0;
    border: 1px solid transparent;
}
.transaction-icon.earn    { background: rgba(22,163,74,0.18);  color: #22C55E; border-color: rgba(22,163,74,0.25); }
.transaction-icon.redeem  { background: rgba(239,68,68,0.18);  color: #F87171; border-color: rgba(239,68,68,0.25); }
.transaction-icon.adjust  { background: rgba(212,175,55,0.2);  color: #D4AF37; border-color: rgba(212,175,55,0.3);  }
.transaction-icon.expire  { background: rgba(156,163,175,0.18);color: #9CA3AF; border-color: rgba(156,163,175,0.25);}
.transaction-icon.reverse { background: rgba(59,130,246,0.18); color: #60A5FA; border-color: rgba(59,130,246,0.25); }
.transaction-icon.bonus   { background: rgba(59,130,246,0.18); color: #60A5FA; border-color: rgba(59,130,246,0.25); }

/* ── Content Cards ── */
.content-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);
}
.content-card:hover {
    transform: translateY(-3px);
    border-color: rgba(212,175,55,0.25);
    box-shadow: var(--shadow-md);
}
.content-card-img {
    height: 140px;
    background: linear-gradient(145deg, var(--royal-blue) 0%, var(--primary-navy) 100%);
    display: flex; align-items: center; justify-content: center;
    font-size: 2.2rem;
    position: relative;
    overflow: hidden;
}
.content-card-img::before {
    content: 'G';
    position: absolute;
    right: -15px; bottom: -15px;
    font-size: 5rem; font-weight: 900;
    color: rgba(255,255,255,0.05);
    font-family: 'Inter', sans-serif;
}
.content-locked-overlay {
    position: absolute;
    inset: 0;
    background: rgba(7,15,34,0.88);
    backdrop-filter: blur(2px);
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--radius-lg);
    z-index: 2;
}

/* ── Reward Cards ── */
.reward-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-lg);
    padding: 18px;
    transition: all var(--transition-base);
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-xs);
}
.reward-card:hover { border-color: rgba(212,175,55,0.35); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.reward-card.can-redeem { border-color: rgba(212,175,55,0.25); }
.reward-pts-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(212,175,55,0.12);
    border: 1px solid rgba(212,175,55,0.3);
    color: var(--gambit-gold);
    border-radius: var(--radius-sm);
    padding: 4px 10px;
    font-size: 0.78rem;
    font-weight: 700;
}
.reward-thumbnail {
    height: 72px;
    background: linear-gradient(145deg, var(--royal-blue) 0%, var(--primary-navy) 100%);
    border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem;
    margin-bottom: 14px;
    position: relative;
    overflow: hidden;
}

/* ── Notifications ── */
.notif-item {
    padding: 14px 16px;
    border-bottom: 1px solid rgba(30,58,110,0.5);
    transition: background var(--transition-fast);
}
.notif-item.unread {
    background: rgba(212,175,55,0.04);
    border-left: 3px solid var(--gambit-gold);
    padding-left: 13px;
}
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: rgba(255,255,255,0.02); }

/* Notification badge */
.notif-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px; height: 20px;
    background: var(--danger-red);
    border-radius: var(--radius-full);
    font-size: 0.65rem;
    font-weight: 700;
    color: #fff;
    padding: 0 5px;
}

/* ── Alerts ── */
.alert { border-radius: var(--radius-md); font-size: 0.875rem; }
.alert-success { background: rgba(22,163,74,0.1);  border-color: rgba(22,163,74,0.25);  color: #86EFAC; }
.alert-danger  { background: rgba(239,68,68,0.1);  border-color: rgba(239,68,68,0.25);  color: #FCA5A5; }
.alert-warning { background: rgba(245,158,11,0.1); border-color: rgba(245,158,11,0.25); color: #FCD34D; }
.alert-info    { background: rgba(59,130,246,0.1); border-color: rgba(59,130,246,0.25); color: #93C5FD; }
.btn-close-white { filter: invert(1) brightness(0.7); }

/* ── Auth Pages ── */
.auth-wrapper {
    min-height: 100vh;
    background: radial-gradient(ellipse at 30% 20%, rgba(18,49,109,0.4) 0%, var(--deep-navy) 60%);
    display: flex; align-items: center; justify-content: center;
    padding: 24px 16px;
}
.auth-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-2xl);
    padding: 40px 32px;
    width: 100%;
    max-width: 420px;
    box-shadow: var(--shadow-lg);
}
.auth-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-bottom: 32px;
}
.auth-logo-icon {
    width: 56px; height: 56px;
    background: linear-gradient(135deg, var(--gambit-gold), var(--gold-dark));
    border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem;
    color: var(--primary-navy);
    font-weight: 900;
    box-shadow: var(--shadow-gold);
}
.auth-logo-text {
    text-align: center;
}
.auth-logo-wordmark {
    font-size: 1.3rem;
    font-weight: 900;
    letter-spacing: 3px;
    color: var(--white-text);
    line-height: 1;
}
.auth-logo-sub {
    font-size: 0.65rem;
    color: var(--muted-text);
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin-top: 3px;
}

/* ── Welcome Page ── */
.welcome-hero {
    min-height: 100vh;
    background:
        radial-gradient(ellipse at 25% 15%, rgba(18,49,109,0.5) 0%, transparent 50%),
        radial-gradient(ellipse at 75% 85%, rgba(212,175,55,0.06) 0%, transparent 50%),
        var(--deep-navy);
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    padding: 48px 24px;
}
.welcome-logo {
    font-size: 3rem;
    font-weight: 900;
    letter-spacing: 5px;
    color: var(--gambit-gold);
    text-shadow: var(--glow-gold);
}
.welcome-tagline {
    color: var(--muted-text);
    font-size: 0.95rem;
    margin-top: 8px;
    margin-bottom: 48px;
    letter-spacing: 0.3px;
}

/* ── Section Headers ── */
.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
}
.section-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--white-text);
}
.section-link {
    font-size: 0.78rem;
    color: var(--gambit-gold);
    text-decoration: none;
    font-weight: 500;
    transition: opacity var(--transition-fast);
}
.section-link:hover { opacity: 0.8; color: var(--gambit-gold); }

/* ── Checklist Items ── */
.checklist-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 0;
    border-bottom: 1px solid rgba(30,58,110,0.5);
}
.checklist-item:last-child { border-bottom: none; }
.checklist-status-done    { color: var(--success-green); font-size: 0.78rem; font-weight: 600; }
.checklist-status-pending { color: var(--warning-amber); font-size: 0.78rem; font-weight: 600; }

/* Legacy checklist states (brand kit) */
.legacy-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-md);
    margin-bottom: 8px;
    transition: all var(--transition-fast);
}
.legacy-item:hover { border-color: var(--border-light); }
.legacy-item-icon {
    width: 36px; height: 36px;
    border-radius: var(--radius-sm);
    background: rgba(18,49,109,0.5);
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    color: var(--gambit-gold);
    flex-shrink: 0;
}
.legacy-item-status {
    margin-left: auto;
    font-size: 0.72rem;
    font-weight: 600;
}
.legacy-item-status.completed { color: var(--success-green); }
.legacy-item-status.in-progress { color: var(--warning-amber); }
.legacy-item-status.pending { color: var(--muted-text); }

/* ── Text Helpers ── */
.text-muted-gambit { color: var(--muted-text) !important; }
.text-gold         { color: var(--gambit-gold) !important; }
.text-light-gambit { color: var(--light-text) !important; }

/* ── Modals ── */
.modal-content {
    background: var(--card-navy) !important;
    border: 1px solid var(--border-navy) !important;
    border-radius: var(--radius-xl) !important;
    box-shadow: var(--shadow-lg) !important;
}
.modal-header { padding: 20px 24px; border-bottom: 1px solid var(--border-navy) !important; }
.modal-body   { padding: 24px; }
.modal-footer { padding: 16px 24px; border-top: 1px solid var(--border-navy) !important; }
.modal-title  { font-size: 1rem; font-weight: 700; color: var(--gambit-gold); }

/* ── Badges ── */
.badge { font-size: 0.7rem; font-weight: 600; }

/* Quick stats cards (brand kit) */
.quick-stat-card {
    background: var(--card-navy);
    border: 1px solid var(--border-navy);
    border-radius: var(--radius-lg);
    padding: 16px 18px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    box-shadow: var(--shadow-xs);
}
.quick-stat-icon-wrap {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: rgba(18,49,109,0.5);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}
.quick-stat-label { font-size: 0.7rem; color: var(--muted-text); text-transform: uppercase; letter-spacing: 0.4px; }
.quick-stat-value { font-size: 1.1rem; font-weight: 800; color: var(--white-text); margin: 2px 0; }
.quick-stat-growth { font-size: 0.72rem; font-weight: 600; }
.quick-stat-growth.up   { color: var(--success-green); }
.quick-stat-growth.down { color: var(--danger-red); }

/* ================================================================
   MEMBER PORTAL — LIGHT THEME
   Applied via body.member-theme (set in layouts/app.blade.php)
   Navbars, hero cards, tier cards, and benefit cards stay dark.
   Everything else uses a clean white/light-gray surface.
   ================================================================ */

/* ── Page base ── */
body.member-theme {
    background: #F5F7FA;
    color: #0D1B3D;
}

/* ── Global text override: dark on light/white backgrounds ── */
body.member-theme .text-white            { color: var(--primary-navy) !important; }
body.member-theme .text-muted-gambit     { color: var(--primary-navy) !important; }
body.member-theme .text-light-gambit     { color: #2D4A6E !important; }

/* ── Re-whitify text inside explicitly DARK surfaces ── */
body.member-theme .hero-card .text-white,
body.member-theme .hero-card p,
body.member-theme .hero-card small,
body.member-theme .hero-card span:not(.tier-badge-bronze):not(.tier-badge-silver):not(.tier-badge-gold):not(.tier-badge-platinum):not(.tier-badge-diamond) {
    color: #FFFFFF !important;
}
body.member-theme .hero-card .text-muted-gambit { color: rgba(255,255,255,0.6) !important; }
body.member-theme .hero-card .text-gold         { color: var(--gambit-gold) !important; }
body.member-theme .hero-card .points-display    { color: var(--gambit-gold) !important; }

body.member-theme .tier-card-gold .text-white,
body.member-theme .tier-card-gold p,
body.member-theme .tier-card-gold small       { color: #FFFFFF !important; }
body.member-theme .tier-card-gold .text-muted-gambit { color: rgba(255,255,255,0.6) !important; }

body.member-theme .tier-card-silver .text-white,
body.member-theme .tier-card-silver p,
body.member-theme .tier-card-silver small     { color: #FFFFFF !important; }
body.member-theme .tier-card-silver .text-muted-gambit { color: rgba(255,255,255,0.6) !important; }

body.member-theme .tier-card-platinum .text-white,
body.member-theme .tier-card-platinum p,
body.member-theme .tier-card-platinum small   { color: #FFFFFF !important; }

body.member-theme .tier-card-diamond .text-white,
body.member-theme .tier-card-diamond p,
body.member-theme .tier-card-diamond small    { color: #FFFFFF !important; }

body.member-theme .benefit-card .text-white,
body.member-theme .benefit-card p,
body.member-theme .benefit-card small         { color: #FFFFFF !important; }
body.member-theme .benefit-card .text-muted-gambit { color: rgba(255,255,255,0.65) !important; }

body.member-theme .promo-card .text-white,
body.member-theme .promo-card p,
body.member-theme .promo-card small           { color: #FFFFFF !important; }

/* Points pill stays on dark background - keep white text */
body.member-theme .points-pill .points-pill-value { color: #0D1B3D !important; }
body.member-theme .points-pill .points-pill-label { color: #5B7FA8 !important; }

/* ── Cards ── */
body.member-theme .gambit-card {
    background: #FFFFFF;
    border: 1px solid #DDE6F5;
    box-shadow: 0 2px 12px rgba(13,27,61,0.06);
    color: #0D1B3D;
}
body.member-theme .gambit-card:hover {
    border-color: rgba(212,175,55,0.3);
    box-shadow: 0 4px 20px rgba(13,27,61,0.1);
}
body.member-theme .gambit-card .text-white        { color: #0D1B3D !important; }
body.member-theme .gambit-card .text-muted-gambit { color: #5B7FA8 !important; }
body.member-theme .gambit-card .text-gold         { color: var(--gambit-gold) !important; }

/* Summary card */
body.member-theme .summary-card {
    background: #FFFFFF;
    border-color: #DDE6F5;
    color: #0D1B3D;
}
body.member-theme .summary-card .summary-card-label { color: #5B7FA8; }
body.member-theme .summary-card .summary-card-value { color: #0D1B3D; }
body.member-theme .summary-card .summary-card-sub   { color: #5B7FA8; }
body.member-theme .summary-card .summary-card-arrow { color: #8FA3C0; }

/* Reward cards */
body.member-theme .reward-card {
    background: #FFFFFF;
    border-color: #DDE6F5;
    color: #0D1B3D;
    box-shadow: 0 2px 8px rgba(13,27,61,0.06);
}
body.member-theme .reward-card:hover  { border-color: rgba(212,175,55,0.4); box-shadow: 0 4px 16px rgba(13,27,61,0.1); }
body.member-theme .reward-card .text-white        { color: #0D1B3D !important; }
body.member-theme .reward-card .text-muted-gambit { color: #5B7FA8 !important; }
body.member-theme .reward-thumbnail {
    background: linear-gradient(145deg, #EEF3FF 0%, #F5F7FA 100%);
}
body.member-theme .reward-thumbnail i { color: var(--gambit-gold); }

/* Content cards */
body.member-theme .content-card {
    background: #FFFFFF;
    border-color: #DDE6F5;
}
body.member-theme .content-card:hover { border-color: rgba(212,175,55,0.3); box-shadow: 0 4px 16px rgba(13,27,61,0.1); }
body.member-theme .content-card .text-white        { color: #0D1B3D !important; }
body.member-theme .content-card .text-muted-gambit { color: #5B7FA8 !important; }
body.member-theme .content-card-img {
    background: linear-gradient(145deg, #EEF3FF 0%, #F0F5FF 100%);
}

/* Content teaser card */
body.member-theme .content-teaser-card { background: #FFFFFF; border-color: #DDE6F5; }
body.member-theme .content-teaser-img  { background: linear-gradient(135deg, #EEF3FF, #F5F7FA); }
body.member-theme .content-teaser-title { color: #0D1B3D !important; }
body.member-theme .content-teaser-meta  { color: #5B7FA8 !important; }

/* Quick stat cards */
body.member-theme .quick-stat-card {
    background: #FFFFFF;
    border-color: #DDE6F5;
    box-shadow: 0 2px 8px rgba(13,27,61,0.06);
}
body.member-theme .quick-stat-icon-wrap { background: #EEF3FF; }
body.member-theme .quick-stat-label { color: #5B7FA8; }
body.member-theme .quick-stat-value { color: #0D1B3D; }

/* Legacy items */
body.member-theme .legacy-item {
    background: #FFFFFF;
    border-color: #DDE6F5;
}
body.member-theme .legacy-item:hover { border-color: #C8D5EE; }
body.member-theme .legacy-item-icon  { background: #EEF3FF; }

/* ── Tables ── */
body.member-theme .gambit-table { color: #0D1B3D; }
body.member-theme .gambit-table thead th {
    background: #F0F5FF;
    border-bottom-color: #DDE6F5;
    color: var(--gambit-gold);
}
body.member-theme .gambit-table tbody td {
    color: #0D1B3D;
    border-bottom-color: #EEF3FF;
}
body.member-theme .gambit-table tbody tr:hover { background: rgba(13,27,61,0.02) !important; }
body.member-theme .gambit-table .text-white { color: #0D1B3D !important; }
body.member-theme .gambit-table .text-muted-gambit { color: #5B7FA8 !important; }

/* ── Forms ── */
body.member-theme .gambit-input {
    background: #FFFFFF !important;
    border-color: #C8D5EE !important;
    color: #0D1B3D !important;
}
body.member-theme .gambit-input:focus {
    border-color: var(--gambit-gold) !important;
    box-shadow: 0 0 0 3px rgba(212,175,55,0.12) !important;
    background: #FFFFFF !important;
}
body.member-theme .gambit-input::placeholder { color: #8FA3C0 !important; }
body.member-theme .gambit-input option { background: #FFFFFF; color: #0D1B3D; }
body.member-theme .form-label { color: #3D5A8A; }

/* ── Section headers ── */
body.member-theme .section-title { color: #0D1B3D; }
body.member-theme .section-link  { color: var(--gambit-gold); }

/* ── Transaction rows ── */
body.member-theme .transaction-row { border-bottom-color: #EEF3FF; }
body.member-theme .transaction-row .text-white { color: #0D1B3D !important; }
body.member-theme .transaction-row .text-muted-gambit { color: #5B7FA8 !important; }
body.member-theme .transaction-icon.earn   { background: rgba(22,163,74,0.2);  color: #4ADE80; border-color: rgba(22,163,74,0.3); }
body.member-theme .transaction-icon.redeem { background: rgba(239,68,68,0.2);  color: #FCA5A5; border-color: rgba(239,68,68,0.3); }
body.member-theme .transaction-icon.adjust { background: rgba(212,175,55,0.2); color: #F0C040; border-color: rgba(212,175,55,0.3); }
body.member-theme .transaction-icon.expire { background: rgba(156,163,175,0.2);color: #D1D5DB; border-color: rgba(156,163,175,0.3); }
body.member-theme .transaction-icon.reverse{ background: rgba(96,165,250,0.2); color: #93C5FD; border-color: rgba(96,165,250,0.3); }

/* ── Notifications ── */
body.member-theme .notif-item { border-bottom-color: #EEF3FF; }
body.member-theme .notif-item:hover { background: #F8FAFD; }
body.member-theme .notif-item.unread {
    background: rgba(212,175,55,0.04);
    border-left-color: var(--gambit-gold);
}
body.member-theme .notif-item .text-white        { color: #0D1B3D !important; }
body.member-theme .notif-item .text-muted-gambit { color: #5B7FA8 !important; }

/* ── Tabs ── */
body.member-theme .gambit-tabs { border-bottom-color: #DDE6F5; }
body.member-theme .gambit-tabs .nav-link { color: #5B7FA8; }
body.member-theme .gambit-tabs .nav-link.active { color: var(--gambit-gold); border-bottom-color: var(--gambit-gold); }
body.member-theme .gambit-tabs .nav-link:hover:not(.active) { color: #0D1B3D; }

/* Filter chips on light background */
body.member-theme .filter-chip {
    border-color: #C8D5EE;
    color: #5B7FA8;
    background: #FFFFFF;
}
body.member-theme .filter-chip:hover  { border-color: #8FA3C0; color: #0D1B3D; }
body.member-theme .filter-chip.active { background: var(--royal-blue); border-color: var(--royal-blue); color: #FFFFFF; }

/* Segmented tabs on light background */
body.member-theme .segmented-tabs { background: #F0F5FF; border-color: #DDE6F5; }

/* ── Progress bars ── */
body.member-theme .progress { background: #DDE6F5; }

/* ── Checklist ── */
body.member-theme .checklist-item { border-bottom-color: #EEF3FF; }
body.member-theme .checklist-item .text-white { color: #FFFFFF !important; }

/* ── Modals ── */
body.member-theme .modal-content {
    background: #FFFFFF !important;
    border-color: #DDE6F5 !important;
    box-shadow: 0 16px 48px rgba(13,27,61,0.15) !important;
}
body.member-theme .modal-content .text-white        { color: #0D1B3D !important; }
body.member-theme .modal-content .text-muted-gambit { color: #5B7FA8 !important; }
body.member-theme .modal-header { border-bottom-color: #EEF3FF !important; }
body.member-theme .modal-footer { border-top-color: #EEF3FF !important; }
body.member-theme .modal-title  { color: var(--navy) !important; }

/* ── Dropdown menus ── */
body.member-theme .dropdown-menu {
    background: #FFFFFF !important;
    border-color: #DDE6F5 !important;
    box-shadow: 0 8px 24px rgba(13,27,61,0.12) !important;
}
body.member-theme .dropdown-item              { color: #0D1B3D !important; }
body.member-theme .dropdown-item:hover        { background: #F0F5FF !important; color: #0D1B3D !important; }
body.member-theme .dropdown-divider           { border-color: #EEF3FF !important; }
body.member-theme .dropdown-item[style*="danger"] { color: var(--danger-red) !important; }

/* ── Auth card on light page ── */
body.member-theme .auth-wrapper { background: #F5F7FA; }
body.member-theme .auth-card {
    background: #FFFFFF;
    border-color: #DDE6F5;
    box-shadow: 0 4px 24px rgba(13,27,61,0.1);
}
body.member-theme .auth-card .text-white        { color: #0D1B3D !important; }
body.member-theme .auth-card .text-muted-gambit { color: #5B7FA8 !important; }
body.member-theme .auth-card h4 { color: #0D1B3D; }

/* Welcome page */
body.member-theme .feature-card {
    background: #FFFFFF;
    border-color: #DDE6F5;
    box-shadow: 0 2px 8px rgba(13,27,61,0.06);
}
body.member-theme .feature-card:hover { border-color: rgba(212,175,55,0.35); }
body.member-theme .feature-card h5 { color: #0D1B3D; }
body.member-theme .feature-card p  { color: #5B7FA8; }

/* ── Alerts on light bg ── */
body.member-theme .alert-success { background: rgba(22,163,74,0.08);  border-color: rgba(22,163,74,0.2);  color: #15803D; }
body.member-theme .alert-danger  { background: rgba(239,68,68,0.08);  border-color: rgba(239,68,68,0.2);  color: #B91C1C; }
body.member-theme .alert-warning { background: rgba(245,158,11,0.08); border-color: rgba(245,158,11,0.2); color: #B45309; }
body.member-theme .alert-info    { background: rgba(59,130,246,0.08); border-color: rgba(59,130,246,0.2); color: #1D4ED8; }

/* ── Code elements ── */
body.member-theme code {
    background: #EEF3FF;
    color: var(--royal-blue);
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.82rem;
}

/* Keep dark navbars/bars intact in light theme */
body.member-theme .gambit-navbar   { background: var(--primary-navy) !important; }
body.member-theme .mobile-topbar   { background: var(--primary-navy); }
body.member-theme .bottom-nav      { background: var(--primary-navy); }
body.member-theme .gambit-navbar .text-white  { color: #FFFFFF !important; }
body.member-theme .mobile-topbar .text-white  { color: #FFFFFF !important; }
body.member-theme .mobile-topbar p,
body.member-theme .mobile-topbar span         { color: #12316D !important; }

/* ── Responsive ── */
@media (max-width: 768px) {
    .points-display { font-size: 1.9rem; }
    .stat-number    { font-size: 1.5rem; }
    .auth-card      { padding: 28px 20px; }
    .hero-card      { padding: 18px; }
    .segmented-tabs { overflow-x: auto; scrollbar-width: none; }
    .segmented-tabs::-webkit-scrollbar { display: none; }
}

@media (max-width: 380px) {
    .points-display { font-size: 1.6rem; }
    .quick-action-icon { width: 48px; height: 48px; font-size: 1.1rem; }
}

/* ═══════════════════════════════════════════════════════════════
   ADMIN PORTAL — LIGHT/DARK ADAPTIVE TEXT OVERRIDES
   Ensures text is always readable regardless of theme
═══════════════════════════════════════════════════════════════ */

/* In admin light mode, .text-white & .text-muted-gambit (dark portal colours)
   become dark enough to be readable on white cards */
body:not([data-theme="dark"]) .argon-card .text-white,
body:not([data-theme="dark"]) .argon-stat-card .text-white,
body:not([data-theme="dark"]) table.dataTable .text-white,
body:not([data-theme="dark"]) .gambit-table .text-white {
    color: #1A2B4A !important;
}
body:not([data-theme="dark"]) .argon-card .text-muted-gambit,
body:not([data-theme="dark"]) .argon-stat-card .text-muted-gambit,
body:not([data-theme="dark"]) table.dataTable .text-muted-gambit,
body:not([data-theme="dark"]) .gambit-table .text-muted-gambit {
    color: #6B7A99 !important;
}
/* Keep gold text readable in both modes */
body:not([data-theme="dark"]) .text-gold,
body:not([data-theme="dark"]) .argon-card .text-gold {
    color: #B8860B !important;
}

/* Page-header titles in light mode */
body:not([data-theme="dark"]) .page-header-title { color: #1A2B4A !important; }
body:not([data-theme="dark"]) .argon-breadcrumb,
body:not([data-theme="dark"]) .argon-breadcrumb a { color: #6B7A99 !important; }

/* fw-semibold / fw-bold inside tables */
body:not([data-theme="dark"]) table.dataTable .fw-semibold,
body:not([data-theme="dark"]) table.dataTable .fw-bold { color: #1A2B4A !important; }

/* Modal in light mode */
body:not([data-theme="dark"]) .modal-content {
    background: #FFFFFF !important;
    border: 1px solid #E5EAF2 !important;
    color: #1A2B4A !important;
}
body:not([data-theme="dark"]) .modal-title { color: #B8860B !important; }
body:not([data-theme="dark"]) .modal-content .text-white { color: #1A2B4A !important; }
body:not([data-theme="dark"]) .modal-content .gambit-input {
    background: #F4F6FA !important;
    border-color: #D1D9E6 !important;
    color: #1A2B4A !important;
}
body:not([data-theme="dark"]) .btn-close-white { filter: invert(1); }

/* Details/summary (tier edit) in light mode */
body:not([data-theme="dark"]) details summary { color: #B8860B !important; border-color: #B8860B !important; }

/* code tag */
body:not([data-theme="dark"]) code { background: #F4F6FA; color: #B8860B; padding: 2px 6px; border-radius: 4px; }

/* ═══════════════════════════════════════════════════════════════
   FOCUS STYLE — clean gold ring, no browser popup / blue glow
═══════════════════════════════════════════════════════════════ */
*, *:focus { outline: none !important; }
.gambit-input:focus,
.form-control:focus,
.form-select:focus,
textarea:focus,
input:focus,
button:focus,
a:focus,
select:focus {
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(212,175,55,0.25) !important;
    border-color: #D4AF37 !important;
}
/* Admin light mode focus ring */
body:not([data-theme="dark"]) .gambit-input:focus,
body:not([data-theme="dark"]) .form-control:focus,
body:not([data-theme="dark"]) .form-select:focus {
    box-shadow: 0 0 0 2px rgba(184,134,11,0.2) !important;
    border-color: #B8860B !important;
}
/* Remove Firefox red/blue border default */
select:-moz-focusring { color: transparent; text-shadow: 0 0 0 #000; }

/* ═══════════════════════════════════════════════════════════════
   CONTRAST RULES — dark background → white/light text
   These override any accidental dark-on-dark rendering
═══════════════════════════════════════════════════════════════ */

/* Member portal dark backgrounds always use light text */
body.member-theme .gambit-card,
body.member-theme .hero-card,
body.member-theme .summary-card,
body.member-theme .benefit-card,
body.member-theme .content-card,
body.member-theme .quick-action { color: #E8EDF5; }

body.member-theme .gambit-card h1,
body.member-theme .gambit-card h2,
body.member-theme .gambit-card h3,
body.member-theme .gambit-card h4,
body.member-theme .gambit-card h5,
body.member-theme .gambit-card h6,
body.member-theme .gambit-card p,
body.member-theme .gambit-card span,
body.member-theme .gambit-card div { color: inherit; }

/* ═══════════════════════════════════════════════════════════════
   CONTRAST RULES — admin light mode → ensure dark text on white
═══════════════════════════════════════════════════════════════ */

/* All plain text inside argon-card in light mode */
body:not([data-theme="dark"]) .argon-card,
body:not([data-theme="dark"]) .argon-stat-card { color: #1A2B4A; }

body:not([data-theme="dark"]) .argon-card h1,
body:not([data-theme="dark"]) .argon-card h2,
body:not([data-theme="dark"]) .argon-card h3,
body:not([data-theme="dark"]) .argon-card h4,
body:not([data-theme="dark"]) .argon-card h5,
body:not([data-theme="dark"]) .argon-card h6,
body:not([data-theme="dark"]) .argon-card p,
body:not([data-theme="dark"]) .argon-card label,
body:not([data-theme="dark"]) .argon-card small,
body:not([data-theme="dark"]) .argon-card span:not(.pill-active):not(.pill-pending):not(.pill-suspended):not(.pill-expired):not(.pill-rejected):not(.pill-approved):not(.badge):not(.docs-sum):not(.badge),
body:not([data-theme="dark"]) .argon-card td,
body:not([data-theme="dark"]) .argon-card th,
body:not([data-theme="dark"]) .argon-stat-card p,
body:not([data-theme="dark"]) .argon-stat-card small { color: #1A2B4A !important; }

/* .text-muted-gambit in light mode admin */
body:not([data-theme="dark"]) .text-muted-gambit { color: #5B7A99 !important; }

/* fw-semibold / fw-bold stay readable */
body:not([data-theme="dark"]) .fw-semibold { color: #0F1F3A; }
body:not([data-theme="dark"]) .fw-bold     { color: #0F1F3A; }

/* Tables in light admin */
body:not([data-theme="dark"]) .table td,
body:not([data-theme="dark"]) .table th { color: #1A2B4A !important; }
body:not([data-theme="dark"]) .table small { color: #5B7A99 !important; }

/* DataTable text */
body:not([data-theme="dark"]) table.dataTable td,
body:not([data-theme="dark"]) table.dataTable th { color: #1A2B4A !important; }
body:not([data-theme="dark"]) table.dataTable small { color: #5B7A99 !important; }
body:not([data-theme="dark"]) table.dataTable .fw-semibold { color: #0F1F3A !important; }

/* Page header titles / breadcrumb */
body:not([data-theme="dark"]) .page-header-title { color: #0F1F3A !important; }
body:not([data-theme="dark"]) .page-header-sub   { color: #5B7A99 !important; }
body:not([data-theme="dark"]) .argon-breadcrumb  { color: #5B7A99 !important; }
body:not([data-theme="dark"]) .argon-breadcrumb a { color: #5B7A99 !important; }
body:not([data-theme="dark"]) .argon-breadcrumb .crumb-active { color: #B8860B !important; }

/* Gold accents in light mode use darker gold for readability */
body:not([data-theme="dark"]) .text-gold { color: #D4AF37 !important; }
body:not([data-theme="dark"]) .argon-card-header h5,
body:not([data-theme="dark"]) .argon-card-header h6 { color: #D4AF37 !important; }

/* Select and textarea text in light mode */
body:not([data-theme="dark"]) .argon-card select,
body:not([data-theme="dark"]) .argon-card textarea,
body:not([data-theme="dark"]) .argon-card input { color: #1A2B4A !important; }

/* Form labels in light mode admin */
body:not([data-theme="dark"]) .argon-card .form-label,
body:not([data-theme="dark"]) .form-label { color: #4A5E80 !important; }

/* form-check-label */
body:not([data-theme="dark"]) .form-check-label { color: #4A5E80 !important; }

/* ═══════════════════════════════════════════════════════════════
   SELECT OPTION DROPDOWN — always readable
═══════════════════════════════════════════════════════════════ */
body:not([data-theme="dark"]) .gambit-input option,
body:not([data-theme="dark"]) select.gambit-input option {
    background: #FFFFFF !important;
    color: #1A2B4A !important;
}
body[data-theme="dark"] .gambit-input option,
body[data-theme="dark"] select.gambit-input option {
    background: #0B2238 !important;
    color: #E8EDF5 !important;
}

/* ═══════════════════════════════════════════════════════════════
   DARK MODE admin → keep white text on dark cards
═══════════════════════════════════════════════════════════════ */
body[data-theme="dark"] .argon-card,
body[data-theme="dark"] .argon-stat-card { color: #E8EDF5; }

body[data-theme="dark"] .text-muted-gambit { color: #7B90B0 !important; }
body[data-theme="dark"] .text-white { color: #E8EDF5 !important; }
body[data-theme="dark"] .text-gold  { color: #F5B21A !important; }

/* ═══════════════════════════════════════════════════════════════
   DETAILS / SUMMARY — remove browser default arrow styling
═══════════════════════════════════════════════════════════════ */
details > summary { list-style: none; }
details > summary::-webkit-details-marker { display: none; }


/* ═══════════════════════════════════════════════════════════════
   TABLE HEAD CONTRAST FIX
   Dark admin: gold text on dark bg
   Light admin: dark text on light-grey bg
   Member portal: navy text on light-blue bg
═══════════════════════════════════════════════════════════════ */

/* Default (dark admin) — gold on dark */
.gambit-table thead th {
    background: #0D1B3D !important;
    color: #D4AF37 !important;
}
table.dataTable thead th {
    background: #0D1B3D !important;
    color: #D4AF37 !important;
}

/* Light admin mode — dark text on very-light-grey */
body:not([data-theme="dark"]) .gambit-table thead th,
body:not([data-theme="dark"]) table.dataTable thead th {
    background: #EEF2FA !important;
    color: #1A2B4A !important;
    border-bottom: 2px solid #D1D9E6 !important;
}

/* Member portal — navy text on light-blue */
body.member-theme .gambit-table thead th {
    background: #EEF3FF !important;
    color: #0D1B3D !important;
    border-bottom: 2px solid #C8D5EE !important;
}

/* ═══════════════════════════════════════════════════════════════
   INPUT-GROUP-TEXT CONTRAST (settings page spans)
═══════════════════════════════════════════════════════════════ */
/* Dark admin */
.input-group-text {
    background: #0F2248 !important;
    border-color: #1E3A6E !important;
    color: #C5D3E8 !important;
    font-weight: 500;
}
/* Light admin */
body:not([data-theme="dark"]) .input-group-text {
    background: #F0F4FA !important;
    border-color: #C8D5EE !important;
    color: #1A2B4A !important;
}
/* Member portal */
body.member-theme .input-group-text {
    background: #F0F5FF !important;
    border-color: #C8D5EE !important;
    color: #0D1B3D !important;
}

/* ═══════════════════════════════════════════════════════════════
   TABLET RESPONSIVE (768px – 1024px)
═══════════════════════════════════════════════════════════════ */

/* ── Admin sidebar collapses at tablet (≤1024) ── */
@media (max-width: 1024px) {
    :root { --sidebar-width: 220px; }
    .content-area { padding: 1.25rem; }
    .argon-stat-value { font-size: 1.5rem; }
}

/* ── Admin fully mobile sidebar at ≤768 ── */
@media (max-width: 768px) {
    :root { --sidebar-width: 260px; }
    .admin-main { margin-left: 0; }
    .admin-topnav { left: 0; }
    .content-area { padding: 1rem; }
    .page-header { padding: 1rem; }
    .page-header-title { font-size: 1.1rem; }
    .argon-stat-card { padding: 1rem; }
    .argon-stat-value { font-size: 1.3rem; }
    .argon-card-header { padding: 0.75rem 1rem; }
    .argon-card-body { padding: 1rem; }
}

/* ── Member portal tablet ── */
@media (min-width: 768px) and (max-width: 1024px) {
    body.member-theme .hero-card { padding: 1.5rem; }
    body.member-theme .gambit-card { padding: 1.25rem !important; }
    body.member-theme .quick-action { min-width: 64px; padding: 0.75rem 0.5rem; }
    .points-pill { padding: 8px 12px; }
    .points-pill-value { font-size: 1rem; }
    /* Tighten nav on tablet */
    .gambit-navbar .container { padding: 0 1rem; }
    .navbar-nav .nav-link { font-size: 0.8rem; padding-left: 0.6rem !important; padding-right: 0.6rem !important; }
}

/* ── Table overflow on tablet ── */
@media (max-width: 900px) {
    .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .gambit-table { min-width: 600px; }
    table.dataTable { min-width: 600px; }
}


/* ═══════════════════════════════════════════════════════════════
   MODAL — adaptive background for light/dark mode
   (removes hardcoded #0B2238 from blade modals that don't inline)
═══════════════════════════════════════════════════════════════ */
.modal-content {
    background: var(--ab-card-bg, #0B2238);
    border: 1px solid var(--ab-card-border, #1E3A56);
    color: var(--ab-text, #E8EDF5);
    border-radius: 16px;
}
body[data-theme="dark"] .modal-content {
    background: #0B2238;
    border-color: #1E3A56;
    color: #E8EDF5;
}
body:not([data-theme="dark"]) .modal-content {
    background: #FFFFFF;
    border-color: #E5EAF2;
    color: #1A2B4A;
}
.modal-title {
    color: var(--ab-text, #E8EDF5);
    font-weight: 700;
}
body:not([data-theme="dark"]) .modal-title { color: #0F1F3A; }
body[data-theme="dark"]       .modal-title { color: #E8EDF5; }

/* btn-close adapts without btn-close-white class */
body:not([data-theme="dark"]) .modal-content .btn-close { filter: none; }
body[data-theme="dark"]       .modal-content .btn-close { filter: invert(1); }

/* Modal footer/header borders */
body:not([data-theme="dark"]) .modal-footer { border-color: #E5EAF2 !important; }
body[data-theme="dark"]       .modal-footer { border-color: #1E3A56 !important; }

/* Modal labels and text */
body:not([data-theme="dark"]) .modal-content .form-label { color: #4A5E80 !important; }
body:not([data-theme="dark"]) .modal-content .form-check-label { color: #4A5E80 !important; }
body:not([data-theme="dark"]) .modal-content p { color: #4A5E80; }

/* ── ADMIN-USERS role badge dark mode colour override ─────────── */


/* ═══════════════════════════════════════════════════════════════
   DATATABLES — UNIFIED THEME (matches gambit-table / admin-users)
   Override Bootstrap5 DataTables CDN CSS for both light & dark
═══════════════════════════════════════════════════════════════ */

/* ── Wrapper controls ─────────────────────────────────────────── */
.dataTables_wrapper {
    font-size: 0.875rem;
    color: var(--ab-text, #E8EDF5);
}
.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate .paginate_button {
    color: var(--ab-text-muted, #7B90B0) !important;
    font-size: 0.82rem;
}
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_length label,
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_filter label,
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_info {
    color: #5B7A99 !important;
}

/* ── Search & Length inputs ───────────────────────────────────── */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
    background: var(--ab-input-bg, #0D1B3D) !important;
    border: 1px solid var(--ab-input-border, #1E3A6E) !important;
    color: var(--ab-text, #E8EDF5) !important;
    border-radius: 8px !important;
    padding: 5px 10px !important;
    outline: none !important;
}
.dataTables_wrapper .dataTables_filter input:focus {
    border-color: #D4AF37 !important;
    box-shadow: 0 0 0 2px rgba(212,175,55,0.15) !important;
}
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_length select,
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_filter input {
    background: #F4F6FA !important;
    border-color: #D1D9E6 !important;
    color: #1A2B4A !important;
}

/* ── Pagination ───────────────────────────────────────────────── */
.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: 6px !important;
    border: none !important;
    padding: 4px 10px !important;
    margin: 0 2px !important;
    background: transparent !important;
    color: var(--ab-text-muted, #7B90B0) !important;
    cursor: pointer;
    transition: all 0.15s;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover:not(.current):not(.disabled) {
    background: rgba(212,175,55,0.12) !important;
    color: #D4AF37 !important;
    border: none !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
    background: #D4AF37 !important;
    color: #0F1F3A !important;
    border: none !important;
    font-weight: 700;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled {
    opacity: 0.3 !important;
    cursor: default !important;
}
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_paginate .paginate_button {
    color: #5B7A99 !important;
}
body:not([data-theme="dark"]) .dataTables_wrapper .dataTables_paginate .paginate_button.current {
    color: #0F1F3A !important;
}

/* ── Table head ───────────────────────────────────────────────── */
table.dataTable thead th,
table.dataTable thead td {
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.7px !important;
    padding: 12px 14px !important;
    border-bottom: 2px solid var(--ab-card-border, #1E3A56) !important;
    border-top: none !important;
    white-space: nowrap;
}
body[data-theme="dark"] table.dataTable thead th,
body[data-theme="dark"] table.dataTable thead td {
    background: #0D1B3D !important;
    color: #D4AF37 !important;
    border-bottom-color: #1E3A56 !important;
}
body:not([data-theme="dark"]) table.dataTable thead th,
body:not([data-theme="dark"]) table.dataTable thead td {
    background: #EEF2FA !important;
    color: #1A2B4A !important;
    border-bottom-color: #D1D9E6 !important;
}

/* Sort arrows ── */
table.dataTable thead th.sorting::after,
table.dataTable thead th.sorting_asc::after,
table.dataTable thead th.sorting_desc::after,
table.dataTable thead th.sorting::before,
table.dataTable thead th.sorting_asc::before,
table.dataTable thead th.sorting_desc::before {
    opacity: 0.65;
}
body:not([data-theme="dark"]) table.dataTable thead th.sorting::after,
body:not([data-theme="dark"]) table.dataTable thead th.sorting_asc::after,
body:not([data-theme="dark"]) table.dataTable thead th.sorting_desc::after { color: #1A2B4A; }
body[data-theme="dark"] table.dataTable thead th.sorting::after,
body[data-theme="dark"] table.dataTable thead th.sorting_asc::after,
body[data-theme="dark"] table.dataTable thead th.sorting_desc::after { color: #D4AF37; }

/* ── Table body ───────────────────────────────────────────────── */
table.dataTable tbody tr {
    border-bottom: 1px solid var(--ab-card-border, #1E3A56) !important;
    transition: background 0.1s;
}
table.dataTable tbody tr td {
    padding: 12px 14px !important;
    vertical-align: middle !important;
    border-top: none !important;
    font-size: 0.875rem;
}
body[data-theme="dark"] table.dataTable tbody tr {
    background: #0B2238 !important;
    border-bottom-color: #1E3A56 !important;
}
body[data-theme="dark"] table.dataTable tbody tr td { color: #E8EDF5 !important; }
body[data-theme="dark"] table.dataTable tbody tr:hover { background: rgba(245,178,26,0.04) !important; }

body:not([data-theme="dark"]) table.dataTable tbody tr { background: #FFFFFF !important; border-bottom-color: #E5EAF2 !important; }
body:not([data-theme="dark"]) table.dataTable tbody tr td { color: #1A2B4A !important; }
body:not([data-theme="dark"]) table.dataTable tbody tr td small { color: #5B7A99 !important; }
body:not([data-theme="dark"]) table.dataTable tbody tr td .fw-semibold { color: #0F1F3A !important; }
body:not([data-theme="dark"]) table.dataTable tbody tr td .text-muted-gambit { color: #5B7A99 !important; }
body:not([data-theme="dark"]) table.dataTable tbody tr:hover { background: #F8FAFD !important; }

/* ── Empty / processing ───────────────────────────────────────── */
table.dataTable tbody td.dataTables_empty {
    text-align: center !important;
    padding: 40px !important;
    color: var(--ab-text-muted, #7B90B0) !important;
}
body:not([data-theme="dark"]) table.dataTable tbody td.dataTables_empty { color: #5B7A99 !important; }
.dataTables_processing {
    background: var(--ab-card-bg, #0B2238) !important;
    border: 1px solid var(--ab-card-border, #1E3A56) !important;
    color: #D4AF37 !important;
    border-radius: 10px !important;
    padding: 12px 24px !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3) !important;
}


/* ═══════════════════════════════════════════════════════════════
   MEMBER PORTAL — CONTRAST FIXES
   Ensures all text, icons and interactive elements are readable
   on the dark navy member theme
═══════════════════════════════════════════════════════════════ */

/* ── Text muted in member context ─────────────────────────────── */
body.member-theme .text-muted-gambit { color: #A8BDD4 !important; }

/* ── Form labels ──────────────────────────────────────────────── */
body.member-theme .form-label { color: #C5D3E8 !important; }
body.member-theme .form-text  { color: #9FB3CC !important; }

/* ── Empty state ──────────────────────────────────────────────── */
body.member-theme .empty-state-icon { color: #4A6080 !important; opacity: 1; font-size: 2.5rem; }
body.member-theme .empty-state-title { color: #E8EDF5; }
body.member-theme .empty-state-sub   { color: #C5D3E8; }

/* ── Nav labels (bottom nav + quick actions) ─────────────────── */
body.member-theme .bottom-nav-item .nav-label { color: #9FB3CC; }
body.member-theme .bottom-nav-item.active .nav-label { color: #D4AF37; }

/* ── Gambit-card secondary text ───────────────────────────────── */
body.member-theme .gambit-card small { color: #A8BDD4; }

/* ── Chevron icons used as row arrows ─────────────────────────── */
body.member-theme .bi-chevron-right,
body.member-theme i.bi-chevron-right { color: #6B8299 !important; }

/* ── Status badge opacities — min 0.2 ────────────────────────── */
body.member-theme .badge { opacity: 1 !important; }

/* ── "More" menu support items (FAQ etc) ─────────────────────── */
body.member-theme .more-support-item {
    color: #C5D3E8 !important;
}
body.member-theme .more-support-item i {
    color: #A8BDD4 !important;
}

/* ── Tier progression circles (unreached) ─────────────────────── */
body.member-theme .tier-circle-unreached {
    background: rgba(255,255,255,0.08) !important;
    border-color: rgba(255,255,255,0.15) !important;
    color: #6B8299 !important;
}

/* ── Membership plans — "Need X more" box ────────────────────── */
body.member-theme .need-more-box {
    background: rgba(255,255,255,0.06) !important;
}
body.member-theme .need-more-box small { color: #A8BDD4 !important; }

/* ── Quick-action icon always gold, visible ─────────────────────── */
body.member-theme .quick-action-icon {
    color: #D4AF37 !important;
    background: rgba(13,27,61,0.9) !important;
    border-color: rgba(212,175,55,0.25) !important;
}

/* ── Table cells in member dark tables ────────────────────────── */
body.member-theme .gambit-table td { color: #E8EDF5 !important; }
body.member-theme .gambit-table td small,
body.member-theme .gambit-table td .text-muted-gambit { color: #A8BDD4 !important; }

/* ── Notification body text ──────────────────────────────────── */
body.member-theme .notif-item .text-muted-gambit { color: #A8BDD4 !important; }

/* ── Checklist items (legacy page) ───────────────────────────── */
body.member-theme .legacy-check-label { color: #E8EDF5; }
body.member-theme .legacy-check-desc  { color: #A8BDD4; }

/* ── Investment/holdings table ────────────────────────────────── */
body.member-theme table td.text-muted-gambit { color: #A8BDD4 !important; }

/* ── Input placeholder ───────────────────────────────────────── */
body.member-theme ::placeholder { color: #6B8299 !important; opacity: 1; }

/* ═══════════════════════════════════════════════════════════════
   LOADING OVERLAY
═══════════════════════════════════════════════════════════════ */
.loading-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(2,16,31,0.85);
    z-index: 9999;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 16px;
}
.loading-overlay.active { display: flex; }
.loading-spinner {
    width: 48px; height: 48px;
    border: 4px solid #1E3A56;
    border-top-color: #F5B21A;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ═══════════════════════════════════════════════════════════════
   DATATABLES STYLING
═══════════════════════════════════════════════════════════════ */
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select {
    background: #061A2E !important;
    border: 1px solid #1E3A56 !important;
    color: #FFFFFF !important;
    border-radius: 8px !important;
    padding: 6px 12px !important;
}
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label {
    color: #AEB8C4 !important;
}
.dataTables_wrapper .paginate_button {
    color: #AEB8C4 !important;
    border-radius: 6px !important;
}
.dataTables_wrapper .paginate_button.current {
    background: #F5B21A !important;
    color: #02101F !important;
    border-color: #F5B21A !important;
}
.dataTables_wrapper .paginate_button:hover {
    background: rgba(245,178,26,0.15) !important;
    color: #F5B21A !important;
}

/* ═══════════════════════════════════════════════════════════════
   FUTURISTIC & ELEGANT AUTHENTICATION STYLING (LIGHT MODE)
   =============================================================== */

/* Base Futuristic Wrapper (Light Theme) */
.auth-wrapper.futuristic-theme {
    min-height: 100vh;
    background: 
        radial-gradient(circle at 10% 20%, rgba(212, 175, 55, 0.09) 0%, transparent 40%),
        radial-gradient(circle at 90% 80%, rgba(59, 130, 246, 0.08) 0%, transparent 50%),
        radial-gradient(circle at 50% 50%, #F5F7FA 0%, #E2E8F0 100%) !important;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 16px;
    z-index: 1;
}

/* Digital Grid Background Effect (Subtle dark grid lines) */
.auth-wrapper.futuristic-theme::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background-image: 
        linear-gradient(rgba(13, 27, 61, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(13, 27, 61, 0.02) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
    z-index: -1;
}

/* Subtle glowing abstract particles/light circles in background */
.auth-wrapper.futuristic-theme::after {
    content: '';
    position: absolute;
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.08) 0%, transparent 70%);
    top: -200px;
    left: -200px;
    pointer-events: none;
    z-index: -1;
}

/* Glassmorphism Card styling (Frosted light white card to prevent overrides) */
body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card,
.auth-wrapper.futuristic-theme .auth-glass-card {
    background: rgba(255, 255, 255, 0.72) !important;
    backdrop-filter: blur(24px) saturate(160%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(160%) !important;
    border: 1px solid rgba(212, 175, 55, 0.28) !important;
    border-radius: 24px !important;
    padding: 44px 38px !important;
    width: 100%;
    max-width: 440px;
    box-shadow: 
        0 24px 60px rgba(13, 27, 61, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.60),
        0 0 40px rgba(212, 175, 55, 0.05) !important;
    z-index: 2;
    position: relative;
    overflow: hidden !important; /* Contain the scanning line sweep */
    transition: border-color 0.4s ease, box-shadow 0.4s ease;
}


/* Hover glow for glass card */
body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card:hover,
.auth-wrapper.futuristic-theme .auth-glass-card:hover {
    border-color: rgba(212, 175, 55, 0.45) !important;
    box-shadow: 
        0 30px 70px rgba(13, 27, 61, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.80),
        0 0 50px rgba(212, 175, 55, 0.08) !important;
}

/* Admin specific glow for admin card */
body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card.admin-card-glow,
.auth-wrapper.futuristic-theme .auth-glass-card.admin-card-glow {
    border: 1px solid rgba(239, 68, 68, 0.3) !important;
    box-shadow: 
        0 24px 60px rgba(13, 27, 61, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.60),
        0 0 40px rgba(239, 68, 68, 0.04) !important;
}

body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card.admin-card-glow:hover,
.auth-wrapper.futuristic-theme .auth-glass-card.admin-card-glow:hover {
    border-color: rgba(239, 68, 68, 0.45) !important;
    box-shadow: 
        0 30px 70px rgba(13, 27, 61, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.80),
        0 0 50px rgba(239, 68, 68, 0.08) !important;
}

/* Text overrides inside glass card to guarantee elegant readability (Dark Wording) */
body.member-theme .auth-glass-card h4,
.auth-glass-card h4 {
    color: var(--navy) !important;
    font-size: 1.5rem;
    font-weight: 800 !important;
    letter-spacing: -0.5px;
}

body.member-theme .auth-glass-card p,
.auth-glass-card p {
    color: #4A5568 !important;
    font-size: 0.88rem !important;
}

body.member-theme .auth-glass-card label,
.auth-glass-card label {
    color: var(--navy) !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin-bottom: 8px;
}

body.member-theme .auth-glass-card .form-check-label,
.auth-glass-card .form-check-label {
    color: #4A5568 !important;
    text-transform: none !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
}

/* Glowing Form inputs inside Glass Card (Light Mode Input Styling) */
body.member-theme .auth-glass-card .gambit-input,
.auth-glass-card .gambit-input {
    background: rgba(255, 255, 255, 0.85) !important;
    border: 1.5px solid rgba(13, 27, 61, 0.12) !important;
    color: var(--navy) !important;
    border-radius: 12px !important;
    padding: 12px 16px !important;
    font-size: 0.9rem !important;
    backdrop-filter: blur(4px);
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Override input padding for fields inside icon wraps to prevent icon/text overlap */
body.member-theme .auth-glass-card .input-icon-wrap .gambit-input,
.auth-glass-card .input-icon-wrap .gambit-input {
    padding-left: 44px !important;
    padding-right: 44px !important;
}


body.member-theme .auth-glass-card .gambit-input:focus,
.auth-glass-card .gambit-input:focus {
    border-color: var(--gambit-gold) !important;
    box-shadow: 0 0 16px rgba(212, 175, 55, 0.22) !important;
    background: #FFFFFF !important;
}

/* Custom Admin input focus */
body.member-theme .auth-glass-card.admin-card-glow .gambit-input:focus,
.auth-glass-card.admin-card-glow .gambit-input:focus {
    border-color: #EF4444 !important;
    box-shadow: 0 0 16px rgba(239, 68, 68, 0.22) !important;
}

/* Glass input Icons wrapper styling */
.auth-glass-card .input-icon-wrap .input-icon {
    color: rgba(13, 27, 61, 0.4) !important;
    transition: color 0.25s ease;
}

.auth-glass-card .input-icon-wrap:focus-within .input-icon {
    color: var(--gambit-gold) !important;
}

/* Admin specific icon coloring */
.auth-glass-card.admin-card-glow .input-icon-wrap .input-icon {
    color: rgba(13, 27, 61, 0.4) !important;
}
.auth-glass-card.admin-card-glow .input-icon-wrap:focus-within .input-icon {
    color: #EF4444 !important;
}

/* Interactive Eye Toggle buttons */
.auth-glass-card .eye-toggle {
    color: rgba(13, 27, 61, 0.4) !important;
    transition: color 0.22s ease;
}
.auth-glass-card .eye-toggle:hover {
    color: var(--gambit-gold) !important;
}
.auth-glass-card.admin-card-glow .eye-toggle:hover {
    color: #EF4444 !important;
}

/* Links inside Glass Card (darker gold for readability contrast) */
body.member-theme .auth-glass-card a.text-gold,
.auth-glass-card a.text-gold,
body.member-theme .auth-glass-card a.text-decoration-none,
.auth-glass-card a.text-decoration-none {
    color: var(--gold-dark) !important;
    transition: all 0.22s ease;
    font-weight: 600;
}
body.member-theme .auth-glass-card a.text-gold:hover,
.auth-glass-card a.text-gold:hover,
body.member-theme .auth-glass-card a.text-decoration-none:hover,
.auth-glass-card a.text-decoration-none:hover {
    color: var(--navy) !important;
    text-shadow: none !important;
}

/* Buttons upgrade with shimmering reflection */
body.member-theme .auth-glass-card .btn-cyber-gold,
.auth-glass-card .btn-cyber-gold {
    background: linear-gradient(135deg, var(--gambit-gold) 0%, var(--gold-dark) 100%) !important;
    color: var(--deep-navy) !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    letter-spacing: 1.5px !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 14px 24px !important;
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 4px 20px rgba(212, 175, 55, 0.25) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

body.member-theme .auth-glass-card .btn-cyber-gold::after,
.auth-glass-card .btn-cyber-gold::after {
    content: '';
    position: absolute;
    top: 0; left: -100%; width: 50%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transform: skewX(-25deg);
    pointer-events: none;
}

body.member-theme .auth-glass-card .btn-cyber-gold:hover::after,
.auth-glass-card .btn-cyber-gold:hover::after {
    left: 150%;
    transition: left 0.8s ease-in-out;
}

body.member-theme .auth-glass-card .btn-cyber-gold:hover,
.auth-glass-card .btn-cyber-gold:hover {
    box-shadow: 0 0 25px rgba(212, 175, 55, 0.4) !important;
    transform: translateY(-1.5px) !important;
}

body.member-theme .auth-glass-card .btn-cyber-gold:active,
.auth-glass-card .btn-cyber-gold:active {
    transform: translateY(0) !important;
}

/* Cyber Admin Red/Gold Button */
body.member-theme .auth-glass-card .btn-cyber-admin,
.auth-glass-card .btn-cyber-admin {
    background: linear-gradient(135deg, #EF4444 0%, #991B1B 100%) !important;
    color: #FFFFFF !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    letter-spacing: 1.5px !important;
    border: none !important;
    border-radius: 12px !important;
    padding: 14px 24px !important;
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    box-shadow: 0 4px 20px rgba(239, 68, 68, 0.25) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

body.member-theme .auth-glass-card .btn-cyber-admin::after,
.auth-glass-card .btn-cyber-admin::after {
    content: '';
    position: absolute;
    top: 0; left: -100%; width: 50%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transform: skewX(-25deg);
    pointer-events: none;
}

body.member-theme .auth-glass-card .btn-cyber-admin:hover::after,
.auth-glass-card .btn-cyber-admin:hover::after {
    left: 150%;
    transition: left 0.8s ease-in-out;
}

body.member-theme .auth-glass-card .btn-cyber-admin:hover,
.auth-glass-card .btn-cyber-admin:hover {
    box-shadow: 0 0 25px rgba(239, 68, 68, 0.4) !important;
    transform: translateY(-1.5px) !important;
}

/* Glassmorphism Badge styling */
.auth-glass-card .admin-badge {
    background: rgba(239, 68, 68, 0.12) !important;
    border: 1px solid rgba(239, 68, 68, 0.25) !important;
    color: #C53030 !important;
    padding: 6px 14px !important;
    border-radius: 20px !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

/* Social/Dividers styling */
.auth-glass-card .divider span {
    background: rgba(13, 27, 61, 0.1) !important;
}
.auth-glass-card .divider small {
    color: #5B7FA8 !important;
    font-weight: 500;
}

/* Custom styles for Bootstrap form check positioning inside glass card */
.auth-glass-card .form-check-input {
    background-color: rgba(255, 255, 255, 0.85) !important;
    border-color: rgba(13, 27, 61, 0.2) !important;
}
.auth-glass-card .form-check-input:checked {
    background-color: var(--gambit-gold) !important;
    border-color: var(--gambit-gold) !important;
}

/* Footer elements styling (Darker text for light mode background legibility) */
.auth-wrapper.futuristic-theme .text-muted-gambit {
    color: #5B7FA8 !important;
    transition: color 0.3s ease;
}
.auth-wrapper.futuristic-theme .text-muted-gambit:hover {
    color: var(--navy) !important;
}

/* ── Futuristic Scanning Line Sweep ── */
body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card::after,
.auth-wrapper.futuristic-theme .auth-glass-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--gambit-gold), transparent) !important;
    animation: scanLine 6s linear infinite !important;
    z-index: 3 !important;
    pointer-events: none;
}

/* Specific red scan line for admin card */
body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card.admin-card-glow::after,
.auth-wrapper.futuristic-theme .auth-glass-card.admin-card-glow::after {
    background: linear-gradient(90deg, transparent, #EF4444, transparent) !important;
}

@keyframes scanLine {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* ── Ambient Floating Glow Orbs ── */
.auth-wrapper.futuristic-theme .glow-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(100px);
    opacity: 0.14;
    z-index: 0;
    pointer-events: none;
}
.auth-wrapper.futuristic-theme .orb-1 {
    width: 350px; height: 350px;
    background: radial-gradient(circle, var(--gambit-gold) 0%, rgba(212, 175, 55, 0) 70%);
    top: 15%; left: 10%;
    animation: floatOrb1 24s ease-in-out infinite alternate;
}
.auth-wrapper.futuristic-theme .orb-2 {
    width: 450px; height: 450px;
    background: radial-gradient(circle, #3B82F6 0%, rgba(59, 130, 246, 0) 70%);
    bottom: 15%; right: 10%;
    animation: floatOrb2 28s ease-in-out infinite alternate;
}
.auth-wrapper.futuristic-theme .orb-3 {
    width: 260px; height: 260px;
    background: radial-gradient(circle, #EF4444 0%, rgba(239, 68, 68, 0) 70%);
    bottom: 35%; left: 20%;
    animation: floatOrb3 20s ease-in-out infinite alternate;
    opacity: 0.05;
}

@keyframes floatOrb1 {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(80px, 50px) scale(1.15); }
}
@keyframes floatOrb2 {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(-90px, -70px) scale(0.9); }
}
@keyframes floatOrb3 {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(50px, -80px) scale(1.15); }
}

/* Mobile responsive fixes */
@media (max-width: 480px) {
    body.member-theme .auth-wrapper.futuristic-theme .auth-glass-card,
    .auth-wrapper.futuristic-theme .auth-glass-card {
        padding: 32px 24px !important;
    }
}


