/* ════════════════════════════════════════════════════════════════════
   حلقه اول — CRM Mini App  ·  بازسازیِ کاملِ ۱۴۰۵ مطابقِ پروتوتایپِ «حلقه اول».
   صفحه‌های دیزاین (کاربر/ادمین/ویزارد/شیت/جشن) با استایلِ این‌لاینِ عینِ
   پروتوتایپ در app.js ساخته می‌شوند؛ این فایل = هلمتِ پروتوتایپ (کی‌فریم‌ها،
   اسکرول، تپ) + پوسته‌ی فریم/هدر/تب‌بار + کلاس‌های دیزاین‌سیستم برای
   بخش‌های ربات/فروشگاه/TV (که در پروتوتایپ نیستند، خاموش‌اند، و کلاس‌محورند).
   ════════════════════════════════════════════════════════════════════ */
@import url("https://fonts.googleapis.com/css2?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:600; font-style:normal; font-display:swap;
  src:url("https://cdn.jsdelivr.net/gh/rastikerdar/vazirmatn@v33.003/fonts/webfonts/Vazirmatn-SemiBold.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:#0f1827; --bg-deeper:#0d1422;
  --fg:#E8EDF4; --fg-dim:#9BA8BF; --muted:#5A6478; --on-accent:#0A0A0B;
  --border:#1A2438; --border-strong:#263450; --border-soft:#1d293f;
  --accent:#FF7A1A; --accent-2:#FFA15C; --accent-deep:#C87828;
  --accent-glow:rgba(255,122,26,0.35); --accent-soft:rgba(255,122,26,0.10); --accent-tint:rgba(255,122,26,0.16);
  --green:#26A69A; --green-2:#5BC28C; --red:#EF5350; --red-2:#f0a3a1;
  --blue:#5FB3FF; --purple:#9B8CFF;
  --font-fa:"Vazirmatn","Tahoma",sans-serif;
  --font-mono:"JetBrains Mono","Vazirmatn",monospace;
  --font-display:"Vazirmatn","Tahoma",sans-serif;
  --radius:9px; --radius-md:11px; --radius-card:14px; --radius-xl:18px; --radius-pill:999px;
  --shadow-cta:0 8px 22px -10px var(--accent-glow); --shadow-card:0 24px 60px -28px rgba(0,0,0,0.85);
  --ease-snap:cubic-bezier(0.4,0,0.2,1); --t-base:0.18s;
  color-scheme:dark;
}
* { box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html { background:#0a0d13; }
html, body { margin:0; padding:0; min-height:100%; }
body { color:var(--fg); font-family:var(--font-fa); font-size:16px; line-height:1.7; -webkit-font-smoothing:antialiased; }
button, input, textarea, select { font-family:inherit; }
button { color:inherit; cursor:pointer; }
::selection { background:var(--accent); color:var(--on-accent); }

/* پس‌زمینه‌ی رادیالِ ثابت */
.bg-glow { position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:radial-gradient(ellipse 90% 60% at 50% -10%, #15233b 0%, #0a0d13 60%); }

/* ── هلمتِ پروتوتایپ: کی‌فریم‌ها + اسکرول + تپ ── */
.ha-scroll::-webkit-scrollbar { width:0; height:0; }
.ha-scroll { scrollbar-width:none; -webkit-overflow-scrolling:touch; }
@keyframes ha-ping { 0%{box-shadow:0 0 0 0 rgba(38,166,154,.5);} 70%{box-shadow:0 0 0 7px rgba(38,166,154,0);} 100%{box-shadow:0 0 0 0 rgba(38,166,154,0);} }
@keyframes ha-fade { from{opacity:0;} to{opacity:1;} }
@keyframes ha-pop { 0%{transform:scale(.6);opacity:0;} 60%{transform:scale(1.06);} 100%{transform:scale(1);opacity:1;} }
@keyframes ha-drop { from{transform:translateY(-14px);opacity:0;} to{transform:translateY(0);opacity:1;} }
@keyframes ha-rise { from{transform:translateY(10px);opacity:0;} to{transform:translateY(0);opacity:1;} }
@keyframes ha-shimmer { 0%{background-position:200% 0;} 100%{background-position:-200% 0;} }
.ha-row:active { background:#1a2740 !important; }
.ha-tap:active { transform:scale(.97); }

/* ── فریم: هدر / محتوا / تب‌بار ── */
.frame { display:flex; flex-direction:column; min-height:100vh; max-width:560px; margin:0 auto; position:relative; }
.hdr { position:sticky; top:0; z-index:6; flex:none; height:54px; display:flex; align-items:center; gap:10px;
  padding:0 10px; background:#0c1623; border-bottom:1px solid #18202e; }
.hdr-side { width:40px; flex:none; display:flex; align-items:center; }
.hdr-right { justify-content:flex-end; }
.hdr-title { flex:1; min-width:0; display:flex; flex-direction:column; align-items:center; line-height:1.25; }
.hdr-t { font-size:14.5px; font-weight:700; color:var(--fg); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:220px; }
.hdr-s { font-size:10.5px; color:var(--blue); }
.hdr-back { width:34px; height:34px; display:flex; align-items:center; justify-content:center; border-radius:9px;
  color:var(--blue); font-size:24px; transform:scaleX(-1); }
.hdr-mark { width:26px; height:26px; border-radius:8px; background:var(--accent); color:#0A0A0B;
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; }
.hdr-icon { width:34px; height:34px; display:flex; align-items:center; justify-content:center; color:var(--fg-dim); font-size:18px; }

.content { flex:1; padding:0; }
body.has-tabbar .content { padding-bottom:calc(70px + env(safe-area-inset-bottom)); }

.tabbar { position:fixed; left:0; right:0; bottom:0; z-index:40; max-width:560px; margin:0 auto;
  height:62px; background:#0c1623; border-top:1px solid #18202e; display:none; align-items:stretch;
  padding-bottom:env(safe-area-inset-bottom); }
body.has-tabbar .tabbar { display:flex; }
.tb-item { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px;
  background:none; border:none; color:var(--muted); font-family:var(--font-fa); font-size:11px; font-weight:600; }
.tb-item .tb-ic { font-size:20px; line-height:1; }
.tb-item.active { color:var(--accent); }
.fab { position:fixed; bottom:calc(74px + env(safe-area-inset-bottom)); left:max(14px, calc(50% - 266px)); z-index:41;
  width:48px; height:48px; border-radius:50%; display:none; align-items:center; justify-content:center;
  background:rgba(22,32,48,.93); backdrop-filter:blur(8px); border:1px solid var(--border-strong);
  font-size:21px; box-shadow:0 10px 24px -8px rgba(0,0,0,.7); }
body.has-fab .fab { display:flex; }
.fab:active { transform:scale(.95); }

.view { display:none; } .view.active { display:block; animation:ha-fade .2s ease; }

/* ── ویزاردِ اتصال (اورلیِ تمام‌صفحه) ── */
.wiz { position:fixed; inset:0; z-index:45; background:#0E1117; display:none; flex-direction:column; max-width:560px; margin:0 auto; }
.wiz.open { display:flex; }

/* ── شیتِ پایین ── */
.sheet-backdrop { position:fixed; inset:0; z-index:50; background:rgba(4,7,12,.6); 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-elev); border-top:1px solid var(--border-strong);
  border-radius:22px 22px 0 0; padding:8px 16px calc(26px + env(safe-area-inset-bottom)); transform:translateY(110%);
  transition:transform .32s var(--ease-snap); max-width:560px; margin:0 auto; max-height:86vh; overflow-y:auto; }
.sheet.open { transform:translateY(0); }
.sheet .grip { width:38px; height:4px; border-radius:99px; background:var(--border-strong); margin:6px auto 16px; }

/* ── جشنِ ارتقا + توست ── */
.celebrate { position:fixed; inset:0; z-index:70; display:none; align-items:center; justify-content:center; padding:28px;
  background:rgba(4,7,12,.78); backdrop-filter:blur(6px); }
.celebrate.open { display:flex; animation:ha-fade .25s ease; }
.toast { position:fixed; left:50%; bottom:calc(96px + env(safe-area-inset-bottom)); transform:translateX(-50%) translateY(20px); z-index:80;
  background:#0d1f1a; border:1px solid #1f5a4a; color:#7fe3c4; padding:12px 16px; border-radius:13px; font-size:13px; font-weight:600;
  box-shadow:0 14px 30px -10px rgba(0,0,0,.6); 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 { background:#1f0e0e; border-color:#5a2b2b; color:var(--red-2); }

/* فرم‌کنترل‌های تیره (date/select) برای ویزارد/شیت‌ها */
input[type=date] { -webkit-appearance:none; appearance:none; text-align:right; }
input[type=date]::-webkit-calendar-picker-indicator { opacity:.6; cursor:pointer; }
select.dark { -webkit-appearance:none; appearance:none; color:var(--fg); background-color:var(--bg-deeper); padding-inline-start:34px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' fill='none' stroke='%235A6478' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat; background-position:left 12px center; }
select.dark option { background:var(--bg-card); color:var(--fg); }

/* لوگوی برند بروکر/صرافی */
.brk-logo { height:20px; width:auto; max-width:96px; object-fit:contain; vertical-align:-5px;
  background:#fff; border-radius:5px; padding:3px 6px; box-sizing:content-box; flex:0 0 auto; margin-inline-end:6px; }

/* ════════════════════════════════════════════════════════════════════
   کلاس‌های دیزاین‌سیستم — برای بخش‌های ربات/فروشگاه/TV (کلاس‌محور)،
   شیت‌ها، و کنترل‌های مشترک. صفحه‌های دیزاین این‌لاین‌اند و این‌ها را لازم ندارند.
   ════════════════════════════════════════════════════════════════════ */
.pad { padding:16px 14px 30px; }
.eyebrow { font-family:var(--font-mono); font-size:11.5px; letter-spacing:.02em; 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:50%; }
.mono { font-family:var(--font-mono); }
.t-accent{color:var(--accent);} .t-green{color:var(--green);} .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.25; }

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

.hero { background:linear-gradient(135deg,#1d2942,#162033); border:1px solid var(--border-strong);
  border-radius:var(--radius-xl); padding:20px; }
.hero .label { font-family:var(--font-mono); font-size:11px; color:var(--fg-dim); }
.hero .big { font-family:var(--font-display); font-weight:700; font-size:30px; line-height:1.15; margin-top:9px; }
.hero .sub { color:var(--fg-dim); font-size:13.5px; margin-top:9px; }

.spill { font-size:12px; font-weight:700; padding:5px 11px; border-radius:var(--radius-pill); border:1px solid;
  display:inline-flex; align-items:center; gap:5px; white-space:nowrap; line-height:1.3; }
.spill .glyph { font-size:11px; }
.s-undetermined{ color:#8893A7; background:#8893A720; border-color:#8893A755; }
.s-guest{ color:#5FB3FF; background:#5FB3FF20; border-color:#5FB3FF55; }
.s-guest_ended{ color:#9BA8BF; background:#9BA8BF20; border-color:#9BA8BF55; }
.s-vip{ color:#FF7A1A; background:#FF7A1A20; border-color:#FF7A1A55; }
.s-vip_expired{ color:#E0885A; background:#E0885A20; border-color:#E0885A55; }
.s-cip{ color:#9B8CFF; background:#9B8CFF20; border-color:#9B8CFF55; }
.s-cip_expired{ color:#B6ABE6; background:#B6ABE620; border-color:#B6ABE655; }
.s-partner{ color:#26A69A; background:#26A69A20; border-color:#26A69A55; }
.s-removed{ color:#EF5350; background:#EF535020; border-color:#EF535055; }

.kv { display:flex; justify-content:space-between; gap:12px; padding:11px 0; border-bottom:1px solid var(--border); font-size:13.5px; }
.kv:last-child { border-bottom:none; } .kv .k { color:var(--fg-dim); } .kv .v { font-family:var(--font-mono); }
.kv .k, .kv .v { min-width:0; overflow-wrap:anywhere; }

.bar { height:8px; border-radius:var(--radius-pill); background:var(--bg-deeper); overflow:hidden; }
.bar > i { display:block; height:100%; background:var(--accent); border-radius:var(--radius-pill); transition:width .5s var(--ease-snap); }
.bar.bar-cip > i { background:var(--purple); }

.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; width:100%; border:none;
  border-radius:var(--radius-md); padding:13px 16px; font-weight:700; font-size:14.5px; 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:scale(.98); } .btn:disabled { opacity:.45; box-shadow:none; }
.btn.ghost { background:var(--bg-deep); color:var(--fg); border:1px solid var(--border-strong); box-shadow:none; }
.btn.primary { background:var(--accent); color:var(--on-accent); }
.btn.green { background:var(--green); color:#04130f; box-shadow:none; }
.btn.sm { width:auto; padding:9px 14px; font-size:12.5px; border-radius:var(--radius); box-shadow:none; }
.btn-row { margin-top:10px; }

.btn.sup-item { justify-content:flex-start; gap:11px; text-align:right; padding:11px 13px; background:var(--bg-deep); }
.sup-ava { position:relative; flex:0 0 auto; width:44px; height:44px; border-radius:50%; display:grid; place-items:center;
  overflow:hidden; background:var(--accent-tint); color:var(--accent); font-weight:800; font-size:17px; }
.sup-ava::before { content:attr(data-letter); }
.sup-ava img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; background:var(--bg-card); }
.sup-meta { display:flex; flex-direction:column; align-items:flex-start; line-height:1.45; min-width:0; }
.sup-meta b { font-size:14px; } .sup-un { font-size:11.5px; color:var(--muted); direction:ltr; }

.field { margin-bottom:14px; }
.field label { display:block; font-family:var(--font-mono); font-size:11px; color:var(--muted); margin-bottom:7px; }
.field input, .field textarea { width:100%; background:var(--bg-deeper); border:1px solid var(--border-soft); 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); }
.field input:disabled { color:var(--muted); cursor:not-allowed; }
.field.locked::after { content:"🔒"; position:absolute; inset-inline-end:12px; bottom:13px; font-size:13px; opacity:.6; }
.field.locked { position:relative; }
.char-count { display:block; text-align:left; font-size:11px; color:var(--muted); margin-top:6px; }

.search { width:100%; background:var(--bg-deeper); border:1px solid var(--border-soft); color:var(--fg);
  border-radius:var(--radius-md); padding:12px 14px; font-family:var(--font-fa); font-size:14px; }
.search:focus { outline:none; border-color:var(--accent); }
.set-grid { display:grid; grid-template-columns:1fr 1fr; gap:9px; margin-top:8px; }

.tabs { display:flex; gap:5px; background:var(--bg-deep); border:1px solid var(--border); border-radius:var(--radius-md); padding:4px; }
.tab { flex:1; background:none; border:none; color:var(--fg-dim); font-family:var(--font-fa); font-size:13px; font-weight:700;
  padding:9px; border-radius:8px; transition:background var(--t-base),color var(--t-base); }
.tab.active { background:#1f2942; color:var(--accent); }

.back { font-size:13px; color:var(--blue); padding:6px 2px 12px; display:inline-block; }
.empty { text-align:center; color:var(--muted); padding:30px 10px; font-size:13.5px; }
.skeleton { height:120px; border-radius:var(--radius-card);
  background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-elev) 50%,var(--bg-card) 75%); background-size:200% 100%; animation:ha-shimmer 1.3s infinite; }
.sk-hero { height:160px; border-radius:var(--radius-xl); margin-bottom:14px; }
.sk-card { height:180px; border-radius:var(--radius-card); }
.skel-row { height:66px; border-radius:var(--radius-card); margin-bottom:9px;
  background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-elev) 50%,var(--bg-card) 75%); background-size:200% 100%; animation:ha-shimmer 1.3s infinite; }

.promo-banner { width:100%; aspect-ratio:16/9; object-fit:cover; display:block; border:1px solid var(--border); border-radius:var(--radius-card); margin-top:14px; }

/* coming-soon / gate */
.soon { min-height:70vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:16px; padding:32px 22px; }
.soon-badge { font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:.12em; border:1px solid var(--border); border-radius:8px; padding:8px 14px; order:3; }
.soon-logo { width:90px; height:90px; filter:drop-shadow(0 0 24px var(--accent-glow)); }
.soon h1 { font-family:var(--font-display); font-size:22px; margin:0; } .soon h1 b { color:var(--accent); }
.soon p { color:var(--fg-dim); font-size:14px; line-height:1.9; max-width:300px; margin:0; }

/* ════════════ فروشگاهِ محصولات (کلاس‌محور) ════════════ */
.shop-intro { margin-top:14px; }
.shop-dis { font-size:11.5px; color:var(--fg-dim); line-height:1.9; background:var(--bg-deep); border:1px solid var(--border); border-radius:var(--radius-md); padding:11px 13px; margin-top:14px; }
.shop-grid { display:grid; gap:12px; margin-top:14px; }
.shop-prod { position:relative; display:block; width:100%; text-align:right; color:inherit; background:var(--bg-card); border:1px solid var(--border);
  border-inline-start:3px solid var(--tag,var(--accent)); border-radius:var(--radius-card); padding:16px 16px 14px; overflow:hidden; transition:border-color var(--t-base),transform var(--t-base); }
.shop-prod.tap:active { transform:scale(.99); }
.shop-prod.feat { background:radial-gradient(circle at 92% 0%, rgba(38,166,154,.12), transparent 60%), var(--bg-card); }
.shop-ribbon { position:absolute; inset-inline-start:0; top:0; font-family:var(--font-mono); font-size:10px; color:var(--on-accent); background:var(--tag,var(--accent)); padding:4px 10px; border-end-end-radius:var(--radius-md); }
.sp-head { display:flex; align-items:flex-start; gap:12px; }
.sp-emoji { font-size:26px; line-height:1; flex:none; }
.sp-tt { min-width:0; flex:1; } .sp-tt b { display:block; font-family:var(--font-display); font-size:16px; }
.sp-tt span { display:block; color:var(--fg-dim); font-size:12.5px; line-height:1.7; margin-top:3px; }
.sp-foot { display:flex; align-items:center; justify-content:space-between; margin-top:14px; padding-top:12px; border-top:1px solid var(--border); }
.sp-from { font-family:var(--font-display); font-weight:700; font-size:16px; color:var(--tag,var(--accent)); }
.sp-go { font-family:var(--font-mono); font-size:12px; color:var(--muted); }
.shop-detail { margin-top:6px; border-inline-start:3px solid var(--tag,var(--accent)); }
.sd-head { display:flex; align-items:flex-start; gap:12px; margin-bottom:6px; }
.sd-feats { list-style:none; margin:14px 0 0; padding:0; display:grid; gap:8px; }
.sd-feats li { position:relative; padding-inline-start:22px; font-size:13px; color:var(--fg-dim); line-height:1.7; }
.sd-feats li::before { content:"✓"; position:absolute; inset-inline-start:0; top:0; color:var(--green); font-weight:800; }
.pl-list { display:flex; flex-direction:column; gap:8px; }
.pl-row { display:flex; align-items:center; gap:11px; width:100%; text-align:right; color:inherit; background:var(--bg-deep);
  border:1px solid var(--border-soft); border-radius:var(--radius-md); padding:12px 13px; transition:border-color var(--t-base),background var(--t-base); }
.pl-row.sel { border-color:var(--accent); background:var(--accent-soft); }
.pl-pick { color:var(--muted); font-size:15px; flex:none; } .pl-row.sel .pl-pick { color:var(--accent); }
.pl-mid { flex:1; min-width:0; display:flex; flex-direction:column; gap:3px; }
.pl-fa { font-size:14px; } .pl-note { font-family:var(--font-mono); font-size:10.5px; color:var(--green); }
.pl-price { text-align:left; flex:none; display:flex; flex-direction:column; align-items:flex-end; gap:2px; }
.pl-price b { font-family:var(--font-display); font-size:17px; } .pl-price s { color:var(--muted); font-size:11px; font-weight:400; }
.pl-per { font-family:var(--font-mono); font-size:10px; color:var(--muted); }
.pl-toman { font-family:var(--font-mono); font-size:10.5px; color:var(--fg-dim); margin-top:2px; }
.gw-row { display:flex; gap:9px; }
.gw-btn { flex:1; background:var(--bg-deep); border:1px solid var(--border-soft); color:var(--fg-dim); font-family:var(--font-fa);
  font-size:13.5px; padding:13px 8px; border-radius:var(--radius-md); transition:border-color var(--t-base),color var(--t-base),background var(--t-base); }
.gw-btn.sel { border-color:var(--accent); color:var(--accent); background:var(--accent-soft); font-weight:700; }
.shop-order b { font-family:var(--font-display); font-size:14.5px; }
