@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Arabic:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&family=Bebas+Neue&display=swap');

:root {
  --bg:        #0a0d12;
  --bg2:       #0f1318;
  --bg3:       #141920;
  --bg4:       #1a2030;
  --bg5:       #1f2635;
  --border:    rgba(255,255,255,0.06);
  --border2:   rgba(255,255,255,0.10);
  --border3:   rgba(255,255,255,0.16);
  --gold:      #f0b90b;
  --gold2:     #f8d060;
  --gold-bg:   rgba(240,185,11,0.08);
  --gold-bd:   rgba(240,185,11,0.22);
  --green:     #0ecb81;
  --green-bg:  rgba(14,203,129,0.08);
  --green-bd:  rgba(14,203,129,0.22);
  --red:       #f6465d;
  --red-bg:    rgba(246,70,93,0.08);
  --red-bd:    rgba(246,70,93,0.22);
  --blue:      #2196f3;
  --blue-bg:   rgba(33,150,243,0.08);
  --blue-bd:   rgba(33,150,243,0.22);
  --text1:     #eaecef;
  --text2:     #b7bdc6;
  --text3:     #848e9c;
  --text4:     #474d57;
  --text5:     #2b3139;
  --font:      'IBM Plex Sans Arabic', sans-serif;
  --mono:      'IBM Plex Mono', monospace;
  --display:   'Bebas Neue', sans-serif;
  --r1: 4px; --r2: 8px; --r3: 12px; --r4: 16px; --r5: 20px; --r6: 24px;
  --s1: 0 2px 8px rgba(0,0,0,.3);
  --s2: 0 4px 20px rgba(0,0,0,.4);
  --s3: 0 8px 40px rgba(0,0,0,.5);
  --trans: .18s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:14px}
body{background:var(--bg);color:var(--text1);font-family:var(--font);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
input,select,textarea{font-family:inherit;color:inherit}
ul,ol{list-style:none}
img{max-width:100%;display:block}
::selection{background:var(--gold-bg);color:var(--gold)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:3px}

/* ─── APP LAYOUT ─────────────────────────────────────── */
.app{display:grid;grid-template-columns:248px 1fr;grid-template-rows:56px 1fr;grid-template-areas:"hd hd" "sb mn";min-height:100vh}
.app.no-sb{grid-template-columns:1fr;grid-template-areas:"hd" "mn"}

/* ─── HEADER ─────────────────────────────────────────── */
.app-hd{grid-area:hd;height:56px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:14px;position:sticky;top:0;z-index:200}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--display);font-size:22px;letter-spacing:2px;color:var(--gold);flex-shrink:0;text-decoration:none}
.logo-box{width:32px;height:32px;background:linear-gradient(135deg,var(--gold),#e65c00);border-radius:var(--r2);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;color:#000;flex-shrink:0}
.hd-spacer{flex:1}
.hd-actions{display:flex;align-items:center;gap:8px}
.hd-icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--r2);color:var(--text3);transition:var(--trans);position:relative;font-size:17px;cursor:pointer}
.hd-icon-btn:hover{background:var(--bg4);color:var(--text1)}
.notif-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;background:var(--red);border-radius:50%;border:2px solid var(--bg2)}
.hd-user{display:flex;align-items:center;gap:9px;padding:5px 10px;border-radius:var(--r2);border:1px solid var(--border);cursor:pointer;transition:var(--trans)}
.hd-user:hover{border-color:var(--border2);background:var(--bg3)}
.av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#e65c00);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#000;flex-shrink:0}
.hd-uname{font-size:13px;font-weight:600}
.hd-urole{font-size:11px;color:var(--text3)}
.lang-btn {
  padding: 5px 12px; border-radius: 20px; font-size: 12px; font-weight: 700;
  cursor: pointer; border: 1px solid var(--border2);
  background: rgba(240,185,11,0.08); color: var(--gold);
  transition: var(--trans); letter-spacing: 0.5px;
  white-space: nowrap;
}
.lang-btn:hover { background: rgba(240,185,11,0.15); }
.lang-btn:hover{border-color:var(--gold);color:var(--gold)}
.ws-pill{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text4);padding:4px 9px;border-radius:100px;border:1px solid var(--border)}
.ws-dot{width:6px;height:6px;border-radius:50%;background:var(--text4);flex-shrink:0}
.ws-dot.on{background:var(--green);box-shadow:0 0 5px var(--green);animation:blink 2s infinite}
.ws-dot.off{background:var(--red)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

/* ─── SIDEBAR ────────────────────────────────────────── */
.app-sb{grid-area:sb;background:var(--bg2);border-left:1px solid var(--border);width:248px;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;display:flex;flex-direction:column;padding:10px 0;z-index:100}
body[dir="ltr"] .app-sb{border-left:none;border-right:1px solid var(--border)}
.sb-profile{margin:0 10px 12px;padding:13px;background:var(--bg3);border-radius:var(--r3);border:1px solid var(--border)}
.sbp-name{font-weight:700;font-size:14px;margin-bottom:1px}
.sbp-email{font-size:11px;color:var(--text3);margin-bottom:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sbp-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.sbp-stat{background:var(--bg4);border-radius:var(--r1);padding:6px 8px}
.sbp-val{font-family:var(--mono);font-size:13px;font-weight:600}
.sbp-lbl{font-size:10px;color:var(--text3);margin-top:1px}
.sb-lbl{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text4);padding:8px 16px 4px}
.nav-a{display:flex;align-items:center;gap:10px;padding:9px 12px;margin:0 8px 1px;border-radius:var(--r2);font-size:13.5px;font-weight:500;color:var(--text2);transition:var(--trans);cursor:pointer;position:relative;text-decoration:none}
.nav-a:hover{background:var(--bg4);color:var(--text1)}
.nav-a.active{background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-bd)}
.nav-a .ni{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.nav-a .nb{margin-right:auto;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}
body[dir="ltr"] .nav-a .nb{margin-right:unset;margin-left:auto}
.sb-bottom{margin-top:auto;padding:10px 8px 0;border-top:1px solid var(--border)}

/* ─── MAIN ───────────────────────────────────────────── */
.app-mn{grid-area:mn;min-height:calc(100vh - 56px)}
.page{padding:24px 28px;animation:pin .22s ease}
@keyframes pin{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.page-hd{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.page-title{font-size:22px;font-weight:800;letter-spacing:-.3px}
.page-sub{font-size:13px;color:var(--text3);margin-top:3px}
.page-acts{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* ─── CARDS ─────────────────────────────────────────── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r4);overflow:hidden}
.card-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);gap:12px}
.card-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.card-sub{font-size:11px;color:var(--text3);margin-top:2px}
.card-body{padding:18px}
.card-body-0{padding:0}
.card-ft{padding:12px 18px;border-top:1px solid var(--border);background:var(--bg3)}

/* ─── STAT CARDS ─────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-c{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r4);padding:18px;position:relative;overflow:hidden;transition:var(--trans);cursor:default}
.stat-c::after{content:'';position:absolute;top:-24px;right:-24px;width:90px;height:90px;border-radius:50%;opacity:.07}
.stat-c.sg::after{background:var(--gold)} .stat-c.sn::after{background:var(--green)}
.stat-c.sr::after{background:var(--red)}  .stat-c.sb::after{background:var(--blue)}
.stat-c:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--s2)}
.sic{width:38px;height:38px;border-radius:var(--r2);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.sg .sic{background:var(--gold-bg)} .sn .sic{background:var(--green-bg)}
.sr .sic{background:var(--red-bg)}  .sb .sic{background:var(--blue-bg)}
.sv{font-family:var(--mono);font-size:24px;font-weight:600;line-height:1.1;margin-bottom:4px;letter-spacing:-.5px}
.sl{font-size:12px;color:var(--text3)}
.sc{font-size:11px;font-family:var(--mono);margin-top:5px}
.sc.up{color:var(--green)} .sc.dn{color:var(--red)}

/* ─── BUTTONS ────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--r2);font-size:13px;font-weight:600;font-family:inherit;transition:var(--trans);white-space:nowrap;cursor:pointer;border:1px solid transparent;line-height:1}
.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.btn-primary{background:var(--gold);color:#000;border-color:var(--gold)}
.btn-primary:hover{background:var(--gold2);box-shadow:0 0 22px rgba(240,185,11,.28)}
.btn-success{background:var(--green);color:#000}
.btn-success:hover{background:#0fe090;box-shadow:0 0 22px rgba(14,203,129,.28)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{background:#f75e72}
.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border2)}
.btn-ghost:hover{border-color:var(--border3);color:var(--text1);background:var(--bg4)}
.btn-gold-o{background:transparent;color:var(--gold);border-color:var(--gold-bd)}
.btn-gold-o:hover{background:var(--gold-bg);border-color:var(--gold)}
.btn-lg{padding:12px 24px;font-size:15px;border-radius:var(--r3)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-xs{padding:4px 9px;font-size:11px;border-radius:var(--r1)}
.btn-full{width:100%}
.btn-icon{width:34px;height:34px;padding:0}
.bot-btn{width:100%;padding:14px;border-radius:var(--r3);font-size:15px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s;border:none;cursor:pointer;font-family:inherit;margin-top:18px}
.bot-btn.start{background:linear-gradient(135deg,var(--green),#059c5a);color:#000;box-shadow:0 4px 18px rgba(14,203,129,.2)}
.bot-btn.start:hover{box-shadow:0 4px 28px rgba(14,203,129,.4);transform:translateY(-1px)}
.bot-btn.stop{background:linear-gradient(135deg,var(--red),#c0392b);color:#fff;box-shadow:0 4px 18px rgba(246,70,93,.2)}
.bot-btn.stop:hover{box-shadow:0 4px 28px rgba(246,70,93,.4);transform:translateY(-1px)}

/* ─── FORMS ──────────────────────────────────────────── */
.frow{margin-bottom:16px}
.frow-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.flabel{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:.3px}
.flabel .req{color:var(--red);margin-right:2px}
.fctrl{width:100%;padding:10px 13px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r2);color:var(--text1);font-size:14px;font-family:inherit;transition:var(--trans);outline:none;appearance:none}
.fctrl:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-bg)}
.fctrl:hover:not(:focus){border-color:var(--border3)}
.fctrl::placeholder{color:var(--text4)}
.fctrl:disabled{opacity:.5;cursor:not-allowed}
.fhint{font-size:11px;color:var(--text3);margin-top:5px}
.ferr{font-size:11px;color:var(--red);margin-top:5px;display:flex;align-items:center;gap:4px}
.fok{font-size:11px;color:var(--green);margin-top:5px}
select.fctrl{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23848e9c' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 12px center;padding-left:34px}
body[dir="ltr"] select.fctrl{background-position:right 12px center;padding-left:13px;padding-right:34px}
textarea.fctrl{resize:vertical;min-height:80px}
.fcheck{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:13px}
.fcheck input[type="checkbox"]{width:16px;height:16px;accent-color:var(--gold);cursor:pointer;flex-shrink:0}

/* ─── TABLES ─────────────────────────────────────────── */
.tw{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{padding:11px 16px;text-align:right;font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg3)}
body[dir="ltr"] .tbl thead th{text-align:left}
.tbl tbody td{padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}
.tbl tbody tr{transition:var(--trans)}
.tbl tbody tr:hover{background:var(--bg3)}
.tbl tbody tr:last-child td{border-bottom:none}
.mono{font-family:var(--mono)}
.c-green{color:var(--green)} .c-red{color:var(--red)} .c-gold{color:var(--gold)} .c-muted{color:var(--text3)}

/* ─── BADGES ─────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;font-family:var(--mono);white-space:nowrap;border:1px solid}
.bg-green{background:var(--green-bg);color:var(--green);border-color:var(--green-bd)}
.bg-red  {background:var(--red-bg);color:var(--red);border-color:var(--red-bd)}
.bg-gold {background:var(--gold-bg);color:var(--gold);border-color:var(--gold-bd)}
.bg-blue {background:var(--blue-bg);color:var(--blue);border-color:var(--blue-bd)}
.bg-gray {background:var(--bg4);color:var(--text3);border-color:var(--border2)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-g{background:var(--green);box-shadow:0 0 6px var(--green);animation:dp 2s infinite}
.dot-r{background:var(--red)} .dot-y{background:var(--gold)} .dot-x{background:var(--text4)}
@keyframes dp{0%,100%{opacity:1}50%{opacity:.4}}

/* ─── MODAL ──────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(6px);z-index:999;display:flex;align-items:center;justify-content:center;padding:20px;animation:bgin .2s ease}
@keyframes bgin{from{opacity:0}to{opacity:1}}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r5);width:100%;max-width:520px;max-height:92vh;overflow-y:auto;animation:mdin .25s ease;position:relative}
@keyframes mdin{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-lg{max-width:760px} .modal-xl{max-width:960px}
.modal-hd{padding:20px 22px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modal-title{font-size:18px;font-weight:800}
.modal-stitle{font-size:12px;color:var(--text3);margin-top:3px}
.modal-bd{padding:18px 22px}
.modal-ft{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
.modal-x{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg4);color:var(--text3);font-size:16px;flex-shrink:0;cursor:pointer;transition:var(--trans)}
.modal-x:hover{background:var(--bg5);color:var(--text1)}

/* ─── TABS ───────────────────────────────────────────── */
.tabs{display:flex;gap:2px;background:var(--bg3);padding:4px;border-radius:var(--r2);margin-bottom:18px}
.tab{flex:1;padding:8px 12px;text-align:center;border-radius:6px;font-size:13px;font-weight:600;color:var(--text3);transition:var(--trans);cursor:pointer;white-space:nowrap}
.tab.active{background:var(--bg2);color:var(--text1);box-shadow:var(--s1)}
.tab:hover:not(.active){color:var(--text2)}
.itabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px}
.itab{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text3);cursor:pointer;border-bottom:2px solid transparent;transition:var(--trans);white-space:nowrap}
.itab.active{color:var(--gold);border-bottom-color:var(--gold)}
.itab:hover:not(.active){color:var(--text2)}

/* ─── TOAST ──────────────────────────────────────────── */
#toasts{position:fixed;bottom:22px;left:22px;z-index:9999;display:flex;flex-direction:column;gap:9px;max-width:360px;pointer-events:none}
body[dir="ltr"] #toasts{left:unset;right:22px}
.toast{display:flex;align-items:flex-start;gap:11px;padding:13px 15px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r3);box-shadow:var(--s3);animation:tin .3s ease;pointer-events:all}
@keyframes tin{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
.toast.tout{animation:tout .3s ease forwards}
@keyframes tout{to{transform:translateX(110%);opacity:0}}
.toast.success{border-color:var(--green-bd)} .toast.error{border-color:var(--red-bd)}
.toast.info{border-color:var(--gold-bd)} .toast.warning{border-color:rgba(255,165,0,.3)}
.t-icon{font-size:17px;flex-shrink:0;margin-top:1px} .t-msg{font-size:13px;line-height:1.5;flex:1}
.t-title{font-weight:700;font-size:13px;margin-bottom:2px}
.t-close{font-size:14px;color:var(--text3);cursor:pointer;padding:2px;flex-shrink:0}
.t-close:hover{color:var(--text1)}

/* ─── SKELETON ───────────────────────────────────────── */
.skel{background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);background-size:200% 100%;animation:sk 1.4s infinite;border-radius:var(--r1)}
@keyframes sk{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ─── PAIR CARD ──────────────────────────────────────── */
.pair-c{display:grid;grid-template-columns:40px 1fr auto auto;align-items:center;gap:13px;padding:13px 15px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r3);margin-bottom:8px;transition:var(--trans)}
.pair-c:hover{border-color:var(--border2);background:var(--bg4)}
.pair-av{width:40px;height:40px;border-radius:50%;background:var(--gold-bg);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--gold);flex-shrink:0;border:1px solid var(--gold-bd)}
.pair-sym{font-family:var(--mono);font-weight:700;font-size:14px}
.pair-info{font-size:11px;color:var(--text3);margin-top:2px}
.pair-amp{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:700;font-family:var(--mono);background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-bd)}
.pair-pnl{font-family:var(--mono);font-weight:700;font-size:14px;text-align:left}

/* ─── BOT CONTROL ────────────────────────────────────── */
.bot-card{background:linear-gradient(145deg,var(--bg2),var(--bg3));border:1px solid var(--border2);border-radius:var(--r5);padding:22px;position:relative;overflow:hidden}
.bot-card::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(240,185,11,.07) 0%,transparent 70%);pointer-events:none}
.bot-card.running::before{background:radial-gradient(circle,rgba(14,203,129,.08) 0%,transparent 70%)}
.ring-wrap{position:relative;width:58px;height:58px;flex-shrink:0}
.ring-wrap svg{transform:rotate(-90deg)}
.ring-track{fill:none;stroke:var(--border2);stroke-width:5}
.ring-fill{fill:none;stroke:var(--gold);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset .6s ease}
.ring-wrap.running .ring-fill{stroke:var(--green)}
.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-pct{font-family:var(--mono);font-size:12px;font-weight:700}
.ring-lbl{font-size:9px;color:var(--text3)}

/* ─── LIVE FEED ──────────────────────────────────────── */
.live-feed{max-height:230px;overflow-y:auto;display:flex;flex-direction:column;gap:5px}
.fi{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg3);border-radius:6px;font-size:12px;animation:fdin .3s ease;border:1px solid var(--border)}
@keyframes fdin{from{opacity:0;transform:translateX(-5px)}to{opacity:1;transform:translateX(0)}}
.fi-time{font-family:var(--mono);font-size:10px;color:var(--text4);flex-shrink:0}
.fi-icon{flex-shrink:0;font-size:13px}

/* ─── ALERT BOX ──────────────────────────────────────── */
.alert{padding:13px 15px;border-radius:var(--r3);font-size:13px;line-height:1.6;display:flex;gap:11px;align-items:flex-start;border:1px solid}
.alert-icon{font-size:17px;flex-shrink:0;margin-top:1px} .alert-bd{flex:1}
.alert-title{font-weight:700;margin-bottom:3px}
.a-green{background:var(--green-bg);border-color:var(--green-bd)} .a-green .alert-icon{color:var(--green)}
.a-red{background:var(--red-bg);border-color:var(--red-bd)} .a-red .alert-icon{color:var(--red)}
.a-gold{background:var(--gold-bg);border-color:var(--gold-bd)} .a-gold .alert-icon{color:var(--gold)}
.a-blue{background:var(--blue-bg);border-color:var(--blue-bd)} .a-blue .alert-icon{color:var(--blue)}

/* ─── PROGRESS ───────────────────────────────────────── */
.prog{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .5s ease}
.prog-fill.gold{background:linear-gradient(90deg,var(--gold),var(--gold2))}
.prog-fill.green{background:linear-gradient(90deg,var(--green),#34d399)}
.prog-fill.red{background:linear-gradient(90deg,var(--red),#fb7185)}

/* ─── TOGGLE ─────────────────────────────────────────── */
.tog-wrap{display:flex;align-items:center;gap:10px;cursor:pointer}
.tog{position:relative;width:38px;height:21px;flex-shrink:0}
.tog input{opacity:0;width:0;height:0;position:absolute}
.tog-sl{position:absolute;inset:0;background:var(--bg5);border-radius:11px;border:1px solid var(--border2);transition:var(--trans)}
.tog-sl::before{content:'';position:absolute;width:15px;height:15px;right:3px;top:2px;background:var(--text3);border-radius:50%;transition:var(--trans)}
body[dir="ltr"] .tog-sl::before{right:unset;left:3px}
.tog input:checked + .tog-sl{background:var(--green-bg);border-color:var(--green-bd)}
.tog input:checked + .tog-sl::before{background:var(--green);transform:translateX(-17px)}
body[dir="ltr"] .tog input:checked + .tog-sl::before{transform:translateX(17px)}

/* ─── PAGINATION ─────────────────────────────────────── */
.pag{display:flex;align-items:center;justify-content:center;gap:5px;padding:14px}
.pag-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r2);font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;border:1px solid var(--border);transition:var(--trans)}
.pag-btn:hover{border-color:var(--border2);color:var(--text1);background:var(--bg4)}
.pag-btn.active{background:var(--gold-bg);color:var(--gold);border-color:var(--gold-bd)}
.pag-btn:disabled{opacity:.3;cursor:not-allowed}

/* ─── EMPTY STATE ────────────────────────────────────── */
.empty{text-align:center;padding:56px 20px;color:var(--text3)}
.empty-icon{font-size:46px;margin-bottom:14px;opacity:.45}
.empty-title{font-size:16px;font-weight:700;color:var(--text2);margin-bottom:8px}
.empty-sub{font-size:13px;line-height:1.7;max-width:320px;margin:0 auto 18px}

/* ─── SPINNER ────────────────────────────────────────── */
.spin-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px;gap:14px;color:var(--text3);font-size:13px}
.spinner{width:34px;height:34px;border:3px solid var(--bg4);border-top-color:var(--gold);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* ─── DIVIDER ────────────────────────────────────────── */
.div-line{height:1px;background:var(--border);margin:16px 0}
.div-text{text-align:center;position:relative;margin:18px 0;font-size:12px;color:var(--text3)}
.div-text::before,.div-text::after{content:'';position:absolute;top:50%;width:calc(50% - 30px);height:1px;background:var(--border)}
.div-text::before{right:0} .div-text::after{left:0}
body[dir="ltr"] .div-text::before{right:unset;left:0} body[dir="ltr"] .div-text::after{left:unset;right:0}

/* ─── GRID UTILS ─────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.g13{display:grid;grid-template-columns:1fr 3fr;gap:20px}
.g31{display:grid;grid-template-columns:3fr 1fr;gap:20px}
.flex{display:flex;align-items:center}
.flex-col{display:flex;flex-direction:column}
.flex-btw{display:flex;align-items:center;justify-content:space-between}
.flex-ctr{display:flex;align-items:center;justify-content:center}
.gap-4{gap:4px} .gap-8{gap:8px} .gap-12{gap:12px} .gap-16{gap:16px} .gap-20{gap:20px}
.mb-4{margin-bottom:4px} .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}
.mt-8{margin-top:8px} .mt-12{margin-top:12px} .mt-16{margin-top:16px}
.tc{text-align:center} .tr{text-align:right} .tl{text-align:left}
.fw7{font-weight:700} .fw6{font-weight:600} .fw5{font-weight:500}
.fs12{font-size:12px} .fs11{font-size:11px} .fs13{font-size:13px} .fs16{font-size:16px}
.hidden{display:none!important} .w-full{width:100%} .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ─── RESPONSIVE ─────────────────────────────────────── */

/* ── Tablet landscape 960-1200 ───────────────────────── */
@media(max-width:1200px){
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .sv{font-size:20px}
}

/* ── Tablet portrait 768-960 ─────────────────────────── */
@media(max-width:960px){
  .app{grid-template-columns:1fr;grid-template-areas:"hd" "mn"}
  .app-sb{display:none}
  .app-mn{min-height:calc(100vh - 56px)}
  .page{padding:14px 14px 24px}
  .page-title{font-size:18px}
  .page-hd{margin-bottom:16px;gap:10px}
  .frow-2{grid-template-columns:1fr}
  .g2,.g3,.g13,.g31{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:10px}
  .ws-pill{display:none}
  .hd-actions{gap:6px}
  #menuToggleBtn{display:flex!important}
  .dashboard-grid{grid-template-columns:1fr!important}
  .bot-card{padding:16px}
  .pair-c{gap:10px;padding:11px 12px}
  .pair-av{width:34px;height:34px;font-size:12px}
  .pair-sym{font-size:13px}
  .pair-info{font-size:10px}
}

/* ── Mobile 480-640 ──────────────────────────────────── */
@media(max-width:640px){
  .page{padding:12px 12px 28px}
  .page-hd{flex-direction:column;align-items:flex-start;gap:8px}
  .page-acts{width:100%;flex-wrap:wrap}
  .page-title{font-size:17px}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}
  .stat-c{padding:13px}
  .sic{width:32px;height:32px;font-size:15px;margin-bottom:10px}
  .sv{font-size:18px}
  .sl{font-size:11px}
  .app-hd{padding:0 12px;gap:8px}
  .hd-user{padding:4px 8px;gap:6px}
  .lang-btn{padding:4px 8px;font-size:11px}
  .hd-icon-btn{width:30px;height:30px;font-size:15px}
  .card-hd{padding:12px 14px;flex-wrap:wrap;gap:8px}
  .card-body{padding:14px}
  .card-title{font-size:13px}
  .modal-bg{align-items:flex-end;padding:0}
  .modal{border-radius:var(--r4) var(--r4) 0 0;max-height:94vh;max-width:100%}
  .modal-hd{padding:16px 16px 0}
  .modal-bd{padding:14px 16px}
  .modal-ft{padding:12px 16px;gap:8px}
  .modal-ft .btn{flex:1}
  .tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl{min-width:500px}
  .pair-c{grid-template-columns:34px 1fr auto;gap:8px;padding:10px 11px}
  .pair-pnl{display:none}
  .bot-card{padding:14px}
  .bot-btn{padding:12px;font-size:14px}
  .ring-wrap{width:48px;height:48px}
  .live-feed{max-height:180px}
  .fi{padding:7px 9px;font-size:11px}
  .fi-time{display:none}
  .fctrl{font-size:15px}
  .badge{font-size:10px;padding:2px 7px}
  .alert{padding:10px 12px;font-size:12px}
  .alert-icon{font-size:15px}
  .btn-lg{padding:11px 20px;font-size:14px}
  .page-acts .btn{font-size:12px;padding:7px 12px}
  .g2,.g3,.g13,.g31{grid-template-columns:1fr;gap:12px}
}

/* ── Small mobile ≤ 420px ────────────────────────────── */
@media(max-width:420px){
  html{font-size:13px}
  .page{padding:10px 10px 24px}
  .app-hd{padding:0 10px;height:52px;gap:6px}
  .logo{font-size:18px;gap:7px}
  .logo span{display:none}
  .logo-box{width:28px;height:28px;font-size:13px}
  .hd-user .hd-uname{display:none}
  .hd-user .hd-urole{display:none}
  .hd-user{padding:5px 8px}
  .hd-user .av{width:26px;height:26px;font-size:11px}
  .lang-btn{padding:4px 7px;font-size:11px}
  .stats-row{grid-template-columns:1fr 1fr;gap:7px}
  .stat-c{padding:11px}
  .sv{font-size:17px;letter-spacing:-.3px}
  .sic{margin-bottom:8px}
  .page-title{font-size:16px}
  .page-hd{margin-bottom:12px}
  .card-hd{padding:10px 12px}
  .card-body{padding:12px}
  .card-title{font-size:12px}
  .pair-c{padding:9px 10px;gap:7px}
  .pair-sym{font-size:12px}
  .bot-card{padding:12px}
  .ring-wrap{display:none}
  .modal-title{font-size:15px}
  .modal-ft .btn{font-size:12px;padding:9px 12px}
  .pag-btn{width:28px;height:28px;font-size:12px}
  #toasts{left:10px;right:10px;max-width:100%}
  body[dir="ltr"] #toasts{right:10px;left:10px}
  .toast{padding:10px 12px}
}
