/* ═══════════════════════════════════════════
   THE GOLDEN BEAN — Global Styles
   ═══════════════════════════════════════════ */

/* ── Theme Variables ─────────────────────── */
:root {
    --accent:         #F5C518;
    --accent-dark:    #000;
    --accent-bg:      rgba(245,197,24,0.08);
    --bg:             #0D0D0D;
    --bg-surface:     #161616;
    --bg-mid:         #1A1A1A;
    --text-primary:   #ffffff;
    --text-secondary: #888888;
    --border-color:   #2A2A2A;
    --sidebar-w:      240px;
    --font:           system-ui,-apple-system,'Segoe UI',sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{
    height:100%;
    background:var(--bg);
    font-family:var(--font);
    color:#fff;
}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#111}
::-webkit-scrollbar-thumb{background:#2A2A2A;border-radius:3px}
input,select,button,textarea{font-family:inherit}
select option{background:#1A1A1A;color:#fff}

/* ── Animations ──────────────────────────── */
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.fade{animation:fadeIn .22s ease forwards}

/* ══════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════ */
#app{display:flex;min-height:100vh}
#sidebar{
    width:var(--sidebar-w);
    background:var(--bg-surface);
    border-right:1px solid #1E1E1E;
    display:flex;flex-direction:column;
    position:fixed;height:100vh;z-index:100;
    transition:transform .25s ease;
}
#main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .25s ease;}
#topbar{height:64px;background:var(--bg-surface);border-bottom:1px solid #1E1E1E;display:flex;align-items:center;padding:0 24px;gap:14px;position:sticky;top:0;z-index:50;}
#content{flex:1;padding:28px;overflow-y:auto}

#menu-toggle{display:none;background:transparent;border:none;color:#aaa;font-size:22px;cursor:pointer;padding:6px;border-radius:8px;line-height:1;}
#menu-toggle:hover{background:#1A1A1A;color:#fff}
#sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:90;backdrop-filter:blur(2px);}
#sidebar-overlay.show{display:block}

/* ── Sidebar ─────────────────────────────── */
.s-logo{padding:20px 16px;border-bottom:1px solid #1E1E1E;display:flex;align-items:center;gap:12px}
.s-logo-icon{
    width:40px;height:40px;
    background:var(--accent);
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    font-size:18px;flex-shrink:0;
    overflow:hidden; /* so logo img fits */
}
.s-logo-icon img{width:100%;height:100%;object-fit:cover;border-radius:10px}
.s-logo-name{font-size:14px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#snav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:3px}
.nitem{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;cursor:pointer;color:#666;font-size:13px;font-weight:400;transition:all .15s;border:none;background:transparent;width:100%;text-align:left}
.nitem:hover{background:#1A1A1A;color:#ccc}
.nitem.on{background:var(--accent);color:var(--accent-dark);font-weight:700}
.s-bot{padding:14px 10px;border-top:1px solid #1E1E1E;display:flex;flex-direction:column;gap:8px}
.s-status{background:#1A1A1A;border-radius:9px;padding:10px 14px}
.s-status-lbl{font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.1em;margin-bottom:5px}
.dot-green{width:7px;height:7px;border-radius:50%;background:#4ADE80;display:inline-block;box-shadow:0 0 6px #4ADE80;margin-right:6px}
.sup-btn{background:var(--accent);color:var(--accent-dark);border:none;border-radius:10px;padding:10px;font-weight:700;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:8px;justify-content:center;transition:opacity .15s}
.sup-btn:hover{opacity:.9}

/* ── Topbar ──────────────────────────────── */
.t-search{flex:1;background:#1A1A1A;border:1px solid #222;border-radius:10px;padding:9px 14px;display:flex;align-items:center;gap:10px}
.t-search input{background:transparent;border:none;color:#fff;font-size:13px;outline:none;flex:1;font-family:inherit}
.t-notif{background:transparent;border:none;color:#777;cursor:pointer;font-size:18px;position:relative;padding:6px;display:flex;align-items:center}
.t-ndot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid #111}
.t-div{height:32px;width:1px;background:#2A2A2A}
.t-user{display:flex;align-items:center;gap:10px;cursor:pointer}
.notif-drop{position:absolute;right:0;top:42px;background:#161616;border:1px solid #2A2A2A;border-radius:12px;padding:18px;width:290px;z-index:60;animation:fadeIn .15s ease}
.notif-item{padding:10px 0;border-bottom:1px solid #1E1E1E;font-size:12px;color:#999;display:flex;gap:10px}
.notif-bullet{width:6px;height:6px;border-radius:50%;background:var(--accent);margin-top:4px;flex-shrink:0}

/* ── Cards ───────────────────────────────── */
.card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:14px;padding:22px 24px;margin-bottom:20px}
.card-sm{padding:14px 18px}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.scard{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:14px;padding:20px 22px;transition:all .2s}
.scard:hover{border-color:#2A2A2A;transform:translateY(-2px)}
.slbl{font-size:12px;color:#555;margin-bottom:6px}
.sval{font-size:26px;font-weight:800}
.s-up{color:#4ADE80;font-size:11px;font-weight:600}
.s-dn{color:#F87171;font-size:11px;font-weight:600}
.s-neu{color:#888;font-size:11px;font-weight:600}

/* ── Page header ─────────────────────────── */
.phdr{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;gap:12px;flex-wrap:wrap}
.ptitle{font-size:28px;font-weight:800;margin-bottom:5px}
.psub{font-size:13px;color:#555}
.breadcrumb{font-size:12px;color:#555;margin-bottom:8px}

/* ── Buttons ─────────────────────────────── */
.btn{border:none;border-radius:10px;padding:10px 18px;font-weight:700;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .15s;white-space:nowrap}
.btn-y{background:var(--accent);color:var(--accent-dark)}
.btn-y:hover{opacity:.9;transform:translateY(-1px)}
.btn-g{background:transparent;color:#888;border:1px solid #333}
.btn-g:hover{background:#1A1A1A}
.bic{background:#1E1E1E;border:none;border-radius:7px;padding:6px 9px;color:#aaa;cursor:pointer;font-size:13px;transition:background .15s}
.bic:hover{background:#2A2A2A}
.bic.danger{color:#F87171}

/* ── Table ───────────────────────────────── */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:520px}
th{padding:9px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.1em;border-bottom:1px solid #1E1E1E;white-space:nowrap}
td{padding:13px 14px;font-size:13px;color:var(--text-primary);border-bottom:1px solid #0F0F0F}
tr.rr:hover td{background:var(--accent-bg)}

/* ── Badges ──────────────────────────────── */
.bdg{padding:3px 10px;border-radius:50px;font-size:11px;font-weight:600;display:inline-block;white-space:nowrap}
.b-ACTIVE,.b-COMPLETED{background:#1A2E1A;color:#4ADE80}
.b-INACTIVE{background:#2A2A1A;color:#888}
.b-SUSPENDED{background:#2E1A1A;color:#F87171}
.b-Gold{background:#2A2200;color:#F5C518}
.b-Silver{background:#1E1E2E;color:#A0A0C8}
.b-Bronze{background:#2A1A0A;color:#CD7F32}
.b-SUPER_ADMIN{background:#2A1A2E;color:#A78BFA}
.b-ADMIN{background:#1A1E2E;color:#60A5FA}
.b-MERCHANT{background:#1E2A1A;color:#4ADE80}
.b-CUSTOMER{background:#1E1E1E;color:#888}

/* ── Toggle ──────────────────────────────── */
.tgl{width:44px;height:24px;border-radius:12px;position:relative;cursor:pointer;transition:background .2s;display:inline-flex;align-items:center;padding:0 3px;flex-shrink:0}
.tgl.on{background:var(--accent)}.tgl.off{background:#333}
.tgl-d{width:18px;height:18px;border-radius:50%;transition:transform .2s}
.tgl.on .tgl-d{background:var(--accent-dark);transform:translateX(20px)}
.tgl.off .tgl-d{background:#888;transform:translateX(0)}

/* ── Form ────────────────────────────────── */
.fg{margin-bottom:14px}
.lbl{font-size:12px;color:#888;font-weight:500;display:block;margin-bottom:6px}
.inp{background:var(--bg-mid);border:1px solid var(--border-color);border-radius:10px;padding:10px 14px;color:#fff;font-size:13px;outline:none;width:100%;transition:border-color .15s;font-family:inherit}
.inp:focus{border-color:var(--accent)}
.r2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── Modal ───────────────────────────────── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(4px);padding:16px}
.modal-bx{background:var(--bg-surface);border:1px solid #2A2A2A;border-radius:16px;padding:28px;width:500px;max-width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}

/* ── Toast ───────────────────────────────── */
.toast{position:fixed;bottom:24px;right:24px;border-radius:10px;padding:12px 20px;font-size:13px;font-weight:500;z-index:1000;box-shadow:0 8px 32px rgba(0,0,0,.5);display:flex;align-items:center;gap:10px;animation:fadeIn .2s ease;max-width:calc(100vw - 48px)}
.t-ok{background:#1A2E1A;border:1px solid #4ADE80;color:#4ADE80}
.t-er{background:#2E1A1A;border:1px solid #F87171;color:#F87171}

/* ── Avatar ──────────────────────────────── */
.av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#000;flex-shrink:0}

/* ── Pagination ──────────────────────────── */
.pgn{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid #1E1E1E;flex-wrap:wrap;gap:10px}
.pgn-info{font-size:12px;color:#555}
.pgs{display:flex;gap:5px;flex-wrap:wrap}
.pb{width:32px;height:32px;border-radius:7px;border:none;cursor:pointer;font-size:13px;transition:all .15s}
.pb.a{background:var(--accent);color:var(--accent-dark);font-weight:700}
.pb.i{background:#1E1E1E;color:#666}.pb.i:hover{background:#2A2A2A}

/* ── Filter bar ──────────────────────────── */
.fbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.fbtn{background:transparent;border:1px solid #2A2A2A;border-radius:8px;padding:8px 14px;color:#555;font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit}
.fbtn:hover{border-color:#444;color:#ccc}
.fbtn.on{background:var(--accent);color:var(--accent-dark);border-color:var(--accent);font-weight:700}

/* ── Chart ───────────────────────────────── */
.cw{position:relative;height:220px;margin-top:8px}
.cw svg{width:100%;height:100%}

/* ── Tier card ───────────────────────────── */
.tc{background:var(--bg-surface);border:2px solid #1E1E1E;border-radius:14px;padding:22px;cursor:pointer;transition:all .2s}
.tc:hover{border-color:#333}
.tc.sel{background:#1C1800;border-color:var(--accent)}
.ti{width:50px;height:50px;border-radius:12px;background:#1E1E1E;display:flex;align-items:center;justify-content:center;font-size:24px}

/* ── Progress bar ────────────────────────── */
.ib{height:6px;border-radius:3px;background:#2A2A2A;overflow:hidden;margin-top:4px}
.if{height:100%;border-radius:3px}

/* ── Utilities ───────────────────────────── */
.hidden{display:none!important}
.loading{opacity:.5;animation:pulse 1.2s infinite;pointer-events:none}

/* ── Theme swatches ──────────────────────── */
.theme-swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;transition:all .2s;border:3px solid transparent}
.theme-swatch:hover{transform:scale(1.15)}
.theme-swatch.active{border-color:#fff;transform:scale(1.1)}

/* ── Font preview ────────────────────────── */
.font-opt{padding:10px 16px;border-radius:10px;border:2px solid #2A2A2A;cursor:pointer;transition:all .15s;background:#1A1A1A;text-align:center}
.font-opt:hover{border-color:#444}
.font-opt.active{border-color:var(--accent);background:var(--accent-bg)}

/* ── BG color swatch ─────────────────────── */
.bg-swatch{width:36px;height:36px;border-radius:8px;cursor:pointer;border:3px solid transparent;transition:all .2s;flex-shrink:0}
.bg-swatch:hover{transform:scale(1.1)}
.bg-swatch.active{border-color:#fff}

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */
@media (max-width: 1024px) {
    :root { --sidebar-w: 200px; }
    .sgrid { grid-template-columns: repeat(2, 1fr); }
    #content { padding: 20px; }
    .ptitle { font-size: 22px; }
}
@media (max-width: 768px) {
    :root { --sidebar-w: 240px; }
    #sidebar { transform: translateX(-100%); box-shadow: none; }
    #sidebar.open { transform: translateX(0); box-shadow: 4px 0 32px rgba(0,0,0,.6); animation: slideIn .25s ease; }
    #main { margin-left: 0; }
    #menu-toggle { display: flex; }
    .t-search { display: none; }
    #topbar { padding: 0 16px; gap: 10px; }
    #content { padding: 16px; }
    .sgrid { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 16px; }
    .sval { font-size: 22px; }
    .scard { padding: 16px; }
    .phdr { flex-direction: column; align-items: flex-start; margin-bottom: 20px; }
    .ptitle { font-size: 20px; }
    .r2 { grid-template-columns: 1fr; }
    .card { padding: 16px; }
    .modal-bx { padding: 20px; border-radius: 14px; }
    .toast { bottom: 16px; right: 16px; left: 16px; max-width: none; }
    .hide-mobile { display: none !important; }
    .t-uname { display: none; }
}
@media (max-width: 480px) {
    .sgrid { grid-template-columns: 1fr 1fr; gap: 8px; }
    .sval  { font-size: 20px; }
    .slbl  { font-size: 11px; }
    .btn   { padding: 8px 14px; font-size: 12px; }
    .ptitle { font-size: 18px; }
    .fbar { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 4px; }
    .fbar::-webkit-scrollbar { display: none; }
}