/* ════════════════════════════════════════════════════════════════════
   حلقه اول — CRM Mini App
   توکن‌ها آینهٔ دیزاین‌سیستمِ Trading Robot (colors_and_type.css): تیره،
   تک‌رنگِ نارنجی، mono برای eyebrow، borderها به‌جای سایه، RTL/Vazirmatn.
   ════════════════════════════════════════════════════════════════════ */
@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap");
@font-face {
  font-family: "Vazirmatn"; font-weight: 400; font-style: normal; font-display: swap;
  src: url("https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/fonts/webfonts/Vazirmatn-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "Vazirmatn"; font-weight: 500; font-style: normal; font-display: swap;
  src: url("https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/fonts/webfonts/Vazirmatn-Medium.woff2") format("woff2");
}
@font-face {
  font-family: "Vazirmatn"; font-weight: 700; font-style: normal; font-display: swap;
  src: url("https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/fonts/webfonts/Vazirmatn-Bold.woff2") format("woff2");
}

:root {
  --bg:#0E1117; --bg-elev:#131B2C; --bg-card:#162030; --bg-deep:#0B0F1A; --bg-deeper:#090E18;
  --fg:#E8EDF4; --fg-dim:#9BA8BF; --muted:#5A6478; --on-accent:#0A0A0B;
  --border:#1A2438; --border-strong:#263450;
  --accent:#FF7A1A; --accent-2:#FFA15C; --accent-deep:#C87828;
  --accent-glow:rgba(255,122,26,0.35); --accent-soft:rgba(255,122,26,0.08); --accent-tint:rgba(255,122,26,0.14);
  --green:#26A69A; --green-2:#5BC28C; --red:#EF5350; --red-2:#E85454;
  --blue:#5FB3FF; --purple:#9B8CFF;
  --font-fa:"Vazirmatn","Tahoma",sans-serif;
  --font-mono:"JetBrains Mono","Vazirmatn",monospace;
  --font-display:"Space Grotesk","Vazirmatn",sans-serif;
  --radius:4px; --radius-md:8px; --radius-card:14px; --radius-xl:18px; --radius-pill:999px;
  --shadow-cta:0 8px 24px -10px var(--accent-glow); --shadow-card:0 20px 48px -20px rgba(0,0,0,0.8);
  --ease-snap:cubic-bezier(0.4,0,0.2,1); --t-base:0.18s;
}
* { box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body { margin:0; padding:0; background:var(--bg); color:var(--fg);
  font-family:var(--font-fa); font-size:16px; line-height:1.7; -webkit-font-smoothing:antialiased; letter-spacing:0; }
button { font-family:inherit; cursor:pointer; }
::selection { background:var(--accent); color:var(--on-accent); }

.bg-glow { position:fixed; top:-240px; right:-200px; width:420px; height:420px;
  background:var(--accent); filter:blur(120px); opacity:.10; z-index:-1; pointer-events:none; }

.app { max-width:560px; margin:0 auto; padding:14px 16px 28px; }
.topbar { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:6px 2px 16px; }
.brand { display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:16px; }
.brand b { color:var(--accent); }
.live-chip { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:11px;
  color:var(--green-2); border:1px solid var(--border); border-radius:var(--radius-pill); padding:5px 11px; background:var(--bg-deep); }
.live-dot { width:7px; height:7px; border-radius:50%; background:var(--green-2); animation:ping 1.7s infinite; }
@keyframes ping { 0%{box-shadow:0 0 0 0 rgba(91,194,140,.55);} 70%{box-shadow:0 0 0 8px rgba(91,194,140,0);} 100%{box-shadow:0 0 0 0 rgba(91,194,140,0);} }

.eyebrow { font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--muted); display:inline-flex; align-items:center; gap:8px; }
.eyebrow::before { content:""; width:6px; height:6px; background:var(--accent); display:inline-block; border-radius:1px; }
.mono { font-family:var(--font-mono); }
.t-accent{color:var(--accent);} .t-green{color:var(--green-2);} .t-red{color:var(--red-2);}
.t-dim{color:var(--fg-dim);} .t-muted{color:var(--muted);}
h1,h2,h3 { font-family:var(--font-display); margin:0; font-weight:700; line-height:1.2; }

.card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-card); padding:18px; }
.card.tap:active { transform:translateY(1px); border-color:var(--border-strong); }
.section-title { display:flex; align-items:baseline; justify-content:space-between; margin:22px 2px 12px; }
.section-title h2 { font-size:18px; } .section-title .hint { font-family:var(--font-mono); font-size:11px; color:var(--muted); }

/* hero (status) */
.hero { background:radial-gradient(circle at 88% 12%, rgba(255,122,26,.16), transparent 52%), var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius-xl); padding:22px; box-shadow:var(--shadow-card); }
.hero .label { font-family:var(--font-mono); font-size:11px; color:var(--fg-dim); letter-spacing:.04em; }
.hero .big { font-family:var(--font-display); font-weight:700; font-size:34px; line-height:1.1; margin-top:8px; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.hero .sub { color:var(--fg-dim); font-size:13.5px; margin-top:8px; }

/* status pill — per-status colour */
.spill { font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; padding:5px 11px; border-radius:var(--radius); border:1px solid currentColor; display:inline-block; }
.s-undetermined{color:var(--muted);} .s-guest{color:var(--blue);} .s-vip{color:var(--accent);}
.s-cip{color:var(--purple);} .s-partner{color:var(--green-2);}

/* review-flag banner */
.flag { background:rgba(232,84,84,.10); border:1px solid var(--red-2); color:#ffd9d9;
  border-radius:var(--radius-md); padding:12px 14px; margin:14px 0; font-size:13.5px; display:flex; gap:10px; }
.flag b { color:var(--red-2); }

/* kv rows */
.kv { display:flex; justify-content:space-between; gap:12px; padding:11px 0; border-bottom:1px solid var(--border); font-size:14px; }
.kv:last-child { border-bottom:none; } .kv .k { color:var(--fg-dim); } .kv .v { font-family:var(--font-mono); }

/* trading-account selector */
.acc-head { font-size:13.5px; margin:14px 0 6px; }
.ta-list { display:flex; flex-direction:column; gap:6px; margin-bottom:6px; }
.ta-row { display:flex; align-items:center; gap:10px; padding:9px 11px; border:1px solid var(--border);
  border-radius:var(--radius-md); background:var(--bg-deep); font-size:13px; transition:border-color var(--t-base); }
.ta-row:not(.sel) { cursor:pointer; } .ta-row:not(.sel):active { border-color:var(--border-strong); }
.ta-row.sel { border-color:var(--accent); background:var(--accent-soft); }
.ta-row .ta-pick { color:var(--muted); font-size:14px; } .ta-row.sel .ta-pick { color:var(--accent); }
.ta-row .ta-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.ta-row .ta-bal { font-family:var(--font-mono); color:var(--fg-dim); } .ta-row.sel .ta-bal { color:var(--accent); }

/* user tabs (profile / status) */
.tabs { display:flex; gap:6px; background:var(--bg-deep); border:1px solid var(--border);
  border-radius:var(--radius-pill); padding:4px; margin:6px 0 4px; }
.tab { flex:1; background:none; border:none; color:var(--fg-dim); font-family:var(--font-fa);
  font-size:14px; padding:9px; border-radius:var(--radius-pill); transition:background var(--t-base),color var(--t-base); }
.tab.active { background:var(--accent); color:var(--on-accent); font-weight:700; }

.support-btn { background:var(--surface); border:1px solid var(--border); color:var(--fg-dim);
  font-family:var(--font-fa); font-size:12.5px; padding:6px 12px; border-radius:var(--radius-pill);
  transition:border-color var(--t-base),color var(--t-base); }
.support-btn:active { border-color:var(--accent); color:var(--accent); }

/* coming-soon (pre-launch gate) */
.soon { min-height:78vh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; gap:14px; padding:32px 20px; }
.soon-badge { font-family:var(--font-fa); font-size:13px; font-weight:700; color:var(--accent);
  border:1px solid var(--accent); border-radius:var(--radius-pill); padding:6px 16px; letter-spacing:.5px; }
.soon-emoji { font-size:54px; line-height:1; margin-top:6px; filter:drop-shadow(0 6px 18px rgba(255,122,26,.35)); }
.soon h1 { font-family:var(--font-display); font-size:23px; margin:4px 0 0; font-weight:700; }
.soon h1 b { color:var(--accent); }
.soon p { color:var(--fg-dim); font-size:14.5px; line-height:2; max-width:330px; margin:0; }
/* progress */
.bar { height:8px; border-radius:var(--radius-pill); background:var(--bg-deep); overflow:hidden; border:1px solid var(--border); }
.bar > i { display:block; height:100%; background:linear-gradient(90deg,var(--accent-deep),var(--accent)); transition:width .5s var(--ease-snap); }

/* timeline */
.tl { position:relative; margin:6px 0 0; padding-right:18px; }
.tl::before { content:""; position:absolute; right:5px; top:4px; bottom:4px; width:2px; background:var(--border-strong); }
.tl-item { position:relative; padding:0 0 16px; }
.tl-item::before { content:""; position:absolute; right:-17px; top:5px; width:10px; height:10px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 3px var(--bg); }
.tl-item .t { font-size:14px; } .tl-item .s { font-family:var(--font-mono); font-size:11.5px; color:var(--muted); margin-top:2px; }

/* buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; width:100%; border:none;
  border-radius:var(--radius); padding:13px 16px; font-weight:700; font-size:15px; font-family:var(--font-fa);
  background:var(--accent); color:var(--on-accent); box-shadow:var(--shadow-cta); transition:transform var(--t-base),opacity var(--t-base); }
.btn:active { transform:translateY(1px); } .btn:disabled { opacity:.4; box-shadow:none; }
.btn.ghost { background:transparent; color:var(--fg); border:1px solid var(--border-strong); box-shadow:none; }
.btn.green { background:var(--green); color:#06120f; box-shadow:none; }
.btn.sm { width:auto; padding:9px 14px; font-size:13px; border-radius:var(--radius); }
.btn-row { margin-top:10px; }

/* field */
.field { margin-bottom:14px; }
.field label { display:block; font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:.04em; margin-bottom:7px; }
.field input, .field textarea { width:100%; background:var(--bg-deep); border:1px solid var(--border); color:var(--fg);
  border-radius:var(--radius-md); padding:12px 14px; font-family:var(--font-fa); font-size:15px; }
.field input:focus, .field textarea:focus { outline:none; border-color:var(--accent); }

/* role chooser */
.chooser { padding:40px 8px; text-align:center; }
.chooser h2 { font-size:22px; margin-bottom:6px; }
.chooser p { color:var(--fg-dim); margin:0 0 26px; font-size:14px; }
.chooser .opts { display:grid; gap:14px; }
.choose-btn { background:var(--bg-card); border:1px solid var(--border-strong); border-radius:var(--radius-card);
  padding:22px; text-align:right; display:flex; align-items:center; gap:16px; transition:border-color var(--t-base); }
.choose-btn:active { border-color:var(--accent); }
.choose-btn .ic { font-size:28px; } .choose-btn .tx b { display:block; font-family:var(--font-display); font-size:17px; }
.choose-btn .tx span { color:var(--fg-dim); font-size:12.5px; }

/* admin: counts chips + search + member rows */
.chips { display:flex; gap:8px; flex-wrap:wrap; margin:2px 0 14px; }
.chip { font-family:var(--font-mono); font-size:11.5px; padding:6px 11px; border-radius:var(--radius-pill);
  border:1px solid var(--border); background:var(--bg-deep); color:var(--fg-dim); }
.chip.active { border-color:var(--accent); color:var(--accent); }
.chip.flag { color:var(--red-2); border-color:var(--red-2); }
.search { width:100%; background:var(--bg-deep); border:1px solid var(--border); color:var(--fg);
  border-radius:var(--radius-md); padding:11px 14px; font-family:var(--font-fa); font-size:14px; margin-bottom:12px; }
.search:focus { outline:none; border-color:var(--accent); }
.mrow { display:flex; align-items:center; gap:12px; padding:13px 4px; border-bottom:1px solid var(--border); }
.mrow:active { background:var(--accent-soft); }
.mrow .who { flex:1; min-width:0; }
.mrow .who .n { font-size:14.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.mrow .who .m { font-family:var(--font-mono); font-size:11px; color:var(--muted); margin-top:2px; }
.mrow .flagdot { width:8px; height:8px; border-radius:50%; background:var(--red-2); flex:none; }

/* bottom sheet */
.sheet-backdrop { position:fixed; inset:0; z-index:50; background:rgba(7,7,10,.7); backdrop-filter:blur(4px); opacity:0; pointer-events:none; transition:opacity var(--t-base); }
.sheet-backdrop.open { opacity:1; pointer-events:auto; }
.sheet { position:fixed; left:0; right:0; bottom:0; z-index:51; background:var(--bg-card); border-top:1px solid var(--border-strong);
  border-radius:20px 20px 0 0; padding:18px 18px calc(22px + env(safe-area-inset-bottom)); transform:translateY(110%);
  transition:transform .32s var(--ease-snap); max-width:560px; margin:0 auto; max-height:88vh; overflow-y:auto; }
.sheet.open { transform:translateY(0); }
.sheet .grip { width:42px; height:4px; border-radius:99px; background:var(--border-strong); margin:0 auto 14px; }
.set-grid { display:grid; grid-template-columns:1fr 1fr; gap:9px; margin-top:8px; }
.set-grid .btn { font-size:13.5px; padding:12px 8px; }
.set-grid .btn[disabled] { background:var(--bg-deep); color:var(--muted); border:1px solid var(--border); }

/* misc */
.toast { position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(20px); z-index:60;
  background:var(--bg-elev); border:1px solid var(--border-strong); color:var(--fg); padding:12px 18px;
  border-radius:var(--radius-md); font-size:14px; box-shadow:var(--shadow-card); opacity:0; pointer-events:none;
  transition:all var(--t-base); max-width:90%; text-align:center; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.err { border-color:var(--red-2); } .toast.ok { border-color:var(--green); }
.view { display:none; } .view.active { display:block; animation:fade .2s ease; }
@keyframes fade { from{opacity:0;} to{opacity:1;} }
.empty { text-align:center; color:var(--muted); padding:30px 10px; font-size:13.5px; }
.skeleton { height:120px; background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-elev) 50%,var(--bg-card) 75%);
  background-size:200% 100%; animation:shimmer 1.3s infinite; border-radius:var(--radius-card); }
@keyframes shimmer { 0%{background-position:200% 0;} 100%{background-position:-200% 0;} }
.back { font-family:var(--font-mono); font-size:13px; color:var(--fg-dim); padding:6px 2px 12px; display:inline-block; }
