:root{--radius: 12px;--radius-sm: 8px;--radius-lg: 18px;--shadow-1: 0 1px 2px rgba(15, 18, 25, .06), 0 1px 3px rgba(15, 18, 25, .05);--shadow-2: 0 6px 24px rgba(15, 18, 25, .1);--space: 16px;--header-h: 64px;--sidebar-w: 248px;--accent: #6d5cff;--accent-strong: #5a47e0;--accent-soft: rgba(109, 92, 255, .12);--accent-contrast: #ffffff;--ok: #1f9d6b;--warn: #d98a00;--err: #e0484d;--ok-soft: rgba(31, 157, 107, .13);--warn-soft: rgba(217, 138, 0, .14);--err-soft: rgba(224, 72, 77, .13)}:root,html[data-theme=light]{--bg: #f6f7f9;--surface-1: #ffffff;--surface-2: #fbfbfd;--surface-3: #f1f2f5;--border-1: #e7e8ee;--border-2: #d9dbe3;--text-1: #15171c;--text-2: #5b6170;--text-3: #8b909e}html[data-theme=dark]{--bg: #0b0c0f;--surface-1: #15171c;--surface-2: #1b1e25;--surface-3: #21242c;--border-1: #262a33;--border-2: #333845;--text-1: #f1f3f7;--text-2: #a7adba;--text-3: #6f7686;--shadow-1: 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 8px 30px rgba(0, 0, 0, .55)}html[data-accent=violet]{--accent: #6d5cff;--accent-strong: #5a47e0;--accent-soft: rgba(109,92,255,.12)}html[data-accent=blue]{--accent: #2f7df6;--accent-strong: #1f63d6;--accent-soft: rgba(47,125,246,.12)}html[data-accent=emerald]{--accent: #12a36b;--accent-strong: #0d8557;--accent-soft: rgba(18,163,107,.12)}html[data-accent=amber]{--accent: #e08a1e;--accent-strong: #c4720f;--accent-soft: rgba(224,138,30,.14)}html[data-accent=rose]{--accent: #e64980;--accent-strong: #cf3169;--accent-soft: rgba(230,73,128,.12)}html[data-accent=slate]{--accent: #5b6472;--accent-strong: #444b57;--accent-soft: rgba(91,100,114,.14)}.stack{display:flex;flex-direction:column;gap:var(--space)}.row{display:flex;align-items:center;gap:12px}.row.wrap{flex-wrap:wrap}.spread{display:flex;align-items:center;justify-content:space-between;gap:12px}.grow{flex:1;min-width:0}.muted{color:var(--text-2)}.dim{color:var(--text-3)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.86em}.page{padding:clamp(16px,3vw,30px);max-width:1240px;margin:0 auto;width:100%}.page-head{margin-bottom:22px}.page-title{font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:700;margin:0 0 4px;letter-spacing:-.01em}.page-sub{color:var(--text-2);font-size:.92rem}.grid{display:grid;gap:var(--space)}.grid-stats{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}.grid-cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.split{grid-template-columns:1.4fr 1fr}@media (max-width: 860px){.split{grid-template-columns:1fr}}.card{background:var(--surface-1);border:1px solid var(--border-1);border-radius:var(--radius);box-shadow:var(--shadow-1)}.card-pad{padding:18px}.card-head{padding:16px 18px;border-bottom:1px solid var(--border-1);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-weight:650;font-size:.98rem}.stat{display:flex;flex-direction:column;gap:10px;padding:18px}.stat-top{display:flex;align-items:center;justify-content:space-between}.stat-ico{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}.stat-val{font-size:1.7rem;font-weight:700;letter-spacing:-.02em;line-height:1}.stat-label{color:var(--text-2);font-size:.85rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;border-radius:var(--radius-sm);border:1px solid var(--border-2);background:var(--surface-1);color:var(--text-1);font-weight:550;font-size:.9rem;cursor:pointer;transition:background .15s,border-color .15s,transform .05s,box-shadow .15s;white-space:nowrap}.btn:hover{background:var(--surface-3)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-contrast)}.btn-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:var(--surface-3)}.btn-danger{color:var(--err);border-color:transparent;background:transparent}.btn-danger:hover{background:var(--err-soft)}.btn-sm{height:32px;padding:0 11px;font-size:.82rem}.btn-icon{width:40px;padding:0}.btn:disabled{opacity:.55;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:6px}.label{font-size:.82rem;font-weight:550;color:var(--text-2)}.input,.select{height:42px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid var(--border-2);background:var(--surface-2);color:var(--text-1);font-size:.92rem;width:100%;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea.input{height:auto;min-height:84px;padding:10px 12px;resize:vertical}.badge{display:inline-flex;align-items:center;gap:5px;height:24px;padding:0 9px;border-radius:999px;font-size:.76rem;font-weight:600}.badge-ok{background:var(--ok-soft);color:var(--ok)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-err{background:var(--err-soft);color:var(--err)}.badge-neutral{background:var(--surface-3);color:var(--text-2)}.badge-accent{background:var(--accent-soft);color:var(--accent)}.dot{width:7px;height:7px;border-radius:50%;background:currentColor}.table-scroll{overflow-x:auto;border-radius:var(--radius)}table.tbl{width:100%;border-collapse:collapse;font-size:.9rem;min-width:520px}.tbl th{text-align:start;font-weight:600;color:var(--text-2);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;padding:12px 16px;border-bottom:1px solid var(--border-1)}.tbl td{padding:13px 16px;border-bottom:1px solid var(--border-1)}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--surface-2)}.bar{height:7px;border-radius:7px;background:var(--surface-3);overflow:hidden}.bar>i{display:block;height:100%;border-radius:7px;background:var(--accent);transition:width .4s ease}.bar.warn>i{background:var(--warn)}.bar.err>i{background:var(--err)}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent);font-weight:700;font-size:.85rem;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a0e80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:20px;z-index:100;animation:fade .15s ease}.modal{background:var(--surface-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);width:100%;max-width:460px;max-height:90vh;overflow:auto;animation:pop .16s ease}.modal-head{padding:18px 20px;border-bottom:1px solid var(--border-1);font-weight:650}.modal-body{padding:20px}.modal-foot{padding:16px 20px;border-top:1px solid var(--border-1);display:flex;justify-content:flex-end;gap:10px}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}.empty{text-align:center;padding:48px 20px;color:var(--text-2)}.empty svg{opacity:.4;margin-bottom:10px}.seg{display:inline-flex;background:var(--surface-3);border-radius:10px;padding:3px;gap:2px}.seg button{border:none;background:transparent;color:var(--text-2);height:30px;padding:0 12px;border-radius:8px;cursor:pointer;font-size:.82rem;font-weight:550}.seg button.active{background:var(--surface-1);color:var(--text-1);box-shadow:var(--shadow-1)}.swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent}.swatch.active{border-color:var(--text-1)}.switch{width:42px;height:24px;border-radius:999px;background:var(--surface-3);border:1px solid var(--border-2);cursor:pointer;padding:0;position:relative;transition:background .16s,border-color .16s}.switch>span{position:absolute;top:2px;inset-inline-start:2px;width:18px;height:18px;border-radius:50%;background:var(--text-3);transition:transform .16s,background .16s}.switch.on{background:var(--accent);border-color:var(--accent)}.switch.on>span{background:#fff;transform:translate(18px)}[dir=rtl] .switch.on>span{transform:translate(-18px)}.toast-wrap{position:fixed;bottom:22px;inset-inline-end:22px;display:flex;flex-direction:column;gap:10px;z-index:200}.toast{background:var(--surface-1);border:1px solid var(--border-1);border-inline-start:3px solid var(--accent);border-radius:10px;box-shadow:var(--shadow-2);padding:12px 16px;min-width:240px;animation:pop .16s ease}.toast.err{border-inline-start-color:var(--err)}.toast.ok{border-inline-start-color:var(--ok)}.app-shell{display:flex;min-height:100%}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface-1);border-inline-end:1px solid var(--border-1);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-brand{height:var(--header-h);display:flex;align-items:center;padding:0 20px;border-bottom:1px solid var(--border-1)}.sidebar-nav{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-2);font-size:.9rem;font-weight:500;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-3);color:var(--text-1)}.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-ico{display:grid;place-items:center}.sidebar-foot{padding:14px;border-top:1px solid var(--border-1)}.role-chip{text-transform:capitalize}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:var(--header-h);position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;padding:0 clamp(14px,3vw,26px);background:color-mix(in srgb,var(--bg) 82%,transparent);-webkit-backdrop-filter:saturate(140%) blur(10px);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--border-1)}.content{flex:1}.notif{position:relative}.notif-dot{position:absolute;top:4px;inset-inline-end:4px;min-width:16px;height:16px;padding:0 4px;background:var(--err);color:#fff;border-radius:999px;font-size:.64rem;font-weight:700;display:grid;place-items:center}.scrim{display:none}.notif-wrap{position:relative}.notif-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.notif-panel{position:absolute;top:calc(100% + 8px);inset-inline-end:0;z-index:50;width:min(360px,calc(100vw - 32px));max-height:70vh;display:flex;flex-direction:column;background:var(--surface-1);border:1px solid var(--border-1);border-radius:var(--radius-lg);box-shadow:var(--shadow-2);overflow:hidden;animation:pop .15s ease}.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-1)}.notif-list{overflow-y:auto}.notif-item{display:flex;gap:11px;padding:13px 14px;border-bottom:1px solid var(--border-1);cursor:pointer;transition:background .12s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-2)}.notif-item.unread{background:var(--accent-soft)}.notif-item.unread:hover{background:color-mix(in srgb,var(--accent-soft) 70%,var(--surface-3))}.notif-ico{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;background:var(--surface-3);color:var(--text-2)}.lvl-info .notif-ico{background:var(--accent-soft);color:var(--accent)}.lvl-warning .notif-ico{background:var(--warn-soft);color:var(--warn)}.lvl-error .notif-ico{background:var(--err-soft);color:var(--err)}.notif-title{font-size:.88rem;font-weight:600}.notif-body{font-size:.82rem;color:var(--text-2);margin-top:2px;line-height:1.4}.notif-time{font-size:.74rem;color:var(--text-3);margin-top:4px}.notif-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}.only-mobile{display:none!important}.only-desktop{display:block}@media (max-width: 920px){.sidebar{position:fixed;inset-inline-start:0;top:0;z-index:60;height:100vh;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow-2)}[dir=rtl] .sidebar{transform:translate(100%)}.sidebar.open{transform:translate(0)}.scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:55}.only-mobile{display:inline-flex!important}.only-desktop{display:none}}.login-wrap{display:grid;grid-template-columns:1.05fr 1fr;min-height:100vh}.login-aside{background:linear-gradient(150deg,var(--accent) 0%,var(--accent-strong) 100%);color:#fff;display:flex;align-items:center;padding:48px;position:relative;overflow:hidden}.login-aside:after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:#ffffff1f;top:-120px;inset-inline-end:-120px;filter:blur(10px)}.login-aside-inner{position:relative;max-width:420px}.login-aside .row span{color:#fff}.login-hero{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:750;line-height:1.12;margin:30px 0 16px;letter-spacing:-.02em}.login-hero-sub{font-size:1rem;line-height:1.6;opacity:.92;margin:0 0 26px}.login-badges{display:flex;flex-wrap:wrap;gap:8px}.login-badges .badge{background:#ffffff29;color:#fff}.login-main{display:flex;align-items:center;justify-content:center;padding:32px;background:var(--bg)}.login-card{width:100%;max-width:380px}.login-err{background:var(--err-soft);color:var(--err);border-radius:var(--radius-sm);padding:11px 14px;font-size:.85rem;margin-bottom:16px}.login-demo{margin-top:24px;padding-top:18px;border-top:1px solid var(--border-1);font-size:.8rem}@media (max-width: 860px){.login-wrap{grid-template-columns:1fr}.login-aside{display:none}}.dns-form{display:flex;flex-wrap:wrap;gap:12px;align-items:end}.dns-form .field{min-width:110px}.fx{display:flex;flex-direction:column;height:min(72vh,680px);border:1px solid var(--border-1);border-radius:var(--radius);overflow:hidden;background:var(--surface-1)}.fx-toolbar{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border-1);background:var(--surface-2);flex-wrap:wrap}.fx-navbtn{width:32px;height:32px;display:grid;place-items:center;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-2);cursor:pointer}.fx-navbtn:hover:not(:disabled){background:var(--surface-3);color:var(--text-1)}.fx-navbtn:disabled{opacity:.35;cursor:not-allowed}.fx-sep{width:1px;height:22px;background:var(--border-2);margin:0 4px}.fx-address{flex:1;min-width:140px;display:flex;align-items:center;gap:2px;height:32px;padding:0 10px;background:var(--surface-1);border:1px solid var(--border-2);border-radius:7px;overflow-x:auto;white-space:nowrap}.fx-crumb{display:inline-flex;align-items:center;gap:4px;padding:3px 7px;border-radius:5px;cursor:pointer;font-size:.84rem;color:var(--text-2)}.fx-crumb:hover{background:var(--surface-3);color:var(--text-1)}.fx-crumb-sep{color:var(--text-3);font-size:.7rem}.fx-search{height:32px;width:150px;padding:0 10px;border:1px solid var(--border-2);border-radius:7px;background:var(--surface-1);color:var(--text-1);font-size:.84rem}.fx-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.fx-body{flex:1;display:grid;grid-template-columns:200px 1fr;min-height:0}.fx-tree{border-inline-end:1px solid var(--border-1);overflow-y:auto;padding:8px;background:var(--surface-2)}.fx-tree-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);padding:6px 8px 4px;font-weight:600}.fx-tnode{-webkit-user-select:none;user-select:none}.fx-trow{display:flex;align-items:center;gap:6px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.85rem;color:var(--text-2)}.fx-trow:hover{background:var(--surface-3)}.fx-trow.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.fx-tcaret{width:14px;display:grid;place-items:center;color:var(--text-3);transition:transform .12s}.fx-tcaret.open{transform:rotate(90deg)}.fx-main{display:flex;flex-direction:column;min-width:0;overflow:hidden}.fx-files{flex:1;overflow:auto}.fx-dhead{display:grid;grid-template-columns:1fr 150px 110px 90px;position:sticky;top:0;background:var(--surface-2);border-bottom:1px solid var(--border-1);font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-3)}.fx-dhead>span{padding:8px 12px}.fx-drow{display:grid;grid-template-columns:1fr 150px 110px 90px;align-items:center;cursor:default;font-size:.86rem;border-bottom:1px solid color-mix(in srgb,var(--border-1) 55%,transparent)}.fx-drow>span{padding:8px 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fx-drow:hover{background:var(--surface-2)}.fx-drow.sel{background:var(--accent-soft)}.fx-name{display:flex;align-items:center;gap:10px}.fx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:6px;padding:12px}.fx-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 6px;border-radius:8px;cursor:default;text-align:center}.fx-tile:hover{background:var(--surface-2)}.fx-tile.sel{background:var(--accent-soft)}.fx-tile-name{font-size:.78rem;color:var(--text-1);word-break:break-word;line-height:1.25;max-width:100%}.fx-ico{display:grid;place-items:center}.fx-ico.folder{color:#e9b949}.fx-ico.code{color:var(--accent)}.fx-ico.image{color:#2f9e6b}.fx-ico.archive{color:#d98a3a}.fx-ico.doc{color:#4a8fd6}.fx-ico.file{color:var(--text-3)}.fx-status{display:flex;align-items:center;gap:14px;padding:6px 14px;border-top:1px solid var(--border-1);background:var(--surface-2);font-size:.78rem;color:var(--text-2)}.fx-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120}.fx-menu{position:fixed;z-index:121;min-width:184px;padding:6px;background:var(--surface-1);border:1px solid var(--border-1);border-radius:10px;box-shadow:var(--shadow-2);animation:pop .12s ease}.fx-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:transparent;color:var(--text-1);font-size:.86rem;border-radius:6px;cursor:pointer;text-align:start}.fx-menu-item:hover{background:var(--surface-3)}.fx-menu-item:disabled{opacity:.4;cursor:not-allowed}.fx-menu-item.danger{color:var(--err)}.fx-menu-item.danger:hover{background:var(--err-soft)}.fx-menu-item .mi-ico{display:grid;place-items:center;color:var(--text-2)}.fx-menu-item.danger .mi-ico{color:var(--err)}.fx-menu-sep{height:1px;background:var(--border-1);margin:5px 4px}.fx-drow,.fx-tile{-webkit-touch-callout:none}.fx-empty{display:grid;place-items:center;height:100%;color:var(--text-3);font-size:.9rem}@media (max-width: 720px){.fx-body{grid-template-columns:1fr}.fx-tree{display:none}.fx-dhead,.fx-drow{grid-template-columns:1fr 84px}.fx-dhead span:nth-child(2),.fx-drow span:nth-child(2),.fx-dhead span:nth-child(3),.fx-drow span:nth-child(3){display:none}.fx-search{width:120px;flex:1}}@font-face{font-family:Vazirmatn;src:url(/fonts/Vazirmatn-Variable.woff2) format("woff2 supports variations"),url(/fonts/Vazirmatn-Variable.woff2) format("woff2-variations");font-weight:100 900;font-style:normal;font-display:swap}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Vazirmatn,Tahoma,Arial,sans-serif;background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-weight:400}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:10px}::-webkit-scrollbar-track{background:transparent}
