/* ══════════════════════════════════════════════════
   MAPA MLM — Fila Design System (Member Section)
   Based on EnvyTheme Fila Bootstrap 5 Dashboard
   Palette: Primary #605DFF · MAPA Blue #0e47a1 · Red #ad2533
   ══════════════════════════════════════════════════ */

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

:root {
    /* ── Fila Palette ── */
    --fi-primary: #605DFF;
    --fi-primary-rgb: 96,93,255;
    --fi-primary-hover: #4845e0;
    --fi-secondary: #ad2533;
    --fi-secondary-rgb: 173,37,51;
    --fi-success: #25B003;
    --fi-success-rgb: 37,176,3;
    --fi-danger: #FD5812;
    --fi-danger-rgb: 253,88,18;
    --fi-warning: #FFBA09;
    --fi-warning-rgb: 255,186,9;
    --fi-info: #0DCAF0;
    --fi-info-rgb: 13,202,240;
    --fi-dark: #260944;
    --fi-gray-900: #1F2937;
    --fi-gray-700: #374151;
    --fi-gray-600: #64748B;
    --fi-gray-400: #9CA3AF;
    --fi-gray-300: #D1D5DB;
    --fi-gray-200: #E5E7EB;
    --fi-gray-100: #F3F4F6;
    --fi-gray-50: #F9FAFB;
    --fi-white: #FFFFFF;
    --fi-body-bg: #f5f7fa;
    --fi-card-shadow: 0 1px 4px rgba(0,0,0,0.06);
    --fi-card-shadow-hover: 0 6px 20px rgba(0,0,0,0.08);
    --fi-sidebar-bg: #0a0e23;
    --fi-sidebar-w: 270px;
    --fi-topbar-h: 70px;
    --fi-radius: 10px;
    --fi-radius-sm: 6px;
    --fi-radius-lg: 16px;
    --fi-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --fi-transition: all 0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ════════════════════════════════
   RESET & BASE
   ════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--fi-font);background:var(--fi-body-bg);color:var(--fi-gray-900);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:var(--fi-primary);text-decoration:none;transition:var(--fi-transition)}
a:hover{color:var(--fi-primary-hover)}
img{max-width:100%;height:auto}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--fi-gray-300);border-radius:10px}
::-webkit-scrollbar-track{background:transparent}

/* ════════════════════════════════
   LAYOUT
   ════════════════════════════════ */
.fi-app{display:flex;min-height:100vh}

/* ── Sidebar ── */
.fi-sidebar{
    width:var(--fi-sidebar-w);background:var(--fi-sidebar-bg);
    position:fixed;top:0;left:0;bottom:0;
    z-index:1000;overflow-y:auto;overflow-x:hidden;
    transition:transform .3s ease;
    display:flex;flex-direction:column;
}
.fi-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15)}

/* Brand */
.fi-brand{
    padding:20px 24px;display:flex;align-items:center;gap:12px;
    border-bottom:1px solid rgba(255,255,255,.06);
    min-height:var(--fi-topbar-h);
}
.fi-brand img{height:42px;flex-shrink:0}
.fi-brand-text{display:flex;flex-direction:column}
.fi-brand-name{color:#fff;font-size:1.15rem;font-weight:700;letter-spacing:.3px;line-height:1.2}
.fi-brand-sub{color:rgba(255,255,255,.4);font-size:.68rem;text-transform:uppercase;letter-spacing:1px}

/* Nav */
.fi-nav{padding:16px 0;flex:1}
.fi-nav-title{
    padding:10px 24px 8px;font-size:.65rem;font-weight:700;
    text-transform:uppercase;letter-spacing:1.2px;
    color:rgba(255,255,255,.3);
}
.fi-nav a{
    display:flex;align-items:center;gap:12px;
    padding:10px 24px;margin:2px 12px;border-radius:8px;
    color:rgba(255,255,255,.65);font-size:.875rem;font-weight:500;
    transition:var(--fi-transition);position:relative;
}
.fi-nav a i{font-size:1.15rem;width:22px;text-align:center;opacity:.8}
.fi-nav a:hover{
    background:rgba(255,255,255,.06);color:#fff;
    text-decoration:none;
}
.fi-nav a.active{
    background:rgba(96,93,255,.15);color:var(--fi-primary);
}
.fi-nav a.active i{opacity:1;color:var(--fi-primary)}
.fi-nav-badge{
    margin-left:auto;background:var(--fi-danger);color:#fff;
    font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:20px;
    min-width:20px;text-align:center;
}

/* Sidebar Footer */
.fi-sidebar-footer{
    padding:16px 20px;border-top:1px solid rgba(255,255,255,.06);
    display:flex;align-items:center;gap:12px;
}
.fi-sidebar-avatar{
    width:40px;height:40px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0;
    background:linear-gradient(135deg,var(--fi-primary),#8b5cf6);
    overflow:hidden;
}
.fi-sidebar-avatar img{width:100%;height:100%;object-fit:cover}
.fi-sidebar-user{flex:1;min-width:0}
.fi-sidebar-user-name{color:#fff;font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fi-sidebar-user-role{color:rgba(255,255,255,.4);font-size:.68rem}
.fi-sidebar-logout{
    color:rgba(255,255,255,.4);font-size:1.2rem;
    padding:6px;border-radius:6px;transition:var(--fi-transition);
    display:flex;align-items:center;
}
.fi-sidebar-logout:hover{color:var(--fi-danger);background:rgba(253,88,18,.1)}

/* ── Main ── */
.fi-main{
    margin-left:var(--fi-sidebar-w);flex:1;
    min-height:100vh;display:flex;flex-direction:column;
}

/* ── Topbar ── */
.fi-topbar{
    background:var(--fi-white);height:var(--fi-topbar-h);
    padding:0 28px;display:flex;align-items:center;justify-content:space-between;
    border-bottom:1px solid var(--fi-gray-200);
    position:sticky;top:0;z-index:500;
}
.fi-topbar-left{display:flex;align-items:center;gap:16px}
.fi-hamburger{
    display:none;background:none;border:none;cursor:pointer;
    padding:8px;border-radius:8px;color:var(--fi-gray-700);
    font-size:1.3rem;transition:var(--fi-transition);
}
.fi-hamburger:hover{background:var(--fi-gray-100);color:var(--fi-primary)}
.fi-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.82rem}
.fi-breadcrumb-item{color:var(--fi-gray-400)}
.fi-breadcrumb-sep{color:var(--fi-gray-300)}
.fi-breadcrumb-active{color:var(--fi-gray-900);font-weight:600}
.fi-topbar-right{display:flex;align-items:center;gap:12px}

/* Search */
.fi-search{
    position:relative;display:flex;align-items:center;
}
.fi-search input{
    background:var(--fi-gray-50);border:1px solid var(--fi-gray-200);
    border-radius:8px;padding:8px 12px 8px 36px;font-size:.82rem;
    width:220px;transition:var(--fi-transition);font-family:var(--fi-font);
    color:var(--fi-gray-900);
}
.fi-search input:focus{
    outline:none;border-color:var(--fi-primary);
    box-shadow:0 0 0 3px rgba(var(--fi-primary-rgb),.1);width:280px;
    background:var(--fi-white);
}
.fi-search i{position:absolute;left:12px;color:var(--fi-gray-400);font-size:1rem}

/* Topbar icons */
.fi-topbar-icon{
    width:40px;height:40px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    color:var(--fi-gray-600);background:var(--fi-gray-50);
    border:1px solid var(--fi-gray-200);font-size:1.15rem;
    transition:var(--fi-transition);cursor:pointer;position:relative;
}
.fi-topbar-icon:hover{background:rgba(var(--fi-primary-rgb),.08);color:var(--fi-primary);border-color:rgba(var(--fi-primary-rgb),.2)}
.fi-topbar-dot{
    position:absolute;top:6px;right:6px;width:8px;height:8px;
    border-radius:50%;background:var(--fi-danger);border:2px solid var(--fi-white);
}

/* Profile pill */
.fi-profile-dd{position:relative}
.fi-topbar-profile{
    display:flex;align-items:center;gap:10px;
    padding:5px 14px 5px 5px;border-radius:50px;
    border:1px solid var(--fi-gray-200);cursor:pointer;
    transition:var(--fi-transition);background:none;
    font-family:var(--fi-font);
}
.fi-topbar-profile:hover{background:var(--fi-gray-50);border-color:var(--fi-gray-300)}
.fi-topbar-profile-img{
    width:34px;height:34px;border-radius:50%;overflow:hidden;
    background:linear-gradient(135deg,var(--fi-primary),#8b5cf6);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-weight:700;font-size:.8rem;flex-shrink:0;
    border:2px solid var(--fi-white);box-shadow:0 1px 3px rgba(0,0,0,.1);
}
.fi-topbar-profile-img img{width:100%;height:100%;object-fit:cover}
.fi-topbar-profile-name{font-size:.82rem;font-weight:600;color:var(--fi-gray-900)}
.fi-topbar-profile-chevron{font-size:1rem;color:var(--fi-gray-400);transition:transform .2s}
.fi-profile-menu.show ~ .fi-topbar-profile .fi-topbar-profile-chevron,
.fi-profile-dd .fi-profile-menu.show + .fi-topbar-profile .fi-topbar-profile-chevron{transform:rotate(180deg)}

/* ── Profile Dropdown Menu ── */
.fi-profile-menu{
    position:absolute;top:calc(100% + 10px);right:0;
    width:240px;background:var(--fi-white);
    border-radius:var(--fi-radius-lg);
    box-shadow:0 10px 40px rgba(0,0,0,.12),0 2px 6px rgba(0,0,0,.04);
    border:1px solid var(--fi-gray-100);
    opacity:0;visibility:hidden;
    transform:translateY(-8px);
    transition:all .2s cubic-bezier(.4,0,.2,1);
    z-index:1000;overflow:hidden;
}
.fi-profile-menu.show{
    opacity:1;visibility:visible;transform:translateY(0);
}

/* Header card with avatar */
.fi-profile-menu-header{
    display:flex;align-items:center;gap:12px;
    padding:18px 18px 14px;
}
.fi-profile-menu-avatar{
    width:44px;height:44px;border-radius:50%;flex-shrink:0;
    overflow:hidden;
    background:linear-gradient(135deg,var(--fi-primary),#8b5cf6);
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-weight:700;font-size:.95rem;
    border:2px solid var(--fi-white);
    box-shadow:0 2px 8px rgba(var(--fi-primary-rgb),.25);
}
.fi-profile-menu-avatar img{width:100%;height:100%;object-fit:cover}
.fi-profile-menu-info{min-width:0;flex:1}
.fi-profile-menu-name{
    font-size:.88rem;font-weight:700;color:var(--fi-gray-900);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.fi-profile-menu-role{
    font-size:.72rem;color:var(--fi-gray-400);margin-top:1px;
}

/* Divider */
.fi-profile-menu-divider{
    height:1px;background:var(--fi-gray-100);margin:4px 0;
}

/* Menu Items */
.fi-profile-menu-item{
    display:flex;align-items:center;gap:12px;
    padding:10px 18px;font-size:.84rem;font-weight:500;
    color:var(--fi-gray-700);transition:var(--fi-transition);
    cursor:pointer;text-decoration:none;
}
.fi-profile-menu-item i{
    font-size:1.1rem;width:20px;text-align:center;
    color:var(--fi-gray-400);transition:var(--fi-transition);
}
.fi-profile-menu-item:hover{
    background:rgba(var(--fi-primary-rgb),.04);
    color:var(--fi-primary);text-decoration:none;
}
.fi-profile-menu-item:hover i{color:var(--fi-primary)}

/* Logout item */
.fi-profile-menu-logout{color:var(--fi-danger)}
.fi-profile-menu-logout i{color:var(--fi-danger)}
.fi-profile-menu-logout:hover{
    background:rgba(var(--fi-danger-rgb),.04);
    color:var(--fi-danger);
}
.fi-profile-menu-logout:hover i{color:var(--fi-danger)}

/* Date pill */
.fi-date-pill{
    background:var(--fi-gray-50);border:1px solid var(--fi-gray-200);
    padding:6px 14px;border-radius:20px;font-size:.75rem;
    color:var(--fi-gray-600);display:flex;align-items:center;gap:6px;
}

/* ── Content Area ── */
.fi-content{padding:24px 28px;flex:1}

/* Page Header */
.fi-page-header{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:24px;
}
.fi-page-title{font-size:1.35rem;font-weight:700;color:var(--fi-dark)}
.fi-page-actions{display:flex;gap:10px}

/* ════════════════════════════════
   CARDS
   ════════════════════════════════ */
.fi-card{
    background:var(--fi-white);border-radius:var(--fi-radius);
    box-shadow:var(--fi-card-shadow);padding:0;
    margin-bottom:20px;border:1px solid var(--fi-gray-100);
    transition:var(--fi-transition);overflow:hidden;
}
.fi-card:hover{box-shadow:var(--fi-card-shadow-hover)}
.fi-card-header{
    display:flex;justify-content:space-between;align-items:center;
    padding:18px 22px;border-bottom:1px solid var(--fi-gray-100);
}
.fi-card-title{font-size:.95rem;font-weight:700;color:var(--fi-gray-900);display:flex;align-items:center;gap:8px}
.fi-card-title i{color:var(--fi-primary);font-size:1.1rem}
.fi-card-body{padding:22px}
.fi-card-flush .fi-card-body{padding:0}

/* ════════════════════════════════
   STAT CARDS
   ════════════════════════════════ */
.fi-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;margin-bottom:24px}
.fi-stat{
    background:var(--fi-white);border-radius:var(--fi-radius);
    padding:20px 22px;box-shadow:var(--fi-card-shadow);
    border:1px solid var(--fi-gray-100);
    display:flex;align-items:center;gap:16px;
    transition:var(--fi-transition);
}
.fi-stat:hover{box-shadow:var(--fi-card-shadow-hover);transform:translateY(-2px)}
.fi-stat-icon{
    width:52px;height:52px;border-radius:var(--fi-radius);
    display:flex;align-items:center;justify-content:center;
    font-size:1.4rem;flex-shrink:0;
}
.fi-stat-icon.primary{background:rgba(var(--fi-primary-rgb),.1);color:var(--fi-primary)}
.fi-stat-icon.success{background:rgba(var(--fi-success-rgb),.1);color:var(--fi-success)}
.fi-stat-icon.danger{background:rgba(var(--fi-danger-rgb),.1);color:var(--fi-danger)}
.fi-stat-icon.warning{background:rgba(var(--fi-warning-rgb),.1);color:var(--fi-warning)}
.fi-stat-icon.info{background:rgba(var(--fi-info-rgb),.1);color:var(--fi-info)}
.fi-stat-icon.secondary{background:rgba(var(--fi-secondary-rgb),.1);color:var(--fi-secondary)}
.fi-stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--fi-gray-400);margin-bottom:4px}
.fi-stat-value{font-size:1.35rem;font-weight:800;color:var(--fi-gray-900);line-height:1.2}
.fi-stat-sub{font-size:.72rem;color:var(--fi-gray-400);margin-top:4px;display:flex;align-items:center;gap:4px}

/* ════════════════════════════════
   WALLET GRADIENT CARDS
   ════════════════════════════════ */
.fi-wallets{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.fi-wallet{
    border-radius:var(--fi-radius-lg);padding:22px;position:relative;
    overflow:hidden;color:#fff;
}
.fi-wallet::before{
    content:'';position:absolute;right:-15px;top:-15px;
    width:80px;height:80px;border-radius:50%;
    background:rgba(255,255,255,.12);
}
.fi-wallet::after{
    content:'';position:absolute;right:30px;bottom:-20px;
    width:50px;height:50px;border-radius:50%;
    background:rgba(255,255,255,.06);
}
.fi-wallet.purple{background:linear-gradient(135deg,#605DFF,#8b5cf6)}
.fi-wallet.green{background:linear-gradient(135deg,#25B003,#4ade80)}
.fi-wallet.orange{background:linear-gradient(135deg,#F97316,#FFBA09)}
.fi-wallet.red{background:linear-gradient(135deg,#ad2533,#ef4444)}
.fi-wallet.slate{background:linear-gradient(135deg,#475569,#94a3b8)}
.fi-wallet-label{font-size:.72rem;opacity:.85;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.fi-wallet-value{font-size:1.5rem;font-weight:800;margin-top:8px;position:relative;z-index:1}
.fi-wallet-icon{position:absolute;right:18px;top:18px;font-size:1.6rem;opacity:.3;z-index:1}

/* ════════════════════════════════
   TABLES
   ════════════════════════════════ */
.fi-table-wrap{overflow-x:auto}
.fi-table{width:100%;border-collapse:collapse}
.fi-table thead th{
    background:var(--fi-gray-50);padding:12px 16px;text-align:left;
    font-size:.72rem;font-weight:700;text-transform:uppercase;
    letter-spacing:.5px;color:var(--fi-gray-400);
    border-bottom:1px solid var(--fi-gray-200);
    white-space:nowrap;
}
.fi-table tbody td{
    padding:14px 16px;border-bottom:1px solid var(--fi-gray-100);
    font-size:.84rem;color:var(--fi-gray-700);vertical-align:middle;
}
.fi-table tbody tr{transition:background .15s}
.fi-table tbody tr:hover{background:rgba(var(--fi-primary-rgb),.02)}
.fi-table tbody tr:last-child td{border-bottom:none}

/* ════════════════════════════════
   BADGES
   ════════════════════════════════ */
.fi-badge{
    display:inline-flex;align-items:center;gap:4px;
    padding:4px 10px;border-radius:20px;
    font-size:.7rem;font-weight:600;white-space:nowrap;
}
.fi-badge-primary{background:rgba(var(--fi-primary-rgb),.1);color:var(--fi-primary)}
.fi-badge-success{background:rgba(var(--fi-success-rgb),.12);color:var(--fi-success)}
.fi-badge-danger{background:rgba(var(--fi-danger-rgb),.1);color:var(--fi-danger)}
.fi-badge-warning{background:rgba(var(--fi-warning-rgb),.12);color:#b45309}
.fi-badge-info{background:rgba(var(--fi-info-rgb),.12);color:#0891b2}
.fi-badge-secondary{background:var(--fi-gray-100);color:var(--fi-gray-600)}
.fi-badge-dark{background:var(--fi-gray-900);color:#fff}
.fi-badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.fi-badge-success .fi-badge-dot{background:var(--fi-success)}
.fi-badge-danger .fi-badge-dot{background:var(--fi-danger)}
.fi-badge-warning .fi-badge-dot{background:#b45309}
.fi-badge-primary .fi-badge-dot{background:var(--fi-primary)}

/* ════════════════════════════════
   BUTTONS
   ════════════════════════════════ */
.fi-btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:9px 18px;border-radius:8px;border:none;
    font-size:.84rem;font-weight:600;cursor:pointer;
    font-family:var(--fi-font);transition:var(--fi-transition);
    white-space:nowrap;line-height:1.4;
}
.fi-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.12)}
.fi-btn:active{transform:translateY(0)}
.fi-btn i{font-size:1rem}
.fi-btn-primary{background:var(--fi-primary);color:#fff}
.fi-btn-primary:hover{background:var(--fi-primary-hover);color:#fff}
.fi-btn-success{background:var(--fi-success);color:#fff}
.fi-btn-success:hover{background:#1d9403;color:#fff}
.fi-btn-danger{background:var(--fi-danger);color:#fff}
.fi-btn-warning{background:var(--fi-warning);color:#000}
.fi-btn-secondary{background:var(--fi-secondary);color:#fff}
.fi-btn-outline{background:transparent;border:1.5px solid var(--fi-gray-300);color:var(--fi-gray-700)}
.fi-btn-outline:hover{border-color:var(--fi-primary);color:var(--fi-primary);background:rgba(var(--fi-primary-rgb),.04)}
.fi-btn-soft{background:rgba(var(--fi-primary-rgb),.08);color:var(--fi-primary);border:none}
.fi-btn-soft:hover{background:rgba(var(--fi-primary-rgb),.15)}
.fi-btn-sm{padding:6px 12px;font-size:.76rem}
.fi-btn-lg{padding:12px 24px;font-size:.95rem}
.fi-btn-icon{width:34px;height:34px;padding:0;justify-content:center;border-radius:8px}
.fi-btn:disabled,.fi-btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important}

/* ════════════════════════════════
   FORMS
   ════════════════════════════════ */
.fi-form-group{margin-bottom:18px}
.fi-form-label{display:block;margin-bottom:6px;font-size:.82rem;font-weight:600;color:var(--fi-gray-700)}
.fi-form-control{
    width:100%;padding:10px 14px;
    border:1.5px solid var(--fi-gray-200);border-radius:8px;
    font-size:.88rem;font-family:var(--fi-font);
    color:var(--fi-gray-900);background:var(--fi-white);
    transition:var(--fi-transition);
}
.fi-form-control:focus{
    outline:none;border-color:var(--fi-primary);
    box-shadow:0 0 0 3px rgba(var(--fi-primary-rgb),.08);
}
.fi-form-control::placeholder{color:var(--fi-gray-400)}
select.fi-form-control{appearance:auto;cursor:pointer}
.fi-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fi-form-hint{font-size:.72rem;color:var(--fi-gray-400);margin-top:4px}
.fi-form-control.is-valid{border-color:var(--fi-success)}
.fi-form-control.is-invalid{border-color:var(--fi-danger)}

/* ════════════════════════════════
   ALERTS
   ════════════════════════════════ */
.fi-alert{
    padding:14px 18px;border-radius:var(--fi-radius);margin-bottom:16px;
    font-size:.84rem;display:flex;align-items:center;gap:10px;
    border-left:4px solid transparent;animation:fiSlideDown .3s ease;
}
@keyframes fiSlideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.fi-alert-success{background:rgba(var(--fi-success-rgb),.08);border-left-color:var(--fi-success);color:#166534}
.fi-alert-error{background:rgba(var(--fi-danger-rgb),.08);border-left-color:var(--fi-danger);color:#9a3412}
.fi-alert-warning{background:rgba(var(--fi-warning-rgb),.08);border-left-color:var(--fi-warning);color:#92400e}
.fi-alert-info{background:rgba(var(--fi-info-rgb),.08);border-left-color:var(--fi-info);color:#0e7490}
.fi-alert i{font-size:1.2rem;flex-shrink:0}

/* ════════════════════════════════
   TABS
   ════════════════════════════════ */
.fi-tabs{display:flex;gap:4px;border-bottom:2px solid var(--fi-gray-100);margin-bottom:20px;overflow-x:auto}
.fi-tab{
    padding:10px 20px;font-size:.84rem;font-weight:600;
    color:var(--fi-gray-400);border-bottom:2px solid transparent;
    margin-bottom:-2px;transition:var(--fi-transition);
    white-space:nowrap;cursor:pointer;
}
.fi-tab:hover{color:var(--fi-primary)}
.fi-tab.active{color:var(--fi-primary);border-bottom-color:var(--fi-primary)}

/* ════════════════════════════════
   REFERRAL BOX
   ════════════════════════════════ */
.fi-referral{
    background:linear-gradient(135deg,rgba(var(--fi-primary-rgb),.04),rgba(var(--fi-primary-rgb),.08));
    border:2px dashed rgba(var(--fi-primary-rgb),.2);
    border-radius:var(--fi-radius-lg);padding:20px;
    text-align:center;margin-bottom:24px;
}
.fi-referral-title{font-size:.88rem;font-weight:700;color:var(--fi-gray-900);margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:8px}
.fi-referral-link{
    background:var(--fi-white);padding:10px 16px;border-radius:8px;
    font-family:'JetBrains Mono','Fira Code',monospace;font-size:.82rem;
    color:var(--fi-primary);word-break:break-all;
    border:1px solid var(--fi-gray-200);margin-bottom:12px;
}
.fi-referral-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.fi-referral-code{font-size:.78rem;color:var(--fi-gray-600)}
.fi-referral-code strong{color:var(--fi-primary)}

/* ════════════════════════════════
   GENEALOGY TREE
   ════════════════════════════════ */
.fi-tree{padding:16px}
.fi-tree ul{list-style:none;padding-left:28px;position:relative}
.fi-tree ul::before{content:'';position:absolute;left:12px;top:0;bottom:0;width:2px;background:var(--fi-gray-200)}
.fi-tree li{position:relative;padding:6px 0}
.fi-tree li::before{content:'';position:absolute;left:-16px;top:18px;width:16px;height:2px;background:var(--fi-gray-200)}
.fi-tree-node{
    display:inline-flex;align-items:center;gap:12px;
    background:var(--fi-white);border:1.5px solid var(--fi-gray-200);
    border-radius:var(--fi-radius);padding:10px 16px;font-size:.84rem;
    transition:var(--fi-transition);
}
.fi-tree-node:hover{box-shadow:var(--fi-card-shadow-hover);border-color:var(--fi-primary)}
.fi-tree-node.root{border:2px solid var(--fi-primary);background:rgba(var(--fi-primary-rgb),.02)}
.fi-tree-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.fi-tree-dot.active{background:var(--fi-success)}
.fi-tree-dot.inactive{background:var(--fi-gray-400)}
.fi-tree-dot.blocked{background:var(--fi-danger)}
.fi-tree-info small{color:var(--fi-gray-400);font-size:.72rem}

/* ════════════════════════════════
   PAGINATION
   ════════════════════════════════ */
.fi-pagination{display:flex;gap:4px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.fi-page-link,.pagination .page-link{
    padding:7px 12px;border-radius:var(--fi-radius-sm);
    border:1px solid var(--fi-gray-200);font-size:.8rem;
    color:var(--fi-gray-700);transition:var(--fi-transition);font-weight:500;
}
.fi-page-link:hover,.pagination .page-link:hover{
    background:rgba(var(--fi-primary-rgb),.06);color:var(--fi-primary);
    border-color:rgba(var(--fi-primary-rgb),.2);text-decoration:none;
}
.fi-page-link.active,.pagination .page-link.active{
    background:var(--fi-primary);color:#fff;border-color:var(--fi-primary);
}

/* ════════════════════════════════
   EMPTY STATE
   ════════════════════════════════ */
.fi-empty{text-align:center;padding:40px 20px;color:var(--fi-gray-400)}
.fi-empty i{font-size:3rem;margin-bottom:12px;display:block;opacity:.4}
.fi-empty p{font-size:.88rem;line-height:1.6}

/* ════════════════════════════════
   GRID HELPERS
   ════════════════════════════════ */
.fi-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.fi-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.fi-grid-2-1{display:grid;grid-template-columns:2fr 1fr;gap:20px}
.fi-grid-1-2{display:grid;grid-template-columns:1fr 2fr;gap:20px}

/* ════════════════════════════════
   LEVEL BADGES (Commission levels)
   ════════════════════════════════ */
.fi-level{display:inline-flex;align-items:center;gap:4px;font-size:.76rem;font-weight:700;padding:4px 10px;border-radius:6px}
.fi-level-personal{background:rgba(var(--fi-primary-rgb),.1);color:var(--fi-primary)}
.fi-level-n1{background:rgba(var(--fi-success-rgb),.1);color:var(--fi-success)}
.fi-level-n2{background:rgba(var(--fi-info-rgb),.1);color:#0891b2}
.fi-level-n3{background:rgba(var(--fi-warning-rgb),.1);color:#b45309}

/* ════════════════════════════════
   SPONSOR INFO BOX
   ════════════════════════════════ */
.fi-sponsor-info{
    background:rgba(var(--fi-success-rgb),.06);
    border:1px solid rgba(var(--fi-success-rgb),.15);
    border-radius:var(--fi-radius);padding:14px 18px;
    margin-bottom:16px;font-size:.84rem;
    display:flex;align-items:center;gap:10px;
}

/* ════════════════════════════════
   AUTH PAGES (Login/Register)
   ════════════════════════════════ */
.fi-auth{
    min-height:100vh;display:flex;align-items:center;justify-content:center;
    background:var(--fi-sidebar-bg);padding:24px;
    position:relative;overflow:hidden;
}
.fi-auth::before{
    content:'';position:absolute;width:600px;height:600px;
    background:radial-gradient(circle,rgba(var(--fi-primary-rgb),.15),transparent);
    top:-200px;right:-200px;border-radius:50%;
}
.fi-auth::after{
    content:'';position:absolute;width:400px;height:400px;
    background:radial-gradient(circle,rgba(var(--fi-secondary-rgb),.1),transparent);
    bottom:-150px;left:-150px;border-radius:50%;
}
.fi-auth-card{
    background:var(--fi-white);border-radius:var(--fi-radius-lg);
    padding:36px;width:100%;max-width:460px;
    box-shadow:0 24px 60px rgba(0,0,0,.25);position:relative;z-index:1;
}
.fi-auth-logo{text-align:center;margin-bottom:20px}
.fi-auth-logo img{height:56px}
.fi-auth-title{text-align:center;font-size:1.3rem;font-weight:800;color:var(--fi-dark);margin-bottom:4px}
.fi-auth-subtitle{text-align:center;color:var(--fi-gray-400);font-size:.84rem;margin-bottom:28px}

/* ════════════════════════════════
   MONEY TEXT
   ════════════════════════════════ */
.fi-money{font-weight:700;font-variant-numeric:tabular-nums}
.fi-money-plus{color:var(--fi-success)}
.fi-money-minus{color:var(--fi-danger)}

/* ════════════════════════════════
   PROFILE CARD
   ════════════════════════════════ */
.fi-profile-info p{font-size:.84rem;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.fi-profile-info p strong{min-width:130px;color:var(--fi-gray-400);font-weight:600;font-size:.76rem;text-transform:uppercase;letter-spacing:.3px}

/* ════════════════════════════════
   SIDEBAR OVERLAY (mobile)
   ════════════════════════════════ */
.fi-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.5);z-index:999;
    backdrop-filter:blur(2px);
}
.fi-overlay.show{display:block}

/* ════════════════════════════════
   RESPONSIVE
   ════════════════════════════════ */
@media(max-width:1024px){
    .fi-sidebar{transform:translateX(-100%)}
    .fi-sidebar.open{transform:translateX(0)}
    .fi-main{margin-left:0}
    .fi-hamburger{display:flex}
    .fi-topbar-profile-name{display:none}
    .fi-topbar-profile-chevron{display:none}
    .fi-topbar-profile{padding:5px}
    .fi-profile-menu{right:-10px;width:220px}
    .fi-search input{width:160px}
    .fi-grid-2,.fi-grid-2-1,.fi-grid-1-2{grid-template-columns:1fr}
}
@media(max-width:768px){
    .fi-content{padding:16px}
    .fi-topbar{padding:0 16px;height:60px}
    .fi-stats{grid-template-columns:1fr 1fr}
    .fi-wallets{grid-template-columns:1fr 1fr}
    .fi-form-row{grid-template-columns:1fr}
    .fi-table thead th,.fi-table tbody td{padding:10px 12px;font-size:.78rem}
    .fi-search{display:none}
    .fi-date-pill{display:none}
}
@media(max-width:480px){
    .fi-stats{grid-template-columns:1fr}
    .fi-wallets{grid-template-columns:1fr}
    .fi-auth-card{padding:24px}
    .fi-grid-3{grid-template-columns:1fr}
}
