/* ============================================================
   TradePro — Premium Fintech UI Design System v2.0
   Dark · Glassmorphism · Lucide Icons · Mobile-first
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&display=swap');

/* ── Variables ──────────────────────────────────────────────── */
:root {
  --blue:        #00c853;
  --blue-2:      #00e676;
  --cyan:        #00e5ff;
  --grad-primary:linear-gradient(135deg, #00c853 0%, #00e676 100%);
  --grad-blue:   linear-gradient(135deg, #1565c0 0%, #0288d1 60%, #00acc1 100%);
  --grad-green:  linear-gradient(135deg, #00c853 0%, #00e676 100%);
  --grad-red:    linear-gradient(135deg, #d50000 0%, #ff1744 100%);
  --grad-purple: linear-gradient(135deg, #6200ea 0%, #aa00ff 100%);
  --grad-orange: linear-gradient(135deg, #e65100 0%, #ff6d00 100%);

  --success:     #00e676;
  --danger:      #ff1744;
  --warning:     #ffd740;
  --purple:      #aa00ff;
  --orange:      #ff6d00;

  --bg:          #060612;
  --bg-1:        #0a0a1e;
  --bg-2:        #0e0e24;
  --bg-3:        #13132e;

  --glass:       rgba(255,255,255,0.04);
  --glass-2:     rgba(255,255,255,0.07);
  --glass-3:     rgba(255,255,255,0.10);

  --border:      rgba(255,255,255,0.07);
  --border-2:    rgba(255,255,255,0.12);
  --border-blue: rgba(0,200,83,0.35);
  --border-glow: rgba(0,200,83,0.4);

  --text:        #f0f4ff;
  --text-2:      rgba(240,244,255,0.65);
  --text-3:      rgba(240,244,255,0.35);

  --r-2xl:  24px;
  --r-xl:   18px;
  --r-lg:   14px;
  --r-md:   10px;
  --r-sm:   8px;

  --shadow-sm:   0 2px 12px rgba(0,0,0,0.3);
  --shadow:      0 8px 32px rgba(0,0,0,0.4);
  --shadow-lg:   0 20px 60px rgba(0,0,0,0.5);
  --glow-blue:   0 0 30px rgba(0,200,83,0.25);
  --glow-green:  0 0 30px rgba(0,200,83,0.25);
  --glow-red:    0 0 30px rgba(255,23,68,0.25);

  --nav-h: 68px;
  --ease:  cubic-bezier(0.4,0,0.2,1);
  --spring:cubic-bezier(0.34,1.56,0.64,1);
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-tap-highlight-color:transparent; }
body {
  font-family:'Poppins',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; }
input,select,textarea,button { font-family:inherit; outline:none; border:none; }
button { cursor:pointer; }

/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border-2); border-radius:4px; }

/* ── Background Orbs ────────────────────────────────────────── */
body::before {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(ellipse 100% 80% at -10% -10%, rgba(0,200,83,0.10) 0%, transparent 55%),
    radial-gradient(ellipse 70%  70% at 110% 110%, rgba(170,0,255,0.08) 0%, transparent 50%),
    radial-gradient(ellipse 50%  50% at 50%  -10%, rgba(0,229,255,0.05) 0%, transparent 50%);
}

/* ── Icon Helper ────────────────────────────────────────────── */
.icon   { width:20px; height:20px; stroke-width:2; flex-shrink:0; }
.icon-sm{ width:16px; height:16px; stroke-width:2; flex-shrink:0; }
.icon-lg{ width:24px; height:24px; stroke-width:1.8; flex-shrink:0; }
.icon-xl{ width:32px; height:32px; stroke-width:1.6; flex-shrink:0; }
.icon-2xl{width:40px; height:40px; stroke-width:1.5; flex-shrink:0; }
svg[data-lucide] { display:inline-block; vertical-align:middle; }

/* ============================================================
   SPLASH SCREEN
   ============================================================ */
.splash {
  position:fixed; inset:0; z-index:9999;
  background:var(--bg);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:0;
}
.splash-bg-orb {
  position:absolute;
  border-radius:50%; filter:blur(80px); pointer-events:none;
  animation:orbFloat 6s ease-in-out infinite alternate;
}
.splash-bg-orb-1 { width:400px;height:400px; background:rgba(0,200,83,0.12); top:-100px; left:-100px; }
.splash-bg-orb-2 { width:300px;height:300px; background:rgba(170,0,255,0.08); bottom:-80px; right:-60px; animation-delay:2s; }
.splash-logo-wrap {
  position:relative;
  animation:splashLogoIn 0.8s var(--spring) forwards; opacity:0;
}
.splash-logo {
  width:110px; height:110px;
  background:var(--grad-primary);
  border-radius:30px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 0 0 rgba(0,200,83,0.4), 0 24px 60px rgba(0,200,83,0.4);
  animation:logoPulse 2s ease-in-out 1s infinite;
}
.splash-logo svg { color:#fff; }
.splash-logo-ring {
  position:absolute; inset:-12px;
  border-radius:40px;
  border:2px solid rgba(0,200,83,0.2);
  animation:ringExpand 1.2s ease-out 0.5s forwards; opacity:0;
}
.splash-name {
  font-size:34px; font-weight:800; margin-top:22px;
  background:var(--grad-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  letter-spacing:1px;
  animation:fadeUp 0.6s var(--ease) 0.35s forwards; opacity:0;
}
.splash-tagline {
  font-size:13px; color:var(--text-2); font-weight:400;
  letter-spacing:3px; text-transform:uppercase; margin-top:6px;
  animation:fadeUp 0.6s var(--ease) 0.5s forwards; opacity:0;
}
.splash-dots {
  display:flex; gap:8px; margin-top:50px;
  animation:fadeUp 0.6s var(--ease) 0.7s forwards; opacity:0;
}
.splash-dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--grad-primary);
  animation:dotBounce 1.4s ease-in-out infinite;
}
.splash-dot:nth-child(2){animation-delay:0.15s;}
.splash-dot:nth-child(3){animation-delay:0.30s;}

/* ============================================================
   PAGE SHELL
   ============================================================ */
.page {
  min-height:100vh;
  padding-bottom:calc(var(--nav-h) + 12px);
  position:relative; z-index:1;
}

/* ── Top Bar ─────────────────────────────────────────────── */
.topbar {
  position:sticky !important; top:0 !important; z-index:100 !important;
  padding:14px 20px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(6,6,18,0.85);
  backdrop-filter:blur(24px) saturate(1.5);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);
}
.topbar-logo {
  font-size:20px; font-weight:800; letter-spacing:0.5px;
  background:var(--grad-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  display:flex; align-items:center; gap:8px;
}
.topbar-logo-icon {
  width:32px; height:32px;
  background:var(--grad-primary);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 12px rgba(0,200,83,0.4);
}
.topbar-logo-icon svg { color:#fff; }
.topbar-title {
  font-size:16px; font-weight:700;
}
.topbar-btn {
  width:38px; height:38px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-2); transition:all 0.2s var(--ease);
  position:relative;
}
.topbar-btn:hover { background:var(--glass-2); border-color:var(--border-2); color:var(--text); }
.topbar-btn svg { width:18px; height:18px; }
.notif-dot {
  position:absolute; top:7px; right:7px;
  width:8px; height:8px; border-radius:50%;
  background:var(--danger); border:2px solid var(--bg);
}

/* Content padding */
.content { padding:20px; max-width:500px; margin:0 auto; position:relative; z-index:1; }

/* ============================================================
   GLASS CARDS
   ============================================================ */
.card {
  background:linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  border:1px solid var(--border);
  border-radius:var(--r-2xl);
  padding:22px;
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  transition:all 0.3s var(--ease);
  position:relative; overflow:hidden;
}
.card::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
}
.card:hover { border-color:var(--border-2); box-shadow:var(--glow-blue); }

.card-glow {
  border-color:var(--border-blue);
  box-shadow:var(--glow-blue);
  background:linear-gradient(135deg, rgba(0,200,83,0.08) 0%, rgba(0,230,118,0.04) 100%);
}

/* ── Balance Card ──────────────────────────────────────────── */
.balance-card {
  background:var(--grad-blue);
  border:none;
  border-radius:var(--r-2xl);
  padding:26px;
  position:relative; overflow:hidden;
  box-shadow:0 20px 60px rgba(2,136,209,0.35), inset 0 1px 0 rgba(255,255,255,0.18);
}
.balance-card::before {
  content:'';
  position:absolute; top:-60px; right:-60px;
  width:220px; height:220px;
  background:rgba(255,255,255,0.10);
  border-radius:50%; filter:blur(30px);
}
.balance-card::after {
  content:'';
  position:absolute; bottom:-80px; left:-20px;
  width:200px; height:200px;
  background:rgba(0,0,0,0.12);
  border-radius:50%;
}
.balance-card-inner { position:relative; z-index:1; }
.balance-chip {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:20px; padding:4px 12px;
  font-size:11px; font-weight:600; letter-spacing:1px;
  text-transform:uppercase; margin-bottom:14px;
  color:rgba(255,255,255,0.9);
}
.balance-chip svg { width:12px; height:12px; }
.balance-label { font-size:13px; font-weight:500; opacity:0.75; }
.balance-amount {
  font-size:38px; font-weight:800;
  margin:6px 0 4px; letter-spacing:0.5px; line-height:1.1;
}
.balance-sub { font-size:12px; opacity:0.65; margin-top:4px; }
.balance-actions {
  display:flex; gap:10px; margin-top:20px;
}
.balance-action-btn {
  flex:1; display:flex; align-items:center; justify-content:center; gap:7px;
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:14px; padding:11px 8px;
  font-size:13px; font-weight:600; color:#fff;
  cursor:pointer; transition:all 0.2s var(--ease);
  text-decoration:none;
}
.balance-action-btn:hover { background:rgba(255,255,255,0.25); }
.balance-action-btn svg { width:16px; height:16px; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 22px;
  border-radius:var(--r-lg);
  font-size:14px; font-weight:600; letter-spacing:0.2px;
  cursor:pointer; transition:all 0.2s var(--ease);
  position:relative; overflow:hidden; border:none;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:rgba(255,255,255,0); transition:0.2s;
}
.btn:hover::after  { background:rgba(255,255,255,0.07); }
.btn:active        { transform:scale(0.97); }
.btn:active::after { background:rgba(255,255,255,0.12); }

.btn-primary {
  background:var(--grad-primary); color:#fff;
  box-shadow:0 6px 24px rgba(0,200,83,0.38);
}
.btn-primary:hover { box-shadow:0 8px 32px rgba(0,200,83,0.55); }

.btn-success {
  background:var(--grad-green); color:#fff;
  box-shadow:0 6px 24px rgba(0,200,83,0.35);
}
.btn-success:hover { box-shadow:0 8px 32px rgba(0,200,83,0.5); }

.btn-danger {
  background:var(--grad-red); color:#fff;
  box-shadow:0 6px 24px rgba(255,23,68,0.35);
}
.btn-danger:hover { box-shadow:0 8px 32px rgba(255,23,68,0.5); }

.btn-ghost {
  background:var(--glass); border:1px solid var(--border);
  color:var(--text-2);
}
.btn-ghost:hover { border-color:var(--border-2); background:var(--glass-2); color:var(--text); }

.btn-block { width:100%; }
.btn-sm { padding:8px 14px; font-size:12px; border-radius:var(--r-md); gap:5px; }
.btn-lg { padding:16px 28px; font-size:15px; border-radius:var(--r-xl); }
.btn svg { flex-shrink:0; }

/* ── Quick Action Grid ─────────────────────────────────────── */
.quick-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:10px;
}
.quick-item {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  cursor:pointer; transition:all 0.2s var(--ease);
  text-decoration:none; color:var(--text);
}
.quick-icon {
  width:54px; height:54px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  display:flex; align-items:center; justify-content:center;
  transition:all 0.25s var(--ease);
  position:relative; overflow:hidden;
}
.quick-icon::before {
  content:''; position:absolute; inset:0;
  background:var(--grad-primary); opacity:0; transition:0.25s;
}
.quick-item:hover .quick-icon {
  border-color:var(--border-glow);
  box-shadow:0 0 20px rgba(0,200,83,0.2);
  transform:translateY(-2px);
}
.quick-item:hover .quick-icon::before { opacity:1; }
.quick-item:hover .quick-icon svg { color:#fff; }
.quick-icon svg { color:var(--blue); position:relative; z-index:1; }
.quick-label { font-size:11px; font-weight:500; color:var(--text-2); }

/* ============================================================
   FORM ELEMENTS
   ============================================================ */
.form-group { margin-bottom:18px; }
.form-label {
  display:block; font-size:12px; font-weight:600;
  color:var(--text-2); margin-bottom:8px; letter-spacing:0.3px;
  text-transform:uppercase;
}
.input-wrap { position:relative; }
.input-icon {
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  color:var(--text-3); pointer-events:none; transition:color 0.2s;
  display:flex;
}
.input-icon svg { width:18px; height:18px; }
.input-end {
  position:absolute; right:14px; top:50%; transform:translateY(-50%);
  cursor:pointer; color:var(--text-3); transition:color 0.2s;
  display:flex;
}
.input-end:hover { color:var(--text-2); }
.input-end svg { width:18px; height:18px; }
.form-control {
  width:100%;
  background:var(--glass);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  padding:14px 16px;
  color:var(--text);
  font-size:14px; font-weight:500;
  transition:all 0.25s var(--ease);
  -webkit-appearance:none;
}
.form-control:focus {
  border-color:var(--blue);
  background:rgba(0,200,83,0.06);
  box-shadow:0 0 0 4px rgba(0,200,83,0.10);
}
.form-control:focus ~ .input-icon svg,
.input-wrap:focus-within .input-icon svg { color:var(--blue); }
.form-control::placeholder { color:var(--text-3); font-weight:400; }
.input-wrap .form-control { padding-left:46px; }
.input-wrap.has-end .form-control { padding-right:46px; }
.form-control option { background:#1a1a3e; }
select.form-control { cursor:pointer; }
.form-hint { font-size:11px; color:var(--text-3); margin-top:5px; display:block; }

/* Quick amount chips */
.amount-chips { display:flex; gap:6px; margin-top:8px; flex-wrap:wrap; }
.amount-chip {
  padding:5px 12px;
  background:var(--glass); border:1px solid var(--border);
  border-radius:20px; font-size:12px; font-weight:600;
  color:var(--text-2); cursor:pointer; transition:all 0.15s;
}
.amount-chip:hover { border-color:var(--blue); color:var(--blue); background:rgba(0,200,83,0.08); }

/* ============================================================
   AUTH PAGES
   ============================================================ */
.auth-page {
  min-height:100vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:24px 20px;
  background:var(--bg);
}
.auth-top {
  text-align:center; margin-bottom:28px;
  animation:fadeUp 0.5s var(--ease);
}
.auth-app-icon {
  width:72px; height:72px;
  background:var(--grad-primary);
  border-radius:22px;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 14px;
  box-shadow:0 12px 40px rgba(0,200,83,0.4);
}
.auth-app-icon svg { color:#fff; width:36px; height:36px; }
.auth-app-name {
  font-size:26px; font-weight:800; letter-spacing:0.5px;
  background:var(--grad-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.auth-card {
  width:100%; max-width:420px;
  background:linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  border:1px solid var(--border);
  border-radius:28px; padding:32px 28px;
  backdrop-filter:blur(30px); -webkit-backdrop-filter:blur(30px);
  animation:fadeUp 0.5s var(--ease) 0.1s both;
  position:relative; overflow:hidden;
}
.auth-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
}
.auth-title { font-size:22px; font-weight:700; margin-bottom:4px; }
.auth-sub   { font-size:14px; color:var(--text-2); margin-bottom:26px; }
.auth-footer {
  text-align:center; margin-top:20px;
  font-size:13px; color:var(--text-2);
}
.auth-footer a { color:var(--blue); font-weight:600; }

.divider-text {
  text-align:center; position:relative; margin:20px 0;
  font-size:12px; color:var(--text-3);
}
.divider-text::before, .divider-text::after {
  content:''; position:absolute; top:50%;
  width:42%; height:1px; background:var(--border);
}
.divider-text::before { left:0; }
.divider-text::after  { right:0; }

/* ============================================================
   BOTTOM NAVIGATION
   ============================================================ */
.bottom-nav {
  position:fixed; bottom:0; left:0; right:0;
  height:var(--nav-h); z-index:200;
  background:rgba(6,6,18,0.92);
  backdrop-filter:blur(30px) saturate(2);
  -webkit-backdrop-filter:blur(30px);
  border-top:1px solid var(--border);
  display:flex; align-items:stretch;
  padding:0 8px;
  padding-bottom:env(safe-area-inset-bottom);
}
.nav-item {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:4px;
  cursor:pointer; transition:all 0.2s var(--ease);
  text-decoration:none; color:var(--text-3);
  position:relative; padding:8px 0;
  border-radius:var(--r-lg);
  margin:6px 2px;
}
.nav-item svg { width:22px; height:22px; transition:all 0.2s var(--ease); }
.nav-label { font-size:10px; font-weight:500; transition:all 0.2s var(--ease); }
.nav-item.active {
  color:var(--blue);
  background:rgba(0,200,83,0.08);
}
.nav-item.active svg { stroke:var(--blue); }
.nav-item.active .nav-label { color:var(--blue); font-weight:700; }
.nav-item.active::after {
  content:''; position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:32px; height:2.5px;
  background:var(--grad-primary); border-radius:0 0 4px 4px;
}
/* Center trade button */
.nav-center {
  display:flex; align-items:center; justify-content:center;
  flex:1.2;
}
.nav-trade-btn {
  width:50px; height:50px;
  background:var(--grad-primary);
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(0,200,83,0.45);
  transition:all 0.25s var(--spring);
  text-decoration:none;
}
.nav-trade-btn:hover { transform:scale(1.08) translateY(-2px); box-shadow:0 8px 28px rgba(0,200,83,0.6); }
.nav-trade-btn svg { color:#fff; width:22px; height:22px; }

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-head {
  display:flex; align-items:center; justify-content:space-between;
  margin:24px 0 14px;
}
.section-title {
  font-size:15px; font-weight:700; display:flex; align-items:center; gap:8px;
}
.section-title svg { color:var(--blue); }
.section-link {
  font-size:12px; color:var(--blue); font-weight:600;
  display:flex; align-items:center; gap:3px;
}
.section-link svg { width:14px; height:14px; }

/* ── Ticker ─────────────────────────────────────────────────── */
.ticker-wrap {
  overflow:hidden; border-radius:var(--r-lg);
  background:var(--glass); border:1px solid var(--border);
  padding:10px 0;
}
.ticker-inner {
  display:flex; gap:0;
  animation:ticker 28s linear infinite;
  white-space:nowrap;
}
.ticker-item {
  display:inline-flex; align-items:center; gap:6px;
  padding:0 18px; font-size:12px;
}
.ticker-sym  { color:var(--text-2); font-weight:600; }
.ticker-val  { font-weight:700; }
.ticker-chg  { font-size:11px; font-weight:600; }
.ticker-chg.up{ color:var(--success); }
.ticker-chg.dn{ color:var(--danger); }
.ticker-dot   { width:4px; height:4px; border-radius:50%; background:var(--border-2); }

/* ── Market List ─────────────────────────────────────────────── */
.market-list { display:flex; flex-direction:column; gap:8px; }
.market-row {
  display:flex; align-items:center;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:14px 16px; gap:12px;
  cursor:pointer; transition:all 0.2s var(--ease);
  text-decoration:none; color:var(--text);
}
.market-row:hover { border-color:var(--border-2); background:var(--glass-2); transform:translateX(2px); }
.market-coin {
  width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:800; flex-shrink:0;
}
.market-name-col { flex:1; }
.market-sym  { font-size:14px; font-weight:700; }
.market-full { font-size:11px; color:var(--text-2); margin-top:2px; }
.market-price-col { text-align:right; }
.market-price { font-size:14px; font-weight:700; }
.market-chg {
  font-size:11px; font-weight:600; margin-top:2px;
  display:inline-flex; align-items:center; gap:2px;
}
.market-chg.up { color:var(--success); }
.market-chg.dn { color:var(--danger); }
.market-chg svg { width:10px; height:10px; }

/* ── Price Badge ─────────────────────────────────────────────── */
.price-change-badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 9px; border-radius:20px; font-size:12px; font-weight:700;
}
.price-change-badge.up { background:rgba(0,230,118,0.12); color:var(--success); }
.price-change-badge.dn { background:rgba(255,23,68,0.12);  color:var(--danger); }

/* ============================================================
   CHART
   ============================================================ */
.chart-card {
  background:linear-gradient(135deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0.02) 100%);
  border:1px solid var(--border);
  border-radius:var(--r-2xl);
  overflow:hidden;
}
.chart-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border-bottom:1px solid var(--border);
}
.chart-pair-label { font-size:14px; font-weight:700; }
.chart-live-price { font-size:13px; font-weight:700; }
.chart-live-price.up { color:var(--success); }
.chart-live-price.dn { color:var(--danger); }
.chart-body { height:240px; }
.tf-tabs { display:flex; gap:4px; }
.tf-tab {
  padding:4px 9px; border-radius:8px;
  font-size:11px; font-weight:700; cursor:pointer;
  background:transparent; color:var(--text-3); border:none;
  transition:all 0.15s;
}
.tf-tab.active { background:var(--grad-primary); color:#fff; }
.tf-tab:hover:not(.active) { color:var(--text-2); }

/* ============================================================
   TRADE PAGE
   ============================================================ */
.timer-card {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-2xl); padding:20px; margin-bottom:16px;
}
.timer-label { font-size:11px; font-weight:600; color:var(--text-2); text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; }
.timer-btns { display:flex; gap:8px; }
.timer-btn {
  flex:1; padding:12px;
  background:var(--glass); border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  font-size:13px; font-weight:700; color:var(--text-2);
  cursor:pointer; transition:all 0.2s var(--ease);
  text-align:center;
}
.timer-btn:hover { border-color:var(--blue); color:var(--blue); }
.timer-btn.active {
  background:var(--grad-primary);
  border-color:transparent; color:#fff;
  box-shadow:0 4px 16px rgba(0,200,83,0.3);
}

.trade-btns { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.trade-buy-btn, .trade-sell-btn {
  padding:18px 12px;
  border-radius:var(--r-xl); font-size:16px; font-weight:700;
  display:flex; align-items:center; justify-content:center; gap:10px;
  border:none; cursor:pointer; transition:all 0.2s var(--ease);
}
.trade-buy-btn {
  background:var(--grad-green);
  box-shadow:0 8px 28px rgba(0,200,83,0.3);
  color:#fff;
}
.trade-buy-btn:hover { box-shadow:0 10px 36px rgba(0,200,83,0.45); transform:translateY(-1px); }
.trade-sell-btn {
  background:var(--grad-red);
  box-shadow:0 8px 28px rgba(255,23,68,0.3);
  color:#fff;
}
.trade-sell-btn:hover { box-shadow:0 10px 36px rgba(255,23,68,0.45); transform:translateY(-1px); }
.trade-buy-btn svg, .trade-sell-btn svg { width:22px; height:22px; }

.trade-stats-row { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:16px; }
.trade-stat {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:12px; text-align:center;
}
.trade-stat-label { font-size:10px; color:var(--text-3); text-transform:uppercase; letter-spacing:0.8px; }
.trade-stat-value { font-size:16px; font-weight:800; margin-top:4px; }

/* ── Trade Overlay ─────────────────────────────────────────── */
.trade-overlay {
  position:fixed; inset:0; z-index:400;
  background:rgba(0,0,0,0.85); backdrop-filter:blur(16px);
  display:flex; align-items:center; justify-content:center; padding:24px;
}
.trade-overlay-card {
  background:var(--bg-2);
  border:1px solid var(--border-blue);
  border-radius:28px; padding:40px 32px;
  text-align:center; width:100%; max-width:340px;
  animation:scaleIn 0.4s var(--spring);
  box-shadow:var(--glow-blue);
}
.trade-direction-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 16px; border-radius:20px;
  font-size:14px; font-weight:700; margin-bottom:24px;
}
.trade-direction-badge.buy { background:rgba(0,230,118,0.15); color:var(--success); border:1px solid rgba(0,230,118,0.3); }
.trade-direction-badge.sell{ background:rgba(255,23,68,0.15);  color:var(--danger);  border:1px solid rgba(255,23,68,0.3); }

/* Circular progress timer */
.ring-timer { position:relative; width:130px; height:130px; margin:0 auto 20px; }
.ring-timer svg { transform:rotate(-90deg); }
.ring-bg   { fill:none; stroke:var(--bg-3); stroke-width:6; }
.ring-prog { fill:none; stroke:url(#ringGrad); stroke-width:6; stroke-linecap:round; transition:stroke-dashoffset 0.5s linear; }
.ring-time {
  position:absolute; inset:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.ring-sec  { font-size:30px; font-weight:800; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.ring-unit { font-size:11px; color:var(--text-3); font-weight:500; margin-top:2px; }

/* ── Result ────────────────────────────────────────────────── */
.result-wrap { text-align:center; padding:20px; animation:scaleIn 0.5s var(--spring); }
.result-ring {
  width:100px; height:100px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
  animation:bounceIn 0.6s var(--spring);
}
.result-ring.win { background:rgba(0,230,118,0.15); border:3px solid rgba(0,230,118,0.4); }
.result-ring.loss{ background:rgba(255,23,68,0.15);  border:3px solid rgba(255,23,68,0.4); }
.result-ring svg { width:44px; height:44px; }
.result-title { font-size:28px; font-weight:800; margin-bottom:6px; }
.result-title.win  { color:var(--success); }
.result-title.loss { color:var(--danger); }
.result-amount { font-size:22px; font-weight:700; margin-bottom:8px; }
.result-balance-row {
  display:flex; align-items:center; justify-content:center; gap:6px;
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:10px 20px; margin:16px 0;
}

/* ── New Result Card (trade.php) ───────── */
.result-card {
  border-radius:22px; padding:28px 20px 22px;
  text-align:center;
  animation:scaleIn .45s var(--spring);
  border:1.5px solid transparent;
}
.result-card.result-win {
  background:linear-gradient(160deg,rgba(0,200,83,0.10),rgba(0,230,118,0.04));
  border-color:rgba(0,200,83,0.3);
}
.result-card.result-loss {
  background:linear-gradient(160deg,rgba(255,23,68,0.10),rgba(255,68,100,0.04));
  border-color:rgba(255,23,68,0.28);
}
.result-icon-ring {
  width:88px; height:88px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 16px;
  animation:bounceIn .6s var(--spring);
}
.ring-win  { background:rgba(0,200,83,0.12); border:2.5px solid rgba(0,200,83,0.35); }
.ring-loss { background:rgba(255,23,68,0.10); border:2.5px solid rgba(255,23,68,0.3); }
.result-headline {
  font-size:26px; font-weight:900; letter-spacing:-.5px; margin-bottom:4px;
}
.result-headline.win  { color:var(--success); }
.result-headline.loss { color:var(--danger); }
.result-big-amt {
  font-size:34px; font-weight:900; letter-spacing:-1px;
  margin:10px 0 4px;
  animation:fadeUp .4s ease;
}
.result-big-amt.win  { color:var(--success); }
.result-big-amt.loss { color:var(--danger); }
.result-amt-sub {
  font-size:12px; color:var(--text-3); margin-bottom:18px;
}
.result-bal-row {
  display:flex; align-items:center; justify-content:center; gap:8px;
  background:rgba(0,200,83,0.07); border:1px solid rgba(0,200,83,0.2);
  border-radius:14px; padding:12px 18px; margin-bottom:18px;
}
.result-bal-lbl { font-size:12px; color:var(--text-3); }
.result-bal-val { font-size:16px; font-weight:800; color:var(--text); margin-left:4px; }
.result-trade-again-btn {
  width:100%; padding:15px; border-radius:16px; border:none; cursor:pointer;
  background:var(--grad-primary); color:#fff;
  font-size:15px; font-weight:800;
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow:0 8px 24px rgba(0,200,83,0.32);
  transition:.2s;
}
.result-trade-again-btn:hover {
  box-shadow:0 10px 32px rgba(0,200,83,0.48);
  transform:translateY(-1px);
}

/* ============================================================
   DEPOSIT / WITHDRAW
   ============================================================ */
.upi-card {
  background:linear-gradient(135deg, rgba(0,200,83,0.08), rgba(0,230,118,0.04));
  border:1px solid var(--border-blue);
  border-radius:var(--r-2xl); padding:22px;
}
.qr-frame {
  background:#fff; border-radius:var(--r-xl);
  padding:14px; display:inline-block;
  box-shadow:0 8px 30px rgba(0,0,0,0.3);
  margin:0 auto; display:flex; justify-content:center;
}
.qr-frame img { width:170px; height:170px; object-fit:contain; }
.qr-placeholder {
  width:170px; height:170px;
  background:linear-gradient(135deg, #f0f0f0, #e0e0e0);
  border-radius:12px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px;
}
.qr-placeholder svg { color:#aaa; width:48px; height:48px; }
.qr-placeholder span { font-size:11px; color:#999; font-weight:500; }
.upi-id-row {
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(0,200,83,0.08); border:1px solid var(--border-blue);
  border-radius:var(--r-lg); padding:13px 16px; margin:16px 0;
}
.upi-id-text { font-size:14px; font-weight:700; font-family:monospace; }
.upi-copy-btn {
  display:flex; align-items:center; gap:5px;
  background:var(--grad-primary);
  border:none; border-radius:10px;
  padding:7px 13px; font-size:12px; font-weight:700;
  color:#fff; cursor:pointer; transition:0.2s;
}
.upi-copy-btn:hover { box-shadow:0 4px 12px rgba(0,200,83,0.4); }
.upi-copy-btn svg { width:14px; height:14px; }

.steps-list { display:flex; flex-direction:column; gap:12px; }
.step-item { display:flex; align-items:flex-start; gap:14px; }
.step-num {
  width:28px; height:28px; flex-shrink:0;
  background:var(--grad-primary); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:800; color:#fff;
}
.step-text { font-size:13px; color:var(--text-2); line-height:1.5; padding-top:4px; }

/* ============================================================
   HISTORY
   ============================================================ */
.tab-bar {
  display:flex; gap:4px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--r-xl); padding:4px; margin-bottom:20px;
}
.tab-pill {
  flex:1; padding:9px 8px;
  background:transparent; border:none;
  border-radius:var(--r-lg); font-size:12px; font-weight:600;
  color:var(--text-2); cursor:pointer; transition:all 0.2s var(--ease);
  display:flex; align-items:center; justify-content:center; gap:5px;
}
.tab-pill svg { width:14px; height:14px; }
.tab-pill.active {
  background:var(--grad-primary); color:#fff;
  box-shadow:0 4px 12px rgba(0,200,83,0.3);
}
.tab-pill:hover:not(.active) { color:var(--text); background:var(--glass-2); }

.tx-list { display:flex; flex-direction:column; gap:8px; }
.tx-item {
  display:flex; align-items:center; gap:13px;
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:14px 16px;
  transition:all 0.2s var(--ease);
}
.tx-item:hover { border-color:var(--border-2); background:var(--glass-2); }
.tx-icon {
  width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.tx-icon.deposit  { background:rgba(0,230,118,0.12); color:var(--success); }
.tx-icon.withdraw { background:rgba(255,23,68,0.12);  color:var(--danger); }
.tx-icon.trade    { background:rgba(0,200,83,0.12);  color:var(--blue); }
.tx-icon svg { width:20px; height:20px; }
.tx-info  { flex:1; min-width:0; }
.tx-title { font-size:13px; font-weight:600; }
.tx-meta  { font-size:11px; color:var(--text-3); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tx-right { text-align:right; flex-shrink:0; }
.tx-amount{ font-size:14px; font-weight:700; }
.tx-status{ font-size:11px; font-weight:600; margin-top:3px; }
.tx-status.pending  { color:var(--warning); }
.tx-status.approved { color:var(--success); }
.tx-status.rejected { color:var(--danger); }
.tx-status.win      { color:var(--success); }
.tx-status.loss     { color:var(--danger); }

/* ============================================================
   PROFILE
   ============================================================ */
.profile-hero {
  text-align:center; padding:28px 20px;
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-2xl); margin-bottom:20px;
  position:relative; overflow:hidden;
}
.profile-hero::before {
  content:''; position:absolute; top:-60px; left:50%; transform:translateX(-50%);
  width:200px; height:200px;
  background:radial-gradient(circle, rgba(0,200,83,0.12) 0%, transparent 60%);
}
.profile-avatar {
  width:80px; height:80px;
  background:var(--grad-primary);
  border-radius:50%; margin:0 auto 14px;
  display:flex; align-items:center; justify-content:center;
  font-size:32px; font-weight:800; color:#fff;
  box-shadow:0 8px 30px rgba(0,200,83,0.35);
  position:relative;
}
.profile-avatar-ring {
  position:absolute; inset:-4px; border-radius:50%;
  border:2px solid rgba(0,200,83,0.3);
}
.profile-name   { font-size:20px; font-weight:700; }
.profile-mobile { font-size:13px; color:var(--text-2); margin-top:4px; display:flex; align-items:center; justify-content:center; gap:5px; }
.profile-mobile svg { width:14px; height:14px; }
.profile-balance {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,200,83,0.08); border:1px solid var(--border-blue);
  border-radius:var(--r-xl); padding:10px 20px; margin-top:16px;
}

.menu-list { display:flex; flex-direction:column; gap:8px; }
.menu-row {
  display:flex; align-items:center; gap:14px;
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:15px 16px;
  cursor:pointer; transition:all 0.2s var(--ease);
  text-decoration:none; color:var(--text);
}
.menu-row:hover { border-color:var(--border-2); background:var(--glass-2); transform:translateX(2px); }
.menu-row.danger { border-color:rgba(255,23,68,0.2); }
.menu-row.danger .menu-icon-wrap { background:rgba(255,23,68,0.1); color:var(--danger); }
.menu-row.danger .menu-row-title { color:var(--danger); }
.menu-icon-wrap {
  width:38px; height:38px; border-radius:var(--r-md);
  background:rgba(0,200,83,0.1); color:var(--blue);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.menu-icon-wrap svg { width:18px; height:18px; }
.menu-row-title { font-size:14px; font-weight:600; flex:1; }
.menu-row-sub   { font-size:11px; color:var(--text-3); margin-top:1px; }
.menu-arrow { color:var(--text-3); }
.menu-arrow svg { width:16px; height:16px; }

/* ============================================================
   ALERTS / TOASTS / PILLS
   ============================================================ */
.alert {
  padding:13px 16px; border-radius:var(--r-lg);
  font-size:13px; font-weight:500;
  display:flex; align-items:flex-start; gap:10px;
  margin-bottom:16px; animation:fadeUp 0.3s var(--ease);
}
.alert svg { flex-shrink:0; margin-top:1px; }
.alert-success { background:rgba(0,230,118,0.08); border:1px solid rgba(0,230,118,0.2); color:var(--success); }
.alert-danger  { background:rgba(255,23,68,0.08);  border:1px solid rgba(255,23,68,0.2);  color:var(--danger); }
.alert-info    { background:rgba(0,200,83,0.08);  border:1px solid rgba(0,200,83,0.2);  color:#00c853; }
.alert-warning { background:rgba(255,215,64,0.08);  border:1px solid rgba(255,215,64,0.2);  color:var(--warning); }

.toast-container {
  position:fixed; top:76px; left:50%; transform:translateX(-50%);
  z-index:9999; width:calc(100% - 32px); max-width:400px;
  display:flex; flex-direction:column; gap:8px; pointer-events:none;
}
.toast {
  padding:13px 16px; border-radius:var(--r-lg);
  font-size:13px; font-weight:600; pointer-events:all;
  display:flex; align-items:center; gap:10px;
  animation:toastIn 0.3s var(--spring); backdrop-filter:blur(20px);
}
.toast svg { width:18px; height:18px; flex-shrink:0; }
.toast-success { background:rgba(0,200,83,0.95);  color:#fff; border:1px solid rgba(0,230,118,0.3); }
.toast-danger  { background:rgba(255,23,68,0.95);  color:#fff; border:1px solid rgba(255,100,100,0.3); }
.toast-info    { background:rgba(0,200,83,0.95);  color:#fff; border:1px solid rgba(0,200,83,0.3); }
.toast.out { animation:toastOut 0.25s var(--ease) forwards; }

.pill {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 10px; border-radius:20px;
  font-size:11px; font-weight:700; letter-spacing:0.2px;
}
.pill-success { background:rgba(0,230,118,0.12); color:var(--success); }
.pill-danger  { background:rgba(255,23,68,0.12);  color:var(--danger); }
.pill-warning { background:rgba(255,215,64,0.12);  color:var(--warning); }
.pill-info    { background:rgba(0,200,83,0.12);  color:#00c853; }
.pill-purple  { background:rgba(170,0,255,0.12);   color:#ce93d8; }

/* ============================================================
   STATS GRIDS
   ============================================================ */
.stats-2x2 { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.stats-4x1 { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.stat-box {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:16px;
  transition:all 0.2s var(--ease);
}
.stat-box:hover { border-color:var(--border-2); }
.stat-box-icon {
  width:38px; height:38px; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center; margin-bottom:12px;
}
.stat-box-icon svg { width:18px; height:18px; }
.stat-box-val   { font-size:20px; font-weight:800; line-height:1.1; }
.stat-box-label { font-size:11px; color:var(--text-2); margin-top:4px; }

/* Colored accent borders */
.accent-blue   { border-color:rgba(0,200,83,0.25); }
.accent-green  { border-color:rgba(0,230,118,0.25); }
.accent-red    { border-color:rgba(255,23,68,0.25); }
.accent-purple { border-color:rgba(170,0,255,0.25); }
.accent-orange { border-color:rgba(255,109,0,0.25); }

/* ============================================================
   ADMIN PANEL
   ============================================================ */
.admin-layout { display:flex; min-height:100vh; }

/* Sidebar */
.admin-sidebar {
  width:248px; flex-shrink:0;
  background:rgba(6,6,18,0.98);
  border-right:1px solid var(--border);
  position:fixed; top:0; left:0; bottom:0;
  z-index:200; display:flex; flex-direction:column;
  transition:transform 0.3s var(--ease);
}
.sidebar-logo-area {
  padding:22px 20px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:12px;
}
.sidebar-logo-icon {
  width:38px; height:38px; border-radius:12px;
  background:var(--grad-primary);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 14px rgba(0,200,83,0.4); flex-shrink:0;
}
.sidebar-logo-icon svg { color:#fff; width:20px; height:20px; }
.sidebar-logo-name { font-size:17px; font-weight:800; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.sidebar-logo-sub  { font-size:10px; color:var(--text-3); font-weight:500; margin-top:1px; }

.sidebar-nav { flex:1; overflow-y:auto; padding:14px 10px; }
.sidebar-section {
  font-size:10px; font-weight:700; color:var(--text-3);
  text-transform:uppercase; letter-spacing:1.5px;
  padding:14px 10px 6px;
}
.sidebar-link {
  display:flex; align-items:center; gap:11px;
  padding:10px 10px; border-radius:var(--r-md);
  font-size:13px; font-weight:500; color:var(--text-2);
  cursor:pointer; transition:all 0.15s var(--ease);
  text-decoration:none; margin-bottom:2px;
  position:relative;
}
.sidebar-link:hover { background:var(--glass-2); color:var(--text); }
.sidebar-link.active {
  background:rgba(0,200,83,0.10);
  color:var(--blue); font-weight:600;
}
.sidebar-link.active::before {
  content:''; position:absolute; left:0; top:25%; bottom:25%;
  width:3px; background:var(--grad-primary); border-radius:0 3px 3px 0;
}
.sidebar-link svg { width:17px; height:17px; flex-shrink:0; }
.sidebar-badge {
  margin-left:auto;
  background:var(--danger); color:#fff;
  font-size:10px; font-weight:700;
  padding:2px 7px; border-radius:20px;
}

/* Admin topbar */
.admin-main { flex:1; margin-left:248px; display:flex; flex-direction:column; min-height:100vh; }
.admin-topbar {
  background:rgba(6,6,18,0.98);
  border-bottom:1px solid var(--border);
  padding:14px 24px;
  display:flex; align-items:center; justify-content:space-between;
  position:sticky; top:0; z-index:100;
}
.admin-topbar-title { font-size:17px; font-weight:700; }
.admin-content { padding:24px; flex:1; }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.hamburger span { width:22px; height:2px; background:var(--text); border-radius:2px; transition:0.3s; }
.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.7); z-index:190; }

/* Admin stats */
.admin-stats {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(190px,1fr));
  gap:16px; margin-bottom:24px;
}
.admin-stat-card {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-2xl); padding:20px;
  display:flex; align-items:flex-start; gap:14px;
  transition:all 0.2s var(--ease);
}
.admin-stat-card:hover { border-color:var(--border-2); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.admin-stat-icon {
  width:46px; height:46px; border-radius:var(--r-xl);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.admin-stat-icon svg { width:22px; height:22px; }
.admin-stat-val   { font-size:22px; font-weight:800; }
.admin-stat-label { font-size:12px; color:var(--text-2); margin-top:2px; }

/* Admin table */
.admin-table-card {
  background:var(--glass); border:1px solid var(--border);
  border-radius:var(--r-2xl); overflow:hidden;
}
.table-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid var(--border);
}
.table-title { font-size:14px; font-weight:700; display:flex; align-items:center; gap:8px; }
.table-title svg { color:var(--blue); }
.admin-table { width:100%; border-collapse:collapse; font-size:13px; }
.admin-table thead tr { background:rgba(255,255,255,0.03); }
.admin-table th {
  padding:12px 16px; text-align:left;
  font-size:11px; font-weight:700; color:var(--text-3);
  text-transform:uppercase; letter-spacing:0.8px;
  border-bottom:1px solid var(--border);
}
.admin-table td {
  padding:13px 16px;
  border-bottom:1px solid rgba(255,255,255,0.03);
  vertical-align:middle;
}
.admin-table tr:last-child td { border-bottom:none; }
.admin-table tr:hover td { background:rgba(255,255,255,0.02); }

/* Filter bar */
.filter-bar { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:18px; }
.filter-btn {
  padding:6px 14px; border-radius:20px;
  font-size:12px; font-weight:600;
  background:var(--glass); border:1px solid var(--border);
  color:var(--text-2); cursor:pointer; transition:all 0.15s;
  text-decoration:none; display:inline-flex; align-items:center; gap:5px;
}
.filter-btn:hover { border-color:var(--border-2); color:var(--text); }
.filter-btn.active { background:var(--grad-primary); border-color:transparent; color:#fff; }
.filter-btn svg { width:13px; height:13px; }

/* ── Inline action forms in tables ── */
.action-form-panel {
  margin-top:8px; padding:12px;
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r-lg); display:none;
}
.action-form-panel.open { display:block; animation:fadeUp 0.2s var(--ease); }

/* ── Empty state ── */
.empty-state { text-align:center; padding:52px 20px; }
.empty-icon  { margin-bottom:14px; color:var(--text-3); display:flex; justify-content:center; }
.empty-icon svg { width:56px; height:56px; }
.empty-text  { font-size:14px; color:var(--text-2); font-weight:500; }
.empty-sub   { font-size:12px; color:var(--text-3); margin-top:6px; }

/* ── Spinner ── */
.spinner-wrap { display:flex; justify-content:center; padding:40px; }
.spinner {
  width:36px; height:36px;
  border:3px solid var(--border);
  border-top-color:var(--blue);
  border-radius:50%; animation:spin 0.7s linear infinite;
}

/* ── Divider ── */
.hr { border:none; border-top:1px solid var(--border); margin:20px 0; }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes splashLogoIn {
  from { opacity:0; transform:scale(0.5) rotate(-15deg); }
  to   { opacity:1; transform:scale(1) rotate(0); }
}
@keyframes ringExpand {
  from { opacity:0; transform:scale(0.8); }
  to   { opacity:1; transform:scale(1); }
}
@keyframes logoPulse {
  0%,100% { box-shadow:0 0 0 0 rgba(0,200,83,0.4), 0 24px 60px rgba(0,200,83,0.4); }
  50%      { box-shadow:0 0 0 16px rgba(0,200,83,0), 0 24px 60px rgba(0,200,83,0.3); }
}
@keyframes orbFloat {
  from { transform:translate(0,0) scale(1); }
  to   { transform:translate(20px,30px) scale(1.05); }
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
  from { opacity:0; } to { opacity:1; }
}
@keyframes scaleIn {
  from { opacity:0; transform:scale(0.88); }
  to   { opacity:1; transform:scale(1); }
}
@keyframes bounceIn {
  0%   { opacity:0; transform:scale(0.3); }
  60%  { transform:scale(1.15); }
  80%  { transform:scale(0.95); }
  100% { opacity:1; transform:scale(1); }
}
@keyframes dotBounce {
  0%,80%,100% { transform:scale(0.5); opacity:0.35; }
  40%          { transform:scale(1);   opacity:1; }
}
@keyframes ticker {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
@keyframes spin { to { transform:rotate(360deg); } }
@keyframes toastIn {
  from { opacity:0; transform:translateY(-8px) scale(0.95); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes toastOut {
  to { opacity:0; transform:translateY(-8px) scale(0.95); }
}
@keyframes pulse {
  0%,100% { opacity:1; } 50% { opacity:0.5; }
}
@keyframes shimmer {
  0%   { background-position:-200% 0; }
  100% { background-position: 200% 0; }
}

.anim-fadein { animation:fadeIn 0.4s var(--ease); }
.anim-fadeup { animation:fadeUp 0.5s var(--ease); }
.anim-scalein{ animation:scaleIn 0.4s var(--spring); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(min-width:600px) {
  .content { padding:24px; }
  .stats-2x2 { grid-template-columns:repeat(4,1fr); }
}

/* ── Admin Mobile Bottom Nav ─────────────────────────────── */
.admin-bottom-nav {
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:300;
  background:rgba(6,6,18,0.98);
  border-top:1px solid var(--border);
  backdrop-filter:blur(20px);
  padding:6px 4px calc(6px + env(safe-area-inset-bottom));
  grid-template-columns:repeat(5,1fr);
}
.abn-item {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px; padding:6px 4px; border-radius:12px;
  color:var(--text-3); text-decoration:none; font-size:10px; font-weight:600;
  position:relative; transition:.15s;
}
.abn-item svg { width:20px; height:20px; }
.abn-item.active { color:var(--blue); }
.abn-item.active svg { color:var(--blue); }
.abn-item:hover { color:var(--text-2); }
.abn-badge {
  position:absolute; top:2px; right:calc(50% - 18px);
  background:var(--danger); color:#fff;
  font-size:9px; font-weight:800; border-radius:20px;
  padding:1px 5px; min-width:16px; text-align:center;
}

/* ── Sidebar close btn ───────────────────────────────────── */
.sidebar-close-btn {
  display:none;
  width:30px; height:30px; border-radius:9px;
  background:var(--glass); border:1px solid var(--border);
  align-items:center; justify-content:center;
  color:var(--text-3); cursor:pointer; flex-shrink:0;
}

/* ── Admin notification btn ─────────────────────────────── */
.admin-notif-btn {
  display:flex; align-items:center; gap:5px;
  background:rgba(255,215,64,0.1); border:1px solid rgba(255,215,64,0.2);
  border-radius:20px; padding:5px 10px;
  font-size:11px; font-weight:700; color:var(--warning);
  text-decoration:none;
}

/* ── Mobile breakpoint ───────────────────────────────────── */
@media(max-width:768px) {
  /* Sidebar */
  .admin-sidebar {
    width:280px;
    transform:translateX(-100%);
  }
  .admin-sidebar.open {
    transform:translateX(0);
    box-shadow:0 0 60px rgba(0,0,0,0.6);
  }
  .sidebar-overlay.open { display:block; }
  .sidebar-close-btn { display:flex; }
  .admin-main { margin-left:0; }
  .hamburger { display:flex; }

  /* Topbar */
  .admin-topbar { padding:12px 14px; }
  .admin-topbar-title { font-size:15px; }

  /* Content */
  .admin-content {
    padding:14px 14px 90px; /* bottom padding for bottom nav */
  }

  /* Stats grid */
  .admin-stats { grid-template-columns:repeat(2,1fr); gap:10px; margin-bottom:16px; }
  .admin-stat-card { padding:14px 12px; }
  .admin-stat-icon { width:38px; height:38px; }
  .admin-stat-icon svg { width:18px; height:18px; }
  .admin-stat-val { font-size:18px; }

  /* Table card */
  .admin-table-card { border-radius:16px; }
  .table-header { padding:14px; flex-wrap:wrap; gap:10px; }
  .table-title { font-size:14px; }

  /* Table → horizontal scroll */
  .admin-table-wrap,
  [style*="overflow-x:auto"] { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .admin-table {
    min-width:560px;
    font-size:12px;
  }
  .admin-table th,
  .admin-table td { padding:10px 10px; }

  /* Mobile bottom nav */
  .admin-bottom-nav { display:grid; }

  /* Settings grid → single column */
  [style*="grid-template-columns:repeat(auto-fit"] {
    display:flex !important;
    flex-direction:column !important;
  }

  /* Action panel */
  .action-form-panel { padding:12px; }
  .action-form-panel .btn { min-height:40px; font-size:12px; }
  .action-form-panel input.form-control { min-height:40px; font-size:13px; }

  /* Form controls bigger for touch */
  .form-control { min-height:44px; font-size:14px; }
  select.form-control { min-height:44px; }
  .btn { min-height:40px; }

  /* Cards grid → single column */
  .admin-stats.two-col { grid-template-columns:repeat(2,1fr); }

  /* Table search row */
  .table-header form { width:100%; }
  .table-header form .input-wrap { min-width:0 !important; flex:1; }
}

/* ── Admin table card mode (mobile) ─────────────────────── */
@media(max-width:540px) {
  .admin-table,
  .admin-table thead,
  .admin-table tbody,
  .admin-table th,
  .admin-table td,
  .admin-table tr { display:block; white-space:normal; min-width:0; }

  .admin-table thead { display:none; }

  .admin-table tbody tr {
    background:var(--glass);
    border:1px solid var(--border);
    border-radius:14px;
    margin-bottom:10px;
    padding:4px 0;
    overflow:hidden;
  }
  .admin-table tbody tr:hover { background:var(--glass); }

  .admin-table td {
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:9px 14px;
    border-bottom:1px solid rgba(255,255,255,0.04);
    font-size:13px;
    gap:8px;
  }
  .admin-table td:last-child { border-bottom:none; }

  .admin-table td::before {
    content:attr(data-label);
    font-size:10px;
    font-weight:700;
    color:var(--text-3);
    text-transform:uppercase;
    letter-spacing:.5px;
    flex-shrink:0;
    min-width:70px;
  }

  /* Hide serial number column on cards */
  .admin-table td:first-child::before { content:none; }
  .admin-table td:first-child { display:none; }

  /* Action td full width */
  .admin-table td:last-child {
    flex-direction:column;
    align-items:flex-start;
  }
  .admin-table td:last-child::before { content:none; }
  .action-form-panel { width:100%; }

  /* Prevent overflow-x:auto wrapping */
  [style*="overflow-x:auto"] { overflow:visible !important; }
}

/* ── Extra small phones ──────────────────────────────────── */
@media(max-width:400px) {
  .admin-stats { grid-template-columns:repeat(2,1fr); gap:8px; }
  .admin-stat-val { font-size:16px; }
  .admin-content { padding:12px 12px 90px; }
  .admin-table { font-size:11px; }
  .admin-table th, .admin-table td { padding:8px 8px; }
  .abn-item { font-size:9px; }
  .abn-item svg { width:18px; height:18px; }
}

/* ── Utils ── */
.flex        { display:flex; }
.flex-col    { flex-direction:column; }
.items-center{ align-items:center; }
.justify-between{ justify-content:space-between; }
.justify-center { justify-content:center; }
.gap-4  { gap:4px; }  .gap-6  { gap:6px; }  .gap-8  { gap:8px; }
.gap-10 { gap:10px; } .gap-12 { gap:12px; } .gap-16 { gap:16px; }
.flex-1 { flex:1; } .w-full { width:100%; }
.text-center{ text-align:center; } .text-right{ text-align:right; }
.font-5 { font-weight:500; } .font-6 { font-weight:600; }
.font-7 { font-weight:700; } .font-8 { font-weight:800; }
.text-xs  { font-size:11px; } .text-sm { font-size:12px; }
.text-base{ font-size:14px; } .text-lg { font-size:16px; }
.text-xl  { font-size:18px; } .text-2xl{ font-size:22px; }
.text-muted  { color:var(--text-2); }
.text-dim    { color:var(--text-3); }
.text-primary{ color:var(--blue); }
.text-success{ color:var(--success); }
.text-danger { color:var(--danger); }
.text-warning{ color:var(--warning); }
.mt-4{margin-top:4px;} .mt-8{margin-top:8px;} .mt-12{margin-top:12px;}
.mt-16{margin-top:16px;} .mt-20{margin-top:20px;} .mt-24{margin-top:24px;}
.mb-8{margin-bottom:8px;} .mb-12{margin-bottom:12px;} .mb-16{margin-bottom:16px;}
.mb-20{margin-bottom:20px;} .mb-24{margin-bottom:24px;}
.p-16{padding:16px;} .p-20{padding:20px;} .p-24{padding:24px;}
.rounded-full { border-radius:9999px; }
.overflow-hidden { overflow:hidden; }
.relative { position:relative; }
.hidden { display:none !important; }
.opacity-0 { opacity:0; }
