/* ════════════════════════════════════════════════════════════════════
   FX Demo — پوسته (ریست + ورود + قابِ اپ + سایدبار)  — مشترکِ همه‌ی سایت‌ها
   پالت از tokens.css هر دامنه می‌آید (که بعدِ این فایل لود می‌شود).
   ════════════════════════════════════════════════════════════════════ */
:root{
  --fx-r-sm:11px; --fx-r:16px; --fx-r-lg:22px; --fx-pill:999px;
  --fx-blur:blur(20px);
  --fx-glass:rgba(13,18,38,.55); --fx-glass-2:rgba(13,18,38,.80);
  --fx-shadow:0 22px 56px -24px rgba(0,0,0,.8);
  --fx-font-fa:'Vazirmatn','Tahoma','Segoe UI',system-ui,sans-serif;
  --fx-font-display:'Michroma','Vazirmatn',system-ui,sans-serif;
  --fx-side-w:270px; --fx-top-h:64px;
  --fx-green:#34d399;
  /* fallbackهای پالت — tokens.css override می‌کند */
  --fx-bg:#05060d; --fx-bg-2:#0a0e1a;
  --fx-surface:rgba(255,255,255,.045); --fx-surface-2:rgba(255,255,255,.075);
  --fx-border:rgba(255,255,255,.10); --fx-border-2:rgba(255,255,255,.17);
  --fx-text:#e9edf8; --fx-text-soft:rgba(233,237,248,.82); --fx-text-dim:rgba(233,237,248,.60); --fx-text-mute:rgba(233,237,248,.42);
  --fx-a:#2dd4bf; --fx-a2:#22d3ee; --fx-b:#6366f1; --fx-b2:#8b5cf6; --fx-c:#f5b301; --fx-c2:#fb7185;
  --fx-on-a:#04140f;
  --fx-grad-brand:linear-gradient(135deg,var(--fx-a) 0%,var(--fx-b) 52%,var(--fx-c) 100%);
  --fx-grad-a:linear-gradient(135deg,var(--fx-a),var(--fx-a2));
  --fx-glow-a:rgba(45,212,191,.45);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--fx-font-fa);background:var(--fx-bg);color:var(--fx-text);line-height:1.8;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
img{max-width:100%;display:block}
.ltr{direction:ltr;unicode-bidi:isolate}
::selection{background:color-mix(in srgb,var(--fx-a) 30%,transparent);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--fx-bg-2)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--fx-a),var(--fx-b));border-radius:999px;border:2px solid var(--fx-bg-2)}

.fx-mesh{position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(60% 50% at 82% 4%,color-mix(in srgb,var(--fx-b) 16%,transparent),transparent 60%),
             radial-gradient(50% 45% at 8% 14%,color-mix(in srgb,var(--fx-a) 13%,transparent),transparent 60%),
             radial-gradient(60% 60% at 50% 112%,color-mix(in srgb,var(--fx-c) 8%,transparent),transparent 60%),var(--fx-bg)}

.fx-grad-text{background:var(--fx-grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.fx-logo-mark{width:34px;height:34px;border-radius:10px;background:var(--fx-grad-brand);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 24px -8px var(--fx-glow-a);flex-shrink:0}

/* ─── صفحه‌ی ورود ─── */
#fx-login{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:22px}
#fx-login.hidden{display:none}
.fx-login-card{width:min(420px,94vw);padding:36px 30px;border-radius:var(--fx-r-lg);background:var(--fx-glass-2);border:1px solid var(--fx-border);backdrop-filter:var(--fx-blur);box-shadow:var(--fx-shadow);text-align:center}
.fx-login-card .brand{display:inline-flex;align-items:center;gap:11px;font-weight:800;font-size:21px;margin-bottom:6px}
.fx-login-card .brand small{display:block;font-size:10px;letter-spacing:2px;color:var(--fx-text-mute);font-family:var(--fx-font-display)}
.fx-login-card h1{font-size:20px;margin:14px 0 4px}
.fx-login-card p{color:var(--fx-text-dim);font-size:14px;margin:0 0 22px}
.fx-field{text-align:right;margin-bottom:14px}
.fx-field label{display:block;font-size:12.5px;color:var(--fx-text-dim);margin-bottom:6px}
.fx-input{width:100%;padding:12px 14px;border-radius:var(--fx-r-sm);background:var(--fx-surface);border:1px solid var(--fx-border-2);color:var(--fx-text);font-family:inherit;font-size:15px}
.fx-input:focus{outline:none;border-color:var(--fx-a)}
.fx-login-hint{margin-top:16px;font-size:12px;color:var(--fx-text-mute)}
.fx-login-roles{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.fx-role-chip{padding:7px 13px;border-radius:var(--fx-pill);background:var(--fx-surface);border:1px solid var(--fx-border);font-size:12.5px;color:var(--fx-text-soft)}
.fx-role-chip.on{border-color:var(--fx-a);color:var(--fx-a);background:color-mix(in srgb,var(--fx-a) 8%,transparent)}

/* ─── دکمه‌ها ─── */
.fx-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:var(--fx-pill);font-weight:700;font-size:15px;border:1px solid transparent;transition:transform .16s,box-shadow .22s,background .2s}
.fx-btn:hover{transform:translateY(-1px)}
.fx-btn-primary{color:var(--fx-on-a);background:var(--fx-grad-a);box-shadow:0 16px 40px -16px var(--fx-glow-a)}
.fx-login-card .fx-btn-primary{width:100%}
.fx-btn-ghost{color:var(--fx-text);background:var(--fx-surface);border-color:var(--fx-border-2)}
.fx-btn-ghost:hover{background:var(--fx-surface-2);border-color:var(--fx-a)}

/* ─── قابِ اپ ─── */
#fx-app{display:none;min-height:100vh}
#fx-app.show{display:block}
.fx-top{position:sticky;top:0;z-index:40;height:var(--fx-top-h);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 18px;background:color-mix(in srgb,var(--fx-bg) 72%,transparent);backdrop-filter:var(--fx-blur);border-bottom:1px solid var(--fx-border)}
.fx-top .left{display:flex;align-items:center;gap:12px;min-width:0}
.fx-top .crumb{font-size:13px;color:var(--fx-text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fx-top .crumb b{color:var(--fx-text)}
.fx-burger{display:none;width:40px;height:40px;border-radius:11px;background:var(--fx-surface);border:1px solid var(--fx-border);color:#fff;align-items:center;justify-content:center}
.fx-top .right{display:flex;align-items:center;gap:10px}
.fx-userchip{display:flex;align-items:center;gap:9px;padding:6px 8px 6px 12px;border-radius:var(--fx-pill);background:var(--fx-surface);border:1px solid var(--fx-border)}
.fx-userchip .av{width:30px;height:30px;border-radius:50%;background:var(--fx-grad-brand);display:grid;place-items:center;font-weight:800;font-size:13px;color:var(--fx-on-a)}
.fx-userchip .nm{font-size:13px}
.fx-userchip .rl{font-size:10.5px;color:var(--fx-text-mute)}

.fx-body{display:grid;grid-template-columns:var(--fx-side-w) 1fr}

/* ─── سایدبار (راست در RTL) ─── */
.fx-side{position:sticky;top:var(--fx-top-h);align-self:start;height:calc(100vh - var(--fx-top-h));overflow-y:auto;border-inline-start:1px solid var(--fx-border);padding:14px 12px 30px}
.fx-side .grp{margin-top:16px}
.fx-side .grp:first-child{margin-top:4px}
.fx-side .grp-title{font-size:11px;color:var(--fx-text-mute);padding:6px 12px;letter-spacing:.3px}
.fx-nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--fx-r-sm);color:var(--fx-text-soft);font-size:14px;transition:background .15s,color .15s;position:relative}
.fx-nav-item:hover{background:var(--fx-surface);color:var(--fx-text)}
.fx-nav-item.active{background:color-mix(in srgb,var(--fx-a) 10%,transparent);color:#fff}
.fx-nav-item.active::before{content:"";position:absolute;inset-inline-start:-12px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--fx-grad-a)}
.fx-nav-item .ic{width:24px;text-align:center;font-size:16px;flex-shrink:0}
.fx-nav-item .soon{margin-inline-start:auto;font-size:9.5px;padding:2px 7px;border-radius:var(--fx-pill);background:color-mix(in srgb,var(--fx-c) 16%,transparent);color:var(--fx-c)}

.fx-view{min-width:0;padding:26px 26px 60px}
@media(max-width:1080px){.fx-view{padding:20px 16px 50px}}

@media(max-width:920px){
  .fx-burger{display:inline-flex}
  .fx-body{grid-template-columns:1fr}
  .fx-side{position:fixed;inset:var(--fx-top-h) auto 0 0;z-index:45;width:var(--fx-side-w);max-width:84vw;background:color-mix(in srgb,var(--fx-bg) 97%,transparent);backdrop-filter:var(--fx-blur);transform:translateX(-110%);transition:transform .26s ease;border-inline-start:0;border-inline-end:1px solid var(--fx-border)}
  html[dir=rtl] .fx-side{inset:var(--fx-top-h) 0 0 auto;transform:translateX(110%)}
  .fx-side.open{transform:none!important}
  .fx-scrim{position:fixed;inset:var(--fx-top-h) 0 0 0;z-index:44;background:rgba(0,0,0,.5);display:none}
  .fx-scrim.show{display:block}
  .fx-userchip .nm,.fx-userchip .rl{display:none}
}
