/* ============================================================
   p2psell.com v2.4 - Refined Compact Design
   ============================================================ */

:root {
    --brand-primary: #fcd535;
    --brand-secondary: #f0b90b;
    --brand-gradient: linear-gradient(135deg, #fcd535 0%, #f0b90b 100%);
    
    /* DARK theme - softer for eyes */
    --bg-base: #0f1116;
    --bg-card: #1a1d24;
    --bg-elevated: #20242c;
    --bg-input: #14171d;
    --bg-hover: rgba(252, 213, 53, 0.04);
    --bg-section: #14171d;
    
    --text-primary: #d8dadc;
    --text-secondary: #a8aebb;
    --text-muted: #707683;
    --text-dim: #4a5161;
    
    --border-primary: #252a33;
    --border-bright: #383f4d;
    --border-soft: #1f2329;
    
    --color-success: #14c98c;
    --color-success-bg: rgba(20, 201, 140, 0.1);
    --color-danger: #ed5a7a;
    --color-warning: #f0b90b;
    --color-warning-bg: rgba(240, 185, 11, 0.1);
    --color-info: #51a3e0;
    --color-purple: #9c5dff;
    
    --bkash: #e2136e;
    --nagad: #f97316;
    --rocket: #a855f7;
    --bank: #d9534f;
    
    --toggle-bg: #20242c;
    --toggle-active-bg: #0a0c10;
    --toggle-active-text: #ffffff;
    
    --shadow-card: 0 1px 2px rgba(0, 0, 0, 0.2);
    --shadow-modal: 0 20px 50px rgba(0, 0, 0, 0.5);
    
    --font-base: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, system-ui, sans-serif;
    --font-mono: 'JetBrains Mono', 'Monaco', 'Consolas', monospace;
}

/* LIGHT theme - clean, easy on eyes */
html[data-theme="light"] {
    --bg-base: #f5f5f7;
    --bg-card: #ffffff;
    --bg-elevated: #f5f6f8;
    --bg-input: #f8f9fb;
    --bg-hover: #f5f6f8;
    --bg-section: #f5f5f7;
    
    --text-primary: #1e2329;
    --text-secondary: #474d57;
    --text-muted: #707a8a;
    --text-dim: #b7bdc6;
    
    --border-primary: #ebedef;
    --border-bright: #d6dadf;
    --border-soft: #f0f1f3;
    
    --color-success: #03ad7e;
    --color-success-bg: rgba(3, 173, 126, 0.08);
    --color-danger: #d94c5f;
    --color-warning-bg: rgba(240, 185, 11, 0.08);
    
    --toggle-bg: #f0f1f3;
    --toggle-active-bg: #1e2329;
    --toggle-active-text: #ffffff;
    
    --shadow-card: 0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-modal: 0 20px 50px rgba(0, 0, 0, 0.15);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    background: var(--bg-base);
    color: var(--text-primary);
    font-family: var(--font-base);
    font-size: 13px;
    line-height: 1.5;
    min-height: 100vh;
    transition: background 0.2s, color 0.2s;
    -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; }
input, select, textarea { font-family: inherit; }

.container { max-width: 1280px; margin: 0 auto; padding: 0 12px; }
.mb-1 { margin-bottom: 4px; } .mb-2 { margin-bottom: 8px; } .mb-3 { margin-bottom: 14px; }
.mt-1 { margin-top: 4px; } .mt-2 { margin-top: 8px; } .mt-3 { margin-top: 14px; }
.text-right { text-align: right; }
.flex { display: flex; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-1 { gap: 4px; } .gap-2 { gap: 6px; } .gap-3 { gap: 10px; }
.mono { font-family: var(--font-mono); }

/* ============================================
   TOP HEADER (kept as before)
   ============================================ */
.top-bar { 
    background: var(--bg-card); 
    border-bottom: 1px solid var(--border-primary); 
    position: sticky; top: 0; z-index: 100; 
}
.top-bar-inner { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; gap: 10px; }
.brand { display: flex; align-items: center; gap: 7px; text-decoration: none; }
.brand-icon { width: 26px; height: 26px; fill: var(--brand-primary); }
.brand-name { font-weight: 800; color: var(--brand-primary); font-size: 16px; letter-spacing: -0.5px; line-height: 1; }
.brand-tag { font-size: 6px; color: var(--text-dim); letter-spacing: 2px; margin-top: 2px; }

.rate-ticker { display: flex; gap: 5px; align-items: center; }
.rate-pill { 
    display: flex; align-items: center; gap: 4px; 
    padding: 4px 8px; 
    background: var(--color-warning-bg); 
    border: 1px solid rgba(252, 213, 53, 0.2); 
    border-radius: 5px; 
    font-size: 10px; font-weight: 700; 
    font-family: var(--font-mono); 
}
.rate-pill.sell { color: var(--color-success); border-color: rgba(20, 201, 140, 0.25); background: var(--color-success-bg); }
.rate-pill.buy { color: var(--brand-secondary); }
.rate-pill-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; animation: pulse 1.5s infinite; }
.rate-pill-label { font-size: 6px; opacity: 0.7; text-transform: uppercase; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

.top-right { display: flex; align-items: center; gap: 7px; }
.top-avatar { 
    width: 32px; height: 32px; border-radius: 50%; 
    background: var(--brand-gradient); 
    display: flex; align-items: center; justify-content: center; 
    font-weight: 800; color: #181a20; font-size: 13px; 
    text-decoration: none; position: relative; 
}
.top-avatar-dot { position: absolute; top: 0; right: 0; width: 8px; height: 8px; background: var(--color-danger); border-radius: 50%; border: 2px solid var(--bg-card); }
.login-btn { padding: 5px 11px; color: var(--brand-primary); font-size: 11px; font-weight: 700; border: 1px solid var(--brand-primary); border-radius: 6px; text-decoration: none; }

.theme-toggle {
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    background: var(--bg-elevated);
    border: 1px solid var(--border-primary);
    border-radius: 8px;
    color: var(--text-secondary);
    font-size: 15px;
    cursor: pointer;
    transition: all 0.2s;
}
.theme-toggle:hover { background: var(--bg-hover); color: var(--brand-primary); border-color: var(--brand-primary); }

.menu-btn { 
    width: 36px; height: 32px; 
    display: flex; align-items: center; justify-content: center; 
    background: var(--color-warning-bg); 
    border: 1px solid var(--border-primary); 
    color: var(--brand-primary); 
    font-size: 17px; border-radius: 6px; cursor: pointer; line-height: 1; 
}

/* SLIDE MENU */
#menuOverlay { display: none; position: fixed; inset: 0; background: rgba(0, 0, 0, 0.75); z-index: 9998; backdrop-filter: blur(2px); }
#menuOverlay.show { display: block; }
#slideMenu { 
    position: fixed; top: 0; right: -340px; 
    width: 305px; max-width: 88vw; height: 100vh; 
    background: var(--bg-base); z-index: 9999; overflow-y: auto; 
    transition: right 0.3s ease; 
    box-shadow: -12px 0 40px rgba(0, 0, 0, 0.6); 
}
#slideMenu.show { right: 0; }

.menu-top { padding: 16px; background: linear-gradient(135deg, rgba(252, 213, 53, 0.12), rgba(252, 213, 53, 0.02)); border-bottom: 1px solid var(--border-primary); }
.menu-top-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.menu-brand { display: flex; align-items: center; gap: 7px; text-decoration: none; }
.menu-brand-icon { width: 22px; height: 22px; fill: var(--brand-primary); }
.menu-brand-name { font-weight: 800; color: var(--brand-primary); font-size: 13px; }
.menu-close { width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; background: var(--bg-elevated); color: var(--text-secondary); font-size: 15px; border-radius: 6px; }

.menu-user-card { display: flex; align-items: center; gap: 9px; padding: 9px; background: rgba(252, 213, 53, 0.05); border: 1px solid rgba(252, 213, 53, 0.15); border-radius: 8px; }
.menu-user-av { width: 38px; height: 38px; border-radius: 50%; background: var(--brand-gradient); display: flex; align-items: center; justify-content: center; font-weight: 800; color: #181a20; font-size: 14px; }
.menu-user-info { flex: 1; min-width: 0; }
.menu-user-name { color: var(--text-primary); font-size: 12px; font-weight: 700; }
.menu-user-email { color: var(--text-muted); font-size: 9px; margin-top: 1px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.menu-vip { background: var(--brand-gradient); color: #181a20; padding: 1px 5px; border-radius: 3px; font-size: 7px; font-weight: 800; }

.menu-guest { padding: 12px; text-align: center; }
.menu-guest-icon { font-size: 32px; margin-bottom: 5px; }
.menu-guest-text { color: var(--text-secondary); font-size: 11px; margin-bottom: 10px; }
.menu-guest-btns { display: flex; gap: 7px; }
.menu-guest-btns a { flex: 1; padding: 7px; border-radius: 6px; font-size: 10px; font-weight: 700; text-align: center; text-decoration: none; }

.menu-quick { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; padding: 12px 14px; border-bottom: 1px solid var(--border-primary); }
.menu-quick-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 10px 5px; border-radius: 10px; text-decoration: none; font-size: 10px; font-weight: 700; transition: transform 0.15s; }
.menu-quick-btn:active { transform: scale(0.97); }
.menu-quick-btn.sell { background: linear-gradient(135deg, var(--color-success), #0fa970); color: #fff; }
.menu-quick-btn.buy { background: var(--brand-gradient); color: #181a20; }
.menu-quick-btn-icon { font-size: 16px; }
.menu-quick-btn-rate { font-size: 7px; opacity: 0.85; font-family: monospace; }

.menu-section { padding: 5px 0; }
.menu-section-title { font-size: 7px; color: var(--text-dim); text-transform: uppercase; letter-spacing: 1.8px; font-weight: 800; padding: 11px 14px 4px; }

.menu-link { display: flex; align-items: center; gap: 11px; padding: 10px 14px; color: var(--text-secondary); font-size: 11px; font-weight: 600; text-decoration: none; transition: all 0.15s; position: relative; }
.menu-link:hover, .menu-link:active { background: var(--bg-hover); color: var(--brand-primary); }
.menu-link.active { background: var(--color-warning-bg); color: var(--brand-primary); }
.menu-link.active::before { content: ''; position: absolute; left: 0; top: 8px; bottom: 8px; width: 3px; background: var(--brand-primary); border-radius: 0 3px 3px 0; }
.menu-link.danger { color: var(--color-danger); }
.menu-link.danger:hover { background: rgba(237, 90, 122, 0.08); }
.menu-icon { width: 30px; height: 30px; border-radius: 8px; background: var(--color-warning-bg); display: flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }
.menu-link.danger .menu-icon { background: rgba(237, 90, 122, 0.08); }
.menu-link-text { flex: 1; }
.menu-link-sub { font-size: 8px; color: var(--text-dim); font-weight: 500; margin-top: 1px; }
.menu-link-arrow { color: var(--text-dim); font-size: 12px; }
.menu-badge { background: var(--color-danger); color: #fff; padding: 2px 6px; border-radius: 10px; font-size: 8px; font-weight: 800; }
.menu-divider { height: 1px; background: var(--border-primary); margin: 5px 0; }
.menu-footer { padding: 16px; margin-top: 8px; border-top: 1px solid var(--border-primary); }
.menu-footer-version { text-align: center; font-size: 8px; color: var(--text-dim); }
body.menu-open { overflow: hidden; }

/* MARQUEE */
.marquee-bar { background: var(--bg-elevated); border-bottom: 1px solid var(--border-primary); display: flex; align-items: center; overflow: hidden; height: 28px; }
.marquee-label { background: var(--brand-gradient); color: #181a20; padding: 4px 10px; font-size: 8px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; display: flex; align-items: center; gap: 5px; flex-shrink: 0; }
.marquee-label-dot { width: 5px; height: 5px; background: #181a20; border-radius: 50%; animation: pulse 1.5s infinite; }
.marquee-content { flex: 1; overflow: hidden; }
.marquee-track { display: flex; animation: marquee linear infinite; gap: 28px; padding: 0 14px; white-space: nowrap; }
.marquee-item { display: inline-flex; align-items: center; gap: 5px; font-size: 10px; color: var(--text-secondary); }
.marquee-item.promo { color: var(--brand-primary); }
.marquee-item.urgent { color: var(--color-danger); }
.marquee-item.success { color: var(--color-success); }
@keyframes marquee { from { transform: translateX(0) } to { transform: translateX(-50%) } }

/* ============================================
   P2P FILTER BAR (Binance-style)
   ============================================ */
.p2p-filter-bar {
    background: var(--bg-card);
    padding: 12px 0 0;
}
.p2p-filter-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    gap: 10px;
}

.bs-toggle {
    display: inline-flex;
    background: var(--toggle-bg);
    border-radius: 30px;
    padding: 3px;
}
.bs-toggle-btn {
    padding: 7px 22px;
    border-radius: 30px;
    background: transparent;
    color: var(--text-secondary);
    font-weight: 700;
    font-size: 13px;
    text-decoration: none;
    line-height: 1;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.bs-toggle-btn.active {
    background: var(--toggle-active-bg);
    color: var(--toggle-active-text);
}

.currency-dropdown {
    padding: 6px 12px;
    background: transparent;
    border: 1px solid var(--border-bright);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 12px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
}

.p2p-filter-row {
    display: flex;
    gap: 14px;
    align-items: center;
    padding-bottom: 12px;
    position: relative;
}

/* Custom dropdown wrapper */
.filter-dd-wrap {
    position: relative;
}
.p2p-filter-item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: var(--text-primary);
    font-weight: 600;
    cursor: pointer;
    background: transparent;
    border: none;
    text-decoration: none;
    padding: 4px 0;
}
.p2p-filter-item.usdt-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.usdt-icon {
    width: 20px; height: 20px;
    background: #26a17b;
    color: #fff;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    font-family: serif;
}
.dropdown-arrow {
    color: var(--text-muted);
    font-size: 9px;
    margin-left: 2px;
    transition: transform 0.2s;
}
.filter-dd-wrap.open .dropdown-arrow {
    transform: rotate(180deg);
}
.p2p-filter-spacer { flex: 1; }
.p2p-filter-icon-btn {
    width: 28px; height: 28px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--brand-secondary);
    background: transparent;
    border: none;
    cursor: pointer;
}

/* Dropdown menu */
.filter-dd-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--bg-card);
    border: 1px solid var(--border-primary);
    border-radius: 8px;
    box-shadow: var(--shadow-modal);
    z-index: 50;
    min-width: 160px;
    margin-top: 6px;
    overflow: hidden;
}
.filter-dd-wrap.open .filter-dd-menu { display: block; }
.filter-dd-item {
    padding: 10px 14px;
    color: var(--text-primary);
    font-size: 12px;
    cursor: pointer;
    transition: background 0.15s;
    display: flex;
    align-items: center;
    gap: 8px;
}
.filter-dd-item:hover { background: var(--bg-hover); color: var(--brand-primary); }
.filter-dd-item.active { color: var(--brand-primary); background: var(--color-warning-bg); }
.filter-dd-item .check { margin-left: auto; color: var(--brand-primary); font-size: 12px; opacity: 0; }
.filter-dd-item.active .check { opacity: 1; }

/* ============================================
   ★ POSTS LIST — Compact List View
   ============================================ */
.posts-section {
    background: var(--bg-section);
    padding: 12px 0 80px;
    min-height: 60vh;
}

.promoted-label {
    padding: 4px 0 10px;
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
}

/* Card */
.p2p-card {
    background: var(--bg-card);
    border-radius: 10px;
    padding: 12px 14px;
    box-shadow: var(--shadow-card);
}
.p2p-card.promoted {
    margin-bottom: 12px;
}

/* Group container for non-promoted */
.p2p-list-divided {
    background: var(--bg-card);
    border-radius: 10px;
    overflow: hidden;
}
.p2p-list-divided > .p2p-card {
    border-radius: 0;
    box-shadow: none;
    padding: 11px 14px;
}
.p2p-list-divided > .p2p-card:not(:last-child) {
    border-bottom: 1px solid var(--border-soft);
}

/* Top row: avatar + name + verified */
.p2p-card-top {
    display: flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 4px;
}
.p2p-avatar {
    width: 26px; height: 26px;
    border-radius: 50%;
    background: #1e2329;
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 12px;
    position: relative;
    flex-shrink: 0;
}
.p2p-avatar.c-1 { background: #1e2329; color: #fff; }
.p2p-avatar.c-2 { background: #f4a261; color: #fff; }
.p2p-avatar.c-3 { background: #5b6175; color: #fff; }
.p2p-avatar.c-4 { background: #6dd49a; color: #fff; }
.p2p-avatar.c-5 { background: #6b7eb8; color: #fff; }
.p2p-avatar.c-6 { background: #b8336a; color: #fff; }
.p2p-avatar.c-7 { background: #e9b855; color: #1e2329; }
.p2p-avatar-online {
    position: absolute;
    bottom: -1px; right: -1px;
    width: 8px; height: 8px;
    background: var(--color-success);
    border-radius: 50%;
    border: 2px solid var(--bg-card);
}
.p2p-merchant-name {
    font-size: 13px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.p2p-verified-icon {
    color: var(--brand-secondary);
    font-size: 11px;
    margin-left: 3px;
}

/* Stats row — animated trade count */
.p2p-stats-row {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    color: var(--text-muted);
    margin-bottom: 8px;
    padding-left: 35px;
    flex-wrap: wrap;
}
.p2p-stats-trade {
    color: var(--text-muted);
    text-decoration: none;
    border-bottom: 1px dotted var(--text-dim);
}
.p2p-stats-trade strong {
    font-weight: 600;
    color: var(--text-muted);
}
.p2p-stats-sep { color: var(--text-dim); }
.p2p-stats-like {
    display: inline-flex;
    align-items: center;
    gap: 3px;
}

/* Body: price+info on left, payment+button on right */
.p2p-card-body {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 14px;
}
.p2p-card-left {
    flex: 1;
    min-width: 0;
}

/* Price */
.p2p-price-row {
    display: flex;
    align-items: baseline;
    gap: 5px;
    margin-bottom: 7px;
}
.p2p-price-tk {
    font-size: 12px;
    color: var(--text-primary);
    font-weight: 500;
}
.p2p-price-value {
    font-size: 23px;
    font-weight: 800;
    color: var(--text-primary);
    line-height: 1;
    letter-spacing: -0.5px;
}
.p2p-price-unit {
    font-size: 11px;
    color: var(--text-muted);
}

/* Limit & Available */
.p2p-info-line {
    font-size: 11px;
    color: var(--text-primary);
    margin-bottom: 3px;
    line-height: 1.4;
}
.p2p-info-label {
    color: var(--text-muted);
    margin-right: 5px;
    font-size: 11px;
}
.p2p-info-value {
    color: var(--text-primary);
}

/* Right column */
.p2p-card-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: space-between;
    min-height: 84px;
    gap: 5px;
}
.p2p-payment-list {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
}
.p2p-payment {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    color: var(--text-primary);
    font-weight: 500;
}
.p2p-payment-bar {
    width: 3px;
    height: 12px;
    border-radius: 2px;
    display: inline-block;
}
.p2p-payment-bar.bkash { background: var(--bkash); }
.p2p-payment-bar.nagad { background: var(--nagad); }
.p2p-payment-bar.rocket { background: var(--rocket); }
.p2p-payment-bar.bank { background: var(--bank); }

.p2p-time {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    color: var(--text-muted);
}

/* Action button - reduced height */
.p2p-action-btn {
    padding: 7px 22px;
    color: #fff;
    border: none;
    border-radius: 5px;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 92px;
    transition: all 0.2s;
    margin-top: 2px;
}
.p2p-action-btn.buy { background: var(--color-success); }
.p2p-action-btn.buy:hover { background: #11a877; transform: translateY(-1px); }
.p2p-action-btn.sell { background: var(--color-danger); }
.p2p-action-btn.sell:hover { background: #d44c69; transform: translateY(-1px); }

/* ============================================
   FLOATING BOTTOM NAV
   ============================================ */
.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0; right: 0;
    background: var(--bg-card);
    border-top: 1px solid var(--border-primary);
    display: none;
    z-index: 99;
    padding: 6px 0 12px;
}
.bottom-nav-inner {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    max-width: 600px;
    margin: 0 auto;
}
.bn-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    padding: 4px;
    text-decoration: none;
    color: var(--text-muted);
    transition: color 0.2s;
    position: relative;
}
.bn-item-icon {
    height: 24px;
    display: flex; align-items: center; justify-content: center;
}
.bn-item-icon svg {
    width: 22px; height: 22px;
    fill: currentColor;
}
.bn-item-label {
    font-size: 10px;
    font-weight: 600;
}
.bn-item.active {
    color: var(--text-primary);
}
.bn-item.active .bn-item-icon { color: var(--text-primary); }
.bn-item-badge {
    position: absolute;
    top: 0;
    right: 14%;
    background: var(--brand-primary);
    color: #181a20;
    font-size: 8px;
    font-weight: 800;
    padding: 1px 5px;
    border-radius: 8px;
    line-height: 1.3;
    min-width: 14px;
    text-align: center;
}

@media (max-width: 1024px) {
    .bottom-nav { display: block; }
    body { padding-bottom: 76px; }
}

/* ============================================
   BEAUTIFUL CONFIRMATION MODAL
   ============================================ */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    padding: 16px;
    backdrop-filter: blur(4px);
    animation: fadeIn 0.2s ease;
}
.modal-overlay.show { display: flex; }
.modal-box {
    background: var(--bg-card);
    border: 1px solid var(--border-primary);
    border-radius: 14px;
    box-shadow: var(--shadow-modal);
    max-width: 380px;
    width: 100%;
    overflow: hidden;
    animation: slideUp 0.25s ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(20px) scale(0.95); } to { opacity: 1; transform: translateY(0) scale(1); } }

.modal-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    margin: 22px auto 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
}
.modal-icon.warning { background: var(--color-warning-bg); color: var(--brand-primary); }
.modal-icon.danger { background: rgba(237, 90, 122, 0.1); color: var(--color-danger); }
.modal-icon.success { background: var(--color-success-bg); color: var(--color-success); }
.modal-icon.info { background: rgba(81, 163, 224, 0.1); color: var(--color-info); }

.modal-title {
    text-align: center;
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
    padding: 0 22px 6px;
}
.modal-message {
    text-align: center;
    font-size: 12px;
    color: var(--text-secondary);
    padding: 0 22px 18px;
    line-height: 1.6;
}
.modal-actions {
    display: flex;
    gap: 8px;
    padding: 14px;
    border-top: 1px solid var(--border-primary);
    background: var(--bg-elevated);
}
.modal-btn {
    flex: 1;
    padding: 10px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    border: none;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
}
.modal-btn.cancel { background: var(--bg-card); color: var(--text-secondary); border: 1px solid var(--border-bright); }
.modal-btn.cancel:hover { color: var(--text-primary); }
.modal-btn.confirm { background: var(--color-danger); color: #fff; }
.modal-btn.confirm:hover { background: #d44c69; }
.modal-btn.confirm.success { background: var(--color-success); }
.modal-btn.confirm.success:hover { background: #11a877; }
.modal-btn.confirm.warning { background: var(--brand-gradient); color: #181a20; }

/* ============================================
   Cards / Common
   ============================================ */
.card { background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 10px; overflow: hidden; margin-bottom: 12px; }
.card-header { padding: 11px 13px; border-bottom: 1px solid var(--border-primary); display: flex; justify-content: space-between; align-items: center; }
.card-title { font-size: 11px; font-weight: 700; color: var(--text-primary); display: flex; align-items: center; gap: 6px; }
.card-body { padding: 13px; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 7px 13px; border: 1px solid transparent; border-radius: 6px; font-size: 11px; font-weight: 700; cursor: pointer; transition: all 0.2s; text-decoration: none; background: transparent; color: var(--text-primary); line-height: 1.2; }
.btn:hover { transform: translateY(-1px); }
.btn-xs { padding: 4px 8px; font-size: 9px; }
.btn-sm { padding: 5px 11px; font-size: 10px; }
.btn-lg { padding: 10px 20px; font-size: 12px; }
.btn-full { width: 100%; }
.btn-primary { background: var(--brand-gradient); color: #181a20; box-shadow: 0 4px 12px rgba(252, 213, 53, 0.3); }
.btn-success { background: var(--color-success); color: #fff; }
.btn-success:hover { background: #11a877; }
.btn-danger { background: var(--color-danger); color: #fff; }
.btn-secondary { background: var(--bg-elevated); border-color: var(--border-bright); color: var(--text-primary); }
.btn-ghost { background: var(--bg-elevated); color: var(--text-secondary); }
.btn-ghost:hover { color: var(--brand-primary); background: var(--bg-hover); }

/* Forms */
.form-group { margin-bottom: 11px; }
.form-label { display: block; font-size: 9px; color: var(--text-muted); margin-bottom: 4px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; }
.form-input { width: 100%; padding: 8px 12px; background: var(--bg-input); border: 1px solid var(--border-primary); border-radius: 6px; color: var(--text-primary); font-size: 12px; font-family: inherit; }
.form-input:focus { outline: none; border-color: var(--brand-primary); box-shadow: 0 0 0 3px rgba(252, 213, 53, 0.1); }
.form-input.mono { font-family: var(--font-mono); }
.form-help { font-size: 9px; color: var(--text-muted); margin-top: 3px; }

/* Auth */
.auth-container { display: flex; justify-content: center; padding: 32px 14px; }
.auth-card { width: 100%; max-width: 380px; background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 12px; padding: 24px; }
.auth-header { text-align: center; margin-bottom: 18px; }
.auth-title { font-size: 19px; font-weight: 800; color: var(--text-primary); }
.auth-subtitle { font-size: 11px; color: var(--text-muted); margin-top: 4px; }
.auth-footer { text-align: center; font-size: 11px; color: var(--text-muted); margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border-primary); }
.auth-footer a { color: var(--brand-primary); font-weight: 700; }

/* Badges */
.badge-status, .badge { display: inline-block; padding: 2px 7px; font-size: 8px; font-weight: 800; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.5px; border: 1px solid; }
.badge-success { color: var(--color-success); border-color: var(--color-success); background: var(--color-success-bg); }
.badge-warning { color: var(--brand-primary); border-color: var(--brand-primary); background: var(--color-warning-bg); }
.badge-danger { color: var(--color-danger); border-color: var(--color-danger); background: rgba(237, 90, 122, 0.08); }
.badge-info { color: var(--color-info); border-color: var(--color-info); background: rgba(81, 163, 224, 0.08); }
.badge-secondary { color: var(--text-secondary); border-color: var(--border-bright); background: var(--bg-elevated); }

.pay-badge { display: inline-block; padding: 2px 6px; font-size: 8px; font-weight: 700; border-radius: 4px; border: 1px solid; }
.pay-bkash { color: var(--bkash); border-color: var(--bkash); background: rgba(226, 19, 110, 0.06); }
.pay-nagad { color: var(--nagad); border-color: var(--nagad); background: rgba(249, 115, 22, 0.06); }
.pay-rocket { color: var(--rocket); border-color: var(--rocket); background: rgba(168, 85, 247, 0.06); }

/* Alerts */
.alert { padding: 11px 13px; border-radius: 8px; border: 1px solid; font-size: 11px; margin-bottom: 11px; }
.alert-success { background: var(--color-success-bg); border-color: var(--color-success); color: var(--color-success); }
.alert-danger, .alert-error { background: rgba(237, 90, 122, 0.08); border-color: var(--color-danger); color: var(--color-danger); }
.alert-warning { background: var(--color-warning-bg); border-color: var(--brand-primary); color: var(--brand-primary); }
.alert-info { background: rgba(81, 163, 224, 0.08); border-color: var(--color-info); color: var(--color-info); }

/* Dashboard */
.page-section { padding: 14px 0; }
.page-header { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: 11px; margin-bottom: 12px; }
.page-title { font-size: 19px; font-weight: 800; color: var(--text-primary); letter-spacing: -0.5px; }
.page-subtitle { font-size: 11px; color: var(--text-muted); display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }

.dashboard { display: grid; grid-template-columns: 210px 1fr; gap: 14px; padding: 18px 0; }
.dashboard-content { min-width: 0; }
.dashboard-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 11px; margin-bottom: 14px; }

.stat-card { background: var(--bg-card); border: 1px solid var(--border-primary); border-left: 3px solid var(--brand-primary); border-radius: 8px; padding: 12px; }
.stat-card.stat-success { border-left-color: var(--color-success); }
.stat-card.stat-warning { border-left-color: var(--brand-primary); }
.stat-card.stat-purple { border-left-color: var(--color-purple); }
.stat-card-label { font-size: 8px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1.5px; font-weight: 700; }
.stat-card-value { font-size: 21px; font-weight: 800; color: var(--text-primary); margin: 4px 0; }
.stat-card-meta { font-size: 9px; color: var(--text-muted); }

.admin-sidebar { background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 10px; padding: 12px 0; height: fit-content; position: sticky; top: 56px; }
.admin-sidebar-header { padding: 0 14px 11px; border-bottom: 1px solid var(--border-primary); margin-bottom: 8px; }
.admin-sidebar-section { padding: 5px 0; }
.admin-sidebar-title { font-size: 7px; color: var(--text-dim); padding: 7px 14px 4px; font-weight: 800; letter-spacing: 1.5px; }
.admin-sidebar-link { display: flex; align-items: center; gap: 7px; padding: 7px 14px; color: var(--text-secondary); font-size: 10px; font-weight: 600; transition: all 0.2s; text-decoration: none; }
.admin-sidebar-link:hover { background: var(--bg-hover); color: var(--brand-primary); }
.admin-sidebar-link.active { background: var(--bg-hover); color: var(--brand-primary); border-left: 2px solid var(--brand-primary); padding-left: 12px; }
.sidebar-badge { background: var(--color-danger); color: #fff; padding: 1px 5px; border-radius: 8px; font-size: 7px; font-weight: 800; margin-left: auto; }

.data-table { background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 10px; overflow: hidden; margin-bottom: 11px; }
.data-table-header { display: grid; gap: 9px; padding: 9px 13px; background: var(--bg-elevated); border-bottom: 1px solid var(--border-primary); font-size: 8px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; }
.data-table-row { display: grid; gap: 9px; padding: 11px 13px; border-bottom: 1px solid var(--border-primary); align-items: center; font-size: 10px; }
.data-table-row:hover { background: var(--bg-hover); }
.data-table-row:last-child { border-bottom: none; }

.pagination { display: flex; justify-content: space-between; align-items: center; padding: 11px 0; flex-wrap: wrap; gap: 7px; }
.pagination-info { font-size: 10px; color: var(--text-muted); }
.pagination-controls { display: flex; gap: 4px; }
.page-btn { min-width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center; background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 5px; color: var(--text-secondary); font-size: 10px; font-weight: 600; padding: 0 7px; text-decoration: none; }
.page-btn:hover:not(.disabled) { border-color: var(--brand-primary); color: var(--text-primary); }
.page-btn.active { background: var(--brand-gradient); border-color: var(--brand-primary); color: #181a20; }
.page-btn.disabled { opacity: 0.4; pointer-events: none; }

.filter-bar { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; margin-bottom: 12px; padding-bottom: 9px; border-bottom: 1px solid var(--border-primary); }
.pill { padding: 4px 10px; background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 16px; font-size: 9px; font-weight: 600; color: var(--text-secondary); cursor: pointer; text-decoration: none; }
.pill:hover { border-color: var(--brand-primary); color: var(--text-primary); }
.pill.active { background: var(--brand-gradient); border-color: var(--brand-primary); color: #181a20; }

.order-summary { background: linear-gradient(135deg, rgba(252, 213, 53, 0.05), var(--bg-card)); border: 1px solid var(--border-primary); border-radius: 10px; padding: 13px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; flex-wrap: wrap; gap: 11px; }
.order-summary-left { display: flex; align-items: center; gap: 11px; }
.order-summary-icon { font-size: 22px; }
.order-summary-title { font-size: 11px; font-weight: 700; color: var(--text-primary); }
.order-summary-meta { font-size: 9px; color: var(--text-muted); margin-top: 2px; }
.order-summary-amount-label { font-size: 8px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1.5px; font-weight: 700; }
.order-summary-amount { font-size: 20px; color: var(--color-success); font-weight: 800; margin-top: 2px; }
.tx-detail-card { max-width: 800px; margin: 0 auto; }

.empty-state { padding: 36px 14px; text-align: center; }
.empty-state-icon { font-size: 32px; margin-bottom: 9px; }
.empty-state-title { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 5px; }
.empty-state-text { font-size: 10px; color: var(--text-muted); }

.payment-picker { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 7px; }
.payment-option { padding: 9px 4px; border-radius: 8px; text-align: center; cursor: pointer; border: 1.5px solid var(--border-primary); background: var(--bg-input); position: relative; }
.payment-option:hover { border-color: var(--brand-primary); }
.payment-option.selected { background: rgba(252, 213, 53, 0.1); border-color: var(--brand-primary); }
.payment-option .check-icon { position: absolute; top: 3px; right: 3px; width: 13px; height: 13px; border-radius: 50%; background: var(--brand-primary); color: #181a20; font-size: 8px; display: none; align-items: center; justify-content: center; font-weight: 800; }
.payment-option.selected .check-icon { display: flex; }
.payment-option-name { font-size: 10px; font-weight: 700; }
.payment-option-sub { font-size: 7px; color: var(--text-muted); margin-top: 2px; }

/* ============================================
   FOOTER (Beautiful redesign)
   ============================================ */
.site-footer { 
    background: var(--bg-card); 
    border-top: 1px solid var(--border-primary); 
    margin-top: 28px; 
    padding: 24px 0 18px; 
}
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 26px;
    margin-bottom: 18px;
}
.footer-brand-section { max-width: 280px; }
.footer-logo-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}
.footer-logo-icon {
    width: 26px; height: 26px;
    fill: var(--brand-primary);
}
.footer-logo-text {
    font-weight: 800; color: var(--brand-primary); font-size: 17px; letter-spacing: -0.5px;
}
.footer-logo-tag {
    font-size: 6px; color: var(--text-dim); letter-spacing: 2px;
}
.footer-tagline {
    color: var(--text-muted);
    font-size: 11px;
    line-height: 1.7;
    margin-bottom: 12px;
}
.footer-socials {
    display: flex;
    gap: 7px;
    margin-bottom: 12px;
}
.footer-social {
    width: 32px; height: 32px;
    border-radius: 8px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    text-decoration: none;
    transition: all 0.2s;
    color: var(--text-secondary);
}
.footer-social:hover {
    background: var(--color-warning-bg);
    border-color: var(--brand-primary);
    color: var(--brand-primary);
    transform: translateY(-2px);
}
.footer-stats {
    display: flex;
    gap: 14px;
    padding: 10px;
    background: var(--bg-elevated);
    border-radius: 8px;
    border: 1px solid var(--border-primary);
}
.footer-stat { flex: 1; }
.footer-stat-num {
    font-size: 14px;
    font-weight: 800;
    color: var(--brand-primary);
}
.footer-stat-label {
    font-size: 8px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 2px;
    font-weight: 700;
}

.footer-col-title {
    font-size: 11px;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 11px;
    letter-spacing: 0.3px;
}
.footer-col-list { list-style: none; padding: 0; }
.footer-col-list li { margin-bottom: 7px; }
.footer-col-list a {
    color: var(--text-secondary);
    font-size: 11px;
    text-decoration: none;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.footer-col-list a:hover { color: var(--brand-primary); }

.footer-payment-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    margin-top: 9px;
}
.footer-payment-chip {
    padding: 4px 8px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-primary);
    border-radius: 5px;
    font-size: 9px;
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.footer-payment-chip-dot {
    width: 5px; height: 5px;
    border-radius: 50%;
}

.footer-bottom {
    padding-top: 16px;
    border-top: 1px solid var(--border-primary);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 10px;
    color: var(--text-muted);
}
.footer-bottom a { color: var(--text-secondary); }
.footer-bottom a:hover { color: var(--brand-primary); }
.footer-trust-badges {
    display: flex;
    gap: 8px;
}
.footer-trust-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    color: var(--text-secondary);
}

/* Responsive */
@media (max-width: 1024px) {
    .dashboard { grid-template-columns: 1fr; }
    .admin-sidebar { position: static; }
    .dashboard-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .footer-brand-section { grid-column: 1 / -1; max-width: none; }
}

@media (max-width: 768px) {
    .container { padding: 0 12px; }
    .p2p-price-value { font-size: 21px; }
    .brand-tag { display: none; }
    .rate-pill-label { display: none; }
    .rate-pill { padding: 3px 7px; font-size: 9px; }
    .p2p-stats-row { padding-left: 0; font-size: 10px; }
    .footer-grid { grid-template-columns: 1fr; gap: 18px; }
    .footer-bottom { flex-direction: column; text-align: center; }
}

@media (max-width: 480px) {
    .dashboard-grid { grid-template-columns: 1fr 1fr; }
    .p2p-action-btn { padding: 6px 16px; font-size: 12px; min-width: 76px; }
    .p2p-card { padding: 10px 12px; }
    .p2p-list-divided > .p2p-card { padding: 10px 12px; }
    .p2p-price-value { font-size: 20px; }
}
