:root{color-scheme:dark;font-family:Inter,Noto Sans SC,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#050814;color:#f1f5f9;--bg-primary: #050814;--bg-secondary: #0a0f24;--panel-bg: rgba(10, 15, 30, .7);--panel-border: rgba(99, 102, 241, .15);--panel-border-glow: rgba(99, 102, 241, .3);--primary-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--primary-hover-gradient: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #9333ea 100%);--text-primary: #f8fafc;--text-muted: #94a3b8;--text-subtle: #64748b;--cyan: #06b6d4;--blue: #3b82f6;--indigo: #6366f1;--green: #10b981;--amber: #f59e0b;--red: #ef4444;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 10px 30px rgba(0, 0, 0, .4);--shadow-lg: 0 20px 50px rgba(0, 0, 0, .6);--glow-shadow: 0 0 20px rgba(99, 102, 241, .2);--border-radius-sm: 6px;--border-radius-md: 12px;--border-radius-lg: 16px;--sidebar-width: 280px;--transition-normal: all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast: all .15s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff05;border-radius:var(--border-radius-sm)}::-webkit-scrollbar-thumb{background:#6366f12e;border-radius:var(--border-radius-sm);border:1px solid rgba(255,255,255,.05)}::-webkit-scrollbar-thumb:hover{background:#6366f159}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-height:100vh;background-color:var(--bg-primary);background-image:radial-gradient(circle at 10% 20%,rgba(99,102,241,.08) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(139,92,246,.08) 0%,transparent 40%),linear-gradient(180deg,#050814,#0a0d1d);background-attachment:fixed;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:linear-gradient(rgba(99,102,241,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.03) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(circle at center,black,transparent 80%);mask-image:radial-gradient(circle at center,black,transparent 80%);z-index:1}button,input,select{font-family:inherit;font-size:14px}button{cursor:pointer;border:none;outline:none;transition:var(--transition-normal)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;z-index:2}.login-panel{position:relative;width:100%;max-width:440px;padding:40px;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg),var(--glow-shadow);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);overflow:hidden;transition:var(--transition-normal)}.login-panel:hover{border-color:var(--panel-border-glow);box-shadow:var(--shadow-lg),0 0 30px #6366f159}.login-panel:after{content:"";position:absolute;top:-50px;right:-50px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.2) 0%,transparent 70%);pointer-events:none}.login-panel h1{font-size:28px;font-weight:800;text-align:center;margin-bottom:8px;background:linear-gradient(135deg,#fff,#c7d2fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.login-panel p{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:32px}label{display:block;margin-bottom:20px;color:var(--text-muted);font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.input-with-icon{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-subtle);display:flex;align-items:center;pointer-events:none}.input-with-icon input{padding-left:42px;margin-top:8px}input,select{display:block;width:100%;margin-top:8px;height:48px;padding:0 16px;border:1px solid rgba(255,255,255,.1);border-radius:var(--border-radius-md);color:var(--text-primary);background:#ffffff08;box-shadow:inset 0 2px 4px #0003;transition:var(--transition-normal)}input::placeholder{color:var(--text-subtle)}input:focus,select:focus{outline:none;background:#ffffff0f;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf640,inset 0 2px 4px #0003}.primary{display:inline-flex;align-items:center;justify-content:center;height:48px;width:100%;padding:0 24px;border-radius:var(--border-radius-md);color:#fff;background:var(--primary-gradient);font-weight:700;letter-spacing:.5px;box-shadow:0 4px 15px #6366f166;transition:var(--transition-normal);position:relative;overflow:hidden}.primary:hover:not(:disabled){background:var(--primary-hover-gradient);transform:translateY(-1px);box-shadow:0 6px 20px #6366f180}.primary:active:not(:disabled){transform:translateY(1px)}.primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.page-actions{display:flex;align-items:center;gap:12px}.module-tabs{display:inline-flex;gap:6px;padding:6px;margin-bottom:20px;border:1px solid var(--panel-border);border-radius:var(--border-radius-md);background:#ffffff08}.module-tabs button{height:38px;padding:0 18px;border-radius:var(--border-radius-sm);color:var(--text-muted);background:transparent;font-weight:700}.module-tabs button.active{color:var(--text-primary);background:#6366f138;box-shadow:inset 0 0 0 1px #6366f140}.danger-action{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 18px;border:1px solid rgba(239,68,68,.35);border-radius:var(--border-radius-md);color:var(--red);background:#ef44441f;font-weight:700}.secondary-action{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 18px;border:1px solid rgba(148,163,184,.24);border-radius:var(--border-radius-md);color:var(--text-primary);background:#ffffff0d;font-weight:700}.secondary-action:hover:not(:disabled){background:#ffffff14;border-color:#94a3b861}.secondary-action:disabled{opacity:.5;cursor:not-allowed}.ghost-action{display:inline-flex;align-items:center;justify-content:center;height:48px;padding:0 18px;border:1px solid transparent;border-radius:var(--border-radius-md);color:var(--text-muted);background:transparent;font-weight:700}.ghost-action:hover:not(:disabled){color:var(--text-primary);background:#ffffff0a}.danger-action:hover:not(:disabled){background:#ef44442e;border-color:#ef444480}.danger-action:disabled{opacity:.5;cursor:not-allowed}.app-shell{position:relative;min-height:100vh;display:grid;grid-template-columns:var(--sidebar-width) 1fr;z-index:2}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:32px 20px;background:#080c1cd9;border-right:1px solid var(--panel-border);box-shadow:10px 0 30px #0000004d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:10}.brand{font-size:20px;font-weight:900;margin-bottom:40px;padding-left:12px;position:relative;background:linear-gradient(135deg,#fff,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.5px}.brand:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:20px;border-radius:2px;background:var(--primary-gradient);box-shadow:0 0 10px #8b5cf699}.sidebar nav{display:flex;flex-direction:column;gap:8px}.sidebar nav button{display:flex;align-items:center;gap:12px;height:48px;padding:0 16px;border-radius:var(--border-radius-md);text-align:left;color:var(--text-muted);background:transparent;font-weight:600;transition:var(--transition-normal)}.sidebar nav button:hover{color:var(--text-primary);background:#ffffff08;transform:translate(4px)}.sidebar nav button.active{color:#fff;background:#6366f126;border:1px solid rgba(99,102,241,.25);box-shadow:inset 0 0 8px #6366f11a}.sidebar nav button svg{width:18px;height:18px;opacity:.7}.sidebar nav button.active svg{opacity:1;color:#8b5cf6}.session-card{margin-top:auto;padding:20px;border:1px solid var(--panel-border);border-radius:var(--border-radius-md);background:#ffffff05;display:flex;flex-direction:column;gap:12px;box-shadow:inset 0 1px #ffffff0d}.session-card strong{color:var(--text-primary);font-size:15px;font-weight:700}.session-card span{color:var(--text-muted);font-size:13px}.session-card button{height:38px;border:1px solid rgba(255,255,255,.1);border-radius:var(--border-radius-sm);color:var(--text-primary);background:#ffffff0d;font-weight:600;transition:var(--transition-normal)}.session-card button:hover{background:#ef444426;border-color:#ef44444d;color:#fca5a5}main{min-width:0;width:100%}.page{max-width:1280px;margin:0 auto;padding:40px;height:100vh;display:flex;flex-direction:column;overflow:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:20px}.page-header h1{font-size:32px;font-weight:900;letter-spacing:-.5px;background:linear-gradient(135deg,#fff,#c7d2fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-header .primary{width:auto}.notice,.error,.empty,.tree-panel,.table,.user-form{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);overflow:hidden;transition:var(--transition-normal)}.notice,.error{margin-bottom:24px;padding:16px 20px;display:flex;align-items:center;gap:12px;font-weight:500}.notice{color:#a7f3d0;background:#10b9811a;border-color:#10b98133}.error{color:#fecaca;background:#ef44441a;border-color:#ef444433}.empty{min-height:380px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;gap:16px}.empty h2{font-size:22px;font-weight:800;color:var(--text-primary)}.empty p{max-width:480px;color:var(--text-muted);line-height:1.6;font-size:14px}.empty button.primary{width:auto;margin-top:8px}.tree-panel{padding:16px;max-height:calc(100vh - 180px);overflow:auto}.tree-node{margin-top:4px}.tree-row{display:flex;align-items:center;gap:12px;min-height:48px;padding:6px 12px;border-radius:var(--border-radius-md);transition:var(--transition-fast)}.tree-row:hover{background:#ffffff08}.tree-row.expandable{cursor:pointer}.tree-row.expandable:hover{background:#6366f11a}.disclosure{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(139,92,246,.38);border-radius:var(--border-radius-sm);background:#6366f129;color:#c4b5fd;font-size:14px;font-weight:700;flex-shrink:0}.disclosure:hover:not(:disabled){border-color:var(--indigo);background:#6366f126;color:#8b5cf6}.disclosure:disabled{opacity:.35;background:transparent;border-color:transparent;cursor:default}.node-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.node-title{font-weight:700;color:var(--text-primary);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-sub{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-children{margin-left:12px;padding-left:16px;border-left:1px dashed rgba(255,255,255,.08)}.table{width:100%;display:flex;flex-direction:column}.table-head{display:grid;grid-template-columns:80px 140px 140px 220px 1fr;align-items:center;gap:16px;height:52px;padding:0 24px;background:#ffffff05;border-bottom:1px solid var(--panel-border);color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.table-row{display:grid;grid-template-columns:80px 140px 140px 220px 1fr;align-items:center;gap:16px;min-height:64px;padding:12px 24px;border-bottom:1px solid rgba(255,255,255,.04);transition:var(--transition-fast);color:var(--text-primary)}.table-row:hover{background:#ffffff04}.table-row:last-child{border-bottom:none}.table-head>span,.table-row>span{min-width:0}.job-error-cell{display:-webkit-box;max-height:42px;overflow:hidden;font-size:13px;line-height:1.6;overflow-wrap:anywhere;-webkit-box-orient:vertical;-webkit-line-clamp:2}.job-error-cell[title]:not([title=""]){cursor:help}.sites-panel{display:flex;flex:1;min-height:0;flex-direction:column;gap:12px}.filter-container{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--panel-border);border-radius:var(--border-radius-md);background:var(--panel-bg);box-shadow:var(--shadow-sm)}.filter-main-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;width:100%}.filter-main-bar input{margin:0;height:38px;padding:0 12px;flex:1;min-width:140px}.filter-main-bar input[name=q]{flex:2;min-width:200px}.filter-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.filter-actions button{height:38px;padding:0 16px}.advanced-toggle-btn{display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 14px;border:1px solid rgba(99,102,241,.25);border-radius:var(--border-radius-md);color:#c7d2fe;background:#6366f114;font-weight:700;transition:var(--transition-fast)}.advanced-toggle-btn:hover{background:#6366f126;border-color:var(--indigo)}.advanced-toggle-btn.active{background:#6366f133;border-color:var(--indigo);color:#fff}.filter-advanced-panel{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding-top:12px;border-top:1px dashed rgba(255,255,255,.08);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.range-group{display:flex;flex-direction:column;gap:6px}.range-group-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.range-inputs{display:flex;align-items:center;gap:8px}.range-inputs input{margin:0;height:38px;padding:0 12px;flex:1;text-align:center}.range-separator{color:var(--text-subtle);font-weight:500;font-size:14px}.site-list-summary{color:var(--text-muted);font-size:13px;font-weight:600}.site-list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.site-list-toolbar-left,.site-scope-tabs,.site-row-actions{display:flex;align-items:center}.site-list-toolbar-left{gap:14px;min-width:0}.site-scope-tabs{gap:4px;padding:3px;border:1px solid var(--panel-border);border-radius:var(--border-radius-sm);background:#ffffff05}.site-scope-tabs button{width:auto;height:30px;padding:0 10px;border:0;border-radius:4px;color:var(--text-muted);background:transparent;font-size:12px;font-weight:700}.site-scope-tabs button.active{color:var(--text-primary);background:#8b5cf638}.site-submit-button{width:auto;height:38px;padding:0 16px}.submit-site-modal{width:min(100%,520px)}.table-panel{flex:1;min-height:280px;max-height:calc(100vh - 280px);overflow:auto;border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);background:var(--panel-bg)}.table-panel .table{background:transparent;border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.site-table{flex:1;min-height:280px;max-height:calc(100vh - 330px);overflow:auto;border:1px solid var(--panel-border);border-radius:var(--border-radius-lg);background:var(--panel-bg)}.site-table{overflow:auto}.site-table-head,.site-table-row{display:grid;grid-template-columns:200px repeat(4,minmax(100px,1fr)) 110px 110px 120px;gap:12px;align-items:center;padding:14px 18px}.site-table-head{position:sticky;top:0;z-index:2;color:var(--text-muted);background:#ffffff06;border-bottom:1px solid var(--panel-border);font-size:12px;font-weight:800}.site-sort-header{display:inline-flex;align-items:center;gap:6px;width:fit-content;margin:0;padding:0;border:0;color:inherit;background:transparent;font:inherit;font-weight:inherit;text-align:left;cursor:pointer;transition:var(--transition-fast)}.site-sort-header:hover,.site-sort-header.active{color:var(--text-primary)}.site-sort-header .sort-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;color:var(--text-subtle);opacity:.35;transition:transform .2s ease,opacity .2s ease,color .2s ease}.site-sort-header:hover .sort-icon{opacity:.8;color:#a78bfa}.site-sort-header.active .sort-icon{opacity:1;color:#a78bfa}.site-sort-header .sort-icon.active.asc svg{transform:rotate(180deg)}.site-sort-header .sort-icon svg{width:12px;height:12px;transition:transform .2s ease}.site-table-row{width:100%;border:0;color:var(--text-primary);text-align:left;background:transparent;min-height:64px;border-bottom:1px solid rgba(255,255,255,.04);font-size:13px}.site-table-row:hover{background:#ffffff05}.site-table-row:last-child{border-bottom:none}.site-table-row>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-domain{color:var(--text-primary);font-weight:800}.site-domain a{color:inherit;text-decoration:none}.site-domain a:hover{color:#c4b5fd;text-decoration:underline}.site-status{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border:1px solid transparent;border-radius:999px;font-size:12px;font-weight:700}.site-status.available{color:#a7f3d0;border-color:#10b98159;background:#10b9811f}.site-status.unavailable{color:#fecaca;border-color:#ef444459;background:#ef44441f}.site-status.unknown{color:var(--text-muted);border-color:#94a3b840;background:#94a3b814}.row-action-button{height:34px;padding:0 12px;border:1px solid rgba(99,102,241,.3);border-radius:var(--border-radius-sm);color:#c7d2fe;background:#6366f11f;font-weight:700}.site-row-actions{gap:7px}.favorite-button,.favorite-detail-button{width:auto;height:34px;padding:0 10px;border:1px solid rgba(148,163,184,.25);border-radius:var(--border-radius-sm);color:var(--text-muted);background:#ffffff06;font-weight:800}.favorite-button{min-width:34px;padding:0;font-size:16px}.favorite-button.active,.favorite-detail-button.active{color:#fcd34d;border-color:#facc1566;background:#facc151f}.row-action-button:disabled{opacity:.55;cursor:not-allowed}.pagination-actions{display:flex;align-items:center;justify-content:space-between;color:var(--text-muted);font-size:13px;font-weight:700}.pagination-left,.pagination-right{display:flex;align-items:center;gap:12px}.pagination-right{justify-content:flex-end}.pagination-field{display:inline-flex;align-items:center;gap:8px;margin:0;color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:0;text-transform:none}.pagination-field select,.pagination-field input{width:86px;height:36px;margin:0;padding:0 10px}.site-table-skeleton{display:grid;min-height:100%;align-content:start;gap:12px;padding:16px}.site-table-skeleton-row{display:grid;grid-template-columns:1.2fr 2fr 1fr 1fr;gap:16px;align-items:center;min-height:56px;padding:0 16px;border-radius:var(--border-radius-md);background:#ffffff06}.site-table-skeleton-row span{height:14px;border-radius:4px;background:#ffffff0f;animation:skeleton-pulse 1.5s infinite ease-in-out}.site-table-skeleton-row span:nth-child(2){width:72%}.site-table-skeleton-row span:nth-child(3),.site-table-skeleton-row span:nth-child(4){width:55%}.site-detail-modal{width:min(100%,1000px);max-height:calc(100vh - 48px);display:flex;flex-direction:column}.site-detail-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:16px;overflow:auto}.site-detail-item{display:flex;flex-direction:column;gap:6px;min-width:0;min-height:74px;padding:10px 12px;border:1px solid rgba(255,255,255,.07);border-radius:var(--border-radius-sm);background:#ffffff06;position:relative}.site-detail-item.wide,.site-detail-actions{grid-column:1 / -1}.site-detail-item.wide{display:flex;flex-direction:row;align-items:flex-start;gap:16px;min-height:0}.site-detail-item.wide span{flex:0 0 100px;margin-top:2px}.site-detail-item span{color:var(--text-muted);font-size:12px;font-weight:700}.site-detail-item strong{color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.45;overflow-wrap:anywhere}.site-detail-link{color:#c4b5fd;text-decoration:none}.site-detail-link:hover{color:#ddd6fe;text-decoration:underline}.site-detail-item.wide strong{flex:1;min-width:0;max-height:none;overflow:hidden;line-height:1.6}.clamp-text{display:-webkit-box!important;-webkit-box-orient:vertical!important;overflow:hidden!important;text-overflow:ellipsis!important;word-break:break-word!important;white-space:pre-wrap!important}.site-detail-item.has-clamp{transition:border-color .15s ease,background-color .15s ease}.site-detail-item.has-clamp:hover{z-index:10;border-color:#8b5cf659;background:#8b5cf60a}.custom-tooltip{visibility:hidden;opacity:0;position:absolute;left:116px;z-index:1000;width:calc(100% - 130px);min-width:250px;max-width:600px;max-height:280px;overflow-y:auto;background:#1e293b;border:1px solid rgba(139,92,246,.5);border-radius:var(--border-radius-md);padding:10px 14px;box-shadow:0 10px 30px #000000bf,0 0 15px #8b5cf640;color:#f1f5f9;font-size:13px;font-weight:500;line-height:1.5;white-space:pre-wrap;word-break:break-word;transition:opacity .15s ease,transform .15s ease,visibility .15s ease;pointer-events:none}.custom-tooltip:before{content:"";position:absolute;left:30px;border-style:solid;display:block;width:0;z-index:1001}.custom-tooltip:after{content:"";position:absolute;left:0;right:0;background:transparent}.custom-tooltip.position-above{bottom:calc(100% - 6px);transform:translateY(5px)}.custom-tooltip.position-above:before{bottom:-6px;border-width:6px 6px 0;border-color:#1e293b transparent transparent}.custom-tooltip.position-above:after{bottom:-10px;height:10px}.site-detail-item.has-clamp:hover .custom-tooltip.position-above,.custom-tooltip.position-above:hover{visibility:visible;opacity:1;transform:translateY(0);pointer-events:auto}.custom-tooltip.position-below{top:calc(100% - 6px);transform:translateY(-5px)}.custom-tooltip.position-below:before{top:-6px;border-width:0 6px 6px;border-color:transparent transparent #1e293b}.custom-tooltip.position-below:after{top:-10px;height:10px}.site-detail-item.has-clamp:hover .custom-tooltip.position-below,.custom-tooltip.position-below:hover{visibility:visible;opacity:1;transform:translateY(0);pointer-events:auto}.site-detail-actions{margin-top:2px}.table-head.users,.table-row.users{grid-template-columns:1.2fr 1.2fr 120px 200px 140px}.status{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:0 12px;border-radius:9999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent}.status.success{background:#10b9811a;color:#34d399;border-color:#10b98133}.status.failed{background:#ef44441a;color:#fca5a5;border-color:#ef444433}.status.running{background:#f59e0b1a;color:#fbbf24;border-color:#f59e0b33}.all-modules{display:inline-flex;align-items:center;padding:4px 10px;background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--border-radius-sm);color:#a5b4fc;font-size:12px;font-weight:600}.user-form{display:grid;grid-template-columns:1fr 1fr 1fr auto auto;gap:16px;align-items:center;padding:24px;margin-bottom:24px}.user-form input,.user-form select{margin-top:0}.user-form .check{display:flex;align-items:center;gap:10px;margin-bottom:0;text-transform:none;font-size:14px;font-weight:500;color:var(--text-muted);cursor:pointer}.user-form .check input{width:18px;height:18px;accent-color:#8b5cf6;margin-top:0}.table-row.users button{height:38px;padding:0 16px;border:1px solid rgba(255,255,255,.1);border-radius:var(--border-radius-sm);color:var(--text-primary);background:#ffffff08;font-weight:600;transition:var(--transition-fast)}.table-row.users button:hover:not(:disabled){border-color:var(--indigo);background:#6366f11a;color:#a5b4fc}.table-row.users button:disabled{opacity:.4;cursor:not-allowed}.user-name{display:flex;align-items:center;gap:12px;font-weight:700}.user-avatar{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex:0 0 32px;border-radius:50%;color:#fff;font-size:13px;font-weight:800;box-shadow:0 2px 10px #00000026}.user-avatar.admin{background:linear-gradient(135deg,#f59e0b,#ef4444)}.user-avatar.sub-user{background:linear-gradient(135deg,#6366f1,#a855f7)}.status.admin-role{color:var(--amber);border-color:#f59e0b3d;background:#f59e0b14}.status.super-admin-role{color:#fbbf24;border-color:#fbbf245c;background:#f59e0b1f}.status.sub-role{color:#a5b4fc;border-color:#6366f13d;background:#6366f114}.module-config-button{min-width:150px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.permission-dot{width:7px;height:7px;border-radius:50%;background:var(--text-subtle)}.permission-dot.enabled{background:var(--green);box-shadow:0 0 8px #10b981bf}.button-arrow{color:var(--text-muted);font-size:20px;line-height:1}.row-actions{display:flex;flex-wrap:wrap;gap:8px}.table-row.users button.danger-button{color:#fca5a5;border-color:#ef44443d}.table-row.users button.danger-button:hover:not(:disabled){color:#fee2e2;border-color:#ef44448c;background:#ef444421}.account-modal-layer{position:fixed;z-index:100;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#020617b8;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.account-modal{width:min(100%,480px);overflow:hidden;border:1px solid rgba(139,92,246,.36);border-radius:var(--border-radius-lg);background:#0b1024;box-shadow:0 24px 80px #000000a6,0 0 36px #6366f126}.account-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 20px;border-bottom:1px solid rgba(255,255,255,.07)}.account-modal-header h2{color:var(--text-primary);font-size:20px;font-weight:800}.account-modal-header p{margin-top:6px;color:var(--text-muted);font-size:14px}.account-modal-error{margin:20px 24px 0;padding:12px 14px;border:1px solid rgba(239,68,68,.34);border-radius:var(--border-radius-sm);color:#fecaca;background:#ef44441a;font-size:13px;font-weight:600;line-height:1.5}.modal-close{width:32px;height:32px;border-radius:50%;color:var(--text-muted);background:#ffffff0d;font-size:23px;line-height:1}.modal-close:hover{color:var(--text-primary);background:#ffffff1f}.account-modal-body{display:grid;gap:18px;padding:24px}.account-modal-body>label{margin:0;color:var(--text-muted);font-size:13px;font-weight:600;letter-spacing:0;text-transform:none}.account-modal-body input,.account-modal-body select{margin-top:8px}.permission-option{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1px solid rgba(99,102,241,.22);border-radius:var(--border-radius-md);background:#6366f10f;cursor:pointer}.module-permissions{display:grid;gap:10px}.permission-option input{width:18px;height:18px;flex:0 0 18px;margin:1px 0 0;accent-color:#8b5cf6}.permission-option span{display:grid;gap:4px}.permission-option strong{color:var(--text-primary);font-size:14px}.permission-option small{color:var(--text-muted);font-size:12px;font-weight:400;line-height:1.5}.account-modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:6px}.account-modal-actions button:not(.primary){height:48px;padding:0 20px;border:1px solid rgba(255,255,255,.12);border-radius:var(--border-radius-md);color:var(--text-primary);background:#ffffff08;font-weight:600}.account-modal-actions .primary{width:auto}.account-modal-actions .danger-primary{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 15px #ef444452}.delete-message{color:#fecaca;line-height:1.7}.password-editor{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#ffffff03;border-top:1px solid rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.03)}.password-editor input{margin-top:0;max-width:300px}.password-editor button{height:48px;padding:0 20px;border-radius:var(--border-radius-md);font-weight:600}.password-editor button:not(.primary){background:#ffffff08;border:1px solid rgba(255,255,255,.1);color:var(--text-primary)}.password-editor button:not(.primary):hover{background:#ffffff14}.mobile-menu-trigger,.mobile-menu-backdrop{display:none}@media(max-width:1024px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:15px 0 40px #00000080}.sidebar.mobile-open{transform:translate(0)}.mobile-menu-trigger{display:flex;align-items:center;justify-content:center;position:fixed;top:16px;left:16px;width:44px;height:44px;z-index:99;border-radius:var(--border-radius-md);background:var(--bg-secondary);border:1px solid var(--panel-border);color:var(--text-primary);box-shadow:var(--shadow-md),0 0 15px #6366f126;font-size:20px}.mobile-menu-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#050814cc;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:9}.page{padding:80px 20px 40px;height:auto;min-height:100vh;overflow:visible}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header .primary{width:100%}.page-actions{width:100%;flex-direction:column-reverse;align-items:stretch}.danger-action,.page-actions .secondary-action{width:100%}.module-tabs{width:100%;display:grid;grid-template-columns:1fr 1fr}.filter-main-bar{flex-direction:column;align-items:stretch}.filter-main-bar input{width:100%;flex:none}.filter-actions{margin-left:0;width:100%;justify-content:stretch}.filter-actions button,.filter-actions .advanced-toggle-btn{flex:1}.filter-advanced-panel{grid-template-columns:1fr}.site-list-toolbar,.site-list-toolbar-left{align-items:stretch;flex-direction:column}.site-scope-tabs{overflow-x:auto}.site-table-head{display:none}.site-table-row{grid-template-columns:1fr;gap:10px;padding:18px}.site-table-row>span{display:flex;justify-content:space-between;gap:16px;white-space:normal}.site-table-row>span[data-label]:before{content:attr(data-label);flex:0 0 96px;color:var(--text-muted);font-size:12px;font-weight:700}.pagination-actions{justify-content:stretch;flex-direction:column;align-items:stretch}.pagination-left,.pagination-right{justify-content:stretch;flex-wrap:wrap}.site-table-skeleton-row,.site-detail-body{grid-template-columns:1fr}.table-head{display:none}.table-row,.table-row.users{grid-template-columns:1fr;gap:12px;padding:20px}.table-row>span,.table-row>button{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%}.table-row>span[data-label]:before,.table-row>button[data-label]:before{content:attr(data-label);color:var(--text-muted);font-size:13px;font-weight:600}.table-row>.status{width:100%;justify-content:space-between}.table-row>.status:before{content:attr(data-label);color:var(--text-muted);font-size:13px;font-weight:600;margin-right:auto}.table-row .all-modules{justify-content:space-between;width:100%}.table-row .all-modules:before{content:attr(data-label);color:var(--text-muted);font-size:13px;font-weight:600}.user-form{grid-template-columns:1fr;gap:16px;padding:20px}.user-form .primary{width:100%}.password-editor{flex-direction:column;align-items:stretch;padding:20px}.password-editor input{max-width:100%}.module-config-button{width:100%;justify-content:flex-start}.row-actions{width:100%}.account-modal-layer{align-items:end;padding:12px}.account-modal{width:100%;max-height:calc(100vh - 24px);overflow-y:auto}.account-modal-actions{flex-direction:column-reverse}.account-modal-actions button,.account-modal-actions .primary{width:100%}.tree-row{padding:8px;gap:8px}.tree-children{margin-left:8px;padding-left:10px}}
