:root{
  --bg:#f6f8ff;--card:rgba(255,255,255,.82);--card2:rgba(255,255,255,.92);--border:rgba(148,163,184,.22);--text:#0f172a;--muted:#64748b;--primary:#4f46e5;--primary2:#06b6d4;--danger:#ef4444;--success:#10b981;--shadow:0 24px 70px rgba(15,23,42,.12)
}
.dark{--bg:#020617;--card:rgba(15,23,42,.74);--card2:rgba(15,23,42,.88);--border:rgba(148,163,184,.16);--text:#f8fafc;--muted:#94a3b8;--shadow:0 24px 70px rgba(0,0,0,.45)}
*{font-family:Vazirmatn,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;scrollbar-width:thin;scrollbar-color:#94a3b8 transparent}
body.app-body{background:radial-gradient(circle at top right,rgba(79,70,229,.18),transparent 30%),radial-gradient(circle at bottom left,rgba(6,182,212,.16),transparent 28%),var(--bg);overflow-x:hidden}
.ltr{direction:ltr;text-align:left}.bg-orb{position:fixed;border-radius:9999px;filter:blur(30px);opacity:.28;pointer-events:none;animation:float 8s ease-in-out infinite}.orb-1{width:360px;height:360px;background:#4f46e5;right:-120px;top:-100px}.orb-2{width:280px;height:280px;background:#06b6d4;left:6%;top:20%;animation-delay:1.5s}.orb-3{width:220px;height:220px;background:#f472b6;left:-80px;bottom:4%;animation-delay:3s}
.sidebar{width:292px;min-height:100vh;position:sticky;top:0;flex-direction:column;padding:22px;background:var(--card);backdrop-filter:blur(22px);border-left:1px solid var(--border);box-shadow:18px 0 60px rgba(15,23,42,.05)}
.brand-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:24px;background:linear-gradient(135deg,rgba(79,70,229,.14),rgba(6,182,212,.10));border:1px solid var(--border);margin-bottom:24px}.brand-icon{width:52px;height:52px;display:grid;place-items:center;border-radius:18px;background:linear-gradient(135deg,var(--primary),var(--primary2));box-shadow:0 18px 35px rgba(79,70,229,.25);font-size:24px}.brand-title{font-weight:950;font-size:17px}.brand-subtitle{font-size:12px;color:var(--muted);direction:ltr;text-align:right}.nav-stack{display:flex;flex-direction:column;gap:8px}.nav-link{display:flex;align-items:center;gap:12px;border-radius:18px;padding:13px 14px;color:var(--text);transition:.22s ease;position:relative;overflow:hidden}.nav-link:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(79,70,229,.14),rgba(6,182,212,.09));opacity:0;transition:.22s}.nav-link:hover{transform:translateX(-4px)}.nav-link:hover:before{opacity:1}.nav-link span,.nav-link b{position:relative}.sidebar-footer{margin-top:auto;display:grid;gap:10px}.theme-toggle,.logout-btn,.icon-btn,.hamburger{border:1px solid var(--border);background:var(--card2);border-radius:18px;padding:12px 14px;transition:.2s;box-shadow:0 10px 24px rgba(15,23,42,.06)}.theme-toggle{display:flex;align-items:center;justify-content:center;gap:8px}.logout-btn{width:100%;color:#ef4444;font-weight:800}.theme-toggle:hover,.logout-btn:hover,.icon-btn:hover,.hamburger:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(15,23,42,.12)}
.mobile-overlay{position:fixed;inset:0;background:rgba(2,6,23,.55);z-index:40}.mobile-sidebar{position:fixed;right:0;top:0;bottom:0;width:285px;background:var(--card2);backdrop-filter:blur(20px);z-index:50;padding:20px;border-left:1px solid var(--border)}
.main-shell{flex:1;padding:20px;max-width:1500px;margin:0 auto;width:100%}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;border:1px solid var(--border);border-radius:28px;padding:16px 18px;background:var(--card);backdrop-filter:blur(22px);box-shadow:var(--shadow)}.topbar-title{font-size:22px;font-weight:950}.topbar-subtitle,.page-desc,.card-header p{font-size:13px;color:var(--muted);margin-top:4px}.topbar-actions{display:flex;align-items:center;gap:10px}.icon-btn{width:46px;height:46px;display:grid;place-items:center;font-size:20px}.hamburger{width:46px;height:46px}.user-chip{border:1px solid var(--border);background:var(--card2);border-radius:999px;padding:12px 16px;font-weight:800;direction:ltr}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px}.eyebrow{font-size:12px;font-weight:900;color:var(--primary);letter-spacing:.08em;text-transform:uppercase;direction:ltr}.page-title{font-size:30px;font-weight:950;letter-spacing:-.04em;margin-top:4px}.panel-card,.glass-card{background:var(--card);border:1px solid var(--border);border-radius:30px;padding:22px;box-shadow:var(--shadow);backdrop-filter:blur(22px);animation:rise .42s ease both}.card-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.card-header h3{font-size:18px;font-weight:950}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}.stat-card{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--border);border-radius:30px;padding:22px;box-shadow:var(--shadow);backdrop-filter:blur(22px);animation:rise .45s ease both;transition:.22s}.stat-card:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,rgba(79,70,229,.16),rgba(6,182,212,.10),transparent);opacity:.9}.stat-card>*{position:relative}.stat-card:hover{transform:translateY(-6px)}.stat-icon{width:46px;height:46px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(79,70,229,.18),rgba(6,182,212,.14));margin-bottom:18px}.stat-card span{display:block;color:var(--muted);font-size:13px;font-weight:700}.stat-card strong{display:block;font-size:42px;font-weight:950;line-height:1.1;margin-top:6px}.stat-card small{display:block;margin-top:8px;color:var(--muted);font-size:12px;direction:ltr;text-align:right}.delay-1{animation-delay:.03s}.delay-2{animation-delay:.08s}.delay-3{animation-delay:.13s}.delay-4{animation-delay:.18s}
.btn-primary,.btn-secondary,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:18px;padding:12px 20px;font-weight:900;transition:.22s;border:1px solid transparent}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:white;box-shadow:0 18px 35px rgba(79,70,229,.22)}.btn-primary:hover,.btn-secondary:hover,.btn-danger:hover{transform:translateY(-2px)}.btn-secondary{background:var(--card2);border-color:var(--border);color:var(--text);box-shadow:0 12px 28px rgba(15,23,42,.07)}.btn-danger{background:linear-gradient(135deg,#ef4444,#f97316);color:white;box-shadow:0 18px 35px rgba(239,68,68,.20)}
.label{display:block;font-size:13px;font-weight:900;margin-bottom:8px;color:var(--muted)}.form-grid{display:grid;gap:16px}.help-text{font-size:12px;color:var(--muted);margin-top:6px}.error-text{font-size:12px;color:#ef4444;margin-top:6px}.form-input,input[type=text],input[type=password],input[type=number],input[type=file],select,textarea{width:100%;border-radius:18px;border:1px solid var(--border);background:var(--card2);padding:13px 15px;outline:none;color:var(--text);transition:.2s}.form-input:focus,input:focus,select:focus,textarea:focus{box-shadow:0 0 0 5px rgba(79,70,229,.15);border-color:rgba(79,70,229,.65)}textarea{min-height:120px}.errorlist{background:rgba(239,68,68,.10);border:1px solid rgba(239,68,68,.2);color:#ef4444;padding:10px 12px;border-radius:16px;margin-bottom:12px;font-size:13px}
.table{width:100%;font-size:14px;border-collapse:separate;border-spacing:0 10px}.modern-table thead th{text-align:right;padding:12px;color:var(--muted);font-size:12px;font-weight:900}.modern-table tbody tr{background:var(--card2);box-shadow:0 10px 28px rgba(15,23,42,.05);transition:.2s}.modern-table tbody tr:hover{transform:scale(1.004)}.modern-table td{padding:14px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.modern-table td:first-child{border-right:1px solid var(--border);border-radius:18px 0 0 18px}.modern-table td:last-child{border-left:1px solid var(--border);border-radius:0 18px 18px 0}.bot-name{display:flex;align-items:center;gap:10px}.empty-state{text-align:center;color:var(--muted);font-weight:800}
.menu-builder-frame{background:rgba(148,163,184,.08);border:1px dashed var(--border);border-radius:26px;padding:16px}.menu-tree{display:grid;gap:10px;min-height:18px}.child-tree{margin-top:10px;margin-right:28px;padding-right:16px;border-right:2px dashed rgba(148,163,184,.35)}.menu-node{list-style:none}.menu-row{display:flex;align-items:center;gap:12px;background:var(--card2);border:1px solid var(--border);border-radius:22px;padding:12px;box-shadow:0 12px 30px rgba(15,23,42,.06);transition:.22s}.menu-row:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(15,23,42,.11)}.drag-handle{width:42px;height:42px;display:grid;place-items:center;border-radius:15px;background:linear-gradient(135deg,rgba(79,70,229,.14),rgba(6,182,212,.12));font-size:20px;user-select:none}.menu-title-wrap{display:grid;gap:2px}.menu-title{font-weight:950}.menu-meta{font-size:11px;color:var(--muted);direction:ltr;text-align:right}.row-actions{margin-right:auto;display:flex;align-items:center;gap:10px}.action-edit,.action-delete{font-size:13px;font-weight:900;border-radius:999px;padding:7px 11px;transition:.2s}.action-edit{color:#2563eb;background:rgba(37,99,235,.10)}.action-delete{color:#ef4444;background:rgba(239,68,68,.10)}.badge{font-size:12px;font-weight:900;border-radius:999px;background:rgba(148,163,184,.16);border:1px solid var(--border);padding:6px 11px;white-space:nowrap}.badge-success{background:rgba(16,185,129,.12);color:#10b981;border-color:rgba(16,185,129,.22)}.badge-danger{background:rgba(239,68,68,.12);color:#ef4444;border-color:rgba(239,68,68,.22)}.sortable-ghost{opacity:.35}.sortable-chosen .menu-row{outline:3px solid rgba(79,70,229,.20)}
.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 440px;align-items:center;gap:40px;padding:34px;position:relative;z-index:2}.login-visual{color:var(--text);max-width:620px;margin-right:auto}.login-logo{width:96px;height:96px;display:grid;place-items:center;border-radius:34px;background:linear-gradient(135deg,var(--primary),var(--primary2));font-size:46px;box-shadow:0 30px 70px rgba(79,70,229,.28);margin-bottom:24px}.login-visual h1{font-size:52px;font-weight:950;letter-spacing:-.06em}.login-visual p{font-size:18px;color:var(--muted);line-height:2;margin-top:12px}.login-card{background:var(--card);border:1px solid var(--border);border-radius:34px;padding:32px;box-shadow:var(--shadow);backdrop-filter:blur(24px)}.login-card h2{font-size:30px;font-weight:950}.login-card p{color:var(--muted);font-size:13px;margin-top:4px}.toast-message{background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.25);color:#10b981;border-radius:20px;padding:14px 16px;font-weight:800;animation:rise .32s ease both}
.animate-rise{animation:rise .45s ease both}.animate-fade-down{animation:fadeDown .42s ease both}.animate-float{animation:floatSoft 5s ease-in-out infinite}@keyframes rise{from{opacity:0;transform:translateY(18px) scale(.985)}to{opacity:1;transform:none}}@keyframes fadeDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:none}}@keyframes float{0%,100%{transform:translate(0,0)}50%{transform:translate(16px,18px)}}@keyframes floatSoft{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.login-page{grid-template-columns:1fr}.login-visual{display:none}.main-shell{padding:14px}.page-head{align-items:stretch;flex-direction:column}.topbar-subtitle{display:none}}
@media(max-width:640px){.stats-grid{grid-template-columns:1fr}.topbar{border-radius:22px}.panel-card,.glass-card{border-radius:24px;padding:16px}.page-title{font-size:25px}.row-actions{width:100%;margin-right:0}.menu-row{flex-wrap:wrap}.login-page{padding:16px}.login-card{padding:22px;border-radius:28px}.user-chip{display:none}}

/* Emoji picker for menu title/text fields */
.field-label-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.field-label-row .label{margin-bottom:0}.emoji-field-hint{font-size:11px;font-weight:900;direction:ltr;color:var(--muted);background:rgba(148,163,184,.12);border:1px solid var(--border);border-radius:999px;padding:5px 9px}.emoji-input-shell{position:relative}.emoji-input-shell input,.emoji-input-shell textarea{padding-left:58px}.emoji-trigger{position:absolute;left:10px;top:10px;width:40px;height:40px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(135deg,rgba(79,70,229,.10),rgba(6,182,212,.09));display:grid;place-items:center;font-size:20px;transition:.2s;box-shadow:0 10px 24px rgba(15,23,42,.06);z-index:3}.emoji-trigger:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 14px 32px rgba(15,23,42,.12)}.emoji-panel{position:absolute;left:0;top:calc(100% + 10px);width:min(360px,calc(100vw - 42px));background:var(--card2);border:1px solid var(--border);border-radius:24px;box-shadow:0 28px 80px rgba(15,23,42,.22);backdrop-filter:blur(24px);padding:14px;z-index:100;animation:rise .18s ease both}.emoji-panel-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.emoji-panel-title strong{font-size:13px;font-weight:950}.emoji-close{width:30px;height:30px;border-radius:10px;background:rgba(148,163,184,.12);border:1px solid var(--border);display:grid;place-items:center;font-weight:900}.emoji-tabs{display:flex;gap:7px;overflow:auto;margin-bottom:10px;padding-bottom:3px}.emoji-tab{white-space:nowrap;border:1px solid var(--border);background:rgba(148,163,184,.10);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900;transition:.18s}.emoji-tab.active,.emoji-tab:hover{background:linear-gradient(135deg,rgba(79,70,229,.18),rgba(6,182,212,.14));transform:translateY(-1px)}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;max-height:235px;overflow:auto;padding:3px}.emoji-item{height:34px;border-radius:12px;display:grid;place-items:center;font-size:21px;background:rgba(148,163,184,.08);border:1px solid transparent;transition:.14s}.emoji-item:hover{background:rgba(79,70,229,.14);border-color:rgba(79,70,229,.22);transform:scale(1.12)}.emoji-search{width:100%;margin-bottom:10px;border-radius:15px!important;padding:10px 12px!important;font-size:13px}.emoji-note{font-size:11px;color:var(--muted);margin-top:10px;line-height:1.8}.dark .emoji-panel{box-shadow:0 28px 80px rgba(0,0,0,.48)}@media(max-width:640px){.emoji-grid{grid-template-columns:repeat(7,1fr)}.emoji-panel{left:auto;right:0}}
