/* ================================================================
   Nexxcon - Premium Glassmorphism Crypto Dashboard
   Inspired by AIBots / Extej trading terminal aesthetics
   Features: Sidebar, glassmorphism cards, gradient borders,
   ambient glow blobs, neon accents, frosted glass
   ================================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
    /* Deep space palette */
    --bg-0:#030712;
    --bg-1:#0a0f1e;
    --bg-2:#0f1629;
    --bg-3:#141c32;
    --bg-4:#1a2340;
    --bg-hover:rgba(255,255,255,.04);
    --border:rgba(255,255,255,.06);
    --border-light:rgba(255,255,255,.10);
    --border-glow:rgba(99,130,255,.15);

    --text-0:#f0f2fa;
    --text-1:#b4bcd0;
    --text-2:#6b7a99;
    --text-3:#3d4b6e;

    /* Accent colors */
    --green:#00d4aa;
    --green-dim:rgba(0,212,170,.10);
    --green-glow:rgba(0,212,170,.30);
    --red:#ff4d6a;
    --red-dim:rgba(255,77,106,.10);
    --red-glow:rgba(255,77,106,.25);
    --blue:#4f7df9;
    --blue-dim:rgba(79,125,249,.10);
    --blue-glow:rgba(79,125,249,.30);
    --purple:#a855f7;
    --purple-dim:rgba(168,85,247,.10);
    --purple-glow:rgba(168,85,247,.25);
    --cyan:#22d3ee;
    --cyan-dim:rgba(34,211,238,.10);
    --cyan-glow:rgba(34,211,238,.25);
    --amber:#f59e0b;
    --amber-dim:rgba(245,158,11,.10);
    --orange:#f97316;
    --orange-dim:rgba(249,115,22,.10);

    /* Glass */
    --glass-bg:rgba(15,22,41,.55);
    --glass-border:rgba(255,255,255,.08);
    --glass-blur:20px;
    --glass-shadow:0 8px 32px rgba(0,0,0,.4);

    /* Sizing */
    --radius:12px;
    --radius-lg:16px;
    --radius-xl:20px;
    --sidebar-width:240px;

    --ease:cubic-bezier(.4,0,.2,1);

    /* Subtle overlay backgrounds (for inline styles in JS) */
    --overlay-1:rgba(255,255,255,.02);
    --overlay-2:rgba(255,255,255,.03);
    --overlay-3:rgba(255,255,255,.04);
    --overlay-4:rgba(255,255,255,.05);
    --overlay-5:rgba(255,255,255,.06);
    --overlay-6:rgba(255,255,255,.08);
}

/* Light theme */
body.light-theme{
    --bg-0:#f0f2f8;--bg-1:#ffffff;--bg-2:#f6f8fc;--bg-3:#eceff5;--bg-4:#e0e5ef;
    --bg-hover:rgba(0,0,0,.03);--border:rgba(0,0,0,.08);--border-light:rgba(0,0,0,.12);--border-glow:rgba(79,125,249,.12);
    --text-0:#0c1220;--text-1:#2a3345;--text-2:#6b7590;--text-3:#9aa0b2;
    --green:#059669;--green-dim:rgba(5,150,105,.08);--green-glow:rgba(5,150,105,.15);
    --red:#dc2626;--red-dim:rgba(220,38,38,.06);--red-glow:rgba(220,38,38,.10);
    --blue:#2563eb;--blue-dim:rgba(37,99,235,.08);--blue-glow:rgba(37,99,235,.12);
    --purple:#7c3aed;--purple-dim:rgba(124,58,237,.06);--purple-glow:rgba(124,58,237,.10);
    --cyan:#0891b2;--cyan-dim:rgba(8,145,178,.08);
    --amber:#d97706;--amber-dim:rgba(217,119,6,.06);
    --orange:#ea580c;--orange-dim:rgba(234,88,12,.08);
    --glass-bg:rgba(255,255,255,.7);--glass-border:rgba(0,0,0,.08);--glass-blur:16px;--glass-shadow:0 4px 16px rgba(0,0,0,.06);

    /* Subtle overlay backgrounds — light mode uses dark overlays */
    --overlay-1:rgba(0,0,0,.02);
    --overlay-2:rgba(0,0,0,.03);
    --overlay-3:rgba(0,0,0,.04);
    --overlay-4:rgba(0,0,0,.05);
    --overlay-5:rgba(0,0,0,.06);
    --overlay-6:rgba(0,0,0,.08);
}
body.light-theme .sidebar{background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(246,248,252,.98));border-right-color:rgba(0,0,0,.06)}
body.light-theme .sidebar::after{background:linear-gradient(180deg,transparent,rgba(37,99,235,.08),rgba(124,58,237,.06),transparent)}
body.light-theme .sidebar::before{background:radial-gradient(circle,rgba(37,99,235,.04),transparent 70%)}
body.light-theme .nav-icon-wrap{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.04)}
body.light-theme .nav-item:hover{background:rgba(0,0,0,.04)}
body.light-theme .nav-item:hover .nav-icon-wrap{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.08)}
body.light-theme .nav-item.active{background:rgba(0,0,0,.04)}
body.light-theme .nav-separator{background:linear-gradient(90deg,transparent,rgba(0,0,0,.06),transparent)}
body.light-theme .sidebar-logo::after{background:linear-gradient(90deg,transparent,rgba(0,0,0,.06),transparent)}
body.light-theme .sidebar-profile{background:rgba(37,99,235,.06);border-color:rgba(0,0,0,.04)}
body.light-theme .sidebar-profile:hover{background:rgba(37,99,235,.10);border-color:rgba(0,0,0,.08)}
body.light-theme .sidebar-bottom{border-top-color:rgba(0,0,0,.06)}

/* ── Light theme: Main content area component overrides ────────── */
body.light-theme .sidebar{border-right-color:rgba(0,0,0,.08)}
body.light-theme .nav-icon-wrap{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.05)}
body.light-theme .nav-item.active .nav-icon-wrap{background:var(--blue-dim);border-color:var(--blue)}

/* Panels, cards, glass elements */
body.light-theme .panel{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.08)}
body.light-theme .method-card{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}
body.light-theme .method-card:hover,
body.light-theme .method-card.active{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.12)}
body.light-theme .method-card::before{background:linear-gradient(90deg,transparent,rgba(0,0,0,.04),transparent)}

/* Inputs & form elements */
body.light-theme .form-input,
body.light-theme .form-select,
body.light-theme .form-textarea,
body.light-theme input[type="text"],
body.light-theme input[type="number"],
body.light-theme textarea,
body.light-theme select{background:rgba(0,0,0,.02) !important;color:var(--text-0) !important;border-color:rgba(0,0,0,.10) !important}
body.light-theme .form-input:focus,
body.light-theme input[type="text"]:focus,
body.light-theme input[type="number"]:focus{background:rgba(0,0,0,.03) !important;border-color:var(--blue) !important}
body.light-theme .copy-btn{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.08)}
body.light-theme .copy-btn:hover{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.12)}

/* Buttons */
body.light-theme .topbar-btn{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.06)}
body.light-theme .topbar-btn:hover{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.10)}
body.light-theme .btn-secondary{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.08)}
body.light-theme .btn-secondary:hover{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.12)}

/* Card tabs */
body.light-theme .card-tabs{background:rgba(0,0,0,.03)}
body.light-theme .card-tab{color:var(--text-2)}
body.light-theme .card-tab.active{background:var(--bg-1);color:var(--text-0);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* Dashboard hero & stat pills */
body.light-theme .stat-pill{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.06)}
body.light-theme .stat-card{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.08)}
body.light-theme .stat-card:hover{border-color:rgba(0,0,0,.12)}
body.light-theme .hero-section{border-color:rgba(0,0,0,.06)}

/* Legend & chart */
body.light-theme .legend-row:hover{background:rgba(0,0,0,.03)}
body.light-theme .legend-row.legend-active{background:rgba(0,0,0,.05)}
body.light-theme .legend-bar-wrap{background:rgba(0,0,0,.06)}

/* Activity items */
body.light-theme .act-item{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}

/* Wallet sections */
body.light-theme .wallet-section{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}
body.light-theme .tx-row{border-bottom-color:rgba(0,0,0,.05)}
body.light-theme .tx-row:hover{background:rgba(0,0,0,.02)}

/* Progress bars */
body.light-theme .progress-bar{background:rgba(0,0,0,.06)}

/* Arb monitor */
body.light-theme .arb-row-rank.cool{background:rgba(0,0,0,.03)}

/* Earnings table & detail boxes */
body.light-theme .earnings-table td,
body.light-theme .earnings-table th{border-color:rgba(0,0,0,.06)}
body.light-theme .earnings-table thead{background:rgba(0,0,0,.02)}

/* Referral link area */
body.light-theme .referral-link-box{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.06)}

/* Notification panel */
body.light-theme .notification-item{border-color:rgba(0,0,0,.05)}
body.light-theme .notification-item:hover{background:rgba(0,0,0,.02)}

/* Tab header borders */
body.light-theme .tab-header{border-bottom-color:rgba(0,0,0,.06)}

/* Modal */
body.light-theme .modal-overlay{background:rgba(0,0,0,.4)}
body.light-theme .modal-content{background:var(--bg-1);border-color:rgba(0,0,0,.10)}

/* Separators & decorative lines */
body.light-theme .nav-separator{background:linear-gradient(90deg,transparent,rgba(0,0,0,.08),transparent)}

html,body{height:100%;overflow:hidden}
body{
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    background:var(--bg-0);
    color:var(--text-1);
    font-size:13px;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}

::selection{background:var(--blue);color:#fff}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--overlay-6);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--border-light)}
body.light-theme ::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12)}
body.light-theme ::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.20)}

/* ================================================================
   AMBIENT GLOW BLOBS - Floating background light effects
   ================================================================ */
.ambient-glow{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.glow-blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.35;animation:blobFloat 20s ease-in-out infinite}
.blob-1{width:600px;height:600px;background:radial-gradient(circle,rgba(79,125,249,.25),transparent 70%);top:-10%;left:10%;animation-delay:0s}
.blob-2{width:500px;height:500px;background:radial-gradient(circle,rgba(168,85,247,.20),transparent 70%);top:40%;right:-5%;animation-delay:-7s}
.blob-3{width:450px;height:450px;background:radial-gradient(circle,rgba(0,212,170,.15),transparent 70%);bottom:-5%;left:30%;animation-delay:-14s}
body.light-theme .ambient-glow{display:none}

/* ── Light theme: Topbar ────────── */
body.light-theme .topbar{background:rgba(255,255,255,.85);border-bottom-color:rgba(0,0,0,.06)}
body.light-theme .topbar::after{background:linear-gradient(90deg,transparent,rgba(37,99,235,.08),rgba(124,58,237,.06),transparent)}
body.light-theme .page-heading{color:var(--text-0)}

/* ── Light theme: Hero balance card ────────── */
body.light-theme .hero-glow{display:none}
body.light-theme .hero-balance-card{background:var(--glass-bg);border-color:var(--glass-border)}
body.light-theme .hero-balance-card::after{background:none}
body.light-theme .hero-label{color:var(--text-2)}

/* ── Light theme: Glass card refinements ────────── */
body.light-theme .glass-card{background:rgba(255,255,255,.8);border-color:rgba(0,0,0,.08);box-shadow:0 2px 8px rgba(0,0,0,.04)}
body.light-theme .glass-card::before{background:linear-gradient(90deg,transparent 5%,rgba(37,99,235,.08) 30%,rgba(124,58,237,.06) 60%,transparent 95%)}
body.light-theme .glass-card:hover{border-color:rgba(0,0,0,.12);box-shadow:0 4px 16px rgba(0,0,0,.06);transform:translateY(-1px)}
@keyframes blobFloat{
    0%,100%{transform:translate(0,0) scale(1)}
    25%{transform:translate(30px,-40px) scale(1.05)}
    50%{transform:translate(-20px,30px) scale(.95)}
    75%{transform:translate(40px,20px) scale(1.02)}
}

/* ================================================================
   APP LAYOUT
   ================================================================ */
.app-layout{display:flex;height:100vh;position:relative;z-index:1}

/* ================================================================
   SIDEBAR - Premium Trading Terminal
   ================================================================ */
.sidebar{
    width:var(--sidebar-width);
    height:100vh;
    background:linear-gradient(180deg,rgba(8,12,28,.92) 0%,rgba(6,10,22,.96) 100%);
    backdrop-filter:blur(32px);
    -webkit-backdrop-filter:blur(32px);
    border-right:1px solid rgba(255,255,255,.04);
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    flex-shrink:0;
    position:relative;
    z-index:10;
    overflow-y:auto;
    overflow-x:hidden;
}
/* Premium right edge glow line */
.sidebar::after{
    content:'';position:absolute;top:0;right:0;bottom:0;width:1px;
    background:linear-gradient(180deg,transparent 5%,rgba(79,125,249,.20) 25%,rgba(168,85,247,.15) 50%,rgba(34,211,238,.10) 75%,transparent 95%);
}
/* Inner ambient glow */
.sidebar::before{
    content:'';position:absolute;top:-60px;left:-40px;width:200px;height:200px;
    background:radial-gradient(circle,rgba(79,125,249,.06) 0%,transparent 70%);
    pointer-events:none;z-index:0;
}

.sidebar-top{padding:0 0 8px;position:relative;z-index:1}
.sidebar-bottom{padding:10px 0;border-top:1px solid rgba(255,255,255,.04);position:relative;z-index:1}
.sidebar-bottom .nav-item{margin:0 10px;width:calc(100% - 20px);box-sizing:border-box}

/* Logo */
.sidebar-logo{
    padding:22px 20px 20px;
    display:flex;align-items:center;
    position:relative;
}
.sidebar-logo::after{
    content:'';position:absolute;bottom:0;left:20px;right:20px;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
}
.sidebar-logo img{height:30px;width:auto;object-fit:contain}
.logo-light{display:none}.logo-dark{display:block}
body.light-theme .logo-light{display:block}body.light-theme .logo-dark{display:none}

/* Nav separator line */
.nav-separator{
    height:1px;margin:6px 24px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);
}

/* Nav container */
.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:12px 0}

/* Nav items - Premium style */
.nav-item{
    display:flex;align-items:center;gap:14px;
    padding:0;margin:0 10px;height:44px;
    background:none;border:none;border-radius:12px;
    color:var(--text-2);font:500 13px/1 'Inter',sans-serif;
    cursor:pointer;transition:all .25s var(--ease);
    position:relative;white-space:nowrap;text-align:left;
    padding-left:14px;
}

/* Icon wrapper - glassmorphic circle */
.nav-icon-wrap{
    width:34px;height:34px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.04);
    transition:all .3s var(--ease);flex-shrink:0;
    position:relative;
}

.nav-label{font-weight:500;letter-spacing:-.1px;transition:color .25s}

.nav-item svg{
    opacity:.4;transition:all .3s var(--ease);
    filter:drop-shadow(0 0 0px transparent);
}

/* Hover state */
.nav-item:hover{background:rgba(255,255,255,.04)}
.nav-item:hover svg{opacity:.85}
.nav-item:hover .nav-label{color:var(--text-0)}
.nav-item:hover .nav-icon-wrap{
    background:rgba(255,255,255,.06);
    border-color:rgba(255,255,255,.08);
}

/* ===== ACTIVE STATE - Per-accent color theming ===== */
.nav-item.active{background:rgba(255,255,255,.04)}
.nav-item.active .nav-label{color:var(--text-0);font-weight:600}
.nav-item.active svg{opacity:1}

/* Active indicator bar (left edge) */
.nav-item.active::before{
    content:'';position:absolute;left:-10px;top:50%;transform:translateY(-50%);
    width:3px;height:22px;border-radius:0 4px 4px 0;
    transition:all .3s var(--ease);
}

/* Blue accent (dashboard, settings) */
.nav-item[data-accent="blue"].active .nav-icon-wrap{background:rgba(79,125,249,.12);border-color:rgba(79,125,249,.20)}
.nav-item[data-accent="blue"].active svg{stroke:var(--blue);filter:drop-shadow(0 0 6px rgba(79,125,249,.35))}
.nav-item[data-accent="blue"].active::before{background:var(--blue);box-shadow:0 0 12px var(--blue-glow)}
.nav-item[data-accent="blue"]:hover .nav-icon-wrap{border-color:rgba(79,125,249,.12)}

/* Green accent (deposit) */
.nav-item[data-accent="green"].active .nav-icon-wrap{background:rgba(0,212,170,.10);border-color:rgba(0,212,170,.18)}
.nav-item[data-accent="green"].active svg{stroke:var(--green);filter:drop-shadow(0 0 6px rgba(0,212,170,.35))}
.nav-item[data-accent="green"].active::before{background:var(--green);box-shadow:0 0 12px var(--green-glow)}
.nav-item[data-accent="green"]:hover .nav-icon-wrap{border-color:rgba(0,212,170,.12)}

/* Red accent (withdraw) */
.nav-item[data-accent="red"].active .nav-icon-wrap{background:rgba(255,77,106,.10);border-color:rgba(255,77,106,.18)}
.nav-item[data-accent="red"].active svg{stroke:var(--red);filter:drop-shadow(0 0 6px rgba(255,77,106,.30))}
.nav-item[data-accent="red"].active::before{background:var(--red);box-shadow:0 0 12px var(--red-glow)}
.nav-item[data-accent="red"]:hover .nav-icon-wrap{border-color:rgba(255,77,106,.12)}

/* Cyan accent (markets) */
.nav-item[data-accent="cyan"].active .nav-icon-wrap{background:rgba(34,211,238,.10);border-color:rgba(34,211,238,.18)}
.nav-item[data-accent="cyan"].active svg{stroke:var(--cyan);filter:drop-shadow(0 0 6px rgba(34,211,238,.35))}
.nav-item[data-accent="cyan"].active::before{background:var(--cyan);box-shadow:0 0 12px var(--cyan-glow)}
.nav-item[data-accent="cyan"]:hover .nav-icon-wrap{border-color:rgba(34,211,238,.12)}

/* Purple accent (earnings) */
.nav-item[data-accent="purple"].active .nav-icon-wrap{background:rgba(168,85,247,.10);border-color:rgba(168,85,247,.18)}
.nav-item[data-accent="purple"].active svg{stroke:var(--purple);filter:drop-shadow(0 0 6px rgba(168,85,247,.35))}
.nav-item[data-accent="purple"].active::before{background:var(--purple);box-shadow:0 0 12px var(--purple-glow)}
.nav-item[data-accent="purple"]:hover .nav-icon-wrap{border-color:rgba(168,85,247,.12)}

/* Amber accent (opportunities, referrals) */
.nav-item[data-accent="amber"].active .nav-icon-wrap{background:rgba(245,158,11,.10);border-color:rgba(245,158,11,.18)}
.nav-item[data-accent="amber"].active svg{stroke:var(--amber);filter:drop-shadow(0 0 6px rgba(245,158,11,.30))}
.nav-item[data-accent="amber"].active::before{background:var(--amber);box-shadow:0 0 12px rgba(245,158,11,.25)}
.nav-item[data-accent="amber"]:hover .nav-icon-wrap{border-color:rgba(245,158,11,.12)}

/* Sidebar profile card */
.sidebar-profile{
    display:flex;align-items:center;gap:12px;
    padding:12px 14px;border-radius:12px;
    background:rgba(37,99,235,.06);
    border:1px solid rgba(255,255,255,.04);
    cursor:pointer;transition:all .25s var(--ease);margin-top:8px;
}
.sidebar-profile:hover{
    background:rgba(37,99,235,.10);
    border-color:rgba(255,255,255,.08);
}
.profile-avatar{
    width:34px;height:34px;border-radius:10px;
    background:var(--avatar-bg, #2563eb);
    color:#fff;display:flex;align-items:center;justify-content:center;
    font-size:11px;font-weight:800;letter-spacing:.5px;flex-shrink:0;
    box-shadow:0 4px 16px rgba(37,99,235,.25);
}
.profile-info{display:flex;flex-direction:column;gap:3px;min-width:0}
.profile-name{font-size:12px;font-weight:600;color:var(--text-0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1}
.profile-badge{
    display:inline-flex;align-items:center;gap:3px;
    font-size:9px;font-weight:700;color:var(--amber);
    letter-spacing:.3px;text-transform:uppercase;line-height:1;
}

/* ================================================================
   MAIN WRAPPER
   ================================================================ */
.main-wrapper{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}

/* ================================================================
   TOPBAR
   ================================================================ */
.topbar{
    height:60px;
    background:rgba(10,15,30,.50);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border-bottom:1px solid var(--border);
    display:flex;align-items:center;justify-content:space-between;
    padding:0 28px;flex-shrink:0;position:relative;z-index:5;
}
.topbar::after{
    content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(79,125,249,.12),rgba(168,85,247,.08),transparent);
}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:12px}
.page-heading{font-size:18px;font-weight:700;color:var(--text-0);letter-spacing:-.2px}

/* Live badge */
.live-badge{
    display:flex;align-items:center;gap:6px;
    padding:4px 10px;border-radius:20px;
    background:var(--green-dim);
    font-size:10px;font-weight:600;color:var(--green);
}
.live-dot-pulse{
    width:6px;height:6px;border-radius:50%;background:var(--green);
    animation:livePulse 2s infinite;box-shadow:0 0 8px var(--green-glow);
}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* Ticker chips */
.header-ticker{display:flex;gap:8px}
.ticker-chip{
    display:flex;align-items:center;gap:6px;
    padding:6px 12px;border-radius:10px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border);font-size:12px;
}
.ticker-icon{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ticker-symbol{font-weight:700;color:var(--text-0);font-size:11px;letter-spacing:.3px}
.ticker-price{font-weight:600;color:var(--text-0);font-variant-numeric:tabular-nums}
.ticker-change{font-weight:600;font-size:10px;padding:2px 6px;border-radius:4px;font-variant-numeric:tabular-nums}
.ticker-change.positive{color:var(--green);background:var(--green-dim)}
.ticker-change.negative{color:var(--red);background:var(--red-dim)}

/* Topbar buttons */
.topbar-btn{
    width:38px;height:38px;border-radius:var(--radius);
    background:rgba(255,255,255,.04);border:1px solid var(--border);
    color:var(--text-2);display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .15s var(--ease);position:relative;flex-shrink:0;
}
.topbar-btn:hover{background:rgba(255,255,255,.08);border-color:var(--border-light);color:var(--text-0)}
.sun-icon{display:block}.moon-icon{display:none}
body.light-theme .sun-icon{display:none}body.light-theme .moon-icon{display:block}
.notif-badge{position:absolute;top:3px;right:3px;min-width:14px;height:14px;background:var(--red);color:#fff;font-size:8px;font-weight:700;border-radius:7px;display:none;align-items:center;justify-content:center;padding:0 3px}
.notif-badge.show{display:flex}
.topbar-time{font-size:12px;font-weight:500;color:var(--text-2);font-variant-numeric:tabular-nums;min-width:72px;text-align:right}

/* Topbar language dropdown */
.topbar-lang-wrap{position:relative}
.topbar-lang-dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--card-bg,#1a1a2e);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:4px;min-width:155px;box-shadow:0 8px 32px rgba(0,0,0,.4);z-index:999;backdrop-filter:blur(20px);animation:topLangDrop .15s ease;}
.topbar-lang-dropdown.open{display:block}
@keyframes topLangDrop{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
.topbar-lang-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text-1);border-radius:7px;cursor:pointer;font-size:13px;font-weight:400;transition:all .15s;}
.topbar-lang-option:hover{background:rgba(255,255,255,.06);}
.topbar-lang-option.active{background:rgba(99,102,241,.15);color:var(--primary);font-weight:600;}
body.light-theme .topbar-lang-dropdown{background:var(--card-bg,#fff);border-color:rgba(0,0,0,.1);box-shadow:0 8px 32px rgba(0,0,0,.12);}
body.light-theme .topbar-lang-option:hover{background:rgba(0,0,0,.04);}

/* ================================================================
   MAIN CONTENT
   ================================================================ */
.main-content{
    flex:1;overflow-y:auto;overflow-x:hidden;
    padding:28px;position:relative;z-index:1;
}
.page{display:none;position:relative}
.page.active{display:block}

/* ================================================================
   PAGE TRANSITION ENGINE
   ================================================================ */
/* --- Slide-Fade (default) --- */
.page.ptr-slide-fade.ptr-entering{
    animation:ptrSlideEnter .32s cubic-bezier(.22,1,.36,1) forwards;
}
.page.ptr-slide-fade.ptr-leaving{
    animation:ptrSlideLeave .32s cubic-bezier(.22,1,.36,1) forwards;
    position:absolute;top:0;left:0;right:0;pointer-events:none;
}
/* Forward direction */
.page.ptr-slide-fade.ptr-forward.ptr-entering{
    animation-name:ptrSlideEnterFwd;
}
.page.ptr-slide-fade.ptr-forward.ptr-leaving{
    animation-name:ptrSlideLeaveFwd;
}
/* Backward direction */
.page.ptr-slide-fade.ptr-backward.ptr-entering{
    animation-name:ptrSlideEnterBwd;
}
.page.ptr-slide-fade.ptr-backward.ptr-leaving{
    animation-name:ptrSlideLeaveBwd;
}

@keyframes ptrSlideEnterFwd{
    from{opacity:0;transform:translateX(40px)}
    to{opacity:1;transform:translateX(0)}
}
@keyframes ptrSlideLeaveFwd{
    from{opacity:1;transform:translateX(0)}
    to{opacity:0;transform:translateX(-40px)}
}
@keyframes ptrSlideEnterBwd{
    from{opacity:0;transform:translateX(-40px)}
    to{opacity:1;transform:translateX(0)}
}
@keyframes ptrSlideLeaveBwd{
    from{opacity:1;transform:translateX(0)}
    to{opacity:0;transform:translateX(40px)}
}

/* --- Fade --- */
.page.ptr-fade.ptr-entering{
    animation:ptrFadeIn .32s cubic-bezier(.22,1,.36,1) forwards;
}
.page.ptr-fade.ptr-leaving{
    animation:ptrFadeOut .32s cubic-bezier(.22,1,.36,1) forwards;
    position:absolute;top:0;left:0;right:0;pointer-events:none;
}
@keyframes ptrFadeIn{from{opacity:0}to{opacity:1}}
@keyframes ptrFadeOut{from{opacity:1}to{opacity:0}}

/* --- Scale --- */
.page.ptr-scale.ptr-entering{
    animation:ptrScaleIn .32s cubic-bezier(.22,1,.36,1) forwards;
}
.page.ptr-scale.ptr-leaving{
    animation:ptrScaleOut .32s cubic-bezier(.22,1,.36,1) forwards;
    position:absolute;top:0;left:0;right:0;pointer-events:none;
}
@keyframes ptrScaleIn{
    from{opacity:0;transform:scale(.94)}
    to{opacity:1;transform:scale(1)}
}
@keyframes ptrScaleOut{
    from{opacity:1;transform:scale(1)}
    to{opacity:0;transform:scale(1.04)}
}

/* --- Slide-Up --- */
.page.ptr-slide-up.ptr-entering{
    animation:ptrSlideUpIn .32s cubic-bezier(.22,1,.36,1) forwards;
}
.page.ptr-slide-up.ptr-leaving{
    animation:ptrSlideUpOut .32s cubic-bezier(.22,1,.36,1) forwards;
    position:absolute;top:0;left:0;right:0;pointer-events:none;
}
@keyframes ptrSlideUpIn{
    from{opacity:0;transform:translateY(30px)}
    to{opacity:1;transform:translateY(0)}
}
@keyframes ptrSlideUpOut{
    from{opacity:1;transform:translateY(0)}
    to{opacity:0;transform:translateY(-20px)}
}

/* --- Flip (subtle 3D) --- */
.page.ptr-flip.ptr-entering{
    animation:ptrFlipIn .36s cubic-bezier(.22,1,.36,1) forwards;
    transform-origin:center center;
}
.page.ptr-flip.ptr-leaving{
    animation:ptrFlipOut .36s cubic-bezier(.22,1,.36,1) forwards;
    position:absolute;top:0;left:0;right:0;pointer-events:none;
    transform-origin:center center;
}
@keyframes ptrFlipIn{
    from{opacity:0;transform:perspective(1200px) rotateY(8deg) scale(.96)}
    to{opacity:1;transform:perspective(1200px) rotateY(0) scale(1)}
}
@keyframes ptrFlipOut{
    from{opacity:1;transform:perspective(1200px) rotateY(0) scale(1)}
    to{opacity:0;transform:perspective(1200px) rotateY(-8deg) scale(.96)}
}

/* Reduced motion preference */
@media(prefers-reduced-motion:reduce){
    .page.ptr-entering,.page.ptr-leaving{animation-duration:.01ms !important}
}
.page-title{margin-bottom:24px}
.page-title h2{font-size:20px;font-weight:700;color:var(--text-0);letter-spacing:-.2px}

/* ================================================================
   GLASS CARD - The core premium component
   ================================================================ */
.glass-card{
    background:var(--glass-bg);
    backdrop-filter:blur(var(--glass-blur));
    -webkit-backdrop-filter:blur(var(--glass-blur));
    border:1px solid var(--glass-border);
    border-radius:var(--radius-xl);
    box-shadow:var(--glass-shadow);
    position:relative;
    overflow:hidden;
    transition:all .25s var(--ease);
}
/* Gradient top edge glow */
.glass-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent 5%,rgba(79,125,249,.25) 30%,rgba(168,85,247,.20) 60%,rgba(34,211,238,.15) 80%,transparent 95%);
    z-index:1;
}
.glass-card:hover{
    border-color:rgba(255,255,255,.12);
    box-shadow:var(--glass-shadow),0 0 30px rgba(79,125,249,.06);
    transform:translateY(-2px);
}
.glass-card-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 24px;border-bottom:1px solid var(--border);
}
.glass-card-header h3{font-size:14px;font-weight:700;color:var(--text-0);letter-spacing:-.1px}

/* ================================================================
   HERO BALANCE CARD
   ================================================================ */
/* Dashboard section row entrances */
.hero-row{margin-bottom:24px;opacity:0;animation:rowFadeUp .5s var(--ease) .1s forwards}
.stats-row{animation:rowFadeUp .5s var(--ease) .2s forwards}
.middle-row{opacity:0;animation:rowFadeUp .5s var(--ease) .35s forwards}
.bottom-row{opacity:0;animation:rowFadeUp .5s var(--ease) .5s forwards}
@keyframes rowFadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.hero-balance-card{
    padding:36px 40px;
    border-radius:var(--radius-xl);
    position:relative;overflow:hidden;
}
/* Animated shimmer sweep */
.hero-balance-card::after{
    content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),transparent);
    animation:heroShimmer 6s ease-in-out infinite;pointer-events:none;z-index:1;
}
@keyframes heroShimmer{0%{left:-100%}50%{left:150%}100%{left:150%}}

/* Internal ambient glow - animated */
.hero-glow{
    position:absolute;top:-50%;right:-20%;width:500px;height:500px;
    background:radial-gradient(circle,rgba(79,125,249,.12) 0%,rgba(168,85,247,.06) 40%,transparent 70%);
    pointer-events:none;animation:heroGlowPulse 4s ease-in-out infinite;
}
@keyframes heroGlowPulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}

.hero-content{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:2;gap:24px;flex-wrap:wrap}
.hero-left{min-width:0}
.hero-label{
    font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;
    color:var(--text-3);margin-bottom:8px;display:block;
}
.hero-value{
    font-size:42px;font-weight:900;color:var(--text-0);
    letter-spacing:-1px;line-height:1.1;
    font-variant-numeric:tabular-nums;
    background:linear-gradient(135deg,#fff 40%,rgba(79,125,249,.7) 70%,rgba(168,85,247,.5));
    background-size:200% 200%;
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    animation:heroGradientShift 5s ease infinite;
}
@keyframes heroGradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
body.light-theme .hero-value{background:linear-gradient(135deg,#0c1220 60%,var(--blue));-webkit-background-clip:text;background-clip:text;animation:none}

.hero-pnl{margin-top:10px}
.pnl-badge{
    display:inline-flex;align-items:center;gap:4px;
    padding:5px 14px;border-radius:20px;
    font-size:12px;font-weight:700;
    transition:all .4s var(--ease);
}
.pnl-badge.positive{color:var(--green);background:var(--green-dim);box-shadow:0 0 16px rgba(0,212,170,.10)}
.pnl-badge.negative{color:var(--red);background:var(--red-dim)}
/* Flash animation when value updates */
.pnl-badge.flash{animation:pnlFlash .6s ease}
@keyframes pnlFlash{0%{transform:scale(1)}30%{transform:scale(1.08)}100%{transform:scale(1)}}

/* Hero action buttons - with ripple */
.hero-right{flex-shrink:0}
.hero-actions{display:flex;gap:10px}
.hero-btn{
    display:flex;align-items:center;gap:8px;
    padding:12px 24px;
    border:1px solid var(--border);
    border-radius:var(--radius);
    background:rgba(255,255,255,.04);
    color:var(--text-1);
    font:600 13px/1 'Inter',sans-serif;
    cursor:pointer;
    transition:all .25s var(--ease);
    white-space:nowrap;
    position:relative;overflow:hidden;
}
/* Shimmer on hover */
.hero-btn::before{
    content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
    transition:left .5s;
}
.hero-btn:hover::before{left:100%}
.hero-btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.hero-btn:active{transform:translateY(-1px) scale(.97);transition:transform .1s}
/* Ripple */
.hero-btn .ripple{
    position:absolute;border-radius:50%;background:rgba(255,255,255,.15);
    transform:scale(0);animation:rippleEffect .6s ease-out;pointer-events:none;
}
@keyframes rippleEffect{to{transform:scale(4);opacity:0}}

.deposit-btn{border-color:rgba(0,212,170,.20);color:var(--green)}
.deposit-btn:hover{border-color:var(--green);background:var(--green-dim);box-shadow:0 8px 32px rgba(0,212,170,.20)}
.withdraw-btn{border-color:rgba(255,77,106,.15);color:var(--red)}
.withdraw-btn:hover{border-color:var(--red);background:var(--red-dim);box-shadow:0 8px 32px rgba(255,77,106,.15)}
.earnings-btn{border-color:rgba(34,211,238,.15);color:var(--cyan)}
.earnings-btn:hover{border-color:var(--cyan);background:var(--cyan-dim);box-shadow:0 8px 32px rgba(34,211,238,.20)}

/* ================================================================
   STATS ROW - Animated stat pills
   ================================================================ */
.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px}
.stat-pill{
    padding:18px 20px;display:flex;align-items:center;gap:14px;
    border-radius:var(--radius-lg);cursor:default;
    transition:all .3s var(--ease);
}
.stat-pill:hover{transform:translateY(-3px);box-shadow:var(--glass-shadow),0 0 20px rgba(79,125,249,.06)}
.stat-pill:hover .stat-pill-icon{transform:scale(1.1)}
.stat-pill-icon{
    width:40px;height:40px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
    transition:transform .3s var(--ease);
}
.stat-pill-icon.green-bg{background:var(--green-dim);color:var(--green)}
.stat-pill-icon.cyan-bg{background:var(--cyan-dim);color:var(--cyan)}
.stat-pill-icon.red-bg{background:var(--red-dim);color:var(--red)}
.stat-pill-icon.purple-bg{background:var(--purple-dim);color:var(--purple)}
.stat-pill-icon.amber-bg{background:var(--amber-dim);color:var(--amber)}
.stat-pill-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:3px}
.stat-pill-value{font-size:16px;font-weight:700;color:var(--text-0);font-variant-numeric:tabular-nums;transition:color .3s}
.stat-pill-value.green{color:var(--green)}
/* Value update pulse */
.stat-pill-value.counting{color:var(--cyan)}

/* Staggered entrance animation */
.stat-pill{opacity:0;animation:statPillIn .5s var(--ease) forwards}
.stat-pill:nth-child(1){animation-delay:.05s}
.stat-pill:nth-child(2){animation-delay:.10s}
.stat-pill:nth-child(3){animation-delay:.15s}
.stat-pill:nth-child(4){animation-delay:.20s}
.stat-pill:nth-child(5){animation-delay:.25s}
@keyframes statPillIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ================================================================
   MIDDLE ROW - Chart + Prices
   ================================================================ */
.middle-row{display:grid;grid-template-columns:380px 1fr;gap:20px;margin-bottom:24px}

/* Chart card */
.chart-card{border-radius:var(--radius-xl)}
.chart-card-body{padding:24px 28px;display:flex;flex-direction:column;align-items:center;gap:20px}
.pie-chart-wrapper{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center}
.pie-chart-wrapper canvas{transition:transform .3s var(--ease)}

/* Portfolio total badge in header */
.portfolio-total-badge{
    font-size:12px;font-weight:700;color:var(--cyan);
    padding:4px 12px;border-radius:8px;
    background:rgba(34,211,238,.08);
    border:1px solid rgba(34,211,238,.12);
    font-variant-numeric:tabular-nums;
    transition:all .3s var(--ease);
}
.portfolio-total-badge.pulse{animation:badgePulse .5s ease}
@keyframes badgePulse{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}

/* Chart legend */
.chart-legend{width:100%;display:flex;flex-direction:column;gap:2px}
.legend-row{
    display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-2);
    padding:7px 10px;border-radius:var(--radius);
    transition:all .2s var(--ease);cursor:pointer;
}
.legend-row:hover{background:rgba(255,255,255,.04)}
.legend-row.legend-active{background:rgba(255,255,255,.06)}
.legend-row.legend-active .legend-dot{transform:scale(1.3)}
.legend-row.legend-active .legend-label{color:var(--text-0);font-weight:600}
.legend-row.legend-active .legend-pct{color:var(--text-0)}
.legend-row.legend-active .legend-val{color:var(--text-0)}
.legend-row.legend-dimmed{opacity:.25}
.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:transform .2s var(--ease)}
.legend-dot.blue{background:var(--blue)}
.legend-dot.green{background:var(--green)}
.legend-dot.emerald{background:var(--green)}
.legend-dot.red{background:var(--red)}
.legend-dot.purple{background:var(--purple)}
.legend-dot.cyan{background:var(--cyan)}
.legend-label{min-width:62px;font-weight:500;font-size:12px;transition:all .2s var(--ease)}
.legend-pct{
    font-size:10px;font-weight:600;color:var(--text-3);
    min-width:32px;text-align:right;font-variant-numeric:tabular-nums;
    transition:color .2s var(--ease);
}
.legend-val{font-weight:600;color:var(--text-1);font-variant-numeric:tabular-nums;min-width:60px;text-align:right;font-size:12px;transition:color .2s var(--ease)}
.legend-bar-wrap{flex:1;height:3px;background:rgba(255,255,255,.04);border-radius:2px;overflow:hidden;margin:0 4px;min-width:40px}
.legend-bar{height:100%;border-radius:2px;transition:width 1s var(--ease);width:0}
.legend-bar.blue{background:var(--blue)}.legend-bar.green{background:var(--green)}.legend-bar.emerald{background:var(--green)}
.legend-bar.red{background:var(--red)}.legend-bar.purple{background:var(--purple)}.legend-bar.cyan{background:var(--cyan)}
.deposit-breakdown-info{
    padding:2px 10px 6px 28px;font-size:10px;color:var(--text-3);line-height:1.6;
}

/* Prices card */
.prices-card{border-radius:var(--radius-xl);display:flex;flex-direction:column;}
.price-ticker-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
    grid-auto-rows:min-content;
    gap:10px;padding:16px 20px;
    max-height:340px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.price-ticker-grid::-webkit-scrollbar{width:4px}
.price-ticker-grid::-webkit-scrollbar-track{background:transparent}
.price-ticker-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.price-card{
    background:rgba(255,255,255,.03);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:14px 16px;cursor:pointer;
    transition:all .2s var(--ease);
    display:flex;flex-direction:column;gap:6px;
    position:relative;overflow:hidden;
}
.price-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
    opacity:0;transition:opacity .2s;
}
.price-card:hover{border-color:var(--border-light);transform:translateY(-4px) scale(1.02);box-shadow:0 12px 32px rgba(0,0,0,.35),0 0 20px rgba(79,125,249,.06)}
.price-card:hover::before{opacity:1}
/* Staggered entrance for price cards */
.price-card{opacity:0;animation:priceCardIn .4s var(--ease) forwards}
.price-card:nth-child(1){animation-delay:.03s}.price-card:nth-child(2){animation-delay:.06s}
.price-card:nth-child(3){animation-delay:.09s}.price-card:nth-child(4){animation-delay:.12s}
.price-card:nth-child(5){animation-delay:.15s}.price-card:nth-child(6){animation-delay:.18s}
.price-card:nth-child(7){animation-delay:.21s}.price-card:nth-child(8){animation-delay:.24s}
.price-card:nth-child(9){animation-delay:.27s}.price-card:nth-child(10){animation-delay:.30s}
.price-card:nth-child(11){animation-delay:.33s}.price-card:nth-child(12){animation-delay:.36s}
.price-card:nth-child(13){animation-delay:.39s}.price-card:nth-child(14){animation-delay:.42s}
.price-card:nth-child(15){animation-delay:.45s}.price-card:nth-child(16){animation-delay:.48s}
.price-card:nth-child(17){animation-delay:.51s}.price-card:nth-child(18){animation-delay:.54s}
.price-card:nth-child(19){animation-delay:.57s}.price-card:nth-child(20){animation-delay:.60s}
.price-card:nth-child(21){animation-delay:.63s}.price-card:nth-child(22){animation-delay:.66s}
.price-card:nth-child(23){animation-delay:.69s}.price-card:nth-child(24){animation-delay:.72s}
@keyframes priceCardIn{from{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:none}}
.pc-top{display:flex;align-items:center;justify-content:space-between}
.pc-symbol{font-size:13px;font-weight:700;color:var(--text-0);display:flex;align-items:center;gap:7px}
.pc-symbol .coin-dot{width:8px;height:8px;border-radius:50%;box-shadow:0 0 8px currentColor}
.pc-change{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;font-variant-numeric:tabular-nums}
.pc-change.positive{color:var(--green);background:var(--green-dim)}
.pc-change.negative{color:var(--red);background:var(--red-dim)}
.pc-price{font-size:17px;font-weight:700;color:var(--text-0);font-variant-numeric:tabular-nums;letter-spacing:-.3px;transition:color .3s}
.pc-price.updated{animation:priceFlash .4s ease}
@keyframes priceFlash{0%{color:var(--cyan)}100%{color:var(--text-0)}}
.pc-volume{font-size:10px;color:var(--text-3);font-weight:500}

/* ── Toggle Switch (user-facing) ── */
.toggle-switch{
    position:relative;width:48px;height:26px;border-radius:13px;
    background:rgba(255,255,255,.08);border:1px solid var(--border);
    cursor:pointer;transition:all .3s var(--ease);flex-shrink:0;
}
.toggle-switch.active{background:var(--green);border-color:var(--green)}
.toggle-switch::after{
    content:'';position:absolute;top:2px;left:2px;
    width:20px;height:20px;border-radius:50%;
    background:white;transition:transform .3s var(--ease);box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle-switch.active::after{transform:translateX(22px)}
.toggle-switch.toggle-sm{width:36px;height:20px;border-radius:10px}
.toggle-switch.toggle-sm::after{width:14px;height:14px;top:2px;left:2px}
.toggle-switch.toggle-sm.active::after{transform:translateX(16px)}
body.light-theme .toggle-switch{background:rgba(0,0,0,.10);border-color:rgba(0,0,0,.14)}
body.light-theme .toggle-switch.active{background:var(--green);border-color:var(--green)}

/* ── Live Chart Toggle & Panel ── */
.chart-toggle-wrap{
    display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;
    padding:4px 8px;border-radius:8px;transition:background .2s;
}
.chart-toggle-wrap:hover{background:rgba(255,255,255,.04)}
.chart-toggle-label{font-size:11px;font-weight:600;color:var(--text-3);white-space:nowrap;}
.live-chart-panel{padding:0 20px 20px;}
.live-chart-tabs{
    display:flex;gap:6px;padding:10px 0;overflow-x:auto;
    scrollbar-width:none;-ms-overflow-style:none;
}
.live-chart-tabs::-webkit-scrollbar{display:none}
.live-chart-tab{
    display:flex;align-items:center;gap:5px;
    padding:6px 12px;border-radius:8px;border:1px solid var(--border);
    background:rgba(255,255,255,.03);cursor:pointer;white-space:nowrap;
    font-size:12px;font-weight:600;color:var(--text-2);
    transition:all .2s var(--ease);flex-shrink:0;
}
.live-chart-tab:hover{border-color:var(--border-light);color:var(--text-1);background:rgba(255,255,255,.06)}
.live-chart-tab.active{
    border-color:var(--blue);color:var(--blue);
    background:rgba(79,125,249,.08);box-shadow:0 0 12px rgba(79,125,249,.1);
}
.live-chart-tab .tab-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.live-chart-tab .tab-change{font-size:10px;font-weight:700;margin-left:2px;}
.live-chart-tab .tab-change.positive{color:var(--green)}
.live-chart-tab .tab-change.negative{color:var(--red)}
.live-chart-container{
    border-radius:var(--radius);overflow:hidden;
    border:1px solid var(--border);background:rgba(0,0,0,.2);
    position:relative;
}
.live-chart-frame{width:100%;height:380px;position:relative;}
.live-chart-frame canvas{display:block;border-radius:var(--radius);}
body.light-theme .live-chart-container{background:rgba(255,255,255,.5)}
body.light-theme .chart-toggle-wrap:hover{background:rgba(0,0,0,.04)}

/* ================================================================
   BOTTOM ROW
   ================================================================ */
.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}

/* ================================================================
   CARD (used inside bottom row)
   ================================================================ */
.card-body{padding:4px 0}
.card-tabs{display:flex;gap:3px;background:rgba(255,255,255,.04);border-radius:10px;padding:3px}
.ctab{
    padding:6px 14px;border-radius:8px;background:none;border:none;
    color:var(--text-3);font:500 11px/1 'Inter',sans-serif;
    cursor:pointer;transition:all .15s var(--ease);
}
.ctab:hover{color:var(--text-1)}
.ctab.active{color:var(--cyan);background:rgba(34,211,238,.10)}
.see-all{background:none;border:none;color:var(--text-3);font:500 11px/1 'Inter',sans-serif;cursor:pointer;transition:color .15s}
.see-all:hover{color:var(--cyan)}
.tab-pane{display:none}.tab-pane.active{display:block}

/* ================================================================
   ACTIVITY LIST
   ================================================================ */
.activity-list{overflow-y:auto;max-height:380px}
.act-item{
    display:flex;align-items:center;padding:10px 18px;gap:10px;
    border-bottom:1px solid var(--border);transition:background .12s;
}
.act-item:last-child{border-bottom:none}
.act-item:hover{background:var(--bg-hover)}
/* Staggered entrance for activity items */
.act-item{opacity:0;animation:actItemIn .35s var(--ease) forwards}
.act-item:nth-child(1){animation-delay:.05s}.act-item:nth-child(2){animation-delay:.1s}
.act-item:nth-child(3){animation-delay:.15s}.act-item:nth-child(4){animation-delay:.2s}
.act-item:nth-child(5){animation-delay:.25s}.act-item:nth-child(6){animation-delay:.3s}
.act-item:nth-child(7){animation-delay:.35s}.act-item:nth-child(8){animation-delay:.4s}
.act-item:nth-child(9){animation-delay:.45s}.act-item:nth-child(10){animation-delay:.5s}
@keyframes actItemIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.act-icon{
    width:36px;height:36px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;
}
.act-icon.deposit-icon{background:var(--green-dim);color:var(--green)}
.act-icon.withdraw-icon{background:var(--red-dim);color:var(--red)}
.act-icon.opp-icon{background:var(--blue-dim);color:var(--blue)}
.act-icon.profit-icon{background:var(--amber-dim);color:var(--amber)}
.act-icon.earning-icon{background:rgba(34,197,94,.12);color:var(--green);position:relative}
.act-icon.earning-icon::after{content:'';position:absolute;top:4px;right:4px;width:6px;height:6px;border-radius:50%;background:var(--green);animation:livePulse 2s infinite}
.act-icon.auth-icon{background:var(--blue-dim);color:var(--blue)}
.act-icon.auth-fail-icon{background:var(--red-dim);color:var(--red)}
.act-icon.security-icon{background:var(--purple-dim);color:var(--purple)}
.act-icon.referral-icon{background:var(--cyan-dim);color:var(--cyan)}
.act-info{flex:1;min-width:0}
.act-title{font-size:12px;font-weight:600;color:var(--text-0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.act-sub{font-size:11px;color:var(--text-3);margin-top:1px}
.act-right{text-align:right;flex-shrink:0}
.act-amount{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}
.act-amount.green{color:var(--green)}.act-amount.red{color:var(--red)}
.act-status{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;display:inline-block;margin-top:2px}
.act-status.pending{background:var(--amber-dim);color:var(--amber)}
.act-status.completed,.act-status.confirmed{background:var(--green-dim);color:var(--green)}
.act-status.processing{background:var(--blue-dim);color:var(--blue)}
.act-status.failed{background:var(--red-dim);color:var(--red)}
.act-status.active{background:var(--blue-dim);color:var(--blue)}
.act-status.live{background:rgba(34,197,94,.15);color:var(--green);display:inline-flex;align-items:center}
.empty-state{text-align:center;padding:40px 16px;color:var(--text-3);font-size:12px;font-weight:500}

/* ================================================================
   ARBITRAGE MONITOR
   ================================================================ */
.arb-monitor-card .glass-card-header h3{display:flex;align-items:center}
.arb-scan-status{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;color:var(--green);padding:3px 10px;border-radius:20px;background:var(--green-dim)}
.arb-pair-label{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--border)}
.arb-pair-badge{
    font-size:12px;font-weight:800;color:var(--cyan);letter-spacing:.5px;
    padding:4px 12px;border-radius:8px;
    background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.15);
}
.arb-pair-info{font-size:10px;color:var(--text-3);font-weight:500}
.arb-monitor-list{overflow-y:auto;max-height:340px}

/* Individual arbitrage row */
.arb-row{
    display:flex;align-items:center;padding:10px 18px;gap:10px;
    border-bottom:1px solid var(--border);transition:background .12s;
    animation:arbRowIn .3s var(--ease);
}
.arb-row:last-child{border-bottom:none}
.arb-row:hover{background:var(--bg-hover)}
@keyframes arbRowIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:none}}

.arb-row-rank{
    width:20px;height:20px;border-radius:6px;
    display:flex;align-items:center;justify-content:center;
    font-size:9px;font-weight:800;color:var(--text-0);flex-shrink:0;
}
.arb-row-rank.hot{background:linear-gradient(135deg,var(--green),#10b981);color:#fff;box-shadow:0 0 10px var(--green-glow)}
.arb-row-rank.warm{background:var(--blue-dim);color:var(--blue)}
.arb-row-rank.cool{background:rgba(255,255,255,.04);color:var(--text-3)}

.arb-row-exchanges{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.arb-route{font-size:11px;font-weight:600;color:var(--text-0);display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arb-route .arb-arrow{color:var(--text-3);font-size:10px;margin:0 2px}
.arb-prices{font-size:10px;color:var(--text-3);font-weight:500;font-variant-numeric:tabular-nums;display:flex;gap:8px}
.arb-buy-price{color:var(--green)}.arb-sell-price{color:var(--red)}

.arb-row-spread{text-align:right;flex-shrink:0;min-width:70px}
.arb-spread-value{font-size:13px;font-weight:800;font-variant-numeric:tabular-nums}
.arb-spread-value.high{color:var(--green);text-shadow:0 0 12px var(--green-glow)}
.arb-spread-value.medium{color:var(--cyan)}
.arb-spread-value.low{color:var(--text-2)}
.arb-spread-label{font-size:9px;color:var(--text-3);font-weight:500;margin-top:1px}

.arb-monitor-footer{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 18px;border-top:1px solid var(--border);
}
.arb-footer-info{font-size:10px;color:var(--text-3);font-weight:500}

/* ================================================================
   LIVE INDICATOR
   ================================================================ */
.live-indicator{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-3);font-weight:500}
.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title h3{font-size:15px;font-weight:700;color:var(--text-0);letter-spacing:-.1px}

/* ================================================================
   MODAL
   ================================================================ */
.modal-overlay{
    position:fixed;inset:0;
    background:rgba(3,7,18,.80);
    backdrop-filter:blur(12px);z-index:1000;
    display:flex;align-items:center;justify-content:center;
}
.modal-box{
    background:var(--bg-2);border:1px solid var(--glass-border);
    border-radius:var(--radius-xl);padding:32px;
    max-width:520px;width:92%;max-height:80vh;overflow-y:auto;
    box-shadow:0 24px 80px rgba(0,0,0,.5);
}
.modal-title{font-size:17px;font-weight:700;color:var(--text-0);margin-bottom:18px}

/* ================================================================
   TOAST
   ================================================================ */
.toast-container{position:fixed;top:70px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{
    padding:14px 22px;border-radius:var(--radius);
    font-size:12px;font-weight:600;color:#fff;
    box-shadow:0 12px 40px rgba(0,0,0,.4);
    animation:toastIn .3s var(--ease),toastOut .3s var(--ease) 3s forwards;
    max-width:360px;backdrop-filter:blur(8px);
}
.toast.success{background:var(--green)}.toast.error{background:var(--red)}.toast.warning{background:var(--amber)}.toast.info{background:var(--blue)}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:none;opacity:1}}
@keyframes toastOut{from{opacity:1}to{transform:translateX(40px);opacity:0}}

/* ================================================================
   FORMS
   ================================================================ */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:10px;font-weight:600;color:var(--text-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}
.form-input,.form-select{
    width:100%;padding:12px 16px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--border);
    border-radius:var(--radius);
    color:var(--text-0);font:400 13px/1.4 'Inter',sans-serif;
    transition:border .15s,box-shadow .15s;outline:none;
}
.form-input:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim),0 0 20px rgba(79,125,249,.08)}
.form-input::placeholder{color:var(--text-3)}
textarea.form-input{resize:vertical;min-height:72px}

/* ================================================================
   BUTTONS
   ================================================================ */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:12px 24px;border:none;border-radius:var(--radius);
    font:600 13px/1 'Inter',sans-serif;cursor:pointer;
    transition:all .2s var(--ease);white-space:nowrap;
    position:relative;overflow:hidden;
}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .2s}
.btn:hover::after{opacity:1}
.btn-primary{background:linear-gradient(135deg,var(--blue),#6366f1);color:#fff;box-shadow:0 4px 16px rgba(79,125,249,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(79,125,249,.35)}
.btn-success{background:linear-gradient(135deg,var(--green),#10b981);color:#fff;box-shadow:0 4px 16px rgba(0,212,170,.20)}
.btn-success:hover{transform:translateY(-1px);box-shadow:0 8px 28px rgba(0,212,170,.30)}
.btn-danger{background:linear-gradient(135deg,var(--red),#ef4444);color:#fff}
.btn-danger:hover{transform:translateY(-1px)}
.btn-secondary{background:rgba(255,255,255,.05);color:var(--text-1);border:1px solid var(--border)}
.btn-secondary:hover{background:rgba(255,255,255,.08);border-color:var(--border-light)}
.btn-block{width:100%}.btn-sm{padding:8px 14px;font-size:11px}.btn-lg{padding:14px 28px;font-size:14px}

/* ================================================================
   TABS
   ================================================================ */
.tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid var(--border)}
.tab-btn{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-3);padding:12px 24px;font:600 13px/1 'Inter',sans-serif;cursor:pointer;transition:all .15s var(--ease);letter-spacing:0.01em}
.tab-btn:hover{color:var(--text-0);background:rgba(255,255,255,0.03)}.tab-btn.active{color:var(--cyan);border-bottom-color:var(--cyan);border-bottom-width:3px;background:rgba(0,212,170,0.04)}
.tab-content{display:none}.tab-content.active{display:block}

/* ================================================================
   DATA TABLE
   ================================================================ */
.data-table{width:100%;border-collapse:collapse;table-layout:auto}
.data-table thead th{text-align:left;padding:12px 16px;font-size:10px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}
.data-table tbody td{padding:12px 16px;font-size:12px;border-bottom:1px solid var(--border);color:var(--text-1);max-width:220px;overflow:hidden;text-overflow:ellipsis;word-break:break-word}
.data-table tbody tr:hover{background:var(--bg-hover)}
.data-table tbody tr:last-child td{border-bottom:none}

/* Skeleton loading */
.skeleton-cell{background:linear-gradient(90deg,var(--bg-3) 25%,var(--bg-4) 50%,var(--bg-3) 75%);background-size:200% 100%;animation:skeletonPulse 1.5s ease-in-out infinite;display:inline-block}
@keyframes skeletonPulse{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-row td{border-bottom:1px solid var(--border)}

/* ================================================================
   METHOD GRID
   ================================================================ */
.method-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}
.method-card{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:24px;cursor:pointer;
    transition:all .2s var(--ease);text-align:center;position:relative;overflow:hidden;
}
.method-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent)}
.method-card:hover{border-color:var(--cyan);background:rgba(34,211,238,.04);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.25)}
.method-card.selected{border-color:var(--cyan);background:rgba(34,211,238,.06);box-shadow:0 0 20px rgba(34,211,238,.10)}
.method-card.disabled{opacity:.5;pointer-events:none;filter:grayscale(.4);}
.method-card.disabled:hover{transform:none;border-color:var(--border);box-shadow:none;}
.method-icon{
    width:52px;height:52px;border-radius:14px;margin:0 auto 12px;
    display:flex;align-items:center;justify-content:center;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.06);
    color:var(--text-1);
    transition:all .3s var(--ease);
}
.method-icon svg{opacity:.7;transition:all .3s var(--ease)}
.method-card:hover .method-icon{background:rgba(34,211,238,.08);border-color:rgba(34,211,238,.15);color:var(--cyan)}
.method-card:hover .method-icon svg{opacity:1;stroke:var(--cyan)}
.method-card.selected .method-icon{background:rgba(34,211,238,.10);border-color:rgba(34,211,238,.20);color:var(--cyan)}
.method-card.selected .method-icon svg{opacity:1;stroke:var(--cyan)}
.method-title{font-size:14px;font-weight:700;color:var(--text-0);margin-bottom:4px}.method-desc{font-size:11px;color:var(--text-3)}

.network-options{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.network-btn{
    flex:1;padding:11px;
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius);color:var(--text-2);
    font:500 12px/1 'Inter',sans-serif;cursor:pointer;text-align:center;
    transition:all .15s var(--ease);
}
.network-btn:hover{border-color:var(--border-light)}.network-btn.active{border-color:var(--cyan);color:var(--cyan);background:rgba(34,211,238,.08)}

.wallet-display{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:28px;text-align:center;
}
.wallet-address{
    font:500 12px/1.4 'SF Mono','Fira Code',monospace;color:var(--text-0);
    word-break:break-all;padding:14px;
    background:rgba(255,255,255,.04);border-radius:var(--radius);
    margin:14px 0;user-select:all;border:1px solid var(--border);
}
.wallet-timer{font-size:24px;font-weight:800;color:var(--amber);margin:14px 0;font-variant-numeric:tabular-nums}

.copy-btn{
    display:inline-flex;align-items:center;gap:6px;padding:8px 16px;
    background:rgba(255,255,255,.04);border:1px solid var(--border);
    border-radius:var(--radius);color:var(--text-1);
    font:500 11px/1 'Inter',sans-serif;cursor:pointer;transition:all .15s;
}
.copy-btn:hover{background:rgba(255,255,255,.08);border-color:var(--border-light)}

/* ── Crypto Payment Card (Elite 2-Column) ── */
.crypto-payment-card{
    background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,rgba(34,211,238,.02) 100%);
    border:1px solid var(--border);border-radius:16px;padding:0;overflow:hidden;
}
.crypto-payment-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 24px;border-bottom:1px solid var(--border);
    background:rgba(255,255,255,.02);
}
.crypto-payment-badge{
    display:inline-flex;align-items:center;gap:6px;
    font-size:11px;font-weight:600;color:var(--green);
    background:rgba(0,212,170,.08);border:1px solid rgba(0,212,170,.15);
    border-radius:20px;padding:5px 12px;
}
.crypto-payment-coin-label{
    display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-0);
}
.crypto-payment-network-tag{
    font-size:10px;font-weight:700;color:var(--cyan);
    background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.2);
    border-radius:4px;padding:2px 7px;letter-spacing:.5px;
}
.crypto-payment-card .info-box{margin:16px 24px 0;border-radius:10px;}
.crypto-payment-columns{
    display:grid;grid-template-columns:auto 1fr;gap:24px;
    padding:20px 24px;align-items:start;
}
.crypto-payment-qr-side{
    display:flex;flex-direction:column;align-items:center;gap:8px;
}
.crypto-payment-qr-frame{
    width:200px;height:200px;display:flex;align-items:center;justify-content:center;
    background:white;border-radius:14px;padding:10px;
    box-shadow:0 4px 24px rgba(0,0,0,.15),0 0 0 1px rgba(255,255,255,.05);
}
.crypto-payment-qr-frame canvas,
.crypto-payment-qr-frame img{border-radius:6px !important;max-width:100%;max-height:100%;}
.crypto-payment-scan-label{
    display:flex;align-items:center;gap:5px;
    font-size:10px;color:var(--text-3);font-weight:500;
}
.crypto-payment-detail-side{display:flex;flex-direction:column;gap:10px;min-width:0;}
.crypto-payment-addr-label{
    font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
    color:var(--text-3);
}
.crypto-payment-addr{
    font:500 11.5px/1.5 'SF Mono','Fira Code',monospace;color:var(--text-0);
    word-break:break-all;padding:12px 14px;
    background:rgba(255,255,255,.04);border:1px solid var(--border);
    border-radius:10px;user-select:all;
}
.crypto-payment-copy-btn{
    display:inline-flex;align-items:center;gap:6px;padding:8px 16px;
    background:rgba(34,211,238,.06);border:1px solid rgba(34,211,238,.15);
    border-radius:8px;color:var(--cyan);
    font:600 11px/1 'Inter',sans-serif;cursor:pointer;transition:all .15s;
    align-self:flex-start;
}
.crypto-payment-copy-btn:hover{background:rgba(34,211,238,.12);border-color:rgba(34,211,238,.3);}
.crypto-payment-timer-box{
    background:rgba(245,158,11,.05);border:1px solid rgba(245,158,11,.12);
    border-radius:10px;padding:12px 14px;
}
.crypto-payment-timer-label{
    font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
    color:var(--text-3);margin-bottom:4px;
}
.crypto-payment-timer-value{
    display:flex;align-items:center;gap:6px;
    font-size:22px;font-weight:800;color:var(--amber);
    font-variant-numeric:tabular-nums;
}
.crypto-payment-min-deposit{
    display:flex;align-items:center;gap:6px;
    font-size:11px;color:var(--amber);
    background:rgba(245,158,11,.05);border:1px solid rgba(245,158,11,.1);
    border-radius:8px;padding:8px 12px;
}
.crypto-payment-footer{
    padding:16px 24px;border-top:1px solid var(--border);
    background:rgba(255,255,255,.02);text-align:center;
}
@media(max-width:560px){
    .crypto-payment-columns{grid-template-columns:1fr;gap:16px;}
    .crypto-payment-qr-side{order:-1;}
}
/* Light theme adjustments */
body.light-theme .crypto-payment-card{background:linear-gradient(135deg,rgba(0,0,0,.01) 0%,rgba(34,211,238,.03) 100%);}
body.light-theme .crypto-payment-qr-frame{box-shadow:0 4px 20px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.06);}
body.light-theme .crypto-payment-addr{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.08);}
body.light-theme .crypto-payment-copy-btn{background:rgba(34,211,238,.06);border-color:rgba(34,211,238,.2);}

.bank-detail-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);font-size:12px}
.bank-detail-row:last-child{border-bottom:none}
.bank-detail-label{color:var(--text-3)}.bank-detail-value{color:var(--text-0);font-weight:600;display:flex;align-items:center;gap:8px}

.amount-presets{display:flex;gap:6px;margin-top:8px}
.preset-btn{
    padding:6px 12px;background:rgba(255,255,255,.03);
    border:1px solid var(--border);border-radius:var(--radius);
    color:var(--text-3);font:500 10px/1 'Inter',sans-serif;cursor:pointer;
    transition:all .15s;
}
.preset-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.split-btn.active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}
.split-btn:hover:not(.active){border-color:var(--cyan);color:var(--cyan)}

.info-box{background:var(--blue-dim);border:1px solid rgba(79,125,249,.15);border-radius:var(--radius);padding:12px 16px;font-size:12px;color:var(--blue);margin-bottom:16px}
.warning-box{background:var(--amber-dim);border:1px solid rgba(245,158,11,.15);border-radius:var(--radius);padding:12px 16px;font-size:12px;color:var(--amber);margin-bottom:16px}
.success-box{background:var(--green-dim);border:1px solid rgba(0,212,170,.15);border-radius:var(--radius);padding:12px 16px;font-size:12px;color:var(--green);margin-bottom:16px}
.error-box{background:var(--red-dim);border:1px solid rgba(255,77,106,.15);border-radius:var(--radius);padding:12px 16px;font-size:12px;color:var(--red);margin-bottom:16px}

/* ================================================================
   STATS GRID (used by other modules)
   ================================================================ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.stat-card{
    background:rgba(255,255,255,.03);border-radius:var(--radius-lg);
    padding:20px;border:1px solid var(--border);
    transition:all .2s var(--ease);
}
.stat-card:hover{border-color:var(--border-light)}
.stat-card .stat-title{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:6px}
.stat-card .stat-number{font-size:22px;font-weight:800;color:var(--text-0);font-variant-numeric:tabular-nums}
.stat-card .stat-number.green{color:var(--green)}.stat-card .stat-number.red{color:var(--red)}

/* ================================================================
   PANELS
   ================================================================ */
.panel{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px;
}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.panel-header h3{font-size:13px;font-weight:700;color:var(--text-0)}
.panel-body{padding:18px 20px}
.link-btn{background:none;border:none;color:var(--cyan);font:500 11px/1 'Inter',sans-serif;cursor:pointer}

/* ================================================================
   SWAP
   ================================================================ */
.swap-container{max-width:440px;margin:0 auto}
.swap-box{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:18px;margin-bottom:3px;
}
.swap-box-label{font-size:10px;color:var(--text-3);margin-bottom:10px;text-transform:uppercase;font-weight:600;letter-spacing:.4px}
.swap-input-row{display:flex;align-items:center;gap:12px}
.swap-input{flex:1;background:transparent;border:none;color:var(--text-0);font-size:24px;font-weight:700;outline:none;font-family:inherit;font-variant-numeric:tabular-nums}
.swap-input::placeholder{color:var(--text-3)}
.swap-token-btn{
    display:flex;align-items:center;gap:6px;padding:9px 16px;
    background:rgba(255,255,255,.04);border:1px solid var(--border);
    border-radius:var(--radius);color:var(--text-0);
    font:700 13px/1 'Inter',sans-serif;cursor:pointer;white-space:nowrap;
}
.swap-arrow{display:flex;justify-content:center;margin:-2px 0;z-index:1;position:relative}
.swap-arrow-btn{
    width:38px;height:38px;border-radius:50%;
    background:var(--bg-2);border:3px solid var(--bg-0);
    color:var(--text-2);display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:all .15s;
}
.swap-arrow-btn:hover{color:var(--cyan);border-color:rgba(34,211,238,.2)}

/* ================================================================
   POOL / STAKING
   ================================================================ */
.pool-card{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:20px;margin-bottom:12px;
    transition:all .2s;
}
.pool-card:hover{border-color:var(--border-light)}
.pool-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.pool-name{font-size:16px;font-weight:700;color:var(--text-0)}
.pool-apy{font-size:15px;font-weight:800;color:var(--green)}
.pool-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.pool-stat{text-align:center}
.pool-stat-label{font-size:10px;color:var(--text-3);margin-bottom:4px;text-transform:uppercase}
.pool-stat-value{font-size:13px;font-weight:700;color:var(--text-0)}

.progress-bar{height:5px;background:rgba(255,255,255,.05);border-radius:3px;overflow:hidden;margin-top:10px}
.progress-fill{height:100%;border-radius:3px;transition:width .5s var(--ease)}
.progress-fill.green{background:var(--green)}.progress-fill.blue{background:var(--blue)}

/* ================================================================
   PAIR ROW (Markets)
   ================================================================ */
.pair-row{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 16px;border-bottom:1px solid var(--border);
    cursor:pointer;transition:background .15s;
}
.pair-row:hover{background:var(--bg-hover)}.pair-row:last-child{border-bottom:none}
.pair-name{font-weight:700;font-size:13px;color:var(--text-0);min-width:100px}
.pair-price{font-weight:600;font-size:13px;color:var(--text-0);min-width:100px;text-align:right;font-variant-numeric:tabular-nums}
.pair-change{font-weight:700;font-size:11px;min-width:76px;text-align:right;padding:4px 10px;border-radius:6px}
.pair-change.positive{color:var(--green);background:var(--green-dim)}
.pair-change.negative{color:var(--red);background:var(--red-dim)}
.fav-star{display:inline-flex;align-items:center;transition:all .2s var(--ease)}
.fav-star:hover{transform:scale(1.3);filter:drop-shadow(0 0 4px var(--amber))}

.search-input{
    width:100%;padding:12px 16px;
    background:rgba(255,255,255,.04);border:1px solid var(--border);
    border-radius:var(--radius);color:var(--text-0);
    font:400 13px 'Inter',sans-serif;outline:none;
    transition:border .15s,box-shadow .15s;margin-bottom:14px;
}
.search-input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-dim)}

/* ================================================================
   REFERRAL
   ================================================================ */
.referral-code-box{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:24px;text-align:center;margin-bottom:20px;
}
.referral-code{font:800 22px/1 'SF Mono','Fira Code',monospace;color:var(--cyan);letter-spacing:3px}

/* ================================================================
   NOTIFICATIONS
   ================================================================ */
.notif-item{display:flex;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}
.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:rgba(34,211,238,.04)}
.notif-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.notif-dot.info{background:var(--blue)}.notif-dot.success{background:var(--green)}.notif-dot.warning{background:var(--amber)}.notif-dot.error{background:var(--red)}
.notif-content{flex:1;min-width:0}
.notif-title{font-size:12px;font-weight:600;color:var(--text-0);margin-bottom:2px}
.notif-message{font-size:11px;color:var(--text-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.notif-time{font-size:10px;color:var(--text-3);white-space:nowrap}

/* ================================================================
   SETTINGS
   ================================================================ */
.settings-section{margin-bottom:28px}
.settings-section-title{font-size:13px;font-weight:700;color:var(--text-0);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}
.setting-row:last-child{border-bottom:none}
.setting-info{display:flex;flex-direction:column;gap:3px}
.setting-name{font-size:12px;font-weight:600;color:var(--text-0)}
.setting-desc{font-size:11px;color:var(--text-3)}
.toggle{width:42px;height:24px;background:rgba(255,255,255,.08);border:1px solid var(--border);border-radius:12px;position:relative;cursor:pointer;transition:all .2s}
.toggle.active{background:var(--cyan);border-color:var(--cyan)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .2s}
.toggle.active::after{left:20px}

/* ================================================================
   ANALYTICS
   ================================================================ */
.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.analytics-card{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);overflow:hidden;
}
.analytics-card-header{padding:14px 18px;border-bottom:1px solid var(--border);font-size:12px;font-weight:700;color:var(--text-0);display:flex;align-items:center;gap:8px}
.analytics-card-body{padding:4px 0;max-height:300px;overflow-y:auto}
.analytics-row{display:flex;justify-content:space-between;align-items:center;padding:10px 18px;border-bottom:1px solid var(--border);font-size:12px}
.analytics-row:last-child{border-bottom:none}

.qr-wrapper{display:flex;justify-content:center;margin:16px 0}
.qr-wrapper canvas{border-radius:var(--radius)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

.tx-status{font-size:10px;padding:3px 9px;border-radius:10px;font-weight:600;display:inline-block}
.tx-status.pending{background:var(--amber-dim);color:var(--amber)}
.tx-status.completed,.tx-status.confirmed{background:var(--green-dim);color:var(--green)}
.tx-status.processing{background:var(--blue-dim);color:var(--blue)}
.tx-status.failed{background:var(--red-dim);color:var(--red)}
.tx-status.active{background:var(--green-dim);color:var(--green)}
.tx-status.warning{background:var(--amber-dim);color:var(--amber)}

/* ================================================================
   UTILITY CLASSES
   ================================================================ */
.green{color:var(--green)!important}.red{color:var(--red)!important}
.text-green{color:var(--green)}.text-red{color:var(--red)}.text-blue{color:var(--blue)}.text-orange,.text-amber{color:var(--amber)}.text-muted{color:var(--text-3)}
.text-sm{font-size:12px}.text-xs{font-size:11px}.text-center{text-align:center}
.font-bold{font-weight:700}.font-medium{font-weight:500}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}
.w-full{width:100%}

/* ================================================================
   EARNINGS
   ================================================================ */
.earnings-duration-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.earnings-duration-card{
    background:rgba(255,255,255,.03);border:1px solid var(--border);
    border-radius:var(--radius-lg);padding:24px;text-align:center;
    cursor:pointer;transition:all .25s var(--ease);position:relative;overflow:hidden;
}
.earnings-duration-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);opacity:0;transition:opacity .2s}
.earnings-duration-card:hover{border-color:var(--border-light);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.25)}
.earnings-duration-card:hover::before{opacity:1}
.earnings-duration-card.selected{border-color:var(--cyan);background:rgba(34,211,238,.06);box-shadow:0 0 24px rgba(34,211,238,.12)}
.earnings-duration-card.selected::before{opacity:1;background:linear-gradient(90deg,transparent,rgba(34,211,238,.3),transparent)}
.duration-years{font-size:22px;font-weight:800;color:var(--text-0);margin-bottom:6px;letter-spacing:-.3px}
.duration-apy{font-size:16px;font-weight:700;color:var(--green)}
.duration-desc{font-size:10px;color:var(--text-3);margin-top:4px}

/* Arbitrage auto-scroll stream effect */
.arb-row-stream{animation:arbStreamIn .4s var(--ease)}
@keyframes arbStreamIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ================================================================
   WALLET - Unified Deposit / Withdraw / Overview
   ================================================================ */

/* Wallet Header Card */
.wallet-header{
    padding:0;border-radius:var(--radius-xl);
    position:relative;overflow:hidden;margin-bottom:24px;
}
.wallet-header-glow{
    position:absolute;top:-60%;right:-15%;width:450px;height:450px;
    background:radial-gradient(circle,rgba(0,212,170,.10) 0%,rgba(79,125,249,.06) 40%,transparent 70%);
    pointer-events:none;animation:heroGlowPulse 4s ease-in-out infinite;
}
.wallet-header-content{
    display:flex;align-items:center;justify-content:space-between;
    padding:32px 36px 24px;position:relative;z-index:2;gap:32px;flex-wrap:wrap;
}
.wallet-balance-section{min-width:0}
.wallet-balance-label{
    display:flex;align-items:center;gap:10px;
    font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;
    color:var(--text-3);margin-bottom:10px;
}
.wallet-balance-label svg{opacity:.5}
.wallet-balance-value{
    font-size:38px;font-weight:900;color:var(--text-0);
    letter-spacing:-1px;line-height:1.1;
    font-variant-numeric:tabular-nums;
    background:linear-gradient(135deg,#fff 40%,rgba(0,212,170,.6) 70%,rgba(79,125,249,.4));
    background-size:200% 200%;
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    animation:heroGradientShift 5s ease infinite;
}
body.light-theme .wallet-balance-value{
    background:linear-gradient(135deg,#0c1220 60%,var(--green));
    -webkit-background-clip:text;background-clip:text;animation:none;
}

/* Earnings cards within wallet header */
.wallet-earnings-grid{
    display:flex;gap:14px;flex-shrink:0;flex-wrap:wrap;
}
.wallet-earning-card{
    display:flex;align-items:center;gap:12px;
    padding:14px 18px;border-radius:var(--radius);
    background:rgba(255,255,255,.04);
    border:1px solid var(--border);
    min-width:170px;
    transition:all .25s var(--ease);
}
.wallet-earning-card:hover{
    border-color:var(--border-light);
    transform:translateY(-2px);
    box-shadow:0 8px 20px rgba(0,0,0,.2);
}
.wallet-earning-icon{
    width:36px;height:36px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.wallet-earning-icon.daily{background:var(--blue-dim);color:var(--blue)}
.wallet-earning-icon.monthly{background:var(--purple-dim);color:var(--purple)}
.wallet-earning-icon.earned{background:var(--green-dim);color:var(--green)}
.wallet-earning-info{display:flex;flex-direction:column;gap:3px}
.wallet-earning-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;font-weight:600}
.wallet-earning-value{font-size:16px;font-weight:800;color:var(--text-0);font-variant-numeric:tabular-nums}
.wallet-earning-value.green{color:var(--green)}

/* Stats strip at bottom of wallet header */
.wallet-stats-strip{
    display:flex;align-items:center;gap:24px;
    padding:14px 36px;
    border-top:1px solid var(--border);
    background:rgba(255,255,255,.02);
    position:relative;z-index:2;
}
.wallet-stat-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2)}
.wallet-stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.wallet-stat-dot.green-dot{background:var(--green);box-shadow:0 0 8px var(--green-glow)}
.wallet-stat-dot.red-dot{background:var(--red);box-shadow:0 0 8px var(--red-glow)}
.wallet-stat-dot.cyan-dot{background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow)}
.wallet-stat-text strong{color:var(--text-0)}

/* Wallet Tabs */
.wallet-tabs{
    display:flex;gap:4px;
    background:rgba(255,255,255,.03);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:5px;margin-bottom:24px;
}
.wallet-tab{
    flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
    padding:12px 16px;border-radius:var(--radius);
    background:none;border:none;
    color:var(--text-3);font:500 13px/1 'Inter',sans-serif;
    cursor:pointer;transition:all .2s var(--ease);
    white-space:nowrap;
}
.wallet-tab:hover{color:var(--text-1);background:rgba(255,255,255,.03)}
.wallet-tab.active{
    color:var(--text-0);font-weight:600;
    background:rgba(255,255,255,.06);
    border:1px solid var(--border-light);
    box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.wallet-tab svg{opacity:.5;transition:opacity .2s}
.wallet-tab.active svg{opacity:1;stroke:var(--cyan)}

/* Quick Actions Grid */
.wallet-quick-actions{
    display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;
}
.wallet-action-btn{
    display:flex;flex-direction:column;align-items:center;gap:12px;
    padding:24px 16px;
    background:rgba(255,255,255,.03);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    color:var(--text-1);
    font:600 13px/1 'Inter',sans-serif;
    cursor:pointer;transition:all .25s var(--ease);
    position:relative;overflow:hidden;
}
.wallet-action-btn::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent);
    opacity:0;transition:opacity .2s;
}
.wallet-action-btn:hover{
    transform:translateY(-4px);
    border-color:var(--border-light);
    box-shadow:0 12px 32px rgba(0,0,0,.25);
}
.wallet-action-btn:hover::before{opacity:1}
.wallet-action-btn.disabled{opacity:.45;pointer-events:none;filter:grayscale(.5);}
.action-btn-icon{
    width:48px;height:48px;border-radius:14px;
    display:flex;align-items:center;justify-content:center;
    transition:all .3s var(--ease);
}

.deposit-action .action-btn-icon{background:var(--green-dim);color:var(--green)}
.deposit-action:hover{border-color:rgba(0,212,170,.25)}
.deposit-action:hover .action-btn-icon{box-shadow:0 0 20px var(--green-glow)}

.withdraw-action .action-btn-icon{background:var(--red-dim);color:var(--red)}
.withdraw-action:hover{border-color:rgba(255,77,106,.20)}
.withdraw-action:hover .action-btn-icon{box-shadow:0 0 20px var(--red-glow)}

.reinvest-action .action-btn-icon{background:var(--cyan-dim);color:var(--cyan)}
.reinvest-action:hover{border-color:rgba(34,211,238,.20)}
.reinvest-action:hover .action-btn-icon{box-shadow:0 0 20px var(--cyan-glow)}

.earnings-action .action-btn-icon{background:var(--purple-dim);color:var(--purple)}
.earnings-action:hover{border-color:rgba(168,85,247,.20)}
.earnings-action:hover .action-btn-icon{box-shadow:0 0 20px var(--purple-glow)}

.statement-action .action-btn-icon{background:var(--blue-dim);color:var(--blue)}
.statement-action:hover{border-color:rgba(79,125,249,.20)}
.statement-action:hover .action-btn-icon{box-shadow:0 0 20px var(--blue-glow)}

/* Wallet withdraw balance display */
.wallet-withdraw-balance{
    display:flex;align-items:center;gap:12px;
    padding:18px 24px;margin-bottom:20px;
    background:rgba(255,255,255,.03);
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
}
.wallet-withdraw-balance-value{
    font-size:22px;font-weight:800;color:var(--text-0);
    font-variant-numeric:tabular-nums;
}

/* Transaction type badge */
.tx-type-badge{
    display:inline-block;font-size:10px;font-weight:700;
    padding:3px 10px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;
}
.tx-type-badge.deposit{background:var(--green-dim);color:var(--green)}
.tx-type-badge.withdraw{background:var(--red-dim);color:var(--red)}
.tx-type-badge.reinvest{background:var(--cyan-dim);color:var(--cyan)}
.tx-type-badge.admin_add{background:rgba(168,85,247,.12);color:#a855f7}
.tx-type-badge.admin_remove{background:rgba(249,115,22,.12);color:#f97316}
.tx-type-badge.investment{background:rgba(34,197,94,.12);color:#22c55e}
.tx-type-badge.profit_settlement{background:rgba(16,185,129,.12);color:#10b981}
.tx-type-badge.auto_reinvest{background:rgba(59,130,246,.12);color:#3b82f6}
.tx-type-badge.commission{background:rgba(245,158,11,.12);color:#f59e0b}
.tx-type-badge.reinvest_profit{background:rgba(99,102,241,.12);color:#6366f1}
.text-amber{color:var(--amber,#f59e0b)!important}

/* Wallet hero button */
.wallet-btn{border-color:rgba(0,212,170,.15);color:var(--green)}
.wallet-btn:hover{border-color:var(--green);background:var(--green-dim);box-shadow:0 8px 32px rgba(0,212,170,.20)}

/* ================================================================
   LEGEND AMBER DOT/BAR (Referral)
   ================================================================ */
.legend-dot.amber{background:var(--amber)}
.legend-bar.amber{background:var(--amber)}

/* Wallet earning icon - referral */
.wallet-earning-icon.referral{background:var(--amber-dim);color:var(--amber)}
.wallet-stat-dot.amber-dot{background:var(--amber);box-shadow:0 0 8px rgba(245,158,11,.25)}

/* ================================================================
   MOBILE BOTTOM NAV — Native App Style
   ================================================================ */
.mobile-bottom-nav{
    display:none;
    position:fixed;bottom:0;left:0;right:0;
    height:68px;z-index:100;
    background:rgba(8,12,28,.97);
    backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);
    border-top:1px solid rgba(255,255,255,.06);
    padding:0 2px;
    padding-bottom:env(safe-area-inset-bottom,0);
    align-items:center;
    flex-wrap:nowrap;
    overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    scrollbar-width:none;
}
.mobile-bottom-nav::-webkit-scrollbar{display:none}
.mobile-bottom-nav::before{
    content:'';position:absolute;top:-1px;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(79,125,249,.18),rgba(168,85,247,.12),transparent);
    z-index:1;pointer-events:none;
}
body.light-theme .mobile-bottom-nav{
    background:rgba(255,255,255,.97);
    border-top-color:rgba(0,0,0,.08);
}
body.light-theme .mobile-bottom-nav::before{
    background:linear-gradient(90deg,transparent,rgba(37,99,235,.12),transparent);
}
.mobile-nav-btn{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;padding:8px 4px 6px;border:none;background:none;
    color:var(--text-3);cursor:pointer;
    font:600 10px/1.1 'Inter',sans-serif;
    letter-spacing:.1px;
    transition:all .2s var(--ease);
    min-width:64px;flex-shrink:0;position:relative;
    scroll-snap-align:center;
    -webkit-tap-highlight-color:transparent;
    user-select:none;-webkit-user-select:none;
}
.mobile-nav-btn svg{
    width:22px;height:22px;
    opacity:.45;transition:all .25s var(--ease);
    filter:drop-shadow(0 0 0px transparent);
}
.mobile-nav-btn span{
    transition:color .25s;
    white-space:nowrap;
}
.mobile-nav-btn:active{
    transform:scale(.92);
    transition:transform .1s;
}
.mobile-nav-btn:hover{color:var(--text-1)}
.mobile-nav-btn:hover svg{opacity:.7}
.mobile-nav-btn.active{color:var(--cyan)}
.mobile-nav-btn.active svg{opacity:1;stroke:var(--cyan);filter:drop-shadow(0 0 8px rgba(34,211,238,.4))}
.mobile-nav-btn.active span{font-weight:700}
.mobile-nav-btn.active::after{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:28px;height:3px;border-radius:0 0 6px 6px;
    background:var(--cyan);box-shadow:0 0 12px var(--cyan-glow);
}

/* ================================================================
   MILESTONE PROGRESS BAR
   ================================================================ */
.milestone-progress{width:100%;height:4px;border-radius:2px;background:rgba(255,255,255,.06);overflow:hidden}
.milestone-progress-bar{height:100%;border-radius:2px;transition:width .4s ease}
body.light-theme .milestone-progress{background:rgba(0,0,0,.06)}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1400px){
    .stats-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:1200px){
    .middle-row{grid-template-columns:1fr}
    .stats-row{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
    .sidebar{width:64px}
    .sidebar .nav-label,.sidebar-logo img,.nav-separator,.profile-info,.sidebar-profile{display:none}
    .sidebar .nav-item{padding:0;margin:0 6px;justify-content:center;height:42px;padding-left:0}
    .sidebar .nav-item .nav-icon-wrap{width:36px;height:36px}
    .sidebar-logo{padding:16px 12px;justify-content:center}
    .sidebar-logo img{display:block!important;height:24px}
    .sidebar-logo::after{display:none}
    .sidebar-bottom{padding:8px 0}
    .sidebar-bottom .nav-item{justify-content:center}
    .bottom-row{grid-template-columns:1fr}
    .stats-row{grid-template-columns:repeat(2,1fr)}
    .hero-content{flex-direction:column;align-items:flex-start}
    .hero-actions{flex-wrap:wrap}
    .analytics-grid{grid-template-columns:1fr}
    .wallet-header-content{flex-direction:column;align-items:flex-start}
    .wallet-earnings-grid{width:100%}
    .wallet-quick-actions{grid-template-columns:repeat(2,1fr)}
    .wallet-stats-strip{flex-wrap:wrap;gap:12px}
}
@media(max-width:600px){
    .sidebar{display:none}
    .mobile-bottom-nav{display:flex}
    .main-content{padding:16px 16px 84px}
    /* Security banner above mobile nav */
    .security-banner>div{bottom:68px!important}
    .main-content.has-security-banner{padding-bottom:140px!important}
    .topbar{padding:0 16px;height:52px}
    .page-heading{font-size:15px}
    .header-ticker{display:none}
    .topbar-time{display:none}

    /* Hero - bigger and bolder on mobile */
    .hero-balance-card{padding:24px 20px}
    .hero-label{font-size:10px;letter-spacing:1px;margin-bottom:6px}
    .hero-value{font-size:36px;letter-spacing:-.5px}
    .hero-pnl{margin-top:8px}
    .hero-actions{gap:8px}
    .hero-btn{padding:10px 16px;font-size:12px;gap:6px}

    /* Stats row */
    .stats-row{grid-template-columns:1fr 1fr;gap:10px}
    .stat-pill{padding:14px 14px;gap:10px}
    .stat-pill-icon{width:34px;height:34px;border-radius:10px}
    .stat-pill-value{font-size:14px}
    .stat-pill-label{font-size:9px}

    /* Portfolio breakdown */
    .chart-card-body{padding:18px 14px;gap:16px}
    .pie-chart-wrapper{width:170px;height:170px}
    .legend-row{padding:5px 8px;gap:6px}
    .legend-label{min-width:52px;font-size:11px}
    .legend-pct{min-width:26px;font-size:9px}
    .legend-val{min-width:48px;font-size:11px}
    .legend-bar-wrap{min-width:28px}
    .glass-card-header{padding:14px 16px}
    .glass-card-header h3{font-size:13px}

    /* Wallet mobile */
    .wallet-balance-value{font-size:32px}
    .wallet-header-content{padding:24px 20px 16px}
    .wallet-stats-strip{padding:12px 16px;gap:10px;flex-direction:column}
    .wallet-stat-item{font-size:11px}
    .wallet-earnings-grid{flex-direction:column;gap:10px}
    .wallet-earning-card{min-width:unset;padding:12px 14px}
    .wallet-earning-value{font-size:14px}
    .wallet-quick-actions{grid-template-columns:1fr 1fr;gap:10px}
    .wallet-action-btn{padding:18px 12px;gap:10px}
    .action-btn-icon{width:40px;height:40px;border-radius:12px}
    .wallet-tabs{flex-wrap:wrap;gap:3px;padding:4px}
    .wallet-tab{font-size:11px;padding:10px 12px;flex:1 1 auto;min-width:0}

    /* Bottom row */
    .bottom-row{gap:14px}
    .arb-monitor-list{max-height:240px}

    /* Daily PnL responsive */
    .pnl-summary-grid{grid-template-columns:repeat(2,1fr) !important}

    /* Earnings grid */
    .earnings-duration-grid{grid-template-columns:1fr;gap:10px}

    /* General mobile polish */
    .method-grid{grid-template-columns:1fr}
    .grid-2{grid-template-columns:1fr}
    .modal-box{padding:24px 18px;border-radius:var(--radius-lg)}

    /* Security mobile */
    .security-status-banner{flex-direction:column;text-align:center;gap:12px}
    .security-method-header{flex-wrap:wrap}
    .totp-digit-input{width:36px;height:44px;font-size:18px}
}

/* ================================================================
   Security — Passkey & TOTP
   ================================================================ */

/* Status Banner */
.security-status-banner{
    display:flex;align-items:center;gap:16px;
    padding:20px 24px;border-radius:var(--radius-lg);
    margin-bottom:20px;
    border:1px solid var(--border);
    background:var(--glass-bg);
    backdrop-filter:blur(var(--glass-blur));
    transition:all .3s;
}
.security-status-banner.secure{
    border-color:rgba(0,212,170,.20);
    background:linear-gradient(135deg,rgba(0,212,170,.06) 0%,rgba(0,212,170,.02) 100%);
}
.security-status-banner.insecure{
    border-color:rgba(255,77,106,.20);
    background:linear-gradient(135deg,rgba(255,77,106,.08) 0%,rgba(255,77,106,.02) 100%);
}
.security-status-icon{
    width:52px;height:52px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.security-status-banner.secure .security-status-icon{
    background:rgba(0,212,170,.12);color:var(--green);
}
.security-status-banner.insecure .security-status-icon{
    background:rgba(255,77,106,.12);color:var(--red);
}
.security-status-info{flex:1;min-width:0}
.security-status-title{
    font-size:15px;font-weight:800;color:var(--text-0);margin-bottom:2px;
}
.security-status-desc{
    font-size:12px;color:var(--text-2);line-height:1.4;
}

/* Security Badge */
.security-badge{
    display:inline-flex;align-items:center;
    padding:4px 12px;border-radius:20px;
    font-size:11px;font-weight:700;letter-spacing:.3px;
    text-transform:uppercase;white-space:nowrap;flex-shrink:0;
}
.security-badge.success{
    background:rgba(0,212,170,.12);color:var(--green);
    border:1px solid rgba(0,212,170,.20);
}
.security-badge.danger{
    background:rgba(255,77,106,.12);color:var(--red);
    border:1px solid rgba(255,77,106,.20);
    animation:badgePulse 2s ease-in-out infinite;
}
.security-badge.neutral{
    background:rgba(255,255,255,.05);color:var(--text-3);
    border:1px solid rgba(255,255,255,.08);
}
@keyframes badgePulse{
    0%,100%{opacity:1}
    50%{opacity:.6}
}

/* Security Method Card */
.security-method-card{
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    background:var(--glass-bg);
    backdrop-filter:blur(var(--glass-blur));
    margin-bottom:16px;
    overflow:hidden;
    transition:all .3s;
}
.security-method-card.active{
    border-color:rgba(0,212,170,.18);
    box-shadow:0 0 20px rgba(0,212,170,.06);
}
.security-method-card:hover{
    border-color:var(--border-light);
}
.security-method-header{
    display:flex;align-items:center;gap:14px;
    padding:18px 20px;
}
.security-method-icon{
    width:44px;height:44px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.security-method-icon.passkey-icon{
    background:linear-gradient(135deg,rgba(79,125,249,.15),rgba(79,125,249,.05));
    color:var(--blue);
}
.security-method-icon.totp-icon{
    background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,.05));
    color:var(--amber);
}
.security-method-info{flex:1;min-width:0}
.security-method-name{
    font-size:14px;font-weight:700;color:var(--text-0);margin-bottom:2px;
}
.security-method-desc{
    font-size:12px;color:var(--text-3);
}
.security-method-body{
    padding:0 20px 18px;
    display:flex;align-items:center;gap:12px;
    flex-wrap:wrap;
}
.security-method-detail{
    display:flex;align-items:center;gap:6px;
    font-size:12px;color:var(--text-2);flex:1;
}

/* TOTP Digit Inputs */
.totp-digit-inputs{
    display:flex;align-items:center;justify-content:center;
    gap:8px;margin:16px 0;
}
.totp-digit-input{
    width:42px;height:52px;
    text-align:center;
    font-size:22px;font-weight:800;
    font-family:'Courier New',monospace;
    color:var(--text-0);
    background:rgba(255,255,255,.04);
    border:2px solid var(--border-light);
    border-radius:10px;
    outline:none;
    transition:all .2s;
    caret-color:var(--amber);
}
.totp-digit-input:focus{
    border-color:var(--amber);
    background:rgba(245,158,11,.06);
    box-shadow:0 0 12px rgba(245,158,11,.15);
}
.totp-digit-input::selection{
    background:rgba(245,158,11,.25);
}
.totp-digit-sep{
    font-size:20px;font-weight:700;color:var(--text-3);
    margin:0 2px;user-select:none;
}

/* TOTP QR Wrapper */
.totp-qr-wrapper{
    display:flex;align-items:center;justify-content:center;
    padding:20px;margin:16px 0;
    background:rgba(255,255,255,.03);
    border-radius:16px;
    border:1px solid rgba(255,255,255,.06);
}
.totp-qr-wrapper canvas{
    border-radius:12px !important;
}

/* TOTP Setup Steps */
.totp-setup-steps{
    display:flex;flex-direction:column;gap:10px;
    margin:16px 0;
}
.totp-step{
    display:flex;align-items:center;gap:12px;
    font-size:13px;color:var(--text-1);
    line-height:1.4;
}
.totp-step-num{
    width:26px;height:26px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:linear-gradient(135deg,var(--amber),#d97706);
    color:#000;font-size:12px;font-weight:800;
    flex-shrink:0;
}

/* Receipt upload */
.receipt-dropzone{border:2px dashed var(--border);border-radius:10px;padding:28px 16px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;transition:border-color .2s,background .2s;color:var(--text-2)}
.receipt-dropzone:hover,.receipt-dropzone.drag-over{border-color:var(--green);background:rgba(0,212,170,.05);color:var(--green)}

/* ================================================================
   OPPORTUNITIES PAGE — Professional Card Layout
   ================================================================ */

/* Live status bar */
.opp-live-bar{
    display:flex;align-items:center;justify-content:space-between;
    background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid var(--glass-border);border-radius:var(--radius-lg);
    padding:12px 18px;margin-bottom:16px;
}
.opp-live-left{display:flex;align-items:center;gap:8px;}
.opp-live-dot{
    width:8px;height:8px;border-radius:50%;background:var(--green);
    box-shadow:0 0 8px var(--green);
    animation:oppPulse 2s ease-in-out infinite;
}
@keyframes oppPulse{
    0%,100%{opacity:1;transform:scale(1)}
    50%{opacity:.5;transform:scale(.85)}
}
.opp-live-label{
    font-size:10px;font-weight:800;letter-spacing:1.2px;
    color:var(--green);background:rgba(34,197,94,.1);
    padding:2px 7px;border-radius:4px;
}
.opp-live-text{font-size:12px;color:var(--text-3);font-weight:500;}
.opp-live-right{display:flex;align-items:center;gap:14px;}
.opp-live-exchanges,.opp-live-refresh{
    display:flex;align-items:center;gap:4px;
    font-size:11px;color:var(--text-3);font-weight:500;
}

/* Stats row */
.opp-stats-row{
    display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;
}
.opp-stat-card{
    background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid var(--glass-border);border-radius:var(--radius-lg);
    padding:16px;display:flex;align-items:center;gap:14px;
    transition:all .2s var(--ease);
}
.opp-stat-card:hover{
    border-color:rgba(255,255,255,.1);
    transform:translateY(-1px);
    box-shadow:0 4px 16px rgba(0,0,0,.15);
}
.opp-stat-icon{
    width:40px;height:40px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.opp-stat-info{display:flex;flex-direction:column;gap:2px;min-width:0;}
.opp-stat-value{font-size:18px;font-weight:700;color:var(--text-0);letter-spacing:-.3px;line-height:1.1;}
.opp-stat-label{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;}

/* Opportunity cards */
.opp-card{
    background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid var(--glass-border);border-radius:var(--radius-xl);
    margin-bottom:12px;overflow:hidden;position:relative;
    transition:all .25s var(--ease);
}
.opp-card:hover{
    border-color:rgba(255,255,255,.1);
    box-shadow:0 8px 32px rgba(0,0,0,.12);
    transform:translateY(-2px);
}
.opp-card-top{
    border-width:1.5px;
}
.opp-card-glow{
    position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,transparent,var(--green),var(--cyan,#06b6d4),transparent);
    opacity:.6;
}

/* Card header */
.opp-card-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 18px 10px;
}
.opp-card-rank-wrap{display:flex;align-items:center;gap:10px;}
.opp-card-rank{
    width:30px;height:30px;border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    font-size:11px;font-weight:800;letter-spacing:-.2px;
}
.opp-card-pair{display:flex;align-items:center;gap:8px;}
.opp-card-token{font-size:14px;font-weight:700;color:var(--text-0);}
.opp-card-badge{
    font-size:9px;font-weight:700;letter-spacing:.5px;
    padding:2px 7px;border-radius:4px;
}
.opp-card-spread{text-align:right;}
.opp-card-spread-value{font-size:20px;font-weight:800;letter-spacing:-.5px;line-height:1.1;}
.opp-card-spread-label{font-size:9px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;}

/* Route visualization */
.opp-card-route{
    display:flex;align-items:center;
    padding:6px 18px 14px;gap:0;
}
.opp-card-exchange-block{
    flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;
}
.opp-card-exchange-label{
    font-size:9px;font-weight:700;letter-spacing:1px;
    color:var(--text-3);text-transform:uppercase;
}
.opp-card-price{
    font-size:13px;font-weight:600;color:var(--text-1);
    font-variant-numeric:tabular-nums;
}

/* Arrow between exchanges */
.opp-card-arrow-wrap{
    display:flex;align-items:center;gap:0;flex-shrink:0;
    padding:0 8px;color:var(--text-3);
}
.opp-card-arrow-line{
    width:24px;height:1px;
    background:linear-gradient(90deg,var(--border),var(--text-3));
}
.opp-card-arrow-icon{
    display:flex;align-items:center;justify-content:center;
    width:28px;height:28px;border-radius:50%;
    background:var(--bg-2);border:1px solid var(--border);
    color:var(--text-2);flex-shrink:0;
}

/* Card footer */
.opp-card-footer{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 18px;border-top:1px solid var(--border);
    background:rgba(0,0,0,.08);
}
.opp-card-foot-item{
    display:flex;align-items:center;gap:4px;
    font-size:11px;color:var(--text-3);font-weight:500;
}
.opp-card-foot-item svg{opacity:.6;}

/* Empty state */
.opp-empty-state{
    text-align:center;padding:60px 20px;
    background:var(--glass-bg);backdrop-filter:blur(12px);
    border:1px solid var(--glass-border);border-radius:var(--radius-xl);
}
.opp-empty-icon{
    width:64px;height:64px;border-radius:20px;
    background:rgba(79,125,249,.1);color:var(--blue);
    display:flex;align-items:center;justify-content:center;
    margin:0 auto 16px;
}
.opp-empty-title{
    font-size:16px;font-weight:700;color:var(--text-0);margin-bottom:6px;
}
.opp-empty-sub{
    font-size:12px;color:var(--text-3);margin-bottom:20px;
}
.opp-empty-loader{
    width:120px;height:3px;border-radius:2px;background:var(--bg-3);
    margin:0 auto;overflow:hidden;
}
.opp-empty-loader-bar{
    width:40%;height:100%;border-radius:2px;background:var(--blue);
    animation:oppLoaderSlide 1.2s ease-in-out infinite;
}
@keyframes oppLoaderSlide{
    0%{transform:translateX(-100%)}
    100%{transform:translateX(350%)}
}

/* ── Engine Performance Cards ──────────────────────────── */
.engine-perf-section{margin-bottom:16px;}
.engine-perf-section-header{
    display:flex;align-items:center;gap:6px;
    font-size:11px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.5px;
    margin-bottom:10px;
}
.engine-perf-grid{
    display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
.engine-perf-card{
    background:var(--bg-1);border:1px solid var(--border);border-radius:12px;
    padding:14px;transition:border-color .2s,transform .2s;
}
.engine-perf-card:hover{border-color:var(--text-3);transform:translateY(-1px);}
.engine-perf-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.engine-perf-icon{
    width:34px;height:34px;min-width:34px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;
}
.engine-perf-name{display:flex;flex-direction:column;gap:2px;}
.engine-perf-status{
    display:inline-flex;align-items:center;gap:4px;
    font-size:10px;font-weight:600;
}
.engine-perf-stats{
    display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px 10px;margin-bottom:10px;
}
.engine-perf-stat-value{
    font-size:14px;font-weight:800;color:var(--text-0);
    font-variant-numeric:tabular-nums;line-height:1.2;
}
.engine-perf-stat-label{font-size:10px;color:var(--text-3);font-weight:500;margin-top:1px;}
.engine-perf-bar{
    height:3px;border-radius:2px;background:var(--border);overflow:hidden;
}
.engine-perf-bar-fill{
    height:100%;border-radius:2px;transition:width .6s ease;
}
/* Light theme */
body.light-theme .engine-perf-card{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.08);}
body.light-theme .engine-perf-card:hover{border-color:rgba(0,0,0,.15);}
/* Responsive */
@media(max-width:1024px){.engine-perf-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.engine-perf-grid{grid-template-columns:1fr;}}

/* ── Opportunities List Table ───────────────────────────── */
.opp-list-table{
    background:var(--bg-1);border:1px solid var(--border);border-radius:12px;overflow:hidden;
}
.opp-list-header{
    display:grid;grid-template-columns:40px 110px 1.3fr 100px 100px 90px 90px 65px 50px;
    padding:10px 16px;gap:8px;align-items:center;
    background:var(--bg-2);border-bottom:1px solid var(--border);
    font-size:10px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;
}
.opp-list-row{
    display:grid;grid-template-columns:40px 110px 1.3fr 100px 100px 90px 90px 65px 50px;
    padding:12px 16px;gap:8px;align-items:center;
    border-bottom:1px solid var(--border);font-size:12px;
    transition:background .15s ease;
}
.opp-list-row:last-child{border-bottom:none;}
.opp-list-row:hover{background:var(--bg-hover);}
.opp-list-row-top{background:rgba(34,197,94,0.03);}
.opp-list-row-top:hover{background:rgba(34,197,94,0.06);}

.opp-col-route{display:flex;align-items:center;gap:6px;min-width:0;}
.opp-col-pair{display:flex;align-items:center;gap:6px;}

.opp-rank-num{
    display:inline-flex;align-items:center;justify-content:center;
    width:24px;height:24px;border-radius:6px;font-size:11px;font-weight:700;
}
.opp-list-badge{
    font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px;
}
.opp-spread-pill{
    display:inline-flex;padding:3px 8px;border-radius:6px;font-size:12px;font-weight:700;letter-spacing:-.2px;
}

/* Light theme overrides */
body.light-theme .opp-live-bar{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.08);}
body.light-theme .opp-stat-card{background:rgba(255,255,255,.7);border-color:rgba(0,0,0,.08);}
body.light-theme .opp-list-table{background:rgba(255,255,255,.8);border-color:rgba(0,0,0,.08);}
body.light-theme .opp-list-header{background:rgba(0,0,0,.02);}
body.light-theme .opp-list-row:hover{background:rgba(0,0,0,.02);}
body.light-theme .opp-empty-state{background:rgba(255,255,255,.8);}

/* Responsive — Opportunities */
@media(max-width:900px){
    .opp-stats-row{grid-template-columns:repeat(2,1fr)}
    .opp-list-header{display:none;}
    .opp-list-row{
        grid-template-columns:1fr 1fr;gap:6px 12px;padding:14px 16px;
        grid-template-areas:"rank spread" "pair pair" "route route" "buy sell" "profit age";
    }
    .opp-col-rank{grid-area:rank}.opp-col-spread{grid-area:spread;text-align:right;}
    .opp-col-pair{grid-area:pair}.opp-col-route{grid-area:route}
    .opp-col-buy{grid-area:buy}.opp-col-sell{grid-area:sell;text-align:right;}
    .opp-col-profit{grid-area:profit}.opp-col-age{grid-area:age;text-align:right;}
}
@media(max-width:600px){
    .opp-live-bar{flex-direction:column;gap:8px;align-items:flex-start;padding:10px 14px;}
    .opp-live-right{flex-wrap:wrap;gap:8px;}
    .opp-stats-row{grid-template-columns:1fr 1fr;gap:8px;}
    .opp-stat-card{padding:12px;gap:10px;}
    .opp-stat-icon{width:34px;height:34px;border-radius:10px;}
    .opp-stat-value{font-size:15px;}
}

/* ═══════════════════════════════════════════════════════
   STATUS PAGE — Premium Real-time API Health Monitor
   ═══════════════════════════════════════════════════════ */
.sts-wrap{display:flex;flex-direction:column;gap:16px;}

/* ── Overall Banner ── */
.sts-banner{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-radius:16px;border:1px solid var(--border, rgba(255,255,255,0.06));backdrop-filter:blur(16px);transition:all 0.5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;}
.sts-banner::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity 0.5s;pointer-events:none;}
.sts-banner.up{background:linear-gradient(135deg, rgba(0,212,170,0.06) 0%, rgba(0,212,170,0.01) 100%);border-color:rgba(0,212,170,0.18);}
.sts-banner.up::before{opacity:1;background:radial-gradient(ellipse at 10% 50%, rgba(0,212,170,0.08), transparent 60%);}
.sts-banner.degraded{background:linear-gradient(135deg, rgba(255,193,7,0.06) 0%, rgba(255,193,7,0.01) 100%);border-color:rgba(255,193,7,0.18);}
.sts-banner.degraded::before{opacity:1;background:radial-gradient(ellipse at 10% 50%, rgba(255,193,7,0.08), transparent 60%);}
.sts-banner.partial{background:linear-gradient(135deg, rgba(255,152,0,0.06) 0%, rgba(255,152,0,0.01) 100%);border-color:rgba(255,152,0,0.18);}
.sts-banner.partial::before{opacity:1;background:radial-gradient(ellipse at 10% 50%, rgba(255,152,0,0.08), transparent 60%);}
.sts-banner.down{background:linear-gradient(135deg, rgba(244,67,54,0.06) 0%, rgba(244,67,54,0.01) 100%);border-color:rgba(244,67,54,0.18);}
.sts-banner.down::before{opacity:1;background:radial-gradient(ellipse at 10% 50%, rgba(244,67,54,0.08), transparent 60%);}
.sts-banner.checking{background:rgba(255,255,255,0.03);border-color:var(--border, rgba(255,255,255,0.06));}

.sts-banner-l{display:flex;align-items:center;gap:14px;position:relative;z-index:1;}
.sts-banner-r{display:flex;align-items:center;gap:14px;position:relative;z-index:1;}

/* Pulse Dot */
.sts-pulse-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;position:relative;transition:background 0.4s;}
.sts-pulse-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;animation:stsPulse 2s ease-in-out infinite;opacity:0.4;}
.sts-banner.up .sts-pulse-dot{background:var(--green, #00d4aa);}
.sts-banner.up .sts-pulse-dot::after{border:2px solid var(--green, #00d4aa);}
.sts-banner.degraded .sts-pulse-dot{background:#ffc107;}
.sts-banner.degraded .sts-pulse-dot::after{border:2px solid #ffc107;}
.sts-banner.partial .sts-pulse-dot{background:#ff9800;}
.sts-banner.partial .sts-pulse-dot::after{border:2px solid #ff9800;}
.sts-banner.down .sts-pulse-dot{background:#f44336;}
.sts-banner.down .sts-pulse-dot::after{border:2px solid #f44336;}
.sts-banner.checking .sts-pulse-dot{background:var(--text-2, rgba(255,255,255,0.3));}
.sts-banner.checking .sts-pulse-dot::after{display:none;}

@keyframes stsPulse{
    0%,100%{transform:scale(1);opacity:0.4;}
    50%{transform:scale(1.6);opacity:0;}
}

.sts-banner-txt{display:flex;flex-direction:column;gap:2px;}
.sts-banner-title{font-size:16px;font-weight:700;color:var(--text-0, #fff);line-height:1.2;}
.sts-banner-sub{font-size:12px;color:var(--text-2, rgba(255,255,255,0.45));font-weight:500;}
.sts-timer{font-size:11px;color:var(--text-2, rgba(255,255,255,0.4));white-space:nowrap;font-variant-numeric:tabular-nums;}

/* ── Server Info Row ── */
.sts-server-info{display:grid;grid-template-columns:repeat(4, 1fr);gap:12px;}
.sts-si-item{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border-radius:14px;background:rgba(255,255,255,0.03);border:1px solid var(--border, rgba(255,255,255,0.06));backdrop-filter:blur(8px);transition:border-color 0.2s;}
.sts-si-item:hover{border-color:rgba(255,255,255,0.12);}
.sts-si-icon{display:flex;align-items:center;color:var(--text-2, rgba(255,255,255,0.35));}
.sts-si-label{font-size:10px;font-weight:600;color:var(--text-2, rgba(255,255,255,0.35));text-transform:uppercase;letter-spacing:0.6px;}
.sts-si-val{font-size:14px;font-weight:700;color:var(--text-0, #fff);font-family:'SF Mono','Fira Code',monospace;font-variant-numeric:tabular-nums;line-height:1.1;}

/* ── Grid ── */
.sts-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:16px;}

/* ── Group Card ── */
.sts-card{background:rgba(255,255,255,0.03);border:1px solid var(--border, rgba(255,255,255,0.06));border-radius:16px;backdrop-filter:blur(12px);overflow:hidden;transition:border-color 0.3s, box-shadow 0.3s;}
.sts-card:hover{border-color:rgba(255,255,255,0.1);box-shadow:0 4px 24px rgba(0,0,0,0.12);}
.sts-card-head{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border, rgba(255,255,255,0.05));}
.sts-card-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,0.05);color:var(--text-1, rgba(255,255,255,0.65));}
.sts-card-title{flex:1;font-size:14px;font-weight:600;color:var(--text-0, #fff);}
.sts-card-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px;}

/* ── Endpoint Block ── */
.sts-ep{display:flex;flex-direction:column;gap:6px;padding:10px 0;border-bottom:1px solid var(--border, rgba(255,255,255,0.04));}
.sts-ep:last-child{border-bottom:none;padding-bottom:0;}
.sts-ep:first-child{padding-top:0;}
.sts-ep-top{display:flex;align-items:center;gap:10px;}
.sts-ep-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;}
.sts-ep-name{font-size:13px;color:var(--text-1, rgba(255,255,255,0.7));font-weight:600;}
.sts-ep-url{font-size:10px;color:var(--text-2, rgba(255,255,255,0.3));font-family:'SF Mono','Fira Code',monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sts-method{display:inline-block;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px;margin-right:4px;letter-spacing:0.3px;}
.sts-method.get{color:var(--green, #00d4aa);background:rgba(0,212,170,0.1);}
.sts-method.post{color:#60a5fa;background:rgba(96,165,250,0.1);}
.sts-method.put{color:#ffc107;background:rgba(255,193,7,0.1);}
.sts-method.delete{color:#f44336;background:rgba(244,67,54,0.1);}
.sts-ep-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.sts-ep-ms{font-size:12px;font-weight:700;font-family:'SF Mono','Fira Code',monospace;color:var(--green, #00d4aa);min-width:48px;text-align:right;font-variant-numeric:tabular-nums;}
.sts-ep-ms.slow{color:#f44336;}
.sts-ep-ms.medium{color:#ffc107;}

/* HTTP Code Badge */
.sts-ep-code{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;font-family:'SF Mono','Fira Code',monospace;letter-spacing:0.3px;white-space:nowrap;}
.sts-ep-code.c2xx{color:var(--green, #00d4aa);background:rgba(0,212,170,0.1);border:1px solid rgba(0,212,170,0.15);}
.sts-ep-code.c3xx{color:#60a5fa;background:rgba(96,165,250,0.1);border:1px solid rgba(96,165,250,0.15);}
.sts-ep-code.c4xx{color:#ffc107;background:rgba(255,193,7,0.08);border:1px solid rgba(255,193,7,0.15);}
.sts-ep-code.c5xx{color:#f44336;background:rgba(244,67,54,0.1);border:1px solid rgba(244,67,54,0.15);}
.sts-ep-code.cerr{color:#f44336;background:rgba(244,67,54,0.1);border:1px solid rgba(244,67,54,0.15);}

/* Endpoint Footer (history + status text) */
.sts-ep-foot{display:flex;align-items:center;gap:8px;}
.sts-ep-status{font-size:10px;font-weight:600;white-space:nowrap;flex-shrink:0;}
.sts-ep-status.up{color:var(--green, #00d4aa);}
.sts-ep-status.degraded{color:#ffc107;}
.sts-ep-status.timeout{color:#ff9800;}
.sts-ep-status.down{color:#f44336;}

/* Status Dot */
.sts-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;transition:all 0.3s;}
.sts-dot.sm{width:8px;height:8px;}
.sts-dot.up{background:var(--green, #00d4aa);box-shadow:0 0 8px rgba(0,212,170,0.5);}
.sts-dot.degraded{background:#ffc107;box-shadow:0 0 8px rgba(255,193,7,0.5);}
.sts-dot.timeout{background:#ff9800;box-shadow:0 0 8px rgba(255,152,0,0.5);}
.sts-dot.down{background:#f44336;box-shadow:0 0 8px rgba(244,67,54,0.5);}

/* Latency Bar */
.sts-bar-track{height:3px;border-radius:2px;background:rgba(255,255,255,0.05);overflow:hidden;}
.sts-bar-fill{height:100%;border-radius:2px;transition:width 0.6s cubic-bezier(.4,0,.2,1), background 0.3s;min-width:2px;}
.sts-bar-fill.up{background:linear-gradient(90deg, rgba(0,212,170,0.6), var(--green, #00d4aa));}
.sts-bar-fill.degraded{background:linear-gradient(90deg, rgba(255,193,7,0.6), #ffc107);}
.sts-bar-fill.timeout{background:linear-gradient(90deg, rgba(255,152,0,0.6), #ff9800);}
.sts-bar-fill.down{background:linear-gradient(90deg, rgba(244,67,54,0.6), #f44336);}

/* History Dots */
.sts-history{display:flex;align-items:center;gap:1.5px;padding-top:2px;flex:1;}
.sts-hdot{width:3px;height:14px;border-radius:1.5px;transition:background 0.2s;flex-shrink:0;}
.sts-hdot.empty{background:rgba(255,255,255,0.04);}
.sts-hdot.up{background:var(--green, #00d4aa);}
.sts-hdot.degraded{background:#ffc107;}
.sts-hdot.timeout{background:#ff9800;}
.sts-hdot.down{background:#f44336;}

/* ── Response Legend ── */
.sts-legend{padding:16px 20px;border-radius:14px;background:rgba(255,255,255,0.02);border:1px solid var(--border, rgba(255,255,255,0.05));}
.sts-legend-title{font-size:11px;font-weight:700;color:var(--text-2, rgba(255,255,255,0.35));text-transform:uppercase;letter-spacing:0.6px;margin-bottom:10px;}
.sts-legend-items{display:flex;flex-wrap:wrap;gap:12px 20px;}
.sts-legend-item{font-size:11px;color:var(--text-2, rgba(255,255,255,0.45));display:flex;align-items:center;gap:6px;}
.sts-legend-code{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;font-family:'SF Mono','Fira Code',monospace;}
.sts-legend-code.c2xx{color:var(--green, #00d4aa);background:rgba(0,212,170,0.1);}
.sts-legend-code.c4xx{color:#ffc107;background:rgba(255,193,7,0.08);}
.sts-legend-code.c5xx{color:#f44336;background:rgba(244,67,54,0.1);}
.sts-legend-code.cerr{color:#f44336;background:rgba(244,67,54,0.1);}

/* ── Responsive ── */
@media(max-width:900px){
    .sts-server-info{grid-template-columns:repeat(2, 1fr);}
}
@media(max-width:768px){
    .sts-grid{grid-template-columns:1fr;}
    .sts-banner{flex-direction:column;gap:14px;align-items:flex-start;padding:18px 20px;}
    .sts-banner-r{width:100%;justify-content:space-between;}
}
@media(max-width:480px){
    .sts-server-info{grid-template-columns:repeat(2, 1fr);gap:8px;}
    .sts-si-item{padding:10px 12px;}
    .sts-si-val{font-size:12px;}
    .sts-banner-title{font-size:14px;}
    .sts-card-head{padding:12px 16px;}
    .sts-card-body{padding:12px 16px;}
    .sts-legend-items{flex-direction:column;gap:8px;}
}

/* ── Light Theme ── */
body.light-theme .sts-banner.up{background:linear-gradient(135deg, rgba(0,180,140,0.05) 0%, rgba(0,180,140,0.01) 100%);}
body.light-theme .sts-banner.degraded{background:linear-gradient(135deg, rgba(255,193,7,0.05) 0%, rgba(255,193,7,0.01) 100%);}
body.light-theme .sts-banner.partial{background:linear-gradient(135deg, rgba(255,152,0,0.05) 0%, rgba(255,152,0,0.01) 100%);}
body.light-theme .sts-banner.down{background:linear-gradient(135deg, rgba(244,67,54,0.05) 0%, rgba(244,67,54,0.01) 100%);}
body.light-theme .sts-si-item{background:rgba(0,0,0,0.02);}
body.light-theme .sts-card{background:rgba(0,0,0,0.02);}
body.light-theme .sts-card-icon{background:rgba(0,0,0,0.04);}
body.light-theme .sts-bar-track{background:rgba(0,0,0,0.04);}
body.light-theme .sts-hdot.empty{background:rgba(0,0,0,0.05);}
body.light-theme .sts-legend{background:rgba(0,0,0,0.02);}
body.light-theme .sts-ep{border-bottom-color:rgba(0,0,0,0.06);}
body.light-theme .sts-ep-url{color:rgba(0,0,0,0.4);}
