/* ============================================================
   MAHADEV SMM PANEL — style.css v1.9
   Performance: GPU layers, contain, will-change, preload
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@700;800;900&family=Poppins:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#dde8f8;
  --card:#ffffff;
  --border:#d0d8e8;
  --primary:#1a56db;
  --primary-dark:#1344b4;
  --accent:#f59e0b;
  --text:#1a2340;
  --text2:#6b7280;
  --green:#16a34a;
  --red:#dc2626;
  --orange:#d97706;
  --shadow:0 2px 8px rgba(26,86,219,0.07);
  --shadow-card:0 1px 4px rgba(0,0,0,0.07);
  --radius:16px;
  --radius-sm:12px;
  --font:'Poppins',sans-serif;
}

/* ── Reset & Performance ─────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;text-size-adjust:100%;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
  /* GPU compositing for smooth scroll */
  -webkit-overflow-scrolling:touch;
}
img{display:block;max-width:100%;height:auto;loading:lazy}
a{text-decoration:none;color:inherit}
button{font-family:var(--font);cursor:pointer}

/* ── Skeleton loader ─────────────────────────────── */
.skeleton{
  background:linear-gradient(90deg,#e8eef8 25%,#d0d8ee 50%,#e8eef8 75%);
  background-size:200% 100%;
  animation:shimmer 1.4s infinite;
  border-radius:8px;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Page transitions ────────────────────────────── */
.page-enter{animation:pageIn 0.2s ease both}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── TOPBAR ──────────────────────────────────────── */
.topbar{
  background:var(--card);
  padding:13px 16px;
  display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 1px 0 var(--border);
  position:sticky;top:0;z-index:100;
  /* GPU layer */
  will-change:transform;
  contain:layout style;
}
.topbar-logo{
  font-family:'Nunito',sans-serif;font-weight:900;font-size:1.12rem;
  color:var(--text);cursor:pointer;display:flex;align-items:center;gap:5px;
  user-select:none;
}
.wallet-btn{
  background:var(--accent);color:#fff;border:none;
  border-radius:30px;padding:8px 16px;
  font-weight:700;font-size:0.82rem;
  display:flex;align-items:center;gap:5px;
  box-shadow:0 2px 8px rgba(245,158,11,0.3);
  transition:transform 0.1s,box-shadow 0.1s;
  will-change:transform;
}
.wallet-btn:active{transform:scale(0.95);box-shadow:none}

/* ── CONTENT ─────────────────────────────────────── */
.content{
  padding:14px 14px 100px;
  max-width:500px;margin:0 auto;
  contain:layout;
}

/* ── SECTION TITLE ───────────────────────────────── */
.page-title{
  font-family:'Nunito',sans-serif;font-weight:900;font-size:1.25rem;
  color:var(--text);text-align:center;margin-bottom:14px;
}

/* ── NOTIFICATION BANNER ─────────────────────────── */
.notif-bar{
  background:linear-gradient(135deg,#4f46e5,#7c3aed);
  border-radius:var(--radius-sm);padding:13px 14px;
  display:flex;gap:10px;align-items:flex-start;
  margin-bottom:14px;position:relative;
  contain:layout style;
}
.notif-close{
  position:absolute;top:10px;right:12px;
  background:none;border:none;
  color:rgba(255,255,255,0.65);font-size:0.95rem;
  padding:0;line-height:1;
}

/* ── LikeViews CARD ──────────────────────────────── */
.lv-card{
  background:var(--card);border-radius:var(--radius-sm);
  border:1.5px solid var(--border);padding:14px 15px;
  display:flex;align-items:center;gap:13px;
  margin-bottom:9px;cursor:pointer;
  box-shadow:var(--shadow-card);
  /* Fast active feedback */
  transition:transform 0.1s;
  will-change:transform;
  contain:layout style;
  text-decoration:none;color:var(--text);
}
.lv-card:active{transform:scale(0.97)}
.lv-card-icon{
  width:44px;height:44px;border-radius:13px;
  overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;
}
.lv-card-icon img{width:100%;height:100%;object-fit:cover;border-radius:13px}
.lv-card-name{font-weight:700;font-size:0.92rem;flex:1;color:var(--text)}
.lv-sub{font-size:0.72rem;color:var(--text2);margin-top:2px}
.lv-arrow svg{width:20px;height:20px;stroke:#1a56db;fill:none;stroke-width:2.5;stroke-linecap:round}

/* ── CATEGORIES ──────────────────────────────────── */
.cat-platform-header{
  background:var(--card);border-radius:var(--radius-sm);
  border:1.5px solid var(--border);padding:15px 16px;
  display:flex;align-items:center;gap:14px;margin-bottom:14px;
  box-shadow:var(--shadow-card);
}
.cat-platform-icon{width:50px;height:50px;border-radius:13px;overflow:hidden;flex-shrink:0}
.cat-platform-icon img{width:100%;height:100%;object-fit:cover}
.cat-platform-name{font-weight:800;font-size:1rem;color:var(--text)}
.cat-platform-sub{font-size:0.74rem;color:var(--text2);margin-top:2px}

/* ── SERVICE CARDS ───────────────────────────────── */
.svc-card{
  background:var(--card);border-radius:var(--radius-sm);
  border:1.5px solid var(--border);padding:14px 15px;
  display:flex;align-items:center;gap:12px;
  margin-bottom:9px;cursor:pointer;
  box-shadow:var(--shadow-card);
  transition:transform 0.1s;
  text-decoration:none;color:var(--text);
}
.svc-card:active{transform:scale(0.97)}
.svc-name{font-weight:700;font-size:0.9rem;flex:1}
.svc-price{font-weight:700;font-size:0.88rem;color:var(--primary);white-space:nowrap}

/* ── QTY PACKAGES ────────────────────────────────── */
.qty-card{
  background:var(--card);border:2px solid #fca5a5;
  border-radius:var(--radius-sm);padding:13px 15px;
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:9px;cursor:pointer;transition:all 0.12s;
}
.qty-card.selected{border-color:var(--primary);background:#eff6ff}
.qty-card:active{transform:scale(0.97)}
.qty-card-name{font-weight:700;font-size:0.88rem}
.qty-card-price{font-weight:800;font-size:0.92rem;color:var(--primary)}
.discount-badge{background:var(--red);color:#fff;border-radius:6px;padding:2px 7px;font-size:0.7rem;font-weight:700;margin-right:6px}

/* ── FORM ────────────────────────────────────────── */
.input-group{margin-bottom:13px}
.input-label{display:block;font-size:0.83rem;font-weight:600;margin-bottom:6px}
.input-field{
  width:100%;border:2px solid var(--border);
  border-radius:var(--radius-sm);padding:12px 14px;
  font-size:0.9rem;font-family:var(--font);
  outline:none;background:var(--card);color:var(--text);
  transition:border-color 0.15s;-webkit-appearance:none;
}
.input-field:focus{border-color:var(--primary)}
.input-field::placeholder{color:#9ca3af}

/* ── BUTTONS ─────────────────────────────────────── */
.btn-primary{
  display:block;width:100%;
  background:#1a2340;color:#fff;border:none;
  border-radius:var(--radius-sm);padding:14px;
  font-size:0.92rem;font-weight:700;
  font-family:var(--font);text-align:center;
  letter-spacing:0.3px;transition:transform 0.1s;
  will-change:transform;
}
.btn-primary:active{transform:scale(0.97)}
.btn-outline{
  display:block;width:100%;
  background:#1a2340;color:#fff;border:none;
  border-radius:var(--radius-sm);padding:13px;
  font-size:0.88rem;font-weight:700;
  font-family:var(--font);text-align:center;text-decoration:none;
  transition:transform 0.1s;
}
.btn-outline:active{transform:scale(0.97)}

/* ── ORDER SUCCESS ───────────────────────────────── */
.success-icon{text-align:center;margin:22px 0 10px}
.success-circle{
  width:88px;height:88px;
  background:linear-gradient(135deg,#16a34a,#22c55e);
  border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 12px rgba(22,163,74,0.14);font-size:2.2rem;
  animation:pop 0.4s cubic-bezier(0.175,0.885,0.32,1.275);
}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
.order-created-title{text-align:center;font-family:'Nunito',sans-serif;font-weight:900;font-size:1.45rem;margin-bottom:4px}
.amount-paid{text-align:center;font-size:0.88rem;color:var(--text2);margin-bottom:16px}
.amount-paid span{color:var(--primary);font-weight:800}
.order-detail-card{background:var(--card);border-radius:var(--radius-sm);padding:15px;margin-bottom:11px;box-shadow:var(--shadow-card);border:1.5px solid var(--border)}
.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:0.85rem}
.detail-row:last-child{border:none}
.detail-key{color:var(--text2)}
.detail-val{font-weight:700;text-align:right;max-width:60%;word-break:break-all}
.status-processing{color:var(--accent);font-weight:800}
.order-progress-box{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:var(--radius-sm);padding:13px;margin-bottom:10px}
.action-row{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.redirect-bar{text-align:center;font-size:0.76rem;color:var(--text2);margin-top:12px}

/* ── ORDERS PAGE ─────────────────────────────────── */
.order-card{
  background:var(--card);border-radius:var(--radius-sm);
  border:1.5px solid var(--border);padding:13px;
  margin-bottom:9px;box-shadow:var(--shadow-card);cursor:pointer;
  transition:transform 0.1s;contain:layout style;
}
.order-card:active{transform:scale(0.98)}
.order-card-header{display:flex;align-items:center;gap:11px;margin-bottom:8px}
.order-icon{width:40px;height:40px;border-radius:11px;background:#fee2e2;display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.order-service{font-weight:700;font-size:0.88rem}
.order-id{font-size:0.72rem;color:var(--text2)}
.order-meta{display:flex;justify-content:space-between;align-items:center;font-size:0.78rem;color:var(--text2);margin-top:4px}
.status-badge{border-radius:8px;padding:4px 10px;font-size:0.7rem;font-weight:700}
.s-completed{background:#16a34a;color:#fff}
.s-pending{background:#2563eb;color:#fff}
.s-processing{background:#d97706;color:#fff}
.s-failed{background:var(--red);color:#fff}
.s-cancelled{background:#6b7280;color:#fff}
.s-in_progress{background:#7c3aed;color:#fff}
.order-detail-expanded{background:#f9fafb;border-radius:10px;padding:11px;margin-top:8px;font-size:0.8rem}
.order-link-box{background:#eff6ff;border-radius:8px;padding:7px 10px;color:var(--primary);font-size:0.76rem;word-break:break-all;margin-bottom:7px;display:flex;align-items:center;gap:5px}
.progress-bar-wrap{background:#e5e7eb;border-radius:10px;height:5px;margin:7px 0 3px}
.progress-bar-fill{background:#16a34a;border-radius:10px;height:5px;transition:width 0.6s ease}
.order-again-btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:7px 14px;font-size:0.76rem;font-weight:700;font-family:var(--font);display:flex;align-items:center;gap:4px}

/* ── FILTER TABS ─────────────────────────────────── */
.filter-tabs{display:flex;gap:7px;overflow-x:auto;padding-bottom:6px;margin-bottom:13px;scrollbar-width:none}
.filter-tabs::-webkit-scrollbar{display:none}
.filter-tab{
  background:var(--card);border:1.5px solid var(--border);
  border-radius:24px;padding:7px 15px;font-size:0.76rem;font-weight:600;
  white-space:nowrap;cursor:pointer;font-family:var(--font);
  color:var(--text2);transition:all 0.12s;flex-shrink:0;
}
.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* ── SEARCH BAR ──────────────────────────────────── */
.search-bar{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 13px;display:flex;align-items:center;gap:9px;margin-bottom:11px;box-shadow:var(--shadow-card)}
.search-bar svg{width:17px;height:17px;stroke:var(--text2);fill:none;stroke-width:2;flex-shrink:0}
.search-bar input{border:none;outline:none;font-family:var(--font);font-size:0.85rem;color:var(--text);background:transparent;flex:1}
.search-bar input::placeholder{color:#9ca3af}

/* ── BACK BUTTON ─────────────────────────────────── */
.back-btn{display:flex;align-items:center;gap:6px;font-weight:600;font-size:0.88rem;color:var(--text);cursor:pointer;margin-bottom:13px;width:fit-content;user-select:none}
.back-btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}

/* ── MESSAGES ────────────────────────────────────── */
.success-box{background:#d1fae5;color:#065f46;border-radius:11px;padding:11px 14px;font-size:0.85rem;font-weight:600;margin-bottom:11px}
.error-box{background:#fee2e2;color:#991b1b;border-radius:11px;padding:11px 14px;font-size:0.85rem;font-weight:600;margin-bottom:11px}

/* ── EMPTY STATE ─────────────────────────────────── */
.empty-state{text-align:center;padding:44px 20px}
.empty-state .emoji{font-size:2.8rem;margin-bottom:11px}
.empty-state h3{font-weight:700;font-size:1rem;margin-bottom:5px}
.empty-state p{color:var(--text2);font-size:0.85rem}

/* ── MENU PAGE ───────────────────────────────────── */
.user-id-card{background:var(--bg);border-radius:var(--radius-sm);padding:15px;display:flex;align-items:center;gap:11px;margin-bottom:13px}
.user-avatar-placeholder{font-size:1.8rem}
.user-id-label{font-size:0.68rem;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:0.4px}
.user-id{font-weight:800;font-size:1rem;color:var(--text);margin-top:1px}
.copy-btn{background:var(--card);color:var(--text);border:1.5px solid var(--border);border-radius:9px;padding:6px 13px;font-size:0.76rem;font-weight:700;font-family:var(--font);display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0;transition:all 0.12s}
.copy-btn:active{background:var(--primary);color:#fff;border-color:var(--primary)}
.menu-item{background:var(--card);border-radius:var(--radius-sm);border:1.5px solid var(--border);padding:14px 15px;display:flex;align-items:center;gap:13px;cursor:pointer;box-shadow:var(--shadow-card);transition:transform 0.1s;text-decoration:none;color:var(--text);margin-bottom:9px}
.menu-item:active{transform:scale(0.97)}
.menu-item-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.menu-item-text{font-weight:700;font-size:0.9rem;flex:1}
.menu-item-arrow{color:var(--primary);font-size:1.1rem;font-weight:700}

/* ── ADDFUNDS ────────────────────────────────────── */
.pm-card{background:var(--card);border-radius:var(--radius-sm);border:1.5px solid var(--border);padding:14px 15px;display:flex;align-items:center;gap:12px;margin-bottom:9px;cursor:pointer;box-shadow:var(--shadow-card);transition:transform 0.1s;text-decoration:none;color:var(--text)}
.pm-card:active{transform:scale(0.97)}
.pm-icon{width:40px;height:40px;border-radius:11px;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.pm-name{font-weight:700;font-size:0.9rem}
.pm-sub{font-size:0.72rem;color:var(--text2);margin-top:2px}
.auto-badge{background:#16a34a;color:#fff;border-radius:20px;padding:1px 7px;font-size:0.62rem;font-weight:700;margin-left:4px}
.quick-amts{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:11px}
.quick-amt{background:var(--card);border:1.5px solid var(--border);border-radius:20px;padding:7px 13px;font-size:0.82rem;font-weight:700;cursor:pointer;color:var(--text);font-family:var(--font);transition:all 0.12s}
.quick-amt.sel{background:var(--primary);color:#fff;border-color:var(--primary)}
.amt-wrap{display:flex;align-items:center;border:2px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;background:var(--card);margin-bottom:14px;transition:border 0.15s}
.amt-wrap:focus-within{border-color:var(--primary)}
.amt-symbol{font-weight:800;font-size:0.95rem;color:#374151;margin-right:5px}
.amt-input{border:none;outline:none;font-size:0.95rem;font-family:var(--font);flex:1;background:transparent;font-weight:700}
.pay-btn{display:block;width:100%;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:14px;font-size:0.9rem;font-weight:800;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:7px;transition:transform 0.1s;letter-spacing:0.3px;will-change:transform}
.pay-btn:active{transform:scale(0.97)}
.pay-btn:disabled{opacity:0.6;cursor:not-allowed}
.service-details{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:13px 14px;font-size:0.82rem;color:var(--text2);margin-top:13px;line-height:1.6}
.service-details-title{font-weight:700;color:var(--text);font-size:0.87rem;margin-bottom:5px}
.order-summary{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:var(--radius-sm);padding:13px;margin-top:13px}
.order-summary-title{font-weight:700;font-size:0.88rem;margin-bottom:7px}
.order-summary-row{display:flex;justify-content:space-between;font-size:0.82rem;margin-bottom:3px;color:var(--text2)}
.order-summary-row span:last-child{font-weight:700;color:var(--text)}
.upi-box{background:#f0fdf4;border:1.5px solid #86efac;border-radius:var(--radius-sm);padding:15px;text-align:center;margin-bottom:13px}
.upi-qr-img{width:180px;height:180px;border-radius:11px;margin:9px auto}
.upi-id-row{background:var(--card);border-radius:9px;padding:10px 13px;display:flex;align-items:center;gap:9px;margin:9px 0}
.copy-upi-btn{background:var(--primary);color:#fff;border:none;border-radius:7px;padding:6px 12px;font-size:0.74rem;font-weight:700;font-family:var(--font)}

/* ── QR OVERLAY ──────────────────────────────────── */
#qr-overlay{display:none;position:fixed;inset:0;background:linear-gradient(180deg,#0f172a 0%,#1e1b4b 100%);z-index:900;overflow-y:auto}
.qr-overlay-inner{max-width:420px;margin:0 auto;padding:15px 15px 40px}
.qr-top-row{display:flex;align-items:center;gap:9px;padding:9px 0 15px}
.qr-back-btn{background:rgba(255,255,255,0.1);border:none;color:#fff;border-radius:9px;padding:7px 13px;font-size:0.82rem;font-weight:600;font-family:var(--font)}
.qr-site{color:#fff;font-weight:800;font-size:0.93rem;display:flex;align-items:center;gap:6px}
.qr-verified{width:20px;height:20px;background:#16a34a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.55rem;color:#fff}
.qr-card{background:#fff;border-radius:18px;padding:20px;text-align:center;margin-bottom:11px}
.qr-img{width:190px;height:190px;border-radius:9px}
.qr-scan-label{font-size:0.74rem;color:#6b7280;margin-top:9px}
.qr-upi-apps{display:flex;justify-content:center;gap:13px;margin:12px 0}
.qr-upi-app{display:flex;flex-direction:column;align-items:center;gap:3px}
.qr-upi-app span{font-size:0.63rem;color:rgba(255,255,255,0.55);font-weight:600}
.qr-app-icon{width:42px;height:42px;border-radius:12px;overflow:hidden;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center}
.qr-app-icon img{width:100%;height:100%;object-fit:cover}
.qr-open-btn{display:flex;align-items:center;justify-content:center;gap:7px;background:rgba(255,255,255,0.1);border:1.5px solid rgba(255,255,255,0.18);border-radius:var(--radius-sm);padding:12px;color:#fff;font-weight:700;font-size:0.88rem;width:100%;margin-bottom:9px;font-family:var(--font)}
.qr-info-card{background:rgba(255,255,255,0.07);border-radius:var(--radius-sm);padding:13px;margin-bottom:9px}
.qr-info-row{display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,0.65);font-size:0.82rem;padding:3px 0}
.qr-info-val{color:#fff;font-weight:700}
.qr-amount-big{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.45rem;color:#fff}
.qr-timer-row{display:flex;justify-content:space-between;align-items:center;color:rgba(255,255,255,0.65);font-size:0.82rem;margin-bottom:9px}
.qr-timer-val{color:#fbbf24;font-weight:800;font-size:0.95rem}
.qr-utr-section{background:rgba(255,255,255,0.07);border-radius:var(--radius-sm);padding:13px;margin-bottom:9px}
.qr-utr-title{color:rgba(255,255,255,0.65);font-size:0.76rem;font-weight:700;margin-bottom:7px}
.qr-utr-input{width:100%;background:rgba(255,255,255,0.09);border:1.5px solid rgba(255,255,255,0.18);border-radius:9px;padding:10px 12px;color:#fff;font-size:0.87rem;font-family:var(--font);outline:none}
.qr-utr-input::placeholder{color:rgba(255,255,255,0.35)}
.qr-submit-btn{background:#16a34a;color:#fff;border:none;border-radius:var(--radius-sm);padding:12px;font-size:0.87rem;font-weight:700;width:100%;margin-top:7px;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:6px}
.qr-cancel-btn{background:rgba(255,255,255,0.05);border:1.5px solid rgba(255,255,255,0.12);border-radius:var(--radius-sm);padding:12px;color:rgba(255,255,255,0.65);font-weight:600;font-size:0.85rem;width:100%;margin-top:7px;font-family:var(--font)}
.ssl-note{text-align:center;color:rgba(255,255,255,0.3);font-size:0.7rem;margin-top:11px}

/* ── TRANSACTIONS ────────────────────────────────── */
.tx-row{background:var(--card);border-radius:12px;padding:12px 13px;display:flex;align-items:center;gap:11px;margin-bottom:8px;box-shadow:var(--shadow-card);border:1.5px solid var(--border)}
.tx-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.tx-icon.debit{background:#fee2e2}
.tx-icon.credit{background:#d1fae5}
.tx-info{flex:1;min-width:0}
.tx-desc{font-weight:600;font-size:0.84rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tx-date{font-size:0.71rem;color:var(--text2);margin-top:2px}
.tx-amt{font-weight:800;font-size:0.92rem;white-space:nowrap}
.tx-amt.debit{color:var(--red)}
.tx-amt.credit{color:var(--green)}

/* ── PROFILE ─────────────────────────────────────── */
.profile-hero{background:linear-gradient(135deg,#1a56db 0%,#1344b4 50%,#3b0764 100%);border-radius:18px;padding:26px 18px 22px;text-align:center;margin-bottom:15px;position:relative;overflow:hidden}
.avatar-ring{width:76px;height:76px;border-radius:50%;background:rgba(255,255,255,0.15);border:3px solid rgba(255,255,255,0.35);display:flex;align-items:center;justify-content:center;font-size:2.1rem;margin:0 auto 12px;position:relative}
.avatar-verified{position:absolute;bottom:0;right:0;width:20px;height:20px;background:#16a34a;border-radius:50%;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:0.55rem;color:#fff;font-weight:800}
.profile-name{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.15rem;color:#fff;margin-bottom:4px}
.profile-uid{font-size:0.74rem;color:rgba(255,255,255,0.62);background:rgba(255,255,255,0.1);border-radius:20px;padding:4px 13px;display:inline-block;margin-bottom:14px;font-family:monospace}
.profile-balance{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.9rem;color:#fff;margin-bottom:3px}
.profile-balance-label{font-size:0.7rem;color:rgba(255,255,255,0.58);text-transform:uppercase;letter-spacing:0.7px}
.hero-copy-btn{background:rgba(255,255,255,0.14);border:1.5px solid rgba(255,255,255,0.28);color:#fff;border-radius:20px;padding:6px 16px;font-size:0.76rem;font-weight:700;margin-top:13px;font-family:var(--font);display:inline-flex;align-items:center;gap:5px;transition:background 0.12s}
.hero-copy-btn:active{background:rgba(255,255,255,0.24)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:14px}
.stat-box{background:var(--card);border-radius:13px;border:1.5px solid var(--border);padding:13px 9px;text-align:center;box-shadow:var(--shadow-card)}
.stat-box .s-icon{font-size:1.3rem;margin-bottom:5px}
.stat-box .s-val{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.1rem;color:var(--text);line-height:1}
.stat-box .s-lbl{font-size:0.64rem;color:var(--text2);font-weight:600;margin-top:3px;text-transform:uppercase;letter-spacing:0.4px}
.info-card{background:var(--card);border-radius:14px;border:1.5px solid var(--border);padding:16px;margin-bottom:13px;box-shadow:var(--shadow-card)}
.info-card-title{font-weight:800;font-size:0.86rem;color:var(--text);margin-bottom:13px;display:flex;align-items:center;gap:6px}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid #f1f5f9;font-size:0.82rem}
.info-row:last-child{border:none}
.info-key{color:var(--text2);font-weight:500}
.info-val{font-weight:700;color:var(--text);text-align:right}
.info-val.green{color:var(--green)}
.info-val.blue{color:var(--primary)}
.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:13px}
.action-btn{background:var(--card);border:1.5px solid var(--border);border-radius:13px;padding:13px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;box-shadow:var(--shadow-card);text-decoration:none;transition:transform 0.1s}
.action-btn:active{transform:scale(0.96)}
.action-btn .a-icon{font-size:1.35rem}
.action-btn .a-name{font-size:0.74rem;font-weight:700;color:var(--text)}
.logout-btn{width:100%;background:#fee2e2;border:1.5px solid #fecaca;color:var(--red);border-radius:13px;padding:13px;font-weight:700;font-size:0.88rem;font-family:var(--font);display:flex;align-items:center;justify-content:center;gap:7px;transition:all 0.12s;margin-bottom:9px}
.logout-btn:active{background:#fecaca}

/* ── BOTTOM NAV ──────────────────────────────────── */
.bottomnav{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--card);
  display:flex;align-items:center;justify-content:space-around;
  padding:9px 7px 22px;
  border-top:1px solid var(--border);
  z-index:200;
  /* GPU layer for smooth */
  will-change:transform;
  contain:layout style;
  box-shadow:0 -2px 10px rgba(0,0,0,0.07);
}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;min-width:62px;color:var(--text2);font-size:0.64rem;font-weight:600;transition:color 0.12s;user-select:none}
.nav-item svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nav-item.active{color:var(--primary)}
.nav-center-btn{background:var(--primary);color:#fff;border:none;border-radius:28px;padding:11px 22px;font-family:var(--font);font-weight:700;font-size:0.84rem;white-space:nowrap;box-shadow:0 4px 13px rgba(26,86,219,0.35);transition:transform 0.1s,box-shadow 0.1s;will-change:transform}
.nav-center-btn:active{transform:scale(0.95);box-shadow:none}

/* ── PAGE HEADER ─────────────────────────────────── */
.page-header{background:var(--card);padding:12px 16px;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--border);flex-shrink:0}
.back-btn-hdr{width:34px;height:34px;border-radius:9px;background:var(--bg);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}
.back-btn-hdr svg{width:17px;height:17px;stroke:var(--text);fill:none;stroke-width:2.5;stroke-linecap:round}
.page-header-title{font-weight:800;font-size:0.95rem;color:var(--text)}

/* ── REFER ───────────────────────────────────────── */
.refer-hero{background:linear-gradient(135deg,#f43f5e,#e11d48);border-radius:var(--radius);padding:20px;color:#fff;margin-bottom:13px;text-align:center}
.refer-code-box{background:rgba(255,255,255,0.14);border-radius:11px;padding:13px;margin:11px 0;font-family:'Nunito',sans-serif;font-size:1.4rem;font-weight:900;letter-spacing:3px;border:1.5px dashed rgba(255,255,255,0.45)}
.refer-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-top:9px}
.refer-stat{background:rgba(255,255,255,0.14);border-radius:11px;padding:11px;text-align:center}
.refer-stat .val{font-weight:800;font-size:1.05rem}
.refer-stat .lbl{font-size:0.7rem;opacity:0.78;margin-top:2px}

/* ── WALLET CARD ─────────────────────────────────── */
.wallet-card{background:var(--primary);border-radius:var(--radius);padding:20px;color:#fff;text-align:center;margin-bottom:15px}
.wallet-bal-label{font-size:0.78rem;opacity:0.82}
.wallet-bal{font-family:'Nunito',sans-serif;font-weight:900;font-size:1.9rem;margin-top:3px}

/* ── TOAST ───────────────────────────────────────── */
.toast{position:fixed;bottom:88px;left:50%;transform:translateX(-50%) translateY(16px);background:#1a2340;color:#fff;border-radius:28px;padding:9px 20px;font-size:0.78rem;font-weight:600;opacity:0;transition:all 0.25s;pointer-events:none;z-index:9999;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── WhatsApp FAB ────────────────────────────────── */
.wa-fab{position:fixed;bottom:88px;left:14px;width:50px;height:50px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 13px rgba(37,211,102,0.38);z-index:150;text-decoration:none;transition:transform 0.1s}
.wa-fab:active{transform:scale(0.92)}
.wa-fab img{width:26px;height:26px;border-radius:3px}

/* ── PWA Install Banner ──────────────────────────── */
#pwa-install-bar{
  position:fixed;bottom:76px;left:12px;right:12px;
  background:#1a2340;color:#fff;
  border-radius:16px;padding:13px 16px;
  display:flex;align-items:center;gap:11px;
  box-shadow:0 8px 28px rgba(0,0,0,0.3);
  z-index:8888;
  animation:slideUp 0.35s cubic-bezier(0.175,0.885,0.32,1.275);
  transition:opacity 0.25s,transform 0.25s;
}
#pwa-install-bar.hiding{opacity:0;transform:translateY(20px)}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
.pwa-icon{width:44px;height:44px;border-radius:12px;overflow:hidden;flex-shrink:0;background:var(--primary)}
.pwa-icon img{width:100%;height:100%;object-fit:cover}
.pwa-text{flex:1;min-width:0}
.pwa-title{font-weight:800;font-size:0.88rem}
.pwa-sub{font-size:0.72rem;color:rgba(255,255,255,0.6);margin-top:2px}
.pwa-install-btn{background:#1a56db;color:#fff;border:none;border-radius:10px;padding:9px 16px;font-size:0.8rem;font-weight:800;font-family:var(--font);white-space:nowrap;flex-shrink:0}
.pwa-close{background:none;border:none;color:rgba(255,255,255,0.4);font-size:1.1rem;padding:0;flex-shrink:0;line-height:1}

/* ── Push Notification prompt ────────────────────── */
#notif-prompt-card{
  position:fixed;bottom:76px;left:12px;right:12px;
  background:#0f172a;color:#fff;
  border-radius:16px;padding:14px 16px;
  display:flex;align-items:flex-start;gap:11px;
  box-shadow:0 8px 28px rgba(0,0,0,0.35);
  z-index:8887;
  animation:slideUp 0.35s cubic-bezier(0.175,0.885,0.32,1.275);
  transition:opacity 0.25s,transform 0.25s;
}
#notif-prompt-card.hiding{opacity:0;transform:translateY(20px)}

/* ── NOTIF BAR (admin sent) ──────────────────────── */
.notif-banner{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:var(--radius-sm);padding:13px 14px;display:flex;gap:10px;margin-bottom:13px;position:relative}
.notif-banner-close{position:absolute;top:9px;right:11px;background:none;border:none;color:rgba(255,255,255,0.6);font-size:0.9rem;padding:0}

/* ── RESPONSIVE ──────────────────────────────────── */
@media(max-width:430px){
  .content{padding:12px 12px 95px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms !important;transition-duration:0.01ms !important}
}
