/* ════════ CogMap Demo — shell layout ════════ */

/* ─── صفحه‌ی ورود ─── */
#cm-login{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:22px}
#cm-login.hidden{display:none}
.cm-login-card{width:min(420px,94vw);padding:36px 30px;border-radius:var(--cm-r-lg);background:var(--cm-glass-2);border:1px solid var(--cm-border);backdrop-filter:var(--cm-blur);box-shadow:var(--cm-shadow);text-align:center}
.cm-login-card .brand{display:inline-flex;align-items:center;gap:11px;font-weight:800;font-size:21px;margin-bottom:6px}
.cm-login-card .brand small{display:block;font-size:10px;letter-spacing:2px;color:var(--cm-text-mute);font-family:var(--cm-font-display)}
.cm-login-card h1{font-size:20px;margin:14px 0 4px}
.cm-login-card p{color:var(--cm-text-dim);font-size:14px;margin:0 0 22px}
.cm-field{text-align:right;margin-bottom:14px}
.cm-field label{display:block;font-size:12.5px;color:var(--cm-text-dim);margin-bottom:6px}
.cm-input{width:100%;padding:12px 14px;border-radius:var(--cm-r-sm);background:var(--cm-surface);border:1px solid var(--cm-border-2);color:var(--cm-text);font-family:inherit;font-size:15px}
.cm-input:focus{outline:none;border-color:var(--cm-teal)}
.cm-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:var(--cm-pill);font-weight:700;font-size:15px;border:1px solid transparent;transition:transform .16s,box-shadow .22s,background .2s}
.cm-btn:hover{transform:translateY(-1px)}
.cm-btn-primary{color:#04140f;background:var(--cm-grad-teal);box-shadow:0 16px 40px -16px var(--cm-glow-teal);width:100%}
.cm-btn-ghost{color:var(--cm-text);background:var(--cm-surface);border-color:var(--cm-border-2)}
.cm-btn-ghost:hover{background:var(--cm-surface-2);border-color:var(--cm-teal)}
.cm-login-hint{margin-top:16px;font-size:12px;color:var(--cm-text-mute)}
.cm-login-roles{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.cm-role-chip{padding:7px 13px;border-radius:var(--cm-pill);background:var(--cm-surface);border:1px solid var(--cm-border);font-size:12.5px;color:var(--cm-text-soft)}
.cm-role-chip.on{border-color:var(--cm-teal);color:var(--cm-teal);background:rgba(45,212,191,.08)}
/* حالتِ «در حالِ آماده‌سازی» دکمهٔ ورود (کلیکِ زودهنگام پیش از آماده‌شدنِ ماژول‌ها) */
.cm-btn.loading{position:relative;color:transparent!important;pointer-events:none}
.cm-btn.loading::after{content:"";position:absolute;top:50%;left:50%;width:18px;height:18px;margin:-9px 0 0 -9px;border:2px solid rgba(4,20,15,.3);border-top-color:#04140f;border-radius:50%;animation:cm-spin .7s linear infinite}
@keyframes cm-spin{to{transform:rotate(360deg)}}

/* ─── قابِ اپ ─── */
#cm-app{display:none;min-height:100vh}
#cm-app.show{display:block}

.cm-top{position:sticky;top:0;z-index:40;height:var(--cm-top-h);display:flex;align-items:center;justify-content:space-between;gap:14px;padding:0 18px;background:rgba(5,6,13,.72);backdrop-filter:var(--cm-blur);border-bottom:1px solid var(--cm-border)}
.cm-top .left{display:flex;align-items:center;gap:12px;min-width:0}
.cm-top .crumb{font-size:13px;color:var(--cm-text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cm-top .crumb b{color:var(--cm-text)}
.cm-burger{display:none;width:40px;height:40px;border-radius:11px;background:var(--cm-surface);border:1px solid var(--cm-border);color:#fff;align-items:center;justify-content:center}
.cm-top .right{display:flex;align-items:center;gap:10px}
.cm-userchip{display:flex;align-items:center;gap:9px;padding:6px 8px 6px 12px;border-radius:var(--cm-pill);background:var(--cm-surface);border:1px solid var(--cm-border)}
.cm-userchip .av{width:30px;height:30px;border-radius:50%;background:var(--cm-grad-brand);display:grid;place-items:center;font-weight:800;font-size:13px;color:#04140f}
.cm-userchip .nm{font-size:13px}
.cm-userchip .rl{font-size:10.5px;color:var(--cm-text-mute)}

.cm-body{display:grid;grid-template-columns:var(--cm-side-w) 1fr}
/* scrim فقط overlayِ موبایل است؛ در دسکتاپ باید از جریانِ گرید خارج باشد، وگرنه ستونِ اصلی را می‌گیرد و cm-view به ستونِ سایدبار می‌افتد */
.cm-scrim{display:none}

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

/* ─── ناحیه‌ی نمایش ─── */
.cm-view{min-width:0;padding:26px 26px 60px}
@media(max-width:1080px){.cm-view{padding:20px 16px 50px}}

/* ─── ریسپانسیو ─── */
@media(max-width:920px){
  .cm-burger{display:inline-flex}
  .cm-body{grid-template-columns:1fr}
  .cm-side{position:fixed;inset:var(--cm-top-h) auto 0 0;z-index:45;width:var(--cm-side-w);max-width:84vw;background:rgba(5,6,13,.97);backdrop-filter:var(--cm-blur);transform:translateX(-110%);transition:transform .26s ease;border-inline-start:0;border-inline-end:1px solid var(--cm-border)}
  html[dir=rtl] .cm-side{inset:var(--cm-top-h) 0 0 auto;transform:translateX(110%)}
  .cm-side.open{transform:none!important}
  .cm-scrim{position:fixed;inset:var(--cm-top-h) 0 0 0;z-index:44;background:rgba(0,0,0,.5);display:none}
  .cm-scrim.show{display:block}
  .cm-userchip .nm,.cm-userchip .rl{display:none}
}
