:root{
  --gold:#f5c518;
  --gold-2:#d4a017;
  --gold-deep:#b8860b;
  --gold-light:#ffe27a;
  --bg:#070707;
  --bg-2:#0e0e0e;
  --card:#121212;
  --card-2:#1a1712;
  --line:rgba(245,197,24,.18);
  --txt:#f4eedd;
  --muted:#9a927f;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(245,197,24,.08), transparent 60%),
    radial-gradient(800px 400px at 90% 100%, rgba(212,160,23,.06), transparent 60%),
    var(--bg);
  color:var(--txt);
  font-family:'Segoe UI',Tahoma,system-ui,-apple-system,sans-serif;
  min-height:100vh;
}
a{color:inherit;text-decoration:none}

/* gold helpers */
.gold-text{
  background:linear-gradient(180deg,#fff6cf 0%,var(--gold) 45%,var(--gold-deep) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.gold-btn{
  background:linear-gradient(180deg,var(--gold-light),var(--gold) 55%,var(--gold-deep));
  color:#1a1300;font-weight:800;border:none;border-radius:12px;
  box-shadow:0 6px 20px rgba(245,197,24,.35), inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .12s ease, box-shadow .12s ease;cursor:pointer;
}
.gold-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(245,197,24,.5)}
.gold-btn:active{transform:translateY(0)}
.ghost-btn{
  background:transparent;border:1px solid var(--line);color:var(--gold-light);
  border-radius:12px;font-weight:700;cursor:pointer;transition:.15s;
}
.ghost-btn:hover{border-color:var(--gold);background:rgba(245,197,24,.06)}

.card{
  background:linear-gradient(180deg,var(--card),var(--bg-2));
  border:1px solid var(--line);border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.5);
}
.card-gold{
  background:linear-gradient(180deg,#19140a,#0c0a06);
  border:1px solid rgba(245,197,24,.35);
  box-shadow:0 0 0 1px rgba(245,197,24,.05), 0 14px 40px rgba(0,0,0,.6);
}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}

/* loader */
.ge-loader{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:var(--bg);z-index:9999;transition:opacity .4s}
.ge-loader-logo{width:120px;height:120px;border-radius:50%;animation:pulse 1.6s infinite}
.ge-spinner{width:44px;height:44px;border:4px solid rgba(245,197,24,.2);border-top-color:var(--gold);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.7}}
.fade-in{animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* nav */
.navbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(7,7,7,.82);border-bottom:1px solid var(--line)}

/* hero glow */
.hero-bg{background:radial-gradient(900px 500px at 50% -20%, rgba(245,197,24,.16), transparent 65%)}
.star{position:absolute;background:#fff;border-radius:50%;opacity:.5;animation:twinkle 3s infinite}
@keyframes twinkle{0%,100%{opacity:.2}50%{opacity:.9}}

/* table */
table{width:100%;border-collapse:collapse}
th,td{padding:12px 14px;text-align:left}
thead th{color:var(--gold-light);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}
tbody tr{border-bottom:1px solid rgba(245,197,24,.08)}
tbody tr:hover{background:rgba(245,197,24,.04)}

/* badges */
.badge{padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:700}
.badge-pending{background:rgba(245,197,24,.15);color:var(--gold)}
.badge-approved{background:rgba(34,197,94,.16);color:#4ade80}
.badge-rejected{background:rgba(239,68,68,.16);color:#f87171}

/* inputs */
.input{
  width:100%;background:#0a0a0a;border:1px solid var(--line);color:var(--txt);
  border-radius:12px;padding:12px 14px;outline:none;transition:.15s;
}
.input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(245,197,24,.12)}
label{font-size:.85rem;color:var(--muted);font-weight:600}

/* toast */
#toast{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:10000;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 18px;border-radius:12px;font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.5);animation:fadeIn .25s}
.toast-ok{background:linear-gradient(90deg,#14532d,#166534);color:#bbf7d0;border:1px solid #22c55e}
.toast-err{background:linear-gradient(90deg,#450a0a,#7f1d1d);color:#fecaca;border:1px solid #ef4444}

/* plan card */
.plan-card{transition:.18s}
.plan-card:hover{transform:translateY(-4px);border-color:var(--gold)}
.scrollbar-thin::-webkit-scrollbar{height:6px;width:6px}
.scrollbar-thin::-webkit-scrollbar-thumb{background:var(--gold-deep);border-radius:9px}

/* nav links */
.nav-link{transition:.15s}
.nav-link:hover{color:var(--gold)}

/* mobile slide-in menu */
.mobile-menu{position:fixed;inset:0;z-index:90;pointer-events:none;visibility:hidden}
.mobile-menu.open{pointer-events:auto;visibility:visible}
.mobile-menu-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;transition:opacity .25s}
.mobile-menu.open .mobile-menu-overlay{opacity:1}
.mobile-menu-panel{
  position:absolute;top:0;right:0;height:100%;width:78%;max-width:300px;
  background:linear-gradient(180deg,#15110a,#0a0a0a);
  border-left:1px solid var(--line);box-shadow:-12px 0 40px rgba(0,0,0,.6);
  padding:20px;z-index:2;transform:translateX(105%);transition:transform .28s ease;
  display:flex;flex-direction:column;
}
.mobile-menu.open .mobile-menu-panel{transform:translateX(0)}
.mobile-menu-panel .nav-link{padding:12px 14px;border-radius:12px;color:var(--txt)}
.mobile-menu-panel .nav-link:hover{background:rgba(245,197,24,.08);color:var(--gold)}

/* admin tabs */
.admin-tab{
  background:transparent;border:1px solid var(--line);color:var(--muted);
  border-radius:12px;font-weight:700;font-size:.85rem;padding:9px 14px;cursor:pointer;transition:.15s;
}
.admin-tab:hover{border-color:var(--gold);color:var(--gold-light)}
.admin-tab-active{
  background:linear-gradient(180deg,var(--gold-light),var(--gold) 55%,var(--gold-deep));
  color:#1a1300;border-color:transparent;
  box-shadow:0 4px 14px rgba(245,197,24,.3);
}
.admin-tab-active .badge{background:rgba(26,19,0,.25);color:#1a1300}

/* ---------- transaction cards ---------- */
.tx-scroll{max-height:560px;overflow-y:auto;padding-right:4px}
.tx-card{
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(0,0,0,.15));
  border:1px solid var(--line);border-radius:16px;padding:14px 16px;
  transition:transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.tx-card:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:0 8px 22px rgba(0,0,0,.4)}
.tx-icon{
  flex:none;width:46px;height:46px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.tx-body{flex:1;min-width:0}
.tx-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tx-title{font-weight:800;color:var(--txt);font-size:.95rem}
.tx-note{color:var(--muted);font-size:.82rem;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tx-date{color:var(--muted);font-size:.72rem;margin-top:4px;opacity:.85}
.tx-amount{flex:none;font-weight:800;font-size:1.02rem;text-align:right;white-space:nowrap}
.tx-amount .tx-cur{display:block;font-size:.62rem;font-weight:700;opacity:.7;letter-spacing:.05em;margin-top:1px}
.tx-pos{color:#4ade80}
.tx-neg{color:#f87171}

/* ---------- deposit screenshot thumbnails (admin) ---------- */
.shot-thumb-btn{position:relative;display:inline-block;border:none;background:none;padding:0;cursor:pointer;border-radius:10px;overflow:hidden}
.shot-thumb{width:46px;height:46px;object-fit:cover;border-radius:10px;border:1px solid var(--line);display:block}
.shot-thumb-eye{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.5);color:var(--gold);opacity:0;transition:opacity .15s;font-size:.85rem;
}
.shot-thumb-btn:hover .shot-thumb-eye{opacity:1}
